diff --git a/CHANGELOG.md b/CHANGELOG.md index d65c100a..9eba2565 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -9,6 +9,9 @@ Repository: **** ## Changelog +### **HEAD -> main** 2021/05/04 mandic00@live.com + + ### **1.8.2** 2021/05/04 mandic00@live.com diff --git a/demo/index.js b/demo/index.js index be7cbcd7..341356e1 100644 --- a/demo/index.js +++ b/demo/index.js @@ -9,17 +9,17 @@ import webRTC from './helpers/webrtc.js'; let human; const userConfig = { - warmup: 'none', + warmup: 'full', /* - backend: 'humangl', - async: false, - profile: false, - videoOptimized: true, + backend: 'webgl', + async: true, + + videoOptimized: false, filter: { enabled: false, flip: false, }, - face: { enabled: true, + face: { enabled: false, detector: { return: false }, mesh: { enabled: true }, iris: { enabled: true }, @@ -28,7 +28,7 @@ const userConfig = { }, hand: { enabled: false }, gesture: { enabled: false }, - body: { enabled: false, modelPath: 'posenet.json' }, + body: { enabled: true, modelPath: 'posenet.json' }, // body: { enabled: true, modelPath: 'blazepose.json' }, // object: { enabled: true }, */ @@ -58,7 +58,7 @@ const ui = { detectFPS: [], // internal, holds fps values for detection performance drawFPS: [], // internal, holds fps values for draw performance buffered: true, // should output be buffered between frames - drawWarmup: false, // debug only, should warmup image processing be displayed on startup + drawWarmup: true, // debug only, should warmup image processing be displayed on startup drawThread: null, // internl, perform draw operations in a separate thread detectThread: null, // internl, perform detect operations in a separate thread framesDraw: 0, // internal, statistics on frames drawn diff --git a/dist/human.esm-nobundle.js b/dist/human.esm-nobundle.js index 08a6b040..2f3f1609 100644 --- a/dist/human.esm-nobundle.js +++ b/dist/human.esm-nobundle.js @@ -5,14 +5,14 @@ author: ' */ -var F5=Object.defineProperty;var YA=Object.prototype.hasOwnProperty,JA=Object.getOwnPropertyNames,KA=Object.getOwnPropertyDescriptor;var Y=(A,e)=>{for(var n in e)F5(A,n,{get:e[n],enumerable:!0})},f=(A,e,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of JA(e))!YA.call(A,s)&&s!=="default"&&F5(A,s,{get:()=>e[s],enumerable:!(n=KA(e,s))||n.enumerable});return A};var q5=(A,e,n)=>{if(!e.has(A))throw TypeError("Cannot "+n)};var B=(A,e,n)=>(q5(A,e,"read from private field"),n?n.call(A):e.get(A)),e0=(A,e,n,s)=>(q5(A,e,"write to private field"),s?s.call(A,n):e.set(A,n),n);function L(A,e){let n=A.endsWith("/")?"":"/",o=e.startsWith(".")||e.startsWith("/")||e.startsWith("http:")||e.startsWith("https:")||e.startsWith("file:")?`${e}`:`${A}${n}${e}`;if(!o.toLocaleLowerCase().includes(".json"))throw new Error(`Human: ModelPath Error: ${o} Expecting JSON file`);return o}function b(...A){let e=new Date,n=`${e.getHours().toString().padStart(2,"0")}:${e.getMinutes().toString().padStart(2,"0")}:${e.getSeconds().toString().padStart(2,"0")}.${e.getMilliseconds().toString().padStart(3,"0")}`;A&&console.log(n,"Human:",...A)}var S=()=>typeof performance!="undefined"?performance.now():parseInt((Number(process.hrtime.bigint())/1e3/1e3).toString());function F(...A){let e=n=>n&&typeof n=="object";return A.reduce((n,s)=>(Object.keys(s||{}).forEach(o=>{let i=n[o],t=s[o];Array.isArray(i)&&Array.isArray(t)?n[o]=i.concat(...t):e(i)&&e(t)?n[o]=F(i,t):n[o]=t}),n),{})}function B5(){let A,e;if(typeof navigator!="undefined"){let n=navigator.userAgent.match(/\(([^()]+)\)/g);if(n&&n[0]){let s=n[0].match(/\(([^()]+)\)/g);A=s?s[0].replace(/\(|\)/g,""):"",e=navigator.userAgent.replace(n[0],""),A[1]&&(e=e.replace(n[1],"")),e=e.replace(/ /g," ")}}else typeof process!="undefined"&&(A=`${process.platform} ${process.arch}`,e=`NodeJS ${process.version}`);return{platform:A,agent:e}}var r={};Y(r,{data:()=>_A,version:()=>$A});f(r,I2);f(r,k2);f(r,O2);f(r,L2);f(r,Z2);f(r,V2);import*as C5 from"@tensorflow/tfjs/package.json";import*as U5 from"@tensorflow/tfjs-core/package.json";import*as Y5 from"@tensorflow/tfjs-data/package.json";import*as J5 from"@tensorflow/tfjs-layers/package.json";import*as K5 from"@tensorflow/tfjs-converter/package.json";import{version_cpu as DA}from"@tensorflow/tfjs-backend-cpu/dist/index.js";import{version_webgl as GA}from"@tensorflow/tfjs-backend-webgl/dist/index.js";import{version_wasm as QA}from"@tensorflow/tfjs-backend-wasm/dist/index.js";import*as I2 from"@tensorflow/tfjs-core/dist/index.js";import*as k2 from"@tensorflow/tfjs-layers/dist/index.js";import*as O2 from"@tensorflow/tfjs-converter/dist/index.js";import*as _A from"@tensorflow/tfjs-data/dist/index.js";import*as L2 from"@tensorflow/tfjs-backend-cpu/dist/index.js";import*as Z2 from"@tensorflow/tfjs-backend-webgl/dist/index.js";import*as V2 from"@tensorflow/tfjs-backend-wasm/dist/index.js";var $A={tfjs:(C5==null?void 0:C5.version)||void 0,"tfjs-core":(U5==null?void 0:U5.version)||void 0,"tfjs-data":(Y5==null?void 0:Y5.version)||void 0,"tfjs-layers":(J5==null?void 0:J5.version)||void 0,"tfjs-converter":(K5==null?void 0:K5.version)||void 0,"tfjs-backend-cpu":DA||void 0,"tfjs-backend-webgl":GA||void 0,"tfjs-backend-wasm":QA||void 0};var X={name:"humangl",priority:99,canvas:null,gl:null,width:1024,height:1024,webGLattr:{alpha:!1,antialias:!1,premultipliedAlpha:!1,preserveDrawingBuffer:!1,depth:!1,stencil:!1,failIfMajorPerformanceCaveat:!1,desynchronized:!0}};function D5(){if(!r.findBackend(X.name)){b("backend registration:",X.name);try{X.canvas=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(X.width,X.height):document.createElement("canvas")}catch(A){b("error: cannot create canvas:",A);return}try{X.gl=X.canvas.getContext("webgl2",X.webGLattr)}catch(A){b("error: cannot get WebGL2 context:",A);return}try{r.setWebGLContext(2,X.gl)}catch(A){b("error: cannot set WebGL2 context:",A);return}try{let A=new r.GPGPUContext(X.gl);r.registerBackend(X.name,()=>new r.MathBackendWebGL(A),X.priority)}catch(A){b("error: cannot register WebGL backend:",A);return}try{r.getKernelsForBackend("webgl").forEach(e=>{let n={...e,backendName:X.name};r.registerKernel(n)})}catch(A){b("error: cannot update WebGL backend registration:",A);return}try{r.ENV.set("WEBGL_VERSION",2)}catch(A){b("error: cannot set WebGL backend flags:",A);return}b("backend registered:",X.name)}}var A5={};Y(A5,{load:()=>n5,predict:()=>t5,triangulation:()=>rA,uvmap:()=>aA});function G5(A,e){let n=[A.startPoint[0]*e[0],A.startPoint[1]*e[1]],s=[A.endPoint[0]*e[0],A.endPoint[1]*e[1]];return{startPoint:n,endPoint:s}}function l0(A){return[Math.abs(A.endPoint[0]-A.startPoint[0]),Math.abs(A.endPoint[1]-A.startPoint[1])]}function i0(A){return[A.startPoint[0]+(A.endPoint[0]-A.startPoint[0])/2,A.startPoint[1]+(A.endPoint[1]-A.startPoint[1])/2]}function r0(A,e,n){let s=e.shape[1],o=e.shape[2],i=[[A.startPoint[1]/s,A.startPoint[0]/o,A.endPoint[1]/s,A.endPoint[0]/o]];return r.image.cropAndResize(e,i,[0],n)}function T0(A,e=1.5){let n=i0(A),s=l0(A),o=[e*s[0]/2,e*s[1]/2],i=[n[0]-o[0],n[1]-o[1]],t=[n[0]+o[0],n[1]+o[1]];return{startPoint:i,endPoint:t,landmarks:A.landmarks}}function P0(A){let e=i0(A),n=l0(A),o=Math.max(...n)/2,i=[Math.round(e[0]-o),Math.round(e[1]-o)],t=[Math.round(e[0]+o),Math.round(e[1]+o)];return{startPoint:i,endPoint:t,landmarks:A.landmarks}}function K0(A){let e=A.map(i=>i[0]),n=A.map(i=>i[1]),s=[Math.min(...e),Math.min(...n)],o=[Math.max(...e),Math.max(...n)];return{startPoint:s,endPoint:o,landmarks:A}}var Q5=A=>({startPoint:r.slice(A,[0,0],[-1,2]),endPoint:r.slice(A,[0,2],[-1,2])});var M0=[[1,0,0],[0,1,0],[0,0,1]];function A2(A){return A-2*Math.PI*Math.floor((A+Math.PI)/(2*Math.PI))}function D0(A,e){let n=Math.PI/2-Math.atan2(-(e[1]-A[1]),e[0]-A[0]);return A2(n)}function _5(A,e){return[[1,0,A],[0,1,e],[0,0,1]]}function D(A,e){let n=0;for(let s=0;s{let l=e.resizeBilinear([this.inputSize,this.inputSize]).div(127.5).sub(.5),d=this.model.execute(l),y;if(Array.isArray(d)){let c=d.sort((R,j)=>R.size-j.size),h=r.concat([c[0],c[2]],2),M=r.concat([c[1],c[3]],2);y=r.concat([M,h],1).squeeze(0)}else y=d.squeeze();let u=t2(y,this.anchors,[this.inputSize,this.inputSize]),p=r.slice(y,[0,0],[-1,1]),E=r.sigmoid(p).squeeze().dataSync();return[y,u,E]}),i=await r.image.nonMaxSuppressionAsync(s,o,this.config.face.detector.maxDetected,this.config.face.detector.iouThreshold,this.config.face.detector.minConfidence),t=i.arraySync();i.dispose();let a=[];for(let x=0;xthis.config.face.detector.minConfidence){let d=r.slice(s,[t[x],0],[1,-1]),y=Q5(d);d.dispose();let u=this.anchorsData[t[x]],p=r.tidy(()=>r.slice(n,[t[x],nA-1],[1,-1]).squeeze().reshape([nA,-1]));a.push({box:y,landmarks:p,anchor:u,confidence:l})}}return n.dispose(),s.dispose(),{boxes:a,scaleFactor:[e.shape[2]/this.inputSize,e.shape[1]/this.inputSize]}}};async function sA(A){let e=await r.loadGraphModel(L(A.modelBasePath,A.face.detector.modelPath),{fromTFHub:A.face.detector.modelPath.includes("tfhub.dev")}),n=new oA(e,A);return!e||!e.modelUrl?b("load model failed:",A.face.detector.modelPath):A.debug&&b("load model:",e.modelUrl),n}var J={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]},G0=[{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]}],c0=[[.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]],t0=[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 n2=[127,234,132,58,172,150,149,148,152,377,378,379,397,288,361,454,356,70,63,105,66,107,336,296,334,293,300,168,6,195,4,98,97,2,326,327,33,160,158,133,153,144,362,385,387,263,373,380,57,40,37,0,267,270,287,321,314,17,84,91,78,81,13,311,308,402,14,178],o2=[33,133,362,263,1,62,308,159,145,386,374,6,102,331,2,13,14,70,105,107,336,334,300,54,10,284,50,280,234,454,58,288,152],s2=[33,133,362,263,1,78,308],Q2=n2.map(A=>c0[A]),_2=o2.map(A=>c0[A]),$2=s2.map(A=>c0[A]);var Q0=J.leftEyeLower0,_0=J.rightEyeLower0,a0={leftBounds:[Q0[0],Q0[Q0.length-1]],rightBounds:[_0[0],_0[_0.length-1]]},v0={count:468,mouth:13,symmetryLine:[13,J.midwayBetweenEyes[0]]},iA={leftEye:0,rightEye:1,nose:2,mouth:3,leftEar:4,rightEar:5,symmetryLine:[3,2]},x0={upperCenter:3,lowerCenter:4,index:71,numCoordinates:76};function E0(A,e,n,s){for(let o=0;o[i[0]/this.meshSize*(y[0]-this.meshSize/2),i[1]/this.meshSize*(y[1]-this.meshSize/2),y[2]]),a=s!==0?z0(s,[0,0]):M0,x=s!==0?t.map(y=>[...eA(y,a),y[2]]):t,l=s!==0?AA(o):M0,d=[...i0({startPoint:n.startPoint,endPoint:n.endPoint}),1];return x.map(y=>[Math.round(y[0]+D(d,l[0])),Math.round(y[1]+D(d,l[1])),Math.round(y[2])])}getLeftToRightEyeDepthDifference(e){let n=e[a0.leftBounds[0]][2],s=e[a0.rightBounds[0]][2];return n-s}getEyeBox(e,n,s,o,i=!1){let t=P0(T0(K0([e[s],e[o]]),this.irisEnlarge)),a=l0(t),x=r.image.cropAndResize(n,[[t.startPoint[1]/this.meshSize,t.startPoint[0]/this.meshSize,t.endPoint[1]/this.meshSize,t.endPoint[0]/this.meshSize]],[0],[this.irisSize,this.irisSize]);return i&&r.ENV.flags.IS_BROWSER&&(x=r.image.flipLeftRight(x)),{box:t,boxSize:a,crop:x}}getEyeCoords(e,n,s,o=!1){let i=[];for(let t=0;t{let l=t;return x===2?l=o:x===4&&(l=i),[a[0],a[1],l]})}async predict(e,n){let s=!1,o;if((this.skipped===0||this.skipped>n.face.detector.skipFrames||!n.face.mesh.enabled||!n.videoOptimized)&&(o=await this.boundingBoxDetector.getBoundingBoxes(e),this.skipped=0),n.videoOptimized&&this.skipped++,!n.videoOptimized||o&&o.boxes&&(!n.face.mesh.enabled||o.boxes.length!==this.detectedFaces&&this.detectedFaces!==n.face.detector.maxDetected)){this.storedBoxes=[],this.detectedFaces=0;for(let t of o.boxes)this.storedBoxes.push({startPoint:t.box.startPoint.dataSync(),endPoint:t.box.endPoint.dataSync(),landmarks:t.landmarks,confidence:t.confidence});this.storedBoxes.length>0&&(s=!0)}if(n.face.detector.skipInitial&&this.detectedFaces===0&&(this.skipped=0),s){if(!o||!o.boxes||o.boxes.length===0)return this.storedBoxes=[],this.detectedFaces=0,null;for(let t=0;t{t.box.startPoint.dispose(),t.box.endPoint.dispose(),t.landmarks.dispose()});let i=r.tidy(()=>this.storedBoxes.map((t,a)=>{let x,l=0,d;if(n.face.detector.rotation&&n.face.mesh.enabled&&r.ENV.flags.IS_BROWSER){let[j,g]=t.landmarks.length>=v0.count?v0.symmetryLine:iA.symmetryLine;l=D0(t.landmarks[j],t.landmarks[g]);let m=i0({startPoint:t.startPoint,endPoint:t.endPoint}),T=[m[0]/e.shape[2],m[1]/e.shape[1]],v=r.image.rotateWithOffset(e,l,0,T);d=z0(-l,m),n.face.mesh.enabled?x=r0({startPoint:t.startPoint,endPoint:t.endPoint},v,[this.meshSize,this.meshSize]).div(255):x=r0({startPoint:t.startPoint,endPoint:t.endPoint},v,[this.boxSize,this.boxSize]).div(255)}else{d=M0;let j=e.clone();n.face.mesh.enabled?x=r0({startPoint:t.startPoint,endPoint:t.endPoint},j,[this.meshSize,this.meshSize]).div(255):x=r0({startPoint:t.startPoint,endPoint:t.endPoint},j,[this.boxSize,this.boxSize]).div(255)}if(!n.face.mesh.enabled)return{mesh:[],box:t,faceConfidence:null,boxConfidence:t.confidence,confidence:t.confidence,image:x};let[,y,u]=this.meshDetector.execute(x),p=y.dataSync()[0];if(p=v0.count?v0.symmetryLine:iA.symmetryLine;l=D0(t.landmarks[j],t.landmarks[g]);let m=i0({startPoint:t.startPoint,endPoint:t.endPoint}),T=[m[0]/e.shape[2],m[1]/e.shape[1]],v=r.image.rotateWithOffset(e.toFloat(),l,0,T);d=z0(-l,m),x=r0({startPoint:t.startPoint,endPoint:t.endPoint},v,[this.meshSize,this.meshSize]).div(255)}let z={mesh:h,box:t,faceConfidence:p,boxConfidence:t.confidence,image:x},R=P0(t);return R.confidence=t.confidence,R.faceConfidence=p,this.storedBoxes[a]=R,z}));return n.face.mesh.enabled&&(this.storedBoxes=this.storedBoxes.filter(t=>t.confidence>n.face.detector.minConfidence)),this.detectedFaces=i.length,i}};var k=[null,null,null],e5;async function t5(A,e){let n=await e5.predict(A,e),s=[];for(let o of n||[]){if(!o||o.isDisposedInternal)continue;let i=o.mesh.map(l=>[l[0]/A.shape[2],l[1]/A.shape[1],l[2]/e5.meshSize]),t={};if(o.mesh&&o.mesh.length>0)for(let l of Object.keys(J))t[l]=J[l].map(d=>o.mesh[d]);let a=o.box?[Math.max(0,o.box.startPoint[0]),Math.max(0,o.box.startPoint[1]),Math.min(A.shape[2],o.box.endPoint[0])-Math.max(0,o.box.startPoint[0]),Math.min(A.shape[1],o.box.endPoint[1])-Math.max(0,o.box.startPoint[1])]:0,x=o.box?[o.box.startPoint[0]/A.shape[2],o.box.startPoint[1]/A.shape[1],(o.box.endPoint[0]-o.box.startPoint[0])/A.shape[2],(o.box.endPoint[1]-o.box.startPoint[1])/A.shape[1]]:[];s.push({confidence:Math.round(100*o.faceConfidence||100*o.boxConfidence||0)/100,boxConfidence:Math.round(100*o.boxConfidence)/100,faceConfidence:Math.round(100*o.faceConfidence)/100,box:a,boxRaw:x,mesh:o.mesh,meshRaw:i,annotations:t,image:o.image}),o.coords&&o.coords.dispose()}return s}async function n5(A){return!k[0]&&A.face.enabled||!k[1]&&A.face.mesh.enabled||!k[2]&&A.face.iris.enabled?(k=await Promise.all([!k[0]&&A.face.enabled?sA(A):null,!k[1]&&A.face.mesh.enabled?r.loadGraphModel(L(A.modelBasePath,A.face.mesh.modelPath),{fromTFHub:A.face.mesh.modelPath.includes("tfhub.dev")}):null,!k[2]&&A.face.iris.enabled?r.loadGraphModel(L(A.modelBasePath,A.face.iris.modelPath),{fromTFHub:A.face.iris.modelPath.includes("tfhub.dev")}):null]),A.face.mesh.enabled&&(!k[1]||!k[1].modelUrl?b("load model failed:",A.face.mesh.modelPath):A.debug&&b("load model:",k[1].modelUrl)),A.face.iris.enabled&&(!k[2]||!k[1].modelUrl?b("load model failed:",A.face.iris.modelPath):A.debug&&b("load model:",k[2].modelUrl))):A.debug&&(b("cached model:",k[0].model.modelUrl),b("cached model:",k[1].modelUrl),b("cached model:",k[2].modelUrl)),e5=new $0(k[0],k[1],k[2]),k}var rA=t0,aA=c0;var o5={};Y(o5,{load:()=>r5,predict:()=>j0});var i2=["angry","disgust","fear","happy","sad","surprise","neutral"],U,s5=[],R0=Number.MAX_SAFE_INTEGER,i5=[.2989,.587,.114];async function r5(A){return U?A.debug&&b("cached model:",U.modelUrl):(U=await r.loadGraphModel(L(A.modelBasePath,A.face.emotion.modelPath)),!U||!U.modelUrl?b("load model failed:",A.face.emotion.modelPath):A.debug&&b("load model:",U.modelUrl)),U}async function j0(A,e){return U?R00?(R0++,s5):(e.videoOptimized?R0=0:R0=Number.MAX_SAFE_INTEGER,new Promise(async n=>{let s=r.image.resizeBilinear(A,[U.inputs[0].shape[2],U.inputs[0].shape[1]],!1),[o,i,t]=r.split(s,3,3);s.dispose();let a=r.mul(o,i5[0]),x=r.mul(i,i5[1]),l=r.mul(t,i5[2]);o.dispose(),i.dispose(),t.dispose();let d=r.addN([a,x,l]);a.dispose(),x.dispose(),l.dispose();let y=r.tidy(()=>d.sub(.5).mul(2));d.dispose();let u=[];if(e.face.emotion.enabled){let p=await U.predict(y),E=p.dataSync();r.dispose(p);for(let c=0;ce.face.emotion.minConfidence&&u.push({score:Math.min(.99,Math.trunc(100*E[c])/100),emotion:i2[c]});u.sort((c,h)=>h.score-c.score)}y.dispose(),s5=u,n(u)})):null}var a5={};Y(a5,{enhance:()=>l5,load:()=>x5,match:()=>xA,predict:()=>W0,similarity:()=>y5});var q,S0={age:0},w0=Number.MAX_SAFE_INTEGER;async function x5(A){return q?A.debug&&b("cached model:",q.modelUrl):(q=await r.loadGraphModel(L(A.modelBasePath,A.face.description.modelPath)),!q||!q.modelUrl?b("load model failed:",A.face.description.modelPath):A.debug&&b("load model:",q.modelUrl)),q}function y5(A,e,n=2){if(!A||!e||(A==null?void 0:A.length)===0||(e==null?void 0:e.length)===0||(A==null?void 0:A.length)!==(e==null?void 0:e.length))return 0;let s=5*A.map((i,t)=>Math.abs(A[t]-e[t])**n).reduce((i,t)=>i+t,0)**(1/n);return Math.max(0,100-s)/100}function xA(A,e,n=0){let s={similarity:0,name:"",source:"",embedding:[]};if(!A||!e||!Array.isArray(A)||!Array.isArray(e))return s;for(let o of e)if(o.embedding&&o.name){let i=y5(A,o.embedding);i>n&&i>s.similarity&&(s={...o,similarity:i})}return s}function l5(A){return r.tidy(()=>{let n=A.image||A.tensor||A;if(!(n instanceof r.Tensor))return null;let s=[[.05,.15,.85,.85]];return(n.shape.length===3?r.image.cropAndResize(r.expandDims(n,0),s,[0],[q.inputs[0].shape[2],q.inputs[0].shape[1]]):r.image.cropAndResize(n,s,[0],[q.inputs[0].shape[2],q.inputs[0].shape[1]])).mul(255)})}async function W0(A,e){return q?w00?(w0++,S0):(e.videoOptimized?w0=0:w0=Number.MAX_SAFE_INTEGER,new Promise(async n=>{let s=l5(A),o,i={age:0,gender:"unknown",genderConfidence:0,descriptor:[]};e.face.description.enabled&&(o=await q.predict(s)),r.dispose(s),o&&(r.tidy(()=>{let t=o.find(y=>y.shape[1]===1).dataSync(),a=Math.trunc(200*Math.abs(t[0]-.5))/100;a>e.face.description.minConfidence&&(i.gender=t[0]<=.5?"female":"male",i.genderConfidence=Math.min(.99,a));let x=o.find(y=>y.shape[1]===100).argMax(1).dataSync()[0],l=o.find(y=>y.shape[1]===100).dataSync();i.age=Math.round(l[x-1]>l[x+1]?10*x-100*l[x-1]:10*x+100*l[x+1])/10;let d=o.find(y=>y.shape[1]===1024);i.descriptor=[...d.dataSync()]}),o.forEach(t=>r.dispose(t))),S0=i,n(i)})):null}var r2=(A,e)=>{let n=h=>h*180/Math.PI,s=h=>{let M=Math.sqrt(h[0]*h[0]+h[1]*h[1]+h[2]*h[2]);return h[0]/=M,h[1]/=M,h[2]/=M,h},o=(h,M)=>{let z=h[0]-M[0],R=h[1]-M[1],j=h[2]-M[2];return[z,R,j]},i=(h,M)=>{let z=h[1]*M[2]-h[2]*M[1],R=h[2]*M[0]-h[0]*M[2],j=h[0]*M[1]-h[1]*M[0];return[z,R,j]},t=h=>{let[M,z,R,j,g,m,T,v,W]=h,O,K,H;return j<1?j>-1?(H=Math.asin(j),K=Math.atan2(-T,M),O=Math.atan2(-m,g)):(H=-Math.PI/2,K=-Math.atan2(v,W),O=0):(H=Math.PI/2,K=Math.atan2(v,W),O=0),{pitch:2*-O,yaw:2*-K,roll:2*-H}},a=h=>{let M=(R,j,g,m)=>Math.atan2(m-j,g-R);return{pitch:M(h[10][1],h[10][2],h[152][1],h[152][2]),yaw:M(h[33][0],h[33][2],h[263][0],h[263][2]),roll:M(h[33][0],h[33][1],h[263][0],h[263][1])}},x=A.meshRaw;if(!x||x.length<300)return{angle:{pitch:0,yaw:0,roll:0},matrix:[1,0,0,0,1,0,0,0,1]};let l=Math.max(A.boxRaw[2]*e[0],A.boxRaw[3]*e[1])/1.5,d=[x[10],x[152],x[234],x[454]].map(h=>[h[0]*e[0]/l,h[1]*e[1]/l,h[2]]),y=s(o(d[1],d[0])),u=s(o(d[3],d[2])),p=s(i(u,y));u=i(y,p);let E=[u[0],u[1],u[2],y[0],y[1],y[2],p[0],p[1],p[2]];return{angle:t(E),matrix:E}},c5=async(A,e)=>{var d,y,u,p,E,c;let n,s,o,i,t,a,x=[];A.state="run:face",n=S();let l=await t5(e,A.config);if(A.perf.face=Math.trunc(S()-n),!l)return[];for(let h of l){if(A.analyze("Get Face"),!h.image||h.image.isDisposedInternal){b("Face object is disposed:",h.image);continue}let M=r2(h,[e.shape[2],e.shape[1]]);A.analyze("Start Emotion:"),A.config.async?i=A.config.face.emotion.enabled?j0(h.image,A.config):{}:(A.state="run:emotion",n=S(),i=A.config.face.emotion.enabled?await j0(h.image,A.config):{},A.perf.emotion=Math.trunc(S()-n)),A.analyze("End Emotion:"),A.analyze("Start Description:"),A.config.async?a=A.config.face.description.enabled?W0(h,A.config):[]:(A.state="run:description",n=S(),a=A.config.face.description.enabled?await W0(h.image,A.config):[],A.perf.embedding=Math.trunc(S()-n)),A.analyze("End Description:"),A.config.async&&([s,o,i,t,a]=await Promise.all([s,o,i,t,a])),A.analyze("Finish Face:"),!A.config.face.iris.enabled&&((d=h==null?void 0:h.annotations)==null?void 0:d.leftEyeIris)&&((y=h==null?void 0:h.annotations)==null?void 0:y.rightEyeIris)&&(delete h.annotations.leftEyeIris,delete h.annotations.rightEyeIris);let z=((u=h.annotations)==null?void 0:u.leftEyeIris)&&((p=h.annotations)==null?void 0:p.rightEyeIris)?11.7*Math.max(Math.abs(h.annotations.leftEyeIris[3][0]-h.annotations.leftEyeIris[1][0]),Math.abs(h.annotations.rightEyeIris[4][1]-h.annotations.rightEyeIris[2][1])):0;x.push({...h,age:a.age,gender:a.gender,genderConfidence:a.genderConfidence,embedding:a.descriptor,emotion:i,iris:z!==0?Math.trunc(z)/100:0,rotation:M,tensor:A.config.face.detector.return?(E=h.image)==null?void 0:E.squeeze():null}),(c=h.image)==null||c.dispose(),A.analyze("End Face")}return A.analyze("End FaceMesh:"),A.config.async&&(A.perf.face&&delete A.perf.face,A.perf.age&&delete A.perf.age,A.perf.gender&&delete A.perf.gender,A.perf.emotion&&delete A.perf.emotion),x};var p5={};Y(p5,{load:()=>g5,predict:()=>b5});var d0=["nose","leftEye","rightEye","leftEar","rightEar","leftShoulder","rightShoulder","leftElbow","rightElbow","leftWrist","rightWrist","leftHip","rightHip","leftKnee","rightKnee","leftAnkle","rightAnkle"],yA=d0.length,f0=d0.reduce((A,e,n)=>(A[e]=n,A),{}),a2=[["leftHip","leftShoulder"],["leftElbow","leftShoulder"],["leftElbow","leftWrist"],["leftHip","leftKnee"],["leftKnee","leftAnkle"],["rightHip","rightShoulder"],["rightElbow","rightShoulder"],["rightElbow","rightWrist"],["rightHip","rightKnee"],["rightKnee","rightAnkle"],["leftShoulder","rightShoulder"],["leftHip","rightHip"]],x2=a2.map(([A,e])=>[f0[A],f0[e]]),lA=[["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"]];function cA(A){let e=A.reduce(({maxX:n,maxY:s,minX:o,minY:i},{position:{x:t,y:a}})=>({maxX:Math.max(n,t),maxY:Math.max(s,a),minX:Math.min(o,t),minY:Math.min(i,a)}),{maxX:Number.NEGATIVE_INFINITY,maxY:Number.NEGATIVE_INFINITY,minX:Number.POSITIVE_INFINITY,minY:Number.POSITIVE_INFINITY});return[e.minX,e.minY,e.maxX-e.minX,e.maxY-e.minY]}function dA(A,[e,n],[s,o]){let i=(a,x,l)=>({score:a.score,box:[Math.trunc(a.box[0]*l),Math.trunc(a.box[1]*x),Math.trunc(a.box[2]*l),Math.trunc(a.box[3]*x)],keypoints:a.keypoints.map(({score:d,part:y,position:u})=>({score:d,part:y,position:{x:Math.trunc(u.x*l),y:Math.trunc(u.y*x)}}))});return A.map(a=>i(a,e/s,n/o))}var d5=class{constructor(e,n){this.priorityQueue=new Array(e),this.numberOfElements=-1,this.getElementValue=n}enqueue(e){this.priorityQueue[++this.numberOfElements]=e,this.swim(this.numberOfElements)}dequeue(){let 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(Math.floor(e/2),e);)this.exchange(e,Math.floor(e/2)),e=Math.floor(e/2)}sink(e){for(;2*e<=this.numberOfElements;){let n=2*e;if(nn?n:A}function fA(A,e,n,s){let o=n-A,i=s-e;return o*o+i*i}function u5(A,e){return{x:A.x+e.x,y:A.y+e.y}}var N0=1,mA=16,y2=20**2;function hA(A,e,n,s,o,i,t,a=2){let x=z=>({y:t.get(z.y,z.x,A),x:t.get(z.y,z.x,t.shape[2]/2+A)}),l=(z,R,j)=>({y:h5(Math.round(z.y/i),0,R-1),x:h5(Math.round(z.x/i),0,j-1)}),[d,y]=s.shape,u=l(e.position,d,y),p=x(u),c=u5(e.position,p);for(let z=0;z[f0[c],f0[h]]),a=t.map(([,c])=>c),x=t.map(([c])=>c),l=e.shape[2],d=a.length,y=new Array(l),{part:u,score:p}=A,E=m5(u,s,n);y[u.id]={score:p,part:d0[u.id],position:E};for(let c=d-1;c>=0;--c){let h=a[c],M=x[c];y[h]&&!y[M]&&(y[M]=hA(c,y[h],M,e,n,s,i))}for(let c=0;ce){a=!1;break}if(!a)break}return a}function d2(A,e){let[n,s,o]=e.shape,i=new d5(n*s*o,({score:t})=>t);for(let t=0;t{let i=o[s].position;return fA(n,e,i.y,i.x)<=y2})}function f2(A,e){return e.reduce((s,{position:o,score:i},t)=>(uA(A,o,t)||(s+=i),s),0)/e.length}function pA(A,e,n,s,o,i){let t=[],a=d2(i,e);for(;t.lengthE.score>i),u=f2(t,y),p=cA(y);u>i&&t.push({keypoints:y,box:p,score:Math.round(100*u)/100})}return t}var C,m2=["MobilenetV1/offset_2/BiasAdd","MobilenetV1/heatmap_2/BiasAdd","MobilenetV1/displacement_fwd_2/BiasAdd","MobilenetV1/displacement_bwd_2/BiasAdd"];async function b5(A,e){let n=r.tidy(()=>{let a=A.resizeBilinear([C.inputs[0].shape[2],C.inputs[0].shape[1]]).toFloat().div(127.5).sub(1),l=C.execute(a,m2).map(d=>d.squeeze([0]));return l[1]=l[1].sigmoid(),l}),s=await Promise.all(n.map(t=>t.buffer()));for(let t of n)t.dispose();let o=await pA(s[0],s[1],s[2],s[3],e.body.maxDetected,e.body.minConfidence);return dA(o,[A.shape[1],A.shape[2]],[C.inputs[0].shape[2],C.inputs[0].shape[1]])}async function g5(A){return C?A.debug&&b("cached model:",C.modelUrl):(C=await r.loadGraphModel(L(A.modelBasePath,A.body.modelPath)),!C||!C.modelUrl?b("load model failed:",A.body.modelPath):A.debug&&b("load model:",C.modelUrl)),C}var v5={};Y(v5,{load:()=>R5,predict:()=>E5});function I0(A){return[Math.abs(A.endPoint[0]-A.startPoint[0]),Math.abs(A.endPoint[1]-A.startPoint[1])]}function m0(A){return[A.startPoint[0]+(A.endPoint[0]-A.startPoint[0])/2,A.startPoint[1]+(A.endPoint[1]-A.startPoint[1])/2]}function bA(A,e,n){let s=e.shape[1],o=e.shape[2],i=[[A.startPoint[1]/s,A.startPoint[0]/o,A.endPoint[1]/s,A.endPoint[0]/o]];return r.image.cropAndResize(e,i,[0],n)}function gA(A,e){let n=[A.startPoint[0]*e[0],A.startPoint[1]*e[1]],s=[A.endPoint[0]*e[0],A.endPoint[1]*e[1]],o=A.palmLandmarks.map(i=>[i[0]*e[0],i[1]*e[1]]);return{startPoint:n,endPoint:s,palmLandmarks:o,confidence:A.confidence}}function k0(A,e=1.5){let n=m0(A),s=I0(A),o=[e*s[0]/2,e*s[1]/2],i=[n[0]-o[0],n[1]-o[1]],t=[n[0]+o[0],n[1]+o[1]];return{startPoint:i,endPoint:t,palmLandmarks:A.palmLandmarks}}function O0(A){let e=m0(A),n=I0(A),o=Math.max(...n)/2,i=[e[0]-o,e[1]-o],t=[e[0]+o,e[1]+o];return{startPoint:i,endPoint:t,palmLandmarks:A.palmLandmarks}}var TA=[{x:.015625,y:.015625},{x:.015625,y:.015625},{x:.046875,y:.015625},{x:.046875,y:.015625},{x:.078125,y:.015625},{x:.078125,y:.015625},{x:.109375,y:.015625},{x:.109375,y:.015625},{x:.140625,y:.015625},{x:.140625,y:.015625},{x:.171875,y:.015625},{x:.171875,y:.015625},{x:.203125,y:.015625},{x:.203125,y:.015625},{x:.234375,y:.015625},{x:.234375,y:.015625},{x:.265625,y:.015625},{x:.265625,y:.015625},{x:.296875,y:.015625},{x:.296875,y:.015625},{x:.328125,y:.015625},{x:.328125,y:.015625},{x:.359375,y:.015625},{x:.359375,y:.015625},{x:.390625,y:.015625},{x:.390625,y:.015625},{x:.421875,y:.015625},{x:.421875,y:.015625},{x:.453125,y:.015625},{x:.453125,y:.015625},{x:.484375,y:.015625},{x:.484375,y:.015625},{x:.515625,y:.015625},{x:.515625,y:.015625},{x:.546875,y:.015625},{x:.546875,y:.015625},{x:.578125,y:.015625},{x:.578125,y:.015625},{x:.609375,y:.015625},{x:.609375,y:.015625},{x:.640625,y:.015625},{x:.640625,y:.015625},{x:.671875,y:.015625},{x:.671875,y:.015625},{x:.703125,y:.015625},{x:.703125,y:.015625},{x:.734375,y:.015625},{x:.734375,y:.015625},{x:.765625,y:.015625},{x:.765625,y:.015625},{x:.796875,y:.015625},{x:.796875,y:.015625},{x:.828125,y:.015625},{x:.828125,y:.015625},{x:.859375,y:.015625},{x:.859375,y:.015625},{x:.890625,y:.015625},{x:.890625,y:.015625},{x:.921875,y:.015625},{x:.921875,y:.015625},{x:.953125,y:.015625},{x:.953125,y:.015625},{x:.984375,y:.015625},{x:.984375,y:.015625},{x:.015625,y:.046875},{x:.015625,y:.046875},{x:.046875,y:.046875},{x:.046875,y:.046875},{x:.078125,y:.046875},{x:.078125,y:.046875},{x:.109375,y:.046875},{x:.109375,y:.046875},{x:.140625,y:.046875},{x:.140625,y:.046875},{x:.171875,y:.046875},{x:.171875,y:.046875},{x:.203125,y:.046875},{x:.203125,y:.046875},{x:.234375,y:.046875},{x:.234375,y:.046875},{x:.265625,y:.046875},{x:.265625,y:.046875},{x:.296875,y:.046875},{x:.296875,y:.046875},{x:.328125,y:.046875},{x:.328125,y:.046875},{x:.359375,y:.046875},{x:.359375,y:.046875},{x:.390625,y:.046875},{x:.390625,y:.046875},{x:.421875,y:.046875},{x:.421875,y:.046875},{x:.453125,y:.046875},{x:.453125,y:.046875},{x:.484375,y:.046875},{x:.484375,y:.046875},{x:.515625,y:.046875},{x:.515625,y:.046875},{x:.546875,y:.046875},{x:.546875,y:.046875},{x:.578125,y:.046875},{x:.578125,y:.046875},{x:.609375,y:.046875},{x:.609375,y:.046875},{x:.640625,y:.046875},{x:.640625,y:.046875},{x:.671875,y:.046875},{x:.671875,y:.046875},{x:.703125,y:.046875},{x:.703125,y:.046875},{x:.734375,y:.046875},{x:.734375,y:.046875},{x:.765625,y:.046875},{x:.765625,y:.046875},{x:.796875,y:.046875},{x:.796875,y:.046875},{x:.828125,y:.046875},{x:.828125,y:.046875},{x:.859375,y:.046875},{x:.859375,y:.046875},{x:.890625,y:.046875},{x:.890625,y:.046875},{x:.921875,y:.046875},{x:.921875,y:.046875},{x:.953125,y:.046875},{x:.953125,y:.046875},{x:.984375,y:.046875},{x:.984375,y:.046875},{x:.015625,y:.078125},{x:.015625,y:.078125},{x:.046875,y:.078125},{x:.046875,y:.078125},{x:.078125,y:.078125},{x:.078125,y:.078125},{x:.109375,y:.078125},{x:.109375,y:.078125},{x:.140625,y:.078125},{x:.140625,y:.078125},{x:.171875,y:.078125},{x:.171875,y:.078125},{x:.203125,y:.078125},{x:.203125,y:.078125},{x:.234375,y:.078125},{x:.234375,y:.078125},{x:.265625,y:.078125},{x:.265625,y:.078125},{x:.296875,y:.078125},{x:.296875,y:.078125},{x:.328125,y:.078125},{x:.328125,y:.078125},{x:.359375,y:.078125},{x:.359375,y:.078125},{x:.390625,y:.078125},{x:.390625,y:.078125},{x:.421875,y:.078125},{x:.421875,y:.078125},{x:.453125,y:.078125},{x:.453125,y:.078125},{x:.484375,y:.078125},{x:.484375,y:.078125},{x:.515625,y:.078125},{x:.515625,y:.078125},{x:.546875,y:.078125},{x:.546875,y:.078125},{x:.578125,y:.078125},{x:.578125,y:.078125},{x:.609375,y:.078125},{x:.609375,y:.078125},{x:.640625,y:.078125},{x:.640625,y:.078125},{x:.671875,y:.078125},{x:.671875,y:.078125},{x:.703125,y:.078125},{x:.703125,y:.078125},{x:.734375,y:.078125},{x:.734375,y:.078125},{x:.765625,y:.078125},{x:.765625,y:.078125},{x:.796875,y:.078125},{x:.796875,y:.078125},{x:.828125,y:.078125},{x:.828125,y:.078125},{x:.859375,y:.078125},{x:.859375,y:.078125},{x:.890625,y:.078125},{x:.890625,y:.078125},{x:.921875,y:.078125},{x:.921875,y:.078125},{x:.953125,y:.078125},{x:.953125,y:.078125},{x:.984375,y:.078125},{x:.984375,y:.078125},{x:.015625,y:.109375},{x:.015625,y:.109375},{x:.046875,y:.109375},{x:.046875,y:.109375},{x:.078125,y:.109375},{x:.078125,y:.109375},{x:.109375,y:.109375},{x:.109375,y:.109375},{x:.140625,y:.109375},{x:.140625,y:.109375},{x:.171875,y:.109375},{x:.171875,y:.109375},{x:.203125,y:.109375},{x:.203125,y:.109375},{x:.234375,y:.109375},{x:.234375,y:.109375},{x:.265625,y:.109375},{x:.265625,y:.109375},{x:.296875,y:.109375},{x:.296875,y:.109375},{x:.328125,y:.109375},{x:.328125,y:.109375},{x:.359375,y:.109375},{x:.359375,y:.109375},{x:.390625,y:.109375},{x:.390625,y:.109375},{x:.421875,y:.109375},{x:.421875,y:.109375},{x:.453125,y:.109375},{x:.453125,y:.109375},{x:.484375,y:.109375},{x:.484375,y:.109375},{x:.515625,y:.109375},{x:.515625,y:.109375},{x:.546875,y:.109375},{x:.546875,y:.109375},{x:.578125,y:.109375},{x:.578125,y:.109375},{x:.609375,y:.109375},{x:.609375,y:.109375},{x:.640625,y:.109375},{x:.640625,y:.109375},{x:.671875,y:.109375},{x:.671875,y:.109375},{x:.703125,y:.109375},{x:.703125,y:.109375},{x:.734375,y:.109375},{x:.734375,y:.109375},{x:.765625,y:.109375},{x:.765625,y:.109375},{x:.796875,y:.109375},{x:.796875,y:.109375},{x:.828125,y:.109375},{x:.828125,y:.109375},{x:.859375,y:.109375},{x:.859375,y:.109375},{x:.890625,y:.109375},{x:.890625,y:.109375},{x:.921875,y:.109375},{x:.921875,y:.109375},{x:.953125,y:.109375},{x:.953125,y:.109375},{x:.984375,y:.109375},{x:.984375,y:.109375},{x:.015625,y:.140625},{x:.015625,y:.140625},{x:.046875,y:.140625},{x:.046875,y:.140625},{x:.078125,y:.140625},{x:.078125,y:.140625},{x:.109375,y:.140625},{x:.109375,y:.140625},{x:.140625,y:.140625},{x:.140625,y:.140625},{x:.171875,y:.140625},{x:.171875,y:.140625},{x:.203125,y:.140625},{x:.203125,y:.140625},{x:.234375,y:.140625},{x:.234375,y:.140625},{x:.265625,y:.140625},{x:.265625,y:.140625},{x:.296875,y:.140625},{x:.296875,y:.140625},{x:.328125,y:.140625},{x:.328125,y:.140625},{x:.359375,y:.140625},{x:.359375,y:.140625},{x:.390625,y:.140625},{x:.390625,y:.140625},{x:.421875,y:.140625},{x:.421875,y:.140625},{x:.453125,y:.140625},{x:.453125,y:.140625},{x:.484375,y:.140625},{x:.484375,y:.140625},{x:.515625,y:.140625},{x:.515625,y:.140625},{x:.546875,y:.140625},{x:.546875,y:.140625},{x:.578125,y:.140625},{x:.578125,y:.140625},{x:.609375,y:.140625},{x:.609375,y:.140625},{x:.640625,y:.140625},{x:.640625,y:.140625},{x:.671875,y:.140625},{x:.671875,y:.140625},{x:.703125,y:.140625},{x:.703125,y:.140625},{x:.734375,y:.140625},{x:.734375,y:.140625},{x:.765625,y:.140625},{x:.765625,y:.140625},{x:.796875,y:.140625},{x:.796875,y:.140625},{x:.828125,y:.140625},{x:.828125,y:.140625},{x:.859375,y:.140625},{x:.859375,y:.140625},{x:.890625,y:.140625},{x:.890625,y:.140625},{x:.921875,y:.140625},{x:.921875,y:.140625},{x:.953125,y:.140625},{x:.953125,y:.140625},{x:.984375,y:.140625},{x:.984375,y:.140625},{x:.015625,y:.171875},{x:.015625,y:.171875},{x:.046875,y:.171875},{x:.046875,y:.171875},{x:.078125,y:.171875},{x:.078125,y:.171875},{x:.109375,y:.171875},{x:.109375,y:.171875},{x:.140625,y:.171875},{x:.140625,y:.171875},{x:.171875,y:.171875},{x:.171875,y:.171875},{x:.203125,y:.171875},{x:.203125,y:.171875},{x:.234375,y:.171875},{x:.234375,y:.171875},{x:.265625,y:.171875},{x:.265625,y:.171875},{x:.296875,y:.171875},{x:.296875,y:.171875},{x:.328125,y:.171875},{x:.328125,y:.171875},{x:.359375,y:.171875},{x:.359375,y:.171875},{x:.390625,y:.171875},{x:.390625,y:.171875},{x:.421875,y:.171875},{x:.421875,y:.171875},{x:.453125,y:.171875},{x:.453125,y:.171875},{x:.484375,y:.171875},{x:.484375,y:.171875},{x:.515625,y:.171875},{x:.515625,y:.171875},{x:.546875,y:.171875},{x:.546875,y:.171875},{x:.578125,y:.171875},{x:.578125,y:.171875},{x:.609375,y:.171875},{x:.609375,y:.171875},{x:.640625,y:.171875},{x:.640625,y:.171875},{x:.671875,y:.171875},{x:.671875,y:.171875},{x:.703125,y:.171875},{x:.703125,y:.171875},{x:.734375,y:.171875},{x:.734375,y:.171875},{x:.765625,y:.171875},{x:.765625,y:.171875},{x:.796875,y:.171875},{x:.796875,y:.171875},{x:.828125,y:.171875},{x:.828125,y:.171875},{x:.859375,y:.171875},{x:.859375,y:.171875},{x:.890625,y:.171875},{x:.890625,y:.171875},{x:.921875,y:.171875},{x:.921875,y:.171875},{x:.953125,y:.171875},{x:.953125,y:.171875},{x:.984375,y:.171875},{x:.984375,y:.171875},{x:.015625,y:.203125},{x:.015625,y:.203125},{x:.046875,y:.203125},{x:.046875,y:.203125},{x:.078125,y:.203125},{x:.078125,y:.203125},{x:.109375,y:.203125},{x:.109375,y:.203125},{x:.140625,y:.203125},{x:.140625,y:.203125},{x:.171875,y:.203125},{x:.171875,y:.203125},{x:.203125,y:.203125},{x:.203125,y:.203125},{x:.234375,y:.203125},{x:.234375,y:.203125},{x:.265625,y:.203125},{x:.265625,y:.203125},{x:.296875,y:.203125},{x:.296875,y:.203125},{x:.328125,y:.203125},{x:.328125,y:.203125},{x:.359375,y:.203125},{x:.359375,y:.203125},{x:.390625,y:.203125},{x:.390625,y:.203125},{x:.421875,y:.203125},{x:.421875,y:.203125},{x:.453125,y:.203125},{x:.453125,y:.203125},{x:.484375,y:.203125},{x:.484375,y:.203125},{x:.515625,y:.203125},{x:.515625,y:.203125},{x:.546875,y:.203125},{x:.546875,y:.203125},{x:.578125,y:.203125},{x:.578125,y:.203125},{x:.609375,y:.203125},{x:.609375,y:.203125},{x:.640625,y:.203125},{x:.640625,y:.203125},{x:.671875,y:.203125},{x:.671875,y:.203125},{x:.703125,y:.203125},{x:.703125,y:.203125},{x:.734375,y:.203125},{x:.734375,y:.203125},{x:.765625,y:.203125},{x:.765625,y:.203125},{x:.796875,y:.203125},{x:.796875,y:.203125},{x:.828125,y:.203125},{x:.828125,y:.203125},{x:.859375,y:.203125},{x:.859375,y:.203125},{x:.890625,y:.203125},{x:.890625,y:.203125},{x:.921875,y:.203125},{x:.921875,y:.203125},{x:.953125,y:.203125},{x:.953125,y:.203125},{x:.984375,y:.203125},{x:.984375,y:.203125},{x:.015625,y:.234375},{x:.015625,y:.234375},{x:.046875,y:.234375},{x:.046875,y:.234375},{x:.078125,y:.234375},{x:.078125,y:.234375},{x:.109375,y:.234375},{x:.109375,y:.234375},{x:.140625,y:.234375},{x:.140625,y:.234375},{x:.171875,y:.234375},{x:.171875,y:.234375},{x:.203125,y:.234375},{x:.203125,y:.234375},{x:.234375,y:.234375},{x:.234375,y:.234375},{x:.265625,y:.234375},{x:.265625,y:.234375},{x:.296875,y:.234375},{x:.296875,y:.234375},{x:.328125,y:.234375},{x:.328125,y:.234375},{x:.359375,y:.234375},{x:.359375,y:.234375},{x:.390625,y:.234375},{x:.390625,y:.234375},{x:.421875,y:.234375},{x:.421875,y:.234375},{x:.453125,y:.234375},{x:.453125,y:.234375},{x:.484375,y:.234375},{x:.484375,y:.234375},{x:.515625,y:.234375},{x:.515625,y:.234375},{x:.546875,y:.234375},{x:.546875,y:.234375},{x:.578125,y:.234375},{x:.578125,y:.234375},{x:.609375,y:.234375},{x:.609375,y:.234375},{x:.640625,y:.234375},{x:.640625,y:.234375},{x:.671875,y:.234375},{x:.671875,y:.234375},{x:.703125,y:.234375},{x:.703125,y:.234375},{x:.734375,y:.234375},{x:.734375,y:.234375},{x:.765625,y:.234375},{x:.765625,y:.234375},{x:.796875,y:.234375},{x:.796875,y:.234375},{x:.828125,y:.234375},{x:.828125,y:.234375},{x:.859375,y:.234375},{x:.859375,y:.234375},{x:.890625,y:.234375},{x:.890625,y:.234375},{x:.921875,y:.234375},{x:.921875,y:.234375},{x:.953125,y:.234375},{x:.953125,y:.234375},{x:.984375,y:.234375},{x:.984375,y:.234375},{x:.015625,y:.265625},{x:.015625,y:.265625},{x:.046875,y:.265625},{x:.046875,y:.265625},{x:.078125,y:.265625},{x:.078125,y:.265625},{x:.109375,y:.265625},{x:.109375,y:.265625},{x:.140625,y:.265625},{x:.140625,y:.265625},{x:.171875,y:.265625},{x:.171875,y:.265625},{x:.203125,y:.265625},{x:.203125,y:.265625},{x:.234375,y:.265625},{x:.234375,y:.265625},{x:.265625,y:.265625},{x:.265625,y:.265625},{x:.296875,y:.265625},{x:.296875,y:.265625},{x:.328125,y:.265625},{x:.328125,y:.265625},{x:.359375,y:.265625},{x:.359375,y:.265625},{x:.390625,y:.265625},{x:.390625,y:.265625},{x:.421875,y:.265625},{x:.421875,y:.265625},{x:.453125,y:.265625},{x:.453125,y:.265625},{x:.484375,y:.265625},{x:.484375,y:.265625},{x:.515625,y:.265625},{x:.515625,y:.265625},{x:.546875,y:.265625},{x:.546875,y:.265625},{x:.578125,y:.265625},{x:.578125,y:.265625},{x:.609375,y:.265625},{x:.609375,y:.265625},{x:.640625,y:.265625},{x:.640625,y:.265625},{x:.671875,y:.265625},{x:.671875,y:.265625},{x:.703125,y:.265625},{x:.703125,y:.265625},{x:.734375,y:.265625},{x:.734375,y:.265625},{x:.765625,y:.265625},{x:.765625,y:.265625},{x:.796875,y:.265625},{x:.796875,y:.265625},{x:.828125,y:.265625},{x:.828125,y:.265625},{x:.859375,y:.265625},{x:.859375,y:.265625},{x:.890625,y:.265625},{x:.890625,y:.265625},{x:.921875,y:.265625},{x:.921875,y:.265625},{x:.953125,y:.265625},{x:.953125,y:.265625},{x:.984375,y:.265625},{x:.984375,y:.265625},{x:.015625,y:.296875},{x:.015625,y:.296875},{x:.046875,y:.296875},{x:.046875,y:.296875},{x:.078125,y:.296875},{x:.078125,y:.296875},{x:.109375,y:.296875},{x:.109375,y:.296875},{x:.140625,y:.296875},{x:.140625,y:.296875},{x:.171875,y:.296875},{x:.171875,y:.296875},{x:.203125,y:.296875},{x:.203125,y:.296875},{x:.234375,y:.296875},{x:.234375,y:.296875},{x:.265625,y:.296875},{x:.265625,y:.296875},{x:.296875,y:.296875},{x:.296875,y:.296875},{x:.328125,y:.296875},{x:.328125,y:.296875},{x:.359375,y:.296875},{x:.359375,y:.296875},{x:.390625,y:.296875},{x:.390625,y:.296875},{x:.421875,y:.296875},{x:.421875,y:.296875},{x:.453125,y:.296875},{x:.453125,y:.296875},{x:.484375,y:.296875},{x:.484375,y:.296875},{x:.515625,y:.296875},{x:.515625,y:.296875},{x:.546875,y:.296875},{x:.546875,y:.296875},{x:.578125,y:.296875},{x:.578125,y:.296875},{x:.609375,y:.296875},{x:.609375,y:.296875},{x:.640625,y:.296875},{x:.640625,y:.296875},{x:.671875,y:.296875},{x:.671875,y:.296875},{x:.703125,y:.296875},{x:.703125,y:.296875},{x:.734375,y:.296875},{x:.734375,y:.296875},{x:.765625,y:.296875},{x:.765625,y:.296875},{x:.796875,y:.296875},{x:.796875,y:.296875},{x:.828125,y:.296875},{x:.828125,y:.296875},{x:.859375,y:.296875},{x:.859375,y:.296875},{x:.890625,y:.296875},{x:.890625,y:.296875},{x:.921875,y:.296875},{x:.921875,y:.296875},{x:.953125,y:.296875},{x:.953125,y:.296875},{x:.984375,y:.296875},{x:.984375,y:.296875},{x:.015625,y:.328125},{x:.015625,y:.328125},{x:.046875,y:.328125},{x:.046875,y:.328125},{x:.078125,y:.328125},{x:.078125,y:.328125},{x:.109375,y:.328125},{x:.109375,y:.328125},{x:.140625,y:.328125},{x:.140625,y:.328125},{x:.171875,y:.328125},{x:.171875,y:.328125},{x:.203125,y:.328125},{x:.203125,y:.328125},{x:.234375,y:.328125},{x:.234375,y:.328125},{x:.265625,y:.328125},{x:.265625,y:.328125},{x:.296875,y:.328125},{x:.296875,y:.328125},{x:.328125,y:.328125},{x:.328125,y:.328125},{x:.359375,y:.328125},{x:.359375,y:.328125},{x:.390625,y:.328125},{x:.390625,y:.328125},{x:.421875,y:.328125},{x:.421875,y:.328125},{x:.453125,y:.328125},{x:.453125,y:.328125},{x:.484375,y:.328125},{x:.484375,y:.328125},{x:.515625,y:.328125},{x:.515625,y:.328125},{x:.546875,y:.328125},{x:.546875,y:.328125},{x:.578125,y:.328125},{x:.578125,y:.328125},{x:.609375,y:.328125},{x:.609375,y:.328125},{x:.640625,y:.328125},{x:.640625,y:.328125},{x:.671875,y:.328125},{x:.671875,y:.328125},{x:.703125,y:.328125},{x:.703125,y:.328125},{x:.734375,y:.328125},{x:.734375,y:.328125},{x:.765625,y:.328125},{x:.765625,y:.328125},{x:.796875,y:.328125},{x:.796875,y:.328125},{x:.828125,y:.328125},{x:.828125,y:.328125},{x:.859375,y:.328125},{x:.859375,y:.328125},{x:.890625,y:.328125},{x:.890625,y:.328125},{x:.921875,y:.328125},{x:.921875,y:.328125},{x:.953125,y:.328125},{x:.953125,y:.328125},{x:.984375,y:.328125},{x:.984375,y:.328125},{x:.015625,y:.359375},{x:.015625,y:.359375},{x:.046875,y:.359375},{x:.046875,y:.359375},{x:.078125,y:.359375},{x:.078125,y:.359375},{x:.109375,y:.359375},{x:.109375,y:.359375},{x:.140625,y:.359375},{x:.140625,y:.359375},{x:.171875,y:.359375},{x:.171875,y:.359375},{x:.203125,y:.359375},{x:.203125,y:.359375},{x:.234375,y:.359375},{x:.234375,y:.359375},{x:.265625,y:.359375},{x:.265625,y:.359375},{x:.296875,y:.359375},{x:.296875,y:.359375},{x:.328125,y:.359375},{x:.328125,y:.359375},{x:.359375,y:.359375},{x:.359375,y:.359375},{x:.390625,y:.359375},{x:.390625,y:.359375},{x:.421875,y:.359375},{x:.421875,y:.359375},{x:.453125,y:.359375},{x:.453125,y:.359375},{x:.484375,y:.359375},{x:.484375,y:.359375},{x:.515625,y:.359375},{x:.515625,y:.359375},{x:.546875,y:.359375},{x:.546875,y:.359375},{x:.578125,y:.359375},{x:.578125,y:.359375},{x:.609375,y:.359375},{x:.609375,y:.359375},{x:.640625,y:.359375},{x:.640625,y:.359375},{x:.671875,y:.359375},{x:.671875,y:.359375},{x:.703125,y:.359375},{x:.703125,y:.359375},{x:.734375,y:.359375},{x:.734375,y:.359375},{x:.765625,y:.359375},{x:.765625,y:.359375},{x:.796875,y:.359375},{x:.796875,y:.359375},{x:.828125,y:.359375},{x:.828125,y:.359375},{x:.859375,y:.359375},{x:.859375,y:.359375},{x:.890625,y:.359375},{x:.890625,y:.359375},{x:.921875,y:.359375},{x:.921875,y:.359375},{x:.953125,y:.359375},{x:.953125,y:.359375},{x:.984375,y:.359375},{x:.984375,y:.359375},{x:.015625,y:.390625},{x:.015625,y:.390625},{x:.046875,y:.390625},{x:.046875,y:.390625},{x:.078125,y:.390625},{x:.078125,y:.390625},{x:.109375,y:.390625},{x:.109375,y:.390625},{x:.140625,y:.390625},{x:.140625,y:.390625},{x:.171875,y:.390625},{x:.171875,y:.390625},{x:.203125,y:.390625},{x:.203125,y:.390625},{x:.234375,y:.390625},{x:.234375,y:.390625},{x:.265625,y:.390625},{x:.265625,y:.390625},{x:.296875,y:.390625},{x:.296875,y:.390625},{x:.328125,y:.390625},{x:.328125,y:.390625},{x:.359375,y:.390625},{x:.359375,y:.390625},{x:.390625,y:.390625},{x:.390625,y:.390625},{x:.421875,y:.390625},{x:.421875,y:.390625},{x:.453125,y:.390625},{x:.453125,y:.390625},{x:.484375,y:.390625},{x:.484375,y:.390625},{x:.515625,y:.390625},{x:.515625,y:.390625},{x:.546875,y:.390625},{x:.546875,y:.390625},{x:.578125,y:.390625},{x:.578125,y:.390625},{x:.609375,y:.390625},{x:.609375,y:.390625},{x:.640625,y:.390625},{x:.640625,y:.390625},{x:.671875,y:.390625},{x:.671875,y:.390625},{x:.703125,y:.390625},{x:.703125,y:.390625},{x:.734375,y:.390625},{x:.734375,y:.390625},{x:.765625,y:.390625},{x:.765625,y:.390625},{x:.796875,y:.390625},{x:.796875,y:.390625},{x:.828125,y:.390625},{x:.828125,y:.390625},{x:.859375,y:.390625},{x:.859375,y:.390625},{x:.890625,y:.390625},{x:.890625,y:.390625},{x:.921875,y:.390625},{x:.921875,y:.390625},{x:.953125,y:.390625},{x:.953125,y:.390625},{x:.984375,y:.390625},{x:.984375,y:.390625},{x:.015625,y:.421875},{x:.015625,y:.421875},{x:.046875,y:.421875},{x:.046875,y:.421875},{x:.078125,y:.421875},{x:.078125,y:.421875},{x:.109375,y:.421875},{x:.109375,y:.421875},{x:.140625,y:.421875},{x:.140625,y:.421875},{x:.171875,y:.421875},{x:.171875,y:.421875},{x:.203125,y:.421875},{x:.203125,y:.421875},{x:.234375,y:.421875},{x:.234375,y:.421875},{x:.265625,y:.421875},{x:.265625,y:.421875},{x:.296875,y:.421875},{x:.296875,y:.421875},{x:.328125,y:.421875},{x:.328125,y:.421875},{x:.359375,y:.421875},{x:.359375,y:.421875},{x:.390625,y:.421875},{x:.390625,y:.421875},{x:.421875,y:.421875},{x:.421875,y:.421875},{x:.453125,y:.421875},{x:.453125,y:.421875},{x:.484375,y:.421875},{x:.484375,y:.421875},{x:.515625,y:.421875},{x:.515625,y:.421875},{x:.546875,y:.421875},{x:.546875,y:.421875},{x:.578125,y:.421875},{x:.578125,y:.421875},{x:.609375,y:.421875},{x:.609375,y:.421875},{x:.640625,y:.421875},{x:.640625,y:.421875},{x:.671875,y:.421875},{x:.671875,y:.421875},{x:.703125,y:.421875},{x:.703125,y:.421875},{x:.734375,y:.421875},{x:.734375,y:.421875},{x:.765625,y:.421875},{x:.765625,y:.421875},{x:.796875,y:.421875},{x:.796875,y:.421875},{x:.828125,y:.421875},{x:.828125,y:.421875},{x:.859375,y:.421875},{x:.859375,y:.421875},{x:.890625,y:.421875},{x:.890625,y:.421875},{x:.921875,y:.421875},{x:.921875,y:.421875},{x:.953125,y:.421875},{x:.953125,y:.421875},{x:.984375,y:.421875},{x:.984375,y:.421875},{x:.015625,y:.453125},{x:.015625,y:.453125},{x:.046875,y:.453125},{x:.046875,y:.453125},{x:.078125,y:.453125},{x:.078125,y:.453125},{x:.109375,y:.453125},{x:.109375,y:.453125},{x:.140625,y:.453125},{x:.140625,y:.453125},{x:.171875,y:.453125},{x:.171875,y:.453125},{x:.203125,y:.453125},{x:.203125,y:.453125},{x:.234375,y:.453125},{x:.234375,y:.453125},{x:.265625,y:.453125},{x:.265625,y:.453125},{x:.296875,y:.453125},{x:.296875,y:.453125},{x:.328125,y:.453125},{x:.328125,y:.453125},{x:.359375,y:.453125},{x:.359375,y:.453125},{x:.390625,y:.453125},{x:.390625,y:.453125},{x:.421875,y:.453125},{x:.421875,y:.453125},{x:.453125,y:.453125},{x:.453125,y:.453125},{x:.484375,y:.453125},{x:.484375,y:.453125},{x:.515625,y:.453125},{x:.515625,y:.453125},{x:.546875,y:.453125},{x:.546875,y:.453125},{x:.578125,y:.453125},{x:.578125,y:.453125},{x:.609375,y:.453125},{x:.609375,y:.453125},{x:.640625,y:.453125},{x:.640625,y:.453125},{x:.671875,y:.453125},{x:.671875,y:.453125},{x:.703125,y:.453125},{x:.703125,y:.453125},{x:.734375,y:.453125},{x:.734375,y:.453125},{x:.765625,y:.453125},{x:.765625,y:.453125},{x:.796875,y:.453125},{x:.796875,y:.453125},{x:.828125,y:.453125},{x:.828125,y:.453125},{x:.859375,y:.453125},{x:.859375,y:.453125},{x:.890625,y:.453125},{x:.890625,y:.453125},{x:.921875,y:.453125},{x:.921875,y:.453125},{x:.953125,y:.453125},{x:.953125,y:.453125},{x:.984375,y:.453125},{x:.984375,y:.453125},{x:.015625,y:.484375},{x:.015625,y:.484375},{x:.046875,y:.484375},{x:.046875,y:.484375},{x:.078125,y:.484375},{x:.078125,y:.484375},{x:.109375,y:.484375},{x:.109375,y:.484375},{x:.140625,y:.484375},{x:.140625,y:.484375},{x:.171875,y:.484375},{x:.171875,y:.484375},{x:.203125,y:.484375},{x:.203125,y:.484375},{x:.234375,y:.484375},{x:.234375,y:.484375},{x:.265625,y:.484375},{x:.265625,y:.484375},{x:.296875,y:.484375},{x:.296875,y:.484375},{x:.328125,y:.484375},{x:.328125,y:.484375},{x:.359375,y:.484375},{x:.359375,y:.484375},{x:.390625,y:.484375},{x:.390625,y:.484375},{x:.421875,y:.484375},{x:.421875,y:.484375},{x:.453125,y:.484375},{x:.453125,y:.484375},{x:.484375,y:.484375},{x:.484375,y:.484375},{x:.515625,y:.484375},{x:.515625,y:.484375},{x:.546875,y:.484375},{x:.546875,y:.484375},{x:.578125,y:.484375},{x:.578125,y:.484375},{x:.609375,y:.484375},{x:.609375,y:.484375},{x:.640625,y:.484375},{x:.640625,y:.484375},{x:.671875,y:.484375},{x:.671875,y:.484375},{x:.703125,y:.484375},{x:.703125,y:.484375},{x:.734375,y:.484375},{x:.734375,y:.484375},{x:.765625,y:.484375},{x:.765625,y:.484375},{x:.796875,y:.484375},{x:.796875,y:.484375},{x:.828125,y:.484375},{x:.828125,y:.484375},{x:.859375,y:.484375},{x:.859375,y:.484375},{x:.890625,y:.484375},{x:.890625,y:.484375},{x:.921875,y:.484375},{x:.921875,y:.484375},{x:.953125,y:.484375},{x:.953125,y:.484375},{x:.984375,y:.484375},{x:.984375,y:.484375},{x:.015625,y:.515625},{x:.015625,y:.515625},{x:.046875,y:.515625},{x:.046875,y:.515625},{x:.078125,y:.515625},{x:.078125,y:.515625},{x:.109375,y:.515625},{x:.109375,y:.515625},{x:.140625,y:.515625},{x:.140625,y:.515625},{x:.171875,y:.515625},{x:.171875,y:.515625},{x:.203125,y:.515625},{x:.203125,y:.515625},{x:.234375,y:.515625},{x:.234375,y:.515625},{x:.265625,y:.515625},{x:.265625,y:.515625},{x:.296875,y:.515625},{x:.296875,y:.515625},{x:.328125,y:.515625},{x:.328125,y:.515625},{x:.359375,y:.515625},{x:.359375,y:.515625},{x:.390625,y:.515625},{x:.390625,y:.515625},{x:.421875,y:.515625},{x:.421875,y:.515625},{x:.453125,y:.515625},{x:.453125,y:.515625},{x:.484375,y:.515625},{x:.484375,y:.515625},{x:.515625,y:.515625},{x:.515625,y:.515625},{x:.546875,y:.515625},{x:.546875,y:.515625},{x:.578125,y:.515625},{x:.578125,y:.515625},{x:.609375,y:.515625},{x:.609375,y:.515625},{x:.640625,y:.515625},{x:.640625,y:.515625},{x:.671875,y:.515625},{x:.671875,y:.515625},{x:.703125,y:.515625},{x:.703125,y:.515625},{x:.734375,y:.515625},{x:.734375,y:.515625},{x:.765625,y:.515625},{x:.765625,y:.515625},{x:.796875,y:.515625},{x:.796875,y:.515625},{x:.828125,y:.515625},{x:.828125,y:.515625},{x:.859375,y:.515625},{x:.859375,y:.515625},{x:.890625,y:.515625},{x:.890625,y:.515625},{x:.921875,y:.515625},{x:.921875,y:.515625},{x:.953125,y:.515625},{x:.953125,y:.515625},{x:.984375,y:.515625},{x:.984375,y:.515625},{x:.015625,y:.546875},{x:.015625,y:.546875},{x:.046875,y:.546875},{x:.046875,y:.546875},{x:.078125,y:.546875},{x:.078125,y:.546875},{x:.109375,y:.546875},{x:.109375,y:.546875},{x:.140625,y:.546875},{x:.140625,y:.546875},{x:.171875,y:.546875},{x:.171875,y:.546875},{x:.203125,y:.546875},{x:.203125,y:.546875},{x:.234375,y:.546875},{x:.234375,y:.546875},{x:.265625,y:.546875},{x:.265625,y:.546875},{x:.296875,y:.546875},{x:.296875,y:.546875},{x:.328125,y:.546875},{x:.328125,y:.546875},{x:.359375,y:.546875},{x:.359375,y:.546875},{x:.390625,y:.546875},{x:.390625,y:.546875},{x:.421875,y:.546875},{x:.421875,y:.546875},{x:.453125,y:.546875},{x:.453125,y:.546875},{x:.484375,y:.546875},{x:.484375,y:.546875},{x:.515625,y:.546875},{x:.515625,y:.546875},{x:.546875,y:.546875},{x:.546875,y:.546875},{x:.578125,y:.546875},{x:.578125,y:.546875},{x:.609375,y:.546875},{x:.609375,y:.546875},{x:.640625,y:.546875},{x:.640625,y:.546875},{x:.671875,y:.546875},{x:.671875,y:.546875},{x:.703125,y:.546875},{x:.703125,y:.546875},{x:.734375,y:.546875},{x:.734375,y:.546875},{x:.765625,y:.546875},{x:.765625,y:.546875},{x:.796875,y:.546875},{x:.796875,y:.546875},{x:.828125,y:.546875},{x:.828125,y:.546875},{x:.859375,y:.546875},{x:.859375,y:.546875},{x:.890625,y:.546875},{x:.890625,y:.546875},{x:.921875,y:.546875},{x:.921875,y:.546875},{x:.953125,y:.546875},{x:.953125,y:.546875},{x:.984375,y:.546875},{x:.984375,y:.546875},{x:.015625,y:.578125},{x:.015625,y:.578125},{x:.046875,y:.578125},{x:.046875,y:.578125},{x:.078125,y:.578125},{x:.078125,y:.578125},{x:.109375,y:.578125},{x:.109375,y:.578125},{x:.140625,y:.578125},{x:.140625,y:.578125},{x:.171875,y:.578125},{x:.171875,y:.578125},{x:.203125,y:.578125},{x:.203125,y:.578125},{x:.234375,y:.578125},{x:.234375,y:.578125},{x:.265625,y:.578125},{x:.265625,y:.578125},{x:.296875,y:.578125},{x:.296875,y:.578125},{x:.328125,y:.578125},{x:.328125,y:.578125},{x:.359375,y:.578125},{x:.359375,y:.578125},{x:.390625,y:.578125},{x:.390625,y:.578125},{x:.421875,y:.578125},{x:.421875,y:.578125},{x:.453125,y:.578125},{x:.453125,y:.578125},{x:.484375,y:.578125},{x:.484375,y:.578125},{x:.515625,y:.578125},{x:.515625,y:.578125},{x:.546875,y:.578125},{x:.546875,y:.578125},{x:.578125,y:.578125},{x:.578125,y:.578125},{x:.609375,y:.578125},{x:.609375,y:.578125},{x:.640625,y:.578125},{x:.640625,y:.578125},{x:.671875,y:.578125},{x:.671875,y:.578125},{x:.703125,y:.578125},{x:.703125,y:.578125},{x:.734375,y:.578125},{x:.734375,y:.578125},{x:.765625,y:.578125},{x:.765625,y:.578125},{x:.796875,y:.578125},{x:.796875,y:.578125},{x:.828125,y:.578125},{x:.828125,y:.578125},{x:.859375,y:.578125},{x:.859375,y:.578125},{x:.890625,y:.578125},{x:.890625,y:.578125},{x:.921875,y:.578125},{x:.921875,y:.578125},{x:.953125,y:.578125},{x:.953125,y:.578125},{x:.984375,y:.578125},{x:.984375,y:.578125},{x:.015625,y:.609375},{x:.015625,y:.609375},{x:.046875,y:.609375},{x:.046875,y:.609375},{x:.078125,y:.609375},{x:.078125,y:.609375},{x:.109375,y:.609375},{x:.109375,y:.609375},{x:.140625,y:.609375},{x:.140625,y:.609375},{x:.171875,y:.609375},{x:.171875,y:.609375},{x:.203125,y:.609375},{x:.203125,y:.609375},{x:.234375,y:.609375},{x:.234375,y:.609375},{x:.265625,y:.609375},{x:.265625,y:.609375},{x:.296875,y:.609375},{x:.296875,y:.609375},{x:.328125,y:.609375},{x:.328125,y:.609375},{x:.359375,y:.609375},{x:.359375,y:.609375},{x:.390625,y:.609375},{x:.390625,y:.609375},{x:.421875,y:.609375},{x:.421875,y:.609375},{x:.453125,y:.609375},{x:.453125,y:.609375},{x:.484375,y:.609375},{x:.484375,y:.609375},{x:.515625,y:.609375},{x:.515625,y:.609375},{x:.546875,y:.609375},{x:.546875,y:.609375},{x:.578125,y:.609375},{x:.578125,y:.609375},{x:.609375,y:.609375},{x:.609375,y:.609375},{x:.640625,y:.609375},{x:.640625,y:.609375},{x:.671875,y:.609375},{x:.671875,y:.609375},{x:.703125,y:.609375},{x:.703125,y:.609375},{x:.734375,y:.609375},{x:.734375,y:.609375},{x:.765625,y:.609375},{x:.765625,y:.609375},{x:.796875,y:.609375},{x:.796875,y:.609375},{x:.828125,y:.609375},{x:.828125,y:.609375},{x:.859375,y:.609375},{x:.859375,y:.609375},{x:.890625,y:.609375},{x:.890625,y:.609375},{x:.921875,y:.609375},{x:.921875,y:.609375},{x:.953125,y:.609375},{x:.953125,y:.609375},{x:.984375,y:.609375},{x:.984375,y:.609375},{x:.015625,y:.640625},{x:.015625,y:.640625},{x:.046875,y:.640625},{x:.046875,y:.640625},{x:.078125,y:.640625},{x:.078125,y:.640625},{x:.109375,y:.640625},{x:.109375,y:.640625},{x:.140625,y:.640625},{x:.140625,y:.640625},{x:.171875,y:.640625},{x:.171875,y:.640625},{x:.203125,y:.640625},{x:.203125,y:.640625},{x:.234375,y:.640625},{x:.234375,y:.640625},{x:.265625,y:.640625},{x:.265625,y:.640625},{x:.296875,y:.640625},{x:.296875,y:.640625},{x:.328125,y:.640625},{x:.328125,y:.640625},{x:.359375,y:.640625},{x:.359375,y:.640625},{x:.390625,y:.640625},{x:.390625,y:.640625},{x:.421875,y:.640625},{x:.421875,y:.640625},{x:.453125,y:.640625},{x:.453125,y:.640625},{x:.484375,y:.640625},{x:.484375,y:.640625},{x:.515625,y:.640625},{x:.515625,y:.640625},{x:.546875,y:.640625},{x:.546875,y:.640625},{x:.578125,y:.640625},{x:.578125,y:.640625},{x:.609375,y:.640625},{x:.609375,y:.640625},{x:.640625,y:.640625},{x:.640625,y:.640625},{x:.671875,y:.640625},{x:.671875,y:.640625},{x:.703125,y:.640625},{x:.703125,y:.640625},{x:.734375,y:.640625},{x:.734375,y:.640625},{x:.765625,y:.640625},{x:.765625,y:.640625},{x:.796875,y:.640625},{x:.796875,y:.640625},{x:.828125,y:.640625},{x:.828125,y:.640625},{x:.859375,y:.640625},{x:.859375,y:.640625},{x:.890625,y:.640625},{x:.890625,y:.640625},{x:.921875,y:.640625},{x:.921875,y:.640625},{x:.953125,y:.640625},{x:.953125,y:.640625},{x:.984375,y:.640625},{x:.984375,y:.640625},{x:.015625,y:.671875},{x:.015625,y:.671875},{x:.046875,y:.671875},{x:.046875,y:.671875},{x:.078125,y:.671875},{x:.078125,y:.671875},{x:.109375,y:.671875},{x:.109375,y:.671875},{x:.140625,y:.671875},{x:.140625,y:.671875},{x:.171875,y:.671875},{x:.171875,y:.671875},{x:.203125,y:.671875},{x:.203125,y:.671875},{x:.234375,y:.671875},{x:.234375,y:.671875},{x:.265625,y:.671875},{x:.265625,y:.671875},{x:.296875,y:.671875},{x:.296875,y:.671875},{x:.328125,y:.671875},{x:.328125,y:.671875},{x:.359375,y:.671875},{x:.359375,y:.671875},{x:.390625,y:.671875},{x:.390625,y:.671875},{x:.421875,y:.671875},{x:.421875,y:.671875},{x:.453125,y:.671875},{x:.453125,y:.671875},{x:.484375,y:.671875},{x:.484375,y:.671875},{x:.515625,y:.671875},{x:.515625,y:.671875},{x:.546875,y:.671875},{x:.546875,y:.671875},{x:.578125,y:.671875},{x:.578125,y:.671875},{x:.609375,y:.671875},{x:.609375,y:.671875},{x:.640625,y:.671875},{x:.640625,y:.671875},{x:.671875,y:.671875},{x:.671875,y:.671875},{x:.703125,y:.671875},{x:.703125,y:.671875},{x:.734375,y:.671875},{x:.734375,y:.671875},{x:.765625,y:.671875},{x:.765625,y:.671875},{x:.796875,y:.671875},{x:.796875,y:.671875},{x:.828125,y:.671875},{x:.828125,y:.671875},{x:.859375,y:.671875},{x:.859375,y:.671875},{x:.890625,y:.671875},{x:.890625,y:.671875},{x:.921875,y:.671875},{x:.921875,y:.671875},{x:.953125,y:.671875},{x:.953125,y:.671875},{x:.984375,y:.671875},{x:.984375,y:.671875},{x:.015625,y:.703125},{x:.015625,y:.703125},{x:.046875,y:.703125},{x:.046875,y:.703125},{x:.078125,y:.703125},{x:.078125,y:.703125},{x:.109375,y:.703125},{x:.109375,y:.703125},{x:.140625,y:.703125},{x:.140625,y:.703125},{x:.171875,y:.703125},{x:.171875,y:.703125},{x:.203125,y:.703125},{x:.203125,y:.703125},{x:.234375,y:.703125},{x:.234375,y:.703125},{x:.265625,y:.703125},{x:.265625,y:.703125},{x:.296875,y:.703125},{x:.296875,y:.703125},{x:.328125,y:.703125},{x:.328125,y:.703125},{x:.359375,y:.703125},{x:.359375,y:.703125},{x:.390625,y:.703125},{x:.390625,y:.703125},{x:.421875,y:.703125},{x:.421875,y:.703125},{x:.453125,y:.703125},{x:.453125,y:.703125},{x:.484375,y:.703125},{x:.484375,y:.703125},{x:.515625,y:.703125},{x:.515625,y:.703125},{x:.546875,y:.703125},{x:.546875,y:.703125},{x:.578125,y:.703125},{x:.578125,y:.703125},{x:.609375,y:.703125},{x:.609375,y:.703125},{x:.640625,y:.703125},{x:.640625,y:.703125},{x:.671875,y:.703125},{x:.671875,y:.703125},{x:.703125,y:.703125},{x:.703125,y:.703125},{x:.734375,y:.703125},{x:.734375,y:.703125},{x:.765625,y:.703125},{x:.765625,y:.703125},{x:.796875,y:.703125},{x:.796875,y:.703125},{x:.828125,y:.703125},{x:.828125,y:.703125},{x:.859375,y:.703125},{x:.859375,y:.703125},{x:.890625,y:.703125},{x:.890625,y:.703125},{x:.921875,y:.703125},{x:.921875,y:.703125},{x:.953125,y:.703125},{x:.953125,y:.703125},{x:.984375,y:.703125},{x:.984375,y:.703125},{x:.015625,y:.734375},{x:.015625,y:.734375},{x:.046875,y:.734375},{x:.046875,y:.734375},{x:.078125,y:.734375},{x:.078125,y:.734375},{x:.109375,y:.734375},{x:.109375,y:.734375},{x:.140625,y:.734375},{x:.140625,y:.734375},{x:.171875,y:.734375},{x:.171875,y:.734375},{x:.203125,y:.734375},{x:.203125,y:.734375},{x:.234375,y:.734375},{x:.234375,y:.734375},{x:.265625,y:.734375},{x:.265625,y:.734375},{x:.296875,y:.734375},{x:.296875,y:.734375},{x:.328125,y:.734375},{x:.328125,y:.734375},{x:.359375,y:.734375},{x:.359375,y:.734375},{x:.390625,y:.734375},{x:.390625,y:.734375},{x:.421875,y:.734375},{x:.421875,y:.734375},{x:.453125,y:.734375},{x:.453125,y:.734375},{x:.484375,y:.734375},{x:.484375,y:.734375},{x:.515625,y:.734375},{x:.515625,y:.734375},{x:.546875,y:.734375},{x:.546875,y:.734375},{x:.578125,y:.734375},{x:.578125,y:.734375},{x:.609375,y:.734375},{x:.609375,y:.734375},{x:.640625,y:.734375},{x:.640625,y:.734375},{x:.671875,y:.734375},{x:.671875,y:.734375},{x:.703125,y:.734375},{x:.703125,y:.734375},{x:.734375,y:.734375},{x:.734375,y:.734375},{x:.765625,y:.734375},{x:.765625,y:.734375},{x:.796875,y:.734375},{x:.796875,y:.734375},{x:.828125,y:.734375},{x:.828125,y:.734375},{x:.859375,y:.734375},{x:.859375,y:.734375},{x:.890625,y:.734375},{x:.890625,y:.734375},{x:.921875,y:.734375},{x:.921875,y:.734375},{x:.953125,y:.734375},{x:.953125,y:.734375},{x:.984375,y:.734375},{x:.984375,y:.734375},{x:.015625,y:.765625},{x:.015625,y:.765625},{x:.046875,y:.765625},{x:.046875,y:.765625},{x:.078125,y:.765625},{x:.078125,y:.765625},{x:.109375,y:.765625},{x:.109375,y:.765625},{x:.140625,y:.765625},{x:.140625,y:.765625},{x:.171875,y:.765625},{x:.171875,y:.765625},{x:.203125,y:.765625},{x:.203125,y:.765625},{x:.234375,y:.765625},{x:.234375,y:.765625},{x:.265625,y:.765625},{x:.265625,y:.765625},{x:.296875,y:.765625},{x:.296875,y:.765625},{x:.328125,y:.765625},{x:.328125,y:.765625},{x:.359375,y:.765625},{x:.359375,y:.765625},{x:.390625,y:.765625},{x:.390625,y:.765625},{x:.421875,y:.765625},{x:.421875,y:.765625},{x:.453125,y:.765625},{x:.453125,y:.765625},{x:.484375,y:.765625},{x:.484375,y:.765625},{x:.515625,y:.765625},{x:.515625,y:.765625},{x:.546875,y:.765625},{x:.546875,y:.765625},{x:.578125,y:.765625},{x:.578125,y:.765625},{x:.609375,y:.765625},{x:.609375,y:.765625},{x:.640625,y:.765625},{x:.640625,y:.765625},{x:.671875,y:.765625},{x:.671875,y:.765625},{x:.703125,y:.765625},{x:.703125,y:.765625},{x:.734375,y:.765625},{x:.734375,y:.765625},{x:.765625,y:.765625},{x:.765625,y:.765625},{x:.796875,y:.765625},{x:.796875,y:.765625},{x:.828125,y:.765625},{x:.828125,y:.765625},{x:.859375,y:.765625},{x:.859375,y:.765625},{x:.890625,y:.765625},{x:.890625,y:.765625},{x:.921875,y:.765625},{x:.921875,y:.765625},{x:.953125,y:.765625},{x:.953125,y:.765625},{x:.984375,y:.765625},{x:.984375,y:.765625},{x:.015625,y:.796875},{x:.015625,y:.796875},{x:.046875,y:.796875},{x:.046875,y:.796875},{x:.078125,y:.796875},{x:.078125,y:.796875},{x:.109375,y:.796875},{x:.109375,y:.796875},{x:.140625,y:.796875},{x:.140625,y:.796875},{x:.171875,y:.796875},{x:.171875,y:.796875},{x:.203125,y:.796875},{x:.203125,y:.796875},{x:.234375,y:.796875},{x:.234375,y:.796875},{x:.265625,y:.796875},{x:.265625,y:.796875},{x:.296875,y:.796875},{x:.296875,y:.796875},{x:.328125,y:.796875},{x:.328125,y:.796875},{x:.359375,y:.796875},{x:.359375,y:.796875},{x:.390625,y:.796875},{x:.390625,y:.796875},{x:.421875,y:.796875},{x:.421875,y:.796875},{x:.453125,y:.796875},{x:.453125,y:.796875},{x:.484375,y:.796875},{x:.484375,y:.796875},{x:.515625,y:.796875},{x:.515625,y:.796875},{x:.546875,y:.796875},{x:.546875,y:.796875},{x:.578125,y:.796875},{x:.578125,y:.796875},{x:.609375,y:.796875},{x:.609375,y:.796875},{x:.640625,y:.796875},{x:.640625,y:.796875},{x:.671875,y:.796875},{x:.671875,y:.796875},{x:.703125,y:.796875},{x:.703125,y:.796875},{x:.734375,y:.796875},{x:.734375,y:.796875},{x:.765625,y:.796875},{x:.765625,y:.796875},{x:.796875,y:.796875},{x:.796875,y:.796875},{x:.828125,y:.796875},{x:.828125,y:.796875},{x:.859375,y:.796875},{x:.859375,y:.796875},{x:.890625,y:.796875},{x:.890625,y:.796875},{x:.921875,y:.796875},{x:.921875,y:.796875},{x:.953125,y:.796875},{x:.953125,y:.796875},{x:.984375,y:.796875},{x:.984375,y:.796875},{x:.015625,y:.828125},{x:.015625,y:.828125},{x:.046875,y:.828125},{x:.046875,y:.828125},{x:.078125,y:.828125},{x:.078125,y:.828125},{x:.109375,y:.828125},{x:.109375,y:.828125},{x:.140625,y:.828125},{x:.140625,y:.828125},{x:.171875,y:.828125},{x:.171875,y:.828125},{x:.203125,y:.828125},{x:.203125,y:.828125},{x:.234375,y:.828125},{x:.234375,y:.828125},{x:.265625,y:.828125},{x:.265625,y:.828125},{x:.296875,y:.828125},{x:.296875,y:.828125},{x:.328125,y:.828125},{x:.328125,y:.828125},{x:.359375,y:.828125},{x:.359375,y:.828125},{x:.390625,y:.828125},{x:.390625,y:.828125},{x:.421875,y:.828125},{x:.421875,y:.828125},{x:.453125,y:.828125},{x:.453125,y:.828125},{x:.484375,y:.828125},{x:.484375,y:.828125},{x:.515625,y:.828125},{x:.515625,y:.828125},{x:.546875,y:.828125},{x:.546875,y:.828125},{x:.578125,y:.828125},{x:.578125,y:.828125},{x:.609375,y:.828125},{x:.609375,y:.828125},{x:.640625,y:.828125},{x:.640625,y:.828125},{x:.671875,y:.828125},{x:.671875,y:.828125},{x:.703125,y:.828125},{x:.703125,y:.828125},{x:.734375,y:.828125},{x:.734375,y:.828125},{x:.765625,y:.828125},{x:.765625,y:.828125},{x:.796875,y:.828125},{x:.796875,y:.828125},{x:.828125,y:.828125},{x:.828125,y:.828125},{x:.859375,y:.828125},{x:.859375,y:.828125},{x:.890625,y:.828125},{x:.890625,y:.828125},{x:.921875,y:.828125},{x:.921875,y:.828125},{x:.953125,y:.828125},{x:.953125,y:.828125},{x:.984375,y:.828125},{x:.984375,y:.828125},{x:.015625,y:.859375},{x:.015625,y:.859375},{x:.046875,y:.859375},{x:.046875,y:.859375},{x:.078125,y:.859375},{x:.078125,y:.859375},{x:.109375,y:.859375},{x:.109375,y:.859375},{x:.140625,y:.859375},{x:.140625,y:.859375},{x:.171875,y:.859375},{x:.171875,y:.859375},{x:.203125,y:.859375},{x:.203125,y:.859375},{x:.234375,y:.859375},{x:.234375,y:.859375},{x:.265625,y:.859375},{x:.265625,y:.859375},{x:.296875,y:.859375},{x:.296875,y:.859375},{x:.328125,y:.859375},{x:.328125,y:.859375},{x:.359375,y:.859375},{x:.359375,y:.859375},{x:.390625,y:.859375},{x:.390625,y:.859375},{x:.421875,y:.859375},{x:.421875,y:.859375},{x:.453125,y:.859375},{x:.453125,y:.859375},{x:.484375,y:.859375},{x:.484375,y:.859375},{x:.515625,y:.859375},{x:.515625,y:.859375},{x:.546875,y:.859375},{x:.546875,y:.859375},{x:.578125,y:.859375},{x:.578125,y:.859375},{x:.609375,y:.859375},{x:.609375,y:.859375},{x:.640625,y:.859375},{x:.640625,y:.859375},{x:.671875,y:.859375},{x:.671875,y:.859375},{x:.703125,y:.859375},{x:.703125,y:.859375},{x:.734375,y:.859375},{x:.734375,y:.859375},{x:.765625,y:.859375},{x:.765625,y:.859375},{x:.796875,y:.859375},{x:.796875,y:.859375},{x:.828125,y:.859375},{x:.828125,y:.859375},{x:.859375,y:.859375},{x:.859375,y:.859375},{x:.890625,y:.859375},{x:.890625,y:.859375},{x:.921875,y:.859375},{x:.921875,y:.859375},{x:.953125,y:.859375},{x:.953125,y:.859375},{x:.984375,y:.859375},{x:.984375,y:.859375},{x:.015625,y:.890625},{x:.015625,y:.890625},{x:.046875,y:.890625},{x:.046875,y:.890625},{x:.078125,y:.890625},{x:.078125,y:.890625},{x:.109375,y:.890625},{x:.109375,y:.890625},{x:.140625,y:.890625},{x:.140625,y:.890625},{x:.171875,y:.890625},{x:.171875,y:.890625},{x:.203125,y:.890625},{x:.203125,y:.890625},{x:.234375,y:.890625},{x:.234375,y:.890625},{x:.265625,y:.890625},{x:.265625,y:.890625},{x:.296875,y:.890625},{x:.296875,y:.890625},{x:.328125,y:.890625},{x:.328125,y:.890625},{x:.359375,y:.890625},{x:.359375,y:.890625},{x:.390625,y:.890625},{x:.390625,y:.890625},{x:.421875,y:.890625},{x:.421875,y:.890625},{x:.453125,y:.890625},{x:.453125,y:.890625},{x:.484375,y:.890625},{x:.484375,y:.890625},{x:.515625,y:.890625},{x:.515625,y:.890625},{x:.546875,y:.890625},{x:.546875,y:.890625},{x:.578125,y:.890625},{x:.578125,y:.890625},{x:.609375,y:.890625},{x:.609375,y:.890625},{x:.640625,y:.890625},{x:.640625,y:.890625},{x:.671875,y:.890625},{x:.671875,y:.890625},{x:.703125,y:.890625},{x:.703125,y:.890625},{x:.734375,y:.890625},{x:.734375,y:.890625},{x:.765625,y:.890625},{x:.765625,y:.890625},{x:.796875,y:.890625},{x:.796875,y:.890625},{x:.828125,y:.890625},{x:.828125,y:.890625},{x:.859375,y:.890625},{x:.859375,y:.890625},{x:.890625,y:.890625},{x:.890625,y:.890625},{x:.921875,y:.890625},{x:.921875,y:.890625},{x:.953125,y:.890625},{x:.953125,y:.890625},{x:.984375,y:.890625},{x:.984375,y:.890625},{x:.015625,y:.921875},{x:.015625,y:.921875},{x:.046875,y:.921875},{x:.046875,y:.921875},{x:.078125,y:.921875},{x:.078125,y:.921875},{x:.109375,y:.921875},{x:.109375,y:.921875},{x:.140625,y:.921875},{x:.140625,y:.921875},{x:.171875,y:.921875},{x:.171875,y:.921875},{x:.203125,y:.921875},{x:.203125,y:.921875},{x:.234375,y:.921875},{x:.234375,y:.921875},{x:.265625,y:.921875},{x:.265625,y:.921875},{x:.296875,y:.921875},{x:.296875,y:.921875},{x:.328125,y:.921875},{x:.328125,y:.921875},{x:.359375,y:.921875},{x:.359375,y:.921875},{x:.390625,y:.921875},{x:.390625,y:.921875},{x:.421875,y:.921875},{x:.421875,y:.921875},{x:.453125,y:.921875},{x:.453125,y:.921875},{x:.484375,y:.921875},{x:.484375,y:.921875},{x:.515625,y:.921875},{x:.515625,y:.921875},{x:.546875,y:.921875},{x:.546875,y:.921875},{x:.578125,y:.921875},{x:.578125,y:.921875},{x:.609375,y:.921875},{x:.609375,y:.921875},{x:.640625,y:.921875},{x:.640625,y:.921875},{x:.671875,y:.921875},{x:.671875,y:.921875},{x:.703125,y:.921875},{x:.703125,y:.921875},{x:.734375,y:.921875},{x:.734375,y:.921875},{x:.765625,y:.921875},{x:.765625,y:.921875},{x:.796875,y:.921875},{x:.796875,y:.921875},{x:.828125,y:.921875},{x:.828125,y:.921875},{x:.859375,y:.921875},{x:.859375,y:.921875},{x:.890625,y:.921875},{x:.890625,y:.921875},{x:.921875,y:.921875},{x:.921875,y:.921875},{x:.953125,y:.921875},{x:.953125,y:.921875},{x:.984375,y:.921875},{x:.984375,y:.921875},{x:.015625,y:.953125},{x:.015625,y:.953125},{x:.046875,y:.953125},{x:.046875,y:.953125},{x:.078125,y:.953125},{x:.078125,y:.953125},{x:.109375,y:.953125},{x:.109375,y:.953125},{x:.140625,y:.953125},{x:.140625,y:.953125},{x:.171875,y:.953125},{x:.171875,y:.953125},{x:.203125,y:.953125},{x:.203125,y:.953125},{x:.234375,y:.953125},{x:.234375,y:.953125},{x:.265625,y:.953125},{x:.265625,y:.953125},{x:.296875,y:.953125},{x:.296875,y:.953125},{x:.328125,y:.953125},{x:.328125,y:.953125},{x:.359375,y:.953125},{x:.359375,y:.953125},{x:.390625,y:.953125},{x:.390625,y:.953125},{x:.421875,y:.953125},{x:.421875,y:.953125},{x:.453125,y:.953125},{x:.453125,y:.953125},{x:.484375,y:.953125},{x:.484375,y:.953125},{x:.515625,y:.953125},{x:.515625,y:.953125},{x:.546875,y:.953125},{x:.546875,y:.953125},{x:.578125,y:.953125},{x:.578125,y:.953125},{x:.609375,y:.953125},{x:.609375,y:.953125},{x:.640625,y:.953125},{x:.640625,y:.953125},{x:.671875,y:.953125},{x:.671875,y:.953125},{x:.703125,y:.953125},{x:.703125,y:.953125},{x:.734375,y:.953125},{x:.734375,y:.953125},{x:.765625,y:.953125},{x:.765625,y:.953125},{x:.796875,y:.953125},{x:.796875,y:.953125},{x:.828125,y:.953125},{x:.828125,y:.953125},{x:.859375,y:.953125},{x:.859375,y:.953125},{x:.890625,y:.953125},{x:.890625,y:.953125},{x:.921875,y:.953125},{x:.921875,y:.953125},{x:.953125,y:.953125},{x:.953125,y:.953125},{x:.984375,y:.953125},{x:.984375,y:.953125},{x:.015625,y:.984375},{x:.015625,y:.984375},{x:.046875,y:.984375},{x:.046875,y:.984375},{x:.078125,y:.984375},{x:.078125,y:.984375},{x:.109375,y:.984375},{x:.109375,y:.984375},{x:.140625,y:.984375},{x:.140625,y:.984375},{x:.171875,y:.984375},{x:.171875,y:.984375},{x:.203125,y:.984375},{x:.203125,y:.984375},{x:.234375,y:.984375},{x:.234375,y:.984375},{x:.265625,y:.984375},{x:.265625,y:.984375},{x:.296875,y:.984375},{x:.296875,y:.984375},{x:.328125,y:.984375},{x:.328125,y:.984375},{x:.359375,y:.984375},{x:.359375,y:.984375},{x:.390625,y:.984375},{x:.390625,y:.984375},{x:.421875,y:.984375},{x:.421875,y:.984375},{x:.453125,y:.984375},{x:.453125,y:.984375},{x:.484375,y:.984375},{x:.484375,y:.984375},{x:.515625,y:.984375},{x:.515625,y:.984375},{x:.546875,y:.984375},{x:.546875,y:.984375},{x:.578125,y:.984375},{x:.578125,y:.984375},{x:.609375,y:.984375},{x:.609375,y:.984375},{x:.640625,y:.984375},{x:.640625,y:.984375},{x:.671875,y:.984375},{x:.671875,y:.984375},{x:.703125,y:.984375},{x:.703125,y:.984375},{x:.734375,y:.984375},{x:.734375,y:.984375},{x:.765625,y:.984375},{x:.765625,y:.984375},{x:.796875,y:.984375},{x:.796875,y:.984375},{x:.828125,y:.984375},{x:.828125,y:.984375},{x:.859375,y:.984375},{x:.859375,y:.984375},{x:.890625,y:.984375},{x:.890625,y:.984375},{x:.921875,y:.984375},{x:.921875,y:.984375},{x:.953125,y:.984375},{x:.953125,y:.984375},{x:.984375,y:.984375},{x:.984375,y:.984375},{x:.03125,y:.03125},{x:.03125,y:.03125},{x:.09375,y:.03125},{x:.09375,y:.03125},{x:.15625,y:.03125},{x:.15625,y:.03125},{x:.21875,y:.03125},{x:.21875,y:.03125},{x:.28125,y:.03125},{x:.28125,y:.03125},{x:.34375,y:.03125},{x:.34375,y:.03125},{x:.40625,y:.03125},{x:.40625,y:.03125},{x:.46875,y:.03125},{x:.46875,y:.03125},{x:.53125,y:.03125},{x:.53125,y:.03125},{x:.59375,y:.03125},{x:.59375,y:.03125},{x:.65625,y:.03125},{x:.65625,y:.03125},{x:.71875,y:.03125},{x:.71875,y:.03125},{x:.78125,y:.03125},{x:.78125,y:.03125},{x:.84375,y:.03125},{x:.84375,y:.03125},{x:.90625,y:.03125},{x:.90625,y:.03125},{x:.96875,y:.03125},{x:.96875,y:.03125},{x:.03125,y:.09375},{x:.03125,y:.09375},{x:.09375,y:.09375},{x:.09375,y:.09375},{x:.15625,y:.09375},{x:.15625,y:.09375},{x:.21875,y:.09375},{x:.21875,y:.09375},{x:.28125,y:.09375},{x:.28125,y:.09375},{x:.34375,y:.09375},{x:.34375,y:.09375},{x:.40625,y:.09375},{x:.40625,y:.09375},{x:.46875,y:.09375},{x:.46875,y:.09375},{x:.53125,y:.09375},{x:.53125,y:.09375},{x:.59375,y:.09375},{x:.59375,y:.09375},{x:.65625,y:.09375},{x:.65625,y:.09375},{x:.71875,y:.09375},{x:.71875,y:.09375},{x:.78125,y:.09375},{x:.78125,y:.09375},{x:.84375,y:.09375},{x:.84375,y:.09375},{x:.90625,y:.09375},{x:.90625,y:.09375},{x:.96875,y:.09375},{x:.96875,y:.09375},{x:.03125,y:.15625},{x:.03125,y:.15625},{x:.09375,y:.15625},{x:.09375,y:.15625},{x:.15625,y:.15625},{x:.15625,y:.15625},{x:.21875,y:.15625},{x:.21875,y:.15625},{x:.28125,y:.15625},{x:.28125,y:.15625},{x:.34375,y:.15625},{x:.34375,y:.15625},{x:.40625,y:.15625},{x:.40625,y:.15625},{x:.46875,y:.15625},{x:.46875,y:.15625},{x:.53125,y:.15625},{x:.53125,y:.15625},{x:.59375,y:.15625},{x:.59375,y:.15625},{x:.65625,y:.15625},{x:.65625,y:.15625},{x:.71875,y:.15625},{x:.71875,y:.15625},{x:.78125,y:.15625},{x:.78125,y:.15625},{x:.84375,y:.15625},{x:.84375,y:.15625},{x:.90625,y:.15625},{x:.90625,y:.15625},{x:.96875,y:.15625},{x:.96875,y:.15625},{x:.03125,y:.21875},{x:.03125,y:.21875},{x:.09375,y:.21875},{x:.09375,y:.21875},{x:.15625,y:.21875},{x:.15625,y:.21875},{x:.21875,y:.21875},{x:.21875,y:.21875},{x:.28125,y:.21875},{x:.28125,y:.21875},{x:.34375,y:.21875},{x:.34375,y:.21875},{x:.40625,y:.21875},{x:.40625,y:.21875},{x:.46875,y:.21875},{x:.46875,y:.21875},{x:.53125,y:.21875},{x:.53125,y:.21875},{x:.59375,y:.21875},{x:.59375,y:.21875},{x:.65625,y:.21875},{x:.65625,y:.21875},{x:.71875,y:.21875},{x:.71875,y:.21875},{x:.78125,y:.21875},{x:.78125,y:.21875},{x:.84375,y:.21875},{x:.84375,y:.21875},{x:.90625,y:.21875},{x:.90625,y:.21875},{x:.96875,y:.21875},{x:.96875,y:.21875},{x:.03125,y:.28125},{x:.03125,y:.28125},{x:.09375,y:.28125},{x:.09375,y:.28125},{x:.15625,y:.28125},{x:.15625,y:.28125},{x:.21875,y:.28125},{x:.21875,y:.28125},{x:.28125,y:.28125},{x:.28125,y:.28125},{x:.34375,y:.28125},{x:.34375,y:.28125},{x:.40625,y:.28125},{x:.40625,y:.28125},{x:.46875,y:.28125},{x:.46875,y:.28125},{x:.53125,y:.28125},{x:.53125,y:.28125},{x:.59375,y:.28125},{x:.59375,y:.28125},{x:.65625,y:.28125},{x:.65625,y:.28125},{x:.71875,y:.28125},{x:.71875,y:.28125},{x:.78125,y:.28125},{x:.78125,y:.28125},{x:.84375,y:.28125},{x:.84375,y:.28125},{x:.90625,y:.28125},{x:.90625,y:.28125},{x:.96875,y:.28125},{x:.96875,y:.28125},{x:.03125,y:.34375},{x:.03125,y:.34375},{x:.09375,y:.34375},{x:.09375,y:.34375},{x:.15625,y:.34375},{x:.15625,y:.34375},{x:.21875,y:.34375},{x:.21875,y:.34375},{x:.28125,y:.34375},{x:.28125,y:.34375},{x:.34375,y:.34375},{x:.34375,y:.34375},{x:.40625,y:.34375},{x:.40625,y:.34375},{x:.46875,y:.34375},{x:.46875,y:.34375},{x:.53125,y:.34375},{x:.53125,y:.34375},{x:.59375,y:.34375},{x:.59375,y:.34375},{x:.65625,y:.34375},{x:.65625,y:.34375},{x:.71875,y:.34375},{x:.71875,y:.34375},{x:.78125,y:.34375},{x:.78125,y:.34375},{x:.84375,y:.34375},{x:.84375,y:.34375},{x:.90625,y:.34375},{x:.90625,y:.34375},{x:.96875,y:.34375},{x:.96875,y:.34375},{x:.03125,y:.40625},{x:.03125,y:.40625},{x:.09375,y:.40625},{x:.09375,y:.40625},{x:.15625,y:.40625},{x:.15625,y:.40625},{x:.21875,y:.40625},{x:.21875,y:.40625},{x:.28125,y:.40625},{x:.28125,y:.40625},{x:.34375,y:.40625},{x:.34375,y:.40625},{x:.40625,y:.40625},{x:.40625,y:.40625},{x:.46875,y:.40625},{x:.46875,y:.40625},{x:.53125,y:.40625},{x:.53125,y:.40625},{x:.59375,y:.40625},{x:.59375,y:.40625},{x:.65625,y:.40625},{x:.65625,y:.40625},{x:.71875,y:.40625},{x:.71875,y:.40625},{x:.78125,y:.40625},{x:.78125,y:.40625},{x:.84375,y:.40625},{x:.84375,y:.40625},{x:.90625,y:.40625},{x:.90625,y:.40625},{x:.96875,y:.40625},{x:.96875,y:.40625},{x:.03125,y:.46875},{x:.03125,y:.46875},{x:.09375,y:.46875},{x:.09375,y:.46875},{x:.15625,y:.46875},{x:.15625,y:.46875},{x:.21875,y:.46875},{x:.21875,y:.46875},{x:.28125,y:.46875},{x:.28125,y:.46875},{x:.34375,y:.46875},{x:.34375,y:.46875},{x:.40625,y:.46875},{x:.40625,y:.46875},{x:.46875,y:.46875},{x:.46875,y:.46875},{x:.53125,y:.46875},{x:.53125,y:.46875},{x:.59375,y:.46875},{x:.59375,y:.46875},{x:.65625,y:.46875},{x:.65625,y:.46875},{x:.71875,y:.46875},{x:.71875,y:.46875},{x:.78125,y:.46875},{x:.78125,y:.46875},{x:.84375,y:.46875},{x:.84375,y:.46875},{x:.90625,y:.46875},{x:.90625,y:.46875},{x:.96875,y:.46875},{x:.96875,y:.46875},{x:.03125,y:.53125},{x:.03125,y:.53125},{x:.09375,y:.53125},{x:.09375,y:.53125},{x:.15625,y:.53125},{x:.15625,y:.53125},{x:.21875,y:.53125},{x:.21875,y:.53125},{x:.28125,y:.53125},{x:.28125,y:.53125},{x:.34375,y:.53125},{x:.34375,y:.53125},{x:.40625,y:.53125},{x:.40625,y:.53125},{x:.46875,y:.53125},{x:.46875,y:.53125},{x:.53125,y:.53125},{x:.53125,y:.53125},{x:.59375,y:.53125},{x:.59375,y:.53125},{x:.65625,y:.53125},{x:.65625,y:.53125},{x:.71875,y:.53125},{x:.71875,y:.53125},{x:.78125,y:.53125},{x:.78125,y:.53125},{x:.84375,y:.53125},{x:.84375,y:.53125},{x:.90625,y:.53125},{x:.90625,y:.53125},{x:.96875,y:.53125},{x:.96875,y:.53125},{x:.03125,y:.59375},{x:.03125,y:.59375},{x:.09375,y:.59375},{x:.09375,y:.59375},{x:.15625,y:.59375},{x:.15625,y:.59375},{x:.21875,y:.59375},{x:.21875,y:.59375},{x:.28125,y:.59375},{x:.28125,y:.59375},{x:.34375,y:.59375},{x:.34375,y:.59375},{x:.40625,y:.59375},{x:.40625,y:.59375},{x:.46875,y:.59375},{x:.46875,y:.59375},{x:.53125,y:.59375},{x:.53125,y:.59375},{x:.59375,y:.59375},{x:.59375,y:.59375},{x:.65625,y:.59375},{x:.65625,y:.59375},{x:.71875,y:.59375},{x:.71875,y:.59375},{x:.78125,y:.59375},{x:.78125,y:.59375},{x:.84375,y:.59375},{x:.84375,y:.59375},{x:.90625,y:.59375},{x:.90625,y:.59375},{x:.96875,y:.59375},{x:.96875,y:.59375},{x:.03125,y:.65625},{x:.03125,y:.65625},{x:.09375,y:.65625},{x:.09375,y:.65625},{x:.15625,y:.65625},{x:.15625,y:.65625},{x:.21875,y:.65625},{x:.21875,y:.65625},{x:.28125,y:.65625},{x:.28125,y:.65625},{x:.34375,y:.65625},{x:.34375,y:.65625},{x:.40625,y:.65625},{x:.40625,y:.65625},{x:.46875,y:.65625},{x:.46875,y:.65625},{x:.53125,y:.65625},{x:.53125,y:.65625},{x:.59375,y:.65625},{x:.59375,y:.65625},{x:.65625,y:.65625},{x:.65625,y:.65625},{x:.71875,y:.65625},{x:.71875,y:.65625},{x:.78125,y:.65625},{x:.78125,y:.65625},{x:.84375,y:.65625},{x:.84375,y:.65625},{x:.90625,y:.65625},{x:.90625,y:.65625},{x:.96875,y:.65625},{x:.96875,y:.65625},{x:.03125,y:.71875},{x:.03125,y:.71875},{x:.09375,y:.71875},{x:.09375,y:.71875},{x:.15625,y:.71875},{x:.15625,y:.71875},{x:.21875,y:.71875},{x:.21875,y:.71875},{x:.28125,y:.71875},{x:.28125,y:.71875},{x:.34375,y:.71875},{x:.34375,y:.71875},{x:.40625,y:.71875},{x:.40625,y:.71875},{x:.46875,y:.71875},{x:.46875,y:.71875},{x:.53125,y:.71875},{x:.53125,y:.71875},{x:.59375,y:.71875},{x:.59375,y:.71875},{x:.65625,y:.71875},{x:.65625,y:.71875},{x:.71875,y:.71875},{x:.71875,y:.71875},{x:.78125,y:.71875},{x:.78125,y:.71875},{x:.84375,y:.71875},{x:.84375,y:.71875},{x:.90625,y:.71875},{x:.90625,y:.71875},{x:.96875,y:.71875},{x:.96875,y:.71875},{x:.03125,y:.78125},{x:.03125,y:.78125},{x:.09375,y:.78125},{x:.09375,y:.78125},{x:.15625,y:.78125},{x:.15625,y:.78125},{x:.21875,y:.78125},{x:.21875,y:.78125},{x:.28125,y:.78125},{x:.28125,y:.78125},{x:.34375,y:.78125},{x:.34375,y:.78125},{x:.40625,y:.78125},{x:.40625,y:.78125},{x:.46875,y:.78125},{x:.46875,y:.78125},{x:.53125,y:.78125},{x:.53125,y:.78125},{x:.59375,y:.78125},{x:.59375,y:.78125},{x:.65625,y:.78125},{x:.65625,y:.78125},{x:.71875,y:.78125},{x:.71875,y:.78125},{x:.78125,y:.78125},{x:.78125,y:.78125},{x:.84375,y:.78125},{x:.84375,y:.78125},{x:.90625,y:.78125},{x:.90625,y:.78125},{x:.96875,y:.78125},{x:.96875,y:.78125},{x:.03125,y:.84375},{x:.03125,y:.84375},{x:.09375,y:.84375},{x:.09375,y:.84375},{x:.15625,y:.84375},{x:.15625,y:.84375},{x:.21875,y:.84375},{x:.21875,y:.84375},{x:.28125,y:.84375},{x:.28125,y:.84375},{x:.34375,y:.84375},{x:.34375,y:.84375},{x:.40625,y:.84375},{x:.40625,y:.84375},{x:.46875,y:.84375},{x:.46875,y:.84375},{x:.53125,y:.84375},{x:.53125,y:.84375},{x:.59375,y:.84375},{x:.59375,y:.84375},{x:.65625,y:.84375},{x:.65625,y:.84375},{x:.71875,y:.84375},{x:.71875,y:.84375},{x:.78125,y:.84375},{x:.78125,y:.84375},{x:.84375,y:.84375},{x:.84375,y:.84375},{x:.90625,y:.84375},{x:.90625,y:.84375},{x:.96875,y:.84375},{x:.96875,y:.84375},{x:.03125,y:.90625},{x:.03125,y:.90625},{x:.09375,y:.90625},{x:.09375,y:.90625},{x:.15625,y:.90625},{x:.15625,y:.90625},{x:.21875,y:.90625},{x:.21875,y:.90625},{x:.28125,y:.90625},{x:.28125,y:.90625},{x:.34375,y:.90625},{x:.34375,y:.90625},{x:.40625,y:.90625},{x:.40625,y:.90625},{x:.46875,y:.90625},{x:.46875,y:.90625},{x:.53125,y:.90625},{x:.53125,y:.90625},{x:.59375,y:.90625},{x:.59375,y:.90625},{x:.65625,y:.90625},{x:.65625,y:.90625},{x:.71875,y:.90625},{x:.71875,y:.90625},{x:.78125,y:.90625},{x:.78125,y:.90625},{x:.84375,y:.90625},{x:.84375,y:.90625},{x:.90625,y:.90625},{x:.90625,y:.90625},{x:.96875,y:.90625},{x:.96875,y:.90625},{x:.03125,y:.96875},{x:.03125,y:.96875},{x:.09375,y:.96875},{x:.09375,y:.96875},{x:.15625,y:.96875},{x:.15625,y:.96875},{x:.21875,y:.96875},{x:.21875,y:.96875},{x:.28125,y:.96875},{x:.28125,y:.96875},{x:.34375,y:.96875},{x:.34375,y:.96875},{x:.40625,y:.96875},{x:.40625,y:.96875},{x:.46875,y:.96875},{x:.46875,y:.96875},{x:.53125,y:.96875},{x:.53125,y:.96875},{x:.59375,y:.96875},{x:.59375,y:.96875},{x:.65625,y:.96875},{x:.65625,y:.96875},{x:.71875,y:.96875},{x:.71875,y:.96875},{x:.78125,y:.96875},{x:.78125,y:.96875},{x:.84375,y:.96875},{x:.84375,y:.96875},{x:.90625,y:.96875},{x:.90625,y:.96875},{x:.96875,y:.96875},{x:.96875,y:.96875},{x:.0625,y:.0625},{x:.0625,y:.0625},{x:.0625,y:.0625},{x:.0625,y:.0625},{x:.0625,y:.0625},{x:.0625,y:.0625},{x:.1875,y:.0625},{x:.1875,y:.0625},{x:.1875,y:.0625},{x:.1875,y:.0625},{x:.1875,y:.0625},{x:.1875,y:.0625},{x:.3125,y:.0625},{x:.3125,y:.0625},{x:.3125,y:.0625},{x:.3125,y:.0625},{x:.3125,y:.0625},{x:.3125,y:.0625},{x:.4375,y:.0625},{x:.4375,y:.0625},{x:.4375,y:.0625},{x:.4375,y:.0625},{x:.4375,y:.0625},{x:.4375,y:.0625},{x:.5625,y:.0625},{x:.5625,y:.0625},{x:.5625,y:.0625},{x:.5625,y:.0625},{x:.5625,y:.0625},{x:.5625,y:.0625},{x:.6875,y:.0625},{x:.6875,y:.0625},{x:.6875,y:.0625},{x:.6875,y:.0625},{x:.6875,y:.0625},{x:.6875,y:.0625},{x:.8125,y:.0625},{x:.8125,y:.0625},{x:.8125,y:.0625},{x:.8125,y:.0625},{x:.8125,y:.0625},{x:.8125,y:.0625},{x:.9375,y:.0625},{x:.9375,y:.0625},{x:.9375,y:.0625},{x:.9375,y:.0625},{x:.9375,y:.0625},{x:.9375,y:.0625},{x:.0625,y:.1875},{x:.0625,y:.1875},{x:.0625,y:.1875},{x:.0625,y:.1875},{x:.0625,y:.1875},{x:.0625,y:.1875},{x:.1875,y:.1875},{x:.1875,y:.1875},{x:.1875,y:.1875},{x:.1875,y:.1875},{x:.1875,y:.1875},{x:.1875,y:.1875},{x:.3125,y:.1875},{x:.3125,y:.1875},{x:.3125,y:.1875},{x:.3125,y:.1875},{x:.3125,y:.1875},{x:.3125,y:.1875},{x:.4375,y:.1875},{x:.4375,y:.1875},{x:.4375,y:.1875},{x:.4375,y:.1875},{x:.4375,y:.1875},{x:.4375,y:.1875},{x:.5625,y:.1875},{x:.5625,y:.1875},{x:.5625,y:.1875},{x:.5625,y:.1875},{x:.5625,y:.1875},{x:.5625,y:.1875},{x:.6875,y:.1875},{x:.6875,y:.1875},{x:.6875,y:.1875},{x:.6875,y:.1875},{x:.6875,y:.1875},{x:.6875,y:.1875},{x:.8125,y:.1875},{x:.8125,y:.1875},{x:.8125,y:.1875},{x:.8125,y:.1875},{x:.8125,y:.1875},{x:.8125,y:.1875},{x:.9375,y:.1875},{x:.9375,y:.1875},{x:.9375,y:.1875},{x:.9375,y:.1875},{x:.9375,y:.1875},{x:.9375,y:.1875},{x:.0625,y:.3125},{x:.0625,y:.3125},{x:.0625,y:.3125},{x:.0625,y:.3125},{x:.0625,y:.3125},{x:.0625,y:.3125},{x:.1875,y:.3125},{x:.1875,y:.3125},{x:.1875,y:.3125},{x:.1875,y:.3125},{x:.1875,y:.3125},{x:.1875,y:.3125},{x:.3125,y:.3125},{x:.3125,y:.3125},{x:.3125,y:.3125},{x:.3125,y:.3125},{x:.3125,y:.3125},{x:.3125,y:.3125},{x:.4375,y:.3125},{x:.4375,y:.3125},{x:.4375,y:.3125},{x:.4375,y:.3125},{x:.4375,y:.3125},{x:.4375,y:.3125},{x:.5625,y:.3125},{x:.5625,y:.3125},{x:.5625,y:.3125},{x:.5625,y:.3125},{x:.5625,y:.3125},{x:.5625,y:.3125},{x:.6875,y:.3125},{x:.6875,y:.3125},{x:.6875,y:.3125},{x:.6875,y:.3125},{x:.6875,y:.3125},{x:.6875,y:.3125},{x:.8125,y:.3125},{x:.8125,y:.3125},{x:.8125,y:.3125},{x:.8125,y:.3125},{x:.8125,y:.3125},{x:.8125,y:.3125},{x:.9375,y:.3125},{x:.9375,y:.3125},{x:.9375,y:.3125},{x:.9375,y:.3125},{x:.9375,y:.3125},{x:.9375,y:.3125},{x:.0625,y:.4375},{x:.0625,y:.4375},{x:.0625,y:.4375},{x:.0625,y:.4375},{x:.0625,y:.4375},{x:.0625,y:.4375},{x:.1875,y:.4375},{x:.1875,y:.4375},{x:.1875,y:.4375},{x:.1875,y:.4375},{x:.1875,y:.4375},{x:.1875,y:.4375},{x:.3125,y:.4375},{x:.3125,y:.4375},{x:.3125,y:.4375},{x:.3125,y:.4375},{x:.3125,y:.4375},{x:.3125,y:.4375},{x:.4375,y:.4375},{x:.4375,y:.4375},{x:.4375,y:.4375},{x:.4375,y:.4375},{x:.4375,y:.4375},{x:.4375,y:.4375},{x:.5625,y:.4375},{x:.5625,y:.4375},{x:.5625,y:.4375},{x:.5625,y:.4375},{x:.5625,y:.4375},{x:.5625,y:.4375},{x:.6875,y:.4375},{x:.6875,y:.4375},{x:.6875,y:.4375},{x:.6875,y:.4375},{x:.6875,y:.4375},{x:.6875,y:.4375},{x:.8125,y:.4375},{x:.8125,y:.4375},{x:.8125,y:.4375},{x:.8125,y:.4375},{x:.8125,y:.4375},{x:.8125,y:.4375},{x:.9375,y:.4375},{x:.9375,y:.4375},{x:.9375,y:.4375},{x:.9375,y:.4375},{x:.9375,y:.4375},{x:.9375,y:.4375},{x:.0625,y:.5625},{x:.0625,y:.5625},{x:.0625,y:.5625},{x:.0625,y:.5625},{x:.0625,y:.5625},{x:.0625,y:.5625},{x:.1875,y:.5625},{x:.1875,y:.5625},{x:.1875,y:.5625},{x:.1875,y:.5625},{x:.1875,y:.5625},{x:.1875,y:.5625},{x:.3125,y:.5625},{x:.3125,y:.5625},{x:.3125,y:.5625},{x:.3125,y:.5625},{x:.3125,y:.5625},{x:.3125,y:.5625},{x:.4375,y:.5625},{x:.4375,y:.5625},{x:.4375,y:.5625},{x:.4375,y:.5625},{x:.4375,y:.5625},{x:.4375,y:.5625},{x:.5625,y:.5625},{x:.5625,y:.5625},{x:.5625,y:.5625},{x:.5625,y:.5625},{x:.5625,y:.5625},{x:.5625,y:.5625},{x:.6875,y:.5625},{x:.6875,y:.5625},{x:.6875,y:.5625},{x:.6875,y:.5625},{x:.6875,y:.5625},{x:.6875,y:.5625},{x:.8125,y:.5625},{x:.8125,y:.5625},{x:.8125,y:.5625},{x:.8125,y:.5625},{x:.8125,y:.5625},{x:.8125,y:.5625},{x:.9375,y:.5625},{x:.9375,y:.5625},{x:.9375,y:.5625},{x:.9375,y:.5625},{x:.9375,y:.5625},{x:.9375,y:.5625},{x:.0625,y:.6875},{x:.0625,y:.6875},{x:.0625,y:.6875},{x:.0625,y:.6875},{x:.0625,y:.6875},{x:.0625,y:.6875},{x:.1875,y:.6875},{x:.1875,y:.6875},{x:.1875,y:.6875},{x:.1875,y:.6875},{x:.1875,y:.6875},{x:.1875,y:.6875},{x:.3125,y:.6875},{x:.3125,y:.6875},{x:.3125,y:.6875},{x:.3125,y:.6875},{x:.3125,y:.6875},{x:.3125,y:.6875},{x:.4375,y:.6875},{x:.4375,y:.6875},{x:.4375,y:.6875},{x:.4375,y:.6875},{x:.4375,y:.6875},{x:.4375,y:.6875},{x:.5625,y:.6875},{x:.5625,y:.6875},{x:.5625,y:.6875},{x:.5625,y:.6875},{x:.5625,y:.6875},{x:.5625,y:.6875},{x:.6875,y:.6875},{x:.6875,y:.6875},{x:.6875,y:.6875},{x:.6875,y:.6875},{x:.6875,y:.6875},{x:.6875,y:.6875},{x:.8125,y:.6875},{x:.8125,y:.6875},{x:.8125,y:.6875},{x:.8125,y:.6875},{x:.8125,y:.6875},{x:.8125,y:.6875},{x:.9375,y:.6875},{x:.9375,y:.6875},{x:.9375,y:.6875},{x:.9375,y:.6875},{x:.9375,y:.6875},{x:.9375,y:.6875},{x:.0625,y:.8125},{x:.0625,y:.8125},{x:.0625,y:.8125},{x:.0625,y:.8125},{x:.0625,y:.8125},{x:.0625,y:.8125},{x:.1875,y:.8125},{x:.1875,y:.8125},{x:.1875,y:.8125},{x:.1875,y:.8125},{x:.1875,y:.8125},{x:.1875,y:.8125},{x:.3125,y:.8125},{x:.3125,y:.8125},{x:.3125,y:.8125},{x:.3125,y:.8125},{x:.3125,y:.8125},{x:.3125,y:.8125},{x:.4375,y:.8125},{x:.4375,y:.8125},{x:.4375,y:.8125},{x:.4375,y:.8125},{x:.4375,y:.8125},{x:.4375,y:.8125},{x:.5625,y:.8125},{x:.5625,y:.8125},{x:.5625,y:.8125},{x:.5625,y:.8125},{x:.5625,y:.8125},{x:.5625,y:.8125},{x:.6875,y:.8125},{x:.6875,y:.8125},{x:.6875,y:.8125},{x:.6875,y:.8125},{x:.6875,y:.8125},{x:.6875,y:.8125},{x:.8125,y:.8125},{x:.8125,y:.8125},{x:.8125,y:.8125},{x:.8125,y:.8125},{x:.8125,y:.8125},{x:.8125,y:.8125},{x:.9375,y:.8125},{x:.9375,y:.8125},{x:.9375,y:.8125},{x:.9375,y:.8125},{x:.9375,y:.8125},{x:.9375,y:.8125},{x:.0625,y:.9375},{x:.0625,y:.9375},{x:.0625,y:.9375},{x:.0625,y:.9375},{x:.0625,y:.9375},{x:.0625,y:.9375},{x:.1875,y:.9375},{x:.1875,y:.9375},{x:.1875,y:.9375},{x:.1875,y:.9375},{x:.1875,y:.9375},{x:.1875,y:.9375},{x:.3125,y:.9375},{x:.3125,y:.9375},{x:.3125,y:.9375},{x:.3125,y:.9375},{x:.3125,y:.9375},{x:.3125,y:.9375},{x:.4375,y:.9375},{x:.4375,y:.9375},{x:.4375,y:.9375},{x:.4375,y:.9375},{x:.4375,y:.9375},{x:.4375,y:.9375},{x:.5625,y:.9375},{x:.5625,y:.9375},{x:.5625,y:.9375},{x:.5625,y:.9375},{x:.5625,y:.9375},{x:.5625,y:.9375},{x:.6875,y:.9375},{x:.6875,y:.9375},{x:.6875,y:.9375},{x:.6875,y:.9375},{x:.6875,y:.9375},{x:.6875,y:.9375},{x:.8125,y:.9375},{x:.8125,y:.9375},{x:.8125,y:.9375},{x:.8125,y:.9375},{x:.8125,y:.9375},{x:.8125,y:.9375},{x:.9375,y:.9375},{x:.9375,y:.9375},{x:.9375,y:.9375},{x:.9375,y:.9375},{x:.9375,y:.9375},{x:.9375,y:.9375}];var T5=class{constructor(e){var n;this.model=e,this.anchors=TA.map(s=>[s.x,s.y]),this.anchorsTensor=r.tensor2d(this.anchors),this.inputSize=(n=this.model)==null?void 0:n.inputs[0].shape[2],this.inputSizeTensor=r.tensor1d([this.inputSize,this.inputSize]),this.doubleInputSizeTensor=r.tensor1d([this.inputSize*2,this.inputSize*2])}normalizeBoxes(e){return r.tidy(()=>{let n=r.slice(e,[0,0],[-1,2]),s=r.slice(e,[0,2],[-1,2]),o=r.add(r.div(n,this.inputSizeTensor),this.anchorsTensor),i=r.div(s,this.doubleInputSizeTensor),t=r.mul(r.sub(o,i),this.inputSizeTensor),a=r.mul(r.add(o,i),this.inputSizeTensor);return r.concat2d([t,a],1)})}normalizeLandmarks(e,n){return r.tidy(()=>{let s=r.add(r.div(e.reshape([-1,7,2]),this.inputSizeTensor),this.anchors[n]);return r.mul(s,this.inputSizeTensor)})}async getBoxes(e,n){let s=this.model.predict(e),o=s.squeeze();s.dispose();let i=r.tidy(()=>r.sigmoid(r.slice(o,[0,0],[-1,1])).squeeze()),t=i.dataSync(),a=r.slice(o,[0,1],[-1,4]),x=this.normalizeBoxes(a);a.dispose();let l=await r.image.nonMaxSuppressionAsync(x,t,n.hand.maxDetected,n.hand.iouThreshold,n.hand.minConfidence),d=l.arraySync();i.dispose(),l.dispose();let y=[];for(let u of d)if(t[u]>=n.hand.minConfidence){let p=r.slice(x,[u,0],[1,-1]),E=r.slice(o,[u,5],[1,14]),c=r.tidy(()=>this.normalizeLandmarks(E,u).reshape([-1,2]));E.dispose(),y.push({box:p,palmLandmarks:c,confidence:t[u]})}return o.dispose(),x.dispose(),y}async estimateHandBounds(e,n){let s=e.shape[1],o=e.shape[2],i=r.tidy(()=>e.resizeBilinear([this.inputSize,this.inputSize]).div(127.5).sub(1)),t=await this.getBoxes(i,n);i.dispose();let a=[];if(!t||t.length===0)return a;for(let x of t){let l=x.box.dataSync(),d=l.slice(0,2),y=l.slice(2,4),u=x.palmLandmarks.arraySync();x.box.dispose(),x.palmLandmarks.dispose(),a.push(gA({startPoint:d,endPoint:y,palmLandmarks:u,confidence:x.confidence},[o/this.inputSize,s/this.inputSize]))}return a}};function h2(A){return A-2*Math.PI*Math.floor((A+Math.PI)/(2*Math.PI))}function PA(A,e){let n=Math.PI/2-Math.atan2(-(e[1]-A[1]),e[0]-A[0]);return h2(n)}var MA=(A,e)=>[[1,0,A],[0,1,e],[0,0,1]];function G(A,e){let n=0;for(let s=0;sM5([...i,1],n)),o=this.calculateLandmarksBoundingBox(s);return k0(O0(o),p2)}getBoxForHandLandmarks(e){let n=this.calculateLandmarksBoundingBox(e),s=k0(O0(n),EA);s.palmLandmarks=[];for(let o=0;o[t[0]*(p[0]-this.inputSize/2),t[1]*(p[1]-this.inputSize/2),t[2]*p[2]]),x=P5(s,[0,0]),l=a.map(p=>[...M5(p,x),p[2]]),d=vA(o),y=[...m0(n),1],u=[G(y,d[0]),G(y,d[1])];return l.map(p=>[p[0]+u[0],p[1]+u[1],p[2]])}async estimateHands(e,n){let s=!1,o;(this.skipped===0||this.skipped>n.hand.skipFrames||!n.hand.landmarks||!n.videoOptimized)&&(o=await this.handDetector.estimateHandBounds(e,n),this.skipped=0),n.videoOptimized&&this.skipped++,o&&o.length>0&&(o.length!==this.detectedHands&&this.detectedHands!==n.hand.maxDetected||!n.hand.landmarks)&&(this.detectedHands=0,this.storedBoxes=[...o],this.storedBoxes.length>0&&(s=!0));let i=[];n.hand.skipInitial&&this.detectedHands===0&&(this.skipped=0);for(let t=0;t=n.hand.minConfidence){let R=r.reshape(M,[-1,3]),j=R.arraySync();M.dispose(),R.dispose();let g=this.transformRawCoords(j,p,x,u),m=this.getBoxForHandLandmarks(g);this.storedBoxes[t]=m;let T={landmarks:g,confidence:z,box:{topLeft:m.startPoint,bottomRight:m.endPoint}};i.push(T)}else this.storedBoxes[t]=null;M.dispose()}else{let x=k0(O0(a),EA),l={confidence:a.confidence,box:{topLeft:x.startPoint,bottomRight:x.endPoint}};i.push(l)}}return this.storedBoxes=this.storedBoxes.filter(t=>t!==null),this.detectedHands=i.length,i}calculateLandmarksBoundingBox(e){let n=e.map(t=>t[0]),s=e.map(t=>t[1]),o=[Math.min(...n),Math.min(...s)],i=[Math.max(...n),Math.max(...s)];return{startPoint:o,endPoint:i}}};var jA={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]},Q,_,SA;async function E5(A,e){let n=await SA.estimateHands(A,e);if(!n)return[];let s=[];for(let o of n){let i={};if(o.landmarks)for(let x of Object.keys(jA))i[x]=jA[x].map(l=>o.landmarks[l]);let t=o.box?[Math.max(0,o.box.topLeft[0]),Math.max(0,o.box.topLeft[1]),Math.min(A.shape[2],o.box.bottomRight[0])-Math.max(0,o.box.topLeft[0]),Math.min(A.shape[1],o.box.bottomRight[1])-Math.max(0,o.box.topLeft[1])]:[],a=[o.box.topLeft[0]/A.shape[2],o.box.topLeft[1]/A.shape[1],(o.box.bottomRight[0]-o.box.topLeft[0])/A.shape[2],(o.box.bottomRight[1]-o.box.topLeft[1])/A.shape[1]];s.push({confidence:Math.round(100*o.confidence)/100,box:t,boxRaw:a,landmarks:o.landmarks,annotations:i})}return s}async function R5(A){!Q||!_?([Q,_]=await Promise.all([A.hand.enabled?r.loadGraphModel(L(A.modelBasePath,A.hand.detector.modelPath),{fromTFHub:A.hand.detector.modelPath.includes("tfhub.dev")}):null,A.hand.landmarks?r.loadGraphModel(L(A.modelBasePath,A.hand.skeleton.modelPath),{fromTFHub:A.hand.skeleton.modelPath.includes("tfhub.dev")}):null]),A.hand.enabled&&(!Q||!Q.modelUrl?b("load model failed:",A.hand.detector.modelPath):A.debug&&b("load model:",Q.modelUrl),!_||!_.modelUrl?b("load model failed:",A.hand.skeleton.modelPath):A.debug&&b("load model:",_.modelUrl))):(A.debug&&b("cached model:",Q.modelUrl),A.debug&&b("cached model:",_.modelUrl));let e=new T5(Q);return SA=new z5(e,_),[Q,_]}var j5={};Y(j5,{load:()=>S5,predict:()=>w5});var wA=["nose","leftEyeInside","leftEye","leftEyeOutside","rightEyeInside","rightEye","rightEyeOutside","leftEar","rightEar","leftMouth","rightMouth","leftShoulder","rightShoulder","leftElbow","rightElbow","leftWrist","rightWrist","leftPalm","rightPalm","leftIndex","rightIndex","leftPinky","rightPinky","leftHip","rightHip","leftKnee","rightKnee","leftAnkle","rightAnkle","leftHeel","rightHeel","leftFoot","rightFoot","midHip","forehead","leftThumb","leftHand","rightThumb","rightHand"],WA=["nose","leftEyeInside","leftEye","leftEyeOutside","rightEyeInside","rightEye","rightEyeOutside","leftEar","rightEar","leftMouth","rightMouth","leftShoulder","rightShoulder","leftElbow","rightElbow","left:15","right:16","left:17","right:18","left:19","right:20","left:21","right:22","leftChest","rightChest","neck","forehead","left:27","right:28","left:29","right:30"];var Z;async function S5(A){return Z?A.debug&&b("cached model:",Z.modelUrl):(Z=await r.loadGraphModel(L(A.modelBasePath,A.body.modelPath)),Z.width=parseInt(Z.signature.inputs["input_1:0"].tensorShape.dim[2].size),Z.height=parseInt(Z.signature.inputs["input_1:0"].tensorShape.dim[1].size),!Z||!Z.modelUrl?b("load model failed:",A.body.modelPath):A.debug&&b("load model:",Z.modelUrl)),Z}async function w5(A,e){if(!Z||!e.body.enabled)return null;let n={width:A.shape[2],height:A.shape[1]},s=r.image.resizeBilinear(A,[Z.width,Z.height],!1),o=r.div(s,[255]);s.dispose();let i=await Z.predict(o),t=i.find(y=>y.size===195||y.size===155).dataSync();i.forEach(y=>y.dispose()),o.dispose();let a=[],x=t.length===195?wA:WA,l=5;for(let y=0;yu.score>y?u.score:y,0),keypoints:a}]}var W5={};Y(W5,{load:()=>I5,predict:()=>k5});var L0=[{class:1,label:"person"},{class:2,label:"bicycle"},{class:3,label:"car"},{class:4,label:"motorcycle"},{class:5,label:"airplane"},{class:6,label:"bus"},{class:7,label:"train"},{class:8,label:"truck"},{class:9,label:"boat"},{class:10,label:"traffic light"},{class:11,label:"fire hydrant"},{class:12,label:"stop sign"},{class:13,label:"parking meter"},{class:14,label:"bench"},{class:15,label:"bird"},{class:16,label:"cat"},{class:17,label:"dog"},{class:18,label:"horse"},{class:19,label:"sheep"},{class:20,label:"cow"},{class:21,label:"elephant"},{class:22,label:"bear"},{class:23,label:"zebra"},{class:24,label:"giraffe"},{class:25,label:"backpack"},{class:26,label:"umbrella"},{class:27,label:"handbag"},{class:28,label:"tie"},{class:29,label:"suitcase"},{class:30,label:"frisbee"},{class:31,label:"skis"},{class:32,label:"snowboard"},{class:33,label:"sports ball"},{class:34,label:"kite"},{class:35,label:"baseball bat"},{class:36,label:"baseball glove"},{class:37,label:"skateboard"},{class:38,label:"surfboard"},{class:39,label:"tennis racket"},{class:40,label:"bottle"},{class:41,label:"wine glass"},{class:42,label:"cup"},{class:43,label:"fork"},{class:44,label:"knife"},{class:45,label:"spoon"},{class:46,label:"bowl"},{class:47,label:"banana"},{class:48,label:"apple"},{class:49,label:"sandwich"},{class:50,label:"orange"},{class:51,label:"broccoli"},{class:52,label:"carrot"},{class:53,label:"hot dog"},{class:54,label:"pizza"},{class:55,label:"donut"},{class:56,label:"cake"},{class:57,label:"chair"},{class:58,label:"couch"},{class:59,label:"potted plant"},{class:60,label:"bed"},{class:61,label:"dining table"},{class:62,label:"toilet"},{class:63,label:"tv"},{class:64,label:"laptop"},{class:65,label:"mouse"},{class:66,label:"remote"},{class:67,label:"keyboard"},{class:68,label:"cell phone"},{class:69,label:"microwave"},{class:70,label:"oven"},{class:71,label:"toaster"},{class:72,label:"sink"},{class:73,label:"refrigerator"},{class:74,label:"book"},{class:75,label:"clock"},{class:76,label:"vase"},{class:77,label:"scissors"},{class:78,label:"teddy bear"},{class:79,label:"hair drier"},{class:80,label:"toothbrush"}];var V,N5=[],Z0=Number.MAX_SAFE_INTEGER,V0=2.5;async function I5(A){if(V)A.debug&&b("cached model:",V.modelUrl);else{V=await r.loadGraphModel(L(A.modelBasePath,A.object.modelPath));let e=Object.values(V.modelSignature.inputs);if(V.inputSize=Array.isArray(e)?parseInt(e[0].tensorShape.dim[2].size):null,!V.inputSize)throw new Error(`Human: Cannot determine model inputSize: ${A.object.modelPath}`);!V||!V.modelUrl?b("load model failed:",A.object.modelPath):A.debug&&b("load model:",V.modelUrl)}return V}async function T2(A,e,n,s){let o=0,i=[];for(let l of[1,2,4])r.tidy(()=>{var h,M;let d=l*13,y=(h=A.find(z=>z.shape[1]===d**2&&z.shape[2]===L0.length))==null?void 0:h.squeeze(),u=(M=A.find(z=>z.shape[1]===d**2&&z.shape[2]s.object.minConfidence&&R!==61){let g=(.5+Math.trunc(z%d))/d,m=(.5+Math.trunc(z/d))/d,T=E[z].map(A0=>A0*(d/l/e)),[v,W]=[g-V0/l*T[0],m-V0/l*T[1]],[O,K]=[g+V0/l*T[2]-v,m+V0/l*T[3]-W],H=[v,W,O,K];H=H.map(A0=>Math.max(0,Math.min(A0,1)));let g0=[H[0]*n[0],H[1]*n[1],H[2]*n[0],H[3]*n[1]],J0={id:o++,strideSize:l,score:Math.round(100*j)/100,class:R+1,label:L0[R].label,center:[Math.trunc(n[0]*g),Math.trunc(n[1]*m)],centerRaw:[g,m],box:g0.map(A0=>Math.trunc(A0)),boxRaw:H};i.push(J0)}}});A.forEach(l=>r.dispose(l));let t=i.map(l=>l.boxRaw),a=i.map(l=>l.score),x=[];if(t&&t.length>0){let l=await r.image.nonMaxSuppressionAsync(t,a,s.object.maxDetected,s.object.iouThreshold,s.object.minConfidence);x=l.dataSync(),r.dispose(l)}return i=i.filter((l,d)=>x.includes(d)).sort((l,d)=>d.score-l.score),i}async function k5(A,e){return V?Z00?(Z0++,N5):(e.videoOptimized?Z0=0:Z0=Number.MAX_SAFE_INTEGER,new Promise(async n=>{let s=[A.shape[2],A.shape[1]],o=r.image.resizeBilinear(A,[V.inputSize,V.inputSize],!1),i=o.div(255),t=i.transpose([0,3,1,2]);i.dispose(),o.dispose();let a;e.object.enabled&&(a=await V.predict(t)),t.dispose();let x=await T2(a,V.inputSize,s,e);N5=x,n(x)})):null}var NA=A=>{if(!A)return[];let e=[];for(let n=0;nx.part==="leftWrist"),o=A[n].keypoints.find(x=>x.part==="rightWrist"),i=A[n].keypoints.find(x=>x.part==="nose");i&&s&&o&&s.position.yx.part==="leftShoulder"),a=A[n].keypoints.find(x=>x.part==="rightShoulder");t&&a&&e.push({body:n,gesture:`leaning ${t.position.y>a.position.y?"left":"right"}`})}return e},IA=A=>{if(!A)return[];let e=[];for(let n=0;n0){let s=A[n].mesh[33][2]-A[n].mesh[263][2];Math.abs(s)<10?e.push({face:n,gesture:"facing center"}):e.push({face:n,gesture:`facing ${s<0?"left":"right"}`}),Math.abs(A[n].mesh[374][1]-A[n].mesh[386][1])/Math.abs(A[n].mesh[443][1]-A[n].mesh[450][1])<.2&&e.push({face:n,gesture:"blink left eye"}),Math.abs(A[n].mesh[145][1]-A[n].mesh[159][1])/Math.abs(A[n].mesh[223][1]-A[n].mesh[230][1])<.2&&e.push({face:n,gesture:"blink right eye"});let t=Math.min(100,500*Math.abs(A[n].mesh[13][1]-A[n].mesh[14][1])/Math.abs(A[n].mesh[10][1]-A[n].mesh[152][1]));t>10&&e.push({face:n,gesture:`mouth ${Math.trunc(t)}% open`});let a=A[n].mesh[152][2];Math.abs(a)>10&&e.push({face:n,gesture:`head ${a<0?"up":"down"}`})}return e},kA=A=>{if(!A)return[];let e=[];for(let n=0;n.033||y>.033)&&(l=!1),u>.033&&e.push({iris:n,gesture:"looking right"}),y>.033&&e.push({iris:n,gesture:"looking left"});let p=Math.abs(A[n].mesh[145][1]-A[n].annotations.rightEyeIris[0][1])/A[n].annotations.rightEyeIris[0][1],E=Math.abs(A[n].mesh[374][1]-A[n].annotations.leftEyeIris[0][1])/A[n].annotations.leftEyeIris[0][1];(E<.015||p<.015||E>.03||p>.03)&&(l=!1),(E<.015||p<.015)&&e.push({iris:n,gesture:"looking down"}),(E>.03||p>.03)&&e.push({iris:n,gesture:"looking up"}),l&&e.push({iris:n,gesture:"looking center"})}return e},OA=A=>{if(!A)return[];let e=[];for(let n=0;n0){let o=s.reduce((t,a)=>t.position[2]t.position[1]L5});function P2(A,e,n){let s=function(a,x,l){let d=new RegExp("\\b"+x+" \\w+ (\\w+)","ig");a.replace(d,(y,u)=>(l[u]=0,y))},o=function(a,x){let l=A.createShader(x);if(A.shaderSource(l,a),A.compileShader(l),!A.getShaderParameter(l,A.COMPILE_STATUS))throw new Error("Filter: GL compile failed",A.getShaderInfoLog(l));return l};this.uniform={},this.attribute={};let i=o(e,A.VERTEX_SHADER),t=o(n,A.FRAGMENT_SHADER);if(this.id=A.createProgram(),A.attachShader(this.id,i),A.attachShader(this.id,t),A.linkProgram(this.id),!A.getProgramParameter(this.id,A.LINK_STATUS))throw new Error("Filter: GL link failed",A.getProgramInfoLog(this.id));A.useProgram(this.id),s(e,"attribute",this.attribute);for(let a in this.attribute)this.attribute[a]=A.getAttribLocation(this.id,a);s(e,"uniform",this.uniform),s(n,"uniform",this.uniform);for(let a in this.uniform)this.uniform[a]=A.getUniformLocation(this.id,a)}function LA(A){A||(A={});let e=0,n=null,s=!1,o=-1,i=[null,null],t=[],a=-1,x=-1,l=null,d=null,y={},u=A.canvas||document.createElement("canvas"),p={},E={INTERMEDIATE:1},c=u.getContext("webgl");if(!c)throw new Error("Filter: getContext() failed");this.addFilter=function(g){let m=Array.prototype.slice.call(arguments,1),T=y[g];t.push({func:T,args:m})},this.reset=function(){t=[]};let h=function(g,m){if(!(g===a&&m===x)){if(u.width=g,a=g,u.height=m,x=m,!l){let T=new Float32Array([-1,-1,0,1,1,-1,1,1,-1,1,0,0,-1,1,0,0,1,-1,1,1,1,1,1,0]);l=c.createBuffer(),c.bindBuffer(c.ARRAY_BUFFER,l),c.bufferData(c.ARRAY_BUFFER,T,c.STATIC_DRAW),c.pixelStorei(c.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!0)}c.viewport(0,0,a,x),i=[null,null]}},M=function(g,m){let T=c.createFramebuffer();c.bindFramebuffer(c.FRAMEBUFFER,T);let v=c.createRenderbuffer();c.bindRenderbuffer(c.RENDERBUFFER,v);let W=c.createTexture();return c.bindTexture(c.TEXTURE_2D,W),c.texImage2D(c.TEXTURE_2D,0,c.RGBA,g,m,0,c.RGBA,c.UNSIGNED_BYTE,null),c.texParameteri(c.TEXTURE_2D,c.TEXTURE_MAG_FILTER,c.LINEAR),c.texParameteri(c.TEXTURE_2D,c.TEXTURE_MIN_FILTER,c.LINEAR),c.texParameteri(c.TEXTURE_2D,c.TEXTURE_WRAP_S,c.CLAMP_TO_EDGE),c.texParameteri(c.TEXTURE_2D,c.TEXTURE_WRAP_T,c.CLAMP_TO_EDGE),c.framebufferTexture2D(c.FRAMEBUFFER,c.COLOR_ATTACHMENT0,c.TEXTURE_2D,W,0),c.bindTexture(c.TEXTURE_2D,null),c.bindFramebuffer(c.FRAMEBUFFER,null),{fbo:T,texture:W}},z=function(g){return i[g]=i[g]||M(a,x),i[g]},R=function(g=null){var W,O;let m=null,T=null,v=!1;e===0?m=n:m=(W=z(o))==null?void 0:W.texture,e++,s&&!(g&E.INTERMEDIATE)?(T=null,v=e%2==0):(o=(o+1)%2,T=(O=z(o))==null?void 0:O.fbo),c.bindTexture(c.TEXTURE_2D,m),c.bindFramebuffer(c.FRAMEBUFFER,T),c.uniform1f(d.uniform.flipY,v?-1:1),c.drawArrays(c.TRIANGLES,0,6)};this.apply=function(g){if(h(g.width,g.height),e=0,n||(n=c.createTexture()),c.bindTexture(c.TEXTURE_2D,n),c.texParameteri(c.TEXTURE_2D,c.TEXTURE_WRAP_S,c.CLAMP_TO_EDGE),c.texParameteri(c.TEXTURE_2D,c.TEXTURE_WRAP_T,c.CLAMP_TO_EDGE),c.texParameteri(c.TEXTURE_2D,c.TEXTURE_MIN_FILTER,c.NEAREST),c.texParameteri(c.TEXTURE_2D,c.TEXTURE_MAG_FILTER,c.NEAREST),c.texImage2D(c.TEXTURE_2D,0,c.RGBA,c.RGBA,c.UNSIGNED_BYTE,g),t.length===0)return R(),u;for(let m=0;m{for(var t in e)F5(A,t,{get:e[t],enumerable:!0})},f=(A,e,t)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of CA(e))!JA.call(A,s)&&s!=="default"&&F5(A,s,{get:()=>e[s],enumerable:!(t=KA(e,s))||t.enumerable});return A};var q5=(A,e,t)=>{if(!e.has(A))throw TypeError("Cannot "+t)};var q=(A,e,t)=>(q5(A,e,"read from private field"),t?t.call(A):e.get(A)),A0=(A,e,t,s)=>(q5(A,e,"write to private field"),s?s.call(A,t):e.set(A,t),t);function O(A,e){let t=A.endsWith("/")?"":"/",o=e.startsWith(".")||e.startsWith("/")||e.startsWith("http:")||e.startsWith("https:")||e.startsWith("file:")?`${e}`:`${A}${t}${e}`;if(!o.toLocaleLowerCase().includes(".json"))throw new Error(`Human: ModelPath Error: ${o} Expecting JSON file`);return o}function b(...A){let e=new Date,t=`${e.getHours().toString().padStart(2,"0")}:${e.getMinutes().toString().padStart(2,"0")}:${e.getSeconds().toString().padStart(2,"0")}.${e.getMilliseconds().toString().padStart(3,"0")}`;A&&console.log(t,"Human:",...A)}var S=()=>typeof performance!="undefined"?performance.now():parseInt((Number(process.hrtime.bigint())/1e3/1e3).toString());function X(...A){let e=t=>t&&typeof t=="object";return A.reduce((t,s)=>(Object.keys(s||{}).forEach(o=>{let i=t[o],n=s[o];Array.isArray(i)&&Array.isArray(n)?t[o]=i.concat(...n):e(i)&&e(n)?t[o]=X(i,n):t[o]=n}),t),{})}function B5(){let A,e;if(typeof navigator!="undefined"){let t=navigator.userAgent.match(/\(([^()]+)\)/g);if(t&&t[0]){let s=t[0].match(/\(([^()]+)\)/g);A=s?s[0].replace(/\(|\)/g,""):"",e=navigator.userAgent.replace(t[0],""),A[1]&&(e=e.replace(t[1],"")),e=e.replace(/ /g," ")}}else typeof process!="undefined"&&(A=`${process.platform} ${process.arch}`,e=`NodeJS ${process.version}`);return{platform:A,agent:e}}var r={};Y(r,{data:()=>_A,version:()=>$A});f(r,I2);f(r,k2);f(r,O2);f(r,L2);f(r,Z2);f(r,V2);import*as U5 from"@tensorflow/tfjs/package.json";import*as Y5 from"@tensorflow/tfjs-core/package.json";import*as J5 from"@tensorflow/tfjs-data/package.json";import*as C5 from"@tensorflow/tfjs-layers/package.json";import*as K5 from"@tensorflow/tfjs-converter/package.json";import{version_cpu as DA}from"@tensorflow/tfjs-backend-cpu/dist/index.js";import{version_webgl as GA}from"@tensorflow/tfjs-backend-webgl/dist/index.js";import{version_wasm as QA}from"@tensorflow/tfjs-backend-wasm/dist/index.js";import*as I2 from"@tensorflow/tfjs-core/dist/index.js";import*as k2 from"@tensorflow/tfjs-layers/dist/index.js";import*as O2 from"@tensorflow/tfjs-converter/dist/index.js";import*as _A from"@tensorflow/tfjs-data/dist/index.js";import*as L2 from"@tensorflow/tfjs-backend-cpu/dist/index.js";import*as Z2 from"@tensorflow/tfjs-backend-webgl/dist/index.js";import*as V2 from"@tensorflow/tfjs-backend-wasm/dist/index.js";var $A={tfjs:(U5==null?void 0:U5.version)||void 0,"tfjs-core":(Y5==null?void 0:Y5.version)||void 0,"tfjs-data":(J5==null?void 0:J5.version)||void 0,"tfjs-layers":(C5==null?void 0:C5.version)||void 0,"tfjs-converter":(K5==null?void 0:K5.version)||void 0,"tfjs-backend-cpu":DA||void 0,"tfjs-backend-webgl":GA||void 0,"tfjs-backend-wasm":QA||void 0};var H={name:"humangl",priority:99,canvas:null,gl:null,width:1024,height:1024,webGLattr:{alpha:!1,antialias:!1,premultipliedAlpha:!1,preserveDrawingBuffer:!1,depth:!1,stencil:!1,failIfMajorPerformanceCaveat:!1,desynchronized:!0}};function D5(){if(!r.findBackend(H.name)){b("backend registration:",H.name);try{H.canvas=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(H.width,H.height):document.createElement("canvas")}catch(A){b("error: cannot create canvas:",A);return}try{H.gl=H.canvas.getContext("webgl2",H.webGLattr)}catch(A){b("error: cannot get WebGL2 context:",A);return}try{r.setWebGLContext(2,H.gl)}catch(A){b("error: cannot set WebGL2 context:",A);return}try{let A=new r.GPGPUContext(H.gl);r.registerBackend(H.name,()=>new r.MathBackendWebGL(A),H.priority)}catch(A){b("error: cannot register WebGL backend:",A);return}try{r.getKernelsForBackend("webgl").forEach(e=>{let t={...e,backendName:H.name};r.registerKernel(t)})}catch(A){b("error: cannot update WebGL backend registration:",A);return}try{r.ENV.set("WEBGL_VERSION",2)}catch(A){b("error: cannot set WebGL backend flags:",A);return}b("backend registered:",H.name)}}var A5={};Y(A5,{load:()=>n5,predict:()=>t5,triangulation:()=>rA,uvmap:()=>aA});function G5(A,e){let t=[A.startPoint[0]*e[0],A.startPoint[1]*e[1]],s=[A.endPoint[0]*e[0],A.endPoint[1]*e[1]];return{startPoint:t,endPoint:s}}function l0(A){return[Math.abs(A.endPoint[0]-A.startPoint[0]),Math.abs(A.endPoint[1]-A.startPoint[1])]}function s0(A){return[A.startPoint[0]+(A.endPoint[0]-A.startPoint[0])/2,A.startPoint[1]+(A.endPoint[1]-A.startPoint[1])/2]}function i0(A,e,t){let s=e.shape[1],o=e.shape[2],i=[[A.startPoint[1]/s,A.startPoint[0]/o,A.endPoint[1]/s,A.endPoint[0]/o]];return r.image.cropAndResize(e,i,[0],t)}function T0(A,e=1.5){let t=s0(A),s=l0(A),o=[e*s[0]/2,e*s[1]/2],i=[t[0]-o[0],t[1]-o[1]],n=[t[0]+o[0],t[1]+o[1]];return{startPoint:i,endPoint:n,landmarks:A.landmarks}}function P0(A){let e=s0(A),t=l0(A),o=Math.max(...t)/2,i=[Math.round(e[0]-o),Math.round(e[1]-o)],n=[Math.round(e[0]+o),Math.round(e[1]+o)];return{startPoint:i,endPoint:n,landmarks:A.landmarks}}function K0(A){let e=A.map(i=>i[0]),t=A.map(i=>i[1]),s=[Math.min(...e),Math.min(...t)],o=[Math.max(...e),Math.max(...t)];return{startPoint:s,endPoint:o,landmarks:A}}var Q5=A=>({startPoint:r.slice(A,[0,0],[-1,2]),endPoint:r.slice(A,[0,2],[-1,2])});var M0=[[1,0,0],[0,1,0],[0,0,1]];function A2(A){return A-2*Math.PI*Math.floor((A+Math.PI)/(2*Math.PI))}function D0(A,e){let t=Math.PI/2-Math.atan2(-(e[1]-A[1]),e[0]-A[0]);return A2(t)}function _5(A,e){return[[1,0,A],[0,1,e],[0,0,1]]}function K(A,e){let t=0;for(let s=0;s{let l=e.resizeBilinear([this.inputSize,this.inputSize]).div(127.5).sub(.5),d=this.model.execute(l),y;if(Array.isArray(d)){let c=d.sort((R,j)=>R.size-j.size),u=r.concat([c[0],c[2]],2),M=r.concat([c[1],c[3]],2);y=r.concat([M,u],1).squeeze(0)}else y=d.squeeze();let h=t2(y,this.anchors,[this.inputSize,this.inputSize]),p=r.slice(y,[0,0],[-1,1]),z=r.sigmoid(p).squeeze().dataSync();return[y,h,z]}),i=await r.image.nonMaxSuppressionAsync(s,o,this.config.face.detector.maxDetected,this.config.face.detector.iouThreshold,this.config.face.detector.minConfidence),n=i.arraySync();i.dispose();let a=[];for(let x=0;xthis.config.face.detector.minConfidence){let d=r.slice(s,[n[x],0],[1,-1]),y=Q5(d);d.dispose();let h=this.anchorsData[n[x]],p=r.tidy(()=>r.slice(t,[n[x],nA-1],[1,-1]).squeeze().reshape([nA,-1]));a.push({box:y,landmarks:p,anchor:h,confidence:l})}}return t.dispose(),s.dispose(),{boxes:a,scaleFactor:[e.shape[2]/this.inputSize,e.shape[1]/this.inputSize]}}};async function sA(A){let e=await r.loadGraphModel(O(A.modelBasePath,A.face.detector.modelPath),{fromTFHub:A.face.detector.modelPath.includes("tfhub.dev")}),t=new oA(e,A);return!e||!e.modelUrl?b("load model failed:",A.face.detector.modelPath):A.debug&&b("load model:",e.modelUrl),t}var J={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]},G0=[{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]}],c0=[[.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]],e0=[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 n2=[127,234,132,58,172,150,149,148,152,377,378,379,397,288,361,454,356,70,63,105,66,107,336,296,334,293,300,168,6,195,4,98,97,2,326,327,33,160,158,133,153,144,362,385,387,263,373,380,57,40,37,0,267,270,287,321,314,17,84,91,78,81,13,311,308,402,14,178],o2=[33,133,362,263,1,62,308,159,145,386,374,6,102,331,2,13,14,70,105,107,336,334,300,54,10,284,50,280,234,454,58,288,152],s2=[33,133,362,263,1,78,308],Q2=n2.map(A=>c0[A]),_2=o2.map(A=>c0[A]),$2=s2.map(A=>c0[A]);var Q0=J.leftEyeLower0,_0=J.rightEyeLower0,r0={leftBounds:[Q0[0],Q0[Q0.length-1]],rightBounds:[_0[0],_0[_0.length-1]]},v0={count:468,mouth:13,symmetryLine:[13,J.midwayBetweenEyes[0]]},iA={leftEye:0,rightEye:1,nose:2,mouth:3,leftEar:4,rightEar:5,symmetryLine:[3,2]},a0={upperCenter:3,lowerCenter:4,index:71,numCoordinates:76};function E0(A,e,t,s){for(let o=0;o[i[0]/this.meshSize*(y[0]-this.meshSize/2),i[1]/this.meshSize*(y[1]-this.meshSize/2),y[2]]),a=s!==0?z0(s,[0,0]):M0,x=s!==0?n.map(y=>[...eA(y,a),y[2]]):n,l=s!==0?AA(o):M0,d=[...s0({startPoint:t.startPoint,endPoint:t.endPoint}),1];return x.map(y=>[Math.round(y[0]+K(d,l[0])),Math.round(y[1]+K(d,l[1])),Math.round(y[2])])}getLeftToRightEyeDepthDifference(e){let t=e[r0.leftBounds[0]][2],s=e[r0.rightBounds[0]][2];return t-s}getEyeBox(e,t,s,o,i=!1){let n=P0(T0(K0([e[s],e[o]]),this.irisEnlarge)),a=l0(n),x=r.image.cropAndResize(t,[[n.startPoint[1]/this.meshSize,n.startPoint[0]/this.meshSize,n.endPoint[1]/this.meshSize,n.endPoint[0]/this.meshSize]],[0],[this.irisSize,this.irisSize]);return i&&r.ENV.flags.IS_BROWSER&&(x=r.image.flipLeftRight(x)),{box:n,boxSize:a,crop:x}}getEyeCoords(e,t,s,o=!1){let i=[];for(let n=0;n{let l=n;return x===2?l=o:x===4&&(l=i),[a[0],a[1],l]})}async predict(e,t){let s=!1,o;if((this.skipped===0||this.skipped>t.face.detector.skipFrames||!t.face.mesh.enabled||!t.videoOptimized)&&(o=await this.boundingBoxDetector.getBoundingBoxes(e),this.skipped=0),t.videoOptimized&&this.skipped++,!t.videoOptimized||o&&o.boxes&&(!t.face.mesh.enabled||o.boxes.length!==this.detectedFaces&&this.detectedFaces!==t.face.detector.maxDetected)){this.storedBoxes=[],this.detectedFaces=0;for(let n of o.boxes)this.storedBoxes.push({startPoint:n.box.startPoint.dataSync(),endPoint:n.box.endPoint.dataSync(),landmarks:n.landmarks,confidence:n.confidence});this.storedBoxes.length>0&&(s=!0)}if(t.face.detector.skipInitial&&this.detectedFaces===0&&(this.skipped=0),s){if(!o||!o.boxes||o.boxes.length===0)return this.storedBoxes=[],this.detectedFaces=0,null;for(let n=0;n{n.box.startPoint.dispose(),n.box.endPoint.dispose(),n.landmarks.dispose()});let i=r.tidy(()=>this.storedBoxes.map((n,a)=>{let x,l=0,d;if(t.face.detector.rotation&&t.face.mesh.enabled&&r.ENV.flags.IS_BROWSER){let[j,g]=n.landmarks.length>=v0.count?v0.symmetryLine:iA.symmetryLine;l=D0(n.landmarks[j],n.landmarks[g]);let m=s0({startPoint:n.startPoint,endPoint:n.endPoint}),T=[m[0]/e.shape[2],m[1]/e.shape[1]],v=r.image.rotateWithOffset(e,l,0,T);d=z0(-l,m),t.face.mesh.enabled?x=i0({startPoint:n.startPoint,endPoint:n.endPoint},v,[this.meshSize,this.meshSize]).div(255):x=i0({startPoint:n.startPoint,endPoint:n.endPoint},v,[this.boxSize,this.boxSize]).div(255)}else{d=M0;let j=e.clone();t.face.mesh.enabled?x=i0({startPoint:n.startPoint,endPoint:n.endPoint},j,[this.meshSize,this.meshSize]).div(255):x=i0({startPoint:n.startPoint,endPoint:n.endPoint},j,[this.boxSize,this.boxSize]).div(255)}if(!t.face.mesh.enabled)return{mesh:[],box:n,faceConfidence:null,boxConfidence:n.confidence,confidence:n.confidence,image:x};let[,y,h]=this.meshDetector.execute(x),p=y.dataSync()[0];if(p=v0.count?v0.symmetryLine:iA.symmetryLine;l=D0(n.landmarks[j],n.landmarks[g]);let m=s0({startPoint:n.startPoint,endPoint:n.endPoint}),T=[m[0]/e.shape[2],m[1]/e.shape[1]],v=r.image.rotateWithOffset(e.toFloat(),l,0,T);d=z0(-l,m),x=i0({startPoint:n.startPoint,endPoint:n.endPoint},v,[this.meshSize,this.meshSize]).div(255)}let E={mesh:u,box:n,faceConfidence:p,boxConfidence:n.confidence,image:x},R=P0(n);return R.confidence=n.confidence,R.faceConfidence=p,this.storedBoxes[a]=R,E}));return t.face.mesh.enabled&&(this.storedBoxes=this.storedBoxes.filter(n=>n.confidence>t.face.detector.minConfidence)),this.detectedFaces=i.length,i}};var I=[null,null,null],e5;async function t5(A,e){let t=await e5.predict(A,e),s=[];for(let o of t||[]){if(!o||o.isDisposedInternal)continue;let i=o.mesh.map(l=>[l[0]/A.shape[2],l[1]/A.shape[1],l[2]/e5.meshSize]),n={};if(o.mesh&&o.mesh.length>0)for(let l of Object.keys(J))n[l]=J[l].map(d=>o.mesh[d]);let a=o.box?[Math.max(0,o.box.startPoint[0]),Math.max(0,o.box.startPoint[1]),Math.min(A.shape[2],o.box.endPoint[0])-Math.max(0,o.box.startPoint[0]),Math.min(A.shape[1],o.box.endPoint[1])-Math.max(0,o.box.startPoint[1])]:0,x=o.box?[o.box.startPoint[0]/A.shape[2],o.box.startPoint[1]/A.shape[1],(o.box.endPoint[0]-o.box.startPoint[0])/A.shape[2],(o.box.endPoint[1]-o.box.startPoint[1])/A.shape[1]]:[];s.push({confidence:Math.round(100*o.faceConfidence||100*o.boxConfidence||0)/100,boxConfidence:Math.round(100*o.boxConfidence)/100,faceConfidence:Math.round(100*o.faceConfidence)/100,box:a,boxRaw:x,mesh:o.mesh,meshRaw:i,annotations:n,image:o.image}),o.coords&&o.coords.dispose()}return s}async function n5(A){return!I[0]&&A.face.enabled||!I[1]&&A.face.mesh.enabled||!I[2]&&A.face.iris.enabled?(I=await Promise.all([!I[0]&&A.face.enabled?sA(A):null,!I[1]&&A.face.mesh.enabled?r.loadGraphModel(O(A.modelBasePath,A.face.mesh.modelPath),{fromTFHub:A.face.mesh.modelPath.includes("tfhub.dev")}):null,!I[2]&&A.face.iris.enabled?r.loadGraphModel(O(A.modelBasePath,A.face.iris.modelPath),{fromTFHub:A.face.iris.modelPath.includes("tfhub.dev")}):null]),A.face.mesh.enabled&&(!I[1]||!I[1].modelUrl?b("load model failed:",A.face.mesh.modelPath):A.debug&&b("load model:",I[1].modelUrl)),A.face.iris.enabled&&(!I[2]||!I[1].modelUrl?b("load model failed:",A.face.iris.modelPath):A.debug&&b("load model:",I[2].modelUrl))):A.debug&&(b("cached model:",I[0].model.modelUrl),b("cached model:",I[1].modelUrl),b("cached model:",I[2].modelUrl)),e5=new $0(I[0],I[1],I[2]),I}var rA=e0,aA=c0;var o5={};Y(o5,{load:()=>r5,predict:()=>j0});var i2=["angry","disgust","fear","happy","sad","surprise","neutral"],U,s5=[],R0=Number.MAX_SAFE_INTEGER,i5=[.2989,.587,.114];async function r5(A){return U?A.debug&&b("cached model:",U.modelUrl):(U=await r.loadGraphModel(O(A.modelBasePath,A.face.emotion.modelPath)),!U||!U.modelUrl?b("load model failed:",A.face.emotion.modelPath):A.debug&&b("load model:",U.modelUrl)),U}async function j0(A,e){return U?R00?(R0++,s5):(e.videoOptimized?R0=0:R0=Number.MAX_SAFE_INTEGER,new Promise(async t=>{let s=r.image.resizeBilinear(A,[U.inputs[0].shape[2],U.inputs[0].shape[1]],!1),[o,i,n]=r.split(s,3,3);s.dispose();let a=r.mul(o,i5[0]),x=r.mul(i,i5[1]),l=r.mul(n,i5[2]);o.dispose(),i.dispose(),n.dispose();let d=r.addN([a,x,l]);a.dispose(),x.dispose(),l.dispose();let y=r.tidy(()=>d.sub(.5).mul(2));d.dispose();let h=[];if(e.face.emotion.enabled){let p=await U.predict(y),z=p.dataSync();r.dispose(p);for(let c=0;ce.face.emotion.minConfidence&&h.push({score:Math.min(.99,Math.trunc(100*z[c])/100),emotion:i2[c]});h.sort((c,u)=>u.score-c.score)}y.dispose(),s5=h,t(h)})):null}var a5={};Y(a5,{enhance:()=>l5,load:()=>x5,match:()=>xA,predict:()=>W0,similarity:()=>y5});var F,S0={age:0},w0=Number.MAX_SAFE_INTEGER;async function x5(A){return F?A.debug&&b("cached model:",F.modelUrl):(F=await r.loadGraphModel(O(A.modelBasePath,A.face.description.modelPath)),!F||!F.modelUrl?b("load model failed:",A.face.description.modelPath):A.debug&&b("load model:",F.modelUrl)),F}function y5(A,e,t=2){if(!A||!e||(A==null?void 0:A.length)===0||(e==null?void 0:e.length)===0||(A==null?void 0:A.length)!==(e==null?void 0:e.length))return 0;let s=5*A.map((i,n)=>Math.abs(A[n]-e[n])**t).reduce((i,n)=>i+n,0)**(1/t);return Math.max(0,100-s)/100}function xA(A,e,t=0){let s={similarity:0,name:"",source:"",embedding:[]};if(!A||!e||!Array.isArray(A)||!Array.isArray(e))return s;for(let o of e)if(o.embedding&&o.name){let i=y5(A,o.embedding);i>t&&i>s.similarity&&(s={...o,similarity:i})}return s}function l5(A){return r.tidy(()=>{let t=A.image||A.tensor||A;if(!(t instanceof r.Tensor))return null;let s=[[.05,.15,.85,.85]];return(t.shape.length===3?r.image.cropAndResize(r.expandDims(t,0),s,[0],[F.inputs[0].shape[2],F.inputs[0].shape[1]]):r.image.cropAndResize(t,s,[0],[F.inputs[0].shape[2],F.inputs[0].shape[1]])).mul(255)})}async function W0(A,e){return F?w00?(w0++,S0):(e.videoOptimized?w0=0:w0=Number.MAX_SAFE_INTEGER,new Promise(async t=>{let s=l5(A),o,i={age:0,gender:"unknown",genderConfidence:0,descriptor:[]};e.face.description.enabled&&(o=await F.predict(s)),r.dispose(s),o&&(r.tidy(()=>{let n=o.find(y=>y.shape[1]===1).dataSync(),a=Math.trunc(200*Math.abs(n[0]-.5))/100;a>e.face.description.minConfidence&&(i.gender=n[0]<=.5?"female":"male",i.genderConfidence=Math.min(.99,a));let x=o.find(y=>y.shape[1]===100).argMax(1).dataSync()[0],l=o.find(y=>y.shape[1]===100).dataSync();i.age=Math.round(l[x-1]>l[x+1]?10*x-100*l[x-1]:10*x+100*l[x+1])/10;let d=o.find(y=>y.shape[1]===1024);i.descriptor=[...d.dataSync()]}),o.forEach(n=>r.dispose(n))),S0=i,t(i)})):null}var r2=(A,e)=>{let t=u=>u*180/Math.PI,s=u=>{let M=Math.sqrt(u[0]*u[0]+u[1]*u[1]+u[2]*u[2]);return u[0]/=M,u[1]/=M,u[2]/=M,u},o=(u,M)=>{let E=u[0]-M[0],R=u[1]-M[1],j=u[2]-M[2];return[E,R,j]},i=(u,M)=>{let E=u[1]*M[2]-u[2]*M[1],R=u[2]*M[0]-u[0]*M[2],j=u[0]*M[1]-u[1]*M[0];return[E,R,j]},n=u=>{let[M,E,R,j,g,m,T,v,w]=u,k,C,V;return j<1?j>-1?(V=Math.asin(j),C=Math.atan2(-T,M),k=Math.atan2(-m,g)):(V=-Math.PI/2,C=-Math.atan2(v,w),k=0):(V=Math.PI/2,C=Math.atan2(v,w),k=0),{pitch:2*-k,yaw:2*-C,roll:2*-V}},a=u=>{let M=(R,j,g,m)=>Math.atan2(m-j,g-R);return{pitch:M(u[10][1],u[10][2],u[152][1],u[152][2]),yaw:M(u[33][0],u[33][2],u[263][0],u[263][2]),roll:M(u[33][0],u[33][1],u[263][0],u[263][1])}},x=A.meshRaw;if(!x||x.length<300)return{angle:{pitch:0,yaw:0,roll:0},matrix:[1,0,0,0,1,0,0,0,1]};let l=Math.max(A.boxRaw[2]*e[0],A.boxRaw[3]*e[1])/1.5,d=[x[10],x[152],x[234],x[454]].map(u=>[u[0]*e[0]/l,u[1]*e[1]/l,u[2]]),y=s(o(d[1],d[0])),h=s(o(d[3],d[2])),p=s(i(h,y));h=i(y,p);let z=[h[0],h[1],h[2],y[0],y[1],y[2],p[0],p[1],p[2]];return{angle:n(z),matrix:z}},c5=async(A,e)=>{var d,y,h,p,z,c;let t,s,o,i,n,a,x=[];A.state="run:face",t=S();let l=await t5(e,A.config);if(A.perf.face=Math.trunc(S()-t),!l)return[];for(let u of l){if(A.analyze("Get Face"),!u.image||u.image.isDisposedInternal){b("Face object is disposed:",u.image);continue}let M=r2(u,[e.shape[2],e.shape[1]]);A.analyze("Start Emotion:"),A.config.async?i=A.config.face.emotion.enabled?j0(u.image,A.config):{}:(A.state="run:emotion",t=S(),i=A.config.face.emotion.enabled?await j0(u.image,A.config):{},A.perf.emotion=Math.trunc(S()-t)),A.analyze("End Emotion:"),A.analyze("Start Description:"),A.config.async?a=A.config.face.description.enabled?W0(u,A.config):[]:(A.state="run:description",t=S(),a=A.config.face.description.enabled?await W0(u.image,A.config):[],A.perf.embedding=Math.trunc(S()-t)),A.analyze("End Description:"),A.config.async&&([s,o,i,n,a]=await Promise.all([s,o,i,n,a])),A.analyze("Finish Face:"),!A.config.face.iris.enabled&&((d=u==null?void 0:u.annotations)==null?void 0:d.leftEyeIris)&&((y=u==null?void 0:u.annotations)==null?void 0:y.rightEyeIris)&&(delete u.annotations.leftEyeIris,delete u.annotations.rightEyeIris);let E=((h=u.annotations)==null?void 0:h.leftEyeIris)&&((p=u.annotations)==null?void 0:p.rightEyeIris)?11.7*Math.max(Math.abs(u.annotations.leftEyeIris[3][0]-u.annotations.leftEyeIris[1][0]),Math.abs(u.annotations.rightEyeIris[4][1]-u.annotations.rightEyeIris[2][1])):0;x.push({...u,age:a.age,gender:a.gender,genderConfidence:a.genderConfidence,embedding:a.descriptor,emotion:i,iris:E!==0?Math.trunc(E)/100:0,rotation:M,tensor:A.config.face.detector.return?(z=u.image)==null?void 0:z.squeeze():null}),(c=u.image)==null||c.dispose(),A.analyze("End Face")}return A.analyze("End FaceMesh:"),A.config.async&&(A.perf.face&&delete A.perf.face,A.perf.age&&delete A.perf.age,A.perf.gender&&delete A.perf.gender,A.perf.emotion&&delete A.perf.emotion),x};var p5={};Y(p5,{load:()=>g5,predict:()=>b5});var d0=["nose","leftEye","rightEye","leftEar","rightEar","leftShoulder","rightShoulder","leftElbow","rightElbow","leftWrist","rightWrist","leftHip","rightHip","leftKnee","rightKnee","leftAnkle","rightAnkle"],yA=d0.length,f0=d0.reduce((A,e,t)=>(A[e]=t,A),{}),a2=[["leftHip","leftShoulder"],["leftElbow","leftShoulder"],["leftElbow","leftWrist"],["leftHip","leftKnee"],["leftKnee","leftAnkle"],["rightHip","rightShoulder"],["rightElbow","rightShoulder"],["rightElbow","rightWrist"],["rightHip","rightKnee"],["rightKnee","rightAnkle"],["leftShoulder","rightShoulder"],["leftHip","rightHip"]],x2=a2.map(([A,e])=>[f0[A],f0[e]]),lA=[["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"]];function cA(A){let e=A.reduce(({maxX:t,maxY:s,minX:o,minY:i},{position:{x:n,y:a}})=>({maxX:Math.max(t,n),maxY:Math.max(s,a),minX:Math.min(o,n),minY:Math.min(i,a)}),{maxX:Number.NEGATIVE_INFINITY,maxY:Number.NEGATIVE_INFINITY,minX:Number.POSITIVE_INFINITY,minY:Number.POSITIVE_INFINITY});return[e.minX,e.minY,e.maxX-e.minX,e.maxY-e.minY]}function dA(A,[e,t],[s,o]){let i=(a,x,l)=>({score:a.score,box:[Math.trunc(a.box[0]*l),Math.trunc(a.box[1]*x),Math.trunc(a.box[2]*l),Math.trunc(a.box[3]*x)],keypoints:a.keypoints.map(({score:d,part:y,position:h})=>({score:d,part:y,position:{x:Math.trunc(h.x*l),y:Math.trunc(h.y*x)}}))});return A.map(a=>i(a,e/s,t/o))}var d5=class{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(){let 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(Math.floor(e/2),e);)this.exchange(e,Math.floor(e/2)),e=Math.floor(e/2)}sink(e){for(;2*e<=this.numberOfElements;){let t=2*e;if(tt?t:A}function fA(A,e,t,s){let o=t-A,i=s-e;return o*o+i*i}function u5(A,e){return{x:A.x+e.x,y:A.y+e.y}}var N0=1,x0=16,y2=50**2;function mA(A,e,t,s,o,i,n=2){let a=M=>({y:i.get(M.y,M.x,A),x:i.get(M.y,M.x,i.shape[2]/2+A)}),x=(M,E,R)=>({y:h5(Math.round(M.y/x0),0,E-1),x:h5(Math.round(M.x/x0),0,R-1)}),[l,d]=s.shape,y=x(e.position,l,d),h=a(y),z=u5(e.position,h);for(let M=0;M[f0[h],f0[p]]),n=i.map(([,h])=>h),a=i.map(([h])=>h),x=e.shape[2],l=n.length,d=new Array(x),y=m5(A.part,x0,t);d[A.part.id]={score:A.score,part:d0[A.part.id],position:y};for(let h=l-1;h>=0;--h){let p=n[h],z=a[h];d[p]&&!d[z]&&(d[z]=mA(h,d[p],z,e,t,o))}for(let h=0;he){a=!1;break}if(!a)break}return a}function d2(A,e){let[t,s,o]=e.shape,i=new d5(t*s*o,({score:n})=>n);for(let n=0;n{let i=o[s].position;return fA(t,e,i.y,i.x)<=y2})}function f2(A,e){return e.reduce((s,{position:o,score:i},n)=>(hA(A,o,n)||(s+=i),s),0)/e.length}function uA(A,e,t,s,o,i){let n=[],a=d2(i,e);for(;n.lengthp.score>i);let y=f2(n,d),h=cA(d);y>i&&n.push({keypoints:d,box:h,score:Math.round(100*y)/100})}return n}var B,m2=["MobilenetV1/offset_2/BiasAdd","MobilenetV1/heatmap_2/BiasAdd","MobilenetV1/displacement_fwd_2/BiasAdd","MobilenetV1/displacement_bwd_2/BiasAdd"];async function b5(A,e){let t=r.tidy(()=>{let a=A.resizeBilinear([B.inputs[0].shape[2],B.inputs[0].shape[1]]).toFloat().div(127.5).sub(1),l=B.execute(a,m2).map(d=>d.squeeze([0]));return l[1]=l[1].sigmoid(),l}),s=await Promise.all(t.map(n=>n.buffer()));for(let n of t)n.dispose();let o=await uA(s[0],s[1],s[2],s[3],e.body.maxDetected,e.body.minConfidence);return dA(o,[A.shape[1],A.shape[2]],[B.inputs[0].shape[2],B.inputs[0].shape[1]])}async function g5(A){return B?A.debug&&b("cached model:",B.modelUrl):(B=await r.loadGraphModel(O(A.modelBasePath,A.body.modelPath)),!B||!B.modelUrl?b("load model failed:",A.body.modelPath):A.debug&&b("load model:",B.modelUrl)),B}var v5={};Y(v5,{load:()=>R5,predict:()=>E5});function I0(A){return[Math.abs(A.endPoint[0]-A.startPoint[0]),Math.abs(A.endPoint[1]-A.startPoint[1])]}function m0(A){return[A.startPoint[0]+(A.endPoint[0]-A.startPoint[0])/2,A.startPoint[1]+(A.endPoint[1]-A.startPoint[1])/2]}function pA(A,e,t){let s=e.shape[1],o=e.shape[2],i=[[A.startPoint[1]/s,A.startPoint[0]/o,A.endPoint[1]/s,A.endPoint[0]/o]];return r.image.cropAndResize(e,i,[0],t)}function bA(A,e){let t=[A.startPoint[0]*e[0],A.startPoint[1]*e[1]],s=[A.endPoint[0]*e[0],A.endPoint[1]*e[1]],o=A.palmLandmarks.map(i=>[i[0]*e[0],i[1]*e[1]]);return{startPoint:t,endPoint:s,palmLandmarks:o,confidence:A.confidence}}function k0(A,e=1.5){let t=m0(A),s=I0(A),o=[e*s[0]/2,e*s[1]/2],i=[t[0]-o[0],t[1]-o[1]],n=[t[0]+o[0],t[1]+o[1]];return{startPoint:i,endPoint:n,palmLandmarks:A.palmLandmarks}}function O0(A){let e=m0(A),t=I0(A),o=Math.max(...t)/2,i=[e[0]-o,e[1]-o],n=[e[0]+o,e[1]+o];return{startPoint:i,endPoint:n,palmLandmarks:A.palmLandmarks}}var gA=[{x:.015625,y:.015625},{x:.015625,y:.015625},{x:.046875,y:.015625},{x:.046875,y:.015625},{x:.078125,y:.015625},{x:.078125,y:.015625},{x:.109375,y:.015625},{x:.109375,y:.015625},{x:.140625,y:.015625},{x:.140625,y:.015625},{x:.171875,y:.015625},{x:.171875,y:.015625},{x:.203125,y:.015625},{x:.203125,y:.015625},{x:.234375,y:.015625},{x:.234375,y:.015625},{x:.265625,y:.015625},{x:.265625,y:.015625},{x:.296875,y:.015625},{x:.296875,y:.015625},{x:.328125,y:.015625},{x:.328125,y:.015625},{x:.359375,y:.015625},{x:.359375,y:.015625},{x:.390625,y:.015625},{x:.390625,y:.015625},{x:.421875,y:.015625},{x:.421875,y:.015625},{x:.453125,y:.015625},{x:.453125,y:.015625},{x:.484375,y:.015625},{x:.484375,y:.015625},{x:.515625,y:.015625},{x:.515625,y:.015625},{x:.546875,y:.015625},{x:.546875,y:.015625},{x:.578125,y:.015625},{x:.578125,y:.015625},{x:.609375,y:.015625},{x:.609375,y:.015625},{x:.640625,y:.015625},{x:.640625,y:.015625},{x:.671875,y:.015625},{x:.671875,y:.015625},{x:.703125,y:.015625},{x:.703125,y:.015625},{x:.734375,y:.015625},{x:.734375,y:.015625},{x:.765625,y:.015625},{x:.765625,y:.015625},{x:.796875,y:.015625},{x:.796875,y:.015625},{x:.828125,y:.015625},{x:.828125,y:.015625},{x:.859375,y:.015625},{x:.859375,y:.015625},{x:.890625,y:.015625},{x:.890625,y:.015625},{x:.921875,y:.015625},{x:.921875,y:.015625},{x:.953125,y:.015625},{x:.953125,y:.015625},{x:.984375,y:.015625},{x:.984375,y:.015625},{x:.015625,y:.046875},{x:.015625,y:.046875},{x:.046875,y:.046875},{x:.046875,y:.046875},{x:.078125,y:.046875},{x:.078125,y:.046875},{x:.109375,y:.046875},{x:.109375,y:.046875},{x:.140625,y:.046875},{x:.140625,y:.046875},{x:.171875,y:.046875},{x:.171875,y:.046875},{x:.203125,y:.046875},{x:.203125,y:.046875},{x:.234375,y:.046875},{x:.234375,y:.046875},{x:.265625,y:.046875},{x:.265625,y:.046875},{x:.296875,y:.046875},{x:.296875,y:.046875},{x:.328125,y:.046875},{x:.328125,y:.046875},{x:.359375,y:.046875},{x:.359375,y:.046875},{x:.390625,y:.046875},{x:.390625,y:.046875},{x:.421875,y:.046875},{x:.421875,y:.046875},{x:.453125,y:.046875},{x:.453125,y:.046875},{x:.484375,y:.046875},{x:.484375,y:.046875},{x:.515625,y:.046875},{x:.515625,y:.046875},{x:.546875,y:.046875},{x:.546875,y:.046875},{x:.578125,y:.046875},{x:.578125,y:.046875},{x:.609375,y:.046875},{x:.609375,y:.046875},{x:.640625,y:.046875},{x:.640625,y:.046875},{x:.671875,y:.046875},{x:.671875,y:.046875},{x:.703125,y:.046875},{x:.703125,y:.046875},{x:.734375,y:.046875},{x:.734375,y:.046875},{x:.765625,y:.046875},{x:.765625,y:.046875},{x:.796875,y:.046875},{x:.796875,y:.046875},{x:.828125,y:.046875},{x:.828125,y:.046875},{x:.859375,y:.046875},{x:.859375,y:.046875},{x:.890625,y:.046875},{x:.890625,y:.046875},{x:.921875,y:.046875},{x:.921875,y:.046875},{x:.953125,y:.046875},{x:.953125,y:.046875},{x:.984375,y:.046875},{x:.984375,y:.046875},{x:.015625,y:.078125},{x:.015625,y:.078125},{x:.046875,y:.078125},{x:.046875,y:.078125},{x:.078125,y:.078125},{x:.078125,y:.078125},{x:.109375,y:.078125},{x:.109375,y:.078125},{x:.140625,y:.078125},{x:.140625,y:.078125},{x:.171875,y:.078125},{x:.171875,y:.078125},{x:.203125,y:.078125},{x:.203125,y:.078125},{x:.234375,y:.078125},{x:.234375,y:.078125},{x:.265625,y:.078125},{x:.265625,y:.078125},{x:.296875,y:.078125},{x:.296875,y:.078125},{x:.328125,y:.078125},{x:.328125,y:.078125},{x:.359375,y:.078125},{x:.359375,y:.078125},{x:.390625,y:.078125},{x:.390625,y:.078125},{x:.421875,y:.078125},{x:.421875,y:.078125},{x:.453125,y:.078125},{x:.453125,y:.078125},{x:.484375,y:.078125},{x:.484375,y:.078125},{x:.515625,y:.078125},{x:.515625,y:.078125},{x:.546875,y:.078125},{x:.546875,y:.078125},{x:.578125,y:.078125},{x:.578125,y:.078125},{x:.609375,y:.078125},{x:.609375,y:.078125},{x:.640625,y:.078125},{x:.640625,y:.078125},{x:.671875,y:.078125},{x:.671875,y:.078125},{x:.703125,y:.078125},{x:.703125,y:.078125},{x:.734375,y:.078125},{x:.734375,y:.078125},{x:.765625,y:.078125},{x:.765625,y:.078125},{x:.796875,y:.078125},{x:.796875,y:.078125},{x:.828125,y:.078125},{x:.828125,y:.078125},{x:.859375,y:.078125},{x:.859375,y:.078125},{x:.890625,y:.078125},{x:.890625,y:.078125},{x:.921875,y:.078125},{x:.921875,y:.078125},{x:.953125,y:.078125},{x:.953125,y:.078125},{x:.984375,y:.078125},{x:.984375,y:.078125},{x:.015625,y:.109375},{x:.015625,y:.109375},{x:.046875,y:.109375},{x:.046875,y:.109375},{x:.078125,y:.109375},{x:.078125,y:.109375},{x:.109375,y:.109375},{x:.109375,y:.109375},{x:.140625,y:.109375},{x:.140625,y:.109375},{x:.171875,y:.109375},{x:.171875,y:.109375},{x:.203125,y:.109375},{x:.203125,y:.109375},{x:.234375,y:.109375},{x:.234375,y:.109375},{x:.265625,y:.109375},{x:.265625,y:.109375},{x:.296875,y:.109375},{x:.296875,y:.109375},{x:.328125,y:.109375},{x:.328125,y:.109375},{x:.359375,y:.109375},{x:.359375,y:.109375},{x:.390625,y:.109375},{x:.390625,y:.109375},{x:.421875,y:.109375},{x:.421875,y:.109375},{x:.453125,y:.109375},{x:.453125,y:.109375},{x:.484375,y:.109375},{x:.484375,y:.109375},{x:.515625,y:.109375},{x:.515625,y:.109375},{x:.546875,y:.109375},{x:.546875,y:.109375},{x:.578125,y:.109375},{x:.578125,y:.109375},{x:.609375,y:.109375},{x:.609375,y:.109375},{x:.640625,y:.109375},{x:.640625,y:.109375},{x:.671875,y:.109375},{x:.671875,y:.109375},{x:.703125,y:.109375},{x:.703125,y:.109375},{x:.734375,y:.109375},{x:.734375,y:.109375},{x:.765625,y:.109375},{x:.765625,y:.109375},{x:.796875,y:.109375},{x:.796875,y:.109375},{x:.828125,y:.109375},{x:.828125,y:.109375},{x:.859375,y:.109375},{x:.859375,y:.109375},{x:.890625,y:.109375},{x:.890625,y:.109375},{x:.921875,y:.109375},{x:.921875,y:.109375},{x:.953125,y:.109375},{x:.953125,y:.109375},{x:.984375,y:.109375},{x:.984375,y:.109375},{x:.015625,y:.140625},{x:.015625,y:.140625},{x:.046875,y:.140625},{x:.046875,y:.140625},{x:.078125,y:.140625},{x:.078125,y:.140625},{x:.109375,y:.140625},{x:.109375,y:.140625},{x:.140625,y:.140625},{x:.140625,y:.140625},{x:.171875,y:.140625},{x:.171875,y:.140625},{x:.203125,y:.140625},{x:.203125,y:.140625},{x:.234375,y:.140625},{x:.234375,y:.140625},{x:.265625,y:.140625},{x:.265625,y:.140625},{x:.296875,y:.140625},{x:.296875,y:.140625},{x:.328125,y:.140625},{x:.328125,y:.140625},{x:.359375,y:.140625},{x:.359375,y:.140625},{x:.390625,y:.140625},{x:.390625,y:.140625},{x:.421875,y:.140625},{x:.421875,y:.140625},{x:.453125,y:.140625},{x:.453125,y:.140625},{x:.484375,y:.140625},{x:.484375,y:.140625},{x:.515625,y:.140625},{x:.515625,y:.140625},{x:.546875,y:.140625},{x:.546875,y:.140625},{x:.578125,y:.140625},{x:.578125,y:.140625},{x:.609375,y:.140625},{x:.609375,y:.140625},{x:.640625,y:.140625},{x:.640625,y:.140625},{x:.671875,y:.140625},{x:.671875,y:.140625},{x:.703125,y:.140625},{x:.703125,y:.140625},{x:.734375,y:.140625},{x:.734375,y:.140625},{x:.765625,y:.140625},{x:.765625,y:.140625},{x:.796875,y:.140625},{x:.796875,y:.140625},{x:.828125,y:.140625},{x:.828125,y:.140625},{x:.859375,y:.140625},{x:.859375,y:.140625},{x:.890625,y:.140625},{x:.890625,y:.140625},{x:.921875,y:.140625},{x:.921875,y:.140625},{x:.953125,y:.140625},{x:.953125,y:.140625},{x:.984375,y:.140625},{x:.984375,y:.140625},{x:.015625,y:.171875},{x:.015625,y:.171875},{x:.046875,y:.171875},{x:.046875,y:.171875},{x:.078125,y:.171875},{x:.078125,y:.171875},{x:.109375,y:.171875},{x:.109375,y:.171875},{x:.140625,y:.171875},{x:.140625,y:.171875},{x:.171875,y:.171875},{x:.171875,y:.171875},{x:.203125,y:.171875},{x:.203125,y:.171875},{x:.234375,y:.171875},{x:.234375,y:.171875},{x:.265625,y:.171875},{x:.265625,y:.171875},{x:.296875,y:.171875},{x:.296875,y:.171875},{x:.328125,y:.171875},{x:.328125,y:.171875},{x:.359375,y:.171875},{x:.359375,y:.171875},{x:.390625,y:.171875},{x:.390625,y:.171875},{x:.421875,y:.171875},{x:.421875,y:.171875},{x:.453125,y:.171875},{x:.453125,y:.171875},{x:.484375,y:.171875},{x:.484375,y:.171875},{x:.515625,y:.171875},{x:.515625,y:.171875},{x:.546875,y:.171875},{x:.546875,y:.171875},{x:.578125,y:.171875},{x:.578125,y:.171875},{x:.609375,y:.171875},{x:.609375,y:.171875},{x:.640625,y:.171875},{x:.640625,y:.171875},{x:.671875,y:.171875},{x:.671875,y:.171875},{x:.703125,y:.171875},{x:.703125,y:.171875},{x:.734375,y:.171875},{x:.734375,y:.171875},{x:.765625,y:.171875},{x:.765625,y:.171875},{x:.796875,y:.171875},{x:.796875,y:.171875},{x:.828125,y:.171875},{x:.828125,y:.171875},{x:.859375,y:.171875},{x:.859375,y:.171875},{x:.890625,y:.171875},{x:.890625,y:.171875},{x:.921875,y:.171875},{x:.921875,y:.171875},{x:.953125,y:.171875},{x:.953125,y:.171875},{x:.984375,y:.171875},{x:.984375,y:.171875},{x:.015625,y:.203125},{x:.015625,y:.203125},{x:.046875,y:.203125},{x:.046875,y:.203125},{x:.078125,y:.203125},{x:.078125,y:.203125},{x:.109375,y:.203125},{x:.109375,y:.203125},{x:.140625,y:.203125},{x:.140625,y:.203125},{x:.171875,y:.203125},{x:.171875,y:.203125},{x:.203125,y:.203125},{x:.203125,y:.203125},{x:.234375,y:.203125},{x:.234375,y:.203125},{x:.265625,y:.203125},{x:.265625,y:.203125},{x:.296875,y:.203125},{x:.296875,y:.203125},{x:.328125,y:.203125},{x:.328125,y:.203125},{x:.359375,y:.203125},{x:.359375,y:.203125},{x:.390625,y:.203125},{x:.390625,y:.203125},{x:.421875,y:.203125},{x:.421875,y:.203125},{x:.453125,y:.203125},{x:.453125,y:.203125},{x:.484375,y:.203125},{x:.484375,y:.203125},{x:.515625,y:.203125},{x:.515625,y:.203125},{x:.546875,y:.203125},{x:.546875,y:.203125},{x:.578125,y:.203125},{x:.578125,y:.203125},{x:.609375,y:.203125},{x:.609375,y:.203125},{x:.640625,y:.203125},{x:.640625,y:.203125},{x:.671875,y:.203125},{x:.671875,y:.203125},{x:.703125,y:.203125},{x:.703125,y:.203125},{x:.734375,y:.203125},{x:.734375,y:.203125},{x:.765625,y:.203125},{x:.765625,y:.203125},{x:.796875,y:.203125},{x:.796875,y:.203125},{x:.828125,y:.203125},{x:.828125,y:.203125},{x:.859375,y:.203125},{x:.859375,y:.203125},{x:.890625,y:.203125},{x:.890625,y:.203125},{x:.921875,y:.203125},{x:.921875,y:.203125},{x:.953125,y:.203125},{x:.953125,y:.203125},{x:.984375,y:.203125},{x:.984375,y:.203125},{x:.015625,y:.234375},{x:.015625,y:.234375},{x:.046875,y:.234375},{x:.046875,y:.234375},{x:.078125,y:.234375},{x:.078125,y:.234375},{x:.109375,y:.234375},{x:.109375,y:.234375},{x:.140625,y:.234375},{x:.140625,y:.234375},{x:.171875,y:.234375},{x:.171875,y:.234375},{x:.203125,y:.234375},{x:.203125,y:.234375},{x:.234375,y:.234375},{x:.234375,y:.234375},{x:.265625,y:.234375},{x:.265625,y:.234375},{x:.296875,y:.234375},{x:.296875,y:.234375},{x:.328125,y:.234375},{x:.328125,y:.234375},{x:.359375,y:.234375},{x:.359375,y:.234375},{x:.390625,y:.234375},{x:.390625,y:.234375},{x:.421875,y:.234375},{x:.421875,y:.234375},{x:.453125,y:.234375},{x:.453125,y:.234375},{x:.484375,y:.234375},{x:.484375,y:.234375},{x:.515625,y:.234375},{x:.515625,y:.234375},{x:.546875,y:.234375},{x:.546875,y:.234375},{x:.578125,y:.234375},{x:.578125,y:.234375},{x:.609375,y:.234375},{x:.609375,y:.234375},{x:.640625,y:.234375},{x:.640625,y:.234375},{x:.671875,y:.234375},{x:.671875,y:.234375},{x:.703125,y:.234375},{x:.703125,y:.234375},{x:.734375,y:.234375},{x:.734375,y:.234375},{x:.765625,y:.234375},{x:.765625,y:.234375},{x:.796875,y:.234375},{x:.796875,y:.234375},{x:.828125,y:.234375},{x:.828125,y:.234375},{x:.859375,y:.234375},{x:.859375,y:.234375},{x:.890625,y:.234375},{x:.890625,y:.234375},{x:.921875,y:.234375},{x:.921875,y:.234375},{x:.953125,y:.234375},{x:.953125,y:.234375},{x:.984375,y:.234375},{x:.984375,y:.234375},{x:.015625,y:.265625},{x:.015625,y:.265625},{x:.046875,y:.265625},{x:.046875,y:.265625},{x:.078125,y:.265625},{x:.078125,y:.265625},{x:.109375,y:.265625},{x:.109375,y:.265625},{x:.140625,y:.265625},{x:.140625,y:.265625},{x:.171875,y:.265625},{x:.171875,y:.265625},{x:.203125,y:.265625},{x:.203125,y:.265625},{x:.234375,y:.265625},{x:.234375,y:.265625},{x:.265625,y:.265625},{x:.265625,y:.265625},{x:.296875,y:.265625},{x:.296875,y:.265625},{x:.328125,y:.265625},{x:.328125,y:.265625},{x:.359375,y:.265625},{x:.359375,y:.265625},{x:.390625,y:.265625},{x:.390625,y:.265625},{x:.421875,y:.265625},{x:.421875,y:.265625},{x:.453125,y:.265625},{x:.453125,y:.265625},{x:.484375,y:.265625},{x:.484375,y:.265625},{x:.515625,y:.265625},{x:.515625,y:.265625},{x:.546875,y:.265625},{x:.546875,y:.265625},{x:.578125,y:.265625},{x:.578125,y:.265625},{x:.609375,y:.265625},{x:.609375,y:.265625},{x:.640625,y:.265625},{x:.640625,y:.265625},{x:.671875,y:.265625},{x:.671875,y:.265625},{x:.703125,y:.265625},{x:.703125,y:.265625},{x:.734375,y:.265625},{x:.734375,y:.265625},{x:.765625,y:.265625},{x:.765625,y:.265625},{x:.796875,y:.265625},{x:.796875,y:.265625},{x:.828125,y:.265625},{x:.828125,y:.265625},{x:.859375,y:.265625},{x:.859375,y:.265625},{x:.890625,y:.265625},{x:.890625,y:.265625},{x:.921875,y:.265625},{x:.921875,y:.265625},{x:.953125,y:.265625},{x:.953125,y:.265625},{x:.984375,y:.265625},{x:.984375,y:.265625},{x:.015625,y:.296875},{x:.015625,y:.296875},{x:.046875,y:.296875},{x:.046875,y:.296875},{x:.078125,y:.296875},{x:.078125,y:.296875},{x:.109375,y:.296875},{x:.109375,y:.296875},{x:.140625,y:.296875},{x:.140625,y:.296875},{x:.171875,y:.296875},{x:.171875,y:.296875},{x:.203125,y:.296875},{x:.203125,y:.296875},{x:.234375,y:.296875},{x:.234375,y:.296875},{x:.265625,y:.296875},{x:.265625,y:.296875},{x:.296875,y:.296875},{x:.296875,y:.296875},{x:.328125,y:.296875},{x:.328125,y:.296875},{x:.359375,y:.296875},{x:.359375,y:.296875},{x:.390625,y:.296875},{x:.390625,y:.296875},{x:.421875,y:.296875},{x:.421875,y:.296875},{x:.453125,y:.296875},{x:.453125,y:.296875},{x:.484375,y:.296875},{x:.484375,y:.296875},{x:.515625,y:.296875},{x:.515625,y:.296875},{x:.546875,y:.296875},{x:.546875,y:.296875},{x:.578125,y:.296875},{x:.578125,y:.296875},{x:.609375,y:.296875},{x:.609375,y:.296875},{x:.640625,y:.296875},{x:.640625,y:.296875},{x:.671875,y:.296875},{x:.671875,y:.296875},{x:.703125,y:.296875},{x:.703125,y:.296875},{x:.734375,y:.296875},{x:.734375,y:.296875},{x:.765625,y:.296875},{x:.765625,y:.296875},{x:.796875,y:.296875},{x:.796875,y:.296875},{x:.828125,y:.296875},{x:.828125,y:.296875},{x:.859375,y:.296875},{x:.859375,y:.296875},{x:.890625,y:.296875},{x:.890625,y:.296875},{x:.921875,y:.296875},{x:.921875,y:.296875},{x:.953125,y:.296875},{x:.953125,y:.296875},{x:.984375,y:.296875},{x:.984375,y:.296875},{x:.015625,y:.328125},{x:.015625,y:.328125},{x:.046875,y:.328125},{x:.046875,y:.328125},{x:.078125,y:.328125},{x:.078125,y:.328125},{x:.109375,y:.328125},{x:.109375,y:.328125},{x:.140625,y:.328125},{x:.140625,y:.328125},{x:.171875,y:.328125},{x:.171875,y:.328125},{x:.203125,y:.328125},{x:.203125,y:.328125},{x:.234375,y:.328125},{x:.234375,y:.328125},{x:.265625,y:.328125},{x:.265625,y:.328125},{x:.296875,y:.328125},{x:.296875,y:.328125},{x:.328125,y:.328125},{x:.328125,y:.328125},{x:.359375,y:.328125},{x:.359375,y:.328125},{x:.390625,y:.328125},{x:.390625,y:.328125},{x:.421875,y:.328125},{x:.421875,y:.328125},{x:.453125,y:.328125},{x:.453125,y:.328125},{x:.484375,y:.328125},{x:.484375,y:.328125},{x:.515625,y:.328125},{x:.515625,y:.328125},{x:.546875,y:.328125},{x:.546875,y:.328125},{x:.578125,y:.328125},{x:.578125,y:.328125},{x:.609375,y:.328125},{x:.609375,y:.328125},{x:.640625,y:.328125},{x:.640625,y:.328125},{x:.671875,y:.328125},{x:.671875,y:.328125},{x:.703125,y:.328125},{x:.703125,y:.328125},{x:.734375,y:.328125},{x:.734375,y:.328125},{x:.765625,y:.328125},{x:.765625,y:.328125},{x:.796875,y:.328125},{x:.796875,y:.328125},{x:.828125,y:.328125},{x:.828125,y:.328125},{x:.859375,y:.328125},{x:.859375,y:.328125},{x:.890625,y:.328125},{x:.890625,y:.328125},{x:.921875,y:.328125},{x:.921875,y:.328125},{x:.953125,y:.328125},{x:.953125,y:.328125},{x:.984375,y:.328125},{x:.984375,y:.328125},{x:.015625,y:.359375},{x:.015625,y:.359375},{x:.046875,y:.359375},{x:.046875,y:.359375},{x:.078125,y:.359375},{x:.078125,y:.359375},{x:.109375,y:.359375},{x:.109375,y:.359375},{x:.140625,y:.359375},{x:.140625,y:.359375},{x:.171875,y:.359375},{x:.171875,y:.359375},{x:.203125,y:.359375},{x:.203125,y:.359375},{x:.234375,y:.359375},{x:.234375,y:.359375},{x:.265625,y:.359375},{x:.265625,y:.359375},{x:.296875,y:.359375},{x:.296875,y:.359375},{x:.328125,y:.359375},{x:.328125,y:.359375},{x:.359375,y:.359375},{x:.359375,y:.359375},{x:.390625,y:.359375},{x:.390625,y:.359375},{x:.421875,y:.359375},{x:.421875,y:.359375},{x:.453125,y:.359375},{x:.453125,y:.359375},{x:.484375,y:.359375},{x:.484375,y:.359375},{x:.515625,y:.359375},{x:.515625,y:.359375},{x:.546875,y:.359375},{x:.546875,y:.359375},{x:.578125,y:.359375},{x:.578125,y:.359375},{x:.609375,y:.359375},{x:.609375,y:.359375},{x:.640625,y:.359375},{x:.640625,y:.359375},{x:.671875,y:.359375},{x:.671875,y:.359375},{x:.703125,y:.359375},{x:.703125,y:.359375},{x:.734375,y:.359375},{x:.734375,y:.359375},{x:.765625,y:.359375},{x:.765625,y:.359375},{x:.796875,y:.359375},{x:.796875,y:.359375},{x:.828125,y:.359375},{x:.828125,y:.359375},{x:.859375,y:.359375},{x:.859375,y:.359375},{x:.890625,y:.359375},{x:.890625,y:.359375},{x:.921875,y:.359375},{x:.921875,y:.359375},{x:.953125,y:.359375},{x:.953125,y:.359375},{x:.984375,y:.359375},{x:.984375,y:.359375},{x:.015625,y:.390625},{x:.015625,y:.390625},{x:.046875,y:.390625},{x:.046875,y:.390625},{x:.078125,y:.390625},{x:.078125,y:.390625},{x:.109375,y:.390625},{x:.109375,y:.390625},{x:.140625,y:.390625},{x:.140625,y:.390625},{x:.171875,y:.390625},{x:.171875,y:.390625},{x:.203125,y:.390625},{x:.203125,y:.390625},{x:.234375,y:.390625},{x:.234375,y:.390625},{x:.265625,y:.390625},{x:.265625,y:.390625},{x:.296875,y:.390625},{x:.296875,y:.390625},{x:.328125,y:.390625},{x:.328125,y:.390625},{x:.359375,y:.390625},{x:.359375,y:.390625},{x:.390625,y:.390625},{x:.390625,y:.390625},{x:.421875,y:.390625},{x:.421875,y:.390625},{x:.453125,y:.390625},{x:.453125,y:.390625},{x:.484375,y:.390625},{x:.484375,y:.390625},{x:.515625,y:.390625},{x:.515625,y:.390625},{x:.546875,y:.390625},{x:.546875,y:.390625},{x:.578125,y:.390625},{x:.578125,y:.390625},{x:.609375,y:.390625},{x:.609375,y:.390625},{x:.640625,y:.390625},{x:.640625,y:.390625},{x:.671875,y:.390625},{x:.671875,y:.390625},{x:.703125,y:.390625},{x:.703125,y:.390625},{x:.734375,y:.390625},{x:.734375,y:.390625},{x:.765625,y:.390625},{x:.765625,y:.390625},{x:.796875,y:.390625},{x:.796875,y:.390625},{x:.828125,y:.390625},{x:.828125,y:.390625},{x:.859375,y:.390625},{x:.859375,y:.390625},{x:.890625,y:.390625},{x:.890625,y:.390625},{x:.921875,y:.390625},{x:.921875,y:.390625},{x:.953125,y:.390625},{x:.953125,y:.390625},{x:.984375,y:.390625},{x:.984375,y:.390625},{x:.015625,y:.421875},{x:.015625,y:.421875},{x:.046875,y:.421875},{x:.046875,y:.421875},{x:.078125,y:.421875},{x:.078125,y:.421875},{x:.109375,y:.421875},{x:.109375,y:.421875},{x:.140625,y:.421875},{x:.140625,y:.421875},{x:.171875,y:.421875},{x:.171875,y:.421875},{x:.203125,y:.421875},{x:.203125,y:.421875},{x:.234375,y:.421875},{x:.234375,y:.421875},{x:.265625,y:.421875},{x:.265625,y:.421875},{x:.296875,y:.421875},{x:.296875,y:.421875},{x:.328125,y:.421875},{x:.328125,y:.421875},{x:.359375,y:.421875},{x:.359375,y:.421875},{x:.390625,y:.421875},{x:.390625,y:.421875},{x:.421875,y:.421875},{x:.421875,y:.421875},{x:.453125,y:.421875},{x:.453125,y:.421875},{x:.484375,y:.421875},{x:.484375,y:.421875},{x:.515625,y:.421875},{x:.515625,y:.421875},{x:.546875,y:.421875},{x:.546875,y:.421875},{x:.578125,y:.421875},{x:.578125,y:.421875},{x:.609375,y:.421875},{x:.609375,y:.421875},{x:.640625,y:.421875},{x:.640625,y:.421875},{x:.671875,y:.421875},{x:.671875,y:.421875},{x:.703125,y:.421875},{x:.703125,y:.421875},{x:.734375,y:.421875},{x:.734375,y:.421875},{x:.765625,y:.421875},{x:.765625,y:.421875},{x:.796875,y:.421875},{x:.796875,y:.421875},{x:.828125,y:.421875},{x:.828125,y:.421875},{x:.859375,y:.421875},{x:.859375,y:.421875},{x:.890625,y:.421875},{x:.890625,y:.421875},{x:.921875,y:.421875},{x:.921875,y:.421875},{x:.953125,y:.421875},{x:.953125,y:.421875},{x:.984375,y:.421875},{x:.984375,y:.421875},{x:.015625,y:.453125},{x:.015625,y:.453125},{x:.046875,y:.453125},{x:.046875,y:.453125},{x:.078125,y:.453125},{x:.078125,y:.453125},{x:.109375,y:.453125},{x:.109375,y:.453125},{x:.140625,y:.453125},{x:.140625,y:.453125},{x:.171875,y:.453125},{x:.171875,y:.453125},{x:.203125,y:.453125},{x:.203125,y:.453125},{x:.234375,y:.453125},{x:.234375,y:.453125},{x:.265625,y:.453125},{x:.265625,y:.453125},{x:.296875,y:.453125},{x:.296875,y:.453125},{x:.328125,y:.453125},{x:.328125,y:.453125},{x:.359375,y:.453125},{x:.359375,y:.453125},{x:.390625,y:.453125},{x:.390625,y:.453125},{x:.421875,y:.453125},{x:.421875,y:.453125},{x:.453125,y:.453125},{x:.453125,y:.453125},{x:.484375,y:.453125},{x:.484375,y:.453125},{x:.515625,y:.453125},{x:.515625,y:.453125},{x:.546875,y:.453125},{x:.546875,y:.453125},{x:.578125,y:.453125},{x:.578125,y:.453125},{x:.609375,y:.453125},{x:.609375,y:.453125},{x:.640625,y:.453125},{x:.640625,y:.453125},{x:.671875,y:.453125},{x:.671875,y:.453125},{x:.703125,y:.453125},{x:.703125,y:.453125},{x:.734375,y:.453125},{x:.734375,y:.453125},{x:.765625,y:.453125},{x:.765625,y:.453125},{x:.796875,y:.453125},{x:.796875,y:.453125},{x:.828125,y:.453125},{x:.828125,y:.453125},{x:.859375,y:.453125},{x:.859375,y:.453125},{x:.890625,y:.453125},{x:.890625,y:.453125},{x:.921875,y:.453125},{x:.921875,y:.453125},{x:.953125,y:.453125},{x:.953125,y:.453125},{x:.984375,y:.453125},{x:.984375,y:.453125},{x:.015625,y:.484375},{x:.015625,y:.484375},{x:.046875,y:.484375},{x:.046875,y:.484375},{x:.078125,y:.484375},{x:.078125,y:.484375},{x:.109375,y:.484375},{x:.109375,y:.484375},{x:.140625,y:.484375},{x:.140625,y:.484375},{x:.171875,y:.484375},{x:.171875,y:.484375},{x:.203125,y:.484375},{x:.203125,y:.484375},{x:.234375,y:.484375},{x:.234375,y:.484375},{x:.265625,y:.484375},{x:.265625,y:.484375},{x:.296875,y:.484375},{x:.296875,y:.484375},{x:.328125,y:.484375},{x:.328125,y:.484375},{x:.359375,y:.484375},{x:.359375,y:.484375},{x:.390625,y:.484375},{x:.390625,y:.484375},{x:.421875,y:.484375},{x:.421875,y:.484375},{x:.453125,y:.484375},{x:.453125,y:.484375},{x:.484375,y:.484375},{x:.484375,y:.484375},{x:.515625,y:.484375},{x:.515625,y:.484375},{x:.546875,y:.484375},{x:.546875,y:.484375},{x:.578125,y:.484375},{x:.578125,y:.484375},{x:.609375,y:.484375},{x:.609375,y:.484375},{x:.640625,y:.484375},{x:.640625,y:.484375},{x:.671875,y:.484375},{x:.671875,y:.484375},{x:.703125,y:.484375},{x:.703125,y:.484375},{x:.734375,y:.484375},{x:.734375,y:.484375},{x:.765625,y:.484375},{x:.765625,y:.484375},{x:.796875,y:.484375},{x:.796875,y:.484375},{x:.828125,y:.484375},{x:.828125,y:.484375},{x:.859375,y:.484375},{x:.859375,y:.484375},{x:.890625,y:.484375},{x:.890625,y:.484375},{x:.921875,y:.484375},{x:.921875,y:.484375},{x:.953125,y:.484375},{x:.953125,y:.484375},{x:.984375,y:.484375},{x:.984375,y:.484375},{x:.015625,y:.515625},{x:.015625,y:.515625},{x:.046875,y:.515625},{x:.046875,y:.515625},{x:.078125,y:.515625},{x:.078125,y:.515625},{x:.109375,y:.515625},{x:.109375,y:.515625},{x:.140625,y:.515625},{x:.140625,y:.515625},{x:.171875,y:.515625},{x:.171875,y:.515625},{x:.203125,y:.515625},{x:.203125,y:.515625},{x:.234375,y:.515625},{x:.234375,y:.515625},{x:.265625,y:.515625},{x:.265625,y:.515625},{x:.296875,y:.515625},{x:.296875,y:.515625},{x:.328125,y:.515625},{x:.328125,y:.515625},{x:.359375,y:.515625},{x:.359375,y:.515625},{x:.390625,y:.515625},{x:.390625,y:.515625},{x:.421875,y:.515625},{x:.421875,y:.515625},{x:.453125,y:.515625},{x:.453125,y:.515625},{x:.484375,y:.515625},{x:.484375,y:.515625},{x:.515625,y:.515625},{x:.515625,y:.515625},{x:.546875,y:.515625},{x:.546875,y:.515625},{x:.578125,y:.515625},{x:.578125,y:.515625},{x:.609375,y:.515625},{x:.609375,y:.515625},{x:.640625,y:.515625},{x:.640625,y:.515625},{x:.671875,y:.515625},{x:.671875,y:.515625},{x:.703125,y:.515625},{x:.703125,y:.515625},{x:.734375,y:.515625},{x:.734375,y:.515625},{x:.765625,y:.515625},{x:.765625,y:.515625},{x:.796875,y:.515625},{x:.796875,y:.515625},{x:.828125,y:.515625},{x:.828125,y:.515625},{x:.859375,y:.515625},{x:.859375,y:.515625},{x:.890625,y:.515625},{x:.890625,y:.515625},{x:.921875,y:.515625},{x:.921875,y:.515625},{x:.953125,y:.515625},{x:.953125,y:.515625},{x:.984375,y:.515625},{x:.984375,y:.515625},{x:.015625,y:.546875},{x:.015625,y:.546875},{x:.046875,y:.546875},{x:.046875,y:.546875},{x:.078125,y:.546875},{x:.078125,y:.546875},{x:.109375,y:.546875},{x:.109375,y:.546875},{x:.140625,y:.546875},{x:.140625,y:.546875},{x:.171875,y:.546875},{x:.171875,y:.546875},{x:.203125,y:.546875},{x:.203125,y:.546875},{x:.234375,y:.546875},{x:.234375,y:.546875},{x:.265625,y:.546875},{x:.265625,y:.546875},{x:.296875,y:.546875},{x:.296875,y:.546875},{x:.328125,y:.546875},{x:.328125,y:.546875},{x:.359375,y:.546875},{x:.359375,y:.546875},{x:.390625,y:.546875},{x:.390625,y:.546875},{x:.421875,y:.546875},{x:.421875,y:.546875},{x:.453125,y:.546875},{x:.453125,y:.546875},{x:.484375,y:.546875},{x:.484375,y:.546875},{x:.515625,y:.546875},{x:.515625,y:.546875},{x:.546875,y:.546875},{x:.546875,y:.546875},{x:.578125,y:.546875},{x:.578125,y:.546875},{x:.609375,y:.546875},{x:.609375,y:.546875},{x:.640625,y:.546875},{x:.640625,y:.546875},{x:.671875,y:.546875},{x:.671875,y:.546875},{x:.703125,y:.546875},{x:.703125,y:.546875},{x:.734375,y:.546875},{x:.734375,y:.546875},{x:.765625,y:.546875},{x:.765625,y:.546875},{x:.796875,y:.546875},{x:.796875,y:.546875},{x:.828125,y:.546875},{x:.828125,y:.546875},{x:.859375,y:.546875},{x:.859375,y:.546875},{x:.890625,y:.546875},{x:.890625,y:.546875},{x:.921875,y:.546875},{x:.921875,y:.546875},{x:.953125,y:.546875},{x:.953125,y:.546875},{x:.984375,y:.546875},{x:.984375,y:.546875},{x:.015625,y:.578125},{x:.015625,y:.578125},{x:.046875,y:.578125},{x:.046875,y:.578125},{x:.078125,y:.578125},{x:.078125,y:.578125},{x:.109375,y:.578125},{x:.109375,y:.578125},{x:.140625,y:.578125},{x:.140625,y:.578125},{x:.171875,y:.578125},{x:.171875,y:.578125},{x:.203125,y:.578125},{x:.203125,y:.578125},{x:.234375,y:.578125},{x:.234375,y:.578125},{x:.265625,y:.578125},{x:.265625,y:.578125},{x:.296875,y:.578125},{x:.296875,y:.578125},{x:.328125,y:.578125},{x:.328125,y:.578125},{x:.359375,y:.578125},{x:.359375,y:.578125},{x:.390625,y:.578125},{x:.390625,y:.578125},{x:.421875,y:.578125},{x:.421875,y:.578125},{x:.453125,y:.578125},{x:.453125,y:.578125},{x:.484375,y:.578125},{x:.484375,y:.578125},{x:.515625,y:.578125},{x:.515625,y:.578125},{x:.546875,y:.578125},{x:.546875,y:.578125},{x:.578125,y:.578125},{x:.578125,y:.578125},{x:.609375,y:.578125},{x:.609375,y:.578125},{x:.640625,y:.578125},{x:.640625,y:.578125},{x:.671875,y:.578125},{x:.671875,y:.578125},{x:.703125,y:.578125},{x:.703125,y:.578125},{x:.734375,y:.578125},{x:.734375,y:.578125},{x:.765625,y:.578125},{x:.765625,y:.578125},{x:.796875,y:.578125},{x:.796875,y:.578125},{x:.828125,y:.578125},{x:.828125,y:.578125},{x:.859375,y:.578125},{x:.859375,y:.578125},{x:.890625,y:.578125},{x:.890625,y:.578125},{x:.921875,y:.578125},{x:.921875,y:.578125},{x:.953125,y:.578125},{x:.953125,y:.578125},{x:.984375,y:.578125},{x:.984375,y:.578125},{x:.015625,y:.609375},{x:.015625,y:.609375},{x:.046875,y:.609375},{x:.046875,y:.609375},{x:.078125,y:.609375},{x:.078125,y:.609375},{x:.109375,y:.609375},{x:.109375,y:.609375},{x:.140625,y:.609375},{x:.140625,y:.609375},{x:.171875,y:.609375},{x:.171875,y:.609375},{x:.203125,y:.609375},{x:.203125,y:.609375},{x:.234375,y:.609375},{x:.234375,y:.609375},{x:.265625,y:.609375},{x:.265625,y:.609375},{x:.296875,y:.609375},{x:.296875,y:.609375},{x:.328125,y:.609375},{x:.328125,y:.609375},{x:.359375,y:.609375},{x:.359375,y:.609375},{x:.390625,y:.609375},{x:.390625,y:.609375},{x:.421875,y:.609375},{x:.421875,y:.609375},{x:.453125,y:.609375},{x:.453125,y:.609375},{x:.484375,y:.609375},{x:.484375,y:.609375},{x:.515625,y:.609375},{x:.515625,y:.609375},{x:.546875,y:.609375},{x:.546875,y:.609375},{x:.578125,y:.609375},{x:.578125,y:.609375},{x:.609375,y:.609375},{x:.609375,y:.609375},{x:.640625,y:.609375},{x:.640625,y:.609375},{x:.671875,y:.609375},{x:.671875,y:.609375},{x:.703125,y:.609375},{x:.703125,y:.609375},{x:.734375,y:.609375},{x:.734375,y:.609375},{x:.765625,y:.609375},{x:.765625,y:.609375},{x:.796875,y:.609375},{x:.796875,y:.609375},{x:.828125,y:.609375},{x:.828125,y:.609375},{x:.859375,y:.609375},{x:.859375,y:.609375},{x:.890625,y:.609375},{x:.890625,y:.609375},{x:.921875,y:.609375},{x:.921875,y:.609375},{x:.953125,y:.609375},{x:.953125,y:.609375},{x:.984375,y:.609375},{x:.984375,y:.609375},{x:.015625,y:.640625},{x:.015625,y:.640625},{x:.046875,y:.640625},{x:.046875,y:.640625},{x:.078125,y:.640625},{x:.078125,y:.640625},{x:.109375,y:.640625},{x:.109375,y:.640625},{x:.140625,y:.640625},{x:.140625,y:.640625},{x:.171875,y:.640625},{x:.171875,y:.640625},{x:.203125,y:.640625},{x:.203125,y:.640625},{x:.234375,y:.640625},{x:.234375,y:.640625},{x:.265625,y:.640625},{x:.265625,y:.640625},{x:.296875,y:.640625},{x:.296875,y:.640625},{x:.328125,y:.640625},{x:.328125,y:.640625},{x:.359375,y:.640625},{x:.359375,y:.640625},{x:.390625,y:.640625},{x:.390625,y:.640625},{x:.421875,y:.640625},{x:.421875,y:.640625},{x:.453125,y:.640625},{x:.453125,y:.640625},{x:.484375,y:.640625},{x:.484375,y:.640625},{x:.515625,y:.640625},{x:.515625,y:.640625},{x:.546875,y:.640625},{x:.546875,y:.640625},{x:.578125,y:.640625},{x:.578125,y:.640625},{x:.609375,y:.640625},{x:.609375,y:.640625},{x:.640625,y:.640625},{x:.640625,y:.640625},{x:.671875,y:.640625},{x:.671875,y:.640625},{x:.703125,y:.640625},{x:.703125,y:.640625},{x:.734375,y:.640625},{x:.734375,y:.640625},{x:.765625,y:.640625},{x:.765625,y:.640625},{x:.796875,y:.640625},{x:.796875,y:.640625},{x:.828125,y:.640625},{x:.828125,y:.640625},{x:.859375,y:.640625},{x:.859375,y:.640625},{x:.890625,y:.640625},{x:.890625,y:.640625},{x:.921875,y:.640625},{x:.921875,y:.640625},{x:.953125,y:.640625},{x:.953125,y:.640625},{x:.984375,y:.640625},{x:.984375,y:.640625},{x:.015625,y:.671875},{x:.015625,y:.671875},{x:.046875,y:.671875},{x:.046875,y:.671875},{x:.078125,y:.671875},{x:.078125,y:.671875},{x:.109375,y:.671875},{x:.109375,y:.671875},{x:.140625,y:.671875},{x:.140625,y:.671875},{x:.171875,y:.671875},{x:.171875,y:.671875},{x:.203125,y:.671875},{x:.203125,y:.671875},{x:.234375,y:.671875},{x:.234375,y:.671875},{x:.265625,y:.671875},{x:.265625,y:.671875},{x:.296875,y:.671875},{x:.296875,y:.671875},{x:.328125,y:.671875},{x:.328125,y:.671875},{x:.359375,y:.671875},{x:.359375,y:.671875},{x:.390625,y:.671875},{x:.390625,y:.671875},{x:.421875,y:.671875},{x:.421875,y:.671875},{x:.453125,y:.671875},{x:.453125,y:.671875},{x:.484375,y:.671875},{x:.484375,y:.671875},{x:.515625,y:.671875},{x:.515625,y:.671875},{x:.546875,y:.671875},{x:.546875,y:.671875},{x:.578125,y:.671875},{x:.578125,y:.671875},{x:.609375,y:.671875},{x:.609375,y:.671875},{x:.640625,y:.671875},{x:.640625,y:.671875},{x:.671875,y:.671875},{x:.671875,y:.671875},{x:.703125,y:.671875},{x:.703125,y:.671875},{x:.734375,y:.671875},{x:.734375,y:.671875},{x:.765625,y:.671875},{x:.765625,y:.671875},{x:.796875,y:.671875},{x:.796875,y:.671875},{x:.828125,y:.671875},{x:.828125,y:.671875},{x:.859375,y:.671875},{x:.859375,y:.671875},{x:.890625,y:.671875},{x:.890625,y:.671875},{x:.921875,y:.671875},{x:.921875,y:.671875},{x:.953125,y:.671875},{x:.953125,y:.671875},{x:.984375,y:.671875},{x:.984375,y:.671875},{x:.015625,y:.703125},{x:.015625,y:.703125},{x:.046875,y:.703125},{x:.046875,y:.703125},{x:.078125,y:.703125},{x:.078125,y:.703125},{x:.109375,y:.703125},{x:.109375,y:.703125},{x:.140625,y:.703125},{x:.140625,y:.703125},{x:.171875,y:.703125},{x:.171875,y:.703125},{x:.203125,y:.703125},{x:.203125,y:.703125},{x:.234375,y:.703125},{x:.234375,y:.703125},{x:.265625,y:.703125},{x:.265625,y:.703125},{x:.296875,y:.703125},{x:.296875,y:.703125},{x:.328125,y:.703125},{x:.328125,y:.703125},{x:.359375,y:.703125},{x:.359375,y:.703125},{x:.390625,y:.703125},{x:.390625,y:.703125},{x:.421875,y:.703125},{x:.421875,y:.703125},{x:.453125,y:.703125},{x:.453125,y:.703125},{x:.484375,y:.703125},{x:.484375,y:.703125},{x:.515625,y:.703125},{x:.515625,y:.703125},{x:.546875,y:.703125},{x:.546875,y:.703125},{x:.578125,y:.703125},{x:.578125,y:.703125},{x:.609375,y:.703125},{x:.609375,y:.703125},{x:.640625,y:.703125},{x:.640625,y:.703125},{x:.671875,y:.703125},{x:.671875,y:.703125},{x:.703125,y:.703125},{x:.703125,y:.703125},{x:.734375,y:.703125},{x:.734375,y:.703125},{x:.765625,y:.703125},{x:.765625,y:.703125},{x:.796875,y:.703125},{x:.796875,y:.703125},{x:.828125,y:.703125},{x:.828125,y:.703125},{x:.859375,y:.703125},{x:.859375,y:.703125},{x:.890625,y:.703125},{x:.890625,y:.703125},{x:.921875,y:.703125},{x:.921875,y:.703125},{x:.953125,y:.703125},{x:.953125,y:.703125},{x:.984375,y:.703125},{x:.984375,y:.703125},{x:.015625,y:.734375},{x:.015625,y:.734375},{x:.046875,y:.734375},{x:.046875,y:.734375},{x:.078125,y:.734375},{x:.078125,y:.734375},{x:.109375,y:.734375},{x:.109375,y:.734375},{x:.140625,y:.734375},{x:.140625,y:.734375},{x:.171875,y:.734375},{x:.171875,y:.734375},{x:.203125,y:.734375},{x:.203125,y:.734375},{x:.234375,y:.734375},{x:.234375,y:.734375},{x:.265625,y:.734375},{x:.265625,y:.734375},{x:.296875,y:.734375},{x:.296875,y:.734375},{x:.328125,y:.734375},{x:.328125,y:.734375},{x:.359375,y:.734375},{x:.359375,y:.734375},{x:.390625,y:.734375},{x:.390625,y:.734375},{x:.421875,y:.734375},{x:.421875,y:.734375},{x:.453125,y:.734375},{x:.453125,y:.734375},{x:.484375,y:.734375},{x:.484375,y:.734375},{x:.515625,y:.734375},{x:.515625,y:.734375},{x:.546875,y:.734375},{x:.546875,y:.734375},{x:.578125,y:.734375},{x:.578125,y:.734375},{x:.609375,y:.734375},{x:.609375,y:.734375},{x:.640625,y:.734375},{x:.640625,y:.734375},{x:.671875,y:.734375},{x:.671875,y:.734375},{x:.703125,y:.734375},{x:.703125,y:.734375},{x:.734375,y:.734375},{x:.734375,y:.734375},{x:.765625,y:.734375},{x:.765625,y:.734375},{x:.796875,y:.734375},{x:.796875,y:.734375},{x:.828125,y:.734375},{x:.828125,y:.734375},{x:.859375,y:.734375},{x:.859375,y:.734375},{x:.890625,y:.734375},{x:.890625,y:.734375},{x:.921875,y:.734375},{x:.921875,y:.734375},{x:.953125,y:.734375},{x:.953125,y:.734375},{x:.984375,y:.734375},{x:.984375,y:.734375},{x:.015625,y:.765625},{x:.015625,y:.765625},{x:.046875,y:.765625},{x:.046875,y:.765625},{x:.078125,y:.765625},{x:.078125,y:.765625},{x:.109375,y:.765625},{x:.109375,y:.765625},{x:.140625,y:.765625},{x:.140625,y:.765625},{x:.171875,y:.765625},{x:.171875,y:.765625},{x:.203125,y:.765625},{x:.203125,y:.765625},{x:.234375,y:.765625},{x:.234375,y:.765625},{x:.265625,y:.765625},{x:.265625,y:.765625},{x:.296875,y:.765625},{x:.296875,y:.765625},{x:.328125,y:.765625},{x:.328125,y:.765625},{x:.359375,y:.765625},{x:.359375,y:.765625},{x:.390625,y:.765625},{x:.390625,y:.765625},{x:.421875,y:.765625},{x:.421875,y:.765625},{x:.453125,y:.765625},{x:.453125,y:.765625},{x:.484375,y:.765625},{x:.484375,y:.765625},{x:.515625,y:.765625},{x:.515625,y:.765625},{x:.546875,y:.765625},{x:.546875,y:.765625},{x:.578125,y:.765625},{x:.578125,y:.765625},{x:.609375,y:.765625},{x:.609375,y:.765625},{x:.640625,y:.765625},{x:.640625,y:.765625},{x:.671875,y:.765625},{x:.671875,y:.765625},{x:.703125,y:.765625},{x:.703125,y:.765625},{x:.734375,y:.765625},{x:.734375,y:.765625},{x:.765625,y:.765625},{x:.765625,y:.765625},{x:.796875,y:.765625},{x:.796875,y:.765625},{x:.828125,y:.765625},{x:.828125,y:.765625},{x:.859375,y:.765625},{x:.859375,y:.765625},{x:.890625,y:.765625},{x:.890625,y:.765625},{x:.921875,y:.765625},{x:.921875,y:.765625},{x:.953125,y:.765625},{x:.953125,y:.765625},{x:.984375,y:.765625},{x:.984375,y:.765625},{x:.015625,y:.796875},{x:.015625,y:.796875},{x:.046875,y:.796875},{x:.046875,y:.796875},{x:.078125,y:.796875},{x:.078125,y:.796875},{x:.109375,y:.796875},{x:.109375,y:.796875},{x:.140625,y:.796875},{x:.140625,y:.796875},{x:.171875,y:.796875},{x:.171875,y:.796875},{x:.203125,y:.796875},{x:.203125,y:.796875},{x:.234375,y:.796875},{x:.234375,y:.796875},{x:.265625,y:.796875},{x:.265625,y:.796875},{x:.296875,y:.796875},{x:.296875,y:.796875},{x:.328125,y:.796875},{x:.328125,y:.796875},{x:.359375,y:.796875},{x:.359375,y:.796875},{x:.390625,y:.796875},{x:.390625,y:.796875},{x:.421875,y:.796875},{x:.421875,y:.796875},{x:.453125,y:.796875},{x:.453125,y:.796875},{x:.484375,y:.796875},{x:.484375,y:.796875},{x:.515625,y:.796875},{x:.515625,y:.796875},{x:.546875,y:.796875},{x:.546875,y:.796875},{x:.578125,y:.796875},{x:.578125,y:.796875},{x:.609375,y:.796875},{x:.609375,y:.796875},{x:.640625,y:.796875},{x:.640625,y:.796875},{x:.671875,y:.796875},{x:.671875,y:.796875},{x:.703125,y:.796875},{x:.703125,y:.796875},{x:.734375,y:.796875},{x:.734375,y:.796875},{x:.765625,y:.796875},{x:.765625,y:.796875},{x:.796875,y:.796875},{x:.796875,y:.796875},{x:.828125,y:.796875},{x:.828125,y:.796875},{x:.859375,y:.796875},{x:.859375,y:.796875},{x:.890625,y:.796875},{x:.890625,y:.796875},{x:.921875,y:.796875},{x:.921875,y:.796875},{x:.953125,y:.796875},{x:.953125,y:.796875},{x:.984375,y:.796875},{x:.984375,y:.796875},{x:.015625,y:.828125},{x:.015625,y:.828125},{x:.046875,y:.828125},{x:.046875,y:.828125},{x:.078125,y:.828125},{x:.078125,y:.828125},{x:.109375,y:.828125},{x:.109375,y:.828125},{x:.140625,y:.828125},{x:.140625,y:.828125},{x:.171875,y:.828125},{x:.171875,y:.828125},{x:.203125,y:.828125},{x:.203125,y:.828125},{x:.234375,y:.828125},{x:.234375,y:.828125},{x:.265625,y:.828125},{x:.265625,y:.828125},{x:.296875,y:.828125},{x:.296875,y:.828125},{x:.328125,y:.828125},{x:.328125,y:.828125},{x:.359375,y:.828125},{x:.359375,y:.828125},{x:.390625,y:.828125},{x:.390625,y:.828125},{x:.421875,y:.828125},{x:.421875,y:.828125},{x:.453125,y:.828125},{x:.453125,y:.828125},{x:.484375,y:.828125},{x:.484375,y:.828125},{x:.515625,y:.828125},{x:.515625,y:.828125},{x:.546875,y:.828125},{x:.546875,y:.828125},{x:.578125,y:.828125},{x:.578125,y:.828125},{x:.609375,y:.828125},{x:.609375,y:.828125},{x:.640625,y:.828125},{x:.640625,y:.828125},{x:.671875,y:.828125},{x:.671875,y:.828125},{x:.703125,y:.828125},{x:.703125,y:.828125},{x:.734375,y:.828125},{x:.734375,y:.828125},{x:.765625,y:.828125},{x:.765625,y:.828125},{x:.796875,y:.828125},{x:.796875,y:.828125},{x:.828125,y:.828125},{x:.828125,y:.828125},{x:.859375,y:.828125},{x:.859375,y:.828125},{x:.890625,y:.828125},{x:.890625,y:.828125},{x:.921875,y:.828125},{x:.921875,y:.828125},{x:.953125,y:.828125},{x:.953125,y:.828125},{x:.984375,y:.828125},{x:.984375,y:.828125},{x:.015625,y:.859375},{x:.015625,y:.859375},{x:.046875,y:.859375},{x:.046875,y:.859375},{x:.078125,y:.859375},{x:.078125,y:.859375},{x:.109375,y:.859375},{x:.109375,y:.859375},{x:.140625,y:.859375},{x:.140625,y:.859375},{x:.171875,y:.859375},{x:.171875,y:.859375},{x:.203125,y:.859375},{x:.203125,y:.859375},{x:.234375,y:.859375},{x:.234375,y:.859375},{x:.265625,y:.859375},{x:.265625,y:.859375},{x:.296875,y:.859375},{x:.296875,y:.859375},{x:.328125,y:.859375},{x:.328125,y:.859375},{x:.359375,y:.859375},{x:.359375,y:.859375},{x:.390625,y:.859375},{x:.390625,y:.859375},{x:.421875,y:.859375},{x:.421875,y:.859375},{x:.453125,y:.859375},{x:.453125,y:.859375},{x:.484375,y:.859375},{x:.484375,y:.859375},{x:.515625,y:.859375},{x:.515625,y:.859375},{x:.546875,y:.859375},{x:.546875,y:.859375},{x:.578125,y:.859375},{x:.578125,y:.859375},{x:.609375,y:.859375},{x:.609375,y:.859375},{x:.640625,y:.859375},{x:.640625,y:.859375},{x:.671875,y:.859375},{x:.671875,y:.859375},{x:.703125,y:.859375},{x:.703125,y:.859375},{x:.734375,y:.859375},{x:.734375,y:.859375},{x:.765625,y:.859375},{x:.765625,y:.859375},{x:.796875,y:.859375},{x:.796875,y:.859375},{x:.828125,y:.859375},{x:.828125,y:.859375},{x:.859375,y:.859375},{x:.859375,y:.859375},{x:.890625,y:.859375},{x:.890625,y:.859375},{x:.921875,y:.859375},{x:.921875,y:.859375},{x:.953125,y:.859375},{x:.953125,y:.859375},{x:.984375,y:.859375},{x:.984375,y:.859375},{x:.015625,y:.890625},{x:.015625,y:.890625},{x:.046875,y:.890625},{x:.046875,y:.890625},{x:.078125,y:.890625},{x:.078125,y:.890625},{x:.109375,y:.890625},{x:.109375,y:.890625},{x:.140625,y:.890625},{x:.140625,y:.890625},{x:.171875,y:.890625},{x:.171875,y:.890625},{x:.203125,y:.890625},{x:.203125,y:.890625},{x:.234375,y:.890625},{x:.234375,y:.890625},{x:.265625,y:.890625},{x:.265625,y:.890625},{x:.296875,y:.890625},{x:.296875,y:.890625},{x:.328125,y:.890625},{x:.328125,y:.890625},{x:.359375,y:.890625},{x:.359375,y:.890625},{x:.390625,y:.890625},{x:.390625,y:.890625},{x:.421875,y:.890625},{x:.421875,y:.890625},{x:.453125,y:.890625},{x:.453125,y:.890625},{x:.484375,y:.890625},{x:.484375,y:.890625},{x:.515625,y:.890625},{x:.515625,y:.890625},{x:.546875,y:.890625},{x:.546875,y:.890625},{x:.578125,y:.890625},{x:.578125,y:.890625},{x:.609375,y:.890625},{x:.609375,y:.890625},{x:.640625,y:.890625},{x:.640625,y:.890625},{x:.671875,y:.890625},{x:.671875,y:.890625},{x:.703125,y:.890625},{x:.703125,y:.890625},{x:.734375,y:.890625},{x:.734375,y:.890625},{x:.765625,y:.890625},{x:.765625,y:.890625},{x:.796875,y:.890625},{x:.796875,y:.890625},{x:.828125,y:.890625},{x:.828125,y:.890625},{x:.859375,y:.890625},{x:.859375,y:.890625},{x:.890625,y:.890625},{x:.890625,y:.890625},{x:.921875,y:.890625},{x:.921875,y:.890625},{x:.953125,y:.890625},{x:.953125,y:.890625},{x:.984375,y:.890625},{x:.984375,y:.890625},{x:.015625,y:.921875},{x:.015625,y:.921875},{x:.046875,y:.921875},{x:.046875,y:.921875},{x:.078125,y:.921875},{x:.078125,y:.921875},{x:.109375,y:.921875},{x:.109375,y:.921875},{x:.140625,y:.921875},{x:.140625,y:.921875},{x:.171875,y:.921875},{x:.171875,y:.921875},{x:.203125,y:.921875},{x:.203125,y:.921875},{x:.234375,y:.921875},{x:.234375,y:.921875},{x:.265625,y:.921875},{x:.265625,y:.921875},{x:.296875,y:.921875},{x:.296875,y:.921875},{x:.328125,y:.921875},{x:.328125,y:.921875},{x:.359375,y:.921875},{x:.359375,y:.921875},{x:.390625,y:.921875},{x:.390625,y:.921875},{x:.421875,y:.921875},{x:.421875,y:.921875},{x:.453125,y:.921875},{x:.453125,y:.921875},{x:.484375,y:.921875},{x:.484375,y:.921875},{x:.515625,y:.921875},{x:.515625,y:.921875},{x:.546875,y:.921875},{x:.546875,y:.921875},{x:.578125,y:.921875},{x:.578125,y:.921875},{x:.609375,y:.921875},{x:.609375,y:.921875},{x:.640625,y:.921875},{x:.640625,y:.921875},{x:.671875,y:.921875},{x:.671875,y:.921875},{x:.703125,y:.921875},{x:.703125,y:.921875},{x:.734375,y:.921875},{x:.734375,y:.921875},{x:.765625,y:.921875},{x:.765625,y:.921875},{x:.796875,y:.921875},{x:.796875,y:.921875},{x:.828125,y:.921875},{x:.828125,y:.921875},{x:.859375,y:.921875},{x:.859375,y:.921875},{x:.890625,y:.921875},{x:.890625,y:.921875},{x:.921875,y:.921875},{x:.921875,y:.921875},{x:.953125,y:.921875},{x:.953125,y:.921875},{x:.984375,y:.921875},{x:.984375,y:.921875},{x:.015625,y:.953125},{x:.015625,y:.953125},{x:.046875,y:.953125},{x:.046875,y:.953125},{x:.078125,y:.953125},{x:.078125,y:.953125},{x:.109375,y:.953125},{x:.109375,y:.953125},{x:.140625,y:.953125},{x:.140625,y:.953125},{x:.171875,y:.953125},{x:.171875,y:.953125},{x:.203125,y:.953125},{x:.203125,y:.953125},{x:.234375,y:.953125},{x:.234375,y:.953125},{x:.265625,y:.953125},{x:.265625,y:.953125},{x:.296875,y:.953125},{x:.296875,y:.953125},{x:.328125,y:.953125},{x:.328125,y:.953125},{x:.359375,y:.953125},{x:.359375,y:.953125},{x:.390625,y:.953125},{x:.390625,y:.953125},{x:.421875,y:.953125},{x:.421875,y:.953125},{x:.453125,y:.953125},{x:.453125,y:.953125},{x:.484375,y:.953125},{x:.484375,y:.953125},{x:.515625,y:.953125},{x:.515625,y:.953125},{x:.546875,y:.953125},{x:.546875,y:.953125},{x:.578125,y:.953125},{x:.578125,y:.953125},{x:.609375,y:.953125},{x:.609375,y:.953125},{x:.640625,y:.953125},{x:.640625,y:.953125},{x:.671875,y:.953125},{x:.671875,y:.953125},{x:.703125,y:.953125},{x:.703125,y:.953125},{x:.734375,y:.953125},{x:.734375,y:.953125},{x:.765625,y:.953125},{x:.765625,y:.953125},{x:.796875,y:.953125},{x:.796875,y:.953125},{x:.828125,y:.953125},{x:.828125,y:.953125},{x:.859375,y:.953125},{x:.859375,y:.953125},{x:.890625,y:.953125},{x:.890625,y:.953125},{x:.921875,y:.953125},{x:.921875,y:.953125},{x:.953125,y:.953125},{x:.953125,y:.953125},{x:.984375,y:.953125},{x:.984375,y:.953125},{x:.015625,y:.984375},{x:.015625,y:.984375},{x:.046875,y:.984375},{x:.046875,y:.984375},{x:.078125,y:.984375},{x:.078125,y:.984375},{x:.109375,y:.984375},{x:.109375,y:.984375},{x:.140625,y:.984375},{x:.140625,y:.984375},{x:.171875,y:.984375},{x:.171875,y:.984375},{x:.203125,y:.984375},{x:.203125,y:.984375},{x:.234375,y:.984375},{x:.234375,y:.984375},{x:.265625,y:.984375},{x:.265625,y:.984375},{x:.296875,y:.984375},{x:.296875,y:.984375},{x:.328125,y:.984375},{x:.328125,y:.984375},{x:.359375,y:.984375},{x:.359375,y:.984375},{x:.390625,y:.984375},{x:.390625,y:.984375},{x:.421875,y:.984375},{x:.421875,y:.984375},{x:.453125,y:.984375},{x:.453125,y:.984375},{x:.484375,y:.984375},{x:.484375,y:.984375},{x:.515625,y:.984375},{x:.515625,y:.984375},{x:.546875,y:.984375},{x:.546875,y:.984375},{x:.578125,y:.984375},{x:.578125,y:.984375},{x:.609375,y:.984375},{x:.609375,y:.984375},{x:.640625,y:.984375},{x:.640625,y:.984375},{x:.671875,y:.984375},{x:.671875,y:.984375},{x:.703125,y:.984375},{x:.703125,y:.984375},{x:.734375,y:.984375},{x:.734375,y:.984375},{x:.765625,y:.984375},{x:.765625,y:.984375},{x:.796875,y:.984375},{x:.796875,y:.984375},{x:.828125,y:.984375},{x:.828125,y:.984375},{x:.859375,y:.984375},{x:.859375,y:.984375},{x:.890625,y:.984375},{x:.890625,y:.984375},{x:.921875,y:.984375},{x:.921875,y:.984375},{x:.953125,y:.984375},{x:.953125,y:.984375},{x:.984375,y:.984375},{x:.984375,y:.984375},{x:.03125,y:.03125},{x:.03125,y:.03125},{x:.09375,y:.03125},{x:.09375,y:.03125},{x:.15625,y:.03125},{x:.15625,y:.03125},{x:.21875,y:.03125},{x:.21875,y:.03125},{x:.28125,y:.03125},{x:.28125,y:.03125},{x:.34375,y:.03125},{x:.34375,y:.03125},{x:.40625,y:.03125},{x:.40625,y:.03125},{x:.46875,y:.03125},{x:.46875,y:.03125},{x:.53125,y:.03125},{x:.53125,y:.03125},{x:.59375,y:.03125},{x:.59375,y:.03125},{x:.65625,y:.03125},{x:.65625,y:.03125},{x:.71875,y:.03125},{x:.71875,y:.03125},{x:.78125,y:.03125},{x:.78125,y:.03125},{x:.84375,y:.03125},{x:.84375,y:.03125},{x:.90625,y:.03125},{x:.90625,y:.03125},{x:.96875,y:.03125},{x:.96875,y:.03125},{x:.03125,y:.09375},{x:.03125,y:.09375},{x:.09375,y:.09375},{x:.09375,y:.09375},{x:.15625,y:.09375},{x:.15625,y:.09375},{x:.21875,y:.09375},{x:.21875,y:.09375},{x:.28125,y:.09375},{x:.28125,y:.09375},{x:.34375,y:.09375},{x:.34375,y:.09375},{x:.40625,y:.09375},{x:.40625,y:.09375},{x:.46875,y:.09375},{x:.46875,y:.09375},{x:.53125,y:.09375},{x:.53125,y:.09375},{x:.59375,y:.09375},{x:.59375,y:.09375},{x:.65625,y:.09375},{x:.65625,y:.09375},{x:.71875,y:.09375},{x:.71875,y:.09375},{x:.78125,y:.09375},{x:.78125,y:.09375},{x:.84375,y:.09375},{x:.84375,y:.09375},{x:.90625,y:.09375},{x:.90625,y:.09375},{x:.96875,y:.09375},{x:.96875,y:.09375},{x:.03125,y:.15625},{x:.03125,y:.15625},{x:.09375,y:.15625},{x:.09375,y:.15625},{x:.15625,y:.15625},{x:.15625,y:.15625},{x:.21875,y:.15625},{x:.21875,y:.15625},{x:.28125,y:.15625},{x:.28125,y:.15625},{x:.34375,y:.15625},{x:.34375,y:.15625},{x:.40625,y:.15625},{x:.40625,y:.15625},{x:.46875,y:.15625},{x:.46875,y:.15625},{x:.53125,y:.15625},{x:.53125,y:.15625},{x:.59375,y:.15625},{x:.59375,y:.15625},{x:.65625,y:.15625},{x:.65625,y:.15625},{x:.71875,y:.15625},{x:.71875,y:.15625},{x:.78125,y:.15625},{x:.78125,y:.15625},{x:.84375,y:.15625},{x:.84375,y:.15625},{x:.90625,y:.15625},{x:.90625,y:.15625},{x:.96875,y:.15625},{x:.96875,y:.15625},{x:.03125,y:.21875},{x:.03125,y:.21875},{x:.09375,y:.21875},{x:.09375,y:.21875},{x:.15625,y:.21875},{x:.15625,y:.21875},{x:.21875,y:.21875},{x:.21875,y:.21875},{x:.28125,y:.21875},{x:.28125,y:.21875},{x:.34375,y:.21875},{x:.34375,y:.21875},{x:.40625,y:.21875},{x:.40625,y:.21875},{x:.46875,y:.21875},{x:.46875,y:.21875},{x:.53125,y:.21875},{x:.53125,y:.21875},{x:.59375,y:.21875},{x:.59375,y:.21875},{x:.65625,y:.21875},{x:.65625,y:.21875},{x:.71875,y:.21875},{x:.71875,y:.21875},{x:.78125,y:.21875},{x:.78125,y:.21875},{x:.84375,y:.21875},{x:.84375,y:.21875},{x:.90625,y:.21875},{x:.90625,y:.21875},{x:.96875,y:.21875},{x:.96875,y:.21875},{x:.03125,y:.28125},{x:.03125,y:.28125},{x:.09375,y:.28125},{x:.09375,y:.28125},{x:.15625,y:.28125},{x:.15625,y:.28125},{x:.21875,y:.28125},{x:.21875,y:.28125},{x:.28125,y:.28125},{x:.28125,y:.28125},{x:.34375,y:.28125},{x:.34375,y:.28125},{x:.40625,y:.28125},{x:.40625,y:.28125},{x:.46875,y:.28125},{x:.46875,y:.28125},{x:.53125,y:.28125},{x:.53125,y:.28125},{x:.59375,y:.28125},{x:.59375,y:.28125},{x:.65625,y:.28125},{x:.65625,y:.28125},{x:.71875,y:.28125},{x:.71875,y:.28125},{x:.78125,y:.28125},{x:.78125,y:.28125},{x:.84375,y:.28125},{x:.84375,y:.28125},{x:.90625,y:.28125},{x:.90625,y:.28125},{x:.96875,y:.28125},{x:.96875,y:.28125},{x:.03125,y:.34375},{x:.03125,y:.34375},{x:.09375,y:.34375},{x:.09375,y:.34375},{x:.15625,y:.34375},{x:.15625,y:.34375},{x:.21875,y:.34375},{x:.21875,y:.34375},{x:.28125,y:.34375},{x:.28125,y:.34375},{x:.34375,y:.34375},{x:.34375,y:.34375},{x:.40625,y:.34375},{x:.40625,y:.34375},{x:.46875,y:.34375},{x:.46875,y:.34375},{x:.53125,y:.34375},{x:.53125,y:.34375},{x:.59375,y:.34375},{x:.59375,y:.34375},{x:.65625,y:.34375},{x:.65625,y:.34375},{x:.71875,y:.34375},{x:.71875,y:.34375},{x:.78125,y:.34375},{x:.78125,y:.34375},{x:.84375,y:.34375},{x:.84375,y:.34375},{x:.90625,y:.34375},{x:.90625,y:.34375},{x:.96875,y:.34375},{x:.96875,y:.34375},{x:.03125,y:.40625},{x:.03125,y:.40625},{x:.09375,y:.40625},{x:.09375,y:.40625},{x:.15625,y:.40625},{x:.15625,y:.40625},{x:.21875,y:.40625},{x:.21875,y:.40625},{x:.28125,y:.40625},{x:.28125,y:.40625},{x:.34375,y:.40625},{x:.34375,y:.40625},{x:.40625,y:.40625},{x:.40625,y:.40625},{x:.46875,y:.40625},{x:.46875,y:.40625},{x:.53125,y:.40625},{x:.53125,y:.40625},{x:.59375,y:.40625},{x:.59375,y:.40625},{x:.65625,y:.40625},{x:.65625,y:.40625},{x:.71875,y:.40625},{x:.71875,y:.40625},{x:.78125,y:.40625},{x:.78125,y:.40625},{x:.84375,y:.40625},{x:.84375,y:.40625},{x:.90625,y:.40625},{x:.90625,y:.40625},{x:.96875,y:.40625},{x:.96875,y:.40625},{x:.03125,y:.46875},{x:.03125,y:.46875},{x:.09375,y:.46875},{x:.09375,y:.46875},{x:.15625,y:.46875},{x:.15625,y:.46875},{x:.21875,y:.46875},{x:.21875,y:.46875},{x:.28125,y:.46875},{x:.28125,y:.46875},{x:.34375,y:.46875},{x:.34375,y:.46875},{x:.40625,y:.46875},{x:.40625,y:.46875},{x:.46875,y:.46875},{x:.46875,y:.46875},{x:.53125,y:.46875},{x:.53125,y:.46875},{x:.59375,y:.46875},{x:.59375,y:.46875},{x:.65625,y:.46875},{x:.65625,y:.46875},{x:.71875,y:.46875},{x:.71875,y:.46875},{x:.78125,y:.46875},{x:.78125,y:.46875},{x:.84375,y:.46875},{x:.84375,y:.46875},{x:.90625,y:.46875},{x:.90625,y:.46875},{x:.96875,y:.46875},{x:.96875,y:.46875},{x:.03125,y:.53125},{x:.03125,y:.53125},{x:.09375,y:.53125},{x:.09375,y:.53125},{x:.15625,y:.53125},{x:.15625,y:.53125},{x:.21875,y:.53125},{x:.21875,y:.53125},{x:.28125,y:.53125},{x:.28125,y:.53125},{x:.34375,y:.53125},{x:.34375,y:.53125},{x:.40625,y:.53125},{x:.40625,y:.53125},{x:.46875,y:.53125},{x:.46875,y:.53125},{x:.53125,y:.53125},{x:.53125,y:.53125},{x:.59375,y:.53125},{x:.59375,y:.53125},{x:.65625,y:.53125},{x:.65625,y:.53125},{x:.71875,y:.53125},{x:.71875,y:.53125},{x:.78125,y:.53125},{x:.78125,y:.53125},{x:.84375,y:.53125},{x:.84375,y:.53125},{x:.90625,y:.53125},{x:.90625,y:.53125},{x:.96875,y:.53125},{x:.96875,y:.53125},{x:.03125,y:.59375},{x:.03125,y:.59375},{x:.09375,y:.59375},{x:.09375,y:.59375},{x:.15625,y:.59375},{x:.15625,y:.59375},{x:.21875,y:.59375},{x:.21875,y:.59375},{x:.28125,y:.59375},{x:.28125,y:.59375},{x:.34375,y:.59375},{x:.34375,y:.59375},{x:.40625,y:.59375},{x:.40625,y:.59375},{x:.46875,y:.59375},{x:.46875,y:.59375},{x:.53125,y:.59375},{x:.53125,y:.59375},{x:.59375,y:.59375},{x:.59375,y:.59375},{x:.65625,y:.59375},{x:.65625,y:.59375},{x:.71875,y:.59375},{x:.71875,y:.59375},{x:.78125,y:.59375},{x:.78125,y:.59375},{x:.84375,y:.59375},{x:.84375,y:.59375},{x:.90625,y:.59375},{x:.90625,y:.59375},{x:.96875,y:.59375},{x:.96875,y:.59375},{x:.03125,y:.65625},{x:.03125,y:.65625},{x:.09375,y:.65625},{x:.09375,y:.65625},{x:.15625,y:.65625},{x:.15625,y:.65625},{x:.21875,y:.65625},{x:.21875,y:.65625},{x:.28125,y:.65625},{x:.28125,y:.65625},{x:.34375,y:.65625},{x:.34375,y:.65625},{x:.40625,y:.65625},{x:.40625,y:.65625},{x:.46875,y:.65625},{x:.46875,y:.65625},{x:.53125,y:.65625},{x:.53125,y:.65625},{x:.59375,y:.65625},{x:.59375,y:.65625},{x:.65625,y:.65625},{x:.65625,y:.65625},{x:.71875,y:.65625},{x:.71875,y:.65625},{x:.78125,y:.65625},{x:.78125,y:.65625},{x:.84375,y:.65625},{x:.84375,y:.65625},{x:.90625,y:.65625},{x:.90625,y:.65625},{x:.96875,y:.65625},{x:.96875,y:.65625},{x:.03125,y:.71875},{x:.03125,y:.71875},{x:.09375,y:.71875},{x:.09375,y:.71875},{x:.15625,y:.71875},{x:.15625,y:.71875},{x:.21875,y:.71875},{x:.21875,y:.71875},{x:.28125,y:.71875},{x:.28125,y:.71875},{x:.34375,y:.71875},{x:.34375,y:.71875},{x:.40625,y:.71875},{x:.40625,y:.71875},{x:.46875,y:.71875},{x:.46875,y:.71875},{x:.53125,y:.71875},{x:.53125,y:.71875},{x:.59375,y:.71875},{x:.59375,y:.71875},{x:.65625,y:.71875},{x:.65625,y:.71875},{x:.71875,y:.71875},{x:.71875,y:.71875},{x:.78125,y:.71875},{x:.78125,y:.71875},{x:.84375,y:.71875},{x:.84375,y:.71875},{x:.90625,y:.71875},{x:.90625,y:.71875},{x:.96875,y:.71875},{x:.96875,y:.71875},{x:.03125,y:.78125},{x:.03125,y:.78125},{x:.09375,y:.78125},{x:.09375,y:.78125},{x:.15625,y:.78125},{x:.15625,y:.78125},{x:.21875,y:.78125},{x:.21875,y:.78125},{x:.28125,y:.78125},{x:.28125,y:.78125},{x:.34375,y:.78125},{x:.34375,y:.78125},{x:.40625,y:.78125},{x:.40625,y:.78125},{x:.46875,y:.78125},{x:.46875,y:.78125},{x:.53125,y:.78125},{x:.53125,y:.78125},{x:.59375,y:.78125},{x:.59375,y:.78125},{x:.65625,y:.78125},{x:.65625,y:.78125},{x:.71875,y:.78125},{x:.71875,y:.78125},{x:.78125,y:.78125},{x:.78125,y:.78125},{x:.84375,y:.78125},{x:.84375,y:.78125},{x:.90625,y:.78125},{x:.90625,y:.78125},{x:.96875,y:.78125},{x:.96875,y:.78125},{x:.03125,y:.84375},{x:.03125,y:.84375},{x:.09375,y:.84375},{x:.09375,y:.84375},{x:.15625,y:.84375},{x:.15625,y:.84375},{x:.21875,y:.84375},{x:.21875,y:.84375},{x:.28125,y:.84375},{x:.28125,y:.84375},{x:.34375,y:.84375},{x:.34375,y:.84375},{x:.40625,y:.84375},{x:.40625,y:.84375},{x:.46875,y:.84375},{x:.46875,y:.84375},{x:.53125,y:.84375},{x:.53125,y:.84375},{x:.59375,y:.84375},{x:.59375,y:.84375},{x:.65625,y:.84375},{x:.65625,y:.84375},{x:.71875,y:.84375},{x:.71875,y:.84375},{x:.78125,y:.84375},{x:.78125,y:.84375},{x:.84375,y:.84375},{x:.84375,y:.84375},{x:.90625,y:.84375},{x:.90625,y:.84375},{x:.96875,y:.84375},{x:.96875,y:.84375},{x:.03125,y:.90625},{x:.03125,y:.90625},{x:.09375,y:.90625},{x:.09375,y:.90625},{x:.15625,y:.90625},{x:.15625,y:.90625},{x:.21875,y:.90625},{x:.21875,y:.90625},{x:.28125,y:.90625},{x:.28125,y:.90625},{x:.34375,y:.90625},{x:.34375,y:.90625},{x:.40625,y:.90625},{x:.40625,y:.90625},{x:.46875,y:.90625},{x:.46875,y:.90625},{x:.53125,y:.90625},{x:.53125,y:.90625},{x:.59375,y:.90625},{x:.59375,y:.90625},{x:.65625,y:.90625},{x:.65625,y:.90625},{x:.71875,y:.90625},{x:.71875,y:.90625},{x:.78125,y:.90625},{x:.78125,y:.90625},{x:.84375,y:.90625},{x:.84375,y:.90625},{x:.90625,y:.90625},{x:.90625,y:.90625},{x:.96875,y:.90625},{x:.96875,y:.90625},{x:.03125,y:.96875},{x:.03125,y:.96875},{x:.09375,y:.96875},{x:.09375,y:.96875},{x:.15625,y:.96875},{x:.15625,y:.96875},{x:.21875,y:.96875},{x:.21875,y:.96875},{x:.28125,y:.96875},{x:.28125,y:.96875},{x:.34375,y:.96875},{x:.34375,y:.96875},{x:.40625,y:.96875},{x:.40625,y:.96875},{x:.46875,y:.96875},{x:.46875,y:.96875},{x:.53125,y:.96875},{x:.53125,y:.96875},{x:.59375,y:.96875},{x:.59375,y:.96875},{x:.65625,y:.96875},{x:.65625,y:.96875},{x:.71875,y:.96875},{x:.71875,y:.96875},{x:.78125,y:.96875},{x:.78125,y:.96875},{x:.84375,y:.96875},{x:.84375,y:.96875},{x:.90625,y:.96875},{x:.90625,y:.96875},{x:.96875,y:.96875},{x:.96875,y:.96875},{x:.0625,y:.0625},{x:.0625,y:.0625},{x:.0625,y:.0625},{x:.0625,y:.0625},{x:.0625,y:.0625},{x:.0625,y:.0625},{x:.1875,y:.0625},{x:.1875,y:.0625},{x:.1875,y:.0625},{x:.1875,y:.0625},{x:.1875,y:.0625},{x:.1875,y:.0625},{x:.3125,y:.0625},{x:.3125,y:.0625},{x:.3125,y:.0625},{x:.3125,y:.0625},{x:.3125,y:.0625},{x:.3125,y:.0625},{x:.4375,y:.0625},{x:.4375,y:.0625},{x:.4375,y:.0625},{x:.4375,y:.0625},{x:.4375,y:.0625},{x:.4375,y:.0625},{x:.5625,y:.0625},{x:.5625,y:.0625},{x:.5625,y:.0625},{x:.5625,y:.0625},{x:.5625,y:.0625},{x:.5625,y:.0625},{x:.6875,y:.0625},{x:.6875,y:.0625},{x:.6875,y:.0625},{x:.6875,y:.0625},{x:.6875,y:.0625},{x:.6875,y:.0625},{x:.8125,y:.0625},{x:.8125,y:.0625},{x:.8125,y:.0625},{x:.8125,y:.0625},{x:.8125,y:.0625},{x:.8125,y:.0625},{x:.9375,y:.0625},{x:.9375,y:.0625},{x:.9375,y:.0625},{x:.9375,y:.0625},{x:.9375,y:.0625},{x:.9375,y:.0625},{x:.0625,y:.1875},{x:.0625,y:.1875},{x:.0625,y:.1875},{x:.0625,y:.1875},{x:.0625,y:.1875},{x:.0625,y:.1875},{x:.1875,y:.1875},{x:.1875,y:.1875},{x:.1875,y:.1875},{x:.1875,y:.1875},{x:.1875,y:.1875},{x:.1875,y:.1875},{x:.3125,y:.1875},{x:.3125,y:.1875},{x:.3125,y:.1875},{x:.3125,y:.1875},{x:.3125,y:.1875},{x:.3125,y:.1875},{x:.4375,y:.1875},{x:.4375,y:.1875},{x:.4375,y:.1875},{x:.4375,y:.1875},{x:.4375,y:.1875},{x:.4375,y:.1875},{x:.5625,y:.1875},{x:.5625,y:.1875},{x:.5625,y:.1875},{x:.5625,y:.1875},{x:.5625,y:.1875},{x:.5625,y:.1875},{x:.6875,y:.1875},{x:.6875,y:.1875},{x:.6875,y:.1875},{x:.6875,y:.1875},{x:.6875,y:.1875},{x:.6875,y:.1875},{x:.8125,y:.1875},{x:.8125,y:.1875},{x:.8125,y:.1875},{x:.8125,y:.1875},{x:.8125,y:.1875},{x:.8125,y:.1875},{x:.9375,y:.1875},{x:.9375,y:.1875},{x:.9375,y:.1875},{x:.9375,y:.1875},{x:.9375,y:.1875},{x:.9375,y:.1875},{x:.0625,y:.3125},{x:.0625,y:.3125},{x:.0625,y:.3125},{x:.0625,y:.3125},{x:.0625,y:.3125},{x:.0625,y:.3125},{x:.1875,y:.3125},{x:.1875,y:.3125},{x:.1875,y:.3125},{x:.1875,y:.3125},{x:.1875,y:.3125},{x:.1875,y:.3125},{x:.3125,y:.3125},{x:.3125,y:.3125},{x:.3125,y:.3125},{x:.3125,y:.3125},{x:.3125,y:.3125},{x:.3125,y:.3125},{x:.4375,y:.3125},{x:.4375,y:.3125},{x:.4375,y:.3125},{x:.4375,y:.3125},{x:.4375,y:.3125},{x:.4375,y:.3125},{x:.5625,y:.3125},{x:.5625,y:.3125},{x:.5625,y:.3125},{x:.5625,y:.3125},{x:.5625,y:.3125},{x:.5625,y:.3125},{x:.6875,y:.3125},{x:.6875,y:.3125},{x:.6875,y:.3125},{x:.6875,y:.3125},{x:.6875,y:.3125},{x:.6875,y:.3125},{x:.8125,y:.3125},{x:.8125,y:.3125},{x:.8125,y:.3125},{x:.8125,y:.3125},{x:.8125,y:.3125},{x:.8125,y:.3125},{x:.9375,y:.3125},{x:.9375,y:.3125},{x:.9375,y:.3125},{x:.9375,y:.3125},{x:.9375,y:.3125},{x:.9375,y:.3125},{x:.0625,y:.4375},{x:.0625,y:.4375},{x:.0625,y:.4375},{x:.0625,y:.4375},{x:.0625,y:.4375},{x:.0625,y:.4375},{x:.1875,y:.4375},{x:.1875,y:.4375},{x:.1875,y:.4375},{x:.1875,y:.4375},{x:.1875,y:.4375},{x:.1875,y:.4375},{x:.3125,y:.4375},{x:.3125,y:.4375},{x:.3125,y:.4375},{x:.3125,y:.4375},{x:.3125,y:.4375},{x:.3125,y:.4375},{x:.4375,y:.4375},{x:.4375,y:.4375},{x:.4375,y:.4375},{x:.4375,y:.4375},{x:.4375,y:.4375},{x:.4375,y:.4375},{x:.5625,y:.4375},{x:.5625,y:.4375},{x:.5625,y:.4375},{x:.5625,y:.4375},{x:.5625,y:.4375},{x:.5625,y:.4375},{x:.6875,y:.4375},{x:.6875,y:.4375},{x:.6875,y:.4375},{x:.6875,y:.4375},{x:.6875,y:.4375},{x:.6875,y:.4375},{x:.8125,y:.4375},{x:.8125,y:.4375},{x:.8125,y:.4375},{x:.8125,y:.4375},{x:.8125,y:.4375},{x:.8125,y:.4375},{x:.9375,y:.4375},{x:.9375,y:.4375},{x:.9375,y:.4375},{x:.9375,y:.4375},{x:.9375,y:.4375},{x:.9375,y:.4375},{x:.0625,y:.5625},{x:.0625,y:.5625},{x:.0625,y:.5625},{x:.0625,y:.5625},{x:.0625,y:.5625},{x:.0625,y:.5625},{x:.1875,y:.5625},{x:.1875,y:.5625},{x:.1875,y:.5625},{x:.1875,y:.5625},{x:.1875,y:.5625},{x:.1875,y:.5625},{x:.3125,y:.5625},{x:.3125,y:.5625},{x:.3125,y:.5625},{x:.3125,y:.5625},{x:.3125,y:.5625},{x:.3125,y:.5625},{x:.4375,y:.5625},{x:.4375,y:.5625},{x:.4375,y:.5625},{x:.4375,y:.5625},{x:.4375,y:.5625},{x:.4375,y:.5625},{x:.5625,y:.5625},{x:.5625,y:.5625},{x:.5625,y:.5625},{x:.5625,y:.5625},{x:.5625,y:.5625},{x:.5625,y:.5625},{x:.6875,y:.5625},{x:.6875,y:.5625},{x:.6875,y:.5625},{x:.6875,y:.5625},{x:.6875,y:.5625},{x:.6875,y:.5625},{x:.8125,y:.5625},{x:.8125,y:.5625},{x:.8125,y:.5625},{x:.8125,y:.5625},{x:.8125,y:.5625},{x:.8125,y:.5625},{x:.9375,y:.5625},{x:.9375,y:.5625},{x:.9375,y:.5625},{x:.9375,y:.5625},{x:.9375,y:.5625},{x:.9375,y:.5625},{x:.0625,y:.6875},{x:.0625,y:.6875},{x:.0625,y:.6875},{x:.0625,y:.6875},{x:.0625,y:.6875},{x:.0625,y:.6875},{x:.1875,y:.6875},{x:.1875,y:.6875},{x:.1875,y:.6875},{x:.1875,y:.6875},{x:.1875,y:.6875},{x:.1875,y:.6875},{x:.3125,y:.6875},{x:.3125,y:.6875},{x:.3125,y:.6875},{x:.3125,y:.6875},{x:.3125,y:.6875},{x:.3125,y:.6875},{x:.4375,y:.6875},{x:.4375,y:.6875},{x:.4375,y:.6875},{x:.4375,y:.6875},{x:.4375,y:.6875},{x:.4375,y:.6875},{x:.5625,y:.6875},{x:.5625,y:.6875},{x:.5625,y:.6875},{x:.5625,y:.6875},{x:.5625,y:.6875},{x:.5625,y:.6875},{x:.6875,y:.6875},{x:.6875,y:.6875},{x:.6875,y:.6875},{x:.6875,y:.6875},{x:.6875,y:.6875},{x:.6875,y:.6875},{x:.8125,y:.6875},{x:.8125,y:.6875},{x:.8125,y:.6875},{x:.8125,y:.6875},{x:.8125,y:.6875},{x:.8125,y:.6875},{x:.9375,y:.6875},{x:.9375,y:.6875},{x:.9375,y:.6875},{x:.9375,y:.6875},{x:.9375,y:.6875},{x:.9375,y:.6875},{x:.0625,y:.8125},{x:.0625,y:.8125},{x:.0625,y:.8125},{x:.0625,y:.8125},{x:.0625,y:.8125},{x:.0625,y:.8125},{x:.1875,y:.8125},{x:.1875,y:.8125},{x:.1875,y:.8125},{x:.1875,y:.8125},{x:.1875,y:.8125},{x:.1875,y:.8125},{x:.3125,y:.8125},{x:.3125,y:.8125},{x:.3125,y:.8125},{x:.3125,y:.8125},{x:.3125,y:.8125},{x:.3125,y:.8125},{x:.4375,y:.8125},{x:.4375,y:.8125},{x:.4375,y:.8125},{x:.4375,y:.8125},{x:.4375,y:.8125},{x:.4375,y:.8125},{x:.5625,y:.8125},{x:.5625,y:.8125},{x:.5625,y:.8125},{x:.5625,y:.8125},{x:.5625,y:.8125},{x:.5625,y:.8125},{x:.6875,y:.8125},{x:.6875,y:.8125},{x:.6875,y:.8125},{x:.6875,y:.8125},{x:.6875,y:.8125},{x:.6875,y:.8125},{x:.8125,y:.8125},{x:.8125,y:.8125},{x:.8125,y:.8125},{x:.8125,y:.8125},{x:.8125,y:.8125},{x:.8125,y:.8125},{x:.9375,y:.8125},{x:.9375,y:.8125},{x:.9375,y:.8125},{x:.9375,y:.8125},{x:.9375,y:.8125},{x:.9375,y:.8125},{x:.0625,y:.9375},{x:.0625,y:.9375},{x:.0625,y:.9375},{x:.0625,y:.9375},{x:.0625,y:.9375},{x:.0625,y:.9375},{x:.1875,y:.9375},{x:.1875,y:.9375},{x:.1875,y:.9375},{x:.1875,y:.9375},{x:.1875,y:.9375},{x:.1875,y:.9375},{x:.3125,y:.9375},{x:.3125,y:.9375},{x:.3125,y:.9375},{x:.3125,y:.9375},{x:.3125,y:.9375},{x:.3125,y:.9375},{x:.4375,y:.9375},{x:.4375,y:.9375},{x:.4375,y:.9375},{x:.4375,y:.9375},{x:.4375,y:.9375},{x:.4375,y:.9375},{x:.5625,y:.9375},{x:.5625,y:.9375},{x:.5625,y:.9375},{x:.5625,y:.9375},{x:.5625,y:.9375},{x:.5625,y:.9375},{x:.6875,y:.9375},{x:.6875,y:.9375},{x:.6875,y:.9375},{x:.6875,y:.9375},{x:.6875,y:.9375},{x:.6875,y:.9375},{x:.8125,y:.9375},{x:.8125,y:.9375},{x:.8125,y:.9375},{x:.8125,y:.9375},{x:.8125,y:.9375},{x:.8125,y:.9375},{x:.9375,y:.9375},{x:.9375,y:.9375},{x:.9375,y:.9375},{x:.9375,y:.9375},{x:.9375,y:.9375},{x:.9375,y:.9375}];var T5=class{constructor(e){var t;this.model=e,this.anchors=gA.map(s=>[s.x,s.y]),this.anchorsTensor=r.tensor2d(this.anchors),this.inputSize=(t=this.model)==null?void 0:t.inputs[0].shape[2],this.inputSizeTensor=r.tensor1d([this.inputSize,this.inputSize]),this.doubleInputSizeTensor=r.tensor1d([this.inputSize*2,this.inputSize*2])}normalizeBoxes(e){return r.tidy(()=>{let t=r.slice(e,[0,0],[-1,2]),s=r.slice(e,[0,2],[-1,2]),o=r.add(r.div(t,this.inputSizeTensor),this.anchorsTensor),i=r.div(s,this.doubleInputSizeTensor),n=r.mul(r.sub(o,i),this.inputSizeTensor),a=r.mul(r.add(o,i),this.inputSizeTensor);return r.concat2d([n,a],1)})}normalizeLandmarks(e,t){return r.tidy(()=>{let s=r.add(r.div(e.reshape([-1,7,2]),this.inputSizeTensor),this.anchors[t]);return r.mul(s,this.inputSizeTensor)})}async getBoxes(e,t){let s=this.model.predict(e),o=s.squeeze();s.dispose();let i=r.tidy(()=>r.sigmoid(r.slice(o,[0,0],[-1,1])).squeeze()),n=i.dataSync(),a=r.slice(o,[0,1],[-1,4]),x=this.normalizeBoxes(a);a.dispose();let l=await r.image.nonMaxSuppressionAsync(x,n,t.hand.maxDetected,t.hand.iouThreshold,t.hand.minConfidence),d=l.arraySync();i.dispose(),l.dispose();let y=[];for(let h of d)if(n[h]>=t.hand.minConfidence){let p=r.slice(x,[h,0],[1,-1]),z=r.slice(o,[h,5],[1,14]),c=r.tidy(()=>this.normalizeLandmarks(z,h).reshape([-1,2]));z.dispose(),y.push({box:p,palmLandmarks:c,confidence:n[h]})}return o.dispose(),x.dispose(),y}async estimateHandBounds(e,t){let s=e.shape[1],o=e.shape[2],i=r.tidy(()=>e.resizeBilinear([this.inputSize,this.inputSize]).div(127.5).sub(1)),n=await this.getBoxes(i,t);i.dispose();let a=[];if(!n||n.length===0)return a;for(let x of n){let l=x.box.dataSync(),d=l.slice(0,2),y=l.slice(2,4),h=x.palmLandmarks.arraySync();x.box.dispose(),x.palmLandmarks.dispose(),a.push(bA({startPoint:d,endPoint:y,palmLandmarks:h,confidence:x.confidence},[o/this.inputSize,s/this.inputSize]))}return a}};function h2(A){return A-2*Math.PI*Math.floor((A+Math.PI)/(2*Math.PI))}function TA(A,e){let t=Math.PI/2-Math.atan2(-(e[1]-A[1]),e[0]-A[0]);return h2(t)}var PA=(A,e)=>[[1,0,A],[0,1,e],[0,0,1]];function D(A,e){let t=0;for(let s=0;sM5([...i,1],t)),o=this.calculateLandmarksBoundingBox(s);return k0(O0(o),p2)}getBoxForHandLandmarks(e){let t=this.calculateLandmarksBoundingBox(e),s=k0(O0(t),vA);s.palmLandmarks=[];for(let o=0;o[n[0]*(p[0]-this.inputSize/2),n[1]*(p[1]-this.inputSize/2),n[2]*p[2]]),x=P5(s,[0,0]),l=a.map(p=>[...M5(p,x),p[2]]),d=zA(o),y=[...m0(t),1],h=[D(y,d[0]),D(y,d[1])];return l.map(p=>[p[0]+h[0],p[1]+h[1],p[2]])}async estimateHands(e,t){let s=!1,o;(this.skipped===0||this.skipped>t.hand.skipFrames||!t.hand.landmarks||!t.videoOptimized)&&(o=await this.handDetector.estimateHandBounds(e,t),this.skipped=0),t.videoOptimized&&this.skipped++,o&&o.length>0&&(o.length!==this.detectedHands&&this.detectedHands!==t.hand.maxDetected||!t.hand.landmarks)&&(this.detectedHands=0,this.storedBoxes=[...o],this.storedBoxes.length>0&&(s=!0));let i=[];t.hand.skipInitial&&this.detectedHands===0&&(this.skipped=0);for(let n=0;n=t.hand.minConfidence){let R=r.reshape(M,[-1,3]),j=R.arraySync();M.dispose(),R.dispose();let g=this.transformRawCoords(j,p,x,h),m=this.getBoxForHandLandmarks(g);this.storedBoxes[n]=m;let T={landmarks:g,confidence:E,box:{topLeft:m.startPoint,bottomRight:m.endPoint}};i.push(T)}else this.storedBoxes[n]=null;M.dispose()}else{let x=k0(O0(a),vA),l={confidence:a.confidence,box:{topLeft:x.startPoint,bottomRight:x.endPoint}};i.push(l)}}return this.storedBoxes=this.storedBoxes.filter(n=>n!==null),this.detectedHands=i.length,i}calculateLandmarksBoundingBox(e){let t=e.map(n=>n[0]),s=e.map(n=>n[1]),o=[Math.min(...t),Math.min(...s)],i=[Math.max(...t),Math.max(...s)];return{startPoint:o,endPoint:i}}};var RA={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]},G,Q,jA;async function E5(A,e){let t=await jA.estimateHands(A,e);if(!t)return[];let s=[];for(let o of t){let i={};if(o.landmarks)for(let x of Object.keys(RA))i[x]=RA[x].map(l=>o.landmarks[l]);let n=o.box?[Math.max(0,o.box.topLeft[0]),Math.max(0,o.box.topLeft[1]),Math.min(A.shape[2],o.box.bottomRight[0])-Math.max(0,o.box.topLeft[0]),Math.min(A.shape[1],o.box.bottomRight[1])-Math.max(0,o.box.topLeft[1])]:[],a=[o.box.topLeft[0]/A.shape[2],o.box.topLeft[1]/A.shape[1],(o.box.bottomRight[0]-o.box.topLeft[0])/A.shape[2],(o.box.bottomRight[1]-o.box.topLeft[1])/A.shape[1]];s.push({confidence:Math.round(100*o.confidence)/100,box:n,boxRaw:a,landmarks:o.landmarks,annotations:i})}return s}async function R5(A){!G||!Q?([G,Q]=await Promise.all([A.hand.enabled?r.loadGraphModel(O(A.modelBasePath,A.hand.detector.modelPath),{fromTFHub:A.hand.detector.modelPath.includes("tfhub.dev")}):null,A.hand.landmarks?r.loadGraphModel(O(A.modelBasePath,A.hand.skeleton.modelPath),{fromTFHub:A.hand.skeleton.modelPath.includes("tfhub.dev")}):null]),A.hand.enabled&&(!G||!G.modelUrl?b("load model failed:",A.hand.detector.modelPath):A.debug&&b("load model:",G.modelUrl),!Q||!Q.modelUrl?b("load model failed:",A.hand.skeleton.modelPath):A.debug&&b("load model:",Q.modelUrl))):(A.debug&&b("cached model:",G.modelUrl),A.debug&&b("cached model:",Q.modelUrl));let e=new T5(G);return jA=new z5(e,Q),[G,Q]}var j5={};Y(j5,{load:()=>S5,predict:()=>w5});var SA=["nose","leftEyeInside","leftEye","leftEyeOutside","rightEyeInside","rightEye","rightEyeOutside","leftEar","rightEar","leftMouth","rightMouth","leftShoulder","rightShoulder","leftElbow","rightElbow","leftWrist","rightWrist","leftPalm","rightPalm","leftIndex","rightIndex","leftPinky","rightPinky","leftHip","rightHip","leftKnee","rightKnee","leftAnkle","rightAnkle","leftHeel","rightHeel","leftFoot","rightFoot","midHip","forehead","leftThumb","leftHand","rightThumb","rightHand"],wA=["nose","leftEyeInside","leftEye","leftEyeOutside","rightEyeInside","rightEye","rightEyeOutside","leftEar","rightEar","leftMouth","rightMouth","leftShoulder","rightShoulder","leftElbow","rightElbow","left:15","right:16","left:17","right:18","left:19","right:20","left:21","right:22","leftChest","rightChest","neck","forehead","left:27","right:28","left:29","right:30"];var L;async function S5(A){return L?A.debug&&b("cached model:",L.modelUrl):(L=await r.loadGraphModel(O(A.modelBasePath,A.body.modelPath)),L.width=parseInt(L.signature.inputs["input_1:0"].tensorShape.dim[2].size),L.height=parseInt(L.signature.inputs["input_1:0"].tensorShape.dim[1].size),!L||!L.modelUrl?b("load model failed:",A.body.modelPath):A.debug&&b("load model:",L.modelUrl)),L}async function w5(A,e){if(!L||!e.body.enabled)return null;let t={width:A.shape[2],height:A.shape[1]},s=r.image.resizeBilinear(A,[L.width,L.height],!1),o=r.div(s,[255]);s.dispose();let i=await L.predict(o),n=i.find(y=>y.size===195||y.size===155).dataSync();i.forEach(y=>y.dispose()),o.dispose();let a=[],x=n.length===195?SA:wA,l=5;for(let y=0;yh.score>y?h.score:y,0),keypoints:a}]}var W5={};Y(W5,{load:()=>I5,predict:()=>k5});var L0=[{class:1,label:"person"},{class:2,label:"bicycle"},{class:3,label:"car"},{class:4,label:"motorcycle"},{class:5,label:"airplane"},{class:6,label:"bus"},{class:7,label:"train"},{class:8,label:"truck"},{class:9,label:"boat"},{class:10,label:"traffic light"},{class:11,label:"fire hydrant"},{class:12,label:"stop sign"},{class:13,label:"parking meter"},{class:14,label:"bench"},{class:15,label:"bird"},{class:16,label:"cat"},{class:17,label:"dog"},{class:18,label:"horse"},{class:19,label:"sheep"},{class:20,label:"cow"},{class:21,label:"elephant"},{class:22,label:"bear"},{class:23,label:"zebra"},{class:24,label:"giraffe"},{class:25,label:"backpack"},{class:26,label:"umbrella"},{class:27,label:"handbag"},{class:28,label:"tie"},{class:29,label:"suitcase"},{class:30,label:"frisbee"},{class:31,label:"skis"},{class:32,label:"snowboard"},{class:33,label:"sports ball"},{class:34,label:"kite"},{class:35,label:"baseball bat"},{class:36,label:"baseball glove"},{class:37,label:"skateboard"},{class:38,label:"surfboard"},{class:39,label:"tennis racket"},{class:40,label:"bottle"},{class:41,label:"wine glass"},{class:42,label:"cup"},{class:43,label:"fork"},{class:44,label:"knife"},{class:45,label:"spoon"},{class:46,label:"bowl"},{class:47,label:"banana"},{class:48,label:"apple"},{class:49,label:"sandwich"},{class:50,label:"orange"},{class:51,label:"broccoli"},{class:52,label:"carrot"},{class:53,label:"hot dog"},{class:54,label:"pizza"},{class:55,label:"donut"},{class:56,label:"cake"},{class:57,label:"chair"},{class:58,label:"couch"},{class:59,label:"potted plant"},{class:60,label:"bed"},{class:61,label:"dining table"},{class:62,label:"toilet"},{class:63,label:"tv"},{class:64,label:"laptop"},{class:65,label:"mouse"},{class:66,label:"remote"},{class:67,label:"keyboard"},{class:68,label:"cell phone"},{class:69,label:"microwave"},{class:70,label:"oven"},{class:71,label:"toaster"},{class:72,label:"sink"},{class:73,label:"refrigerator"},{class:74,label:"book"},{class:75,label:"clock"},{class:76,label:"vase"},{class:77,label:"scissors"},{class:78,label:"teddy bear"},{class:79,label:"hair drier"},{class:80,label:"toothbrush"}];var Z,N5=[],Z0=Number.MAX_SAFE_INTEGER,V0=2.5;async function I5(A){if(Z)A.debug&&b("cached model:",Z.modelUrl);else{Z=await r.loadGraphModel(O(A.modelBasePath,A.object.modelPath));let e=Object.values(Z.modelSignature.inputs);if(Z.inputSize=Array.isArray(e)?parseInt(e[0].tensorShape.dim[2].size):null,!Z.inputSize)throw new Error(`Human: Cannot determine model inputSize: ${A.object.modelPath}`);!Z||!Z.modelUrl?b("load model failed:",A.object.modelPath):A.debug&&b("load model:",Z.modelUrl)}return Z}async function T2(A,e,t,s){let o=0,i=[];for(let l of[1,2,4])r.tidy(()=>{var u,M;let d=l*13,y=(u=A.find(E=>E.shape[1]===d**2&&E.shape[2]===L0.length))==null?void 0:u.squeeze(),h=(M=A.find(E=>E.shape[1]===d**2&&E.shape[2]s.object.minConfidence&&R!==61){let g=(.5+Math.trunc(E%d))/d,m=(.5+Math.trunc(E/d))/d,T=z[E].map($=>$*(d/l/e)),[v,w]=[g-V0/l*T[0],m-V0/l*T[1]],[k,C]=[g+V0/l*T[2]-v,m+V0/l*T[3]-w],V=[v,w,k,C];V=V.map($=>Math.max(0,Math.min($,1)));let g0=[V[0]*t[0],V[1]*t[1],V[2]*t[0],V[3]*t[1]],C0={id:o++,strideSize:l,score:Math.round(100*j)/100,class:R+1,label:L0[R].label,center:[Math.trunc(t[0]*g),Math.trunc(t[1]*m)],centerRaw:[g,m],box:g0.map($=>Math.trunc($)),boxRaw:V};i.push(C0)}}});A.forEach(l=>r.dispose(l));let n=i.map(l=>l.boxRaw),a=i.map(l=>l.score),x=[];if(n&&n.length>0){let l=await r.image.nonMaxSuppressionAsync(n,a,s.object.maxDetected,s.object.iouThreshold,s.object.minConfidence);x=l.dataSync(),r.dispose(l)}return i=i.filter((l,d)=>x.includes(d)).sort((l,d)=>d.score-l.score),i}async function k5(A,e){return Z?Z00?(Z0++,N5):(e.videoOptimized?Z0=0:Z0=Number.MAX_SAFE_INTEGER,new Promise(async t=>{let s=[A.shape[2],A.shape[1]],o=r.image.resizeBilinear(A,[Z.inputSize,Z.inputSize],!1),i=o.div(255),n=i.transpose([0,3,1,2]);i.dispose(),o.dispose();let a;e.object.enabled&&(a=await Z.predict(n)),n.dispose();let x=await T2(a,Z.inputSize,s,e);N5=x,t(x)})):null}var WA=A=>{if(!A)return[];let e=[];for(let t=0;tx.part==="leftWrist"),o=A[t].keypoints.find(x=>x.part==="rightWrist"),i=A[t].keypoints.find(x=>x.part==="nose");i&&s&&o&&s.position.yx.part==="leftShoulder"),a=A[t].keypoints.find(x=>x.part==="rightShoulder");n&&a&&e.push({body:t,gesture:`leaning ${n.position.y>a.position.y?"left":"right"}`})}return e},NA=A=>{if(!A)return[];let e=[];for(let t=0;t0){let s=A[t].mesh[33][2]-A[t].mesh[263][2];Math.abs(s)<10?e.push({face:t,gesture:"facing center"}):e.push({face:t,gesture:`facing ${s<0?"left":"right"}`}),Math.abs(A[t].mesh[374][1]-A[t].mesh[386][1])/Math.abs(A[t].mesh[443][1]-A[t].mesh[450][1])<.2&&e.push({face:t,gesture:"blink left eye"}),Math.abs(A[t].mesh[145][1]-A[t].mesh[159][1])/Math.abs(A[t].mesh[223][1]-A[t].mesh[230][1])<.2&&e.push({face:t,gesture:"blink right eye"});let n=Math.min(100,500*Math.abs(A[t].mesh[13][1]-A[t].mesh[14][1])/Math.abs(A[t].mesh[10][1]-A[t].mesh[152][1]));n>10&&e.push({face:t,gesture:`mouth ${Math.trunc(n)}% open`});let a=A[t].mesh[152][2];Math.abs(a)>10&&e.push({face:t,gesture:`head ${a<0?"up":"down"}`})}return e},IA=A=>{if(!A)return[];let e=[];for(let t=0;t.033||y>.033)&&(l=!1),h>.033&&e.push({iris:t,gesture:"looking right"}),y>.033&&e.push({iris:t,gesture:"looking left"});let p=Math.abs(A[t].mesh[145][1]-A[t].annotations.rightEyeIris[0][1])/A[t].annotations.rightEyeIris[0][1],z=Math.abs(A[t].mesh[374][1]-A[t].annotations.leftEyeIris[0][1])/A[t].annotations.leftEyeIris[0][1];(z<.015||p<.015||z>.03||p>.03)&&(l=!1),(z<.015||p<.015)&&e.push({iris:t,gesture:"looking down"}),(z>.03||p>.03)&&e.push({iris:t,gesture:"looking up"}),l&&e.push({iris:t,gesture:"looking center"})}return e},kA=A=>{if(!A)return[];let e=[];for(let t=0;t0){let o=s.reduce((n,a)=>n.position[2]n.position[1]L5});function P2(A,e,t){let s=function(a,x,l){let d=new RegExp("\\b"+x+" \\w+ (\\w+)","ig");a.replace(d,(y,h)=>(l[h]=0,y))},o=function(a,x){let l=A.createShader(x);if(A.shaderSource(l,a),A.compileShader(l),!A.getShaderParameter(l,A.COMPILE_STATUS))throw new Error("Filter: GL compile failed",A.getShaderInfoLog(l));return l};this.uniform={},this.attribute={};let i=o(e,A.VERTEX_SHADER),n=o(t,A.FRAGMENT_SHADER);if(this.id=A.createProgram(),A.attachShader(this.id,i),A.attachShader(this.id,n),A.linkProgram(this.id),!A.getProgramParameter(this.id,A.LINK_STATUS))throw new Error("Filter: GL link failed",A.getProgramInfoLog(this.id));A.useProgram(this.id),s(e,"attribute",this.attribute);for(let a in this.attribute)this.attribute[a]=A.getAttribLocation(this.id,a);s(e,"uniform",this.uniform),s(t,"uniform",this.uniform);for(let a in this.uniform)this.uniform[a]=A.getUniformLocation(this.id,a)}function OA(A){A||(A={});let e=0,t=null,s=!1,o=-1,i=[null,null],n=[],a=-1,x=-1,l=null,d=null,y={},h=A.canvas||document.createElement("canvas"),p={},z={INTERMEDIATE:1},c=h.getContext("webgl");if(!c)throw new Error("Filter: getContext() failed");this.addFilter=function(g){let m=Array.prototype.slice.call(arguments,1),T=y[g];n.push({func:T,args:m})},this.reset=function(){n=[]};let u=function(g,m){if(!(g===a&&m===x)){if(h.width=g,a=g,h.height=m,x=m,!l){let T=new Float32Array([-1,-1,0,1,1,-1,1,1,-1,1,0,0,-1,1,0,0,1,-1,1,1,1,1,1,0]);l=c.createBuffer(),c.bindBuffer(c.ARRAY_BUFFER,l),c.bufferData(c.ARRAY_BUFFER,T,c.STATIC_DRAW),c.pixelStorei(c.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!0)}c.viewport(0,0,a,x),i=[null,null]}},M=function(g,m){let T=c.createFramebuffer();c.bindFramebuffer(c.FRAMEBUFFER,T);let v=c.createRenderbuffer();c.bindRenderbuffer(c.RENDERBUFFER,v);let w=c.createTexture();return c.bindTexture(c.TEXTURE_2D,w),c.texImage2D(c.TEXTURE_2D,0,c.RGBA,g,m,0,c.RGBA,c.UNSIGNED_BYTE,null),c.texParameteri(c.TEXTURE_2D,c.TEXTURE_MAG_FILTER,c.LINEAR),c.texParameteri(c.TEXTURE_2D,c.TEXTURE_MIN_FILTER,c.LINEAR),c.texParameteri(c.TEXTURE_2D,c.TEXTURE_WRAP_S,c.CLAMP_TO_EDGE),c.texParameteri(c.TEXTURE_2D,c.TEXTURE_WRAP_T,c.CLAMP_TO_EDGE),c.framebufferTexture2D(c.FRAMEBUFFER,c.COLOR_ATTACHMENT0,c.TEXTURE_2D,w,0),c.bindTexture(c.TEXTURE_2D,null),c.bindFramebuffer(c.FRAMEBUFFER,null),{fbo:T,texture:w}},E=function(g){return i[g]=i[g]||M(a,x),i[g]},R=function(g=null){var w,k;let m=null,T=null,v=!1;e===0?m=t:m=(w=E(o))==null?void 0:w.texture,e++,s&&!(g&z.INTERMEDIATE)?(T=null,v=e%2==0):(o=(o+1)%2,T=(k=E(o))==null?void 0:k.fbo),c.bindTexture(c.TEXTURE_2D,m),c.bindFramebuffer(c.FRAMEBUFFER,T),c.uniform1f(d.uniform.flipY,v?-1:1),c.drawArrays(c.TRIANGLES,0,6)};this.apply=function(g){if(u(g.width,g.height),e=0,t||(t=c.createTexture()),c.bindTexture(c.TEXTURE_2D,t),c.texParameteri(c.TEXTURE_2D,c.TEXTURE_WRAP_S,c.CLAMP_TO_EDGE),c.texParameteri(c.TEXTURE_2D,c.TEXTURE_WRAP_T,c.CLAMP_TO_EDGE),c.texParameteri(c.TEXTURE_2D,c.TEXTURE_MIN_FILTER,c.NEAREST),c.texParameteri(c.TEXTURE_2D,c.TEXTURE_MAG_FILTER,c.NEAREST),c.texImage2D(c.TEXTURE_2D,0,c.RGBA,c.RGBA,c.UNSIGNED_BYTE,g),n.length===0)return R(),h;for(let m=0;m0,i=A.naturalHeight||A.videoHeight||A.height||A.shape&&A.shape[2]>0,t=o,a=i;if(t>H0&&(t=H0,a=t*i/o),a>H0&&(a=H0,t=a*o/i),e.filter.width>0?t=e.filter.width:e.filter.height>0&&(t=o*(e.filter.height/i)),e.filter.height>0?a=e.filter.height:e.filter.width>0&&(a=i*(e.filter.width/o)),!t||!a)throw new Error("Human: Input cannot determine dimension");(!P||(P==null?void 0:P.width)!==t||(P==null?void 0:P.height)!==a)&&(P=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(t,a):document.createElement("canvas"),(P==null?void 0:P.width)!==t&&(P.width=t),(P==null?void 0:P.height)!==a&&(P.height=a));let x=P.getContext("2d");if(A instanceof ImageData?x.putImageData(A,0,0):e.filter.flip&&typeof x.translate!="undefined"?(x.translate(o,0),x.scale(-1,1),x.drawImage(A,0,0,o,i,0,0,P==null?void 0:P.width,P==null?void 0:P.height),x.setTransform(1,0,0,1,0,0)):x.drawImage(A,0,0,o,i,0,0,P==null?void 0:P.width,P==null?void 0:P.height),e.filter.enabled){if((!I||!N||P.width!==N.width||(P==null?void 0:P.height)!==(N==null?void 0:N.height))&&(N=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(P==null?void 0:P.width,P==null?void 0:P.height):document.createElement("canvas"),(N==null?void 0:N.width)!==(P==null?void 0:P.width)&&(N.width=P==null?void 0:P.width),(N==null?void 0:N.height)!==(P==null?void 0:P.height)&&(N.height=P==null?void 0:P.height),I=r.ENV.flags.IS_BROWSER?new LA({canvas:N}):null),!I)return{tensor:null,canvas:P};I.reset(),I.addFilter("brightness",e.filter.brightness),e.filter.contrast!==0&&I.addFilter("contrast",e.filter.contrast),e.filter.sharpness!==0&&I.addFilter("sharpen",e.filter.sharpness),e.filter.blur!==0&&I.addFilter("blur",e.filter.blur),e.filter.saturation!==0&&I.addFilter("saturation",e.filter.saturation),e.filter.hue!==0&&I.addFilter("hue",e.filter.hue),e.filter.negative&&I.addFilter("negative"),e.filter.sepia&&I.addFilter("sepia"),e.filter.vintage&&I.addFilter("brownie"),e.filter.sepia&&I.addFilter("sepia"),e.filter.kodachrome&&I.addFilter("kodachrome"),e.filter.technicolor&&I.addFilter("technicolor"),e.filter.polaroid&&I.addFilter("polaroid"),e.filter.pixelate!==0&&I.addFilter("pixelate",e.filter.pixelate),I.apply(P)}else N=P,I&&(I=null);let l;if(N.data){let y=[N.height,N.width,3];l=r.tensor3d(N.data,y,"int32")}else if(N instanceof ImageData)l=r.browser.fromPixels(N);else if(e.backend==="webgl"||e.backend==="humangl"){let y=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(t,a):document.createElement("canvas");y.width=t,y.height=a;let u=y.getContext("2d");u==null||u.drawImage(N,0,0),l=r.browser.fromPixels(y)}else{let y=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(t,a):document.createElement("canvas");y.width=t,y.height=a;let u=y.getContext("2d");u==null||u.drawImage(N,0,0);let p=u==null?void 0:u.getImageData(0,0,t,a);l=r.browser.fromPixels(p)}let d=l.toFloat();n=d.expandDims(0),l.dispose(),d.dispose()}let s=e.filter.return?N:null;return{tensor:n,canvas:s}}var Z5={};Y(Z5,{all:()=>z2,body:()=>HA,canvas:()=>M2,face:()=>VA,gesture:()=>ZA,hand:()=>XA,object:()=>FA,options:()=>n0});var w={backend:"webgl",modelBasePath:"../models/",wasmPath:"../assets/",debug:!0,async:!0,videoOptimized:!0,warmup:"full",filter:{enabled:!0,width:0,height:0,flip:!1,return:!0,brightness:0,contrast:0,sharpness:0,blur:0,saturation:0,hue:0,negative:!1,sepia:!1,vintage:!1,kodachrome:!1,technicolor:!1,polaroid:!1,pixelate:0},gesture:{enabled:!0},face:{enabled:!0,detector:{modelPath:"blazeface.json",rotation:!1,maxDetected:10,skipFrames:21,skipInitial:!1,minConfidence:.2,iouThreshold:.1,return:!1},mesh:{enabled:!0,modelPath:"facemesh.json"},iris:{enabled:!0,modelPath:"iris.json"},description:{enabled:!0,modelPath:"faceres.json",skipFrames:31,minConfidence:.1},emotion:{enabled:!0,minConfidence:.1,skipFrames:32,modelPath:"emotion.json"}},body:{enabled:!0,modelPath:"posenet.json",maxDetected:1,minConfidence:.2},hand:{enabled:!0,rotation:!1,skipFrames:12,skipInitial:!1,minConfidence:.1,iouThreshold:.1,maxDetected:1,landmarks:!0,detector:{modelPath:"handdetect.json"},skeleton:{modelPath:"handskeleton.json"}},object:{enabled:!1,modelPath:"nanodet.json",minConfidence:.2,iouThreshold:.4,maxDetected:10,skipFrames:41}};var n0={color:"rgba(173, 216, 230, 0.3)",labelColor:"rgba(173, 216, 230, 1)",shadowColor:"black",font:'small-caps 16px "Segoe UI"',lineHeight:24,lineWidth:6,pointSize:2,roundRect:28,drawPoints:!1,drawLabels:!0,drawBoxes:!1,drawPolygons:!0,fillPolygons:!1,useDepth:!0,useCurves:!1,bufferedOutput:!1,useRawBoxes:!1,calculateHandBox:!0};function X0(A,e,n,s=0,o){A.fillStyle=o.useDepth&&s?`rgba(${127.5+2*s}, ${127.5-2*s}, 255, 0.3)`:o.color,A.beginPath(),A.arc(e,n,o.pointSize,0,2*Math.PI),A.fill()}function o0(A,e,n,s,o,i){if(A.beginPath(),i.useCurves){let t=(e+e+s)/2,a=(n+n+o)/2;A.ellipse(t,a,s/2,o/2,0,0,2*Math.PI)}else A.lineWidth=i.lineWidth,A.moveTo(e+i.roundRect,n),A.lineTo(e+s-i.roundRect,n),A.quadraticCurveTo(e+s,n,e+s,n+i.roundRect),A.lineTo(e+s,n+o-i.roundRect),A.quadraticCurveTo(e+s,n+o,e+s-i.roundRect,n+o),A.lineTo(e+i.roundRect,n+o),A.quadraticCurveTo(e,n+o,e,n+o-i.roundRect),A.lineTo(e,n+i.roundRect),A.quadraticCurveTo(e,n,e+i.roundRect,n),A.closePath();A.stroke()}function V5(A,e=[],n){if(!(e===void 0||e.length===0)){A.beginPath(),A.moveTo(e[0][0],e[0][1]);for(let s of e)A.strokeStyle=n.useDepth&&s[2]?`rgba(${127.5+2*s[2]}, ${127.5-2*s[2]}, 255, 0.3)`:n.color,A.fillStyle=n.useDepth&&s[2]?`rgba(${127.5+2*s[2]}, ${127.5-2*s[2]}, 255, 0.3)`:n.color,A.lineTo(s[0],parseInt(s[1]));A.stroke(),n.fillPolygons&&(A.closePath(),A.fill())}}function h0(A,e=[],n){if(!(e===void 0||e.length===0)){if(!n.useCurves||e.length<=2){V5(A,e,n);return}A.moveTo(e[0][0],e[0][1]);for(let s=0;s1&&x[1].length>0){let l=a[1]>0?`#${a[1]}`:"",d=`${a[0]} ${l}: ${x[1]}`;s.shadowColor&&s.shadowColor!==""&&(o.fillStyle=s.shadowColor,o.fillText(d,8,2+i*s.lineHeight)),o.fillStyle=s.labelColor,o.fillText(d,6,0+i*s.lineHeight),i+=1}}}async function VA(A,e,n){let s=F(n0,n);if(!e||!A||!(A instanceof HTMLCanvasElement))return;let o=A.getContext("2d");if(!!o)for(let i of e){o.font=s.font,o.strokeStyle=s.color,o.fillStyle=s.color,s.drawBoxes&&(s.useRawBoxes?o0(o,A.width*i.boxRaw[0],A.height*i.boxRaw[1],A.width*i.boxRaw[2],A.height*i.boxRaw[3],s):o0(o,i.box[0],i.box[1],i.box[2],i.box[3],s));let t=[];if(t.push(`face confidence: ${Math.trunc(100*i.confidence)}%`),i.genderConfidence&&t.push(`${i.gender||""} ${Math.trunc(100*i.genderConfidence)}% confident`),i.age&&t.push(`age: ${i.age||""}`),i.iris&&t.push(`iris distance: ${i.iris}`),i.emotion&&i.emotion.length>0){let a=i.emotion.map(x=>`${Math.trunc(100*x.score)}% ${x.emotion}`);t.push(a.join(" "))}i.rotation&&i.rotation.angle&&i.rotation.angle.roll&&t.push(`roll: ${Math.trunc(100*i.rotation.angle.roll)/100} yaw:${Math.trunc(100*i.rotation.angle.yaw)/100} pitch:${Math.trunc(100*i.rotation.angle.pitch)/100}`),t.length===0&&t.push("face"),o.fillStyle=s.color;for(let a=t.length-1;a>=0;a--){let x=Math.max(i.box[0],0),l=a*s.lineHeight+i.box[1];s.shadowColor&&s.shadowColor!==""&&(o.fillStyle=s.shadowColor,o.fillText(t[a],x+5,l+16)),o.fillStyle=s.labelColor,o.fillText(t[a],x+4,l+15)}if(o.lineWidth=1,i.mesh&&i.mesh.length>0){if(s.drawPoints)for(let a of i.mesh)X0(o,a[0],a[1],a[2],s);if(s.drawPolygons){o.lineWidth=1;for(let a=0;ai.mesh[l]);V5(o,x,s)}if(i.annotations&&i.annotations.leftEyeIris){o.strokeStyle=s.useDepth?"rgba(255, 200, 255, 0.3)":s.color,o.beginPath();let a=Math.abs(i.annotations.leftEyeIris[3][0]-i.annotations.leftEyeIris[1][0])/2,x=Math.abs(i.annotations.leftEyeIris[4][1]-i.annotations.leftEyeIris[2][1])/2;o.ellipse(i.annotations.leftEyeIris[0][0],i.annotations.leftEyeIris[0][1],a,x,0,0,2*Math.PI),o.stroke(),s.fillPolygons&&(o.fillStyle=s.useDepth?"rgba(255, 255, 200, 0.3)":s.color,o.fill())}if(i.annotations&&i.annotations.rightEyeIris){o.strokeStyle=s.useDepth?"rgba(255, 200, 255, 0.3)":s.color,o.beginPath();let a=Math.abs(i.annotations.rightEyeIris[3][0]-i.annotations.rightEyeIris[1][0])/2,x=Math.abs(i.annotations.rightEyeIris[4][1]-i.annotations.rightEyeIris[2][1])/2;o.ellipse(i.annotations.rightEyeIris[0][0],i.annotations.rightEyeIris[0][1],a,x,0,0,2*Math.PI),o.stroke(),s.fillPolygons&&(o.fillStyle=s.useDepth?"rgba(255, 255, 200, 0.3)":s.color,o.fill())}}}}}var $=[];async function HA(A,e,n){let s=F(n0,n);if(!e||!A||!(A instanceof HTMLCanvasElement))return;let o=A.getContext("2d");if(!!o){o.lineJoin="round";for(let i=0;ix.part==="leftShoulder"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),t=e[i].keypoints.find(x=>x.part==="rightShoulder"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),h0(o,a,s),a.length=0,t=e[i].keypoints.find(x=>x.part==="rightShoulder"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),t=e[i].keypoints.find(x=>x.part==="rightHip"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),t=e[i].keypoints.find(x=>x.part==="leftHip"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),t=e[i].keypoints.find(x=>x.part==="leftShoulder"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),a.length===4&&V5(o,a,s),a.length=0,t=e[i].keypoints.find(x=>x.part==="leftHip"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),t=e[i].keypoints.find(x=>x.part==="leftKnee"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),t=e[i].keypoints.find(x=>x.part==="leftAnkle"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),t=e[i].keypoints.find(x=>x.part==="leftHeel"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),t=e[i].keypoints.find(x=>x.part==="leftFoot"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),h0(o,a,s),a.length=0,t=e[i].keypoints.find(x=>x.part==="rightHip"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),t=e[i].keypoints.find(x=>x.part==="rightKnee"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),t=e[i].keypoints.find(x=>x.part==="rightAnkle"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),t=e[i].keypoints.find(x=>x.part==="rightHeel"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),t=e[i].keypoints.find(x=>x.part==="rightFoot"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),h0(o,a,s),a.length=0,t=e[i].keypoints.find(x=>x.part==="leftShoulder"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),t=e[i].keypoints.find(x=>x.part==="leftElbow"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),t=e[i].keypoints.find(x=>x.part==="leftWrist"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),t=e[i].keypoints.find(x=>x.part==="leftPalm"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),h0(o,a,s),a.length=0,t=e[i].keypoints.find(x=>x.part==="rightShoulder"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),t=e[i].keypoints.find(x=>x.part==="rightElbow"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),t=e[i].keypoints.find(x=>x.part==="rightWrist"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),t=e[i].keypoints.find(x=>x.part==="rightPalm"),t&&t.score>w.body.minConfidence&&a.push([t.position.x,t.position.y]),h0(o,a,s)}}}}async function XA(A,e,n){let s=F(n0,n);if(!e||!A||!(A instanceof HTMLCanvasElement))return;let o=A.getContext("2d");if(!!o){o.lineJoin="round",o.font=s.font;for(let i of e){if(s.drawBoxes){o.strokeStyle=s.color,o.fillStyle=s.color;let t;if(!s.calculateHandBox)t=s.useRawBoxes?i.boxRaw:i.box;else if(t=[Number.MAX_SAFE_INTEGER,Number.MAX_SAFE_INTEGER,0,0],i.landmarks&&i.landmarks.length>0){for(let a of i.landmarks)a[0]t[2]&&(t[2]=a[0]),a[1]>t[3]&&(t[3]=a[1]);t[2]-=t[0],t[3]-=t[1]}s.useRawBoxes?o0(o,A.width*t[0],A.height*t[1],A.width*t[2],A.height*t[3],s):o0(o,t[0],t[1],t[2],t[3],s),s.drawLabels&&(s.shadowColor&&s.shadowColor!==""&&(o.fillStyle=s.shadowColor,o.fillText("hand",t[0]+3,1+t[1]+s.lineHeight,t[2])),o.fillStyle=s.labelColor,o.fillText("hand",t[0]+2,0+t[1]+s.lineHeight,t[2])),o.stroke()}if(s.drawPoints&&i.landmarks&&i.landmarks.length>0)for(let t of i.landmarks)o.fillStyle=s.useDepth?`rgba(${127.5+2*t[2]}, ${127.5-2*t[2]}, 255, 0.5)`:s.color,X0(o,t[0],t[1],0,s);if(s.drawLabels){let t=(a,x)=>{o.fillStyle=s.useDepth?`rgba(${127.5+2*a[a.length-1][2]}, ${127.5-2*a[a.length-1][2]}, 255, 0.5)`:s.color,o.fillText(x,a[a.length-1][0]+4,a[a.length-1][1]+4)};o.font=s.font,t(i.annotations.indexFinger,"index"),t(i.annotations.middleFinger,"middle"),t(i.annotations.ringFinger,"ring"),t(i.annotations.pinky,"pinky"),t(i.annotations.thumb,"thumb"),t(i.annotations.palmBase,"palm")}if(s.drawPolygons){let t=a=>{if(!!a)for(let x=0;x0?x-1:0][0],a[x>0?x-1:0][1]),o.lineTo(a[x][0],a[x][1]),o.stroke()};o.lineWidth=s.lineWidth,t(i.annotations.indexFinger),t(i.annotations.middleFinger),t(i.annotations.ringFinger),t(i.annotations.pinky),t(i.annotations.thumb)}}}}async function FA(A,e,n){let s=F(n0,n);if(!e||!A||!(A instanceof HTMLCanvasElement))return;let o=A.getContext("2d");if(!!o){o.lineJoin="round",o.font=s.font;for(let i of e)if(s.drawBoxes){if(o.strokeStyle=s.color,o.fillStyle=s.color,s.useRawBoxes?o0(o,A.width*i.boxRaw[0],A.height*i.boxRaw[1],A.width*i.boxRaw[2],A.height*i.boxRaw[3],s):o0(o,i.box[0],i.box[1],i.box[2],i.box[3],s),s.drawLabels){let t=`${Math.round(100*i.score)}% ${i.label}`;s.shadowColor&&s.shadowColor!==""&&(o.fillStyle=s.shadowColor,o.fillText(t,i.box[0]+3,1+i.box[1]+s.lineHeight,i.box[2])),o.fillStyle=s.labelColor,o.fillText(t,i.box[0]+2,0+i.box[1]+s.lineHeight,i.box[2])}o.stroke()}}}async function M2(A,e){if(!A||!e||!(A instanceof HTMLCanvasElement)||!(e instanceof HTMLCanvasElement))return;let n=A.getContext("2d");n==null||n.drawImage(A,0,0)}async function z2(A,e,n){let s=F(n0,n);!e||!A||A instanceof HTMLCanvasElement&&(VA(A,e.face,s),HA(A,e.body,s),XA(A,e.hand,s),ZA(A,e.gesture,s),FA(A,e.object,s))}var F0=` +`)}var H0=2048,P,W,N;function L5(A,e){let t;if(!A)throw new Error("Human: Input is missing");if(!(A instanceof r.Tensor)&&!(typeof Image!="undefined"&&A instanceof Image)&&!(typeof ImageData!="undefined"&&A instanceof ImageData)&&!(typeof ImageBitmap!="undefined"&&A instanceof ImageBitmap)&&!(typeof HTMLImageElement!="undefined"&&A instanceof HTMLImageElement)&&!(typeof HTMLMediaElement!="undefined"&&A instanceof HTMLMediaElement)&&!(typeof HTMLVideoElement!="undefined"&&A instanceof HTMLVideoElement)&&!(typeof HTMLCanvasElement!="undefined"&&A instanceof HTMLCanvasElement)&&!(typeof OffscreenCanvas!="undefined"&&A instanceof OffscreenCanvas))throw new Error("Human: Input type is not recognized");if(A instanceof r.Tensor)if(A.shape&&A.shape.length===4&&A.shape[0]===1&&A.shape[3]===3)t=r.clone(A);else throw new Error(`Human: Input tensor shape must be [1, height, width, 3] and instead was ${A.shape}`);else{let o=A.naturalWidth||A.videoWidth||A.width||A.shape&&A.shape[1]>0,i=A.naturalHeight||A.videoHeight||A.height||A.shape&&A.shape[2]>0,n=o,a=i;if(n>H0&&(n=H0,a=n*i/o),a>H0&&(a=H0,n=a*o/i),e.filter.width>0?n=e.filter.width:e.filter.height>0&&(n=o*(e.filter.height/i)),e.filter.height>0?a=e.filter.height:e.filter.width>0&&(a=i*(e.filter.width/o)),!n||!a)throw new Error("Human: Input cannot determine dimension");(!P||(P==null?void 0:P.width)!==n||(P==null?void 0:P.height)!==a)&&(P=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(n,a):document.createElement("canvas"),(P==null?void 0:P.width)!==n&&(P.width=n),(P==null?void 0:P.height)!==a&&(P.height=a));let x=P.getContext("2d");if(A instanceof ImageData?x.putImageData(A,0,0):e.filter.flip&&typeof x.translate!="undefined"?(x.translate(o,0),x.scale(-1,1),x.drawImage(A,0,0,o,i,0,0,P==null?void 0:P.width,P==null?void 0:P.height),x.setTransform(1,0,0,1,0,0)):x.drawImage(A,0,0,o,i,0,0,P==null?void 0:P.width,P==null?void 0:P.height),e.filter.enabled){if((!N||!W||P.width!==W.width||(P==null?void 0:P.height)!==(W==null?void 0:W.height))&&(W=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(P==null?void 0:P.width,P==null?void 0:P.height):document.createElement("canvas"),(W==null?void 0:W.width)!==(P==null?void 0:P.width)&&(W.width=P==null?void 0:P.width),(W==null?void 0:W.height)!==(P==null?void 0:P.height)&&(W.height=P==null?void 0:P.height),N=r.ENV.flags.IS_BROWSER?new OA({canvas:W}):null),!N)return{tensor:null,canvas:P};N.reset(),N.addFilter("brightness",e.filter.brightness),e.filter.contrast!==0&&N.addFilter("contrast",e.filter.contrast),e.filter.sharpness!==0&&N.addFilter("sharpen",e.filter.sharpness),e.filter.blur!==0&&N.addFilter("blur",e.filter.blur),e.filter.saturation!==0&&N.addFilter("saturation",e.filter.saturation),e.filter.hue!==0&&N.addFilter("hue",e.filter.hue),e.filter.negative&&N.addFilter("negative"),e.filter.sepia&&N.addFilter("sepia"),e.filter.vintage&&N.addFilter("brownie"),e.filter.sepia&&N.addFilter("sepia"),e.filter.kodachrome&&N.addFilter("kodachrome"),e.filter.technicolor&&N.addFilter("technicolor"),e.filter.polaroid&&N.addFilter("polaroid"),e.filter.pixelate!==0&&N.addFilter("pixelate",e.filter.pixelate),N.apply(P)}else W=P,N&&(N=null);let l;if(W.data){let y=[W.height,W.width,3];l=r.tensor3d(W.data,y,"int32")}else if(W instanceof ImageData)l=r.browser.fromPixels(W);else if(e.backend==="webgl"||e.backend==="humangl"){let y=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(n,a):document.createElement("canvas");y.width=n,y.height=a;let h=y.getContext("2d");h==null||h.drawImage(W,0,0),l=r.browser.fromPixels(y)}else{let y=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(n,a):document.createElement("canvas");y.width=n,y.height=a;let h=y.getContext("2d");h==null||h.drawImage(W,0,0);let p=h==null?void 0:h.getImageData(0,0,n,a);l=r.browser.fromPixels(p)}let d=l.toFloat();t=d.expandDims(0),l.dispose(),d.dispose()}let s=e.filter.return?W:null;return{tensor:t,canvas:s}}var Z5={};Y(Z5,{all:()=>z2,body:()=>VA,canvas:()=>M2,face:()=>ZA,gesture:()=>LA,hand:()=>HA,object:()=>XA,options:()=>t0});var t0={color:"rgba(173, 216, 230, 0.3)",labelColor:"rgba(173, 216, 230, 1)",shadowColor:"black",font:'small-caps 16px "Segoe UI"',lineHeight:24,lineWidth:6,pointSize:2,roundRect:28,drawPoints:!1,drawLabels:!0,drawBoxes:!1,drawPolygons:!0,fillPolygons:!1,useDepth:!0,useCurves:!1,bufferedOutput:!1,useRawBoxes:!1,calculateHandBox:!0};function X0(A,e,t,s=0,o){A.fillStyle=o.useDepth&&s?`rgba(${127.5+2*s}, ${127.5-2*s}, 255, 0.3)`:o.color,A.beginPath(),A.arc(e,t,o.pointSize,0,2*Math.PI),A.fill()}function n0(A,e,t,s,o,i){if(A.beginPath(),i.useCurves){let n=(e+e+s)/2,a=(t+t+o)/2;A.ellipse(n,a,s/2,o/2,0,0,2*Math.PI)}else A.lineWidth=i.lineWidth,A.moveTo(e+i.roundRect,t),A.lineTo(e+s-i.roundRect,t),A.quadraticCurveTo(e+s,t,e+s,t+i.roundRect),A.lineTo(e+s,t+o-i.roundRect),A.quadraticCurveTo(e+s,t+o,e+s-i.roundRect,t+o),A.lineTo(e+i.roundRect,t+o),A.quadraticCurveTo(e,t+o,e,t+o-i.roundRect),A.lineTo(e,t+i.roundRect),A.quadraticCurveTo(e,t,e+i.roundRect,t),A.closePath();A.stroke()}function V5(A,e=[],t){if(!(e===void 0||e.length===0)){A.beginPath(),A.moveTo(e[0][0],e[0][1]);for(let s of e)A.strokeStyle=t.useDepth&&s[2]?`rgba(${127.5+2*s[2]}, ${127.5-2*s[2]}, 255, 0.3)`:t.color,A.fillStyle=t.useDepth&&s[2]?`rgba(${127.5+2*s[2]}, ${127.5-2*s[2]}, 255, 0.3)`:t.color,A.lineTo(s[0],parseInt(s[1]));A.stroke(),t.fillPolygons&&(A.closePath(),A.fill())}}function h0(A,e=[],t){if(!(e===void 0||e.length===0)){if(!t.useCurves||e.length<=2){V5(A,e,t);return}A.moveTo(e[0][0],e[0][1]);for(let s=0;s1&&x[1].length>0){let l=a[1]>0?`#${a[1]}`:"",d=`${a[0]} ${l}: ${x[1]}`;s.shadowColor&&s.shadowColor!==""&&(o.fillStyle=s.shadowColor,o.fillText(d,8,2+i*s.lineHeight)),o.fillStyle=s.labelColor,o.fillText(d,6,0+i*s.lineHeight),i+=1}}}async function ZA(A,e,t){let s=X(t0,t);if(!e||!A||!(A instanceof HTMLCanvasElement))return;let o=A.getContext("2d");if(!!o)for(let i of e){o.font=s.font,o.strokeStyle=s.color,o.fillStyle=s.color,s.drawBoxes&&(s.useRawBoxes?n0(o,A.width*i.boxRaw[0],A.height*i.boxRaw[1],A.width*i.boxRaw[2],A.height*i.boxRaw[3],s):n0(o,i.box[0],i.box[1],i.box[2],i.box[3],s));let n=[];if(n.push(`face confidence: ${Math.trunc(100*i.confidence)}%`),i.genderConfidence&&n.push(`${i.gender||""} ${Math.trunc(100*i.genderConfidence)}% confident`),i.age&&n.push(`age: ${i.age||""}`),i.iris&&n.push(`iris distance: ${i.iris}`),i.emotion&&i.emotion.length>0){let a=i.emotion.map(x=>`${Math.trunc(100*x.score)}% ${x.emotion}`);n.push(a.join(" "))}i.rotation&&i.rotation.angle&&i.rotation.angle.roll&&n.push(`roll: ${Math.trunc(100*i.rotation.angle.roll)/100} yaw:${Math.trunc(100*i.rotation.angle.yaw)/100} pitch:${Math.trunc(100*i.rotation.angle.pitch)/100}`),n.length===0&&n.push("face"),o.fillStyle=s.color;for(let a=n.length-1;a>=0;a--){let x=Math.max(i.box[0],0),l=a*s.lineHeight+i.box[1];s.shadowColor&&s.shadowColor!==""&&(o.fillStyle=s.shadowColor,o.fillText(n[a],x+5,l+16)),o.fillStyle=s.labelColor,o.fillText(n[a],x+4,l+15)}if(o.lineWidth=1,i.mesh&&i.mesh.length>0){if(s.drawPoints)for(let a of i.mesh)X0(o,a[0],a[1],a[2],s);if(s.drawPolygons){o.lineWidth=1;for(let a=0;ai.mesh[l]);V5(o,x,s)}if(i.annotations&&i.annotations.leftEyeIris){o.strokeStyle=s.useDepth?"rgba(255, 200, 255, 0.3)":s.color,o.beginPath();let a=Math.abs(i.annotations.leftEyeIris[3][0]-i.annotations.leftEyeIris[1][0])/2,x=Math.abs(i.annotations.leftEyeIris[4][1]-i.annotations.leftEyeIris[2][1])/2;o.ellipse(i.annotations.leftEyeIris[0][0],i.annotations.leftEyeIris[0][1],a,x,0,0,2*Math.PI),o.stroke(),s.fillPolygons&&(o.fillStyle=s.useDepth?"rgba(255, 255, 200, 0.3)":s.color,o.fill())}if(i.annotations&&i.annotations.rightEyeIris){o.strokeStyle=s.useDepth?"rgba(255, 200, 255, 0.3)":s.color,o.beginPath();let a=Math.abs(i.annotations.rightEyeIris[3][0]-i.annotations.rightEyeIris[1][0])/2,x=Math.abs(i.annotations.rightEyeIris[4][1]-i.annotations.rightEyeIris[2][1])/2;o.ellipse(i.annotations.rightEyeIris[0][0],i.annotations.rightEyeIris[0][1],a,x,0,0,2*Math.PI),o.stroke(),s.fillPolygons&&(o.fillStyle=s.useDepth?"rgba(255, 255, 200, 0.3)":s.color,o.fill())}}}}}var _=[];async function VA(A,e,t){let s=X(t0,t);if(!e||!A||!(A instanceof HTMLCanvasElement))return;let o=A.getContext("2d");if(!!o){o.lineJoin="round";for(let i=0;ix.part==="leftShoulder"),n&&a.push([n.position.x,n.position.y]),n=e[i].keypoints.find(x=>x.part==="rightShoulder"),n&&a.push([n.position.x,n.position.y]),h0(o,a,s),a.length=0,n=e[i].keypoints.find(x=>x.part==="rightShoulder"),n&&a.push([n.position.x,n.position.y]),n=e[i].keypoints.find(x=>x.part==="rightHip"),n&&a.push([n.position.x,n.position.y]),n=e[i].keypoints.find(x=>x.part==="leftHip"),n&&a.push([n.position.x,n.position.y]),n=e[i].keypoints.find(x=>x.part==="leftShoulder"),n&&a.push([n.position.x,n.position.y]),a.length===4&&V5(o,a,s),a.length=0,n=e[i].keypoints.find(x=>x.part==="leftHip"),n&&a.push([n.position.x,n.position.y]),n=e[i].keypoints.find(x=>x.part==="leftKnee"),n&&a.push([n.position.x,n.position.y]),n=e[i].keypoints.find(x=>x.part==="leftAnkle"),n&&a.push([n.position.x,n.position.y]),n=e[i].keypoints.find(x=>x.part==="leftHeel"),n&&a.push([n.position.x,n.position.y]),n=e[i].keypoints.find(x=>x.part==="leftFoot"),n&&a.push([n.position.x,n.position.y]),h0(o,a,s),a.length=0,n=e[i].keypoints.find(x=>x.part==="rightHip"),n&&a.push([n.position.x,n.position.y]),n=e[i].keypoints.find(x=>x.part==="rightKnee"),n&&a.push([n.position.x,n.position.y]),n=e[i].keypoints.find(x=>x.part==="rightAnkle"),n&&a.push([n.position.x,n.position.y]),n=e[i].keypoints.find(x=>x.part==="rightHeel"),n&&a.push([n.position.x,n.position.y]),n=e[i].keypoints.find(x=>x.part==="rightFoot"),n&&a.push([n.position.x,n.position.y]),h0(o,a,s),a.length=0,n=e[i].keypoints.find(x=>x.part==="leftShoulder"),n&&a.push([n.position.x,n.position.y]),n=e[i].keypoints.find(x=>x.part==="leftElbow"),n&&a.push([n.position.x,n.position.y]),n=e[i].keypoints.find(x=>x.part==="leftWrist"),n&&a.push([n.position.x,n.position.y]),n=e[i].keypoints.find(x=>x.part==="leftPalm"),n&&a.push([n.position.x,n.position.y]),h0(o,a,s),a.length=0,n=e[i].keypoints.find(x=>x.part==="rightShoulder"),n&&a.push([n.position.x,n.position.y]),n=e[i].keypoints.find(x=>x.part==="rightElbow"),n&&a.push([n.position.x,n.position.y]),n=e[i].keypoints.find(x=>x.part==="rightWrist"),n&&a.push([n.position.x,n.position.y]),n=e[i].keypoints.find(x=>x.part==="rightPalm"),n&&a.push([n.position.x,n.position.y]),h0(o,a,s)}}}}async function HA(A,e,t){let s=X(t0,t);if(!e||!A||!(A instanceof HTMLCanvasElement))return;let o=A.getContext("2d");if(!!o){o.lineJoin="round",o.font=s.font;for(let i of e){if(s.drawBoxes){o.strokeStyle=s.color,o.fillStyle=s.color;let n;if(!s.calculateHandBox)n=s.useRawBoxes?i.boxRaw:i.box;else if(n=[Number.MAX_SAFE_INTEGER,Number.MAX_SAFE_INTEGER,0,0],i.landmarks&&i.landmarks.length>0){for(let a of i.landmarks)a[0]n[2]&&(n[2]=a[0]),a[1]>n[3]&&(n[3]=a[1]);n[2]-=n[0],n[3]-=n[1]}s.useRawBoxes?n0(o,A.width*n[0],A.height*n[1],A.width*n[2],A.height*n[3],s):n0(o,n[0],n[1],n[2],n[3],s),s.drawLabels&&(s.shadowColor&&s.shadowColor!==""&&(o.fillStyle=s.shadowColor,o.fillText("hand",n[0]+3,1+n[1]+s.lineHeight,n[2])),o.fillStyle=s.labelColor,o.fillText("hand",n[0]+2,0+n[1]+s.lineHeight,n[2])),o.stroke()}if(s.drawPoints&&i.landmarks&&i.landmarks.length>0)for(let n of i.landmarks)o.fillStyle=s.useDepth?`rgba(${127.5+2*n[2]}, ${127.5-2*n[2]}, 255, 0.5)`:s.color,X0(o,n[0],n[1],0,s);if(s.drawLabels){let n=(a,x)=>{o.fillStyle=s.useDepth?`rgba(${127.5+2*a[a.length-1][2]}, ${127.5-2*a[a.length-1][2]}, 255, 0.5)`:s.color,o.fillText(x,a[a.length-1][0]+4,a[a.length-1][1]+4)};o.font=s.font,n(i.annotations.indexFinger,"index"),n(i.annotations.middleFinger,"middle"),n(i.annotations.ringFinger,"ring"),n(i.annotations.pinky,"pinky"),n(i.annotations.thumb,"thumb"),n(i.annotations.palmBase,"palm")}if(s.drawPolygons){let n=a=>{if(!!a)for(let x=0;x0?x-1:0][0],a[x>0?x-1:0][1]),o.lineTo(a[x][0],a[x][1]),o.stroke()};o.lineWidth=s.lineWidth,n(i.annotations.indexFinger),n(i.annotations.middleFinger),n(i.annotations.ringFinger),n(i.annotations.pinky),n(i.annotations.thumb)}}}}async function XA(A,e,t){let s=X(t0,t);if(!e||!A||!(A instanceof HTMLCanvasElement))return;let o=A.getContext("2d");if(!!o){o.lineJoin="round",o.font=s.font;for(let i of e)if(s.drawBoxes){if(o.strokeStyle=s.color,o.fillStyle=s.color,s.useRawBoxes?n0(o,A.width*i.boxRaw[0],A.height*i.boxRaw[1],A.width*i.boxRaw[2],A.height*i.boxRaw[3],s):n0(o,i.box[0],i.box[1],i.box[2],i.box[3],s),s.drawLabels){let n=`${Math.round(100*i.score)}% ${i.label}`;s.shadowColor&&s.shadowColor!==""&&(o.fillStyle=s.shadowColor,o.fillText(n,i.box[0]+3,1+i.box[1]+s.lineHeight,i.box[2])),o.fillStyle=s.labelColor,o.fillText(n,i.box[0]+2,0+i.box[1]+s.lineHeight,i.box[2])}o.stroke()}}}async function M2(A,e){if(!A||!e||!(A instanceof HTMLCanvasElement)||!(e instanceof HTMLCanvasElement))return;let t=A.getContext("2d");t==null||t.drawImage(A,0,0)}async function z2(A,e,t){let s=X(t0,t);!e||!A||A instanceof HTMLCanvasElement&&(ZA(A,e.face,s),VA(A,e.body,s),HA(A,e.hand,s),LA(A,e.gesture,s),XA(A,e.object,s))}var FA={backend:"webgl",modelBasePath:"../models/",wasmPath:"../assets/",debug:!0,async:!0,videoOptimized:!0,warmup:"full",filter:{enabled:!0,width:0,height:0,flip:!1,return:!0,brightness:0,contrast:0,sharpness:0,blur:0,saturation:0,hue:0,negative:!1,sepia:!1,vintage:!1,kodachrome:!1,technicolor:!1,polaroid:!1,pixelate:0},gesture:{enabled:!0},face:{enabled:!0,detector:{modelPath:"blazeface.json",rotation:!1,maxDetected:10,skipFrames:21,skipInitial:!1,minConfidence:.2,iouThreshold:.1,return:!1},mesh:{enabled:!0,modelPath:"facemesh.json"},iris:{enabled:!0,modelPath:"iris.json"},description:{enabled:!0,modelPath:"faceres.json",skipFrames:31,minConfidence:.1},emotion:{enabled:!0,minConfidence:.1,skipFrames:32,modelPath:"emotion.json"}},body:{enabled:!0,modelPath:"posenet.json",maxDetected:1,minConfidence:.1},hand:{enabled:!0,rotation:!1,skipFrames:12,skipInitial:!1,minConfidence:.1,iouThreshold:.1,maxDetected:1,landmarks:!0,detector:{modelPath:"handdetect.json"},skeleton:{modelPath:"handskeleton.json"}},object:{enabled:!1,modelPath:"nanodet.json",minConfidence:.2,iouThreshold:.4,maxDetected:10,skipFrames:41}};var F0=` /9j/4AAQSkZJRgABAQEAYABgAAD/4QBoRXhpZgAATU0AKgAAAAgABAEaAAUAAAABAAAAPgEbAAUA AAABAAAARgEoAAMAAAABAAIAAAExAAIAAAARAAAATgAAAAAAAABgAAAAAQAAAGAAAAABcGFpbnQu bmV0IDQuMi4xMwAA/9sAQwAGBAUGBQQGBgUGBwcGCAoQCgoJCQoUDg8MEBcUGBgXFBYWGh0lHxob @@ -731,5 +731,5 @@ AAAAAAJAAAAAAAAAAAAAABAJEAAAAAAAAAAAAAAAIEoBKAAAAAAAAAAAAAAABAlAAAAAAAIAAAAA BAkBAkBAkBAlACEgMZjdjbFW8bWrEx8YWANb6Fp+bfwab+vLDKMFK9qxH5L0bAr8OPRPKz2AY7J2 SbAjYZAI2E7AIEgIEgIEgMdkSy2NgY7MdlmyNoBXsxmFuyNgVTVjNV3KjlBRNTlXTVHKCrlIqt5T lBhEMohlFerLlBjEMohMVTEARDKCITsAk2AEgAAAkAAAAAAAAAAAAAAAAAAAAAAAASAAAAAAAAD/ -2Q==`;var qA="1.8.2";var y0,u0,p0,s0,B0,b0,C0,U0,Y0,E2=class{constructor(e={}){y0.set(this,void 0);u0.set(this,void 0);p0.set(this,void 0);s0.set(this,void 0);this.analyze=(...e)=>{if(!B(this,u0))return;let n=this.tf.engine().state.numTensors,s=B(this,y0);e0(this,y0,n);let o=n-s;o!==0&&b(...e,o)};B0.set(this,e=>{if(!B(this,p0))return null;if(!e)return"input is not defined";if(this.tf.ENV.flags.IS_NODE&&!(e instanceof r.Tensor))return"input must be a tensor";try{this.tf.getBackend()}catch(n){return"backend not loaded"}return null});b0.set(this,async(e=!1)=>{var n;if(this.config.backend&&this.config.backend.length>0&&e||this.tf.getBackend()!==this.config.backend){let s=S();if(this.state="backend",this.config.backend&&this.config.backend.length>0){if(typeof window=="undefined"&&typeof WorkerGlobalScope!="undefined"&&this.config.debug&&b("running inside web worker"),this.tf.ENV.flags.IS_BROWSER&&this.config.backend==="tensorflow"&&(this.config.backend="webgl"),this.tf.ENV.flags.IS_NODE&&(this.config.backend==="webgl"||this.config.backend==="humangl")&&(this.config.backend="tensorflow"),this.config.debug&&b("setting backend:",this.config.backend),this.config.backend==="wasm"){if(this.config.debug&&b("wasm path:",this.config.wasmPath),typeof((n=this.tf)==null?void 0:n.setWasmPaths)!="undefined")this.tf.setWasmPaths(this.config.wasmPath);else throw new Error("Human: WASM backend is not loaded");let o=await this.tf.env().getAsync("WASM_HAS_SIMD_SUPPORT"),i=await this.tf.env().getAsync("WASM_HAS_MULTITHREAD_SUPPORT");this.config.debug&&b(`wasm execution: ${o?"SIMD":"no SIMD"} ${i?"multithreaded":"singlethreaded"}`),this.config.debug&&!o&&b("warning: wasm simd support is not enabled")}this.config.backend==="humangl"&&D5();try{await this.tf.setBackend(this.config.backend)}catch(o){b("error: cannot set backend:",this.config.backend,o)}}if(this.tf.enableProdMode(),this.tf.getBackend()==="webgl"||this.tf.getBackend()==="humangl"){this.tf.ENV.set("CHECK_COMPUTATION_FOR_ERRORS",!1),this.tf.ENV.set("WEBGL_PACK_DEPTHWISECONV",!0),typeof this.config.deallocate!="undefined"&&(b("changing webgl: WEBGL_DELETE_TEXTURE_THRESHOLD:",!0),this.tf.ENV.set("WEBGL_DELETE_TEXTURE_THRESHOLD",0));let o=await this.tf.backend().getGPGPUContext().gl;this.config.debug&&b(`gl version:${o.getParameter(o.VERSION)} renderer:${o.getParameter(o.RENDERER)}`)}await this.tf.ready(),this.perf.backend=Math.trunc(S()-s)}});C0.set(this,async()=>{let e=(o,i="application/octet-stream")=>fetch(`data:${i};base64,${o}`).then(t=>t.blob()),n,s;switch(this.config.warmup){case"face":n=await e(F0);break;case"full":n=await e(q0);break;default:n=null}if(n){let o=await createImageBitmap(n);s=await this.detect(o,this.config),o.close()}return s});U0.set(this,async()=>new Promise(e=>{let n,s=0;switch(this.config.warmup){case"face":s=256,n="data:image/jpeg;base64,"+F0;break;case"full":case"body":s=1200,n="data:image/jpeg;base64,"+q0;break;default:n=null}let o=new Image;o.onload=async()=>{let i=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(s,s):document.createElement("canvas");i.width=o.naturalWidth,i.height=o.naturalHeight;let t=i.getContext("2d");t==null||t.drawImage(o,0,0);let a=await this.detect(i,this.config);e(a)},n?o.src=n:e(null)}));Y0.set(this,async()=>{let e=o=>Buffer.from(o,"base64"),n;if(this.config.warmup==="face"&&(n=e(F0)),(this.config.warmup==="body"||this.config.warmup==="full")&&(n=e(q0)),!n)return null;let s;if(typeof r.node!="undefined"){let o=r.node.decodeJpeg(n),i=o.expandDims(0);this.tf.dispose(o),s=await this.detect(i,this.config),this.tf.dispose(i)}else this.config.debug&&b("Warmup tfjs-node not loaded");return s});this.tf=r,this.draw=Z5,this.version=qA,this.config=F(w,e),this.state="idle",e0(this,y0,0),e0(this,u0,!1),e0(this,p0,!1),e0(this,s0,!0),this.perf={},this.models={face:null,posenet:null,blazepose:null,efficientpose:null,handpose:null,iris:null,age:null,gender:null,emotion:null,embedding:null,nanodet:null,faceres:null},this.image=n=>L5(n,this.config),this.classes={facemesh:A5,emotion:o5,faceres:a5,body:this.config.body.modelPath.includes("posenet")?p5:j5,hand:v5,nanodet:W5},this.faceTriangulation=rA,this.faceUVMap=aA,this.sysinfo=B5()}similarity(e,n){return y5(e,n)}enhance(e){return l5(e)}match(e,n,s=0){return xA(e,n,s)}async load(e={}){this.state="load";let n=S();e&&(this.config=F(this.config,e)),B(this,s0)&&(this.config.debug&&b(`version: ${this.version}`),this.config.debug&&b(`tfjs version: ${this.tf.version_core}`),this.config.debug&&b("platform:",this.sysinfo.platform),this.config.debug&&b("agent:",this.sysinfo.agent),await B(this,b0).call(this,!0),this.tf.ENV.flags.IS_BROWSER&&(this.config.debug&&b("configuration:",this.config),this.config.debug&&b("tf flags:",this.tf.ENV.flags))),this.config.async?[this.models.face,this.models.emotion,this.models.handpose,this.models.posenet,this.models.blazepose,this.models.nanodet,this.models.faceres]=await Promise.all([this.models.face||(this.config.face.enabled?n5(this.config):null),this.models.emotion||(this.config.face.enabled&&this.config.face.emotion.enabled?r5(this.config):null),this.models.handpose||(this.config.hand.enabled?R5(this.config):null),this.models.posenet||(this.config.body.enabled&&this.config.body.modelPath.includes("posenet")?g5(this.config):null),this.models.blazepose||(this.config.body.enabled&&this.config.body.modelPath.includes("blazepose")?S5(this.config):null),this.models.nanodet||(this.config.object.enabled?I5(this.config):null),this.models.faceres||(this.config.face.enabled&&this.config.face.description.enabled?x5(this.config):null)]):(this.config.face.enabled&&!this.models.face&&(this.models.face=await n5(this.config)),this.config.face.enabled&&this.config.face.emotion.enabled&&!this.models.emotion&&(this.models.emotion=await r5(this.config)),this.config.hand.enabled&&!this.models.handpose&&(this.models.handpose=await R5(this.config)),this.config.body.enabled&&!this.models.posenet&&this.config.body.modelPath.includes("posenet")&&(this.models.posenet=await g5(this.config)),this.config.body.enabled&&!this.models.blazepose&&this.config.body.modelPath.includes("blazepose")&&(this.models.blazepose=await S5(this.config)),this.config.object.enabled&&!this.models.nanodet&&(this.models.nanodet=await I5(this.config)),this.config.face.enabled&&this.config.face.description.enabled&&!this.models.faceres&&(this.models.faceres=await x5(this.config))),B(this,s0)&&(this.config.debug&&b("tf engine state:",this.tf.engine().state.numBytes,"bytes",this.tf.engine().state.numTensors,"tensors"),e0(this,s0,!1));let s=Math.trunc(S()-n);s>(this.perf.load||0)&&(this.perf.load=s)}async detect(e,n={}){return new Promise(async s=>{this.state="config";let o;this.config=F(this.config,n),this.state="check";let i=B(this,B0).call(this,e);i&&(b(i,e),s({error:i}));let t=S();await B(this,b0).call(this),await this.load();let a;e&&this.config.videoOptimized&&typeof window!="undefined"&&typeof WorkerGlobalScope!="undefined"&&(typeof HTMLImageElement!="undefined"&&e instanceof HTMLImageElement||typeof Image!="undefined"&&e instanceof Image||typeof ImageData!="undefined"&&e instanceof ImageData||typeof ImageBitmap!="undefined"&&O5 instanceof ImageBitmap)&&(b("disabling video optimization"),a=this.config.videoOptimized,this.config.videoOptimized=!1),o=S();let x=L5(e,this.config);if(!x||!x.tensor){b("could not convert input to tensor"),s({error:"could not convert input to tensor"});return}this.perf.image=Math.trunc(S()-o),this.analyze("Get Image:");let l,d,y,u,p;this.config.async?(y=this.config.face.enabled?c5(this,x.tensor):[],this.perf.face&&delete this.perf.face):(this.state="run:face",o=S(),y=this.config.face.enabled?await c5(this,x.tensor):[],p=Math.trunc(S()-o),p>0&&(this.perf.face=p)),this.analyze("Start Body:"),this.config.async?(this.config.body.modelPath.includes("posenet")?l=this.config.body.enabled?b5(x.tensor,this.config):[]:this.config.body.modelPath.includes("blazepose")&&(l=this.config.body.enabled?w5(x.tensor,this.config):[]),this.perf.body&&delete this.perf.body):(this.state="run:body",o=S(),this.config.body.modelPath.includes("posenet")?l=this.config.body.enabled?await b5(x.tensor,this.config):[]:this.config.body.modelPath.includes("blazepose")&&(l=this.config.body.enabled?await w5(x.tensor,this.config):[]),p=Math.trunc(S()-o),p>0&&(this.perf.body=p)),this.analyze("End Body:"),this.analyze("Start Hand:"),this.config.async?(d=this.config.hand.enabled?E5(x.tensor,this.config):[],this.perf.hand&&delete this.perf.hand):(this.state="run:hand",o=S(),d=this.config.hand.enabled?await E5(x.tensor,this.config):[],p=Math.trunc(S()-o),p>0&&(this.perf.hand=p)),this.analyze("End Hand:"),this.analyze("Start Object:"),this.config.async?(u=this.config.object.enabled?k5(x.tensor,this.config):[],this.perf.object&&delete this.perf.object):(this.state="run:object",o=S(),u=this.config.object.enabled?await k5(x.tensor,this.config):[],p=Math.trunc(S()-o),p>0&&(this.perf.object=p)),this.analyze("End Object:"),this.config.async&&([y,l,d,u]=await Promise.all([y,l,d,u])),r.dispose(x.tensor);let E=[];this.config.gesture.enabled&&(o=S(),E=[...IA(y),...NA(l),...OA(d),...kA(y)],this.config.async?this.perf.gesture&&delete this.perf.gesture:this.perf.gesture=Math.trunc(S()-o)),a&&(this.config.videoOptimized=a),this.perf.total=Math.trunc(S()-t),this.state="idle";let c={face:y,body:l,hand:d,gesture:E,object:u,performance:this.perf,canvas:x.canvas};s(c)})}async warmup(e={}){let n=S();if(e&&(this.config=F(this.config,e)),!this.config.warmup||this.config.warmup==="none")return{error:"null"};let s=this.config.videoOptimized;this.config.videoOptimized=!1;let o;typeof createImageBitmap=="function"?o=await B(this,C0).call(this):typeof Image!="undefined"?o=await B(this,U0).call(this):o=await B(this,Y0).call(this),this.config.videoOptimized=s;let i=S();return this.config.debug&&b("Warmup",this.config.warmup,Math.round(i-n),"ms",o),o}};y0=new WeakMap,u0=new WeakMap,p0=new WeakMap,s0=new WeakMap,B0=new WeakMap,b0=new WeakMap,C0=new WeakMap,U0=new WeakMap,Y0=new WeakMap;export{E2 as Human,E2 as default}; +2Q==`;var qA="1.8.2";var y0,u0,p0,o0,B0,b0,U0,Y0,J0,E2=class{constructor(e={}){y0.set(this,void 0);u0.set(this,void 0);p0.set(this,void 0);o0.set(this,void 0);this.analyze=(...e)=>{if(!q(this,u0))return;let t=this.tf.engine().state.numTensors,s=q(this,y0);A0(this,y0,t);let o=t-s;o!==0&&b(...e,o)};B0.set(this,e=>{if(!q(this,p0))return null;if(!e)return"input is not defined";if(this.tf.ENV.flags.IS_NODE&&!(e instanceof r.Tensor))return"input must be a tensor";try{this.tf.getBackend()}catch(t){return"backend not loaded"}return null});b0.set(this,async(e=!1)=>{var t;if(this.config.backend&&this.config.backend.length>0&&e||this.tf.getBackend()!==this.config.backend){let s=S();if(this.state="backend",this.config.backend&&this.config.backend.length>0){if(typeof window=="undefined"&&typeof WorkerGlobalScope!="undefined"&&this.config.debug&&b("running inside web worker"),this.tf.ENV.flags.IS_BROWSER&&this.config.backend==="tensorflow"&&(this.config.backend="webgl"),this.tf.ENV.flags.IS_NODE&&(this.config.backend==="webgl"||this.config.backend==="humangl")&&(this.config.backend="tensorflow"),this.config.debug&&b("setting backend:",this.config.backend),this.config.backend==="wasm"){if(this.config.debug&&b("wasm path:",this.config.wasmPath),typeof((t=this.tf)==null?void 0:t.setWasmPaths)!="undefined")this.tf.setWasmPaths(this.config.wasmPath);else throw new Error("Human: WASM backend is not loaded");let o=await this.tf.env().getAsync("WASM_HAS_SIMD_SUPPORT"),i=await this.tf.env().getAsync("WASM_HAS_MULTITHREAD_SUPPORT");this.config.debug&&b(`wasm execution: ${o?"SIMD":"no SIMD"} ${i?"multithreaded":"singlethreaded"}`),this.config.debug&&!o&&b("warning: wasm simd support is not enabled")}this.config.backend==="humangl"&&D5();try{await this.tf.setBackend(this.config.backend)}catch(o){b("error: cannot set backend:",this.config.backend,o)}}if(this.tf.enableProdMode(),this.tf.getBackend()==="webgl"||this.tf.getBackend()==="humangl"){this.tf.ENV.set("CHECK_COMPUTATION_FOR_ERRORS",!1),this.tf.ENV.set("WEBGL_PACK_DEPTHWISECONV",!0),typeof this.config.deallocate!="undefined"&&(b("changing webgl: WEBGL_DELETE_TEXTURE_THRESHOLD:",!0),this.tf.ENV.set("WEBGL_DELETE_TEXTURE_THRESHOLD",0));let o=await this.tf.backend().getGPGPUContext().gl;this.config.debug&&b(`gl version:${o.getParameter(o.VERSION)} renderer:${o.getParameter(o.RENDERER)}`)}await this.tf.ready(),this.perf.backend=Math.trunc(S()-s)}});U0.set(this,async()=>{let e=(o,i="application/octet-stream")=>fetch(`data:${i};base64,${o}`).then(n=>n.blob()),t,s;switch(this.config.warmup){case"face":t=await e(F0);break;case"full":t=await e(q0);break;default:t=null}if(t){let o=await createImageBitmap(t);s=await this.detect(o,this.config),o.close()}return s});Y0.set(this,async()=>new Promise(e=>{let t,s=0;switch(this.config.warmup){case"face":s=256,t="data:image/jpeg;base64,"+F0;break;case"full":case"body":s=1200,t="data:image/jpeg;base64,"+q0;break;default:t=null}let o=new Image;o.onload=async()=>{let i=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(s,s):document.createElement("canvas");i.width=o.naturalWidth,i.height=o.naturalHeight;let n=i.getContext("2d");n==null||n.drawImage(o,0,0);let a=await this.detect(i,this.config);e(a)},t?o.src=t:e(null)}));J0.set(this,async()=>{let e=o=>Buffer.from(o,"base64"),t;if(this.config.warmup==="face"&&(t=e(F0)),(this.config.warmup==="body"||this.config.warmup==="full")&&(t=e(q0)),!t)return null;let s;if(typeof r.node!="undefined"){let o=r.node.decodeJpeg(t),i=o.expandDims(0);this.tf.dispose(o),s=await this.detect(i,this.config),this.tf.dispose(i)}else this.config.debug&&b("Warmup tfjs-node not loaded");return s});this.tf=r,this.draw=Z5,this.version=qA,this.config=X(FA,e),this.state="idle",A0(this,y0,0),A0(this,u0,!1),A0(this,p0,!1),A0(this,o0,!0),this.perf={},this.models={face:null,posenet:null,blazepose:null,efficientpose:null,handpose:null,iris:null,age:null,gender:null,emotion:null,embedding:null,nanodet:null,faceres:null},this.image=t=>L5(t,this.config),this.classes={facemesh:A5,emotion:o5,faceres:a5,body:this.config.body.modelPath.includes("posenet")?p5:j5,hand:v5,nanodet:W5},this.faceTriangulation=rA,this.faceUVMap=aA,this.sysinfo=B5()}similarity(e,t){return y5(e,t)}enhance(e){return l5(e)}match(e,t,s=0){return xA(e,t,s)}async load(e={}){this.state="load";let t=S();e&&(this.config=X(this.config,e)),q(this,o0)&&(this.config.debug&&b(`version: ${this.version}`),this.config.debug&&b(`tfjs version: ${this.tf.version_core}`),this.config.debug&&b("platform:",this.sysinfo.platform),this.config.debug&&b("agent:",this.sysinfo.agent),await q(this,b0).call(this,!0),this.tf.ENV.flags.IS_BROWSER&&(this.config.debug&&b("configuration:",this.config),this.config.debug&&b("tf flags:",this.tf.ENV.flags))),this.config.async?[this.models.face,this.models.emotion,this.models.handpose,this.models.posenet,this.models.blazepose,this.models.nanodet,this.models.faceres]=await Promise.all([this.models.face||(this.config.face.enabled?n5(this.config):null),this.models.emotion||(this.config.face.enabled&&this.config.face.emotion.enabled?r5(this.config):null),this.models.handpose||(this.config.hand.enabled?R5(this.config):null),this.models.posenet||(this.config.body.enabled&&this.config.body.modelPath.includes("posenet")?g5(this.config):null),this.models.blazepose||(this.config.body.enabled&&this.config.body.modelPath.includes("blazepose")?S5(this.config):null),this.models.nanodet||(this.config.object.enabled?I5(this.config):null),this.models.faceres||(this.config.face.enabled&&this.config.face.description.enabled?x5(this.config):null)]):(this.config.face.enabled&&!this.models.face&&(this.models.face=await n5(this.config)),this.config.face.enabled&&this.config.face.emotion.enabled&&!this.models.emotion&&(this.models.emotion=await r5(this.config)),this.config.hand.enabled&&!this.models.handpose&&(this.models.handpose=await R5(this.config)),this.config.body.enabled&&!this.models.posenet&&this.config.body.modelPath.includes("posenet")&&(this.models.posenet=await g5(this.config)),this.config.body.enabled&&!this.models.blazepose&&this.config.body.modelPath.includes("blazepose")&&(this.models.blazepose=await S5(this.config)),this.config.object.enabled&&!this.models.nanodet&&(this.models.nanodet=await I5(this.config)),this.config.face.enabled&&this.config.face.description.enabled&&!this.models.faceres&&(this.models.faceres=await x5(this.config))),q(this,o0)&&(this.config.debug&&b("tf engine state:",this.tf.engine().state.numBytes,"bytes",this.tf.engine().state.numTensors,"tensors"),A0(this,o0,!1));let s=Math.trunc(S()-t);s>(this.perf.load||0)&&(this.perf.load=s)}async detect(e,t={}){return new Promise(async s=>{this.state="config";let o;this.config=X(this.config,t),this.state="check";let i=q(this,B0).call(this,e);i&&(b(i,e),s({error:i}));let n=S();await q(this,b0).call(this),await this.load();let a;e&&this.config.videoOptimized&&typeof window!="undefined"&&typeof WorkerGlobalScope!="undefined"&&(typeof HTMLImageElement!="undefined"&&e instanceof HTMLImageElement||typeof Image!="undefined"&&e instanceof Image||typeof ImageData!="undefined"&&e instanceof ImageData||typeof ImageBitmap!="undefined"&&O5 instanceof ImageBitmap)&&(b("disabling video optimization"),a=this.config.videoOptimized,this.config.videoOptimized=!1),o=S();let x=L5(e,this.config);if(!x||!x.tensor){b("could not convert input to tensor"),s({error:"could not convert input to tensor"});return}this.perf.image=Math.trunc(S()-o),this.analyze("Get Image:");let l,d,y,h,p;this.config.async?(y=this.config.face.enabled?c5(this,x.tensor):[],this.perf.face&&delete this.perf.face):(this.state="run:face",o=S(),y=this.config.face.enabled?await c5(this,x.tensor):[],p=Math.trunc(S()-o),p>0&&(this.perf.face=p)),this.analyze("Start Body:"),this.config.async?(this.config.body.modelPath.includes("posenet")?l=this.config.body.enabled?b5(x.tensor,this.config):[]:this.config.body.modelPath.includes("blazepose")&&(l=this.config.body.enabled?w5(x.tensor,this.config):[]),this.perf.body&&delete this.perf.body):(this.state="run:body",o=S(),this.config.body.modelPath.includes("posenet")?l=this.config.body.enabled?await b5(x.tensor,this.config):[]:this.config.body.modelPath.includes("blazepose")&&(l=this.config.body.enabled?await w5(x.tensor,this.config):[]),p=Math.trunc(S()-o),p>0&&(this.perf.body=p)),this.analyze("End Body:"),this.analyze("Start Hand:"),this.config.async?(d=this.config.hand.enabled?E5(x.tensor,this.config):[],this.perf.hand&&delete this.perf.hand):(this.state="run:hand",o=S(),d=this.config.hand.enabled?await E5(x.tensor,this.config):[],p=Math.trunc(S()-o),p>0&&(this.perf.hand=p)),this.analyze("End Hand:"),this.analyze("Start Object:"),this.config.async?(h=this.config.object.enabled?k5(x.tensor,this.config):[],this.perf.object&&delete this.perf.object):(this.state="run:object",o=S(),h=this.config.object.enabled?await k5(x.tensor,this.config):[],p=Math.trunc(S()-o),p>0&&(this.perf.object=p)),this.analyze("End Object:"),this.config.async&&([y,l,d,h]=await Promise.all([y,l,d,h])),r.dispose(x.tensor);let z=[];this.config.gesture.enabled&&(o=S(),z=[...NA(y),...WA(l),...kA(d),...IA(y)],this.config.async?this.perf.gesture&&delete this.perf.gesture:this.perf.gesture=Math.trunc(S()-o)),a&&(this.config.videoOptimized=a),this.perf.total=Math.trunc(S()-n),this.state="idle";let c={face:y,body:l,hand:d,gesture:z,object:h,performance:this.perf,canvas:x.canvas};s(c)})}async warmup(e={}){let t=S();if(e&&(this.config=X(this.config,e)),!this.config.warmup||this.config.warmup==="none")return{error:"null"};let s=this.config.videoOptimized;this.config.videoOptimized=!1;let o;typeof createImageBitmap=="function"?o=await q(this,U0).call(this):typeof Image!="undefined"?o=await q(this,Y0).call(this):o=await q(this,J0).call(this),this.config.videoOptimized=s;let i=S();return this.config.debug&&b("Warmup",this.config.warmup,Math.round(i-t),"ms",o),o}};y0=new WeakMap,u0=new WeakMap,p0=new WeakMap,o0=new WeakMap,B0=new WeakMap,b0=new WeakMap,U0=new WeakMap,Y0=new WeakMap,J0=new WeakMap;export{E2 as Human,E2 as default}; //# sourceMappingURL=human.esm-nobundle.js.map diff --git a/dist/human.esm-nobundle.js.map b/dist/human.esm-nobundle.js.map index 03d82921..8d389c8c 100644 --- a/dist/human.esm-nobundle.js.map +++ b/dist/human.esm-nobundle.js.map @@ -1,7 +1,7 @@ { "version": 3, "sources": ["../src/helpers.ts", "../src/sysinfo.ts", "../src/tfjs/tf-browser.ts", "../src/tfjs/backend.ts", "../src/blazeface/facemesh.ts", "../src/blazeface/box.ts", "../src/blazeface/util.ts", "../src/blazeface/blazeface.ts", "../src/blazeface/coords.ts", "../src/blazeface/facepipeline.ts", "../src/emotion/emotion.ts", "../src/faceres/faceres.ts", "../src/faceall.ts", "../src/posenet/posenet.ts", "../src/posenet/keypoints.ts", "../src/posenet/utils.ts", "../src/posenet/poses.ts", "../src/handpose/handpose.ts", "../src/handpose/box.ts", "../src/handpose/anchors.ts", "../src/handpose/handdetector.ts", "../src/handpose/util.ts", "../src/handpose/handpipeline.ts", "../src/blazepose/blazepose.ts", "../src/blazepose/annotations.ts", "../src/nanodet/nanodet.ts", "../src/nanodet/labels.ts", "../src/gesture/gesture.ts", "../src/image/image.ts", "../src/image/imagefx.js", "../src/draw/draw.ts", "../src/config.ts", "../src/sample.ts", "../src/human.ts"], - "sourcesContent": ["// helper function: join two paths\nexport function join(folder: string, file: string): string {\n const separator = folder.endsWith('/') ? '' : '/';\n const skipJoin = file.startsWith('.') || file.startsWith('/') || file.startsWith('http:') || file.startsWith('https:') || file.startsWith('file:');\n const path = skipJoin ? `${file}` : `${folder}${separator}${file}`;\n if (!path.toLocaleLowerCase().includes('.json')) throw new Error(`Human: ModelPath Error: ${path} Expecting JSON file`);\n return path;\n}\n\n// helper function: wrapper around console output\nexport function log(...msg) {\n const dt = new Date();\n const ts = `${dt.getHours().toString().padStart(2, '0')}:${dt.getMinutes().toString().padStart(2, '0')}:${dt.getSeconds().toString().padStart(2, '0')}.${dt.getMilliseconds().toString().padStart(3, '0')}`;\n // eslint-disable-next-line no-console\n if (msg) console.log(ts, 'Human:', ...msg);\n}\n\n// helper function: gets elapsed time on both browser and nodejs\nexport const now = () => {\n if (typeof performance !== 'undefined') return performance.now();\n return parseInt((Number(process.hrtime.bigint()) / 1000 / 1000).toString());\n};\n\n// helper function: perform deep merge of multiple objects so it allows full inheriance with overrides\nexport function mergeDeep(...objects) {\n const isObject = (obj) => obj && typeof obj === 'object';\n return objects.reduce((prev, obj) => {\n Object.keys(obj || {}).forEach((key) => {\n const pVal = prev[key];\n const oVal = obj[key];\n if (Array.isArray(pVal) && Array.isArray(oVal)) prev[key] = pVal.concat(...oVal);\n else if (isObject(pVal) && isObject(oVal)) prev[key] = mergeDeep(pVal, oVal);\n else prev[key] = oVal;\n });\n return prev;\n }, {});\n}\n", "export function info(): { platform: string, agent: string } {\n let platform;\n let agent;\n if (typeof navigator !== 'undefined') {\n const raw = navigator.userAgent.match(/\\(([^()]+)\\)/g);\n if (raw && raw[0]) {\n const platformMatch = raw[0].match(/\\(([^()]+)\\)/g);\n platform = platformMatch ? platformMatch[0].replace(/\\(|\\)/g, '') : '';\n agent = navigator.userAgent.replace(raw[0], '');\n if (platform[1]) agent = agent.replace(raw[1], '');\n agent = agent.replace(/ /g, ' ');\n }\n } else if (typeof process !== 'undefined') {\n platform = `${process.platform} ${process.arch}`;\n agent = `NodeJS ${process.version}`;\n }\n return { platform, agent };\n}\n", "// wrapper to load tfjs in a single place so version can be changed quickly\n\n// simplified\n// { modules: 1250, moduleBytes: 4013323, imports: 7, importBytes: 2255, outputBytes: 2991826, outputFiles: 'dist/tfjs.esm.js' }\n// export * from '@tensorflow/tfjs/dist/index.js';\n// export * from '@tensorflow/tfjs-backend-wasm';\n\n// modular\n// { modules: 1253, moduleBytes: 4029357, imports: 7, importBytes: 2285, outputBytes: 2998298, outputFiles: 'dist/tfjs.esm.js' }\n\n// get versions of all packages.\nimport * as packageBundle from '@tensorflow/tfjs/package.json';\nimport * as packageCore from '@tensorflow/tfjs-core/package.json';\nimport * as packageData from '@tensorflow/tfjs-data/package.json';\nimport * as packageLayers from '@tensorflow/tfjs-layers/package.json';\nimport * as packageConverter from '@tensorflow/tfjs-converter/package.json';\n// for backends, get version from source so it can register backend during import\nimport { version_cpu } from '@tensorflow/tfjs-backend-cpu/dist/index.js';\nimport { version_webgl } from '@tensorflow/tfjs-backend-webgl/dist/index.js';\nimport { version_wasm } from '@tensorflow/tfjs-backend-wasm/dist/index.js';\n\n// export all - compiled\nexport * from '@tensorflow/tfjs-core/dist/index.js';\nexport * from '@tensorflow/tfjs-layers/dist/index.js';\nexport * from '@tensorflow/tfjs-converter/dist/index.js';\nexport * as data from '@tensorflow/tfjs-data/dist/index.js';\nexport * from '@tensorflow/tfjs-backend-cpu/dist/index.js';\nexport * from '@tensorflow/tfjs-backend-webgl/dist/index.js';\nexport * from '@tensorflow/tfjs-backend-wasm/dist/index.js';\n\n// export all - sources\n/*\nexport * from '@tensorflow/tfjs-core/src/index';\nexport * from '@tensorflow/tfjs-layers/src/index';\nexport * from '@tensorflow/tfjs-converter/src/index';\nexport * as data from '@tensorflow/tfjs-data/src/index';\nexport * from '@tensorflow/tfjs-backend-cpu/src/index';\nexport * from '@tensorflow/tfjs-backend-webgl/src/index';\nexport * from '@tensorflow/tfjs-backend-wasm/src/index';\n*/\n\n// export versions\nexport const version = {\n tfjs: packageBundle?.version || undefined,\n 'tfjs-core': packageCore?.version || undefined,\n 'tfjs-data': packageData?.version || undefined,\n 'tfjs-layers': packageLayers?.version || undefined,\n 'tfjs-converter': packageConverter?.version || undefined,\n 'tfjs-backend-cpu': version_cpu || undefined,\n 'tfjs-backend-webgl': version_webgl || undefined,\n 'tfjs-backend-wasm': version_wasm || undefined,\n};\n// export const version = {};\n", "import { log } from '../helpers';\nimport * as tf from '../../dist/tfjs.esm.js';\n\nexport const config = {\n name: 'humangl',\n priority: 99,\n canvas: null,\n gl: null,\n width: 1024,\n height: 1024,\n webGLattr: { // https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.2\n alpha: false,\n antialias: false,\n premultipliedAlpha: false,\n preserveDrawingBuffer: false,\n depth: false,\n stencil: false,\n failIfMajorPerformanceCaveat: false,\n desynchronized: true,\n },\n};\n\nexport function register(): void {\n if (!tf.findBackend(config.name)) {\n log('backend registration:', config.name);\n try {\n config.canvas = (typeof OffscreenCanvas !== 'undefined') ? new OffscreenCanvas(config.width, config.height) : document.createElement('canvas');\n } catch (err) {\n log('error: cannot create canvas:', err);\n return;\n }\n try {\n config.gl = config.canvas.getContext('webgl2', config.webGLattr);\n } catch (err) {\n log('error: cannot get WebGL2 context:', err);\n return;\n }\n try {\n tf.setWebGLContext(2, config.gl);\n } catch (err) {\n log('error: cannot set WebGL2 context:', err);\n return;\n }\n try {\n const ctx = new tf.GPGPUContext(config.gl);\n tf.registerBackend(config.name, () => new tf.MathBackendWebGL(ctx), config.priority);\n } catch (err) {\n log('error: cannot register WebGL backend:', err);\n return;\n }\n try {\n const kernels = tf.getKernelsForBackend('webgl');\n kernels.forEach((kernelConfig) => {\n const newKernelConfig = { ...kernelConfig, backendName: config.name };\n tf.registerKernel(newKernelConfig);\n });\n } catch (err) {\n log('error: cannot update WebGL backend registration:', err);\n return;\n }\n try {\n tf.ENV.set('WEBGL_VERSION', 2);\n // tf.ENV.set('WEBGL_MAX_TEXTURE_SIZE', config.gl.getParameter(config.gl.MAX_TEXTURE_SIZE));\n // tf.ENV.set('WEBGL_FORCE_F16_TEXTURES', true);\n // tf.ENV.set('WEBGL_PACK_DEPTHWISECONV', true);\n } catch (err) {\n log('error: cannot set WebGL backend flags:', err);\n return;\n }\n log('backend registered:', config.name);\n }\n}\n", "import { log, join } from '../helpers';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as blazeface from './blazeface';\nimport * as facepipeline from './facepipeline';\nimport * as coords from './coords';\n\nlet faceModels:[any, any, any] = [null, null, null];\nlet facePipeline;\n\nexport async function predict(input, config): Promise<{ confidence, boxConfidence, faceConfidence, box, mesh, boxRaw, meshRaw, annotations, image }[]> {\n const predictions = await facePipeline.predict(input, config);\n const results: Array<{ confidence, boxConfidence, faceConfidence, box, mesh, boxRaw, meshRaw, annotations, image }> = [];\n for (const prediction of (predictions || [])) {\n if (!prediction || prediction.isDisposedInternal) continue; // guard against disposed tensors on long running operations such as pause in middle of processing\n const meshRaw = prediction.mesh.map((pt) => [\n pt[0] / input.shape[2],\n pt[1] / input.shape[1],\n pt[2] / facePipeline.meshSize,\n ]);\n const annotations = {};\n if (prediction.mesh && prediction.mesh.length > 0) {\n for (const key of Object.keys(coords.MESH_ANNOTATIONS)) annotations[key] = coords.MESH_ANNOTATIONS[key].map((index) => prediction.mesh[index]);\n }\n const clampedBox = prediction.box ? [\n Math.max(0, prediction.box.startPoint[0]),\n Math.max(0, prediction.box.startPoint[1]),\n Math.min(input.shape[2], prediction.box.endPoint[0]) - Math.max(0, prediction.box.startPoint[0]),\n Math.min(input.shape[1], prediction.box.endPoint[1]) - Math.max(0, prediction.box.startPoint[1]),\n ] : 0;\n const boxRaw = prediction.box ? [\n prediction.box.startPoint[0] / input.shape[2],\n prediction.box.startPoint[1] / input.shape[1],\n (prediction.box.endPoint[0] - prediction.box.startPoint[0]) / input.shape[2],\n (prediction.box.endPoint[1] - prediction.box.startPoint[1]) / input.shape[1],\n ] : [];\n results.push({\n confidence: Math.round(100 * prediction.faceConfidence || 100 * prediction.boxConfidence || 0) / 100,\n boxConfidence: Math.round(100 * prediction.boxConfidence) / 100,\n faceConfidence: Math.round(100 * prediction.faceConfidence) / 100,\n box: clampedBox,\n boxRaw,\n mesh: prediction.mesh,\n meshRaw,\n annotations,\n image: prediction.image,\n });\n if (prediction.coords) prediction.coords.dispose();\n }\n return results;\n}\n\nexport async function load(config): Promise<[Object, Object, Object]> {\n if ((!faceModels[0] && config.face.enabled) || (!faceModels[1] && config.face.mesh.enabled) || (!faceModels[2] && config.face.iris.enabled)) {\n faceModels = await Promise.all([\n (!faceModels[0] && config.face.enabled) ? blazeface.load(config) : null,\n (!faceModels[1] && config.face.mesh.enabled) ? tf.loadGraphModel(join(config.modelBasePath, config.face.mesh.modelPath), { fromTFHub: config.face.mesh.modelPath.includes('tfhub.dev') }) : null,\n (!faceModels[2] && config.face.iris.enabled) ? tf.loadGraphModel(join(config.modelBasePath, config.face.iris.modelPath), { fromTFHub: config.face.iris.modelPath.includes('tfhub.dev') }) : null,\n ]);\n if (config.face.mesh.enabled) {\n if (!faceModels[1] || !faceModels[1].modelUrl) log('load model failed:', config.face.mesh.modelPath);\n else if (config.debug) log('load model:', faceModels[1].modelUrl);\n }\n if (config.face.iris.enabled) {\n if (!faceModels[2] || !faceModels[1].modelUrl) log('load model failed:', config.face.iris.modelPath);\n else if (config.debug) log('load model:', faceModels[2].modelUrl);\n }\n } else if (config.debug) {\n log('cached model:', faceModels[0].model.modelUrl);\n log('cached model:', faceModels[1].modelUrl);\n log('cached model:', faceModels[2].modelUrl);\n }\n facePipeline = new facepipeline.Pipeline(faceModels[0], faceModels[1], faceModels[2]);\n return faceModels;\n}\n\nexport const triangulation = coords.TRI468;\nexport const uvmap = coords.UV468;\n", "import * as tf from '../../dist/tfjs.esm.js';\n\nexport function scaleBoxCoordinates(box, factor) {\n const startPoint = [box.startPoint[0] * factor[0], box.startPoint[1] * factor[1]];\n const endPoint = [box.endPoint[0] * factor[0], box.endPoint[1] * factor[1]];\n return { startPoint, endPoint };\n}\n\nexport function getBoxSize(box) {\n return [\n Math.abs(box.endPoint[0] - box.startPoint[0]),\n Math.abs(box.endPoint[1] - box.startPoint[1]),\n ];\n}\n\nexport function getBoxCenter(box) {\n return [\n box.startPoint[0] + (box.endPoint[0] - box.startPoint[0]) / 2,\n box.startPoint[1] + (box.endPoint[1] - box.startPoint[1]) / 2,\n ];\n}\n\nexport function cutBoxFromImageAndResize(box, image, cropSize) {\n const h = image.shape[1];\n const w = image.shape[2];\n const boxes = [[\n box.startPoint[1] / h,\n box.startPoint[0] / w,\n box.endPoint[1] / h,\n box.endPoint[0] / w,\n ]];\n return tf.image.cropAndResize(image, boxes, [0], cropSize);\n}\n\nexport function enlargeBox(box, factor = 1.5) {\n const center = getBoxCenter(box);\n const size = getBoxSize(box);\n const newHalfSize = [factor * size[0] / 2, factor * size[1] / 2];\n const startPoint = [center[0] - newHalfSize[0], center[1] - newHalfSize[1]];\n const endPoint = [center[0] + newHalfSize[0], center[1] + newHalfSize[1]];\n return { startPoint, endPoint, landmarks: box.landmarks };\n}\n\nexport function squarifyBox(box) {\n const centers = getBoxCenter(box);\n const size = getBoxSize(box);\n const maxEdge = Math.max(...size);\n const halfSize = maxEdge / 2;\n const startPoint = [Math.round(centers[0] - halfSize), Math.round(centers[1] - halfSize)];\n const endPoint = [Math.round(centers[0] + halfSize), Math.round(centers[1] + halfSize)];\n return { startPoint, endPoint, landmarks: box.landmarks };\n}\n\nexport function calculateLandmarksBoundingBox(landmarks) {\n const xs = landmarks.map((d) => d[0]);\n const ys = landmarks.map((d) => d[1]);\n const startPoint = [Math.min(...xs), Math.min(...ys)];\n const endPoint = [Math.max(...xs), Math.max(...ys)];\n return { startPoint, endPoint, landmarks };\n}\n\nexport const disposeBox = (t) => {\n t.startPoint.dispose();\n t.endPoint.dispose();\n};\n\nexport const createBox = (startEndTensor) => ({\n startPoint: tf.slice(startEndTensor, [0, 0], [-1, 2]),\n endPoint: tf.slice(startEndTensor, [0, 2], [-1, 2]),\n});\n", "export const IDENTITY_MATRIX = [[1, 0, 0], [0, 1, 0], [0, 0, 1]];\n/**\n * Normalizes the provided angle to the range -pi to pi.\n * @param angle The angle in radians to be normalized.\n */\nexport function normalizeRadians(angle) {\n return angle - 2 * Math.PI * Math.floor((angle + Math.PI) / (2 * Math.PI));\n}\n\n/**\n * Computes the angle of rotation between two anchor points.\n * @param point1 First anchor point\n * @param point2 Second anchor point\n */\nexport function computeRotation(point1, point2) {\n const radians = Math.PI / 2 - Math.atan2(-(point2[1] - point1[1]), point2[0] - point1[0]);\n return normalizeRadians(radians);\n}\n\nexport function radToDegrees(rad) {\n return rad * 180 / Math.PI;\n}\n\nexport function buildTranslationMatrix(x, y) {\n return [[1, 0, x], [0, 1, y], [0, 0, 1]];\n}\n\nexport function dot(v1, v2) {\n let product = 0;\n for (let i = 0; i < v1.length; i++) {\n product += v1[i] * v2[i];\n }\n return product;\n}\n\nexport function getColumnFrom2DArr(arr, columnIndex) {\n const column: Array = [];\n for (let i = 0; i < arr.length; i++) {\n column.push(arr[i][columnIndex]);\n }\n return column;\n}\n\nexport function multiplyTransformMatrices(mat1, mat2) {\n const product: Array = [];\n const size = mat1.length;\n for (let row = 0; row < size; row++) {\n product.push([]);\n for (let col = 0; col < size; col++) {\n product[row].push(dot(mat1[row], getColumnFrom2DArr(mat2, col)));\n }\n }\n return product;\n}\n\nexport function buildRotationMatrix(rotation, center) {\n const cosA = Math.cos(rotation);\n const sinA = Math.sin(rotation);\n const rotationMatrix = [[cosA, -sinA, 0], [sinA, cosA, 0], [0, 0, 1]];\n const translationMatrix = buildTranslationMatrix(center[0], center[1]);\n const translationTimesRotation = multiplyTransformMatrices(translationMatrix, rotationMatrix);\n const negativeTranslationMatrix = buildTranslationMatrix(-center[0], -center[1]);\n return multiplyTransformMatrices(translationTimesRotation, negativeTranslationMatrix);\n}\n\nexport function invertTransformMatrix(matrix) {\n const rotationComponent = [[matrix[0][0], matrix[1][0]], [matrix[0][1], matrix[1][1]]];\n const translationComponent = [matrix[0][2], matrix[1][2]];\n const invertedTranslation = [\n -dot(rotationComponent[0], translationComponent),\n -dot(rotationComponent[1], translationComponent),\n ];\n return [\n rotationComponent[0].concat(invertedTranslation[0]),\n rotationComponent[1].concat(invertedTranslation[1]),\n [0, 0, 1],\n ];\n}\n\nexport function rotatePoint(homogeneousCoordinate, rotationMatrix) {\n return [\n dot(homogeneousCoordinate, rotationMatrix[0]),\n dot(homogeneousCoordinate, rotationMatrix[1]),\n ];\n}\n\nexport function xyDistanceBetweenPoints(a, b) {\n return Math.sqrt(((a[0] - b[0]) ** 2) + ((a[1] - b[1]) ** 2));\n}\n\nexport function generateAnchors(inputSize) {\n const spec = { strides: [inputSize / 16, inputSize / 8], anchors: [2, 6] };\n const anchors: Array<[number, number]> = [];\n for (let i = 0; i < spec.strides.length; i++) {\n const stride = spec.strides[i];\n const gridRows = Math.floor((inputSize + stride - 1) / stride);\n const gridCols = Math.floor((inputSize + stride - 1) / stride);\n const anchorsNum = spec.anchors[i];\n for (let gridY = 0; gridY < gridRows; gridY++) {\n const anchorY = stride * (gridY + 0.5);\n for (let gridX = 0; gridX < gridCols; gridX++) {\n const anchorX = stride * (gridX + 0.5);\n for (let n = 0; n < anchorsNum; n++) {\n anchors.push([anchorX, anchorY]);\n }\n }\n }\n }\n return anchors;\n}\n", "import { log, join } from '../helpers';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as box from './box';\nimport * as util from './util';\n\nconst keypointsCount = 6;\n\nfunction decodeBounds(boxOutputs, anchors, inputSize) {\n const boxStarts = tf.slice(boxOutputs, [0, 1], [-1, 2]);\n const centers = tf.add(boxStarts, anchors);\n const boxSizes = tf.slice(boxOutputs, [0, 3], [-1, 2]);\n const boxSizesNormalized = tf.div(boxSizes, inputSize);\n const centersNormalized = tf.div(centers, inputSize);\n const halfBoxSize = tf.div(boxSizesNormalized, 2);\n const starts = tf.sub(centersNormalized, halfBoxSize);\n const ends = tf.add(centersNormalized, halfBoxSize);\n const startNormalized = tf.mul(starts, inputSize);\n const endNormalized = tf.mul(ends, inputSize);\n const concatAxis = 1;\n return tf.concat2d([startNormalized, endNormalized], concatAxis);\n}\n\nexport class BlazeFaceModel {\n model: any;\n anchorsData: any;\n anchors: any;\n inputSize: number;\n config: any;\n\n constructor(model, config) {\n this.model = model;\n this.anchorsData = util.generateAnchors(model.inputs[0].shape[1]);\n this.anchors = tf.tensor2d(this.anchorsData);\n this.inputSize = model.inputs[0].shape[2];\n this.config = config;\n }\n\n async getBoundingBoxes(inputImage) {\n // sanity check on input\n if ((!inputImage) || (inputImage.isDisposedInternal) || (inputImage.shape.length !== 4) || (inputImage.shape[1] < 1) || (inputImage.shape[2] < 1)) return null;\n const [batch, boxes, scores] = tf.tidy(() => {\n const resizedImage = inputImage.resizeBilinear([this.inputSize, this.inputSize]);\n const normalizedImage = resizedImage.div(127.5).sub(0.5);\n const res = this.model.execute(normalizedImage);\n let batchOut;\n if (Array.isArray(res)) { // are we using tfhub or pinto converted model?\n const sorted = res.sort((a, b) => a.size - b.size);\n const concat384 = tf.concat([sorted[0], sorted[2]], 2); // dim: 384, 1 + 16\n const concat512 = tf.concat([sorted[1], sorted[3]], 2); // dim: 512, 1 + 16\n const concat = tf.concat([concat512, concat384], 1);\n batchOut = concat.squeeze(0);\n } else {\n batchOut = res.squeeze(); // when using tfhub model\n }\n const boxesOut = decodeBounds(batchOut, this.anchors, [this.inputSize, this.inputSize]);\n const logits = tf.slice(batchOut, [0, 0], [-1, 1]);\n const scoresOut = tf.sigmoid(logits).squeeze().dataSync();\n return [batchOut, boxesOut, scoresOut];\n });\n const nmsTensor = await tf.image.nonMaxSuppressionAsync(boxes, scores, this.config.face.detector.maxDetected, this.config.face.detector.iouThreshold, this.config.face.detector.minConfidence);\n const nms = nmsTensor.arraySync();\n nmsTensor.dispose();\n const annotatedBoxes: Array<{ box: any, landmarks: any, anchor: number[], confidence: number }> = [];\n for (let i = 0; i < nms.length; i++) {\n const confidence = scores[nms[i]];\n if (confidence > this.config.face.detector.minConfidence) {\n const boundingBox = tf.slice(boxes, [nms[i], 0], [1, -1]);\n const localBox = box.createBox(boundingBox);\n boundingBox.dispose();\n const anchor = this.anchorsData[nms[i]];\n const landmarks = tf.tidy(() => tf.slice(batch, [nms[i], keypointsCount - 1], [1, -1]).squeeze().reshape([keypointsCount, -1]));\n annotatedBoxes.push({ box: localBox, landmarks, anchor, confidence });\n }\n }\n // boundingBoxes.forEach((t) => t.dispose());\n batch.dispose();\n boxes.dispose();\n // scores.dispose();\n return {\n boxes: annotatedBoxes,\n scaleFactor: [inputImage.shape[2] / this.inputSize, inputImage.shape[1] / this.inputSize],\n };\n }\n}\n\nexport async function load(config) {\n const model = await tf.loadGraphModel(join(config.modelBasePath, config.face.detector.modelPath), { fromTFHub: config.face.detector.modelPath.includes('tfhub.dev') });\n const blazeFace = new BlazeFaceModel(model, config);\n if (!model || !model.modelUrl) log('load model failed:', config.face.detector.modelPath);\n else if (config.debug) log('load model:', model.modelUrl);\n return blazeFace;\n}\n", "export const MESH_ANNOTATIONS = {\n silhouette: [\n 10, 338, 297, 332, 284, 251, 389, 356, 454, 323, 361, 288,\n 397, 365, 379, 378, 400, 377, 152, 148, 176, 149, 150, 136,\n 172, 58, 132, 93, 234, 127, 162, 21, 54, 103, 67, 109,\n ],\n lipsUpperOuter: [61, 185, 40, 39, 37, 0, 267, 269, 270, 409, 291],\n lipsLowerOuter: [146, 91, 181, 84, 17, 314, 405, 321, 375, 291],\n lipsUpperInner: [78, 191, 80, 81, 82, 13, 312, 311, 310, 415, 308],\n lipsLowerInner: [78, 95, 88, 178, 87, 14, 317, 402, 318, 324, 308],\n rightEyeUpper0: [246, 161, 160, 159, 158, 157, 173],\n rightEyeLower0: [33, 7, 163, 144, 145, 153, 154, 155, 133],\n rightEyeUpper1: [247, 30, 29, 27, 28, 56, 190],\n rightEyeLower1: [130, 25, 110, 24, 23, 22, 26, 112, 243],\n rightEyeUpper2: [113, 225, 224, 223, 222, 221, 189],\n rightEyeLower2: [226, 31, 228, 229, 230, 231, 232, 233, 244],\n rightEyeLower3: [143, 111, 117, 118, 119, 120, 121, 128, 245],\n rightEyebrowUpper: [156, 70, 63, 105, 66, 107, 55, 193],\n rightEyebrowLower: [35, 124, 46, 53, 52, 65],\n rightEyeIris: [473, 474, 475, 476, 477],\n leftEyeUpper0: [466, 388, 387, 386, 385, 384, 398],\n leftEyeLower0: [263, 249, 390, 373, 374, 380, 381, 382, 362],\n leftEyeUpper1: [467, 260, 259, 257, 258, 286, 414],\n leftEyeLower1: [359, 255, 339, 254, 253, 252, 256, 341, 463],\n leftEyeUpper2: [342, 445, 444, 443, 442, 441, 413],\n leftEyeLower2: [446, 261, 448, 449, 450, 451, 452, 453, 464],\n leftEyeLower3: [372, 340, 346, 347, 348, 349, 350, 357, 465],\n leftEyebrowUpper: [383, 300, 293, 334, 296, 336, 285, 417],\n leftEyebrowLower: [265, 353, 276, 283, 282, 295],\n leftEyeIris: [468, 469, 470, 471, 472],\n midwayBetweenEyes: [168],\n noseTip: [1],\n noseBottom: [2],\n noseRightCorner: [98],\n noseLeftCorner: [327],\n rightCheek: [205],\n leftCheek: [425],\n};\n\nexport const MESH_TO_IRIS_INDICES_MAP = [ // A mapping from facemesh model keypoints to iris model keypoints.\n { key: 'EyeUpper0', indices: [9, 10, 11, 12, 13, 14, 15] },\n { key: 'EyeUpper1', indices: [25, 26, 27, 28, 29, 30, 31] },\n { key: 'EyeUpper2', indices: [41, 42, 43, 44, 45, 46, 47] },\n { key: 'EyeLower0', indices: [0, 1, 2, 3, 4, 5, 6, 7, 8] },\n { key: 'EyeLower1', indices: [16, 17, 18, 19, 20, 21, 22, 23, 24] },\n { key: 'EyeLower2', indices: [32, 33, 34, 35, 36, 37, 38, 39, 40] },\n { key: 'EyeLower3', indices: [54, 55, 56, 57, 58, 59, 60, 61, 62] },\n // { key: 'EyebrowUpper', indices: [63, 64, 65, 66, 67, 68, 69, 70] },\n // { key: 'EyebrowLower', indices: [48, 49, 50, 51, 52, 53] },\n];\n\nexport const UV468 = [\n [0.499976992607117, 0.652534008026123],\n [0.500025987625122, 0.547487020492554],\n [0.499974012374878, 0.602371990680695],\n [0.482113003730774, 0.471979022026062],\n [0.500150978565216, 0.527155995368958],\n [0.499909996986389, 0.498252987861633],\n [0.499523013830185, 0.40106201171875],\n [0.289712011814117, 0.380764007568359],\n [0.499954998493195, 0.312398016452789],\n [0.499987006187439, 0.269918978214264],\n [0.500023007392883, 0.107050001621246],\n [0.500023007392883, 0.666234016418457],\n [0.5000159740448, 0.679224014282227],\n [0.500023007392883, 0.692348003387451],\n [0.499976992607117, 0.695277988910675],\n [0.499976992607117, 0.70593398809433],\n [0.499976992607117, 0.719385027885437],\n [0.499976992607117, 0.737019002437592],\n [0.499967992305756, 0.781370997428894],\n [0.499816000461578, 0.562981009483337],\n [0.473773002624512, 0.573909997940063],\n [0.104906998574734, 0.254140973091125],\n [0.365929991006851, 0.409575998783112],\n [0.338757991790771, 0.41302502155304],\n [0.311120003461838, 0.409460008144379],\n [0.274657994508743, 0.389131009578705],\n [0.393361985683441, 0.403706014156342],\n [0.345234006643295, 0.344011008739471],\n [0.370094001293182, 0.346076011657715],\n [0.319321990013123, 0.347265005111694],\n [0.297903001308441, 0.353591024875641],\n [0.24779200553894, 0.410809993743896],\n [0.396889001131058, 0.842755019664764],\n [0.280097991228104, 0.375599980354309],\n [0.106310002505779, 0.399955987930298],\n [0.2099249958992, 0.391353011131287],\n [0.355807989835739, 0.534406006336212],\n [0.471751004457474, 0.65040397644043],\n [0.474155008792877, 0.680191993713379],\n [0.439785003662109, 0.657229006290436],\n [0.414617002010345, 0.66654098033905],\n [0.450374007225037, 0.680860996246338],\n [0.428770989179611, 0.682690978050232],\n [0.374971002340317, 0.727805018424988],\n [0.486716985702515, 0.547628998756409],\n [0.485300987958908, 0.527395009994507],\n [0.257764995098114, 0.314490020275116],\n [0.401223003864288, 0.455172002315521],\n [0.429818987846375, 0.548614978790283],\n [0.421351999044418, 0.533740997314453],\n [0.276895999908447, 0.532056987285614],\n [0.483370006084442, 0.499586999416351],\n [0.33721199631691, 0.282882988452911],\n [0.296391993761063, 0.293242990970612],\n [0.169294998049736, 0.193813979625702],\n [0.447580009698868, 0.302609980106354],\n [0.392390012741089, 0.353887975215912],\n [0.354490011930466, 0.696784019470215],\n [0.067304998636246, 0.730105042457581],\n [0.442739009857178, 0.572826027870178],\n [0.457098007202148, 0.584792017936707],\n [0.381974011659622, 0.694710969924927],\n [0.392388999462128, 0.694203019142151],\n [0.277076005935669, 0.271932005882263],\n [0.422551989555359, 0.563233017921448],\n [0.385919004678726, 0.281364023685455],\n [0.383103013038635, 0.255840003490448],\n [0.331431001424789, 0.119714021682739],\n [0.229923993349075, 0.232002973556519],\n [0.364500999450684, 0.189113974571228],\n [0.229622006416321, 0.299540996551514],\n [0.173287004232407, 0.278747975826263],\n [0.472878992557526, 0.666198015213013],\n [0.446828007698059, 0.668527007102966],\n [0.422762006521225, 0.673889994621277],\n [0.445307999849319, 0.580065965652466],\n [0.388103008270264, 0.693961024284363],\n [0.403039008378983, 0.706539988517761],\n [0.403629004955292, 0.693953037261963],\n [0.460041999816895, 0.557139039039612],\n [0.431158006191254, 0.692366003990173],\n [0.452181994915009, 0.692366003990173],\n [0.475387006998062, 0.692366003990173],\n [0.465828001499176, 0.779190003871918],\n [0.472328990697861, 0.736225962638855],\n [0.473087012767792, 0.717857003211975],\n [0.473122000694275, 0.704625964164734],\n [0.473033010959625, 0.695277988910675],\n [0.427942007780075, 0.695277988910675],\n [0.426479011774063, 0.703539967536926],\n [0.423162013292313, 0.711845993995667],\n [0.4183090031147, 0.720062971115112],\n [0.390094995498657, 0.639572978019714],\n [0.013953999616206, 0.560034036636353],\n [0.499913990497589, 0.58014702796936],\n [0.413199990987778, 0.69539999961853],\n [0.409626007080078, 0.701822996139526],\n [0.468080013990402, 0.601534962654114],\n [0.422728985548019, 0.585985004901886],\n [0.463079988956451, 0.593783974647522],\n [0.37211999297142, 0.47341400384903],\n [0.334562003612518, 0.496073007583618],\n [0.411671012639999, 0.546965003013611],\n [0.242175996303558, 0.14767599105835],\n [0.290776997804642, 0.201445996761322],\n [0.327338010072708, 0.256527006626129],\n [0.399509996175766, 0.748921036720276],\n [0.441727995872498, 0.261676013469696],\n [0.429764986038208, 0.187834024429321],\n [0.412198007106781, 0.108901023864746],\n [0.288955003023148, 0.398952007293701],\n [0.218936994671822, 0.435410976409912],\n [0.41278201341629, 0.398970007896423],\n [0.257135003805161, 0.355440020561218],\n [0.427684992551804, 0.437960982322693],\n [0.448339998722076, 0.536936044692993],\n [0.178560003638268, 0.45755398273468],\n [0.247308000922203, 0.457193970680237],\n [0.286267012357712, 0.467674970626831],\n [0.332827985286713, 0.460712015628815],\n [0.368755996227264, 0.447206974029541],\n [0.398963987827301, 0.432654976844788],\n [0.476410001516342, 0.405806005001068],\n [0.189241006970406, 0.523923993110657],\n [0.228962004184723, 0.348950982093811],\n [0.490725994110107, 0.562400996685028],\n [0.404670000076294, 0.485132992267609],\n [0.019469000399113, 0.401564002037048],\n [0.426243007183075, 0.420431017875671],\n [0.396993011236191, 0.548797011375427],\n [0.266469985246658, 0.376977026462555],\n [0.439121007919312, 0.51895797252655],\n [0.032313998788595, 0.644356966018677],\n [0.419054001569748, 0.387154996395111],\n [0.462783008813858, 0.505746960639954],\n [0.238978996872902, 0.779744982719421],\n [0.198220998048782, 0.831938028335571],\n [0.107550002634525, 0.540755033493042],\n [0.183610007166862, 0.740257024765015],\n [0.134409993886948, 0.333683013916016],\n [0.385764002799988, 0.883153975009918],\n [0.490967005491257, 0.579378008842468],\n [0.382384985685349, 0.508572995662689],\n [0.174399003386497, 0.397670984268188],\n [0.318785011768341, 0.39623498916626],\n [0.343364000320435, 0.400596976280212],\n [0.396100014448166, 0.710216999053955],\n [0.187885001301765, 0.588537991046906],\n [0.430987000465393, 0.944064974784851],\n [0.318993002176285, 0.898285031318665],\n [0.266247987747192, 0.869701027870178],\n [0.500023007392883, 0.190576016902924],\n [0.499976992607117, 0.954452991485596],\n [0.366169989109039, 0.398822009563446],\n [0.393207013607025, 0.39553701877594],\n [0.410373002290726, 0.391080021858215],\n [0.194993004202843, 0.342101991176605],\n [0.388664990663528, 0.362284004688263],\n [0.365961998701096, 0.355970978736877],\n [0.343364000320435, 0.355356991291046],\n [0.318785011768341, 0.35834002494812],\n [0.301414996385574, 0.363156020641327],\n [0.058132998645306, 0.319076001644135],\n [0.301414996385574, 0.387449026107788],\n [0.499987989664078, 0.618434011936188],\n [0.415838003158569, 0.624195992946625],\n [0.445681989192963, 0.566076993942261],\n [0.465844005346298, 0.620640993118286],\n [0.49992299079895, 0.351523995399475],\n [0.288718998432159, 0.819945991039276],\n [0.335278987884521, 0.852819979190826],\n [0.440512001514435, 0.902418971061707],\n [0.128294005990028, 0.791940987110138],\n [0.408771991729736, 0.373893976211548],\n [0.455606997013092, 0.451801002025604],\n [0.499877005815506, 0.908990025520325],\n [0.375436991453171, 0.924192011356354],\n [0.11421000212431, 0.615022003650665],\n [0.448662012815475, 0.695277988910675],\n [0.4480200111866, 0.704632043838501],\n [0.447111994028091, 0.715808033943176],\n [0.444831997156143, 0.730794012546539],\n [0.430011987686157, 0.766808986663818],\n [0.406787008047104, 0.685672998428345],\n [0.400738000869751, 0.681069016456604],\n [0.392399996519089, 0.677703022956848],\n [0.367855995893478, 0.663918972015381],\n [0.247923001646996, 0.601333022117615],\n [0.452769994735718, 0.420849978923798],\n [0.43639200925827, 0.359887003898621],\n [0.416164010763168, 0.368713974952698],\n [0.413385987281799, 0.692366003990173],\n [0.228018000721931, 0.683571994304657],\n [0.468268007040024, 0.352671027183533],\n [0.411361992359161, 0.804327011108398],\n [0.499989002943039, 0.469825029373169],\n [0.479153990745544, 0.442654013633728],\n [0.499974012374878, 0.439637005329132],\n [0.432112008333206, 0.493588984012604],\n [0.499886006116867, 0.866917014122009],\n [0.49991300702095, 0.821729004383087],\n [0.456548988819122, 0.819200992584229],\n [0.344549000263214, 0.745438992977142],\n [0.37890899181366, 0.574010014533997],\n [0.374292999505997, 0.780184984207153],\n [0.319687992334366, 0.570737957954407],\n [0.357154995203018, 0.604269981384277],\n [0.295284003019333, 0.621580958366394],\n [0.447750002145767, 0.862477004528046],\n [0.410986006259918, 0.508723020553589],\n [0.31395098567009, 0.775308012962341],\n [0.354128003120422, 0.812552988529205],\n [0.324548006057739, 0.703992962837219],\n [0.189096003770828, 0.646299958229065],\n [0.279776990413666, 0.71465802192688],\n [0.1338230073452, 0.682700991630554],\n [0.336768001317978, 0.644733011722565],\n [0.429883986711502, 0.466521978378296],\n [0.455527991056442, 0.548622965812683],\n [0.437114000320435, 0.558896005153656],\n [0.467287987470627, 0.529924988746643],\n [0.414712011814117, 0.335219979286194],\n [0.37704598903656, 0.322777986526489],\n [0.344107985496521, 0.320150971412659],\n [0.312875986099243, 0.32233202457428],\n [0.283526003360748, 0.333190023899078],\n [0.241245999932289, 0.382785975933075],\n [0.102986000478268, 0.468762993812561],\n [0.267612010240555, 0.424560010433197],\n [0.297879010438919, 0.433175981044769],\n [0.333433985710144, 0.433878004550934],\n [0.366427004337311, 0.426115989685059],\n [0.396012008190155, 0.416696012020111],\n [0.420121014118195, 0.41022801399231],\n [0.007561000064015, 0.480777025222778],\n [0.432949006557465, 0.569517970085144],\n [0.458638995885849, 0.479089021682739],\n [0.473466008901596, 0.545744001865387],\n [0.476087987422943, 0.563830018043518],\n [0.468472003936768, 0.555056989192963],\n [0.433990985155106, 0.582361996173859],\n [0.483518004417419, 0.562983989715576],\n [0.482482999563217, 0.57784903049469],\n [0.42645001411438, 0.389798998832703],\n [0.438998997211456, 0.39649498462677],\n [0.450067013502121, 0.400434017181396],\n [0.289712011814117, 0.368252992630005],\n [0.276670008897781, 0.363372981548309],\n [0.517862021923065, 0.471948027610779],\n [0.710287988185883, 0.380764007568359],\n [0.526226997375488, 0.573909997940063],\n [0.895093023777008, 0.254140973091125],\n [0.634069979190826, 0.409575998783112],\n [0.661242008209229, 0.41302502155304],\n [0.688880026340485, 0.409460008144379],\n [0.725341975688934, 0.389131009578705],\n [0.606630027294159, 0.40370500087738],\n [0.654766023159027, 0.344011008739471],\n [0.629905998706818, 0.346076011657715],\n [0.680678009986877, 0.347265005111694],\n [0.702096998691559, 0.353591024875641],\n [0.75221198797226, 0.410804986953735],\n [0.602918028831482, 0.842862963676453],\n [0.719901978969574, 0.375599980354309],\n [0.893692970275879, 0.399959981441498],\n [0.790081977844238, 0.391354024410248],\n [0.643998026847839, 0.534487962722778],\n [0.528249025344849, 0.65040397644043],\n [0.525849997997284, 0.680191040039062],\n [0.560214996337891, 0.657229006290436],\n [0.585384011268616, 0.66654098033905],\n [0.549625992774963, 0.680860996246338],\n [0.57122802734375, 0.682691991329193],\n [0.624852001667023, 0.72809898853302],\n [0.513050019741058, 0.547281980514526],\n [0.51509702205658, 0.527251958847046],\n [0.742246985435486, 0.314507007598877],\n [0.598631024360657, 0.454979002475739],\n [0.570338010787964, 0.548575043678284],\n [0.578631997108459, 0.533622980117798],\n [0.723087012767792, 0.532054007053375],\n [0.516445994377136, 0.499638974666595],\n [0.662801027297974, 0.282917976379395],\n [0.70362401008606, 0.293271005153656],\n [0.830704987049103, 0.193813979625702],\n [0.552385985851288, 0.302568018436432],\n [0.607609987258911, 0.353887975215912],\n [0.645429015159607, 0.696707010269165],\n [0.932694971561432, 0.730105042457581],\n [0.557260990142822, 0.572826027870178],\n [0.542901992797852, 0.584792017936707],\n [0.6180260181427, 0.694710969924927],\n [0.607590973377228, 0.694203019142151],\n [0.722943007946014, 0.271963000297546],\n [0.577413976192474, 0.563166975975037],\n [0.614082992076874, 0.281386971473694],\n [0.616907000541687, 0.255886018276215],\n [0.668509006500244, 0.119913995265961],\n [0.770092010498047, 0.232020974159241],\n [0.635536015033722, 0.189248979091644],\n [0.77039098739624, 0.299556016921997],\n [0.826722025871277, 0.278755009174347],\n [0.527121007442474, 0.666198015213013],\n [0.553171992301941, 0.668527007102966],\n [0.577238023281097, 0.673889994621277],\n [0.554691970348358, 0.580065965652466],\n [0.611896991729736, 0.693961024284363],\n [0.59696102142334, 0.706539988517761],\n [0.596370995044708, 0.693953037261963],\n [0.539958000183105, 0.557139039039612],\n [0.568841993808746, 0.692366003990173],\n [0.547818005084991, 0.692366003990173],\n [0.52461302280426, 0.692366003990173],\n [0.534089982509613, 0.779141008853912],\n [0.527670979499817, 0.736225962638855],\n [0.526912987232208, 0.717857003211975],\n [0.526877999305725, 0.704625964164734],\n [0.526966989040375, 0.695277988910675],\n [0.572058022022247, 0.695277988910675],\n [0.573521018028259, 0.703539967536926],\n [0.57683801651001, 0.711845993995667],\n [0.581691026687622, 0.720062971115112],\n [0.609944999217987, 0.639909982681274],\n [0.986046016216278, 0.560034036636353],\n [0.5867999792099, 0.69539999961853],\n [0.590372025966644, 0.701822996139526],\n [0.531915009021759, 0.601536989212036],\n [0.577268004417419, 0.585934996604919],\n [0.536915004253387, 0.593786001205444],\n [0.627542972564697, 0.473352015018463],\n [0.665585994720459, 0.495950996875763],\n [0.588353991508484, 0.546862006187439],\n [0.757824003696442, 0.14767599105835],\n [0.709249973297119, 0.201507985591888],\n [0.672684013843536, 0.256581008434296],\n [0.600408971309662, 0.74900496006012],\n [0.55826598405838, 0.261672019958496],\n [0.570303976535797, 0.187870979309082],\n [0.588165998458862, 0.109044015407562],\n [0.711045026779175, 0.398952007293701],\n [0.781069993972778, 0.435405015945435],\n [0.587247014045715, 0.398931980133057],\n [0.742869973182678, 0.355445981025696],\n [0.572156012058258, 0.437651991844177],\n [0.55186802148819, 0.536570012569427],\n [0.821442008018494, 0.457556009292603],\n [0.752701997756958, 0.457181990146637],\n [0.71375697851181, 0.467626988887787],\n [0.66711300611496, 0.460672974586487],\n [0.631101012229919, 0.447153985500336],\n [0.6008620262146, 0.432473003864288],\n [0.523481011390686, 0.405627012252808],\n [0.810747981071472, 0.523926019668579],\n [0.771045982837677, 0.348959028720856],\n [0.509127020835876, 0.562718033790588],\n [0.595292985439301, 0.485023975372314],\n [0.980530977249146, 0.401564002037048],\n [0.573499977588654, 0.420000016689301],\n [0.602994978427887, 0.548687994480133],\n [0.733529984951019, 0.376977026462555],\n [0.560611009597778, 0.519016981124878],\n [0.967685997486115, 0.644356966018677],\n [0.580985009670258, 0.387160003185272],\n [0.537728011608124, 0.505385041236877],\n [0.760966002941132, 0.779752969741821],\n [0.801778972148895, 0.831938028335571],\n [0.892440974712372, 0.54076099395752],\n [0.816350996494293, 0.740260004997253],\n [0.865594983100891, 0.333687007427216],\n [0.614073991775513, 0.883246004581451],\n [0.508952975273132, 0.579437971115112],\n [0.617941975593567, 0.508316040039062],\n [0.825608015060425, 0.397674977779388],\n [0.681214988231659, 0.39623498916626],\n [0.656635999679565, 0.400596976280212],\n [0.603900015354156, 0.710216999053955],\n [0.81208598613739, 0.588539004325867],\n [0.56801301240921, 0.944564998149872],\n [0.681007981300354, 0.898285031318665],\n [0.733752012252808, 0.869701027870178],\n [0.633830010890961, 0.398822009563446],\n [0.606792986392975, 0.39553701877594],\n [0.589659988880157, 0.391062021255493],\n [0.805015981197357, 0.342108011245728],\n [0.611334979534149, 0.362284004688263],\n [0.634037971496582, 0.355970978736877],\n [0.656635999679565, 0.355356991291046],\n [0.681214988231659, 0.35834002494812],\n [0.698584973812103, 0.363156020641327],\n [0.941866993904114, 0.319076001644135],\n [0.698584973812103, 0.387449026107788],\n [0.584177017211914, 0.624107003211975],\n [0.554318010807037, 0.566076993942261],\n [0.534153997898102, 0.62064003944397],\n [0.711217999458313, 0.819975018501282],\n [0.664629995822906, 0.852871000766754],\n [0.559099972248077, 0.902631998062134],\n [0.871706008911133, 0.791940987110138],\n [0.591234028339386, 0.373893976211548],\n [0.544341027736664, 0.451583981513977],\n [0.624562978744507, 0.924192011356354],\n [0.88577002286911, 0.615028977394104],\n [0.551338016986847, 0.695277988910675],\n [0.551980018615723, 0.704632043838501],\n [0.552887976169586, 0.715808033943176],\n [0.555167973041534, 0.730794012546539],\n [0.569944024085999, 0.767035007476807],\n [0.593203008174896, 0.685675978660583],\n [0.599261999130249, 0.681069016456604],\n [0.607599973678589, 0.677703022956848],\n [0.631937980651855, 0.663500010967255],\n [0.752032995223999, 0.601315021514893],\n [0.547226011753082, 0.420395016670227],\n [0.563543975353241, 0.359827995300293],\n [0.583841025829315, 0.368713974952698],\n [0.586614012718201, 0.692366003990173],\n [0.771915018558502, 0.683578014373779],\n [0.531597018241882, 0.352482974529266],\n [0.588370978832245, 0.804440975189209],\n [0.52079701423645, 0.442565023899078],\n [0.567984998226166, 0.493479013442993],\n [0.543282985687256, 0.819254994392395],\n [0.655317008495331, 0.745514988899231],\n [0.621008992195129, 0.574018001556396],\n [0.625559985637665, 0.78031200170517],\n [0.680198013782501, 0.570719003677368],\n [0.64276397228241, 0.604337990283966],\n [0.704662978649139, 0.621529996395111],\n [0.552012026309967, 0.862591981887817],\n [0.589071989059448, 0.508637011051178],\n [0.685944974422455, 0.775357007980347],\n [0.645735025405884, 0.812640011310577],\n [0.675342977046967, 0.703978002071381],\n [0.810858011245728, 0.646304965019226],\n [0.72012197971344, 0.714666962623596],\n [0.866151988506317, 0.682704985141754],\n [0.663187026977539, 0.644596993923187],\n [0.570082008838654, 0.466325998306274],\n [0.544561982154846, 0.548375964164734],\n [0.562758982181549, 0.558784961700439],\n [0.531987011432648, 0.530140042304993],\n [0.585271000862122, 0.335177004337311],\n [0.622952997684479, 0.32277899980545],\n [0.655896008014679, 0.320163011550903],\n [0.687132000923157, 0.322345972061157],\n [0.716481983661652, 0.333200991153717],\n [0.758756995201111, 0.382786989212036],\n [0.897013008594513, 0.468769013881683],\n [0.732392013072968, 0.424547016620636],\n [0.70211398601532, 0.433162987232208],\n [0.66652500629425, 0.433866024017334],\n [0.633504986763, 0.426087975502014],\n [0.603875994682312, 0.416586995124817],\n [0.579657971858978, 0.409945011138916],\n [0.992439985275269, 0.480777025222778],\n [0.567192018032074, 0.569419980049133],\n [0.54136598110199, 0.478899002075195],\n [0.526564002037048, 0.546118021011353],\n [0.523913025856018, 0.563830018043518],\n [0.531529009342194, 0.555056989192963],\n [0.566035985946655, 0.582329034805298],\n [0.51631098985672, 0.563053965568542],\n [0.5174720287323, 0.577877044677734],\n [0.573594987392426, 0.389806985855103],\n [0.560697972774506, 0.395331978797913],\n [0.549755990505219, 0.399751007556915],\n [0.710287988185883, 0.368252992630005],\n [0.723330020904541, 0.363372981548309],\n];\n\nexport const TRI468 = [\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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];\n\nexport const TRI68 = [0, 1, 36, 0, 36, 17, 1, 2, 41, 1, 41, 36, 2, 3, 31, 2, 31, 41, 3, 4, 48, 3, 48, 31, 4, 5, 48, 5, 6, 48, 6, 7, 59, 6, 59, 48, 7, 8, 58, 7, 58, 59,\n 8, 9, 56, 8, 56, 57, 8, 57, 58, 9, 10, 55, 9, 55, 56, 10, 11, 54, 10, 54, 55, 11, 12, 54, 12, 13, 54, 13, 14, 35, 13, 35, 54, 14, 15, 46, 14, 46, 35, 15, 16,\n 45, 15, 45, 46, 16, 26, 45, 17, 36, 18, 18, 37, 19, 18, 36, 37, 19, 38, 20, 19, 37, 38, 20, 39, 21, 20, 38, 39, 21, 39, 27, 22, 42, 23, 22, 27, 42, 23, 43, 24,\n 23, 42, 43, 24, 44, 25, 24, 43, 44, 25, 45, 26, 25, 44, 45, 27, 39, 28, 27, 28, 42, 28, 39, 29, 28, 29, 42, 29, 31, 30, 29, 30, 35, 29, 40, 31, 29, 35, 47, 29,\n 39, 40, 29, 47, 42, 30, 31, 32, 30, 32, 33, 30, 33, 34, 30, 34, 35, 31, 50, 32, 31, 40, 41, 31, 48, 49, 31, 49, 50, 32, 51, 33, 32, 50, 51, 33, 51, 34, 34, 52,\n 35, 34, 51, 52, 35, 46, 47, 35, 52, 53, 35, 53, 54, 36, 41, 37, 37, 40, 38, 37, 41, 40, 38, 40, 39, 42, 47, 43, 43, 47, 44, 44, 46, 45, 44, 47, 46, 48, 60, 49,\n 48, 59, 60, 49, 61, 50, 49, 60, 61, 50, 62, 51, 50, 61, 62, 51, 62, 52, 52, 63, 53, 52, 62, 63, 53, 64, 54, 53, 63, 64, 54, 64, 55, 55, 65, 56, 55, 64, 65, 56,\n 66, 57, 56, 65, 66, 57, 66, 58, 58, 67, 59, 58, 66, 67, 59, 67, 60, 60, 67, 61, 61, 66, 62, 61, 67, 66, 62, 66, 63, 63, 65, 64, 63, 66, 65, 21, 27, 22];\n\nexport const TRI33 = [\n /* eyes */ 0, 8, 7, 7, 8, 1, 2, 10, 9, 9, 10, 3,\n /* brows */ 17, 0, 18, 18, 0, 7, 18, 7, 19, 19, 7, 1, 19, 1, 11, 19, 11, 20, 21, 3, 22, 21, 9, 3, 20, 9, 21, 20, 2, 9, 20, 11, 2,\n /* 4head */ 23, 17, 18, 25, 21, 22, 24, 19, 20, 24, 18, 19, 24, 20, 21, 24, 23, 18, 24, 21, 25,\n /* nose */ 11, 12, 4, 11, 4, 13, 1, 12, 11, 11, 13, 2, 12, 14, 4, 4, 14, 13,\n /* up-lip */ 14, 5, 15, 14, 15, 6, 12, 5, 14, 14, 6, 13,\n /* cheeks */ 8, 12, 1, 2, 13, 10, 8, 26, 12, 10, 13, 27, 26, 5, 12, 13, 6, 27, 0, 26, 8, 10, 27, 3,\n /* chin */ 5, 32, 16, 16, 32, 6, 5, 30, 32, 6, 32, 31,\n /* cont */ 26, 30, 5, 27, 6, 31, 0, 28, 26, 3, 27, 29, 17, 28, 0, 3, 29, 22, 23, 28, 17, 22, 29, 25, 28, 30, 26, 27, 31, 29,\n];\n\nexport const TRI7 = [0, 4, 1, 2, 4, 3, 4, 5, 6];\n\nexport const VTX68 = [\n /* cont */ 127, 234, 132, 58, 172, 150, 149, 148, 152, 377, 378, 379, 397, 288, 361, 454, 356,\n /* brows */ 70, 63, 105, 66, 107, 336, 296, 334, 293, 300,\n /* nose */ 168, 6, 195, 4, 98, 97, 2, 326, 327,\n /* eyes */ 33, 160, 158, 133, 153, 144, 362, 385, 387, 263, 373, 380,\n /* lip */ 57, 40, 37, 0, 267, 270, 287, 321, 314, 17, 84, 91,\n /* mouth */ 78, 81, 13, 311, 308, 402, 14, 178,\n];\n\nexport const VTX33 = [33, 133, 362, 263, 1, 62, 308, 159, 145, 386, 374, 6, 102, 331, 2, 13, 14, 70, 105, 107, 336, 334, 300, 54, 10, 284, 50, 280, 234, 454, 58, 288, 152];\n\nexport const VTX7 = [33, 133, 362, 263, 1, 78, 308];\n\nexport const UV68 = VTX68.map((x) => UV468[x]);\n\nexport const UV33 = VTX33.map((x) => UV468[x]);\n\nexport const UV7 = VTX7.map((x) => UV468[x]);\n", "import * as tf from '../../dist/tfjs.esm.js';\nimport * as bounding from './box';\nimport * as util from './util';\nimport * as coords from './coords';\n\nconst leftOutline = coords.MESH_ANNOTATIONS['leftEyeLower0'];\nconst rightOutline = coords.MESH_ANNOTATIONS['rightEyeLower0'];\n\nconst eyeLandmarks = {\n leftBounds: [leftOutline[0], leftOutline[leftOutline.length - 1]],\n rightBounds: [rightOutline[0], rightOutline[rightOutline.length - 1]],\n};\n\nconst meshLandmarks = {\n count: 468,\n mouth: 13,\n symmetryLine: [13, coords.MESH_ANNOTATIONS['midwayBetweenEyes'][0]],\n};\n\nconst blazeFaceLandmarks = {\n leftEye: 0,\n rightEye: 1,\n nose: 2,\n mouth: 3,\n leftEar: 4,\n rightEar: 5,\n symmetryLine: [3, 2],\n};\n\nconst irisLandmarks = {\n upperCenter: 3,\n lowerCenter: 4,\n index: 71,\n numCoordinates: 76,\n};\n\n// Replace the raw coordinates returned by facemesh with refined iris model coordinates\n// Update the z coordinate to be an average of the original and the new.\nfunction replaceRawCoordinates(rawCoords, newCoords, prefix, keys) {\n for (let i = 0; i < coords.MESH_TO_IRIS_INDICES_MAP.length; i++) {\n const { key, indices } = coords.MESH_TO_IRIS_INDICES_MAP[i];\n const originalIndices = coords.MESH_ANNOTATIONS[`${prefix}${key}`];\n if (!keys || keys.includes(key)) {\n for (let j = 0; j < indices.length; j++) {\n const index = indices[j];\n rawCoords[originalIndices[j]] = [\n newCoords[index][0], newCoords[index][1],\n (newCoords[index][2] + rawCoords[originalIndices[j]][2]) / 2,\n ];\n }\n }\n }\n}\n// The Pipeline coordinates between the bounding box and skeleton models.\nexport class Pipeline {\n storedBoxes: any;\n boundingBoxDetector: any;\n meshDetector: any;\n irisModel: any;\n boxSize: number;\n meshSize: number;\n irisSize: number;\n irisEnlarge: number;\n skipped: number;\n detectedFaces: number;\n\n constructor(boundingBoxDetector, meshDetector, irisModel) {\n // An array of facial bounding boxes.\n this.storedBoxes = [];\n this.boundingBoxDetector = boundingBoxDetector;\n this.meshDetector = meshDetector;\n this.irisModel = irisModel;\n this.boxSize = boundingBoxDetector?.model?.inputs[0].shape[2] || 0;\n this.meshSize = meshDetector?.inputs[0].shape[2] || boundingBoxDetector?.model?.inputs[0].shape[2];\n this.irisSize = irisModel?.inputs[0].shape[1] || 0;\n this.irisEnlarge = 2.3;\n this.skipped = 0;\n this.detectedFaces = 0;\n }\n\n transformRawCoords(rawCoords, box, angle, rotationMatrix) {\n const boxSize = bounding.getBoxSize({ startPoint: box.startPoint, endPoint: box.endPoint });\n const coordsScaled = rawCoords.map((coord) => ([\n boxSize[0] / this.meshSize * (coord[0] - this.meshSize / 2),\n boxSize[1] / this.meshSize * (coord[1] - this.meshSize / 2),\n coord[2],\n ]));\n const coordsRotationMatrix = (angle !== 0) ? util.buildRotationMatrix(angle, [0, 0]) : util.IDENTITY_MATRIX;\n const coordsRotated = (angle !== 0) ? coordsScaled.map((coord) => ([...util.rotatePoint(coord, coordsRotationMatrix), coord[2]])) : coordsScaled;\n const inverseRotationMatrix = (angle !== 0) ? util.invertTransformMatrix(rotationMatrix) : util.IDENTITY_MATRIX;\n const boxCenter = [...bounding.getBoxCenter({ startPoint: box.startPoint, endPoint: box.endPoint }), 1];\n return coordsRotated.map((coord) => ([\n Math.round(coord[0] + util.dot(boxCenter, inverseRotationMatrix[0])),\n Math.round(coord[1] + util.dot(boxCenter, inverseRotationMatrix[1])),\n Math.round(coord[2]),\n ]));\n }\n\n // eslint-disable-next-line class-methods-use-this\n getLeftToRightEyeDepthDifference(rawCoords) {\n const leftEyeZ = rawCoords[eyeLandmarks.leftBounds[0]][2];\n const rightEyeZ = rawCoords[eyeLandmarks.rightBounds[0]][2];\n return leftEyeZ - rightEyeZ;\n }\n\n // Returns a box describing a cropped region around the eye fit for passing to the iris model.\n getEyeBox(rawCoords, face, eyeInnerCornerIndex, eyeOuterCornerIndex, flip = false) {\n const box = bounding.squarifyBox(bounding.enlargeBox(bounding.calculateLandmarksBoundingBox([rawCoords[eyeInnerCornerIndex], rawCoords[eyeOuterCornerIndex]]), this.irisEnlarge));\n const boxSize = bounding.getBoxSize(box);\n let crop = tf.image.cropAndResize(face, [[\n box.startPoint[1] / this.meshSize,\n box.startPoint[0] / this.meshSize, box.endPoint[1] / this.meshSize,\n box.endPoint[0] / this.meshSize,\n ]], [0], [this.irisSize, this.irisSize]);\n if (flip && tf.ENV.flags.IS_BROWSER) {\n crop = tf.image.flipLeftRight(crop); // flipLeftRight is not defined for tfjs-node\n }\n return { box, boxSize, crop };\n }\n\n // Given a cropped image of an eye, returns the coordinates of the contours surrounding the eye and the iris.\n getEyeCoords(eyeData, eyeBox, eyeBoxSize, flip = false) {\n const eyeRawCoords: Array = [];\n for (let i = 0; i < irisLandmarks.numCoordinates; i++) {\n const x = eyeData[i * 3];\n const y = eyeData[i * 3 + 1];\n const z = eyeData[i * 3 + 2];\n eyeRawCoords.push([\n (flip ? (1 - (x / this.irisSize)) : (x / this.irisSize)) * eyeBoxSize[0] + eyeBox.startPoint[0],\n (y / this.irisSize) * eyeBoxSize[1] + eyeBox.startPoint[1], z,\n ]);\n }\n return { rawCoords: eyeRawCoords, iris: eyeRawCoords.slice(irisLandmarks.index) };\n }\n\n // The z-coordinates returned for the iris are unreliable, so we take the z values from the surrounding keypoints.\n // eslint-disable-next-line class-methods-use-this\n getAdjustedIrisCoords(rawCoords, irisCoords, direction) {\n const upperCenterZ = rawCoords[coords.MESH_ANNOTATIONS[`${direction}EyeUpper0`][irisLandmarks.upperCenter]][2];\n const lowerCenterZ = rawCoords[coords.MESH_ANNOTATIONS[`${direction}EyeLower0`][irisLandmarks.lowerCenter]][2];\n const averageZ = (upperCenterZ + lowerCenterZ) / 2;\n // Iris indices: 0: center | 1: right | 2: above | 3: left | 4: below\n return irisCoords.map((coord, i) => {\n let z = averageZ;\n if (i === 2) {\n z = upperCenterZ;\n } else if (i === 4) {\n z = lowerCenterZ;\n }\n return [coord[0], coord[1], z];\n });\n }\n\n async predict(input, config) {\n let useFreshBox = false;\n // run new detector every skipFrames unless we only want box to start with\n let detector;\n if ((this.skipped === 0) || (this.skipped > config.face.detector.skipFrames) || !config.face.mesh.enabled || !config.videoOptimized) {\n detector = await this.boundingBoxDetector.getBoundingBoxes(input);\n this.skipped = 0;\n }\n if (config.videoOptimized) this.skipped++;\n\n // if detector result count doesn't match current working set, use it to reset current working set\n if (!config.videoOptimized || (detector && detector.boxes && (!config.face.mesh.enabled || (detector.boxes.length !== this.detectedFaces) && (this.detectedFaces !== config.face.detector.maxDetected)))) {\n this.storedBoxes = [];\n this.detectedFaces = 0;\n for (const possible of detector.boxes) {\n this.storedBoxes.push({ startPoint: possible.box.startPoint.dataSync(), endPoint: possible.box.endPoint.dataSync(), landmarks: possible.landmarks, confidence: possible.confidence });\n }\n if (this.storedBoxes.length > 0) useFreshBox = true;\n }\n\n if (config.face.detector.skipInitial && this.detectedFaces === 0) this.skipped = 0;\n\n if (useFreshBox) {\n if (!detector || !detector.boxes || (detector.boxes.length === 0)) {\n this.storedBoxes = [];\n this.detectedFaces = 0;\n return null;\n }\n for (let i = 0; i < this.storedBoxes.length; i++) {\n const scaledBox = bounding.scaleBoxCoordinates({ startPoint: this.storedBoxes[i].startPoint, endPoint: this.storedBoxes[i].endPoint }, detector.scaleFactor);\n const enlargedBox = bounding.enlargeBox(scaledBox);\n const squarifiedBox = bounding.squarifyBox(enlargedBox);\n const landmarks = this.storedBoxes[i].landmarks.arraySync();\n const confidence = this.storedBoxes[i].confidence;\n this.storedBoxes[i] = { ...squarifiedBox, confidence, landmarks };\n }\n }\n if (detector && detector.boxes) {\n detector.boxes.forEach((prediction) => {\n prediction.box.startPoint.dispose();\n prediction.box.endPoint.dispose();\n prediction.landmarks.dispose();\n });\n }\n const results = tf.tidy(() => this.storedBoxes.map((box, i) => {\n // The facial bounding box landmarks could come either from blazeface (if we are using a fresh box), or from the mesh model (if we are reusing an old box).\n let face;\n let angle = 0;\n let rotationMatrix;\n\n if (config.face.detector.rotation && config.face.mesh.enabled && tf.ENV.flags.IS_BROWSER) {\n const [indexOfMouth, indexOfForehead] = (box.landmarks.length >= meshLandmarks.count) ? meshLandmarks.symmetryLine : blazeFaceLandmarks.symmetryLine;\n angle = util.computeRotation(box.landmarks[indexOfMouth], box.landmarks[indexOfForehead]);\n const faceCenter = bounding.getBoxCenter({ startPoint: box.startPoint, endPoint: box.endPoint });\n const faceCenterNormalized = [faceCenter[0] / input.shape[2], faceCenter[1] / input.shape[1]];\n const rotatedImage = tf.image.rotateWithOffset(input, angle, 0, faceCenterNormalized); // rotateWithOffset is not defined for tfjs-node\n rotationMatrix = util.buildRotationMatrix(-angle, faceCenter);\n if (config.face.mesh.enabled) face = bounding.cutBoxFromImageAndResize({ startPoint: box.startPoint, endPoint: box.endPoint }, rotatedImage, [this.meshSize, this.meshSize]).div(255);\n else face = bounding.cutBoxFromImageAndResize({ startPoint: box.startPoint, endPoint: box.endPoint }, rotatedImage, [this.boxSize, this.boxSize]).div(255);\n } else {\n rotationMatrix = util.IDENTITY_MATRIX;\n const clonedImage = input.clone();\n if (config.face.mesh.enabled) face = bounding.cutBoxFromImageAndResize({ startPoint: box.startPoint, endPoint: box.endPoint }, clonedImage, [this.meshSize, this.meshSize]).div(255);\n else face = bounding.cutBoxFromImageAndResize({ startPoint: box.startPoint, endPoint: box.endPoint }, clonedImage, [this.boxSize, this.boxSize]).div(255);\n }\n\n // if we're not going to produce mesh, don't spend time with further processing\n if (!config.face.mesh.enabled) {\n const prediction = {\n mesh: [],\n box,\n faceConfidence: null,\n boxConfidence: box.confidence,\n confidence: box.confidence,\n image: face,\n };\n return prediction;\n }\n\n const [, confidence, contourCoords] = this.meshDetector.execute(face); // The first returned tensor represents facial contours which are already included in the coordinates.\n const faceConfidence = confidence.dataSync()[0];\n if (faceConfidence < config.face.detector.minConfidence) {\n this.storedBoxes[i].confidence = faceConfidence; // reset confidence of cached box\n return null; // if below confidence just exit\n }\n const coordsReshaped = tf.reshape(contourCoords, [-1, 3]);\n let rawCoords = coordsReshaped.arraySync();\n\n if (config.face.iris.enabled) {\n const { box: leftEyeBox, boxSize: leftEyeBoxSize, crop: leftEyeCrop } = this.getEyeBox(rawCoords, face, eyeLandmarks.leftBounds[0], eyeLandmarks.leftBounds[1], true);\n const { box: rightEyeBox, boxSize: rightEyeBoxSize, crop: rightEyeCrop } = this.getEyeBox(rawCoords, face, eyeLandmarks.rightBounds[0], eyeLandmarks.rightBounds[1]);\n const eyePredictions = this.irisModel.predict(tf.concat([leftEyeCrop, rightEyeCrop]));\n const eyePredictionsData = eyePredictions.dataSync();\n const leftEyeData = eyePredictionsData.slice(0, irisLandmarks.numCoordinates * 3);\n const { rawCoords: leftEyeRawCoords, iris: leftIrisRawCoords } = this.getEyeCoords(leftEyeData, leftEyeBox, leftEyeBoxSize, true);\n const rightEyeData = eyePredictionsData.slice(irisLandmarks.numCoordinates * 3);\n const { rawCoords: rightEyeRawCoords, iris: rightIrisRawCoords } = this.getEyeCoords(rightEyeData, rightEyeBox, rightEyeBoxSize);\n const leftToRightEyeDepthDifference = this.getLeftToRightEyeDepthDifference(rawCoords);\n if (Math.abs(leftToRightEyeDepthDifference) < 30) { // User is looking straight ahead.\n replaceRawCoordinates(rawCoords, leftEyeRawCoords, 'left', null);\n replaceRawCoordinates(rawCoords, rightEyeRawCoords, 'right', null);\n // If the user is looking to the left or to the right, the iris coordinates tend to diverge too much from the mesh coordinates for them to be merged\n // So we only update a single contour line above and below the eye.\n } else if (leftToRightEyeDepthDifference < 1) { // User is looking towards the right.\n replaceRawCoordinates(rawCoords, leftEyeRawCoords, 'left', ['EyeUpper0', 'EyeLower0']);\n } else { // User is looking towards the left.\n replaceRawCoordinates(rawCoords, rightEyeRawCoords, 'right', ['EyeUpper0', 'EyeLower0']);\n }\n const adjustedLeftIrisCoords = this.getAdjustedIrisCoords(rawCoords, leftIrisRawCoords, 'left');\n const adjustedRightIrisCoords = this.getAdjustedIrisCoords(rawCoords, rightIrisRawCoords, 'right');\n rawCoords = rawCoords.concat(adjustedLeftIrisCoords).concat(adjustedRightIrisCoords);\n }\n\n // override box from detection with one calculated from mesh\n const mesh = this.transformRawCoords(rawCoords, box, angle, rotationMatrix);\n const storeConfidence = box.confidence;\n box = bounding.enlargeBox(bounding.calculateLandmarksBoundingBox(mesh), 1.5); // redefine box with mesh calculated one\n box.confidence = storeConfidence;\n\n // do rotation one more time with mesh keypoints if we want to return perfect image\n if (config.face.detector.rotation && config.face.mesh.enabled && config.face.description.enabled && tf.ENV.flags.IS_BROWSER) {\n const [indexOfMouth, indexOfForehead] = (box.landmarks.length >= meshLandmarks.count) ? meshLandmarks.symmetryLine : blazeFaceLandmarks.symmetryLine;\n angle = util.computeRotation(box.landmarks[indexOfMouth], box.landmarks[indexOfForehead]);\n const faceCenter = bounding.getBoxCenter({ startPoint: box.startPoint, endPoint: box.endPoint });\n const faceCenterNormalized = [faceCenter[0] / input.shape[2], faceCenter[1] / input.shape[1]];\n const rotatedImage = tf.image.rotateWithOffset(input.toFloat(), angle, 0, faceCenterNormalized); // rotateWithOffset is not defined for tfjs-node\n rotationMatrix = util.buildRotationMatrix(-angle, faceCenter);\n face = bounding.cutBoxFromImageAndResize({ startPoint: box.startPoint, endPoint: box.endPoint }, rotatedImage, [this.meshSize, this.meshSize]).div(255);\n }\n\n const prediction = {\n mesh,\n box,\n faceConfidence,\n boxConfidence: box.confidence,\n image: face,\n };\n\n // updated stored cache values\n const storedBox = bounding.squarifyBox(box);\n // @ts-ignore box itself doesn't have those properties, but we stored them for future use\n storedBox.confidence = box.confidence;\n // @ts-ignore box itself doesn't have those properties, but we stored them for future use\n storedBox.faceConfidence = faceConfidence;\n // this.storedBoxes[i] = { ...squarifiedLandmarksBox, confidence: box.confidence, faceConfidence };\n this.storedBoxes[i] = storedBox;\n\n return prediction;\n }));\n\n // results = results.filter((a) => a !== null);\n // remove cache entries for detected boxes on low confidence\n if (config.face.mesh.enabled) this.storedBoxes = this.storedBoxes.filter((a) => a.confidence > config.face.detector.minConfidence);\n this.detectedFaces = results.length;\n\n return results;\n }\n}\n", "import { log, join } from '../helpers';\nimport * as tf from '../../dist/tfjs.esm.js';\n\nconst annotations = ['angry', 'disgust', 'fear', 'happy', 'sad', 'surprise', 'neutral'];\nlet model;\nlet last: Array<{ score: number, emotion: string }> = [];\nlet skipped = Number.MAX_SAFE_INTEGER;\n\n// tuning values\nconst rgb = [0.2989, 0.5870, 0.1140]; // factors for red/green/blue colors when converting to grayscale\n\nexport async function load(config) {\n if (!model) {\n model = await tf.loadGraphModel(join(config.modelBasePath, config.face.emotion.modelPath));\n if (!model || !model.modelUrl) log('load model failed:', config.face.emotion.modelPath);\n else if (config.debug) log('load model:', model.modelUrl);\n } else if (config.debug) log('cached model:', model.modelUrl);\n return model;\n}\n\nexport async function predict(image, config) {\n if (!model) return null;\n if ((skipped < config.face.emotion.skipFrames) && config.videoOptimized && (last.length > 0)) {\n skipped++;\n return last;\n }\n if (config.videoOptimized) skipped = 0;\n else skipped = Number.MAX_SAFE_INTEGER;\n return new Promise(async (resolve) => {\n const resize = tf.image.resizeBilinear(image, [model.inputs[0].shape[2], model.inputs[0].shape[1]], false);\n const [red, green, blue] = tf.split(resize, 3, 3);\n resize.dispose();\n // weighted rgb to grayscale: https://www.mathworks.com/help/matlab/ref/rgb2gray.html\n const redNorm = tf.mul(red, rgb[0]);\n const greenNorm = tf.mul(green, rgb[1]);\n const blueNorm = tf.mul(blue, rgb[2]);\n red.dispose();\n green.dispose();\n blue.dispose();\n const grayscale = tf.addN([redNorm, greenNorm, blueNorm]);\n redNorm.dispose();\n greenNorm.dispose();\n blueNorm.dispose();\n const normalize = tf.tidy(() => grayscale.sub(0.5).mul(2));\n grayscale.dispose();\n const obj: Array<{ score: number, emotion: string }> = [];\n if (config.face.emotion.enabled) {\n const emotionT = await model.predict(normalize); // result is already in range 0..1, no need for additional activation\n const data = emotionT.dataSync();\n tf.dispose(emotionT);\n for (let i = 0; i < data.length; i++) {\n if (data[i] > config.face.emotion.minConfidence) obj.push({ score: Math.min(0.99, Math.trunc(100 * data[i]) / 100), emotion: annotations[i] });\n }\n obj.sort((a, b) => b.score - a.score);\n }\n normalize.dispose();\n last = obj;\n resolve(obj);\n });\n}\n", "import { log, join } from '../helpers';\nimport * as tf from '../../dist/tfjs.esm.js';\n\nlet model;\nlet last = { age: 0 };\nlet skipped = Number.MAX_SAFE_INTEGER;\n\ntype Tensor = typeof tf.Tensor;\ntype DB = Array<{ name: string, source: string, embedding: number[] }>;\n\nexport async function load(config) {\n if (!model) {\n model = await tf.loadGraphModel(join(config.modelBasePath, config.face.description.modelPath));\n if (!model || !model.modelUrl) log('load model failed:', config.face.description.modelPath);\n else if (config.debug) log('load model:', model.modelUrl);\n } else if (config.debug) log('cached model:', model.modelUrl);\n return model;\n}\n\nexport function similarity(embedding1, embedding2, order = 2): number {\n if (!embedding1 || !embedding2) return 0;\n if (embedding1?.length === 0 || embedding2?.length === 0) return 0;\n if (embedding1?.length !== embedding2?.length) return 0;\n // general minkowski distance, euclidean distance is limited case where order is 2\n const distance = 5.0 * embedding1\n .map((val, i) => (Math.abs(embedding1[i] - embedding2[i]) ** order)) // distance squared\n .reduce((sum, now) => (sum + now), 0) // sum all distances\n ** (1 / order); // get root of\n const res = Math.max(0, 100 - distance) / 100.0;\n return res;\n}\n\nexport function match(embedding: Array, db: DB, threshold = 0) {\n let best = { similarity: 0, name: '', source: '', embedding: [] as number[] };\n if (!embedding || !db || !Array.isArray(embedding) || !Array.isArray(db)) return best;\n for (const f of db) {\n if (f.embedding && f.name) {\n const perc = similarity(embedding, f.embedding);\n if (perc > threshold && perc > best.similarity) best = { ...f, similarity: perc };\n }\n }\n return best;\n}\n\nexport function enhance(input): Tensor {\n const image = tf.tidy(() => {\n // input received from detector is already normalized to 0..1\n // input is also assumed to be straightened\n const tensor = input.image || input.tensor || input;\n if (!(tensor instanceof tf.Tensor)) return null;\n // do a tight crop of image and resize it to fit the model\n const box = [[0.05, 0.15, 0.85, 0.85]]; // empyrical values for top, left, bottom, right\n // const box = [[0.0, 0.0, 1.0, 1.0]]; // basically no crop for test\n const crop = (tensor.shape.length === 3)\n ? tf.image.cropAndResize(tf.expandDims(tensor, 0), box, [0], [model.inputs[0].shape[2], model.inputs[0].shape[1]]) // add batch dimension if missing\n : tf.image.cropAndResize(tensor, box, [0], [model.inputs[0].shape[2], model.inputs[0].shape[1]]);\n // const crop = tf.image.resizeBilinear(tensor, [model.inputs[0].shape[2], model.inputs[0].shape[1]], false); // just resize to fit the embedding model\n\n /*\n // convert to black&white to avoid colorization impact\n const rgb = [0.2989, 0.5870, 0.1140]; // factors for red/green/blue colors when converting to grayscale: https://www.mathworks.com/help/matlab/ref/rgb2gray.html\n const [red, green, blue] = tf.split(crop, 3, 3);\n const redNorm = tf.mul(red, rgb[0]);\n const greenNorm = tf.mul(green, rgb[1]);\n const blueNorm = tf.mul(blue, rgb[2]);\n const grayscale = tf.addN([redNorm, greenNorm, blueNorm]);\n const merge = tf.stack([grayscale, grayscale, grayscale], 3).squeeze(4);\n */\n\n /*\n // optional increase image contrast\n // or do it per-channel so mean is done on each channel\n // or do it based on histogram\n const mean = merge.mean();\n const factor = 5;\n const contrast = merge.sub(mean).mul(factor).add(mean);\n */\n\n /*\n // normalize brightness from 0..1\n const darken = crop.sub(crop.min());\n const lighten = darken.div(darken.max());\n */\n\n const norm = crop.mul(255);\n\n return norm;\n });\n return image;\n}\n\nexport async function predict(image, config) {\n if (!model) return null;\n if ((skipped < config.face.description.skipFrames) && config.videoOptimized && last.age && (last.age > 0)) {\n skipped++;\n return last;\n }\n if (config.videoOptimized) skipped = 0;\n else skipped = Number.MAX_SAFE_INTEGER;\n return new Promise(async (resolve) => {\n const enhanced = enhance(image);\n\n let resT;\n const obj = {\n age: 0,\n gender: 'unknown',\n genderConfidence: 0,\n descriptor: [] };\n\n if (config.face.description.enabled) resT = await model.predict(enhanced);\n tf.dispose(enhanced);\n\n if (resT) {\n tf.tidy(() => {\n const gender = resT.find((t) => t.shape[1] === 1).dataSync();\n const confidence = Math.trunc(200 * Math.abs((gender[0] - 0.5))) / 100;\n if (confidence > config.face.description.minConfidence) {\n obj.gender = gender[0] <= 0.5 ? 'female' : 'male';\n obj.genderConfidence = Math.min(0.99, confidence);\n }\n const age = resT.find((t) => t.shape[1] === 100).argMax(1).dataSync()[0];\n const all = resT.find((t) => t.shape[1] === 100).dataSync();\n obj.age = Math.round(all[age - 1] > all[age + 1] ? 10 * age - 100 * all[age - 1] : 10 * age + 100 * all[age + 1]) / 10;\n\n const desc = resT.find((t) => t.shape[1] === 1024);\n // const reshape = desc.reshape([128, 8]);\n // const reduce = reshape.logSumExp(1); // reduce 2nd dimension by calculating logSumExp on it\n\n obj.descriptor = [...desc.dataSync()];\n });\n resT.forEach((t) => tf.dispose(t));\n }\n\n last = obj;\n resolve(obj);\n });\n}\n", "import { log, now } from './helpers';\nimport * as tf from '../dist/tfjs.esm.js';\nimport * as facemesh from './blazeface/facemesh';\nimport * as emotion from './emotion/emotion';\nimport * as faceres from './faceres/faceres';\n\ntype Tensor = typeof tf.Tensor;\n\nconst calculateFaceAngle = (face, image_size): { angle: { pitch: number, yaw: number, roll: number }, matrix: [number, number, number, number, number, number, number, number, number] } => {\n // eslint-disable-next-line no-unused-vars, @typescript-eslint/no-unused-vars\n const degrees = (theta) => (theta * 180) / Math.PI;\n // const degrees = (theta) => Math.abs(((theta * 180) / Math.PI) % 360);\n const normalize = (v) => { // normalize vector\n const length = Math.sqrt(v[0] * v[0] + v[1] * v[1] + v[2] * v[2]);\n v[0] /= length;\n v[1] /= length;\n v[2] /= length;\n return v;\n };\n const subVectors = (a, b) => { // vector subtraction (a - b)\n const x = a[0] - b[0];\n const y = a[1] - b[1];\n const z = a[2] - b[2];\n return [x, y, z];\n };\n const crossVectors = (a, b) => { // vector cross product (a x b)\n const x = a[1] * b[2] - a[2] * b[1];\n const y = a[2] * b[0] - a[0] * b[2];\n const z = a[0] * b[1] - a[1] * b[0];\n return [x, y, z];\n };\n // 3x3 rotation matrix to Euler angles based on https://www.geometrictools.com/Documentation/EulerAngles.pdf\n const rotationMatrixToEulerAngle = (r) => {\n // eslint-disable-next-line no-unused-vars, @typescript-eslint/no-unused-vars\n const [r00, r01, r02, r10, r11, r12, r20, r21, r22] = r;\n let thetaX; let thetaY; let thetaZ;\n if (r10 < 1) { // YZX calculation\n if (r10 > -1) {\n thetaZ = Math.asin(r10);\n thetaY = Math.atan2(-r20, r00);\n thetaX = Math.atan2(-r12, r11);\n } else {\n thetaZ = -Math.PI / 2;\n thetaY = -Math.atan2(r21, r22);\n thetaX = 0;\n }\n } else {\n thetaZ = Math.PI / 2;\n thetaY = Math.atan2(r21, r22);\n thetaX = 0;\n }\n return { pitch: 2 * -thetaX, yaw: 2 * -thetaY, roll: 2 * -thetaZ };\n };\n // simple Euler angle calculation based existing 3D mesh\n // eslint-disable-next-line no-unused-vars, @typescript-eslint/no-unused-vars\n const meshToEulerAngle = (mesh) => {\n const radians = (a1, a2, b1, b2) => Math.atan2(b2 - a2, b1 - a1);\n // eslint-disable-next-line no-unused-vars, @typescript-eslint/no-unused-vars\n const angle = {\n // values are in radians in range of -pi/2 to pi/2 which is -90 to +90 degrees\n // value of 0 means center\n // pitch is face move up/down\n pitch: radians(mesh[10][1], mesh[10][2], mesh[152][1], mesh[152][2]), // looking at y,z of top and bottom points of the face\n // yaw is face turn left/right\n yaw: radians(mesh[33][0], mesh[33][2], mesh[263][0], mesh[263][2]), // looking at x,z of outside corners of leftEye and rightEye\n // roll is face lean left/right\n roll: radians(mesh[33][0], mesh[33][1], mesh[263][0], mesh[263][1]), // looking at x,y of outside corners of leftEye and rightEye\n };\n return angle;\n };\n\n const mesh = face.meshRaw;\n if (!mesh || mesh.length < 300) return { angle: { pitch: 0, yaw: 0, roll: 0 }, matrix: [1, 0, 0, 0, 1, 0, 0, 0, 1] };\n\n const size = Math.max(face.boxRaw[2] * image_size[0], face.boxRaw[3] * image_size[1]) / 1.5;\n // top, bottom, left, right\n const pts = [mesh[10], mesh[152], mesh[234], mesh[454]].map((pt) => [\n // make the xyz coordinates proportional, independent of the image/box size\n pt[0] * image_size[0] / size,\n pt[1] * image_size[1] / size,\n pt[2],\n ]);\n\n const y_axis = normalize(subVectors(pts[1], pts[0]));\n let x_axis = normalize(subVectors(pts[3], pts[2]));\n const z_axis = normalize(crossVectors(x_axis, y_axis));\n // adjust x_axis to make sure that all axes are perpendicular to each other\n x_axis = crossVectors(y_axis, z_axis);\n\n // Rotation Matrix from Axis Vectors - http://renderdan.blogspot.com/2006/05/rotation-matrix-from-axis-vectors.html\n // 3x3 rotation matrix is flatten to array in row-major order. Note that the rotation represented by this matrix is inverted.\n const matrix: [number, number, number, number, number, number, number, number, number] = [\n x_axis[0], x_axis[1], x_axis[2],\n y_axis[0], y_axis[1], y_axis[2],\n z_axis[0], z_axis[1], z_axis[2],\n ];\n const angle = rotationMatrixToEulerAngle(matrix);\n // const angle = meshToEulerAngle(mesh);\n return { angle, matrix };\n};\n\nexport const detectFace = async (parent, input): Promise => {\n // run facemesh, includes blazeface and iris\n // eslint-disable-next-line no-async-promise-executor\n let timeStamp;\n let ageRes;\n let genderRes;\n let emotionRes;\n let embeddingRes;\n let descRes;\n const faceRes: Array<{\n confidence: number,\n boxConfidence: number,\n faceConfidence: number,\n box: [number, number, number, number],\n mesh: Array<[number, number, number]>\n meshRaw: Array<[number, number, number]>\n boxRaw: [number, number, number, number],\n annotations: Array<{ part: string, points: Array<[number, number, number]>[] }>,\n age: number,\n gender: string,\n genderConfidence: number,\n emotion: string,\n embedding: number[],\n iris: number,\n rotation: {\n angle: { pitch: number, yaw: number, roll: number },\n matrix: [number, number, number, number, number, number, number, number, number]\n },\n tensor: Tensor,\n }> = [];\n parent.state = 'run:face';\n timeStamp = now();\n const faces = await facemesh.predict(input, parent.config);\n parent.perf.face = Math.trunc(now() - timeStamp);\n if (!faces) return [];\n for (const face of faces) {\n parent.analyze('Get Face');\n\n // is something went wrong, skip the face\n if (!face.image || face.image.isDisposedInternal) {\n log('Face object is disposed:', face.image);\n continue;\n }\n\n const rotation = calculateFaceAngle(face, [input.shape[2], input.shape[1]]);\n\n // run emotion, inherits face from blazeface\n parent.analyze('Start Emotion:');\n if (parent.config.async) {\n emotionRes = parent.config.face.emotion.enabled ? emotion.predict(face.image, parent.config) : {};\n } else {\n parent.state = 'run:emotion';\n timeStamp = now();\n emotionRes = parent.config.face.emotion.enabled ? await emotion.predict(face.image, parent.config) : {};\n parent.perf.emotion = Math.trunc(now() - timeStamp);\n }\n parent.analyze('End Emotion:');\n\n // run emotion, inherits face from blazeface\n parent.analyze('Start Description:');\n if (parent.config.async) {\n descRes = parent.config.face.description.enabled ? faceres.predict(face, parent.config) : [];\n } else {\n parent.state = 'run:description';\n timeStamp = now();\n descRes = parent.config.face.description.enabled ? await faceres.predict(face.image, parent.config) : [];\n parent.perf.embedding = Math.trunc(now() - timeStamp);\n }\n parent.analyze('End Description:');\n\n // if async wait for results\n if (parent.config.async) {\n [ageRes, genderRes, emotionRes, embeddingRes, descRes] = await Promise.all([ageRes, genderRes, emotionRes, embeddingRes, descRes]);\n }\n\n parent.analyze('Finish Face:');\n\n // calculate iris distance\n // iris: array[ center, left, top, right, bottom]\n if (!parent.config.face.iris.enabled && face?.annotations?.leftEyeIris && face?.annotations?.rightEyeIris) {\n delete face.annotations.leftEyeIris;\n delete face.annotations.rightEyeIris;\n }\n const irisSize = (face.annotations?.leftEyeIris && face.annotations?.rightEyeIris)\n /* average human iris size is 11.7mm */\n ? 11.7 * Math.max(Math.abs(face.annotations.leftEyeIris[3][0] - face.annotations.leftEyeIris[1][0]), Math.abs(face.annotations.rightEyeIris[4][1] - face.annotations.rightEyeIris[2][1]))\n : 0;\n\n // combine results\n faceRes.push({\n ...face,\n age: descRes.age,\n gender: descRes.gender,\n genderConfidence: descRes.genderConfidence,\n embedding: descRes.descriptor,\n emotion: emotionRes,\n iris: (irisSize !== 0) ? Math.trunc(irisSize) / 100 : 0,\n rotation,\n tensor: parent.config.face.detector.return ? face.image?.squeeze() : null,\n });\n // dispose original face tensor\n face.image?.dispose();\n\n parent.analyze('End Face');\n }\n parent.analyze('End FaceMesh:');\n if (parent.config.async) {\n if (parent.perf.face) delete parent.perf.face;\n if (parent.perf.age) delete parent.perf.age;\n if (parent.perf.gender) delete parent.perf.gender;\n if (parent.perf.emotion) delete parent.perf.emotion;\n }\n return faceRes;\n};\n", "import { log, join } from '../helpers';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as poses from './poses';\nimport * as util from './utils';\n\nlet model;\nconst poseNetOutputs = ['MobilenetV1/offset_2/BiasAdd'/* offsets */, 'MobilenetV1/heatmap_2/BiasAdd'/* heatmapScores */, 'MobilenetV1/displacement_fwd_2/BiasAdd'/* displacementFwd */, 'MobilenetV1/displacement_bwd_2/BiasAdd'/* displacementBwd */];\n\nexport async function predict(input, config) {\n const res = tf.tidy(() => {\n const resized = input.resizeBilinear([model.inputs[0].shape[2], model.inputs[0].shape[1]]);\n const normalized = resized.toFloat().div(127.5).sub(1.0);\n const results = model.execute(normalized, poseNetOutputs);\n const results3d = results.map((y) => y.squeeze([0]));\n results3d[1] = results3d[1].sigmoid(); // apply sigmoid on scores\n return results3d;\n });\n\n const buffers = await Promise.all(res.map((tensor) => tensor.buffer()));\n for (const t of res) t.dispose();\n\n const decoded = await poses.decode(buffers[0], buffers[1], buffers[2], buffers[3], config.body.maxDetected, config.body.minConfidence);\n const scaled = util.scalePoses(decoded, [input.shape[1], input.shape[2]], [model.inputs[0].shape[2], model.inputs[0].shape[1]]);\n\n return scaled;\n}\n\nexport async function load(config) {\n if (!model) {\n model = await tf.loadGraphModel(join(config.modelBasePath, config.body.modelPath));\n if (!model || !model.modelUrl) log('load model failed:', config.body.modelPath);\n else if (config.debug) log('load model:', model.modelUrl);\n } else if (config.debug) log('cached model:', model.modelUrl);\n return model;\n}\n", "export const partNames = [\n 'nose', 'leftEye', 'rightEye', 'leftEar', 'rightEar', 'leftShoulder',\n 'rightShoulder', 'leftElbow', 'rightElbow', 'leftWrist', 'rightWrist',\n 'leftHip', 'rightHip', 'leftKnee', 'rightKnee', 'leftAnkle', 'rightAnkle',\n];\n\nexport const count = partNames.length; // 17 keypoints\n\nexport const partIds = partNames.reduce((result, jointName, i) => {\n result[jointName] = i;\n return result;\n}, {});\n\nconst connectedPartNames = [\n ['leftHip', 'leftShoulder'], ['leftElbow', 'leftShoulder'],\n ['leftElbow', 'leftWrist'], ['leftHip', 'leftKnee'],\n ['leftKnee', 'leftAnkle'], ['rightHip', 'rightShoulder'],\n ['rightElbow', 'rightShoulder'], ['rightElbow', 'rightWrist'],\n ['rightHip', 'rightKnee'], ['rightKnee', 'rightAnkle'],\n ['leftShoulder', 'rightShoulder'], ['leftHip', 'rightHip'],\n];\nexport const connectedPartIndices = connectedPartNames.map(([jointNameA, jointNameB]) => ([partIds[jointNameA], partIds[jointNameB]]));\n\nexport const poseChain = [\n ['nose', 'leftEye'], ['leftEye', 'leftEar'], ['nose', 'rightEye'],\n ['rightEye', 'rightEar'], ['nose', 'leftShoulder'],\n ['leftShoulder', 'leftElbow'], ['leftElbow', 'leftWrist'],\n ['leftShoulder', 'leftHip'], ['leftHip', 'leftKnee'],\n ['leftKnee', 'leftAnkle'], ['nose', 'rightShoulder'],\n ['rightShoulder', 'rightElbow'], ['rightElbow', 'rightWrist'],\n ['rightShoulder', 'rightHip'], ['rightHip', 'rightKnee'],\n ['rightKnee', 'rightAnkle'],\n];\n", "import * as kpt from './keypoints';\n\nexport function eitherPointDoesntMeetConfidence(a, b, minConfidence) {\n return (a < minConfidence || b < minConfidence);\n}\n\nexport function getAdjacentKeyPoints(keypoints, minConfidence) {\n return kpt.connectedPartIndices.reduce((result, [leftJoint, rightJoint]) => {\n if (eitherPointDoesntMeetConfidence(keypoints[leftJoint].score, keypoints[rightJoint].score, minConfidence)) {\n return result;\n }\n result.push([keypoints[leftJoint], keypoints[rightJoint]]);\n return result;\n }, []);\n}\n\nexport function getBoundingBox(keypoints) {\n const coord = keypoints.reduce(({ maxX, maxY, minX, minY }, { position: { x, y } }) => ({\n maxX: Math.max(maxX, x),\n maxY: Math.max(maxY, y),\n minX: Math.min(minX, x),\n minY: Math.min(minY, y),\n }), {\n maxX: Number.NEGATIVE_INFINITY,\n maxY: Number.NEGATIVE_INFINITY,\n minX: Number.POSITIVE_INFINITY,\n minY: Number.POSITIVE_INFINITY,\n });\n return [coord.minX, coord.minY, coord.maxX - coord.minX, coord.maxY - coord.minY];\n}\n\nexport function scalePoses(poses, [height, width], [inputResolutionHeight, inputResolutionWidth]) {\n const scalePose = (pose, scaleY, scaleX) => ({\n score: pose.score,\n box: [Math.trunc(pose.box[0] * scaleX), Math.trunc(pose.box[1] * scaleY), Math.trunc(pose.box[2] * scaleX), Math.trunc(pose.box[3] * scaleY)],\n keypoints: pose.keypoints.map(({ score, part, position }) => ({\n score,\n part,\n position: { x: Math.trunc(position.x * scaleX), y: Math.trunc(position.y * scaleY) },\n })),\n });\n\n const scaledPoses = poses.map((pose) => scalePose(pose, height / inputResolutionHeight, width / inputResolutionWidth));\n return scaledPoses;\n}\n\n// algorithm based on Coursera Lecture from Algorithms, Part 1: https://www.coursera.org/learn/algorithms-part1/lecture/ZjoSM/heapsort\nexport class MaxHeap {\n priorityQueue: any;\n numberOfElements: number;\n getElementValue: any;\n\n constructor(maxSize, getElementValue) {\n this.priorityQueue = new Array(maxSize);\n this.numberOfElements = -1;\n this.getElementValue = getElementValue;\n }\n\n enqueue(x) {\n this.priorityQueue[++this.numberOfElements] = x;\n this.swim(this.numberOfElements);\n }\n\n dequeue() {\n const max = this.priorityQueue[0];\n this.exchange(0, this.numberOfElements--);\n this.sink(0);\n this.priorityQueue[this.numberOfElements + 1] = null;\n return max;\n }\n\n empty() { return this.numberOfElements === -1; }\n\n size() { return this.numberOfElements + 1; }\n\n all() { return this.priorityQueue.slice(0, this.numberOfElements + 1); }\n\n max() { return this.priorityQueue[0]; }\n\n swim(k) {\n while (k > 0 && this.less(Math.floor(k / 2), k)) {\n this.exchange(k, Math.floor(k / 2));\n k = Math.floor(k / 2);\n }\n }\n\n sink(k) {\n while (2 * k <= this.numberOfElements) {\n let j = 2 * k;\n if (j < this.numberOfElements && this.less(j, j + 1)) j++;\n if (!this.less(k, j)) break;\n this.exchange(k, j);\n k = j;\n }\n }\n\n getValueAt(i) {\n return this.getElementValue(this.priorityQueue[i]);\n }\n\n less(i, j) {\n return this.getValueAt(i) < this.getValueAt(j);\n }\n\n exchange(i, j) {\n const t = this.priorityQueue[i];\n this.priorityQueue[i] = this.priorityQueue[j];\n this.priorityQueue[j] = t;\n }\n}\n\nexport function getOffsetPoint(y, x, keypoint, offsets) {\n return {\n y: offsets.get(y, x, keypoint),\n x: offsets.get(y, x, keypoint + kpt.count),\n };\n}\n\nexport function getImageCoords(part, outputStride, offsets) {\n const { heatmapY, heatmapX, id: keypoint } = part;\n const { y, x } = getOffsetPoint(heatmapY, heatmapX, keypoint, offsets);\n return {\n x: part.heatmapX * outputStride + x,\n y: part.heatmapY * outputStride + y,\n };\n}\n\nexport function fillArray(element, size) {\n const result = new Array(size);\n for (let i = 0; i < size; i++) {\n result[i] = element;\n }\n return result;\n}\n\nexport function clamp(a, min, max) {\n if (a < min) return min;\n if (a > max) return max;\n return a;\n}\n\nexport function squaredDistance(y1, x1, y2, x2) {\n const dy = y2 - y1;\n const dx = x2 - x1;\n return dy * dy + dx * dx;\n}\n\nexport function addVectors(a, b) {\n return { x: a.x + b.x, y: a.y + b.y };\n}\n\nexport function clampVector(a, min, max) {\n return { y: clamp(a.y, min, max), x: clamp(a.x, min, max) };\n}\n", "import * as utils from './utils';\nimport * as kpt from './keypoints';\n\nconst localMaximumRadius = 1;\nconst defaultOutputStride = 16;\nconst squaredNmsRadius = 20 ** 2;\n\nfunction traverseToTargetKeypoint(edgeId, sourceKeypoint, targetKeypointId, scoresBuffer, offsets, outputStride, displacements, offsetRefineStep = 2) {\n const getDisplacement = (point) => ({\n y: displacements.get(point.y, point.x, edgeId),\n x: displacements.get(point.y, point.x, (displacements.shape[2] / 2) + edgeId),\n });\n const getStridedIndexNearPoint = (point, height, width) => ({\n y: utils.clamp(Math.round(point.y / outputStride), 0, height - 1),\n x: utils.clamp(Math.round(point.x / outputStride), 0, width - 1),\n });\n\n const [height, width] = scoresBuffer.shape;\n // Nearest neighbor interpolation for the source->target displacements.\n const sourceKeypointIndices = getStridedIndexNearPoint(sourceKeypoint.position, height, width);\n const displacement = getDisplacement(sourceKeypointIndices);\n const displacedPoint = utils.addVectors(sourceKeypoint.position, displacement);\n let targetKeypoint = displacedPoint;\n for (let i = 0; i < offsetRefineStep; i++) {\n const targetKeypointIndices = getStridedIndexNearPoint(targetKeypoint, height, width);\n const offsetPoint = utils.getOffsetPoint(targetKeypointIndices.y, targetKeypointIndices.x, targetKeypointId, offsets);\n targetKeypoint = utils.addVectors({\n x: targetKeypointIndices.x * outputStride,\n y: targetKeypointIndices.y * outputStride,\n }, { x: offsetPoint.x, y: offsetPoint.y });\n }\n const targetKeyPointIndices = getStridedIndexNearPoint(targetKeypoint, height, width);\n const score = scoresBuffer.get(targetKeyPointIndices.y, targetKeyPointIndices.x, targetKeypointId);\n return { position: targetKeypoint, part: kpt.partNames[targetKeypointId], score };\n}\n\nexport function decodePose(root, scores, offsets, outputStride, displacementsFwd, displacementsBwd) {\n const parentChildrenTuples = kpt.poseChain.map(([parentJoinName, childJoinName]) => ([kpt.partIds[parentJoinName], kpt.partIds[childJoinName]]));\n const parentToChildEdges = parentChildrenTuples.map(([, childJointId]) => childJointId);\n const childToParentEdges = parentChildrenTuples.map(([parentJointId]) => parentJointId);\n const numParts = scores.shape[2];\n const numEdges = parentToChildEdges.length;\n const instanceKeypoints = new Array(numParts);\n // Start a new detection instance at the position of the root.\n const { part: rootPart, score: rootScore } = root;\n const rootPoint = utils.getImageCoords(rootPart, outputStride, offsets);\n instanceKeypoints[rootPart.id] = {\n score: rootScore,\n part: kpt.partNames[rootPart.id],\n position: rootPoint,\n };\n // Decode the part positions upwards in the tree, following the backward displacements.\n for (let edge = numEdges - 1; edge >= 0; --edge) {\n const sourceKeypointId = parentToChildEdges[edge];\n const targetKeypointId = childToParentEdges[edge];\n if (instanceKeypoints[sourceKeypointId] && !instanceKeypoints[targetKeypointId]) {\n instanceKeypoints[targetKeypointId] = traverseToTargetKeypoint(edge, instanceKeypoints[sourceKeypointId], targetKeypointId, scores, offsets, outputStride, displacementsBwd);\n }\n }\n // Decode the part positions downwards in the tree, following the forward displacements.\n for (let edge = 0; edge < numEdges; ++edge) {\n const sourceKeypointId = childToParentEdges[edge];\n const targetKeypointId = parentToChildEdges[edge];\n if (instanceKeypoints[sourceKeypointId] && !instanceKeypoints[targetKeypointId]) {\n instanceKeypoints[targetKeypointId] = traverseToTargetKeypoint(edge, instanceKeypoints[sourceKeypointId], targetKeypointId, scores, offsets, outputStride, displacementsFwd);\n }\n }\n return instanceKeypoints;\n}\n\nfunction scoreIsMaximumInLocalWindow(keypointId, score, heatmapY, heatmapX, scores) {\n const [height, width] = scores.shape;\n let localMaximum = true;\n const yStart = Math.max(heatmapY - localMaximumRadius, 0);\n const yEnd = Math.min(heatmapY + localMaximumRadius + 1, height);\n for (let yCurrent = yStart; yCurrent < yEnd; ++yCurrent) {\n const xStart = Math.max(heatmapX - localMaximumRadius, 0);\n const xEnd = Math.min(heatmapX + localMaximumRadius + 1, width);\n for (let xCurrent = xStart; xCurrent < xEnd; ++xCurrent) {\n if (scores.get(yCurrent, xCurrent, keypointId) > score) {\n localMaximum = false;\n break;\n }\n }\n if (!localMaximum) break;\n }\n return localMaximum;\n}\n\nexport function buildPartWithScoreQueue(minConfidence, scores) {\n const [height, width, numKeypoints] = scores.shape;\n const queue = new utils.MaxHeap(height * width * numKeypoints, ({ score }) => score);\n for (let heatmapY = 0; heatmapY < height; ++heatmapY) {\n for (let heatmapX = 0; heatmapX < width; ++heatmapX) {\n for (let keypointId = 0; keypointId < numKeypoints; ++keypointId) {\n const score = scores.get(heatmapY, heatmapX, keypointId);\n // Only consider parts with score greater or equal to threshold as root candidates.\n if (score < minConfidence) continue;\n // Only consider keypoints whose score is maximum in a local window.\n if (scoreIsMaximumInLocalWindow(keypointId, score, heatmapY, heatmapX, scores)) queue.enqueue({ score, part: { heatmapY, heatmapX, id: keypointId } });\n }\n }\n }\n return queue;\n}\n\nfunction withinRadius(poses, { x, y }, keypointId) {\n return poses.some(({ keypoints }) => {\n const correspondingKeypoint = keypoints[keypointId].position;\n return utils.squaredDistance(y, x, correspondingKeypoint.y, correspondingKeypoint.x) <= squaredNmsRadius;\n });\n}\n\nfunction getInstanceScore(existingPoses, instanceKeypoints) {\n const notOverlappedKeypointScores = instanceKeypoints.reduce((result, { position, score }, keypointId) => {\n if (!withinRadius(existingPoses, position, keypointId)) result += score;\n return result;\n }, 0.0);\n return notOverlappedKeypointScores / instanceKeypoints.length;\n}\n\nexport function decode(offsetsBuffer, scoresBuffer, displacementsFwdBuffer, displacementsBwdBuffer, maxDetected, minConfidence) {\n const poses: Array<{ keypoints: any, box: any, score: number }> = [];\n const queue = buildPartWithScoreQueue(minConfidence, scoresBuffer);\n // Generate at most maxDetected object instances per image in decreasing root part score order.\n while (poses.length < maxDetected && !queue.empty()) {\n // The top element in the queue is the next root candidate.\n const root = queue.dequeue();\n // Part-based non-maximum suppression: We reject a root candidate if it is within a disk of `nmsRadius` pixels from the corresponding part of a previously detected instance.\n const rootImageCoords = utils.getImageCoords(root.part, defaultOutputStride, offsetsBuffer);\n if (withinRadius(poses, rootImageCoords, root.part.id)) continue;\n // Else start a new detection instance at the position of the root.\n const allKeypoints = decodePose(root, scoresBuffer, offsetsBuffer, defaultOutputStride, displacementsFwdBuffer, displacementsBwdBuffer);\n const keypoints = allKeypoints.filter((a) => a.score > minConfidence);\n const score = getInstanceScore(poses, keypoints);\n const box = utils.getBoundingBox(keypoints);\n if (score > minConfidence) poses.push({ keypoints, box, score: Math.round(100 * score) / 100 });\n }\n return poses;\n}\n", "import { log, join } from '../helpers';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as handdetector from './handdetector';\nimport * as handpipeline from './handpipeline';\n\nconst meshAnnotations = {\n thumb: [1, 2, 3, 4],\n indexFinger: [5, 6, 7, 8],\n middleFinger: [9, 10, 11, 12],\n ringFinger: [13, 14, 15, 16],\n pinky: [17, 18, 19, 20],\n palmBase: [0],\n};\n\nlet handDetectorModel;\nlet handPoseModel;\nlet handPipeline;\n\nexport async function predict(input, config) {\n const predictions = await handPipeline.estimateHands(input, config);\n if (!predictions) return [];\n const hands: Array<{ confidence: number, box: any, boxRaw: any, landmarks: any, annotations: any }> = [];\n for (const prediction of predictions) {\n const annotations = {};\n if (prediction.landmarks) {\n for (const key of Object.keys(meshAnnotations)) {\n annotations[key] = meshAnnotations[key].map((index) => prediction.landmarks[index]);\n }\n }\n const box = prediction.box ? [\n Math.max(0, prediction.box.topLeft[0]),\n Math.max(0, prediction.box.topLeft[1]),\n Math.min(input.shape[2], prediction.box.bottomRight[0]) - Math.max(0, prediction.box.topLeft[0]),\n Math.min(input.shape[1], prediction.box.bottomRight[1]) - Math.max(0, prediction.box.topLeft[1]),\n ] : [];\n const boxRaw = [\n (prediction.box.topLeft[0]) / input.shape[2],\n (prediction.box.topLeft[1]) / input.shape[1],\n (prediction.box.bottomRight[0] - prediction.box.topLeft[0]) / input.shape[2],\n (prediction.box.bottomRight[1] - prediction.box.topLeft[1]) / input.shape[1],\n ];\n hands.push({ confidence: Math.round(100 * prediction.confidence) / 100, box, boxRaw, landmarks: prediction.landmarks, annotations });\n }\n return hands;\n}\n\nexport async function load(config): Promise<[Object, Object]> {\n if (!handDetectorModel || !handPoseModel) {\n [handDetectorModel, handPoseModel] = await Promise.all([\n config.hand.enabled ? tf.loadGraphModel(join(config.modelBasePath, config.hand.detector.modelPath), { fromTFHub: config.hand.detector.modelPath.includes('tfhub.dev') }) : null,\n config.hand.landmarks ? tf.loadGraphModel(join(config.modelBasePath, config.hand.skeleton.modelPath), { fromTFHub: config.hand.skeleton.modelPath.includes('tfhub.dev') }) : null,\n ]);\n if (config.hand.enabled) {\n if (!handDetectorModel || !handDetectorModel.modelUrl) log('load model failed:', config.hand.detector.modelPath);\n else if (config.debug) log('load model:', handDetectorModel.modelUrl);\n if (!handPoseModel || !handPoseModel.modelUrl) log('load model failed:', config.hand.skeleton.modelPath);\n else if (config.debug) log('load model:', handPoseModel.modelUrl);\n }\n } else {\n if (config.debug) log('cached model:', handDetectorModel.modelUrl);\n if (config.debug) log('cached model:', handPoseModel.modelUrl);\n }\n const handDetector = new handdetector.HandDetector(handDetectorModel);\n handPipeline = new handpipeline.HandPipeline(handDetector, handPoseModel);\n return [handDetectorModel, handPoseModel];\n}\n", "import * as tf from '../../dist/tfjs.esm.js';\n\nexport function getBoxSize(box) {\n return [\n Math.abs(box.endPoint[0] - box.startPoint[0]),\n Math.abs(box.endPoint[1] - box.startPoint[1]),\n ];\n}\n\nexport function getBoxCenter(box) {\n return [\n box.startPoint[0] + (box.endPoint[0] - box.startPoint[0]) / 2,\n box.startPoint[1] + (box.endPoint[1] - box.startPoint[1]) / 2,\n ];\n}\n\nexport function cutBoxFromImageAndResize(box, image, cropSize) {\n const h = image.shape[1];\n const w = image.shape[2];\n const boxes = [[\n box.startPoint[1] / h,\n box.startPoint[0] / w,\n box.endPoint[1] / h,\n box.endPoint[0] / w,\n ]];\n return tf.image.cropAndResize(image, boxes, [0], cropSize);\n}\n\nexport function scaleBoxCoordinates(box, factor) {\n const startPoint = [box.startPoint[0] * factor[0], box.startPoint[1] * factor[1]];\n const endPoint = [box.endPoint[0] * factor[0], box.endPoint[1] * factor[1]];\n const palmLandmarks = box.palmLandmarks.map((coord) => {\n const scaledCoord = [coord[0] * factor[0], coord[1] * factor[1]];\n return scaledCoord;\n });\n return { startPoint, endPoint, palmLandmarks, confidence: box.confidence };\n}\n\nexport function enlargeBox(box, factor = 1.5) {\n const center = getBoxCenter(box);\n const size = getBoxSize(box);\n const newHalfSize = [factor * size[0] / 2, factor * size[1] / 2];\n const startPoint = [center[0] - newHalfSize[0], center[1] - newHalfSize[1]];\n const endPoint = [center[0] + newHalfSize[0], center[1] + newHalfSize[1]];\n return { startPoint, endPoint, palmLandmarks: box.palmLandmarks };\n}\n\nexport function squarifyBox(box) {\n const centers = getBoxCenter(box);\n const size = getBoxSize(box);\n const maxEdge = Math.max(...size);\n const halfSize = maxEdge / 2;\n const startPoint = [centers[0] - halfSize, centers[1] - halfSize];\n const endPoint = [centers[0] + halfSize, centers[1] + halfSize];\n return { startPoint, endPoint, palmLandmarks: box.palmLandmarks };\n}\n\nexport function shiftBox(box, shiftFactor) {\n const boxSize = [\n box.endPoint[0] - box.startPoint[0],\n box.endPoint[1] - box.startPoint[1],\n ];\n const shiftVector = [boxSize[0] * shiftFactor[0], boxSize[1] * shiftFactor[1]];\n const startPoint = [box.startPoint[0] + shiftVector[0], box.startPoint[1] + shiftVector[1]];\n const endPoint = [box.endPoint[0] + shiftVector[0], box.endPoint[1] + shiftVector[1]];\n return { startPoint, endPoint, palmLandmarks: box.palmLandmarks };\n}\n", "export const anchors = [\n {\n x: 0.015625,\n y: 0.015625,\n },\n {\n x: 0.015625,\n y: 0.015625,\n },\n {\n x: 0.046875,\n y: 0.015625,\n },\n {\n x: 0.046875,\n y: 0.015625,\n },\n {\n x: 0.078125,\n y: 0.015625,\n },\n {\n x: 0.078125,\n y: 0.015625,\n },\n {\n x: 0.109375,\n y: 0.015625,\n },\n {\n x: 0.109375,\n y: 0.015625,\n },\n {\n x: 0.140625,\n y: 0.015625,\n },\n {\n x: 0.140625,\n y: 0.015625,\n },\n {\n x: 0.171875,\n y: 0.015625,\n },\n {\n x: 0.171875,\n y: 0.015625,\n },\n {\n x: 0.203125,\n y: 0.015625,\n },\n {\n x: 0.203125,\n y: 0.015625,\n },\n {\n x: 0.234375,\n y: 0.015625,\n },\n {\n x: 0.234375,\n y: 0.015625,\n },\n {\n x: 0.265625,\n y: 0.015625,\n },\n {\n x: 0.265625,\n y: 0.015625,\n },\n {\n x: 0.296875,\n y: 0.015625,\n },\n {\n x: 0.296875,\n y: 0.015625,\n },\n {\n x: 0.328125,\n y: 0.015625,\n },\n {\n x: 0.328125,\n y: 0.015625,\n },\n {\n x: 0.359375,\n y: 0.015625,\n },\n {\n x: 0.359375,\n y: 0.015625,\n },\n {\n x: 0.390625,\n y: 0.015625,\n },\n {\n x: 0.390625,\n y: 0.015625,\n },\n {\n x: 0.421875,\n y: 0.015625,\n },\n {\n x: 0.421875,\n y: 0.015625,\n },\n {\n x: 0.453125,\n y: 0.015625,\n },\n {\n x: 0.453125,\n y: 0.015625,\n },\n {\n x: 0.484375,\n y: 0.015625,\n },\n {\n x: 0.484375,\n y: 0.015625,\n },\n {\n x: 0.515625,\n y: 0.015625,\n },\n {\n x: 0.515625,\n y: 0.015625,\n },\n {\n x: 0.546875,\n y: 0.015625,\n },\n {\n x: 0.546875,\n y: 0.015625,\n },\n {\n x: 0.578125,\n y: 0.015625,\n },\n {\n x: 0.578125,\n y: 0.015625,\n },\n {\n x: 0.609375,\n y: 0.015625,\n },\n {\n x: 0.609375,\n y: 0.015625,\n },\n {\n x: 0.640625,\n y: 0.015625,\n },\n {\n x: 0.640625,\n y: 0.015625,\n },\n {\n x: 0.671875,\n y: 0.015625,\n },\n {\n x: 0.671875,\n y: 0.015625,\n },\n {\n x: 0.703125,\n y: 0.015625,\n },\n {\n x: 0.703125,\n y: 0.015625,\n },\n {\n x: 0.734375,\n y: 0.015625,\n },\n {\n x: 0.734375,\n y: 0.015625,\n },\n {\n x: 0.765625,\n y: 0.015625,\n },\n {\n x: 0.765625,\n y: 0.015625,\n },\n {\n x: 0.796875,\n y: 0.015625,\n },\n {\n x: 0.796875,\n y: 0.015625,\n },\n {\n x: 0.828125,\n y: 0.015625,\n },\n {\n x: 0.828125,\n y: 0.015625,\n },\n {\n x: 0.859375,\n y: 0.015625,\n },\n {\n x: 0.859375,\n y: 0.015625,\n },\n {\n x: 0.890625,\n y: 0.015625,\n },\n {\n x: 0.890625,\n y: 0.015625,\n },\n {\n x: 0.921875,\n y: 0.015625,\n },\n {\n x: 0.921875,\n y: 0.015625,\n },\n {\n x: 0.953125,\n y: 0.015625,\n },\n {\n x: 0.953125,\n y: 0.015625,\n },\n {\n x: 0.984375,\n y: 0.015625,\n },\n {\n x: 0.984375,\n y: 0.015625,\n },\n {\n x: 0.015625,\n y: 0.046875,\n },\n {\n x: 0.015625,\n y: 0.046875,\n },\n {\n x: 0.046875,\n y: 0.046875,\n },\n {\n x: 0.046875,\n y: 0.046875,\n },\n {\n x: 0.078125,\n y: 0.046875,\n },\n {\n x: 0.078125,\n y: 0.046875,\n },\n {\n x: 0.109375,\n y: 0.046875,\n },\n {\n x: 0.109375,\n y: 0.046875,\n },\n {\n x: 0.140625,\n y: 0.046875,\n },\n {\n x: 0.140625,\n y: 0.046875,\n },\n {\n x: 0.171875,\n y: 0.046875,\n },\n {\n x: 0.171875,\n y: 0.046875,\n },\n {\n x: 0.203125,\n y: 0.046875,\n },\n {\n x: 0.203125,\n y: 0.046875,\n },\n {\n x: 0.234375,\n y: 0.046875,\n },\n {\n x: 0.234375,\n y: 0.046875,\n },\n {\n x: 0.265625,\n y: 0.046875,\n },\n {\n x: 0.265625,\n y: 0.046875,\n },\n {\n x: 0.296875,\n y: 0.046875,\n },\n {\n x: 0.296875,\n y: 0.046875,\n },\n {\n x: 0.328125,\n y: 0.046875,\n },\n {\n x: 0.328125,\n y: 0.046875,\n },\n {\n x: 0.359375,\n y: 0.046875,\n },\n {\n x: 0.359375,\n y: 0.046875,\n },\n {\n x: 0.390625,\n y: 0.046875,\n },\n {\n x: 0.390625,\n y: 0.046875,\n },\n {\n x: 0.421875,\n y: 0.046875,\n },\n {\n x: 0.421875,\n y: 0.046875,\n },\n {\n x: 0.453125,\n y: 0.046875,\n },\n {\n x: 0.453125,\n y: 0.046875,\n },\n {\n x: 0.484375,\n y: 0.046875,\n },\n {\n x: 0.484375,\n y: 0.046875,\n },\n {\n x: 0.515625,\n y: 0.046875,\n },\n {\n x: 0.515625,\n y: 0.046875,\n },\n {\n x: 0.546875,\n y: 0.046875,\n },\n {\n x: 0.546875,\n y: 0.046875,\n },\n {\n x: 0.578125,\n y: 0.046875,\n },\n {\n x: 0.578125,\n y: 0.046875,\n },\n {\n x: 0.609375,\n y: 0.046875,\n },\n {\n x: 0.609375,\n y: 0.046875,\n },\n {\n x: 0.640625,\n y: 0.046875,\n },\n {\n x: 0.640625,\n y: 0.046875,\n },\n {\n x: 0.671875,\n y: 0.046875,\n },\n {\n x: 0.671875,\n y: 0.046875,\n },\n {\n x: 0.703125,\n y: 0.046875,\n },\n {\n x: 0.703125,\n y: 0.046875,\n },\n {\n x: 0.734375,\n y: 0.046875,\n },\n {\n x: 0.734375,\n y: 0.046875,\n },\n {\n x: 0.765625,\n y: 0.046875,\n },\n {\n x: 0.765625,\n y: 0.046875,\n },\n {\n x: 0.796875,\n y: 0.046875,\n },\n {\n x: 0.796875,\n y: 0.046875,\n },\n {\n x: 0.828125,\n y: 0.046875,\n },\n {\n x: 0.828125,\n y: 0.046875,\n },\n {\n x: 0.859375,\n y: 0.046875,\n },\n {\n x: 0.859375,\n y: 0.046875,\n },\n {\n x: 0.890625,\n y: 0.046875,\n },\n {\n x: 0.890625,\n y: 0.046875,\n },\n {\n x: 0.921875,\n y: 0.046875,\n },\n {\n x: 0.921875,\n y: 0.046875,\n },\n {\n x: 0.953125,\n y: 0.046875,\n },\n {\n x: 0.953125,\n y: 0.046875,\n },\n {\n x: 0.984375,\n y: 0.046875,\n },\n {\n x: 0.984375,\n y: 0.046875,\n },\n {\n x: 0.015625,\n y: 0.078125,\n },\n {\n x: 0.015625,\n y: 0.078125,\n },\n {\n x: 0.046875,\n y: 0.078125,\n },\n {\n x: 0.046875,\n y: 0.078125,\n },\n {\n x: 0.078125,\n y: 0.078125,\n },\n {\n x: 0.078125,\n y: 0.078125,\n },\n {\n x: 0.109375,\n y: 0.078125,\n },\n {\n x: 0.109375,\n y: 0.078125,\n },\n {\n x: 0.140625,\n y: 0.078125,\n },\n {\n x: 0.140625,\n y: 0.078125,\n },\n {\n x: 0.171875,\n y: 0.078125,\n },\n {\n x: 0.171875,\n y: 0.078125,\n },\n {\n x: 0.203125,\n y: 0.078125,\n },\n {\n x: 0.203125,\n y: 0.078125,\n },\n {\n x: 0.234375,\n y: 0.078125,\n },\n {\n x: 0.234375,\n y: 0.078125,\n },\n {\n x: 0.265625,\n y: 0.078125,\n },\n {\n x: 0.265625,\n y: 0.078125,\n },\n {\n x: 0.296875,\n y: 0.078125,\n },\n {\n x: 0.296875,\n y: 0.078125,\n },\n {\n x: 0.328125,\n y: 0.078125,\n },\n {\n x: 0.328125,\n y: 0.078125,\n },\n {\n x: 0.359375,\n y: 0.078125,\n },\n {\n x: 0.359375,\n y: 0.078125,\n },\n {\n x: 0.390625,\n y: 0.078125,\n },\n {\n x: 0.390625,\n y: 0.078125,\n },\n {\n x: 0.421875,\n y: 0.078125,\n },\n {\n x: 0.421875,\n y: 0.078125,\n },\n {\n x: 0.453125,\n y: 0.078125,\n },\n {\n x: 0.453125,\n y: 0.078125,\n },\n {\n x: 0.484375,\n y: 0.078125,\n },\n {\n x: 0.484375,\n y: 0.078125,\n },\n {\n x: 0.515625,\n y: 0.078125,\n },\n {\n x: 0.515625,\n y: 0.078125,\n },\n {\n x: 0.546875,\n y: 0.078125,\n },\n {\n x: 0.546875,\n y: 0.078125,\n },\n {\n x: 0.578125,\n y: 0.078125,\n },\n {\n x: 0.578125,\n y: 0.078125,\n },\n {\n x: 0.609375,\n y: 0.078125,\n },\n {\n x: 0.609375,\n y: 0.078125,\n },\n {\n x: 0.640625,\n y: 0.078125,\n },\n {\n x: 0.640625,\n y: 0.078125,\n },\n {\n x: 0.671875,\n y: 0.078125,\n },\n {\n x: 0.671875,\n y: 0.078125,\n },\n {\n x: 0.703125,\n y: 0.078125,\n },\n {\n x: 0.703125,\n y: 0.078125,\n },\n {\n x: 0.734375,\n y: 0.078125,\n },\n {\n x: 0.734375,\n y: 0.078125,\n },\n {\n x: 0.765625,\n y: 0.078125,\n },\n {\n x: 0.765625,\n y: 0.078125,\n },\n {\n x: 0.796875,\n y: 0.078125,\n },\n {\n x: 0.796875,\n y: 0.078125,\n },\n {\n x: 0.828125,\n y: 0.078125,\n },\n {\n x: 0.828125,\n y: 0.078125,\n },\n {\n x: 0.859375,\n y: 0.078125,\n },\n {\n x: 0.859375,\n y: 0.078125,\n },\n {\n x: 0.890625,\n y: 0.078125,\n },\n {\n x: 0.890625,\n y: 0.078125,\n },\n {\n x: 0.921875,\n y: 0.078125,\n },\n {\n x: 0.921875,\n y: 0.078125,\n },\n {\n x: 0.953125,\n y: 0.078125,\n },\n {\n x: 0.953125,\n y: 0.078125,\n },\n {\n x: 0.984375,\n y: 0.078125,\n },\n {\n x: 0.984375,\n y: 0.078125,\n },\n {\n x: 0.015625,\n y: 0.109375,\n },\n {\n x: 0.015625,\n y: 0.109375,\n },\n {\n x: 0.046875,\n y: 0.109375,\n },\n {\n x: 0.046875,\n y: 0.109375,\n },\n {\n x: 0.078125,\n y: 0.109375,\n },\n {\n x: 0.078125,\n y: 0.109375,\n },\n {\n x: 0.109375,\n y: 0.109375,\n },\n {\n x: 0.109375,\n y: 0.109375,\n },\n {\n x: 0.140625,\n y: 0.109375,\n },\n {\n x: 0.140625,\n y: 0.109375,\n },\n {\n x: 0.171875,\n y: 0.109375,\n },\n {\n x: 0.171875,\n y: 0.109375,\n },\n {\n x: 0.203125,\n y: 0.109375,\n },\n {\n x: 0.203125,\n y: 0.109375,\n },\n {\n x: 0.234375,\n y: 0.109375,\n },\n {\n x: 0.234375,\n y: 0.109375,\n },\n {\n x: 0.265625,\n y: 0.109375,\n },\n {\n x: 0.265625,\n y: 0.109375,\n },\n {\n x: 0.296875,\n y: 0.109375,\n },\n {\n x: 0.296875,\n y: 0.109375,\n },\n {\n x: 0.328125,\n y: 0.109375,\n },\n {\n x: 0.328125,\n y: 0.109375,\n },\n {\n x: 0.359375,\n y: 0.109375,\n },\n {\n x: 0.359375,\n y: 0.109375,\n },\n {\n x: 0.390625,\n y: 0.109375,\n },\n {\n x: 0.390625,\n y: 0.109375,\n },\n {\n x: 0.421875,\n y: 0.109375,\n },\n {\n x: 0.421875,\n y: 0.109375,\n },\n {\n x: 0.453125,\n y: 0.109375,\n },\n {\n x: 0.453125,\n y: 0.109375,\n },\n {\n x: 0.484375,\n y: 0.109375,\n },\n {\n x: 0.484375,\n y: 0.109375,\n },\n {\n x: 0.515625,\n y: 0.109375,\n },\n {\n x: 0.515625,\n y: 0.109375,\n },\n {\n x: 0.546875,\n y: 0.109375,\n },\n {\n x: 0.546875,\n y: 0.109375,\n },\n {\n x: 0.578125,\n y: 0.109375,\n },\n {\n x: 0.578125,\n y: 0.109375,\n },\n {\n x: 0.609375,\n y: 0.109375,\n },\n {\n x: 0.609375,\n y: 0.109375,\n },\n {\n x: 0.640625,\n y: 0.109375,\n },\n {\n x: 0.640625,\n y: 0.109375,\n },\n {\n x: 0.671875,\n y: 0.109375,\n },\n {\n x: 0.671875,\n y: 0.109375,\n },\n {\n x: 0.703125,\n y: 0.109375,\n },\n {\n x: 0.703125,\n y: 0.109375,\n },\n {\n x: 0.734375,\n y: 0.109375,\n },\n {\n x: 0.734375,\n y: 0.109375,\n },\n {\n x: 0.765625,\n y: 0.109375,\n },\n {\n x: 0.765625,\n y: 0.109375,\n },\n {\n x: 0.796875,\n y: 0.109375,\n },\n {\n x: 0.796875,\n y: 0.109375,\n },\n {\n x: 0.828125,\n y: 0.109375,\n },\n {\n x: 0.828125,\n y: 0.109375,\n },\n {\n x: 0.859375,\n y: 0.109375,\n },\n {\n x: 0.859375,\n y: 0.109375,\n },\n {\n x: 0.890625,\n y: 0.109375,\n },\n {\n x: 0.890625,\n y: 0.109375,\n },\n {\n x: 0.921875,\n y: 0.109375,\n },\n {\n x: 0.921875,\n y: 0.109375,\n },\n {\n x: 0.953125,\n y: 0.109375,\n },\n {\n x: 0.953125,\n y: 0.109375,\n },\n {\n x: 0.984375,\n y: 0.109375,\n },\n {\n x: 0.984375,\n y: 0.109375,\n },\n {\n x: 0.015625,\n y: 0.140625,\n },\n {\n x: 0.015625,\n y: 0.140625,\n },\n {\n x: 0.046875,\n y: 0.140625,\n },\n {\n x: 0.046875,\n y: 0.140625,\n },\n {\n x: 0.078125,\n y: 0.140625,\n },\n {\n x: 0.078125,\n y: 0.140625,\n },\n {\n x: 0.109375,\n y: 0.140625,\n },\n {\n x: 0.109375,\n y: 0.140625,\n },\n {\n x: 0.140625,\n y: 0.140625,\n },\n {\n x: 0.140625,\n y: 0.140625,\n },\n {\n x: 0.171875,\n y: 0.140625,\n },\n {\n x: 0.171875,\n y: 0.140625,\n },\n {\n x: 0.203125,\n y: 0.140625,\n },\n {\n x: 0.203125,\n y: 0.140625,\n },\n {\n x: 0.234375,\n y: 0.140625,\n },\n {\n x: 0.234375,\n y: 0.140625,\n },\n {\n x: 0.265625,\n y: 0.140625,\n },\n {\n x: 0.265625,\n y: 0.140625,\n },\n {\n x: 0.296875,\n y: 0.140625,\n },\n {\n x: 0.296875,\n y: 0.140625,\n },\n {\n x: 0.328125,\n y: 0.140625,\n },\n {\n x: 0.328125,\n y: 0.140625,\n },\n {\n x: 0.359375,\n y: 0.140625,\n },\n {\n x: 0.359375,\n y: 0.140625,\n },\n {\n x: 0.390625,\n y: 0.140625,\n },\n {\n x: 0.390625,\n y: 0.140625,\n },\n {\n x: 0.421875,\n y: 0.140625,\n },\n {\n x: 0.421875,\n y: 0.140625,\n },\n {\n x: 0.453125,\n y: 0.140625,\n },\n {\n x: 0.453125,\n y: 0.140625,\n },\n {\n x: 0.484375,\n y: 0.140625,\n },\n {\n x: 0.484375,\n y: 0.140625,\n },\n {\n x: 0.515625,\n y: 0.140625,\n },\n {\n x: 0.515625,\n y: 0.140625,\n },\n {\n x: 0.546875,\n y: 0.140625,\n },\n {\n x: 0.546875,\n y: 0.140625,\n },\n {\n x: 0.578125,\n y: 0.140625,\n },\n {\n x: 0.578125,\n y: 0.140625,\n },\n {\n x: 0.609375,\n y: 0.140625,\n },\n {\n x: 0.609375,\n y: 0.140625,\n },\n {\n x: 0.640625,\n y: 0.140625,\n },\n {\n x: 0.640625,\n y: 0.140625,\n },\n {\n x: 0.671875,\n y: 0.140625,\n },\n {\n x: 0.671875,\n y: 0.140625,\n },\n {\n x: 0.703125,\n y: 0.140625,\n },\n {\n x: 0.703125,\n y: 0.140625,\n },\n {\n x: 0.734375,\n y: 0.140625,\n },\n {\n x: 0.734375,\n y: 0.140625,\n },\n {\n x: 0.765625,\n y: 0.140625,\n },\n {\n x: 0.765625,\n y: 0.140625,\n },\n {\n x: 0.796875,\n y: 0.140625,\n },\n {\n x: 0.796875,\n y: 0.140625,\n },\n {\n x: 0.828125,\n y: 0.140625,\n },\n {\n x: 0.828125,\n y: 0.140625,\n },\n {\n x: 0.859375,\n y: 0.140625,\n },\n {\n x: 0.859375,\n y: 0.140625,\n },\n {\n x: 0.890625,\n y: 0.140625,\n },\n {\n x: 0.890625,\n y: 0.140625,\n },\n {\n x: 0.921875,\n y: 0.140625,\n },\n {\n x: 0.921875,\n y: 0.140625,\n },\n {\n x: 0.953125,\n y: 0.140625,\n },\n {\n x: 0.953125,\n y: 0.140625,\n },\n {\n x: 0.984375,\n y: 0.140625,\n },\n {\n x: 0.984375,\n y: 0.140625,\n },\n {\n x: 0.015625,\n y: 0.171875,\n },\n {\n x: 0.015625,\n y: 0.171875,\n },\n {\n x: 0.046875,\n y: 0.171875,\n },\n {\n x: 0.046875,\n y: 0.171875,\n },\n {\n x: 0.078125,\n y: 0.171875,\n },\n {\n x: 0.078125,\n y: 0.171875,\n },\n {\n x: 0.109375,\n y: 0.171875,\n },\n {\n x: 0.109375,\n y: 0.171875,\n },\n {\n x: 0.140625,\n y: 0.171875,\n },\n {\n x: 0.140625,\n y: 0.171875,\n },\n {\n x: 0.171875,\n y: 0.171875,\n },\n {\n x: 0.171875,\n y: 0.171875,\n },\n {\n x: 0.203125,\n y: 0.171875,\n },\n {\n x: 0.203125,\n y: 0.171875,\n },\n {\n x: 0.234375,\n y: 0.171875,\n },\n {\n x: 0.234375,\n y: 0.171875,\n },\n {\n x: 0.265625,\n y: 0.171875,\n },\n {\n x: 0.265625,\n y: 0.171875,\n },\n {\n x: 0.296875,\n y: 0.171875,\n },\n {\n x: 0.296875,\n y: 0.171875,\n },\n {\n x: 0.328125,\n y: 0.171875,\n },\n {\n x: 0.328125,\n y: 0.171875,\n },\n {\n x: 0.359375,\n y: 0.171875,\n },\n {\n x: 0.359375,\n y: 0.171875,\n },\n {\n x: 0.390625,\n y: 0.171875,\n },\n {\n x: 0.390625,\n y: 0.171875,\n },\n {\n x: 0.421875,\n y: 0.171875,\n },\n {\n x: 0.421875,\n y: 0.171875,\n },\n {\n x: 0.453125,\n y: 0.171875,\n },\n {\n x: 0.453125,\n y: 0.171875,\n },\n {\n x: 0.484375,\n y: 0.171875,\n },\n {\n x: 0.484375,\n y: 0.171875,\n },\n {\n x: 0.515625,\n y: 0.171875,\n },\n {\n x: 0.515625,\n y: 0.171875,\n },\n {\n x: 0.546875,\n y: 0.171875,\n },\n {\n x: 0.546875,\n y: 0.171875,\n },\n {\n x: 0.578125,\n y: 0.171875,\n },\n {\n x: 0.578125,\n y: 0.171875,\n },\n {\n x: 0.609375,\n y: 0.171875,\n },\n {\n x: 0.609375,\n y: 0.171875,\n },\n {\n x: 0.640625,\n y: 0.171875,\n },\n {\n x: 0.640625,\n y: 0.171875,\n },\n {\n x: 0.671875,\n y: 0.171875,\n },\n {\n x: 0.671875,\n y: 0.171875,\n },\n {\n x: 0.703125,\n y: 0.171875,\n },\n {\n x: 0.703125,\n y: 0.171875,\n },\n {\n x: 0.734375,\n y: 0.171875,\n },\n {\n x: 0.734375,\n y: 0.171875,\n },\n {\n x: 0.765625,\n y: 0.171875,\n },\n {\n x: 0.765625,\n y: 0.171875,\n },\n {\n x: 0.796875,\n y: 0.171875,\n },\n {\n x: 0.796875,\n y: 0.171875,\n },\n {\n x: 0.828125,\n y: 0.171875,\n },\n {\n x: 0.828125,\n y: 0.171875,\n },\n {\n x: 0.859375,\n y: 0.171875,\n },\n {\n x: 0.859375,\n y: 0.171875,\n },\n {\n x: 0.890625,\n y: 0.171875,\n },\n {\n x: 0.890625,\n y: 0.171875,\n },\n {\n x: 0.921875,\n y: 0.171875,\n },\n {\n x: 0.921875,\n y: 0.171875,\n },\n {\n x: 0.953125,\n y: 0.171875,\n },\n {\n x: 0.953125,\n y: 0.171875,\n },\n {\n x: 0.984375,\n y: 0.171875,\n },\n {\n x: 0.984375,\n y: 0.171875,\n },\n {\n x: 0.015625,\n y: 0.203125,\n },\n {\n x: 0.015625,\n y: 0.203125,\n },\n {\n x: 0.046875,\n y: 0.203125,\n },\n {\n x: 0.046875,\n y: 0.203125,\n },\n {\n x: 0.078125,\n y: 0.203125,\n },\n {\n x: 0.078125,\n y: 0.203125,\n },\n {\n x: 0.109375,\n y: 0.203125,\n },\n {\n x: 0.109375,\n y: 0.203125,\n },\n {\n x: 0.140625,\n y: 0.203125,\n },\n {\n x: 0.140625,\n y: 0.203125,\n },\n {\n x: 0.171875,\n y: 0.203125,\n },\n {\n x: 0.171875,\n y: 0.203125,\n },\n {\n x: 0.203125,\n y: 0.203125,\n },\n {\n x: 0.203125,\n y: 0.203125,\n },\n {\n x: 0.234375,\n y: 0.203125,\n },\n {\n x: 0.234375,\n y: 0.203125,\n },\n {\n x: 0.265625,\n y: 0.203125,\n },\n {\n x: 0.265625,\n y: 0.203125,\n },\n {\n x: 0.296875,\n y: 0.203125,\n },\n {\n x: 0.296875,\n y: 0.203125,\n },\n {\n x: 0.328125,\n y: 0.203125,\n },\n {\n x: 0.328125,\n y: 0.203125,\n },\n {\n x: 0.359375,\n y: 0.203125,\n },\n {\n x: 0.359375,\n y: 0.203125,\n },\n {\n x: 0.390625,\n y: 0.203125,\n },\n {\n x: 0.390625,\n y: 0.203125,\n },\n {\n x: 0.421875,\n y: 0.203125,\n },\n {\n x: 0.421875,\n y: 0.203125,\n },\n {\n x: 0.453125,\n y: 0.203125,\n },\n {\n x: 0.453125,\n y: 0.203125,\n },\n {\n x: 0.484375,\n y: 0.203125,\n },\n {\n x: 0.484375,\n y: 0.203125,\n },\n {\n x: 0.515625,\n y: 0.203125,\n },\n {\n x: 0.515625,\n y: 0.203125,\n },\n {\n x: 0.546875,\n y: 0.203125,\n },\n {\n x: 0.546875,\n y: 0.203125,\n },\n {\n x: 0.578125,\n y: 0.203125,\n },\n {\n x: 0.578125,\n y: 0.203125,\n },\n {\n x: 0.609375,\n y: 0.203125,\n },\n {\n x: 0.609375,\n y: 0.203125,\n },\n {\n x: 0.640625,\n y: 0.203125,\n },\n {\n x: 0.640625,\n y: 0.203125,\n },\n {\n x: 0.671875,\n y: 0.203125,\n },\n {\n x: 0.671875,\n y: 0.203125,\n },\n {\n x: 0.703125,\n y: 0.203125,\n },\n {\n x: 0.703125,\n y: 0.203125,\n },\n {\n x: 0.734375,\n y: 0.203125,\n },\n {\n x: 0.734375,\n y: 0.203125,\n },\n {\n x: 0.765625,\n y: 0.203125,\n },\n {\n x: 0.765625,\n y: 0.203125,\n },\n {\n x: 0.796875,\n y: 0.203125,\n },\n {\n x: 0.796875,\n y: 0.203125,\n },\n {\n x: 0.828125,\n y: 0.203125,\n },\n {\n x: 0.828125,\n y: 0.203125,\n },\n {\n x: 0.859375,\n y: 0.203125,\n },\n {\n x: 0.859375,\n y: 0.203125,\n },\n {\n x: 0.890625,\n y: 0.203125,\n },\n {\n x: 0.890625,\n y: 0.203125,\n },\n {\n x: 0.921875,\n y: 0.203125,\n },\n {\n x: 0.921875,\n y: 0.203125,\n },\n {\n x: 0.953125,\n y: 0.203125,\n },\n {\n x: 0.953125,\n y: 0.203125,\n },\n {\n x: 0.984375,\n y: 0.203125,\n },\n {\n x: 0.984375,\n y: 0.203125,\n },\n {\n x: 0.015625,\n y: 0.234375,\n },\n {\n x: 0.015625,\n y: 0.234375,\n },\n {\n x: 0.046875,\n y: 0.234375,\n },\n {\n x: 0.046875,\n y: 0.234375,\n },\n {\n x: 0.078125,\n y: 0.234375,\n },\n {\n x: 0.078125,\n y: 0.234375,\n },\n {\n x: 0.109375,\n y: 0.234375,\n },\n {\n x: 0.109375,\n y: 0.234375,\n },\n {\n x: 0.140625,\n y: 0.234375,\n },\n {\n x: 0.140625,\n y: 0.234375,\n },\n {\n x: 0.171875,\n y: 0.234375,\n },\n {\n x: 0.171875,\n y: 0.234375,\n },\n {\n x: 0.203125,\n y: 0.234375,\n },\n {\n x: 0.203125,\n y: 0.234375,\n },\n {\n x: 0.234375,\n y: 0.234375,\n },\n {\n x: 0.234375,\n y: 0.234375,\n },\n {\n x: 0.265625,\n y: 0.234375,\n },\n {\n x: 0.265625,\n y: 0.234375,\n },\n {\n x: 0.296875,\n y: 0.234375,\n },\n {\n x: 0.296875,\n y: 0.234375,\n },\n {\n x: 0.328125,\n y: 0.234375,\n },\n {\n x: 0.328125,\n y: 0.234375,\n },\n {\n x: 0.359375,\n y: 0.234375,\n },\n {\n x: 0.359375,\n y: 0.234375,\n },\n {\n x: 0.390625,\n y: 0.234375,\n },\n {\n x: 0.390625,\n y: 0.234375,\n },\n {\n x: 0.421875,\n y: 0.234375,\n },\n {\n x: 0.421875,\n y: 0.234375,\n },\n {\n x: 0.453125,\n y: 0.234375,\n },\n {\n x: 0.453125,\n y: 0.234375,\n },\n {\n x: 0.484375,\n y: 0.234375,\n },\n {\n x: 0.484375,\n y: 0.234375,\n },\n {\n x: 0.515625,\n y: 0.234375,\n },\n {\n x: 0.515625,\n y: 0.234375,\n },\n {\n x: 0.546875,\n y: 0.234375,\n },\n {\n x: 0.546875,\n y: 0.234375,\n },\n {\n x: 0.578125,\n y: 0.234375,\n },\n {\n x: 0.578125,\n y: 0.234375,\n },\n {\n x: 0.609375,\n y: 0.234375,\n },\n {\n x: 0.609375,\n y: 0.234375,\n },\n {\n x: 0.640625,\n y: 0.234375,\n },\n {\n x: 0.640625,\n y: 0.234375,\n },\n {\n x: 0.671875,\n y: 0.234375,\n },\n {\n x: 0.671875,\n y: 0.234375,\n },\n {\n x: 0.703125,\n y: 0.234375,\n },\n {\n x: 0.703125,\n y: 0.234375,\n },\n {\n x: 0.734375,\n y: 0.234375,\n },\n {\n x: 0.734375,\n y: 0.234375,\n },\n {\n x: 0.765625,\n y: 0.234375,\n },\n {\n x: 0.765625,\n y: 0.234375,\n },\n {\n x: 0.796875,\n y: 0.234375,\n },\n {\n x: 0.796875,\n y: 0.234375,\n },\n {\n x: 0.828125,\n y: 0.234375,\n },\n {\n x: 0.828125,\n y: 0.234375,\n },\n {\n x: 0.859375,\n y: 0.234375,\n },\n {\n x: 0.859375,\n y: 0.234375,\n },\n {\n x: 0.890625,\n y: 0.234375,\n },\n {\n x: 0.890625,\n y: 0.234375,\n },\n {\n x: 0.921875,\n y: 0.234375,\n },\n {\n x: 0.921875,\n y: 0.234375,\n },\n {\n x: 0.953125,\n y: 0.234375,\n },\n {\n x: 0.953125,\n y: 0.234375,\n },\n {\n x: 0.984375,\n y: 0.234375,\n },\n {\n x: 0.984375,\n y: 0.234375,\n },\n {\n x: 0.015625,\n y: 0.265625,\n },\n {\n x: 0.015625,\n y: 0.265625,\n },\n {\n x: 0.046875,\n y: 0.265625,\n },\n {\n x: 0.046875,\n y: 0.265625,\n },\n {\n x: 0.078125,\n y: 0.265625,\n },\n {\n x: 0.078125,\n y: 0.265625,\n },\n {\n x: 0.109375,\n y: 0.265625,\n },\n {\n x: 0.109375,\n y: 0.265625,\n },\n {\n x: 0.140625,\n y: 0.265625,\n },\n {\n x: 0.140625,\n y: 0.265625,\n },\n {\n x: 0.171875,\n y: 0.265625,\n },\n {\n x: 0.171875,\n y: 0.265625,\n },\n {\n x: 0.203125,\n y: 0.265625,\n },\n {\n x: 0.203125,\n y: 0.265625,\n },\n {\n x: 0.234375,\n y: 0.265625,\n },\n {\n x: 0.234375,\n y: 0.265625,\n },\n {\n x: 0.265625,\n y: 0.265625,\n },\n {\n x: 0.265625,\n y: 0.265625,\n },\n {\n x: 0.296875,\n y: 0.265625,\n },\n {\n x: 0.296875,\n y: 0.265625,\n },\n {\n x: 0.328125,\n y: 0.265625,\n },\n {\n x: 0.328125,\n y: 0.265625,\n },\n {\n x: 0.359375,\n y: 0.265625,\n },\n {\n x: 0.359375,\n y: 0.265625,\n },\n {\n x: 0.390625,\n y: 0.265625,\n },\n {\n x: 0.390625,\n y: 0.265625,\n },\n {\n x: 0.421875,\n y: 0.265625,\n },\n {\n x: 0.421875,\n y: 0.265625,\n },\n {\n x: 0.453125,\n y: 0.265625,\n },\n {\n x: 0.453125,\n y: 0.265625,\n },\n {\n x: 0.484375,\n y: 0.265625,\n },\n {\n x: 0.484375,\n y: 0.265625,\n },\n {\n x: 0.515625,\n y: 0.265625,\n },\n {\n x: 0.515625,\n y: 0.265625,\n },\n {\n x: 0.546875,\n y: 0.265625,\n },\n {\n x: 0.546875,\n y: 0.265625,\n },\n {\n x: 0.578125,\n y: 0.265625,\n },\n {\n x: 0.578125,\n y: 0.265625,\n },\n {\n x: 0.609375,\n y: 0.265625,\n },\n {\n x: 0.609375,\n y: 0.265625,\n },\n {\n x: 0.640625,\n y: 0.265625,\n },\n {\n x: 0.640625,\n y: 0.265625,\n },\n {\n x: 0.671875,\n y: 0.265625,\n },\n {\n x: 0.671875,\n y: 0.265625,\n },\n {\n x: 0.703125,\n y: 0.265625,\n },\n {\n x: 0.703125,\n y: 0.265625,\n },\n {\n x: 0.734375,\n y: 0.265625,\n },\n {\n x: 0.734375,\n y: 0.265625,\n },\n {\n x: 0.765625,\n y: 0.265625,\n },\n {\n x: 0.765625,\n y: 0.265625,\n },\n {\n x: 0.796875,\n y: 0.265625,\n },\n {\n x: 0.796875,\n y: 0.265625,\n },\n {\n x: 0.828125,\n y: 0.265625,\n },\n {\n x: 0.828125,\n y: 0.265625,\n },\n {\n x: 0.859375,\n y: 0.265625,\n },\n {\n x: 0.859375,\n y: 0.265625,\n },\n {\n x: 0.890625,\n y: 0.265625,\n },\n {\n x: 0.890625,\n y: 0.265625,\n },\n {\n x: 0.921875,\n y: 0.265625,\n },\n {\n x: 0.921875,\n y: 0.265625,\n },\n {\n x: 0.953125,\n y: 0.265625,\n },\n {\n x: 0.953125,\n y: 0.265625,\n },\n {\n x: 0.984375,\n y: 0.265625,\n },\n {\n x: 0.984375,\n y: 0.265625,\n },\n {\n x: 0.015625,\n y: 0.296875,\n },\n {\n x: 0.015625,\n y: 0.296875,\n },\n {\n x: 0.046875,\n y: 0.296875,\n },\n {\n x: 0.046875,\n y: 0.296875,\n },\n {\n x: 0.078125,\n y: 0.296875,\n },\n {\n x: 0.078125,\n y: 0.296875,\n },\n {\n x: 0.109375,\n y: 0.296875,\n },\n {\n x: 0.109375,\n y: 0.296875,\n },\n {\n x: 0.140625,\n y: 0.296875,\n },\n {\n x: 0.140625,\n y: 0.296875,\n },\n {\n x: 0.171875,\n y: 0.296875,\n },\n {\n x: 0.171875,\n y: 0.296875,\n },\n {\n x: 0.203125,\n y: 0.296875,\n },\n {\n x: 0.203125,\n y: 0.296875,\n },\n {\n x: 0.234375,\n y: 0.296875,\n },\n {\n x: 0.234375,\n y: 0.296875,\n },\n {\n x: 0.265625,\n y: 0.296875,\n },\n {\n x: 0.265625,\n y: 0.296875,\n },\n {\n x: 0.296875,\n y: 0.296875,\n },\n {\n x: 0.296875,\n y: 0.296875,\n },\n {\n x: 0.328125,\n y: 0.296875,\n },\n {\n x: 0.328125,\n y: 0.296875,\n },\n {\n x: 0.359375,\n y: 0.296875,\n },\n {\n x: 0.359375,\n y: 0.296875,\n },\n {\n x: 0.390625,\n y: 0.296875,\n },\n {\n x: 0.390625,\n y: 0.296875,\n },\n {\n x: 0.421875,\n y: 0.296875,\n },\n {\n x: 0.421875,\n y: 0.296875,\n },\n {\n x: 0.453125,\n y: 0.296875,\n },\n {\n x: 0.453125,\n y: 0.296875,\n },\n {\n x: 0.484375,\n y: 0.296875,\n },\n {\n x: 0.484375,\n y: 0.296875,\n },\n {\n x: 0.515625,\n y: 0.296875,\n },\n {\n x: 0.515625,\n y: 0.296875,\n },\n {\n x: 0.546875,\n y: 0.296875,\n },\n {\n x: 0.546875,\n y: 0.296875,\n },\n {\n x: 0.578125,\n y: 0.296875,\n },\n {\n x: 0.578125,\n y: 0.296875,\n },\n {\n x: 0.609375,\n y: 0.296875,\n },\n {\n x: 0.609375,\n y: 0.296875,\n },\n {\n x: 0.640625,\n y: 0.296875,\n },\n {\n x: 0.640625,\n y: 0.296875,\n },\n {\n x: 0.671875,\n y: 0.296875,\n },\n {\n x: 0.671875,\n y: 0.296875,\n },\n {\n x: 0.703125,\n y: 0.296875,\n },\n {\n x: 0.703125,\n y: 0.296875,\n },\n {\n x: 0.734375,\n y: 0.296875,\n },\n {\n x: 0.734375,\n y: 0.296875,\n },\n {\n x: 0.765625,\n y: 0.296875,\n },\n {\n x: 0.765625,\n y: 0.296875,\n },\n {\n x: 0.796875,\n y: 0.296875,\n },\n {\n x: 0.796875,\n y: 0.296875,\n },\n {\n x: 0.828125,\n y: 0.296875,\n },\n {\n x: 0.828125,\n y: 0.296875,\n },\n {\n x: 0.859375,\n y: 0.296875,\n },\n {\n x: 0.859375,\n y: 0.296875,\n },\n {\n x: 0.890625,\n y: 0.296875,\n },\n {\n x: 0.890625,\n y: 0.296875,\n },\n {\n x: 0.921875,\n y: 0.296875,\n },\n {\n x: 0.921875,\n y: 0.296875,\n },\n {\n x: 0.953125,\n y: 0.296875,\n },\n {\n x: 0.953125,\n y: 0.296875,\n },\n {\n x: 0.984375,\n y: 0.296875,\n },\n {\n x: 0.984375,\n y: 0.296875,\n },\n {\n x: 0.015625,\n y: 0.328125,\n },\n {\n x: 0.015625,\n y: 0.328125,\n },\n {\n x: 0.046875,\n y: 0.328125,\n },\n {\n x: 0.046875,\n y: 0.328125,\n },\n {\n x: 0.078125,\n y: 0.328125,\n },\n {\n x: 0.078125,\n y: 0.328125,\n },\n {\n x: 0.109375,\n y: 0.328125,\n },\n {\n x: 0.109375,\n y: 0.328125,\n },\n {\n x: 0.140625,\n y: 0.328125,\n },\n {\n x: 0.140625,\n y: 0.328125,\n },\n {\n x: 0.171875,\n y: 0.328125,\n },\n {\n x: 0.171875,\n y: 0.328125,\n },\n {\n x: 0.203125,\n y: 0.328125,\n },\n {\n x: 0.203125,\n y: 0.328125,\n },\n {\n x: 0.234375,\n y: 0.328125,\n },\n {\n x: 0.234375,\n y: 0.328125,\n },\n {\n x: 0.265625,\n y: 0.328125,\n },\n {\n x: 0.265625,\n y: 0.328125,\n },\n {\n x: 0.296875,\n y: 0.328125,\n },\n {\n x: 0.296875,\n y: 0.328125,\n },\n {\n x: 0.328125,\n y: 0.328125,\n },\n {\n x: 0.328125,\n y: 0.328125,\n },\n {\n x: 0.359375,\n y: 0.328125,\n },\n {\n x: 0.359375,\n y: 0.328125,\n },\n {\n x: 0.390625,\n y: 0.328125,\n },\n {\n x: 0.390625,\n y: 0.328125,\n },\n {\n x: 0.421875,\n y: 0.328125,\n },\n {\n x: 0.421875,\n y: 0.328125,\n },\n {\n x: 0.453125,\n y: 0.328125,\n },\n {\n x: 0.453125,\n y: 0.328125,\n },\n {\n x: 0.484375,\n y: 0.328125,\n },\n {\n x: 0.484375,\n y: 0.328125,\n },\n {\n x: 0.515625,\n y: 0.328125,\n },\n {\n x: 0.515625,\n y: 0.328125,\n },\n {\n x: 0.546875,\n y: 0.328125,\n },\n {\n x: 0.546875,\n y: 0.328125,\n },\n {\n x: 0.578125,\n y: 0.328125,\n },\n {\n x: 0.578125,\n y: 0.328125,\n },\n {\n x: 0.609375,\n y: 0.328125,\n },\n {\n x: 0.609375,\n y: 0.328125,\n },\n {\n x: 0.640625,\n y: 0.328125,\n },\n {\n x: 0.640625,\n y: 0.328125,\n },\n {\n x: 0.671875,\n y: 0.328125,\n },\n {\n x: 0.671875,\n y: 0.328125,\n },\n {\n x: 0.703125,\n y: 0.328125,\n },\n {\n x: 0.703125,\n y: 0.328125,\n },\n {\n x: 0.734375,\n y: 0.328125,\n },\n {\n x: 0.734375,\n y: 0.328125,\n },\n {\n x: 0.765625,\n y: 0.328125,\n },\n {\n x: 0.765625,\n y: 0.328125,\n },\n {\n x: 0.796875,\n y: 0.328125,\n },\n {\n x: 0.796875,\n y: 0.328125,\n },\n {\n x: 0.828125,\n y: 0.328125,\n },\n {\n x: 0.828125,\n y: 0.328125,\n },\n {\n x: 0.859375,\n y: 0.328125,\n },\n {\n x: 0.859375,\n y: 0.328125,\n },\n {\n x: 0.890625,\n y: 0.328125,\n },\n {\n x: 0.890625,\n y: 0.328125,\n },\n {\n x: 0.921875,\n y: 0.328125,\n },\n {\n x: 0.921875,\n y: 0.328125,\n },\n {\n x: 0.953125,\n y: 0.328125,\n },\n {\n x: 0.953125,\n y: 0.328125,\n },\n {\n x: 0.984375,\n y: 0.328125,\n },\n {\n x: 0.984375,\n y: 0.328125,\n },\n {\n x: 0.015625,\n y: 0.359375,\n },\n {\n x: 0.015625,\n y: 0.359375,\n },\n {\n x: 0.046875,\n y: 0.359375,\n },\n {\n x: 0.046875,\n y: 0.359375,\n },\n {\n x: 0.078125,\n y: 0.359375,\n },\n {\n x: 0.078125,\n y: 0.359375,\n },\n {\n x: 0.109375,\n y: 0.359375,\n },\n {\n x: 0.109375,\n y: 0.359375,\n },\n {\n x: 0.140625,\n y: 0.359375,\n },\n {\n x: 0.140625,\n y: 0.359375,\n },\n {\n x: 0.171875,\n y: 0.359375,\n },\n {\n x: 0.171875,\n y: 0.359375,\n },\n {\n x: 0.203125,\n y: 0.359375,\n },\n {\n x: 0.203125,\n y: 0.359375,\n },\n {\n x: 0.234375,\n y: 0.359375,\n },\n {\n x: 0.234375,\n y: 0.359375,\n },\n {\n x: 0.265625,\n y: 0.359375,\n },\n {\n x: 0.265625,\n y: 0.359375,\n },\n {\n x: 0.296875,\n y: 0.359375,\n },\n {\n x: 0.296875,\n y: 0.359375,\n },\n {\n x: 0.328125,\n y: 0.359375,\n },\n {\n x: 0.328125,\n y: 0.359375,\n },\n {\n x: 0.359375,\n y: 0.359375,\n },\n {\n x: 0.359375,\n y: 0.359375,\n },\n {\n x: 0.390625,\n y: 0.359375,\n },\n {\n x: 0.390625,\n y: 0.359375,\n },\n {\n x: 0.421875,\n y: 0.359375,\n },\n {\n x: 0.421875,\n y: 0.359375,\n },\n {\n x: 0.453125,\n y: 0.359375,\n },\n {\n x: 0.453125,\n y: 0.359375,\n },\n {\n x: 0.484375,\n y: 0.359375,\n },\n {\n x: 0.484375,\n y: 0.359375,\n },\n {\n x: 0.515625,\n y: 0.359375,\n },\n {\n x: 0.515625,\n y: 0.359375,\n },\n {\n x: 0.546875,\n y: 0.359375,\n },\n {\n x: 0.546875,\n y: 0.359375,\n },\n {\n x: 0.578125,\n y: 0.359375,\n },\n {\n x: 0.578125,\n y: 0.359375,\n },\n {\n x: 0.609375,\n y: 0.359375,\n },\n {\n x: 0.609375,\n y: 0.359375,\n },\n {\n x: 0.640625,\n y: 0.359375,\n },\n {\n x: 0.640625,\n y: 0.359375,\n },\n {\n x: 0.671875,\n y: 0.359375,\n },\n {\n x: 0.671875,\n y: 0.359375,\n },\n {\n x: 0.703125,\n y: 0.359375,\n },\n {\n x: 0.703125,\n y: 0.359375,\n },\n {\n x: 0.734375,\n y: 0.359375,\n },\n {\n x: 0.734375,\n y: 0.359375,\n },\n {\n x: 0.765625,\n y: 0.359375,\n },\n {\n x: 0.765625,\n y: 0.359375,\n },\n {\n x: 0.796875,\n y: 0.359375,\n },\n {\n x: 0.796875,\n y: 0.359375,\n },\n {\n x: 0.828125,\n y: 0.359375,\n },\n {\n x: 0.828125,\n y: 0.359375,\n },\n {\n x: 0.859375,\n y: 0.359375,\n },\n {\n x: 0.859375,\n y: 0.359375,\n },\n {\n x: 0.890625,\n y: 0.359375,\n },\n {\n x: 0.890625,\n y: 0.359375,\n },\n {\n x: 0.921875,\n y: 0.359375,\n },\n {\n x: 0.921875,\n y: 0.359375,\n },\n {\n x: 0.953125,\n y: 0.359375,\n },\n {\n x: 0.953125,\n y: 0.359375,\n },\n {\n x: 0.984375,\n y: 0.359375,\n },\n {\n x: 0.984375,\n y: 0.359375,\n },\n {\n x: 0.015625,\n y: 0.390625,\n },\n {\n x: 0.015625,\n y: 0.390625,\n },\n {\n x: 0.046875,\n y: 0.390625,\n },\n {\n x: 0.046875,\n y: 0.390625,\n },\n {\n x: 0.078125,\n y: 0.390625,\n },\n {\n x: 0.078125,\n y: 0.390625,\n },\n {\n x: 0.109375,\n y: 0.390625,\n },\n {\n x: 0.109375,\n y: 0.390625,\n },\n {\n x: 0.140625,\n y: 0.390625,\n },\n {\n x: 0.140625,\n y: 0.390625,\n },\n {\n x: 0.171875,\n y: 0.390625,\n },\n {\n x: 0.171875,\n y: 0.390625,\n },\n {\n x: 0.203125,\n y: 0.390625,\n },\n {\n x: 0.203125,\n y: 0.390625,\n },\n {\n x: 0.234375,\n y: 0.390625,\n },\n {\n x: 0.234375,\n y: 0.390625,\n },\n {\n x: 0.265625,\n y: 0.390625,\n },\n {\n x: 0.265625,\n y: 0.390625,\n },\n {\n x: 0.296875,\n y: 0.390625,\n },\n {\n x: 0.296875,\n y: 0.390625,\n },\n {\n x: 0.328125,\n y: 0.390625,\n },\n {\n x: 0.328125,\n y: 0.390625,\n },\n {\n x: 0.359375,\n y: 0.390625,\n },\n {\n x: 0.359375,\n y: 0.390625,\n },\n {\n x: 0.390625,\n y: 0.390625,\n },\n {\n x: 0.390625,\n y: 0.390625,\n },\n {\n x: 0.421875,\n y: 0.390625,\n },\n {\n x: 0.421875,\n y: 0.390625,\n },\n {\n x: 0.453125,\n y: 0.390625,\n },\n {\n x: 0.453125,\n y: 0.390625,\n },\n {\n x: 0.484375,\n y: 0.390625,\n },\n {\n x: 0.484375,\n y: 0.390625,\n },\n {\n x: 0.515625,\n y: 0.390625,\n },\n {\n x: 0.515625,\n y: 0.390625,\n },\n {\n x: 0.546875,\n y: 0.390625,\n },\n {\n x: 0.546875,\n y: 0.390625,\n },\n {\n x: 0.578125,\n y: 0.390625,\n },\n {\n x: 0.578125,\n y: 0.390625,\n },\n {\n x: 0.609375,\n y: 0.390625,\n },\n {\n x: 0.609375,\n y: 0.390625,\n },\n {\n x: 0.640625,\n y: 0.390625,\n },\n {\n x: 0.640625,\n y: 0.390625,\n },\n {\n x: 0.671875,\n y: 0.390625,\n },\n {\n x: 0.671875,\n y: 0.390625,\n },\n {\n x: 0.703125,\n y: 0.390625,\n },\n {\n x: 0.703125,\n y: 0.390625,\n },\n {\n x: 0.734375,\n y: 0.390625,\n },\n {\n x: 0.734375,\n y: 0.390625,\n },\n {\n x: 0.765625,\n y: 0.390625,\n },\n {\n x: 0.765625,\n y: 0.390625,\n },\n {\n x: 0.796875,\n y: 0.390625,\n },\n {\n x: 0.796875,\n y: 0.390625,\n },\n {\n x: 0.828125,\n y: 0.390625,\n },\n {\n x: 0.828125,\n y: 0.390625,\n },\n {\n x: 0.859375,\n y: 0.390625,\n },\n {\n x: 0.859375,\n y: 0.390625,\n },\n {\n x: 0.890625,\n y: 0.390625,\n },\n {\n x: 0.890625,\n y: 0.390625,\n },\n {\n x: 0.921875,\n y: 0.390625,\n },\n {\n x: 0.921875,\n y: 0.390625,\n },\n {\n x: 0.953125,\n y: 0.390625,\n },\n {\n x: 0.953125,\n y: 0.390625,\n },\n {\n x: 0.984375,\n y: 0.390625,\n },\n {\n x: 0.984375,\n y: 0.390625,\n },\n {\n x: 0.015625,\n y: 0.421875,\n },\n {\n x: 0.015625,\n y: 0.421875,\n },\n {\n x: 0.046875,\n y: 0.421875,\n },\n {\n x: 0.046875,\n y: 0.421875,\n },\n {\n x: 0.078125,\n y: 0.421875,\n },\n {\n x: 0.078125,\n y: 0.421875,\n },\n {\n x: 0.109375,\n y: 0.421875,\n },\n {\n x: 0.109375,\n y: 0.421875,\n },\n {\n x: 0.140625,\n y: 0.421875,\n },\n {\n x: 0.140625,\n y: 0.421875,\n },\n {\n x: 0.171875,\n y: 0.421875,\n },\n {\n x: 0.171875,\n y: 0.421875,\n },\n {\n x: 0.203125,\n y: 0.421875,\n },\n {\n x: 0.203125,\n y: 0.421875,\n },\n {\n x: 0.234375,\n y: 0.421875,\n },\n {\n x: 0.234375,\n y: 0.421875,\n },\n {\n x: 0.265625,\n y: 0.421875,\n },\n {\n x: 0.265625,\n y: 0.421875,\n },\n {\n x: 0.296875,\n y: 0.421875,\n },\n {\n x: 0.296875,\n y: 0.421875,\n },\n {\n x: 0.328125,\n y: 0.421875,\n },\n {\n x: 0.328125,\n y: 0.421875,\n },\n {\n x: 0.359375,\n y: 0.421875,\n },\n {\n x: 0.359375,\n y: 0.421875,\n },\n {\n x: 0.390625,\n y: 0.421875,\n },\n {\n x: 0.390625,\n y: 0.421875,\n },\n {\n x: 0.421875,\n y: 0.421875,\n },\n {\n x: 0.421875,\n y: 0.421875,\n },\n {\n x: 0.453125,\n y: 0.421875,\n },\n {\n x: 0.453125,\n y: 0.421875,\n },\n {\n x: 0.484375,\n y: 0.421875,\n },\n {\n x: 0.484375,\n y: 0.421875,\n },\n {\n x: 0.515625,\n y: 0.421875,\n },\n {\n x: 0.515625,\n y: 0.421875,\n },\n {\n x: 0.546875,\n y: 0.421875,\n },\n {\n x: 0.546875,\n y: 0.421875,\n },\n {\n x: 0.578125,\n y: 0.421875,\n },\n {\n x: 0.578125,\n y: 0.421875,\n },\n {\n x: 0.609375,\n y: 0.421875,\n },\n {\n x: 0.609375,\n y: 0.421875,\n },\n {\n x: 0.640625,\n y: 0.421875,\n },\n {\n x: 0.640625,\n y: 0.421875,\n },\n {\n x: 0.671875,\n y: 0.421875,\n },\n {\n x: 0.671875,\n y: 0.421875,\n },\n {\n x: 0.703125,\n y: 0.421875,\n },\n {\n x: 0.703125,\n y: 0.421875,\n },\n {\n x: 0.734375,\n y: 0.421875,\n },\n {\n x: 0.734375,\n y: 0.421875,\n },\n {\n x: 0.765625,\n y: 0.421875,\n },\n {\n x: 0.765625,\n y: 0.421875,\n },\n {\n x: 0.796875,\n y: 0.421875,\n },\n {\n x: 0.796875,\n y: 0.421875,\n },\n {\n x: 0.828125,\n y: 0.421875,\n },\n {\n x: 0.828125,\n y: 0.421875,\n },\n {\n x: 0.859375,\n y: 0.421875,\n },\n {\n x: 0.859375,\n y: 0.421875,\n },\n {\n x: 0.890625,\n y: 0.421875,\n },\n {\n x: 0.890625,\n y: 0.421875,\n },\n {\n x: 0.921875,\n y: 0.421875,\n },\n {\n x: 0.921875,\n y: 0.421875,\n },\n {\n x: 0.953125,\n y: 0.421875,\n },\n {\n x: 0.953125,\n y: 0.421875,\n },\n {\n x: 0.984375,\n y: 0.421875,\n },\n {\n x: 0.984375,\n y: 0.421875,\n },\n {\n x: 0.015625,\n y: 0.453125,\n },\n {\n x: 0.015625,\n y: 0.453125,\n },\n {\n x: 0.046875,\n y: 0.453125,\n },\n {\n x: 0.046875,\n y: 0.453125,\n },\n {\n x: 0.078125,\n y: 0.453125,\n },\n {\n x: 0.078125,\n y: 0.453125,\n },\n {\n x: 0.109375,\n y: 0.453125,\n },\n {\n x: 0.109375,\n y: 0.453125,\n },\n {\n x: 0.140625,\n y: 0.453125,\n },\n {\n x: 0.140625,\n y: 0.453125,\n },\n {\n x: 0.171875,\n y: 0.453125,\n },\n {\n x: 0.171875,\n y: 0.453125,\n },\n {\n x: 0.203125,\n y: 0.453125,\n },\n {\n x: 0.203125,\n y: 0.453125,\n },\n {\n x: 0.234375,\n y: 0.453125,\n },\n {\n x: 0.234375,\n y: 0.453125,\n },\n {\n x: 0.265625,\n y: 0.453125,\n },\n {\n x: 0.265625,\n y: 0.453125,\n },\n {\n x: 0.296875,\n y: 0.453125,\n },\n {\n x: 0.296875,\n y: 0.453125,\n },\n {\n x: 0.328125,\n y: 0.453125,\n },\n {\n x: 0.328125,\n y: 0.453125,\n },\n {\n x: 0.359375,\n y: 0.453125,\n },\n {\n x: 0.359375,\n y: 0.453125,\n },\n {\n x: 0.390625,\n y: 0.453125,\n },\n {\n x: 0.390625,\n y: 0.453125,\n },\n {\n x: 0.421875,\n y: 0.453125,\n },\n {\n x: 0.421875,\n y: 0.453125,\n },\n {\n x: 0.453125,\n y: 0.453125,\n },\n {\n x: 0.453125,\n y: 0.453125,\n },\n {\n x: 0.484375,\n y: 0.453125,\n },\n {\n x: 0.484375,\n y: 0.453125,\n },\n {\n x: 0.515625,\n y: 0.453125,\n },\n {\n x: 0.515625,\n y: 0.453125,\n },\n {\n x: 0.546875,\n y: 0.453125,\n },\n {\n x: 0.546875,\n y: 0.453125,\n },\n {\n x: 0.578125,\n y: 0.453125,\n },\n {\n x: 0.578125,\n y: 0.453125,\n },\n {\n x: 0.609375,\n y: 0.453125,\n },\n {\n x: 0.609375,\n y: 0.453125,\n },\n {\n x: 0.640625,\n y: 0.453125,\n },\n {\n x: 0.640625,\n y: 0.453125,\n },\n {\n x: 0.671875,\n y: 0.453125,\n },\n {\n x: 0.671875,\n y: 0.453125,\n },\n {\n x: 0.703125,\n y: 0.453125,\n },\n {\n x: 0.703125,\n y: 0.453125,\n },\n {\n x: 0.734375,\n y: 0.453125,\n },\n {\n x: 0.734375,\n y: 0.453125,\n },\n {\n x: 0.765625,\n y: 0.453125,\n },\n {\n x: 0.765625,\n y: 0.453125,\n },\n {\n x: 0.796875,\n y: 0.453125,\n },\n {\n x: 0.796875,\n y: 0.453125,\n },\n {\n x: 0.828125,\n y: 0.453125,\n },\n {\n x: 0.828125,\n y: 0.453125,\n },\n {\n x: 0.859375,\n y: 0.453125,\n },\n {\n x: 0.859375,\n y: 0.453125,\n },\n {\n x: 0.890625,\n y: 0.453125,\n },\n {\n x: 0.890625,\n y: 0.453125,\n },\n {\n x: 0.921875,\n y: 0.453125,\n },\n {\n x: 0.921875,\n y: 0.453125,\n },\n {\n x: 0.953125,\n y: 0.453125,\n },\n {\n x: 0.953125,\n y: 0.453125,\n },\n {\n x: 0.984375,\n y: 0.453125,\n },\n {\n x: 0.984375,\n y: 0.453125,\n },\n {\n x: 0.015625,\n y: 0.484375,\n },\n {\n x: 0.015625,\n y: 0.484375,\n },\n {\n x: 0.046875,\n y: 0.484375,\n },\n {\n x: 0.046875,\n y: 0.484375,\n },\n {\n x: 0.078125,\n y: 0.484375,\n },\n {\n x: 0.078125,\n y: 0.484375,\n },\n {\n x: 0.109375,\n y: 0.484375,\n },\n {\n x: 0.109375,\n y: 0.484375,\n },\n {\n x: 0.140625,\n y: 0.484375,\n },\n {\n x: 0.140625,\n y: 0.484375,\n },\n {\n x: 0.171875,\n y: 0.484375,\n },\n {\n x: 0.171875,\n y: 0.484375,\n },\n {\n x: 0.203125,\n y: 0.484375,\n },\n {\n x: 0.203125,\n y: 0.484375,\n },\n {\n x: 0.234375,\n y: 0.484375,\n },\n {\n x: 0.234375,\n y: 0.484375,\n },\n {\n x: 0.265625,\n y: 0.484375,\n },\n {\n x: 0.265625,\n y: 0.484375,\n },\n {\n x: 0.296875,\n y: 0.484375,\n },\n {\n x: 0.296875,\n y: 0.484375,\n },\n {\n x: 0.328125,\n y: 0.484375,\n },\n {\n x: 0.328125,\n y: 0.484375,\n },\n {\n x: 0.359375,\n y: 0.484375,\n },\n {\n x: 0.359375,\n y: 0.484375,\n },\n {\n x: 0.390625,\n y: 0.484375,\n },\n {\n x: 0.390625,\n y: 0.484375,\n },\n {\n x: 0.421875,\n y: 0.484375,\n },\n {\n x: 0.421875,\n y: 0.484375,\n },\n {\n x: 0.453125,\n y: 0.484375,\n },\n {\n x: 0.453125,\n y: 0.484375,\n },\n {\n x: 0.484375,\n y: 0.484375,\n },\n {\n x: 0.484375,\n y: 0.484375,\n },\n {\n x: 0.515625,\n y: 0.484375,\n },\n {\n x: 0.515625,\n y: 0.484375,\n },\n {\n x: 0.546875,\n y: 0.484375,\n },\n {\n x: 0.546875,\n y: 0.484375,\n },\n {\n x: 0.578125,\n y: 0.484375,\n },\n {\n x: 0.578125,\n y: 0.484375,\n },\n {\n x: 0.609375,\n y: 0.484375,\n },\n {\n x: 0.609375,\n y: 0.484375,\n },\n {\n x: 0.640625,\n y: 0.484375,\n },\n {\n x: 0.640625,\n y: 0.484375,\n },\n {\n x: 0.671875,\n y: 0.484375,\n },\n {\n x: 0.671875,\n y: 0.484375,\n },\n {\n x: 0.703125,\n y: 0.484375,\n },\n {\n x: 0.703125,\n y: 0.484375,\n },\n {\n x: 0.734375,\n y: 0.484375,\n },\n {\n x: 0.734375,\n y: 0.484375,\n },\n {\n x: 0.765625,\n y: 0.484375,\n },\n {\n x: 0.765625,\n y: 0.484375,\n },\n {\n x: 0.796875,\n y: 0.484375,\n },\n {\n x: 0.796875,\n y: 0.484375,\n },\n {\n x: 0.828125,\n y: 0.484375,\n },\n {\n x: 0.828125,\n y: 0.484375,\n },\n {\n x: 0.859375,\n y: 0.484375,\n },\n {\n x: 0.859375,\n y: 0.484375,\n },\n {\n x: 0.890625,\n y: 0.484375,\n },\n {\n x: 0.890625,\n y: 0.484375,\n },\n {\n x: 0.921875,\n y: 0.484375,\n },\n {\n x: 0.921875,\n y: 0.484375,\n },\n {\n x: 0.953125,\n y: 0.484375,\n },\n {\n x: 0.953125,\n y: 0.484375,\n },\n {\n x: 0.984375,\n y: 0.484375,\n },\n {\n x: 0.984375,\n y: 0.484375,\n },\n {\n x: 0.015625,\n y: 0.515625,\n },\n {\n x: 0.015625,\n y: 0.515625,\n },\n {\n x: 0.046875,\n y: 0.515625,\n },\n {\n x: 0.046875,\n y: 0.515625,\n },\n {\n x: 0.078125,\n y: 0.515625,\n },\n {\n x: 0.078125,\n y: 0.515625,\n },\n {\n x: 0.109375,\n y: 0.515625,\n },\n {\n x: 0.109375,\n y: 0.515625,\n },\n {\n x: 0.140625,\n y: 0.515625,\n },\n {\n x: 0.140625,\n y: 0.515625,\n },\n {\n x: 0.171875,\n y: 0.515625,\n },\n {\n x: 0.171875,\n y: 0.515625,\n },\n {\n x: 0.203125,\n y: 0.515625,\n },\n {\n x: 0.203125,\n y: 0.515625,\n },\n {\n x: 0.234375,\n y: 0.515625,\n },\n {\n x: 0.234375,\n y: 0.515625,\n },\n {\n x: 0.265625,\n y: 0.515625,\n },\n {\n x: 0.265625,\n y: 0.515625,\n },\n {\n x: 0.296875,\n y: 0.515625,\n },\n {\n x: 0.296875,\n y: 0.515625,\n },\n {\n x: 0.328125,\n y: 0.515625,\n },\n {\n x: 0.328125,\n y: 0.515625,\n },\n {\n x: 0.359375,\n y: 0.515625,\n },\n {\n x: 0.359375,\n y: 0.515625,\n },\n {\n x: 0.390625,\n y: 0.515625,\n },\n {\n x: 0.390625,\n y: 0.515625,\n },\n {\n x: 0.421875,\n y: 0.515625,\n },\n {\n x: 0.421875,\n y: 0.515625,\n },\n {\n x: 0.453125,\n y: 0.515625,\n },\n {\n x: 0.453125,\n y: 0.515625,\n },\n {\n x: 0.484375,\n y: 0.515625,\n },\n {\n x: 0.484375,\n y: 0.515625,\n },\n {\n x: 0.515625,\n y: 0.515625,\n },\n {\n x: 0.515625,\n y: 0.515625,\n },\n {\n x: 0.546875,\n y: 0.515625,\n },\n {\n x: 0.546875,\n y: 0.515625,\n },\n {\n x: 0.578125,\n y: 0.515625,\n },\n {\n x: 0.578125,\n y: 0.515625,\n },\n {\n x: 0.609375,\n y: 0.515625,\n },\n {\n x: 0.609375,\n y: 0.515625,\n },\n {\n x: 0.640625,\n y: 0.515625,\n },\n {\n x: 0.640625,\n y: 0.515625,\n },\n {\n x: 0.671875,\n y: 0.515625,\n },\n {\n x: 0.671875,\n y: 0.515625,\n },\n {\n x: 0.703125,\n y: 0.515625,\n },\n {\n x: 0.703125,\n y: 0.515625,\n },\n {\n x: 0.734375,\n y: 0.515625,\n },\n {\n x: 0.734375,\n y: 0.515625,\n },\n {\n x: 0.765625,\n y: 0.515625,\n },\n {\n x: 0.765625,\n y: 0.515625,\n },\n {\n x: 0.796875,\n y: 0.515625,\n },\n {\n x: 0.796875,\n y: 0.515625,\n },\n {\n x: 0.828125,\n y: 0.515625,\n },\n {\n x: 0.828125,\n y: 0.515625,\n },\n {\n x: 0.859375,\n y: 0.515625,\n },\n {\n x: 0.859375,\n y: 0.515625,\n },\n {\n x: 0.890625,\n y: 0.515625,\n },\n {\n x: 0.890625,\n y: 0.515625,\n },\n {\n x: 0.921875,\n y: 0.515625,\n },\n {\n x: 0.921875,\n y: 0.515625,\n },\n {\n x: 0.953125,\n y: 0.515625,\n },\n {\n x: 0.953125,\n y: 0.515625,\n },\n {\n x: 0.984375,\n y: 0.515625,\n },\n {\n x: 0.984375,\n y: 0.515625,\n },\n {\n x: 0.015625,\n y: 0.546875,\n },\n {\n x: 0.015625,\n y: 0.546875,\n },\n {\n x: 0.046875,\n y: 0.546875,\n },\n {\n x: 0.046875,\n y: 0.546875,\n },\n {\n x: 0.078125,\n y: 0.546875,\n },\n {\n x: 0.078125,\n y: 0.546875,\n },\n {\n x: 0.109375,\n y: 0.546875,\n },\n {\n x: 0.109375,\n y: 0.546875,\n },\n {\n x: 0.140625,\n y: 0.546875,\n },\n {\n x: 0.140625,\n y: 0.546875,\n },\n {\n x: 0.171875,\n y: 0.546875,\n },\n {\n x: 0.171875,\n y: 0.546875,\n },\n {\n x: 0.203125,\n y: 0.546875,\n },\n {\n x: 0.203125,\n y: 0.546875,\n },\n {\n x: 0.234375,\n y: 0.546875,\n },\n {\n x: 0.234375,\n y: 0.546875,\n },\n {\n x: 0.265625,\n y: 0.546875,\n },\n {\n x: 0.265625,\n y: 0.546875,\n },\n {\n x: 0.296875,\n y: 0.546875,\n },\n {\n x: 0.296875,\n y: 0.546875,\n },\n {\n x: 0.328125,\n y: 0.546875,\n },\n {\n x: 0.328125,\n y: 0.546875,\n },\n {\n x: 0.359375,\n y: 0.546875,\n },\n {\n x: 0.359375,\n y: 0.546875,\n },\n {\n x: 0.390625,\n y: 0.546875,\n },\n {\n x: 0.390625,\n y: 0.546875,\n },\n {\n x: 0.421875,\n y: 0.546875,\n },\n {\n x: 0.421875,\n y: 0.546875,\n },\n {\n x: 0.453125,\n y: 0.546875,\n },\n {\n x: 0.453125,\n y: 0.546875,\n },\n {\n x: 0.484375,\n y: 0.546875,\n },\n {\n x: 0.484375,\n y: 0.546875,\n },\n {\n x: 0.515625,\n y: 0.546875,\n },\n {\n x: 0.515625,\n y: 0.546875,\n },\n {\n x: 0.546875,\n y: 0.546875,\n },\n {\n x: 0.546875,\n y: 0.546875,\n },\n {\n x: 0.578125,\n y: 0.546875,\n },\n {\n x: 0.578125,\n y: 0.546875,\n },\n {\n x: 0.609375,\n y: 0.546875,\n },\n {\n x: 0.609375,\n y: 0.546875,\n },\n {\n x: 0.640625,\n y: 0.546875,\n },\n {\n x: 0.640625,\n y: 0.546875,\n },\n {\n x: 0.671875,\n y: 0.546875,\n },\n {\n x: 0.671875,\n y: 0.546875,\n },\n {\n x: 0.703125,\n y: 0.546875,\n },\n {\n x: 0.703125,\n y: 0.546875,\n },\n {\n x: 0.734375,\n y: 0.546875,\n },\n {\n x: 0.734375,\n y: 0.546875,\n },\n {\n x: 0.765625,\n y: 0.546875,\n },\n {\n x: 0.765625,\n y: 0.546875,\n },\n {\n x: 0.796875,\n y: 0.546875,\n },\n {\n x: 0.796875,\n y: 0.546875,\n },\n {\n x: 0.828125,\n y: 0.546875,\n },\n {\n x: 0.828125,\n y: 0.546875,\n },\n {\n x: 0.859375,\n y: 0.546875,\n },\n {\n x: 0.859375,\n y: 0.546875,\n },\n {\n x: 0.890625,\n y: 0.546875,\n },\n {\n x: 0.890625,\n y: 0.546875,\n },\n {\n x: 0.921875,\n y: 0.546875,\n },\n {\n x: 0.921875,\n y: 0.546875,\n },\n {\n x: 0.953125,\n y: 0.546875,\n },\n {\n x: 0.953125,\n y: 0.546875,\n },\n {\n x: 0.984375,\n y: 0.546875,\n },\n {\n x: 0.984375,\n y: 0.546875,\n },\n {\n x: 0.015625,\n y: 0.578125,\n },\n {\n x: 0.015625,\n y: 0.578125,\n },\n {\n x: 0.046875,\n y: 0.578125,\n },\n {\n x: 0.046875,\n y: 0.578125,\n },\n {\n x: 0.078125,\n y: 0.578125,\n },\n {\n x: 0.078125,\n y: 0.578125,\n },\n {\n x: 0.109375,\n y: 0.578125,\n },\n {\n x: 0.109375,\n y: 0.578125,\n },\n {\n x: 0.140625,\n y: 0.578125,\n },\n {\n x: 0.140625,\n y: 0.578125,\n },\n {\n x: 0.171875,\n y: 0.578125,\n },\n {\n x: 0.171875,\n y: 0.578125,\n },\n {\n x: 0.203125,\n y: 0.578125,\n },\n {\n x: 0.203125,\n y: 0.578125,\n },\n {\n x: 0.234375,\n y: 0.578125,\n },\n {\n x: 0.234375,\n y: 0.578125,\n },\n {\n x: 0.265625,\n y: 0.578125,\n },\n {\n x: 0.265625,\n y: 0.578125,\n },\n {\n x: 0.296875,\n y: 0.578125,\n },\n {\n x: 0.296875,\n y: 0.578125,\n },\n {\n x: 0.328125,\n y: 0.578125,\n },\n {\n x: 0.328125,\n y: 0.578125,\n },\n {\n x: 0.359375,\n y: 0.578125,\n },\n {\n x: 0.359375,\n y: 0.578125,\n },\n {\n x: 0.390625,\n y: 0.578125,\n },\n {\n x: 0.390625,\n y: 0.578125,\n },\n {\n x: 0.421875,\n y: 0.578125,\n },\n {\n x: 0.421875,\n y: 0.578125,\n },\n {\n x: 0.453125,\n y: 0.578125,\n },\n {\n x: 0.453125,\n y: 0.578125,\n },\n {\n x: 0.484375,\n y: 0.578125,\n },\n {\n x: 0.484375,\n y: 0.578125,\n },\n {\n x: 0.515625,\n y: 0.578125,\n },\n {\n x: 0.515625,\n y: 0.578125,\n },\n {\n x: 0.546875,\n y: 0.578125,\n },\n {\n x: 0.546875,\n y: 0.578125,\n },\n {\n x: 0.578125,\n y: 0.578125,\n },\n {\n x: 0.578125,\n y: 0.578125,\n },\n {\n x: 0.609375,\n y: 0.578125,\n },\n {\n x: 0.609375,\n y: 0.578125,\n },\n {\n x: 0.640625,\n y: 0.578125,\n },\n {\n x: 0.640625,\n y: 0.578125,\n },\n {\n x: 0.671875,\n y: 0.578125,\n },\n {\n x: 0.671875,\n y: 0.578125,\n },\n {\n x: 0.703125,\n y: 0.578125,\n },\n {\n x: 0.703125,\n y: 0.578125,\n },\n {\n x: 0.734375,\n y: 0.578125,\n },\n {\n x: 0.734375,\n y: 0.578125,\n },\n {\n x: 0.765625,\n y: 0.578125,\n },\n {\n x: 0.765625,\n y: 0.578125,\n },\n {\n x: 0.796875,\n y: 0.578125,\n },\n {\n x: 0.796875,\n y: 0.578125,\n },\n {\n x: 0.828125,\n y: 0.578125,\n },\n {\n x: 0.828125,\n y: 0.578125,\n },\n {\n x: 0.859375,\n y: 0.578125,\n },\n {\n x: 0.859375,\n y: 0.578125,\n },\n {\n x: 0.890625,\n y: 0.578125,\n },\n {\n x: 0.890625,\n y: 0.578125,\n },\n {\n x: 0.921875,\n y: 0.578125,\n },\n {\n x: 0.921875,\n y: 0.578125,\n },\n {\n x: 0.953125,\n y: 0.578125,\n },\n {\n x: 0.953125,\n y: 0.578125,\n },\n {\n x: 0.984375,\n y: 0.578125,\n },\n {\n x: 0.984375,\n y: 0.578125,\n },\n {\n x: 0.015625,\n y: 0.609375,\n },\n {\n x: 0.015625,\n y: 0.609375,\n },\n {\n x: 0.046875,\n y: 0.609375,\n },\n {\n x: 0.046875,\n y: 0.609375,\n },\n {\n x: 0.078125,\n y: 0.609375,\n },\n {\n x: 0.078125,\n y: 0.609375,\n },\n {\n x: 0.109375,\n y: 0.609375,\n },\n {\n x: 0.109375,\n y: 0.609375,\n },\n {\n x: 0.140625,\n y: 0.609375,\n },\n {\n x: 0.140625,\n y: 0.609375,\n },\n {\n x: 0.171875,\n y: 0.609375,\n },\n {\n x: 0.171875,\n y: 0.609375,\n },\n {\n x: 0.203125,\n y: 0.609375,\n },\n {\n x: 0.203125,\n y: 0.609375,\n },\n {\n x: 0.234375,\n y: 0.609375,\n },\n {\n x: 0.234375,\n y: 0.609375,\n },\n {\n x: 0.265625,\n y: 0.609375,\n },\n {\n x: 0.265625,\n y: 0.609375,\n },\n {\n x: 0.296875,\n y: 0.609375,\n },\n {\n x: 0.296875,\n y: 0.609375,\n },\n {\n x: 0.328125,\n y: 0.609375,\n },\n {\n x: 0.328125,\n y: 0.609375,\n },\n {\n x: 0.359375,\n y: 0.609375,\n },\n {\n x: 0.359375,\n y: 0.609375,\n },\n {\n x: 0.390625,\n y: 0.609375,\n },\n {\n x: 0.390625,\n y: 0.609375,\n },\n {\n x: 0.421875,\n y: 0.609375,\n },\n {\n x: 0.421875,\n y: 0.609375,\n },\n {\n x: 0.453125,\n y: 0.609375,\n },\n {\n x: 0.453125,\n y: 0.609375,\n },\n {\n x: 0.484375,\n y: 0.609375,\n },\n {\n x: 0.484375,\n y: 0.609375,\n },\n {\n x: 0.515625,\n y: 0.609375,\n },\n {\n x: 0.515625,\n y: 0.609375,\n },\n {\n x: 0.546875,\n y: 0.609375,\n },\n {\n x: 0.546875,\n y: 0.609375,\n },\n {\n x: 0.578125,\n y: 0.609375,\n },\n {\n x: 0.578125,\n y: 0.609375,\n },\n {\n x: 0.609375,\n y: 0.609375,\n },\n {\n x: 0.609375,\n y: 0.609375,\n },\n {\n x: 0.640625,\n y: 0.609375,\n },\n {\n x: 0.640625,\n y: 0.609375,\n },\n {\n x: 0.671875,\n y: 0.609375,\n },\n {\n x: 0.671875,\n y: 0.609375,\n },\n {\n x: 0.703125,\n y: 0.609375,\n },\n {\n x: 0.703125,\n y: 0.609375,\n },\n {\n x: 0.734375,\n y: 0.609375,\n },\n {\n x: 0.734375,\n y: 0.609375,\n },\n {\n x: 0.765625,\n y: 0.609375,\n },\n {\n x: 0.765625,\n y: 0.609375,\n },\n {\n x: 0.796875,\n y: 0.609375,\n },\n {\n x: 0.796875,\n y: 0.609375,\n },\n {\n x: 0.828125,\n y: 0.609375,\n },\n {\n x: 0.828125,\n y: 0.609375,\n },\n {\n x: 0.859375,\n y: 0.609375,\n },\n {\n x: 0.859375,\n y: 0.609375,\n },\n {\n x: 0.890625,\n y: 0.609375,\n },\n {\n x: 0.890625,\n y: 0.609375,\n },\n {\n x: 0.921875,\n y: 0.609375,\n },\n {\n x: 0.921875,\n y: 0.609375,\n },\n {\n x: 0.953125,\n y: 0.609375,\n },\n {\n x: 0.953125,\n y: 0.609375,\n },\n {\n x: 0.984375,\n y: 0.609375,\n },\n {\n x: 0.984375,\n y: 0.609375,\n },\n {\n x: 0.015625,\n y: 0.640625,\n },\n {\n x: 0.015625,\n y: 0.640625,\n },\n {\n x: 0.046875,\n y: 0.640625,\n },\n {\n x: 0.046875,\n y: 0.640625,\n },\n {\n x: 0.078125,\n y: 0.640625,\n },\n {\n x: 0.078125,\n y: 0.640625,\n },\n {\n x: 0.109375,\n y: 0.640625,\n },\n {\n x: 0.109375,\n y: 0.640625,\n },\n {\n x: 0.140625,\n y: 0.640625,\n },\n {\n x: 0.140625,\n y: 0.640625,\n },\n {\n x: 0.171875,\n y: 0.640625,\n },\n {\n x: 0.171875,\n y: 0.640625,\n },\n {\n x: 0.203125,\n y: 0.640625,\n },\n {\n x: 0.203125,\n y: 0.640625,\n },\n {\n x: 0.234375,\n y: 0.640625,\n },\n {\n x: 0.234375,\n y: 0.640625,\n },\n {\n x: 0.265625,\n y: 0.640625,\n },\n {\n x: 0.265625,\n y: 0.640625,\n },\n {\n x: 0.296875,\n y: 0.640625,\n },\n {\n x: 0.296875,\n y: 0.640625,\n },\n {\n x: 0.328125,\n y: 0.640625,\n },\n {\n x: 0.328125,\n y: 0.640625,\n },\n {\n x: 0.359375,\n y: 0.640625,\n },\n {\n x: 0.359375,\n y: 0.640625,\n },\n {\n x: 0.390625,\n y: 0.640625,\n },\n {\n x: 0.390625,\n y: 0.640625,\n },\n {\n x: 0.421875,\n y: 0.640625,\n },\n {\n x: 0.421875,\n y: 0.640625,\n },\n {\n x: 0.453125,\n y: 0.640625,\n },\n {\n x: 0.453125,\n y: 0.640625,\n },\n {\n x: 0.484375,\n y: 0.640625,\n },\n {\n x: 0.484375,\n y: 0.640625,\n },\n {\n x: 0.515625,\n y: 0.640625,\n },\n {\n x: 0.515625,\n y: 0.640625,\n },\n {\n x: 0.546875,\n y: 0.640625,\n },\n {\n x: 0.546875,\n y: 0.640625,\n },\n {\n x: 0.578125,\n y: 0.640625,\n },\n {\n x: 0.578125,\n y: 0.640625,\n },\n {\n x: 0.609375,\n y: 0.640625,\n },\n {\n x: 0.609375,\n y: 0.640625,\n },\n {\n x: 0.640625,\n y: 0.640625,\n },\n {\n x: 0.640625,\n y: 0.640625,\n },\n {\n x: 0.671875,\n y: 0.640625,\n },\n {\n x: 0.671875,\n y: 0.640625,\n },\n {\n x: 0.703125,\n y: 0.640625,\n },\n {\n x: 0.703125,\n y: 0.640625,\n },\n {\n x: 0.734375,\n y: 0.640625,\n },\n {\n x: 0.734375,\n y: 0.640625,\n },\n {\n x: 0.765625,\n y: 0.640625,\n },\n {\n x: 0.765625,\n y: 0.640625,\n },\n {\n x: 0.796875,\n y: 0.640625,\n },\n {\n x: 0.796875,\n y: 0.640625,\n },\n {\n x: 0.828125,\n y: 0.640625,\n },\n {\n x: 0.828125,\n y: 0.640625,\n },\n {\n x: 0.859375,\n y: 0.640625,\n },\n {\n x: 0.859375,\n y: 0.640625,\n },\n {\n x: 0.890625,\n y: 0.640625,\n },\n {\n x: 0.890625,\n y: 0.640625,\n },\n {\n x: 0.921875,\n y: 0.640625,\n },\n {\n x: 0.921875,\n y: 0.640625,\n },\n {\n x: 0.953125,\n y: 0.640625,\n },\n {\n x: 0.953125,\n y: 0.640625,\n },\n {\n x: 0.984375,\n y: 0.640625,\n },\n {\n x: 0.984375,\n y: 0.640625,\n },\n {\n x: 0.015625,\n y: 0.671875,\n },\n {\n x: 0.015625,\n y: 0.671875,\n },\n {\n x: 0.046875,\n y: 0.671875,\n },\n {\n x: 0.046875,\n y: 0.671875,\n },\n {\n x: 0.078125,\n y: 0.671875,\n },\n {\n x: 0.078125,\n y: 0.671875,\n },\n {\n x: 0.109375,\n y: 0.671875,\n },\n {\n x: 0.109375,\n y: 0.671875,\n },\n {\n x: 0.140625,\n y: 0.671875,\n },\n {\n x: 0.140625,\n y: 0.671875,\n },\n {\n x: 0.171875,\n y: 0.671875,\n },\n {\n x: 0.171875,\n y: 0.671875,\n },\n {\n x: 0.203125,\n y: 0.671875,\n },\n {\n x: 0.203125,\n y: 0.671875,\n },\n {\n x: 0.234375,\n y: 0.671875,\n },\n {\n x: 0.234375,\n y: 0.671875,\n },\n {\n x: 0.265625,\n y: 0.671875,\n },\n {\n x: 0.265625,\n y: 0.671875,\n },\n {\n x: 0.296875,\n y: 0.671875,\n },\n {\n x: 0.296875,\n y: 0.671875,\n },\n {\n x: 0.328125,\n y: 0.671875,\n },\n {\n x: 0.328125,\n y: 0.671875,\n },\n {\n x: 0.359375,\n y: 0.671875,\n },\n {\n x: 0.359375,\n y: 0.671875,\n },\n {\n x: 0.390625,\n y: 0.671875,\n },\n {\n x: 0.390625,\n y: 0.671875,\n },\n {\n x: 0.421875,\n y: 0.671875,\n },\n {\n x: 0.421875,\n y: 0.671875,\n },\n {\n x: 0.453125,\n y: 0.671875,\n },\n {\n x: 0.453125,\n y: 0.671875,\n },\n {\n x: 0.484375,\n y: 0.671875,\n },\n {\n x: 0.484375,\n y: 0.671875,\n },\n {\n x: 0.515625,\n y: 0.671875,\n },\n {\n x: 0.515625,\n y: 0.671875,\n },\n {\n x: 0.546875,\n y: 0.671875,\n },\n {\n x: 0.546875,\n y: 0.671875,\n },\n {\n x: 0.578125,\n y: 0.671875,\n },\n {\n x: 0.578125,\n y: 0.671875,\n },\n {\n x: 0.609375,\n y: 0.671875,\n },\n {\n x: 0.609375,\n y: 0.671875,\n },\n {\n x: 0.640625,\n y: 0.671875,\n },\n {\n x: 0.640625,\n y: 0.671875,\n },\n {\n x: 0.671875,\n y: 0.671875,\n },\n {\n x: 0.671875,\n y: 0.671875,\n },\n {\n x: 0.703125,\n y: 0.671875,\n },\n {\n x: 0.703125,\n y: 0.671875,\n },\n {\n x: 0.734375,\n y: 0.671875,\n },\n {\n x: 0.734375,\n y: 0.671875,\n },\n {\n x: 0.765625,\n y: 0.671875,\n },\n {\n x: 0.765625,\n y: 0.671875,\n },\n {\n x: 0.796875,\n y: 0.671875,\n },\n {\n x: 0.796875,\n y: 0.671875,\n },\n {\n x: 0.828125,\n y: 0.671875,\n },\n {\n x: 0.828125,\n y: 0.671875,\n },\n {\n x: 0.859375,\n y: 0.671875,\n },\n {\n x: 0.859375,\n y: 0.671875,\n },\n {\n x: 0.890625,\n y: 0.671875,\n },\n {\n x: 0.890625,\n y: 0.671875,\n },\n {\n x: 0.921875,\n y: 0.671875,\n },\n {\n x: 0.921875,\n y: 0.671875,\n },\n {\n x: 0.953125,\n y: 0.671875,\n },\n {\n x: 0.953125,\n y: 0.671875,\n },\n {\n x: 0.984375,\n y: 0.671875,\n },\n {\n x: 0.984375,\n y: 0.671875,\n },\n {\n x: 0.015625,\n y: 0.703125,\n },\n {\n x: 0.015625,\n y: 0.703125,\n },\n {\n x: 0.046875,\n y: 0.703125,\n },\n {\n x: 0.046875,\n y: 0.703125,\n },\n {\n x: 0.078125,\n y: 0.703125,\n },\n {\n x: 0.078125,\n y: 0.703125,\n },\n {\n x: 0.109375,\n y: 0.703125,\n },\n {\n x: 0.109375,\n y: 0.703125,\n },\n {\n x: 0.140625,\n y: 0.703125,\n },\n {\n x: 0.140625,\n y: 0.703125,\n },\n {\n x: 0.171875,\n y: 0.703125,\n },\n {\n x: 0.171875,\n y: 0.703125,\n },\n {\n x: 0.203125,\n y: 0.703125,\n },\n {\n x: 0.203125,\n y: 0.703125,\n },\n {\n x: 0.234375,\n y: 0.703125,\n },\n {\n x: 0.234375,\n y: 0.703125,\n },\n {\n x: 0.265625,\n y: 0.703125,\n },\n {\n x: 0.265625,\n y: 0.703125,\n },\n {\n x: 0.296875,\n y: 0.703125,\n },\n {\n x: 0.296875,\n y: 0.703125,\n },\n {\n x: 0.328125,\n y: 0.703125,\n },\n {\n x: 0.328125,\n y: 0.703125,\n },\n {\n x: 0.359375,\n y: 0.703125,\n },\n {\n x: 0.359375,\n y: 0.703125,\n },\n {\n x: 0.390625,\n y: 0.703125,\n },\n {\n x: 0.390625,\n y: 0.703125,\n },\n {\n x: 0.421875,\n y: 0.703125,\n },\n {\n x: 0.421875,\n y: 0.703125,\n },\n {\n x: 0.453125,\n y: 0.703125,\n },\n {\n x: 0.453125,\n y: 0.703125,\n },\n {\n x: 0.484375,\n y: 0.703125,\n },\n {\n x: 0.484375,\n y: 0.703125,\n },\n {\n x: 0.515625,\n y: 0.703125,\n },\n {\n x: 0.515625,\n y: 0.703125,\n },\n {\n x: 0.546875,\n y: 0.703125,\n },\n {\n x: 0.546875,\n y: 0.703125,\n },\n {\n x: 0.578125,\n y: 0.703125,\n },\n {\n x: 0.578125,\n y: 0.703125,\n },\n {\n x: 0.609375,\n y: 0.703125,\n },\n {\n x: 0.609375,\n y: 0.703125,\n },\n {\n x: 0.640625,\n y: 0.703125,\n },\n {\n x: 0.640625,\n y: 0.703125,\n },\n {\n x: 0.671875,\n y: 0.703125,\n },\n {\n x: 0.671875,\n y: 0.703125,\n },\n {\n x: 0.703125,\n y: 0.703125,\n },\n {\n x: 0.703125,\n y: 0.703125,\n },\n {\n x: 0.734375,\n y: 0.703125,\n },\n {\n x: 0.734375,\n y: 0.703125,\n },\n {\n x: 0.765625,\n y: 0.703125,\n },\n {\n x: 0.765625,\n y: 0.703125,\n },\n {\n x: 0.796875,\n y: 0.703125,\n },\n {\n x: 0.796875,\n y: 0.703125,\n },\n {\n x: 0.828125,\n y: 0.703125,\n },\n {\n x: 0.828125,\n y: 0.703125,\n },\n {\n x: 0.859375,\n y: 0.703125,\n },\n {\n x: 0.859375,\n y: 0.703125,\n },\n {\n x: 0.890625,\n y: 0.703125,\n },\n {\n x: 0.890625,\n y: 0.703125,\n },\n {\n x: 0.921875,\n y: 0.703125,\n },\n {\n x: 0.921875,\n y: 0.703125,\n },\n {\n x: 0.953125,\n y: 0.703125,\n },\n {\n x: 0.953125,\n y: 0.703125,\n },\n {\n x: 0.984375,\n y: 0.703125,\n },\n {\n x: 0.984375,\n y: 0.703125,\n },\n {\n x: 0.015625,\n y: 0.734375,\n },\n {\n x: 0.015625,\n y: 0.734375,\n },\n {\n x: 0.046875,\n y: 0.734375,\n },\n {\n x: 0.046875,\n y: 0.734375,\n },\n {\n x: 0.078125,\n y: 0.734375,\n },\n {\n x: 0.078125,\n y: 0.734375,\n },\n {\n x: 0.109375,\n y: 0.734375,\n },\n {\n x: 0.109375,\n y: 0.734375,\n },\n {\n x: 0.140625,\n y: 0.734375,\n },\n {\n x: 0.140625,\n y: 0.734375,\n },\n {\n x: 0.171875,\n y: 0.734375,\n },\n {\n x: 0.171875,\n y: 0.734375,\n },\n {\n x: 0.203125,\n y: 0.734375,\n },\n {\n x: 0.203125,\n y: 0.734375,\n },\n {\n x: 0.234375,\n y: 0.734375,\n },\n {\n x: 0.234375,\n y: 0.734375,\n },\n {\n x: 0.265625,\n y: 0.734375,\n },\n {\n x: 0.265625,\n y: 0.734375,\n },\n {\n x: 0.296875,\n y: 0.734375,\n },\n {\n x: 0.296875,\n y: 0.734375,\n },\n {\n x: 0.328125,\n y: 0.734375,\n },\n {\n x: 0.328125,\n y: 0.734375,\n },\n {\n x: 0.359375,\n y: 0.734375,\n },\n {\n x: 0.359375,\n y: 0.734375,\n },\n {\n x: 0.390625,\n y: 0.734375,\n },\n {\n x: 0.390625,\n y: 0.734375,\n },\n {\n x: 0.421875,\n y: 0.734375,\n },\n {\n x: 0.421875,\n y: 0.734375,\n },\n {\n x: 0.453125,\n y: 0.734375,\n },\n {\n x: 0.453125,\n y: 0.734375,\n },\n {\n x: 0.484375,\n y: 0.734375,\n },\n {\n x: 0.484375,\n y: 0.734375,\n },\n {\n x: 0.515625,\n y: 0.734375,\n },\n {\n x: 0.515625,\n y: 0.734375,\n },\n {\n x: 0.546875,\n y: 0.734375,\n },\n {\n x: 0.546875,\n y: 0.734375,\n },\n {\n x: 0.578125,\n y: 0.734375,\n },\n {\n x: 0.578125,\n y: 0.734375,\n },\n {\n x: 0.609375,\n y: 0.734375,\n },\n {\n x: 0.609375,\n y: 0.734375,\n },\n {\n x: 0.640625,\n y: 0.734375,\n },\n {\n x: 0.640625,\n y: 0.734375,\n },\n {\n x: 0.671875,\n y: 0.734375,\n },\n {\n x: 0.671875,\n y: 0.734375,\n },\n {\n x: 0.703125,\n y: 0.734375,\n },\n {\n x: 0.703125,\n y: 0.734375,\n },\n {\n x: 0.734375,\n y: 0.734375,\n },\n {\n x: 0.734375,\n y: 0.734375,\n },\n {\n x: 0.765625,\n y: 0.734375,\n },\n {\n x: 0.765625,\n y: 0.734375,\n },\n {\n x: 0.796875,\n y: 0.734375,\n },\n {\n x: 0.796875,\n y: 0.734375,\n },\n {\n x: 0.828125,\n y: 0.734375,\n },\n {\n x: 0.828125,\n y: 0.734375,\n },\n {\n x: 0.859375,\n y: 0.734375,\n },\n {\n x: 0.859375,\n y: 0.734375,\n },\n {\n x: 0.890625,\n y: 0.734375,\n },\n {\n x: 0.890625,\n y: 0.734375,\n },\n {\n x: 0.921875,\n y: 0.734375,\n },\n {\n x: 0.921875,\n y: 0.734375,\n },\n {\n x: 0.953125,\n y: 0.734375,\n },\n {\n x: 0.953125,\n y: 0.734375,\n },\n {\n x: 0.984375,\n y: 0.734375,\n },\n {\n x: 0.984375,\n y: 0.734375,\n },\n {\n x: 0.015625,\n y: 0.765625,\n },\n {\n x: 0.015625,\n y: 0.765625,\n },\n {\n x: 0.046875,\n y: 0.765625,\n },\n {\n x: 0.046875,\n y: 0.765625,\n },\n {\n x: 0.078125,\n y: 0.765625,\n },\n {\n x: 0.078125,\n y: 0.765625,\n },\n {\n x: 0.109375,\n y: 0.765625,\n },\n {\n x: 0.109375,\n y: 0.765625,\n },\n {\n x: 0.140625,\n y: 0.765625,\n },\n {\n x: 0.140625,\n y: 0.765625,\n },\n {\n x: 0.171875,\n y: 0.765625,\n },\n {\n x: 0.171875,\n y: 0.765625,\n },\n {\n x: 0.203125,\n y: 0.765625,\n },\n {\n x: 0.203125,\n y: 0.765625,\n },\n {\n x: 0.234375,\n y: 0.765625,\n },\n {\n x: 0.234375,\n y: 0.765625,\n },\n {\n x: 0.265625,\n y: 0.765625,\n },\n {\n x: 0.265625,\n y: 0.765625,\n },\n {\n x: 0.296875,\n y: 0.765625,\n },\n {\n x: 0.296875,\n y: 0.765625,\n },\n {\n x: 0.328125,\n y: 0.765625,\n },\n {\n x: 0.328125,\n y: 0.765625,\n },\n {\n x: 0.359375,\n y: 0.765625,\n },\n {\n x: 0.359375,\n y: 0.765625,\n },\n {\n x: 0.390625,\n y: 0.765625,\n },\n {\n x: 0.390625,\n y: 0.765625,\n },\n {\n x: 0.421875,\n y: 0.765625,\n },\n {\n x: 0.421875,\n y: 0.765625,\n },\n {\n x: 0.453125,\n y: 0.765625,\n },\n {\n x: 0.453125,\n y: 0.765625,\n },\n {\n x: 0.484375,\n y: 0.765625,\n },\n {\n x: 0.484375,\n y: 0.765625,\n },\n {\n x: 0.515625,\n y: 0.765625,\n },\n {\n x: 0.515625,\n y: 0.765625,\n },\n {\n x: 0.546875,\n y: 0.765625,\n },\n {\n x: 0.546875,\n y: 0.765625,\n },\n {\n x: 0.578125,\n y: 0.765625,\n },\n {\n x: 0.578125,\n y: 0.765625,\n },\n {\n x: 0.609375,\n y: 0.765625,\n },\n {\n x: 0.609375,\n y: 0.765625,\n },\n {\n x: 0.640625,\n y: 0.765625,\n },\n {\n x: 0.640625,\n y: 0.765625,\n },\n {\n x: 0.671875,\n y: 0.765625,\n },\n {\n x: 0.671875,\n y: 0.765625,\n },\n {\n x: 0.703125,\n y: 0.765625,\n },\n {\n x: 0.703125,\n y: 0.765625,\n },\n {\n x: 0.734375,\n y: 0.765625,\n },\n {\n x: 0.734375,\n y: 0.765625,\n },\n {\n x: 0.765625,\n y: 0.765625,\n },\n {\n x: 0.765625,\n y: 0.765625,\n },\n {\n x: 0.796875,\n y: 0.765625,\n },\n {\n x: 0.796875,\n y: 0.765625,\n },\n {\n x: 0.828125,\n y: 0.765625,\n },\n {\n x: 0.828125,\n y: 0.765625,\n },\n {\n x: 0.859375,\n y: 0.765625,\n },\n {\n x: 0.859375,\n y: 0.765625,\n },\n {\n x: 0.890625,\n y: 0.765625,\n },\n {\n x: 0.890625,\n y: 0.765625,\n },\n {\n x: 0.921875,\n y: 0.765625,\n },\n {\n x: 0.921875,\n y: 0.765625,\n },\n {\n x: 0.953125,\n y: 0.765625,\n },\n {\n x: 0.953125,\n y: 0.765625,\n },\n {\n x: 0.984375,\n y: 0.765625,\n },\n {\n x: 0.984375,\n y: 0.765625,\n },\n {\n x: 0.015625,\n y: 0.796875,\n },\n {\n x: 0.015625,\n y: 0.796875,\n },\n {\n x: 0.046875,\n y: 0.796875,\n },\n {\n x: 0.046875,\n y: 0.796875,\n },\n {\n x: 0.078125,\n y: 0.796875,\n },\n {\n x: 0.078125,\n y: 0.796875,\n },\n {\n x: 0.109375,\n y: 0.796875,\n },\n {\n x: 0.109375,\n y: 0.796875,\n },\n {\n x: 0.140625,\n y: 0.796875,\n },\n {\n x: 0.140625,\n y: 0.796875,\n },\n {\n x: 0.171875,\n y: 0.796875,\n },\n {\n x: 0.171875,\n y: 0.796875,\n },\n {\n x: 0.203125,\n y: 0.796875,\n },\n {\n x: 0.203125,\n y: 0.796875,\n },\n {\n x: 0.234375,\n y: 0.796875,\n },\n {\n x: 0.234375,\n y: 0.796875,\n },\n {\n x: 0.265625,\n y: 0.796875,\n },\n {\n x: 0.265625,\n y: 0.796875,\n },\n {\n x: 0.296875,\n y: 0.796875,\n },\n {\n x: 0.296875,\n y: 0.796875,\n },\n {\n x: 0.328125,\n y: 0.796875,\n },\n {\n x: 0.328125,\n y: 0.796875,\n },\n {\n x: 0.359375,\n y: 0.796875,\n },\n {\n x: 0.359375,\n y: 0.796875,\n },\n {\n x: 0.390625,\n y: 0.796875,\n },\n {\n x: 0.390625,\n y: 0.796875,\n },\n {\n x: 0.421875,\n y: 0.796875,\n },\n {\n x: 0.421875,\n y: 0.796875,\n },\n {\n x: 0.453125,\n y: 0.796875,\n },\n {\n x: 0.453125,\n y: 0.796875,\n },\n {\n x: 0.484375,\n y: 0.796875,\n },\n {\n x: 0.484375,\n y: 0.796875,\n },\n {\n x: 0.515625,\n y: 0.796875,\n },\n {\n x: 0.515625,\n y: 0.796875,\n },\n {\n x: 0.546875,\n y: 0.796875,\n },\n {\n x: 0.546875,\n y: 0.796875,\n },\n {\n x: 0.578125,\n y: 0.796875,\n },\n {\n x: 0.578125,\n y: 0.796875,\n },\n {\n x: 0.609375,\n y: 0.796875,\n },\n {\n x: 0.609375,\n y: 0.796875,\n },\n {\n x: 0.640625,\n y: 0.796875,\n },\n {\n x: 0.640625,\n y: 0.796875,\n },\n {\n x: 0.671875,\n y: 0.796875,\n },\n {\n x: 0.671875,\n y: 0.796875,\n },\n {\n x: 0.703125,\n y: 0.796875,\n },\n {\n x: 0.703125,\n y: 0.796875,\n },\n {\n x: 0.734375,\n y: 0.796875,\n },\n {\n x: 0.734375,\n y: 0.796875,\n },\n {\n x: 0.765625,\n y: 0.796875,\n },\n {\n x: 0.765625,\n y: 0.796875,\n },\n {\n x: 0.796875,\n y: 0.796875,\n },\n {\n x: 0.796875,\n y: 0.796875,\n },\n {\n x: 0.828125,\n y: 0.796875,\n },\n {\n x: 0.828125,\n y: 0.796875,\n },\n {\n x: 0.859375,\n y: 0.796875,\n },\n {\n x: 0.859375,\n y: 0.796875,\n },\n {\n x: 0.890625,\n y: 0.796875,\n },\n {\n x: 0.890625,\n y: 0.796875,\n },\n {\n x: 0.921875,\n y: 0.796875,\n },\n {\n x: 0.921875,\n y: 0.796875,\n },\n {\n x: 0.953125,\n y: 0.796875,\n },\n {\n x: 0.953125,\n y: 0.796875,\n },\n {\n x: 0.984375,\n y: 0.796875,\n },\n {\n x: 0.984375,\n y: 0.796875,\n },\n {\n x: 0.015625,\n y: 0.828125,\n },\n {\n x: 0.015625,\n y: 0.828125,\n },\n {\n x: 0.046875,\n y: 0.828125,\n },\n {\n x: 0.046875,\n y: 0.828125,\n },\n {\n x: 0.078125,\n y: 0.828125,\n },\n {\n x: 0.078125,\n y: 0.828125,\n },\n {\n x: 0.109375,\n y: 0.828125,\n },\n {\n x: 0.109375,\n y: 0.828125,\n },\n {\n x: 0.140625,\n y: 0.828125,\n },\n {\n x: 0.140625,\n y: 0.828125,\n },\n {\n x: 0.171875,\n y: 0.828125,\n },\n {\n x: 0.171875,\n y: 0.828125,\n },\n {\n x: 0.203125,\n y: 0.828125,\n },\n {\n x: 0.203125,\n y: 0.828125,\n },\n {\n x: 0.234375,\n y: 0.828125,\n },\n {\n x: 0.234375,\n y: 0.828125,\n },\n {\n x: 0.265625,\n y: 0.828125,\n },\n {\n x: 0.265625,\n y: 0.828125,\n },\n {\n x: 0.296875,\n y: 0.828125,\n },\n {\n x: 0.296875,\n y: 0.828125,\n },\n {\n x: 0.328125,\n y: 0.828125,\n },\n {\n x: 0.328125,\n y: 0.828125,\n },\n {\n x: 0.359375,\n y: 0.828125,\n },\n {\n x: 0.359375,\n y: 0.828125,\n },\n {\n x: 0.390625,\n y: 0.828125,\n },\n {\n x: 0.390625,\n y: 0.828125,\n },\n {\n x: 0.421875,\n y: 0.828125,\n },\n {\n x: 0.421875,\n y: 0.828125,\n },\n {\n x: 0.453125,\n y: 0.828125,\n },\n {\n x: 0.453125,\n y: 0.828125,\n },\n {\n x: 0.484375,\n y: 0.828125,\n },\n {\n x: 0.484375,\n y: 0.828125,\n },\n {\n x: 0.515625,\n y: 0.828125,\n },\n {\n x: 0.515625,\n y: 0.828125,\n },\n {\n x: 0.546875,\n y: 0.828125,\n },\n {\n x: 0.546875,\n y: 0.828125,\n },\n {\n x: 0.578125,\n y: 0.828125,\n },\n {\n x: 0.578125,\n y: 0.828125,\n },\n {\n x: 0.609375,\n y: 0.828125,\n },\n {\n x: 0.609375,\n y: 0.828125,\n },\n {\n x: 0.640625,\n y: 0.828125,\n },\n {\n x: 0.640625,\n y: 0.828125,\n },\n {\n x: 0.671875,\n y: 0.828125,\n },\n {\n x: 0.671875,\n y: 0.828125,\n },\n {\n x: 0.703125,\n y: 0.828125,\n },\n {\n x: 0.703125,\n y: 0.828125,\n },\n {\n x: 0.734375,\n y: 0.828125,\n },\n {\n x: 0.734375,\n y: 0.828125,\n },\n {\n x: 0.765625,\n y: 0.828125,\n },\n {\n x: 0.765625,\n y: 0.828125,\n },\n {\n x: 0.796875,\n y: 0.828125,\n },\n {\n x: 0.796875,\n y: 0.828125,\n },\n {\n x: 0.828125,\n y: 0.828125,\n },\n {\n x: 0.828125,\n y: 0.828125,\n },\n {\n x: 0.859375,\n y: 0.828125,\n },\n {\n x: 0.859375,\n y: 0.828125,\n },\n {\n x: 0.890625,\n y: 0.828125,\n },\n {\n x: 0.890625,\n y: 0.828125,\n },\n {\n x: 0.921875,\n y: 0.828125,\n },\n {\n x: 0.921875,\n y: 0.828125,\n },\n {\n x: 0.953125,\n y: 0.828125,\n },\n {\n x: 0.953125,\n y: 0.828125,\n },\n {\n x: 0.984375,\n y: 0.828125,\n },\n {\n x: 0.984375,\n y: 0.828125,\n },\n {\n x: 0.015625,\n y: 0.859375,\n },\n {\n x: 0.015625,\n y: 0.859375,\n },\n {\n x: 0.046875,\n y: 0.859375,\n },\n {\n x: 0.046875,\n y: 0.859375,\n },\n {\n x: 0.078125,\n y: 0.859375,\n },\n {\n x: 0.078125,\n y: 0.859375,\n },\n {\n x: 0.109375,\n y: 0.859375,\n },\n {\n x: 0.109375,\n y: 0.859375,\n },\n {\n x: 0.140625,\n y: 0.859375,\n },\n {\n x: 0.140625,\n y: 0.859375,\n },\n {\n x: 0.171875,\n y: 0.859375,\n },\n {\n x: 0.171875,\n y: 0.859375,\n },\n {\n x: 0.203125,\n y: 0.859375,\n },\n {\n x: 0.203125,\n y: 0.859375,\n },\n {\n x: 0.234375,\n y: 0.859375,\n },\n {\n x: 0.234375,\n y: 0.859375,\n },\n {\n x: 0.265625,\n y: 0.859375,\n },\n {\n x: 0.265625,\n y: 0.859375,\n },\n {\n x: 0.296875,\n y: 0.859375,\n },\n {\n x: 0.296875,\n y: 0.859375,\n },\n {\n x: 0.328125,\n y: 0.859375,\n },\n {\n x: 0.328125,\n y: 0.859375,\n },\n {\n x: 0.359375,\n y: 0.859375,\n },\n {\n x: 0.359375,\n y: 0.859375,\n },\n {\n x: 0.390625,\n y: 0.859375,\n },\n {\n x: 0.390625,\n y: 0.859375,\n },\n {\n x: 0.421875,\n y: 0.859375,\n },\n {\n x: 0.421875,\n y: 0.859375,\n },\n {\n x: 0.453125,\n y: 0.859375,\n },\n {\n x: 0.453125,\n y: 0.859375,\n },\n {\n x: 0.484375,\n y: 0.859375,\n },\n {\n x: 0.484375,\n y: 0.859375,\n },\n {\n x: 0.515625,\n y: 0.859375,\n },\n {\n x: 0.515625,\n y: 0.859375,\n },\n {\n x: 0.546875,\n y: 0.859375,\n },\n {\n x: 0.546875,\n y: 0.859375,\n },\n {\n x: 0.578125,\n y: 0.859375,\n },\n {\n x: 0.578125,\n y: 0.859375,\n },\n {\n x: 0.609375,\n y: 0.859375,\n },\n {\n x: 0.609375,\n y: 0.859375,\n },\n {\n x: 0.640625,\n y: 0.859375,\n },\n {\n x: 0.640625,\n y: 0.859375,\n },\n {\n x: 0.671875,\n y: 0.859375,\n },\n {\n x: 0.671875,\n y: 0.859375,\n },\n {\n x: 0.703125,\n y: 0.859375,\n },\n {\n x: 0.703125,\n y: 0.859375,\n },\n {\n x: 0.734375,\n y: 0.859375,\n },\n {\n x: 0.734375,\n y: 0.859375,\n },\n {\n x: 0.765625,\n y: 0.859375,\n },\n {\n x: 0.765625,\n y: 0.859375,\n },\n {\n x: 0.796875,\n y: 0.859375,\n },\n {\n x: 0.796875,\n y: 0.859375,\n },\n {\n x: 0.828125,\n y: 0.859375,\n },\n {\n x: 0.828125,\n y: 0.859375,\n },\n {\n x: 0.859375,\n y: 0.859375,\n },\n {\n x: 0.859375,\n y: 0.859375,\n },\n {\n x: 0.890625,\n y: 0.859375,\n },\n {\n x: 0.890625,\n y: 0.859375,\n },\n {\n x: 0.921875,\n y: 0.859375,\n },\n {\n x: 0.921875,\n y: 0.859375,\n },\n {\n x: 0.953125,\n y: 0.859375,\n },\n {\n x: 0.953125,\n y: 0.859375,\n },\n {\n x: 0.984375,\n y: 0.859375,\n },\n {\n x: 0.984375,\n y: 0.859375,\n },\n {\n x: 0.015625,\n y: 0.890625,\n },\n {\n x: 0.015625,\n y: 0.890625,\n },\n {\n x: 0.046875,\n y: 0.890625,\n },\n {\n x: 0.046875,\n y: 0.890625,\n },\n {\n x: 0.078125,\n y: 0.890625,\n },\n {\n x: 0.078125,\n y: 0.890625,\n },\n {\n x: 0.109375,\n y: 0.890625,\n },\n {\n x: 0.109375,\n y: 0.890625,\n },\n {\n x: 0.140625,\n y: 0.890625,\n },\n {\n x: 0.140625,\n y: 0.890625,\n },\n {\n x: 0.171875,\n y: 0.890625,\n },\n {\n x: 0.171875,\n y: 0.890625,\n },\n {\n x: 0.203125,\n y: 0.890625,\n },\n {\n x: 0.203125,\n y: 0.890625,\n },\n {\n x: 0.234375,\n y: 0.890625,\n },\n {\n x: 0.234375,\n y: 0.890625,\n },\n {\n x: 0.265625,\n y: 0.890625,\n },\n {\n x: 0.265625,\n y: 0.890625,\n },\n {\n x: 0.296875,\n y: 0.890625,\n },\n {\n x: 0.296875,\n y: 0.890625,\n },\n {\n x: 0.328125,\n y: 0.890625,\n },\n {\n x: 0.328125,\n y: 0.890625,\n },\n {\n x: 0.359375,\n y: 0.890625,\n },\n {\n x: 0.359375,\n y: 0.890625,\n },\n {\n x: 0.390625,\n y: 0.890625,\n },\n {\n x: 0.390625,\n y: 0.890625,\n },\n {\n x: 0.421875,\n y: 0.890625,\n },\n {\n x: 0.421875,\n y: 0.890625,\n },\n {\n x: 0.453125,\n y: 0.890625,\n },\n {\n x: 0.453125,\n y: 0.890625,\n },\n {\n x: 0.484375,\n y: 0.890625,\n },\n {\n x: 0.484375,\n y: 0.890625,\n },\n {\n x: 0.515625,\n y: 0.890625,\n },\n {\n x: 0.515625,\n y: 0.890625,\n },\n {\n x: 0.546875,\n y: 0.890625,\n },\n {\n x: 0.546875,\n y: 0.890625,\n },\n {\n x: 0.578125,\n y: 0.890625,\n },\n {\n x: 0.578125,\n y: 0.890625,\n },\n {\n x: 0.609375,\n y: 0.890625,\n },\n {\n x: 0.609375,\n y: 0.890625,\n },\n {\n x: 0.640625,\n y: 0.890625,\n },\n {\n x: 0.640625,\n y: 0.890625,\n },\n {\n x: 0.671875,\n y: 0.890625,\n },\n {\n x: 0.671875,\n y: 0.890625,\n },\n {\n x: 0.703125,\n y: 0.890625,\n },\n {\n x: 0.703125,\n y: 0.890625,\n },\n {\n x: 0.734375,\n y: 0.890625,\n },\n {\n x: 0.734375,\n y: 0.890625,\n },\n {\n x: 0.765625,\n y: 0.890625,\n },\n {\n x: 0.765625,\n y: 0.890625,\n },\n {\n x: 0.796875,\n y: 0.890625,\n },\n {\n x: 0.796875,\n y: 0.890625,\n },\n {\n x: 0.828125,\n y: 0.890625,\n },\n {\n x: 0.828125,\n y: 0.890625,\n },\n {\n x: 0.859375,\n y: 0.890625,\n },\n {\n x: 0.859375,\n y: 0.890625,\n },\n {\n x: 0.890625,\n y: 0.890625,\n },\n {\n x: 0.890625,\n y: 0.890625,\n },\n {\n x: 0.921875,\n y: 0.890625,\n },\n {\n x: 0.921875,\n y: 0.890625,\n },\n {\n x: 0.953125,\n y: 0.890625,\n },\n {\n x: 0.953125,\n y: 0.890625,\n },\n {\n x: 0.984375,\n y: 0.890625,\n },\n {\n x: 0.984375,\n y: 0.890625,\n },\n {\n x: 0.015625,\n y: 0.921875,\n },\n {\n x: 0.015625,\n y: 0.921875,\n },\n {\n x: 0.046875,\n y: 0.921875,\n },\n {\n x: 0.046875,\n y: 0.921875,\n },\n {\n x: 0.078125,\n y: 0.921875,\n },\n {\n x: 0.078125,\n y: 0.921875,\n },\n {\n x: 0.109375,\n y: 0.921875,\n },\n {\n x: 0.109375,\n y: 0.921875,\n },\n {\n x: 0.140625,\n y: 0.921875,\n },\n {\n x: 0.140625,\n y: 0.921875,\n },\n {\n x: 0.171875,\n y: 0.921875,\n },\n {\n x: 0.171875,\n y: 0.921875,\n },\n {\n x: 0.203125,\n y: 0.921875,\n },\n {\n x: 0.203125,\n y: 0.921875,\n },\n {\n x: 0.234375,\n y: 0.921875,\n },\n {\n x: 0.234375,\n y: 0.921875,\n },\n {\n x: 0.265625,\n y: 0.921875,\n },\n {\n x: 0.265625,\n y: 0.921875,\n },\n {\n x: 0.296875,\n y: 0.921875,\n },\n {\n x: 0.296875,\n y: 0.921875,\n },\n {\n x: 0.328125,\n y: 0.921875,\n },\n {\n x: 0.328125,\n y: 0.921875,\n },\n {\n x: 0.359375,\n y: 0.921875,\n },\n {\n x: 0.359375,\n y: 0.921875,\n },\n {\n x: 0.390625,\n y: 0.921875,\n },\n {\n x: 0.390625,\n y: 0.921875,\n },\n {\n x: 0.421875,\n y: 0.921875,\n },\n {\n x: 0.421875,\n y: 0.921875,\n },\n {\n x: 0.453125,\n y: 0.921875,\n },\n {\n x: 0.453125,\n y: 0.921875,\n },\n {\n x: 0.484375,\n y: 0.921875,\n },\n {\n x: 0.484375,\n y: 0.921875,\n },\n {\n x: 0.515625,\n y: 0.921875,\n },\n {\n x: 0.515625,\n y: 0.921875,\n },\n {\n x: 0.546875,\n y: 0.921875,\n },\n {\n x: 0.546875,\n y: 0.921875,\n },\n {\n x: 0.578125,\n y: 0.921875,\n },\n {\n x: 0.578125,\n y: 0.921875,\n },\n {\n x: 0.609375,\n y: 0.921875,\n },\n {\n x: 0.609375,\n y: 0.921875,\n },\n {\n x: 0.640625,\n y: 0.921875,\n },\n {\n x: 0.640625,\n y: 0.921875,\n },\n {\n x: 0.671875,\n y: 0.921875,\n },\n {\n x: 0.671875,\n y: 0.921875,\n },\n {\n x: 0.703125,\n y: 0.921875,\n },\n {\n x: 0.703125,\n y: 0.921875,\n },\n {\n x: 0.734375,\n y: 0.921875,\n },\n {\n x: 0.734375,\n y: 0.921875,\n },\n {\n x: 0.765625,\n y: 0.921875,\n },\n {\n x: 0.765625,\n y: 0.921875,\n },\n {\n x: 0.796875,\n y: 0.921875,\n },\n {\n x: 0.796875,\n y: 0.921875,\n },\n {\n x: 0.828125,\n y: 0.921875,\n },\n {\n x: 0.828125,\n y: 0.921875,\n },\n {\n x: 0.859375,\n y: 0.921875,\n },\n {\n x: 0.859375,\n y: 0.921875,\n },\n {\n x: 0.890625,\n y: 0.921875,\n },\n {\n x: 0.890625,\n y: 0.921875,\n },\n {\n x: 0.921875,\n y: 0.921875,\n },\n {\n x: 0.921875,\n y: 0.921875,\n },\n {\n x: 0.953125,\n y: 0.921875,\n },\n {\n x: 0.953125,\n y: 0.921875,\n },\n {\n x: 0.984375,\n y: 0.921875,\n },\n {\n x: 0.984375,\n y: 0.921875,\n },\n {\n x: 0.015625,\n y: 0.953125,\n },\n {\n x: 0.015625,\n y: 0.953125,\n },\n {\n x: 0.046875,\n y: 0.953125,\n },\n {\n x: 0.046875,\n y: 0.953125,\n },\n {\n x: 0.078125,\n y: 0.953125,\n },\n {\n x: 0.078125,\n y: 0.953125,\n },\n {\n x: 0.109375,\n y: 0.953125,\n },\n {\n x: 0.109375,\n y: 0.953125,\n },\n {\n x: 0.140625,\n y: 0.953125,\n },\n {\n x: 0.140625,\n y: 0.953125,\n },\n {\n x: 0.171875,\n y: 0.953125,\n },\n {\n x: 0.171875,\n y: 0.953125,\n },\n {\n x: 0.203125,\n y: 0.953125,\n },\n {\n x: 0.203125,\n y: 0.953125,\n },\n {\n x: 0.234375,\n y: 0.953125,\n },\n {\n x: 0.234375,\n y: 0.953125,\n },\n {\n x: 0.265625,\n y: 0.953125,\n },\n {\n x: 0.265625,\n y: 0.953125,\n },\n {\n x: 0.296875,\n y: 0.953125,\n },\n {\n x: 0.296875,\n y: 0.953125,\n },\n {\n x: 0.328125,\n y: 0.953125,\n },\n {\n x: 0.328125,\n y: 0.953125,\n },\n {\n x: 0.359375,\n y: 0.953125,\n },\n {\n x: 0.359375,\n y: 0.953125,\n },\n {\n x: 0.390625,\n y: 0.953125,\n },\n {\n x: 0.390625,\n y: 0.953125,\n },\n {\n x: 0.421875,\n y: 0.953125,\n },\n {\n x: 0.421875,\n y: 0.953125,\n },\n {\n x: 0.453125,\n y: 0.953125,\n },\n {\n x: 0.453125,\n y: 0.953125,\n },\n {\n x: 0.484375,\n y: 0.953125,\n },\n {\n x: 0.484375,\n y: 0.953125,\n },\n {\n x: 0.515625,\n y: 0.953125,\n },\n {\n x: 0.515625,\n y: 0.953125,\n },\n {\n x: 0.546875,\n y: 0.953125,\n },\n {\n x: 0.546875,\n y: 0.953125,\n },\n {\n x: 0.578125,\n y: 0.953125,\n },\n {\n x: 0.578125,\n y: 0.953125,\n },\n {\n x: 0.609375,\n y: 0.953125,\n },\n {\n x: 0.609375,\n y: 0.953125,\n },\n {\n x: 0.640625,\n y: 0.953125,\n },\n {\n x: 0.640625,\n y: 0.953125,\n },\n {\n x: 0.671875,\n y: 0.953125,\n },\n {\n x: 0.671875,\n y: 0.953125,\n },\n {\n x: 0.703125,\n y: 0.953125,\n },\n {\n x: 0.703125,\n y: 0.953125,\n },\n {\n x: 0.734375,\n y: 0.953125,\n },\n {\n x: 0.734375,\n y: 0.953125,\n },\n {\n x: 0.765625,\n y: 0.953125,\n },\n {\n x: 0.765625,\n y: 0.953125,\n },\n {\n x: 0.796875,\n y: 0.953125,\n },\n {\n x: 0.796875,\n y: 0.953125,\n },\n {\n x: 0.828125,\n y: 0.953125,\n },\n {\n x: 0.828125,\n y: 0.953125,\n },\n {\n x: 0.859375,\n y: 0.953125,\n },\n {\n x: 0.859375,\n y: 0.953125,\n },\n {\n x: 0.890625,\n y: 0.953125,\n },\n {\n x: 0.890625,\n y: 0.953125,\n },\n {\n x: 0.921875,\n y: 0.953125,\n },\n {\n x: 0.921875,\n y: 0.953125,\n },\n {\n x: 0.953125,\n y: 0.953125,\n },\n {\n x: 0.953125,\n y: 0.953125,\n },\n {\n x: 0.984375,\n y: 0.953125,\n },\n {\n x: 0.984375,\n y: 0.953125,\n },\n {\n x: 0.015625,\n y: 0.984375,\n },\n {\n x: 0.015625,\n y: 0.984375,\n },\n {\n x: 0.046875,\n y: 0.984375,\n },\n {\n x: 0.046875,\n y: 0.984375,\n },\n {\n x: 0.078125,\n y: 0.984375,\n },\n {\n x: 0.078125,\n y: 0.984375,\n },\n {\n x: 0.109375,\n y: 0.984375,\n },\n {\n x: 0.109375,\n y: 0.984375,\n },\n {\n x: 0.140625,\n y: 0.984375,\n },\n {\n x: 0.140625,\n y: 0.984375,\n },\n {\n x: 0.171875,\n y: 0.984375,\n },\n {\n x: 0.171875,\n y: 0.984375,\n },\n {\n x: 0.203125,\n y: 0.984375,\n },\n {\n x: 0.203125,\n y: 0.984375,\n },\n {\n x: 0.234375,\n y: 0.984375,\n },\n {\n x: 0.234375,\n y: 0.984375,\n },\n {\n x: 0.265625,\n y: 0.984375,\n },\n {\n x: 0.265625,\n y: 0.984375,\n },\n {\n x: 0.296875,\n y: 0.984375,\n },\n {\n x: 0.296875,\n y: 0.984375,\n },\n {\n x: 0.328125,\n y: 0.984375,\n },\n {\n x: 0.328125,\n y: 0.984375,\n },\n {\n x: 0.359375,\n y: 0.984375,\n },\n {\n x: 0.359375,\n y: 0.984375,\n },\n {\n x: 0.390625,\n y: 0.984375,\n },\n {\n x: 0.390625,\n y: 0.984375,\n },\n {\n x: 0.421875,\n y: 0.984375,\n },\n {\n x: 0.421875,\n y: 0.984375,\n },\n {\n x: 0.453125,\n y: 0.984375,\n },\n {\n x: 0.453125,\n y: 0.984375,\n },\n {\n x: 0.484375,\n y: 0.984375,\n },\n {\n x: 0.484375,\n y: 0.984375,\n },\n {\n x: 0.515625,\n y: 0.984375,\n },\n {\n x: 0.515625,\n y: 0.984375,\n },\n {\n x: 0.546875,\n y: 0.984375,\n },\n {\n x: 0.546875,\n y: 0.984375,\n },\n {\n x: 0.578125,\n y: 0.984375,\n },\n {\n x: 0.578125,\n y: 0.984375,\n },\n {\n x: 0.609375,\n y: 0.984375,\n },\n {\n x: 0.609375,\n y: 0.984375,\n },\n {\n x: 0.640625,\n y: 0.984375,\n },\n {\n x: 0.640625,\n y: 0.984375,\n },\n {\n x: 0.671875,\n y: 0.984375,\n },\n {\n x: 0.671875,\n y: 0.984375,\n },\n {\n x: 0.703125,\n y: 0.984375,\n },\n {\n x: 0.703125,\n y: 0.984375,\n },\n {\n x: 0.734375,\n y: 0.984375,\n },\n {\n x: 0.734375,\n y: 0.984375,\n },\n {\n x: 0.765625,\n y: 0.984375,\n },\n {\n x: 0.765625,\n y: 0.984375,\n },\n {\n x: 0.796875,\n y: 0.984375,\n },\n {\n x: 0.796875,\n y: 0.984375,\n },\n {\n x: 0.828125,\n y: 0.984375,\n },\n {\n x: 0.828125,\n y: 0.984375,\n },\n {\n x: 0.859375,\n y: 0.984375,\n },\n {\n x: 0.859375,\n y: 0.984375,\n },\n {\n x: 0.890625,\n y: 0.984375,\n },\n {\n x: 0.890625,\n y: 0.984375,\n },\n {\n x: 0.921875,\n y: 0.984375,\n },\n {\n x: 0.921875,\n y: 0.984375,\n },\n {\n x: 0.953125,\n y: 0.984375,\n },\n {\n x: 0.953125,\n y: 0.984375,\n },\n {\n x: 0.984375,\n y: 0.984375,\n },\n {\n x: 0.984375,\n y: 0.984375,\n },\n {\n x: 0.03125,\n y: 0.03125,\n },\n {\n x: 0.03125,\n y: 0.03125,\n },\n {\n x: 0.09375,\n y: 0.03125,\n },\n {\n x: 0.09375,\n y: 0.03125,\n },\n {\n x: 0.15625,\n y: 0.03125,\n },\n {\n x: 0.15625,\n y: 0.03125,\n },\n {\n x: 0.21875,\n y: 0.03125,\n },\n {\n x: 0.21875,\n y: 0.03125,\n },\n {\n x: 0.28125,\n y: 0.03125,\n },\n {\n x: 0.28125,\n y: 0.03125,\n },\n {\n x: 0.34375,\n y: 0.03125,\n },\n {\n x: 0.34375,\n y: 0.03125,\n },\n {\n x: 0.40625,\n y: 0.03125,\n },\n {\n x: 0.40625,\n y: 0.03125,\n },\n {\n x: 0.46875,\n y: 0.03125,\n },\n {\n x: 0.46875,\n y: 0.03125,\n },\n {\n x: 0.53125,\n y: 0.03125,\n },\n {\n x: 0.53125,\n y: 0.03125,\n },\n {\n x: 0.59375,\n y: 0.03125,\n },\n {\n x: 0.59375,\n y: 0.03125,\n },\n {\n x: 0.65625,\n y: 0.03125,\n },\n {\n x: 0.65625,\n y: 0.03125,\n },\n {\n x: 0.71875,\n y: 0.03125,\n },\n {\n x: 0.71875,\n y: 0.03125,\n },\n {\n x: 0.78125,\n y: 0.03125,\n },\n {\n x: 0.78125,\n y: 0.03125,\n },\n {\n x: 0.84375,\n y: 0.03125,\n },\n {\n x: 0.84375,\n y: 0.03125,\n },\n {\n x: 0.90625,\n y: 0.03125,\n },\n {\n x: 0.90625,\n y: 0.03125,\n },\n {\n x: 0.96875,\n y: 0.03125,\n },\n {\n x: 0.96875,\n y: 0.03125,\n },\n {\n x: 0.03125,\n y: 0.09375,\n },\n {\n x: 0.03125,\n y: 0.09375,\n },\n {\n x: 0.09375,\n y: 0.09375,\n },\n {\n x: 0.09375,\n y: 0.09375,\n },\n {\n x: 0.15625,\n y: 0.09375,\n },\n {\n x: 0.15625,\n y: 0.09375,\n },\n {\n x: 0.21875,\n y: 0.09375,\n },\n {\n x: 0.21875,\n y: 0.09375,\n },\n {\n x: 0.28125,\n y: 0.09375,\n },\n {\n x: 0.28125,\n y: 0.09375,\n },\n {\n x: 0.34375,\n y: 0.09375,\n },\n {\n x: 0.34375,\n y: 0.09375,\n },\n {\n x: 0.40625,\n y: 0.09375,\n },\n {\n x: 0.40625,\n y: 0.09375,\n },\n {\n x: 0.46875,\n y: 0.09375,\n },\n {\n x: 0.46875,\n y: 0.09375,\n },\n {\n x: 0.53125,\n y: 0.09375,\n },\n {\n x: 0.53125,\n y: 0.09375,\n },\n {\n x: 0.59375,\n y: 0.09375,\n },\n {\n x: 0.59375,\n y: 0.09375,\n },\n {\n x: 0.65625,\n y: 0.09375,\n },\n {\n x: 0.65625,\n y: 0.09375,\n },\n {\n x: 0.71875,\n y: 0.09375,\n },\n {\n x: 0.71875,\n y: 0.09375,\n },\n {\n x: 0.78125,\n y: 0.09375,\n },\n {\n x: 0.78125,\n y: 0.09375,\n },\n {\n x: 0.84375,\n y: 0.09375,\n },\n {\n x: 0.84375,\n y: 0.09375,\n },\n {\n x: 0.90625,\n y: 0.09375,\n },\n {\n x: 0.90625,\n y: 0.09375,\n },\n {\n x: 0.96875,\n y: 0.09375,\n },\n {\n x: 0.96875,\n y: 0.09375,\n },\n {\n x: 0.03125,\n y: 0.15625,\n },\n {\n x: 0.03125,\n y: 0.15625,\n },\n {\n x: 0.09375,\n y: 0.15625,\n },\n {\n x: 0.09375,\n y: 0.15625,\n },\n {\n x: 0.15625,\n y: 0.15625,\n },\n {\n x: 0.15625,\n y: 0.15625,\n },\n {\n x: 0.21875,\n y: 0.15625,\n },\n {\n x: 0.21875,\n y: 0.15625,\n },\n {\n x: 0.28125,\n y: 0.15625,\n },\n {\n x: 0.28125,\n y: 0.15625,\n },\n {\n x: 0.34375,\n y: 0.15625,\n },\n {\n x: 0.34375,\n y: 0.15625,\n },\n {\n x: 0.40625,\n y: 0.15625,\n },\n {\n x: 0.40625,\n y: 0.15625,\n },\n {\n x: 0.46875,\n y: 0.15625,\n },\n {\n x: 0.46875,\n y: 0.15625,\n },\n {\n x: 0.53125,\n y: 0.15625,\n },\n {\n x: 0.53125,\n y: 0.15625,\n },\n {\n x: 0.59375,\n y: 0.15625,\n },\n {\n x: 0.59375,\n y: 0.15625,\n },\n {\n x: 0.65625,\n y: 0.15625,\n },\n {\n x: 0.65625,\n y: 0.15625,\n },\n {\n x: 0.71875,\n y: 0.15625,\n },\n {\n x: 0.71875,\n y: 0.15625,\n },\n {\n x: 0.78125,\n y: 0.15625,\n },\n {\n x: 0.78125,\n y: 0.15625,\n },\n {\n x: 0.84375,\n y: 0.15625,\n },\n {\n x: 0.84375,\n y: 0.15625,\n },\n {\n x: 0.90625,\n y: 0.15625,\n },\n {\n x: 0.90625,\n y: 0.15625,\n },\n {\n x: 0.96875,\n y: 0.15625,\n },\n {\n x: 0.96875,\n y: 0.15625,\n },\n {\n x: 0.03125,\n y: 0.21875,\n },\n {\n x: 0.03125,\n y: 0.21875,\n },\n {\n x: 0.09375,\n y: 0.21875,\n },\n {\n x: 0.09375,\n y: 0.21875,\n },\n {\n x: 0.15625,\n y: 0.21875,\n },\n {\n x: 0.15625,\n y: 0.21875,\n },\n {\n x: 0.21875,\n y: 0.21875,\n },\n {\n x: 0.21875,\n y: 0.21875,\n },\n {\n x: 0.28125,\n y: 0.21875,\n },\n {\n x: 0.28125,\n y: 0.21875,\n },\n {\n x: 0.34375,\n y: 0.21875,\n },\n {\n x: 0.34375,\n y: 0.21875,\n },\n {\n x: 0.40625,\n y: 0.21875,\n },\n {\n x: 0.40625,\n y: 0.21875,\n },\n {\n x: 0.46875,\n y: 0.21875,\n },\n {\n x: 0.46875,\n y: 0.21875,\n },\n {\n x: 0.53125,\n y: 0.21875,\n },\n {\n x: 0.53125,\n y: 0.21875,\n },\n {\n x: 0.59375,\n y: 0.21875,\n },\n {\n x: 0.59375,\n y: 0.21875,\n },\n {\n x: 0.65625,\n y: 0.21875,\n },\n {\n x: 0.65625,\n y: 0.21875,\n },\n {\n x: 0.71875,\n y: 0.21875,\n },\n {\n x: 0.71875,\n y: 0.21875,\n },\n {\n x: 0.78125,\n y: 0.21875,\n },\n {\n x: 0.78125,\n y: 0.21875,\n },\n {\n x: 0.84375,\n y: 0.21875,\n },\n {\n x: 0.84375,\n y: 0.21875,\n },\n {\n x: 0.90625,\n y: 0.21875,\n },\n {\n x: 0.90625,\n y: 0.21875,\n },\n {\n x: 0.96875,\n y: 0.21875,\n },\n {\n x: 0.96875,\n y: 0.21875,\n },\n {\n x: 0.03125,\n y: 0.28125,\n },\n {\n x: 0.03125,\n y: 0.28125,\n },\n {\n x: 0.09375,\n y: 0.28125,\n },\n {\n x: 0.09375,\n y: 0.28125,\n },\n {\n x: 0.15625,\n y: 0.28125,\n },\n {\n x: 0.15625,\n y: 0.28125,\n },\n {\n x: 0.21875,\n y: 0.28125,\n },\n {\n x: 0.21875,\n y: 0.28125,\n },\n {\n x: 0.28125,\n y: 0.28125,\n },\n {\n x: 0.28125,\n y: 0.28125,\n },\n {\n x: 0.34375,\n y: 0.28125,\n },\n {\n x: 0.34375,\n y: 0.28125,\n },\n {\n x: 0.40625,\n y: 0.28125,\n },\n {\n x: 0.40625,\n y: 0.28125,\n },\n {\n x: 0.46875,\n y: 0.28125,\n },\n {\n x: 0.46875,\n y: 0.28125,\n },\n {\n x: 0.53125,\n y: 0.28125,\n },\n {\n x: 0.53125,\n y: 0.28125,\n },\n {\n x: 0.59375,\n y: 0.28125,\n },\n {\n x: 0.59375,\n y: 0.28125,\n },\n {\n x: 0.65625,\n y: 0.28125,\n },\n {\n x: 0.65625,\n y: 0.28125,\n },\n {\n x: 0.71875,\n y: 0.28125,\n },\n {\n x: 0.71875,\n y: 0.28125,\n },\n {\n x: 0.78125,\n y: 0.28125,\n },\n {\n x: 0.78125,\n y: 0.28125,\n },\n {\n x: 0.84375,\n y: 0.28125,\n },\n {\n x: 0.84375,\n y: 0.28125,\n },\n {\n x: 0.90625,\n y: 0.28125,\n },\n {\n x: 0.90625,\n y: 0.28125,\n },\n {\n x: 0.96875,\n y: 0.28125,\n },\n {\n x: 0.96875,\n y: 0.28125,\n },\n {\n x: 0.03125,\n y: 0.34375,\n },\n {\n x: 0.03125,\n y: 0.34375,\n },\n {\n x: 0.09375,\n y: 0.34375,\n },\n {\n x: 0.09375,\n y: 0.34375,\n },\n {\n x: 0.15625,\n y: 0.34375,\n },\n {\n x: 0.15625,\n y: 0.34375,\n },\n {\n x: 0.21875,\n y: 0.34375,\n },\n {\n x: 0.21875,\n y: 0.34375,\n },\n {\n x: 0.28125,\n y: 0.34375,\n },\n {\n x: 0.28125,\n y: 0.34375,\n },\n {\n x: 0.34375,\n y: 0.34375,\n },\n {\n x: 0.34375,\n y: 0.34375,\n },\n {\n x: 0.40625,\n y: 0.34375,\n },\n {\n x: 0.40625,\n y: 0.34375,\n },\n {\n x: 0.46875,\n y: 0.34375,\n },\n {\n x: 0.46875,\n y: 0.34375,\n },\n {\n x: 0.53125,\n y: 0.34375,\n },\n {\n x: 0.53125,\n y: 0.34375,\n },\n {\n x: 0.59375,\n y: 0.34375,\n },\n {\n x: 0.59375,\n y: 0.34375,\n },\n {\n x: 0.65625,\n y: 0.34375,\n },\n {\n x: 0.65625,\n y: 0.34375,\n },\n {\n x: 0.71875,\n y: 0.34375,\n },\n {\n x: 0.71875,\n y: 0.34375,\n },\n {\n x: 0.78125,\n y: 0.34375,\n },\n {\n x: 0.78125,\n y: 0.34375,\n },\n {\n x: 0.84375,\n y: 0.34375,\n },\n {\n x: 0.84375,\n y: 0.34375,\n },\n {\n x: 0.90625,\n y: 0.34375,\n },\n {\n x: 0.90625,\n y: 0.34375,\n },\n {\n x: 0.96875,\n y: 0.34375,\n },\n {\n x: 0.96875,\n y: 0.34375,\n },\n {\n x: 0.03125,\n y: 0.40625,\n },\n {\n x: 0.03125,\n y: 0.40625,\n },\n {\n x: 0.09375,\n y: 0.40625,\n },\n {\n x: 0.09375,\n y: 0.40625,\n },\n {\n x: 0.15625,\n y: 0.40625,\n },\n {\n x: 0.15625,\n y: 0.40625,\n },\n {\n x: 0.21875,\n y: 0.40625,\n },\n {\n x: 0.21875,\n y: 0.40625,\n },\n {\n x: 0.28125,\n y: 0.40625,\n },\n {\n x: 0.28125,\n y: 0.40625,\n },\n {\n x: 0.34375,\n y: 0.40625,\n },\n {\n x: 0.34375,\n y: 0.40625,\n },\n {\n x: 0.40625,\n y: 0.40625,\n },\n {\n x: 0.40625,\n y: 0.40625,\n },\n {\n x: 0.46875,\n y: 0.40625,\n },\n {\n x: 0.46875,\n y: 0.40625,\n },\n {\n x: 0.53125,\n y: 0.40625,\n },\n {\n x: 0.53125,\n y: 0.40625,\n },\n {\n x: 0.59375,\n y: 0.40625,\n },\n {\n x: 0.59375,\n y: 0.40625,\n },\n {\n x: 0.65625,\n y: 0.40625,\n },\n {\n x: 0.65625,\n y: 0.40625,\n },\n {\n x: 0.71875,\n y: 0.40625,\n },\n {\n x: 0.71875,\n y: 0.40625,\n },\n {\n x: 0.78125,\n y: 0.40625,\n },\n {\n x: 0.78125,\n y: 0.40625,\n },\n {\n x: 0.84375,\n y: 0.40625,\n },\n {\n x: 0.84375,\n y: 0.40625,\n },\n {\n x: 0.90625,\n y: 0.40625,\n },\n {\n x: 0.90625,\n y: 0.40625,\n },\n {\n x: 0.96875,\n y: 0.40625,\n },\n {\n x: 0.96875,\n y: 0.40625,\n },\n {\n x: 0.03125,\n y: 0.46875,\n },\n {\n x: 0.03125,\n y: 0.46875,\n },\n {\n x: 0.09375,\n y: 0.46875,\n },\n {\n x: 0.09375,\n y: 0.46875,\n },\n {\n x: 0.15625,\n y: 0.46875,\n },\n {\n x: 0.15625,\n y: 0.46875,\n },\n {\n x: 0.21875,\n y: 0.46875,\n },\n {\n x: 0.21875,\n y: 0.46875,\n },\n {\n x: 0.28125,\n y: 0.46875,\n },\n {\n x: 0.28125,\n y: 0.46875,\n },\n {\n x: 0.34375,\n y: 0.46875,\n },\n {\n x: 0.34375,\n y: 0.46875,\n },\n {\n x: 0.40625,\n y: 0.46875,\n },\n {\n x: 0.40625,\n y: 0.46875,\n },\n {\n x: 0.46875,\n y: 0.46875,\n },\n {\n x: 0.46875,\n y: 0.46875,\n },\n {\n x: 0.53125,\n y: 0.46875,\n },\n {\n x: 0.53125,\n y: 0.46875,\n },\n {\n x: 0.59375,\n y: 0.46875,\n },\n {\n x: 0.59375,\n y: 0.46875,\n },\n {\n x: 0.65625,\n y: 0.46875,\n },\n {\n x: 0.65625,\n y: 0.46875,\n },\n {\n x: 0.71875,\n y: 0.46875,\n },\n {\n x: 0.71875,\n y: 0.46875,\n },\n {\n x: 0.78125,\n y: 0.46875,\n },\n {\n x: 0.78125,\n y: 0.46875,\n },\n {\n x: 0.84375,\n y: 0.46875,\n },\n {\n x: 0.84375,\n y: 0.46875,\n },\n {\n x: 0.90625,\n y: 0.46875,\n },\n {\n x: 0.90625,\n y: 0.46875,\n },\n {\n x: 0.96875,\n y: 0.46875,\n },\n {\n x: 0.96875,\n y: 0.46875,\n },\n {\n x: 0.03125,\n y: 0.53125,\n },\n {\n x: 0.03125,\n y: 0.53125,\n },\n {\n x: 0.09375,\n y: 0.53125,\n },\n {\n x: 0.09375,\n y: 0.53125,\n },\n {\n x: 0.15625,\n y: 0.53125,\n },\n {\n x: 0.15625,\n y: 0.53125,\n },\n {\n x: 0.21875,\n y: 0.53125,\n },\n {\n x: 0.21875,\n y: 0.53125,\n },\n {\n x: 0.28125,\n y: 0.53125,\n },\n {\n x: 0.28125,\n y: 0.53125,\n },\n {\n x: 0.34375,\n y: 0.53125,\n },\n {\n x: 0.34375,\n y: 0.53125,\n },\n {\n x: 0.40625,\n y: 0.53125,\n },\n {\n x: 0.40625,\n y: 0.53125,\n },\n {\n x: 0.46875,\n y: 0.53125,\n },\n {\n x: 0.46875,\n y: 0.53125,\n },\n {\n x: 0.53125,\n y: 0.53125,\n },\n {\n x: 0.53125,\n y: 0.53125,\n },\n {\n x: 0.59375,\n y: 0.53125,\n },\n {\n x: 0.59375,\n y: 0.53125,\n },\n {\n x: 0.65625,\n y: 0.53125,\n },\n {\n x: 0.65625,\n y: 0.53125,\n },\n {\n x: 0.71875,\n y: 0.53125,\n },\n {\n x: 0.71875,\n y: 0.53125,\n },\n {\n x: 0.78125,\n y: 0.53125,\n },\n {\n x: 0.78125,\n y: 0.53125,\n },\n {\n x: 0.84375,\n y: 0.53125,\n },\n {\n x: 0.84375,\n y: 0.53125,\n },\n {\n x: 0.90625,\n y: 0.53125,\n },\n {\n x: 0.90625,\n y: 0.53125,\n },\n {\n x: 0.96875,\n y: 0.53125,\n },\n {\n x: 0.96875,\n y: 0.53125,\n },\n {\n x: 0.03125,\n y: 0.59375,\n },\n {\n x: 0.03125,\n y: 0.59375,\n },\n {\n x: 0.09375,\n y: 0.59375,\n },\n {\n x: 0.09375,\n y: 0.59375,\n },\n {\n x: 0.15625,\n y: 0.59375,\n },\n {\n x: 0.15625,\n y: 0.59375,\n },\n {\n x: 0.21875,\n y: 0.59375,\n },\n {\n x: 0.21875,\n y: 0.59375,\n },\n {\n x: 0.28125,\n y: 0.59375,\n },\n {\n x: 0.28125,\n y: 0.59375,\n },\n {\n x: 0.34375,\n y: 0.59375,\n },\n {\n x: 0.34375,\n y: 0.59375,\n },\n {\n x: 0.40625,\n y: 0.59375,\n },\n {\n x: 0.40625,\n y: 0.59375,\n },\n {\n x: 0.46875,\n y: 0.59375,\n },\n {\n x: 0.46875,\n y: 0.59375,\n },\n {\n x: 0.53125,\n y: 0.59375,\n },\n {\n x: 0.53125,\n y: 0.59375,\n },\n {\n x: 0.59375,\n y: 0.59375,\n },\n {\n x: 0.59375,\n y: 0.59375,\n },\n {\n x: 0.65625,\n y: 0.59375,\n },\n {\n x: 0.65625,\n y: 0.59375,\n },\n {\n x: 0.71875,\n y: 0.59375,\n },\n {\n x: 0.71875,\n y: 0.59375,\n },\n {\n x: 0.78125,\n y: 0.59375,\n },\n {\n x: 0.78125,\n y: 0.59375,\n },\n {\n x: 0.84375,\n y: 0.59375,\n },\n {\n x: 0.84375,\n y: 0.59375,\n },\n {\n x: 0.90625,\n y: 0.59375,\n },\n {\n x: 0.90625,\n y: 0.59375,\n },\n {\n x: 0.96875,\n y: 0.59375,\n },\n {\n x: 0.96875,\n y: 0.59375,\n },\n {\n x: 0.03125,\n y: 0.65625,\n },\n {\n x: 0.03125,\n y: 0.65625,\n },\n {\n x: 0.09375,\n y: 0.65625,\n },\n {\n x: 0.09375,\n y: 0.65625,\n },\n {\n x: 0.15625,\n y: 0.65625,\n },\n {\n x: 0.15625,\n y: 0.65625,\n },\n {\n x: 0.21875,\n y: 0.65625,\n },\n {\n x: 0.21875,\n y: 0.65625,\n },\n {\n x: 0.28125,\n y: 0.65625,\n },\n {\n x: 0.28125,\n y: 0.65625,\n },\n {\n x: 0.34375,\n y: 0.65625,\n },\n {\n x: 0.34375,\n y: 0.65625,\n },\n {\n x: 0.40625,\n y: 0.65625,\n },\n {\n x: 0.40625,\n y: 0.65625,\n },\n {\n x: 0.46875,\n y: 0.65625,\n },\n {\n x: 0.46875,\n y: 0.65625,\n },\n {\n x: 0.53125,\n y: 0.65625,\n },\n {\n x: 0.53125,\n y: 0.65625,\n },\n {\n x: 0.59375,\n y: 0.65625,\n },\n {\n x: 0.59375,\n y: 0.65625,\n },\n {\n x: 0.65625,\n y: 0.65625,\n },\n {\n x: 0.65625,\n y: 0.65625,\n },\n {\n x: 0.71875,\n y: 0.65625,\n },\n {\n x: 0.71875,\n y: 0.65625,\n },\n {\n x: 0.78125,\n y: 0.65625,\n },\n {\n x: 0.78125,\n y: 0.65625,\n },\n {\n x: 0.84375,\n y: 0.65625,\n },\n {\n x: 0.84375,\n y: 0.65625,\n },\n {\n x: 0.90625,\n y: 0.65625,\n },\n {\n x: 0.90625,\n y: 0.65625,\n },\n {\n x: 0.96875,\n y: 0.65625,\n },\n {\n x: 0.96875,\n y: 0.65625,\n },\n {\n x: 0.03125,\n y: 0.71875,\n },\n {\n x: 0.03125,\n y: 0.71875,\n },\n {\n x: 0.09375,\n y: 0.71875,\n },\n {\n x: 0.09375,\n y: 0.71875,\n },\n {\n x: 0.15625,\n y: 0.71875,\n },\n {\n x: 0.15625,\n y: 0.71875,\n },\n {\n x: 0.21875,\n y: 0.71875,\n },\n {\n x: 0.21875,\n y: 0.71875,\n },\n {\n x: 0.28125,\n y: 0.71875,\n },\n {\n x: 0.28125,\n y: 0.71875,\n },\n {\n x: 0.34375,\n y: 0.71875,\n },\n {\n x: 0.34375,\n y: 0.71875,\n },\n {\n x: 0.40625,\n y: 0.71875,\n },\n {\n x: 0.40625,\n y: 0.71875,\n },\n {\n x: 0.46875,\n y: 0.71875,\n },\n {\n x: 0.46875,\n y: 0.71875,\n },\n {\n x: 0.53125,\n y: 0.71875,\n },\n {\n x: 0.53125,\n y: 0.71875,\n },\n {\n x: 0.59375,\n y: 0.71875,\n },\n {\n x: 0.59375,\n y: 0.71875,\n },\n {\n x: 0.65625,\n y: 0.71875,\n },\n {\n x: 0.65625,\n y: 0.71875,\n },\n {\n x: 0.71875,\n y: 0.71875,\n },\n {\n x: 0.71875,\n y: 0.71875,\n },\n {\n x: 0.78125,\n y: 0.71875,\n },\n {\n x: 0.78125,\n y: 0.71875,\n },\n {\n x: 0.84375,\n y: 0.71875,\n },\n {\n x: 0.84375,\n y: 0.71875,\n },\n {\n x: 0.90625,\n y: 0.71875,\n },\n {\n x: 0.90625,\n y: 0.71875,\n },\n {\n x: 0.96875,\n y: 0.71875,\n },\n {\n x: 0.96875,\n y: 0.71875,\n },\n {\n x: 0.03125,\n y: 0.78125,\n },\n {\n x: 0.03125,\n y: 0.78125,\n },\n {\n x: 0.09375,\n y: 0.78125,\n },\n {\n x: 0.09375,\n y: 0.78125,\n },\n {\n x: 0.15625,\n y: 0.78125,\n },\n {\n x: 0.15625,\n y: 0.78125,\n },\n {\n x: 0.21875,\n y: 0.78125,\n },\n {\n x: 0.21875,\n y: 0.78125,\n },\n {\n x: 0.28125,\n y: 0.78125,\n },\n {\n x: 0.28125,\n y: 0.78125,\n },\n {\n x: 0.34375,\n y: 0.78125,\n },\n {\n x: 0.34375,\n y: 0.78125,\n },\n {\n x: 0.40625,\n y: 0.78125,\n },\n {\n x: 0.40625,\n y: 0.78125,\n },\n {\n x: 0.46875,\n y: 0.78125,\n },\n {\n x: 0.46875,\n y: 0.78125,\n },\n {\n x: 0.53125,\n y: 0.78125,\n },\n {\n x: 0.53125,\n y: 0.78125,\n },\n {\n x: 0.59375,\n y: 0.78125,\n },\n {\n x: 0.59375,\n y: 0.78125,\n },\n {\n x: 0.65625,\n y: 0.78125,\n },\n {\n x: 0.65625,\n y: 0.78125,\n },\n {\n x: 0.71875,\n y: 0.78125,\n },\n {\n x: 0.71875,\n y: 0.78125,\n },\n {\n x: 0.78125,\n y: 0.78125,\n },\n {\n x: 0.78125,\n y: 0.78125,\n },\n {\n x: 0.84375,\n y: 0.78125,\n },\n {\n x: 0.84375,\n y: 0.78125,\n },\n {\n x: 0.90625,\n y: 0.78125,\n },\n {\n x: 0.90625,\n y: 0.78125,\n },\n {\n x: 0.96875,\n y: 0.78125,\n },\n {\n x: 0.96875,\n y: 0.78125,\n },\n {\n x: 0.03125,\n y: 0.84375,\n },\n {\n x: 0.03125,\n y: 0.84375,\n },\n {\n x: 0.09375,\n y: 0.84375,\n },\n {\n x: 0.09375,\n y: 0.84375,\n },\n {\n x: 0.15625,\n y: 0.84375,\n },\n {\n x: 0.15625,\n y: 0.84375,\n },\n {\n x: 0.21875,\n y: 0.84375,\n },\n {\n x: 0.21875,\n y: 0.84375,\n },\n {\n x: 0.28125,\n y: 0.84375,\n },\n {\n x: 0.28125,\n y: 0.84375,\n },\n {\n x: 0.34375,\n y: 0.84375,\n },\n {\n x: 0.34375,\n y: 0.84375,\n },\n {\n x: 0.40625,\n y: 0.84375,\n },\n {\n x: 0.40625,\n y: 0.84375,\n },\n {\n x: 0.46875,\n y: 0.84375,\n },\n {\n x: 0.46875,\n y: 0.84375,\n },\n {\n x: 0.53125,\n y: 0.84375,\n },\n {\n x: 0.53125,\n y: 0.84375,\n },\n {\n x: 0.59375,\n y: 0.84375,\n },\n {\n x: 0.59375,\n y: 0.84375,\n },\n {\n x: 0.65625,\n y: 0.84375,\n },\n {\n x: 0.65625,\n y: 0.84375,\n },\n {\n x: 0.71875,\n y: 0.84375,\n },\n {\n x: 0.71875,\n y: 0.84375,\n },\n {\n x: 0.78125,\n y: 0.84375,\n },\n {\n x: 0.78125,\n y: 0.84375,\n },\n {\n x: 0.84375,\n y: 0.84375,\n },\n {\n x: 0.84375,\n y: 0.84375,\n },\n {\n x: 0.90625,\n y: 0.84375,\n },\n {\n x: 0.90625,\n y: 0.84375,\n },\n {\n x: 0.96875,\n y: 0.84375,\n },\n {\n x: 0.96875,\n y: 0.84375,\n },\n {\n x: 0.03125,\n y: 0.90625,\n },\n {\n x: 0.03125,\n y: 0.90625,\n },\n {\n x: 0.09375,\n y: 0.90625,\n },\n {\n x: 0.09375,\n y: 0.90625,\n },\n {\n x: 0.15625,\n y: 0.90625,\n },\n {\n x: 0.15625,\n y: 0.90625,\n },\n {\n x: 0.21875,\n y: 0.90625,\n },\n {\n x: 0.21875,\n y: 0.90625,\n },\n {\n x: 0.28125,\n y: 0.90625,\n },\n {\n x: 0.28125,\n y: 0.90625,\n },\n {\n x: 0.34375,\n y: 0.90625,\n },\n {\n x: 0.34375,\n y: 0.90625,\n },\n {\n x: 0.40625,\n y: 0.90625,\n },\n {\n x: 0.40625,\n y: 0.90625,\n },\n {\n x: 0.46875,\n y: 0.90625,\n },\n {\n x: 0.46875,\n y: 0.90625,\n },\n {\n x: 0.53125,\n y: 0.90625,\n },\n {\n x: 0.53125,\n y: 0.90625,\n },\n {\n x: 0.59375,\n y: 0.90625,\n },\n {\n x: 0.59375,\n y: 0.90625,\n },\n {\n x: 0.65625,\n y: 0.90625,\n },\n {\n x: 0.65625,\n y: 0.90625,\n },\n {\n x: 0.71875,\n y: 0.90625,\n },\n {\n x: 0.71875,\n y: 0.90625,\n },\n {\n x: 0.78125,\n y: 0.90625,\n },\n {\n x: 0.78125,\n y: 0.90625,\n },\n {\n x: 0.84375,\n y: 0.90625,\n },\n {\n x: 0.84375,\n y: 0.90625,\n },\n {\n x: 0.90625,\n y: 0.90625,\n },\n {\n x: 0.90625,\n y: 0.90625,\n },\n {\n x: 0.96875,\n y: 0.90625,\n },\n {\n x: 0.96875,\n y: 0.90625,\n },\n {\n x: 0.03125,\n y: 0.96875,\n },\n {\n x: 0.03125,\n y: 0.96875,\n },\n {\n x: 0.09375,\n y: 0.96875,\n },\n {\n x: 0.09375,\n y: 0.96875,\n },\n {\n x: 0.15625,\n y: 0.96875,\n },\n {\n x: 0.15625,\n y: 0.96875,\n },\n {\n x: 0.21875,\n y: 0.96875,\n },\n {\n x: 0.21875,\n y: 0.96875,\n },\n {\n x: 0.28125,\n y: 0.96875,\n },\n {\n x: 0.28125,\n y: 0.96875,\n },\n {\n x: 0.34375,\n y: 0.96875,\n },\n {\n x: 0.34375,\n y: 0.96875,\n },\n {\n x: 0.40625,\n y: 0.96875,\n },\n {\n x: 0.40625,\n y: 0.96875,\n },\n {\n x: 0.46875,\n y: 0.96875,\n },\n {\n x: 0.46875,\n y: 0.96875,\n },\n {\n x: 0.53125,\n y: 0.96875,\n },\n {\n x: 0.53125,\n y: 0.96875,\n },\n {\n x: 0.59375,\n y: 0.96875,\n },\n {\n x: 0.59375,\n y: 0.96875,\n },\n {\n x: 0.65625,\n y: 0.96875,\n },\n {\n x: 0.65625,\n y: 0.96875,\n },\n {\n x: 0.71875,\n y: 0.96875,\n },\n {\n x: 0.71875,\n y: 0.96875,\n },\n {\n x: 0.78125,\n y: 0.96875,\n },\n {\n x: 0.78125,\n y: 0.96875,\n },\n {\n x: 0.84375,\n y: 0.96875,\n },\n {\n x: 0.84375,\n y: 0.96875,\n },\n {\n x: 0.90625,\n y: 0.96875,\n },\n {\n x: 0.90625,\n y: 0.96875,\n },\n {\n x: 0.96875,\n y: 0.96875,\n },\n {\n x: 0.96875,\n y: 0.96875,\n },\n {\n x: 0.0625,\n y: 0.0625,\n },\n {\n x: 0.0625,\n y: 0.0625,\n },\n {\n x: 0.0625,\n y: 0.0625,\n },\n {\n x: 0.0625,\n y: 0.0625,\n },\n {\n x: 0.0625,\n y: 0.0625,\n },\n {\n x: 0.0625,\n y: 0.0625,\n },\n {\n x: 0.1875,\n y: 0.0625,\n },\n {\n x: 0.1875,\n y: 0.0625,\n },\n {\n x: 0.1875,\n y: 0.0625,\n },\n {\n x: 0.1875,\n y: 0.0625,\n },\n {\n x: 0.1875,\n y: 0.0625,\n },\n {\n x: 0.1875,\n y: 0.0625,\n },\n {\n x: 0.3125,\n y: 0.0625,\n },\n {\n x: 0.3125,\n y: 0.0625,\n },\n {\n x: 0.3125,\n y: 0.0625,\n },\n {\n x: 0.3125,\n y: 0.0625,\n },\n {\n x: 0.3125,\n y: 0.0625,\n },\n {\n x: 0.3125,\n y: 0.0625,\n },\n {\n x: 0.4375,\n y: 0.0625,\n },\n {\n x: 0.4375,\n y: 0.0625,\n },\n {\n x: 0.4375,\n y: 0.0625,\n },\n {\n x: 0.4375,\n y: 0.0625,\n },\n {\n x: 0.4375,\n y: 0.0625,\n },\n {\n x: 0.4375,\n y: 0.0625,\n },\n {\n x: 0.5625,\n y: 0.0625,\n },\n {\n x: 0.5625,\n y: 0.0625,\n },\n {\n x: 0.5625,\n y: 0.0625,\n },\n {\n x: 0.5625,\n y: 0.0625,\n },\n {\n x: 0.5625,\n y: 0.0625,\n },\n {\n x: 0.5625,\n y: 0.0625,\n },\n {\n x: 0.6875,\n y: 0.0625,\n },\n {\n x: 0.6875,\n y: 0.0625,\n },\n {\n x: 0.6875,\n y: 0.0625,\n },\n {\n x: 0.6875,\n y: 0.0625,\n },\n {\n x: 0.6875,\n y: 0.0625,\n },\n {\n x: 0.6875,\n y: 0.0625,\n },\n {\n x: 0.8125,\n y: 0.0625,\n },\n {\n x: 0.8125,\n y: 0.0625,\n },\n {\n x: 0.8125,\n y: 0.0625,\n },\n {\n x: 0.8125,\n y: 0.0625,\n },\n {\n x: 0.8125,\n y: 0.0625,\n },\n {\n x: 0.8125,\n y: 0.0625,\n },\n {\n x: 0.9375,\n y: 0.0625,\n },\n {\n x: 0.9375,\n y: 0.0625,\n },\n {\n x: 0.9375,\n y: 0.0625,\n },\n {\n x: 0.9375,\n y: 0.0625,\n },\n {\n x: 0.9375,\n y: 0.0625,\n },\n {\n x: 0.9375,\n y: 0.0625,\n },\n {\n x: 0.0625,\n y: 0.1875,\n },\n {\n x: 0.0625,\n y: 0.1875,\n },\n {\n x: 0.0625,\n y: 0.1875,\n },\n {\n x: 0.0625,\n y: 0.1875,\n },\n {\n x: 0.0625,\n y: 0.1875,\n },\n {\n x: 0.0625,\n y: 0.1875,\n },\n {\n x: 0.1875,\n y: 0.1875,\n },\n {\n x: 0.1875,\n y: 0.1875,\n },\n {\n x: 0.1875,\n y: 0.1875,\n },\n {\n x: 0.1875,\n y: 0.1875,\n },\n {\n x: 0.1875,\n y: 0.1875,\n },\n {\n x: 0.1875,\n y: 0.1875,\n },\n {\n x: 0.3125,\n y: 0.1875,\n },\n {\n x: 0.3125,\n y: 0.1875,\n },\n {\n x: 0.3125,\n y: 0.1875,\n },\n {\n x: 0.3125,\n y: 0.1875,\n },\n {\n x: 0.3125,\n y: 0.1875,\n },\n {\n x: 0.3125,\n y: 0.1875,\n },\n {\n x: 0.4375,\n y: 0.1875,\n },\n {\n x: 0.4375,\n y: 0.1875,\n },\n {\n x: 0.4375,\n y: 0.1875,\n },\n {\n x: 0.4375,\n y: 0.1875,\n },\n {\n x: 0.4375,\n y: 0.1875,\n },\n {\n x: 0.4375,\n y: 0.1875,\n },\n {\n x: 0.5625,\n y: 0.1875,\n },\n {\n x: 0.5625,\n y: 0.1875,\n },\n {\n x: 0.5625,\n y: 0.1875,\n },\n {\n x: 0.5625,\n y: 0.1875,\n },\n {\n x: 0.5625,\n y: 0.1875,\n },\n {\n x: 0.5625,\n y: 0.1875,\n },\n {\n x: 0.6875,\n y: 0.1875,\n },\n {\n x: 0.6875,\n y: 0.1875,\n },\n {\n x: 0.6875,\n y: 0.1875,\n },\n {\n x: 0.6875,\n y: 0.1875,\n },\n {\n x: 0.6875,\n y: 0.1875,\n },\n {\n x: 0.6875,\n y: 0.1875,\n },\n {\n x: 0.8125,\n y: 0.1875,\n },\n {\n x: 0.8125,\n y: 0.1875,\n },\n {\n x: 0.8125,\n y: 0.1875,\n },\n {\n x: 0.8125,\n y: 0.1875,\n },\n {\n x: 0.8125,\n y: 0.1875,\n },\n {\n x: 0.8125,\n y: 0.1875,\n },\n {\n x: 0.9375,\n y: 0.1875,\n },\n {\n x: 0.9375,\n y: 0.1875,\n },\n {\n x: 0.9375,\n y: 0.1875,\n },\n {\n x: 0.9375,\n y: 0.1875,\n },\n {\n x: 0.9375,\n y: 0.1875,\n },\n {\n x: 0.9375,\n y: 0.1875,\n },\n {\n x: 0.0625,\n y: 0.3125,\n },\n {\n x: 0.0625,\n y: 0.3125,\n },\n {\n x: 0.0625,\n y: 0.3125,\n },\n {\n x: 0.0625,\n y: 0.3125,\n },\n {\n x: 0.0625,\n y: 0.3125,\n },\n {\n x: 0.0625,\n y: 0.3125,\n },\n {\n x: 0.1875,\n y: 0.3125,\n },\n {\n x: 0.1875,\n y: 0.3125,\n },\n {\n x: 0.1875,\n y: 0.3125,\n },\n {\n x: 0.1875,\n y: 0.3125,\n },\n {\n x: 0.1875,\n y: 0.3125,\n },\n {\n x: 0.1875,\n y: 0.3125,\n },\n {\n x: 0.3125,\n y: 0.3125,\n },\n {\n x: 0.3125,\n y: 0.3125,\n },\n {\n x: 0.3125,\n y: 0.3125,\n },\n {\n x: 0.3125,\n y: 0.3125,\n },\n {\n x: 0.3125,\n y: 0.3125,\n },\n {\n x: 0.3125,\n y: 0.3125,\n },\n {\n x: 0.4375,\n y: 0.3125,\n },\n {\n x: 0.4375,\n y: 0.3125,\n },\n {\n x: 0.4375,\n y: 0.3125,\n },\n {\n x: 0.4375,\n y: 0.3125,\n },\n {\n x: 0.4375,\n y: 0.3125,\n },\n {\n x: 0.4375,\n y: 0.3125,\n },\n {\n x: 0.5625,\n y: 0.3125,\n },\n {\n x: 0.5625,\n y: 0.3125,\n },\n {\n x: 0.5625,\n y: 0.3125,\n },\n {\n x: 0.5625,\n y: 0.3125,\n },\n {\n x: 0.5625,\n y: 0.3125,\n },\n {\n x: 0.5625,\n y: 0.3125,\n },\n {\n x: 0.6875,\n y: 0.3125,\n },\n {\n x: 0.6875,\n y: 0.3125,\n },\n {\n x: 0.6875,\n y: 0.3125,\n },\n {\n x: 0.6875,\n y: 0.3125,\n },\n {\n x: 0.6875,\n y: 0.3125,\n },\n {\n x: 0.6875,\n y: 0.3125,\n },\n {\n x: 0.8125,\n y: 0.3125,\n },\n {\n x: 0.8125,\n y: 0.3125,\n },\n {\n x: 0.8125,\n y: 0.3125,\n },\n {\n x: 0.8125,\n y: 0.3125,\n },\n {\n x: 0.8125,\n y: 0.3125,\n },\n {\n x: 0.8125,\n y: 0.3125,\n },\n {\n x: 0.9375,\n y: 0.3125,\n },\n {\n x: 0.9375,\n y: 0.3125,\n },\n {\n x: 0.9375,\n y: 0.3125,\n },\n {\n x: 0.9375,\n y: 0.3125,\n },\n {\n x: 0.9375,\n y: 0.3125,\n },\n {\n x: 0.9375,\n y: 0.3125,\n },\n {\n x: 0.0625,\n y: 0.4375,\n },\n {\n x: 0.0625,\n y: 0.4375,\n },\n {\n x: 0.0625,\n y: 0.4375,\n },\n {\n x: 0.0625,\n y: 0.4375,\n },\n {\n x: 0.0625,\n y: 0.4375,\n },\n {\n x: 0.0625,\n y: 0.4375,\n },\n {\n x: 0.1875,\n y: 0.4375,\n },\n {\n x: 0.1875,\n y: 0.4375,\n },\n {\n x: 0.1875,\n y: 0.4375,\n },\n {\n x: 0.1875,\n y: 0.4375,\n },\n {\n x: 0.1875,\n y: 0.4375,\n },\n {\n x: 0.1875,\n y: 0.4375,\n },\n {\n x: 0.3125,\n y: 0.4375,\n },\n {\n x: 0.3125,\n y: 0.4375,\n },\n {\n x: 0.3125,\n y: 0.4375,\n },\n {\n x: 0.3125,\n y: 0.4375,\n },\n {\n x: 0.3125,\n y: 0.4375,\n },\n {\n x: 0.3125,\n y: 0.4375,\n },\n {\n x: 0.4375,\n y: 0.4375,\n },\n {\n x: 0.4375,\n y: 0.4375,\n },\n {\n x: 0.4375,\n y: 0.4375,\n },\n {\n x: 0.4375,\n y: 0.4375,\n },\n {\n x: 0.4375,\n y: 0.4375,\n },\n {\n x: 0.4375,\n y: 0.4375,\n },\n {\n x: 0.5625,\n y: 0.4375,\n },\n {\n x: 0.5625,\n y: 0.4375,\n },\n {\n x: 0.5625,\n y: 0.4375,\n },\n {\n x: 0.5625,\n y: 0.4375,\n },\n {\n x: 0.5625,\n y: 0.4375,\n },\n {\n x: 0.5625,\n y: 0.4375,\n },\n {\n x: 0.6875,\n y: 0.4375,\n },\n {\n x: 0.6875,\n y: 0.4375,\n },\n {\n x: 0.6875,\n y: 0.4375,\n },\n {\n x: 0.6875,\n y: 0.4375,\n },\n {\n x: 0.6875,\n y: 0.4375,\n },\n {\n x: 0.6875,\n y: 0.4375,\n },\n {\n x: 0.8125,\n y: 0.4375,\n },\n {\n x: 0.8125,\n y: 0.4375,\n },\n {\n x: 0.8125,\n y: 0.4375,\n },\n {\n x: 0.8125,\n y: 0.4375,\n },\n {\n x: 0.8125,\n y: 0.4375,\n },\n {\n x: 0.8125,\n y: 0.4375,\n },\n {\n x: 0.9375,\n y: 0.4375,\n },\n {\n x: 0.9375,\n y: 0.4375,\n },\n {\n x: 0.9375,\n y: 0.4375,\n },\n {\n x: 0.9375,\n y: 0.4375,\n },\n {\n x: 0.9375,\n y: 0.4375,\n },\n {\n x: 0.9375,\n y: 0.4375,\n },\n {\n x: 0.0625,\n y: 0.5625,\n },\n {\n x: 0.0625,\n y: 0.5625,\n },\n {\n x: 0.0625,\n y: 0.5625,\n },\n {\n x: 0.0625,\n y: 0.5625,\n },\n {\n x: 0.0625,\n y: 0.5625,\n },\n {\n x: 0.0625,\n y: 0.5625,\n },\n {\n x: 0.1875,\n y: 0.5625,\n },\n {\n x: 0.1875,\n y: 0.5625,\n },\n {\n x: 0.1875,\n y: 0.5625,\n },\n {\n x: 0.1875,\n y: 0.5625,\n },\n {\n x: 0.1875,\n y: 0.5625,\n },\n {\n x: 0.1875,\n y: 0.5625,\n },\n {\n x: 0.3125,\n y: 0.5625,\n },\n {\n x: 0.3125,\n y: 0.5625,\n },\n {\n x: 0.3125,\n y: 0.5625,\n },\n {\n x: 0.3125,\n y: 0.5625,\n },\n {\n x: 0.3125,\n y: 0.5625,\n },\n {\n x: 0.3125,\n y: 0.5625,\n },\n {\n x: 0.4375,\n y: 0.5625,\n },\n {\n x: 0.4375,\n y: 0.5625,\n },\n {\n x: 0.4375,\n y: 0.5625,\n },\n {\n x: 0.4375,\n y: 0.5625,\n },\n {\n x: 0.4375,\n y: 0.5625,\n },\n {\n x: 0.4375,\n y: 0.5625,\n },\n {\n x: 0.5625,\n y: 0.5625,\n },\n {\n x: 0.5625,\n y: 0.5625,\n },\n {\n x: 0.5625,\n y: 0.5625,\n },\n {\n x: 0.5625,\n y: 0.5625,\n },\n {\n x: 0.5625,\n y: 0.5625,\n },\n {\n x: 0.5625,\n y: 0.5625,\n },\n {\n x: 0.6875,\n y: 0.5625,\n },\n {\n x: 0.6875,\n y: 0.5625,\n },\n {\n x: 0.6875,\n y: 0.5625,\n },\n {\n x: 0.6875,\n y: 0.5625,\n },\n {\n x: 0.6875,\n y: 0.5625,\n },\n {\n x: 0.6875,\n y: 0.5625,\n },\n {\n x: 0.8125,\n y: 0.5625,\n },\n {\n x: 0.8125,\n y: 0.5625,\n },\n {\n x: 0.8125,\n y: 0.5625,\n },\n {\n x: 0.8125,\n y: 0.5625,\n },\n {\n x: 0.8125,\n y: 0.5625,\n },\n {\n x: 0.8125,\n y: 0.5625,\n },\n {\n x: 0.9375,\n y: 0.5625,\n },\n {\n x: 0.9375,\n y: 0.5625,\n },\n {\n x: 0.9375,\n y: 0.5625,\n },\n {\n x: 0.9375,\n y: 0.5625,\n },\n {\n x: 0.9375,\n y: 0.5625,\n },\n {\n x: 0.9375,\n y: 0.5625,\n },\n {\n x: 0.0625,\n y: 0.6875,\n },\n {\n x: 0.0625,\n y: 0.6875,\n },\n {\n x: 0.0625,\n y: 0.6875,\n },\n {\n x: 0.0625,\n y: 0.6875,\n },\n {\n x: 0.0625,\n y: 0.6875,\n },\n {\n x: 0.0625,\n y: 0.6875,\n },\n {\n x: 0.1875,\n y: 0.6875,\n },\n {\n x: 0.1875,\n y: 0.6875,\n },\n {\n x: 0.1875,\n y: 0.6875,\n },\n {\n x: 0.1875,\n y: 0.6875,\n },\n {\n x: 0.1875,\n y: 0.6875,\n },\n {\n x: 0.1875,\n y: 0.6875,\n },\n {\n x: 0.3125,\n y: 0.6875,\n },\n {\n x: 0.3125,\n y: 0.6875,\n },\n {\n x: 0.3125,\n y: 0.6875,\n },\n {\n x: 0.3125,\n y: 0.6875,\n },\n {\n x: 0.3125,\n y: 0.6875,\n },\n {\n x: 0.3125,\n y: 0.6875,\n },\n {\n x: 0.4375,\n y: 0.6875,\n },\n {\n x: 0.4375,\n y: 0.6875,\n },\n {\n x: 0.4375,\n y: 0.6875,\n },\n {\n x: 0.4375,\n y: 0.6875,\n },\n {\n x: 0.4375,\n y: 0.6875,\n },\n {\n x: 0.4375,\n y: 0.6875,\n },\n {\n x: 0.5625,\n y: 0.6875,\n },\n {\n x: 0.5625,\n y: 0.6875,\n },\n {\n x: 0.5625,\n y: 0.6875,\n },\n {\n x: 0.5625,\n y: 0.6875,\n },\n {\n x: 0.5625,\n y: 0.6875,\n },\n {\n x: 0.5625,\n y: 0.6875,\n },\n {\n x: 0.6875,\n y: 0.6875,\n },\n {\n x: 0.6875,\n y: 0.6875,\n },\n {\n x: 0.6875,\n y: 0.6875,\n },\n {\n x: 0.6875,\n y: 0.6875,\n },\n {\n x: 0.6875,\n y: 0.6875,\n },\n {\n x: 0.6875,\n y: 0.6875,\n },\n {\n x: 0.8125,\n y: 0.6875,\n },\n {\n x: 0.8125,\n y: 0.6875,\n },\n {\n x: 0.8125,\n y: 0.6875,\n },\n {\n x: 0.8125,\n y: 0.6875,\n },\n {\n x: 0.8125,\n y: 0.6875,\n },\n {\n x: 0.8125,\n y: 0.6875,\n },\n {\n x: 0.9375,\n y: 0.6875,\n },\n {\n x: 0.9375,\n y: 0.6875,\n },\n {\n x: 0.9375,\n y: 0.6875,\n },\n {\n x: 0.9375,\n y: 0.6875,\n },\n {\n x: 0.9375,\n y: 0.6875,\n },\n {\n x: 0.9375,\n y: 0.6875,\n },\n {\n x: 0.0625,\n y: 0.8125,\n },\n {\n x: 0.0625,\n y: 0.8125,\n },\n {\n x: 0.0625,\n y: 0.8125,\n },\n {\n x: 0.0625,\n y: 0.8125,\n },\n {\n x: 0.0625,\n y: 0.8125,\n },\n {\n x: 0.0625,\n y: 0.8125,\n },\n {\n x: 0.1875,\n y: 0.8125,\n },\n {\n x: 0.1875,\n y: 0.8125,\n },\n {\n x: 0.1875,\n y: 0.8125,\n },\n {\n x: 0.1875,\n y: 0.8125,\n },\n {\n x: 0.1875,\n y: 0.8125,\n },\n {\n x: 0.1875,\n y: 0.8125,\n },\n {\n x: 0.3125,\n y: 0.8125,\n },\n {\n x: 0.3125,\n y: 0.8125,\n },\n {\n x: 0.3125,\n y: 0.8125,\n },\n {\n x: 0.3125,\n y: 0.8125,\n },\n {\n x: 0.3125,\n y: 0.8125,\n },\n {\n x: 0.3125,\n y: 0.8125,\n },\n {\n x: 0.4375,\n y: 0.8125,\n },\n {\n x: 0.4375,\n y: 0.8125,\n },\n {\n x: 0.4375,\n y: 0.8125,\n },\n {\n x: 0.4375,\n y: 0.8125,\n },\n {\n x: 0.4375,\n y: 0.8125,\n },\n {\n x: 0.4375,\n y: 0.8125,\n },\n {\n x: 0.5625,\n y: 0.8125,\n },\n {\n x: 0.5625,\n y: 0.8125,\n },\n {\n x: 0.5625,\n y: 0.8125,\n },\n {\n x: 0.5625,\n y: 0.8125,\n },\n {\n x: 0.5625,\n y: 0.8125,\n },\n {\n x: 0.5625,\n y: 0.8125,\n },\n {\n x: 0.6875,\n y: 0.8125,\n },\n {\n x: 0.6875,\n y: 0.8125,\n },\n {\n x: 0.6875,\n y: 0.8125,\n },\n {\n x: 0.6875,\n y: 0.8125,\n },\n {\n x: 0.6875,\n y: 0.8125,\n },\n {\n x: 0.6875,\n y: 0.8125,\n },\n {\n x: 0.8125,\n y: 0.8125,\n },\n {\n x: 0.8125,\n y: 0.8125,\n },\n {\n x: 0.8125,\n y: 0.8125,\n },\n {\n x: 0.8125,\n y: 0.8125,\n },\n {\n x: 0.8125,\n y: 0.8125,\n },\n {\n x: 0.8125,\n y: 0.8125,\n },\n {\n x: 0.9375,\n y: 0.8125,\n },\n {\n x: 0.9375,\n y: 0.8125,\n },\n {\n x: 0.9375,\n y: 0.8125,\n },\n {\n x: 0.9375,\n y: 0.8125,\n },\n {\n x: 0.9375,\n y: 0.8125,\n },\n {\n x: 0.9375,\n y: 0.8125,\n },\n {\n x: 0.0625,\n y: 0.9375,\n },\n {\n x: 0.0625,\n y: 0.9375,\n },\n {\n x: 0.0625,\n y: 0.9375,\n },\n {\n x: 0.0625,\n y: 0.9375,\n },\n {\n x: 0.0625,\n y: 0.9375,\n },\n {\n x: 0.0625,\n y: 0.9375,\n },\n {\n x: 0.1875,\n y: 0.9375,\n },\n {\n x: 0.1875,\n y: 0.9375,\n },\n {\n x: 0.1875,\n y: 0.9375,\n },\n {\n x: 0.1875,\n y: 0.9375,\n },\n {\n x: 0.1875,\n y: 0.9375,\n },\n {\n x: 0.1875,\n y: 0.9375,\n },\n {\n x: 0.3125,\n y: 0.9375,\n },\n {\n x: 0.3125,\n y: 0.9375,\n },\n {\n x: 0.3125,\n y: 0.9375,\n },\n {\n x: 0.3125,\n y: 0.9375,\n },\n {\n x: 0.3125,\n y: 0.9375,\n },\n {\n x: 0.3125,\n y: 0.9375,\n },\n {\n x: 0.4375,\n y: 0.9375,\n },\n {\n x: 0.4375,\n y: 0.9375,\n },\n {\n x: 0.4375,\n y: 0.9375,\n },\n {\n x: 0.4375,\n y: 0.9375,\n },\n {\n x: 0.4375,\n y: 0.9375,\n },\n {\n x: 0.4375,\n y: 0.9375,\n },\n {\n x: 0.5625,\n y: 0.9375,\n },\n {\n x: 0.5625,\n y: 0.9375,\n },\n {\n x: 0.5625,\n y: 0.9375,\n },\n {\n x: 0.5625,\n y: 0.9375,\n },\n {\n x: 0.5625,\n y: 0.9375,\n },\n {\n x: 0.5625,\n y: 0.9375,\n },\n {\n x: 0.6875,\n y: 0.9375,\n },\n {\n x: 0.6875,\n y: 0.9375,\n },\n {\n x: 0.6875,\n y: 0.9375,\n },\n {\n x: 0.6875,\n y: 0.9375,\n },\n {\n x: 0.6875,\n y: 0.9375,\n },\n {\n x: 0.6875,\n y: 0.9375,\n },\n {\n x: 0.8125,\n y: 0.9375,\n },\n {\n x: 0.8125,\n y: 0.9375,\n },\n {\n x: 0.8125,\n y: 0.9375,\n },\n {\n x: 0.8125,\n y: 0.9375,\n },\n {\n x: 0.8125,\n y: 0.9375,\n },\n {\n x: 0.8125,\n y: 0.9375,\n },\n {\n x: 0.9375,\n y: 0.9375,\n },\n {\n x: 0.9375,\n y: 0.9375,\n },\n {\n x: 0.9375,\n y: 0.9375,\n },\n {\n x: 0.9375,\n y: 0.9375,\n },\n {\n x: 0.9375,\n y: 0.9375,\n },\n {\n x: 0.9375,\n y: 0.9375,\n },\n];\n", "import * as tf from '../../dist/tfjs.esm.js';\nimport * as box from './box';\nimport * as anchors from './anchors';\n\nexport class HandDetector {\n model: any;\n anchors: any;\n anchorsTensor: any;\n inputSize: number;\n inputSizeTensor: any;\n doubleInputSizeTensor: any;\n\n constructor(model) {\n this.model = model;\n this.anchors = anchors.anchors.map((anchor) => [anchor.x, anchor.y]);\n this.anchorsTensor = tf.tensor2d(this.anchors);\n this.inputSize = this.model?.inputs[0].shape[2];\n this.inputSizeTensor = tf.tensor1d([this.inputSize, this.inputSize]);\n this.doubleInputSizeTensor = tf.tensor1d([this.inputSize * 2, this.inputSize * 2]);\n }\n\n normalizeBoxes(boxes) {\n return tf.tidy(() => {\n const boxOffsets = tf.slice(boxes, [0, 0], [-1, 2]);\n const boxSizes = tf.slice(boxes, [0, 2], [-1, 2]);\n const boxCenterPoints = tf.add(tf.div(boxOffsets, this.inputSizeTensor), this.anchorsTensor);\n const halfBoxSizes = tf.div(boxSizes, this.doubleInputSizeTensor);\n const startPoints = tf.mul(tf.sub(boxCenterPoints, halfBoxSizes), this.inputSizeTensor);\n const endPoints = tf.mul(tf.add(boxCenterPoints, halfBoxSizes), this.inputSizeTensor);\n return tf.concat2d([startPoints, endPoints], 1);\n });\n }\n\n normalizeLandmarks(rawPalmLandmarks, index) {\n return tf.tidy(() => {\n const landmarks = tf.add(tf.div(rawPalmLandmarks.reshape([-1, 7, 2]), this.inputSizeTensor), this.anchors[index]);\n return tf.mul(landmarks, this.inputSizeTensor);\n });\n }\n\n async getBoxes(input, config) {\n const batched = this.model.predict(input);\n const predictions = batched.squeeze();\n batched.dispose();\n const scoresT = tf.tidy(() => tf.sigmoid(tf.slice(predictions, [0, 0], [-1, 1])).squeeze());\n const scores = scoresT.dataSync();\n const rawBoxes = tf.slice(predictions, [0, 1], [-1, 4]);\n const boxes = this.normalizeBoxes(rawBoxes);\n rawBoxes.dispose();\n const filteredT = await tf.image.nonMaxSuppressionAsync(boxes, scores, config.hand.maxDetected, config.hand.iouThreshold, config.hand.minConfidence);\n const filtered = filteredT.arraySync();\n\n scoresT.dispose();\n filteredT.dispose();\n const hands: Array<{ box: any, palmLandmarks: any, confidence: number }> = [];\n for (const index of filtered) {\n if (scores[index] >= config.hand.minConfidence) {\n const matchingBox = tf.slice(boxes, [index, 0], [1, -1]);\n const rawPalmLandmarks = tf.slice(predictions, [index, 5], [1, 14]);\n const palmLandmarks = tf.tidy(() => this.normalizeLandmarks(rawPalmLandmarks, index).reshape([-1, 2]));\n rawPalmLandmarks.dispose();\n hands.push({ box: matchingBox, palmLandmarks, confidence: scores[index] });\n }\n }\n predictions.dispose();\n boxes.dispose();\n return hands;\n }\n\n async estimateHandBounds(input, config) {\n const inputHeight = input.shape[1];\n const inputWidth = input.shape[2];\n const image = tf.tidy(() => input.resizeBilinear([this.inputSize, this.inputSize]).div(127.5).sub(1));\n const predictions = await this.getBoxes(image, config);\n image.dispose();\n const hands: Array<{}> = [];\n if (!predictions || predictions.length === 0) return hands;\n for (const prediction of predictions) {\n const boxes = prediction.box.dataSync();\n const startPoint = boxes.slice(0, 2);\n const endPoint = boxes.slice(2, 4);\n const palmLandmarks = prediction.palmLandmarks.arraySync();\n prediction.box.dispose();\n prediction.palmLandmarks.dispose();\n hands.push(box.scaleBoxCoordinates({ startPoint, endPoint, palmLandmarks, confidence: prediction.confidence }, [inputWidth / this.inputSize, inputHeight / this.inputSize]));\n }\n return hands;\n }\n}\n", "export function normalizeRadians(angle) {\n return angle - 2 * Math.PI * Math.floor((angle + Math.PI) / (2 * Math.PI));\n}\n\nexport function computeRotation(point1, point2) {\n const radians = Math.PI / 2 - Math.atan2(-(point2[1] - point1[1]), point2[0] - point1[0]);\n return normalizeRadians(radians);\n}\n\nexport const buildTranslationMatrix = (x, y) => [[1, 0, x], [0, 1, y], [0, 0, 1]];\n\nexport function dot(v1, v2) {\n let product = 0;\n for (let i = 0; i < v1.length; i++) {\n product += v1[i] * v2[i];\n }\n return product;\n}\n\nexport function getColumnFrom2DArr(arr, columnIndex) {\n const column: Array = [];\n for (let i = 0; i < arr.length; i++) {\n column.push(arr[i][columnIndex]);\n }\n return column;\n}\n\nexport function multiplyTransformMatrices(mat1, mat2) {\n const product: Array = [];\n const size = mat1.length;\n for (let row = 0; row < size; row++) {\n product.push([]);\n for (let col = 0; col < size; col++) {\n product[row].push(dot(mat1[row], getColumnFrom2DArr(mat2, col)));\n }\n }\n return product;\n}\n\nexport function buildRotationMatrix(rotation, center) {\n const cosA = Math.cos(rotation);\n const sinA = Math.sin(rotation);\n const rotationMatrix = [[cosA, -sinA, 0], [sinA, cosA, 0], [0, 0, 1]];\n const translationMatrix = buildTranslationMatrix(center[0], center[1]);\n const translationTimesRotation = multiplyTransformMatrices(translationMatrix, rotationMatrix);\n const negativeTranslationMatrix = buildTranslationMatrix(-center[0], -center[1]);\n return multiplyTransformMatrices(translationTimesRotation, negativeTranslationMatrix);\n}\n\nexport function invertTransformMatrix(matrix) {\n const rotationComponent = [[matrix[0][0], matrix[1][0]], [matrix[0][1], matrix[1][1]]];\n const translationComponent = [matrix[0][2], matrix[1][2]];\n const invertedTranslation = [\n -dot(rotationComponent[0], translationComponent),\n -dot(rotationComponent[1], translationComponent),\n ];\n return [\n rotationComponent[0].concat(invertedTranslation[0]),\n rotationComponent[1].concat(invertedTranslation[1]),\n [0, 0, 1],\n ];\n}\n\nexport function rotatePoint(homogeneousCoordinate, rotationMatrix) {\n return [\n dot(homogeneousCoordinate, rotationMatrix[0]),\n dot(homogeneousCoordinate, rotationMatrix[1]),\n ];\n}\n", "import * as tf from '../../dist/tfjs.esm.js';\nimport * as box from './box';\nimport * as util from './util';\n\n// const PALM_BOX_SHIFT_VECTOR = [0, -0.4];\nconst PALM_BOX_ENLARGE_FACTOR = 5; // default 3\n// const HAND_BOX_SHIFT_VECTOR = [0, -0.1]; // move detected hand box by x,y to ease landmark detection\nconst HAND_BOX_ENLARGE_FACTOR = 1.65; // default 1.65\nconst PALM_LANDMARK_IDS = [0, 5, 9, 13, 17, 1, 2];\nconst PALM_LANDMARKS_INDEX_OF_PALM_BASE = 0;\nconst PALM_LANDMARKS_INDEX_OF_MIDDLE_FINGER_BASE = 2;\n\nexport class HandPipeline {\n handDetector: any;\n landmarkDetector: any;\n inputSize: number;\n storedBoxes: any;\n skipped: number;\n detectedHands: number;\n\n constructor(handDetector, landmarkDetector) {\n this.handDetector = handDetector;\n this.landmarkDetector = landmarkDetector;\n this.inputSize = this.landmarkDetector?.inputs[0].shape[2];\n this.storedBoxes = [];\n this.skipped = 0;\n this.detectedHands = 0;\n }\n\n getBoxForPalmLandmarks(palmLandmarks, rotationMatrix) {\n const rotatedPalmLandmarks = palmLandmarks.map((coord) => util.rotatePoint([...coord, 1], rotationMatrix));\n const boxAroundPalm = this.calculateLandmarksBoundingBox(rotatedPalmLandmarks);\n // return box.enlargeBox(box.squarifyBox(box.shiftBox(boxAroundPalm, PALM_BOX_SHIFT_VECTOR)), PALM_BOX_ENLARGE_FACTOR);\n return box.enlargeBox(box.squarifyBox(boxAroundPalm), PALM_BOX_ENLARGE_FACTOR);\n }\n\n getBoxForHandLandmarks(landmarks) {\n const boundingBox = this.calculateLandmarksBoundingBox(landmarks);\n // const boxAroundHand = box.enlargeBox(box.squarifyBox(box.shiftBox(boundingBox, HAND_BOX_SHIFT_VECTOR)), HAND_BOX_ENLARGE_FACTOR);\n const boxAroundHand = box.enlargeBox(box.squarifyBox(boundingBox), HAND_BOX_ENLARGE_FACTOR);\n boxAroundHand.palmLandmarks = [];\n for (let i = 0; i < PALM_LANDMARK_IDS.length; i++) {\n boxAroundHand.palmLandmarks.push(landmarks[PALM_LANDMARK_IDS[i]].slice(0, 2));\n }\n return boxAroundHand;\n }\n\n transformRawCoords(rawCoords, box2, angle, rotationMatrix) {\n const boxSize = box.getBoxSize(box2);\n const scaleFactor = [boxSize[0] / this.inputSize, boxSize[1] / this.inputSize, (boxSize[0] + boxSize[1]) / this.inputSize / 2];\n const coordsScaled = rawCoords.map((coord) => [\n scaleFactor[0] * (coord[0] - this.inputSize / 2),\n scaleFactor[1] * (coord[1] - this.inputSize / 2),\n scaleFactor[2] * coord[2],\n ]);\n const coordsRotationMatrix = util.buildRotationMatrix(angle, [0, 0]);\n const coordsRotated = coordsScaled.map((coord) => {\n const rotated = util.rotatePoint(coord, coordsRotationMatrix);\n return [...rotated, coord[2]];\n });\n const inverseRotationMatrix = util.invertTransformMatrix(rotationMatrix);\n const boxCenter = [...box.getBoxCenter(box2), 1];\n const originalBoxCenter = [\n util.dot(boxCenter, inverseRotationMatrix[0]),\n util.dot(boxCenter, inverseRotationMatrix[1]),\n ];\n return coordsRotated.map((coord) => [\n coord[0] + originalBoxCenter[0],\n coord[1] + originalBoxCenter[1],\n coord[2],\n ]);\n }\n\n async estimateHands(image, config) {\n let useFreshBox = false;\n\n // run new detector every skipFrames unless we only want box to start with\n let boxes;\n if ((this.skipped === 0) || (this.skipped > config.hand.skipFrames) || !config.hand.landmarks || !config.videoOptimized) {\n boxes = await this.handDetector.estimateHandBounds(image, config);\n this.skipped = 0;\n }\n if (config.videoOptimized) this.skipped++;\n\n // if detector result count doesn't match current working set, use it to reset current working set\n if (boxes && (boxes.length > 0) && ((boxes.length !== this.detectedHands) && (this.detectedHands !== config.hand.maxDetected) || !config.hand.landmarks)) {\n this.detectedHands = 0;\n this.storedBoxes = [...boxes];\n // for (const possible of boxes) this.storedBoxes.push(possible);\n if (this.storedBoxes.length > 0) useFreshBox = true;\n }\n const hands: Array<{}> = [];\n\n if (config.hand.skipInitial && this.detectedHands === 0) this.skipped = 0;\n\n // go through working set of boxes\n for (let i = 0; i < this.storedBoxes.length; i++) {\n const currentBox = this.storedBoxes[i];\n if (!currentBox) continue;\n if (config.hand.landmarks) {\n const angle = config.hand.rotation ? util.computeRotation(currentBox.palmLandmarks[PALM_LANDMARKS_INDEX_OF_PALM_BASE], currentBox.palmLandmarks[PALM_LANDMARKS_INDEX_OF_MIDDLE_FINGER_BASE]) : 0;\n const palmCenter = box.getBoxCenter(currentBox);\n const palmCenterNormalized = [palmCenter[0] / image.shape[2], palmCenter[1] / image.shape[1]];\n const rotatedImage = config.hand.rotation ? tf.image.rotateWithOffset(image, angle, 0, palmCenterNormalized) : image.clone();\n const rotationMatrix = util.buildRotationMatrix(-angle, palmCenter);\n const newBox = useFreshBox ? this.getBoxForPalmLandmarks(currentBox.palmLandmarks, rotationMatrix) : currentBox;\n const croppedInput = box.cutBoxFromImageAndResize(newBox, rotatedImage, [this.inputSize, this.inputSize]);\n const handImage = croppedInput.div(255);\n croppedInput.dispose();\n rotatedImage.dispose();\n const [confidenceT, keypoints] = await this.landmarkDetector.predict(handImage);\n handImage.dispose();\n const confidence = confidenceT.dataSync()[0];\n confidenceT.dispose();\n if (confidence >= config.hand.minConfidence) {\n const keypointsReshaped = tf.reshape(keypoints, [-1, 3]);\n const rawCoords = keypointsReshaped.arraySync();\n keypoints.dispose();\n keypointsReshaped.dispose();\n const coords = this.transformRawCoords(rawCoords, newBox, angle, rotationMatrix);\n const nextBoundingBox = this.getBoxForHandLandmarks(coords);\n this.storedBoxes[i] = nextBoundingBox;\n const result = {\n landmarks: coords,\n confidence,\n box: { topLeft: nextBoundingBox.startPoint, bottomRight: nextBoundingBox.endPoint },\n };\n hands.push(result);\n } else {\n this.storedBoxes[i] = null;\n }\n keypoints.dispose();\n } else {\n // const enlarged = box.enlargeBox(box.squarifyBox(box.shiftBox(currentBox, HAND_BOX_SHIFT_VECTOR)), HAND_BOX_ENLARGE_FACTOR);\n const enlarged = box.enlargeBox(box.squarifyBox(currentBox), HAND_BOX_ENLARGE_FACTOR);\n const result = {\n confidence: currentBox.confidence,\n box: { topLeft: enlarged.startPoint, bottomRight: enlarged.endPoint },\n };\n hands.push(result);\n }\n }\n this.storedBoxes = this.storedBoxes.filter((a) => a !== null);\n this.detectedHands = hands.length;\n return hands;\n }\n\n // eslint-disable-next-line class-methods-use-this\n calculateLandmarksBoundingBox(landmarks) {\n const xs = landmarks.map((d) => d[0]);\n const ys = landmarks.map((d) => d[1]);\n const startPoint = [Math.min(...xs), Math.min(...ys)];\n const endPoint = [Math.max(...xs), Math.max(...ys)];\n return { startPoint, endPoint };\n }\n}\n", "// paper: https://ai.googleblog.com/2020/08/on-device-real-time-body-pose-tracking.html\n\nimport { log, join } from '../helpers';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as annotations from './annotations';\n\nlet model;\n\nexport async function load(config) {\n if (!model) {\n model = await tf.loadGraphModel(join(config.modelBasePath, config.body.modelPath));\n model.width = parseInt(model.signature.inputs['input_1:0'].tensorShape.dim[2].size);\n model.height = parseInt(model.signature.inputs['input_1:0'].tensorShape.dim[1].size);\n if (!model || !model.modelUrl) log('load model failed:', config.body.modelPath);\n else if (config.debug) log('load model:', model.modelUrl);\n } else if (config.debug) log('cached model:', model.modelUrl);\n return model;\n}\n\nexport async function predict(image, config) {\n if (!model) return null;\n if (!config.body.enabled) return null;\n const imgSize = { width: image.shape[2], height: image.shape[1] };\n const resize = tf.image.resizeBilinear(image, [model.width, model.height], false);\n const normalize = tf.div(resize, [255.0]);\n resize.dispose();\n const resT = await model.predict(normalize);\n const points = resT.find((t) => (t.size === 195 || t.size === 155)).dataSync(); // order of output tensors may change between models, full has 195 and upper has 155 items\n resT.forEach((t) => t.dispose());\n normalize.dispose();\n const keypoints: Array<{ id, part, position: { x, y, z }, score, presence }> = [];\n const labels = points.length === 195 ? annotations.full : annotations.upper; // full model has 39 keypoints, upper has 31 keypoints\n const depth = 5; // each points has x,y,z,visibility,presence\n for (let i = 0; i < points.length / depth; i++) {\n keypoints.push({\n id: i,\n part: labels[i],\n position: {\n x: Math.trunc(imgSize.width * points[depth * i + 0] / 255), // return normalized x value istead of 0..255\n y: Math.trunc(imgSize.height * points[depth * i + 1] / 255), // return normalized y value istead of 0..255\n z: Math.trunc(points[depth * i + 2]) + 0, // fix negative zero\n },\n score: (100 - Math.trunc(100 / (1 + Math.exp(points[depth * i + 3])))) / 100, // reverse sigmoid value\n presence: (100 - Math.trunc(100 / (1 + Math.exp(points[depth * i + 4])))) / 100, // reverse sigmoid value\n });\n }\n const score = keypoints.reduce((prev, curr) => (curr.score > prev ? curr.score : prev), 0);\n return [{ score, keypoints }];\n}\n", "export const full = [\n 'nose',\n 'leftEyeInside',\n 'leftEye',\n 'leftEyeOutside',\n 'rightEyeInside',\n 'rightEye',\n 'rightEyeOutside',\n 'leftEar',\n 'rightEar',\n 'leftMouth',\n 'rightMouth',\n 'leftShoulder',\n 'rightShoulder',\n 'leftElbow',\n 'rightElbow',\n 'leftWrist',\n 'rightWrist',\n 'leftPalm',\n 'rightPalm',\n 'leftIndex',\n 'rightIndex',\n 'leftPinky',\n 'rightPinky',\n 'leftHip',\n 'rightHip',\n 'leftKnee',\n 'rightKnee',\n 'leftAnkle',\n 'rightAnkle',\n 'leftHeel',\n 'rightHeel',\n 'leftFoot',\n 'rightFoot',\n 'midHip',\n 'forehead',\n 'leftThumb',\n 'leftHand',\n 'rightThumb',\n 'rightHand',\n];\n\nexport const upper = [\n 'nose',\n 'leftEyeInside',\n 'leftEye',\n 'leftEyeOutside',\n 'rightEyeInside',\n 'rightEye',\n 'rightEyeOutside',\n 'leftEar',\n 'rightEar',\n 'leftMouth',\n 'rightMouth',\n 'leftShoulder',\n 'rightShoulder',\n 'leftElbow',\n 'rightElbow',\n 'left:15',\n 'right:16',\n 'left:17',\n 'right:18',\n 'left:19',\n 'right:20',\n 'left:21',\n 'right:22',\n 'leftChest',\n 'rightChest',\n 'neck',\n 'forehead',\n 'left:27',\n 'right:28',\n 'left:29',\n 'right:30',\n];\n", "import { log, join } from '../helpers';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { labels } from './labels';\n\nlet model;\nlet last: Array<{}> = [];\nlet skipped = Number.MAX_SAFE_INTEGER;\n\nconst scaleBox = 2.5; // increase box size\n\nexport async function load(config) {\n if (!model) {\n model = await tf.loadGraphModel(join(config.modelBasePath, config.object.modelPath));\n const inputs = Object.values(model.modelSignature['inputs']);\n model.inputSize = Array.isArray(inputs) ? parseInt(inputs[0].tensorShape.dim[2].size) : null;\n if (!model.inputSize) throw new Error(`Human: Cannot determine model inputSize: ${config.object.modelPath}`);\n if (!model || !model.modelUrl) log('load model failed:', config.object.modelPath);\n else if (config.debug) log('load model:', model.modelUrl);\n } else if (config.debug) log('cached model:', model.modelUrl);\n return model;\n}\n\nasync function process(res, inputSize, outputShape, config) {\n let id = 0;\n let results: Array<{ score: number, strideSize: number, class: number, label: string, center: number[], centerRaw: number[], box: number[], boxRaw: number[] }> = [];\n for (const strideSize of [1, 2, 4]) { // try each stride size as it detects large/medium/small objects\n // find scores, boxes, classes\n tf.tidy(() => { // wrap in tidy to automatically deallocate temp tensors\n const baseSize = strideSize * 13; // 13x13=169, 26x26=676, 52x52=2704\n // find boxes and scores output depending on stride\n const scoresT = res.find((a) => (a.shape[1] === (baseSize ** 2) && a.shape[2] === labels.length))?.squeeze();\n const featuresT = res.find((a) => (a.shape[1] === (baseSize ** 2) && a.shape[2] < labels.length))?.squeeze();\n const boxesMax = featuresT.reshape([-1, 4, featuresT.shape[1] / 4]); // reshape [output] to [4, output / 4] where number is number of different features inside each stride\n const boxIdx = boxesMax.argMax(2).arraySync(); // what we need is indexes of features with highest scores, not values itself\n const scores = scoresT.arraySync(); // optionally use exponential scores or just as-is\n for (let i = 0; i < scoresT.shape[0]; i++) { // total strides (x * y matrix)\n for (let j = 0; j < scoresT.shape[1]; j++) { // one score for each class\n const score = scores[i][j]; // get score for current position\n if (score > config.object.minConfidence && j !== 61) {\n const cx = (0.5 + Math.trunc(i % baseSize)) / baseSize; // center.x normalized to range 0..1\n const cy = (0.5 + Math.trunc(i / baseSize)) / baseSize; // center.y normalized to range 0..1\n const boxOffset = boxIdx[i].map((a) => a * (baseSize / strideSize / inputSize)); // just grab indexes of features with highest scores\n const [x, y] = [\n cx - (scaleBox / strideSize * boxOffset[0]),\n cy - (scaleBox / strideSize * boxOffset[1]),\n ];\n const [w, h] = [\n cx + (scaleBox / strideSize * boxOffset[2]) - x,\n cy + (scaleBox / strideSize * boxOffset[3]) - y,\n ];\n let boxRaw = [x, y, w, h]; // results normalized to range 0..1\n boxRaw = boxRaw.map((a) => Math.max(0, Math.min(a, 1))); // fix out-of-bounds coords\n const box = [ // results normalized to input image pixels\n boxRaw[0] * outputShape[0],\n boxRaw[1] * outputShape[1],\n boxRaw[2] * outputShape[0],\n boxRaw[3] * outputShape[1],\n ];\n const result = {\n id: id++,\n strideSize,\n score: Math.round(100 * score) / 100,\n class: j + 1,\n label: labels[j].label,\n center: [Math.trunc(outputShape[0] * cx), Math.trunc(outputShape[1] * cy)],\n centerRaw: [cx, cy],\n box: box.map((a) => Math.trunc(a)),\n boxRaw,\n };\n results.push(result);\n }\n }\n }\n });\n }\n // deallocate tensors\n res.forEach((t) => tf.dispose(t));\n\n // normally nms is run on raw results, but since boxes need to be calculated this way we skip calulcation of\n // unnecessary boxes and run nms only on good candidates (basically it just does IOU analysis as scores are already filtered)\n const nmsBoxes = results.map((a) => a.boxRaw);\n const nmsScores = results.map((a) => a.score);\n let nmsIdx: any[] = [];\n if (nmsBoxes && nmsBoxes.length > 0) {\n const nms = await tf.image.nonMaxSuppressionAsync(nmsBoxes, nmsScores, config.object.maxDetected, config.object.iouThreshold, config.object.minConfidence);\n nmsIdx = nms.dataSync();\n tf.dispose(nms);\n }\n\n // filter & sort results\n results = results\n .filter((a, idx) => nmsIdx.includes(idx))\n .sort((a, b) => (b.score - a.score));\n\n return results;\n}\n\nexport async function predict(image, config) {\n if (!model) return null;\n // console.log(skipped, config.object.skipFrames, config.videoOptimized, ((skipped < config.object.skipFrames) && config.videoOptimized && (last.length > 0)));\n if ((skipped < config.object.skipFrames) && config.videoOptimized && (last.length > 0)) {\n skipped++;\n return last;\n }\n if (config.videoOptimized) skipped = 0;\n else skipped = Number.MAX_SAFE_INTEGER;\n return new Promise(async (resolve) => {\n const outputSize = [image.shape[2], image.shape[1]];\n const resize = tf.image.resizeBilinear(image, [model.inputSize, model.inputSize], false);\n const norm = resize.div(255);\n const transpose = norm.transpose([0, 3, 1, 2]);\n norm.dispose();\n resize.dispose();\n\n let objectT;\n if (config.object.enabled) objectT = await model.predict(transpose);\n transpose.dispose();\n\n const obj = await process(objectT, model.inputSize, outputSize, config);\n last = obj;\n resolve(obj);\n });\n}\n", "export const labels = [\n { class: 1, label: 'person' },\n { class: 2, label: 'bicycle' },\n { class: 3, label: 'car' },\n { class: 4, label: 'motorcycle' },\n { class: 5, label: 'airplane' },\n { class: 6, label: 'bus' },\n { class: 7, label: 'train' },\n { class: 8, label: 'truck' },\n { class: 9, label: 'boat' },\n { class: 10, label: 'traffic light' },\n { class: 11, label: 'fire hydrant' },\n { class: 12, label: 'stop sign' },\n { class: 13, label: 'parking meter' },\n { class: 14, label: 'bench' },\n { class: 15, label: 'bird' },\n { class: 16, label: 'cat' },\n { class: 17, label: 'dog' },\n { class: 18, label: 'horse' },\n { class: 19, label: 'sheep' },\n { class: 20, label: 'cow' },\n { class: 21, label: 'elephant' },\n { class: 22, label: 'bear' },\n { class: 23, label: 'zebra' },\n { class: 24, label: 'giraffe' },\n { class: 25, label: 'backpack' },\n { class: 26, label: 'umbrella' },\n { class: 27, label: 'handbag' },\n { class: 28, label: 'tie' },\n { class: 29, label: 'suitcase' },\n { class: 30, label: 'frisbee' },\n { class: 31, label: 'skis' },\n { class: 32, label: 'snowboard' },\n { class: 33, label: 'sports ball' },\n { class: 34, label: 'kite' },\n { class: 35, label: 'baseball bat' },\n { class: 36, label: 'baseball glove' },\n { class: 37, label: 'skateboard' },\n { class: 38, label: 'surfboard' },\n { class: 39, label: 'tennis racket' },\n { class: 40, label: 'bottle' },\n { class: 41, label: 'wine glass' },\n { class: 42, label: 'cup' },\n { class: 43, label: 'fork' },\n { class: 44, label: 'knife' },\n { class: 45, label: 'spoon' },\n { class: 46, label: 'bowl' },\n { class: 47, label: 'banana' },\n { class: 48, label: 'apple' },\n { class: 49, label: 'sandwich' },\n { class: 50, label: 'orange' },\n { class: 51, label: 'broccoli' },\n { class: 52, label: 'carrot' },\n { class: 53, label: 'hot dog' },\n { class: 54, label: 'pizza' },\n { class: 55, label: 'donut' },\n { class: 56, label: 'cake' },\n { class: 57, label: 'chair' },\n { class: 58, label: 'couch' },\n { class: 59, label: 'potted plant' },\n { class: 60, label: 'bed' },\n { class: 61, label: 'dining table' },\n { class: 62, label: 'toilet' },\n { class: 63, label: 'tv' },\n { class: 64, label: 'laptop' },\n { class: 65, label: 'mouse' },\n { class: 66, label: 'remote' },\n { class: 67, label: 'keyboard' },\n { class: 68, label: 'cell phone' },\n { class: 69, label: 'microwave' },\n { class: 70, label: 'oven' },\n { class: 71, label: 'toaster' },\n { class: 72, label: 'sink' },\n { class: 73, label: 'refrigerator' },\n { class: 74, label: 'book' },\n { class: 75, label: 'clock' },\n { class: 76, label: 'vase' },\n { class: 77, label: 'scissors' },\n { class: 78, label: 'teddy bear' },\n { class: 79, label: 'hair drier' },\n { class: 80, label: 'toothbrush' },\n];\n", "export const body = (res) => {\n if (!res) return [];\n const gestures: Array<{ body: number, gesture: string }> = [];\n for (let i = 0; i < res.length; i++) {\n // raising hands\n const leftWrist = res[i].keypoints.find((a) => (a.part === 'leftWrist'));\n const rightWrist = res[i].keypoints.find((a) => (a.part === 'rightWrist'));\n const nose = res[i].keypoints.find((a) => (a.part === 'nose'));\n if (nose && leftWrist && rightWrist && (leftWrist.position.y < nose.position.y) && (rightWrist.position.y < nose.position.y)) gestures.push({ body: i, gesture: 'i give up' });\n else if (nose && leftWrist && (leftWrist.position.y < nose.position.y)) gestures.push({ body: i, gesture: 'raise left hand' });\n else if (nose && rightWrist && (rightWrist.position.y < nose.position.y)) gestures.push({ body: i, gesture: 'raise right hand' });\n\n // leaning\n const leftShoulder = res[i].keypoints.find((a) => (a.part === 'leftShoulder'));\n const rightShoulder = res[i].keypoints.find((a) => (a.part === 'rightShoulder'));\n if (leftShoulder && rightShoulder) gestures.push({ body: i, gesture: `leaning ${(leftShoulder.position.y > rightShoulder.position.y) ? 'left' : 'right'}` });\n }\n return gestures;\n};\n\nexport const face = (res) => {\n if (!res) return [];\n const gestures: Array<{ face: number, gesture: string }> = [];\n for (let i = 0; i < res.length; i++) {\n if (res[i].mesh && res[i].mesh.length > 0) {\n const eyeFacing = res[i].mesh[33][2] - res[i].mesh[263][2];\n if (Math.abs(eyeFacing) < 10) gestures.push({ face: i, gesture: 'facing center' });\n else gestures.push({ face: i, gesture: `facing ${eyeFacing < 0 ? 'left' : 'right'}` });\n const openLeft = Math.abs(res[i].mesh[374][1] - res[i].mesh[386][1]) / Math.abs(res[i].mesh[443][1] - res[i].mesh[450][1]); // center of eye inner lid y coord div center of wider eye border y coord\n if (openLeft < 0.2) gestures.push({ face: i, gesture: 'blink left eye' });\n const openRight = Math.abs(res[i].mesh[145][1] - res[i].mesh[159][1]) / Math.abs(res[i].mesh[223][1] - res[i].mesh[230][1]); // center of eye inner lid y coord div center of wider eye border y coord\n if (openRight < 0.2) gestures.push({ face: i, gesture: 'blink right eye' });\n const mouthOpen = Math.min(100, 500 * Math.abs(res[i].mesh[13][1] - res[i].mesh[14][1]) / Math.abs(res[i].mesh[10][1] - res[i].mesh[152][1]));\n if (mouthOpen > 10) gestures.push({ face: i, gesture: `mouth ${Math.trunc(mouthOpen)}% open` });\n const chinDepth = res[i].mesh[152][2];\n if (Math.abs(chinDepth) > 10) gestures.push({ face: i, gesture: `head ${chinDepth < 0 ? 'up' : 'down'}` });\n }\n }\n return gestures;\n};\n\nexport const iris = (res) => {\n if (!res) return [];\n const gestures: Array<{ iris: number, gesture: string }> = [];\n for (let i = 0; i < res.length; i++) {\n if (!res[i].annotations || !res[i].annotations.leftEyeIris || !res[i].annotations.rightEyeIris) continue;\n const sizeXLeft = res[i].annotations.leftEyeIris[3][0] - res[i].annotations.leftEyeIris[1][0];\n const sizeYLeft = res[i].annotations.leftEyeIris[4][1] - res[i].annotations.leftEyeIris[2][1];\n const areaLeft = Math.abs(sizeXLeft * sizeYLeft);\n\n const sizeXRight = res[i].annotations.rightEyeIris[3][0] - res[i].annotations.rightEyeIris[1][0];\n const sizeYRight = res[i].annotations.rightEyeIris[4][1] - res[i].annotations.rightEyeIris[2][1];\n const areaRight = Math.abs(sizeXRight * sizeYRight);\n\n let center = false;\n const difference = Math.abs(areaLeft - areaRight) / Math.max(areaLeft, areaRight);\n if (difference < 0.25) {\n center = true;\n gestures.push({ iris: i, gesture: 'facing center' });\n }\n\n const rightIrisCenterX = Math.abs(res[i].mesh[33][0] - res[i].annotations.rightEyeIris[0][0]) / res[i].annotations.rightEyeIris[0][0];\n const leftIrisCenterX = Math.abs(res[i].mesh[263][0] - res[i].annotations.leftEyeIris[0][0]) / res[i].annotations.leftEyeIris[0][0];\n if (leftIrisCenterX > 0.033 || rightIrisCenterX > 0.033) center = false;\n if (leftIrisCenterX > 0.033) gestures.push({ iris: i, gesture: 'looking right' });\n if (rightIrisCenterX > 0.033) gestures.push({ iris: i, gesture: 'looking left' });\n\n const rightIrisCenterY = Math.abs(res[i].mesh[145][1] - res[i].annotations.rightEyeIris[0][1]) / res[i].annotations.rightEyeIris[0][1];\n const leftIrisCenterY = Math.abs(res[i].mesh[374][1] - res[i].annotations.leftEyeIris[0][1]) / res[i].annotations.leftEyeIris[0][1];\n if (leftIrisCenterY < 0.015 || rightIrisCenterY < 0.015 || leftIrisCenterY > 0.030 || rightIrisCenterY > 0.030) center = false;\n if (leftIrisCenterY < 0.015 || rightIrisCenterY < 0.015) gestures.push({ iris: i, gesture: 'looking down' });\n if (leftIrisCenterY > 0.030 || rightIrisCenterY > 0.030) gestures.push({ iris: i, gesture: 'looking up' });\n\n // still center;\n if (center) gestures.push({ iris: i, gesture: 'looking center' });\n }\n return gestures;\n};\n\nexport const hand = (res) => {\n if (!res) return [];\n const gestures: Array<{ hand: number, gesture: string }> = [];\n for (let i = 0; i < res.length; i++) {\n const fingers: Array<{ name: string, position: number }> = [];\n for (const [finger, pos] of Object.entries(res[i]['annotations'])) {\n if (finger !== 'palmBase' && Array.isArray(pos)) fingers.push({ name: finger.toLowerCase(), position: pos[0] }); // get tip of each finger\n }\n if (fingers && fingers.length > 0) {\n const closest = fingers.reduce((best, a) => (best.position[2] < a.position[2] ? best : a));\n const highest = fingers.reduce((best, a) => (best.position[1] < a.position[1] ? best : a));\n gestures.push({ hand: i, gesture: `${closest.name} forward ${highest.name} up` });\n }\n }\n return gestures;\n};\n", "import * as tf from '../../dist/tfjs.esm.js';\nimport * as fxImage from './imagefx';\n\nconst maxSize = 2048;\n// internal temp canvases\nlet inCanvas;\nlet outCanvas;\n// instance of fximage\nlet fx;\n\n// process input image and return tensor\n// input can be tensor, imagedata, htmlimageelement, htmlvideoelement\n// input is resized and run through imagefx filter\nexport function process(input, config): { tensor: typeof tf.Tensor | null, canvas: OffscreenCanvas | HTMLCanvasElement } {\n let tensor;\n if (!input) throw new Error('Human: Input is missing');\n // sanity checks since different browsers do not implement all dom elements\n if (\n !(input instanceof tf.Tensor)\n && !(typeof Image !== 'undefined' && input instanceof Image)\n && !(typeof ImageData !== 'undefined' && input instanceof ImageData)\n && !(typeof ImageBitmap !== 'undefined' && input instanceof ImageBitmap)\n && !(typeof HTMLImageElement !== 'undefined' && input instanceof HTMLImageElement)\n && !(typeof HTMLMediaElement !== 'undefined' && input instanceof HTMLMediaElement)\n && !(typeof HTMLVideoElement !== 'undefined' && input instanceof HTMLVideoElement)\n && !(typeof HTMLCanvasElement !== 'undefined' && input instanceof HTMLCanvasElement)\n && !(typeof OffscreenCanvas !== 'undefined' && input instanceof OffscreenCanvas)\n ) {\n throw new Error('Human: Input type is not recognized');\n }\n if (input instanceof tf.Tensor) {\n // if input is tensor, use as-is\n if (input.shape && input.shape.length === 4 && input.shape[0] === 1 && input.shape[3] === 3) tensor = tf.clone(input);\n else throw new Error(`Human: Input tensor shape must be [1, height, width, 3] and instead was ${input.shape}`);\n } else {\n // check if resizing will be needed\n const originalWidth = input['naturalWidth'] || input['videoWidth'] || input['width'] || (input['shape'] && (input['shape'][1] > 0));\n const originalHeight = input['naturalHeight'] || input['videoHeight'] || input['height'] || (input['shape'] && (input['shape'][2] > 0));\n let targetWidth = originalWidth;\n let targetHeight = originalHeight;\n if (targetWidth > maxSize) {\n targetWidth = maxSize;\n targetHeight = targetWidth * originalHeight / originalWidth;\n }\n if (targetHeight > maxSize) {\n targetHeight = maxSize;\n targetWidth = targetHeight * originalWidth / originalHeight;\n }\n\n // create our canvas and resize it if needed\n if (config.filter.width > 0) targetWidth = config.filter.width;\n else if (config.filter.height > 0) targetWidth = originalWidth * (config.filter.height / originalHeight);\n if (config.filter.height > 0) targetHeight = config.filter.height;\n else if (config.filter.width > 0) targetHeight = originalHeight * (config.filter.width / originalWidth);\n if (!targetWidth || !targetHeight) throw new Error('Human: Input cannot determine dimension');\n if (!inCanvas || (inCanvas?.width !== targetWidth) || (inCanvas?.height !== targetHeight)) {\n inCanvas = (typeof OffscreenCanvas !== 'undefined') ? new OffscreenCanvas(targetWidth, targetHeight) : document.createElement('canvas');\n if (inCanvas?.width !== targetWidth) inCanvas.width = targetWidth;\n if (inCanvas?.height !== targetHeight) inCanvas.height = targetHeight;\n }\n\n // draw input to our canvas\n const ctx = inCanvas.getContext('2d');\n if (input instanceof ImageData) {\n ctx.putImageData(input, 0, 0);\n } else {\n if (config.filter.flip && typeof ctx.translate !== 'undefined') {\n ctx.translate(originalWidth, 0);\n ctx.scale(-1, 1);\n ctx.drawImage(input, 0, 0, originalWidth, originalHeight, 0, 0, inCanvas?.width, inCanvas?.height);\n ctx.setTransform(1, 0, 0, 1, 0, 0); // resets transforms to defaults\n } else {\n ctx.drawImage(input, 0, 0, originalWidth, originalHeight, 0, 0, inCanvas?.width, inCanvas?.height);\n }\n }\n\n // imagefx transforms using gl\n if (config.filter.enabled) {\n if (!fx || !outCanvas || (inCanvas.width !== outCanvas.width) || (inCanvas?.height !== outCanvas?.height)) {\n outCanvas = (typeof OffscreenCanvas !== 'undefined') ? new OffscreenCanvas(inCanvas?.width, inCanvas?.height) : document.createElement('canvas');\n if (outCanvas?.width !== inCanvas?.width) outCanvas.width = inCanvas?.width;\n if (outCanvas?.height !== inCanvas?.height) outCanvas.height = inCanvas?.height;\n // log('created FX filter');\n fx = tf.ENV.flags.IS_BROWSER ? new fxImage.GLImageFilter({ canvas: outCanvas }) : null; // && (typeof document !== 'undefined')\n }\n if (!fx) return { tensor: null, canvas: inCanvas };\n fx.reset();\n fx.addFilter('brightness', config.filter.brightness); // must have at least one filter enabled\n if (config.filter.contrast !== 0) fx.addFilter('contrast', config.filter.contrast);\n if (config.filter.sharpness !== 0) fx.addFilter('sharpen', config.filter.sharpness);\n if (config.filter.blur !== 0) fx.addFilter('blur', config.filter.blur);\n if (config.filter.saturation !== 0) fx.addFilter('saturation', config.filter.saturation);\n if (config.filter.hue !== 0) fx.addFilter('hue', config.filter.hue);\n if (config.filter.negative) fx.addFilter('negative');\n if (config.filter.sepia) fx.addFilter('sepia');\n if (config.filter.vintage) fx.addFilter('brownie');\n if (config.filter.sepia) fx.addFilter('sepia');\n if (config.filter.kodachrome) fx.addFilter('kodachrome');\n if (config.filter.technicolor) fx.addFilter('technicolor');\n if (config.filter.polaroid) fx.addFilter('polaroid');\n if (config.filter.pixelate !== 0) fx.addFilter('pixelate', config.filter.pixelate);\n fx.apply(inCanvas);\n // read pixel data\n /*\n const gl = outCanvas.getContext('webgl');\n if (gl) {\n const glBuffer = new Uint8Array(outCanvas.width * outCanvas.height * 4);\n const pixBuffer = new Uint8Array(outCanvas.width * outCanvas.height * 3);\n gl.readPixels(0, 0, outCanvas.width, outCanvas.height, gl.RGBA, gl.UNSIGNED_BYTE, glBuffer);\n // gl returns rbga while we only need rgb, so discarding alpha channel\n // gl returns starting point as lower left, so need to invert vertical\n let i = 0;\n for (let y = outCanvas.height - 1; y >= 0; y--) {\n for (let x = 0; x < outCanvas.width; x++) {\n const index = (x + y * outCanvas.width) * 4;\n pixBuffer[i++] = glBuffer[index + 0];\n pixBuffer[i++] = glBuffer[index + 1];\n pixBuffer[i++] = glBuffer[index + 2];\n }\n }\n outCanvas.data = pixBuffer;\n }\n */\n } else {\n outCanvas = inCanvas;\n if (fx) fx = null;\n }\n\n // create tensor from image\n let pixels;\n if (outCanvas.data) { // if we have data, just convert to tensor\n const shape = [outCanvas.height, outCanvas.width, 3];\n pixels = tf.tensor3d(outCanvas.data, shape, 'int32');\n } else if (outCanvas instanceof ImageData) { // if input is imagedata, just use it\n pixels = tf.browser.fromPixels(outCanvas);\n } else if (config.backend === 'webgl' || config.backend === 'humangl') { // tf kernel-optimized method to get imagedata\n // we can use canvas as-is as it already has a context, so we do a silly one more canvas\n const tempCanvas = (typeof OffscreenCanvas !== 'undefined') ? new OffscreenCanvas(targetWidth, targetHeight) : document.createElement('canvas');\n tempCanvas.width = targetWidth;\n tempCanvas.height = targetHeight;\n const tempCtx = tempCanvas.getContext('2d');\n tempCtx?.drawImage(outCanvas, 0, 0);\n pixels = tf.browser.fromPixels(tempCanvas);\n } else { // cpu and wasm kernel does not implement efficient fromPixels method\n // we can use canvas as-is as it already has a context, so we do a silly one more canvas\n const tempCanvas = (typeof OffscreenCanvas !== 'undefined') ? new OffscreenCanvas(targetWidth, targetHeight) : document.createElement('canvas');\n tempCanvas.width = targetWidth;\n tempCanvas.height = targetHeight;\n const tempCtx = tempCanvas.getContext('2d');\n tempCtx?.drawImage(outCanvas, 0, 0);\n const data = tempCtx?.getImageData(0, 0, targetWidth, targetHeight);\n pixels = tf.browser.fromPixels(data);\n }\n const casted = pixels.toFloat();\n tensor = casted.expandDims(0);\n pixels.dispose();\n casted.dispose();\n }\n const canvas = config.filter.return ? outCanvas : null;\n return { tensor, canvas };\n}\n", "/*\nWebGLImageFilter - MIT Licensed\n2013, Dominic Szablewski - phoboslab.org\n\n*/\n\nfunction GLProgram(gl, vertexSource, fragmentSource) {\n const _collect = function (source, prefix, collection) {\n const r = new RegExp('\\\\b' + prefix + ' \\\\w+ (\\\\w+)', 'ig');\n source.replace(r, (match, name) => {\n collection[name] = 0;\n return match;\n });\n };\n\n const _compile = function (source, type) {\n const shader = gl.createShader(type);\n gl.shaderSource(shader, source);\n gl.compileShader(shader);\n if (!gl.getShaderParameter(shader, gl.COMPILE_STATUS)) throw new Error('Filter: GL compile failed', gl.getShaderInfoLog(shader));\n return shader;\n };\n\n this.uniform = {};\n this.attribute = {};\n const _vsh = _compile(vertexSource, gl.VERTEX_SHADER);\n const _fsh = _compile(fragmentSource, gl.FRAGMENT_SHADER);\n this.id = gl.createProgram();\n gl.attachShader(this.id, _vsh);\n gl.attachShader(this.id, _fsh);\n gl.linkProgram(this.id);\n\n if (!gl.getProgramParameter(this.id, gl.LINK_STATUS)) throw new Error('Filter: GL link failed', gl.getProgramInfoLog(this.id));\n\n gl.useProgram(this.id);\n // Collect attributes\n _collect(vertexSource, 'attribute', this.attribute);\n for (const a in this.attribute) this.attribute[a] = gl.getAttribLocation(this.id, a);\n // Collect uniforms\n _collect(vertexSource, 'uniform', this.uniform);\n _collect(fragmentSource, 'uniform', this.uniform);\n for (const u in this.uniform) this.uniform[u] = gl.getUniformLocation(this.id, u);\n}\n\n// export const GLImageFilter = function (params) {\nexport function GLImageFilter(params) {\n if (!params) params = { };\n let _drawCount = 0;\n let _sourceTexture = null;\n let _lastInChain = false;\n let _currentFramebufferIndex = -1;\n let _tempFramebuffers = [null, null];\n let _filterChain = [];\n let _width = -1;\n let _height = -1;\n let _vertexBuffer = null;\n let _currentProgram = null;\n const _filter = {};\n const _canvas = params.canvas || document.createElement('canvas');\n // key is the shader program source, value is the compiled program\n const _shaderProgramCache = { };\n const DRAW = { INTERMEDIATE: 1 };\n const gl = _canvas.getContext('webgl');\n if (!gl) throw new Error('Filter: getContext() failed');\n\n this.addFilter = function (name) {\n // eslint-disable-next-line prefer-rest-params\n const args = Array.prototype.slice.call(arguments, 1);\n const filter = _filter[name];\n _filterChain.push({ func: filter, args });\n };\n\n this.reset = function () {\n _filterChain = [];\n };\n\n const _resize = function (width, height) {\n // Same width/height? Nothing to do here\n if (width === _width && height === _height) { return; }\n _canvas.width = width;\n _width = width;\n _canvas.height = height;\n _height = height;\n // Create the context if we don't have it yet\n if (!_vertexBuffer) {\n // Create the vertex buffer for the two triangles [x, y, u, v] * 6\n const vertices = new Float32Array([\n -1, -1, 0, 1, 1, -1, 1, 1, -1, 1, 0, 0,\n -1, 1, 0, 0, 1, -1, 1, 1, 1, 1, 1, 0,\n ]);\n // eslint-disable-next-line no-unused-expressions\n (_vertexBuffer = gl.createBuffer(), gl.bindBuffer(gl.ARRAY_BUFFER, _vertexBuffer));\n gl.bufferData(gl.ARRAY_BUFFER, vertices, gl.STATIC_DRAW);\n gl.pixelStorei(gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, true);\n }\n gl.viewport(0, 0, _width, _height);\n // Delete old temp framebuffers\n _tempFramebuffers = [null, null];\n };\n\n const _createFramebufferTexture = function (width, height) {\n const fbo = gl.createFramebuffer();\n gl.bindFramebuffer(gl.FRAMEBUFFER, fbo);\n const renderbuffer = gl.createRenderbuffer();\n gl.bindRenderbuffer(gl.RENDERBUFFER, renderbuffer);\n const texture = gl.createTexture();\n gl.bindTexture(gl.TEXTURE_2D, texture);\n gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, width, height, 0, gl.RGBA, gl.UNSIGNED_BYTE, null);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\n gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, texture, 0);\n gl.bindTexture(gl.TEXTURE_2D, null);\n gl.bindFramebuffer(gl.FRAMEBUFFER, null);\n return { fbo, texture };\n };\n\n const _getTempFramebuffer = function (index) {\n _tempFramebuffers[index] = _tempFramebuffers[index] || _createFramebufferTexture(_width, _height);\n return _tempFramebuffers[index];\n };\n\n const _draw = function (flags = null) {\n let source = null;\n let target = null;\n let flipY = false;\n // Set up the source\n if (_drawCount === 0) {\n // First draw call - use the source texture\n source = _sourceTexture;\n } else {\n // All following draw calls use the temp buffer last drawn to\n source = _getTempFramebuffer(_currentFramebufferIndex)?.texture;\n }\n _drawCount++;\n // Set up the target\n if (_lastInChain && !(flags & DRAW.INTERMEDIATE)) {\n // Last filter in our chain - draw directly to the WebGL Canvas. We may\n // also have to flip the image vertically now\n target = null;\n flipY = _drawCount % 2 === 0;\n } else {\n // Intermediate draw call - get a temp buffer to draw to\n _currentFramebufferIndex = (_currentFramebufferIndex + 1) % 2;\n target = _getTempFramebuffer(_currentFramebufferIndex)?.fbo;\n }\n // Bind the source and target and draw the two triangles\n gl.bindTexture(gl.TEXTURE_2D, source);\n gl.bindFramebuffer(gl.FRAMEBUFFER, target);\n gl.uniform1f(_currentProgram.uniform.flipY, (flipY ? -1 : 1));\n gl.drawArrays(gl.TRIANGLES, 0, 6);\n };\n\n this.apply = function (image) {\n _resize(image.width, image.height);\n _drawCount = 0;\n // Create the texture for the input image if we haven't yet\n if (!_sourceTexture) _sourceTexture = gl.createTexture();\n gl.bindTexture(gl.TEXTURE_2D, _sourceTexture);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.NEAREST);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.NEAREST);\n gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, image);\n // No filters? Just draw\n if (_filterChain.length === 0) {\n // const program = _compileShader(SHADER.FRAGMENT_IDENTITY);\n _draw();\n return _canvas;\n }\n for (let i = 0; i < _filterChain.length; i++) {\n _lastInChain = (i === _filterChain.length - 1);\n const f = _filterChain[i];\n f.func.apply(this, f.args || []);\n }\n return _canvas;\n };\n\n const _compileShader = function (fragmentSource) {\n if (_shaderProgramCache[fragmentSource]) {\n _currentProgram = _shaderProgramCache[fragmentSource];\n gl.useProgram(_currentProgram.id);\n return _currentProgram;\n }\n // Compile shaders\n const SHADER = {};\n SHADER.VERTEX_IDENTITY = [\n 'precision highp float;',\n 'attribute vec2 pos;',\n 'attribute vec2 uv;',\n 'varying vec2 vUv;',\n 'uniform float flipY;',\n 'void main(void) {',\n 'vUv = uv;',\n 'gl_Position = vec4(pos.x, pos.y*flipY, 0.0, 1.);',\n '}',\n ].join('\\n');\n SHADER.FRAGMENT_IDENTITY = [\n 'precision highp float;',\n 'varying vec2 vUv;',\n 'uniform sampler2D texture;',\n 'void main(void) {',\n 'gl_FragColor = texture2D(texture, vUv);',\n '}',\n ].join('\\n');\n _currentProgram = new GLProgram(gl, SHADER.VERTEX_IDENTITY, fragmentSource);\n const floatSize = Float32Array.BYTES_PER_ELEMENT;\n const vertSize = 4 * floatSize;\n gl.enableVertexAttribArray(_currentProgram.attribute.pos);\n gl.vertexAttribPointer(_currentProgram.attribute.pos, 2, gl.FLOAT, false, vertSize, 0 * floatSize);\n gl.enableVertexAttribArray(_currentProgram.attribute.uv);\n gl.vertexAttribPointer(_currentProgram.attribute.uv, 2, gl.FLOAT, false, vertSize, 2 * floatSize);\n _shaderProgramCache[fragmentSource] = _currentProgram;\n return _currentProgram;\n };\n\n // -------------------------------------------------------------------------\n // Color Matrix Filter\n _filter.colorMatrix = function (matrix) {\n // Create a Float32 Array and normalize the offset component to 0-1\n const m = new Float32Array(matrix);\n m[4] /= 255;\n m[9] /= 255;\n m[14] /= 255;\n m[19] /= 255;\n // Can we ignore the alpha value? Makes things a bit faster.\n const shader = (m[18] === 1 && m[3] === 0 && m[8] === 0 && m[13] === 0 && m[15] === 0 && m[16] === 0 && m[17] === 0 && m[19] === 0)\n ? _filter.colorMatrix.SHADER.WITHOUT_ALPHA\n : _filter.colorMatrix.SHADER.WITH_ALPHA;\n const program = _compileShader(shader);\n gl.uniform1fv(program.uniform.m, m);\n _draw();\n };\n _filter.colorMatrix.SHADER = {};\n _filter.colorMatrix.SHADER.WITH_ALPHA = [\n 'precision highp float;',\n 'varying vec2 vUv;',\n 'uniform sampler2D texture;',\n 'uniform float m[20];',\n 'void main(void) {',\n 'vec4 c = texture2D(texture, vUv);',\n 'gl_FragColor.r = m[0] * c.r + m[1] * c.g + m[2] * c.b + m[3] * c.a + m[4];',\n 'gl_FragColor.g = m[5] * c.r + m[6] * c.g + m[7] * c.b + m[8] * c.a + m[9];',\n 'gl_FragColor.b = m[10] * c.r + m[11] * c.g + m[12] * c.b + m[13] * c.a + m[14];',\n 'gl_FragColor.a = m[15] * c.r + m[16] * c.g + m[17] * c.b + m[18] * c.a + m[19];',\n '}',\n ].join('\\n');\n _filter.colorMatrix.SHADER.WITHOUT_ALPHA = [\n 'precision highp float;',\n 'varying vec2 vUv;',\n 'uniform sampler2D texture;',\n 'uniform float m[20];',\n 'void main(void) {',\n 'vec4 c = texture2D(texture, vUv);',\n 'gl_FragColor.r = m[0] * c.r + m[1] * c.g + m[2] * c.b + m[4];',\n 'gl_FragColor.g = m[5] * c.r + m[6] * c.g + m[7] * c.b + m[9];',\n 'gl_FragColor.b = m[10] * c.r + m[11] * c.g + m[12] * c.b + m[14];',\n 'gl_FragColor.a = c.a;',\n '}',\n ].join('\\n');\n\n _filter.brightness = function (brightness) {\n const b = (brightness || 0) + 1;\n _filter.colorMatrix([\n b, 0, 0, 0, 0,\n 0, b, 0, 0, 0,\n 0, 0, b, 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n _filter.saturation = function (amount) {\n const x = (amount || 0) * 2 / 3 + 1;\n const y = ((x - 1) * -0.5);\n _filter.colorMatrix([\n x, y, y, 0, 0,\n y, x, y, 0, 0,\n y, y, x, 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n _filter.desaturate = function () {\n _filter.saturation(-1);\n };\n\n _filter.contrast = function (amount) {\n const v = (amount || 0) + 1;\n const o = -128 * (v - 1);\n\n _filter.colorMatrix([\n v, 0, 0, 0, o,\n 0, v, 0, 0, o,\n 0, 0, v, 0, o,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n _filter.negative = function () {\n _filter.contrast(-2);\n };\n\n _filter.hue = function (rotation) {\n rotation = (rotation || 0) / 180 * Math.PI;\n const cos = Math.cos(rotation);\n const sin = Math.sin(rotation);\n const lumR = 0.213;\n const lumG = 0.715;\n const lumB = 0.072;\n\n _filter.colorMatrix([\n lumR + cos * (1 - lumR) + sin * (-lumR), lumG + cos * (-lumG) + sin * (-lumG), lumB + cos * (-lumB) + sin * (1 - lumB), 0, 0,\n lumR + cos * (-lumR) + sin * (0.143), lumG + cos * (1 - lumG) + sin * (0.140), lumB + cos * (-lumB) + sin * (-0.283), 0, 0,\n lumR + cos * (-lumR) + sin * (-(1 - lumR)), lumG + cos * (-lumG) + sin * (lumG), lumB + cos * (1 - lumB) + sin * (lumB), 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n _filter.desaturateLuminance = function () {\n _filter.colorMatrix([\n 0.2764723, 0.9297080, 0.0938197, 0, -37.1,\n 0.2764723, 0.9297080, 0.0938197, 0, -37.1,\n 0.2764723, 0.9297080, 0.0938197, 0, -37.1,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n _filter.sepia = function () {\n _filter.colorMatrix([\n 0.393, 0.7689999, 0.18899999, 0, 0,\n 0.349, 0.6859999, 0.16799999, 0, 0,\n 0.272, 0.5339999, 0.13099999, 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n _filter.brownie = function () {\n _filter.colorMatrix([\n 0.5997023498159715, 0.34553243048391263, -0.2708298674538042, 0, 47.43192855600873,\n -0.037703249837783157, 0.8609577587992641, 0.15059552388459913, 0, -36.96841498319127,\n 0.24113635128153335, -0.07441037908422492, 0.44972182064877153, 0, -7.562075277591283,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n _filter.vintagePinhole = function () {\n _filter.colorMatrix([\n 0.6279345635605994, 0.3202183420819367, -0.03965408211312453, 0, 9.651285835294123,\n 0.02578397704808868, 0.6441188644374771, 0.03259127616149294, 0, 7.462829176470591,\n 0.0466055556782719, -0.0851232987247891, 0.5241648018700465, 0, 5.159190588235296,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n _filter.kodachrome = function () {\n _filter.colorMatrix([\n 1.1285582396593525, -0.3967382283601348, -0.03992559172921793, 0, 63.72958762196502,\n -0.16404339962244616, 1.0835251566291304, -0.05498805115633132, 0, 24.732407896706203,\n -0.16786010706155763, -0.5603416277695248, 1.6014850761964943, 0, 35.62982807460946,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n _filter.technicolor = function () {\n _filter.colorMatrix([\n 1.9125277891456083, -0.8545344976951645, -0.09155508482755585, 0, 11.793603434377337,\n -0.3087833385928097, 1.7658908555458428, -0.10601743074722245, 0, -70.35205161461398,\n -0.231103377548616, -0.7501899197440212, 1.847597816108189, 0, 30.950940869491138,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n _filter.polaroid = function () {\n _filter.colorMatrix([\n 1.438, -0.062, -0.062, 0, 0,\n -0.122, 1.378, -0.122, 0, 0,\n -0.016, -0.016, 1.483, 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n _filter.shiftToBGR = function () {\n _filter.colorMatrix([\n 0, 0, 1, 0, 0,\n 0, 1, 0, 0, 0,\n 1, 0, 0, 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n // -------------------------------------------------------------------------\n // Convolution Filter\n _filter.convolution = function (matrix) {\n const m = new Float32Array(matrix);\n const pixelSizeX = 1 / _width;\n const pixelSizeY = 1 / _height;\n const program = _compileShader(_filter.convolution.SHADER);\n gl.uniform1fv(program.uniform.m, m);\n gl.uniform2f(program.uniform.px, pixelSizeX, pixelSizeY);\n _draw();\n };\n\n _filter.convolution.SHADER = [\n 'precision highp float;',\n 'varying vec2 vUv;',\n 'uniform sampler2D texture;',\n 'uniform vec2 px;',\n 'uniform float m[9];',\n 'void main(void) {',\n 'vec4 c11 = texture2D(texture, vUv - px);', // top left\n 'vec4 c12 = texture2D(texture, vec2(vUv.x, vUv.y - px.y));', // top center\n 'vec4 c13 = texture2D(texture, vec2(vUv.x + px.x, vUv.y - px.y));', // top right\n 'vec4 c21 = texture2D(texture, vec2(vUv.x - px.x, vUv.y) );', // mid left\n 'vec4 c22 = texture2D(texture, vUv);', // mid center\n 'vec4 c23 = texture2D(texture, vec2(vUv.x + px.x, vUv.y) );', // mid right\n 'vec4 c31 = texture2D(texture, vec2(vUv.x - px.x, vUv.y + px.y) );', // bottom left\n 'vec4 c32 = texture2D(texture, vec2(vUv.x, vUv.y + px.y) );', // bottom center\n 'vec4 c33 = texture2D(texture, vUv + px );', // bottom right\n 'gl_FragColor = ',\n 'c11 * m[0] + c12 * m[1] + c22 * m[2] +',\n 'c21 * m[3] + c22 * m[4] + c23 * m[5] +',\n 'c31 * m[6] + c32 * m[7] + c33 * m[8];',\n 'gl_FragColor.a = c22.a;',\n '}',\n ].join('\\n');\n\n _filter.detectEdges = function () {\n _filter.convolution.call(this, [\n 0, 1, 0,\n 1, -4, 1,\n 0, 1, 0,\n ]);\n };\n\n _filter.sobelX = function () {\n _filter.convolution.call(this, [\n -1, 0, 1,\n -2, 0, 2,\n -1, 0, 1,\n ]);\n };\n\n _filter.sobelY = function () {\n _filter.convolution.call(this, [\n -1, -2, -1,\n 0, 0, 0,\n 1, 2, 1,\n ]);\n };\n\n _filter.sharpen = function (amount) {\n const a = amount || 1;\n _filter.convolution.call(this, [\n 0, -1 * a, 0,\n -1 * a, 1 + 4 * a, -1 * a,\n 0, -1 * a, 0,\n ]);\n };\n\n _filter.emboss = function (size) {\n const s = size || 1;\n _filter.convolution.call(this, [\n -2 * s, -1 * s, 0,\n -1 * s, 1, 1 * s,\n 0, 1 * s, 2 * s,\n ]);\n };\n\n // -------------------------------------------------------------------------\n // Blur Filter\n _filter.blur = function (size) {\n const blurSizeX = (size / 7) / _width;\n const blurSizeY = (size / 7) / _height;\n const program = _compileShader(_filter.blur.SHADER);\n // Vertical\n gl.uniform2f(program.uniform.px, 0, blurSizeY);\n _draw(DRAW.INTERMEDIATE);\n // Horizontal\n gl.uniform2f(program.uniform.px, blurSizeX, 0);\n _draw();\n };\n\n _filter.blur.SHADER = [\n 'precision highp float;',\n 'varying vec2 vUv;',\n 'uniform sampler2D texture;',\n 'uniform vec2 px;',\n 'void main(void) {',\n 'gl_FragColor = vec4(0.0);',\n 'gl_FragColor += texture2D(texture, vUv + vec2(-7.0*px.x, -7.0*px.y))*0.0044299121055113265;',\n 'gl_FragColor += texture2D(texture, vUv + vec2(-6.0*px.x, -6.0*px.y))*0.00895781211794;',\n 'gl_FragColor += texture2D(texture, vUv + vec2(-5.0*px.x, -5.0*px.y))*0.0215963866053;',\n 'gl_FragColor += texture2D(texture, vUv + vec2(-4.0*px.x, -4.0*px.y))*0.0443683338718;',\n 'gl_FragColor += texture2D(texture, vUv + vec2(-3.0*px.x, -3.0*px.y))*0.0776744219933;',\n 'gl_FragColor += texture2D(texture, vUv + vec2(-2.0*px.x, -2.0*px.y))*0.115876621105;',\n 'gl_FragColor += texture2D(texture, vUv + vec2(-1.0*px.x, -1.0*px.y))*0.147308056121;',\n 'gl_FragColor += texture2D(texture, vUv )*0.159576912161;',\n 'gl_FragColor += texture2D(texture, vUv + vec2( 1.0*px.x, 1.0*px.y))*0.147308056121;',\n 'gl_FragColor += texture2D(texture, vUv + vec2( 2.0*px.x, 2.0*px.y))*0.115876621105;',\n 'gl_FragColor += texture2D(texture, vUv + vec2( 3.0*px.x, 3.0*px.y))*0.0776744219933;',\n 'gl_FragColor += texture2D(texture, vUv + vec2( 4.0*px.x, 4.0*px.y))*0.0443683338718;',\n 'gl_FragColor += texture2D(texture, vUv + vec2( 5.0*px.x, 5.0*px.y))*0.0215963866053;',\n 'gl_FragColor += texture2D(texture, vUv + vec2( 6.0*px.x, 6.0*px.y))*0.00895781211794;',\n 'gl_FragColor += texture2D(texture, vUv + vec2( 7.0*px.x, 7.0*px.y))*0.0044299121055113265;',\n '}',\n ].join('\\n');\n\n // -------------------------------------------------------------------------\n // Pixelate Filter\n _filter.pixelate = function (size) {\n const blurSizeX = (size) / _width;\n const blurSizeY = (size) / _height;\n const program = _compileShader(_filter.pixelate.SHADER);\n // Horizontal\n gl.uniform2f(program.uniform.size, blurSizeX, blurSizeY);\n _draw();\n };\n\n _filter.pixelate.SHADER = [\n 'precision highp float;',\n 'varying vec2 vUv;',\n 'uniform vec2 size;',\n 'uniform sampler2D texture;',\n 'vec2 pixelate(vec2 coord, vec2 size) {',\n 'return floor( coord / size ) * size;',\n '}',\n 'void main(void) {',\n 'gl_FragColor = vec4(0.0);',\n 'vec2 coord = pixelate(vUv, size);',\n 'gl_FragColor += texture2D(texture, coord);',\n '}',\n ].join('\\n');\n}\n", "import { defaults } from '../config';\nimport { TRI468 as triangulation } from '../blazeface/coords';\nimport { mergeDeep } from '../helpers';\n\n/**\n * Draw Options\n * Accessed via `human.draw.options` or provided per each draw method as the drawOptions optional parameter\n * -color: draw color\n * -labelColor: color for labels\n * -shadowColor: optional shadow color for labels\n * -font: font for labels\n * -lineHeight: line height for labels, used for multi-line labels,\n * -lineWidth: width of any lines,\n * -pointSize: size of any point,\n * -roundRect: for boxes, round corners by this many pixels,\n * -drawPoints: should points be drawn,\n * -drawLabels: should labels be drawn,\n * -drawBoxes: should boxes be drawn,\n * -drawPolygons: should polygons be drawn,\n * -fillPolygons: should drawn polygons be filled,\n * -useDepth: use z-axis coordinate as color shade,\n * -useCurves: draw polygons as cures or as lines,\n * -bufferedOutput: experimental: allows to call draw methods multiple times for each detection and interpolate results between results thus achieving smoother animations\n * -useRawBoxes: Boolean: internal: use non-normalized coordinates when performing draw methods,\n */\nexport interface DrawOptions {\n color: string,\n labelColor: string,\n shadowColor: string,\n font: string,\n lineHeight: number,\n lineWidth: number,\n pointSize: number,\n roundRect: number,\n drawPoints: Boolean,\n drawLabels: Boolean,\n drawBoxes: Boolean,\n drawPolygons: Boolean,\n fillPolygons: Boolean,\n useDepth: Boolean,\n useCurves: Boolean,\n bufferedOutput: Boolean,\n useRawBoxes: Boolean,\n calculateHandBox: Boolean,\n}\n\nexport const options: DrawOptions = {\n color: 'rgba(173, 216, 230, 0.3)', // 'lightblue' with light alpha channel\n labelColor: 'rgba(173, 216, 230, 1)', // 'lightblue' with dark alpha channel\n shadowColor: 'black',\n font: 'small-caps 16px \"Segoe UI\"',\n lineHeight: 24,\n lineWidth: 6,\n pointSize: 2,\n roundRect: 28,\n drawPoints: false,\n drawLabels: true,\n drawBoxes: false,\n drawPolygons: true,\n fillPolygons: false,\n useDepth: true,\n useCurves: false,\n bufferedOutput: false,\n useRawBoxes: false,\n calculateHandBox: true,\n};\n\nfunction point(ctx, x, y, z = 0, localOptions) {\n ctx.fillStyle = localOptions.useDepth && z ? `rgba(${127.5 + (2 * z)}, ${127.5 - (2 * z)}, 255, 0.3)` : localOptions.color;\n ctx.beginPath();\n ctx.arc(x, y, localOptions.pointSize, 0, 2 * Math.PI);\n ctx.fill();\n}\n\nfunction rect(ctx, x, y, width, height, localOptions) {\n ctx.beginPath();\n if (localOptions.useCurves) {\n const cx = (x + x + width) / 2;\n const cy = (y + y + height) / 2;\n ctx.ellipse(cx, cy, width / 2, height / 2, 0, 0, 2 * Math.PI);\n } else {\n ctx.lineWidth = localOptions.lineWidth;\n ctx.moveTo(x + localOptions.roundRect, y);\n ctx.lineTo(x + width - localOptions.roundRect, y);\n ctx.quadraticCurveTo(x + width, y, x + width, y + localOptions.roundRect);\n ctx.lineTo(x + width, y + height - localOptions.roundRect);\n ctx.quadraticCurveTo(x + width, y + height, x + width - localOptions.roundRect, y + height);\n ctx.lineTo(x + localOptions.roundRect, y + height);\n ctx.quadraticCurveTo(x, y + height, x, y + height - localOptions.roundRect);\n ctx.lineTo(x, y + localOptions.roundRect);\n ctx.quadraticCurveTo(x, y, x + localOptions.roundRect, y);\n ctx.closePath();\n }\n ctx.stroke();\n}\n\nfunction lines(ctx, points: number[] = [], localOptions) {\n if (points === undefined || points.length === 0) return;\n ctx.beginPath();\n ctx.moveTo(points[0][0], points[0][1]);\n for (const pt of points) {\n ctx.strokeStyle = localOptions.useDepth && pt[2] ? `rgba(${127.5 + (2 * pt[2])}, ${127.5 - (2 * pt[2])}, 255, 0.3)` : localOptions.color;\n ctx.fillStyle = localOptions.useDepth && pt[2] ? `rgba(${127.5 + (2 * pt[2])}, ${127.5 - (2 * pt[2])}, 255, 0.3)` : localOptions.color;\n ctx.lineTo(pt[0], parseInt(pt[1]));\n }\n ctx.stroke();\n if (localOptions.fillPolygons) {\n ctx.closePath();\n ctx.fill();\n }\n}\n\nfunction curves(ctx, points: number[] = [], localOptions) {\n if (points === undefined || points.length === 0) return;\n if (!localOptions.useCurves || points.length <= 2) {\n lines(ctx, points, localOptions);\n return;\n }\n ctx.moveTo(points[0][0], points[0][1]);\n for (let i = 0; i < points.length - 2; i++) {\n const xc = (points[i][0] + points[i + 1][0]) / 2;\n const yc = (points[i][1] + points[i + 1][1]) / 2;\n ctx.quadraticCurveTo(points[i][0], points[i][1], xc, yc);\n }\n ctx.quadraticCurveTo(points[points.length - 2][0], points[points.length - 2][1], points[points.length - 1][0], points[points.length - 1][1]);\n ctx.stroke();\n if (localOptions.fillPolygons) {\n ctx.closePath();\n ctx.fill();\n }\n}\n\nexport async function gesture(inCanvas: HTMLCanvasElement, result: Array, drawOptions?: DrawOptions) {\n const localOptions = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n if (!(inCanvas instanceof HTMLCanvasElement)) return;\n const ctx = inCanvas.getContext('2d');\n if (!ctx) return;\n ctx.font = localOptions.font;\n ctx.fillStyle = localOptions.color;\n let i = 1;\n for (let j = 0; j < result.length; j++) {\n let where:any[] = [];\n let what:any[] = [];\n [where, what] = Object.entries(result[j]);\n if ((what.length > 1) && (what[1].length > 0)) {\n const person = where[1] > 0 ? `#${where[1]}` : '';\n const label = `${where[0]} ${person}: ${what[1]}`;\n if (localOptions.shadowColor && localOptions.shadowColor !== '') {\n ctx.fillStyle = localOptions.shadowColor;\n ctx.fillText(label, 8, 2 + (i * localOptions.lineHeight));\n }\n ctx.fillStyle = localOptions.labelColor;\n ctx.fillText(label, 6, 0 + (i * localOptions.lineHeight));\n i += 1;\n }\n }\n}\n\nexport async function face(inCanvas: HTMLCanvasElement, result: Array, drawOptions?: DrawOptions) {\n const localOptions = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n if (!(inCanvas instanceof HTMLCanvasElement)) return;\n const ctx = inCanvas.getContext('2d');\n if (!ctx) return;\n for (const f of result) {\n ctx.font = localOptions.font;\n ctx.strokeStyle = localOptions.color;\n ctx.fillStyle = localOptions.color;\n if (localOptions.drawBoxes) {\n if (localOptions.useRawBoxes) rect(ctx, inCanvas.width * f.boxRaw[0], inCanvas.height * f.boxRaw[1], inCanvas.width * f.boxRaw[2], inCanvas.height * f.boxRaw[3], localOptions);\n else rect(ctx, f.box[0], f.box[1], f.box[2], f.box[3], localOptions);\n }\n // silly hack since fillText does not suport new line\n const labels:string[] = [];\n labels.push(`face confidence: ${Math.trunc(100 * f.confidence)}%`);\n if (f.genderConfidence) labels.push(`${f.gender || ''} ${Math.trunc(100 * f.genderConfidence)}% confident`);\n // if (f.genderConfidence) labels.push(f.gender);\n if (f.age) labels.push(`age: ${f.age || ''}`);\n if (f.iris) labels.push(`iris distance: ${f.iris}`);\n if (f.emotion && f.emotion.length > 0) {\n const emotion = f.emotion.map((a) => `${Math.trunc(100 * a.score)}% ${a.emotion}`);\n labels.push(emotion.join(' '));\n }\n if (f.rotation && f.rotation.angle && f.rotation.angle.roll) labels.push(`roll: ${Math.trunc(100 * f.rotation.angle.roll) / 100} yaw:${Math.trunc(100 * f.rotation.angle.yaw) / 100} pitch:${Math.trunc(100 * f.rotation.angle.pitch) / 100}`);\n if (labels.length === 0) labels.push('face');\n ctx.fillStyle = localOptions.color;\n for (let i = labels.length - 1; i >= 0; i--) {\n const x = Math.max(f.box[0], 0);\n const y = i * localOptions.lineHeight + f.box[1];\n if (localOptions.shadowColor && localOptions.shadowColor !== '') {\n ctx.fillStyle = localOptions.shadowColor;\n ctx.fillText(labels[i], x + 5, y + 16);\n }\n ctx.fillStyle = localOptions.labelColor;\n ctx.fillText(labels[i], x + 4, y + 15);\n }\n ctx.lineWidth = 1;\n if (f.mesh && f.mesh.length > 0) {\n if (localOptions.drawPoints) {\n for (const pt of f.mesh) point(ctx, pt[0], pt[1], pt[2], localOptions);\n // for (const pt of f.meshRaw) point(ctx, pt[0] * inCanvas.offsetWidth, pt[1] * inCanvas.offsetHeight, pt[2]);\n }\n if (localOptions.drawPolygons) {\n ctx.lineWidth = 1;\n for (let i = 0; i < triangulation.length / 3; i++) {\n const points = [\n triangulation[i * 3 + 0],\n triangulation[i * 3 + 1],\n triangulation[i * 3 + 2],\n ].map((index) => f.mesh[index]);\n lines(ctx, points, localOptions);\n }\n // iris: array[center, left, top, right, bottom]\n if (f.annotations && f.annotations.leftEyeIris) {\n ctx.strokeStyle = localOptions.useDepth ? 'rgba(255, 200, 255, 0.3)' : localOptions.color;\n ctx.beginPath();\n const sizeX = Math.abs(f.annotations.leftEyeIris[3][0] - f.annotations.leftEyeIris[1][0]) / 2;\n const sizeY = Math.abs(f.annotations.leftEyeIris[4][1] - f.annotations.leftEyeIris[2][1]) / 2;\n ctx.ellipse(f.annotations.leftEyeIris[0][0], f.annotations.leftEyeIris[0][1], sizeX, sizeY, 0, 0, 2 * Math.PI);\n ctx.stroke();\n if (localOptions.fillPolygons) {\n ctx.fillStyle = localOptions.useDepth ? 'rgba(255, 255, 200, 0.3)' : localOptions.color;\n ctx.fill();\n }\n }\n if (f.annotations && f.annotations.rightEyeIris) {\n ctx.strokeStyle = localOptions.useDepth ? 'rgba(255, 200, 255, 0.3)' : localOptions.color;\n ctx.beginPath();\n const sizeX = Math.abs(f.annotations.rightEyeIris[3][0] - f.annotations.rightEyeIris[1][0]) / 2;\n const sizeY = Math.abs(f.annotations.rightEyeIris[4][1] - f.annotations.rightEyeIris[2][1]) / 2;\n ctx.ellipse(f.annotations.rightEyeIris[0][0], f.annotations.rightEyeIris[0][1], sizeX, sizeY, 0, 0, 2 * Math.PI);\n ctx.stroke();\n if (localOptions.fillPolygons) {\n ctx.fillStyle = localOptions.useDepth ? 'rgba(255, 255, 200, 0.3)' : localOptions.color;\n ctx.fill();\n }\n }\n }\n }\n }\n}\n\nconst lastDrawnPose:any[] = [];\nexport async function body(inCanvas: HTMLCanvasElement, result: Array, drawOptions?: DrawOptions) {\n const localOptions = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n if (!(inCanvas instanceof HTMLCanvasElement)) return;\n const ctx = inCanvas.getContext('2d');\n if (!ctx) return;\n ctx.lineJoin = 'round';\n for (let i = 0; i < result.length; i++) {\n // result[i].keypoints = result[i].keypoints.filter((a) => a.score > 0.5);\n if (!lastDrawnPose[i] && localOptions.bufferedOutput) lastDrawnPose[i] = { ...result[i] };\n ctx.strokeStyle = localOptions.color;\n ctx.fillStyle = localOptions.color;\n ctx.lineWidth = localOptions.lineWidth;\n ctx.font = localOptions.font;\n if (localOptions.drawBoxes) {\n rect(ctx, result[i].box[0], result[i].box[1], result[i].box[2], result[i].box[3], localOptions);\n if (localOptions.drawLabels) {\n if (localOptions.shadowColor && localOptions.shadowColor !== '') {\n ctx.fillStyle = localOptions.shadowColor;\n ctx.fillText(`body ${100 * result[i].score}%`, result[i].box[0] + 3, 1 + result[i].box[1] + localOptions.lineHeight, result[i].box[2]);\n }\n ctx.fillStyle = localOptions.labelColor;\n ctx.fillText(`body ${100 * result[i].score}%`, result[i].box[0] + 2, 0 + result[i].box[1] + localOptions.lineHeight, result[i].box[2]);\n }\n }\n if (localOptions.drawPoints) {\n for (let pt = 0; pt < result[i].keypoints.length; pt++) {\n ctx.fillStyle = localOptions.useDepth && result[i].keypoints[pt].position.z ? `rgba(${127.5 + (2 * result[i].keypoints[pt].position.z)}, ${127.5 - (2 * result[i].keypoints[pt].position.z)}, 255, 0.5)` : localOptions.color;\n if (localOptions.bufferedOutput) {\n lastDrawnPose[i].keypoints[pt][0] = (lastDrawnPose[i].keypoints[pt][0] + result[i].keypoints[pt].position.x) / 2;\n lastDrawnPose[i].keypoints[pt][1] = (lastDrawnPose[i].keypoints[pt][1] + result[i].keypoints[pt].position.y) / 2;\n point(ctx, lastDrawnPose[i].keypoints[pt][0], lastDrawnPose[i].keypoints[pt][1], 0, localOptions);\n } else {\n point(ctx, result[i].keypoints[pt].position.x, result[i].keypoints[pt].position.y, 0, localOptions);\n }\n }\n }\n if (localOptions.drawLabels) {\n ctx.font = localOptions.font;\n if (result[i].keypoints) {\n for (const pt of result[i].keypoints) {\n ctx.fillStyle = localOptions.useDepth && pt.position.z ? `rgba(${127.5 + (2 * pt.position.z)}, ${127.5 - (2 * pt.position.z)}, 255, 0.5)` : localOptions.color;\n ctx.fillText(`${pt.part} ${Math.trunc(100 * pt.score)}%`, pt.position.x + 4, pt.position.y + 4);\n }\n }\n }\n if (localOptions.drawPolygons && result[i].keypoints) {\n let part;\n const points: any[] = [];\n // shoulder line\n points.length = 0;\n part = result[i].keypoints.find((a) => a.part === 'leftShoulder');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'rightShoulder');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n curves(ctx, points, localOptions);\n // torso main\n points.length = 0;\n part = result[i].keypoints.find((a) => a.part === 'rightShoulder');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'rightHip');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'leftHip');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'leftShoulder');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n if (points.length === 4) lines(ctx, points, localOptions); // only draw if we have complete torso\n // leg left\n points.length = 0;\n part = result[i].keypoints.find((a) => a.part === 'leftHip');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'leftKnee');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'leftAnkle');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'leftHeel');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'leftFoot');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n curves(ctx, points, localOptions);\n // leg right\n points.length = 0;\n part = result[i].keypoints.find((a) => a.part === 'rightHip');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'rightKnee');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'rightAnkle');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'rightHeel');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'rightFoot');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n curves(ctx, points, localOptions);\n // arm left\n points.length = 0;\n part = result[i].keypoints.find((a) => a.part === 'leftShoulder');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'leftElbow');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'leftWrist');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'leftPalm');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n curves(ctx, points, localOptions);\n // arm right\n points.length = 0;\n part = result[i].keypoints.find((a) => a.part === 'rightShoulder');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'rightElbow');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'rightWrist');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'rightPalm');\n if (part && part.score > defaults.body.minConfidence) points.push([part.position.x, part.position.y]);\n curves(ctx, points, localOptions);\n // draw all\n }\n }\n}\n\nexport async function hand(inCanvas: HTMLCanvasElement, result: Array, drawOptions?: DrawOptions) {\n const localOptions = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n if (!(inCanvas instanceof HTMLCanvasElement)) return;\n const ctx = inCanvas.getContext('2d');\n if (!ctx) return;\n ctx.lineJoin = 'round';\n ctx.font = localOptions.font;\n for (const h of result) {\n if (localOptions.drawBoxes) {\n ctx.strokeStyle = localOptions.color;\n ctx.fillStyle = localOptions.color;\n let box;\n if (!localOptions.calculateHandBox) {\n box = localOptions.useRawBoxes ? h.boxRaw : h.box;\n } else {\n box = [Number.MAX_SAFE_INTEGER, Number.MAX_SAFE_INTEGER, 0, 0];\n if (h.landmarks && h.landmarks.length > 0) {\n for (const pt of h.landmarks) {\n if (pt[0] < box[0]) box[0] = pt[0];\n if (pt[1] < box[1]) box[1] = pt[1];\n if (pt[0] > box[2]) box[2] = pt[0];\n if (pt[1] > box[3]) box[3] = pt[1];\n }\n box[2] -= box[0];\n box[3] -= box[1];\n }\n }\n if (localOptions.useRawBoxes) rect(ctx, inCanvas.width * box[0], inCanvas.height * box[1], inCanvas.width * box[2], inCanvas.height * box[3], localOptions);\n else rect(ctx, box[0], box[1], box[2], box[3], localOptions);\n if (localOptions.drawLabels) {\n if (localOptions.shadowColor && localOptions.shadowColor !== '') {\n ctx.fillStyle = localOptions.shadowColor;\n ctx.fillText('hand', box[0] + 3, 1 + box[1] + localOptions.lineHeight, box[2]);\n }\n ctx.fillStyle = localOptions.labelColor;\n ctx.fillText('hand', box[0] + 2, 0 + box[1] + localOptions.lineHeight, box[2]);\n }\n ctx.stroke();\n }\n if (localOptions.drawPoints) {\n if (h.landmarks && h.landmarks.length > 0) {\n for (const pt of h.landmarks) {\n ctx.fillStyle = localOptions.useDepth ? `rgba(${127.5 + (2 * pt[2])}, ${127.5 - (2 * pt[2])}, 255, 0.5)` : localOptions.color;\n point(ctx, pt[0], pt[1], 0, localOptions);\n }\n }\n }\n if (localOptions.drawLabels) {\n const addHandLabel = (part, title) => {\n ctx.fillStyle = localOptions.useDepth ? `rgba(${127.5 + (2 * part[part.length - 1][2])}, ${127.5 - (2 * part[part.length - 1][2])}, 255, 0.5)` : localOptions.color;\n ctx.fillText(title, part[part.length - 1][0] + 4, part[part.length - 1][1] + 4);\n };\n ctx.font = localOptions.font;\n addHandLabel(h.annotations.indexFinger, 'index');\n addHandLabel(h.annotations.middleFinger, 'middle');\n addHandLabel(h.annotations.ringFinger, 'ring');\n addHandLabel(h.annotations.pinky, 'pinky');\n addHandLabel(h.annotations.thumb, 'thumb');\n addHandLabel(h.annotations.palmBase, 'palm');\n }\n if (localOptions.drawPolygons) {\n const addHandLine = (part) => {\n if (!part) return;\n for (let i = 0; i < part.length; i++) {\n ctx.beginPath();\n ctx.strokeStyle = localOptions.useDepth ? `rgba(${127.5 + (2 * part[i][2])}, ${127.5 - (2 * part[i][2])}, 255, 0.5)` : localOptions.color;\n ctx.moveTo(part[i > 0 ? i - 1 : 0][0], part[i > 0 ? i - 1 : 0][1]);\n ctx.lineTo(part[i][0], part[i][1]);\n ctx.stroke();\n }\n };\n ctx.lineWidth = localOptions.lineWidth;\n addHandLine(h.annotations.indexFinger);\n addHandLine(h.annotations.middleFinger);\n addHandLine(h.annotations.ringFinger);\n addHandLine(h.annotations.pinky);\n addHandLine(h.annotations.thumb);\n // addPart(h.annotations.palmBase);\n }\n }\n}\n\nexport async function object(inCanvas: HTMLCanvasElement, result: Array, drawOptions?: DrawOptions) {\n const localOptions = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n if (!(inCanvas instanceof HTMLCanvasElement)) return;\n const ctx = inCanvas.getContext('2d');\n if (!ctx) return;\n ctx.lineJoin = 'round';\n ctx.font = localOptions.font;\n for (const h of result) {\n if (localOptions.drawBoxes) {\n ctx.strokeStyle = localOptions.color;\n ctx.fillStyle = localOptions.color;\n if (localOptions.useRawBoxes) rect(ctx, inCanvas.width * h.boxRaw[0], inCanvas.height * h.boxRaw[1], inCanvas.width * h.boxRaw[2], inCanvas.height * h.boxRaw[3], localOptions);\n else rect(ctx, h.box[0], h.box[1], h.box[2], h.box[3], localOptions);\n if (localOptions.drawLabels) {\n const label = `${Math.round(100 * h.score)}% ${h.label}`;\n if (localOptions.shadowColor && localOptions.shadowColor !== '') {\n ctx.fillStyle = localOptions.shadowColor;\n ctx.fillText(label, h.box[0] + 3, 1 + h.box[1] + localOptions.lineHeight, h.box[2]);\n }\n ctx.fillStyle = localOptions.labelColor;\n ctx.fillText(label, h.box[0] + 2, 0 + h.box[1] + localOptions.lineHeight, h.box[2]);\n }\n ctx.stroke();\n }\n }\n}\n\nexport async function canvas(inCanvas: HTMLCanvasElement, outCanvas: HTMLCanvasElement) {\n if (!inCanvas || !outCanvas) return;\n if (!(inCanvas instanceof HTMLCanvasElement) || !(outCanvas instanceof HTMLCanvasElement)) return;\n const outCtx = inCanvas.getContext('2d');\n outCtx?.drawImage(inCanvas, 0, 0);\n}\n\nexport async function all(inCanvas: HTMLCanvasElement, result:any, drawOptions?: DrawOptions) {\n const localOptions = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n if (!(inCanvas instanceof HTMLCanvasElement)) return;\n face(inCanvas, result.face, localOptions);\n body(inCanvas, result.body, localOptions);\n hand(inCanvas, result.hand, localOptions);\n gesture(inCanvas, result.gesture, localOptions);\n object(inCanvas, result.object, localOptions);\n}\n", "/* eslint-disable indent */\n/* eslint-disable no-multi-spaces */\n\n/**\n * Configuration interface definition for **Human** library\n *\n * Contains all configurable parameters\n */\nexport interface Config {\n /** Backend used for TFJS operations */\n backend: null | '' | 'cpu' | 'wasm' | 'webgl' | 'humangl' | 'tensorflow',\n\n /** Path to *.wasm files if backend is set to `wasm` */\n wasmPath: string,\n\n /** Print debug statements to console */\n debug: boolean,\n\n /** Perform model loading and inference concurrently or sequentially */\n async: boolean,\n\n /** Perform additional optimizations when input is video,\n * - must be disabled for images\n * - automatically disabled for Image, ImageData, ImageBitmap and Tensor inputs\n * - skips boundary detection for every `skipFrames` frames specified for each model\n * - while maintaining in-box detection since objects don't change definition as fast */\n videoOptimized: boolean,\n\n /** What to use for `human.warmup()`\n * - warmup pre-initializes all models for faster inference but can take significant time on startup\n * - only used for `webgl` and `humangl` backends\n */\n warmup: 'none' | 'face' | 'full' | 'body',\n\n /** Base model path (typically starting with file://, http:// or https://) for all models\n * - individual modelPath values are relative to this path\n */\n modelBasePath: string,\n\n /** Run input through image filters before inference\n * - image filters run with near-zero latency as they are executed on the GPU\n */\n filter: {\n enabled: boolean,\n /** Resize input width\n * - if both width and height are set to 0, there is no resizing\n * - if just one is set, second one is scaled automatically\n * - if both are set, values are used as-is\n */\n width: number,\n /** Resize input height\n * - if both width and height are set to 0, there is no resizing\n * - if just one is set, second one is scaled automatically\n * - if both are set, values are used as-is\n */\n height: number,\n /** Return processed canvas imagedata in result */\n return: boolean,\n /** Flip input as mirror image */\n flip: boolean,\n /** Range: -1 (darken) to 1 (lighten) */\n brightness: number,\n /** Range: -1 (reduce contrast) to 1 (increase contrast) */\n contrast: number,\n /** Range: 0 (no sharpening) to 1 (maximum sharpening) */\n sharpness: number,\n /** Range: 0 (no blur) to N (blur radius in pixels) */\n blur: number\n /** Range: -1 (reduce saturation) to 1 (increase saturation) */\n saturation: number,\n /** Range: 0 (no change) to 360 (hue rotation in degrees) */\n hue: number,\n /** Image negative */\n negative: boolean,\n /** Image sepia colors */\n sepia: boolean,\n /** Image vintage colors */\n vintage: boolean,\n /** Image kodachrome colors */\n kodachrome: boolean,\n /** Image technicolor colors */\n technicolor: boolean,\n /** Image polaroid camera effect */\n polaroid: boolean,\n /** Range: 0 (no pixelate) to N (number of pixels to pixelate) */\n pixelate: number,\n },\n // type definition end\n\n /** Controlls gesture detection */\n gesture: {\n enabled: boolean,\n },\n\n /** Controlls and configures all face-specific options:\n * - face detection, face mesh detection, age, gender, emotion detection and face description\n * Parameters:\n * - enabled: true/false\n * - modelPath: path for each of face models\n * - minConfidence: threshold for discarding a prediction\n * - iouThreshold: ammount of overlap between two detected objects before one object is removed\n * - maxDetected: maximum number of faces detected in the input, should be set to the minimum number for performance\n * - rotation: use calculated rotated face image or just box with rotation as-is, false means higher performance, but incorrect mesh mapping on higher face angles\n * - skipFrames: how many frames to go without re-running the face detector and just run modified face mesh analysis, only valid if videoOptimized is set to true\n * - skipInitial: if previous detection resulted in no faces detected, should skipFrames be reset immediately to force new detection cycle\n * - return: return extracted face as tensor for futher user processing\n */\n face: {\n enabled: boolean,\n detector: {\n modelPath: string,\n rotation: boolean,\n maxDetected: number,\n skipFrames: number,\n skipInitial: boolean,\n minConfidence: number,\n iouThreshold: number,\n return: boolean,\n },\n mesh: {\n enabled: boolean,\n modelPath: string,\n },\n iris: {\n enabled: boolean,\n modelPath: string,\n },\n description: {\n enabled: boolean,\n modelPath: string,\n skipFrames: number,\n minConfidence: number,\n },\n emotion: {\n enabled: boolean,\n minConfidence: number,\n skipFrames: number,\n modelPath: string,\n },\n },\n\n /** Controlls and configures all body detection specific options\n * - enabled: true/false\n * - modelPath: body pose model, can be absolute path or relative to modelBasePath\n * - minConfidence: threshold for discarding a prediction\n * - maxDetected: maximum number of people detected in the input, should be set to the minimum number for performance\n */\n body: {\n enabled: boolean,\n modelPath: string,\n maxDetected: number,\n minConfidence: number,\n },\n\n /** Controlls and configures all hand detection specific options\n * - enabled: true/false\n * - landmarks: detect hand landmarks or just hand boundary box\n * - modelPath: paths for hand detector and hand skeleton models, can be absolute path or relative to modelBasePath\n * - minConfidence: threshold for discarding a prediction\n * - iouThreshold: ammount of overlap between two detected objects before one object is removed\n * - maxDetected: maximum number of hands detected in the input, should be set to the minimum number for performance\n * - rotation: use best-guess rotated hand image or just box with rotation as-is, false means higher performance, but incorrect finger mapping if hand is inverted\n * - skipFrames: how many frames to go without re-running the hand bounding box detector and just run modified hand skeleton detector, only valid if videoOptimized is set to true\n * - skipInitial: if previous detection resulted in no hands detected, should skipFrames be reset immediately to force new detection cycle\n */\n hand: {\n enabled: boolean,\n rotation: boolean,\n skipFrames: number,\n skipInitial: boolean,\n minConfidence: number,\n iouThreshold: number,\n maxDetected: number,\n landmarks: boolean,\n detector: {\n modelPath: string,\n },\n skeleton: {\n modelPath: string,\n },\n },\n\n /** Controlls and configures all object detection specific options\n * - enabled: true/false\n * - modelPath: object detection model, can be absolute path or relative to modelBasePath\n * - minConfidence: minimum score that detection must have to return as valid object\n * - iouThreshold: ammount of overlap between two detected objects before one object is removed\n * - maxDetected: maximum number of detections to return\n * - skipFrames: run object detection every n input frames, only valid if videoOptimized is set to true\n */\n object: {\n enabled: boolean,\n modelPath: string,\n minConfidence: number,\n iouThreshold: number,\n maxDetected: number,\n skipFrames: number,\n },\n}\n\nconst config: Config = {\n backend: 'webgl', // select tfjs backend to use, leave empty to use default backend\n // can be 'webgl', 'wasm', 'cpu', or 'humangl' which is a custom version of webgl\n modelBasePath: '../models/', // base path for all models\n wasmPath: '../assets/', // path for wasm binariesm, only used for backend: wasm\n debug: true, // print additional status messages to console\n async: true, // execute enabled models in parallel\n videoOptimized: true, // perform additional optimizations when input is video,\n // automatically disabled for Image, ImageData, ImageBitmap\n // skips boundary detection for every n frames\n // while maintaining in-box detection since objects cannot move that fast\n warmup: 'full', // what to use for human.warmup(), can be 'none', 'face', 'full'\n // warmup pre-initializes all models for faster inference but can take\n // significant time on startup\n // only used for `webgl` and `humangl` backends\n filter: { // run input through image filters before inference\n // image filters run with near-zero latency as they are executed on the GPU\n enabled: true, // enable image pre-processing filters\n width: 0, // resize input width\n height: 0, // resize input height\n // if both width and height are set to 0, there is no resizing\n // if just one is set, second one is scaled automatically\n // if both are set, values are used as-is\n flip: false, // flip input as mirror image\n return: true, // return processed canvas imagedata in result\n brightness: 0, // range: -1 (darken) to 1 (lighten)\n contrast: 0, // range: -1 (reduce contrast) to 1 (increase contrast)\n sharpness: 0, // range: 0 (no sharpening) to 1 (maximum sharpening)\n blur: 0, // range: 0 (no blur) to N (blur radius in pixels)\n saturation: 0, // range: -1 (reduce saturation) to 1 (increase saturation)\n hue: 0, // range: 0 (no change) to 360 (hue rotation in degrees)\n negative: false, // image negative\n sepia: false, // image sepia colors\n vintage: false, // image vintage colors\n kodachrome: false, // image kodachrome colors\n technicolor: false, // image technicolor colors\n polaroid: false, // image polaroid camera effect\n pixelate: 0, // range: 0 (no pixelate) to N (number of pixels to pixelate)\n },\n\n gesture: {\n enabled: true, // enable gesture recognition based on model results\n },\n\n face: {\n enabled: true, // controls if specified modul is enabled\n // face.enabled is required for all face models:\n // detector, mesh, iris, age, gender, emotion\n // (note: module is not loaded until it is required)\n detector: {\n modelPath: 'blazeface.json', // detector model, can be absolute path or relative to modelBasePath\n rotation: false, // use best-guess rotated face image or just box with rotation as-is\n // false means higher performance, but incorrect mesh mapping if face angle is above 20 degrees\n // this parameter is not valid in nodejs\n maxDetected: 10, // maximum number of faces detected in the input\n // should be set to the minimum number for performance\n skipFrames: 21, // how many frames to go without re-running the face bounding box detector\n // only used for video inputs\n // e.g., if model is running st 25 FPS, we can re-use existing bounding\n // box for updated face analysis as the head probably hasn't moved much\n // in short time (10 * 1/25 = 0.25 sec)\n skipInitial: false, // if previous detection resulted in no faces detected,\n // should skipFrames be reset immediately to force new detection cycle\n minConfidence: 0.2, // threshold for discarding a prediction\n iouThreshold: 0.1, // ammount of overlap between two detected objects before one object is removed\n return: false, // return extracted face as tensor\n },\n\n mesh: {\n enabled: true,\n modelPath: 'facemesh.json', // facemesh model, can be absolute path or relative to modelBasePath\n },\n\n iris: {\n enabled: true,\n modelPath: 'iris.json', // face iris model\n // can be either absolute path or relative to modelBasePath\n },\n\n description: {\n enabled: true, // to improve accuracy of face description extraction it is\n // recommended to enable detector.rotation and mesh.enabled\n modelPath: 'faceres.json', // face description model\n // can be either absolute path or relative to modelBasePath\n skipFrames: 31, // how many frames to go without re-running the detector\n // only used for video inputs\n minConfidence: 0.1, // threshold for discarding a prediction\n },\n\n emotion: {\n enabled: true,\n minConfidence: 0.1, // threshold for discarding a prediction\n skipFrames: 32, // how many frames to go without re-running the detector\n modelPath: 'emotion.json', // face emotion model, can be absolute path or relative to modelBasePath\n },\n },\n\n body: {\n enabled: true,\n modelPath: 'posenet.json', // body model, can be absolute path or relative to modelBasePath\n // can be 'posenet' or 'blazepose'\n maxDetected: 1, // maximum number of people detected in the input\n // should be set to the minimum number for performance\n // only valid for posenet as blazepose only detects single pose\n minConfidence: 0.2, // threshold for discarding a prediction\n },\n\n hand: {\n enabled: true,\n rotation: false, // use best-guess rotated hand image or just box with rotation as-is\n // false means higher performance, but incorrect finger mapping if hand is inverted\n skipFrames: 12, // how many frames to go without re-running the hand bounding box detector\n // only used for video inputs\n // e.g., if model is running st 25 FPS, we can re-use existing bounding\n // box for updated hand skeleton analysis as the hand probably\n // hasn't moved much in short time (10 * 1/25 = 0.25 sec)\n skipInitial: false, // if previous detection resulted in no hands detected,\n // should skipFrames be reset immediately to force new detection cycle\n minConfidence: 0.1, // threshold for discarding a prediction\n iouThreshold: 0.1, // ammount of overlap between two detected objects before one object is removed\n maxDetected: 1, // maximum number of hands detected in the input\n // should be set to the minimum number for performance\n landmarks: true, // detect hand landmarks or just hand boundary box\n detector: {\n modelPath: 'handdetect.json', // hand detector model, can be absolute path or relative to modelBasePath\n },\n skeleton: {\n modelPath: 'handskeleton.json', // hand skeleton model, can be absolute path or relative to modelBasePath\n },\n },\n\n object: {\n enabled: false,\n modelPath: 'nanodet.json', // experimental: object detection model, can be absolute path or relative to modelBasePath\n minConfidence: 0.2, // threshold for discarding a prediction\n iouThreshold: 0.4, // ammount of overlap between two detected objects before one object is removed\n maxDetected: 10, // maximum number of objects detected in the input\n skipFrames: 41, // how many frames to go without re-running the detector\n },\n};\nexport { config as defaults };\n", "// data:image/jpeg;base64,\nexport const face = `\n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`;\n\n// data:image/jpeg;base64,\nexport const body = `\n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\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAa2p1UYo5adbz+xbxMlvqJ1OqjDHLXree0ejmzNrWm953tPmTPWbWneZ7yoy5YhjrXXTjH8s75N\nmtkyxt0VZM2/m175N1V03yTKubMLXVXybeYLLX2VXy7eam+b0bOg4VquJW+rry4/O9uyZOq3UjVm\n9r25axMzPaIdvhns1kzbZddM0p5Y47z8/R2+HcF03Doi1a8+Xzvbv+TotJnjDXkt+K8ODHp8cY8N\nIpSO0RCwF2YAAAAAAAAACvUZYw6fJkntWN3k8dfHz2vLucdz8mkjFE9bz1+UOZosX1UzPm0nqI/W\nMYo9FlcPNklfFGeH/NshLGun+Cz6PtHZtVZWlRLS+jxPkRpIn7rdoupHTdA5s6SI+7H6Mfo+32Y2\n+To3neSIiZ7A0IjPXpXLePlMotGW3272t85datKzHZjbTVnsDj+FG/2Y/RlGP4R+jo20u7H6N1Ql\no+H8I/REY957R+jpfReiK6eOYHLtj2tttH6KrY/6Y/R2c+kjeJiFVtLG24hxpw7/AHY/RRkw9O37\nO99Hrt1YX0tfOBLjcGp4XF8c+u8fs9c4dcVcGemSI61nd3IneN1orQAAAAAAAAAAAAABFqxes1tE\nTE9JiUgPKcX4RbRXnNgiZwWnrH4XPi28PdXpW9JraImsxtMS8pxXhF9DecuGJtgmf+1TWW2N/la1\nL7N7T5e3Vy6W3hsYcvLbqzbO9jvvCzvDR0+XeO7crO6FmGSvRThy/RtVXJ92elvk2rRvDUzU7pl4\nizsd2J3jeBpcNz+Lg5LT7+Pp+Xk3W7js5eAAgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADs0NTrN96Yp6edkW8Wzm6+LNTq4pvTHO9vOfRoWtt\n1mes95YWvs1s2fZldddOczLPLn2ju0MmebT3YZc2/mpm3qqllN1drsbZIhr3yzvtHf4AsvlYYseb\nV5Yx4KTe0+UQ6nDvZ3UazbJqd8OKeu33peq0eh0+hxcmnxxWPOfOfm0mP+steT/ji8N9mKY9suum\nL37+HHaPm9DSlaVitKxWsdohI0Y22gAgAAAAAAAAAABXnyRhw3yT92Nwef4xm8bVzET0rPJH5d12\n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\nAOZE/OsPS29nuH27YrV+VpeV9pdPXhOtw49NG9Mld55+vXcTPd42I47qo7xSfyWV9oM8d8VJ/VxM\nd8l46xWF9cV7en6o/qLfxp2I9ob+eCv/AHMo9op89P8A/wBORGmyT5R+qfo2X8P7n9Q/jTsx7RR5\n6ef+4/8AuHftg/8A6cWcOSO9J/WEbWr3pY7Efzp2Lcfv5YK/9zWy8d1E/ZpSv5Oba1/+Hb9lc+LP\nbFt87I7E/wAabWbiurvEx4nL/pjZzc2bJkn372t85ZXx55/BX85lucC0vPxnTxlnnjm32mOiZqUu\nLJ2p4TwnVavNWaYbRTfre0bQ99pcH0bT0xb78vmtiIiNojaErMwAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAHnfarF7umzRHaZrLjYrdIen9ocPi8JyTt1xzF4eUw23rCm3R4r6bMy\nwt6kdTaWLdjswmNoZontsCm0K5XWjopnuDC0dGpqG5bs08/daKV672MjbSaif6oh6Z5f2LtvptRX\n0tEvUN3Jfo8f7cYve0eX4zV7B5z20xc/C8eSPuZIRficfXlcPaG7ino08HWIbePpLF2NuiyOyrHK\n3fZFSwuovHVfaVF4QK5YWTM9UT0EKry6Ps1Tn4zjn8NZn9nOtLseydObiWW34cf918fWfk+PYANn\nKAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAq1WKM+ly4p+/WYeBxTNd6zG0xO0\nvobw3FcP0bi2em20Tbmj5Srr418V9sa2Z7qKyzi07MXUylhaU7yjqhLCeiq3ddaFNxFYW7NLNG8t\nzya+WO6Va9J7FW66mvwidnrXiPY3Ny8RyUn71Jj9Ht3RPjk19HK9pMHj8D1ER3rHN+jqqtTjjNps\nuOe16zAifXzfTz7kNyndpYazS9qT0mszDdoxrsi6m8LazMq6zDOsq1ZEyrt1WWlXaUCqyq0rbKbi\nFdp6PReyFd8uqv8ACsfy83aXrPZHHto89/xX2/SP/dpj6y8vx6EBq5gAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAB5n2q03LfDqqx39y39npmlxbS/TOG5se29tuavzgWzeV4mtui2\nO3RRSY2hdVhqO2MvI36iu9lUsrSrvDHn6spnmSiq5jooyV6tq1VV69RC32byTh43h8otMx+r6I+Z\naK/g8TwX7bXh9Mid4iW+fjl8n1ICWb57xLBOm4zqse20Tbmj8+qKdnS9q8PhcTw5tumSm0/OHMxz\n0Za+uzx3sX1t0Zxurr1ZxvspWiZYWZbsbT0QK7KLrZVZJFaqt5vbezNOTg9J/FaZeJns93wCvLwb\nT/GJn92uGHldIBowAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADuAPA67F9H4l\nqMW20VvO3yRWW97T4fC4rXJHSMtI/WGhVlue3b473K2KzMML4+62tujG9pnozXaOSOVFMnVbmq1t\ntrJRW5E7wwvUxTvCyY6CHOt7moxz6Wh9PxTzYaT61h8x1MbZK/OH0zTf+Fxf6I/htj45vL9WgLMn\nmvbPFvocGWO9L7fq85p5maw9d7VYvE4JkmPu2if3eW0+PasdFNOnxfF1Y2hlykRsmY+LJ0MZjZXa\neq2eyi8oQTO0KLdZWzPRjWu6VaqtHR73g0bcI0sf0Q8Nkq93wqNuFaWP+XDTDDytwBowAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAef9q8HNpcGaI60vtPyl56k9Iew49j8ThGe\nPwxFv0l4zH2U26fDfTYiyJljvsjf4sm6vJ1hrXjq2MkqLdZEVbgbMx0auGdmzNt6iHN1Ub5af6of\nTdPG2nxx6Vj+HzaaTm1+nx/iyVj930ysbViPRrj45vL9SAuyc7j1efguqj+jd4/T33rD3HEcPj8O\n1GP8WOY/Z4TTT7sKadHhbcsZnaCJ3TPZk6VdrKbTutmP0U2nqgrGOsr8deiuI2X09EqKM1dt3uuG\nf/jdN/06/wAPE546S9rwud+Gaaf+XH8NMMPK2wGjAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAABrcRp4nDtRWPPHP8PCYusPoWSvNjtX1iYfPuWaXtX8MzCuvjfw32siu8ptXoxi\n0wy5t4YulReqmazu2skbquURWFInddM7VYRGyL291KFnCcfj8e0le/Lbmn8n0N4b2Ur4nHLWmPsY\n5e5a5+OXyXugBZmiY3iY9Xz7NjnTa3Ph/BeYj5PoTxftFg8Hjk2iOmWkW/Psrr418V5WrWd2faFc\nV2jdnEMXWxntupmN7NiYU27iWML6dVMVnddjgVqMsdHr+CW5uE6f4Rt+7yuSsTDv+zWXn0WTHP3L\n/tK+GHl+O0A1c4AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA8Dn93W56/wDM\nt/L3z59qp24jn+OS38lnpr4r7ZxHQ2TEstt3PXUrt27K57rr1VT0BjKnJPRbMqMs7QlV2fYvHvrd\nVknyrEfu9m8f7FZI8fVU85iJewbT45NfQBKo817W4eulzxHaZrL0rje09ItwqbfhtBVs3leai8RD\nKLw1sduesL606dWFdsZT1jdhNeq6K9DlhCVUU6s4jZnt1YzAhnM71dH2bycmszY/K1d/0c6OzY4R\nfwuK4p8rTstn6z8k7HrwGzkAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHz3\nVxvr80/8y38voTwGpj/F5/8AqT/JfjTx/WVeyY6FPspc9dZPVXaOq2WEwIUTVRmjo2rNfLHRI3vZ\nDJycXtX8dZh7t879nsnhcbwz23tt+r6I2nxyb+gCVBzuPY/E4PqI9K7ui19fTxNBnp60n+Aj5/pJ\n3jZu1aOnnltMNussdfXbm+l3ZM9URHREdZVXTuT1Nk7boQiOkJw28PU47/htEp5eivJPLMTCZ9Vv\nx7mJ3iJ9UqNHk8XR4b+tIXuhxAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD\nweqjbWZ4/wCZP8vePCaz/wDIaiP+Zb+UX408f0r9lOxWOifJhXWjfyYWllPRXYQxnrCrJHRd3YZI\n6A1NJecHEsN/S0T+76bE7xE+r5dk93LW3pL6ZpMni6PDf8VIn9m2fjm8s9rgFmQxvHNS0esbMiew\nPnHLyai9fS0w2aNfUTtrs3+uf5bGPqy068fF227KtSsdFlKqNGMV6myyY6sbdIQI8tlOWOi6Jhhk\nj3RD0vA8nicMx9etZmHRcT2Zyb6XNT8N9/2dt0T449T2AJVAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAHhdfG3E9TH9cvdPEcXjk4zqI/q3L8aeP6xr2TsxpLOekMK6mFo6qpXSrm\nOqBixvHSVmzC4OfqK7S9/wAByeLwbTW9K7fo8Fqo6Paeyl+fglI/Da0NcMPK7QC7AAB8313TiOf/\nAKk/y2MHWrX4jG3E9R/1Lfyv0/aFNOrHxuU7LI7MMayGTVlHWUXhNe6Z6wIUsb9d1m20q7dkDpez\nN9tRqKT5xEvRvKez9+Xis1/FSYerb5+OTyf6AFlAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAB43j9eXjN/jWJ/Z7J5L2mry8Upb8VIF8f6aGOey2eynHvOy7bowrrYSxZSwQJ2YXZ\n92N4BoanrEvVexmTm4blr+HJ/aHltRHSXofYm/1Wrp5RaJaYY+X49WA0c4AD51xONuKan/qW/lbp\n+0MOLRtxbU/9SU4J7KadWPjep2WQrr2WRPRk1TvsndXMpiRCb9FNu0rbTuqvKBscCjfi9PhWZeue\nV9n434rafTHL1TfPxy+T/QAszAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHmv\navHtfTZfnV6VxPajHzcNrf8ABeJFs/XnMcr4no18c+6vr2YadkY2YM57sEDLyY37Mo7MMnYGlqO0\nvQ+xNfqNVb1tEfs87qZ2rL0/sVX/AHdnt65P7Q0wx8vx6UBo5wAHz/jUbcX1PT78qtO2vaCnJxjP\n8Zif2amnnspp04+OjWejKJ6MKdmcMmyJn4m5ZHzEVPMwtJv0VZLbQDqezcb8RzT6Y/7vUPM+ytZt\nn1OTyiIh6Ztn45N/6AFlAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABocbxeLw\nnUR5xXm/Rvq8+OMuDJjntaswEeBxT0bNZ6NatZpNqz3rO0rqsdO3PxlaWEMpY+aqWXkryT0ZT2V3\n7A0dVPuy9f7G124NM/iyT/Z4zWT7sw957MYfB4Fp4/FE2/WWmGHldcBowAAeM9qKcvFeb8VIly9P\n0nq7ntbTbVYL+tJj93CwT76unR4/jo0nozhhTsy3Y1sWljM9Ce7HyQIm3RRlttVbaWrnt0Sh6n2U\nx8vD8mSfv3/h3XN4Bi8Lg2nj8Uc36y6TeOPXugCUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAPD8RxeBxXUU26Tbmj8+quro+02Lw+I4ssdslNvzhzazvDPbq8d7GW7Dfqz2VzG\n0s2qd+iu/Zn5Ksk9BVztX1mI8930zh2LwOHabH+HHWP2fNYp4+vwYvxXiP3fUqxtWIjyjZtj45/L\nfaQFmQADzftfj3w6fJ6WmHmsP23rvaqnNwqLfhvEvIYZ+sV038bo0noy36MK9oZQxrdMyrlnMbMZ\nQKrS1M07zEestq/RRjr4utwY/wAV4j91p9V18fQdJj8LR4ccfdpEfsuREbREJbuMAAAAAAAAAAAA\nBAJAAAAEAJEAJQAJQAJEAJQAJQAJEACUJAQlAJEAJQAJQJAAAEAJEAJBAAAJAABAJEJAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABwvanDzaPFmjvjv8A\ntLztJ3h7HjGHx+FainnFeaPnHV4vFbeIU038VbHeGF+kso7Mb9mTdhKnLK3dRm7SIrHhGPxeP6Sv\n9cT/AHfSnz72Zx+J7Q45/BWZ/Z9BbZ+OXyfQBZQABzeP4/E4NqI9Ii36S8Ng/wAx9C4jTxOH6ivr\njn+Hz3B/mQi/GvjdCnWNlsdI2V07LIlg6USrt2ZzZXMoFV+zPhGLxeOaavpbm/RVltEN72Yx+Jxm\nb7dKUmf7L5+s9/HtRA2cqRACRACRACRACUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAACQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQCQQCRACRACRCQBCQBCQB\nACRACRACRACRACL1i9LVntMbPATTwdRkxT3pea/u+gPE8Xx+DxrPHlaYt+qNfGvjvtXXsi0dOrKk\ndEXjZg6VMtbP2bMtXUdpEV0/Y2nNxbNf8OP+727xvsXH+N1U/wBEfy9k3nxyb+gCVQAGOWvNivX1\nrMPnGGOXNNfOJ2fSZ6w+dZKeHxDPX8N7R+6L8a+L63KdoZ7q6zvEMpnowdKJ6ywmWUyqvIKM0vQ+\nx+D6rU55+9aKx+TzWa36vbezmDwODYenW+95/Nphj5L6dQBo5wAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACAEiAAAEoA\nAAAAAAAAAAAAAEAkEAkRuAkQbgkQAkQAkQAkQAl5T2nx8nEMOT8dNv0l6pwfarHvpcGWPu32/WCr\nYvK4mOem6b9mGKd4Z3idmFdka0y1c892zfpMtLPaNpEV6D2Kj/Eauf6YeweQ9ieuTVz8K/3evbT4\n5NfQBKoAA8FxCvJxrUx/XMvevD8Zry8fz/Haf2RfjTx/6RSOnRMyypHu9kXjowrqVSrvPRnZVl6V\nkK0775MsUjvadn0nT4ow6bFijtSsVfPuFYvpPGtNTy54mfy6vorXDm8l9pEC7JIgBIgBIgBIgBIg\nBIgBIhIAgBIhIAgBIgBIIBIAAhIAhIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAJAAAAAAAAAAAAAAA\nAAAAAAAAABAJQkAEAAAAAAAAAAjc3BIjdG4Mkbo5kcwMjdhzHMDPc3V8xzAs3N1fMjmBZubq+Y5g\nWbm6vmOYFm5ur5jmBZubq+Y5gWbm6vmOYFm5ur5jmBZubq+Y5gWbm6vmTzAz3N2HMnmBlu5ftFTx\nOEZJ/DMW/d0t2rxKni8N1FPWkiZ9eS08e7Cy8dGGn6UhZaJljXZGnmc3UT3dPP2cnUT78xCIV6j2\nH/8A9c/6f7vXPI+w8bU1U+vL/d63du5NfUiDcVSIAS8b7RV5eOb/AIqRL2TyXtNX/e2KfXH/AHlF\n+NPH/pr4+2xcxx0hFpY11K7R16KM32ZWz3UaidqSgrc9kcPicWyZJjfw6T+727y3sXh2xarN+K0V\nh6lvPjj3e0ASqAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAJQAAAAAkQAkQAkAAAAAAAAAAAAAAA\nEgAAAAAAAAAAAAAAAAAAAAAgAAABKDcAN0bgkY8xzAyRux5kcwM9zdXNkTcFm6OZXzMeYFvMibKu\nZHMC2bo51U2RuC2bom6rc3BZzom6sBZzI52ADPnOdggFnMc6skFnMc6rc3BbznOp3RzAv50c6nml\nHMC/nOf4qOY5wX85zqOc5wbHOc7X5znBsc6edr85zg2ec52vzpi4NjmY5bROG+/bllVzsNTk5dLl\nn0pP8BHmMHWNmzt0aum8obm08vVjfrtnxztR0mXHzTvaZdjVRMTLkZo6yiFen9iZ2pqY/wBP93rN\n3kPY+/LfPX1rE/u9XzN3HfqzdO6vmTuIZ7m7Hc3Bnu8t7TR/vHBP9E/y9Pu837SV31umn+if5Rfi\n/j/01MMb1hjkrtKzBG0bMsmOZY11tOYamr6Und0LUc7XT7u3rJPqL8er9lcPhcFpbzyWm39v7O00\n+FYvA4Zpsc94xxu227jv1IAgAAAAAAAAABKAAAASgASgBIgBIgBIgBIhIAAAAAAAAAAAAAAAAAAC\nUACUJAAAAAAAAAAAABIAAAAAAAAAAAAAAAAAAAAg3AEbomQZbo3YzLGbAz3RNlc3YzcFs2YzdVN2\nM2Bdzom6nmNwW86JurTAMuY3REJ2BB1ZRVMVBhsbSsiqeUFXLucq3lTygp5TlXcpygp5TlXcpygp\n5TlXcqOUFXKjlXcrGYBXysdlswiYBVMdUTCyY6sZBWxlnMMZgGLGZZSwkDdHMiWO4MuY5mEyjcFn\nN1OdVzHMC3nTzqeY5gX85zqOZPMC+Lqdbk20eb/RKOZr8QybaK/XvtH7iZ9aGlp2luzT3fg19NHS\nOjbmPcYX67XH1XSZ9XIzRvMuzrK7zLkZYmYnciunb9lZ5dTk+OP+71cXeP8AZnJ/ip2nf3J/l6iL\n/Fu5L9bMWZczXi6YuIbEWTzKIuyiwLt3nuO25uI4a/hx7/rLuczg8TicvFLbfdpEK6+NPH/phhjo\nstLGkctUWnoxrrU3j1cnWTzZq1jzl1clo5Zcu8c+txR63iP3Tn6pv4+g4o5cVI9IiGe7CJ2iE7t3\nGyN2O6dwSINwSISAlAAlACRAAlAAlACRACRCQAAAAAAAAAASgASISAAAAAAAAAAAAACQAAAAAAAA\nAAAAAASAAAAAAAAAAAAAAAAIAAAQCAJljuljsCJlhMs9mOwMJYys5TkBVsjZdyHICrZPKt5E8oK4\nqmKrOVOwMIqyirPY2Bjyp2ZbAI2NmSARsbMgEbI2ZAMdjZICNkbMkSCNmOzJEgx2YyzljMAwlhKy\nWEwCuWErJhhMArlhLOWEgxljMpljIImWMyTKJA3N0IBO5vux3NwZbnMx3NwZczT4jf3MdPW27a3a\nfJOq1XNP2KdIRfi+J2trSYfcjeF+Wm1OicVeWIiN9kai8xjY12ORqultnI1Ecsujq79XP1FovWYI\nrTgeq+j8QrWZ+3Mx+r2UXeC0WG2Ti2kiN5mL807eUREvbzbaejefHJv62Iv8WUXa0WTFhVtRdlF2\nrz9WUXBtc7jR9dqc2T1ttHyhvZMvJitb0jdq6XHNcNenWVN3028U99WRj6Kb02be3Tq18/SN2Lpc\n3UdN9nOmZrqKX/DaJ/d0svvTLRzV3jomK6+Pd1vvWJj0ZczT0mXxNJht60hfFnQ4qu3N1cWTEgs3\nTur5k7gz3N2O5uDM3Y7m4MtxBuCQASIASIASAAAAAAACRCQAAAAAAAAEoSAAAAAAAAAAAlAAlCQA\nAAAAAAAAAAASAAAAAAAAAAAAIASgAAAEJAQJQCNkbMgGOyOVnsAw5TlZ7GwMOVPKy2NgY7GzIBGx\nskA2AAAAAAAAAAQkBAEghEskAxYzDPZGwK5hjMLJhjMAqmGEwumrCagomFcw2JqqtUFEsLLrV82F\no7gqljKyYYTGwMZRKUSCAQAboJnaN5Bjkneu0d5W4ccViIiOzHFWbTzNumP1Zarr8eeRMbxDW1Mx\nNO67NbkhzNVnmInqzaOZrL93JyZeV0M1++7S02jvxDWxhxx033tPpC8Z6rrezWjmZyazJG2/u03h\n2vFibTHoqvamiwVwY+nLGzV0+SZ1Mx8G0/45tOhzJ5lXMc3UVXRdlF1HP+iYsDPLPPy49/tz1+Te\npSIr0ho6ak5Ms5J8o2q6NImOrHV7XX488ypzTtHXo0s9t6zG7c1G1qz6ubeZiZ3UatXJG3yauSO7\ncvMTEx5tPLb3prPRMVr0HB8vicNxf0+7+kt+LOJwTJyY/Bnz3tH93X36N58cWvq6LSyiyndMSlC7\nmZcymLJiwLosmJVRLKLAtiU7q4lMSCzc3YxJuDMRuAlKAEgAAAlAkAAAAAABKAEgAAAAAJAAAAAA\nAAAAAAAEgAAAAAAAAAAAAAkAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAhIAAACAAAASgAAAAAAEAAAA\nhGzJAImGMwzQDDZjNVuyNgUTVhNGxysZqDVmiu1G5NN2M4waM0+DCaN2cbGcQNGaMZq3JxMJxA1J\nqx2bU4kU09slorWNwa20z02RXHbJbl26QvtFovbHWkxEdJt5y2MOHlr2U1W3jx+1hiw8vSO63lmI\nXRTaEWmtY6snRHO1VpmJ+DjavpSZl2s8b7y4HFcnh0n0gha5ebJN55KRM2mdoiPN6fh+kpwXh0Wy\nRHj5Otp/s5Ps1p62y31+em9aTMYt/OfVfxTiPjZ52naI7fBrI5t66xz5+a1rW7yx0eSL6iZjtEOX\nqNbSletom3lENjh2fbHzbbWt3iVozruc+5ztWubf4M4ybpQ2Oboyrva0Vjza8WdDR4OkXt3n9ldX\nkaePP9VtYqctYhdvt5oivTeCZ2YOxXk6ubqMfV0b9mrljfqlFcq88k7z2U5axeItDa1OPessuC8P\nya7XRWYnwqdbT/ZMilvIu4dpslNdixXja8Y5tt85djZdbDWnGOesRtXFtuw6T27No5Kx2OrKYQlC\nExKJgBnEpiyvdlEgsizKLKollFgWxLKJVRLKJBbEp3VxLKJBnuMWQJEbpBIAAAJAAAABIAAAAAAA\nlAJAAAAAAAAAAAAAASAAAAAAAAAAAAAJAAAABAJABAlAAAAAAAAAAAAAAAAAAAAAAAAIAAAAAAAA\nAAABAJQAAAAgAABAAI2EoBGyJhkgGPKxmqxAKpownHC+YRMdN5BrTj67R3bOn01o7p01Iv71u89o\n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\n2Q==`;\n", "import { log, now, mergeDeep } from './helpers';\nimport * as sysinfo from './sysinfo';\nimport * as tf from '../dist/tfjs.esm.js';\nimport * as backend from './tfjs/backend';\nimport * as faceall from './faceall';\nimport * as facemesh from './blazeface/facemesh';\nimport * as faceres from './faceres/faceres';\nimport * as emotion from './emotion/emotion';\nimport * as posenet from './posenet/posenet';\nimport * as handpose from './handpose/handpose';\nimport * as blazepose from './blazepose/blazepose';\nimport * as nanodet from './nanodet/nanodet';\nimport * as gesture from './gesture/gesture';\nimport * as image from './image/image';\nimport * as draw from './draw/draw';\nimport { Config, defaults } from './config';\nimport { Result } from './result';\nimport * as sample from './sample';\nimport * as app from '../package.json';\n\n/** Generic Tensor object type */\nexport type Tensor = typeof tf.Tensor;\n\nexport type { Config } from './config';\nexport type { Result } from './result';\nexport type { DrawOptions } from './draw/draw';\n\n/** Defines all possible input types for **Human** detection */\nexport type Input = Tensor | typeof Image | ImageData | ImageBitmap | HTMLImageElement | HTMLMediaElement | HTMLVideoElement | HTMLCanvasElement | OffscreenCanvas;\n\n/** Error message */\nexport type Error = { error: string };\n\n/** Instance of TensorFlow/JS */\nexport type TensorFlow = typeof tf;\n\n/** Generic Model object type, holds instance of individual models */\ntype Model = Object;\n\n/**\n * **Human** library main class\n *\n * All methods and properties are available only as members of Human class\n *\n * - Configuration object definition: {@link Config}\n * - Results object definition: {@link Result}\n * - Possible inputs: {@link Input}\n */\nexport class Human {\n /** Current version of Human library in semver format */\n version: string;\n /** Current configuration\n * - Details: {@link Config}\n */\n config: Config;\n /** Current state of Human library\n * - Can be polled to determine operations that are currently executed\n */\n state: string;\n /** Internal: Instance of current image being processed */\n image: { tensor: Tensor | null, canvas: OffscreenCanvas | HTMLCanvasElement | null };\n /** Internal: Instance of TensorFlow/JS used by Human\n * - Can be embedded or externally provided\n */\n tf: TensorFlow;\n /** Draw helper classes that can draw detected objects on canvas using specified draw styles\n * - options: global settings for all draw operations, can be overriden for each draw method, for details see {@link DrawOptions}\n * - face: draw detected faces\n * - body: draw detected people and body parts\n * - hand: draw detected hands and hand parts\n * - canvas: draw processed canvas which is a processed copy of the input\n * - all: meta-function that performs: canvas, face, body, hand\n */\n draw: {\n options: draw.DrawOptions,\n gesture: typeof draw.gesture,\n face: typeof draw.face,\n body: typeof draw.body,\n hand: typeof draw.hand,\n canvas: typeof draw.canvas,\n all: typeof draw.all,\n };\n /** Internal: Currently loaded models */\n models: {\n face: [Model, Model, Model] | null,\n posenet: Model | null,\n blazepose: Model | null,\n efficientpose: Model | null,\n handpose: [Model, Model] | null,\n iris: Model | null,\n age: Model | null,\n gender: Model | null,\n emotion: Model | null,\n embedding: Model | null,\n nanodet: Model | null,\n faceres: Model | null,\n };\n /** Internal: Currently loaded classes */\n classes: {\n facemesh: typeof facemesh;\n emotion: typeof emotion;\n body: typeof posenet | typeof blazepose;\n hand: typeof handpose;\n nanodet: typeof nanodet;\n faceres: typeof faceres;\n };\n /** Face triangualtion array of 468 points, used for triangle references between points */\n faceTriangulation: typeof facemesh.triangulation;\n /** UV map of 468 values, used for 3D mapping of the face mesh */\n faceUVMap: typeof facemesh.uvmap;\n /** Platform and agent information detected by Human */\n sysinfo: { platform: string, agent: string };\n /** Performance object that contains values for all recently performed operations */\n perf: any;\n #numTensors: number;\n #analyzeMemoryLeaks: boolean;\n #checkSanity: boolean;\n #firstRun: boolean;\n\n // definition end\n\n /**\n * Creates instance of Human library that is futher used for all operations\n * - @param userConfig: {@link Config}\n */\n constructor(userConfig: Config | Object = {}) {\n this.tf = tf;\n this.draw = draw;\n this.version = app.version;\n this.config = mergeDeep(defaults, userConfig);\n this.state = 'idle';\n this.#numTensors = 0;\n this.#analyzeMemoryLeaks = false;\n this.#checkSanity = false;\n this.#firstRun = true;\n this.perf = {};\n // object that contains all initialized models\n this.models = {\n face: null,\n posenet: null,\n blazepose: null,\n efficientpose: null,\n handpose: null,\n iris: null,\n age: null,\n gender: null,\n emotion: null,\n embedding: null,\n nanodet: null,\n faceres: null,\n };\n // export access to image processing\n // @ts-ignore eslint-typescript cannot correctly infer type in anonymous function\n this.image = (input: Input) => image.process(input, this.config);\n // export raw access to underlying models\n this.classes = {\n facemesh,\n emotion,\n faceres,\n body: this.config.body.modelPath.includes('posenet') ? posenet : blazepose,\n hand: handpose,\n nanodet,\n };\n this.faceTriangulation = facemesh.triangulation;\n this.faceUVMap = facemesh.uvmap;\n // include platform info\n this.sysinfo = sysinfo.info();\n }\n\n // helper function: measure tensor leak\n /** @hidden */\n analyze = (...msg) => {\n if (!this.#analyzeMemoryLeaks) return;\n const current = this.tf.engine().state.numTensors;\n const previous = this.#numTensors;\n this.#numTensors = current;\n const leaked = current - previous;\n if (leaked !== 0) log(...msg, leaked);\n }\n\n // quick sanity check on inputs\n /** @hidden */\n #sanity = (input): null | string => {\n if (!this.#checkSanity) return null;\n if (!input) return 'input is not defined';\n if (this.tf.ENV.flags.IS_NODE && !(input instanceof tf.Tensor)) return 'input must be a tensor';\n try {\n this.tf.getBackend();\n } catch {\n return 'backend not loaded';\n }\n return null;\n }\n\n /** Simmilarity method calculates simmilarity between two provided face descriptors (face embeddings)\n * - Calculation is based on normalized Minkowski distance between\n */\n // eslint-disable-next-line class-methods-use-this\n similarity(embedding1: Array, embedding2: Array): number {\n return faceres.similarity(embedding1, embedding2);\n }\n\n /** Enhance method performs additional enhacements to face image previously detected for futher processing\n * @param input Tensor as provided in human.result.face[n].tensor\n * @returns Tensor\n */\n // eslint-disable-next-line class-methods-use-this\n enhance(input: Tensor): Tensor | null {\n return faceres.enhance(input);\n }\n\n /**\n * Math method find best match between provided face descriptor and predefined database of known descriptors\n * @param faceEmbedding: face descriptor previsouly calculated on any face\n * @param db: array of mapping of face descriptors to known values\n * @param threshold: minimum score for matching to be considered in the result\n * @returns best match\n */\n // eslint-disable-next-line class-methods-use-this\n match(faceEmbedding: Array, db: Array<{ name: string, source: string, embedding: number[] }>, threshold = 0): { name: string, source: string, similarity: number, embedding: number[] } {\n return faceres.match(faceEmbedding, db, threshold);\n }\n\n /** Load method preloads all configured models on-demand\n * - Not explicitly required as any required model is load implicitly on it's first run\n */\n async load(userConfig: Config | Object = {}) {\n this.state = 'load';\n const timeStamp = now();\n if (userConfig) this.config = mergeDeep(this.config, userConfig);\n\n if (this.#firstRun) {\n if (this.config.debug) log(`version: ${this.version}`);\n if (this.config.debug) log(`tfjs version: ${this.tf.version_core}`);\n if (this.config.debug) log('platform:', this.sysinfo.platform);\n if (this.config.debug) log('agent:', this.sysinfo.agent);\n\n await this.#checkBackend(true);\n if (this.tf.ENV.flags.IS_BROWSER) {\n if (this.config.debug) log('configuration:', this.config);\n if (this.config.debug) log('tf flags:', this.tf.ENV.flags);\n }\n }\n if (this.config.async) {\n [\n this.models.face,\n this.models.emotion,\n this.models.handpose,\n this.models.posenet,\n this.models.blazepose,\n this.models.nanodet,\n this.models.faceres,\n ] = await Promise.all([\n this.models.face || (this.config.face.enabled ? facemesh.load(this.config) : null),\n this.models.emotion || ((this.config.face.enabled && this.config.face.emotion.enabled) ? emotion.load(this.config) : null),\n this.models.handpose || (this.config.hand.enabled ? handpose.load(this.config) : null),\n this.models.posenet || (this.config.body.enabled && this.config.body.modelPath.includes('posenet') ? posenet.load(this.config) : null),\n this.models.blazepose || (this.config.body.enabled && this.config.body.modelPath.includes('blazepose') ? blazepose.load(this.config) : null),\n this.models.nanodet || (this.config.object.enabled ? nanodet.load(this.config) : null),\n this.models.faceres || ((this.config.face.enabled && this.config.face.description.enabled) ? faceres.load(this.config) : null),\n ]);\n } else {\n if (this.config.face.enabled && !this.models.face) this.models.face = await facemesh.load(this.config);\n if (this.config.face.enabled && this.config.face.emotion.enabled && !this.models.emotion) this.models.emotion = await emotion.load(this.config);\n if (this.config.hand.enabled && !this.models.handpose) this.models.handpose = await handpose.load(this.config);\n if (this.config.body.enabled && !this.models.posenet && this.config.body.modelPath.includes('posenet')) this.models.posenet = await posenet.load(this.config);\n if (this.config.body.enabled && !this.models.blazepose && this.config.body.modelPath.includes('blazepose')) this.models.blazepose = await blazepose.load(this.config);\n if (this.config.object.enabled && !this.models.nanodet) this.models.nanodet = await nanodet.load(this.config);\n if (this.config.face.enabled && this.config.face.description.enabled && !this.models.faceres) this.models.faceres = await faceres.load(this.config);\n }\n\n if (this.#firstRun) {\n if (this.config.debug) log('tf engine state:', this.tf.engine().state.numBytes, 'bytes', this.tf.engine().state.numTensors, 'tensors');\n this.#firstRun = false;\n }\n\n const current = Math.trunc(now() - timeStamp);\n if (current > (this.perf.load || 0)) this.perf.load = current;\n }\n\n // check if backend needs initialization if it changed\n /** @hidden */\n #checkBackend = async (force = false) => {\n if (this.config.backend && (this.config.backend.length > 0) && force || (this.tf.getBackend() !== this.config.backend)) {\n const timeStamp = now();\n this.state = 'backend';\n /* force backend reload\n if (this.config.backend in tf.engine().registry) {\n const backendFactory = tf.findBackendFactory(this.config.backend);\n tf.removeBackend(this.config.backend);\n tf.registerBackend(this.config.backend, backendFactory);\n } else {\n log('Backend not registred:', this.config.backend);\n }\n */\n\n if (this.config.backend && this.config.backend.length > 0) {\n // @ts-ignore ignore missing type for WorkerGlobalScope as that is the point\n if (typeof window === 'undefined' && typeof WorkerGlobalScope !== 'undefined' && this.config.debug) log('running inside web worker');\n\n // force browser vs node backend\n if (this.tf.ENV.flags.IS_BROWSER && this.config.backend === 'tensorflow') this.config.backend = 'webgl';\n if (this.tf.ENV.flags.IS_NODE && (this.config.backend === 'webgl' || this.config.backend === 'humangl')) this.config.backend = 'tensorflow';\n\n if (this.config.debug) log('setting backend:', this.config.backend);\n\n if (this.config.backend === 'wasm') {\n if (this.config.debug) log('wasm path:', this.config.wasmPath);\n if (typeof this.tf?.setWasmPaths !== 'undefined') this.tf.setWasmPaths(this.config.wasmPath);\n else throw new Error('Human: WASM backend is not loaded');\n const simd = await this.tf.env().getAsync('WASM_HAS_SIMD_SUPPORT');\n const mt = await this.tf.env().getAsync('WASM_HAS_MULTITHREAD_SUPPORT');\n if (this.config.debug) log(`wasm execution: ${simd ? 'SIMD' : 'no SIMD'} ${mt ? 'multithreaded' : 'singlethreaded'}`);\n if (this.config.debug && !simd) log('warning: wasm simd support is not enabled');\n }\n\n if (this.config.backend === 'humangl') backend.register();\n try {\n await this.tf.setBackend(this.config.backend);\n } catch (err) {\n log('error: cannot set backend:', this.config.backend, err);\n }\n }\n this.tf.enableProdMode();\n // this.tf.enableDebugMode();\n if (this.tf.getBackend() === 'webgl' || this.tf.getBackend() === 'humangl') {\n this.tf.ENV.set('CHECK_COMPUTATION_FOR_ERRORS', false);\n this.tf.ENV.set('WEBGL_PACK_DEPTHWISECONV', true);\n if (typeof this.config['deallocate'] !== 'undefined') {\n log('changing webgl: WEBGL_DELETE_TEXTURE_THRESHOLD:', true);\n this.tf.ENV.set('WEBGL_DELETE_TEXTURE_THRESHOLD', 0);\n }\n const gl = await this.tf.backend().getGPGPUContext().gl;\n if (this.config.debug) log(`gl version:${gl.getParameter(gl.VERSION)} renderer:${gl.getParameter(gl.RENDERER)}`);\n }\n await this.tf.ready();\n this.perf.backend = Math.trunc(now() - timeStamp);\n }\n }\n\n /** Main detection method\n * - Analyze configuration: {@link Config}\n * - Pre-process input: {@link Input}\n * - Run inference for all configured models\n * - Process and return result: {@link Result}\n */\n async detect(input: Input, userConfig: Config | Object = {}): Promise {\n // detection happens inside a promise\n return new Promise(async (resolve) => {\n this.state = 'config';\n let timeStamp;\n\n // update configuration\n this.config = mergeDeep(this.config, userConfig);\n\n // sanity checks\n this.state = 'check';\n const error = this.#sanity(input);\n if (error) {\n log(error, input);\n resolve({ error });\n }\n\n const timeStart = now();\n\n // configure backend\n await this.#checkBackend();\n\n // load models if enabled\n await this.load();\n\n // disable video optimization for inputs of type image, but skip if inside worker thread\n let previousVideoOptimized;\n // @ts-ignore ignore missing type for WorkerGlobalScope as that is the point\n if (input && this.config.videoOptimized && (typeof window !== 'undefined') && (typeof WorkerGlobalScope !== 'undefined') && (\n (typeof HTMLImageElement !== 'undefined' && input instanceof HTMLImageElement)\n || (typeof Image !== 'undefined' && input instanceof Image)\n || (typeof ImageData !== 'undefined' && input instanceof ImageData)\n || (typeof ImageBitmap !== 'undefined' && image instanceof ImageBitmap))\n ) {\n log('disabling video optimization');\n previousVideoOptimized = this.config.videoOptimized;\n this.config.videoOptimized = false;\n }\n\n timeStamp = now();\n const process = image.process(input, this.config);\n if (!process || !process.tensor) {\n log('could not convert input to tensor');\n resolve({ error: 'could not convert input to tensor' });\n return;\n }\n this.perf.image = Math.trunc(now() - timeStamp);\n this.analyze('Get Image:');\n\n // prepare where to store model results\n let bodyRes;\n let handRes;\n let faceRes;\n let objectRes;\n let current;\n\n // run face detection followed by all models that rely on face bounding box: face mesh, age, gender, emotion\n if (this.config.async) {\n faceRes = this.config.face.enabled ? faceall.detectFace(this, process.tensor) : [];\n if (this.perf.face) delete this.perf.face;\n } else {\n this.state = 'run:face';\n timeStamp = now();\n faceRes = this.config.face.enabled ? await faceall.detectFace(this, process.tensor) : [];\n current = Math.trunc(now() - timeStamp);\n if (current > 0) this.perf.face = current;\n }\n\n // run body: can be posenet or blazepose\n this.analyze('Start Body:');\n if (this.config.async) {\n if (this.config.body.modelPath.includes('posenet')) bodyRes = this.config.body.enabled ? posenet.predict(process.tensor, this.config) : [];\n else if (this.config.body.modelPath.includes('blazepose')) bodyRes = this.config.body.enabled ? blazepose.predict(process.tensor, this.config) : [];\n if (this.perf.body) delete this.perf.body;\n } else {\n this.state = 'run:body';\n timeStamp = now();\n if (this.config.body.modelPath.includes('posenet')) bodyRes = this.config.body.enabled ? await posenet.predict(process.tensor, this.config) : [];\n else if (this.config.body.modelPath.includes('blazepose')) bodyRes = this.config.body.enabled ? await blazepose.predict(process.tensor, this.config) : [];\n current = Math.trunc(now() - timeStamp);\n if (current > 0) this.perf.body = current;\n }\n this.analyze('End Body:');\n\n // run handpose\n this.analyze('Start Hand:');\n if (this.config.async) {\n handRes = this.config.hand.enabled ? handpose.predict(process.tensor, this.config) : [];\n if (this.perf.hand) delete this.perf.hand;\n } else {\n this.state = 'run:hand';\n timeStamp = now();\n handRes = this.config.hand.enabled ? await handpose.predict(process.tensor, this.config) : [];\n current = Math.trunc(now() - timeStamp);\n if (current > 0) this.perf.hand = current;\n }\n this.analyze('End Hand:');\n\n // run nanodet\n this.analyze('Start Object:');\n if (this.config.async) {\n objectRes = this.config.object.enabled ? nanodet.predict(process.tensor, this.config) : [];\n if (this.perf.object) delete this.perf.object;\n } else {\n this.state = 'run:object';\n timeStamp = now();\n objectRes = this.config.object.enabled ? await nanodet.predict(process.tensor, this.config) : [];\n current = Math.trunc(now() - timeStamp);\n if (current > 0) this.perf.object = current;\n }\n this.analyze('End Object:');\n\n // if async wait for results\n if (this.config.async) {\n [faceRes, bodyRes, handRes, objectRes] = await Promise.all([faceRes, bodyRes, handRes, objectRes]);\n }\n tf.dispose(process.tensor);\n\n // run gesture analysis last\n let gestureRes: any[] = [];\n if (this.config.gesture.enabled) {\n timeStamp = now();\n gestureRes = [...gesture.face(faceRes), ...gesture.body(bodyRes), ...gesture.hand(handRes), ...gesture.iris(faceRes)];\n if (!this.config.async) this.perf.gesture = Math.trunc(now() - timeStamp);\n else if (this.perf.gesture) delete this.perf.gesture;\n }\n\n // restore video optimizations if previously disabled\n if (previousVideoOptimized) this.config.videoOptimized = previousVideoOptimized;\n\n this.perf.total = Math.trunc(now() - timeStart);\n this.state = 'idle';\n const result = {\n face: faceRes,\n body: bodyRes,\n hand: handRes,\n gesture: gestureRes,\n object: objectRes,\n performance: this.perf,\n canvas: process.canvas,\n };\n // log('Result:', result);\n resolve(result);\n });\n }\n\n /** @hidden */\n #warmupBitmap = async () => {\n const b64toBlob = (base64, type = 'application/octet-stream') => fetch(`data:${type};base64,${base64}`).then((res) => res.blob());\n let blob;\n let res;\n switch (this.config.warmup) {\n case 'face': blob = await b64toBlob(sample.face); break;\n case 'full': blob = await b64toBlob(sample.body); break;\n default: blob = null;\n }\n if (blob) {\n const bitmap = await createImageBitmap(blob);\n res = await this.detect(bitmap, this.config);\n bitmap.close();\n }\n return res;\n }\n\n /** @hidden */\n #warmupCanvas = async () => new Promise((resolve) => {\n let src;\n let size = 0;\n switch (this.config.warmup) {\n case 'face':\n size = 256;\n src = 'data:image/jpeg;base64,' + sample.face;\n break;\n case 'full':\n case 'body':\n size = 1200;\n src = 'data:image/jpeg;base64,' + sample.body;\n break;\n default:\n src = null;\n }\n // src = encodeURI('../assets/human-sample-upper.jpg');\n const img = new Image();\n img.onload = async () => {\n const canvas = (typeof OffscreenCanvas !== 'undefined') ? new OffscreenCanvas(size, size) : document.createElement('canvas');\n canvas.width = img.naturalWidth;\n canvas.height = img.naturalHeight;\n const ctx = canvas.getContext('2d');\n ctx?.drawImage(img, 0, 0);\n // const data = ctx?.getImageData(0, 0, canvas.height, canvas.width);\n const res = await this.detect(canvas, this.config);\n resolve(res);\n };\n if (src) img.src = src;\n else resolve(null);\n });\n\n /** @hidden */\n #warmupNode = async () => {\n const atob = (str) => Buffer.from(str, 'base64');\n let img;\n if (this.config.warmup === 'face') img = atob(sample.face);\n if (this.config.warmup === 'body' || this.config.warmup === 'full') img = atob(sample.body);\n if (!img) return null;\n let res;\n if (typeof tf['node'] !== 'undefined') {\n const data = tf['node'].decodeJpeg(img);\n const expanded = data.expandDims(0);\n this.tf.dispose(data);\n // log('Input:', expanded);\n res = await this.detect(expanded, this.config);\n this.tf.dispose(expanded);\n } else {\n if (this.config.debug) log('Warmup tfjs-node not loaded');\n /*\n const input = await canvasJS.loadImage(img);\n const canvas = canvasJS.createCanvas(input.width, input.height);\n const ctx = canvas.getContext('2d');\n ctx.drawImage(img, 0, 0, input.width, input.height);\n res = await this.detect(input, this.config);\n */\n }\n return res;\n }\n\n /** Warmup metho pre-initializes all models for faster inference\n * - can take significant time on startup\n * - only used for `webgl` and `humangl` backends\n */\n async warmup(userConfig: Config | Object = {}): Promise {\n const t0 = now();\n if (userConfig) this.config = mergeDeep(this.config, userConfig);\n if (!this.config.warmup || this.config.warmup === 'none') return { error: 'null' };\n const save = this.config.videoOptimized;\n this.config.videoOptimized = false;\n let res;\n if (typeof createImageBitmap === 'function') res = await this.#warmupBitmap();\n else if (typeof Image !== 'undefined') res = await this.#warmupCanvas();\n else res = await this.#warmupNode();\n this.config.videoOptimized = save;\n const t1 = now();\n if (this.config.debug) log('Warmup', this.config.warmup, Math.round(t1 - t0), 'ms', res);\n return res;\n }\n}\n\n/**\n * Class Human is also available as default export\n */\nexport { Human as default };\n"], - "mappings": "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,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,eAAiB,kBAClB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,iBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,eAAiB,kBAClB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,eAAiB,kBAClB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,eAAiB,kBAClB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,eAAiB,iBAClB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,eAAiB,kBAClB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,gBAAkB,kBACnB,CAAC,cAAgB,kBACjB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,eAAiB,kBAClB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,mBAGT,GAAS,CACpB,IAAK,GAAI,IAAK,GAAI,EAAG,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,EACtJ,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,GAAI,GAClJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,EAAG,IAAK,GAAI,GAAI,GAAI,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,GACrJ,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,EAAG,IAC7I,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAClJ,IAAK,IAAK,GAAI,GAAI,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,GAAI,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,GACrJ,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,GACpJ,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,GACjJ,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,EAAG,EAAG,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,EAAG,IAC/I,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,IAAK,EAAG,GAAI,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IACnJ,IAAK,GAAI,EAAG,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IACnJ,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,EAAG,IAAK,IAAK,GAAI,EAAG,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAC9I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,EAAG,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GACtJ,GAAI,GAAI,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,GAClJ,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,EAAG,EAAG,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GACnJ,IAAK,IAAK,IAAK,GAAI,GAAI,EAAG,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GACrJ,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IACpJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,EAAG,IAClJ,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,EAAG,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACnJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,GAAI,IAAK,IAAK,IAAK,IACnJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IACnJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAChJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,EAAG,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAChJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAC7I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAClJ,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAC7I,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,EAAG,IAAK,GAAI,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GACnJ,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,EAAG,GAAI,EAAG,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GACpJ,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,GAAI,IAAK,GAAI,IAAK,EAAG,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAClJ,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAClJ,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,GAAI,GAAI,EAAG,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAChJ,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IACpJ,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GACrJ,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,GAAI,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,GACpJ,IAAK,GAAI,IAAK,IAAK,EAAG,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,EAAG,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAC/I,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,EAAG,IAAK,GAAI,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAC9I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GACpJ,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GACrJ,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IACpJ,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,EAAG,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,EACpJ,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAC9I,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,EAAG,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,EAAG,GAAI,IAClJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAC9I,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAChJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAChJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAC9I,IAAK,GAAI,IAAK,EAAG,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAChJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAClJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,EAAG,IAAK,IAAK,IAAK,IAAK,IACpJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,KAwBvI,GAAM,IAAQ,CACP,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/E,GAAI,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAC1C,IAAK,EAAG,IAAK,EAAG,GAAI,GAAI,EAAG,IAAK,IAChC,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACtD,GAAI,GAAI,GAAI,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAChD,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,KAGhC,GAAQ,CAAC,GAAI,IAAK,IAAK,IAAK,EAAG,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,EAAG,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,KAE1J,GAAO,CAAC,GAAI,IAAK,IAAK,IAAK,EAAG,GAAI,KAElC,GAAO,GAAM,IAAI,AAAC,GAAM,GAAM,IAE9B,GAAO,GAAM,IAAI,AAAC,GAAM,GAAM,IAE9B,GAAM,GAAK,IAAI,AAAC,GAAM,GAAM,ICloBzC,GAAM,IAAc,AAAO,EAAiB,cACtC,GAAe,AAAO,EAAiB,eAEvC,GAAe,CACnB,WAAY,CAAC,GAAY,GAAI,GAAY,GAAY,OAAS,IAC9D,YAAa,CAAC,GAAa,GAAI,GAAa,GAAa,OAAS,KAG9D,GAAgB,CACpB,MAAO,IACP,MAAO,GACP,aAAc,CAAC,GAAI,AAAO,EAAiB,kBAAqB,KAG5D,GAAqB,CACzB,QAAS,EACT,SAAU,EACV,KAAM,EACN,MAAO,EACP,QAAS,EACT,SAAU,EACV,aAAc,CAAC,EAAG,IAGd,GAAgB,CACpB,YAAa,EACb,YAAa,EACb,MAAO,GACP,eAAgB,IAKlB,YAA+B,EAAW,EAAW,EAAQ,EAAM,CACjE,OAAS,GAAI,EAAG,EAAI,AAAO,GAAyB,OAAQ,IAAK,CAC/D,GAAM,CAAE,MAAK,WAAY,AAAO,GAAyB,GACnD,EAAkB,AAAO,EAAiB,GAAG,IAAS,KAC5D,GAAI,CAAC,GAAQ,EAAK,SAAS,GACzB,OAAS,GAAI,EAAG,EAAI,EAAQ,OAAQ,IAAK,CACvC,GAAM,GAAQ,EAAQ,GACtB,EAAU,EAAgB,IAAM,CAC9B,EAAU,GAAO,GAAI,EAAU,GAAO,GACrC,GAAU,GAAO,GAAK,EAAU,EAAgB,IAAI,IAAM,KAO9D,YAAe,CAYpB,YAAY,EAAqB,EAAc,EAAW,CAlE5D,QAoEI,KAAK,YAAc,GACnB,KAAK,oBAAsB,EAC3B,KAAK,aAAe,EACpB,KAAK,UAAY,EACjB,KAAK,QAAU,qBAAqB,QAArB,cAA4B,OAAO,GAAG,MAAM,KAAM,EACjE,KAAK,SAAW,kBAAc,OAAO,GAAG,MAAM,KAAM,qBAAqB,QAArB,cAA4B,OAAO,GAAG,MAAM,IAChG,KAAK,SAAW,kBAAW,OAAO,GAAG,MAAM,KAAM,EACjD,KAAK,YAAc,IACnB,KAAK,QAAU,EACf,KAAK,cAAgB,EAGvB,mBAAmB,EAAW,EAAK,EAAO,EAAgB,CACxD,GAAM,GAAU,AAAS,GAAW,CAAE,WAAY,EAAI,WAAY,SAAU,EAAI,WAC1E,EAAe,EAAU,IAAI,AAAC,GAAW,CAC7C,EAAQ,GAAK,KAAK,SAAY,GAAM,GAAK,KAAK,SAAW,GACzD,EAAQ,GAAK,KAAK,SAAY,GAAM,GAAK,KAAK,SAAW,GACzD,EAAM,KAEF,EAAwB,IAAU,EAAK,AAAK,GAAoB,EAAO,CAAC,EAAG,IAAW,GACtF,EAAiB,IAAU,EAAK,EAAa,IAAI,AAAC,GAAW,CAAC,GAAG,AAAK,GAAY,EAAO,GAAuB,EAAM,KAAQ,EAC9H,EAAyB,IAAU,EAAK,AAAK,GAAsB,GAAuB,GAC1F,EAAY,CAAC,GAAG,AAAS,GAAa,CAAE,WAAY,EAAI,WAAY,SAAU,EAAI,WAAa,GACrG,MAAO,GAAc,IAAI,AAAC,GAAW,CACnC,KAAK,MAAM,EAAM,GAAK,AAAK,EAAI,EAAW,EAAsB,KAChE,KAAK,MAAM,EAAM,GAAK,AAAK,EAAI,EAAW,EAAsB,KAChE,KAAK,MAAM,EAAM,MAKrB,iCAAiC,EAAW,CAC1C,GAAM,GAAW,EAAU,GAAa,WAAW,IAAI,GACjD,EAAY,EAAU,GAAa,YAAY,IAAI,GACzD,MAAO,GAAW,EAIpB,UAAU,EAAW,EAAM,EAAqB,EAAqB,EAAO,GAAO,CACjF,GAAM,GAAM,AAAS,GAAY,AAAS,GAAW,AAAS,GAA8B,CAAC,EAAU,GAAsB,EAAU,KAAwB,KAAK,cAC9J,EAAU,AAAS,GAAW,GAChC,EAAO,AAAG,QAAM,cAAc,EAAM,CAAC,CACvC,EAAI,WAAW,GAAK,KAAK,SACzB,EAAI,WAAW,GAAK,KAAK,SAAU,EAAI,SAAS,GAAK,KAAK,SAC1D,EAAI,SAAS,GAAK,KAAK,WACrB,CAAC,GAAI,CAAC,KAAK,SAAU,KAAK,WAC9B,MAAI,IAAQ,AAAG,MAAI,MAAM,YACvB,GAAO,AAAG,QAAM,cAAc,IAEzB,CAAE,MAAK,UAAS,QAIzB,aAAa,EAAS,EAAQ,EAAY,EAAO,GAAO,CACtD,GAAM,GAA6B,GACnC,OAAS,GAAI,EAAG,EAAI,GAAc,eAAgB,IAAK,CACrD,GAAM,GAAI,EAAQ,EAAI,GAChB,EAAI,EAAQ,EAAI,EAAI,GACpB,EAAI,EAAQ,EAAI,EAAI,GAC1B,EAAa,KAAK,CACf,GAAQ,EAAK,EAAI,KAAK,SAAc,EAAI,KAAK,UAAa,EAAW,GAAK,EAAO,WAAW,GAC5F,EAAI,KAAK,SAAY,EAAW,GAAK,EAAO,WAAW,GAAI,IAGhE,MAAO,CAAE,UAAW,EAAc,KAAM,EAAa,MAAM,GAAc,QAK3E,sBAAsB,EAAW,EAAY,EAAW,CACtD,GAAM,GAAe,EAAU,AAAO,EAAiB,GAAG,cAAsB,GAAc,cAAc,GACtG,EAAe,EAAU,AAAO,EAAiB,GAAG,cAAsB,GAAc,cAAc,GACtG,EAAY,GAAe,GAAgB,EAEjD,MAAO,GAAW,IAAI,CAAC,EAAO,IAAM,CAClC,GAAI,GAAI,EACR,MAAI,KAAM,EACR,EAAI,EACK,IAAM,GACf,GAAI,GAEC,CAAC,EAAM,GAAI,EAAM,GAAI,UAI1B,SAAQ,EAAO,EAAQ,CAC3B,GAAI,GAAc,GAEd,EAQJ,GAPK,MAAK,UAAY,GAAO,KAAK,QAAU,EAAO,KAAK,SAAS,YAAe,CAAC,EAAO,KAAK,KAAK,SAAW,CAAC,EAAO,iBACnH,GAAW,KAAM,MAAK,oBAAoB,iBAAiB,GAC3D,KAAK,QAAU,GAEb,EAAO,gBAAgB,KAAK,UAG5B,CAAC,EAAO,gBAAmB,GAAY,EAAS,OAAU,EAAC,EAAO,KAAK,KAAK,SAAY,EAAS,MAAM,SAAW,KAAK,eAAmB,KAAK,gBAAkB,EAAO,KAAK,SAAS,aAAgB,CACxM,KAAK,YAAc,GACnB,KAAK,cAAgB,EACrB,OAAW,KAAY,GAAS,MAC9B,KAAK,YAAY,KAAK,CAAE,WAAY,EAAS,IAAI,WAAW,WAAY,SAAU,EAAS,IAAI,SAAS,WAAY,UAAW,EAAS,UAAW,WAAY,EAAS,aAE1K,AAAI,KAAK,YAAY,OAAS,GAAG,GAAc,IAKjD,GAFI,EAAO,KAAK,SAAS,aAAe,KAAK,gBAAkB,GAAG,MAAK,QAAU,GAE7E,EAAa,CACf,GAAI,CAAC,GAAY,CAAC,EAAS,OAAU,EAAS,MAAM,SAAW,EAC7D,YAAK,YAAc,GACnB,KAAK,cAAgB,EACd,KAET,OAAS,GAAI,EAAG,EAAI,KAAK,YAAY,OAAQ,IAAK,CAChD,GAAM,GAAY,AAAS,GAAoB,CAAE,WAAY,KAAK,YAAY,GAAG,WAAY,SAAU,KAAK,YAAY,GAAG,UAAY,EAAS,aAC1I,EAAc,AAAS,GAAW,GAClC,EAAgB,AAAS,GAAY,GACrC,EAAY,KAAK,YAAY,GAAG,UAAU,YAC1C,EAAa,KAAK,YAAY,GAAG,WACvC,KAAK,YAAY,GAAK,IAAK,EAAe,aAAY,cAG1D,AAAI,GAAY,EAAS,OACvB,EAAS,MAAM,QAAQ,AAAC,GAAe,CACrC,EAAW,IAAI,WAAW,UAC1B,EAAW,IAAI,SAAS,UACxB,EAAW,UAAU,YAGzB,GAAM,GAAU,AAAG,OAAK,IAAM,KAAK,YAAY,IAAI,CAAC,EAAK,IAAM,CAE7D,GAAI,GACA,EAAQ,EACR,EAEJ,GAAI,EAAO,KAAK,SAAS,UAAY,EAAO,KAAK,KAAK,SAAW,AAAG,MAAI,MAAM,WAAY,CACxF,GAAM,CAAC,EAAc,GAAoB,EAAI,UAAU,QAAU,GAAc,MAAS,GAAc,aAAe,GAAmB,aACxI,EAAQ,AAAK,GAAgB,EAAI,UAAU,GAAe,EAAI,UAAU,IACxE,GAAM,GAAa,AAAS,GAAa,CAAE,WAAY,EAAI,WAAY,SAAU,EAAI,WAC/E,EAAuB,CAAC,EAAW,GAAK,EAAM,MAAM,GAAI,EAAW,GAAK,EAAM,MAAM,IACpF,EAAe,AAAG,QAAM,iBAAiB,EAAO,EAAO,EAAG,GAChE,EAAiB,AAAK,GAAoB,CAAC,EAAO,GAClD,AAAI,EAAO,KAAK,KAAK,QAAS,EAAO,AAAS,GAAyB,CAAE,WAAY,EAAI,WAAY,SAAU,EAAI,UAAY,EAAc,CAAC,KAAK,SAAU,KAAK,WAAW,IAAI,KAC5K,EAAO,AAAS,GAAyB,CAAE,WAAY,EAAI,WAAY,SAAU,EAAI,UAAY,EAAc,CAAC,KAAK,QAAS,KAAK,UAAU,IAAI,SACjJ,CACL,EAAsB,GACtB,GAAM,GAAc,EAAM,QAC1B,AAAI,EAAO,KAAK,KAAK,QAAS,EAAO,AAAS,GAAyB,CAAE,WAAY,EAAI,WAAY,SAAU,EAAI,UAAY,EAAa,CAAC,KAAK,SAAU,KAAK,WAAW,IAAI,KAC3K,EAAO,AAAS,GAAyB,CAAE,WAAY,EAAI,WAAY,SAAU,EAAI,UAAY,EAAa,CAAC,KAAK,QAAS,KAAK,UAAU,IAAI,KAIvJ,GAAI,CAAC,EAAO,KAAK,KAAK,QASpB,MARmB,CACjB,KAAM,GACN,MACA,eAAgB,KAChB,cAAe,EAAI,WACnB,WAAY,EAAI,WAChB,MAAO,GAKX,GAAM,CAAC,CAAE,EAAY,GAAiB,KAAK,aAAa,QAAQ,GAC1D,EAAiB,EAAW,WAAW,GAC7C,GAAI,EAAiB,EAAO,KAAK,SAAS,cACxC,YAAK,YAAY,GAAG,WAAa,EAC1B,KAGT,GAAI,GAAY,AADO,AAAG,UAAQ,EAAe,CAAC,GAAI,IACvB,YAE/B,GAAI,EAAO,KAAK,KAAK,QAAS,CAC5B,GAAM,CAAE,IAAK,EAAY,QAAS,EAAgB,KAAM,GAAgB,KAAK,UAAU,EAAW,EAAM,GAAa,WAAW,GAAI,GAAa,WAAW,GAAI,IAC1J,CAAE,IAAK,EAAa,QAAS,EAAiB,KAAM,GAAiB,KAAK,UAAU,EAAW,EAAM,GAAa,YAAY,GAAI,GAAa,YAAY,IAE3J,EAAqB,AADJ,KAAK,UAAU,QAAQ,AAAG,SAAO,CAAC,EAAa,KAC5B,WACpC,EAAc,EAAmB,MAAM,EAAG,GAAc,eAAiB,GACzE,CAAE,UAAW,GAAkB,KAAM,IAAsB,KAAK,aAAa,EAAa,EAAY,EAAgB,IACtH,GAAe,EAAmB,MAAM,GAAc,eAAiB,GACvE,CAAE,UAAW,GAAmB,KAAM,IAAuB,KAAK,aAAa,GAAc,EAAa,GAC1G,GAAgC,KAAK,iCAAiC,GAC5E,AAAI,KAAK,IAAI,IAAiC,GAC5C,IAAsB,EAAW,GAAkB,OAAQ,MAC3D,GAAsB,EAAW,GAAmB,QAAS,OAGxD,AAAI,GAAgC,EACzC,GAAsB,EAAW,GAAkB,OAAQ,CAAC,YAAa,cAEzE,GAAsB,EAAW,GAAmB,QAAS,CAAC,YAAa,cAE7E,GAAM,IAAyB,KAAK,sBAAsB,EAAW,GAAmB,QAClF,GAA0B,KAAK,sBAAsB,EAAW,GAAoB,SAC1F,EAAY,EAAU,OAAO,IAAwB,OAAO,IAI9D,GAAM,GAAO,KAAK,mBAAmB,EAAW,EAAK,EAAO,GACtD,EAAkB,EAAI,WAK5B,GAJA,EAAM,AAAS,GAAW,AAAS,GAA8B,GAAO,KACxE,EAAI,WAAa,EAGb,EAAO,KAAK,SAAS,UAAY,EAAO,KAAK,KAAK,SAAW,EAAO,KAAK,YAAY,SAAW,AAAG,MAAI,MAAM,WAAY,CAC3H,GAAM,CAAC,EAAc,GAAoB,EAAI,UAAU,QAAU,GAAc,MAAS,GAAc,aAAe,GAAmB,aACxI,EAAQ,AAAK,GAAgB,EAAI,UAAU,GAAe,EAAI,UAAU,IACxE,GAAM,GAAa,AAAS,GAAa,CAAE,WAAY,EAAI,WAAY,SAAU,EAAI,WAC/E,EAAuB,CAAC,EAAW,GAAK,EAAM,MAAM,GAAI,EAAW,GAAK,EAAM,MAAM,IACpF,EAAe,AAAG,QAAM,iBAAiB,EAAM,UAAW,EAAO,EAAG,GAC1E,EAAiB,AAAK,GAAoB,CAAC,EAAO,GAClD,EAAO,AAAS,GAAyB,CAAE,WAAY,EAAI,WAAY,SAAU,EAAI,UAAY,EAAc,CAAC,KAAK,SAAU,KAAK,WAAW,IAAI,KAGrJ,GAAM,GAAa,CACjB,OACA,MACA,iBACA,cAAe,EAAI,WACnB,MAAO,GAIH,EAAY,AAAS,GAAY,GAEvC,SAAU,WAAa,EAAI,WAE3B,EAAU,eAAiB,EAE3B,KAAK,YAAY,GAAK,EAEf,KAKT,MAAI,GAAO,KAAK,KAAK,SAAS,MAAK,YAAc,KAAK,YAAY,OAAO,AAAC,GAAM,EAAE,WAAa,EAAO,KAAK,SAAS,gBACpH,KAAK,cAAgB,EAAQ,OAEtB,IL9SX,GAAI,GAA6B,CAAC,KAAM,KAAM,MAC1C,GAEJ,kBAA8B,EAAO,EAAkH,CACrJ,GAAM,GAAc,KAAM,IAAa,QAAQ,EAAO,GAChD,EAAgH,GACtH,OAAW,KAAe,IAAe,GAAK,CAC5C,GAAI,CAAC,GAAc,EAAW,mBAAoB,SAClD,GAAM,GAAU,EAAW,KAAK,IAAI,AAAC,GAAO,CAC1C,EAAG,GAAK,EAAM,MAAM,GACpB,EAAG,GAAK,EAAM,MAAM,GACpB,EAAG,GAAK,GAAa,WAEjB,EAAc,GACpB,GAAI,EAAW,MAAQ,EAAW,KAAK,OAAS,EAC9C,OAAW,KAAO,QAAO,KAAY,GAAmB,EAAY,GAAO,AAAO,EAAiB,GAAK,IAAI,AAAC,GAAU,EAAW,KAAK,IAEzI,GAAM,GAAa,EAAW,IAAM,CAClC,KAAK,IAAI,EAAG,EAAW,IAAI,WAAW,IACtC,KAAK,IAAI,EAAG,EAAW,IAAI,WAAW,IACtC,KAAK,IAAI,EAAM,MAAM,GAAI,EAAW,IAAI,SAAS,IAAM,KAAK,IAAI,EAAG,EAAW,IAAI,WAAW,IAC7F,KAAK,IAAI,EAAM,MAAM,GAAI,EAAW,IAAI,SAAS,IAAM,KAAK,IAAI,EAAG,EAAW,IAAI,WAAW,KAC3F,EACE,EAAS,EAAW,IAAM,CAC9B,EAAW,IAAI,WAAW,GAAK,EAAM,MAAM,GAC3C,EAAW,IAAI,WAAW,GAAK,EAAM,MAAM,GAC1C,GAAW,IAAI,SAAS,GAAK,EAAW,IAAI,WAAW,IAAM,EAAM,MAAM,GACzE,GAAW,IAAI,SAAS,GAAK,EAAW,IAAI,WAAW,IAAM,EAAM,MAAM,IACxE,GACJ,EAAQ,KAAK,CACX,WAAY,KAAK,MAAM,IAAM,EAAW,gBAAkB,IAAM,EAAW,eAAiB,GAAK,IACjG,cAAe,KAAK,MAAM,IAAM,EAAW,eAAiB,IAC5D,eAAgB,KAAK,MAAM,IAAM,EAAW,gBAAkB,IAC9D,IAAK,EACL,SACA,KAAM,EAAW,KACjB,UACA,cACA,MAAO,EAAW,QAEhB,EAAW,QAAQ,EAAW,OAAO,UAE3C,MAAO,GAGT,kBAA2B,EAA2C,CACpE,MAAK,CAAC,EAAW,IAAM,EAAO,KAAK,SAAa,CAAC,EAAW,IAAM,EAAO,KAAK,KAAK,SAAa,CAAC,EAAW,IAAM,EAAO,KAAK,KAAK,QACjI,GAAa,KAAM,SAAQ,IAAI,CAC5B,CAAC,EAAW,IAAM,EAAO,KAAK,QAAW,AAAU,GAAK,GAAU,KAClE,CAAC,EAAW,IAAM,EAAO,KAAK,KAAK,QAAW,AAAG,iBAAe,EAAK,EAAO,cAAe,EAAO,KAAK,KAAK,WAAY,CAAE,UAAW,EAAO,KAAK,KAAK,UAAU,SAAS,eAAkB,KAC3L,CAAC,EAAW,IAAM,EAAO,KAAK,KAAK,QAAW,AAAG,iBAAe,EAAK,EAAO,cAAe,EAAO,KAAK,KAAK,WAAY,CAAE,UAAW,EAAO,KAAK,KAAK,UAAU,SAAS,eAAkB,OAE1L,EAAO,KAAK,KAAK,SACnB,CAAI,CAAC,EAAW,IAAM,CAAC,EAAW,GAAG,SAAU,EAAI,qBAAsB,EAAO,KAAK,KAAK,WACjF,EAAO,OAAO,EAAI,cAAe,EAAW,GAAG,WAEtD,EAAO,KAAK,KAAK,SACnB,CAAI,CAAC,EAAW,IAAM,CAAC,EAAW,GAAG,SAAU,EAAI,qBAAsB,EAAO,KAAK,KAAK,WACjF,EAAO,OAAO,EAAI,cAAe,EAAW,GAAG,YAEjD,EAAO,OAChB,GAAI,gBAAiB,EAAW,GAAG,MAAM,UACzC,EAAI,gBAAiB,EAAW,GAAG,UACnC,EAAI,gBAAiB,EAAW,GAAG,WAErC,GAAe,GAAiB,IAAS,EAAW,GAAI,EAAW,GAAI,EAAW,IAC3E,EAGF,GAAM,IAAuB,GACvB,GAAe,GM5E5B,6CAGA,GAAM,IAAc,CAAC,QAAS,UAAW,OAAQ,QAAS,MAAO,WAAY,WACzE,EACA,GAAkD,GAClD,GAAU,OAAO,iBAGf,GAAM,CAAC,MAAQ,KAAQ,MAE7B,kBAA2B,EAAQ,CACjC,MAAK,GAIM,EAAO,OAAO,EAAI,gBAAiB,EAAM,UAHlD,GAAQ,KAAM,AAAG,kBAAe,EAAK,EAAO,cAAe,EAAO,KAAK,QAAQ,YAC/E,AAAI,CAAC,GAAS,CAAC,EAAM,SAAU,EAAI,qBAAsB,EAAO,KAAK,QAAQ,WACpE,EAAO,OAAO,EAAI,cAAe,EAAM,WAE3C,EAGT,kBAA8B,EAAO,EAAQ,CAC3C,MAAK,GACA,GAAU,EAAO,KAAK,QAAQ,YAAe,EAAO,gBAAmB,GAAK,OAAS,EACxF,MACO,IAET,CAAI,EAAO,eAAgB,GAAU,EAChC,GAAU,OAAO,iBACf,GAAI,SAAQ,KAAO,IAAY,CACpC,GAAM,GAAS,AAAG,QAAM,eAAe,EAAO,CAAC,EAAM,OAAO,GAAG,MAAM,GAAI,EAAM,OAAO,GAAG,MAAM,IAAK,IAC9F,CAAC,EAAK,EAAO,GAAQ,AAAG,QAAM,EAAQ,EAAG,GAC/C,EAAO,UAEP,GAAM,GAAU,AAAG,MAAI,EAAK,GAAI,IAC1B,EAAY,AAAG,MAAI,EAAO,GAAI,IAC9B,EAAW,AAAG,MAAI,EAAM,GAAI,IAClC,EAAI,UACJ,EAAM,UACN,EAAK,UACL,GAAM,GAAY,AAAG,OAAK,CAAC,EAAS,EAAW,IAC/C,EAAQ,UACR,EAAU,UACV,EAAS,UACT,GAAM,GAAY,AAAG,OAAK,IAAM,EAAU,IAAI,IAAK,IAAI,IACvD,EAAU,UACV,GAAM,GAAiD,GACvD,GAAI,EAAO,KAAK,QAAQ,QAAS,CAC/B,GAAM,GAAW,KAAM,GAAM,QAAQ,GAC/B,EAAO,EAAS,WACtB,AAAG,UAAQ,GACX,OAAS,GAAI,EAAG,EAAI,EAAK,OAAQ,IAC/B,AAAI,EAAK,GAAK,EAAO,KAAK,QAAQ,eAAe,EAAI,KAAK,CAAE,MAAO,KAAK,IAAI,IAAM,KAAK,MAAM,IAAM,EAAK,IAAM,KAAM,QAAS,GAAY,KAE3I,EAAI,KAAK,CAAC,EAAG,IAAM,EAAE,MAAQ,EAAE,OAEjC,EAAU,UACV,GAAO,EACP,EAAQ,MApCS,KCrBrB,2FAGA,GAAI,GACA,GAAO,CAAE,IAAK,GACd,GAAU,OAAO,iBAKrB,kBAA2B,EAAQ,CACjC,MAAK,GAIM,EAAO,OAAO,EAAI,gBAAiB,EAAM,UAHlD,GAAQ,KAAM,AAAG,kBAAe,EAAK,EAAO,cAAe,EAAO,KAAK,YAAY,YACnF,AAAI,CAAC,GAAS,CAAC,EAAM,SAAU,EAAI,qBAAsB,EAAO,KAAK,YAAY,WACxE,EAAO,OAAO,EAAI,cAAe,EAAM,WAE3C,EAGF,YAAoB,EAAY,EAAY,EAAQ,EAAW,CAGpE,GAFI,CAAC,GAAc,CAAC,GAChB,kBAAY,UAAW,GAAK,kBAAY,UAAW,GACnD,kBAAY,UAAW,kBAAY,QAAQ,MAAO,GAEtD,GAAM,GAAW,EAAM,EACpB,IAAI,CAAC,EAAK,IAAO,KAAK,IAAI,EAAW,GAAK,EAAW,KAAO,GAC5D,OAAO,CAAC,EAAK,IAAS,EAAM,EAAM,IAC/B,GAAI,GAEV,MADY,MAAK,IAAI,EAAG,IAAM,GAAY,IAIrC,YAAe,EAA0B,EAAQ,EAAY,EAAG,CACrE,GAAI,GAAO,CAAE,WAAY,EAAG,KAAM,GAAI,OAAQ,GAAI,UAAW,IAC7D,GAAI,CAAC,GAAa,CAAC,GAAM,CAAC,MAAM,QAAQ,IAAc,CAAC,MAAM,QAAQ,GAAK,MAAO,GACjF,OAAW,KAAK,GACd,GAAI,EAAE,WAAa,EAAE,KAAM,CACzB,GAAM,GAAO,GAAW,EAAW,EAAE,WACrC,AAAI,EAAO,GAAa,EAAO,EAAK,YAAY,GAAO,IAAK,EAAG,WAAY,IAG/E,MAAO,GAGF,YAAiB,EAAe,CA4CrC,MA3Cc,AAAG,QAAK,IAAM,CAG1B,GAAM,GAAS,EAAM,OAAS,EAAM,QAAU,EAC9C,GAAI,CAAE,aAAqB,WAAS,MAAO,MAE3C,GAAM,GAAM,CAAC,CAAC,IAAM,IAAM,IAAM,MAmChC,MAFa,AA/BC,GAAO,MAAM,SAAW,EAClC,AAAG,QAAM,cAAc,AAAG,aAAW,EAAQ,GAAI,EAAK,CAAC,GAAI,CAAC,EAAM,OAAO,GAAG,MAAM,GAAI,EAAM,OAAO,GAAG,MAAM,KAC5G,AAAG,QAAM,cAAc,EAAQ,EAAK,CAAC,GAAI,CAAC,EAAM,OAAO,GAAG,MAAM,GAAI,EAAM,OAAO,GAAG,MAAM,MA6B5E,IAAI,OAO1B,kBAA8B,EAAO,EAAQ,CAC3C,MAAK,GACA,GAAU,EAAO,KAAK,YAAY,YAAe,EAAO,gBAAkB,GAAK,KAAQ,GAAK,IAAM,EACrG,MACO,IAET,CAAI,EAAO,eAAgB,GAAU,EAChC,GAAU,OAAO,iBACf,GAAI,SAAQ,KAAO,IAAY,CACpC,GAAM,GAAW,GAAQ,GAErB,EACE,EAAM,CACV,IAAa,EACb,OAAgB,UAChB,iBAA0B,EAC1B,WAAsB,IAExB,AAAI,EAAO,KAAK,YAAY,SAAS,GAAO,KAAM,GAAM,QAAQ,IAChE,AAAG,UAAQ,GAEP,GACF,CAAG,OAAK,IAAM,CACZ,GAAM,GAAS,EAAK,KAAK,AAAC,GAAM,EAAE,MAAM,KAAO,GAAG,WAC5C,EAAa,KAAK,MAAM,IAAM,KAAK,IAAK,EAAO,GAAK,KAAS,IACnE,AAAI,EAAa,EAAO,KAAK,YAAY,eACvC,GAAI,OAAS,EAAO,IAAM,GAAM,SAAW,OAC3C,EAAI,iBAAmB,KAAK,IAAI,IAAM,IAExC,GAAM,GAAM,EAAK,KAAK,AAAC,GAAM,EAAE,MAAM,KAAO,KAAK,OAAO,GAAG,WAAW,GAChE,EAAM,EAAK,KAAK,AAAC,GAAM,EAAE,MAAM,KAAO,KAAK,WACjD,EAAI,IAAM,KAAK,MAAM,EAAI,EAAM,GAAK,EAAI,EAAM,GAAK,GAAK,EAAM,IAAM,EAAI,EAAM,GAAK,GAAK,EAAM,IAAM,EAAI,EAAM,IAAM,GAEpH,GAAM,GAAO,EAAK,KAAK,AAAC,GAAM,EAAE,MAAM,KAAO,MAI7C,EAAI,WAAa,CAAC,GAAG,EAAK,cAE5B,EAAK,QAAQ,AAAC,GAAM,AAAG,UAAQ,KAGjC,GAAO,EACP,EAAQ,MA1CS,KCpFrB,GAAM,IAAqB,CAAC,EAAM,IAA0J,CAE1L,GAAM,GAAU,AAAC,GAAW,EAAQ,IAAO,KAAK,GAE1C,EAAY,AAAC,GAAM,CACvB,GAAM,GAAS,KAAK,KAAK,EAAE,GAAK,EAAE,GAAK,EAAE,GAAK,EAAE,GAAK,EAAE,GAAK,EAAE,IAC9D,SAAE,IAAM,EACR,EAAE,IAAM,EACR,EAAE,IAAM,EACD,GAEH,EAAa,CAAC,EAAG,IAAM,CAC3B,GAAM,GAAI,EAAE,GAAK,EAAE,GACb,EAAI,EAAE,GAAK,EAAE,GACb,EAAI,EAAE,GAAK,EAAE,GACnB,MAAO,CAAC,EAAG,EAAG,IAEV,EAAe,CAAC,EAAG,IAAM,CAC7B,GAAM,GAAI,EAAE,GAAK,EAAE,GAAK,EAAE,GAAK,EAAE,GAC3B,EAAI,EAAE,GAAK,EAAE,GAAK,EAAE,GAAK,EAAE,GAC3B,EAAI,EAAE,GAAK,EAAE,GAAK,EAAE,GAAK,EAAE,GACjC,MAAO,CAAC,EAAG,EAAG,IAGV,EAA6B,AAAC,GAAM,CAExC,GAAM,CAAC,EAAK,EAAK,EAAK,EAAK,EAAK,EAAK,EAAK,EAAK,GAAO,EAClD,EAAY,EAAY,EAC5B,MAAI,GAAM,EACR,AAAI,EAAM,GACR,GAAS,KAAK,KAAK,GACnB,EAAS,KAAK,MAAM,CAAC,EAAK,GAC1B,EAAS,KAAK,MAAM,CAAC,EAAK,IAE1B,GAAS,CAAC,KAAK,GAAK,EACpB,EAAS,CAAC,KAAK,MAAM,EAAK,GAC1B,EAAS,GAGX,GAAS,KAAK,GAAK,EACnB,EAAS,KAAK,MAAM,EAAK,GACzB,EAAS,GAEJ,CAAE,MAAO,EAAI,CAAC,EAAQ,IAAK,EAAI,CAAC,EAAQ,KAAM,EAAI,CAAC,IAItD,EAAmB,AAAC,GAAS,CACjC,GAAM,GAAU,CAAC,EAAI,EAAI,EAAI,IAAO,KAAK,MAAM,EAAK,EAAI,EAAK,GAY7D,MAVc,CAIZ,MAAO,EAAQ,EAAK,IAAI,GAAI,EAAK,IAAI,GAAI,EAAK,KAAK,GAAI,EAAK,KAAK,IAEjE,IAAK,EAAQ,EAAK,IAAI,GAAI,EAAK,IAAI,GAAI,EAAK,KAAK,GAAI,EAAK,KAAK,IAE/D,KAAM,EAAQ,EAAK,IAAI,GAAI,EAAK,IAAI,GAAI,EAAK,KAAK,GAAI,EAAK,KAAK,MAK9D,EAAO,EAAK,QAClB,GAAI,CAAC,GAAQ,EAAK,OAAS,IAAK,MAAO,CAAE,MAAO,CAAE,MAAO,EAAG,IAAK,EAAG,KAAM,GAAK,OAAQ,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,IAEhH,GAAM,GAAO,KAAK,IAAI,EAAK,OAAO,GAAK,EAAW,GAAI,EAAK,OAAO,GAAK,EAAW,IAAM,IAElF,EAAM,CAAC,EAAK,IAAK,EAAK,KAAM,EAAK,KAAM,EAAK,MAAM,IAAI,AAAC,GAAO,CAElE,EAAG,GAAK,EAAW,GAAK,EACxB,EAAG,GAAK,EAAW,GAAK,EACxB,EAAG,KAGC,EAAS,EAAU,EAAW,EAAI,GAAI,EAAI,KAC5C,EAAS,EAAU,EAAW,EAAI,GAAI,EAAI,KACxC,EAAS,EAAU,EAAa,EAAQ,IAE9C,EAAS,EAAa,EAAQ,GAI9B,GAAM,GAAmF,CACvF,EAAO,GAAI,EAAO,GAAI,EAAO,GAC7B,EAAO,GAAI,EAAO,GAAI,EAAO,GAC7B,EAAO,GAAI,EAAO,GAAI,EAAO,IAI/B,MAAO,CAAE,MAFK,EAA2B,GAEzB,WAGL,GAAa,MAAO,EAAQ,IAAwB,CArGjE,gBAwGE,GAAI,GACA,EACA,EACA,EACA,EACA,EACE,EAoBC,GACP,EAAO,MAAQ,WACf,EAAY,IACZ,GAAM,GAAQ,KAAM,AAAS,IAAQ,EAAO,EAAO,QAEnD,GADA,EAAO,KAAK,KAAO,KAAK,MAAM,IAAQ,GAClC,CAAC,EAAO,MAAO,GACnB,OAAW,KAAQ,GAAO,CAIxB,GAHA,EAAO,QAAQ,YAGX,CAAC,EAAK,OAAS,EAAK,MAAM,mBAAoB,CAChD,EAAI,2BAA4B,EAAK,OACrC,SAGF,GAAM,GAAW,GAAmB,EAAM,CAAC,EAAM,MAAM,GAAI,EAAM,MAAM,KAGvE,EAAO,QAAQ,kBACf,AAAI,EAAO,OAAO,MAChB,EAAa,EAAO,OAAO,KAAK,QAAQ,QAAU,AAAQ,GAAQ,EAAK,MAAO,EAAO,QAAU,GAE/F,GAAO,MAAQ,cACf,EAAY,IACZ,EAAa,EAAO,OAAO,KAAK,QAAQ,QAAU,KAAM,AAAQ,IAAQ,EAAK,MAAO,EAAO,QAAU,GACrG,EAAO,KAAK,QAAU,KAAK,MAAM,IAAQ,IAE3C,EAAO,QAAQ,gBAGf,EAAO,QAAQ,sBACf,AAAI,EAAO,OAAO,MAChB,EAAU,EAAO,OAAO,KAAK,YAAY,QAAU,AAAQ,GAAQ,EAAM,EAAO,QAAU,GAE1F,GAAO,MAAQ,kBACf,EAAY,IACZ,EAAU,EAAO,OAAO,KAAK,YAAY,QAAU,KAAM,AAAQ,IAAQ,EAAK,MAAO,EAAO,QAAU,GACtG,EAAO,KAAK,UAAY,KAAK,MAAM,IAAQ,IAE7C,EAAO,QAAQ,oBAGX,EAAO,OAAO,OAChB,EAAC,EAAQ,EAAW,EAAY,EAAc,GAAW,KAAM,SAAQ,IAAI,CAAC,EAAQ,EAAW,EAAY,EAAc,KAG3H,EAAO,QAAQ,gBAIX,CAAC,EAAO,OAAO,KAAK,KAAK,SAAW,qBAAM,cAAN,cAAmB,cAAe,qBAAM,cAAN,cAAmB,eAC3F,OAAO,GAAK,YAAY,YACxB,MAAO,GAAK,YAAY,cAE1B,GAAM,GAAY,MAAK,cAAL,cAAkB,cAAe,MAAK,cAAL,cAAkB,cAEjE,KAAO,KAAK,IAAI,KAAK,IAAI,EAAK,YAAY,YAAY,GAAG,GAAK,EAAK,YAAY,YAAY,GAAG,IAAK,KAAK,IAAI,EAAK,YAAY,aAAa,GAAG,GAAK,EAAK,YAAY,aAAa,GAAG,KACnL,EAGJ,EAAQ,KAAK,IACR,EACH,IAAK,EAAQ,IACb,OAAQ,EAAQ,OAChB,iBAAkB,EAAQ,iBAC1B,UAAW,EAAQ,WACnB,QAAS,EACT,KAAO,IAAa,EAAK,KAAK,MAAM,GAAY,IAAM,EACtD,WACA,OAAQ,EAAO,OAAO,KAAK,SAAS,OAAS,KAAK,QAAL,cAAY,UAAY,OAGvE,KAAK,QAAL,QAAY,UAEZ,EAAO,QAAQ,YAEjB,SAAO,QAAQ,iBACX,EAAO,OAAO,OACZ,GAAO,KAAK,MAAM,MAAO,GAAO,KAAK,KACrC,EAAO,KAAK,KAAK,MAAO,GAAO,KAAK,IACpC,EAAO,KAAK,QAAQ,MAAO,GAAO,KAAK,OACvC,EAAO,KAAK,SAAS,MAAO,GAAO,KAAK,SAEvC,GCrNT,6CCAO,GAAM,IAAY,CACvB,OAAQ,UAAW,WAAY,UAAW,WAAY,eACtD,gBAAiB,YAAa,aAAc,YAAa,aACzD,UAAW,WAAY,WAAY,YAAa,YAAa,cAGlD,GAAQ,GAAU,OAElB,GAAU,GAAU,OAAO,CAAC,EAAQ,EAAW,IAC1D,GAAO,GAAa,EACb,GACN,IAEG,GAAqB,CACzB,CAAC,UAAW,gBAAiB,CAAC,YAAa,gBAC3C,CAAC,YAAa,aAAc,CAAC,UAAW,YACxC,CAAC,WAAY,aAAc,CAAC,WAAY,iBACxC,CAAC,aAAc,iBAAkB,CAAC,aAAc,cAChD,CAAC,WAAY,aAAc,CAAC,YAAa,cACzC,CAAC,eAAgB,iBAAkB,CAAC,UAAW,aAEpC,GAAuB,GAAmB,IAAI,CAAC,CAAC,EAAY,KAAiB,CAAC,GAAQ,GAAa,GAAQ,KAE3G,GAAY,CACvB,CAAC,OAAQ,WAAY,CAAC,UAAW,WAAY,CAAC,OAAQ,YACtD,CAAC,WAAY,YAAa,CAAC,OAAQ,gBACnC,CAAC,eAAgB,aAAc,CAAC,YAAa,aAC7C,CAAC,eAAgB,WAAY,CAAC,UAAW,YACzC,CAAC,WAAY,aAAc,CAAC,OAAQ,iBACpC,CAAC,gBAAiB,cAAe,CAAC,aAAc,cAChD,CAAC,gBAAiB,YAAa,CAAC,WAAY,aAC5C,CAAC,YAAa,eCfT,YAAwB,EAAW,CACxC,GAAM,GAAQ,EAAU,OAAO,CAAC,CAAE,OAAM,OAAM,OAAM,QAAQ,CAAE,SAAU,CAAE,IAAG,QAAW,EACtF,KAAM,KAAK,IAAI,EAAM,GACrB,KAAM,KAAK,IAAI,EAAM,GACrB,KAAM,KAAK,IAAI,EAAM,GACrB,KAAM,KAAK,IAAI,EAAM,KACnB,CACF,KAAM,OAAO,kBACb,KAAM,OAAO,kBACb,KAAM,OAAO,kBACb,KAAM,OAAO,oBAEf,MAAO,CAAC,EAAM,KAAM,EAAM,KAAM,EAAM,KAAO,EAAM,KAAM,EAAM,KAAO,EAAM,MAGvE,YAAoB,EAAO,CAAC,EAAQ,GAAQ,CAAC,EAAuB,GAAuB,CAChG,GAAM,GAAY,CAAC,EAAM,EAAQ,IAAY,EAC3C,MAAO,EAAK,MACZ,IAAK,CAAC,KAAK,MAAM,EAAK,IAAI,GAAK,GAAS,KAAK,MAAM,EAAK,IAAI,GAAK,GAAS,KAAK,MAAM,EAAK,IAAI,GAAK,GAAS,KAAK,MAAM,EAAK,IAAI,GAAK,IACrI,UAAW,EAAK,UAAU,IAAI,CAAC,CAAE,QAAO,OAAM,cAAgB,EAC5D,QACA,OACA,SAAU,CAAE,EAAG,KAAK,MAAM,EAAS,EAAI,GAAS,EAAG,KAAK,MAAM,EAAS,EAAI,SAK/E,MADoB,GAAM,IAAI,AAAC,GAAS,EAAU,EAAM,EAAS,EAAuB,EAAQ,IAK3F,YAAc,CAKnB,YAAY,EAAS,EAAiB,CACpC,KAAK,cAAgB,GAAI,OAAM,GAC/B,KAAK,iBAAmB,GACxB,KAAK,gBAAkB,EAGzB,QAAQ,EAAG,CACT,KAAK,cAAc,EAAE,KAAK,kBAAoB,EAC9C,KAAK,KAAK,KAAK,kBAGjB,SAAU,CACR,GAAM,GAAM,KAAK,cAAc,GAC/B,YAAK,SAAS,EAAG,KAAK,oBACtB,KAAK,KAAK,GACV,KAAK,cAAc,KAAK,iBAAmB,GAAK,KACzC,EAGT,OAAQ,CAAE,MAAO,MAAK,mBAAqB,GAE3C,MAAO,CAAE,MAAO,MAAK,iBAAmB,EAExC,KAAM,CAAE,MAAO,MAAK,cAAc,MAAM,EAAG,KAAK,iBAAmB,GAEnE,KAAM,CAAE,MAAO,MAAK,cAAc,GAElC,KAAK,EAAG,CACN,KAAO,EAAI,GAAK,KAAK,KAAK,KAAK,MAAM,EAAI,GAAI,IAC3C,KAAK,SAAS,EAAG,KAAK,MAAM,EAAI,IAChC,EAAI,KAAK,MAAM,EAAI,GAIvB,KAAK,EAAG,CACN,KAAO,EAAI,GAAK,KAAK,kBAAkB,CACrC,GAAI,GAAI,EAAI,EAEZ,GADI,EAAI,KAAK,kBAAoB,KAAK,KAAK,EAAG,EAAI,IAAI,IAClD,CAAC,KAAK,KAAK,EAAG,GAAI,MACtB,KAAK,SAAS,EAAG,GACjB,EAAI,GAIR,WAAW,EAAG,CACZ,MAAO,MAAK,gBAAgB,KAAK,cAAc,IAGjD,KAAK,EAAG,EAAG,CACT,MAAO,MAAK,WAAW,GAAK,KAAK,WAAW,GAG9C,SAAS,EAAG,EAAG,CACb,GAAM,GAAI,KAAK,cAAc,GAC7B,KAAK,cAAc,GAAK,KAAK,cAAc,GAC3C,KAAK,cAAc,GAAK,IAIrB,YAAwB,EAAG,EAAG,EAAU,EAAS,CACtD,MAAO,CACL,EAAG,EAAQ,IAAI,EAAG,EAAG,GACrB,EAAG,EAAQ,IAAI,EAAG,EAAG,EAAe,KAIjC,YAAwB,EAAM,EAAc,EAAS,CAC1D,GAAM,CAAE,WAAU,WAAU,GAAI,GAAa,EACvC,CAAE,IAAG,KAAM,GAAe,EAAU,EAAU,EAAU,GAC9D,MAAO,CACL,EAAG,EAAK,SAAW,EAAe,EAClC,EAAG,EAAK,SAAW,EAAe,GAY/B,YAAe,EAAG,EAAK,EAAK,CACjC,MAAI,GAAI,EAAY,EAChB,EAAI,EAAY,EACb,EAGF,YAAyB,EAAI,EAAI,EAAI,EAAI,CAC9C,GAAM,GAAK,EAAK,EACV,EAAK,EAAK,EAChB,MAAO,GAAK,EAAK,EAAK,EAGjB,YAAoB,EAAG,EAAG,CAC/B,MAAO,CAAE,EAAG,EAAE,EAAI,EAAE,EAAG,EAAG,EAAE,EAAI,EAAE,GCjJpC,GAAM,IAAqB,EACrB,GAAsB,GACtB,GAAmB,IAAM,EAE/B,YAAkC,EAAQ,EAAgB,EAAkB,EAAc,EAAS,EAAc,EAAe,EAAmB,EAAG,CACpJ,GAAM,GAAkB,AAAC,GAAW,EAClC,EAAG,EAAc,IAAI,EAAM,EAAG,EAAM,EAAG,GACvC,EAAG,EAAc,IAAI,EAAM,EAAG,EAAM,EAAI,EAAc,MAAM,GAAK,EAAK,KAElE,EAA2B,CAAC,EAAO,EAAQ,IAAW,EAC1D,EAAG,AAAM,GAAM,KAAK,MAAM,EAAM,EAAI,GAAe,EAAG,EAAS,GAC/D,EAAG,AAAM,GAAM,KAAK,MAAM,EAAM,EAAI,GAAe,EAAG,EAAQ,KAG1D,CAAC,EAAQ,GAAS,EAAa,MAE/B,EAAwB,EAAyB,EAAe,SAAU,EAAQ,GAClF,EAAe,EAAgB,GAEjC,EADmB,AAAM,GAAW,EAAe,SAAU,GAEjE,OAAS,GAAI,EAAG,EAAI,EAAkB,IAAK,CACzC,GAAM,GAAwB,EAAyB,EAAgB,EAAQ,GACzE,EAAc,AAAM,GAAe,EAAsB,EAAG,EAAsB,EAAG,EAAkB,GAC7G,EAAiB,AAAM,GAAW,CAChC,EAAG,EAAsB,EAAI,EAC7B,EAAG,EAAsB,EAAI,GAC5B,CAAE,EAAG,EAAY,EAAG,EAAG,EAAY,IAExC,GAAM,GAAwB,EAAyB,EAAgB,EAAQ,GACzE,EAAQ,EAAa,IAAI,EAAsB,EAAG,EAAsB,EAAG,GACjF,MAAO,CAAE,SAAU,EAAgB,KAAM,AAAI,GAAU,GAAmB,SAGrE,YAAoB,EAAM,EAAQ,EAAS,EAAc,EAAkB,EAAkB,CAClG,GAAM,GAAuB,AAAI,GAAU,IAAI,CAAC,CAAC,EAAgB,KAAoB,CAAC,AAAI,GAAQ,GAAiB,AAAI,GAAQ,KACzH,EAAqB,EAAqB,IAAI,CAAC,CAAC,CAAE,KAAkB,GACpE,EAAqB,EAAqB,IAAI,CAAC,CAAC,KAAmB,GACnE,EAAW,EAAO,MAAM,GACxB,EAAW,EAAmB,OAC9B,EAAoB,GAAI,OAAM,GAE9B,CAAE,KAAM,EAAU,MAAO,GAAc,EACvC,EAAY,AAAM,GAAe,EAAU,EAAc,GAC/D,EAAkB,EAAS,IAAM,CAC/B,MAAO,EACP,KAAM,AAAI,GAAU,EAAS,IAC7B,SAAU,GAGZ,OAAS,GAAO,EAAW,EAAG,GAAQ,EAAG,EAAE,EAAM,CAC/C,GAAM,GAAmB,EAAmB,GACtC,EAAmB,EAAmB,GAC5C,AAAI,EAAkB,IAAqB,CAAC,EAAkB,IAC5D,GAAkB,GAAoB,GAAyB,EAAM,EAAkB,GAAmB,EAAkB,EAAQ,EAAS,EAAc,IAI/J,OAAS,GAAO,EAAG,EAAO,EAAU,EAAE,EAAM,CAC1C,GAAM,GAAmB,EAAmB,GACtC,EAAmB,EAAmB,GAC5C,AAAI,EAAkB,IAAqB,CAAC,EAAkB,IAC5D,GAAkB,GAAoB,GAAyB,EAAM,EAAkB,GAAmB,EAAkB,EAAQ,EAAS,EAAc,IAG/J,MAAO,GAGT,YAAqC,EAAY,EAAO,EAAU,EAAU,EAAQ,CAClF,GAAM,CAAC,EAAQ,GAAS,EAAO,MAC3B,EAAe,GACb,EAAS,KAAK,IAAI,EAAW,GAAoB,GACjD,EAAO,KAAK,IAAI,EAAW,GAAqB,EAAG,GACzD,OAAS,GAAW,EAAQ,EAAW,EAAM,EAAE,EAAU,CACvD,GAAM,GAAS,KAAK,IAAI,EAAW,GAAoB,GACjD,EAAO,KAAK,IAAI,EAAW,GAAqB,EAAG,GACzD,OAAS,GAAW,EAAQ,EAAW,EAAM,EAAE,EAC7C,GAAI,EAAO,IAAI,EAAU,EAAU,GAAc,EAAO,CACtD,EAAe,GACf,MAGJ,GAAI,CAAC,EAAc,MAErB,MAAO,GAGF,YAAiC,EAAe,EAAQ,CAC7D,GAAM,CAAC,EAAQ,EAAO,GAAgB,EAAO,MACvC,EAAQ,GAAU,IAAQ,EAAS,EAAQ,EAAc,CAAC,CAAE,WAAY,GAC9E,OAAS,GAAW,EAAG,EAAW,EAAQ,EAAE,EAC1C,OAAS,GAAW,EAAG,EAAW,EAAO,EAAE,EACzC,OAAS,GAAa,EAAG,EAAa,EAAc,EAAE,EAAY,CAChE,GAAM,GAAQ,EAAO,IAAI,EAAU,EAAU,GAE7C,AAAI,EAAQ,GAER,GAA4B,EAAY,EAAO,EAAU,EAAU,IAAS,EAAM,QAAQ,CAAE,QAAO,KAAM,CAAE,WAAU,WAAU,GAAI,KAI7I,MAAO,GAGT,YAAsB,EAAO,CAAE,IAAG,KAAK,EAAY,CACjD,MAAO,GAAM,KAAK,CAAC,CAAE,eAAgB,CACnC,GAAM,GAAwB,EAAU,GAAY,SACpD,MAAO,AAAM,IAAgB,EAAG,EAAG,EAAsB,EAAG,EAAsB,IAAM,KAI5F,YAA0B,EAAe,EAAmB,CAK1D,MAAO,AAJ6B,GAAkB,OAAO,CAAC,EAAQ,CAAE,WAAU,SAAS,IACpF,IAAa,EAAe,EAAU,IAAa,IAAU,GAC3D,GACN,GACkC,EAAkB,OAGlD,YAAgB,EAAe,EAAc,EAAwB,EAAwB,EAAa,EAAe,CAC9H,GAAM,GAA4D,GAC5D,EAAQ,GAAwB,EAAe,GAErD,KAAO,EAAM,OAAS,GAAe,CAAC,EAAM,SAAS,CAEnD,GAAM,GAAO,EAAM,UAEb,EAAkB,AAAM,GAAe,EAAK,KAAM,GAAqB,GAC7E,GAAI,GAAa,EAAO,EAAiB,EAAK,KAAK,IAAK,SAGxD,GAAM,GAAY,AADG,GAAW,EAAM,EAAc,EAAe,GAAqB,EAAwB,GACjF,OAAO,AAAC,GAAM,EAAE,MAAQ,GACjD,EAAQ,GAAiB,EAAO,GAChC,EAAM,AAAM,GAAe,GACjC,AAAI,EAAQ,GAAe,EAAM,KAAK,CAAE,YAAW,MAAK,MAAO,KAAK,MAAM,IAAM,GAAS,MAE3F,MAAO,GHrIT,GAAI,GACE,GAAiB,CAAC,+BAA6C,gCAAoD,yCAA+D,0CAExL,kBAA8B,EAAO,EAAQ,CAC3C,GAAM,GAAM,AAAG,OAAK,IAAM,CAExB,GAAM,GAAa,AADH,EAAM,eAAe,CAAC,EAAM,OAAO,GAAG,MAAM,GAAI,EAAM,OAAO,GAAG,MAAM,KAC3D,UAAU,IAAI,OAAO,IAAI,GAE9C,EAAY,AADF,EAAM,QAAQ,EAAY,IAChB,IAAI,AAAC,GAAM,EAAE,QAAQ,CAAC,KAChD,SAAU,GAAK,EAAU,GAAG,UACrB,IAGH,EAAU,KAAM,SAAQ,IAAI,EAAI,IAAI,AAAC,GAAW,EAAO,WAC7D,OAAW,KAAK,GAAK,EAAE,UAEvB,GAAM,GAAU,KAAM,AAAM,IAAO,EAAQ,GAAI,EAAQ,GAAI,EAAQ,GAAI,EAAQ,GAAI,EAAO,KAAK,YAAa,EAAO,KAAK,eAGxH,MAFe,AAAK,IAAW,EAAS,CAAC,EAAM,MAAM,GAAI,EAAM,MAAM,IAAK,CAAC,EAAM,OAAO,GAAG,MAAM,GAAI,EAAM,OAAO,GAAG,MAAM,KAK7H,kBAA2B,EAAQ,CACjC,MAAK,GAIM,EAAO,OAAO,EAAI,gBAAiB,EAAM,UAHlD,GAAQ,KAAM,AAAG,kBAAe,EAAK,EAAO,cAAe,EAAO,KAAK,YACvE,AAAI,CAAC,GAAS,CAAC,EAAM,SAAU,EAAI,qBAAsB,EAAO,KAAK,WAC5D,EAAO,OAAO,EAAI,cAAe,EAAM,WAE3C,EIjCT,6CCEO,YAAoB,EAAK,CAC9B,MAAO,CACL,KAAK,IAAI,EAAI,SAAS,GAAK,EAAI,WAAW,IAC1C,KAAK,IAAI,EAAI,SAAS,GAAK,EAAI,WAAW,KAIvC,YAAsB,EAAK,CAChC,MAAO,CACL,EAAI,WAAW,GAAM,GAAI,SAAS,GAAK,EAAI,WAAW,IAAM,EAC5D,EAAI,WAAW,GAAM,GAAI,SAAS,GAAK,EAAI,WAAW,IAAM,GAIzD,YAAkC,EAAK,EAAO,EAAU,CAC7D,GAAM,GAAI,EAAM,MAAM,GAChB,EAAI,EAAM,MAAM,GAChB,EAAQ,CAAC,CACb,EAAI,WAAW,GAAK,EACpB,EAAI,WAAW,GAAK,EACpB,EAAI,SAAS,GAAK,EAClB,EAAI,SAAS,GAAK,IAEpB,MAAO,AAAG,SAAM,cAAc,EAAO,EAAO,CAAC,GAAI,GAG5C,YAA6B,EAAK,EAAQ,CAC/C,GAAM,GAAa,CAAC,EAAI,WAAW,GAAK,EAAO,GAAI,EAAI,WAAW,GAAK,EAAO,IACxE,EAAW,CAAC,EAAI,SAAS,GAAK,EAAO,GAAI,EAAI,SAAS,GAAK,EAAO,IAClE,EAAgB,EAAI,cAAc,IAAI,AAAC,GACvB,CAAC,EAAM,GAAK,EAAO,GAAI,EAAM,GAAK,EAAO,KAG/D,MAAO,CAAE,aAAY,WAAU,gBAAe,WAAY,EAAI,YAGzD,YAAoB,EAAK,EAAS,IAAK,CAC5C,GAAM,GAAS,GAAa,GACtB,EAAO,GAAW,GAClB,EAAc,CAAC,EAAS,EAAK,GAAK,EAAG,EAAS,EAAK,GAAK,GACxD,EAAa,CAAC,EAAO,GAAK,EAAY,GAAI,EAAO,GAAK,EAAY,IAClE,EAAW,CAAC,EAAO,GAAK,EAAY,GAAI,EAAO,GAAK,EAAY,IACtE,MAAO,CAAE,aAAY,WAAU,cAAe,EAAI,eAG7C,YAAqB,EAAK,CAC/B,GAAM,GAAU,GAAa,GACvB,EAAO,GAAW,GAElB,EAAW,AADD,KAAK,IAAI,GAAG,GACD,EACrB,EAAa,CAAC,EAAQ,GAAK,EAAU,EAAQ,GAAK,GAClD,EAAW,CAAC,EAAQ,GAAK,EAAU,EAAQ,GAAK,GACtD,MAAO,CAAE,aAAY,WAAU,cAAe,EAAI,eCtD7C,GAAM,IAAU,CACrB,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EA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AA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,kEA0JP,GAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;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", + "sourcesContent": ["// helper function: join two paths\nexport function join(folder: string, file: string): string {\n const separator = folder.endsWith('/') ? '' : '/';\n const skipJoin = file.startsWith('.') || file.startsWith('/') || file.startsWith('http:') || file.startsWith('https:') || file.startsWith('file:');\n const path = skipJoin ? `${file}` : `${folder}${separator}${file}`;\n if (!path.toLocaleLowerCase().includes('.json')) throw new Error(`Human: ModelPath Error: ${path} Expecting JSON file`);\n return path;\n}\n\n// helper function: wrapper around console output\nexport function log(...msg) {\n const dt = new Date();\n const ts = `${dt.getHours().toString().padStart(2, '0')}:${dt.getMinutes().toString().padStart(2, '0')}:${dt.getSeconds().toString().padStart(2, '0')}.${dt.getMilliseconds().toString().padStart(3, '0')}`;\n // eslint-disable-next-line no-console\n if (msg) console.log(ts, 'Human:', ...msg);\n}\n\n// helper function: gets elapsed time on both browser and nodejs\nexport const now = () => {\n if (typeof performance !== 'undefined') return performance.now();\n return parseInt((Number(process.hrtime.bigint()) / 1000 / 1000).toString());\n};\n\n// helper function: perform deep merge of multiple objects so it allows full inheriance with overrides\nexport function mergeDeep(...objects) {\n const isObject = (obj) => obj && typeof obj === 'object';\n return objects.reduce((prev, obj) => {\n Object.keys(obj || {}).forEach((key) => {\n const pVal = prev[key];\n const oVal = obj[key];\n if (Array.isArray(pVal) && Array.isArray(oVal)) prev[key] = pVal.concat(...oVal);\n else if (isObject(pVal) && isObject(oVal)) prev[key] = mergeDeep(pVal, oVal);\n else prev[key] = oVal;\n });\n return prev;\n }, {});\n}\n", "export function info(): { platform: string, agent: string } {\n let platform;\n let agent;\n if (typeof navigator !== 'undefined') {\n const raw = navigator.userAgent.match(/\\(([^()]+)\\)/g);\n if (raw && raw[0]) {\n const platformMatch = raw[0].match(/\\(([^()]+)\\)/g);\n platform = platformMatch ? platformMatch[0].replace(/\\(|\\)/g, '') : '';\n agent = navigator.userAgent.replace(raw[0], '');\n if (platform[1]) agent = agent.replace(raw[1], '');\n agent = agent.replace(/ /g, ' ');\n }\n } else if (typeof process !== 'undefined') {\n platform = `${process.platform} ${process.arch}`;\n agent = `NodeJS ${process.version}`;\n }\n return { platform, agent };\n}\n", "// wrapper to load tfjs in a single place so version can be changed quickly\n\n// simplified\n// { modules: 1250, moduleBytes: 4013323, imports: 7, importBytes: 2255, outputBytes: 2991826, outputFiles: 'dist/tfjs.esm.js' }\n// export * from '@tensorflow/tfjs/dist/index.js';\n// export * from '@tensorflow/tfjs-backend-wasm';\n\n// modular\n// { modules: 1253, moduleBytes: 4029357, imports: 7, importBytes: 2285, outputBytes: 2998298, outputFiles: 'dist/tfjs.esm.js' }\n\n// get versions of all packages.\nimport * as packageBundle from '@tensorflow/tfjs/package.json';\nimport * as packageCore from '@tensorflow/tfjs-core/package.json';\nimport * as packageData from '@tensorflow/tfjs-data/package.json';\nimport * as packageLayers from '@tensorflow/tfjs-layers/package.json';\nimport * as packageConverter from '@tensorflow/tfjs-converter/package.json';\n// for backends, get version from source so it can register backend during import\nimport { version_cpu } from '@tensorflow/tfjs-backend-cpu/dist/index.js';\nimport { version_webgl } from '@tensorflow/tfjs-backend-webgl/dist/index.js';\nimport { version_wasm } from '@tensorflow/tfjs-backend-wasm/dist/index.js';\n\n// export all - compiled\nexport * from '@tensorflow/tfjs-core/dist/index.js';\nexport * from '@tensorflow/tfjs-layers/dist/index.js';\nexport * from '@tensorflow/tfjs-converter/dist/index.js';\nexport * as data from '@tensorflow/tfjs-data/dist/index.js';\nexport * from '@tensorflow/tfjs-backend-cpu/dist/index.js';\nexport * from '@tensorflow/tfjs-backend-webgl/dist/index.js';\nexport * from '@tensorflow/tfjs-backend-wasm/dist/index.js';\n\n// export all - sources\n/*\nexport * from '@tensorflow/tfjs-core/src/index';\nexport * from '@tensorflow/tfjs-layers/src/index';\nexport * from '@tensorflow/tfjs-converter/src/index';\nexport * as data from '@tensorflow/tfjs-data/src/index';\nexport * from '@tensorflow/tfjs-backend-cpu/src/index';\nexport * from '@tensorflow/tfjs-backend-webgl/src/index';\nexport * from '@tensorflow/tfjs-backend-wasm/src/index';\n*/\n\n// export versions\nexport const version = {\n tfjs: packageBundle?.version || undefined,\n 'tfjs-core': packageCore?.version || undefined,\n 'tfjs-data': packageData?.version || undefined,\n 'tfjs-layers': packageLayers?.version || undefined,\n 'tfjs-converter': packageConverter?.version || undefined,\n 'tfjs-backend-cpu': version_cpu || undefined,\n 'tfjs-backend-webgl': version_webgl || undefined,\n 'tfjs-backend-wasm': version_wasm || undefined,\n};\n// export const version = {};\n", "import { log } from '../helpers';\nimport * as tf from '../../dist/tfjs.esm.js';\n\nexport const config = {\n name: 'humangl',\n priority: 99,\n canvas: null,\n gl: null,\n width: 1024,\n height: 1024,\n webGLattr: { // https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.2\n alpha: false,\n antialias: false,\n premultipliedAlpha: false,\n preserveDrawingBuffer: false,\n depth: false,\n stencil: false,\n failIfMajorPerformanceCaveat: false,\n desynchronized: true,\n },\n};\n\nexport function register(): void {\n if (!tf.findBackend(config.name)) {\n log('backend registration:', config.name);\n try {\n config.canvas = (typeof OffscreenCanvas !== 'undefined') ? new OffscreenCanvas(config.width, config.height) : document.createElement('canvas');\n } catch (err) {\n log('error: cannot create canvas:', err);\n return;\n }\n try {\n config.gl = config.canvas.getContext('webgl2', config.webGLattr);\n } catch (err) {\n log('error: cannot get WebGL2 context:', err);\n return;\n }\n try {\n tf.setWebGLContext(2, config.gl);\n } catch (err) {\n log('error: cannot set WebGL2 context:', err);\n return;\n }\n try {\n const ctx = new tf.GPGPUContext(config.gl);\n tf.registerBackend(config.name, () => new tf.MathBackendWebGL(ctx), config.priority);\n } catch (err) {\n log('error: cannot register WebGL backend:', err);\n return;\n }\n try {\n const kernels = tf.getKernelsForBackend('webgl');\n kernels.forEach((kernelConfig) => {\n const newKernelConfig = { ...kernelConfig, backendName: config.name };\n tf.registerKernel(newKernelConfig);\n });\n } catch (err) {\n log('error: cannot update WebGL backend registration:', err);\n return;\n }\n try {\n tf.ENV.set('WEBGL_VERSION', 2);\n // tf.ENV.set('WEBGL_MAX_TEXTURE_SIZE', config.gl.getParameter(config.gl.MAX_TEXTURE_SIZE));\n // tf.ENV.set('WEBGL_FORCE_F16_TEXTURES', true);\n // tf.ENV.set('WEBGL_PACK_DEPTHWISECONV', true);\n } catch (err) {\n log('error: cannot set WebGL backend flags:', err);\n return;\n }\n log('backend registered:', config.name);\n }\n}\n", "import { log, join } from '../helpers';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as blazeface from './blazeface';\nimport * as facepipeline from './facepipeline';\nimport * as coords from './coords';\n\nlet faceModels:[any, any, any] = [null, null, null];\nlet facePipeline;\n\nexport async function predict(input, config): Promise<{ confidence, boxConfidence, faceConfidence, box, mesh, boxRaw, meshRaw, annotations, image }[]> {\n const predictions = await facePipeline.predict(input, config);\n const results: Array<{ confidence, boxConfidence, faceConfidence, box, mesh, boxRaw, meshRaw, annotations, image }> = [];\n for (const prediction of (predictions || [])) {\n if (!prediction || prediction.isDisposedInternal) continue; // guard against disposed tensors on long running operations such as pause in middle of processing\n const meshRaw = prediction.mesh.map((pt) => [\n pt[0] / input.shape[2],\n pt[1] / input.shape[1],\n pt[2] / facePipeline.meshSize,\n ]);\n const annotations = {};\n if (prediction.mesh && prediction.mesh.length > 0) {\n for (const key of Object.keys(coords.MESH_ANNOTATIONS)) annotations[key] = coords.MESH_ANNOTATIONS[key].map((index) => prediction.mesh[index]);\n }\n const clampedBox = prediction.box ? [\n Math.max(0, prediction.box.startPoint[0]),\n Math.max(0, prediction.box.startPoint[1]),\n Math.min(input.shape[2], prediction.box.endPoint[0]) - Math.max(0, prediction.box.startPoint[0]),\n Math.min(input.shape[1], prediction.box.endPoint[1]) - Math.max(0, prediction.box.startPoint[1]),\n ] : 0;\n const boxRaw = prediction.box ? [\n prediction.box.startPoint[0] / input.shape[2],\n prediction.box.startPoint[1] / input.shape[1],\n (prediction.box.endPoint[0] - prediction.box.startPoint[0]) / input.shape[2],\n (prediction.box.endPoint[1] - prediction.box.startPoint[1]) / input.shape[1],\n ] : [];\n results.push({\n confidence: Math.round(100 * prediction.faceConfidence || 100 * prediction.boxConfidence || 0) / 100,\n boxConfidence: Math.round(100 * prediction.boxConfidence) / 100,\n faceConfidence: Math.round(100 * prediction.faceConfidence) / 100,\n box: clampedBox,\n boxRaw,\n mesh: prediction.mesh,\n meshRaw,\n annotations,\n image: prediction.image,\n });\n if (prediction.coords) prediction.coords.dispose();\n }\n return results;\n}\n\nexport async function load(config): Promise<[Object, Object, Object]> {\n if ((!faceModels[0] && config.face.enabled) || (!faceModels[1] && config.face.mesh.enabled) || (!faceModels[2] && config.face.iris.enabled)) {\n faceModels = await Promise.all([\n (!faceModels[0] && config.face.enabled) ? blazeface.load(config) : null,\n (!faceModels[1] && config.face.mesh.enabled) ? tf.loadGraphModel(join(config.modelBasePath, config.face.mesh.modelPath), { fromTFHub: config.face.mesh.modelPath.includes('tfhub.dev') }) : null,\n (!faceModels[2] && config.face.iris.enabled) ? tf.loadGraphModel(join(config.modelBasePath, config.face.iris.modelPath), { fromTFHub: config.face.iris.modelPath.includes('tfhub.dev') }) : null,\n ]);\n if (config.face.mesh.enabled) {\n if (!faceModels[1] || !faceModels[1].modelUrl) log('load model failed:', config.face.mesh.modelPath);\n else if (config.debug) log('load model:', faceModels[1].modelUrl);\n }\n if (config.face.iris.enabled) {\n if (!faceModels[2] || !faceModels[1].modelUrl) log('load model failed:', config.face.iris.modelPath);\n else if (config.debug) log('load model:', faceModels[2].modelUrl);\n }\n } else if (config.debug) {\n log('cached model:', faceModels[0].model.modelUrl);\n log('cached model:', faceModels[1].modelUrl);\n log('cached model:', faceModels[2].modelUrl);\n }\n facePipeline = new facepipeline.Pipeline(faceModels[0], faceModels[1], faceModels[2]);\n return faceModels;\n}\n\nexport const triangulation = coords.TRI468;\nexport const uvmap = coords.UV468;\n", "import * as tf from '../../dist/tfjs.esm.js';\n\nexport function scaleBoxCoordinates(box, factor) {\n const startPoint = [box.startPoint[0] * factor[0], box.startPoint[1] * factor[1]];\n const endPoint = [box.endPoint[0] * factor[0], box.endPoint[1] * factor[1]];\n return { startPoint, endPoint };\n}\n\nexport function getBoxSize(box) {\n return [\n Math.abs(box.endPoint[0] - box.startPoint[0]),\n Math.abs(box.endPoint[1] - box.startPoint[1]),\n ];\n}\n\nexport function getBoxCenter(box) {\n return [\n box.startPoint[0] + (box.endPoint[0] - box.startPoint[0]) / 2,\n box.startPoint[1] + (box.endPoint[1] - box.startPoint[1]) / 2,\n ];\n}\n\nexport function cutBoxFromImageAndResize(box, image, cropSize) {\n const h = image.shape[1];\n const w = image.shape[2];\n const boxes = [[\n box.startPoint[1] / h,\n box.startPoint[0] / w,\n box.endPoint[1] / h,\n box.endPoint[0] / w,\n ]];\n return tf.image.cropAndResize(image, boxes, [0], cropSize);\n}\n\nexport function enlargeBox(box, factor = 1.5) {\n const center = getBoxCenter(box);\n const size = getBoxSize(box);\n const newHalfSize = [factor * size[0] / 2, factor * size[1] / 2];\n const startPoint = [center[0] - newHalfSize[0], center[1] - newHalfSize[1]];\n const endPoint = [center[0] + newHalfSize[0], center[1] + newHalfSize[1]];\n return { startPoint, endPoint, landmarks: box.landmarks };\n}\n\nexport function squarifyBox(box) {\n const centers = getBoxCenter(box);\n const size = getBoxSize(box);\n const maxEdge = Math.max(...size);\n const halfSize = maxEdge / 2;\n const startPoint = [Math.round(centers[0] - halfSize), Math.round(centers[1] - halfSize)];\n const endPoint = [Math.round(centers[0] + halfSize), Math.round(centers[1] + halfSize)];\n return { startPoint, endPoint, landmarks: box.landmarks };\n}\n\nexport function calculateLandmarksBoundingBox(landmarks) {\n const xs = landmarks.map((d) => d[0]);\n const ys = landmarks.map((d) => d[1]);\n const startPoint = [Math.min(...xs), Math.min(...ys)];\n const endPoint = [Math.max(...xs), Math.max(...ys)];\n return { startPoint, endPoint, landmarks };\n}\n\nexport const disposeBox = (t) => {\n t.startPoint.dispose();\n t.endPoint.dispose();\n};\n\nexport const createBox = (startEndTensor) => ({\n startPoint: tf.slice(startEndTensor, [0, 0], [-1, 2]),\n endPoint: tf.slice(startEndTensor, [0, 2], [-1, 2]),\n});\n", "export const IDENTITY_MATRIX = [[1, 0, 0], [0, 1, 0], [0, 0, 1]];\n/**\n * Normalizes the provided angle to the range -pi to pi.\n * @param angle The angle in radians to be normalized.\n */\nexport function normalizeRadians(angle) {\n return angle - 2 * Math.PI * Math.floor((angle + Math.PI) / (2 * Math.PI));\n}\n\n/**\n * Computes the angle of rotation between two anchor points.\n * @param point1 First anchor point\n * @param point2 Second anchor point\n */\nexport function computeRotation(point1, point2) {\n const radians = Math.PI / 2 - Math.atan2(-(point2[1] - point1[1]), point2[0] - point1[0]);\n return normalizeRadians(radians);\n}\n\nexport function radToDegrees(rad) {\n return rad * 180 / Math.PI;\n}\n\nexport function buildTranslationMatrix(x, y) {\n return [[1, 0, x], [0, 1, y], [0, 0, 1]];\n}\n\nexport function dot(v1, v2) {\n let product = 0;\n for (let i = 0; i < v1.length; i++) {\n product += v1[i] * v2[i];\n }\n return product;\n}\n\nexport function getColumnFrom2DArr(arr, columnIndex) {\n const column: Array = [];\n for (let i = 0; i < arr.length; i++) {\n column.push(arr[i][columnIndex]);\n }\n return column;\n}\n\nexport function multiplyTransformMatrices(mat1, mat2) {\n const product: Array = [];\n const size = mat1.length;\n for (let row = 0; row < size; row++) {\n product.push([]);\n for (let col = 0; col < size; col++) {\n product[row].push(dot(mat1[row], getColumnFrom2DArr(mat2, col)));\n }\n }\n return product;\n}\n\nexport function buildRotationMatrix(rotation, center) {\n const cosA = Math.cos(rotation);\n const sinA = Math.sin(rotation);\n const rotationMatrix = [[cosA, -sinA, 0], [sinA, cosA, 0], [0, 0, 1]];\n const translationMatrix = buildTranslationMatrix(center[0], center[1]);\n const translationTimesRotation = multiplyTransformMatrices(translationMatrix, rotationMatrix);\n const negativeTranslationMatrix = buildTranslationMatrix(-center[0], -center[1]);\n return multiplyTransformMatrices(translationTimesRotation, negativeTranslationMatrix);\n}\n\nexport function invertTransformMatrix(matrix) {\n const rotationComponent = [[matrix[0][0], matrix[1][0]], [matrix[0][1], matrix[1][1]]];\n const translationComponent = [matrix[0][2], matrix[1][2]];\n const invertedTranslation = [\n -dot(rotationComponent[0], translationComponent),\n -dot(rotationComponent[1], translationComponent),\n ];\n return [\n rotationComponent[0].concat(invertedTranslation[0]),\n rotationComponent[1].concat(invertedTranslation[1]),\n [0, 0, 1],\n ];\n}\n\nexport function rotatePoint(homogeneousCoordinate, rotationMatrix) {\n return [\n dot(homogeneousCoordinate, rotationMatrix[0]),\n dot(homogeneousCoordinate, rotationMatrix[1]),\n ];\n}\n\nexport function xyDistanceBetweenPoints(a, b) {\n return Math.sqrt(((a[0] - b[0]) ** 2) + ((a[1] - b[1]) ** 2));\n}\n\nexport function generateAnchors(inputSize) {\n const spec = { strides: [inputSize / 16, inputSize / 8], anchors: [2, 6] };\n const anchors: Array<[number, number]> = [];\n for (let i = 0; i < spec.strides.length; i++) {\n const stride = spec.strides[i];\n const gridRows = Math.floor((inputSize + stride - 1) / stride);\n const gridCols = Math.floor((inputSize + stride - 1) / stride);\n const anchorsNum = spec.anchors[i];\n for (let gridY = 0; gridY < gridRows; gridY++) {\n const anchorY = stride * (gridY + 0.5);\n for (let gridX = 0; gridX < gridCols; gridX++) {\n const anchorX = stride * (gridX + 0.5);\n for (let n = 0; n < anchorsNum; n++) {\n anchors.push([anchorX, anchorY]);\n }\n }\n }\n }\n return anchors;\n}\n", "import { log, join } from '../helpers';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as box from './box';\nimport * as util from './util';\n\nconst keypointsCount = 6;\n\nfunction decodeBounds(boxOutputs, anchors, inputSize) {\n const boxStarts = tf.slice(boxOutputs, [0, 1], [-1, 2]);\n const centers = tf.add(boxStarts, anchors);\n const boxSizes = tf.slice(boxOutputs, [0, 3], [-1, 2]);\n const boxSizesNormalized = tf.div(boxSizes, inputSize);\n const centersNormalized = tf.div(centers, inputSize);\n const halfBoxSize = tf.div(boxSizesNormalized, 2);\n const starts = tf.sub(centersNormalized, halfBoxSize);\n const ends = tf.add(centersNormalized, halfBoxSize);\n const startNormalized = tf.mul(starts, inputSize);\n const endNormalized = tf.mul(ends, inputSize);\n const concatAxis = 1;\n return tf.concat2d([startNormalized, endNormalized], concatAxis);\n}\n\nexport class BlazeFaceModel {\n model: any;\n anchorsData: any;\n anchors: any;\n inputSize: number;\n config: any;\n\n constructor(model, config) {\n this.model = model;\n this.anchorsData = util.generateAnchors(model.inputs[0].shape[1]);\n this.anchors = tf.tensor2d(this.anchorsData);\n this.inputSize = model.inputs[0].shape[2];\n this.config = config;\n }\n\n async getBoundingBoxes(inputImage) {\n // sanity check on input\n if ((!inputImage) || (inputImage.isDisposedInternal) || (inputImage.shape.length !== 4) || (inputImage.shape[1] < 1) || (inputImage.shape[2] < 1)) return null;\n const [batch, boxes, scores] = tf.tidy(() => {\n const resizedImage = inputImage.resizeBilinear([this.inputSize, this.inputSize]);\n const normalizedImage = resizedImage.div(127.5).sub(0.5);\n const res = this.model.execute(normalizedImage);\n let batchOut;\n if (Array.isArray(res)) { // are we using tfhub or pinto converted model?\n const sorted = res.sort((a, b) => a.size - b.size);\n const concat384 = tf.concat([sorted[0], sorted[2]], 2); // dim: 384, 1 + 16\n const concat512 = tf.concat([sorted[1], sorted[3]], 2); // dim: 512, 1 + 16\n const concat = tf.concat([concat512, concat384], 1);\n batchOut = concat.squeeze(0);\n } else {\n batchOut = res.squeeze(); // when using tfhub model\n }\n const boxesOut = decodeBounds(batchOut, this.anchors, [this.inputSize, this.inputSize]);\n const logits = tf.slice(batchOut, [0, 0], [-1, 1]);\n const scoresOut = tf.sigmoid(logits).squeeze().dataSync();\n return [batchOut, boxesOut, scoresOut];\n });\n const nmsTensor = await tf.image.nonMaxSuppressionAsync(boxes, scores, this.config.face.detector.maxDetected, this.config.face.detector.iouThreshold, this.config.face.detector.minConfidence);\n const nms = nmsTensor.arraySync();\n nmsTensor.dispose();\n const annotatedBoxes: Array<{ box: any, landmarks: any, anchor: number[], confidence: number }> = [];\n for (let i = 0; i < nms.length; i++) {\n const confidence = scores[nms[i]];\n if (confidence > this.config.face.detector.minConfidence) {\n const boundingBox = tf.slice(boxes, [nms[i], 0], [1, -1]);\n const localBox = box.createBox(boundingBox);\n boundingBox.dispose();\n const anchor = this.anchorsData[nms[i]];\n const landmarks = tf.tidy(() => tf.slice(batch, [nms[i], keypointsCount - 1], [1, -1]).squeeze().reshape([keypointsCount, -1]));\n annotatedBoxes.push({ box: localBox, landmarks, anchor, confidence });\n }\n }\n // boundingBoxes.forEach((t) => t.dispose());\n batch.dispose();\n boxes.dispose();\n // scores.dispose();\n return {\n boxes: annotatedBoxes,\n scaleFactor: [inputImage.shape[2] / this.inputSize, inputImage.shape[1] / this.inputSize],\n };\n }\n}\n\nexport async function load(config) {\n const model = await tf.loadGraphModel(join(config.modelBasePath, config.face.detector.modelPath), { fromTFHub: config.face.detector.modelPath.includes('tfhub.dev') });\n const blazeFace = new BlazeFaceModel(model, config);\n if (!model || !model.modelUrl) log('load model failed:', config.face.detector.modelPath);\n else if (config.debug) log('load model:', model.modelUrl);\n return blazeFace;\n}\n", "export const MESH_ANNOTATIONS = {\n silhouette: [\n 10, 338, 297, 332, 284, 251, 389, 356, 454, 323, 361, 288,\n 397, 365, 379, 378, 400, 377, 152, 148, 176, 149, 150, 136,\n 172, 58, 132, 93, 234, 127, 162, 21, 54, 103, 67, 109,\n ],\n lipsUpperOuter: [61, 185, 40, 39, 37, 0, 267, 269, 270, 409, 291],\n lipsLowerOuter: [146, 91, 181, 84, 17, 314, 405, 321, 375, 291],\n lipsUpperInner: [78, 191, 80, 81, 82, 13, 312, 311, 310, 415, 308],\n lipsLowerInner: [78, 95, 88, 178, 87, 14, 317, 402, 318, 324, 308],\n rightEyeUpper0: [246, 161, 160, 159, 158, 157, 173],\n rightEyeLower0: [33, 7, 163, 144, 145, 153, 154, 155, 133],\n rightEyeUpper1: [247, 30, 29, 27, 28, 56, 190],\n rightEyeLower1: [130, 25, 110, 24, 23, 22, 26, 112, 243],\n rightEyeUpper2: [113, 225, 224, 223, 222, 221, 189],\n rightEyeLower2: [226, 31, 228, 229, 230, 231, 232, 233, 244],\n rightEyeLower3: [143, 111, 117, 118, 119, 120, 121, 128, 245],\n rightEyebrowUpper: [156, 70, 63, 105, 66, 107, 55, 193],\n rightEyebrowLower: [35, 124, 46, 53, 52, 65],\n rightEyeIris: [473, 474, 475, 476, 477],\n leftEyeUpper0: [466, 388, 387, 386, 385, 384, 398],\n leftEyeLower0: [263, 249, 390, 373, 374, 380, 381, 382, 362],\n leftEyeUpper1: [467, 260, 259, 257, 258, 286, 414],\n leftEyeLower1: [359, 255, 339, 254, 253, 252, 256, 341, 463],\n leftEyeUpper2: [342, 445, 444, 443, 442, 441, 413],\n leftEyeLower2: [446, 261, 448, 449, 450, 451, 452, 453, 464],\n leftEyeLower3: [372, 340, 346, 347, 348, 349, 350, 357, 465],\n leftEyebrowUpper: [383, 300, 293, 334, 296, 336, 285, 417],\n leftEyebrowLower: [265, 353, 276, 283, 282, 295],\n leftEyeIris: [468, 469, 470, 471, 472],\n midwayBetweenEyes: [168],\n noseTip: [1],\n noseBottom: [2],\n noseRightCorner: [98],\n noseLeftCorner: [327],\n rightCheek: [205],\n leftCheek: [425],\n};\n\nexport const MESH_TO_IRIS_INDICES_MAP = [ // A mapping from facemesh model keypoints to iris model keypoints.\n { key: 'EyeUpper0', indices: [9, 10, 11, 12, 13, 14, 15] },\n { key: 'EyeUpper1', indices: [25, 26, 27, 28, 29, 30, 31] },\n { key: 'EyeUpper2', indices: [41, 42, 43, 44, 45, 46, 47] },\n { key: 'EyeLower0', indices: [0, 1, 2, 3, 4, 5, 6, 7, 8] },\n { key: 'EyeLower1', indices: [16, 17, 18, 19, 20, 21, 22, 23, 24] },\n { key: 'EyeLower2', indices: [32, 33, 34, 35, 36, 37, 38, 39, 40] },\n { key: 'EyeLower3', indices: [54, 55, 56, 57, 58, 59, 60, 61, 62] },\n // { key: 'EyebrowUpper', indices: [63, 64, 65, 66, 67, 68, 69, 70] },\n // { key: 'EyebrowLower', indices: [48, 49, 50, 51, 52, 53] },\n];\n\nexport const UV468 = [\n [0.499976992607117, 0.652534008026123],\n [0.500025987625122, 0.547487020492554],\n [0.499974012374878, 0.602371990680695],\n [0.482113003730774, 0.471979022026062],\n [0.500150978565216, 0.527155995368958],\n [0.499909996986389, 0.498252987861633],\n [0.499523013830185, 0.40106201171875],\n [0.289712011814117, 0.380764007568359],\n [0.499954998493195, 0.312398016452789],\n [0.499987006187439, 0.269918978214264],\n [0.500023007392883, 0.107050001621246],\n [0.500023007392883, 0.666234016418457],\n [0.5000159740448, 0.679224014282227],\n [0.500023007392883, 0.692348003387451],\n [0.499976992607117, 0.695277988910675],\n [0.499976992607117, 0.70593398809433],\n [0.499976992607117, 0.719385027885437],\n [0.499976992607117, 0.737019002437592],\n [0.499967992305756, 0.781370997428894],\n [0.499816000461578, 0.562981009483337],\n [0.473773002624512, 0.573909997940063],\n [0.104906998574734, 0.254140973091125],\n [0.365929991006851, 0.409575998783112],\n [0.338757991790771, 0.41302502155304],\n [0.311120003461838, 0.409460008144379],\n [0.274657994508743, 0.389131009578705],\n [0.393361985683441, 0.403706014156342],\n [0.345234006643295, 0.344011008739471],\n [0.370094001293182, 0.346076011657715],\n [0.319321990013123, 0.347265005111694],\n [0.297903001308441, 0.353591024875641],\n [0.24779200553894, 0.410809993743896],\n [0.396889001131058, 0.842755019664764],\n [0.280097991228104, 0.375599980354309],\n [0.106310002505779, 0.399955987930298],\n [0.2099249958992, 0.391353011131287],\n [0.355807989835739, 0.534406006336212],\n [0.471751004457474, 0.65040397644043],\n [0.474155008792877, 0.680191993713379],\n [0.439785003662109, 0.657229006290436],\n [0.414617002010345, 0.66654098033905],\n [0.450374007225037, 0.680860996246338],\n [0.428770989179611, 0.682690978050232],\n [0.374971002340317, 0.727805018424988],\n [0.486716985702515, 0.547628998756409],\n [0.485300987958908, 0.527395009994507],\n [0.257764995098114, 0.314490020275116],\n [0.401223003864288, 0.455172002315521],\n [0.429818987846375, 0.548614978790283],\n [0.421351999044418, 0.533740997314453],\n [0.276895999908447, 0.532056987285614],\n [0.483370006084442, 0.499586999416351],\n [0.33721199631691, 0.282882988452911],\n [0.296391993761063, 0.293242990970612],\n [0.169294998049736, 0.193813979625702],\n [0.447580009698868, 0.302609980106354],\n [0.392390012741089, 0.353887975215912],\n [0.354490011930466, 0.696784019470215],\n [0.067304998636246, 0.730105042457581],\n [0.442739009857178, 0.572826027870178],\n [0.457098007202148, 0.584792017936707],\n [0.381974011659622, 0.694710969924927],\n [0.392388999462128, 0.694203019142151],\n [0.277076005935669, 0.271932005882263],\n [0.422551989555359, 0.563233017921448],\n [0.385919004678726, 0.281364023685455],\n [0.383103013038635, 0.255840003490448],\n [0.331431001424789, 0.119714021682739],\n [0.229923993349075, 0.232002973556519],\n [0.364500999450684, 0.189113974571228],\n [0.229622006416321, 0.299540996551514],\n [0.173287004232407, 0.278747975826263],\n [0.472878992557526, 0.666198015213013],\n [0.446828007698059, 0.668527007102966],\n [0.422762006521225, 0.673889994621277],\n [0.445307999849319, 0.580065965652466],\n [0.388103008270264, 0.693961024284363],\n [0.403039008378983, 0.706539988517761],\n [0.403629004955292, 0.693953037261963],\n [0.460041999816895, 0.557139039039612],\n [0.431158006191254, 0.692366003990173],\n [0.452181994915009, 0.692366003990173],\n [0.475387006998062, 0.692366003990173],\n [0.465828001499176, 0.779190003871918],\n [0.472328990697861, 0.736225962638855],\n [0.473087012767792, 0.717857003211975],\n [0.473122000694275, 0.704625964164734],\n [0.473033010959625, 0.695277988910675],\n [0.427942007780075, 0.695277988910675],\n [0.426479011774063, 0.703539967536926],\n [0.423162013292313, 0.711845993995667],\n [0.4183090031147, 0.720062971115112],\n [0.390094995498657, 0.639572978019714],\n [0.013953999616206, 0.560034036636353],\n [0.499913990497589, 0.58014702796936],\n [0.413199990987778, 0.69539999961853],\n [0.409626007080078, 0.701822996139526],\n [0.468080013990402, 0.601534962654114],\n [0.422728985548019, 0.585985004901886],\n [0.463079988956451, 0.593783974647522],\n [0.37211999297142, 0.47341400384903],\n [0.334562003612518, 0.496073007583618],\n [0.411671012639999, 0.546965003013611],\n [0.242175996303558, 0.14767599105835],\n [0.290776997804642, 0.201445996761322],\n [0.327338010072708, 0.256527006626129],\n [0.399509996175766, 0.748921036720276],\n [0.441727995872498, 0.261676013469696],\n [0.429764986038208, 0.187834024429321],\n [0.412198007106781, 0.108901023864746],\n [0.288955003023148, 0.398952007293701],\n [0.218936994671822, 0.435410976409912],\n [0.41278201341629, 0.398970007896423],\n [0.257135003805161, 0.355440020561218],\n [0.427684992551804, 0.437960982322693],\n [0.448339998722076, 0.536936044692993],\n [0.178560003638268, 0.45755398273468],\n [0.247308000922203, 0.457193970680237],\n [0.286267012357712, 0.467674970626831],\n [0.332827985286713, 0.460712015628815],\n [0.368755996227264, 0.447206974029541],\n [0.398963987827301, 0.432654976844788],\n [0.476410001516342, 0.405806005001068],\n [0.189241006970406, 0.523923993110657],\n [0.228962004184723, 0.348950982093811],\n [0.490725994110107, 0.562400996685028],\n [0.404670000076294, 0.485132992267609],\n [0.019469000399113, 0.401564002037048],\n [0.426243007183075, 0.420431017875671],\n [0.396993011236191, 0.548797011375427],\n [0.266469985246658, 0.376977026462555],\n [0.439121007919312, 0.51895797252655],\n [0.032313998788595, 0.644356966018677],\n [0.419054001569748, 0.387154996395111],\n [0.462783008813858, 0.505746960639954],\n [0.238978996872902, 0.779744982719421],\n [0.198220998048782, 0.831938028335571],\n [0.107550002634525, 0.540755033493042],\n [0.183610007166862, 0.740257024765015],\n [0.134409993886948, 0.333683013916016],\n [0.385764002799988, 0.883153975009918],\n [0.490967005491257, 0.579378008842468],\n [0.382384985685349, 0.508572995662689],\n [0.174399003386497, 0.397670984268188],\n [0.318785011768341, 0.39623498916626],\n [0.343364000320435, 0.400596976280212],\n [0.396100014448166, 0.710216999053955],\n [0.187885001301765, 0.588537991046906],\n [0.430987000465393, 0.944064974784851],\n [0.318993002176285, 0.898285031318665],\n [0.266247987747192, 0.869701027870178],\n [0.500023007392883, 0.190576016902924],\n [0.499976992607117, 0.954452991485596],\n [0.366169989109039, 0.398822009563446],\n [0.393207013607025, 0.39553701877594],\n [0.410373002290726, 0.391080021858215],\n [0.194993004202843, 0.342101991176605],\n [0.388664990663528, 0.362284004688263],\n [0.365961998701096, 0.355970978736877],\n [0.343364000320435, 0.355356991291046],\n [0.318785011768341, 0.35834002494812],\n [0.301414996385574, 0.363156020641327],\n [0.058132998645306, 0.319076001644135],\n [0.301414996385574, 0.387449026107788],\n [0.499987989664078, 0.618434011936188],\n [0.415838003158569, 0.624195992946625],\n [0.445681989192963, 0.566076993942261],\n [0.465844005346298, 0.620640993118286],\n [0.49992299079895, 0.351523995399475],\n [0.288718998432159, 0.819945991039276],\n [0.335278987884521, 0.852819979190826],\n [0.440512001514435, 0.902418971061707],\n [0.128294005990028, 0.791940987110138],\n [0.408771991729736, 0.373893976211548],\n [0.455606997013092, 0.451801002025604],\n [0.499877005815506, 0.908990025520325],\n [0.375436991453171, 0.924192011356354],\n [0.11421000212431, 0.615022003650665],\n [0.448662012815475, 0.695277988910675],\n [0.4480200111866, 0.704632043838501],\n [0.447111994028091, 0.715808033943176],\n [0.444831997156143, 0.730794012546539],\n [0.430011987686157, 0.766808986663818],\n [0.406787008047104, 0.685672998428345],\n [0.400738000869751, 0.681069016456604],\n [0.392399996519089, 0.677703022956848],\n [0.367855995893478, 0.663918972015381],\n [0.247923001646996, 0.601333022117615],\n [0.452769994735718, 0.420849978923798],\n [0.43639200925827, 0.359887003898621],\n [0.416164010763168, 0.368713974952698],\n [0.413385987281799, 0.692366003990173],\n [0.228018000721931, 0.683571994304657],\n [0.468268007040024, 0.352671027183533],\n [0.411361992359161, 0.804327011108398],\n [0.499989002943039, 0.469825029373169],\n [0.479153990745544, 0.442654013633728],\n [0.499974012374878, 0.439637005329132],\n [0.432112008333206, 0.493588984012604],\n [0.499886006116867, 0.866917014122009],\n [0.49991300702095, 0.821729004383087],\n [0.456548988819122, 0.819200992584229],\n [0.344549000263214, 0.745438992977142],\n [0.37890899181366, 0.574010014533997],\n [0.374292999505997, 0.780184984207153],\n [0.319687992334366, 0.570737957954407],\n [0.357154995203018, 0.604269981384277],\n [0.295284003019333, 0.621580958366394],\n [0.447750002145767, 0.862477004528046],\n [0.410986006259918, 0.508723020553589],\n [0.31395098567009, 0.775308012962341],\n [0.354128003120422, 0.812552988529205],\n [0.324548006057739, 0.703992962837219],\n [0.189096003770828, 0.646299958229065],\n [0.279776990413666, 0.71465802192688],\n [0.1338230073452, 0.682700991630554],\n [0.336768001317978, 0.644733011722565],\n [0.429883986711502, 0.466521978378296],\n [0.455527991056442, 0.548622965812683],\n [0.437114000320435, 0.558896005153656],\n [0.467287987470627, 0.529924988746643],\n [0.414712011814117, 0.335219979286194],\n [0.37704598903656, 0.322777986526489],\n [0.344107985496521, 0.320150971412659],\n [0.312875986099243, 0.32233202457428],\n [0.283526003360748, 0.333190023899078],\n [0.241245999932289, 0.382785975933075],\n [0.102986000478268, 0.468762993812561],\n [0.267612010240555, 0.424560010433197],\n [0.297879010438919, 0.433175981044769],\n [0.333433985710144, 0.433878004550934],\n [0.366427004337311, 0.426115989685059],\n [0.396012008190155, 0.416696012020111],\n [0.420121014118195, 0.41022801399231],\n [0.007561000064015, 0.480777025222778],\n [0.432949006557465, 0.569517970085144],\n [0.458638995885849, 0.479089021682739],\n [0.473466008901596, 0.545744001865387],\n [0.476087987422943, 0.563830018043518],\n [0.468472003936768, 0.555056989192963],\n [0.433990985155106, 0.582361996173859],\n [0.483518004417419, 0.562983989715576],\n [0.482482999563217, 0.57784903049469],\n [0.42645001411438, 0.389798998832703],\n [0.438998997211456, 0.39649498462677],\n [0.450067013502121, 0.400434017181396],\n [0.289712011814117, 0.368252992630005],\n [0.276670008897781, 0.363372981548309],\n [0.517862021923065, 0.471948027610779],\n [0.710287988185883, 0.380764007568359],\n [0.526226997375488, 0.573909997940063],\n [0.895093023777008, 0.254140973091125],\n [0.634069979190826, 0.409575998783112],\n [0.661242008209229, 0.41302502155304],\n [0.688880026340485, 0.409460008144379],\n [0.725341975688934, 0.389131009578705],\n [0.606630027294159, 0.40370500087738],\n [0.654766023159027, 0.344011008739471],\n [0.629905998706818, 0.346076011657715],\n [0.680678009986877, 0.347265005111694],\n [0.702096998691559, 0.353591024875641],\n [0.75221198797226, 0.410804986953735],\n [0.602918028831482, 0.842862963676453],\n [0.719901978969574, 0.375599980354309],\n [0.893692970275879, 0.399959981441498],\n [0.790081977844238, 0.391354024410248],\n [0.643998026847839, 0.534487962722778],\n [0.528249025344849, 0.65040397644043],\n [0.525849997997284, 0.680191040039062],\n [0.560214996337891, 0.657229006290436],\n [0.585384011268616, 0.66654098033905],\n [0.549625992774963, 0.680860996246338],\n [0.57122802734375, 0.682691991329193],\n [0.624852001667023, 0.72809898853302],\n [0.513050019741058, 0.547281980514526],\n [0.51509702205658, 0.527251958847046],\n [0.742246985435486, 0.314507007598877],\n [0.598631024360657, 0.454979002475739],\n [0.570338010787964, 0.548575043678284],\n [0.578631997108459, 0.533622980117798],\n [0.723087012767792, 0.532054007053375],\n [0.516445994377136, 0.499638974666595],\n [0.662801027297974, 0.282917976379395],\n [0.70362401008606, 0.293271005153656],\n [0.830704987049103, 0.193813979625702],\n [0.552385985851288, 0.302568018436432],\n [0.607609987258911, 0.353887975215912],\n [0.645429015159607, 0.696707010269165],\n [0.932694971561432, 0.730105042457581],\n [0.557260990142822, 0.572826027870178],\n [0.542901992797852, 0.584792017936707],\n [0.6180260181427, 0.694710969924927],\n [0.607590973377228, 0.694203019142151],\n [0.722943007946014, 0.271963000297546],\n [0.577413976192474, 0.563166975975037],\n [0.614082992076874, 0.281386971473694],\n [0.616907000541687, 0.255886018276215],\n [0.668509006500244, 0.119913995265961],\n [0.770092010498047, 0.232020974159241],\n [0.635536015033722, 0.189248979091644],\n [0.77039098739624, 0.299556016921997],\n [0.826722025871277, 0.278755009174347],\n [0.527121007442474, 0.666198015213013],\n [0.553171992301941, 0.668527007102966],\n [0.577238023281097, 0.673889994621277],\n [0.554691970348358, 0.580065965652466],\n [0.611896991729736, 0.693961024284363],\n [0.59696102142334, 0.706539988517761],\n [0.596370995044708, 0.693953037261963],\n [0.539958000183105, 0.557139039039612],\n [0.568841993808746, 0.692366003990173],\n [0.547818005084991, 0.692366003990173],\n [0.52461302280426, 0.692366003990173],\n [0.534089982509613, 0.779141008853912],\n [0.527670979499817, 0.736225962638855],\n [0.526912987232208, 0.717857003211975],\n [0.526877999305725, 0.704625964164734],\n [0.526966989040375, 0.695277988910675],\n [0.572058022022247, 0.695277988910675],\n [0.573521018028259, 0.703539967536926],\n [0.57683801651001, 0.711845993995667],\n [0.581691026687622, 0.720062971115112],\n [0.609944999217987, 0.639909982681274],\n [0.986046016216278, 0.560034036636353],\n [0.5867999792099, 0.69539999961853],\n [0.590372025966644, 0.701822996139526],\n [0.531915009021759, 0.601536989212036],\n [0.577268004417419, 0.585934996604919],\n [0.536915004253387, 0.593786001205444],\n [0.627542972564697, 0.473352015018463],\n [0.665585994720459, 0.495950996875763],\n [0.588353991508484, 0.546862006187439],\n [0.757824003696442, 0.14767599105835],\n [0.709249973297119, 0.201507985591888],\n [0.672684013843536, 0.256581008434296],\n [0.600408971309662, 0.74900496006012],\n [0.55826598405838, 0.261672019958496],\n [0.570303976535797, 0.187870979309082],\n [0.588165998458862, 0.109044015407562],\n [0.711045026779175, 0.398952007293701],\n [0.781069993972778, 0.435405015945435],\n [0.587247014045715, 0.398931980133057],\n [0.742869973182678, 0.355445981025696],\n [0.572156012058258, 0.437651991844177],\n [0.55186802148819, 0.536570012569427],\n [0.821442008018494, 0.457556009292603],\n [0.752701997756958, 0.457181990146637],\n [0.71375697851181, 0.467626988887787],\n [0.66711300611496, 0.460672974586487],\n [0.631101012229919, 0.447153985500336],\n [0.6008620262146, 0.432473003864288],\n [0.523481011390686, 0.405627012252808],\n [0.810747981071472, 0.523926019668579],\n [0.771045982837677, 0.348959028720856],\n [0.509127020835876, 0.562718033790588],\n [0.595292985439301, 0.485023975372314],\n [0.980530977249146, 0.401564002037048],\n [0.573499977588654, 0.420000016689301],\n [0.602994978427887, 0.548687994480133],\n [0.733529984951019, 0.376977026462555],\n [0.560611009597778, 0.519016981124878],\n [0.967685997486115, 0.644356966018677],\n [0.580985009670258, 0.387160003185272],\n [0.537728011608124, 0.505385041236877],\n [0.760966002941132, 0.779752969741821],\n [0.801778972148895, 0.831938028335571],\n [0.892440974712372, 0.54076099395752],\n [0.816350996494293, 0.740260004997253],\n [0.865594983100891, 0.333687007427216],\n [0.614073991775513, 0.883246004581451],\n [0.508952975273132, 0.579437971115112],\n [0.617941975593567, 0.508316040039062],\n [0.825608015060425, 0.397674977779388],\n [0.681214988231659, 0.39623498916626],\n [0.656635999679565, 0.400596976280212],\n [0.603900015354156, 0.710216999053955],\n [0.81208598613739, 0.588539004325867],\n [0.56801301240921, 0.944564998149872],\n [0.681007981300354, 0.898285031318665],\n [0.733752012252808, 0.869701027870178],\n [0.633830010890961, 0.398822009563446],\n [0.606792986392975, 0.39553701877594],\n [0.589659988880157, 0.391062021255493],\n [0.805015981197357, 0.342108011245728],\n [0.611334979534149, 0.362284004688263],\n [0.634037971496582, 0.355970978736877],\n [0.656635999679565, 0.355356991291046],\n [0.681214988231659, 0.35834002494812],\n [0.698584973812103, 0.363156020641327],\n [0.941866993904114, 0.319076001644135],\n [0.698584973812103, 0.387449026107788],\n [0.584177017211914, 0.624107003211975],\n [0.554318010807037, 0.566076993942261],\n [0.534153997898102, 0.62064003944397],\n [0.711217999458313, 0.819975018501282],\n [0.664629995822906, 0.852871000766754],\n [0.559099972248077, 0.902631998062134],\n [0.871706008911133, 0.791940987110138],\n [0.591234028339386, 0.373893976211548],\n [0.544341027736664, 0.451583981513977],\n [0.624562978744507, 0.924192011356354],\n [0.88577002286911, 0.615028977394104],\n [0.551338016986847, 0.695277988910675],\n [0.551980018615723, 0.704632043838501],\n [0.552887976169586, 0.715808033943176],\n [0.555167973041534, 0.730794012546539],\n [0.569944024085999, 0.767035007476807],\n [0.593203008174896, 0.685675978660583],\n [0.599261999130249, 0.681069016456604],\n [0.607599973678589, 0.677703022956848],\n [0.631937980651855, 0.663500010967255],\n [0.752032995223999, 0.601315021514893],\n [0.547226011753082, 0.420395016670227],\n [0.563543975353241, 0.359827995300293],\n [0.583841025829315, 0.368713974952698],\n [0.586614012718201, 0.692366003990173],\n [0.771915018558502, 0.683578014373779],\n [0.531597018241882, 0.352482974529266],\n [0.588370978832245, 0.804440975189209],\n [0.52079701423645, 0.442565023899078],\n [0.567984998226166, 0.493479013442993],\n [0.543282985687256, 0.819254994392395],\n [0.655317008495331, 0.745514988899231],\n [0.621008992195129, 0.574018001556396],\n [0.625559985637665, 0.78031200170517],\n [0.680198013782501, 0.570719003677368],\n [0.64276397228241, 0.604337990283966],\n [0.704662978649139, 0.621529996395111],\n [0.552012026309967, 0.862591981887817],\n [0.589071989059448, 0.508637011051178],\n [0.685944974422455, 0.775357007980347],\n [0.645735025405884, 0.812640011310577],\n [0.675342977046967, 0.703978002071381],\n [0.810858011245728, 0.646304965019226],\n [0.72012197971344, 0.714666962623596],\n [0.866151988506317, 0.682704985141754],\n [0.663187026977539, 0.644596993923187],\n [0.570082008838654, 0.466325998306274],\n [0.544561982154846, 0.548375964164734],\n [0.562758982181549, 0.558784961700439],\n [0.531987011432648, 0.530140042304993],\n [0.585271000862122, 0.335177004337311],\n [0.622952997684479, 0.32277899980545],\n [0.655896008014679, 0.320163011550903],\n [0.687132000923157, 0.322345972061157],\n [0.716481983661652, 0.333200991153717],\n [0.758756995201111, 0.382786989212036],\n [0.897013008594513, 0.468769013881683],\n [0.732392013072968, 0.424547016620636],\n [0.70211398601532, 0.433162987232208],\n [0.66652500629425, 0.433866024017334],\n [0.633504986763, 0.426087975502014],\n [0.603875994682312, 0.416586995124817],\n [0.579657971858978, 0.409945011138916],\n [0.992439985275269, 0.480777025222778],\n [0.567192018032074, 0.569419980049133],\n [0.54136598110199, 0.478899002075195],\n [0.526564002037048, 0.546118021011353],\n [0.523913025856018, 0.563830018043518],\n [0.531529009342194, 0.555056989192963],\n [0.566035985946655, 0.582329034805298],\n [0.51631098985672, 0.563053965568542],\n [0.5174720287323, 0.577877044677734],\n [0.573594987392426, 0.389806985855103],\n [0.560697972774506, 0.395331978797913],\n [0.549755990505219, 0.399751007556915],\n [0.710287988185883, 0.368252992630005],\n [0.723330020904541, 0.363372981548309],\n];\n\nexport const TRI468 = [\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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,\n 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];\n\nexport const TRI68 = [0, 1, 36, 0, 36, 17, 1, 2, 41, 1, 41, 36, 2, 3, 31, 2, 31, 41, 3, 4, 48, 3, 48, 31, 4, 5, 48, 5, 6, 48, 6, 7, 59, 6, 59, 48, 7, 8, 58, 7, 58, 59,\n 8, 9, 56, 8, 56, 57, 8, 57, 58, 9, 10, 55, 9, 55, 56, 10, 11, 54, 10, 54, 55, 11, 12, 54, 12, 13, 54, 13, 14, 35, 13, 35, 54, 14, 15, 46, 14, 46, 35, 15, 16,\n 45, 15, 45, 46, 16, 26, 45, 17, 36, 18, 18, 37, 19, 18, 36, 37, 19, 38, 20, 19, 37, 38, 20, 39, 21, 20, 38, 39, 21, 39, 27, 22, 42, 23, 22, 27, 42, 23, 43, 24,\n 23, 42, 43, 24, 44, 25, 24, 43, 44, 25, 45, 26, 25, 44, 45, 27, 39, 28, 27, 28, 42, 28, 39, 29, 28, 29, 42, 29, 31, 30, 29, 30, 35, 29, 40, 31, 29, 35, 47, 29,\n 39, 40, 29, 47, 42, 30, 31, 32, 30, 32, 33, 30, 33, 34, 30, 34, 35, 31, 50, 32, 31, 40, 41, 31, 48, 49, 31, 49, 50, 32, 51, 33, 32, 50, 51, 33, 51, 34, 34, 52,\n 35, 34, 51, 52, 35, 46, 47, 35, 52, 53, 35, 53, 54, 36, 41, 37, 37, 40, 38, 37, 41, 40, 38, 40, 39, 42, 47, 43, 43, 47, 44, 44, 46, 45, 44, 47, 46, 48, 60, 49,\n 48, 59, 60, 49, 61, 50, 49, 60, 61, 50, 62, 51, 50, 61, 62, 51, 62, 52, 52, 63, 53, 52, 62, 63, 53, 64, 54, 53, 63, 64, 54, 64, 55, 55, 65, 56, 55, 64, 65, 56,\n 66, 57, 56, 65, 66, 57, 66, 58, 58, 67, 59, 58, 66, 67, 59, 67, 60, 60, 67, 61, 61, 66, 62, 61, 67, 66, 62, 66, 63, 63, 65, 64, 63, 66, 65, 21, 27, 22];\n\nexport const TRI33 = [\n /* eyes */ 0, 8, 7, 7, 8, 1, 2, 10, 9, 9, 10, 3,\n /* brows */ 17, 0, 18, 18, 0, 7, 18, 7, 19, 19, 7, 1, 19, 1, 11, 19, 11, 20, 21, 3, 22, 21, 9, 3, 20, 9, 21, 20, 2, 9, 20, 11, 2,\n /* 4head */ 23, 17, 18, 25, 21, 22, 24, 19, 20, 24, 18, 19, 24, 20, 21, 24, 23, 18, 24, 21, 25,\n /* nose */ 11, 12, 4, 11, 4, 13, 1, 12, 11, 11, 13, 2, 12, 14, 4, 4, 14, 13,\n /* up-lip */ 14, 5, 15, 14, 15, 6, 12, 5, 14, 14, 6, 13,\n /* cheeks */ 8, 12, 1, 2, 13, 10, 8, 26, 12, 10, 13, 27, 26, 5, 12, 13, 6, 27, 0, 26, 8, 10, 27, 3,\n /* chin */ 5, 32, 16, 16, 32, 6, 5, 30, 32, 6, 32, 31,\n /* cont */ 26, 30, 5, 27, 6, 31, 0, 28, 26, 3, 27, 29, 17, 28, 0, 3, 29, 22, 23, 28, 17, 22, 29, 25, 28, 30, 26, 27, 31, 29,\n];\n\nexport const TRI7 = [0, 4, 1, 2, 4, 3, 4, 5, 6];\n\nexport const VTX68 = [\n /* cont */ 127, 234, 132, 58, 172, 150, 149, 148, 152, 377, 378, 379, 397, 288, 361, 454, 356,\n /* brows */ 70, 63, 105, 66, 107, 336, 296, 334, 293, 300,\n /* nose */ 168, 6, 195, 4, 98, 97, 2, 326, 327,\n /* eyes */ 33, 160, 158, 133, 153, 144, 362, 385, 387, 263, 373, 380,\n /* lip */ 57, 40, 37, 0, 267, 270, 287, 321, 314, 17, 84, 91,\n /* mouth */ 78, 81, 13, 311, 308, 402, 14, 178,\n];\n\nexport const VTX33 = [33, 133, 362, 263, 1, 62, 308, 159, 145, 386, 374, 6, 102, 331, 2, 13, 14, 70, 105, 107, 336, 334, 300, 54, 10, 284, 50, 280, 234, 454, 58, 288, 152];\n\nexport const VTX7 = [33, 133, 362, 263, 1, 78, 308];\n\nexport const UV68 = VTX68.map((x) => UV468[x]);\n\nexport const UV33 = VTX33.map((x) => UV468[x]);\n\nexport const UV7 = VTX7.map((x) => UV468[x]);\n", "import * as tf from '../../dist/tfjs.esm.js';\nimport * as bounding from './box';\nimport * as util from './util';\nimport * as coords from './coords';\n\nconst leftOutline = coords.MESH_ANNOTATIONS['leftEyeLower0'];\nconst rightOutline = coords.MESH_ANNOTATIONS['rightEyeLower0'];\n\nconst eyeLandmarks = {\n leftBounds: [leftOutline[0], leftOutline[leftOutline.length - 1]],\n rightBounds: [rightOutline[0], rightOutline[rightOutline.length - 1]],\n};\n\nconst meshLandmarks = {\n count: 468,\n mouth: 13,\n symmetryLine: [13, coords.MESH_ANNOTATIONS['midwayBetweenEyes'][0]],\n};\n\nconst blazeFaceLandmarks = {\n leftEye: 0,\n rightEye: 1,\n nose: 2,\n mouth: 3,\n leftEar: 4,\n rightEar: 5,\n symmetryLine: [3, 2],\n};\n\nconst irisLandmarks = {\n upperCenter: 3,\n lowerCenter: 4,\n index: 71,\n numCoordinates: 76,\n};\n\n// Replace the raw coordinates returned by facemesh with refined iris model coordinates\n// Update the z coordinate to be an average of the original and the new.\nfunction replaceRawCoordinates(rawCoords, newCoords, prefix, keys) {\n for (let i = 0; i < coords.MESH_TO_IRIS_INDICES_MAP.length; i++) {\n const { key, indices } = coords.MESH_TO_IRIS_INDICES_MAP[i];\n const originalIndices = coords.MESH_ANNOTATIONS[`${prefix}${key}`];\n if (!keys || keys.includes(key)) {\n for (let j = 0; j < indices.length; j++) {\n const index = indices[j];\n rawCoords[originalIndices[j]] = [\n newCoords[index][0], newCoords[index][1],\n (newCoords[index][2] + rawCoords[originalIndices[j]][2]) / 2,\n ];\n }\n }\n }\n}\n// The Pipeline coordinates between the bounding box and skeleton models.\nexport class Pipeline {\n storedBoxes: any;\n boundingBoxDetector: any;\n meshDetector: any;\n irisModel: any;\n boxSize: number;\n meshSize: number;\n irisSize: number;\n irisEnlarge: number;\n skipped: number;\n detectedFaces: number;\n\n constructor(boundingBoxDetector, meshDetector, irisModel) {\n // An array of facial bounding boxes.\n this.storedBoxes = [];\n this.boundingBoxDetector = boundingBoxDetector;\n this.meshDetector = meshDetector;\n this.irisModel = irisModel;\n this.boxSize = boundingBoxDetector?.model?.inputs[0].shape[2] || 0;\n this.meshSize = meshDetector?.inputs[0].shape[2] || boundingBoxDetector?.model?.inputs[0].shape[2];\n this.irisSize = irisModel?.inputs[0].shape[1] || 0;\n this.irisEnlarge = 2.3;\n this.skipped = 0;\n this.detectedFaces = 0;\n }\n\n transformRawCoords(rawCoords, box, angle, rotationMatrix) {\n const boxSize = bounding.getBoxSize({ startPoint: box.startPoint, endPoint: box.endPoint });\n const coordsScaled = rawCoords.map((coord) => ([\n boxSize[0] / this.meshSize * (coord[0] - this.meshSize / 2),\n boxSize[1] / this.meshSize * (coord[1] - this.meshSize / 2),\n coord[2],\n ]));\n const coordsRotationMatrix = (angle !== 0) ? util.buildRotationMatrix(angle, [0, 0]) : util.IDENTITY_MATRIX;\n const coordsRotated = (angle !== 0) ? coordsScaled.map((coord) => ([...util.rotatePoint(coord, coordsRotationMatrix), coord[2]])) : coordsScaled;\n const inverseRotationMatrix = (angle !== 0) ? util.invertTransformMatrix(rotationMatrix) : util.IDENTITY_MATRIX;\n const boxCenter = [...bounding.getBoxCenter({ startPoint: box.startPoint, endPoint: box.endPoint }), 1];\n return coordsRotated.map((coord) => ([\n Math.round(coord[0] + util.dot(boxCenter, inverseRotationMatrix[0])),\n Math.round(coord[1] + util.dot(boxCenter, inverseRotationMatrix[1])),\n Math.round(coord[2]),\n ]));\n }\n\n // eslint-disable-next-line class-methods-use-this\n getLeftToRightEyeDepthDifference(rawCoords) {\n const leftEyeZ = rawCoords[eyeLandmarks.leftBounds[0]][2];\n const rightEyeZ = rawCoords[eyeLandmarks.rightBounds[0]][2];\n return leftEyeZ - rightEyeZ;\n }\n\n // Returns a box describing a cropped region around the eye fit for passing to the iris model.\n getEyeBox(rawCoords, face, eyeInnerCornerIndex, eyeOuterCornerIndex, flip = false) {\n const box = bounding.squarifyBox(bounding.enlargeBox(bounding.calculateLandmarksBoundingBox([rawCoords[eyeInnerCornerIndex], rawCoords[eyeOuterCornerIndex]]), this.irisEnlarge));\n const boxSize = bounding.getBoxSize(box);\n let crop = tf.image.cropAndResize(face, [[\n box.startPoint[1] / this.meshSize,\n box.startPoint[0] / this.meshSize, box.endPoint[1] / this.meshSize,\n box.endPoint[0] / this.meshSize,\n ]], [0], [this.irisSize, this.irisSize]);\n if (flip && tf.ENV.flags.IS_BROWSER) {\n crop = tf.image.flipLeftRight(crop); // flipLeftRight is not defined for tfjs-node\n }\n return { box, boxSize, crop };\n }\n\n // Given a cropped image of an eye, returns the coordinates of the contours surrounding the eye and the iris.\n getEyeCoords(eyeData, eyeBox, eyeBoxSize, flip = false) {\n const eyeRawCoords: Array = [];\n for (let i = 0; i < irisLandmarks.numCoordinates; i++) {\n const x = eyeData[i * 3];\n const y = eyeData[i * 3 + 1];\n const z = eyeData[i * 3 + 2];\n eyeRawCoords.push([\n (flip ? (1 - (x / this.irisSize)) : (x / this.irisSize)) * eyeBoxSize[0] + eyeBox.startPoint[0],\n (y / this.irisSize) * eyeBoxSize[1] + eyeBox.startPoint[1], z,\n ]);\n }\n return { rawCoords: eyeRawCoords, iris: eyeRawCoords.slice(irisLandmarks.index) };\n }\n\n // The z-coordinates returned for the iris are unreliable, so we take the z values from the surrounding keypoints.\n // eslint-disable-next-line class-methods-use-this\n getAdjustedIrisCoords(rawCoords, irisCoords, direction) {\n const upperCenterZ = rawCoords[coords.MESH_ANNOTATIONS[`${direction}EyeUpper0`][irisLandmarks.upperCenter]][2];\n const lowerCenterZ = rawCoords[coords.MESH_ANNOTATIONS[`${direction}EyeLower0`][irisLandmarks.lowerCenter]][2];\n const averageZ = (upperCenterZ + lowerCenterZ) / 2;\n // Iris indices: 0: center | 1: right | 2: above | 3: left | 4: below\n return irisCoords.map((coord, i) => {\n let z = averageZ;\n if (i === 2) {\n z = upperCenterZ;\n } else if (i === 4) {\n z = lowerCenterZ;\n }\n return [coord[0], coord[1], z];\n });\n }\n\n async predict(input, config) {\n let useFreshBox = false;\n // run new detector every skipFrames unless we only want box to start with\n let detector;\n if ((this.skipped === 0) || (this.skipped > config.face.detector.skipFrames) || !config.face.mesh.enabled || !config.videoOptimized) {\n detector = await this.boundingBoxDetector.getBoundingBoxes(input);\n this.skipped = 0;\n }\n if (config.videoOptimized) this.skipped++;\n\n // if detector result count doesn't match current working set, use it to reset current working set\n if (!config.videoOptimized || (detector && detector.boxes && (!config.face.mesh.enabled || (detector.boxes.length !== this.detectedFaces) && (this.detectedFaces !== config.face.detector.maxDetected)))) {\n this.storedBoxes = [];\n this.detectedFaces = 0;\n for (const possible of detector.boxes) {\n this.storedBoxes.push({ startPoint: possible.box.startPoint.dataSync(), endPoint: possible.box.endPoint.dataSync(), landmarks: possible.landmarks, confidence: possible.confidence });\n }\n if (this.storedBoxes.length > 0) useFreshBox = true;\n }\n\n if (config.face.detector.skipInitial && this.detectedFaces === 0) this.skipped = 0;\n\n if (useFreshBox) {\n if (!detector || !detector.boxes || (detector.boxes.length === 0)) {\n this.storedBoxes = [];\n this.detectedFaces = 0;\n return null;\n }\n for (let i = 0; i < this.storedBoxes.length; i++) {\n const scaledBox = bounding.scaleBoxCoordinates({ startPoint: this.storedBoxes[i].startPoint, endPoint: this.storedBoxes[i].endPoint }, detector.scaleFactor);\n const enlargedBox = bounding.enlargeBox(scaledBox);\n const squarifiedBox = bounding.squarifyBox(enlargedBox);\n const landmarks = this.storedBoxes[i].landmarks.arraySync();\n const confidence = this.storedBoxes[i].confidence;\n this.storedBoxes[i] = { ...squarifiedBox, confidence, landmarks };\n }\n }\n if (detector && detector.boxes) {\n detector.boxes.forEach((prediction) => {\n prediction.box.startPoint.dispose();\n prediction.box.endPoint.dispose();\n prediction.landmarks.dispose();\n });\n }\n const results = tf.tidy(() => this.storedBoxes.map((box, i) => {\n // The facial bounding box landmarks could come either from blazeface (if we are using a fresh box), or from the mesh model (if we are reusing an old box).\n let face;\n let angle = 0;\n let rotationMatrix;\n\n if (config.face.detector.rotation && config.face.mesh.enabled && tf.ENV.flags.IS_BROWSER) {\n const [indexOfMouth, indexOfForehead] = (box.landmarks.length >= meshLandmarks.count) ? meshLandmarks.symmetryLine : blazeFaceLandmarks.symmetryLine;\n angle = util.computeRotation(box.landmarks[indexOfMouth], box.landmarks[indexOfForehead]);\n const faceCenter = bounding.getBoxCenter({ startPoint: box.startPoint, endPoint: box.endPoint });\n const faceCenterNormalized = [faceCenter[0] / input.shape[2], faceCenter[1] / input.shape[1]];\n const rotatedImage = tf.image.rotateWithOffset(input, angle, 0, faceCenterNormalized); // rotateWithOffset is not defined for tfjs-node\n rotationMatrix = util.buildRotationMatrix(-angle, faceCenter);\n if (config.face.mesh.enabled) face = bounding.cutBoxFromImageAndResize({ startPoint: box.startPoint, endPoint: box.endPoint }, rotatedImage, [this.meshSize, this.meshSize]).div(255);\n else face = bounding.cutBoxFromImageAndResize({ startPoint: box.startPoint, endPoint: box.endPoint }, rotatedImage, [this.boxSize, this.boxSize]).div(255);\n } else {\n rotationMatrix = util.IDENTITY_MATRIX;\n const clonedImage = input.clone();\n if (config.face.mesh.enabled) face = bounding.cutBoxFromImageAndResize({ startPoint: box.startPoint, endPoint: box.endPoint }, clonedImage, [this.meshSize, this.meshSize]).div(255);\n else face = bounding.cutBoxFromImageAndResize({ startPoint: box.startPoint, endPoint: box.endPoint }, clonedImage, [this.boxSize, this.boxSize]).div(255);\n }\n\n // if we're not going to produce mesh, don't spend time with further processing\n if (!config.face.mesh.enabled) {\n const prediction = {\n mesh: [],\n box,\n faceConfidence: null,\n boxConfidence: box.confidence,\n confidence: box.confidence,\n image: face,\n };\n return prediction;\n }\n\n const [, confidence, contourCoords] = this.meshDetector.execute(face); // The first returned tensor represents facial contours which are already included in the coordinates.\n const faceConfidence = confidence.dataSync()[0];\n if (faceConfidence < config.face.detector.minConfidence) {\n this.storedBoxes[i].confidence = faceConfidence; // reset confidence of cached box\n return null; // if below confidence just exit\n }\n const coordsReshaped = tf.reshape(contourCoords, [-1, 3]);\n let rawCoords = coordsReshaped.arraySync();\n\n if (config.face.iris.enabled) {\n const { box: leftEyeBox, boxSize: leftEyeBoxSize, crop: leftEyeCrop } = this.getEyeBox(rawCoords, face, eyeLandmarks.leftBounds[0], eyeLandmarks.leftBounds[1], true);\n const { box: rightEyeBox, boxSize: rightEyeBoxSize, crop: rightEyeCrop } = this.getEyeBox(rawCoords, face, eyeLandmarks.rightBounds[0], eyeLandmarks.rightBounds[1]);\n const eyePredictions = this.irisModel.predict(tf.concat([leftEyeCrop, rightEyeCrop]));\n const eyePredictionsData = eyePredictions.dataSync();\n const leftEyeData = eyePredictionsData.slice(0, irisLandmarks.numCoordinates * 3);\n const { rawCoords: leftEyeRawCoords, iris: leftIrisRawCoords } = this.getEyeCoords(leftEyeData, leftEyeBox, leftEyeBoxSize, true);\n const rightEyeData = eyePredictionsData.slice(irisLandmarks.numCoordinates * 3);\n const { rawCoords: rightEyeRawCoords, iris: rightIrisRawCoords } = this.getEyeCoords(rightEyeData, rightEyeBox, rightEyeBoxSize);\n const leftToRightEyeDepthDifference = this.getLeftToRightEyeDepthDifference(rawCoords);\n if (Math.abs(leftToRightEyeDepthDifference) < 30) { // User is looking straight ahead.\n replaceRawCoordinates(rawCoords, leftEyeRawCoords, 'left', null);\n replaceRawCoordinates(rawCoords, rightEyeRawCoords, 'right', null);\n // If the user is looking to the left or to the right, the iris coordinates tend to diverge too much from the mesh coordinates for them to be merged\n // So we only update a single contour line above and below the eye.\n } else if (leftToRightEyeDepthDifference < 1) { // User is looking towards the right.\n replaceRawCoordinates(rawCoords, leftEyeRawCoords, 'left', ['EyeUpper0', 'EyeLower0']);\n } else { // User is looking towards the left.\n replaceRawCoordinates(rawCoords, rightEyeRawCoords, 'right', ['EyeUpper0', 'EyeLower0']);\n }\n const adjustedLeftIrisCoords = this.getAdjustedIrisCoords(rawCoords, leftIrisRawCoords, 'left');\n const adjustedRightIrisCoords = this.getAdjustedIrisCoords(rawCoords, rightIrisRawCoords, 'right');\n rawCoords = rawCoords.concat(adjustedLeftIrisCoords).concat(adjustedRightIrisCoords);\n }\n\n // override box from detection with one calculated from mesh\n const mesh = this.transformRawCoords(rawCoords, box, angle, rotationMatrix);\n const storeConfidence = box.confidence;\n box = bounding.enlargeBox(bounding.calculateLandmarksBoundingBox(mesh), 1.5); // redefine box with mesh calculated one\n box.confidence = storeConfidence;\n\n // do rotation one more time with mesh keypoints if we want to return perfect image\n if (config.face.detector.rotation && config.face.mesh.enabled && config.face.description.enabled && tf.ENV.flags.IS_BROWSER) {\n const [indexOfMouth, indexOfForehead] = (box.landmarks.length >= meshLandmarks.count) ? meshLandmarks.symmetryLine : blazeFaceLandmarks.symmetryLine;\n angle = util.computeRotation(box.landmarks[indexOfMouth], box.landmarks[indexOfForehead]);\n const faceCenter = bounding.getBoxCenter({ startPoint: box.startPoint, endPoint: box.endPoint });\n const faceCenterNormalized = [faceCenter[0] / input.shape[2], faceCenter[1] / input.shape[1]];\n const rotatedImage = tf.image.rotateWithOffset(input.toFloat(), angle, 0, faceCenterNormalized); // rotateWithOffset is not defined for tfjs-node\n rotationMatrix = util.buildRotationMatrix(-angle, faceCenter);\n face = bounding.cutBoxFromImageAndResize({ startPoint: box.startPoint, endPoint: box.endPoint }, rotatedImage, [this.meshSize, this.meshSize]).div(255);\n }\n\n const prediction = {\n mesh,\n box,\n faceConfidence,\n boxConfidence: box.confidence,\n image: face,\n };\n\n // updated stored cache values\n const storedBox = bounding.squarifyBox(box);\n // @ts-ignore box itself doesn't have those properties, but we stored them for future use\n storedBox.confidence = box.confidence;\n // @ts-ignore box itself doesn't have those properties, but we stored them for future use\n storedBox.faceConfidence = faceConfidence;\n // this.storedBoxes[i] = { ...squarifiedLandmarksBox, confidence: box.confidence, faceConfidence };\n this.storedBoxes[i] = storedBox;\n\n return prediction;\n }));\n\n // results = results.filter((a) => a !== null);\n // remove cache entries for detected boxes on low confidence\n if (config.face.mesh.enabled) this.storedBoxes = this.storedBoxes.filter((a) => a.confidence > config.face.detector.minConfidence);\n this.detectedFaces = results.length;\n\n return results;\n }\n}\n", "import { log, join } from '../helpers';\nimport * as tf from '../../dist/tfjs.esm.js';\n\nconst annotations = ['angry', 'disgust', 'fear', 'happy', 'sad', 'surprise', 'neutral'];\nlet model;\nlet last: Array<{ score: number, emotion: string }> = [];\nlet skipped = Number.MAX_SAFE_INTEGER;\n\n// tuning values\nconst rgb = [0.2989, 0.5870, 0.1140]; // factors for red/green/blue colors when converting to grayscale\n\nexport async function load(config) {\n if (!model) {\n model = await tf.loadGraphModel(join(config.modelBasePath, config.face.emotion.modelPath));\n if (!model || !model.modelUrl) log('load model failed:', config.face.emotion.modelPath);\n else if (config.debug) log('load model:', model.modelUrl);\n } else if (config.debug) log('cached model:', model.modelUrl);\n return model;\n}\n\nexport async function predict(image, config) {\n if (!model) return null;\n if ((skipped < config.face.emotion.skipFrames) && config.videoOptimized && (last.length > 0)) {\n skipped++;\n return last;\n }\n if (config.videoOptimized) skipped = 0;\n else skipped = Number.MAX_SAFE_INTEGER;\n return new Promise(async (resolve) => {\n const resize = tf.image.resizeBilinear(image, [model.inputs[0].shape[2], model.inputs[0].shape[1]], false);\n const [red, green, blue] = tf.split(resize, 3, 3);\n resize.dispose();\n // weighted rgb to grayscale: https://www.mathworks.com/help/matlab/ref/rgb2gray.html\n const redNorm = tf.mul(red, rgb[0]);\n const greenNorm = tf.mul(green, rgb[1]);\n const blueNorm = tf.mul(blue, rgb[2]);\n red.dispose();\n green.dispose();\n blue.dispose();\n const grayscale = tf.addN([redNorm, greenNorm, blueNorm]);\n redNorm.dispose();\n greenNorm.dispose();\n blueNorm.dispose();\n const normalize = tf.tidy(() => grayscale.sub(0.5).mul(2));\n grayscale.dispose();\n const obj: Array<{ score: number, emotion: string }> = [];\n if (config.face.emotion.enabled) {\n const emotionT = await model.predict(normalize); // result is already in range 0..1, no need for additional activation\n const data = emotionT.dataSync();\n tf.dispose(emotionT);\n for (let i = 0; i < data.length; i++) {\n if (data[i] > config.face.emotion.minConfidence) obj.push({ score: Math.min(0.99, Math.trunc(100 * data[i]) / 100), emotion: annotations[i] });\n }\n obj.sort((a, b) => b.score - a.score);\n }\n normalize.dispose();\n last = obj;\n resolve(obj);\n });\n}\n", "import { log, join } from '../helpers';\nimport * as tf from '../../dist/tfjs.esm.js';\n\nlet model;\nlet last = { age: 0 };\nlet skipped = Number.MAX_SAFE_INTEGER;\n\ntype Tensor = typeof tf.Tensor;\ntype DB = Array<{ name: string, source: string, embedding: number[] }>;\n\nexport async function load(config) {\n if (!model) {\n model = await tf.loadGraphModel(join(config.modelBasePath, config.face.description.modelPath));\n if (!model || !model.modelUrl) log('load model failed:', config.face.description.modelPath);\n else if (config.debug) log('load model:', model.modelUrl);\n } else if (config.debug) log('cached model:', model.modelUrl);\n return model;\n}\n\nexport function similarity(embedding1, embedding2, order = 2): number {\n if (!embedding1 || !embedding2) return 0;\n if (embedding1?.length === 0 || embedding2?.length === 0) return 0;\n if (embedding1?.length !== embedding2?.length) return 0;\n // general minkowski distance, euclidean distance is limited case where order is 2\n const distance = 5.0 * embedding1\n .map((val, i) => (Math.abs(embedding1[i] - embedding2[i]) ** order)) // distance squared\n .reduce((sum, now) => (sum + now), 0) // sum all distances\n ** (1 / order); // get root of\n const res = Math.max(0, 100 - distance) / 100.0;\n return res;\n}\n\nexport function match(embedding: Array, db: DB, threshold = 0) {\n let best = { similarity: 0, name: '', source: '', embedding: [] as number[] };\n if (!embedding || !db || !Array.isArray(embedding) || !Array.isArray(db)) return best;\n for (const f of db) {\n if (f.embedding && f.name) {\n const perc = similarity(embedding, f.embedding);\n if (perc > threshold && perc > best.similarity) best = { ...f, similarity: perc };\n }\n }\n return best;\n}\n\nexport function enhance(input): Tensor {\n const image = tf.tidy(() => {\n // input received from detector is already normalized to 0..1\n // input is also assumed to be straightened\n const tensor = input.image || input.tensor || input;\n if (!(tensor instanceof tf.Tensor)) return null;\n // do a tight crop of image and resize it to fit the model\n const box = [[0.05, 0.15, 0.85, 0.85]]; // empyrical values for top, left, bottom, right\n // const box = [[0.0, 0.0, 1.0, 1.0]]; // basically no crop for test\n const crop = (tensor.shape.length === 3)\n ? tf.image.cropAndResize(tf.expandDims(tensor, 0), box, [0], [model.inputs[0].shape[2], model.inputs[0].shape[1]]) // add batch dimension if missing\n : tf.image.cropAndResize(tensor, box, [0], [model.inputs[0].shape[2], model.inputs[0].shape[1]]);\n // const crop = tf.image.resizeBilinear(tensor, [model.inputs[0].shape[2], model.inputs[0].shape[1]], false); // just resize to fit the embedding model\n\n /*\n // convert to black&white to avoid colorization impact\n const rgb = [0.2989, 0.5870, 0.1140]; // factors for red/green/blue colors when converting to grayscale: https://www.mathworks.com/help/matlab/ref/rgb2gray.html\n const [red, green, blue] = tf.split(crop, 3, 3);\n const redNorm = tf.mul(red, rgb[0]);\n const greenNorm = tf.mul(green, rgb[1]);\n const blueNorm = tf.mul(blue, rgb[2]);\n const grayscale = tf.addN([redNorm, greenNorm, blueNorm]);\n const merge = tf.stack([grayscale, grayscale, grayscale], 3).squeeze(4);\n */\n\n /*\n // optional increase image contrast\n // or do it per-channel so mean is done on each channel\n // or do it based on histogram\n const mean = merge.mean();\n const factor = 5;\n const contrast = merge.sub(mean).mul(factor).add(mean);\n */\n\n /*\n // normalize brightness from 0..1\n const darken = crop.sub(crop.min());\n const lighten = darken.div(darken.max());\n */\n\n const norm = crop.mul(255);\n\n return norm;\n });\n return image;\n}\n\nexport async function predict(image, config) {\n if (!model) return null;\n if ((skipped < config.face.description.skipFrames) && config.videoOptimized && last.age && (last.age > 0)) {\n skipped++;\n return last;\n }\n if (config.videoOptimized) skipped = 0;\n else skipped = Number.MAX_SAFE_INTEGER;\n return new Promise(async (resolve) => {\n const enhanced = enhance(image);\n\n let resT;\n const obj = {\n age: 0,\n gender: 'unknown',\n genderConfidence: 0,\n descriptor: [] };\n\n if (config.face.description.enabled) resT = await model.predict(enhanced);\n tf.dispose(enhanced);\n\n if (resT) {\n tf.tidy(() => {\n const gender = resT.find((t) => t.shape[1] === 1).dataSync();\n const confidence = Math.trunc(200 * Math.abs((gender[0] - 0.5))) / 100;\n if (confidence > config.face.description.minConfidence) {\n obj.gender = gender[0] <= 0.5 ? 'female' : 'male';\n obj.genderConfidence = Math.min(0.99, confidence);\n }\n const age = resT.find((t) => t.shape[1] === 100).argMax(1).dataSync()[0];\n const all = resT.find((t) => t.shape[1] === 100).dataSync();\n obj.age = Math.round(all[age - 1] > all[age + 1] ? 10 * age - 100 * all[age - 1] : 10 * age + 100 * all[age + 1]) / 10;\n\n const desc = resT.find((t) => t.shape[1] === 1024);\n // const reshape = desc.reshape([128, 8]);\n // const reduce = reshape.logSumExp(1); // reduce 2nd dimension by calculating logSumExp on it\n\n obj.descriptor = [...desc.dataSync()];\n });\n resT.forEach((t) => tf.dispose(t));\n }\n\n last = obj;\n resolve(obj);\n });\n}\n", "import { log, now } from './helpers';\nimport * as tf from '../dist/tfjs.esm.js';\nimport * as facemesh from './blazeface/facemesh';\nimport * as emotion from './emotion/emotion';\nimport * as faceres from './faceres/faceres';\n\ntype Tensor = typeof tf.Tensor;\n\nconst calculateFaceAngle = (face, image_size): { angle: { pitch: number, yaw: number, roll: number }, matrix: [number, number, number, number, number, number, number, number, number] } => {\n // eslint-disable-next-line no-unused-vars, @typescript-eslint/no-unused-vars\n const degrees = (theta) => (theta * 180) / Math.PI;\n // const degrees = (theta) => Math.abs(((theta * 180) / Math.PI) % 360);\n const normalize = (v) => { // normalize vector\n const length = Math.sqrt(v[0] * v[0] + v[1] * v[1] + v[2] * v[2]);\n v[0] /= length;\n v[1] /= length;\n v[2] /= length;\n return v;\n };\n const subVectors = (a, b) => { // vector subtraction (a - b)\n const x = a[0] - b[0];\n const y = a[1] - b[1];\n const z = a[2] - b[2];\n return [x, y, z];\n };\n const crossVectors = (a, b) => { // vector cross product (a x b)\n const x = a[1] * b[2] - a[2] * b[1];\n const y = a[2] * b[0] - a[0] * b[2];\n const z = a[0] * b[1] - a[1] * b[0];\n return [x, y, z];\n };\n // 3x3 rotation matrix to Euler angles based on https://www.geometrictools.com/Documentation/EulerAngles.pdf\n const rotationMatrixToEulerAngle = (r) => {\n // eslint-disable-next-line no-unused-vars, @typescript-eslint/no-unused-vars\n const [r00, r01, r02, r10, r11, r12, r20, r21, r22] = r;\n let thetaX; let thetaY; let thetaZ;\n if (r10 < 1) { // YZX calculation\n if (r10 > -1) {\n thetaZ = Math.asin(r10);\n thetaY = Math.atan2(-r20, r00);\n thetaX = Math.atan2(-r12, r11);\n } else {\n thetaZ = -Math.PI / 2;\n thetaY = -Math.atan2(r21, r22);\n thetaX = 0;\n }\n } else {\n thetaZ = Math.PI / 2;\n thetaY = Math.atan2(r21, r22);\n thetaX = 0;\n }\n return { pitch: 2 * -thetaX, yaw: 2 * -thetaY, roll: 2 * -thetaZ };\n };\n // simple Euler angle calculation based existing 3D mesh\n // eslint-disable-next-line no-unused-vars, @typescript-eslint/no-unused-vars\n const meshToEulerAngle = (mesh) => {\n const radians = (a1, a2, b1, b2) => Math.atan2(b2 - a2, b1 - a1);\n // eslint-disable-next-line no-unused-vars, @typescript-eslint/no-unused-vars\n const angle = {\n // values are in radians in range of -pi/2 to pi/2 which is -90 to +90 degrees\n // value of 0 means center\n // pitch is face move up/down\n pitch: radians(mesh[10][1], mesh[10][2], mesh[152][1], mesh[152][2]), // looking at y,z of top and bottom points of the face\n // yaw is face turn left/right\n yaw: radians(mesh[33][0], mesh[33][2], mesh[263][0], mesh[263][2]), // looking at x,z of outside corners of leftEye and rightEye\n // roll is face lean left/right\n roll: radians(mesh[33][0], mesh[33][1], mesh[263][0], mesh[263][1]), // looking at x,y of outside corners of leftEye and rightEye\n };\n return angle;\n };\n\n const mesh = face.meshRaw;\n if (!mesh || mesh.length < 300) return { angle: { pitch: 0, yaw: 0, roll: 0 }, matrix: [1, 0, 0, 0, 1, 0, 0, 0, 1] };\n\n const size = Math.max(face.boxRaw[2] * image_size[0], face.boxRaw[3] * image_size[1]) / 1.5;\n // top, bottom, left, right\n const pts = [mesh[10], mesh[152], mesh[234], mesh[454]].map((pt) => [\n // make the xyz coordinates proportional, independent of the image/box size\n pt[0] * image_size[0] / size,\n pt[1] * image_size[1] / size,\n pt[2],\n ]);\n\n const y_axis = normalize(subVectors(pts[1], pts[0]));\n let x_axis = normalize(subVectors(pts[3], pts[2]));\n const z_axis = normalize(crossVectors(x_axis, y_axis));\n // adjust x_axis to make sure that all axes are perpendicular to each other\n x_axis = crossVectors(y_axis, z_axis);\n\n // Rotation Matrix from Axis Vectors - http://renderdan.blogspot.com/2006/05/rotation-matrix-from-axis-vectors.html\n // 3x3 rotation matrix is flatten to array in row-major order. Note that the rotation represented by this matrix is inverted.\n const matrix: [number, number, number, number, number, number, number, number, number] = [\n x_axis[0], x_axis[1], x_axis[2],\n y_axis[0], y_axis[1], y_axis[2],\n z_axis[0], z_axis[1], z_axis[2],\n ];\n const angle = rotationMatrixToEulerAngle(matrix);\n // const angle = meshToEulerAngle(mesh);\n return { angle, matrix };\n};\n\nexport const detectFace = async (parent, input): Promise => {\n // run facemesh, includes blazeface and iris\n // eslint-disable-next-line no-async-promise-executor\n let timeStamp;\n let ageRes;\n let genderRes;\n let emotionRes;\n let embeddingRes;\n let descRes;\n const faceRes: Array<{\n confidence: number,\n boxConfidence: number,\n faceConfidence: number,\n box: [number, number, number, number],\n mesh: Array<[number, number, number]>\n meshRaw: Array<[number, number, number]>\n boxRaw: [number, number, number, number],\n annotations: Array<{ part: string, points: Array<[number, number, number]>[] }>,\n age: number,\n gender: string,\n genderConfidence: number,\n emotion: string,\n embedding: number[],\n iris: number,\n rotation: {\n angle: { pitch: number, yaw: number, roll: number },\n matrix: [number, number, number, number, number, number, number, number, number]\n },\n tensor: Tensor,\n }> = [];\n parent.state = 'run:face';\n timeStamp = now();\n const faces = await facemesh.predict(input, parent.config);\n parent.perf.face = Math.trunc(now() - timeStamp);\n if (!faces) return [];\n for (const face of faces) {\n parent.analyze('Get Face');\n\n // is something went wrong, skip the face\n if (!face.image || face.image.isDisposedInternal) {\n log('Face object is disposed:', face.image);\n continue;\n }\n\n const rotation = calculateFaceAngle(face, [input.shape[2], input.shape[1]]);\n\n // run emotion, inherits face from blazeface\n parent.analyze('Start Emotion:');\n if (parent.config.async) {\n emotionRes = parent.config.face.emotion.enabled ? emotion.predict(face.image, parent.config) : {};\n } else {\n parent.state = 'run:emotion';\n timeStamp = now();\n emotionRes = parent.config.face.emotion.enabled ? await emotion.predict(face.image, parent.config) : {};\n parent.perf.emotion = Math.trunc(now() - timeStamp);\n }\n parent.analyze('End Emotion:');\n\n // run emotion, inherits face from blazeface\n parent.analyze('Start Description:');\n if (parent.config.async) {\n descRes = parent.config.face.description.enabled ? faceres.predict(face, parent.config) : [];\n } else {\n parent.state = 'run:description';\n timeStamp = now();\n descRes = parent.config.face.description.enabled ? await faceres.predict(face.image, parent.config) : [];\n parent.perf.embedding = Math.trunc(now() - timeStamp);\n }\n parent.analyze('End Description:');\n\n // if async wait for results\n if (parent.config.async) {\n [ageRes, genderRes, emotionRes, embeddingRes, descRes] = await Promise.all([ageRes, genderRes, emotionRes, embeddingRes, descRes]);\n }\n\n parent.analyze('Finish Face:');\n\n // calculate iris distance\n // iris: array[ center, left, top, right, bottom]\n if (!parent.config.face.iris.enabled && face?.annotations?.leftEyeIris && face?.annotations?.rightEyeIris) {\n delete face.annotations.leftEyeIris;\n delete face.annotations.rightEyeIris;\n }\n const irisSize = (face.annotations?.leftEyeIris && face.annotations?.rightEyeIris)\n /* average human iris size is 11.7mm */\n ? 11.7 * Math.max(Math.abs(face.annotations.leftEyeIris[3][0] - face.annotations.leftEyeIris[1][0]), Math.abs(face.annotations.rightEyeIris[4][1] - face.annotations.rightEyeIris[2][1]))\n : 0;\n\n // combine results\n faceRes.push({\n ...face,\n age: descRes.age,\n gender: descRes.gender,\n genderConfidence: descRes.genderConfidence,\n embedding: descRes.descriptor,\n emotion: emotionRes,\n iris: (irisSize !== 0) ? Math.trunc(irisSize) / 100 : 0,\n rotation,\n tensor: parent.config.face.detector.return ? face.image?.squeeze() : null,\n });\n // dispose original face tensor\n face.image?.dispose();\n\n parent.analyze('End Face');\n }\n parent.analyze('End FaceMesh:');\n if (parent.config.async) {\n if (parent.perf.face) delete parent.perf.face;\n if (parent.perf.age) delete parent.perf.age;\n if (parent.perf.gender) delete parent.perf.gender;\n if (parent.perf.emotion) delete parent.perf.emotion;\n }\n return faceRes;\n};\n", "import { log, join } from '../helpers';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as poses from './poses';\nimport * as util from './utils';\n\nlet model;\nconst poseNetOutputs = ['MobilenetV1/offset_2/BiasAdd'/* offsets */, 'MobilenetV1/heatmap_2/BiasAdd'/* heatmapScores */, 'MobilenetV1/displacement_fwd_2/BiasAdd'/* displacementFwd */, 'MobilenetV1/displacement_bwd_2/BiasAdd'/* displacementBwd */];\n\nexport async function predict(input, config) {\n const res = tf.tidy(() => {\n const resized = input.resizeBilinear([model.inputs[0].shape[2], model.inputs[0].shape[1]]);\n const normalized = resized.toFloat().div(127.5).sub(1.0);\n const results = model.execute(normalized, poseNetOutputs);\n const results3d = results.map((y) => y.squeeze([0]));\n results3d[1] = results3d[1].sigmoid(); // apply sigmoid on scores\n return results3d;\n });\n\n const buffers = await Promise.all(res.map((tensor) => tensor.buffer()));\n for (const t of res) t.dispose();\n\n const decoded = await poses.decode(buffers[0], buffers[1], buffers[2], buffers[3], config.body.maxDetected, config.body.minConfidence);\n const scaled = util.scalePoses(decoded, [input.shape[1], input.shape[2]], [model.inputs[0].shape[2], model.inputs[0].shape[1]]);\n return scaled;\n}\n\nexport async function load(config) {\n if (!model) {\n model = await tf.loadGraphModel(join(config.modelBasePath, config.body.modelPath));\n if (!model || !model.modelUrl) log('load model failed:', config.body.modelPath);\n else if (config.debug) log('load model:', model.modelUrl);\n } else if (config.debug) log('cached model:', model.modelUrl);\n return model;\n}\n", "export const partNames = [\n 'nose', 'leftEye', 'rightEye', 'leftEar', 'rightEar', 'leftShoulder',\n 'rightShoulder', 'leftElbow', 'rightElbow', 'leftWrist', 'rightWrist',\n 'leftHip', 'rightHip', 'leftKnee', 'rightKnee', 'leftAnkle', 'rightAnkle',\n];\n\nexport const count = partNames.length; // 17 keypoints\n\nexport const partIds = partNames.reduce((result, jointName, i) => {\n result[jointName] = i;\n return result;\n}, {});\n\nconst connectedPartNames = [\n ['leftHip', 'leftShoulder'], ['leftElbow', 'leftShoulder'],\n ['leftElbow', 'leftWrist'], ['leftHip', 'leftKnee'],\n ['leftKnee', 'leftAnkle'], ['rightHip', 'rightShoulder'],\n ['rightElbow', 'rightShoulder'], ['rightElbow', 'rightWrist'],\n ['rightHip', 'rightKnee'], ['rightKnee', 'rightAnkle'],\n ['leftShoulder', 'rightShoulder'], ['leftHip', 'rightHip'],\n];\nexport const connectedPartIndices = connectedPartNames.map(([jointNameA, jointNameB]) => ([partIds[jointNameA], partIds[jointNameB]]));\n\nexport const poseChain = [\n ['nose', 'leftEye'], ['leftEye', 'leftEar'], ['nose', 'rightEye'],\n ['rightEye', 'rightEar'], ['nose', 'leftShoulder'],\n ['leftShoulder', 'leftElbow'], ['leftElbow', 'leftWrist'],\n ['leftShoulder', 'leftHip'], ['leftHip', 'leftKnee'],\n ['leftKnee', 'leftAnkle'], ['nose', 'rightShoulder'],\n ['rightShoulder', 'rightElbow'], ['rightElbow', 'rightWrist'],\n ['rightShoulder', 'rightHip'], ['rightHip', 'rightKnee'],\n ['rightKnee', 'rightAnkle'],\n];\n", "import * as kpt from './keypoints';\n\nexport function eitherPointDoesntMeetConfidence(a, b, minConfidence) {\n return (a < minConfidence || b < minConfidence);\n}\n\nexport function getAdjacentKeyPoints(keypoints, minConfidence) {\n return kpt.connectedPartIndices.reduce((result, [leftJoint, rightJoint]) => {\n if (eitherPointDoesntMeetConfidence(keypoints[leftJoint].score, keypoints[rightJoint].score, minConfidence)) {\n return result;\n }\n result.push([keypoints[leftJoint], keypoints[rightJoint]]);\n return result;\n }, []);\n}\n\nexport function getBoundingBox(keypoints) {\n const coord = keypoints.reduce(({ maxX, maxY, minX, minY }, { position: { x, y } }) => ({\n maxX: Math.max(maxX, x),\n maxY: Math.max(maxY, y),\n minX: Math.min(minX, x),\n minY: Math.min(minY, y),\n }), {\n maxX: Number.NEGATIVE_INFINITY,\n maxY: Number.NEGATIVE_INFINITY,\n minX: Number.POSITIVE_INFINITY,\n minY: Number.POSITIVE_INFINITY,\n });\n return [coord.minX, coord.minY, coord.maxX - coord.minX, coord.maxY - coord.minY];\n}\n\nexport function scalePoses(poses, [height, width], [inputResolutionHeight, inputResolutionWidth]) {\n const scalePose = (pose, scaleY, scaleX) => ({\n score: pose.score,\n box: [Math.trunc(pose.box[0] * scaleX), Math.trunc(pose.box[1] * scaleY), Math.trunc(pose.box[2] * scaleX), Math.trunc(pose.box[3] * scaleY)],\n keypoints: pose.keypoints.map(({ score, part, position }) => ({\n score,\n part,\n position: { x: Math.trunc(position.x * scaleX), y: Math.trunc(position.y * scaleY) },\n })),\n });\n\n const scaledPoses = poses.map((pose) => scalePose(pose, height / inputResolutionHeight, width / inputResolutionWidth));\n return scaledPoses;\n}\n\n// algorithm based on Coursera Lecture from Algorithms, Part 1: https://www.coursera.org/learn/algorithms-part1/lecture/ZjoSM/heapsort\nexport class MaxHeap {\n priorityQueue: any;\n numberOfElements: number;\n getElementValue: any;\n\n constructor(maxSize, getElementValue) {\n this.priorityQueue = new Array(maxSize);\n this.numberOfElements = -1;\n this.getElementValue = getElementValue;\n }\n\n enqueue(x) {\n this.priorityQueue[++this.numberOfElements] = x;\n this.swim(this.numberOfElements);\n }\n\n dequeue() {\n const max = this.priorityQueue[0];\n this.exchange(0, this.numberOfElements--);\n this.sink(0);\n this.priorityQueue[this.numberOfElements + 1] = null;\n return max;\n }\n\n empty() { return this.numberOfElements === -1; }\n\n size() { return this.numberOfElements + 1; }\n\n all() { return this.priorityQueue.slice(0, this.numberOfElements + 1); }\n\n max() { return this.priorityQueue[0]; }\n\n swim(k) {\n while (k > 0 && this.less(Math.floor(k / 2), k)) {\n this.exchange(k, Math.floor(k / 2));\n k = Math.floor(k / 2);\n }\n }\n\n sink(k) {\n while (2 * k <= this.numberOfElements) {\n let j = 2 * k;\n if (j < this.numberOfElements && this.less(j, j + 1)) j++;\n if (!this.less(k, j)) break;\n this.exchange(k, j);\n k = j;\n }\n }\n\n getValueAt(i) {\n return this.getElementValue(this.priorityQueue[i]);\n }\n\n less(i, j) {\n return this.getValueAt(i) < this.getValueAt(j);\n }\n\n exchange(i, j) {\n const t = this.priorityQueue[i];\n this.priorityQueue[i] = this.priorityQueue[j];\n this.priorityQueue[j] = t;\n }\n}\n\nexport function getOffsetPoint(y, x, keypoint, offsets) {\n return {\n y: offsets.get(y, x, keypoint),\n x: offsets.get(y, x, keypoint + kpt.count),\n };\n}\n\nexport function getImageCoords(part, outputStride, offsets) {\n const { heatmapY, heatmapX, id: keypoint } = part;\n const { y, x } = getOffsetPoint(heatmapY, heatmapX, keypoint, offsets);\n return {\n x: part.heatmapX * outputStride + x,\n y: part.heatmapY * outputStride + y,\n };\n}\n\nexport function fillArray(element, size) {\n const result = new Array(size);\n for (let i = 0; i < size; i++) {\n result[i] = element;\n }\n return result;\n}\n\nexport function clamp(a, min, max) {\n if (a < min) return min;\n if (a > max) return max;\n return a;\n}\n\nexport function squaredDistance(y1, x1, y2, x2) {\n const dy = y2 - y1;\n const dx = x2 - x1;\n return dy * dy + dx * dx;\n}\n\nexport function addVectors(a, b) {\n return { x: a.x + b.x, y: a.y + b.y };\n}\n\nexport function clampVector(a, min, max) {\n return { y: clamp(a.y, min, max), x: clamp(a.x, min, max) };\n}\n", "import * as utils from './utils';\nimport * as kpt from './keypoints';\n\nconst localMaximumRadius = 1;\nconst outputStride = 16;\nconst squaredNmsRadius = 50 ** 2;\n\nfunction traverseToTargetKeypoint(edgeId, sourceKeypoint, targetKeypointId, scoresBuffer, offsets, displacements, offsetRefineStep = 2) {\n const getDisplacement = (point) => ({\n y: displacements.get(point.y, point.x, edgeId),\n x: displacements.get(point.y, point.x, (displacements.shape[2] / 2) + edgeId),\n });\n const getStridedIndexNearPoint = (point, height, width) => ({\n y: utils.clamp(Math.round(point.y / outputStride), 0, height - 1),\n x: utils.clamp(Math.round(point.x / outputStride), 0, width - 1),\n });\n\n const [height, width] = scoresBuffer.shape;\n // Nearest neighbor interpolation for the source->target displacements.\n const sourceKeypointIndices = getStridedIndexNearPoint(sourceKeypoint.position, height, width);\n const displacement = getDisplacement(sourceKeypointIndices);\n const displacedPoint = utils.addVectors(sourceKeypoint.position, displacement);\n let targetKeypoint = displacedPoint;\n for (let i = 0; i < offsetRefineStep; i++) {\n const targetKeypointIndices = getStridedIndexNearPoint(targetKeypoint, height, width);\n const offsetPoint = utils.getOffsetPoint(targetKeypointIndices.y, targetKeypointIndices.x, targetKeypointId, offsets);\n targetKeypoint = utils.addVectors({\n x: targetKeypointIndices.x * outputStride,\n y: targetKeypointIndices.y * outputStride,\n }, { x: offsetPoint.x, y: offsetPoint.y });\n }\n const targetKeyPointIndices = getStridedIndexNearPoint(targetKeypoint, height, width);\n const score = scoresBuffer.get(targetKeyPointIndices.y, targetKeyPointIndices.x, targetKeypointId);\n return { position: targetKeypoint, part: kpt.partNames[targetKeypointId], score };\n}\n\nexport function decodePose(root, scores, offsets, displacementsFwd, displacementsBwd) {\n const parentChildrenTuples = kpt.poseChain.map(([parentJoinName, childJoinName]) => ([kpt.partIds[parentJoinName], kpt.partIds[childJoinName]]));\n const parentToChildEdges = parentChildrenTuples.map(([, childJointId]) => childJointId);\n const childToParentEdges = parentChildrenTuples.map(([parentJointId]) => parentJointId);\n const numParts = scores.shape[2]; // [21,21,17]\n const numEdges = parentToChildEdges.length;\n const instanceKeypoints = new Array(numParts);\n // Start a new detection instance at the position of the root.\n // const { part: rootPart, score: rootScore } = root;\n const rootPoint = utils.getImageCoords(root.part, outputStride, offsets);\n instanceKeypoints[root.part.id] = {\n score: root.score,\n part: kpt.partNames[root.part.id],\n position: rootPoint,\n };\n // Decode the part positions upwards in the tree, following the backward displacements.\n for (let edge = numEdges - 1; edge >= 0; --edge) {\n const sourceKeypointId = parentToChildEdges[edge];\n const targetKeypointId = childToParentEdges[edge];\n if (instanceKeypoints[sourceKeypointId] && !instanceKeypoints[targetKeypointId]) {\n instanceKeypoints[targetKeypointId] = traverseToTargetKeypoint(edge, instanceKeypoints[sourceKeypointId], targetKeypointId, scores, offsets, displacementsBwd);\n }\n }\n // Decode the part positions downwards in the tree, following the forward displacements.\n for (let edge = 0; edge < numEdges; ++edge) {\n const sourceKeypointId = childToParentEdges[edge];\n const targetKeypointId = parentToChildEdges[edge];\n if (instanceKeypoints[sourceKeypointId] && !instanceKeypoints[targetKeypointId]) {\n instanceKeypoints[targetKeypointId] = traverseToTargetKeypoint(edge, instanceKeypoints[sourceKeypointId], targetKeypointId, scores, offsets, displacementsFwd);\n }\n }\n return instanceKeypoints;\n}\n\nfunction scoreIsMaximumInLocalWindow(keypointId, score, heatmapY, heatmapX, scores) {\n const [height, width] = scores.shape;\n let localMaximum = true;\n const yStart = Math.max(heatmapY - localMaximumRadius, 0);\n const yEnd = Math.min(heatmapY + localMaximumRadius + 1, height);\n for (let yCurrent = yStart; yCurrent < yEnd; ++yCurrent) {\n const xStart = Math.max(heatmapX - localMaximumRadius, 0);\n const xEnd = Math.min(heatmapX + localMaximumRadius + 1, width);\n for (let xCurrent = xStart; xCurrent < xEnd; ++xCurrent) {\n if (scores.get(yCurrent, xCurrent, keypointId) > score) {\n localMaximum = false;\n break;\n }\n }\n if (!localMaximum) break;\n }\n return localMaximum;\n}\n\nexport function buildPartWithScoreQueue(minConfidence, scores) {\n const [height, width, numKeypoints] = scores.shape;\n const queue = new utils.MaxHeap(height * width * numKeypoints, ({ score }) => score);\n for (let heatmapY = 0; heatmapY < height; ++heatmapY) {\n for (let heatmapX = 0; heatmapX < width; ++heatmapX) {\n for (let keypointId = 0; keypointId < numKeypoints; ++keypointId) {\n const score = scores.get(heatmapY, heatmapX, keypointId);\n // Only consider parts with score greater or equal to threshold as root candidates.\n if (score < minConfidence) continue;\n // Only consider keypoints whose score is maximum in a local window.\n if (scoreIsMaximumInLocalWindow(keypointId, score, heatmapY, heatmapX, scores)) queue.enqueue({ score, part: { heatmapY, heatmapX, id: keypointId } });\n }\n }\n }\n return queue;\n}\n\nfunction withinRadius(poses, { x, y }, keypointId) {\n return poses.some(({ keypoints }) => {\n const correspondingKeypoint = keypoints[keypointId].position;\n return utils.squaredDistance(y, x, correspondingKeypoint.y, correspondingKeypoint.x) <= squaredNmsRadius;\n });\n}\n\nfunction getInstanceScore(existingPoses, instanceKeypoints) {\n const notOverlappedKeypointScores = instanceKeypoints.reduce((result, { position, score }, keypointId) => {\n if (!withinRadius(existingPoses, position, keypointId)) result += score;\n return result;\n }, 0.0);\n return notOverlappedKeypointScores / instanceKeypoints.length;\n}\n\nexport function decode(offsetsBuffer, scoresBuffer, displacementsFwdBuffer, displacementsBwdBuffer, maxDetected, minConfidence) {\n const poses: Array<{ keypoints: any, box: any, score: number }> = [];\n const queue = buildPartWithScoreQueue(minConfidence, scoresBuffer);\n // Generate at most maxDetected object instances per image in decreasing root part score order.\n while (poses.length < maxDetected && !queue.empty()) {\n // The top element in the queue is the next root candidate.\n const root = queue.dequeue();\n // Part-based non-maximum suppression: We reject a root candidate if it is within a disk of `nmsRadius` pixels from the corresponding part of a previously detected instance.\n const rootImageCoords = utils.getImageCoords(root.part, outputStride, offsetsBuffer);\n if (withinRadius(poses, rootImageCoords, root.part.id)) continue;\n // Else start a new detection instance at the position of the root.\n let keypoints = decodePose(root, scoresBuffer, offsetsBuffer, displacementsFwdBuffer, displacementsBwdBuffer);\n keypoints = keypoints.filter((a) => a.score > minConfidence);\n const score = getInstanceScore(poses, keypoints);\n const box = utils.getBoundingBox(keypoints);\n if (score > minConfidence) poses.push({ keypoints, box, score: Math.round(100 * score) / 100 });\n }\n return poses;\n}\n", "import { log, join } from '../helpers';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as handdetector from './handdetector';\nimport * as handpipeline from './handpipeline';\n\nconst meshAnnotations = {\n thumb: [1, 2, 3, 4],\n indexFinger: [5, 6, 7, 8],\n middleFinger: [9, 10, 11, 12],\n ringFinger: [13, 14, 15, 16],\n pinky: [17, 18, 19, 20],\n palmBase: [0],\n};\n\nlet handDetectorModel;\nlet handPoseModel;\nlet handPipeline;\n\nexport async function predict(input, config) {\n const predictions = await handPipeline.estimateHands(input, config);\n if (!predictions) return [];\n const hands: Array<{ confidence: number, box: any, boxRaw: any, landmarks: any, annotations: any }> = [];\n for (const prediction of predictions) {\n const annotations = {};\n if (prediction.landmarks) {\n for (const key of Object.keys(meshAnnotations)) {\n annotations[key] = meshAnnotations[key].map((index) => prediction.landmarks[index]);\n }\n }\n const box = prediction.box ? [\n Math.max(0, prediction.box.topLeft[0]),\n Math.max(0, prediction.box.topLeft[1]),\n Math.min(input.shape[2], prediction.box.bottomRight[0]) - Math.max(0, prediction.box.topLeft[0]),\n Math.min(input.shape[1], prediction.box.bottomRight[1]) - Math.max(0, prediction.box.topLeft[1]),\n ] : [];\n const boxRaw = [\n (prediction.box.topLeft[0]) / input.shape[2],\n (prediction.box.topLeft[1]) / input.shape[1],\n (prediction.box.bottomRight[0] - prediction.box.topLeft[0]) / input.shape[2],\n (prediction.box.bottomRight[1] - prediction.box.topLeft[1]) / input.shape[1],\n ];\n hands.push({ confidence: Math.round(100 * prediction.confidence) / 100, box, boxRaw, landmarks: prediction.landmarks, annotations });\n }\n return hands;\n}\n\nexport async function load(config): Promise<[Object, Object]> {\n if (!handDetectorModel || !handPoseModel) {\n [handDetectorModel, handPoseModel] = await Promise.all([\n config.hand.enabled ? tf.loadGraphModel(join(config.modelBasePath, config.hand.detector.modelPath), { fromTFHub: config.hand.detector.modelPath.includes('tfhub.dev') }) : null,\n config.hand.landmarks ? tf.loadGraphModel(join(config.modelBasePath, config.hand.skeleton.modelPath), { fromTFHub: config.hand.skeleton.modelPath.includes('tfhub.dev') }) : null,\n ]);\n if (config.hand.enabled) {\n if (!handDetectorModel || !handDetectorModel.modelUrl) log('load model failed:', config.hand.detector.modelPath);\n else if (config.debug) log('load model:', handDetectorModel.modelUrl);\n if (!handPoseModel || !handPoseModel.modelUrl) log('load model failed:', config.hand.skeleton.modelPath);\n else if (config.debug) log('load model:', handPoseModel.modelUrl);\n }\n } else {\n if (config.debug) log('cached model:', handDetectorModel.modelUrl);\n if (config.debug) log('cached model:', handPoseModel.modelUrl);\n }\n const handDetector = new handdetector.HandDetector(handDetectorModel);\n handPipeline = new handpipeline.HandPipeline(handDetector, handPoseModel);\n return [handDetectorModel, handPoseModel];\n}\n", "import * as tf from '../../dist/tfjs.esm.js';\n\nexport function getBoxSize(box) {\n return [\n Math.abs(box.endPoint[0] - box.startPoint[0]),\n Math.abs(box.endPoint[1] - box.startPoint[1]),\n ];\n}\n\nexport function getBoxCenter(box) {\n return [\n box.startPoint[0] + (box.endPoint[0] - box.startPoint[0]) / 2,\n box.startPoint[1] + (box.endPoint[1] - box.startPoint[1]) / 2,\n ];\n}\n\nexport function cutBoxFromImageAndResize(box, image, cropSize) {\n const h = image.shape[1];\n const w = image.shape[2];\n const boxes = [[\n box.startPoint[1] / h,\n box.startPoint[0] / w,\n box.endPoint[1] / h,\n box.endPoint[0] / w,\n ]];\n return tf.image.cropAndResize(image, boxes, [0], cropSize);\n}\n\nexport function scaleBoxCoordinates(box, factor) {\n const startPoint = [box.startPoint[0] * factor[0], box.startPoint[1] * factor[1]];\n const endPoint = [box.endPoint[0] * factor[0], box.endPoint[1] * factor[1]];\n const palmLandmarks = box.palmLandmarks.map((coord) => {\n const scaledCoord = [coord[0] * factor[0], coord[1] * factor[1]];\n return scaledCoord;\n });\n return { startPoint, endPoint, palmLandmarks, confidence: box.confidence };\n}\n\nexport function enlargeBox(box, factor = 1.5) {\n const center = getBoxCenter(box);\n const size = getBoxSize(box);\n const newHalfSize = [factor * size[0] / 2, factor * size[1] / 2];\n const startPoint = [center[0] - newHalfSize[0], center[1] - newHalfSize[1]];\n const endPoint = [center[0] + newHalfSize[0], center[1] + newHalfSize[1]];\n return { startPoint, endPoint, palmLandmarks: box.palmLandmarks };\n}\n\nexport function squarifyBox(box) {\n const centers = getBoxCenter(box);\n const size = getBoxSize(box);\n const maxEdge = Math.max(...size);\n const halfSize = maxEdge / 2;\n const startPoint = [centers[0] - halfSize, centers[1] - halfSize];\n const endPoint = [centers[0] + halfSize, centers[1] + halfSize];\n return { startPoint, endPoint, palmLandmarks: box.palmLandmarks };\n}\n\nexport function shiftBox(box, shiftFactor) {\n const boxSize = [\n box.endPoint[0] - box.startPoint[0],\n box.endPoint[1] - box.startPoint[1],\n ];\n const shiftVector = [boxSize[0] * shiftFactor[0], boxSize[1] * shiftFactor[1]];\n const startPoint = [box.startPoint[0] + shiftVector[0], box.startPoint[1] + shiftVector[1]];\n const endPoint = [box.endPoint[0] + shiftVector[0], box.endPoint[1] + shiftVector[1]];\n return { startPoint, endPoint, palmLandmarks: box.palmLandmarks };\n}\n", "export const anchors = [\n {\n x: 0.015625,\n y: 0.015625,\n },\n {\n x: 0.015625,\n y: 0.015625,\n },\n {\n x: 0.046875,\n y: 0.015625,\n },\n {\n x: 0.046875,\n y: 0.015625,\n },\n {\n x: 0.078125,\n y: 0.015625,\n },\n {\n x: 0.078125,\n y: 0.015625,\n },\n {\n x: 0.109375,\n y: 0.015625,\n },\n {\n x: 0.109375,\n y: 0.015625,\n },\n {\n x: 0.140625,\n y: 0.015625,\n },\n {\n x: 0.140625,\n y: 0.015625,\n },\n {\n x: 0.171875,\n y: 0.015625,\n },\n {\n x: 0.171875,\n y: 0.015625,\n },\n {\n x: 0.203125,\n y: 0.015625,\n },\n {\n x: 0.203125,\n y: 0.015625,\n },\n {\n x: 0.234375,\n y: 0.015625,\n },\n {\n x: 0.234375,\n y: 0.015625,\n },\n {\n x: 0.265625,\n y: 0.015625,\n },\n {\n x: 0.265625,\n y: 0.015625,\n },\n {\n x: 0.296875,\n y: 0.015625,\n },\n {\n x: 0.296875,\n y: 0.015625,\n },\n {\n x: 0.328125,\n y: 0.015625,\n },\n {\n x: 0.328125,\n y: 0.015625,\n },\n {\n x: 0.359375,\n y: 0.015625,\n },\n {\n x: 0.359375,\n y: 0.015625,\n },\n {\n x: 0.390625,\n y: 0.015625,\n },\n {\n x: 0.390625,\n y: 0.015625,\n },\n {\n x: 0.421875,\n y: 0.015625,\n },\n {\n x: 0.421875,\n y: 0.015625,\n },\n {\n x: 0.453125,\n y: 0.015625,\n },\n {\n x: 0.453125,\n y: 0.015625,\n },\n {\n x: 0.484375,\n y: 0.015625,\n },\n {\n x: 0.484375,\n y: 0.015625,\n },\n {\n x: 0.515625,\n y: 0.015625,\n },\n {\n x: 0.515625,\n y: 0.015625,\n },\n {\n x: 0.546875,\n y: 0.015625,\n },\n {\n x: 0.546875,\n y: 0.015625,\n },\n {\n x: 0.578125,\n y: 0.015625,\n },\n {\n x: 0.578125,\n y: 0.015625,\n },\n {\n x: 0.609375,\n y: 0.015625,\n },\n {\n x: 0.609375,\n y: 0.015625,\n },\n {\n x: 0.640625,\n y: 0.015625,\n },\n {\n x: 0.640625,\n y: 0.015625,\n },\n {\n x: 0.671875,\n y: 0.015625,\n },\n {\n x: 0.671875,\n y: 0.015625,\n },\n {\n x: 0.703125,\n y: 0.015625,\n },\n {\n x: 0.703125,\n y: 0.015625,\n },\n {\n x: 0.734375,\n y: 0.015625,\n },\n {\n x: 0.734375,\n y: 0.015625,\n },\n {\n x: 0.765625,\n y: 0.015625,\n },\n {\n x: 0.765625,\n y: 0.015625,\n },\n {\n x: 0.796875,\n y: 0.015625,\n },\n {\n x: 0.796875,\n y: 0.015625,\n },\n {\n x: 0.828125,\n y: 0.015625,\n },\n {\n x: 0.828125,\n y: 0.015625,\n },\n {\n x: 0.859375,\n y: 0.015625,\n },\n {\n x: 0.859375,\n y: 0.015625,\n },\n {\n x: 0.890625,\n y: 0.015625,\n },\n {\n x: 0.890625,\n y: 0.015625,\n },\n {\n x: 0.921875,\n y: 0.015625,\n },\n {\n x: 0.921875,\n y: 0.015625,\n },\n {\n x: 0.953125,\n y: 0.015625,\n },\n {\n x: 0.953125,\n y: 0.015625,\n },\n {\n x: 0.984375,\n y: 0.015625,\n },\n {\n x: 0.984375,\n y: 0.015625,\n },\n {\n x: 0.015625,\n y: 0.046875,\n },\n {\n x: 0.015625,\n y: 0.046875,\n },\n {\n x: 0.046875,\n y: 0.046875,\n },\n {\n x: 0.046875,\n y: 0.046875,\n },\n {\n x: 0.078125,\n y: 0.046875,\n },\n {\n x: 0.078125,\n y: 0.046875,\n },\n {\n x: 0.109375,\n y: 0.046875,\n },\n {\n x: 0.109375,\n y: 0.046875,\n },\n {\n x: 0.140625,\n y: 0.046875,\n },\n {\n x: 0.140625,\n y: 0.046875,\n },\n {\n x: 0.171875,\n y: 0.046875,\n },\n {\n x: 0.171875,\n y: 0.046875,\n },\n {\n x: 0.203125,\n y: 0.046875,\n },\n {\n x: 0.203125,\n y: 0.046875,\n },\n {\n x: 0.234375,\n y: 0.046875,\n },\n {\n x: 0.234375,\n y: 0.046875,\n },\n {\n x: 0.265625,\n y: 0.046875,\n },\n {\n x: 0.265625,\n y: 0.046875,\n },\n {\n x: 0.296875,\n y: 0.046875,\n },\n {\n x: 0.296875,\n y: 0.046875,\n },\n {\n x: 0.328125,\n y: 0.046875,\n },\n {\n x: 0.328125,\n y: 0.046875,\n },\n {\n x: 0.359375,\n y: 0.046875,\n },\n {\n x: 0.359375,\n y: 0.046875,\n },\n {\n x: 0.390625,\n y: 0.046875,\n },\n {\n x: 0.390625,\n y: 0.046875,\n },\n {\n x: 0.421875,\n y: 0.046875,\n },\n {\n x: 0.421875,\n y: 0.046875,\n },\n {\n x: 0.453125,\n y: 0.046875,\n },\n {\n x: 0.453125,\n y: 0.046875,\n },\n {\n x: 0.484375,\n y: 0.046875,\n },\n {\n x: 0.484375,\n y: 0.046875,\n },\n {\n x: 0.515625,\n y: 0.046875,\n },\n {\n x: 0.515625,\n y: 0.046875,\n },\n {\n x: 0.546875,\n y: 0.046875,\n },\n {\n x: 0.546875,\n y: 0.046875,\n },\n {\n x: 0.578125,\n y: 0.046875,\n },\n {\n x: 0.578125,\n y: 0.046875,\n },\n {\n x: 0.609375,\n y: 0.046875,\n },\n {\n x: 0.609375,\n y: 0.046875,\n },\n {\n x: 0.640625,\n y: 0.046875,\n },\n {\n x: 0.640625,\n y: 0.046875,\n },\n {\n x: 0.671875,\n y: 0.046875,\n },\n {\n x: 0.671875,\n y: 0.046875,\n },\n {\n x: 0.703125,\n y: 0.046875,\n },\n {\n x: 0.703125,\n y: 0.046875,\n },\n {\n x: 0.734375,\n y: 0.046875,\n },\n {\n x: 0.734375,\n y: 0.046875,\n },\n {\n x: 0.765625,\n y: 0.046875,\n },\n {\n x: 0.765625,\n y: 0.046875,\n },\n {\n x: 0.796875,\n y: 0.046875,\n },\n {\n x: 0.796875,\n y: 0.046875,\n },\n {\n x: 0.828125,\n y: 0.046875,\n },\n {\n x: 0.828125,\n y: 0.046875,\n },\n {\n x: 0.859375,\n y: 0.046875,\n },\n {\n x: 0.859375,\n y: 0.046875,\n },\n {\n x: 0.890625,\n y: 0.046875,\n },\n {\n x: 0.890625,\n y: 0.046875,\n },\n {\n x: 0.921875,\n y: 0.046875,\n },\n {\n x: 0.921875,\n y: 0.046875,\n },\n {\n x: 0.953125,\n y: 0.046875,\n },\n {\n x: 0.953125,\n y: 0.046875,\n },\n {\n x: 0.984375,\n y: 0.046875,\n },\n {\n x: 0.984375,\n y: 0.046875,\n },\n {\n x: 0.015625,\n y: 0.078125,\n },\n {\n x: 0.015625,\n y: 0.078125,\n },\n {\n x: 0.046875,\n y: 0.078125,\n },\n {\n x: 0.046875,\n y: 0.078125,\n },\n {\n x: 0.078125,\n y: 0.078125,\n },\n {\n x: 0.078125,\n y: 0.078125,\n },\n {\n x: 0.109375,\n y: 0.078125,\n },\n {\n x: 0.109375,\n y: 0.078125,\n },\n {\n x: 0.140625,\n y: 0.078125,\n },\n {\n x: 0.140625,\n y: 0.078125,\n },\n {\n x: 0.171875,\n y: 0.078125,\n },\n {\n x: 0.171875,\n y: 0.078125,\n },\n {\n x: 0.203125,\n y: 0.078125,\n },\n {\n x: 0.203125,\n y: 0.078125,\n },\n {\n x: 0.234375,\n y: 0.078125,\n },\n {\n x: 0.234375,\n y: 0.078125,\n },\n {\n x: 0.265625,\n y: 0.078125,\n },\n {\n x: 0.265625,\n y: 0.078125,\n },\n {\n x: 0.296875,\n y: 0.078125,\n },\n {\n x: 0.296875,\n y: 0.078125,\n },\n {\n x: 0.328125,\n y: 0.078125,\n },\n {\n x: 0.328125,\n y: 0.078125,\n },\n {\n x: 0.359375,\n y: 0.078125,\n },\n {\n x: 0.359375,\n y: 0.078125,\n },\n {\n x: 0.390625,\n y: 0.078125,\n },\n {\n x: 0.390625,\n y: 0.078125,\n },\n {\n x: 0.421875,\n y: 0.078125,\n },\n {\n x: 0.421875,\n y: 0.078125,\n },\n {\n x: 0.453125,\n y: 0.078125,\n },\n {\n x: 0.453125,\n y: 0.078125,\n },\n {\n x: 0.484375,\n y: 0.078125,\n },\n {\n x: 0.484375,\n y: 0.078125,\n },\n {\n x: 0.515625,\n y: 0.078125,\n },\n {\n x: 0.515625,\n y: 0.078125,\n },\n {\n x: 0.546875,\n y: 0.078125,\n },\n {\n x: 0.546875,\n y: 0.078125,\n },\n {\n x: 0.578125,\n y: 0.078125,\n },\n {\n x: 0.578125,\n y: 0.078125,\n },\n {\n x: 0.609375,\n y: 0.078125,\n },\n {\n x: 0.609375,\n y: 0.078125,\n },\n {\n x: 0.640625,\n y: 0.078125,\n },\n {\n x: 0.640625,\n y: 0.078125,\n },\n {\n x: 0.671875,\n y: 0.078125,\n },\n {\n x: 0.671875,\n y: 0.078125,\n },\n {\n x: 0.703125,\n y: 0.078125,\n },\n {\n x: 0.703125,\n y: 0.078125,\n },\n {\n x: 0.734375,\n y: 0.078125,\n },\n {\n x: 0.734375,\n y: 0.078125,\n },\n {\n x: 0.765625,\n y: 0.078125,\n },\n {\n x: 0.765625,\n y: 0.078125,\n },\n {\n x: 0.796875,\n y: 0.078125,\n },\n {\n x: 0.796875,\n y: 0.078125,\n },\n {\n x: 0.828125,\n y: 0.078125,\n },\n {\n x: 0.828125,\n y: 0.078125,\n },\n {\n x: 0.859375,\n y: 0.078125,\n },\n {\n x: 0.859375,\n y: 0.078125,\n },\n {\n x: 0.890625,\n y: 0.078125,\n },\n {\n x: 0.890625,\n y: 0.078125,\n },\n {\n x: 0.921875,\n y: 0.078125,\n },\n {\n x: 0.921875,\n y: 0.078125,\n },\n {\n x: 0.953125,\n y: 0.078125,\n },\n {\n x: 0.953125,\n y: 0.078125,\n },\n {\n x: 0.984375,\n y: 0.078125,\n },\n {\n x: 0.984375,\n y: 0.078125,\n },\n {\n x: 0.015625,\n y: 0.109375,\n },\n {\n x: 0.015625,\n y: 0.109375,\n },\n {\n x: 0.046875,\n y: 0.109375,\n },\n {\n x: 0.046875,\n y: 0.109375,\n },\n {\n x: 0.078125,\n y: 0.109375,\n },\n {\n x: 0.078125,\n y: 0.109375,\n },\n {\n x: 0.109375,\n y: 0.109375,\n },\n {\n x: 0.109375,\n y: 0.109375,\n },\n {\n x: 0.140625,\n y: 0.109375,\n },\n {\n x: 0.140625,\n y: 0.109375,\n },\n {\n x: 0.171875,\n y: 0.109375,\n },\n {\n x: 0.171875,\n y: 0.109375,\n },\n {\n x: 0.203125,\n y: 0.109375,\n },\n {\n x: 0.203125,\n y: 0.109375,\n },\n {\n x: 0.234375,\n y: 0.109375,\n },\n {\n x: 0.234375,\n y: 0.109375,\n },\n {\n x: 0.265625,\n y: 0.109375,\n },\n {\n x: 0.265625,\n y: 0.109375,\n },\n {\n x: 0.296875,\n y: 0.109375,\n },\n {\n x: 0.296875,\n y: 0.109375,\n },\n {\n x: 0.328125,\n y: 0.109375,\n },\n {\n x: 0.328125,\n y: 0.109375,\n },\n {\n x: 0.359375,\n y: 0.109375,\n },\n {\n x: 0.359375,\n y: 0.109375,\n },\n {\n x: 0.390625,\n y: 0.109375,\n },\n {\n x: 0.390625,\n y: 0.109375,\n },\n {\n x: 0.421875,\n y: 0.109375,\n },\n {\n x: 0.421875,\n y: 0.109375,\n },\n {\n x: 0.453125,\n y: 0.109375,\n },\n {\n x: 0.453125,\n y: 0.109375,\n },\n {\n x: 0.484375,\n y: 0.109375,\n },\n {\n x: 0.484375,\n y: 0.109375,\n },\n {\n x: 0.515625,\n y: 0.109375,\n },\n {\n x: 0.515625,\n y: 0.109375,\n },\n {\n x: 0.546875,\n y: 0.109375,\n },\n {\n x: 0.546875,\n y: 0.109375,\n },\n {\n x: 0.578125,\n y: 0.109375,\n },\n {\n x: 0.578125,\n y: 0.109375,\n },\n {\n x: 0.609375,\n y: 0.109375,\n },\n {\n x: 0.609375,\n y: 0.109375,\n },\n {\n x: 0.640625,\n y: 0.109375,\n },\n {\n x: 0.640625,\n y: 0.109375,\n },\n {\n x: 0.671875,\n y: 0.109375,\n },\n {\n x: 0.671875,\n y: 0.109375,\n },\n {\n x: 0.703125,\n y: 0.109375,\n },\n {\n x: 0.703125,\n y: 0.109375,\n },\n {\n x: 0.734375,\n y: 0.109375,\n },\n {\n x: 0.734375,\n y: 0.109375,\n },\n {\n x: 0.765625,\n y: 0.109375,\n },\n {\n x: 0.765625,\n y: 0.109375,\n },\n {\n x: 0.796875,\n y: 0.109375,\n },\n {\n x: 0.796875,\n y: 0.109375,\n },\n {\n x: 0.828125,\n y: 0.109375,\n },\n {\n x: 0.828125,\n y: 0.109375,\n },\n {\n x: 0.859375,\n y: 0.109375,\n },\n {\n x: 0.859375,\n y: 0.109375,\n },\n {\n x: 0.890625,\n y: 0.109375,\n },\n {\n x: 0.890625,\n y: 0.109375,\n },\n {\n x: 0.921875,\n y: 0.109375,\n },\n {\n x: 0.921875,\n y: 0.109375,\n },\n {\n x: 0.953125,\n y: 0.109375,\n },\n {\n x: 0.953125,\n y: 0.109375,\n },\n {\n x: 0.984375,\n y: 0.109375,\n },\n {\n x: 0.984375,\n y: 0.109375,\n },\n {\n x: 0.015625,\n y: 0.140625,\n },\n {\n x: 0.015625,\n y: 0.140625,\n },\n {\n x: 0.046875,\n y: 0.140625,\n },\n {\n x: 0.046875,\n y: 0.140625,\n },\n {\n x: 0.078125,\n y: 0.140625,\n },\n {\n x: 0.078125,\n y: 0.140625,\n },\n {\n x: 0.109375,\n y: 0.140625,\n },\n {\n x: 0.109375,\n y: 0.140625,\n },\n {\n x: 0.140625,\n y: 0.140625,\n },\n {\n x: 0.140625,\n y: 0.140625,\n },\n {\n x: 0.171875,\n y: 0.140625,\n },\n {\n x: 0.171875,\n y: 0.140625,\n },\n {\n x: 0.203125,\n y: 0.140625,\n },\n {\n x: 0.203125,\n y: 0.140625,\n },\n {\n x: 0.234375,\n y: 0.140625,\n },\n {\n x: 0.234375,\n y: 0.140625,\n },\n {\n x: 0.265625,\n y: 0.140625,\n },\n {\n x: 0.265625,\n y: 0.140625,\n },\n {\n x: 0.296875,\n y: 0.140625,\n },\n {\n x: 0.296875,\n y: 0.140625,\n },\n {\n x: 0.328125,\n y: 0.140625,\n },\n {\n x: 0.328125,\n y: 0.140625,\n },\n {\n x: 0.359375,\n y: 0.140625,\n },\n {\n x: 0.359375,\n y: 0.140625,\n },\n {\n x: 0.390625,\n y: 0.140625,\n },\n {\n x: 0.390625,\n y: 0.140625,\n },\n {\n x: 0.421875,\n y: 0.140625,\n },\n {\n x: 0.421875,\n y: 0.140625,\n },\n {\n x: 0.453125,\n y: 0.140625,\n },\n {\n x: 0.453125,\n y: 0.140625,\n },\n {\n x: 0.484375,\n y: 0.140625,\n },\n {\n x: 0.484375,\n y: 0.140625,\n },\n {\n x: 0.515625,\n y: 0.140625,\n },\n {\n x: 0.515625,\n y: 0.140625,\n },\n {\n x: 0.546875,\n y: 0.140625,\n },\n {\n x: 0.546875,\n y: 0.140625,\n },\n {\n x: 0.578125,\n y: 0.140625,\n },\n {\n x: 0.578125,\n y: 0.140625,\n },\n {\n x: 0.609375,\n y: 0.140625,\n },\n {\n x: 0.609375,\n y: 0.140625,\n },\n {\n x: 0.640625,\n y: 0.140625,\n },\n {\n x: 0.640625,\n y: 0.140625,\n },\n {\n x: 0.671875,\n y: 0.140625,\n },\n {\n x: 0.671875,\n y: 0.140625,\n },\n {\n x: 0.703125,\n y: 0.140625,\n },\n {\n x: 0.703125,\n y: 0.140625,\n },\n {\n x: 0.734375,\n y: 0.140625,\n },\n {\n x: 0.734375,\n y: 0.140625,\n },\n {\n x: 0.765625,\n y: 0.140625,\n },\n {\n x: 0.765625,\n y: 0.140625,\n },\n {\n x: 0.796875,\n y: 0.140625,\n },\n {\n x: 0.796875,\n y: 0.140625,\n },\n {\n x: 0.828125,\n y: 0.140625,\n },\n {\n x: 0.828125,\n y: 0.140625,\n },\n {\n x: 0.859375,\n y: 0.140625,\n },\n {\n x: 0.859375,\n y: 0.140625,\n },\n {\n x: 0.890625,\n y: 0.140625,\n },\n {\n x: 0.890625,\n y: 0.140625,\n },\n {\n x: 0.921875,\n y: 0.140625,\n },\n {\n x: 0.921875,\n y: 0.140625,\n },\n {\n x: 0.953125,\n y: 0.140625,\n },\n {\n x: 0.953125,\n y: 0.140625,\n },\n {\n x: 0.984375,\n y: 0.140625,\n },\n {\n x: 0.984375,\n y: 0.140625,\n },\n {\n x: 0.015625,\n y: 0.171875,\n },\n {\n x: 0.015625,\n y: 0.171875,\n },\n {\n x: 0.046875,\n y: 0.171875,\n },\n {\n x: 0.046875,\n y: 0.171875,\n },\n {\n x: 0.078125,\n y: 0.171875,\n },\n {\n x: 0.078125,\n y: 0.171875,\n },\n {\n x: 0.109375,\n y: 0.171875,\n },\n {\n x: 0.109375,\n y: 0.171875,\n },\n {\n x: 0.140625,\n y: 0.171875,\n },\n {\n x: 0.140625,\n y: 0.171875,\n },\n {\n x: 0.171875,\n y: 0.171875,\n },\n {\n x: 0.171875,\n y: 0.171875,\n },\n {\n x: 0.203125,\n y: 0.171875,\n },\n {\n x: 0.203125,\n y: 0.171875,\n },\n {\n x: 0.234375,\n y: 0.171875,\n },\n {\n x: 0.234375,\n y: 0.171875,\n },\n {\n x: 0.265625,\n y: 0.171875,\n },\n {\n x: 0.265625,\n y: 0.171875,\n },\n {\n x: 0.296875,\n y: 0.171875,\n },\n {\n x: 0.296875,\n y: 0.171875,\n },\n {\n x: 0.328125,\n y: 0.171875,\n },\n {\n x: 0.328125,\n y: 0.171875,\n },\n {\n x: 0.359375,\n y: 0.171875,\n },\n {\n x: 0.359375,\n y: 0.171875,\n },\n {\n x: 0.390625,\n y: 0.171875,\n },\n {\n x: 0.390625,\n y: 0.171875,\n },\n {\n x: 0.421875,\n y: 0.171875,\n },\n {\n x: 0.421875,\n y: 0.171875,\n },\n {\n x: 0.453125,\n y: 0.171875,\n },\n {\n x: 0.453125,\n y: 0.171875,\n },\n {\n x: 0.484375,\n y: 0.171875,\n },\n {\n x: 0.484375,\n y: 0.171875,\n },\n {\n x: 0.515625,\n y: 0.171875,\n },\n {\n x: 0.515625,\n y: 0.171875,\n },\n {\n x: 0.546875,\n y: 0.171875,\n },\n {\n x: 0.546875,\n y: 0.171875,\n },\n {\n x: 0.578125,\n y: 0.171875,\n },\n {\n x: 0.578125,\n y: 0.171875,\n },\n {\n x: 0.609375,\n y: 0.171875,\n },\n {\n x: 0.609375,\n y: 0.171875,\n },\n {\n x: 0.640625,\n y: 0.171875,\n },\n {\n x: 0.640625,\n y: 0.171875,\n },\n {\n x: 0.671875,\n y: 0.171875,\n },\n {\n x: 0.671875,\n y: 0.171875,\n },\n {\n x: 0.703125,\n y: 0.171875,\n },\n {\n x: 0.703125,\n y: 0.171875,\n },\n {\n x: 0.734375,\n y: 0.171875,\n },\n {\n x: 0.734375,\n y: 0.171875,\n },\n {\n x: 0.765625,\n y: 0.171875,\n },\n {\n x: 0.765625,\n y: 0.171875,\n },\n {\n x: 0.796875,\n y: 0.171875,\n },\n {\n x: 0.796875,\n y: 0.171875,\n },\n {\n x: 0.828125,\n y: 0.171875,\n },\n {\n x: 0.828125,\n y: 0.171875,\n },\n {\n x: 0.859375,\n y: 0.171875,\n },\n {\n x: 0.859375,\n y: 0.171875,\n },\n {\n x: 0.890625,\n y: 0.171875,\n },\n {\n x: 0.890625,\n y: 0.171875,\n },\n {\n x: 0.921875,\n y: 0.171875,\n },\n {\n x: 0.921875,\n y: 0.171875,\n },\n {\n x: 0.953125,\n y: 0.171875,\n },\n {\n x: 0.953125,\n y: 0.171875,\n },\n {\n x: 0.984375,\n y: 0.171875,\n },\n {\n x: 0.984375,\n y: 0.171875,\n },\n {\n x: 0.015625,\n y: 0.203125,\n },\n {\n x: 0.015625,\n y: 0.203125,\n },\n {\n x: 0.046875,\n y: 0.203125,\n },\n {\n x: 0.046875,\n y: 0.203125,\n },\n {\n x: 0.078125,\n y: 0.203125,\n },\n {\n x: 0.078125,\n y: 0.203125,\n },\n {\n x: 0.109375,\n y: 0.203125,\n },\n {\n x: 0.109375,\n y: 0.203125,\n },\n {\n x: 0.140625,\n y: 0.203125,\n },\n {\n x: 0.140625,\n y: 0.203125,\n },\n {\n x: 0.171875,\n y: 0.203125,\n },\n {\n x: 0.171875,\n y: 0.203125,\n },\n {\n x: 0.203125,\n y: 0.203125,\n },\n {\n x: 0.203125,\n y: 0.203125,\n },\n {\n x: 0.234375,\n y: 0.203125,\n },\n {\n x: 0.234375,\n y: 0.203125,\n },\n {\n x: 0.265625,\n y: 0.203125,\n },\n {\n x: 0.265625,\n y: 0.203125,\n },\n {\n x: 0.296875,\n y: 0.203125,\n },\n {\n x: 0.296875,\n y: 0.203125,\n },\n {\n x: 0.328125,\n y: 0.203125,\n },\n {\n x: 0.328125,\n y: 0.203125,\n },\n {\n x: 0.359375,\n y: 0.203125,\n },\n {\n x: 0.359375,\n y: 0.203125,\n },\n {\n x: 0.390625,\n y: 0.203125,\n },\n {\n x: 0.390625,\n y: 0.203125,\n },\n {\n x: 0.421875,\n y: 0.203125,\n },\n {\n x: 0.421875,\n y: 0.203125,\n },\n {\n x: 0.453125,\n y: 0.203125,\n },\n {\n x: 0.453125,\n y: 0.203125,\n },\n {\n x: 0.484375,\n y: 0.203125,\n },\n {\n x: 0.484375,\n y: 0.203125,\n },\n {\n x: 0.515625,\n y: 0.203125,\n },\n {\n x: 0.515625,\n y: 0.203125,\n },\n {\n x: 0.546875,\n y: 0.203125,\n },\n {\n x: 0.546875,\n y: 0.203125,\n },\n {\n x: 0.578125,\n y: 0.203125,\n },\n {\n x: 0.578125,\n y: 0.203125,\n },\n {\n x: 0.609375,\n y: 0.203125,\n },\n {\n x: 0.609375,\n y: 0.203125,\n },\n {\n x: 0.640625,\n y: 0.203125,\n },\n {\n x: 0.640625,\n y: 0.203125,\n },\n {\n x: 0.671875,\n y: 0.203125,\n },\n {\n x: 0.671875,\n y: 0.203125,\n },\n {\n x: 0.703125,\n y: 0.203125,\n },\n {\n x: 0.703125,\n y: 0.203125,\n },\n {\n x: 0.734375,\n y: 0.203125,\n },\n {\n x: 0.734375,\n y: 0.203125,\n },\n {\n x: 0.765625,\n y: 0.203125,\n },\n {\n x: 0.765625,\n y: 0.203125,\n },\n {\n x: 0.796875,\n y: 0.203125,\n },\n {\n x: 0.796875,\n y: 0.203125,\n },\n {\n x: 0.828125,\n y: 0.203125,\n },\n {\n x: 0.828125,\n y: 0.203125,\n },\n {\n x: 0.859375,\n y: 0.203125,\n },\n {\n x: 0.859375,\n y: 0.203125,\n },\n {\n x: 0.890625,\n y: 0.203125,\n },\n {\n x: 0.890625,\n y: 0.203125,\n },\n {\n x: 0.921875,\n y: 0.203125,\n },\n {\n x: 0.921875,\n y: 0.203125,\n },\n {\n x: 0.953125,\n y: 0.203125,\n },\n {\n x: 0.953125,\n y: 0.203125,\n },\n {\n x: 0.984375,\n y: 0.203125,\n },\n {\n x: 0.984375,\n y: 0.203125,\n },\n {\n x: 0.015625,\n y: 0.234375,\n },\n {\n x: 0.015625,\n y: 0.234375,\n },\n {\n x: 0.046875,\n y: 0.234375,\n },\n {\n x: 0.046875,\n y: 0.234375,\n },\n {\n x: 0.078125,\n y: 0.234375,\n },\n {\n x: 0.078125,\n y: 0.234375,\n },\n {\n x: 0.109375,\n y: 0.234375,\n },\n {\n x: 0.109375,\n y: 0.234375,\n },\n {\n x: 0.140625,\n y: 0.234375,\n },\n {\n x: 0.140625,\n y: 0.234375,\n },\n {\n x: 0.171875,\n y: 0.234375,\n },\n {\n x: 0.171875,\n y: 0.234375,\n },\n {\n x: 0.203125,\n y: 0.234375,\n },\n {\n x: 0.203125,\n y: 0.234375,\n },\n {\n x: 0.234375,\n y: 0.234375,\n },\n {\n x: 0.234375,\n y: 0.234375,\n },\n {\n x: 0.265625,\n y: 0.234375,\n },\n {\n x: 0.265625,\n y: 0.234375,\n },\n {\n x: 0.296875,\n y: 0.234375,\n },\n {\n x: 0.296875,\n y: 0.234375,\n },\n {\n x: 0.328125,\n y: 0.234375,\n },\n {\n x: 0.328125,\n y: 0.234375,\n },\n {\n x: 0.359375,\n y: 0.234375,\n },\n {\n x: 0.359375,\n y: 0.234375,\n },\n {\n x: 0.390625,\n y: 0.234375,\n },\n {\n x: 0.390625,\n y: 0.234375,\n },\n {\n x: 0.421875,\n y: 0.234375,\n },\n {\n x: 0.421875,\n y: 0.234375,\n },\n {\n x: 0.453125,\n y: 0.234375,\n },\n {\n x: 0.453125,\n y: 0.234375,\n },\n {\n x: 0.484375,\n y: 0.234375,\n },\n {\n x: 0.484375,\n y: 0.234375,\n },\n {\n x: 0.515625,\n y: 0.234375,\n },\n {\n x: 0.515625,\n y: 0.234375,\n },\n {\n x: 0.546875,\n y: 0.234375,\n },\n {\n x: 0.546875,\n y: 0.234375,\n },\n {\n x: 0.578125,\n y: 0.234375,\n },\n {\n x: 0.578125,\n y: 0.234375,\n },\n {\n x: 0.609375,\n y: 0.234375,\n },\n {\n x: 0.609375,\n y: 0.234375,\n },\n {\n x: 0.640625,\n y: 0.234375,\n },\n {\n x: 0.640625,\n y: 0.234375,\n },\n {\n x: 0.671875,\n y: 0.234375,\n },\n {\n x: 0.671875,\n y: 0.234375,\n },\n {\n x: 0.703125,\n y: 0.234375,\n },\n {\n x: 0.703125,\n y: 0.234375,\n },\n {\n x: 0.734375,\n y: 0.234375,\n },\n {\n x: 0.734375,\n y: 0.234375,\n },\n {\n x: 0.765625,\n y: 0.234375,\n },\n {\n x: 0.765625,\n y: 0.234375,\n },\n {\n x: 0.796875,\n y: 0.234375,\n },\n {\n x: 0.796875,\n y: 0.234375,\n },\n {\n x: 0.828125,\n y: 0.234375,\n },\n {\n x: 0.828125,\n y: 0.234375,\n },\n {\n x: 0.859375,\n y: 0.234375,\n },\n {\n x: 0.859375,\n y: 0.234375,\n },\n {\n x: 0.890625,\n y: 0.234375,\n },\n {\n x: 0.890625,\n y: 0.234375,\n },\n {\n x: 0.921875,\n y: 0.234375,\n },\n {\n x: 0.921875,\n y: 0.234375,\n },\n {\n x: 0.953125,\n y: 0.234375,\n },\n {\n x: 0.953125,\n y: 0.234375,\n },\n {\n x: 0.984375,\n y: 0.234375,\n },\n {\n x: 0.984375,\n y: 0.234375,\n },\n {\n x: 0.015625,\n y: 0.265625,\n },\n {\n x: 0.015625,\n y: 0.265625,\n },\n {\n x: 0.046875,\n y: 0.265625,\n },\n {\n x: 0.046875,\n y: 0.265625,\n },\n {\n x: 0.078125,\n y: 0.265625,\n },\n {\n x: 0.078125,\n y: 0.265625,\n },\n {\n x: 0.109375,\n y: 0.265625,\n },\n {\n x: 0.109375,\n y: 0.265625,\n },\n {\n x: 0.140625,\n y: 0.265625,\n },\n {\n x: 0.140625,\n y: 0.265625,\n },\n {\n x: 0.171875,\n y: 0.265625,\n },\n {\n x: 0.171875,\n y: 0.265625,\n },\n {\n x: 0.203125,\n y: 0.265625,\n },\n {\n x: 0.203125,\n y: 0.265625,\n },\n {\n x: 0.234375,\n y: 0.265625,\n },\n {\n x: 0.234375,\n y: 0.265625,\n },\n {\n x: 0.265625,\n y: 0.265625,\n },\n {\n x: 0.265625,\n y: 0.265625,\n },\n {\n x: 0.296875,\n y: 0.265625,\n },\n {\n x: 0.296875,\n y: 0.265625,\n },\n {\n x: 0.328125,\n y: 0.265625,\n },\n {\n x: 0.328125,\n y: 0.265625,\n },\n {\n x: 0.359375,\n y: 0.265625,\n },\n {\n x: 0.359375,\n y: 0.265625,\n },\n {\n x: 0.390625,\n y: 0.265625,\n },\n {\n x: 0.390625,\n y: 0.265625,\n },\n {\n x: 0.421875,\n y: 0.265625,\n },\n {\n x: 0.421875,\n y: 0.265625,\n },\n {\n x: 0.453125,\n y: 0.265625,\n },\n {\n x: 0.453125,\n y: 0.265625,\n },\n {\n x: 0.484375,\n y: 0.265625,\n },\n {\n x: 0.484375,\n y: 0.265625,\n },\n {\n x: 0.515625,\n y: 0.265625,\n },\n {\n x: 0.515625,\n y: 0.265625,\n },\n {\n x: 0.546875,\n y: 0.265625,\n },\n {\n x: 0.546875,\n y: 0.265625,\n },\n {\n x: 0.578125,\n y: 0.265625,\n },\n {\n x: 0.578125,\n y: 0.265625,\n },\n {\n x: 0.609375,\n y: 0.265625,\n },\n {\n x: 0.609375,\n y: 0.265625,\n },\n {\n x: 0.640625,\n y: 0.265625,\n },\n {\n x: 0.640625,\n y: 0.265625,\n },\n {\n x: 0.671875,\n y: 0.265625,\n },\n {\n x: 0.671875,\n y: 0.265625,\n },\n {\n x: 0.703125,\n y: 0.265625,\n },\n {\n x: 0.703125,\n y: 0.265625,\n },\n {\n x: 0.734375,\n y: 0.265625,\n },\n {\n x: 0.734375,\n y: 0.265625,\n },\n {\n x: 0.765625,\n y: 0.265625,\n },\n {\n x: 0.765625,\n y: 0.265625,\n },\n {\n x: 0.796875,\n y: 0.265625,\n },\n {\n x: 0.796875,\n y: 0.265625,\n },\n {\n x: 0.828125,\n y: 0.265625,\n },\n {\n x: 0.828125,\n y: 0.265625,\n },\n {\n x: 0.859375,\n y: 0.265625,\n },\n {\n x: 0.859375,\n y: 0.265625,\n },\n {\n x: 0.890625,\n y: 0.265625,\n },\n {\n x: 0.890625,\n y: 0.265625,\n },\n {\n x: 0.921875,\n y: 0.265625,\n },\n {\n x: 0.921875,\n y: 0.265625,\n },\n {\n x: 0.953125,\n y: 0.265625,\n },\n {\n x: 0.953125,\n y: 0.265625,\n },\n {\n x: 0.984375,\n y: 0.265625,\n },\n {\n x: 0.984375,\n y: 0.265625,\n },\n {\n x: 0.015625,\n y: 0.296875,\n },\n {\n x: 0.015625,\n y: 0.296875,\n },\n {\n x: 0.046875,\n y: 0.296875,\n },\n {\n x: 0.046875,\n y: 0.296875,\n },\n {\n x: 0.078125,\n y: 0.296875,\n },\n {\n x: 0.078125,\n y: 0.296875,\n },\n {\n x: 0.109375,\n y: 0.296875,\n },\n {\n x: 0.109375,\n y: 0.296875,\n },\n {\n x: 0.140625,\n y: 0.296875,\n },\n {\n x: 0.140625,\n y: 0.296875,\n },\n {\n x: 0.171875,\n y: 0.296875,\n },\n {\n x: 0.171875,\n y: 0.296875,\n },\n {\n x: 0.203125,\n y: 0.296875,\n },\n {\n x: 0.203125,\n y: 0.296875,\n },\n {\n x: 0.234375,\n y: 0.296875,\n },\n {\n x: 0.234375,\n y: 0.296875,\n },\n {\n x: 0.265625,\n y: 0.296875,\n },\n {\n x: 0.265625,\n y: 0.296875,\n },\n {\n x: 0.296875,\n y: 0.296875,\n },\n {\n x: 0.296875,\n y: 0.296875,\n },\n {\n x: 0.328125,\n y: 0.296875,\n },\n {\n x: 0.328125,\n y: 0.296875,\n },\n {\n x: 0.359375,\n y: 0.296875,\n },\n {\n x: 0.359375,\n y: 0.296875,\n },\n {\n x: 0.390625,\n y: 0.296875,\n },\n {\n x: 0.390625,\n y: 0.296875,\n },\n {\n x: 0.421875,\n y: 0.296875,\n },\n {\n x: 0.421875,\n y: 0.296875,\n },\n {\n x: 0.453125,\n y: 0.296875,\n },\n {\n x: 0.453125,\n y: 0.296875,\n },\n {\n x: 0.484375,\n y: 0.296875,\n },\n {\n x: 0.484375,\n y: 0.296875,\n },\n {\n x: 0.515625,\n y: 0.296875,\n },\n {\n x: 0.515625,\n y: 0.296875,\n },\n {\n x: 0.546875,\n y: 0.296875,\n },\n {\n x: 0.546875,\n y: 0.296875,\n },\n {\n x: 0.578125,\n y: 0.296875,\n },\n {\n x: 0.578125,\n y: 0.296875,\n },\n {\n x: 0.609375,\n y: 0.296875,\n },\n {\n x: 0.609375,\n y: 0.296875,\n },\n {\n x: 0.640625,\n y: 0.296875,\n },\n {\n x: 0.640625,\n y: 0.296875,\n },\n {\n x: 0.671875,\n y: 0.296875,\n },\n {\n x: 0.671875,\n y: 0.296875,\n },\n {\n x: 0.703125,\n y: 0.296875,\n },\n {\n x: 0.703125,\n y: 0.296875,\n },\n {\n x: 0.734375,\n y: 0.296875,\n },\n {\n x: 0.734375,\n y: 0.296875,\n },\n {\n x: 0.765625,\n y: 0.296875,\n },\n {\n x: 0.765625,\n y: 0.296875,\n },\n {\n x: 0.796875,\n y: 0.296875,\n },\n {\n x: 0.796875,\n y: 0.296875,\n },\n {\n x: 0.828125,\n y: 0.296875,\n },\n {\n x: 0.828125,\n y: 0.296875,\n },\n {\n x: 0.859375,\n y: 0.296875,\n },\n {\n x: 0.859375,\n y: 0.296875,\n },\n {\n x: 0.890625,\n y: 0.296875,\n },\n {\n x: 0.890625,\n y: 0.296875,\n },\n {\n x: 0.921875,\n y: 0.296875,\n },\n {\n x: 0.921875,\n y: 0.296875,\n },\n {\n x: 0.953125,\n y: 0.296875,\n },\n {\n x: 0.953125,\n y: 0.296875,\n },\n {\n x: 0.984375,\n y: 0.296875,\n },\n {\n x: 0.984375,\n y: 0.296875,\n },\n {\n x: 0.015625,\n y: 0.328125,\n },\n {\n x: 0.015625,\n y: 0.328125,\n },\n {\n x: 0.046875,\n y: 0.328125,\n },\n {\n x: 0.046875,\n y: 0.328125,\n },\n {\n x: 0.078125,\n y: 0.328125,\n },\n {\n x: 0.078125,\n y: 0.328125,\n },\n {\n x: 0.109375,\n y: 0.328125,\n },\n {\n x: 0.109375,\n y: 0.328125,\n },\n {\n x: 0.140625,\n y: 0.328125,\n },\n {\n x: 0.140625,\n y: 0.328125,\n },\n {\n x: 0.171875,\n y: 0.328125,\n },\n {\n x: 0.171875,\n y: 0.328125,\n },\n {\n x: 0.203125,\n y: 0.328125,\n },\n {\n x: 0.203125,\n y: 0.328125,\n },\n {\n x: 0.234375,\n y: 0.328125,\n },\n {\n x: 0.234375,\n y: 0.328125,\n },\n {\n x: 0.265625,\n y: 0.328125,\n },\n {\n x: 0.265625,\n y: 0.328125,\n },\n {\n x: 0.296875,\n y: 0.328125,\n },\n {\n x: 0.296875,\n y: 0.328125,\n },\n {\n x: 0.328125,\n y: 0.328125,\n },\n {\n x: 0.328125,\n y: 0.328125,\n },\n {\n x: 0.359375,\n y: 0.328125,\n },\n {\n x: 0.359375,\n y: 0.328125,\n },\n {\n x: 0.390625,\n y: 0.328125,\n },\n {\n x: 0.390625,\n y: 0.328125,\n },\n {\n x: 0.421875,\n y: 0.328125,\n },\n {\n x: 0.421875,\n y: 0.328125,\n },\n {\n x: 0.453125,\n y: 0.328125,\n },\n {\n x: 0.453125,\n y: 0.328125,\n },\n {\n x: 0.484375,\n y: 0.328125,\n },\n {\n x: 0.484375,\n y: 0.328125,\n },\n {\n x: 0.515625,\n y: 0.328125,\n },\n {\n x: 0.515625,\n y: 0.328125,\n },\n {\n x: 0.546875,\n y: 0.328125,\n },\n {\n x: 0.546875,\n y: 0.328125,\n },\n {\n x: 0.578125,\n y: 0.328125,\n },\n {\n x: 0.578125,\n y: 0.328125,\n },\n {\n x: 0.609375,\n y: 0.328125,\n },\n {\n x: 0.609375,\n y: 0.328125,\n },\n {\n x: 0.640625,\n y: 0.328125,\n },\n {\n x: 0.640625,\n y: 0.328125,\n },\n {\n x: 0.671875,\n y: 0.328125,\n },\n {\n x: 0.671875,\n y: 0.328125,\n },\n {\n x: 0.703125,\n y: 0.328125,\n },\n {\n x: 0.703125,\n y: 0.328125,\n },\n {\n x: 0.734375,\n y: 0.328125,\n },\n {\n x: 0.734375,\n y: 0.328125,\n },\n {\n x: 0.765625,\n y: 0.328125,\n },\n {\n x: 0.765625,\n y: 0.328125,\n },\n {\n x: 0.796875,\n y: 0.328125,\n },\n {\n x: 0.796875,\n y: 0.328125,\n },\n {\n x: 0.828125,\n y: 0.328125,\n },\n {\n x: 0.828125,\n y: 0.328125,\n },\n {\n x: 0.859375,\n y: 0.328125,\n },\n {\n x: 0.859375,\n y: 0.328125,\n },\n {\n x: 0.890625,\n y: 0.328125,\n },\n {\n x: 0.890625,\n y: 0.328125,\n },\n {\n x: 0.921875,\n y: 0.328125,\n },\n {\n x: 0.921875,\n y: 0.328125,\n },\n {\n x: 0.953125,\n y: 0.328125,\n },\n {\n x: 0.953125,\n y: 0.328125,\n },\n {\n x: 0.984375,\n y: 0.328125,\n },\n {\n x: 0.984375,\n y: 0.328125,\n },\n {\n x: 0.015625,\n y: 0.359375,\n },\n {\n x: 0.015625,\n y: 0.359375,\n },\n {\n x: 0.046875,\n y: 0.359375,\n },\n {\n x: 0.046875,\n y: 0.359375,\n },\n {\n x: 0.078125,\n y: 0.359375,\n },\n {\n x: 0.078125,\n y: 0.359375,\n },\n {\n x: 0.109375,\n y: 0.359375,\n },\n {\n x: 0.109375,\n y: 0.359375,\n },\n {\n x: 0.140625,\n y: 0.359375,\n },\n {\n x: 0.140625,\n y: 0.359375,\n },\n {\n x: 0.171875,\n y: 0.359375,\n },\n {\n x: 0.171875,\n y: 0.359375,\n },\n {\n x: 0.203125,\n y: 0.359375,\n },\n {\n x: 0.203125,\n y: 0.359375,\n },\n {\n x: 0.234375,\n y: 0.359375,\n },\n {\n x: 0.234375,\n y: 0.359375,\n },\n {\n x: 0.265625,\n y: 0.359375,\n },\n {\n x: 0.265625,\n y: 0.359375,\n },\n {\n x: 0.296875,\n y: 0.359375,\n },\n {\n x: 0.296875,\n y: 0.359375,\n },\n {\n x: 0.328125,\n y: 0.359375,\n },\n {\n x: 0.328125,\n y: 0.359375,\n },\n {\n x: 0.359375,\n y: 0.359375,\n },\n {\n x: 0.359375,\n y: 0.359375,\n },\n {\n x: 0.390625,\n y: 0.359375,\n },\n {\n x: 0.390625,\n y: 0.359375,\n },\n {\n x: 0.421875,\n y: 0.359375,\n },\n {\n x: 0.421875,\n y: 0.359375,\n },\n {\n x: 0.453125,\n y: 0.359375,\n },\n {\n x: 0.453125,\n y: 0.359375,\n },\n {\n x: 0.484375,\n y: 0.359375,\n },\n {\n x: 0.484375,\n y: 0.359375,\n },\n {\n x: 0.515625,\n y: 0.359375,\n },\n {\n x: 0.515625,\n y: 0.359375,\n },\n {\n x: 0.546875,\n y: 0.359375,\n },\n {\n x: 0.546875,\n y: 0.359375,\n },\n {\n x: 0.578125,\n y: 0.359375,\n },\n {\n x: 0.578125,\n y: 0.359375,\n },\n {\n x: 0.609375,\n y: 0.359375,\n },\n {\n x: 0.609375,\n y: 0.359375,\n },\n {\n x: 0.640625,\n y: 0.359375,\n },\n {\n x: 0.640625,\n y: 0.359375,\n },\n {\n x: 0.671875,\n y: 0.359375,\n },\n {\n x: 0.671875,\n y: 0.359375,\n },\n {\n x: 0.703125,\n y: 0.359375,\n },\n {\n x: 0.703125,\n y: 0.359375,\n },\n {\n x: 0.734375,\n y: 0.359375,\n },\n {\n x: 0.734375,\n y: 0.359375,\n },\n {\n x: 0.765625,\n y: 0.359375,\n },\n {\n x: 0.765625,\n y: 0.359375,\n },\n {\n x: 0.796875,\n y: 0.359375,\n },\n {\n x: 0.796875,\n y: 0.359375,\n },\n {\n x: 0.828125,\n y: 0.359375,\n },\n {\n x: 0.828125,\n y: 0.359375,\n },\n {\n x: 0.859375,\n y: 0.359375,\n },\n {\n x: 0.859375,\n y: 0.359375,\n },\n {\n x: 0.890625,\n y: 0.359375,\n },\n {\n x: 0.890625,\n y: 0.359375,\n },\n {\n x: 0.921875,\n y: 0.359375,\n },\n {\n x: 0.921875,\n y: 0.359375,\n },\n {\n x: 0.953125,\n y: 0.359375,\n },\n {\n x: 0.953125,\n y: 0.359375,\n },\n {\n x: 0.984375,\n y: 0.359375,\n },\n {\n x: 0.984375,\n y: 0.359375,\n },\n {\n x: 0.015625,\n y: 0.390625,\n },\n {\n x: 0.015625,\n y: 0.390625,\n },\n {\n x: 0.046875,\n y: 0.390625,\n },\n {\n x: 0.046875,\n y: 0.390625,\n },\n {\n x: 0.078125,\n y: 0.390625,\n },\n {\n x: 0.078125,\n y: 0.390625,\n },\n {\n x: 0.109375,\n y: 0.390625,\n },\n {\n x: 0.109375,\n y: 0.390625,\n },\n {\n x: 0.140625,\n y: 0.390625,\n },\n {\n x: 0.140625,\n y: 0.390625,\n },\n {\n x: 0.171875,\n y: 0.390625,\n },\n {\n x: 0.171875,\n y: 0.390625,\n },\n {\n x: 0.203125,\n y: 0.390625,\n },\n {\n x: 0.203125,\n y: 0.390625,\n },\n {\n x: 0.234375,\n y: 0.390625,\n },\n {\n x: 0.234375,\n y: 0.390625,\n },\n {\n x: 0.265625,\n y: 0.390625,\n },\n {\n x: 0.265625,\n y: 0.390625,\n },\n {\n x: 0.296875,\n y: 0.390625,\n },\n {\n x: 0.296875,\n y: 0.390625,\n },\n {\n x: 0.328125,\n y: 0.390625,\n },\n {\n x: 0.328125,\n y: 0.390625,\n },\n {\n x: 0.359375,\n y: 0.390625,\n },\n {\n x: 0.359375,\n y: 0.390625,\n },\n {\n x: 0.390625,\n y: 0.390625,\n },\n {\n x: 0.390625,\n y: 0.390625,\n },\n {\n x: 0.421875,\n y: 0.390625,\n },\n {\n x: 0.421875,\n y: 0.390625,\n },\n {\n x: 0.453125,\n y: 0.390625,\n },\n {\n x: 0.453125,\n y: 0.390625,\n },\n {\n x: 0.484375,\n y: 0.390625,\n },\n {\n x: 0.484375,\n y: 0.390625,\n },\n {\n x: 0.515625,\n y: 0.390625,\n },\n {\n x: 0.515625,\n y: 0.390625,\n },\n {\n x: 0.546875,\n y: 0.390625,\n },\n {\n x: 0.546875,\n y: 0.390625,\n },\n {\n x: 0.578125,\n y: 0.390625,\n },\n {\n x: 0.578125,\n y: 0.390625,\n },\n {\n x: 0.609375,\n y: 0.390625,\n },\n {\n x: 0.609375,\n y: 0.390625,\n },\n {\n x: 0.640625,\n y: 0.390625,\n },\n {\n x: 0.640625,\n y: 0.390625,\n },\n {\n x: 0.671875,\n y: 0.390625,\n },\n {\n x: 0.671875,\n y: 0.390625,\n },\n {\n x: 0.703125,\n y: 0.390625,\n },\n {\n x: 0.703125,\n y: 0.390625,\n },\n {\n x: 0.734375,\n y: 0.390625,\n },\n {\n x: 0.734375,\n y: 0.390625,\n },\n {\n x: 0.765625,\n y: 0.390625,\n },\n {\n x: 0.765625,\n y: 0.390625,\n },\n {\n x: 0.796875,\n y: 0.390625,\n },\n {\n x: 0.796875,\n y: 0.390625,\n },\n {\n x: 0.828125,\n y: 0.390625,\n },\n {\n x: 0.828125,\n y: 0.390625,\n },\n {\n x: 0.859375,\n y: 0.390625,\n },\n {\n x: 0.859375,\n y: 0.390625,\n },\n {\n x: 0.890625,\n y: 0.390625,\n },\n {\n x: 0.890625,\n y: 0.390625,\n },\n {\n x: 0.921875,\n y: 0.390625,\n },\n {\n x: 0.921875,\n y: 0.390625,\n },\n {\n x: 0.953125,\n y: 0.390625,\n },\n {\n x: 0.953125,\n y: 0.390625,\n },\n {\n x: 0.984375,\n y: 0.390625,\n },\n {\n x: 0.984375,\n y: 0.390625,\n },\n {\n x: 0.015625,\n y: 0.421875,\n },\n {\n x: 0.015625,\n y: 0.421875,\n },\n {\n x: 0.046875,\n y: 0.421875,\n },\n {\n x: 0.046875,\n y: 0.421875,\n },\n {\n x: 0.078125,\n y: 0.421875,\n },\n {\n x: 0.078125,\n y: 0.421875,\n },\n {\n x: 0.109375,\n y: 0.421875,\n },\n {\n x: 0.109375,\n y: 0.421875,\n },\n {\n x: 0.140625,\n y: 0.421875,\n },\n {\n x: 0.140625,\n y: 0.421875,\n },\n {\n x: 0.171875,\n y: 0.421875,\n },\n {\n x: 0.171875,\n y: 0.421875,\n },\n {\n x: 0.203125,\n y: 0.421875,\n },\n {\n x: 0.203125,\n y: 0.421875,\n },\n {\n x: 0.234375,\n y: 0.421875,\n },\n {\n x: 0.234375,\n y: 0.421875,\n },\n {\n x: 0.265625,\n y: 0.421875,\n },\n {\n x: 0.265625,\n y: 0.421875,\n },\n {\n x: 0.296875,\n y: 0.421875,\n },\n {\n x: 0.296875,\n y: 0.421875,\n },\n {\n x: 0.328125,\n y: 0.421875,\n },\n {\n x: 0.328125,\n y: 0.421875,\n },\n {\n x: 0.359375,\n y: 0.421875,\n },\n {\n x: 0.359375,\n y: 0.421875,\n },\n {\n x: 0.390625,\n y: 0.421875,\n },\n {\n x: 0.390625,\n y: 0.421875,\n },\n {\n x: 0.421875,\n y: 0.421875,\n },\n {\n x: 0.421875,\n y: 0.421875,\n },\n {\n x: 0.453125,\n y: 0.421875,\n },\n {\n x: 0.453125,\n y: 0.421875,\n },\n {\n x: 0.484375,\n y: 0.421875,\n },\n {\n x: 0.484375,\n y: 0.421875,\n },\n {\n x: 0.515625,\n y: 0.421875,\n },\n {\n x: 0.515625,\n y: 0.421875,\n },\n {\n x: 0.546875,\n y: 0.421875,\n },\n {\n x: 0.546875,\n y: 0.421875,\n },\n {\n x: 0.578125,\n y: 0.421875,\n },\n {\n x: 0.578125,\n y: 0.421875,\n },\n {\n x: 0.609375,\n y: 0.421875,\n },\n {\n x: 0.609375,\n y: 0.421875,\n },\n {\n x: 0.640625,\n y: 0.421875,\n },\n {\n x: 0.640625,\n y: 0.421875,\n },\n {\n x: 0.671875,\n y: 0.421875,\n },\n {\n x: 0.671875,\n y: 0.421875,\n },\n {\n x: 0.703125,\n y: 0.421875,\n },\n {\n x: 0.703125,\n y: 0.421875,\n },\n {\n x: 0.734375,\n y: 0.421875,\n },\n {\n x: 0.734375,\n y: 0.421875,\n },\n {\n x: 0.765625,\n y: 0.421875,\n },\n {\n x: 0.765625,\n y: 0.421875,\n },\n {\n x: 0.796875,\n y: 0.421875,\n },\n {\n x: 0.796875,\n y: 0.421875,\n },\n {\n x: 0.828125,\n y: 0.421875,\n },\n {\n x: 0.828125,\n y: 0.421875,\n },\n {\n x: 0.859375,\n y: 0.421875,\n },\n {\n x: 0.859375,\n y: 0.421875,\n },\n {\n x: 0.890625,\n y: 0.421875,\n },\n {\n x: 0.890625,\n y: 0.421875,\n },\n {\n x: 0.921875,\n y: 0.421875,\n },\n {\n x: 0.921875,\n y: 0.421875,\n },\n {\n x: 0.953125,\n y: 0.421875,\n },\n {\n x: 0.953125,\n y: 0.421875,\n },\n {\n x: 0.984375,\n y: 0.421875,\n },\n {\n x: 0.984375,\n y: 0.421875,\n },\n {\n x: 0.015625,\n y: 0.453125,\n },\n {\n x: 0.015625,\n y: 0.453125,\n },\n {\n x: 0.046875,\n y: 0.453125,\n },\n {\n x: 0.046875,\n y: 0.453125,\n },\n {\n x: 0.078125,\n y: 0.453125,\n },\n {\n x: 0.078125,\n y: 0.453125,\n },\n {\n x: 0.109375,\n y: 0.453125,\n },\n {\n x: 0.109375,\n y: 0.453125,\n },\n {\n x: 0.140625,\n y: 0.453125,\n },\n {\n x: 0.140625,\n y: 0.453125,\n },\n {\n x: 0.171875,\n y: 0.453125,\n },\n {\n x: 0.171875,\n y: 0.453125,\n },\n {\n x: 0.203125,\n y: 0.453125,\n },\n {\n x: 0.203125,\n y: 0.453125,\n },\n {\n x: 0.234375,\n y: 0.453125,\n },\n {\n x: 0.234375,\n y: 0.453125,\n },\n {\n x: 0.265625,\n y: 0.453125,\n },\n {\n x: 0.265625,\n y: 0.453125,\n },\n {\n x: 0.296875,\n y: 0.453125,\n },\n {\n x: 0.296875,\n y: 0.453125,\n },\n {\n x: 0.328125,\n y: 0.453125,\n },\n {\n x: 0.328125,\n y: 0.453125,\n },\n {\n x: 0.359375,\n y: 0.453125,\n },\n {\n x: 0.359375,\n y: 0.453125,\n },\n {\n x: 0.390625,\n y: 0.453125,\n },\n {\n x: 0.390625,\n y: 0.453125,\n },\n {\n x: 0.421875,\n y: 0.453125,\n },\n {\n x: 0.421875,\n y: 0.453125,\n },\n {\n x: 0.453125,\n y: 0.453125,\n },\n {\n x: 0.453125,\n y: 0.453125,\n },\n {\n x: 0.484375,\n y: 0.453125,\n },\n {\n x: 0.484375,\n y: 0.453125,\n },\n {\n x: 0.515625,\n y: 0.453125,\n },\n {\n x: 0.515625,\n y: 0.453125,\n },\n {\n x: 0.546875,\n y: 0.453125,\n },\n {\n x: 0.546875,\n y: 0.453125,\n },\n {\n x: 0.578125,\n y: 0.453125,\n },\n {\n x: 0.578125,\n y: 0.453125,\n },\n {\n x: 0.609375,\n y: 0.453125,\n },\n {\n x: 0.609375,\n y: 0.453125,\n },\n {\n x: 0.640625,\n y: 0.453125,\n },\n {\n x: 0.640625,\n y: 0.453125,\n },\n {\n x: 0.671875,\n y: 0.453125,\n },\n {\n x: 0.671875,\n y: 0.453125,\n },\n {\n x: 0.703125,\n y: 0.453125,\n },\n {\n x: 0.703125,\n y: 0.453125,\n },\n {\n x: 0.734375,\n y: 0.453125,\n },\n {\n x: 0.734375,\n y: 0.453125,\n },\n {\n x: 0.765625,\n y: 0.453125,\n },\n {\n x: 0.765625,\n y: 0.453125,\n },\n {\n x: 0.796875,\n y: 0.453125,\n },\n {\n x: 0.796875,\n y: 0.453125,\n },\n {\n x: 0.828125,\n y: 0.453125,\n },\n {\n x: 0.828125,\n y: 0.453125,\n },\n {\n x: 0.859375,\n y: 0.453125,\n },\n {\n x: 0.859375,\n y: 0.453125,\n },\n {\n x: 0.890625,\n y: 0.453125,\n },\n {\n x: 0.890625,\n y: 0.453125,\n },\n {\n x: 0.921875,\n y: 0.453125,\n },\n {\n x: 0.921875,\n y: 0.453125,\n },\n {\n x: 0.953125,\n y: 0.453125,\n },\n {\n x: 0.953125,\n y: 0.453125,\n },\n {\n x: 0.984375,\n y: 0.453125,\n },\n {\n x: 0.984375,\n y: 0.453125,\n },\n {\n x: 0.015625,\n y: 0.484375,\n },\n {\n x: 0.015625,\n y: 0.484375,\n },\n {\n x: 0.046875,\n y: 0.484375,\n },\n {\n x: 0.046875,\n y: 0.484375,\n },\n {\n x: 0.078125,\n y: 0.484375,\n },\n {\n x: 0.078125,\n y: 0.484375,\n },\n {\n x: 0.109375,\n y: 0.484375,\n },\n {\n x: 0.109375,\n y: 0.484375,\n },\n {\n x: 0.140625,\n y: 0.484375,\n },\n {\n x: 0.140625,\n y: 0.484375,\n },\n {\n x: 0.171875,\n y: 0.484375,\n },\n {\n x: 0.171875,\n y: 0.484375,\n },\n {\n x: 0.203125,\n y: 0.484375,\n },\n {\n x: 0.203125,\n y: 0.484375,\n },\n {\n x: 0.234375,\n y: 0.484375,\n },\n {\n x: 0.234375,\n y: 0.484375,\n },\n {\n x: 0.265625,\n y: 0.484375,\n },\n {\n x: 0.265625,\n y: 0.484375,\n },\n {\n x: 0.296875,\n y: 0.484375,\n },\n {\n x: 0.296875,\n y: 0.484375,\n },\n {\n x: 0.328125,\n y: 0.484375,\n },\n {\n x: 0.328125,\n y: 0.484375,\n },\n {\n x: 0.359375,\n y: 0.484375,\n },\n {\n x: 0.359375,\n y: 0.484375,\n },\n {\n x: 0.390625,\n y: 0.484375,\n },\n {\n x: 0.390625,\n y: 0.484375,\n },\n {\n x: 0.421875,\n y: 0.484375,\n },\n {\n x: 0.421875,\n y: 0.484375,\n },\n {\n x: 0.453125,\n y: 0.484375,\n },\n {\n x: 0.453125,\n y: 0.484375,\n },\n {\n x: 0.484375,\n y: 0.484375,\n },\n {\n x: 0.484375,\n y: 0.484375,\n },\n {\n x: 0.515625,\n y: 0.484375,\n },\n {\n x: 0.515625,\n y: 0.484375,\n },\n {\n x: 0.546875,\n y: 0.484375,\n },\n {\n x: 0.546875,\n y: 0.484375,\n },\n {\n x: 0.578125,\n y: 0.484375,\n },\n {\n x: 0.578125,\n y: 0.484375,\n },\n {\n x: 0.609375,\n y: 0.484375,\n },\n {\n x: 0.609375,\n y: 0.484375,\n },\n {\n x: 0.640625,\n y: 0.484375,\n },\n {\n x: 0.640625,\n y: 0.484375,\n },\n {\n x: 0.671875,\n y: 0.484375,\n },\n {\n x: 0.671875,\n y: 0.484375,\n },\n {\n x: 0.703125,\n y: 0.484375,\n },\n {\n x: 0.703125,\n y: 0.484375,\n },\n {\n x: 0.734375,\n y: 0.484375,\n },\n {\n x: 0.734375,\n y: 0.484375,\n },\n {\n x: 0.765625,\n y: 0.484375,\n },\n {\n x: 0.765625,\n y: 0.484375,\n },\n {\n x: 0.796875,\n y: 0.484375,\n },\n {\n x: 0.796875,\n y: 0.484375,\n },\n {\n x: 0.828125,\n y: 0.484375,\n },\n {\n x: 0.828125,\n y: 0.484375,\n },\n {\n x: 0.859375,\n y: 0.484375,\n },\n {\n x: 0.859375,\n y: 0.484375,\n },\n {\n x: 0.890625,\n y: 0.484375,\n },\n {\n x: 0.890625,\n y: 0.484375,\n },\n {\n x: 0.921875,\n y: 0.484375,\n },\n {\n x: 0.921875,\n y: 0.484375,\n },\n {\n x: 0.953125,\n y: 0.484375,\n },\n {\n x: 0.953125,\n y: 0.484375,\n },\n {\n x: 0.984375,\n y: 0.484375,\n },\n {\n x: 0.984375,\n y: 0.484375,\n },\n {\n x: 0.015625,\n y: 0.515625,\n },\n {\n x: 0.015625,\n y: 0.515625,\n },\n {\n x: 0.046875,\n y: 0.515625,\n },\n {\n x: 0.046875,\n y: 0.515625,\n },\n {\n x: 0.078125,\n y: 0.515625,\n },\n {\n x: 0.078125,\n y: 0.515625,\n },\n {\n x: 0.109375,\n y: 0.515625,\n },\n {\n x: 0.109375,\n y: 0.515625,\n },\n {\n x: 0.140625,\n y: 0.515625,\n },\n {\n x: 0.140625,\n y: 0.515625,\n },\n {\n x: 0.171875,\n y: 0.515625,\n },\n {\n x: 0.171875,\n y: 0.515625,\n },\n {\n x: 0.203125,\n y: 0.515625,\n },\n {\n x: 0.203125,\n y: 0.515625,\n },\n {\n x: 0.234375,\n y: 0.515625,\n },\n {\n x: 0.234375,\n y: 0.515625,\n },\n {\n x: 0.265625,\n y: 0.515625,\n },\n {\n x: 0.265625,\n y: 0.515625,\n },\n {\n x: 0.296875,\n y: 0.515625,\n },\n {\n x: 0.296875,\n y: 0.515625,\n },\n {\n x: 0.328125,\n y: 0.515625,\n },\n {\n x: 0.328125,\n y: 0.515625,\n },\n {\n x: 0.359375,\n y: 0.515625,\n },\n {\n x: 0.359375,\n y: 0.515625,\n },\n {\n x: 0.390625,\n y: 0.515625,\n },\n {\n x: 0.390625,\n y: 0.515625,\n },\n {\n x: 0.421875,\n y: 0.515625,\n },\n {\n x: 0.421875,\n y: 0.515625,\n },\n {\n x: 0.453125,\n y: 0.515625,\n },\n {\n x: 0.453125,\n y: 0.515625,\n },\n {\n x: 0.484375,\n y: 0.515625,\n },\n {\n x: 0.484375,\n y: 0.515625,\n },\n {\n x: 0.515625,\n y: 0.515625,\n },\n {\n x: 0.515625,\n y: 0.515625,\n },\n {\n x: 0.546875,\n y: 0.515625,\n },\n {\n x: 0.546875,\n y: 0.515625,\n },\n {\n x: 0.578125,\n y: 0.515625,\n },\n {\n x: 0.578125,\n y: 0.515625,\n },\n {\n x: 0.609375,\n y: 0.515625,\n },\n {\n x: 0.609375,\n y: 0.515625,\n },\n {\n x: 0.640625,\n y: 0.515625,\n },\n {\n x: 0.640625,\n y: 0.515625,\n },\n {\n x: 0.671875,\n y: 0.515625,\n },\n {\n x: 0.671875,\n y: 0.515625,\n },\n {\n x: 0.703125,\n y: 0.515625,\n },\n {\n x: 0.703125,\n y: 0.515625,\n },\n {\n x: 0.734375,\n y: 0.515625,\n },\n {\n x: 0.734375,\n y: 0.515625,\n },\n {\n x: 0.765625,\n y: 0.515625,\n },\n {\n x: 0.765625,\n y: 0.515625,\n },\n {\n x: 0.796875,\n y: 0.515625,\n },\n {\n x: 0.796875,\n y: 0.515625,\n },\n {\n x: 0.828125,\n y: 0.515625,\n },\n {\n x: 0.828125,\n y: 0.515625,\n },\n {\n x: 0.859375,\n y: 0.515625,\n },\n {\n x: 0.859375,\n y: 0.515625,\n },\n {\n x: 0.890625,\n y: 0.515625,\n },\n {\n x: 0.890625,\n y: 0.515625,\n },\n {\n x: 0.921875,\n y: 0.515625,\n },\n {\n x: 0.921875,\n y: 0.515625,\n },\n {\n x: 0.953125,\n y: 0.515625,\n },\n {\n x: 0.953125,\n y: 0.515625,\n },\n {\n x: 0.984375,\n y: 0.515625,\n },\n {\n x: 0.984375,\n y: 0.515625,\n },\n {\n x: 0.015625,\n y: 0.546875,\n },\n {\n x: 0.015625,\n y: 0.546875,\n },\n {\n x: 0.046875,\n y: 0.546875,\n },\n {\n x: 0.046875,\n y: 0.546875,\n },\n {\n x: 0.078125,\n y: 0.546875,\n },\n {\n x: 0.078125,\n y: 0.546875,\n },\n {\n x: 0.109375,\n y: 0.546875,\n },\n {\n x: 0.109375,\n y: 0.546875,\n },\n {\n x: 0.140625,\n y: 0.546875,\n },\n {\n x: 0.140625,\n y: 0.546875,\n },\n {\n x: 0.171875,\n y: 0.546875,\n },\n {\n x: 0.171875,\n y: 0.546875,\n },\n {\n x: 0.203125,\n y: 0.546875,\n },\n {\n x: 0.203125,\n y: 0.546875,\n },\n {\n x: 0.234375,\n y: 0.546875,\n },\n {\n x: 0.234375,\n y: 0.546875,\n },\n {\n x: 0.265625,\n y: 0.546875,\n },\n {\n x: 0.265625,\n y: 0.546875,\n },\n {\n x: 0.296875,\n y: 0.546875,\n },\n {\n x: 0.296875,\n y: 0.546875,\n },\n {\n x: 0.328125,\n y: 0.546875,\n },\n {\n x: 0.328125,\n y: 0.546875,\n },\n {\n x: 0.359375,\n y: 0.546875,\n },\n {\n x: 0.359375,\n y: 0.546875,\n },\n {\n x: 0.390625,\n y: 0.546875,\n },\n {\n x: 0.390625,\n y: 0.546875,\n },\n {\n x: 0.421875,\n y: 0.546875,\n },\n {\n x: 0.421875,\n y: 0.546875,\n },\n {\n x: 0.453125,\n y: 0.546875,\n },\n {\n x: 0.453125,\n y: 0.546875,\n },\n {\n x: 0.484375,\n y: 0.546875,\n },\n {\n x: 0.484375,\n y: 0.546875,\n },\n {\n x: 0.515625,\n y: 0.546875,\n },\n {\n x: 0.515625,\n y: 0.546875,\n },\n {\n x: 0.546875,\n y: 0.546875,\n },\n {\n x: 0.546875,\n y: 0.546875,\n },\n {\n x: 0.578125,\n y: 0.546875,\n },\n {\n x: 0.578125,\n y: 0.546875,\n },\n {\n x: 0.609375,\n y: 0.546875,\n },\n {\n x: 0.609375,\n y: 0.546875,\n },\n {\n x: 0.640625,\n y: 0.546875,\n },\n {\n x: 0.640625,\n y: 0.546875,\n },\n {\n x: 0.671875,\n y: 0.546875,\n },\n {\n x: 0.671875,\n y: 0.546875,\n },\n {\n x: 0.703125,\n y: 0.546875,\n },\n {\n x: 0.703125,\n y: 0.546875,\n },\n {\n x: 0.734375,\n y: 0.546875,\n },\n {\n x: 0.734375,\n y: 0.546875,\n },\n {\n x: 0.765625,\n y: 0.546875,\n },\n {\n x: 0.765625,\n y: 0.546875,\n },\n {\n x: 0.796875,\n y: 0.546875,\n },\n {\n x: 0.796875,\n y: 0.546875,\n },\n {\n x: 0.828125,\n y: 0.546875,\n },\n {\n x: 0.828125,\n y: 0.546875,\n },\n {\n x: 0.859375,\n y: 0.546875,\n },\n {\n x: 0.859375,\n y: 0.546875,\n },\n {\n x: 0.890625,\n y: 0.546875,\n },\n {\n x: 0.890625,\n y: 0.546875,\n },\n {\n x: 0.921875,\n y: 0.546875,\n },\n {\n x: 0.921875,\n y: 0.546875,\n },\n {\n x: 0.953125,\n y: 0.546875,\n },\n {\n x: 0.953125,\n y: 0.546875,\n },\n {\n x: 0.984375,\n y: 0.546875,\n },\n {\n x: 0.984375,\n y: 0.546875,\n },\n {\n x: 0.015625,\n y: 0.578125,\n },\n {\n x: 0.015625,\n y: 0.578125,\n },\n {\n x: 0.046875,\n y: 0.578125,\n },\n {\n x: 0.046875,\n y: 0.578125,\n },\n {\n x: 0.078125,\n y: 0.578125,\n },\n {\n x: 0.078125,\n y: 0.578125,\n },\n {\n x: 0.109375,\n y: 0.578125,\n },\n {\n x: 0.109375,\n y: 0.578125,\n },\n {\n x: 0.140625,\n y: 0.578125,\n },\n {\n x: 0.140625,\n y: 0.578125,\n },\n {\n x: 0.171875,\n y: 0.578125,\n },\n {\n x: 0.171875,\n y: 0.578125,\n },\n {\n x: 0.203125,\n y: 0.578125,\n },\n {\n x: 0.203125,\n y: 0.578125,\n },\n {\n x: 0.234375,\n y: 0.578125,\n },\n {\n x: 0.234375,\n y: 0.578125,\n },\n {\n x: 0.265625,\n y: 0.578125,\n },\n {\n x: 0.265625,\n y: 0.578125,\n },\n {\n x: 0.296875,\n y: 0.578125,\n },\n {\n x: 0.296875,\n y: 0.578125,\n },\n {\n x: 0.328125,\n y: 0.578125,\n },\n {\n x: 0.328125,\n y: 0.578125,\n },\n {\n x: 0.359375,\n y: 0.578125,\n },\n {\n x: 0.359375,\n y: 0.578125,\n },\n {\n x: 0.390625,\n y: 0.578125,\n },\n {\n x: 0.390625,\n y: 0.578125,\n },\n {\n x: 0.421875,\n y: 0.578125,\n },\n {\n x: 0.421875,\n y: 0.578125,\n },\n {\n x: 0.453125,\n y: 0.578125,\n },\n {\n x: 0.453125,\n y: 0.578125,\n },\n {\n x: 0.484375,\n y: 0.578125,\n },\n {\n x: 0.484375,\n y: 0.578125,\n },\n {\n x: 0.515625,\n y: 0.578125,\n },\n {\n x: 0.515625,\n y: 0.578125,\n },\n {\n x: 0.546875,\n y: 0.578125,\n },\n {\n x: 0.546875,\n y: 0.578125,\n },\n {\n x: 0.578125,\n y: 0.578125,\n },\n {\n x: 0.578125,\n y: 0.578125,\n },\n {\n x: 0.609375,\n y: 0.578125,\n },\n {\n x: 0.609375,\n y: 0.578125,\n },\n {\n x: 0.640625,\n y: 0.578125,\n },\n {\n x: 0.640625,\n y: 0.578125,\n },\n {\n x: 0.671875,\n y: 0.578125,\n },\n {\n x: 0.671875,\n y: 0.578125,\n },\n {\n x: 0.703125,\n y: 0.578125,\n },\n {\n x: 0.703125,\n y: 0.578125,\n },\n {\n x: 0.734375,\n y: 0.578125,\n },\n {\n x: 0.734375,\n y: 0.578125,\n },\n {\n x: 0.765625,\n y: 0.578125,\n },\n {\n x: 0.765625,\n y: 0.578125,\n },\n {\n x: 0.796875,\n y: 0.578125,\n },\n {\n x: 0.796875,\n y: 0.578125,\n },\n {\n x: 0.828125,\n y: 0.578125,\n },\n {\n x: 0.828125,\n y: 0.578125,\n },\n {\n x: 0.859375,\n y: 0.578125,\n },\n {\n x: 0.859375,\n y: 0.578125,\n },\n {\n x: 0.890625,\n y: 0.578125,\n },\n {\n x: 0.890625,\n y: 0.578125,\n },\n {\n x: 0.921875,\n y: 0.578125,\n },\n {\n x: 0.921875,\n y: 0.578125,\n },\n {\n x: 0.953125,\n y: 0.578125,\n },\n {\n x: 0.953125,\n y: 0.578125,\n },\n {\n x: 0.984375,\n y: 0.578125,\n },\n {\n x: 0.984375,\n y: 0.578125,\n },\n {\n x: 0.015625,\n y: 0.609375,\n },\n {\n x: 0.015625,\n y: 0.609375,\n },\n {\n x: 0.046875,\n y: 0.609375,\n },\n {\n x: 0.046875,\n y: 0.609375,\n },\n {\n x: 0.078125,\n y: 0.609375,\n },\n {\n x: 0.078125,\n y: 0.609375,\n },\n {\n x: 0.109375,\n y: 0.609375,\n },\n {\n x: 0.109375,\n y: 0.609375,\n },\n {\n x: 0.140625,\n y: 0.609375,\n },\n {\n x: 0.140625,\n y: 0.609375,\n },\n {\n x: 0.171875,\n y: 0.609375,\n },\n {\n x: 0.171875,\n y: 0.609375,\n },\n {\n x: 0.203125,\n y: 0.609375,\n },\n {\n x: 0.203125,\n y: 0.609375,\n },\n {\n x: 0.234375,\n y: 0.609375,\n },\n {\n x: 0.234375,\n y: 0.609375,\n },\n {\n x: 0.265625,\n y: 0.609375,\n },\n {\n x: 0.265625,\n y: 0.609375,\n },\n {\n x: 0.296875,\n y: 0.609375,\n },\n {\n x: 0.296875,\n y: 0.609375,\n },\n {\n x: 0.328125,\n y: 0.609375,\n },\n {\n x: 0.328125,\n y: 0.609375,\n },\n {\n x: 0.359375,\n y: 0.609375,\n },\n {\n x: 0.359375,\n y: 0.609375,\n },\n {\n x: 0.390625,\n y: 0.609375,\n },\n {\n x: 0.390625,\n y: 0.609375,\n },\n {\n x: 0.421875,\n y: 0.609375,\n },\n {\n x: 0.421875,\n y: 0.609375,\n },\n {\n x: 0.453125,\n y: 0.609375,\n },\n {\n x: 0.453125,\n y: 0.609375,\n },\n {\n x: 0.484375,\n y: 0.609375,\n },\n {\n x: 0.484375,\n y: 0.609375,\n },\n {\n x: 0.515625,\n y: 0.609375,\n },\n {\n x: 0.515625,\n y: 0.609375,\n },\n {\n x: 0.546875,\n y: 0.609375,\n },\n {\n x: 0.546875,\n y: 0.609375,\n },\n {\n x: 0.578125,\n y: 0.609375,\n },\n {\n x: 0.578125,\n y: 0.609375,\n },\n {\n x: 0.609375,\n y: 0.609375,\n },\n {\n x: 0.609375,\n y: 0.609375,\n },\n {\n x: 0.640625,\n y: 0.609375,\n },\n {\n x: 0.640625,\n y: 0.609375,\n },\n {\n x: 0.671875,\n y: 0.609375,\n },\n {\n x: 0.671875,\n y: 0.609375,\n },\n {\n x: 0.703125,\n y: 0.609375,\n },\n {\n x: 0.703125,\n y: 0.609375,\n },\n {\n x: 0.734375,\n y: 0.609375,\n },\n {\n x: 0.734375,\n y: 0.609375,\n },\n {\n x: 0.765625,\n y: 0.609375,\n },\n {\n x: 0.765625,\n y: 0.609375,\n },\n {\n x: 0.796875,\n y: 0.609375,\n },\n {\n x: 0.796875,\n y: 0.609375,\n },\n {\n x: 0.828125,\n y: 0.609375,\n },\n {\n x: 0.828125,\n y: 0.609375,\n },\n {\n x: 0.859375,\n y: 0.609375,\n },\n {\n x: 0.859375,\n y: 0.609375,\n },\n {\n x: 0.890625,\n y: 0.609375,\n },\n {\n x: 0.890625,\n y: 0.609375,\n },\n {\n x: 0.921875,\n y: 0.609375,\n },\n {\n x: 0.921875,\n y: 0.609375,\n },\n {\n x: 0.953125,\n y: 0.609375,\n },\n {\n x: 0.953125,\n y: 0.609375,\n },\n {\n x: 0.984375,\n y: 0.609375,\n },\n {\n x: 0.984375,\n y: 0.609375,\n },\n {\n x: 0.015625,\n y: 0.640625,\n },\n {\n x: 0.015625,\n y: 0.640625,\n },\n {\n x: 0.046875,\n y: 0.640625,\n },\n {\n x: 0.046875,\n y: 0.640625,\n },\n {\n x: 0.078125,\n y: 0.640625,\n },\n {\n x: 0.078125,\n y: 0.640625,\n },\n {\n x: 0.109375,\n y: 0.640625,\n },\n {\n x: 0.109375,\n y: 0.640625,\n },\n {\n x: 0.140625,\n y: 0.640625,\n },\n {\n x: 0.140625,\n y: 0.640625,\n },\n {\n x: 0.171875,\n y: 0.640625,\n },\n {\n x: 0.171875,\n y: 0.640625,\n },\n {\n x: 0.203125,\n y: 0.640625,\n },\n {\n x: 0.203125,\n y: 0.640625,\n },\n {\n x: 0.234375,\n y: 0.640625,\n },\n {\n x: 0.234375,\n y: 0.640625,\n },\n {\n x: 0.265625,\n y: 0.640625,\n },\n {\n x: 0.265625,\n y: 0.640625,\n },\n {\n x: 0.296875,\n y: 0.640625,\n },\n {\n x: 0.296875,\n y: 0.640625,\n },\n {\n x: 0.328125,\n y: 0.640625,\n },\n {\n x: 0.328125,\n y: 0.640625,\n },\n {\n x: 0.359375,\n y: 0.640625,\n },\n {\n x: 0.359375,\n y: 0.640625,\n },\n {\n x: 0.390625,\n y: 0.640625,\n },\n {\n x: 0.390625,\n y: 0.640625,\n },\n {\n x: 0.421875,\n y: 0.640625,\n },\n {\n x: 0.421875,\n y: 0.640625,\n },\n {\n x: 0.453125,\n y: 0.640625,\n },\n {\n x: 0.453125,\n y: 0.640625,\n },\n {\n x: 0.484375,\n y: 0.640625,\n },\n {\n x: 0.484375,\n y: 0.640625,\n },\n {\n x: 0.515625,\n y: 0.640625,\n },\n {\n x: 0.515625,\n y: 0.640625,\n },\n {\n x: 0.546875,\n y: 0.640625,\n },\n {\n x: 0.546875,\n y: 0.640625,\n },\n {\n x: 0.578125,\n y: 0.640625,\n },\n {\n x: 0.578125,\n y: 0.640625,\n },\n {\n x: 0.609375,\n y: 0.640625,\n },\n {\n x: 0.609375,\n y: 0.640625,\n },\n {\n x: 0.640625,\n y: 0.640625,\n },\n {\n x: 0.640625,\n y: 0.640625,\n },\n {\n x: 0.671875,\n y: 0.640625,\n },\n {\n x: 0.671875,\n y: 0.640625,\n },\n {\n x: 0.703125,\n y: 0.640625,\n },\n {\n x: 0.703125,\n y: 0.640625,\n },\n {\n x: 0.734375,\n y: 0.640625,\n },\n {\n x: 0.734375,\n y: 0.640625,\n },\n {\n x: 0.765625,\n y: 0.640625,\n },\n {\n x: 0.765625,\n y: 0.640625,\n },\n {\n x: 0.796875,\n y: 0.640625,\n },\n {\n x: 0.796875,\n y: 0.640625,\n },\n {\n x: 0.828125,\n y: 0.640625,\n },\n {\n x: 0.828125,\n y: 0.640625,\n },\n {\n x: 0.859375,\n y: 0.640625,\n },\n {\n x: 0.859375,\n y: 0.640625,\n },\n {\n x: 0.890625,\n y: 0.640625,\n },\n {\n x: 0.890625,\n y: 0.640625,\n },\n {\n x: 0.921875,\n y: 0.640625,\n },\n {\n x: 0.921875,\n y: 0.640625,\n },\n {\n x: 0.953125,\n y: 0.640625,\n },\n {\n x: 0.953125,\n y: 0.640625,\n },\n {\n x: 0.984375,\n y: 0.640625,\n },\n {\n x: 0.984375,\n y: 0.640625,\n },\n {\n x: 0.015625,\n y: 0.671875,\n },\n {\n x: 0.015625,\n y: 0.671875,\n },\n {\n x: 0.046875,\n y: 0.671875,\n },\n {\n x: 0.046875,\n y: 0.671875,\n },\n {\n x: 0.078125,\n y: 0.671875,\n },\n {\n x: 0.078125,\n y: 0.671875,\n },\n {\n x: 0.109375,\n y: 0.671875,\n },\n {\n x: 0.109375,\n y: 0.671875,\n },\n {\n x: 0.140625,\n y: 0.671875,\n },\n {\n x: 0.140625,\n y: 0.671875,\n },\n {\n x: 0.171875,\n y: 0.671875,\n },\n {\n x: 0.171875,\n y: 0.671875,\n },\n {\n x: 0.203125,\n y: 0.671875,\n },\n {\n x: 0.203125,\n y: 0.671875,\n },\n {\n x: 0.234375,\n y: 0.671875,\n },\n {\n x: 0.234375,\n y: 0.671875,\n },\n {\n x: 0.265625,\n y: 0.671875,\n },\n {\n x: 0.265625,\n y: 0.671875,\n },\n {\n x: 0.296875,\n y: 0.671875,\n },\n {\n x: 0.296875,\n y: 0.671875,\n },\n {\n x: 0.328125,\n y: 0.671875,\n },\n {\n x: 0.328125,\n y: 0.671875,\n },\n {\n x: 0.359375,\n y: 0.671875,\n },\n {\n x: 0.359375,\n y: 0.671875,\n },\n {\n x: 0.390625,\n y: 0.671875,\n },\n {\n x: 0.390625,\n y: 0.671875,\n },\n {\n x: 0.421875,\n y: 0.671875,\n },\n {\n x: 0.421875,\n y: 0.671875,\n },\n {\n x: 0.453125,\n y: 0.671875,\n },\n {\n x: 0.453125,\n y: 0.671875,\n },\n {\n x: 0.484375,\n y: 0.671875,\n },\n {\n x: 0.484375,\n y: 0.671875,\n },\n {\n x: 0.515625,\n y: 0.671875,\n },\n {\n x: 0.515625,\n y: 0.671875,\n },\n {\n x: 0.546875,\n y: 0.671875,\n },\n {\n x: 0.546875,\n y: 0.671875,\n },\n {\n x: 0.578125,\n y: 0.671875,\n },\n {\n x: 0.578125,\n y: 0.671875,\n },\n {\n x: 0.609375,\n y: 0.671875,\n },\n {\n x: 0.609375,\n y: 0.671875,\n },\n {\n x: 0.640625,\n y: 0.671875,\n },\n {\n x: 0.640625,\n y: 0.671875,\n },\n {\n x: 0.671875,\n y: 0.671875,\n },\n {\n x: 0.671875,\n y: 0.671875,\n },\n {\n x: 0.703125,\n y: 0.671875,\n },\n {\n x: 0.703125,\n y: 0.671875,\n },\n {\n x: 0.734375,\n y: 0.671875,\n },\n {\n x: 0.734375,\n y: 0.671875,\n },\n {\n x: 0.765625,\n y: 0.671875,\n },\n {\n x: 0.765625,\n y: 0.671875,\n },\n {\n x: 0.796875,\n y: 0.671875,\n },\n {\n x: 0.796875,\n y: 0.671875,\n },\n {\n x: 0.828125,\n y: 0.671875,\n },\n {\n x: 0.828125,\n y: 0.671875,\n },\n {\n x: 0.859375,\n y: 0.671875,\n },\n {\n x: 0.859375,\n y: 0.671875,\n },\n {\n x: 0.890625,\n y: 0.671875,\n },\n {\n x: 0.890625,\n y: 0.671875,\n },\n {\n x: 0.921875,\n y: 0.671875,\n },\n {\n x: 0.921875,\n y: 0.671875,\n },\n {\n x: 0.953125,\n y: 0.671875,\n },\n {\n x: 0.953125,\n y: 0.671875,\n },\n {\n x: 0.984375,\n y: 0.671875,\n },\n {\n x: 0.984375,\n y: 0.671875,\n },\n {\n x: 0.015625,\n y: 0.703125,\n },\n {\n x: 0.015625,\n y: 0.703125,\n },\n {\n x: 0.046875,\n y: 0.703125,\n },\n {\n x: 0.046875,\n y: 0.703125,\n },\n {\n x: 0.078125,\n y: 0.703125,\n },\n {\n x: 0.078125,\n y: 0.703125,\n },\n {\n x: 0.109375,\n y: 0.703125,\n },\n {\n x: 0.109375,\n y: 0.703125,\n },\n {\n x: 0.140625,\n y: 0.703125,\n },\n {\n x: 0.140625,\n y: 0.703125,\n },\n {\n x: 0.171875,\n y: 0.703125,\n },\n {\n x: 0.171875,\n y: 0.703125,\n },\n {\n x: 0.203125,\n y: 0.703125,\n },\n {\n x: 0.203125,\n y: 0.703125,\n },\n {\n x: 0.234375,\n y: 0.703125,\n },\n {\n x: 0.234375,\n y: 0.703125,\n },\n {\n x: 0.265625,\n y: 0.703125,\n },\n {\n x: 0.265625,\n y: 0.703125,\n },\n {\n x: 0.296875,\n y: 0.703125,\n },\n {\n x: 0.296875,\n y: 0.703125,\n },\n {\n x: 0.328125,\n y: 0.703125,\n },\n {\n x: 0.328125,\n y: 0.703125,\n },\n {\n x: 0.359375,\n y: 0.703125,\n },\n {\n x: 0.359375,\n y: 0.703125,\n },\n {\n x: 0.390625,\n y: 0.703125,\n },\n {\n x: 0.390625,\n y: 0.703125,\n },\n {\n x: 0.421875,\n y: 0.703125,\n },\n {\n x: 0.421875,\n y: 0.703125,\n },\n {\n x: 0.453125,\n y: 0.703125,\n },\n {\n x: 0.453125,\n y: 0.703125,\n },\n {\n x: 0.484375,\n y: 0.703125,\n },\n {\n x: 0.484375,\n y: 0.703125,\n },\n {\n x: 0.515625,\n y: 0.703125,\n },\n {\n x: 0.515625,\n y: 0.703125,\n },\n {\n x: 0.546875,\n y: 0.703125,\n },\n {\n x: 0.546875,\n y: 0.703125,\n },\n {\n x: 0.578125,\n y: 0.703125,\n },\n {\n x: 0.578125,\n y: 0.703125,\n },\n {\n x: 0.609375,\n y: 0.703125,\n },\n {\n x: 0.609375,\n y: 0.703125,\n },\n {\n x: 0.640625,\n y: 0.703125,\n },\n {\n x: 0.640625,\n y: 0.703125,\n },\n {\n x: 0.671875,\n y: 0.703125,\n },\n {\n x: 0.671875,\n y: 0.703125,\n },\n {\n x: 0.703125,\n y: 0.703125,\n },\n {\n x: 0.703125,\n y: 0.703125,\n },\n {\n x: 0.734375,\n y: 0.703125,\n },\n {\n x: 0.734375,\n y: 0.703125,\n },\n {\n x: 0.765625,\n y: 0.703125,\n },\n {\n x: 0.765625,\n y: 0.703125,\n },\n {\n x: 0.796875,\n y: 0.703125,\n },\n {\n x: 0.796875,\n y: 0.703125,\n },\n {\n x: 0.828125,\n y: 0.703125,\n },\n {\n x: 0.828125,\n y: 0.703125,\n },\n {\n x: 0.859375,\n y: 0.703125,\n },\n {\n x: 0.859375,\n y: 0.703125,\n },\n {\n x: 0.890625,\n y: 0.703125,\n },\n {\n x: 0.890625,\n y: 0.703125,\n },\n {\n x: 0.921875,\n y: 0.703125,\n },\n {\n x: 0.921875,\n y: 0.703125,\n },\n {\n x: 0.953125,\n y: 0.703125,\n },\n {\n x: 0.953125,\n y: 0.703125,\n },\n {\n x: 0.984375,\n y: 0.703125,\n },\n {\n x: 0.984375,\n y: 0.703125,\n },\n {\n x: 0.015625,\n y: 0.734375,\n },\n {\n x: 0.015625,\n y: 0.734375,\n },\n {\n x: 0.046875,\n y: 0.734375,\n },\n {\n x: 0.046875,\n y: 0.734375,\n },\n {\n x: 0.078125,\n y: 0.734375,\n },\n {\n x: 0.078125,\n y: 0.734375,\n },\n {\n x: 0.109375,\n y: 0.734375,\n },\n {\n x: 0.109375,\n y: 0.734375,\n },\n {\n x: 0.140625,\n y: 0.734375,\n },\n {\n x: 0.140625,\n y: 0.734375,\n },\n {\n x: 0.171875,\n y: 0.734375,\n },\n {\n x: 0.171875,\n y: 0.734375,\n },\n {\n x: 0.203125,\n y: 0.734375,\n },\n {\n x: 0.203125,\n y: 0.734375,\n },\n {\n x: 0.234375,\n y: 0.734375,\n },\n {\n x: 0.234375,\n y: 0.734375,\n },\n {\n x: 0.265625,\n y: 0.734375,\n },\n {\n x: 0.265625,\n y: 0.734375,\n },\n {\n x: 0.296875,\n y: 0.734375,\n },\n {\n x: 0.296875,\n y: 0.734375,\n },\n {\n x: 0.328125,\n y: 0.734375,\n },\n {\n x: 0.328125,\n y: 0.734375,\n },\n {\n x: 0.359375,\n y: 0.734375,\n },\n {\n x: 0.359375,\n y: 0.734375,\n },\n {\n x: 0.390625,\n y: 0.734375,\n },\n {\n x: 0.390625,\n y: 0.734375,\n },\n {\n x: 0.421875,\n y: 0.734375,\n },\n {\n x: 0.421875,\n y: 0.734375,\n },\n {\n x: 0.453125,\n y: 0.734375,\n },\n {\n x: 0.453125,\n y: 0.734375,\n },\n {\n x: 0.484375,\n y: 0.734375,\n },\n {\n x: 0.484375,\n y: 0.734375,\n },\n {\n x: 0.515625,\n y: 0.734375,\n },\n {\n x: 0.515625,\n y: 0.734375,\n },\n {\n x: 0.546875,\n y: 0.734375,\n },\n {\n x: 0.546875,\n y: 0.734375,\n },\n {\n x: 0.578125,\n y: 0.734375,\n },\n {\n x: 0.578125,\n y: 0.734375,\n },\n {\n x: 0.609375,\n y: 0.734375,\n },\n {\n x: 0.609375,\n y: 0.734375,\n },\n {\n x: 0.640625,\n y: 0.734375,\n },\n {\n x: 0.640625,\n y: 0.734375,\n },\n {\n x: 0.671875,\n y: 0.734375,\n },\n {\n x: 0.671875,\n y: 0.734375,\n },\n {\n x: 0.703125,\n y: 0.734375,\n },\n {\n x: 0.703125,\n y: 0.734375,\n },\n {\n x: 0.734375,\n y: 0.734375,\n },\n {\n x: 0.734375,\n y: 0.734375,\n },\n {\n x: 0.765625,\n y: 0.734375,\n },\n {\n x: 0.765625,\n y: 0.734375,\n },\n {\n x: 0.796875,\n y: 0.734375,\n },\n {\n x: 0.796875,\n y: 0.734375,\n },\n {\n x: 0.828125,\n y: 0.734375,\n },\n {\n x: 0.828125,\n y: 0.734375,\n },\n {\n x: 0.859375,\n y: 0.734375,\n },\n {\n x: 0.859375,\n y: 0.734375,\n },\n {\n x: 0.890625,\n y: 0.734375,\n },\n {\n x: 0.890625,\n y: 0.734375,\n },\n {\n x: 0.921875,\n y: 0.734375,\n },\n {\n x: 0.921875,\n y: 0.734375,\n },\n {\n x: 0.953125,\n y: 0.734375,\n },\n {\n x: 0.953125,\n y: 0.734375,\n },\n {\n x: 0.984375,\n y: 0.734375,\n },\n {\n x: 0.984375,\n y: 0.734375,\n },\n {\n x: 0.015625,\n y: 0.765625,\n },\n {\n x: 0.015625,\n y: 0.765625,\n },\n {\n x: 0.046875,\n y: 0.765625,\n },\n {\n x: 0.046875,\n y: 0.765625,\n },\n {\n x: 0.078125,\n y: 0.765625,\n },\n {\n x: 0.078125,\n y: 0.765625,\n },\n {\n x: 0.109375,\n y: 0.765625,\n },\n {\n x: 0.109375,\n y: 0.765625,\n },\n {\n x: 0.140625,\n y: 0.765625,\n },\n {\n x: 0.140625,\n y: 0.765625,\n },\n {\n x: 0.171875,\n y: 0.765625,\n },\n {\n x: 0.171875,\n y: 0.765625,\n },\n {\n x: 0.203125,\n y: 0.765625,\n },\n {\n x: 0.203125,\n y: 0.765625,\n },\n {\n x: 0.234375,\n y: 0.765625,\n },\n {\n x: 0.234375,\n y: 0.765625,\n },\n {\n x: 0.265625,\n y: 0.765625,\n },\n {\n x: 0.265625,\n y: 0.765625,\n },\n {\n x: 0.296875,\n y: 0.765625,\n },\n {\n x: 0.296875,\n y: 0.765625,\n },\n {\n x: 0.328125,\n y: 0.765625,\n },\n {\n x: 0.328125,\n y: 0.765625,\n },\n {\n x: 0.359375,\n y: 0.765625,\n },\n {\n x: 0.359375,\n y: 0.765625,\n },\n {\n x: 0.390625,\n y: 0.765625,\n },\n {\n x: 0.390625,\n y: 0.765625,\n },\n {\n x: 0.421875,\n y: 0.765625,\n },\n {\n x: 0.421875,\n y: 0.765625,\n },\n {\n x: 0.453125,\n y: 0.765625,\n },\n {\n x: 0.453125,\n y: 0.765625,\n },\n {\n x: 0.484375,\n y: 0.765625,\n },\n {\n x: 0.484375,\n y: 0.765625,\n },\n {\n x: 0.515625,\n y: 0.765625,\n },\n {\n x: 0.515625,\n y: 0.765625,\n },\n {\n x: 0.546875,\n y: 0.765625,\n },\n {\n x: 0.546875,\n y: 0.765625,\n },\n {\n x: 0.578125,\n y: 0.765625,\n },\n {\n x: 0.578125,\n y: 0.765625,\n },\n {\n x: 0.609375,\n y: 0.765625,\n },\n {\n x: 0.609375,\n y: 0.765625,\n },\n {\n x: 0.640625,\n y: 0.765625,\n },\n {\n x: 0.640625,\n y: 0.765625,\n },\n {\n x: 0.671875,\n y: 0.765625,\n },\n {\n x: 0.671875,\n y: 0.765625,\n },\n {\n x: 0.703125,\n y: 0.765625,\n },\n {\n x: 0.703125,\n y: 0.765625,\n },\n {\n x: 0.734375,\n y: 0.765625,\n },\n {\n x: 0.734375,\n y: 0.765625,\n },\n {\n x: 0.765625,\n y: 0.765625,\n },\n {\n x: 0.765625,\n y: 0.765625,\n },\n {\n x: 0.796875,\n y: 0.765625,\n },\n {\n x: 0.796875,\n y: 0.765625,\n },\n {\n x: 0.828125,\n y: 0.765625,\n },\n {\n x: 0.828125,\n y: 0.765625,\n },\n {\n x: 0.859375,\n y: 0.765625,\n },\n {\n x: 0.859375,\n y: 0.765625,\n },\n {\n x: 0.890625,\n y: 0.765625,\n },\n {\n x: 0.890625,\n y: 0.765625,\n },\n {\n x: 0.921875,\n y: 0.765625,\n },\n {\n x: 0.921875,\n y: 0.765625,\n },\n {\n x: 0.953125,\n y: 0.765625,\n },\n {\n x: 0.953125,\n y: 0.765625,\n },\n {\n x: 0.984375,\n y: 0.765625,\n },\n {\n x: 0.984375,\n y: 0.765625,\n },\n {\n x: 0.015625,\n y: 0.796875,\n },\n {\n x: 0.015625,\n y: 0.796875,\n },\n {\n x: 0.046875,\n y: 0.796875,\n },\n {\n x: 0.046875,\n y: 0.796875,\n },\n {\n x: 0.078125,\n y: 0.796875,\n },\n {\n x: 0.078125,\n y: 0.796875,\n },\n {\n x: 0.109375,\n y: 0.796875,\n },\n {\n x: 0.109375,\n y: 0.796875,\n },\n {\n x: 0.140625,\n y: 0.796875,\n },\n {\n x: 0.140625,\n y: 0.796875,\n },\n {\n x: 0.171875,\n y: 0.796875,\n },\n {\n x: 0.171875,\n y: 0.796875,\n },\n {\n x: 0.203125,\n y: 0.796875,\n },\n {\n x: 0.203125,\n y: 0.796875,\n },\n {\n x: 0.234375,\n y: 0.796875,\n },\n {\n x: 0.234375,\n y: 0.796875,\n },\n {\n x: 0.265625,\n y: 0.796875,\n },\n {\n x: 0.265625,\n y: 0.796875,\n },\n {\n x: 0.296875,\n y: 0.796875,\n },\n {\n x: 0.296875,\n y: 0.796875,\n },\n {\n x: 0.328125,\n y: 0.796875,\n },\n {\n x: 0.328125,\n y: 0.796875,\n },\n {\n x: 0.359375,\n y: 0.796875,\n },\n {\n x: 0.359375,\n y: 0.796875,\n },\n {\n x: 0.390625,\n y: 0.796875,\n },\n {\n x: 0.390625,\n y: 0.796875,\n },\n {\n x: 0.421875,\n y: 0.796875,\n },\n {\n x: 0.421875,\n y: 0.796875,\n },\n {\n x: 0.453125,\n y: 0.796875,\n },\n {\n x: 0.453125,\n y: 0.796875,\n },\n {\n x: 0.484375,\n y: 0.796875,\n },\n {\n x: 0.484375,\n y: 0.796875,\n },\n {\n x: 0.515625,\n y: 0.796875,\n },\n {\n x: 0.515625,\n y: 0.796875,\n },\n {\n x: 0.546875,\n y: 0.796875,\n },\n {\n x: 0.546875,\n y: 0.796875,\n },\n {\n x: 0.578125,\n y: 0.796875,\n },\n {\n x: 0.578125,\n y: 0.796875,\n },\n {\n x: 0.609375,\n y: 0.796875,\n },\n {\n x: 0.609375,\n y: 0.796875,\n },\n {\n x: 0.640625,\n y: 0.796875,\n },\n {\n x: 0.640625,\n y: 0.796875,\n },\n {\n x: 0.671875,\n y: 0.796875,\n },\n {\n x: 0.671875,\n y: 0.796875,\n },\n {\n x: 0.703125,\n y: 0.796875,\n },\n {\n x: 0.703125,\n y: 0.796875,\n },\n {\n x: 0.734375,\n y: 0.796875,\n },\n {\n x: 0.734375,\n y: 0.796875,\n },\n {\n x: 0.765625,\n y: 0.796875,\n },\n {\n x: 0.765625,\n y: 0.796875,\n },\n {\n x: 0.796875,\n y: 0.796875,\n },\n {\n x: 0.796875,\n y: 0.796875,\n },\n {\n x: 0.828125,\n y: 0.796875,\n },\n {\n x: 0.828125,\n y: 0.796875,\n },\n {\n x: 0.859375,\n y: 0.796875,\n },\n {\n x: 0.859375,\n y: 0.796875,\n },\n {\n x: 0.890625,\n y: 0.796875,\n },\n {\n x: 0.890625,\n y: 0.796875,\n },\n {\n x: 0.921875,\n y: 0.796875,\n },\n {\n x: 0.921875,\n y: 0.796875,\n },\n {\n x: 0.953125,\n y: 0.796875,\n },\n {\n x: 0.953125,\n y: 0.796875,\n },\n {\n x: 0.984375,\n y: 0.796875,\n },\n {\n x: 0.984375,\n y: 0.796875,\n },\n {\n x: 0.015625,\n y: 0.828125,\n },\n {\n x: 0.015625,\n y: 0.828125,\n },\n {\n x: 0.046875,\n y: 0.828125,\n },\n {\n x: 0.046875,\n y: 0.828125,\n },\n {\n x: 0.078125,\n y: 0.828125,\n },\n {\n x: 0.078125,\n y: 0.828125,\n },\n {\n x: 0.109375,\n y: 0.828125,\n },\n {\n x: 0.109375,\n y: 0.828125,\n },\n {\n x: 0.140625,\n y: 0.828125,\n },\n {\n x: 0.140625,\n y: 0.828125,\n },\n {\n x: 0.171875,\n y: 0.828125,\n },\n {\n x: 0.171875,\n y: 0.828125,\n },\n {\n x: 0.203125,\n y: 0.828125,\n },\n {\n x: 0.203125,\n y: 0.828125,\n },\n {\n x: 0.234375,\n y: 0.828125,\n },\n {\n x: 0.234375,\n y: 0.828125,\n },\n {\n x: 0.265625,\n y: 0.828125,\n },\n {\n x: 0.265625,\n y: 0.828125,\n },\n {\n x: 0.296875,\n y: 0.828125,\n },\n {\n x: 0.296875,\n y: 0.828125,\n },\n {\n x: 0.328125,\n y: 0.828125,\n },\n {\n x: 0.328125,\n y: 0.828125,\n },\n {\n x: 0.359375,\n y: 0.828125,\n },\n {\n x: 0.359375,\n y: 0.828125,\n },\n {\n x: 0.390625,\n y: 0.828125,\n },\n {\n x: 0.390625,\n y: 0.828125,\n },\n {\n x: 0.421875,\n y: 0.828125,\n },\n {\n x: 0.421875,\n y: 0.828125,\n },\n {\n x: 0.453125,\n y: 0.828125,\n },\n {\n x: 0.453125,\n y: 0.828125,\n },\n {\n x: 0.484375,\n y: 0.828125,\n },\n {\n x: 0.484375,\n y: 0.828125,\n },\n {\n x: 0.515625,\n y: 0.828125,\n },\n {\n x: 0.515625,\n y: 0.828125,\n },\n {\n x: 0.546875,\n y: 0.828125,\n },\n {\n x: 0.546875,\n y: 0.828125,\n },\n {\n x: 0.578125,\n y: 0.828125,\n },\n {\n x: 0.578125,\n y: 0.828125,\n },\n {\n x: 0.609375,\n y: 0.828125,\n },\n {\n x: 0.609375,\n y: 0.828125,\n },\n {\n x: 0.640625,\n y: 0.828125,\n },\n {\n x: 0.640625,\n y: 0.828125,\n },\n {\n x: 0.671875,\n y: 0.828125,\n },\n {\n x: 0.671875,\n y: 0.828125,\n },\n {\n x: 0.703125,\n y: 0.828125,\n },\n {\n x: 0.703125,\n y: 0.828125,\n },\n {\n x: 0.734375,\n y: 0.828125,\n },\n {\n x: 0.734375,\n y: 0.828125,\n },\n {\n x: 0.765625,\n y: 0.828125,\n },\n {\n x: 0.765625,\n y: 0.828125,\n },\n {\n x: 0.796875,\n y: 0.828125,\n },\n {\n x: 0.796875,\n y: 0.828125,\n },\n {\n x: 0.828125,\n y: 0.828125,\n },\n {\n x: 0.828125,\n y: 0.828125,\n },\n {\n x: 0.859375,\n y: 0.828125,\n },\n {\n x: 0.859375,\n y: 0.828125,\n },\n {\n x: 0.890625,\n y: 0.828125,\n },\n {\n x: 0.890625,\n y: 0.828125,\n },\n {\n x: 0.921875,\n y: 0.828125,\n },\n {\n x: 0.921875,\n y: 0.828125,\n },\n {\n x: 0.953125,\n y: 0.828125,\n },\n {\n x: 0.953125,\n y: 0.828125,\n },\n {\n x: 0.984375,\n y: 0.828125,\n },\n {\n x: 0.984375,\n y: 0.828125,\n },\n {\n x: 0.015625,\n y: 0.859375,\n },\n {\n x: 0.015625,\n y: 0.859375,\n },\n {\n x: 0.046875,\n y: 0.859375,\n },\n {\n x: 0.046875,\n y: 0.859375,\n },\n {\n x: 0.078125,\n y: 0.859375,\n },\n {\n x: 0.078125,\n y: 0.859375,\n },\n {\n x: 0.109375,\n y: 0.859375,\n },\n {\n x: 0.109375,\n y: 0.859375,\n },\n {\n x: 0.140625,\n y: 0.859375,\n },\n {\n x: 0.140625,\n y: 0.859375,\n },\n {\n x: 0.171875,\n y: 0.859375,\n },\n {\n x: 0.171875,\n y: 0.859375,\n },\n {\n x: 0.203125,\n y: 0.859375,\n },\n {\n x: 0.203125,\n y: 0.859375,\n },\n {\n x: 0.234375,\n y: 0.859375,\n },\n {\n x: 0.234375,\n y: 0.859375,\n },\n {\n x: 0.265625,\n y: 0.859375,\n },\n {\n x: 0.265625,\n y: 0.859375,\n },\n {\n x: 0.296875,\n y: 0.859375,\n },\n {\n x: 0.296875,\n y: 0.859375,\n },\n {\n x: 0.328125,\n y: 0.859375,\n },\n {\n x: 0.328125,\n y: 0.859375,\n },\n {\n x: 0.359375,\n y: 0.859375,\n },\n {\n x: 0.359375,\n y: 0.859375,\n },\n {\n x: 0.390625,\n y: 0.859375,\n },\n {\n x: 0.390625,\n y: 0.859375,\n },\n {\n x: 0.421875,\n y: 0.859375,\n },\n {\n x: 0.421875,\n y: 0.859375,\n },\n {\n x: 0.453125,\n y: 0.859375,\n },\n {\n x: 0.453125,\n y: 0.859375,\n },\n {\n x: 0.484375,\n y: 0.859375,\n },\n {\n x: 0.484375,\n y: 0.859375,\n },\n {\n x: 0.515625,\n y: 0.859375,\n },\n {\n x: 0.515625,\n y: 0.859375,\n },\n {\n x: 0.546875,\n y: 0.859375,\n },\n {\n x: 0.546875,\n y: 0.859375,\n },\n {\n x: 0.578125,\n y: 0.859375,\n },\n {\n x: 0.578125,\n y: 0.859375,\n },\n {\n x: 0.609375,\n y: 0.859375,\n },\n {\n x: 0.609375,\n y: 0.859375,\n },\n {\n x: 0.640625,\n y: 0.859375,\n },\n {\n x: 0.640625,\n y: 0.859375,\n },\n {\n x: 0.671875,\n y: 0.859375,\n },\n {\n x: 0.671875,\n y: 0.859375,\n },\n {\n x: 0.703125,\n y: 0.859375,\n },\n {\n x: 0.703125,\n y: 0.859375,\n },\n {\n x: 0.734375,\n y: 0.859375,\n },\n {\n x: 0.734375,\n y: 0.859375,\n },\n {\n x: 0.765625,\n y: 0.859375,\n },\n {\n x: 0.765625,\n y: 0.859375,\n },\n {\n x: 0.796875,\n y: 0.859375,\n },\n {\n x: 0.796875,\n y: 0.859375,\n },\n {\n x: 0.828125,\n y: 0.859375,\n },\n {\n x: 0.828125,\n y: 0.859375,\n },\n {\n x: 0.859375,\n y: 0.859375,\n },\n {\n x: 0.859375,\n y: 0.859375,\n },\n {\n x: 0.890625,\n y: 0.859375,\n },\n {\n x: 0.890625,\n y: 0.859375,\n },\n {\n x: 0.921875,\n y: 0.859375,\n },\n {\n x: 0.921875,\n y: 0.859375,\n },\n {\n x: 0.953125,\n y: 0.859375,\n },\n {\n x: 0.953125,\n y: 0.859375,\n },\n {\n x: 0.984375,\n y: 0.859375,\n },\n {\n x: 0.984375,\n y: 0.859375,\n },\n {\n x: 0.015625,\n y: 0.890625,\n },\n {\n x: 0.015625,\n y: 0.890625,\n },\n {\n x: 0.046875,\n y: 0.890625,\n },\n {\n x: 0.046875,\n y: 0.890625,\n },\n {\n x: 0.078125,\n y: 0.890625,\n },\n {\n x: 0.078125,\n y: 0.890625,\n },\n {\n x: 0.109375,\n y: 0.890625,\n },\n {\n x: 0.109375,\n y: 0.890625,\n },\n {\n x: 0.140625,\n y: 0.890625,\n },\n {\n x: 0.140625,\n y: 0.890625,\n },\n {\n x: 0.171875,\n y: 0.890625,\n },\n {\n x: 0.171875,\n y: 0.890625,\n },\n {\n x: 0.203125,\n y: 0.890625,\n },\n {\n x: 0.203125,\n y: 0.890625,\n },\n {\n x: 0.234375,\n y: 0.890625,\n },\n {\n x: 0.234375,\n y: 0.890625,\n },\n {\n x: 0.265625,\n y: 0.890625,\n },\n {\n x: 0.265625,\n y: 0.890625,\n },\n {\n x: 0.296875,\n y: 0.890625,\n },\n {\n x: 0.296875,\n y: 0.890625,\n },\n {\n x: 0.328125,\n y: 0.890625,\n },\n {\n x: 0.328125,\n y: 0.890625,\n },\n {\n x: 0.359375,\n y: 0.890625,\n },\n {\n x: 0.359375,\n y: 0.890625,\n },\n {\n x: 0.390625,\n y: 0.890625,\n },\n {\n x: 0.390625,\n y: 0.890625,\n },\n {\n x: 0.421875,\n y: 0.890625,\n },\n {\n x: 0.421875,\n y: 0.890625,\n },\n {\n x: 0.453125,\n y: 0.890625,\n },\n {\n x: 0.453125,\n y: 0.890625,\n },\n {\n x: 0.484375,\n y: 0.890625,\n },\n {\n x: 0.484375,\n y: 0.890625,\n },\n {\n x: 0.515625,\n y: 0.890625,\n },\n {\n x: 0.515625,\n y: 0.890625,\n },\n {\n x: 0.546875,\n y: 0.890625,\n },\n {\n x: 0.546875,\n y: 0.890625,\n },\n {\n x: 0.578125,\n y: 0.890625,\n },\n {\n x: 0.578125,\n y: 0.890625,\n },\n {\n x: 0.609375,\n y: 0.890625,\n },\n {\n x: 0.609375,\n y: 0.890625,\n },\n {\n x: 0.640625,\n y: 0.890625,\n },\n {\n x: 0.640625,\n y: 0.890625,\n },\n {\n x: 0.671875,\n y: 0.890625,\n },\n {\n x: 0.671875,\n y: 0.890625,\n },\n {\n x: 0.703125,\n y: 0.890625,\n },\n {\n x: 0.703125,\n y: 0.890625,\n },\n {\n x: 0.734375,\n y: 0.890625,\n },\n {\n x: 0.734375,\n y: 0.890625,\n },\n {\n x: 0.765625,\n y: 0.890625,\n },\n {\n x: 0.765625,\n y: 0.890625,\n },\n {\n x: 0.796875,\n y: 0.890625,\n },\n {\n x: 0.796875,\n y: 0.890625,\n },\n {\n x: 0.828125,\n y: 0.890625,\n },\n {\n x: 0.828125,\n y: 0.890625,\n },\n {\n x: 0.859375,\n y: 0.890625,\n },\n {\n x: 0.859375,\n y: 0.890625,\n },\n {\n x: 0.890625,\n y: 0.890625,\n },\n {\n x: 0.890625,\n y: 0.890625,\n },\n {\n x: 0.921875,\n y: 0.890625,\n },\n {\n x: 0.921875,\n y: 0.890625,\n },\n {\n x: 0.953125,\n y: 0.890625,\n },\n {\n x: 0.953125,\n y: 0.890625,\n },\n {\n x: 0.984375,\n y: 0.890625,\n },\n {\n x: 0.984375,\n y: 0.890625,\n },\n {\n x: 0.015625,\n y: 0.921875,\n },\n {\n x: 0.015625,\n y: 0.921875,\n },\n {\n x: 0.046875,\n y: 0.921875,\n },\n {\n x: 0.046875,\n y: 0.921875,\n },\n {\n x: 0.078125,\n y: 0.921875,\n },\n {\n x: 0.078125,\n y: 0.921875,\n },\n {\n x: 0.109375,\n y: 0.921875,\n },\n {\n x: 0.109375,\n y: 0.921875,\n },\n {\n x: 0.140625,\n y: 0.921875,\n },\n {\n x: 0.140625,\n y: 0.921875,\n },\n {\n x: 0.171875,\n y: 0.921875,\n },\n {\n x: 0.171875,\n y: 0.921875,\n },\n {\n x: 0.203125,\n y: 0.921875,\n },\n {\n x: 0.203125,\n y: 0.921875,\n },\n {\n x: 0.234375,\n y: 0.921875,\n },\n {\n x: 0.234375,\n y: 0.921875,\n },\n {\n x: 0.265625,\n y: 0.921875,\n },\n {\n x: 0.265625,\n y: 0.921875,\n },\n {\n x: 0.296875,\n y: 0.921875,\n },\n {\n x: 0.296875,\n y: 0.921875,\n },\n {\n x: 0.328125,\n y: 0.921875,\n },\n {\n x: 0.328125,\n y: 0.921875,\n },\n {\n x: 0.359375,\n y: 0.921875,\n },\n {\n x: 0.359375,\n y: 0.921875,\n },\n {\n x: 0.390625,\n y: 0.921875,\n },\n {\n x: 0.390625,\n y: 0.921875,\n },\n {\n x: 0.421875,\n y: 0.921875,\n },\n {\n x: 0.421875,\n y: 0.921875,\n },\n {\n x: 0.453125,\n y: 0.921875,\n },\n {\n x: 0.453125,\n y: 0.921875,\n },\n {\n x: 0.484375,\n y: 0.921875,\n },\n {\n x: 0.484375,\n y: 0.921875,\n },\n {\n x: 0.515625,\n y: 0.921875,\n },\n {\n x: 0.515625,\n y: 0.921875,\n },\n {\n x: 0.546875,\n y: 0.921875,\n },\n {\n x: 0.546875,\n y: 0.921875,\n },\n {\n x: 0.578125,\n y: 0.921875,\n },\n {\n x: 0.578125,\n y: 0.921875,\n },\n {\n x: 0.609375,\n y: 0.921875,\n },\n {\n x: 0.609375,\n y: 0.921875,\n },\n {\n x: 0.640625,\n y: 0.921875,\n },\n {\n x: 0.640625,\n y: 0.921875,\n },\n {\n x: 0.671875,\n y: 0.921875,\n },\n {\n x: 0.671875,\n y: 0.921875,\n },\n {\n x: 0.703125,\n y: 0.921875,\n },\n {\n x: 0.703125,\n y: 0.921875,\n },\n {\n x: 0.734375,\n y: 0.921875,\n },\n {\n x: 0.734375,\n y: 0.921875,\n },\n {\n x: 0.765625,\n y: 0.921875,\n },\n {\n x: 0.765625,\n y: 0.921875,\n },\n {\n x: 0.796875,\n y: 0.921875,\n },\n {\n x: 0.796875,\n y: 0.921875,\n },\n {\n x: 0.828125,\n y: 0.921875,\n },\n {\n x: 0.828125,\n y: 0.921875,\n },\n {\n x: 0.859375,\n y: 0.921875,\n },\n {\n x: 0.859375,\n y: 0.921875,\n },\n {\n x: 0.890625,\n y: 0.921875,\n },\n {\n x: 0.890625,\n y: 0.921875,\n },\n {\n x: 0.921875,\n y: 0.921875,\n },\n {\n x: 0.921875,\n y: 0.921875,\n },\n {\n x: 0.953125,\n y: 0.921875,\n },\n {\n x: 0.953125,\n y: 0.921875,\n },\n {\n x: 0.984375,\n y: 0.921875,\n },\n {\n x: 0.984375,\n y: 0.921875,\n },\n {\n x: 0.015625,\n y: 0.953125,\n },\n {\n x: 0.015625,\n y: 0.953125,\n },\n {\n x: 0.046875,\n y: 0.953125,\n },\n {\n x: 0.046875,\n y: 0.953125,\n },\n {\n x: 0.078125,\n y: 0.953125,\n },\n {\n x: 0.078125,\n y: 0.953125,\n },\n {\n x: 0.109375,\n y: 0.953125,\n },\n {\n x: 0.109375,\n y: 0.953125,\n },\n {\n x: 0.140625,\n y: 0.953125,\n },\n {\n x: 0.140625,\n y: 0.953125,\n },\n {\n x: 0.171875,\n y: 0.953125,\n },\n {\n x: 0.171875,\n y: 0.953125,\n },\n {\n x: 0.203125,\n y: 0.953125,\n },\n {\n x: 0.203125,\n y: 0.953125,\n },\n {\n x: 0.234375,\n y: 0.953125,\n },\n {\n x: 0.234375,\n y: 0.953125,\n },\n {\n x: 0.265625,\n y: 0.953125,\n },\n {\n x: 0.265625,\n y: 0.953125,\n },\n {\n x: 0.296875,\n y: 0.953125,\n },\n {\n x: 0.296875,\n y: 0.953125,\n },\n {\n x: 0.328125,\n y: 0.953125,\n },\n {\n x: 0.328125,\n y: 0.953125,\n },\n {\n x: 0.359375,\n y: 0.953125,\n },\n {\n x: 0.359375,\n y: 0.953125,\n },\n {\n x: 0.390625,\n y: 0.953125,\n },\n {\n x: 0.390625,\n y: 0.953125,\n },\n {\n x: 0.421875,\n y: 0.953125,\n },\n {\n x: 0.421875,\n y: 0.953125,\n },\n {\n x: 0.453125,\n y: 0.953125,\n },\n {\n x: 0.453125,\n y: 0.953125,\n },\n {\n x: 0.484375,\n y: 0.953125,\n },\n {\n x: 0.484375,\n y: 0.953125,\n },\n {\n x: 0.515625,\n y: 0.953125,\n },\n {\n x: 0.515625,\n y: 0.953125,\n },\n {\n x: 0.546875,\n y: 0.953125,\n },\n {\n x: 0.546875,\n y: 0.953125,\n },\n {\n x: 0.578125,\n y: 0.953125,\n },\n {\n x: 0.578125,\n y: 0.953125,\n },\n {\n x: 0.609375,\n y: 0.953125,\n },\n {\n x: 0.609375,\n y: 0.953125,\n },\n {\n x: 0.640625,\n y: 0.953125,\n },\n {\n x: 0.640625,\n y: 0.953125,\n },\n {\n x: 0.671875,\n y: 0.953125,\n },\n {\n x: 0.671875,\n y: 0.953125,\n },\n {\n x: 0.703125,\n y: 0.953125,\n },\n {\n x: 0.703125,\n y: 0.953125,\n },\n {\n x: 0.734375,\n y: 0.953125,\n },\n {\n x: 0.734375,\n y: 0.953125,\n },\n {\n x: 0.765625,\n y: 0.953125,\n },\n {\n x: 0.765625,\n y: 0.953125,\n },\n {\n x: 0.796875,\n y: 0.953125,\n },\n {\n x: 0.796875,\n y: 0.953125,\n },\n {\n x: 0.828125,\n y: 0.953125,\n },\n {\n x: 0.828125,\n y: 0.953125,\n },\n {\n x: 0.859375,\n y: 0.953125,\n },\n {\n x: 0.859375,\n y: 0.953125,\n },\n {\n x: 0.890625,\n y: 0.953125,\n },\n {\n x: 0.890625,\n y: 0.953125,\n },\n {\n x: 0.921875,\n y: 0.953125,\n },\n {\n x: 0.921875,\n y: 0.953125,\n },\n {\n x: 0.953125,\n y: 0.953125,\n },\n {\n x: 0.953125,\n y: 0.953125,\n },\n {\n x: 0.984375,\n y: 0.953125,\n },\n {\n x: 0.984375,\n y: 0.953125,\n },\n {\n x: 0.015625,\n y: 0.984375,\n },\n {\n x: 0.015625,\n y: 0.984375,\n },\n {\n x: 0.046875,\n y: 0.984375,\n },\n {\n x: 0.046875,\n y: 0.984375,\n },\n {\n x: 0.078125,\n y: 0.984375,\n },\n {\n x: 0.078125,\n y: 0.984375,\n },\n {\n x: 0.109375,\n y: 0.984375,\n },\n {\n x: 0.109375,\n y: 0.984375,\n },\n {\n x: 0.140625,\n y: 0.984375,\n },\n {\n x: 0.140625,\n y: 0.984375,\n },\n {\n x: 0.171875,\n y: 0.984375,\n },\n {\n x: 0.171875,\n y: 0.984375,\n },\n {\n x: 0.203125,\n y: 0.984375,\n },\n {\n x: 0.203125,\n y: 0.984375,\n },\n {\n x: 0.234375,\n y: 0.984375,\n },\n {\n x: 0.234375,\n y: 0.984375,\n },\n {\n x: 0.265625,\n y: 0.984375,\n },\n {\n x: 0.265625,\n y: 0.984375,\n },\n {\n x: 0.296875,\n y: 0.984375,\n },\n {\n x: 0.296875,\n y: 0.984375,\n },\n {\n x: 0.328125,\n y: 0.984375,\n },\n {\n x: 0.328125,\n y: 0.984375,\n },\n {\n x: 0.359375,\n y: 0.984375,\n },\n {\n x: 0.359375,\n y: 0.984375,\n },\n {\n x: 0.390625,\n y: 0.984375,\n },\n {\n x: 0.390625,\n y: 0.984375,\n },\n {\n x: 0.421875,\n y: 0.984375,\n },\n {\n x: 0.421875,\n y: 0.984375,\n },\n {\n x: 0.453125,\n y: 0.984375,\n },\n {\n x: 0.453125,\n y: 0.984375,\n },\n {\n x: 0.484375,\n y: 0.984375,\n },\n {\n x: 0.484375,\n y: 0.984375,\n },\n {\n x: 0.515625,\n y: 0.984375,\n },\n {\n x: 0.515625,\n y: 0.984375,\n },\n {\n x: 0.546875,\n y: 0.984375,\n },\n {\n x: 0.546875,\n y: 0.984375,\n },\n {\n x: 0.578125,\n y: 0.984375,\n },\n {\n x: 0.578125,\n y: 0.984375,\n },\n {\n x: 0.609375,\n y: 0.984375,\n },\n {\n x: 0.609375,\n y: 0.984375,\n },\n {\n x: 0.640625,\n y: 0.984375,\n },\n {\n x: 0.640625,\n y: 0.984375,\n },\n {\n x: 0.671875,\n y: 0.984375,\n },\n {\n x: 0.671875,\n y: 0.984375,\n },\n {\n x: 0.703125,\n y: 0.984375,\n },\n {\n x: 0.703125,\n y: 0.984375,\n },\n {\n x: 0.734375,\n y: 0.984375,\n },\n {\n x: 0.734375,\n y: 0.984375,\n },\n {\n x: 0.765625,\n y: 0.984375,\n },\n {\n x: 0.765625,\n y: 0.984375,\n },\n {\n x: 0.796875,\n y: 0.984375,\n },\n {\n x: 0.796875,\n y: 0.984375,\n },\n {\n x: 0.828125,\n y: 0.984375,\n },\n {\n x: 0.828125,\n y: 0.984375,\n },\n {\n x: 0.859375,\n y: 0.984375,\n },\n {\n x: 0.859375,\n y: 0.984375,\n },\n {\n x: 0.890625,\n y: 0.984375,\n },\n {\n x: 0.890625,\n y: 0.984375,\n },\n {\n x: 0.921875,\n y: 0.984375,\n },\n {\n x: 0.921875,\n y: 0.984375,\n },\n {\n x: 0.953125,\n y: 0.984375,\n },\n {\n x: 0.953125,\n y: 0.984375,\n },\n {\n x: 0.984375,\n y: 0.984375,\n },\n {\n x: 0.984375,\n y: 0.984375,\n },\n {\n x: 0.03125,\n y: 0.03125,\n },\n {\n x: 0.03125,\n y: 0.03125,\n },\n {\n x: 0.09375,\n y: 0.03125,\n },\n {\n x: 0.09375,\n y: 0.03125,\n },\n {\n x: 0.15625,\n y: 0.03125,\n },\n {\n x: 0.15625,\n y: 0.03125,\n },\n {\n x: 0.21875,\n y: 0.03125,\n },\n {\n x: 0.21875,\n y: 0.03125,\n },\n {\n x: 0.28125,\n y: 0.03125,\n },\n {\n x: 0.28125,\n y: 0.03125,\n },\n {\n x: 0.34375,\n y: 0.03125,\n },\n {\n x: 0.34375,\n y: 0.03125,\n },\n {\n x: 0.40625,\n y: 0.03125,\n },\n {\n x: 0.40625,\n y: 0.03125,\n },\n {\n x: 0.46875,\n y: 0.03125,\n },\n {\n x: 0.46875,\n y: 0.03125,\n },\n {\n x: 0.53125,\n y: 0.03125,\n },\n {\n x: 0.53125,\n y: 0.03125,\n },\n {\n x: 0.59375,\n y: 0.03125,\n },\n {\n x: 0.59375,\n y: 0.03125,\n },\n {\n x: 0.65625,\n y: 0.03125,\n },\n {\n x: 0.65625,\n y: 0.03125,\n },\n {\n x: 0.71875,\n y: 0.03125,\n },\n {\n x: 0.71875,\n y: 0.03125,\n },\n {\n x: 0.78125,\n y: 0.03125,\n },\n {\n x: 0.78125,\n y: 0.03125,\n },\n {\n x: 0.84375,\n y: 0.03125,\n },\n {\n x: 0.84375,\n y: 0.03125,\n },\n {\n x: 0.90625,\n y: 0.03125,\n },\n {\n x: 0.90625,\n y: 0.03125,\n },\n {\n x: 0.96875,\n y: 0.03125,\n },\n {\n x: 0.96875,\n y: 0.03125,\n },\n {\n x: 0.03125,\n y: 0.09375,\n },\n {\n x: 0.03125,\n y: 0.09375,\n },\n {\n x: 0.09375,\n y: 0.09375,\n },\n {\n x: 0.09375,\n y: 0.09375,\n },\n {\n x: 0.15625,\n y: 0.09375,\n },\n {\n x: 0.15625,\n y: 0.09375,\n },\n {\n x: 0.21875,\n y: 0.09375,\n },\n {\n x: 0.21875,\n y: 0.09375,\n },\n {\n x: 0.28125,\n y: 0.09375,\n },\n {\n x: 0.28125,\n y: 0.09375,\n },\n {\n x: 0.34375,\n y: 0.09375,\n },\n {\n x: 0.34375,\n y: 0.09375,\n },\n {\n x: 0.40625,\n y: 0.09375,\n },\n {\n x: 0.40625,\n y: 0.09375,\n },\n {\n x: 0.46875,\n y: 0.09375,\n },\n {\n x: 0.46875,\n y: 0.09375,\n },\n {\n x: 0.53125,\n y: 0.09375,\n },\n {\n x: 0.53125,\n y: 0.09375,\n },\n {\n x: 0.59375,\n y: 0.09375,\n },\n {\n x: 0.59375,\n y: 0.09375,\n },\n {\n x: 0.65625,\n y: 0.09375,\n },\n {\n x: 0.65625,\n y: 0.09375,\n },\n {\n x: 0.71875,\n y: 0.09375,\n },\n {\n x: 0.71875,\n y: 0.09375,\n },\n {\n x: 0.78125,\n y: 0.09375,\n },\n {\n x: 0.78125,\n y: 0.09375,\n },\n {\n x: 0.84375,\n y: 0.09375,\n },\n {\n x: 0.84375,\n y: 0.09375,\n },\n {\n x: 0.90625,\n y: 0.09375,\n },\n {\n x: 0.90625,\n y: 0.09375,\n },\n {\n x: 0.96875,\n y: 0.09375,\n },\n {\n x: 0.96875,\n y: 0.09375,\n },\n {\n x: 0.03125,\n y: 0.15625,\n },\n {\n x: 0.03125,\n y: 0.15625,\n },\n {\n x: 0.09375,\n y: 0.15625,\n },\n {\n x: 0.09375,\n y: 0.15625,\n },\n {\n x: 0.15625,\n y: 0.15625,\n },\n {\n x: 0.15625,\n y: 0.15625,\n },\n {\n x: 0.21875,\n y: 0.15625,\n },\n {\n x: 0.21875,\n y: 0.15625,\n },\n {\n x: 0.28125,\n y: 0.15625,\n },\n {\n x: 0.28125,\n y: 0.15625,\n },\n {\n x: 0.34375,\n y: 0.15625,\n },\n {\n x: 0.34375,\n y: 0.15625,\n },\n {\n x: 0.40625,\n y: 0.15625,\n },\n {\n x: 0.40625,\n y: 0.15625,\n },\n {\n x: 0.46875,\n y: 0.15625,\n },\n {\n x: 0.46875,\n y: 0.15625,\n },\n {\n x: 0.53125,\n y: 0.15625,\n },\n {\n x: 0.53125,\n y: 0.15625,\n },\n {\n x: 0.59375,\n y: 0.15625,\n },\n {\n x: 0.59375,\n y: 0.15625,\n },\n {\n x: 0.65625,\n y: 0.15625,\n },\n {\n x: 0.65625,\n y: 0.15625,\n },\n {\n x: 0.71875,\n y: 0.15625,\n },\n {\n x: 0.71875,\n y: 0.15625,\n },\n {\n x: 0.78125,\n y: 0.15625,\n },\n {\n x: 0.78125,\n y: 0.15625,\n },\n {\n x: 0.84375,\n y: 0.15625,\n },\n {\n x: 0.84375,\n y: 0.15625,\n },\n {\n x: 0.90625,\n y: 0.15625,\n },\n {\n x: 0.90625,\n y: 0.15625,\n },\n {\n x: 0.96875,\n y: 0.15625,\n },\n {\n x: 0.96875,\n y: 0.15625,\n },\n {\n x: 0.03125,\n y: 0.21875,\n },\n {\n x: 0.03125,\n y: 0.21875,\n },\n {\n x: 0.09375,\n y: 0.21875,\n },\n {\n x: 0.09375,\n y: 0.21875,\n },\n {\n x: 0.15625,\n y: 0.21875,\n },\n {\n x: 0.15625,\n y: 0.21875,\n },\n {\n x: 0.21875,\n y: 0.21875,\n },\n {\n x: 0.21875,\n y: 0.21875,\n },\n {\n x: 0.28125,\n y: 0.21875,\n },\n {\n x: 0.28125,\n y: 0.21875,\n },\n {\n x: 0.34375,\n y: 0.21875,\n },\n {\n x: 0.34375,\n y: 0.21875,\n },\n {\n x: 0.40625,\n y: 0.21875,\n },\n {\n x: 0.40625,\n y: 0.21875,\n },\n {\n x: 0.46875,\n y: 0.21875,\n },\n {\n x: 0.46875,\n y: 0.21875,\n },\n {\n x: 0.53125,\n y: 0.21875,\n },\n {\n x: 0.53125,\n y: 0.21875,\n },\n {\n x: 0.59375,\n y: 0.21875,\n },\n {\n x: 0.59375,\n y: 0.21875,\n },\n {\n x: 0.65625,\n y: 0.21875,\n },\n {\n x: 0.65625,\n y: 0.21875,\n },\n {\n x: 0.71875,\n y: 0.21875,\n },\n {\n x: 0.71875,\n y: 0.21875,\n },\n {\n x: 0.78125,\n y: 0.21875,\n },\n {\n x: 0.78125,\n y: 0.21875,\n },\n {\n x: 0.84375,\n y: 0.21875,\n },\n {\n x: 0.84375,\n y: 0.21875,\n },\n {\n x: 0.90625,\n y: 0.21875,\n },\n {\n x: 0.90625,\n y: 0.21875,\n },\n {\n x: 0.96875,\n y: 0.21875,\n },\n {\n x: 0.96875,\n y: 0.21875,\n },\n {\n x: 0.03125,\n y: 0.28125,\n },\n {\n x: 0.03125,\n y: 0.28125,\n },\n {\n x: 0.09375,\n y: 0.28125,\n },\n {\n x: 0.09375,\n y: 0.28125,\n },\n {\n x: 0.15625,\n y: 0.28125,\n },\n {\n x: 0.15625,\n y: 0.28125,\n },\n {\n x: 0.21875,\n y: 0.28125,\n },\n {\n x: 0.21875,\n y: 0.28125,\n },\n {\n x: 0.28125,\n y: 0.28125,\n },\n {\n x: 0.28125,\n y: 0.28125,\n },\n {\n x: 0.34375,\n y: 0.28125,\n },\n {\n x: 0.34375,\n y: 0.28125,\n },\n {\n x: 0.40625,\n y: 0.28125,\n },\n {\n x: 0.40625,\n y: 0.28125,\n },\n {\n x: 0.46875,\n y: 0.28125,\n },\n {\n x: 0.46875,\n y: 0.28125,\n },\n {\n x: 0.53125,\n y: 0.28125,\n },\n {\n x: 0.53125,\n y: 0.28125,\n },\n {\n x: 0.59375,\n y: 0.28125,\n },\n {\n x: 0.59375,\n y: 0.28125,\n },\n {\n x: 0.65625,\n y: 0.28125,\n },\n {\n x: 0.65625,\n y: 0.28125,\n },\n {\n x: 0.71875,\n y: 0.28125,\n },\n {\n x: 0.71875,\n y: 0.28125,\n },\n {\n x: 0.78125,\n y: 0.28125,\n },\n {\n x: 0.78125,\n y: 0.28125,\n },\n {\n x: 0.84375,\n y: 0.28125,\n },\n {\n x: 0.84375,\n y: 0.28125,\n },\n {\n x: 0.90625,\n y: 0.28125,\n },\n {\n x: 0.90625,\n y: 0.28125,\n },\n {\n x: 0.96875,\n y: 0.28125,\n },\n {\n x: 0.96875,\n y: 0.28125,\n },\n {\n x: 0.03125,\n y: 0.34375,\n },\n {\n x: 0.03125,\n y: 0.34375,\n },\n {\n x: 0.09375,\n y: 0.34375,\n },\n {\n x: 0.09375,\n y: 0.34375,\n },\n {\n x: 0.15625,\n y: 0.34375,\n },\n {\n x: 0.15625,\n y: 0.34375,\n },\n {\n x: 0.21875,\n y: 0.34375,\n },\n {\n x: 0.21875,\n y: 0.34375,\n },\n {\n x: 0.28125,\n y: 0.34375,\n },\n {\n x: 0.28125,\n y: 0.34375,\n },\n {\n x: 0.34375,\n y: 0.34375,\n },\n {\n x: 0.34375,\n y: 0.34375,\n },\n {\n x: 0.40625,\n y: 0.34375,\n },\n {\n x: 0.40625,\n y: 0.34375,\n },\n {\n x: 0.46875,\n y: 0.34375,\n },\n {\n x: 0.46875,\n y: 0.34375,\n },\n {\n x: 0.53125,\n y: 0.34375,\n },\n {\n x: 0.53125,\n y: 0.34375,\n },\n {\n x: 0.59375,\n y: 0.34375,\n },\n {\n x: 0.59375,\n y: 0.34375,\n },\n {\n x: 0.65625,\n y: 0.34375,\n },\n {\n x: 0.65625,\n y: 0.34375,\n },\n {\n x: 0.71875,\n y: 0.34375,\n },\n {\n x: 0.71875,\n y: 0.34375,\n },\n {\n x: 0.78125,\n y: 0.34375,\n },\n {\n x: 0.78125,\n y: 0.34375,\n },\n {\n x: 0.84375,\n y: 0.34375,\n },\n {\n x: 0.84375,\n y: 0.34375,\n },\n {\n x: 0.90625,\n y: 0.34375,\n },\n {\n x: 0.90625,\n y: 0.34375,\n },\n {\n x: 0.96875,\n y: 0.34375,\n },\n {\n x: 0.96875,\n y: 0.34375,\n },\n {\n x: 0.03125,\n y: 0.40625,\n },\n {\n x: 0.03125,\n y: 0.40625,\n },\n {\n x: 0.09375,\n y: 0.40625,\n },\n {\n x: 0.09375,\n y: 0.40625,\n },\n {\n x: 0.15625,\n y: 0.40625,\n },\n {\n x: 0.15625,\n y: 0.40625,\n },\n {\n x: 0.21875,\n y: 0.40625,\n },\n {\n x: 0.21875,\n y: 0.40625,\n },\n {\n x: 0.28125,\n y: 0.40625,\n },\n {\n x: 0.28125,\n y: 0.40625,\n },\n {\n x: 0.34375,\n y: 0.40625,\n },\n {\n x: 0.34375,\n y: 0.40625,\n },\n {\n x: 0.40625,\n y: 0.40625,\n },\n {\n x: 0.40625,\n y: 0.40625,\n },\n {\n x: 0.46875,\n y: 0.40625,\n },\n {\n x: 0.46875,\n y: 0.40625,\n },\n {\n x: 0.53125,\n y: 0.40625,\n },\n {\n x: 0.53125,\n y: 0.40625,\n },\n {\n x: 0.59375,\n y: 0.40625,\n },\n {\n x: 0.59375,\n y: 0.40625,\n },\n {\n x: 0.65625,\n y: 0.40625,\n },\n {\n x: 0.65625,\n y: 0.40625,\n },\n {\n x: 0.71875,\n y: 0.40625,\n },\n {\n x: 0.71875,\n y: 0.40625,\n },\n {\n x: 0.78125,\n y: 0.40625,\n },\n {\n x: 0.78125,\n y: 0.40625,\n },\n {\n x: 0.84375,\n y: 0.40625,\n },\n {\n x: 0.84375,\n y: 0.40625,\n },\n {\n x: 0.90625,\n y: 0.40625,\n },\n {\n x: 0.90625,\n y: 0.40625,\n },\n {\n x: 0.96875,\n y: 0.40625,\n },\n {\n x: 0.96875,\n y: 0.40625,\n },\n {\n x: 0.03125,\n y: 0.46875,\n },\n {\n x: 0.03125,\n y: 0.46875,\n },\n {\n x: 0.09375,\n y: 0.46875,\n },\n {\n x: 0.09375,\n y: 0.46875,\n },\n {\n x: 0.15625,\n y: 0.46875,\n },\n {\n x: 0.15625,\n y: 0.46875,\n },\n {\n x: 0.21875,\n y: 0.46875,\n },\n {\n x: 0.21875,\n y: 0.46875,\n },\n {\n x: 0.28125,\n y: 0.46875,\n },\n {\n x: 0.28125,\n y: 0.46875,\n },\n {\n x: 0.34375,\n y: 0.46875,\n },\n {\n x: 0.34375,\n y: 0.46875,\n },\n {\n x: 0.40625,\n y: 0.46875,\n },\n {\n x: 0.40625,\n y: 0.46875,\n },\n {\n x: 0.46875,\n y: 0.46875,\n },\n {\n x: 0.46875,\n y: 0.46875,\n },\n {\n x: 0.53125,\n y: 0.46875,\n },\n {\n x: 0.53125,\n y: 0.46875,\n },\n {\n x: 0.59375,\n y: 0.46875,\n },\n {\n x: 0.59375,\n y: 0.46875,\n },\n {\n x: 0.65625,\n y: 0.46875,\n },\n {\n x: 0.65625,\n y: 0.46875,\n },\n {\n x: 0.71875,\n y: 0.46875,\n },\n {\n x: 0.71875,\n y: 0.46875,\n },\n {\n x: 0.78125,\n y: 0.46875,\n },\n {\n x: 0.78125,\n y: 0.46875,\n },\n {\n x: 0.84375,\n y: 0.46875,\n },\n {\n x: 0.84375,\n y: 0.46875,\n },\n {\n x: 0.90625,\n y: 0.46875,\n },\n {\n x: 0.90625,\n y: 0.46875,\n },\n {\n x: 0.96875,\n y: 0.46875,\n },\n {\n x: 0.96875,\n y: 0.46875,\n },\n {\n x: 0.03125,\n y: 0.53125,\n },\n {\n x: 0.03125,\n y: 0.53125,\n },\n {\n x: 0.09375,\n y: 0.53125,\n },\n {\n x: 0.09375,\n y: 0.53125,\n },\n {\n x: 0.15625,\n y: 0.53125,\n },\n {\n x: 0.15625,\n y: 0.53125,\n },\n {\n x: 0.21875,\n y: 0.53125,\n },\n {\n x: 0.21875,\n y: 0.53125,\n },\n {\n x: 0.28125,\n y: 0.53125,\n },\n {\n x: 0.28125,\n y: 0.53125,\n },\n {\n x: 0.34375,\n y: 0.53125,\n },\n {\n x: 0.34375,\n y: 0.53125,\n },\n {\n x: 0.40625,\n y: 0.53125,\n },\n {\n x: 0.40625,\n y: 0.53125,\n },\n {\n x: 0.46875,\n y: 0.53125,\n },\n {\n x: 0.46875,\n y: 0.53125,\n },\n {\n x: 0.53125,\n y: 0.53125,\n },\n {\n x: 0.53125,\n y: 0.53125,\n },\n {\n x: 0.59375,\n y: 0.53125,\n },\n {\n x: 0.59375,\n y: 0.53125,\n },\n {\n x: 0.65625,\n y: 0.53125,\n },\n {\n x: 0.65625,\n y: 0.53125,\n },\n {\n x: 0.71875,\n y: 0.53125,\n },\n {\n x: 0.71875,\n y: 0.53125,\n },\n {\n x: 0.78125,\n y: 0.53125,\n },\n {\n x: 0.78125,\n y: 0.53125,\n },\n {\n x: 0.84375,\n y: 0.53125,\n },\n {\n x: 0.84375,\n y: 0.53125,\n },\n {\n x: 0.90625,\n y: 0.53125,\n },\n {\n x: 0.90625,\n y: 0.53125,\n },\n {\n x: 0.96875,\n y: 0.53125,\n },\n {\n x: 0.96875,\n y: 0.53125,\n },\n {\n x: 0.03125,\n y: 0.59375,\n },\n {\n x: 0.03125,\n y: 0.59375,\n },\n {\n x: 0.09375,\n y: 0.59375,\n },\n {\n x: 0.09375,\n y: 0.59375,\n },\n {\n x: 0.15625,\n y: 0.59375,\n },\n {\n x: 0.15625,\n y: 0.59375,\n },\n {\n x: 0.21875,\n y: 0.59375,\n },\n {\n x: 0.21875,\n y: 0.59375,\n },\n {\n x: 0.28125,\n y: 0.59375,\n },\n {\n x: 0.28125,\n y: 0.59375,\n },\n {\n x: 0.34375,\n y: 0.59375,\n },\n {\n x: 0.34375,\n y: 0.59375,\n },\n {\n x: 0.40625,\n y: 0.59375,\n },\n {\n x: 0.40625,\n y: 0.59375,\n },\n {\n x: 0.46875,\n y: 0.59375,\n },\n {\n x: 0.46875,\n y: 0.59375,\n },\n {\n x: 0.53125,\n y: 0.59375,\n },\n {\n x: 0.53125,\n y: 0.59375,\n },\n {\n x: 0.59375,\n y: 0.59375,\n },\n {\n x: 0.59375,\n y: 0.59375,\n },\n {\n x: 0.65625,\n y: 0.59375,\n },\n {\n x: 0.65625,\n y: 0.59375,\n },\n {\n x: 0.71875,\n y: 0.59375,\n },\n {\n x: 0.71875,\n y: 0.59375,\n },\n {\n x: 0.78125,\n y: 0.59375,\n },\n {\n x: 0.78125,\n y: 0.59375,\n },\n {\n x: 0.84375,\n y: 0.59375,\n },\n {\n x: 0.84375,\n y: 0.59375,\n },\n {\n x: 0.90625,\n y: 0.59375,\n },\n {\n x: 0.90625,\n y: 0.59375,\n },\n {\n x: 0.96875,\n y: 0.59375,\n },\n {\n x: 0.96875,\n y: 0.59375,\n },\n {\n x: 0.03125,\n y: 0.65625,\n },\n {\n x: 0.03125,\n y: 0.65625,\n },\n {\n x: 0.09375,\n y: 0.65625,\n },\n {\n x: 0.09375,\n y: 0.65625,\n },\n {\n x: 0.15625,\n y: 0.65625,\n },\n {\n x: 0.15625,\n y: 0.65625,\n },\n {\n x: 0.21875,\n y: 0.65625,\n },\n {\n x: 0.21875,\n y: 0.65625,\n },\n {\n x: 0.28125,\n y: 0.65625,\n },\n {\n x: 0.28125,\n y: 0.65625,\n },\n {\n x: 0.34375,\n y: 0.65625,\n },\n {\n x: 0.34375,\n y: 0.65625,\n },\n {\n x: 0.40625,\n y: 0.65625,\n },\n {\n x: 0.40625,\n y: 0.65625,\n },\n {\n x: 0.46875,\n y: 0.65625,\n },\n {\n x: 0.46875,\n y: 0.65625,\n },\n {\n x: 0.53125,\n y: 0.65625,\n },\n {\n x: 0.53125,\n y: 0.65625,\n },\n {\n x: 0.59375,\n y: 0.65625,\n },\n {\n x: 0.59375,\n y: 0.65625,\n },\n {\n x: 0.65625,\n y: 0.65625,\n },\n {\n x: 0.65625,\n y: 0.65625,\n },\n {\n x: 0.71875,\n y: 0.65625,\n },\n {\n x: 0.71875,\n y: 0.65625,\n },\n {\n x: 0.78125,\n y: 0.65625,\n },\n {\n x: 0.78125,\n y: 0.65625,\n },\n {\n x: 0.84375,\n y: 0.65625,\n },\n {\n x: 0.84375,\n y: 0.65625,\n },\n {\n x: 0.90625,\n y: 0.65625,\n },\n {\n x: 0.90625,\n y: 0.65625,\n },\n {\n x: 0.96875,\n y: 0.65625,\n },\n {\n x: 0.96875,\n y: 0.65625,\n },\n {\n x: 0.03125,\n y: 0.71875,\n },\n {\n x: 0.03125,\n y: 0.71875,\n },\n {\n x: 0.09375,\n y: 0.71875,\n },\n {\n x: 0.09375,\n y: 0.71875,\n },\n {\n x: 0.15625,\n y: 0.71875,\n },\n {\n x: 0.15625,\n y: 0.71875,\n },\n {\n x: 0.21875,\n y: 0.71875,\n },\n {\n x: 0.21875,\n y: 0.71875,\n },\n {\n x: 0.28125,\n y: 0.71875,\n },\n {\n x: 0.28125,\n y: 0.71875,\n },\n {\n x: 0.34375,\n y: 0.71875,\n },\n {\n x: 0.34375,\n y: 0.71875,\n },\n {\n x: 0.40625,\n y: 0.71875,\n },\n {\n x: 0.40625,\n y: 0.71875,\n },\n {\n x: 0.46875,\n y: 0.71875,\n },\n {\n x: 0.46875,\n y: 0.71875,\n },\n {\n x: 0.53125,\n y: 0.71875,\n },\n {\n x: 0.53125,\n y: 0.71875,\n },\n {\n x: 0.59375,\n y: 0.71875,\n },\n {\n x: 0.59375,\n y: 0.71875,\n },\n {\n x: 0.65625,\n y: 0.71875,\n },\n {\n x: 0.65625,\n y: 0.71875,\n },\n {\n x: 0.71875,\n y: 0.71875,\n },\n {\n x: 0.71875,\n y: 0.71875,\n },\n {\n x: 0.78125,\n y: 0.71875,\n },\n {\n x: 0.78125,\n y: 0.71875,\n },\n {\n x: 0.84375,\n y: 0.71875,\n },\n {\n x: 0.84375,\n y: 0.71875,\n },\n {\n x: 0.90625,\n y: 0.71875,\n },\n {\n x: 0.90625,\n y: 0.71875,\n },\n {\n x: 0.96875,\n y: 0.71875,\n },\n {\n x: 0.96875,\n y: 0.71875,\n },\n {\n x: 0.03125,\n y: 0.78125,\n },\n {\n x: 0.03125,\n y: 0.78125,\n },\n {\n x: 0.09375,\n y: 0.78125,\n },\n {\n x: 0.09375,\n y: 0.78125,\n },\n {\n x: 0.15625,\n y: 0.78125,\n },\n {\n x: 0.15625,\n y: 0.78125,\n },\n {\n x: 0.21875,\n y: 0.78125,\n },\n {\n x: 0.21875,\n y: 0.78125,\n },\n {\n x: 0.28125,\n y: 0.78125,\n },\n {\n x: 0.28125,\n y: 0.78125,\n },\n {\n x: 0.34375,\n y: 0.78125,\n },\n {\n x: 0.34375,\n y: 0.78125,\n },\n {\n x: 0.40625,\n y: 0.78125,\n },\n {\n x: 0.40625,\n y: 0.78125,\n },\n {\n x: 0.46875,\n y: 0.78125,\n },\n {\n x: 0.46875,\n y: 0.78125,\n },\n {\n x: 0.53125,\n y: 0.78125,\n },\n {\n x: 0.53125,\n y: 0.78125,\n },\n {\n x: 0.59375,\n y: 0.78125,\n },\n {\n x: 0.59375,\n y: 0.78125,\n },\n {\n x: 0.65625,\n y: 0.78125,\n },\n {\n x: 0.65625,\n y: 0.78125,\n },\n {\n x: 0.71875,\n y: 0.78125,\n },\n {\n x: 0.71875,\n y: 0.78125,\n },\n {\n x: 0.78125,\n y: 0.78125,\n },\n {\n x: 0.78125,\n y: 0.78125,\n },\n {\n x: 0.84375,\n y: 0.78125,\n },\n {\n x: 0.84375,\n y: 0.78125,\n },\n {\n x: 0.90625,\n y: 0.78125,\n },\n {\n x: 0.90625,\n y: 0.78125,\n },\n {\n x: 0.96875,\n y: 0.78125,\n },\n {\n x: 0.96875,\n y: 0.78125,\n },\n {\n x: 0.03125,\n y: 0.84375,\n },\n {\n x: 0.03125,\n y: 0.84375,\n },\n {\n x: 0.09375,\n y: 0.84375,\n },\n {\n x: 0.09375,\n y: 0.84375,\n },\n {\n x: 0.15625,\n y: 0.84375,\n },\n {\n x: 0.15625,\n y: 0.84375,\n },\n {\n x: 0.21875,\n y: 0.84375,\n },\n {\n x: 0.21875,\n y: 0.84375,\n },\n {\n x: 0.28125,\n y: 0.84375,\n },\n {\n x: 0.28125,\n y: 0.84375,\n },\n {\n x: 0.34375,\n y: 0.84375,\n },\n {\n x: 0.34375,\n y: 0.84375,\n },\n {\n x: 0.40625,\n y: 0.84375,\n },\n {\n x: 0.40625,\n y: 0.84375,\n },\n {\n x: 0.46875,\n y: 0.84375,\n },\n {\n x: 0.46875,\n y: 0.84375,\n },\n {\n x: 0.53125,\n y: 0.84375,\n },\n {\n x: 0.53125,\n y: 0.84375,\n },\n {\n x: 0.59375,\n y: 0.84375,\n },\n {\n x: 0.59375,\n y: 0.84375,\n },\n {\n x: 0.65625,\n y: 0.84375,\n },\n {\n x: 0.65625,\n y: 0.84375,\n },\n {\n x: 0.71875,\n y: 0.84375,\n },\n {\n x: 0.71875,\n y: 0.84375,\n },\n {\n x: 0.78125,\n y: 0.84375,\n },\n {\n x: 0.78125,\n y: 0.84375,\n },\n {\n x: 0.84375,\n y: 0.84375,\n },\n {\n x: 0.84375,\n y: 0.84375,\n },\n {\n x: 0.90625,\n y: 0.84375,\n },\n {\n x: 0.90625,\n y: 0.84375,\n },\n {\n x: 0.96875,\n y: 0.84375,\n },\n {\n x: 0.96875,\n y: 0.84375,\n },\n {\n x: 0.03125,\n y: 0.90625,\n },\n {\n x: 0.03125,\n y: 0.90625,\n },\n {\n x: 0.09375,\n y: 0.90625,\n },\n {\n x: 0.09375,\n y: 0.90625,\n },\n {\n x: 0.15625,\n y: 0.90625,\n },\n {\n x: 0.15625,\n y: 0.90625,\n },\n {\n x: 0.21875,\n y: 0.90625,\n },\n {\n x: 0.21875,\n y: 0.90625,\n },\n {\n x: 0.28125,\n y: 0.90625,\n },\n {\n x: 0.28125,\n y: 0.90625,\n },\n {\n x: 0.34375,\n y: 0.90625,\n },\n {\n x: 0.34375,\n y: 0.90625,\n },\n {\n x: 0.40625,\n y: 0.90625,\n },\n {\n x: 0.40625,\n y: 0.90625,\n },\n {\n x: 0.46875,\n y: 0.90625,\n },\n {\n x: 0.46875,\n y: 0.90625,\n },\n {\n x: 0.53125,\n y: 0.90625,\n },\n {\n x: 0.53125,\n y: 0.90625,\n },\n {\n x: 0.59375,\n y: 0.90625,\n },\n {\n x: 0.59375,\n y: 0.90625,\n },\n {\n x: 0.65625,\n y: 0.90625,\n },\n {\n x: 0.65625,\n y: 0.90625,\n },\n {\n x: 0.71875,\n y: 0.90625,\n },\n {\n x: 0.71875,\n y: 0.90625,\n },\n {\n x: 0.78125,\n y: 0.90625,\n },\n {\n x: 0.78125,\n y: 0.90625,\n },\n {\n x: 0.84375,\n y: 0.90625,\n },\n {\n x: 0.84375,\n y: 0.90625,\n },\n {\n x: 0.90625,\n y: 0.90625,\n },\n {\n x: 0.90625,\n y: 0.90625,\n },\n {\n x: 0.96875,\n y: 0.90625,\n },\n {\n x: 0.96875,\n y: 0.90625,\n },\n {\n x: 0.03125,\n y: 0.96875,\n },\n {\n x: 0.03125,\n y: 0.96875,\n },\n {\n x: 0.09375,\n y: 0.96875,\n },\n {\n x: 0.09375,\n y: 0.96875,\n },\n {\n x: 0.15625,\n y: 0.96875,\n },\n {\n x: 0.15625,\n y: 0.96875,\n },\n {\n x: 0.21875,\n y: 0.96875,\n },\n {\n x: 0.21875,\n y: 0.96875,\n },\n {\n x: 0.28125,\n y: 0.96875,\n },\n {\n x: 0.28125,\n y: 0.96875,\n },\n {\n x: 0.34375,\n y: 0.96875,\n },\n {\n x: 0.34375,\n y: 0.96875,\n },\n {\n x: 0.40625,\n y: 0.96875,\n },\n {\n x: 0.40625,\n y: 0.96875,\n },\n {\n x: 0.46875,\n y: 0.96875,\n },\n {\n x: 0.46875,\n y: 0.96875,\n },\n {\n x: 0.53125,\n y: 0.96875,\n },\n {\n x: 0.53125,\n y: 0.96875,\n },\n {\n x: 0.59375,\n y: 0.96875,\n },\n {\n x: 0.59375,\n y: 0.96875,\n },\n {\n x: 0.65625,\n y: 0.96875,\n },\n {\n x: 0.65625,\n y: 0.96875,\n },\n {\n x: 0.71875,\n y: 0.96875,\n },\n {\n x: 0.71875,\n y: 0.96875,\n },\n {\n x: 0.78125,\n y: 0.96875,\n },\n {\n x: 0.78125,\n y: 0.96875,\n },\n {\n x: 0.84375,\n y: 0.96875,\n },\n {\n x: 0.84375,\n y: 0.96875,\n },\n {\n x: 0.90625,\n y: 0.96875,\n },\n {\n x: 0.90625,\n y: 0.96875,\n },\n {\n x: 0.96875,\n y: 0.96875,\n },\n {\n x: 0.96875,\n y: 0.96875,\n },\n {\n x: 0.0625,\n y: 0.0625,\n },\n {\n x: 0.0625,\n y: 0.0625,\n },\n {\n x: 0.0625,\n y: 0.0625,\n },\n {\n x: 0.0625,\n y: 0.0625,\n },\n {\n x: 0.0625,\n y: 0.0625,\n },\n {\n x: 0.0625,\n y: 0.0625,\n },\n {\n x: 0.1875,\n y: 0.0625,\n },\n {\n x: 0.1875,\n y: 0.0625,\n },\n {\n x: 0.1875,\n y: 0.0625,\n },\n {\n x: 0.1875,\n y: 0.0625,\n },\n {\n x: 0.1875,\n y: 0.0625,\n },\n {\n x: 0.1875,\n y: 0.0625,\n },\n {\n x: 0.3125,\n y: 0.0625,\n },\n {\n x: 0.3125,\n y: 0.0625,\n },\n {\n x: 0.3125,\n y: 0.0625,\n },\n {\n x: 0.3125,\n y: 0.0625,\n },\n {\n x: 0.3125,\n y: 0.0625,\n },\n {\n x: 0.3125,\n y: 0.0625,\n },\n {\n x: 0.4375,\n y: 0.0625,\n },\n {\n x: 0.4375,\n y: 0.0625,\n },\n {\n x: 0.4375,\n y: 0.0625,\n },\n {\n x: 0.4375,\n y: 0.0625,\n },\n {\n x: 0.4375,\n y: 0.0625,\n },\n {\n x: 0.4375,\n y: 0.0625,\n },\n {\n x: 0.5625,\n y: 0.0625,\n },\n {\n x: 0.5625,\n y: 0.0625,\n },\n {\n x: 0.5625,\n y: 0.0625,\n },\n {\n x: 0.5625,\n y: 0.0625,\n },\n {\n x: 0.5625,\n y: 0.0625,\n },\n {\n x: 0.5625,\n y: 0.0625,\n },\n {\n x: 0.6875,\n y: 0.0625,\n },\n {\n x: 0.6875,\n y: 0.0625,\n },\n {\n x: 0.6875,\n y: 0.0625,\n },\n {\n x: 0.6875,\n y: 0.0625,\n },\n {\n x: 0.6875,\n y: 0.0625,\n },\n {\n x: 0.6875,\n y: 0.0625,\n },\n {\n x: 0.8125,\n y: 0.0625,\n },\n {\n x: 0.8125,\n y: 0.0625,\n },\n {\n x: 0.8125,\n y: 0.0625,\n },\n {\n x: 0.8125,\n y: 0.0625,\n },\n {\n x: 0.8125,\n y: 0.0625,\n },\n {\n x: 0.8125,\n y: 0.0625,\n },\n {\n x: 0.9375,\n y: 0.0625,\n },\n {\n x: 0.9375,\n y: 0.0625,\n },\n {\n x: 0.9375,\n y: 0.0625,\n },\n {\n x: 0.9375,\n y: 0.0625,\n },\n {\n x: 0.9375,\n y: 0.0625,\n },\n {\n x: 0.9375,\n y: 0.0625,\n },\n {\n x: 0.0625,\n y: 0.1875,\n },\n {\n x: 0.0625,\n y: 0.1875,\n },\n {\n x: 0.0625,\n y: 0.1875,\n },\n {\n x: 0.0625,\n y: 0.1875,\n },\n {\n x: 0.0625,\n y: 0.1875,\n },\n {\n x: 0.0625,\n y: 0.1875,\n },\n {\n x: 0.1875,\n y: 0.1875,\n },\n {\n x: 0.1875,\n y: 0.1875,\n },\n {\n x: 0.1875,\n y: 0.1875,\n },\n {\n x: 0.1875,\n y: 0.1875,\n },\n {\n x: 0.1875,\n y: 0.1875,\n },\n {\n x: 0.1875,\n y: 0.1875,\n },\n {\n x: 0.3125,\n y: 0.1875,\n },\n {\n x: 0.3125,\n y: 0.1875,\n },\n {\n x: 0.3125,\n y: 0.1875,\n },\n {\n x: 0.3125,\n y: 0.1875,\n },\n {\n x: 0.3125,\n y: 0.1875,\n },\n {\n x: 0.3125,\n y: 0.1875,\n },\n {\n x: 0.4375,\n y: 0.1875,\n },\n {\n x: 0.4375,\n y: 0.1875,\n },\n {\n x: 0.4375,\n y: 0.1875,\n },\n {\n x: 0.4375,\n y: 0.1875,\n },\n {\n x: 0.4375,\n y: 0.1875,\n },\n {\n x: 0.4375,\n y: 0.1875,\n },\n {\n x: 0.5625,\n y: 0.1875,\n },\n {\n x: 0.5625,\n y: 0.1875,\n },\n {\n x: 0.5625,\n y: 0.1875,\n },\n {\n x: 0.5625,\n y: 0.1875,\n },\n {\n x: 0.5625,\n y: 0.1875,\n },\n {\n x: 0.5625,\n y: 0.1875,\n },\n {\n x: 0.6875,\n y: 0.1875,\n },\n {\n x: 0.6875,\n y: 0.1875,\n },\n {\n x: 0.6875,\n y: 0.1875,\n },\n {\n x: 0.6875,\n y: 0.1875,\n },\n {\n x: 0.6875,\n y: 0.1875,\n },\n {\n x: 0.6875,\n y: 0.1875,\n },\n {\n x: 0.8125,\n y: 0.1875,\n },\n {\n x: 0.8125,\n y: 0.1875,\n },\n {\n x: 0.8125,\n y: 0.1875,\n },\n {\n x: 0.8125,\n y: 0.1875,\n },\n {\n x: 0.8125,\n y: 0.1875,\n },\n {\n x: 0.8125,\n y: 0.1875,\n },\n {\n x: 0.9375,\n y: 0.1875,\n },\n {\n x: 0.9375,\n y: 0.1875,\n },\n {\n x: 0.9375,\n y: 0.1875,\n },\n {\n x: 0.9375,\n y: 0.1875,\n },\n {\n x: 0.9375,\n y: 0.1875,\n },\n {\n x: 0.9375,\n y: 0.1875,\n },\n {\n x: 0.0625,\n y: 0.3125,\n },\n {\n x: 0.0625,\n y: 0.3125,\n },\n {\n x: 0.0625,\n y: 0.3125,\n },\n {\n x: 0.0625,\n y: 0.3125,\n },\n {\n x: 0.0625,\n y: 0.3125,\n },\n {\n x: 0.0625,\n y: 0.3125,\n },\n {\n x: 0.1875,\n y: 0.3125,\n },\n {\n x: 0.1875,\n y: 0.3125,\n },\n {\n x: 0.1875,\n y: 0.3125,\n },\n {\n x: 0.1875,\n y: 0.3125,\n },\n {\n x: 0.1875,\n y: 0.3125,\n },\n {\n x: 0.1875,\n y: 0.3125,\n },\n {\n x: 0.3125,\n y: 0.3125,\n },\n {\n x: 0.3125,\n y: 0.3125,\n },\n {\n x: 0.3125,\n y: 0.3125,\n },\n {\n x: 0.3125,\n y: 0.3125,\n },\n {\n x: 0.3125,\n y: 0.3125,\n },\n {\n x: 0.3125,\n y: 0.3125,\n },\n {\n x: 0.4375,\n y: 0.3125,\n },\n {\n x: 0.4375,\n y: 0.3125,\n },\n {\n x: 0.4375,\n y: 0.3125,\n },\n {\n x: 0.4375,\n y: 0.3125,\n },\n {\n x: 0.4375,\n y: 0.3125,\n },\n {\n x: 0.4375,\n y: 0.3125,\n },\n {\n x: 0.5625,\n y: 0.3125,\n },\n {\n x: 0.5625,\n y: 0.3125,\n },\n {\n x: 0.5625,\n y: 0.3125,\n },\n {\n x: 0.5625,\n y: 0.3125,\n },\n {\n x: 0.5625,\n y: 0.3125,\n },\n {\n x: 0.5625,\n y: 0.3125,\n },\n {\n x: 0.6875,\n y: 0.3125,\n },\n {\n x: 0.6875,\n y: 0.3125,\n },\n {\n x: 0.6875,\n y: 0.3125,\n },\n {\n x: 0.6875,\n y: 0.3125,\n },\n {\n x: 0.6875,\n y: 0.3125,\n },\n {\n x: 0.6875,\n y: 0.3125,\n },\n {\n x: 0.8125,\n y: 0.3125,\n },\n {\n x: 0.8125,\n y: 0.3125,\n },\n {\n x: 0.8125,\n y: 0.3125,\n },\n {\n x: 0.8125,\n y: 0.3125,\n },\n {\n x: 0.8125,\n y: 0.3125,\n },\n {\n x: 0.8125,\n y: 0.3125,\n },\n {\n x: 0.9375,\n y: 0.3125,\n },\n {\n x: 0.9375,\n y: 0.3125,\n },\n {\n x: 0.9375,\n y: 0.3125,\n },\n {\n x: 0.9375,\n y: 0.3125,\n },\n {\n x: 0.9375,\n y: 0.3125,\n },\n {\n x: 0.9375,\n y: 0.3125,\n },\n {\n x: 0.0625,\n y: 0.4375,\n },\n {\n x: 0.0625,\n y: 0.4375,\n },\n {\n x: 0.0625,\n y: 0.4375,\n },\n {\n x: 0.0625,\n y: 0.4375,\n },\n {\n x: 0.0625,\n y: 0.4375,\n },\n {\n x: 0.0625,\n y: 0.4375,\n },\n {\n x: 0.1875,\n y: 0.4375,\n },\n {\n x: 0.1875,\n y: 0.4375,\n },\n {\n x: 0.1875,\n y: 0.4375,\n },\n {\n x: 0.1875,\n y: 0.4375,\n },\n {\n x: 0.1875,\n y: 0.4375,\n },\n {\n x: 0.1875,\n y: 0.4375,\n },\n {\n x: 0.3125,\n y: 0.4375,\n },\n {\n x: 0.3125,\n y: 0.4375,\n },\n {\n x: 0.3125,\n y: 0.4375,\n },\n {\n x: 0.3125,\n y: 0.4375,\n },\n {\n x: 0.3125,\n y: 0.4375,\n },\n {\n x: 0.3125,\n y: 0.4375,\n },\n {\n x: 0.4375,\n y: 0.4375,\n },\n {\n x: 0.4375,\n y: 0.4375,\n },\n {\n x: 0.4375,\n y: 0.4375,\n },\n {\n x: 0.4375,\n y: 0.4375,\n },\n {\n x: 0.4375,\n y: 0.4375,\n },\n {\n x: 0.4375,\n y: 0.4375,\n },\n {\n x: 0.5625,\n y: 0.4375,\n },\n {\n x: 0.5625,\n y: 0.4375,\n },\n {\n x: 0.5625,\n y: 0.4375,\n },\n {\n x: 0.5625,\n y: 0.4375,\n },\n {\n x: 0.5625,\n y: 0.4375,\n },\n {\n x: 0.5625,\n y: 0.4375,\n },\n {\n x: 0.6875,\n y: 0.4375,\n },\n {\n x: 0.6875,\n y: 0.4375,\n },\n {\n x: 0.6875,\n y: 0.4375,\n },\n {\n x: 0.6875,\n y: 0.4375,\n },\n {\n x: 0.6875,\n y: 0.4375,\n },\n {\n x: 0.6875,\n y: 0.4375,\n },\n {\n x: 0.8125,\n y: 0.4375,\n },\n {\n x: 0.8125,\n y: 0.4375,\n },\n {\n x: 0.8125,\n y: 0.4375,\n },\n {\n x: 0.8125,\n y: 0.4375,\n },\n {\n x: 0.8125,\n y: 0.4375,\n },\n {\n x: 0.8125,\n y: 0.4375,\n },\n {\n x: 0.9375,\n y: 0.4375,\n },\n {\n x: 0.9375,\n y: 0.4375,\n },\n {\n x: 0.9375,\n y: 0.4375,\n },\n {\n x: 0.9375,\n y: 0.4375,\n },\n {\n x: 0.9375,\n y: 0.4375,\n },\n {\n x: 0.9375,\n y: 0.4375,\n },\n {\n x: 0.0625,\n y: 0.5625,\n },\n {\n x: 0.0625,\n y: 0.5625,\n },\n {\n x: 0.0625,\n y: 0.5625,\n },\n {\n x: 0.0625,\n y: 0.5625,\n },\n {\n x: 0.0625,\n y: 0.5625,\n },\n {\n x: 0.0625,\n y: 0.5625,\n },\n {\n x: 0.1875,\n y: 0.5625,\n },\n {\n x: 0.1875,\n y: 0.5625,\n },\n {\n x: 0.1875,\n y: 0.5625,\n },\n {\n x: 0.1875,\n y: 0.5625,\n },\n {\n x: 0.1875,\n y: 0.5625,\n },\n {\n x: 0.1875,\n y: 0.5625,\n },\n {\n x: 0.3125,\n y: 0.5625,\n },\n {\n x: 0.3125,\n y: 0.5625,\n },\n {\n x: 0.3125,\n y: 0.5625,\n },\n {\n x: 0.3125,\n y: 0.5625,\n },\n {\n x: 0.3125,\n y: 0.5625,\n },\n {\n x: 0.3125,\n y: 0.5625,\n },\n {\n x: 0.4375,\n y: 0.5625,\n },\n {\n x: 0.4375,\n y: 0.5625,\n },\n {\n x: 0.4375,\n y: 0.5625,\n },\n {\n x: 0.4375,\n y: 0.5625,\n },\n {\n x: 0.4375,\n y: 0.5625,\n },\n {\n x: 0.4375,\n y: 0.5625,\n },\n {\n x: 0.5625,\n y: 0.5625,\n },\n {\n x: 0.5625,\n y: 0.5625,\n },\n {\n x: 0.5625,\n y: 0.5625,\n },\n {\n x: 0.5625,\n y: 0.5625,\n },\n {\n x: 0.5625,\n y: 0.5625,\n },\n {\n x: 0.5625,\n y: 0.5625,\n },\n {\n x: 0.6875,\n y: 0.5625,\n },\n {\n x: 0.6875,\n y: 0.5625,\n },\n {\n x: 0.6875,\n y: 0.5625,\n },\n {\n x: 0.6875,\n y: 0.5625,\n },\n {\n x: 0.6875,\n y: 0.5625,\n },\n {\n x: 0.6875,\n y: 0.5625,\n },\n {\n x: 0.8125,\n y: 0.5625,\n },\n {\n x: 0.8125,\n y: 0.5625,\n },\n {\n x: 0.8125,\n y: 0.5625,\n },\n {\n x: 0.8125,\n y: 0.5625,\n },\n {\n x: 0.8125,\n y: 0.5625,\n },\n {\n x: 0.8125,\n y: 0.5625,\n },\n {\n x: 0.9375,\n y: 0.5625,\n },\n {\n x: 0.9375,\n y: 0.5625,\n },\n {\n x: 0.9375,\n y: 0.5625,\n },\n {\n x: 0.9375,\n y: 0.5625,\n },\n {\n x: 0.9375,\n y: 0.5625,\n },\n {\n x: 0.9375,\n y: 0.5625,\n },\n {\n x: 0.0625,\n y: 0.6875,\n },\n {\n x: 0.0625,\n y: 0.6875,\n },\n {\n x: 0.0625,\n y: 0.6875,\n },\n {\n x: 0.0625,\n y: 0.6875,\n },\n {\n x: 0.0625,\n y: 0.6875,\n },\n {\n x: 0.0625,\n y: 0.6875,\n },\n {\n x: 0.1875,\n y: 0.6875,\n },\n {\n x: 0.1875,\n y: 0.6875,\n },\n {\n x: 0.1875,\n y: 0.6875,\n },\n {\n x: 0.1875,\n y: 0.6875,\n },\n {\n x: 0.1875,\n y: 0.6875,\n },\n {\n x: 0.1875,\n y: 0.6875,\n },\n {\n x: 0.3125,\n y: 0.6875,\n },\n {\n x: 0.3125,\n y: 0.6875,\n },\n {\n x: 0.3125,\n y: 0.6875,\n },\n {\n x: 0.3125,\n y: 0.6875,\n },\n {\n x: 0.3125,\n y: 0.6875,\n },\n {\n x: 0.3125,\n y: 0.6875,\n },\n {\n x: 0.4375,\n y: 0.6875,\n },\n {\n x: 0.4375,\n y: 0.6875,\n },\n {\n x: 0.4375,\n y: 0.6875,\n },\n {\n x: 0.4375,\n y: 0.6875,\n },\n {\n x: 0.4375,\n y: 0.6875,\n },\n {\n x: 0.4375,\n y: 0.6875,\n },\n {\n x: 0.5625,\n y: 0.6875,\n },\n {\n x: 0.5625,\n y: 0.6875,\n },\n {\n x: 0.5625,\n y: 0.6875,\n },\n {\n x: 0.5625,\n y: 0.6875,\n },\n {\n x: 0.5625,\n y: 0.6875,\n },\n {\n x: 0.5625,\n y: 0.6875,\n },\n {\n x: 0.6875,\n y: 0.6875,\n },\n {\n x: 0.6875,\n y: 0.6875,\n },\n {\n x: 0.6875,\n y: 0.6875,\n },\n {\n x: 0.6875,\n y: 0.6875,\n },\n {\n x: 0.6875,\n y: 0.6875,\n },\n {\n x: 0.6875,\n y: 0.6875,\n },\n {\n x: 0.8125,\n y: 0.6875,\n },\n {\n x: 0.8125,\n y: 0.6875,\n },\n {\n x: 0.8125,\n y: 0.6875,\n },\n {\n x: 0.8125,\n y: 0.6875,\n },\n {\n x: 0.8125,\n y: 0.6875,\n },\n {\n x: 0.8125,\n y: 0.6875,\n },\n {\n x: 0.9375,\n y: 0.6875,\n },\n {\n x: 0.9375,\n y: 0.6875,\n },\n {\n x: 0.9375,\n y: 0.6875,\n },\n {\n x: 0.9375,\n y: 0.6875,\n },\n {\n x: 0.9375,\n y: 0.6875,\n },\n {\n x: 0.9375,\n y: 0.6875,\n },\n {\n x: 0.0625,\n y: 0.8125,\n },\n {\n x: 0.0625,\n y: 0.8125,\n },\n {\n x: 0.0625,\n y: 0.8125,\n },\n {\n x: 0.0625,\n y: 0.8125,\n },\n {\n x: 0.0625,\n y: 0.8125,\n },\n {\n x: 0.0625,\n y: 0.8125,\n },\n {\n x: 0.1875,\n y: 0.8125,\n },\n {\n x: 0.1875,\n y: 0.8125,\n },\n {\n x: 0.1875,\n y: 0.8125,\n },\n {\n x: 0.1875,\n y: 0.8125,\n },\n {\n x: 0.1875,\n y: 0.8125,\n },\n {\n x: 0.1875,\n y: 0.8125,\n },\n {\n x: 0.3125,\n y: 0.8125,\n },\n {\n x: 0.3125,\n y: 0.8125,\n },\n {\n x: 0.3125,\n y: 0.8125,\n },\n {\n x: 0.3125,\n y: 0.8125,\n },\n {\n x: 0.3125,\n y: 0.8125,\n },\n {\n x: 0.3125,\n y: 0.8125,\n },\n {\n x: 0.4375,\n y: 0.8125,\n },\n {\n x: 0.4375,\n y: 0.8125,\n },\n {\n x: 0.4375,\n y: 0.8125,\n },\n {\n x: 0.4375,\n y: 0.8125,\n },\n {\n x: 0.4375,\n y: 0.8125,\n },\n {\n x: 0.4375,\n y: 0.8125,\n },\n {\n x: 0.5625,\n y: 0.8125,\n },\n {\n x: 0.5625,\n y: 0.8125,\n },\n {\n x: 0.5625,\n y: 0.8125,\n },\n {\n x: 0.5625,\n y: 0.8125,\n },\n {\n x: 0.5625,\n y: 0.8125,\n },\n {\n x: 0.5625,\n y: 0.8125,\n },\n {\n x: 0.6875,\n y: 0.8125,\n },\n {\n x: 0.6875,\n y: 0.8125,\n },\n {\n x: 0.6875,\n y: 0.8125,\n },\n {\n x: 0.6875,\n y: 0.8125,\n },\n {\n x: 0.6875,\n y: 0.8125,\n },\n {\n x: 0.6875,\n y: 0.8125,\n },\n {\n x: 0.8125,\n y: 0.8125,\n },\n {\n x: 0.8125,\n y: 0.8125,\n },\n {\n x: 0.8125,\n y: 0.8125,\n },\n {\n x: 0.8125,\n y: 0.8125,\n },\n {\n x: 0.8125,\n y: 0.8125,\n },\n {\n x: 0.8125,\n y: 0.8125,\n },\n {\n x: 0.9375,\n y: 0.8125,\n },\n {\n x: 0.9375,\n y: 0.8125,\n },\n {\n x: 0.9375,\n y: 0.8125,\n },\n {\n x: 0.9375,\n y: 0.8125,\n },\n {\n x: 0.9375,\n y: 0.8125,\n },\n {\n x: 0.9375,\n y: 0.8125,\n },\n {\n x: 0.0625,\n y: 0.9375,\n },\n {\n x: 0.0625,\n y: 0.9375,\n },\n {\n x: 0.0625,\n y: 0.9375,\n },\n {\n x: 0.0625,\n y: 0.9375,\n },\n {\n x: 0.0625,\n y: 0.9375,\n },\n {\n x: 0.0625,\n y: 0.9375,\n },\n {\n x: 0.1875,\n y: 0.9375,\n },\n {\n x: 0.1875,\n y: 0.9375,\n },\n {\n x: 0.1875,\n y: 0.9375,\n },\n {\n x: 0.1875,\n y: 0.9375,\n },\n {\n x: 0.1875,\n y: 0.9375,\n },\n {\n x: 0.1875,\n y: 0.9375,\n },\n {\n x: 0.3125,\n y: 0.9375,\n },\n {\n x: 0.3125,\n y: 0.9375,\n },\n {\n x: 0.3125,\n y: 0.9375,\n },\n {\n x: 0.3125,\n y: 0.9375,\n },\n {\n x: 0.3125,\n y: 0.9375,\n },\n {\n x: 0.3125,\n y: 0.9375,\n },\n {\n x: 0.4375,\n y: 0.9375,\n },\n {\n x: 0.4375,\n y: 0.9375,\n },\n {\n x: 0.4375,\n y: 0.9375,\n },\n {\n x: 0.4375,\n y: 0.9375,\n },\n {\n x: 0.4375,\n y: 0.9375,\n },\n {\n x: 0.4375,\n y: 0.9375,\n },\n {\n x: 0.5625,\n y: 0.9375,\n },\n {\n x: 0.5625,\n y: 0.9375,\n },\n {\n x: 0.5625,\n y: 0.9375,\n },\n {\n x: 0.5625,\n y: 0.9375,\n },\n {\n x: 0.5625,\n y: 0.9375,\n },\n {\n x: 0.5625,\n y: 0.9375,\n },\n {\n x: 0.6875,\n y: 0.9375,\n },\n {\n x: 0.6875,\n y: 0.9375,\n },\n {\n x: 0.6875,\n y: 0.9375,\n },\n {\n x: 0.6875,\n y: 0.9375,\n },\n {\n x: 0.6875,\n y: 0.9375,\n },\n {\n x: 0.6875,\n y: 0.9375,\n },\n {\n x: 0.8125,\n y: 0.9375,\n },\n {\n x: 0.8125,\n y: 0.9375,\n },\n {\n x: 0.8125,\n y: 0.9375,\n },\n {\n x: 0.8125,\n y: 0.9375,\n },\n {\n x: 0.8125,\n y: 0.9375,\n },\n {\n x: 0.8125,\n y: 0.9375,\n },\n {\n x: 0.9375,\n y: 0.9375,\n },\n {\n x: 0.9375,\n y: 0.9375,\n },\n {\n x: 0.9375,\n y: 0.9375,\n },\n {\n x: 0.9375,\n y: 0.9375,\n },\n {\n x: 0.9375,\n y: 0.9375,\n },\n {\n x: 0.9375,\n y: 0.9375,\n },\n];\n", "import * as tf from '../../dist/tfjs.esm.js';\nimport * as box from './box';\nimport * as anchors from './anchors';\n\nexport class HandDetector {\n model: any;\n anchors: any;\n anchorsTensor: any;\n inputSize: number;\n inputSizeTensor: any;\n doubleInputSizeTensor: any;\n\n constructor(model) {\n this.model = model;\n this.anchors = anchors.anchors.map((anchor) => [anchor.x, anchor.y]);\n this.anchorsTensor = tf.tensor2d(this.anchors);\n this.inputSize = this.model?.inputs[0].shape[2];\n this.inputSizeTensor = tf.tensor1d([this.inputSize, this.inputSize]);\n this.doubleInputSizeTensor = tf.tensor1d([this.inputSize * 2, this.inputSize * 2]);\n }\n\n normalizeBoxes(boxes) {\n return tf.tidy(() => {\n const boxOffsets = tf.slice(boxes, [0, 0], [-1, 2]);\n const boxSizes = tf.slice(boxes, [0, 2], [-1, 2]);\n const boxCenterPoints = tf.add(tf.div(boxOffsets, this.inputSizeTensor), this.anchorsTensor);\n const halfBoxSizes = tf.div(boxSizes, this.doubleInputSizeTensor);\n const startPoints = tf.mul(tf.sub(boxCenterPoints, halfBoxSizes), this.inputSizeTensor);\n const endPoints = tf.mul(tf.add(boxCenterPoints, halfBoxSizes), this.inputSizeTensor);\n return tf.concat2d([startPoints, endPoints], 1);\n });\n }\n\n normalizeLandmarks(rawPalmLandmarks, index) {\n return tf.tidy(() => {\n const landmarks = tf.add(tf.div(rawPalmLandmarks.reshape([-1, 7, 2]), this.inputSizeTensor), this.anchors[index]);\n return tf.mul(landmarks, this.inputSizeTensor);\n });\n }\n\n async getBoxes(input, config) {\n const batched = this.model.predict(input);\n const predictions = batched.squeeze();\n batched.dispose();\n const scoresT = tf.tidy(() => tf.sigmoid(tf.slice(predictions, [0, 0], [-1, 1])).squeeze());\n const scores = scoresT.dataSync();\n const rawBoxes = tf.slice(predictions, [0, 1], [-1, 4]);\n const boxes = this.normalizeBoxes(rawBoxes);\n rawBoxes.dispose();\n const filteredT = await tf.image.nonMaxSuppressionAsync(boxes, scores, config.hand.maxDetected, config.hand.iouThreshold, config.hand.minConfidence);\n const filtered = filteredT.arraySync();\n\n scoresT.dispose();\n filteredT.dispose();\n const hands: Array<{ box: any, palmLandmarks: any, confidence: number }> = [];\n for (const index of filtered) {\n if (scores[index] >= config.hand.minConfidence) {\n const matchingBox = tf.slice(boxes, [index, 0], [1, -1]);\n const rawPalmLandmarks = tf.slice(predictions, [index, 5], [1, 14]);\n const palmLandmarks = tf.tidy(() => this.normalizeLandmarks(rawPalmLandmarks, index).reshape([-1, 2]));\n rawPalmLandmarks.dispose();\n hands.push({ box: matchingBox, palmLandmarks, confidence: scores[index] });\n }\n }\n predictions.dispose();\n boxes.dispose();\n return hands;\n }\n\n async estimateHandBounds(input, config) {\n const inputHeight = input.shape[1];\n const inputWidth = input.shape[2];\n const image = tf.tidy(() => input.resizeBilinear([this.inputSize, this.inputSize]).div(127.5).sub(1));\n const predictions = await this.getBoxes(image, config);\n image.dispose();\n const hands: Array<{}> = [];\n if (!predictions || predictions.length === 0) return hands;\n for (const prediction of predictions) {\n const boxes = prediction.box.dataSync();\n const startPoint = boxes.slice(0, 2);\n const endPoint = boxes.slice(2, 4);\n const palmLandmarks = prediction.palmLandmarks.arraySync();\n prediction.box.dispose();\n prediction.palmLandmarks.dispose();\n hands.push(box.scaleBoxCoordinates({ startPoint, endPoint, palmLandmarks, confidence: prediction.confidence }, [inputWidth / this.inputSize, inputHeight / this.inputSize]));\n }\n return hands;\n }\n}\n", "export function normalizeRadians(angle) {\n return angle - 2 * Math.PI * Math.floor((angle + Math.PI) / (2 * Math.PI));\n}\n\nexport function computeRotation(point1, point2) {\n const radians = Math.PI / 2 - Math.atan2(-(point2[1] - point1[1]), point2[0] - point1[0]);\n return normalizeRadians(radians);\n}\n\nexport const buildTranslationMatrix = (x, y) => [[1, 0, x], [0, 1, y], [0, 0, 1]];\n\nexport function dot(v1, v2) {\n let product = 0;\n for (let i = 0; i < v1.length; i++) {\n product += v1[i] * v2[i];\n }\n return product;\n}\n\nexport function getColumnFrom2DArr(arr, columnIndex) {\n const column: Array = [];\n for (let i = 0; i < arr.length; i++) {\n column.push(arr[i][columnIndex]);\n }\n return column;\n}\n\nexport function multiplyTransformMatrices(mat1, mat2) {\n const product: Array = [];\n const size = mat1.length;\n for (let row = 0; row < size; row++) {\n product.push([]);\n for (let col = 0; col < size; col++) {\n product[row].push(dot(mat1[row], getColumnFrom2DArr(mat2, col)));\n }\n }\n return product;\n}\n\nexport function buildRotationMatrix(rotation, center) {\n const cosA = Math.cos(rotation);\n const sinA = Math.sin(rotation);\n const rotationMatrix = [[cosA, -sinA, 0], [sinA, cosA, 0], [0, 0, 1]];\n const translationMatrix = buildTranslationMatrix(center[0], center[1]);\n const translationTimesRotation = multiplyTransformMatrices(translationMatrix, rotationMatrix);\n const negativeTranslationMatrix = buildTranslationMatrix(-center[0], -center[1]);\n return multiplyTransformMatrices(translationTimesRotation, negativeTranslationMatrix);\n}\n\nexport function invertTransformMatrix(matrix) {\n const rotationComponent = [[matrix[0][0], matrix[1][0]], [matrix[0][1], matrix[1][1]]];\n const translationComponent = [matrix[0][2], matrix[1][2]];\n const invertedTranslation = [\n -dot(rotationComponent[0], translationComponent),\n -dot(rotationComponent[1], translationComponent),\n ];\n return [\n rotationComponent[0].concat(invertedTranslation[0]),\n rotationComponent[1].concat(invertedTranslation[1]),\n [0, 0, 1],\n ];\n}\n\nexport function rotatePoint(homogeneousCoordinate, rotationMatrix) {\n return [\n dot(homogeneousCoordinate, rotationMatrix[0]),\n dot(homogeneousCoordinate, rotationMatrix[1]),\n ];\n}\n", "import * as tf from '../../dist/tfjs.esm.js';\nimport * as box from './box';\nimport * as util from './util';\n\n// const PALM_BOX_SHIFT_VECTOR = [0, -0.4];\nconst PALM_BOX_ENLARGE_FACTOR = 5; // default 3\n// const HAND_BOX_SHIFT_VECTOR = [0, -0.1]; // move detected hand box by x,y to ease landmark detection\nconst HAND_BOX_ENLARGE_FACTOR = 1.65; // default 1.65\nconst PALM_LANDMARK_IDS = [0, 5, 9, 13, 17, 1, 2];\nconst PALM_LANDMARKS_INDEX_OF_PALM_BASE = 0;\nconst PALM_LANDMARKS_INDEX_OF_MIDDLE_FINGER_BASE = 2;\n\nexport class HandPipeline {\n handDetector: any;\n landmarkDetector: any;\n inputSize: number;\n storedBoxes: any;\n skipped: number;\n detectedHands: number;\n\n constructor(handDetector, landmarkDetector) {\n this.handDetector = handDetector;\n this.landmarkDetector = landmarkDetector;\n this.inputSize = this.landmarkDetector?.inputs[0].shape[2];\n this.storedBoxes = [];\n this.skipped = 0;\n this.detectedHands = 0;\n }\n\n getBoxForPalmLandmarks(palmLandmarks, rotationMatrix) {\n const rotatedPalmLandmarks = palmLandmarks.map((coord) => util.rotatePoint([...coord, 1], rotationMatrix));\n const boxAroundPalm = this.calculateLandmarksBoundingBox(rotatedPalmLandmarks);\n // return box.enlargeBox(box.squarifyBox(box.shiftBox(boxAroundPalm, PALM_BOX_SHIFT_VECTOR)), PALM_BOX_ENLARGE_FACTOR);\n return box.enlargeBox(box.squarifyBox(boxAroundPalm), PALM_BOX_ENLARGE_FACTOR);\n }\n\n getBoxForHandLandmarks(landmarks) {\n const boundingBox = this.calculateLandmarksBoundingBox(landmarks);\n // const boxAroundHand = box.enlargeBox(box.squarifyBox(box.shiftBox(boundingBox, HAND_BOX_SHIFT_VECTOR)), HAND_BOX_ENLARGE_FACTOR);\n const boxAroundHand = box.enlargeBox(box.squarifyBox(boundingBox), HAND_BOX_ENLARGE_FACTOR);\n boxAroundHand.palmLandmarks = [];\n for (let i = 0; i < PALM_LANDMARK_IDS.length; i++) {\n boxAroundHand.palmLandmarks.push(landmarks[PALM_LANDMARK_IDS[i]].slice(0, 2));\n }\n return boxAroundHand;\n }\n\n transformRawCoords(rawCoords, box2, angle, rotationMatrix) {\n const boxSize = box.getBoxSize(box2);\n const scaleFactor = [boxSize[0] / this.inputSize, boxSize[1] / this.inputSize, (boxSize[0] + boxSize[1]) / this.inputSize / 2];\n const coordsScaled = rawCoords.map((coord) => [\n scaleFactor[0] * (coord[0] - this.inputSize / 2),\n scaleFactor[1] * (coord[1] - this.inputSize / 2),\n scaleFactor[2] * coord[2],\n ]);\n const coordsRotationMatrix = util.buildRotationMatrix(angle, [0, 0]);\n const coordsRotated = coordsScaled.map((coord) => {\n const rotated = util.rotatePoint(coord, coordsRotationMatrix);\n return [...rotated, coord[2]];\n });\n const inverseRotationMatrix = util.invertTransformMatrix(rotationMatrix);\n const boxCenter = [...box.getBoxCenter(box2), 1];\n const originalBoxCenter = [\n util.dot(boxCenter, inverseRotationMatrix[0]),\n util.dot(boxCenter, inverseRotationMatrix[1]),\n ];\n return coordsRotated.map((coord) => [\n coord[0] + originalBoxCenter[0],\n coord[1] + originalBoxCenter[1],\n coord[2],\n ]);\n }\n\n async estimateHands(image, config) {\n let useFreshBox = false;\n\n // run new detector every skipFrames unless we only want box to start with\n let boxes;\n if ((this.skipped === 0) || (this.skipped > config.hand.skipFrames) || !config.hand.landmarks || !config.videoOptimized) {\n boxes = await this.handDetector.estimateHandBounds(image, config);\n this.skipped = 0;\n }\n if (config.videoOptimized) this.skipped++;\n\n // if detector result count doesn't match current working set, use it to reset current working set\n if (boxes && (boxes.length > 0) && ((boxes.length !== this.detectedHands) && (this.detectedHands !== config.hand.maxDetected) || !config.hand.landmarks)) {\n this.detectedHands = 0;\n this.storedBoxes = [...boxes];\n // for (const possible of boxes) this.storedBoxes.push(possible);\n if (this.storedBoxes.length > 0) useFreshBox = true;\n }\n const hands: Array<{}> = [];\n\n if (config.hand.skipInitial && this.detectedHands === 0) this.skipped = 0;\n\n // go through working set of boxes\n for (let i = 0; i < this.storedBoxes.length; i++) {\n const currentBox = this.storedBoxes[i];\n if (!currentBox) continue;\n if (config.hand.landmarks) {\n const angle = config.hand.rotation ? util.computeRotation(currentBox.palmLandmarks[PALM_LANDMARKS_INDEX_OF_PALM_BASE], currentBox.palmLandmarks[PALM_LANDMARKS_INDEX_OF_MIDDLE_FINGER_BASE]) : 0;\n const palmCenter = box.getBoxCenter(currentBox);\n const palmCenterNormalized = [palmCenter[0] / image.shape[2], palmCenter[1] / image.shape[1]];\n const rotatedImage = config.hand.rotation ? tf.image.rotateWithOffset(image, angle, 0, palmCenterNormalized) : image.clone();\n const rotationMatrix = util.buildRotationMatrix(-angle, palmCenter);\n const newBox = useFreshBox ? this.getBoxForPalmLandmarks(currentBox.palmLandmarks, rotationMatrix) : currentBox;\n const croppedInput = box.cutBoxFromImageAndResize(newBox, rotatedImage, [this.inputSize, this.inputSize]);\n const handImage = croppedInput.div(255);\n croppedInput.dispose();\n rotatedImage.dispose();\n const [confidenceT, keypoints] = await this.landmarkDetector.predict(handImage);\n handImage.dispose();\n const confidence = confidenceT.dataSync()[0];\n confidenceT.dispose();\n if (confidence >= config.hand.minConfidence) {\n const keypointsReshaped = tf.reshape(keypoints, [-1, 3]);\n const rawCoords = keypointsReshaped.arraySync();\n keypoints.dispose();\n keypointsReshaped.dispose();\n const coords = this.transformRawCoords(rawCoords, newBox, angle, rotationMatrix);\n const nextBoundingBox = this.getBoxForHandLandmarks(coords);\n this.storedBoxes[i] = nextBoundingBox;\n const result = {\n landmarks: coords,\n confidence,\n box: { topLeft: nextBoundingBox.startPoint, bottomRight: nextBoundingBox.endPoint },\n };\n hands.push(result);\n } else {\n this.storedBoxes[i] = null;\n }\n keypoints.dispose();\n } else {\n // const enlarged = box.enlargeBox(box.squarifyBox(box.shiftBox(currentBox, HAND_BOX_SHIFT_VECTOR)), HAND_BOX_ENLARGE_FACTOR);\n const enlarged = box.enlargeBox(box.squarifyBox(currentBox), HAND_BOX_ENLARGE_FACTOR);\n const result = {\n confidence: currentBox.confidence,\n box: { topLeft: enlarged.startPoint, bottomRight: enlarged.endPoint },\n };\n hands.push(result);\n }\n }\n this.storedBoxes = this.storedBoxes.filter((a) => a !== null);\n this.detectedHands = hands.length;\n return hands;\n }\n\n // eslint-disable-next-line class-methods-use-this\n calculateLandmarksBoundingBox(landmarks) {\n const xs = landmarks.map((d) => d[0]);\n const ys = landmarks.map((d) => d[1]);\n const startPoint = [Math.min(...xs), Math.min(...ys)];\n const endPoint = [Math.max(...xs), Math.max(...ys)];\n return { startPoint, endPoint };\n }\n}\n", "// paper: https://ai.googleblog.com/2020/08/on-device-real-time-body-pose-tracking.html\n\nimport { log, join } from '../helpers';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as annotations from './annotations';\n\nlet model;\n\nexport async function load(config) {\n if (!model) {\n model = await tf.loadGraphModel(join(config.modelBasePath, config.body.modelPath));\n model.width = parseInt(model.signature.inputs['input_1:0'].tensorShape.dim[2].size);\n model.height = parseInt(model.signature.inputs['input_1:0'].tensorShape.dim[1].size);\n if (!model || !model.modelUrl) log('load model failed:', config.body.modelPath);\n else if (config.debug) log('load model:', model.modelUrl);\n } else if (config.debug) log('cached model:', model.modelUrl);\n return model;\n}\n\nexport async function predict(image, config) {\n if (!model) return null;\n if (!config.body.enabled) return null;\n const imgSize = { width: image.shape[2], height: image.shape[1] };\n const resize = tf.image.resizeBilinear(image, [model.width, model.height], false);\n const normalize = tf.div(resize, [255.0]);\n resize.dispose();\n const resT = await model.predict(normalize);\n const points = resT.find((t) => (t.size === 195 || t.size === 155)).dataSync(); // order of output tensors may change between models, full has 195 and upper has 155 items\n resT.forEach((t) => t.dispose());\n normalize.dispose();\n const keypoints: Array<{ id, part, position: { x, y, z }, score, presence }> = [];\n const labels = points.length === 195 ? annotations.full : annotations.upper; // full model has 39 keypoints, upper has 31 keypoints\n const depth = 5; // each points has x,y,z,visibility,presence\n for (let i = 0; i < points.length / depth; i++) {\n keypoints.push({\n id: i,\n part: labels[i],\n position: {\n x: Math.trunc(imgSize.width * points[depth * i + 0] / 255), // return normalized x value istead of 0..255\n y: Math.trunc(imgSize.height * points[depth * i + 1] / 255), // return normalized y value istead of 0..255\n z: Math.trunc(points[depth * i + 2]) + 0, // fix negative zero\n },\n score: (100 - Math.trunc(100 / (1 + Math.exp(points[depth * i + 3])))) / 100, // reverse sigmoid value\n presence: (100 - Math.trunc(100 / (1 + Math.exp(points[depth * i + 4])))) / 100, // reverse sigmoid value\n });\n }\n const score = keypoints.reduce((prev, curr) => (curr.score > prev ? curr.score : prev), 0);\n return [{ score, keypoints }];\n}\n", "export const full = [\n 'nose',\n 'leftEyeInside',\n 'leftEye',\n 'leftEyeOutside',\n 'rightEyeInside',\n 'rightEye',\n 'rightEyeOutside',\n 'leftEar',\n 'rightEar',\n 'leftMouth',\n 'rightMouth',\n 'leftShoulder',\n 'rightShoulder',\n 'leftElbow',\n 'rightElbow',\n 'leftWrist',\n 'rightWrist',\n 'leftPalm',\n 'rightPalm',\n 'leftIndex',\n 'rightIndex',\n 'leftPinky',\n 'rightPinky',\n 'leftHip',\n 'rightHip',\n 'leftKnee',\n 'rightKnee',\n 'leftAnkle',\n 'rightAnkle',\n 'leftHeel',\n 'rightHeel',\n 'leftFoot',\n 'rightFoot',\n 'midHip',\n 'forehead',\n 'leftThumb',\n 'leftHand',\n 'rightThumb',\n 'rightHand',\n];\n\nexport const upper = [\n 'nose',\n 'leftEyeInside',\n 'leftEye',\n 'leftEyeOutside',\n 'rightEyeInside',\n 'rightEye',\n 'rightEyeOutside',\n 'leftEar',\n 'rightEar',\n 'leftMouth',\n 'rightMouth',\n 'leftShoulder',\n 'rightShoulder',\n 'leftElbow',\n 'rightElbow',\n 'left:15',\n 'right:16',\n 'left:17',\n 'right:18',\n 'left:19',\n 'right:20',\n 'left:21',\n 'right:22',\n 'leftChest',\n 'rightChest',\n 'neck',\n 'forehead',\n 'left:27',\n 'right:28',\n 'left:29',\n 'right:30',\n];\n", "import { log, join } from '../helpers';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { labels } from './labels';\n\nlet model;\nlet last: Array<{}> = [];\nlet skipped = Number.MAX_SAFE_INTEGER;\n\nconst scaleBox = 2.5; // increase box size\n\nexport async function load(config) {\n if (!model) {\n model = await tf.loadGraphModel(join(config.modelBasePath, config.object.modelPath));\n const inputs = Object.values(model.modelSignature['inputs']);\n model.inputSize = Array.isArray(inputs) ? parseInt(inputs[0].tensorShape.dim[2].size) : null;\n if (!model.inputSize) throw new Error(`Human: Cannot determine model inputSize: ${config.object.modelPath}`);\n if (!model || !model.modelUrl) log('load model failed:', config.object.modelPath);\n else if (config.debug) log('load model:', model.modelUrl);\n } else if (config.debug) log('cached model:', model.modelUrl);\n return model;\n}\n\nasync function process(res, inputSize, outputShape, config) {\n let id = 0;\n let results: Array<{ score: number, strideSize: number, class: number, label: string, center: number[], centerRaw: number[], box: number[], boxRaw: number[] }> = [];\n for (const strideSize of [1, 2, 4]) { // try each stride size as it detects large/medium/small objects\n // find scores, boxes, classes\n tf.tidy(() => { // wrap in tidy to automatically deallocate temp tensors\n const baseSize = strideSize * 13; // 13x13=169, 26x26=676, 52x52=2704\n // find boxes and scores output depending on stride\n const scoresT = res.find((a) => (a.shape[1] === (baseSize ** 2) && a.shape[2] === labels.length))?.squeeze();\n const featuresT = res.find((a) => (a.shape[1] === (baseSize ** 2) && a.shape[2] < labels.length))?.squeeze();\n const boxesMax = featuresT.reshape([-1, 4, featuresT.shape[1] / 4]); // reshape [output] to [4, output / 4] where number is number of different features inside each stride\n const boxIdx = boxesMax.argMax(2).arraySync(); // what we need is indexes of features with highest scores, not values itself\n const scores = scoresT.arraySync(); // optionally use exponential scores or just as-is\n for (let i = 0; i < scoresT.shape[0]; i++) { // total strides (x * y matrix)\n for (let j = 0; j < scoresT.shape[1]; j++) { // one score for each class\n const score = scores[i][j]; // get score for current position\n if (score > config.object.minConfidence && j !== 61) {\n const cx = (0.5 + Math.trunc(i % baseSize)) / baseSize; // center.x normalized to range 0..1\n const cy = (0.5 + Math.trunc(i / baseSize)) / baseSize; // center.y normalized to range 0..1\n const boxOffset = boxIdx[i].map((a) => a * (baseSize / strideSize / inputSize)); // just grab indexes of features with highest scores\n const [x, y] = [\n cx - (scaleBox / strideSize * boxOffset[0]),\n cy - (scaleBox / strideSize * boxOffset[1]),\n ];\n const [w, h] = [\n cx + (scaleBox / strideSize * boxOffset[2]) - x,\n cy + (scaleBox / strideSize * boxOffset[3]) - y,\n ];\n let boxRaw = [x, y, w, h]; // results normalized to range 0..1\n boxRaw = boxRaw.map((a) => Math.max(0, Math.min(a, 1))); // fix out-of-bounds coords\n const box = [ // results normalized to input image pixels\n boxRaw[0] * outputShape[0],\n boxRaw[1] * outputShape[1],\n boxRaw[2] * outputShape[0],\n boxRaw[3] * outputShape[1],\n ];\n const result = {\n id: id++,\n strideSize,\n score: Math.round(100 * score) / 100,\n class: j + 1,\n label: labels[j].label,\n center: [Math.trunc(outputShape[0] * cx), Math.trunc(outputShape[1] * cy)],\n centerRaw: [cx, cy],\n box: box.map((a) => Math.trunc(a)),\n boxRaw,\n };\n results.push(result);\n }\n }\n }\n });\n }\n // deallocate tensors\n res.forEach((t) => tf.dispose(t));\n\n // normally nms is run on raw results, but since boxes need to be calculated this way we skip calulcation of\n // unnecessary boxes and run nms only on good candidates (basically it just does IOU analysis as scores are already filtered)\n const nmsBoxes = results.map((a) => a.boxRaw);\n const nmsScores = results.map((a) => a.score);\n let nmsIdx: any[] = [];\n if (nmsBoxes && nmsBoxes.length > 0) {\n const nms = await tf.image.nonMaxSuppressionAsync(nmsBoxes, nmsScores, config.object.maxDetected, config.object.iouThreshold, config.object.minConfidence);\n nmsIdx = nms.dataSync();\n tf.dispose(nms);\n }\n\n // filter & sort results\n results = results\n .filter((a, idx) => nmsIdx.includes(idx))\n .sort((a, b) => (b.score - a.score));\n\n return results;\n}\n\nexport async function predict(image, config) {\n if (!model) return null;\n // console.log(skipped, config.object.skipFrames, config.videoOptimized, ((skipped < config.object.skipFrames) && config.videoOptimized && (last.length > 0)));\n if ((skipped < config.object.skipFrames) && config.videoOptimized && (last.length > 0)) {\n skipped++;\n return last;\n }\n if (config.videoOptimized) skipped = 0;\n else skipped = Number.MAX_SAFE_INTEGER;\n return new Promise(async (resolve) => {\n const outputSize = [image.shape[2], image.shape[1]];\n const resize = tf.image.resizeBilinear(image, [model.inputSize, model.inputSize], false);\n const norm = resize.div(255);\n const transpose = norm.transpose([0, 3, 1, 2]);\n norm.dispose();\n resize.dispose();\n\n let objectT;\n if (config.object.enabled) objectT = await model.predict(transpose);\n transpose.dispose();\n\n const obj = await process(objectT, model.inputSize, outputSize, config);\n last = obj;\n resolve(obj);\n });\n}\n", "export const labels = [\n { class: 1, label: 'person' },\n { class: 2, label: 'bicycle' },\n { class: 3, label: 'car' },\n { class: 4, label: 'motorcycle' },\n { class: 5, label: 'airplane' },\n { class: 6, label: 'bus' },\n { class: 7, label: 'train' },\n { class: 8, label: 'truck' },\n { class: 9, label: 'boat' },\n { class: 10, label: 'traffic light' },\n { class: 11, label: 'fire hydrant' },\n { class: 12, label: 'stop sign' },\n { class: 13, label: 'parking meter' },\n { class: 14, label: 'bench' },\n { class: 15, label: 'bird' },\n { class: 16, label: 'cat' },\n { class: 17, label: 'dog' },\n { class: 18, label: 'horse' },\n { class: 19, label: 'sheep' },\n { class: 20, label: 'cow' },\n { class: 21, label: 'elephant' },\n { class: 22, label: 'bear' },\n { class: 23, label: 'zebra' },\n { class: 24, label: 'giraffe' },\n { class: 25, label: 'backpack' },\n { class: 26, label: 'umbrella' },\n { class: 27, label: 'handbag' },\n { class: 28, label: 'tie' },\n { class: 29, label: 'suitcase' },\n { class: 30, label: 'frisbee' },\n { class: 31, label: 'skis' },\n { class: 32, label: 'snowboard' },\n { class: 33, label: 'sports ball' },\n { class: 34, label: 'kite' },\n { class: 35, label: 'baseball bat' },\n { class: 36, label: 'baseball glove' },\n { class: 37, label: 'skateboard' },\n { class: 38, label: 'surfboard' },\n { class: 39, label: 'tennis racket' },\n { class: 40, label: 'bottle' },\n { class: 41, label: 'wine glass' },\n { class: 42, label: 'cup' },\n { class: 43, label: 'fork' },\n { class: 44, label: 'knife' },\n { class: 45, label: 'spoon' },\n { class: 46, label: 'bowl' },\n { class: 47, label: 'banana' },\n { class: 48, label: 'apple' },\n { class: 49, label: 'sandwich' },\n { class: 50, label: 'orange' },\n { class: 51, label: 'broccoli' },\n { class: 52, label: 'carrot' },\n { class: 53, label: 'hot dog' },\n { class: 54, label: 'pizza' },\n { class: 55, label: 'donut' },\n { class: 56, label: 'cake' },\n { class: 57, label: 'chair' },\n { class: 58, label: 'couch' },\n { class: 59, label: 'potted plant' },\n { class: 60, label: 'bed' },\n { class: 61, label: 'dining table' },\n { class: 62, label: 'toilet' },\n { class: 63, label: 'tv' },\n { class: 64, label: 'laptop' },\n { class: 65, label: 'mouse' },\n { class: 66, label: 'remote' },\n { class: 67, label: 'keyboard' },\n { class: 68, label: 'cell phone' },\n { class: 69, label: 'microwave' },\n { class: 70, label: 'oven' },\n { class: 71, label: 'toaster' },\n { class: 72, label: 'sink' },\n { class: 73, label: 'refrigerator' },\n { class: 74, label: 'book' },\n { class: 75, label: 'clock' },\n { class: 76, label: 'vase' },\n { class: 77, label: 'scissors' },\n { class: 78, label: 'teddy bear' },\n { class: 79, label: 'hair drier' },\n { class: 80, label: 'toothbrush' },\n];\n", "export const body = (res) => {\n if (!res) return [];\n const gestures: Array<{ body: number, gesture: string }> = [];\n for (let i = 0; i < res.length; i++) {\n // raising hands\n const leftWrist = res[i].keypoints.find((a) => (a.part === 'leftWrist'));\n const rightWrist = res[i].keypoints.find((a) => (a.part === 'rightWrist'));\n const nose = res[i].keypoints.find((a) => (a.part === 'nose'));\n if (nose && leftWrist && rightWrist && (leftWrist.position.y < nose.position.y) && (rightWrist.position.y < nose.position.y)) gestures.push({ body: i, gesture: 'i give up' });\n else if (nose && leftWrist && (leftWrist.position.y < nose.position.y)) gestures.push({ body: i, gesture: 'raise left hand' });\n else if (nose && rightWrist && (rightWrist.position.y < nose.position.y)) gestures.push({ body: i, gesture: 'raise right hand' });\n\n // leaning\n const leftShoulder = res[i].keypoints.find((a) => (a.part === 'leftShoulder'));\n const rightShoulder = res[i].keypoints.find((a) => (a.part === 'rightShoulder'));\n if (leftShoulder && rightShoulder) gestures.push({ body: i, gesture: `leaning ${(leftShoulder.position.y > rightShoulder.position.y) ? 'left' : 'right'}` });\n }\n return gestures;\n};\n\nexport const face = (res) => {\n if (!res) return [];\n const gestures: Array<{ face: number, gesture: string }> = [];\n for (let i = 0; i < res.length; i++) {\n if (res[i].mesh && res[i].mesh.length > 0) {\n const eyeFacing = res[i].mesh[33][2] - res[i].mesh[263][2];\n if (Math.abs(eyeFacing) < 10) gestures.push({ face: i, gesture: 'facing center' });\n else gestures.push({ face: i, gesture: `facing ${eyeFacing < 0 ? 'left' : 'right'}` });\n const openLeft = Math.abs(res[i].mesh[374][1] - res[i].mesh[386][1]) / Math.abs(res[i].mesh[443][1] - res[i].mesh[450][1]); // center of eye inner lid y coord div center of wider eye border y coord\n if (openLeft < 0.2) gestures.push({ face: i, gesture: 'blink left eye' });\n const openRight = Math.abs(res[i].mesh[145][1] - res[i].mesh[159][1]) / Math.abs(res[i].mesh[223][1] - res[i].mesh[230][1]); // center of eye inner lid y coord div center of wider eye border y coord\n if (openRight < 0.2) gestures.push({ face: i, gesture: 'blink right eye' });\n const mouthOpen = Math.min(100, 500 * Math.abs(res[i].mesh[13][1] - res[i].mesh[14][1]) / Math.abs(res[i].mesh[10][1] - res[i].mesh[152][1]));\n if (mouthOpen > 10) gestures.push({ face: i, gesture: `mouth ${Math.trunc(mouthOpen)}% open` });\n const chinDepth = res[i].mesh[152][2];\n if (Math.abs(chinDepth) > 10) gestures.push({ face: i, gesture: `head ${chinDepth < 0 ? 'up' : 'down'}` });\n }\n }\n return gestures;\n};\n\nexport const iris = (res) => {\n if (!res) return [];\n const gestures: Array<{ iris: number, gesture: string }> = [];\n for (let i = 0; i < res.length; i++) {\n if (!res[i].annotations || !res[i].annotations.leftEyeIris || !res[i].annotations.rightEyeIris) continue;\n const sizeXLeft = res[i].annotations.leftEyeIris[3][0] - res[i].annotations.leftEyeIris[1][0];\n const sizeYLeft = res[i].annotations.leftEyeIris[4][1] - res[i].annotations.leftEyeIris[2][1];\n const areaLeft = Math.abs(sizeXLeft * sizeYLeft);\n\n const sizeXRight = res[i].annotations.rightEyeIris[3][0] - res[i].annotations.rightEyeIris[1][0];\n const sizeYRight = res[i].annotations.rightEyeIris[4][1] - res[i].annotations.rightEyeIris[2][1];\n const areaRight = Math.abs(sizeXRight * sizeYRight);\n\n let center = false;\n const difference = Math.abs(areaLeft - areaRight) / Math.max(areaLeft, areaRight);\n if (difference < 0.25) {\n center = true;\n gestures.push({ iris: i, gesture: 'facing center' });\n }\n\n const rightIrisCenterX = Math.abs(res[i].mesh[33][0] - res[i].annotations.rightEyeIris[0][0]) / res[i].annotations.rightEyeIris[0][0];\n const leftIrisCenterX = Math.abs(res[i].mesh[263][0] - res[i].annotations.leftEyeIris[0][0]) / res[i].annotations.leftEyeIris[0][0];\n if (leftIrisCenterX > 0.033 || rightIrisCenterX > 0.033) center = false;\n if (leftIrisCenterX > 0.033) gestures.push({ iris: i, gesture: 'looking right' });\n if (rightIrisCenterX > 0.033) gestures.push({ iris: i, gesture: 'looking left' });\n\n const rightIrisCenterY = Math.abs(res[i].mesh[145][1] - res[i].annotations.rightEyeIris[0][1]) / res[i].annotations.rightEyeIris[0][1];\n const leftIrisCenterY = Math.abs(res[i].mesh[374][1] - res[i].annotations.leftEyeIris[0][1]) / res[i].annotations.leftEyeIris[0][1];\n if (leftIrisCenterY < 0.015 || rightIrisCenterY < 0.015 || leftIrisCenterY > 0.030 || rightIrisCenterY > 0.030) center = false;\n if (leftIrisCenterY < 0.015 || rightIrisCenterY < 0.015) gestures.push({ iris: i, gesture: 'looking down' });\n if (leftIrisCenterY > 0.030 || rightIrisCenterY > 0.030) gestures.push({ iris: i, gesture: 'looking up' });\n\n // still center;\n if (center) gestures.push({ iris: i, gesture: 'looking center' });\n }\n return gestures;\n};\n\nexport const hand = (res) => {\n if (!res) return [];\n const gestures: Array<{ hand: number, gesture: string }> = [];\n for (let i = 0; i < res.length; i++) {\n const fingers: Array<{ name: string, position: number }> = [];\n for (const [finger, pos] of Object.entries(res[i]['annotations'])) {\n if (finger !== 'palmBase' && Array.isArray(pos)) fingers.push({ name: finger.toLowerCase(), position: pos[0] }); // get tip of each finger\n }\n if (fingers && fingers.length > 0) {\n const closest = fingers.reduce((best, a) => (best.position[2] < a.position[2] ? best : a));\n const highest = fingers.reduce((best, a) => (best.position[1] < a.position[1] ? best : a));\n gestures.push({ hand: i, gesture: `${closest.name} forward ${highest.name} up` });\n }\n }\n return gestures;\n};\n", "import * as tf from '../../dist/tfjs.esm.js';\nimport * as fxImage from './imagefx';\n\nconst maxSize = 2048;\n// internal temp canvases\nlet inCanvas;\nlet outCanvas;\n// instance of fximage\nlet fx;\n\n// process input image and return tensor\n// input can be tensor, imagedata, htmlimageelement, htmlvideoelement\n// input is resized and run through imagefx filter\nexport function process(input, config): { tensor: typeof tf.Tensor | null, canvas: OffscreenCanvas | HTMLCanvasElement } {\n let tensor;\n if (!input) throw new Error('Human: Input is missing');\n // sanity checks since different browsers do not implement all dom elements\n if (\n !(input instanceof tf.Tensor)\n && !(typeof Image !== 'undefined' && input instanceof Image)\n && !(typeof ImageData !== 'undefined' && input instanceof ImageData)\n && !(typeof ImageBitmap !== 'undefined' && input instanceof ImageBitmap)\n && !(typeof HTMLImageElement !== 'undefined' && input instanceof HTMLImageElement)\n && !(typeof HTMLMediaElement !== 'undefined' && input instanceof HTMLMediaElement)\n && !(typeof HTMLVideoElement !== 'undefined' && input instanceof HTMLVideoElement)\n && !(typeof HTMLCanvasElement !== 'undefined' && input instanceof HTMLCanvasElement)\n && !(typeof OffscreenCanvas !== 'undefined' && input instanceof OffscreenCanvas)\n ) {\n throw new Error('Human: Input type is not recognized');\n }\n if (input instanceof tf.Tensor) {\n // if input is tensor, use as-is\n if (input.shape && input.shape.length === 4 && input.shape[0] === 1 && input.shape[3] === 3) tensor = tf.clone(input);\n else throw new Error(`Human: Input tensor shape must be [1, height, width, 3] and instead was ${input.shape}`);\n } else {\n // check if resizing will be needed\n const originalWidth = input['naturalWidth'] || input['videoWidth'] || input['width'] || (input['shape'] && (input['shape'][1] > 0));\n const originalHeight = input['naturalHeight'] || input['videoHeight'] || input['height'] || (input['shape'] && (input['shape'][2] > 0));\n let targetWidth = originalWidth;\n let targetHeight = originalHeight;\n if (targetWidth > maxSize) {\n targetWidth = maxSize;\n targetHeight = targetWidth * originalHeight / originalWidth;\n }\n if (targetHeight > maxSize) {\n targetHeight = maxSize;\n targetWidth = targetHeight * originalWidth / originalHeight;\n }\n\n // create our canvas and resize it if needed\n if (config.filter.width > 0) targetWidth = config.filter.width;\n else if (config.filter.height > 0) targetWidth = originalWidth * (config.filter.height / originalHeight);\n if (config.filter.height > 0) targetHeight = config.filter.height;\n else if (config.filter.width > 0) targetHeight = originalHeight * (config.filter.width / originalWidth);\n if (!targetWidth || !targetHeight) throw new Error('Human: Input cannot determine dimension');\n if (!inCanvas || (inCanvas?.width !== targetWidth) || (inCanvas?.height !== targetHeight)) {\n inCanvas = (typeof OffscreenCanvas !== 'undefined') ? new OffscreenCanvas(targetWidth, targetHeight) : document.createElement('canvas');\n if (inCanvas?.width !== targetWidth) inCanvas.width = targetWidth;\n if (inCanvas?.height !== targetHeight) inCanvas.height = targetHeight;\n }\n\n // draw input to our canvas\n const ctx = inCanvas.getContext('2d');\n if (input instanceof ImageData) {\n ctx.putImageData(input, 0, 0);\n } else {\n if (config.filter.flip && typeof ctx.translate !== 'undefined') {\n ctx.translate(originalWidth, 0);\n ctx.scale(-1, 1);\n ctx.drawImage(input, 0, 0, originalWidth, originalHeight, 0, 0, inCanvas?.width, inCanvas?.height);\n ctx.setTransform(1, 0, 0, 1, 0, 0); // resets transforms to defaults\n } else {\n ctx.drawImage(input, 0, 0, originalWidth, originalHeight, 0, 0, inCanvas?.width, inCanvas?.height);\n }\n }\n\n // imagefx transforms using gl\n if (config.filter.enabled) {\n if (!fx || !outCanvas || (inCanvas.width !== outCanvas.width) || (inCanvas?.height !== outCanvas?.height)) {\n outCanvas = (typeof OffscreenCanvas !== 'undefined') ? new OffscreenCanvas(inCanvas?.width, inCanvas?.height) : document.createElement('canvas');\n if (outCanvas?.width !== inCanvas?.width) outCanvas.width = inCanvas?.width;\n if (outCanvas?.height !== inCanvas?.height) outCanvas.height = inCanvas?.height;\n // log('created FX filter');\n fx = tf.ENV.flags.IS_BROWSER ? new fxImage.GLImageFilter({ canvas: outCanvas }) : null; // && (typeof document !== 'undefined')\n }\n if (!fx) return { tensor: null, canvas: inCanvas };\n fx.reset();\n fx.addFilter('brightness', config.filter.brightness); // must have at least one filter enabled\n if (config.filter.contrast !== 0) fx.addFilter('contrast', config.filter.contrast);\n if (config.filter.sharpness !== 0) fx.addFilter('sharpen', config.filter.sharpness);\n if (config.filter.blur !== 0) fx.addFilter('blur', config.filter.blur);\n if (config.filter.saturation !== 0) fx.addFilter('saturation', config.filter.saturation);\n if (config.filter.hue !== 0) fx.addFilter('hue', config.filter.hue);\n if (config.filter.negative) fx.addFilter('negative');\n if (config.filter.sepia) fx.addFilter('sepia');\n if (config.filter.vintage) fx.addFilter('brownie');\n if (config.filter.sepia) fx.addFilter('sepia');\n if (config.filter.kodachrome) fx.addFilter('kodachrome');\n if (config.filter.technicolor) fx.addFilter('technicolor');\n if (config.filter.polaroid) fx.addFilter('polaroid');\n if (config.filter.pixelate !== 0) fx.addFilter('pixelate', config.filter.pixelate);\n fx.apply(inCanvas);\n // read pixel data\n /*\n const gl = outCanvas.getContext('webgl');\n if (gl) {\n const glBuffer = new Uint8Array(outCanvas.width * outCanvas.height * 4);\n const pixBuffer = new Uint8Array(outCanvas.width * outCanvas.height * 3);\n gl.readPixels(0, 0, outCanvas.width, outCanvas.height, gl.RGBA, gl.UNSIGNED_BYTE, glBuffer);\n // gl returns rbga while we only need rgb, so discarding alpha channel\n // gl returns starting point as lower left, so need to invert vertical\n let i = 0;\n for (let y = outCanvas.height - 1; y >= 0; y--) {\n for (let x = 0; x < outCanvas.width; x++) {\n const index = (x + y * outCanvas.width) * 4;\n pixBuffer[i++] = glBuffer[index + 0];\n pixBuffer[i++] = glBuffer[index + 1];\n pixBuffer[i++] = glBuffer[index + 2];\n }\n }\n outCanvas.data = pixBuffer;\n }\n */\n } else {\n outCanvas = inCanvas;\n if (fx) fx = null;\n }\n\n // create tensor from image\n let pixels;\n if (outCanvas.data) { // if we have data, just convert to tensor\n const shape = [outCanvas.height, outCanvas.width, 3];\n pixels = tf.tensor3d(outCanvas.data, shape, 'int32');\n } else if (outCanvas instanceof ImageData) { // if input is imagedata, just use it\n pixels = tf.browser.fromPixels(outCanvas);\n } else if (config.backend === 'webgl' || config.backend === 'humangl') { // tf kernel-optimized method to get imagedata\n // we can use canvas as-is as it already has a context, so we do a silly one more canvas\n const tempCanvas = (typeof OffscreenCanvas !== 'undefined') ? new OffscreenCanvas(targetWidth, targetHeight) : document.createElement('canvas');\n tempCanvas.width = targetWidth;\n tempCanvas.height = targetHeight;\n const tempCtx = tempCanvas.getContext('2d');\n tempCtx?.drawImage(outCanvas, 0, 0);\n pixels = tf.browser.fromPixels(tempCanvas);\n } else { // cpu and wasm kernel does not implement efficient fromPixels method\n // we can use canvas as-is as it already has a context, so we do a silly one more canvas\n const tempCanvas = (typeof OffscreenCanvas !== 'undefined') ? new OffscreenCanvas(targetWidth, targetHeight) : document.createElement('canvas');\n tempCanvas.width = targetWidth;\n tempCanvas.height = targetHeight;\n const tempCtx = tempCanvas.getContext('2d');\n tempCtx?.drawImage(outCanvas, 0, 0);\n const data = tempCtx?.getImageData(0, 0, targetWidth, targetHeight);\n pixels = tf.browser.fromPixels(data);\n }\n const casted = pixels.toFloat();\n tensor = casted.expandDims(0);\n pixels.dispose();\n casted.dispose();\n }\n const canvas = config.filter.return ? outCanvas : null;\n return { tensor, canvas };\n}\n", "/*\nWebGLImageFilter - MIT Licensed\n2013, Dominic Szablewski - phoboslab.org\n\n*/\n\nfunction GLProgram(gl, vertexSource, fragmentSource) {\n const _collect = function (source, prefix, collection) {\n const r = new RegExp('\\\\b' + prefix + ' \\\\w+ (\\\\w+)', 'ig');\n source.replace(r, (match, name) => {\n collection[name] = 0;\n return match;\n });\n };\n\n const _compile = function (source, type) {\n const shader = gl.createShader(type);\n gl.shaderSource(shader, source);\n gl.compileShader(shader);\n if (!gl.getShaderParameter(shader, gl.COMPILE_STATUS)) throw new Error('Filter: GL compile failed', gl.getShaderInfoLog(shader));\n return shader;\n };\n\n this.uniform = {};\n this.attribute = {};\n const _vsh = _compile(vertexSource, gl.VERTEX_SHADER);\n const _fsh = _compile(fragmentSource, gl.FRAGMENT_SHADER);\n this.id = gl.createProgram();\n gl.attachShader(this.id, _vsh);\n gl.attachShader(this.id, _fsh);\n gl.linkProgram(this.id);\n\n if (!gl.getProgramParameter(this.id, gl.LINK_STATUS)) throw new Error('Filter: GL link failed', gl.getProgramInfoLog(this.id));\n\n gl.useProgram(this.id);\n // Collect attributes\n _collect(vertexSource, 'attribute', this.attribute);\n for (const a in this.attribute) this.attribute[a] = gl.getAttribLocation(this.id, a);\n // Collect uniforms\n _collect(vertexSource, 'uniform', this.uniform);\n _collect(fragmentSource, 'uniform', this.uniform);\n for (const u in this.uniform) this.uniform[u] = gl.getUniformLocation(this.id, u);\n}\n\n// export const GLImageFilter = function (params) {\nexport function GLImageFilter(params) {\n if (!params) params = { };\n let _drawCount = 0;\n let _sourceTexture = null;\n let _lastInChain = false;\n let _currentFramebufferIndex = -1;\n let _tempFramebuffers = [null, null];\n let _filterChain = [];\n let _width = -1;\n let _height = -1;\n let _vertexBuffer = null;\n let _currentProgram = null;\n const _filter = {};\n const _canvas = params.canvas || document.createElement('canvas');\n // key is the shader program source, value is the compiled program\n const _shaderProgramCache = { };\n const DRAW = { INTERMEDIATE: 1 };\n const gl = _canvas.getContext('webgl');\n if (!gl) throw new Error('Filter: getContext() failed');\n\n this.addFilter = function (name) {\n // eslint-disable-next-line prefer-rest-params\n const args = Array.prototype.slice.call(arguments, 1);\n const filter = _filter[name];\n _filterChain.push({ func: filter, args });\n };\n\n this.reset = function () {\n _filterChain = [];\n };\n\n const _resize = function (width, height) {\n // Same width/height? Nothing to do here\n if (width === _width && height === _height) { return; }\n _canvas.width = width;\n _width = width;\n _canvas.height = height;\n _height = height;\n // Create the context if we don't have it yet\n if (!_vertexBuffer) {\n // Create the vertex buffer for the two triangles [x, y, u, v] * 6\n const vertices = new Float32Array([\n -1, -1, 0, 1, 1, -1, 1, 1, -1, 1, 0, 0,\n -1, 1, 0, 0, 1, -1, 1, 1, 1, 1, 1, 0,\n ]);\n // eslint-disable-next-line no-unused-expressions\n (_vertexBuffer = gl.createBuffer(), gl.bindBuffer(gl.ARRAY_BUFFER, _vertexBuffer));\n gl.bufferData(gl.ARRAY_BUFFER, vertices, gl.STATIC_DRAW);\n gl.pixelStorei(gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, true);\n }\n gl.viewport(0, 0, _width, _height);\n // Delete old temp framebuffers\n _tempFramebuffers = [null, null];\n };\n\n const _createFramebufferTexture = function (width, height) {\n const fbo = gl.createFramebuffer();\n gl.bindFramebuffer(gl.FRAMEBUFFER, fbo);\n const renderbuffer = gl.createRenderbuffer();\n gl.bindRenderbuffer(gl.RENDERBUFFER, renderbuffer);\n const texture = gl.createTexture();\n gl.bindTexture(gl.TEXTURE_2D, texture);\n gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, width, height, 0, gl.RGBA, gl.UNSIGNED_BYTE, null);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\n gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, texture, 0);\n gl.bindTexture(gl.TEXTURE_2D, null);\n gl.bindFramebuffer(gl.FRAMEBUFFER, null);\n return { fbo, texture };\n };\n\n const _getTempFramebuffer = function (index) {\n _tempFramebuffers[index] = _tempFramebuffers[index] || _createFramebufferTexture(_width, _height);\n return _tempFramebuffers[index];\n };\n\n const _draw = function (flags = null) {\n let source = null;\n let target = null;\n let flipY = false;\n // Set up the source\n if (_drawCount === 0) {\n // First draw call - use the source texture\n source = _sourceTexture;\n } else {\n // All following draw calls use the temp buffer last drawn to\n source = _getTempFramebuffer(_currentFramebufferIndex)?.texture;\n }\n _drawCount++;\n // Set up the target\n if (_lastInChain && !(flags & DRAW.INTERMEDIATE)) {\n // Last filter in our chain - draw directly to the WebGL Canvas. We may\n // also have to flip the image vertically now\n target = null;\n flipY = _drawCount % 2 === 0;\n } else {\n // Intermediate draw call - get a temp buffer to draw to\n _currentFramebufferIndex = (_currentFramebufferIndex + 1) % 2;\n target = _getTempFramebuffer(_currentFramebufferIndex)?.fbo;\n }\n // Bind the source and target and draw the two triangles\n gl.bindTexture(gl.TEXTURE_2D, source);\n gl.bindFramebuffer(gl.FRAMEBUFFER, target);\n gl.uniform1f(_currentProgram.uniform.flipY, (flipY ? -1 : 1));\n gl.drawArrays(gl.TRIANGLES, 0, 6);\n };\n\n this.apply = function (image) {\n _resize(image.width, image.height);\n _drawCount = 0;\n // Create the texture for the input image if we haven't yet\n if (!_sourceTexture) _sourceTexture = gl.createTexture();\n gl.bindTexture(gl.TEXTURE_2D, _sourceTexture);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.NEAREST);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.NEAREST);\n gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, image);\n // No filters? Just draw\n if (_filterChain.length === 0) {\n // const program = _compileShader(SHADER.FRAGMENT_IDENTITY);\n _draw();\n return _canvas;\n }\n for (let i = 0; i < _filterChain.length; i++) {\n _lastInChain = (i === _filterChain.length - 1);\n const f = _filterChain[i];\n f.func.apply(this, f.args || []);\n }\n return _canvas;\n };\n\n const _compileShader = function (fragmentSource) {\n if (_shaderProgramCache[fragmentSource]) {\n _currentProgram = _shaderProgramCache[fragmentSource];\n gl.useProgram(_currentProgram.id);\n return _currentProgram;\n }\n // Compile shaders\n const SHADER = {};\n SHADER.VERTEX_IDENTITY = [\n 'precision highp float;',\n 'attribute vec2 pos;',\n 'attribute vec2 uv;',\n 'varying vec2 vUv;',\n 'uniform float flipY;',\n 'void main(void) {',\n 'vUv = uv;',\n 'gl_Position = vec4(pos.x, pos.y*flipY, 0.0, 1.);',\n '}',\n ].join('\\n');\n SHADER.FRAGMENT_IDENTITY = [\n 'precision highp float;',\n 'varying vec2 vUv;',\n 'uniform sampler2D texture;',\n 'void main(void) {',\n 'gl_FragColor = texture2D(texture, vUv);',\n '}',\n ].join('\\n');\n _currentProgram = new GLProgram(gl, SHADER.VERTEX_IDENTITY, fragmentSource);\n const floatSize = Float32Array.BYTES_PER_ELEMENT;\n const vertSize = 4 * floatSize;\n gl.enableVertexAttribArray(_currentProgram.attribute.pos);\n gl.vertexAttribPointer(_currentProgram.attribute.pos, 2, gl.FLOAT, false, vertSize, 0 * floatSize);\n gl.enableVertexAttribArray(_currentProgram.attribute.uv);\n gl.vertexAttribPointer(_currentProgram.attribute.uv, 2, gl.FLOAT, false, vertSize, 2 * floatSize);\n _shaderProgramCache[fragmentSource] = _currentProgram;\n return _currentProgram;\n };\n\n // -------------------------------------------------------------------------\n // Color Matrix Filter\n _filter.colorMatrix = function (matrix) {\n // Create a Float32 Array and normalize the offset component to 0-1\n const m = new Float32Array(matrix);\n m[4] /= 255;\n m[9] /= 255;\n m[14] /= 255;\n m[19] /= 255;\n // Can we ignore the alpha value? Makes things a bit faster.\n const shader = (m[18] === 1 && m[3] === 0 && m[8] === 0 && m[13] === 0 && m[15] === 0 && m[16] === 0 && m[17] === 0 && m[19] === 0)\n ? _filter.colorMatrix.SHADER.WITHOUT_ALPHA\n : _filter.colorMatrix.SHADER.WITH_ALPHA;\n const program = _compileShader(shader);\n gl.uniform1fv(program.uniform.m, m);\n _draw();\n };\n _filter.colorMatrix.SHADER = {};\n _filter.colorMatrix.SHADER.WITH_ALPHA = [\n 'precision highp float;',\n 'varying vec2 vUv;',\n 'uniform sampler2D texture;',\n 'uniform float m[20];',\n 'void main(void) {',\n 'vec4 c = texture2D(texture, vUv);',\n 'gl_FragColor.r = m[0] * c.r + m[1] * c.g + m[2] * c.b + m[3] * c.a + m[4];',\n 'gl_FragColor.g = m[5] * c.r + m[6] * c.g + m[7] * c.b + m[8] * c.a + m[9];',\n 'gl_FragColor.b = m[10] * c.r + m[11] * c.g + m[12] * c.b + m[13] * c.a + m[14];',\n 'gl_FragColor.a = m[15] * c.r + m[16] * c.g + m[17] * c.b + m[18] * c.a + m[19];',\n '}',\n ].join('\\n');\n _filter.colorMatrix.SHADER.WITHOUT_ALPHA = [\n 'precision highp float;',\n 'varying vec2 vUv;',\n 'uniform sampler2D texture;',\n 'uniform float m[20];',\n 'void main(void) {',\n 'vec4 c = texture2D(texture, vUv);',\n 'gl_FragColor.r = m[0] * c.r + m[1] * c.g + m[2] * c.b + m[4];',\n 'gl_FragColor.g = m[5] * c.r + m[6] * c.g + m[7] * c.b + m[9];',\n 'gl_FragColor.b = m[10] * c.r + m[11] * c.g + m[12] * c.b + m[14];',\n 'gl_FragColor.a = c.a;',\n '}',\n ].join('\\n');\n\n _filter.brightness = function (brightness) {\n const b = (brightness || 0) + 1;\n _filter.colorMatrix([\n b, 0, 0, 0, 0,\n 0, b, 0, 0, 0,\n 0, 0, b, 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n _filter.saturation = function (amount) {\n const x = (amount || 0) * 2 / 3 + 1;\n const y = ((x - 1) * -0.5);\n _filter.colorMatrix([\n x, y, y, 0, 0,\n y, x, y, 0, 0,\n y, y, x, 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n _filter.desaturate = function () {\n _filter.saturation(-1);\n };\n\n _filter.contrast = function (amount) {\n const v = (amount || 0) + 1;\n const o = -128 * (v - 1);\n\n _filter.colorMatrix([\n v, 0, 0, 0, o,\n 0, v, 0, 0, o,\n 0, 0, v, 0, o,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n _filter.negative = function () {\n _filter.contrast(-2);\n };\n\n _filter.hue = function (rotation) {\n rotation = (rotation || 0) / 180 * Math.PI;\n const cos = Math.cos(rotation);\n const sin = Math.sin(rotation);\n const lumR = 0.213;\n const lumG = 0.715;\n const lumB = 0.072;\n\n _filter.colorMatrix([\n lumR + cos * (1 - lumR) + sin * (-lumR), lumG + cos * (-lumG) + sin * (-lumG), lumB + cos * (-lumB) + sin * (1 - lumB), 0, 0,\n lumR + cos * (-lumR) + sin * (0.143), lumG + cos * (1 - lumG) + sin * (0.140), lumB + cos * (-lumB) + sin * (-0.283), 0, 0,\n lumR + cos * (-lumR) + sin * (-(1 - lumR)), lumG + cos * (-lumG) + sin * (lumG), lumB + cos * (1 - lumB) + sin * (lumB), 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n _filter.desaturateLuminance = function () {\n _filter.colorMatrix([\n 0.2764723, 0.9297080, 0.0938197, 0, -37.1,\n 0.2764723, 0.9297080, 0.0938197, 0, -37.1,\n 0.2764723, 0.9297080, 0.0938197, 0, -37.1,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n _filter.sepia = function () {\n _filter.colorMatrix([\n 0.393, 0.7689999, 0.18899999, 0, 0,\n 0.349, 0.6859999, 0.16799999, 0, 0,\n 0.272, 0.5339999, 0.13099999, 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n _filter.brownie = function () {\n _filter.colorMatrix([\n 0.5997023498159715, 0.34553243048391263, -0.2708298674538042, 0, 47.43192855600873,\n -0.037703249837783157, 0.8609577587992641, 0.15059552388459913, 0, -36.96841498319127,\n 0.24113635128153335, -0.07441037908422492, 0.44972182064877153, 0, -7.562075277591283,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n _filter.vintagePinhole = function () {\n _filter.colorMatrix([\n 0.6279345635605994, 0.3202183420819367, -0.03965408211312453, 0, 9.651285835294123,\n 0.02578397704808868, 0.6441188644374771, 0.03259127616149294, 0, 7.462829176470591,\n 0.0466055556782719, -0.0851232987247891, 0.5241648018700465, 0, 5.159190588235296,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n _filter.kodachrome = function () {\n _filter.colorMatrix([\n 1.1285582396593525, -0.3967382283601348, -0.03992559172921793, 0, 63.72958762196502,\n -0.16404339962244616, 1.0835251566291304, -0.05498805115633132, 0, 24.732407896706203,\n -0.16786010706155763, -0.5603416277695248, 1.6014850761964943, 0, 35.62982807460946,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n _filter.technicolor = function () {\n _filter.colorMatrix([\n 1.9125277891456083, -0.8545344976951645, -0.09155508482755585, 0, 11.793603434377337,\n -0.3087833385928097, 1.7658908555458428, -0.10601743074722245, 0, -70.35205161461398,\n -0.231103377548616, -0.7501899197440212, 1.847597816108189, 0, 30.950940869491138,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n _filter.polaroid = function () {\n _filter.colorMatrix([\n 1.438, -0.062, -0.062, 0, 0,\n -0.122, 1.378, -0.122, 0, 0,\n -0.016, -0.016, 1.483, 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n _filter.shiftToBGR = function () {\n _filter.colorMatrix([\n 0, 0, 1, 0, 0,\n 0, 1, 0, 0, 0,\n 1, 0, 0, 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n };\n\n // -------------------------------------------------------------------------\n // Convolution Filter\n _filter.convolution = function (matrix) {\n const m = new Float32Array(matrix);\n const pixelSizeX = 1 / _width;\n const pixelSizeY = 1 / _height;\n const program = _compileShader(_filter.convolution.SHADER);\n gl.uniform1fv(program.uniform.m, m);\n gl.uniform2f(program.uniform.px, pixelSizeX, pixelSizeY);\n _draw();\n };\n\n _filter.convolution.SHADER = [\n 'precision highp float;',\n 'varying vec2 vUv;',\n 'uniform sampler2D texture;',\n 'uniform vec2 px;',\n 'uniform float m[9];',\n 'void main(void) {',\n 'vec4 c11 = texture2D(texture, vUv - px);', // top left\n 'vec4 c12 = texture2D(texture, vec2(vUv.x, vUv.y - px.y));', // top center\n 'vec4 c13 = texture2D(texture, vec2(vUv.x + px.x, vUv.y - px.y));', // top right\n 'vec4 c21 = texture2D(texture, vec2(vUv.x - px.x, vUv.y) );', // mid left\n 'vec4 c22 = texture2D(texture, vUv);', // mid center\n 'vec4 c23 = texture2D(texture, vec2(vUv.x + px.x, vUv.y) );', // mid right\n 'vec4 c31 = texture2D(texture, vec2(vUv.x - px.x, vUv.y + px.y) );', // bottom left\n 'vec4 c32 = texture2D(texture, vec2(vUv.x, vUv.y + px.y) );', // bottom center\n 'vec4 c33 = texture2D(texture, vUv + px );', // bottom right\n 'gl_FragColor = ',\n 'c11 * m[0] + c12 * m[1] + c22 * m[2] +',\n 'c21 * m[3] + c22 * m[4] + c23 * m[5] +',\n 'c31 * m[6] + c32 * m[7] + c33 * m[8];',\n 'gl_FragColor.a = c22.a;',\n '}',\n ].join('\\n');\n\n _filter.detectEdges = function () {\n _filter.convolution.call(this, [\n 0, 1, 0,\n 1, -4, 1,\n 0, 1, 0,\n ]);\n };\n\n _filter.sobelX = function () {\n _filter.convolution.call(this, [\n -1, 0, 1,\n -2, 0, 2,\n -1, 0, 1,\n ]);\n };\n\n _filter.sobelY = function () {\n _filter.convolution.call(this, [\n -1, -2, -1,\n 0, 0, 0,\n 1, 2, 1,\n ]);\n };\n\n _filter.sharpen = function (amount) {\n const a = amount || 1;\n _filter.convolution.call(this, [\n 0, -1 * a, 0,\n -1 * a, 1 + 4 * a, -1 * a,\n 0, -1 * a, 0,\n ]);\n };\n\n _filter.emboss = function (size) {\n const s = size || 1;\n _filter.convolution.call(this, [\n -2 * s, -1 * s, 0,\n -1 * s, 1, 1 * s,\n 0, 1 * s, 2 * s,\n ]);\n };\n\n // -------------------------------------------------------------------------\n // Blur Filter\n _filter.blur = function (size) {\n const blurSizeX = (size / 7) / _width;\n const blurSizeY = (size / 7) / _height;\n const program = _compileShader(_filter.blur.SHADER);\n // Vertical\n gl.uniform2f(program.uniform.px, 0, blurSizeY);\n _draw(DRAW.INTERMEDIATE);\n // Horizontal\n gl.uniform2f(program.uniform.px, blurSizeX, 0);\n _draw();\n };\n\n _filter.blur.SHADER = [\n 'precision highp float;',\n 'varying vec2 vUv;',\n 'uniform sampler2D texture;',\n 'uniform vec2 px;',\n 'void main(void) {',\n 'gl_FragColor = vec4(0.0);',\n 'gl_FragColor += texture2D(texture, vUv + vec2(-7.0*px.x, -7.0*px.y))*0.0044299121055113265;',\n 'gl_FragColor += texture2D(texture, vUv + vec2(-6.0*px.x, -6.0*px.y))*0.00895781211794;',\n 'gl_FragColor += texture2D(texture, vUv + vec2(-5.0*px.x, -5.0*px.y))*0.0215963866053;',\n 'gl_FragColor += texture2D(texture, vUv + vec2(-4.0*px.x, -4.0*px.y))*0.0443683338718;',\n 'gl_FragColor += texture2D(texture, vUv + vec2(-3.0*px.x, -3.0*px.y))*0.0776744219933;',\n 'gl_FragColor += texture2D(texture, vUv + vec2(-2.0*px.x, -2.0*px.y))*0.115876621105;',\n 'gl_FragColor += texture2D(texture, vUv + vec2(-1.0*px.x, -1.0*px.y))*0.147308056121;',\n 'gl_FragColor += texture2D(texture, vUv )*0.159576912161;',\n 'gl_FragColor += texture2D(texture, vUv + vec2( 1.0*px.x, 1.0*px.y))*0.147308056121;',\n 'gl_FragColor += texture2D(texture, vUv + vec2( 2.0*px.x, 2.0*px.y))*0.115876621105;',\n 'gl_FragColor += texture2D(texture, vUv + vec2( 3.0*px.x, 3.0*px.y))*0.0776744219933;',\n 'gl_FragColor += texture2D(texture, vUv + vec2( 4.0*px.x, 4.0*px.y))*0.0443683338718;',\n 'gl_FragColor += texture2D(texture, vUv + vec2( 5.0*px.x, 5.0*px.y))*0.0215963866053;',\n 'gl_FragColor += texture2D(texture, vUv + vec2( 6.0*px.x, 6.0*px.y))*0.00895781211794;',\n 'gl_FragColor += texture2D(texture, vUv + vec2( 7.0*px.x, 7.0*px.y))*0.0044299121055113265;',\n '}',\n ].join('\\n');\n\n // -------------------------------------------------------------------------\n // Pixelate Filter\n _filter.pixelate = function (size) {\n const blurSizeX = (size) / _width;\n const blurSizeY = (size) / _height;\n const program = _compileShader(_filter.pixelate.SHADER);\n // Horizontal\n gl.uniform2f(program.uniform.size, blurSizeX, blurSizeY);\n _draw();\n };\n\n _filter.pixelate.SHADER = [\n 'precision highp float;',\n 'varying vec2 vUv;',\n 'uniform vec2 size;',\n 'uniform sampler2D texture;',\n 'vec2 pixelate(vec2 coord, vec2 size) {',\n 'return floor( coord / size ) * size;',\n '}',\n 'void main(void) {',\n 'gl_FragColor = vec4(0.0);',\n 'vec2 coord = pixelate(vUv, size);',\n 'gl_FragColor += texture2D(texture, coord);',\n '}',\n ].join('\\n');\n}\n", "import { TRI468 as triangulation } from '../blazeface/coords';\nimport { mergeDeep } from '../helpers';\n\n/**\n * Draw Options\n * Accessed via `human.draw.options` or provided per each draw method as the drawOptions optional parameter\n * -color: draw color\n * -labelColor: color for labels\n * -shadowColor: optional shadow color for labels\n * -font: font for labels\n * -lineHeight: line height for labels, used for multi-line labels,\n * -lineWidth: width of any lines,\n * -pointSize: size of any point,\n * -roundRect: for boxes, round corners by this many pixels,\n * -drawPoints: should points be drawn,\n * -drawLabels: should labels be drawn,\n * -drawBoxes: should boxes be drawn,\n * -drawPolygons: should polygons be drawn,\n * -fillPolygons: should drawn polygons be filled,\n * -useDepth: use z-axis coordinate as color shade,\n * -useCurves: draw polygons as cures or as lines,\n * -bufferedOutput: experimental: allows to call draw methods multiple times for each detection and interpolate results between results thus achieving smoother animations\n * -useRawBoxes: Boolean: internal: use non-normalized coordinates when performing draw methods,\n */\nexport interface DrawOptions {\n color: string,\n labelColor: string,\n shadowColor: string,\n font: string,\n lineHeight: number,\n lineWidth: number,\n pointSize: number,\n roundRect: number,\n drawPoints: Boolean,\n drawLabels: Boolean,\n drawBoxes: Boolean,\n drawPolygons: Boolean,\n fillPolygons: Boolean,\n useDepth: Boolean,\n useCurves: Boolean,\n bufferedOutput: Boolean,\n useRawBoxes: Boolean,\n calculateHandBox: Boolean,\n}\n\nexport const options: DrawOptions = {\n color: 'rgba(173, 216, 230, 0.3)', // 'lightblue' with light alpha channel\n labelColor: 'rgba(173, 216, 230, 1)', // 'lightblue' with dark alpha channel\n shadowColor: 'black',\n font: 'small-caps 16px \"Segoe UI\"',\n lineHeight: 24,\n lineWidth: 6,\n pointSize: 2,\n roundRect: 28,\n drawPoints: false,\n drawLabels: true,\n drawBoxes: false,\n drawPolygons: true,\n fillPolygons: false,\n useDepth: true,\n useCurves: false,\n bufferedOutput: false,\n useRawBoxes: false,\n calculateHandBox: true,\n};\n\nfunction point(ctx, x, y, z = 0, localOptions) {\n ctx.fillStyle = localOptions.useDepth && z ? `rgba(${127.5 + (2 * z)}, ${127.5 - (2 * z)}, 255, 0.3)` : localOptions.color;\n ctx.beginPath();\n ctx.arc(x, y, localOptions.pointSize, 0, 2 * Math.PI);\n ctx.fill();\n}\n\nfunction rect(ctx, x, y, width, height, localOptions) {\n ctx.beginPath();\n if (localOptions.useCurves) {\n const cx = (x + x + width) / 2;\n const cy = (y + y + height) / 2;\n ctx.ellipse(cx, cy, width / 2, height / 2, 0, 0, 2 * Math.PI);\n } else {\n ctx.lineWidth = localOptions.lineWidth;\n ctx.moveTo(x + localOptions.roundRect, y);\n ctx.lineTo(x + width - localOptions.roundRect, y);\n ctx.quadraticCurveTo(x + width, y, x + width, y + localOptions.roundRect);\n ctx.lineTo(x + width, y + height - localOptions.roundRect);\n ctx.quadraticCurveTo(x + width, y + height, x + width - localOptions.roundRect, y + height);\n ctx.lineTo(x + localOptions.roundRect, y + height);\n ctx.quadraticCurveTo(x, y + height, x, y + height - localOptions.roundRect);\n ctx.lineTo(x, y + localOptions.roundRect);\n ctx.quadraticCurveTo(x, y, x + localOptions.roundRect, y);\n ctx.closePath();\n }\n ctx.stroke();\n}\n\nfunction lines(ctx, points: number[] = [], localOptions) {\n if (points === undefined || points.length === 0) return;\n ctx.beginPath();\n ctx.moveTo(points[0][0], points[0][1]);\n for (const pt of points) {\n ctx.strokeStyle = localOptions.useDepth && pt[2] ? `rgba(${127.5 + (2 * pt[2])}, ${127.5 - (2 * pt[2])}, 255, 0.3)` : localOptions.color;\n ctx.fillStyle = localOptions.useDepth && pt[2] ? `rgba(${127.5 + (2 * pt[2])}, ${127.5 - (2 * pt[2])}, 255, 0.3)` : localOptions.color;\n ctx.lineTo(pt[0], parseInt(pt[1]));\n }\n ctx.stroke();\n if (localOptions.fillPolygons) {\n ctx.closePath();\n ctx.fill();\n }\n}\n\nfunction curves(ctx, points: number[] = [], localOptions) {\n if (points === undefined || points.length === 0) return;\n if (!localOptions.useCurves || points.length <= 2) {\n lines(ctx, points, localOptions);\n return;\n }\n ctx.moveTo(points[0][0], points[0][1]);\n for (let i = 0; i < points.length - 2; i++) {\n const xc = (points[i][0] + points[i + 1][0]) / 2;\n const yc = (points[i][1] + points[i + 1][1]) / 2;\n ctx.quadraticCurveTo(points[i][0], points[i][1], xc, yc);\n }\n ctx.quadraticCurveTo(points[points.length - 2][0], points[points.length - 2][1], points[points.length - 1][0], points[points.length - 1][1]);\n ctx.stroke();\n if (localOptions.fillPolygons) {\n ctx.closePath();\n ctx.fill();\n }\n}\n\nexport async function gesture(inCanvas: HTMLCanvasElement, result: Array, drawOptions?: DrawOptions) {\n const localOptions = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n if (!(inCanvas instanceof HTMLCanvasElement)) return;\n const ctx = inCanvas.getContext('2d');\n if (!ctx) return;\n ctx.font = localOptions.font;\n ctx.fillStyle = localOptions.color;\n let i = 1;\n for (let j = 0; j < result.length; j++) {\n let where:any[] = [];\n let what:any[] = [];\n [where, what] = Object.entries(result[j]);\n if ((what.length > 1) && (what[1].length > 0)) {\n const person = where[1] > 0 ? `#${where[1]}` : '';\n const label = `${where[0]} ${person}: ${what[1]}`;\n if (localOptions.shadowColor && localOptions.shadowColor !== '') {\n ctx.fillStyle = localOptions.shadowColor;\n ctx.fillText(label, 8, 2 + (i * localOptions.lineHeight));\n }\n ctx.fillStyle = localOptions.labelColor;\n ctx.fillText(label, 6, 0 + (i * localOptions.lineHeight));\n i += 1;\n }\n }\n}\n\nexport async function face(inCanvas: HTMLCanvasElement, result: Array, drawOptions?: DrawOptions) {\n const localOptions = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n if (!(inCanvas instanceof HTMLCanvasElement)) return;\n const ctx = inCanvas.getContext('2d');\n if (!ctx) return;\n for (const f of result) {\n ctx.font = localOptions.font;\n ctx.strokeStyle = localOptions.color;\n ctx.fillStyle = localOptions.color;\n if (localOptions.drawBoxes) {\n if (localOptions.useRawBoxes) rect(ctx, inCanvas.width * f.boxRaw[0], inCanvas.height * f.boxRaw[1], inCanvas.width * f.boxRaw[2], inCanvas.height * f.boxRaw[3], localOptions);\n else rect(ctx, f.box[0], f.box[1], f.box[2], f.box[3], localOptions);\n }\n // silly hack since fillText does not suport new line\n const labels:string[] = [];\n labels.push(`face confidence: ${Math.trunc(100 * f.confidence)}%`);\n if (f.genderConfidence) labels.push(`${f.gender || ''} ${Math.trunc(100 * f.genderConfidence)}% confident`);\n // if (f.genderConfidence) labels.push(f.gender);\n if (f.age) labels.push(`age: ${f.age || ''}`);\n if (f.iris) labels.push(`iris distance: ${f.iris}`);\n if (f.emotion && f.emotion.length > 0) {\n const emotion = f.emotion.map((a) => `${Math.trunc(100 * a.score)}% ${a.emotion}`);\n labels.push(emotion.join(' '));\n }\n if (f.rotation && f.rotation.angle && f.rotation.angle.roll) labels.push(`roll: ${Math.trunc(100 * f.rotation.angle.roll) / 100} yaw:${Math.trunc(100 * f.rotation.angle.yaw) / 100} pitch:${Math.trunc(100 * f.rotation.angle.pitch) / 100}`);\n if (labels.length === 0) labels.push('face');\n ctx.fillStyle = localOptions.color;\n for (let i = labels.length - 1; i >= 0; i--) {\n const x = Math.max(f.box[0], 0);\n const y = i * localOptions.lineHeight + f.box[1];\n if (localOptions.shadowColor && localOptions.shadowColor !== '') {\n ctx.fillStyle = localOptions.shadowColor;\n ctx.fillText(labels[i], x + 5, y + 16);\n }\n ctx.fillStyle = localOptions.labelColor;\n ctx.fillText(labels[i], x + 4, y + 15);\n }\n ctx.lineWidth = 1;\n if (f.mesh && f.mesh.length > 0) {\n if (localOptions.drawPoints) {\n for (const pt of f.mesh) point(ctx, pt[0], pt[1], pt[2], localOptions);\n // for (const pt of f.meshRaw) point(ctx, pt[0] * inCanvas.offsetWidth, pt[1] * inCanvas.offsetHeight, pt[2]);\n }\n if (localOptions.drawPolygons) {\n ctx.lineWidth = 1;\n for (let i = 0; i < triangulation.length / 3; i++) {\n const points = [\n triangulation[i * 3 + 0],\n triangulation[i * 3 + 1],\n triangulation[i * 3 + 2],\n ].map((index) => f.mesh[index]);\n lines(ctx, points, localOptions);\n }\n // iris: array[center, left, top, right, bottom]\n if (f.annotations && f.annotations.leftEyeIris) {\n ctx.strokeStyle = localOptions.useDepth ? 'rgba(255, 200, 255, 0.3)' : localOptions.color;\n ctx.beginPath();\n const sizeX = Math.abs(f.annotations.leftEyeIris[3][0] - f.annotations.leftEyeIris[1][0]) / 2;\n const sizeY = Math.abs(f.annotations.leftEyeIris[4][1] - f.annotations.leftEyeIris[2][1]) / 2;\n ctx.ellipse(f.annotations.leftEyeIris[0][0], f.annotations.leftEyeIris[0][1], sizeX, sizeY, 0, 0, 2 * Math.PI);\n ctx.stroke();\n if (localOptions.fillPolygons) {\n ctx.fillStyle = localOptions.useDepth ? 'rgba(255, 255, 200, 0.3)' : localOptions.color;\n ctx.fill();\n }\n }\n if (f.annotations && f.annotations.rightEyeIris) {\n ctx.strokeStyle = localOptions.useDepth ? 'rgba(255, 200, 255, 0.3)' : localOptions.color;\n ctx.beginPath();\n const sizeX = Math.abs(f.annotations.rightEyeIris[3][0] - f.annotations.rightEyeIris[1][0]) / 2;\n const sizeY = Math.abs(f.annotations.rightEyeIris[4][1] - f.annotations.rightEyeIris[2][1]) / 2;\n ctx.ellipse(f.annotations.rightEyeIris[0][0], f.annotations.rightEyeIris[0][1], sizeX, sizeY, 0, 0, 2 * Math.PI);\n ctx.stroke();\n if (localOptions.fillPolygons) {\n ctx.fillStyle = localOptions.useDepth ? 'rgba(255, 255, 200, 0.3)' : localOptions.color;\n ctx.fill();\n }\n }\n }\n }\n }\n}\n\nconst lastDrawnPose:any[] = [];\nexport async function body(inCanvas: HTMLCanvasElement, result: Array, drawOptions?: DrawOptions) {\n const localOptions = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n if (!(inCanvas instanceof HTMLCanvasElement)) return;\n const ctx = inCanvas.getContext('2d');\n if (!ctx) return;\n ctx.lineJoin = 'round';\n for (let i = 0; i < result.length; i++) {\n // result[i].keypoints = result[i].keypoints.filter((a) => a.score > 0.5);\n if (!lastDrawnPose[i] && localOptions.bufferedOutput) lastDrawnPose[i] = { ...result[i] };\n ctx.strokeStyle = localOptions.color;\n ctx.fillStyle = localOptions.color;\n ctx.lineWidth = localOptions.lineWidth;\n ctx.font = localOptions.font;\n if (localOptions.drawBoxes) {\n rect(ctx, result[i].box[0], result[i].box[1], result[i].box[2], result[i].box[3], localOptions);\n if (localOptions.drawLabels) {\n if (localOptions.shadowColor && localOptions.shadowColor !== '') {\n ctx.fillStyle = localOptions.shadowColor;\n ctx.fillText(`body ${100 * result[i].score}%`, result[i].box[0] + 3, 1 + result[i].box[1] + localOptions.lineHeight, result[i].box[2]);\n }\n ctx.fillStyle = localOptions.labelColor;\n ctx.fillText(`body ${100 * result[i].score}%`, result[i].box[0] + 2, 0 + result[i].box[1] + localOptions.lineHeight, result[i].box[2]);\n }\n }\n if (localOptions.drawPoints) {\n for (let pt = 0; pt < result[i].keypoints.length; pt++) {\n ctx.fillStyle = localOptions.useDepth && result[i].keypoints[pt].position.z ? `rgba(${127.5 + (2 * result[i].keypoints[pt].position.z)}, ${127.5 - (2 * result[i].keypoints[pt].position.z)}, 255, 0.5)` : localOptions.color;\n if (localOptions.bufferedOutput) {\n lastDrawnPose[i].keypoints[pt][0] = (lastDrawnPose[i].keypoints[pt][0] + result[i].keypoints[pt].position.x) / 2;\n lastDrawnPose[i].keypoints[pt][1] = (lastDrawnPose[i].keypoints[pt][1] + result[i].keypoints[pt].position.y) / 2;\n point(ctx, lastDrawnPose[i].keypoints[pt][0], lastDrawnPose[i].keypoints[pt][1], 0, localOptions);\n } else {\n point(ctx, result[i].keypoints[pt].position.x, result[i].keypoints[pt].position.y, 0, localOptions);\n }\n }\n }\n if (localOptions.drawLabels) {\n ctx.font = localOptions.font;\n if (result[i].keypoints) {\n for (const pt of result[i].keypoints) {\n ctx.fillStyle = localOptions.useDepth && pt.position.z ? `rgba(${127.5 + (2 * pt.position.z)}, ${127.5 - (2 * pt.position.z)}, 255, 0.5)` : localOptions.color;\n ctx.fillText(`${pt.part} ${Math.trunc(100 * pt.score)}%`, pt.position.x + 4, pt.position.y + 4);\n }\n }\n }\n if (localOptions.drawPolygons && result[i].keypoints) {\n let part;\n const points: any[] = [];\n // shoulder line\n points.length = 0;\n part = result[i].keypoints.find((a) => a.part === 'leftShoulder');\n if (part) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'rightShoulder');\n if (part) points.push([part.position.x, part.position.y]);\n curves(ctx, points, localOptions);\n // torso main\n points.length = 0;\n part = result[i].keypoints.find((a) => a.part === 'rightShoulder');\n if (part) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'rightHip');\n if (part) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'leftHip');\n if (part) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'leftShoulder');\n if (part) points.push([part.position.x, part.position.y]);\n if (points.length === 4) lines(ctx, points, localOptions); // only draw if we have complete torso\n // leg left\n points.length = 0;\n part = result[i].keypoints.find((a) => a.part === 'leftHip');\n if (part) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'leftKnee');\n if (part) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'leftAnkle');\n if (part) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'leftHeel');\n if (part) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'leftFoot');\n if (part) points.push([part.position.x, part.position.y]);\n curves(ctx, points, localOptions);\n // leg right\n points.length = 0;\n part = result[i].keypoints.find((a) => a.part === 'rightHip');\n if (part) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'rightKnee');\n if (part) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'rightAnkle');\n if (part) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'rightHeel');\n if (part) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'rightFoot');\n if (part) points.push([part.position.x, part.position.y]);\n curves(ctx, points, localOptions);\n // arm left\n points.length = 0;\n part = result[i].keypoints.find((a) => a.part === 'leftShoulder');\n if (part) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'leftElbow');\n if (part) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'leftWrist');\n if (part) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'leftPalm');\n if (part) points.push([part.position.x, part.position.y]);\n curves(ctx, points, localOptions);\n // arm right\n points.length = 0;\n part = result[i].keypoints.find((a) => a.part === 'rightShoulder');\n if (part) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'rightElbow');\n if (part) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'rightWrist');\n if (part) points.push([part.position.x, part.position.y]);\n part = result[i].keypoints.find((a) => a.part === 'rightPalm');\n if (part) points.push([part.position.x, part.position.y]);\n curves(ctx, points, localOptions);\n // draw all\n }\n }\n}\n\nexport async function hand(inCanvas: HTMLCanvasElement, result: Array, drawOptions?: DrawOptions) {\n const localOptions = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n if (!(inCanvas instanceof HTMLCanvasElement)) return;\n const ctx = inCanvas.getContext('2d');\n if (!ctx) return;\n ctx.lineJoin = 'round';\n ctx.font = localOptions.font;\n for (const h of result) {\n if (localOptions.drawBoxes) {\n ctx.strokeStyle = localOptions.color;\n ctx.fillStyle = localOptions.color;\n let box;\n if (!localOptions.calculateHandBox) {\n box = localOptions.useRawBoxes ? h.boxRaw : h.box;\n } else {\n box = [Number.MAX_SAFE_INTEGER, Number.MAX_SAFE_INTEGER, 0, 0];\n if (h.landmarks && h.landmarks.length > 0) {\n for (const pt of h.landmarks) {\n if (pt[0] < box[0]) box[0] = pt[0];\n if (pt[1] < box[1]) box[1] = pt[1];\n if (pt[0] > box[2]) box[2] = pt[0];\n if (pt[1] > box[3]) box[3] = pt[1];\n }\n box[2] -= box[0];\n box[3] -= box[1];\n }\n }\n if (localOptions.useRawBoxes) rect(ctx, inCanvas.width * box[0], inCanvas.height * box[1], inCanvas.width * box[2], inCanvas.height * box[3], localOptions);\n else rect(ctx, box[0], box[1], box[2], box[3], localOptions);\n if (localOptions.drawLabels) {\n if (localOptions.shadowColor && localOptions.shadowColor !== '') {\n ctx.fillStyle = localOptions.shadowColor;\n ctx.fillText('hand', box[0] + 3, 1 + box[1] + localOptions.lineHeight, box[2]);\n }\n ctx.fillStyle = localOptions.labelColor;\n ctx.fillText('hand', box[0] + 2, 0 + box[1] + localOptions.lineHeight, box[2]);\n }\n ctx.stroke();\n }\n if (localOptions.drawPoints) {\n if (h.landmarks && h.landmarks.length > 0) {\n for (const pt of h.landmarks) {\n ctx.fillStyle = localOptions.useDepth ? `rgba(${127.5 + (2 * pt[2])}, ${127.5 - (2 * pt[2])}, 255, 0.5)` : localOptions.color;\n point(ctx, pt[0], pt[1], 0, localOptions);\n }\n }\n }\n if (localOptions.drawLabels) {\n const addHandLabel = (part, title) => {\n ctx.fillStyle = localOptions.useDepth ? `rgba(${127.5 + (2 * part[part.length - 1][2])}, ${127.5 - (2 * part[part.length - 1][2])}, 255, 0.5)` : localOptions.color;\n ctx.fillText(title, part[part.length - 1][0] + 4, part[part.length - 1][1] + 4);\n };\n ctx.font = localOptions.font;\n addHandLabel(h.annotations.indexFinger, 'index');\n addHandLabel(h.annotations.middleFinger, 'middle');\n addHandLabel(h.annotations.ringFinger, 'ring');\n addHandLabel(h.annotations.pinky, 'pinky');\n addHandLabel(h.annotations.thumb, 'thumb');\n addHandLabel(h.annotations.palmBase, 'palm');\n }\n if (localOptions.drawPolygons) {\n const addHandLine = (part) => {\n if (!part) return;\n for (let i = 0; i < part.length; i++) {\n ctx.beginPath();\n ctx.strokeStyle = localOptions.useDepth ? `rgba(${127.5 + (2 * part[i][2])}, ${127.5 - (2 * part[i][2])}, 255, 0.5)` : localOptions.color;\n ctx.moveTo(part[i > 0 ? i - 1 : 0][0], part[i > 0 ? i - 1 : 0][1]);\n ctx.lineTo(part[i][0], part[i][1]);\n ctx.stroke();\n }\n };\n ctx.lineWidth = localOptions.lineWidth;\n addHandLine(h.annotations.indexFinger);\n addHandLine(h.annotations.middleFinger);\n addHandLine(h.annotations.ringFinger);\n addHandLine(h.annotations.pinky);\n addHandLine(h.annotations.thumb);\n // addPart(h.annotations.palmBase);\n }\n }\n}\n\nexport async function object(inCanvas: HTMLCanvasElement, result: Array, drawOptions?: DrawOptions) {\n const localOptions = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n if (!(inCanvas instanceof HTMLCanvasElement)) return;\n const ctx = inCanvas.getContext('2d');\n if (!ctx) return;\n ctx.lineJoin = 'round';\n ctx.font = localOptions.font;\n for (const h of result) {\n if (localOptions.drawBoxes) {\n ctx.strokeStyle = localOptions.color;\n ctx.fillStyle = localOptions.color;\n if (localOptions.useRawBoxes) rect(ctx, inCanvas.width * h.boxRaw[0], inCanvas.height * h.boxRaw[1], inCanvas.width * h.boxRaw[2], inCanvas.height * h.boxRaw[3], localOptions);\n else rect(ctx, h.box[0], h.box[1], h.box[2], h.box[3], localOptions);\n if (localOptions.drawLabels) {\n const label = `${Math.round(100 * h.score)}% ${h.label}`;\n if (localOptions.shadowColor && localOptions.shadowColor !== '') {\n ctx.fillStyle = localOptions.shadowColor;\n ctx.fillText(label, h.box[0] + 3, 1 + h.box[1] + localOptions.lineHeight, h.box[2]);\n }\n ctx.fillStyle = localOptions.labelColor;\n ctx.fillText(label, h.box[0] + 2, 0 + h.box[1] + localOptions.lineHeight, h.box[2]);\n }\n ctx.stroke();\n }\n }\n}\n\nexport async function canvas(inCanvas: HTMLCanvasElement, outCanvas: HTMLCanvasElement) {\n if (!inCanvas || !outCanvas) return;\n if (!(inCanvas instanceof HTMLCanvasElement) || !(outCanvas instanceof HTMLCanvasElement)) return;\n const outCtx = inCanvas.getContext('2d');\n outCtx?.drawImage(inCanvas, 0, 0);\n}\n\nexport async function all(inCanvas: HTMLCanvasElement, result:any, drawOptions?: DrawOptions) {\n const localOptions = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n if (!(inCanvas instanceof HTMLCanvasElement)) return;\n face(inCanvas, result.face, localOptions);\n body(inCanvas, result.body, localOptions);\n hand(inCanvas, result.hand, localOptions);\n gesture(inCanvas, result.gesture, localOptions);\n object(inCanvas, result.object, localOptions);\n}\n", "/* eslint-disable indent */\n/* eslint-disable no-multi-spaces */\n\n/**\n * Configuration interface definition for **Human** library\n *\n * Contains all configurable parameters\n */\nexport interface Config {\n /** Backend used for TFJS operations */\n backend: null | '' | 'cpu' | 'wasm' | 'webgl' | 'humangl' | 'tensorflow',\n\n /** Path to *.wasm files if backend is set to `wasm` */\n wasmPath: string,\n\n /** Print debug statements to console */\n debug: boolean,\n\n /** Perform model loading and inference concurrently or sequentially */\n async: boolean,\n\n /** Perform additional optimizations when input is video,\n * - must be disabled for images\n * - automatically disabled for Image, ImageData, ImageBitmap and Tensor inputs\n * - skips boundary detection for every `skipFrames` frames specified for each model\n * - while maintaining in-box detection since objects don't change definition as fast */\n videoOptimized: boolean,\n\n /** What to use for `human.warmup()`\n * - warmup pre-initializes all models for faster inference but can take significant time on startup\n * - only used for `webgl` and `humangl` backends\n */\n warmup: 'none' | 'face' | 'full' | 'body',\n\n /** Base model path (typically starting with file://, http:// or https://) for all models\n * - individual modelPath values are relative to this path\n */\n modelBasePath: string,\n\n /** Run input through image filters before inference\n * - image filters run with near-zero latency as they are executed on the GPU\n */\n filter: {\n enabled: boolean,\n /** Resize input width\n * - if both width and height are set to 0, there is no resizing\n * - if just one is set, second one is scaled automatically\n * - if both are set, values are used as-is\n */\n width: number,\n /** Resize input height\n * - if both width and height are set to 0, there is no resizing\n * - if just one is set, second one is scaled automatically\n * - if both are set, values are used as-is\n */\n height: number,\n /** Return processed canvas imagedata in result */\n return: boolean,\n /** Flip input as mirror image */\n flip: boolean,\n /** Range: -1 (darken) to 1 (lighten) */\n brightness: number,\n /** Range: -1 (reduce contrast) to 1 (increase contrast) */\n contrast: number,\n /** Range: 0 (no sharpening) to 1 (maximum sharpening) */\n sharpness: number,\n /** Range: 0 (no blur) to N (blur radius in pixels) */\n blur: number\n /** Range: -1 (reduce saturation) to 1 (increase saturation) */\n saturation: number,\n /** Range: 0 (no change) to 360 (hue rotation in degrees) */\n hue: number,\n /** Image negative */\n negative: boolean,\n /** Image sepia colors */\n sepia: boolean,\n /** Image vintage colors */\n vintage: boolean,\n /** Image kodachrome colors */\n kodachrome: boolean,\n /** Image technicolor colors */\n technicolor: boolean,\n /** Image polaroid camera effect */\n polaroid: boolean,\n /** Range: 0 (no pixelate) to N (number of pixels to pixelate) */\n pixelate: number,\n },\n // type definition end\n\n /** Controlls gesture detection */\n gesture: {\n enabled: boolean,\n },\n\n /** Controlls and configures all face-specific options:\n * - face detection, face mesh detection, age, gender, emotion detection and face description\n * Parameters:\n * - enabled: true/false\n * - modelPath: path for each of face models\n * - minConfidence: threshold for discarding a prediction\n * - iouThreshold: ammount of overlap between two detected objects before one object is removed\n * - maxDetected: maximum number of faces detected in the input, should be set to the minimum number for performance\n * - rotation: use calculated rotated face image or just box with rotation as-is, false means higher performance, but incorrect mesh mapping on higher face angles\n * - skipFrames: how many frames to go without re-running the face detector and just run modified face mesh analysis, only valid if videoOptimized is set to true\n * - skipInitial: if previous detection resulted in no faces detected, should skipFrames be reset immediately to force new detection cycle\n * - return: return extracted face as tensor for futher user processing\n */\n face: {\n enabled: boolean,\n detector: {\n modelPath: string,\n rotation: boolean,\n maxDetected: number,\n skipFrames: number,\n skipInitial: boolean,\n minConfidence: number,\n iouThreshold: number,\n return: boolean,\n },\n mesh: {\n enabled: boolean,\n modelPath: string,\n },\n iris: {\n enabled: boolean,\n modelPath: string,\n },\n description: {\n enabled: boolean,\n modelPath: string,\n skipFrames: number,\n minConfidence: number,\n },\n emotion: {\n enabled: boolean,\n minConfidence: number,\n skipFrames: number,\n modelPath: string,\n },\n },\n\n /** Controlls and configures all body detection specific options\n * - enabled: true/false\n * - modelPath: body pose model, can be absolute path or relative to modelBasePath\n * - minConfidence: threshold for discarding a prediction\n * - maxDetected: maximum number of people detected in the input, should be set to the minimum number for performance\n */\n body: {\n enabled: boolean,\n modelPath: string,\n maxDetected: number,\n minConfidence: number,\n },\n\n /** Controlls and configures all hand detection specific options\n * - enabled: true/false\n * - landmarks: detect hand landmarks or just hand boundary box\n * - modelPath: paths for hand detector and hand skeleton models, can be absolute path or relative to modelBasePath\n * - minConfidence: threshold for discarding a prediction\n * - iouThreshold: ammount of overlap between two detected objects before one object is removed\n * - maxDetected: maximum number of hands detected in the input, should be set to the minimum number for performance\n * - rotation: use best-guess rotated hand image or just box with rotation as-is, false means higher performance, but incorrect finger mapping if hand is inverted\n * - skipFrames: how many frames to go without re-running the hand bounding box detector and just run modified hand skeleton detector, only valid if videoOptimized is set to true\n * - skipInitial: if previous detection resulted in no hands detected, should skipFrames be reset immediately to force new detection cycle\n */\n hand: {\n enabled: boolean,\n rotation: boolean,\n skipFrames: number,\n skipInitial: boolean,\n minConfidence: number,\n iouThreshold: number,\n maxDetected: number,\n landmarks: boolean,\n detector: {\n modelPath: string,\n },\n skeleton: {\n modelPath: string,\n },\n },\n\n /** Controlls and configures all object detection specific options\n * - enabled: true/false\n * - modelPath: object detection model, can be absolute path or relative to modelBasePath\n * - minConfidence: minimum score that detection must have to return as valid object\n * - iouThreshold: ammount of overlap between two detected objects before one object is removed\n * - maxDetected: maximum number of detections to return\n * - skipFrames: run object detection every n input frames, only valid if videoOptimized is set to true\n */\n object: {\n enabled: boolean,\n modelPath: string,\n minConfidence: number,\n iouThreshold: number,\n maxDetected: number,\n skipFrames: number,\n },\n}\n\nconst config: Config = {\n backend: 'webgl', // select tfjs backend to use, leave empty to use default backend\n // can be 'webgl', 'wasm', 'cpu', or 'humangl' which is a custom version of webgl\n modelBasePath: '../models/', // base path for all models\n wasmPath: '../assets/', // path for wasm binariesm, only used for backend: wasm\n debug: true, // print additional status messages to console\n async: true, // execute enabled models in parallel\n videoOptimized: true, // perform additional optimizations when input is video,\n // automatically disabled for Image, ImageData, ImageBitmap\n // skips boundary detection for every n frames\n // while maintaining in-box detection since objects cannot move that fast\n warmup: 'full', // what to use for human.warmup(), can be 'none', 'face', 'full'\n // warmup pre-initializes all models for faster inference but can take\n // significant time on startup\n // only used for `webgl` and `humangl` backends\n filter: { // run input through image filters before inference\n // image filters run with near-zero latency as they are executed on the GPU\n enabled: true, // enable image pre-processing filters\n width: 0, // resize input width\n height: 0, // resize input height\n // if both width and height are set to 0, there is no resizing\n // if just one is set, second one is scaled automatically\n // if both are set, values are used as-is\n flip: false, // flip input as mirror image\n return: true, // return processed canvas imagedata in result\n brightness: 0, // range: -1 (darken) to 1 (lighten)\n contrast: 0, // range: -1 (reduce contrast) to 1 (increase contrast)\n sharpness: 0, // range: 0 (no sharpening) to 1 (maximum sharpening)\n blur: 0, // range: 0 (no blur) to N (blur radius in pixels)\n saturation: 0, // range: -1 (reduce saturation) to 1 (increase saturation)\n hue: 0, // range: 0 (no change) to 360 (hue rotation in degrees)\n negative: false, // image negative\n sepia: false, // image sepia colors\n vintage: false, // image vintage colors\n kodachrome: false, // image kodachrome colors\n technicolor: false, // image technicolor colors\n polaroid: false, // image polaroid camera effect\n pixelate: 0, // range: 0 (no pixelate) to N (number of pixels to pixelate)\n },\n\n gesture: {\n enabled: true, // enable gesture recognition based on model results\n },\n\n face: {\n enabled: true, // controls if specified modul is enabled\n // face.enabled is required for all face models:\n // detector, mesh, iris, age, gender, emotion\n // (note: module is not loaded until it is required)\n detector: {\n modelPath: 'blazeface.json', // detector model, can be absolute path or relative to modelBasePath\n rotation: false, // use best-guess rotated face image or just box with rotation as-is\n // false means higher performance, but incorrect mesh mapping if face angle is above 20 degrees\n // this parameter is not valid in nodejs\n maxDetected: 10, // maximum number of faces detected in the input\n // should be set to the minimum number for performance\n skipFrames: 21, // how many frames to go without re-running the face bounding box detector\n // only used for video inputs\n // e.g., if model is running st 25 FPS, we can re-use existing bounding\n // box for updated face analysis as the head probably hasn't moved much\n // in short time (10 * 1/25 = 0.25 sec)\n skipInitial: false, // if previous detection resulted in no faces detected,\n // should skipFrames be reset immediately to force new detection cycle\n minConfidence: 0.2, // threshold for discarding a prediction\n iouThreshold: 0.1, // ammount of overlap between two detected objects before one object is removed\n return: false, // return extracted face as tensor\n },\n\n mesh: {\n enabled: true,\n modelPath: 'facemesh.json', // facemesh model, can be absolute path or relative to modelBasePath\n },\n\n iris: {\n enabled: true,\n modelPath: 'iris.json', // face iris model\n // can be either absolute path or relative to modelBasePath\n },\n\n description: {\n enabled: true, // to improve accuracy of face description extraction it is\n // recommended to enable detector.rotation and mesh.enabled\n modelPath: 'faceres.json', // face description model\n // can be either absolute path or relative to modelBasePath\n skipFrames: 31, // how many frames to go without re-running the detector\n // only used for video inputs\n minConfidence: 0.1, // threshold for discarding a prediction\n },\n\n emotion: {\n enabled: true,\n minConfidence: 0.1, // threshold for discarding a prediction\n skipFrames: 32, // how many frames to go without re-running the detector\n modelPath: 'emotion.json', // face emotion model, can be absolute path or relative to modelBasePath\n },\n },\n\n body: {\n enabled: true,\n modelPath: 'posenet.json', // body model, can be absolute path or relative to modelBasePath\n // can be 'posenet' or 'blazepose'\n maxDetected: 1, // maximum number of people detected in the input\n // should be set to the minimum number for performance\n // only valid for posenet as blazepose only detects single pose\n minConfidence: 0.1, // threshold for discarding a prediction\n },\n\n hand: {\n enabled: true,\n rotation: false, // use best-guess rotated hand image or just box with rotation as-is\n // false means higher performance, but incorrect finger mapping if hand is inverted\n skipFrames: 12, // how many frames to go without re-running the hand bounding box detector\n // only used for video inputs\n // e.g., if model is running st 25 FPS, we can re-use existing bounding\n // box for updated hand skeleton analysis as the hand probably\n // hasn't moved much in short time (10 * 1/25 = 0.25 sec)\n skipInitial: false, // if previous detection resulted in no hands detected,\n // should skipFrames be reset immediately to force new detection cycle\n minConfidence: 0.1, // threshold for discarding a prediction\n iouThreshold: 0.1, // ammount of overlap between two detected objects before one object is removed\n maxDetected: 1, // maximum number of hands detected in the input\n // should be set to the minimum number for performance\n landmarks: true, // detect hand landmarks or just hand boundary box\n detector: {\n modelPath: 'handdetect.json', // hand detector model, can be absolute path or relative to modelBasePath\n },\n skeleton: {\n modelPath: 'handskeleton.json', // hand skeleton model, can be absolute path or relative to modelBasePath\n },\n },\n\n object: {\n enabled: false,\n modelPath: 'nanodet.json', // experimental: object detection model, can be absolute path or relative to modelBasePath\n minConfidence: 0.2, // threshold for discarding a prediction\n iouThreshold: 0.4, // ammount of overlap between two detected objects before one object is removed\n maxDetected: 10, // maximum number of objects detected in the input\n skipFrames: 41, // how many frames to go without re-running the detector\n },\n};\nexport { config as defaults };\n", "// data:image/jpeg;base64,\nexport const face = `\n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`;\n\n// data:image/jpeg;base64,\nexport const body = `\n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\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAa2p1UYo5adbz+xbxMlvqJ1OqjDHLXree0ejmzNrWm953tPmTPWbWneZ7yoy5YhjrXXTjH8s75N\nmtkyxt0VZM2/m175N1V03yTKubMLXVXybeYLLX2VXy7eam+b0bOg4VquJW+rry4/O9uyZOq3UjVm\n9r25axMzPaIdvhns1kzbZddM0p5Y47z8/R2+HcF03Doi1a8+Xzvbv+TotJnjDXkt+K8ODHp8cY8N\nIpSO0RCwF2YAAAAAAAAACvUZYw6fJkntWN3k8dfHz2vLucdz8mkjFE9bz1+UOZosX1UzPm0nqI/W\nMYo9FlcPNklfFGeH/NshLGun+Cz6PtHZtVZWlRLS+jxPkRpIn7rdoupHTdA5s6SI+7H6Mfo+32Y2\n+To3neSIiZ7A0IjPXpXLePlMotGW3272t85datKzHZjbTVnsDj+FG/2Y/RlGP4R+jo20u7H6N1Ql\no+H8I/REY957R+jpfReiK6eOYHLtj2tttH6KrY/6Y/R2c+kjeJiFVtLG24hxpw7/AHY/RRkw9O37\nO99Hrt1YX0tfOBLjcGp4XF8c+u8fs9c4dcVcGemSI61nd3IneN1orQAAAAAAAAAAAAABFqxes1tE\nTE9JiUgPKcX4RbRXnNgiZwWnrH4XPi28PdXpW9JraImsxtMS8pxXhF9DecuGJtgmf+1TWW2N/la1\nL7N7T5e3Vy6W3hsYcvLbqzbO9jvvCzvDR0+XeO7crO6FmGSvRThy/RtVXJ92elvk2rRvDUzU7pl4\nizsd2J3jeBpcNz+Lg5LT7+Pp+Xk3W7js5eAAgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADs0NTrN96Yp6edkW8Wzm6+LNTq4pvTHO9vOfRoWtt\n1mes95YWvs1s2fZldddOczLPLn2ju0MmebT3YZc2/mpm3qqllN1drsbZIhr3yzvtHf4AsvlYYseb\nV5Yx4KTe0+UQ6nDvZ3UazbJqd8OKeu33peq0eh0+hxcmnxxWPOfOfm0mP+steT/ji8N9mKY9suum\nL37+HHaPm9DSlaVitKxWsdohI0Y22gAgAAAAAAAAAABXnyRhw3yT92Nwef4xm8bVzET0rPJH5d12\n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\nAOZE/OsPS29nuH27YrV+VpeV9pdPXhOtw49NG9Mld55+vXcTPd42I47qo7xSfyWV9oM8d8VJ/VxM\nd8l46xWF9cV7en6o/qLfxp2I9ob+eCv/AHMo9op89P8A/wBORGmyT5R+qfo2X8P7n9Q/jTsx7RR5\n6ef+4/8AuHftg/8A6cWcOSO9J/WEbWr3pY7Efzp2Lcfv5YK/9zWy8d1E/ZpSv5Oba1/+Hb9lc+LP\nbFt87I7E/wAabWbiurvEx4nL/pjZzc2bJkn372t85ZXx55/BX85lucC0vPxnTxlnnjm32mOiZqUu\nLJ2p4TwnVavNWaYbRTfre0bQ99pcH0bT0xb78vmtiIiNojaErMwAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAHnfarF7umzRHaZrLjYrdIen9ocPi8JyTt1xzF4eUw23rCm3R4r6bMy\nwt6kdTaWLdjswmNoZontsCm0K5XWjopnuDC0dGpqG5bs08/daKV672MjbSaif6oh6Z5f2LtvptRX\n0tEvUN3Jfo8f7cYve0eX4zV7B5z20xc/C8eSPuZIRficfXlcPaG7ino08HWIbePpLF2NuiyOyrHK\n3fZFSwuovHVfaVF4QK5YWTM9UT0EKry6Ps1Tn4zjn8NZn9nOtLseydObiWW34cf918fWfk+PYANn\nKAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAq1WKM+ly4p+/WYeBxTNd6zG0xO0\nvobw3FcP0bi2em20Tbmj5Srr418V9sa2Z7qKyzi07MXUylhaU7yjqhLCeiq3ddaFNxFYW7NLNG8t\nzya+WO6Va9J7FW66mvwidnrXiPY3Ny8RyUn71Jj9Ht3RPjk19HK9pMHj8D1ER3rHN+jqqtTjjNps\nuOe16zAifXzfTz7kNyndpYazS9qT0mszDdoxrsi6m8LazMq6zDOsq1ZEyrt1WWlXaUCqyq0rbKbi\nFdp6PReyFd8uqv8ACsfy83aXrPZHHto89/xX2/SP/dpj6y8vx6EBq5gAAAAAAAAAAAAAAAAAAAAA\n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\nNO67NbkhzNVnmInqzaOZrL93JyZeV0M1++7S02jvxDWxhxx033tPpC8Z6rrezWjmZyazJG2/u03h\n2vFibTHoqvamiwVwY+nLGzV0+SZ1Mx8G0/45tOhzJ5lXMc3UVXRdlF1HP+iYsDPLPPy49/tz1+Te\npSIr0ho6ak5Ms5J8o2q6NImOrHV7XX488ypzTtHXo0s9t6zG7c1G1qz6ubeZiZ3UatXJG3yauSO7\ncvMTEx5tPLb3prPRMVr0HB8vicNxf0+7+kt+LOJwTJyY/Bnz3tH93X36N58cWvq6LSyiyndMSlC7\nmZcymLJiwLosmJVRLKLAtiU7q4lMSCzc3YxJuDMRuAlKAEgAAAlAkAAAAAABKAEgAAAAAJAAAAAA\nAAAAAAAEgAAAAAAAAAAAAAkAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAhIAAACAAAASgAAAAAAEAAAA\nhGzJAImGMwzQDDZjNVuyNgUTVhNGxysZqDVmiu1G5NN2M4waM0+DCaN2cbGcQNGaMZq3JxMJxA1J\nqx2bU4kU09slorWNwa20z02RXHbJbl26QvtFovbHWkxEdJt5y2MOHlr2U1W3jx+1hiw8vSO63lmI\nXRTaEWmtY6snRHO1VpmJ+DjavpSZl2s8b7y4HFcnh0n0gha5ebJN55KRM2mdoiPN6fh+kpwXh0Wy\nRHj5Otp/s5Ps1p62y31+em9aTMYt/OfVfxTiPjZ52naI7fBrI5t66xz5+a1rW7yx0eSL6iZjtEOX\nqNbSletom3lENjh2fbHzbbWt3iVozruc+5ztWubf4M4ybpQ2Oboyrva0Vjza8WdDR4OkXt3n9ldX\nkaePP9VtYqctYhdvt5oivTeCZ2YOxXk6ubqMfV0b9mrljfqlFcq88k7z2U5axeItDa1OPessuC8P\nya7XRWYnwqdbT/ZMilvIu4dpslNdixXja8Y5tt85djZdbDWnGOesRtXFtuw6T27No5Kx2OrKYQlC\nExKJgBnEpiyvdlEgsizKLKollFgWxLKJVRLKJBbEp3VxLKJBnuMWQJEbpBIAAAJAAAABIAAAAAAA\nlAJAAAAAAAAAAAAAASAAAAAAAAAAAAAJAAAABAJABAlAAAAAAAAAAAAAAAAAAAAAAAAIAAAAAAAA\nAAABAJQAAAAgAABAAI2EoBGyJhkgGPKxmqxAKpownHC+YRMdN5BrTj67R3bOn01o7p01Iv71u89o\n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\n2Q==`;\n", "import { log, now, mergeDeep } from './helpers';\nimport * as sysinfo from './sysinfo';\nimport * as tf from '../dist/tfjs.esm.js';\nimport * as backend from './tfjs/backend';\nimport * as faceall from './faceall';\nimport * as facemesh from './blazeface/facemesh';\nimport * as faceres from './faceres/faceres';\nimport * as emotion from './emotion/emotion';\nimport * as posenet from './posenet/posenet';\nimport * as handpose from './handpose/handpose';\nimport * as blazepose from './blazepose/blazepose';\nimport * as nanodet from './nanodet/nanodet';\nimport * as gesture from './gesture/gesture';\nimport * as image from './image/image';\nimport * as draw from './draw/draw';\nimport { Config, defaults } from './config';\nimport { Result } from './result';\nimport * as sample from './sample';\nimport * as app from '../package.json';\n\n/** Generic Tensor object type */\nexport type Tensor = typeof tf.Tensor;\n\nexport type { Config } from './config';\nexport type { Result } from './result';\nexport type { DrawOptions } from './draw/draw';\n\n/** Defines all possible input types for **Human** detection */\nexport type Input = Tensor | typeof Image | ImageData | ImageBitmap | HTMLImageElement | HTMLMediaElement | HTMLVideoElement | HTMLCanvasElement | OffscreenCanvas;\n\n/** Error message */\nexport type Error = { error: string };\n\n/** Instance of TensorFlow/JS */\nexport type TensorFlow = typeof tf;\n\n/** Generic Model object type, holds instance of individual models */\ntype Model = Object;\n\n/**\n * **Human** library main class\n *\n * All methods and properties are available only as members of Human class\n *\n * - Configuration object definition: {@link Config}\n * - Results object definition: {@link Result}\n * - Possible inputs: {@link Input}\n */\nexport class Human {\n /** Current version of Human library in semver format */\n version: string;\n /** Current configuration\n * - Details: {@link Config}\n */\n config: Config;\n /** Current state of Human library\n * - Can be polled to determine operations that are currently executed\n */\n state: string;\n /** Internal: Instance of current image being processed */\n image: { tensor: Tensor | null, canvas: OffscreenCanvas | HTMLCanvasElement | null };\n /** Internal: Instance of TensorFlow/JS used by Human\n * - Can be embedded or externally provided\n */\n tf: TensorFlow;\n /** Draw helper classes that can draw detected objects on canvas using specified draw styles\n * - options: global settings for all draw operations, can be overriden for each draw method, for details see {@link DrawOptions}\n * - face: draw detected faces\n * - body: draw detected people and body parts\n * - hand: draw detected hands and hand parts\n * - canvas: draw processed canvas which is a processed copy of the input\n * - all: meta-function that performs: canvas, face, body, hand\n */\n draw: {\n options: draw.DrawOptions,\n gesture: typeof draw.gesture,\n face: typeof draw.face,\n body: typeof draw.body,\n hand: typeof draw.hand,\n canvas: typeof draw.canvas,\n all: typeof draw.all,\n };\n /** Internal: Currently loaded models */\n models: {\n face: [Model, Model, Model] | null,\n posenet: Model | null,\n blazepose: Model | null,\n efficientpose: Model | null,\n handpose: [Model, Model] | null,\n iris: Model | null,\n age: Model | null,\n gender: Model | null,\n emotion: Model | null,\n embedding: Model | null,\n nanodet: Model | null,\n faceres: Model | null,\n };\n /** Internal: Currently loaded classes */\n classes: {\n facemesh: typeof facemesh;\n emotion: typeof emotion;\n body: typeof posenet | typeof blazepose;\n hand: typeof handpose;\n nanodet: typeof nanodet;\n faceres: typeof faceres;\n };\n /** Face triangualtion array of 468 points, used for triangle references between points */\n faceTriangulation: typeof facemesh.triangulation;\n /** UV map of 468 values, used for 3D mapping of the face mesh */\n faceUVMap: typeof facemesh.uvmap;\n /** Platform and agent information detected by Human */\n sysinfo: { platform: string, agent: string };\n /** Performance object that contains values for all recently performed operations */\n perf: any;\n #numTensors: number;\n #analyzeMemoryLeaks: boolean;\n #checkSanity: boolean;\n #firstRun: boolean;\n\n // definition end\n\n /**\n * Creates instance of Human library that is futher used for all operations\n * - @param userConfig: {@link Config}\n */\n constructor(userConfig: Config | Object = {}) {\n this.tf = tf;\n this.draw = draw;\n this.version = app.version;\n this.config = mergeDeep(defaults, userConfig);\n this.state = 'idle';\n this.#numTensors = 0;\n this.#analyzeMemoryLeaks = false;\n this.#checkSanity = false;\n this.#firstRun = true;\n this.perf = {};\n // object that contains all initialized models\n this.models = {\n face: null,\n posenet: null,\n blazepose: null,\n efficientpose: null,\n handpose: null,\n iris: null,\n age: null,\n gender: null,\n emotion: null,\n embedding: null,\n nanodet: null,\n faceres: null,\n };\n // export access to image processing\n // @ts-ignore eslint-typescript cannot correctly infer type in anonymous function\n this.image = (input: Input) => image.process(input, this.config);\n // export raw access to underlying models\n this.classes = {\n facemesh,\n emotion,\n faceres,\n body: this.config.body.modelPath.includes('posenet') ? posenet : blazepose,\n hand: handpose,\n nanodet,\n };\n this.faceTriangulation = facemesh.triangulation;\n this.faceUVMap = facemesh.uvmap;\n // include platform info\n this.sysinfo = sysinfo.info();\n }\n\n // helper function: measure tensor leak\n /** @hidden */\n analyze = (...msg) => {\n if (!this.#analyzeMemoryLeaks) return;\n const current = this.tf.engine().state.numTensors;\n const previous = this.#numTensors;\n this.#numTensors = current;\n const leaked = current - previous;\n if (leaked !== 0) log(...msg, leaked);\n }\n\n // quick sanity check on inputs\n /** @hidden */\n #sanity = (input): null | string => {\n if (!this.#checkSanity) return null;\n if (!input) return 'input is not defined';\n if (this.tf.ENV.flags.IS_NODE && !(input instanceof tf.Tensor)) return 'input must be a tensor';\n try {\n this.tf.getBackend();\n } catch {\n return 'backend not loaded';\n }\n return null;\n }\n\n /** Simmilarity method calculates simmilarity between two provided face descriptors (face embeddings)\n * - Calculation is based on normalized Minkowski distance between\n */\n // eslint-disable-next-line class-methods-use-this\n similarity(embedding1: Array, embedding2: Array): number {\n return faceres.similarity(embedding1, embedding2);\n }\n\n /** Enhance method performs additional enhacements to face image previously detected for futher processing\n * @param input Tensor as provided in human.result.face[n].tensor\n * @returns Tensor\n */\n // eslint-disable-next-line class-methods-use-this\n enhance(input: Tensor): Tensor | null {\n return faceres.enhance(input);\n }\n\n /**\n * Math method find best match between provided face descriptor and predefined database of known descriptors\n * @param faceEmbedding: face descriptor previsouly calculated on any face\n * @param db: array of mapping of face descriptors to known values\n * @param threshold: minimum score for matching to be considered in the result\n * @returns best match\n */\n // eslint-disable-next-line class-methods-use-this\n match(faceEmbedding: Array, db: Array<{ name: string, source: string, embedding: number[] }>, threshold = 0): { name: string, source: string, similarity: number, embedding: number[] } {\n return faceres.match(faceEmbedding, db, threshold);\n }\n\n /** Load method preloads all configured models on-demand\n * - Not explicitly required as any required model is load implicitly on it's first run\n */\n async load(userConfig: Config | Object = {}) {\n this.state = 'load';\n const timeStamp = now();\n if (userConfig) this.config = mergeDeep(this.config, userConfig);\n\n if (this.#firstRun) {\n if (this.config.debug) log(`version: ${this.version}`);\n if (this.config.debug) log(`tfjs version: ${this.tf.version_core}`);\n if (this.config.debug) log('platform:', this.sysinfo.platform);\n if (this.config.debug) log('agent:', this.sysinfo.agent);\n\n await this.#checkBackend(true);\n if (this.tf.ENV.flags.IS_BROWSER) {\n if (this.config.debug) log('configuration:', this.config);\n if (this.config.debug) log('tf flags:', this.tf.ENV.flags);\n }\n }\n if (this.config.async) {\n [\n this.models.face,\n this.models.emotion,\n this.models.handpose,\n this.models.posenet,\n this.models.blazepose,\n this.models.nanodet,\n this.models.faceres,\n ] = await Promise.all([\n this.models.face || (this.config.face.enabled ? facemesh.load(this.config) : null),\n this.models.emotion || ((this.config.face.enabled && this.config.face.emotion.enabled) ? emotion.load(this.config) : null),\n this.models.handpose || (this.config.hand.enabled ? handpose.load(this.config) : null),\n this.models.posenet || (this.config.body.enabled && this.config.body.modelPath.includes('posenet') ? posenet.load(this.config) : null),\n this.models.blazepose || (this.config.body.enabled && this.config.body.modelPath.includes('blazepose') ? blazepose.load(this.config) : null),\n this.models.nanodet || (this.config.object.enabled ? nanodet.load(this.config) : null),\n this.models.faceres || ((this.config.face.enabled && this.config.face.description.enabled) ? faceres.load(this.config) : null),\n ]);\n } else {\n if (this.config.face.enabled && !this.models.face) this.models.face = await facemesh.load(this.config);\n if (this.config.face.enabled && this.config.face.emotion.enabled && !this.models.emotion) this.models.emotion = await emotion.load(this.config);\n if (this.config.hand.enabled && !this.models.handpose) this.models.handpose = await handpose.load(this.config);\n if (this.config.body.enabled && !this.models.posenet && this.config.body.modelPath.includes('posenet')) this.models.posenet = await posenet.load(this.config);\n if (this.config.body.enabled && !this.models.blazepose && this.config.body.modelPath.includes('blazepose')) this.models.blazepose = await blazepose.load(this.config);\n if (this.config.object.enabled && !this.models.nanodet) this.models.nanodet = await nanodet.load(this.config);\n if (this.config.face.enabled && this.config.face.description.enabled && !this.models.faceres) this.models.faceres = await faceres.load(this.config);\n }\n\n if (this.#firstRun) {\n if (this.config.debug) log('tf engine state:', this.tf.engine().state.numBytes, 'bytes', this.tf.engine().state.numTensors, 'tensors');\n this.#firstRun = false;\n }\n\n const current = Math.trunc(now() - timeStamp);\n if (current > (this.perf.load || 0)) this.perf.load = current;\n }\n\n // check if backend needs initialization if it changed\n /** @hidden */\n #checkBackend = async (force = false) => {\n if (this.config.backend && (this.config.backend.length > 0) && force || (this.tf.getBackend() !== this.config.backend)) {\n const timeStamp = now();\n this.state = 'backend';\n /* force backend reload\n if (this.config.backend in tf.engine().registry) {\n const backendFactory = tf.findBackendFactory(this.config.backend);\n tf.removeBackend(this.config.backend);\n tf.registerBackend(this.config.backend, backendFactory);\n } else {\n log('Backend not registred:', this.config.backend);\n }\n */\n\n if (this.config.backend && this.config.backend.length > 0) {\n // @ts-ignore ignore missing type for WorkerGlobalScope as that is the point\n if (typeof window === 'undefined' && typeof WorkerGlobalScope !== 'undefined' && this.config.debug) log('running inside web worker');\n\n // force browser vs node backend\n if (this.tf.ENV.flags.IS_BROWSER && this.config.backend === 'tensorflow') this.config.backend = 'webgl';\n if (this.tf.ENV.flags.IS_NODE && (this.config.backend === 'webgl' || this.config.backend === 'humangl')) this.config.backend = 'tensorflow';\n\n if (this.config.debug) log('setting backend:', this.config.backend);\n\n if (this.config.backend === 'wasm') {\n if (this.config.debug) log('wasm path:', this.config.wasmPath);\n if (typeof this.tf?.setWasmPaths !== 'undefined') this.tf.setWasmPaths(this.config.wasmPath);\n else throw new Error('Human: WASM backend is not loaded');\n const simd = await this.tf.env().getAsync('WASM_HAS_SIMD_SUPPORT');\n const mt = await this.tf.env().getAsync('WASM_HAS_MULTITHREAD_SUPPORT');\n if (this.config.debug) log(`wasm execution: ${simd ? 'SIMD' : 'no SIMD'} ${mt ? 'multithreaded' : 'singlethreaded'}`);\n if (this.config.debug && !simd) log('warning: wasm simd support is not enabled');\n }\n\n if (this.config.backend === 'humangl') backend.register();\n try {\n await this.tf.setBackend(this.config.backend);\n } catch (err) {\n log('error: cannot set backend:', this.config.backend, err);\n }\n }\n this.tf.enableProdMode();\n // this.tf.enableDebugMode();\n if (this.tf.getBackend() === 'webgl' || this.tf.getBackend() === 'humangl') {\n this.tf.ENV.set('CHECK_COMPUTATION_FOR_ERRORS', false);\n this.tf.ENV.set('WEBGL_PACK_DEPTHWISECONV', true);\n if (typeof this.config['deallocate'] !== 'undefined') {\n log('changing webgl: WEBGL_DELETE_TEXTURE_THRESHOLD:', true);\n this.tf.ENV.set('WEBGL_DELETE_TEXTURE_THRESHOLD', 0);\n }\n const gl = await this.tf.backend().getGPGPUContext().gl;\n if (this.config.debug) log(`gl version:${gl.getParameter(gl.VERSION)} renderer:${gl.getParameter(gl.RENDERER)}`);\n }\n await this.tf.ready();\n this.perf.backend = Math.trunc(now() - timeStamp);\n }\n }\n\n /** Main detection method\n * - Analyze configuration: {@link Config}\n * - Pre-process input: {@link Input}\n * - Run inference for all configured models\n * - Process and return result: {@link Result}\n */\n async detect(input: Input, userConfig: Config | Object = {}): Promise {\n // detection happens inside a promise\n return new Promise(async (resolve) => {\n this.state = 'config';\n let timeStamp;\n\n // update configuration\n this.config = mergeDeep(this.config, userConfig);\n\n // sanity checks\n this.state = 'check';\n const error = this.#sanity(input);\n if (error) {\n log(error, input);\n resolve({ error });\n }\n\n const timeStart = now();\n\n // configure backend\n await this.#checkBackend();\n\n // load models if enabled\n await this.load();\n\n // disable video optimization for inputs of type image, but skip if inside worker thread\n let previousVideoOptimized;\n // @ts-ignore ignore missing type for WorkerGlobalScope as that is the point\n if (input && this.config.videoOptimized && (typeof window !== 'undefined') && (typeof WorkerGlobalScope !== 'undefined') && (\n (typeof HTMLImageElement !== 'undefined' && input instanceof HTMLImageElement)\n || (typeof Image !== 'undefined' && input instanceof Image)\n || (typeof ImageData !== 'undefined' && input instanceof ImageData)\n || (typeof ImageBitmap !== 'undefined' && image instanceof ImageBitmap))\n ) {\n log('disabling video optimization');\n previousVideoOptimized = this.config.videoOptimized;\n this.config.videoOptimized = false;\n }\n\n timeStamp = now();\n const process = image.process(input, this.config);\n if (!process || !process.tensor) {\n log('could not convert input to tensor');\n resolve({ error: 'could not convert input to tensor' });\n return;\n }\n this.perf.image = Math.trunc(now() - timeStamp);\n this.analyze('Get Image:');\n\n // prepare where to store model results\n let bodyRes;\n let handRes;\n let faceRes;\n let objectRes;\n let current;\n\n // run face detection followed by all models that rely on face bounding box: face mesh, age, gender, emotion\n if (this.config.async) {\n faceRes = this.config.face.enabled ? faceall.detectFace(this, process.tensor) : [];\n if (this.perf.face) delete this.perf.face;\n } else {\n this.state = 'run:face';\n timeStamp = now();\n faceRes = this.config.face.enabled ? await faceall.detectFace(this, process.tensor) : [];\n current = Math.trunc(now() - timeStamp);\n if (current > 0) this.perf.face = current;\n }\n\n // run body: can be posenet or blazepose\n this.analyze('Start Body:');\n if (this.config.async) {\n if (this.config.body.modelPath.includes('posenet')) bodyRes = this.config.body.enabled ? posenet.predict(process.tensor, this.config) : [];\n else if (this.config.body.modelPath.includes('blazepose')) bodyRes = this.config.body.enabled ? blazepose.predict(process.tensor, this.config) : [];\n if (this.perf.body) delete this.perf.body;\n } else {\n this.state = 'run:body';\n timeStamp = now();\n if (this.config.body.modelPath.includes('posenet')) bodyRes = this.config.body.enabled ? await posenet.predict(process.tensor, this.config) : [];\n else if (this.config.body.modelPath.includes('blazepose')) bodyRes = this.config.body.enabled ? await blazepose.predict(process.tensor, this.config) : [];\n current = Math.trunc(now() - timeStamp);\n if (current > 0) this.perf.body = current;\n }\n this.analyze('End Body:');\n\n // run handpose\n this.analyze('Start Hand:');\n if (this.config.async) {\n handRes = this.config.hand.enabled ? handpose.predict(process.tensor, this.config) : [];\n if (this.perf.hand) delete this.perf.hand;\n } else {\n this.state = 'run:hand';\n timeStamp = now();\n handRes = this.config.hand.enabled ? await handpose.predict(process.tensor, this.config) : [];\n current = Math.trunc(now() - timeStamp);\n if (current > 0) this.perf.hand = current;\n }\n this.analyze('End Hand:');\n\n // run nanodet\n this.analyze('Start Object:');\n if (this.config.async) {\n objectRes = this.config.object.enabled ? nanodet.predict(process.tensor, this.config) : [];\n if (this.perf.object) delete this.perf.object;\n } else {\n this.state = 'run:object';\n timeStamp = now();\n objectRes = this.config.object.enabled ? await nanodet.predict(process.tensor, this.config) : [];\n current = Math.trunc(now() - timeStamp);\n if (current > 0) this.perf.object = current;\n }\n this.analyze('End Object:');\n\n // if async wait for results\n if (this.config.async) {\n [faceRes, bodyRes, handRes, objectRes] = await Promise.all([faceRes, bodyRes, handRes, objectRes]);\n }\n tf.dispose(process.tensor);\n\n // run gesture analysis last\n let gestureRes: any[] = [];\n if (this.config.gesture.enabled) {\n timeStamp = now();\n gestureRes = [...gesture.face(faceRes), ...gesture.body(bodyRes), ...gesture.hand(handRes), ...gesture.iris(faceRes)];\n if (!this.config.async) this.perf.gesture = Math.trunc(now() - timeStamp);\n else if (this.perf.gesture) delete this.perf.gesture;\n }\n\n // restore video optimizations if previously disabled\n if (previousVideoOptimized) this.config.videoOptimized = previousVideoOptimized;\n\n this.perf.total = Math.trunc(now() - timeStart);\n this.state = 'idle';\n const result = {\n face: faceRes,\n body: bodyRes,\n hand: handRes,\n gesture: gestureRes,\n object: objectRes,\n performance: this.perf,\n canvas: process.canvas,\n };\n // log('Result:', result);\n resolve(result);\n });\n }\n\n /** @hidden */\n #warmupBitmap = async () => {\n const b64toBlob = (base64, type = 'application/octet-stream') => fetch(`data:${type};base64,${base64}`).then((res) => res.blob());\n let blob;\n let res;\n switch (this.config.warmup) {\n case 'face': blob = await b64toBlob(sample.face); break;\n case 'full': blob = await b64toBlob(sample.body); break;\n default: blob = null;\n }\n if (blob) {\n const bitmap = await createImageBitmap(blob);\n res = await this.detect(bitmap, this.config);\n bitmap.close();\n }\n return res;\n }\n\n /** @hidden */\n #warmupCanvas = async () => new Promise((resolve) => {\n let src;\n let size = 0;\n switch (this.config.warmup) {\n case 'face':\n size = 256;\n src = 'data:image/jpeg;base64,' + sample.face;\n break;\n case 'full':\n case 'body':\n size = 1200;\n src = 'data:image/jpeg;base64,' + sample.body;\n break;\n default:\n src = null;\n }\n // src = encodeURI('../assets/human-sample-upper.jpg');\n const img = new Image();\n img.onload = async () => {\n const canvas = (typeof OffscreenCanvas !== 'undefined') ? new OffscreenCanvas(size, size) : document.createElement('canvas');\n canvas.width = img.naturalWidth;\n canvas.height = img.naturalHeight;\n const ctx = canvas.getContext('2d');\n ctx?.drawImage(img, 0, 0);\n // const data = ctx?.getImageData(0, 0, canvas.height, canvas.width);\n const res = await this.detect(canvas, this.config);\n resolve(res);\n };\n if (src) img.src = src;\n else resolve(null);\n });\n\n /** @hidden */\n #warmupNode = async () => {\n const atob = (str) => Buffer.from(str, 'base64');\n let img;\n if (this.config.warmup === 'face') img = atob(sample.face);\n if (this.config.warmup === 'body' || this.config.warmup === 'full') img = atob(sample.body);\n if (!img) return null;\n let res;\n if (typeof tf['node'] !== 'undefined') {\n const data = tf['node'].decodeJpeg(img);\n const expanded = data.expandDims(0);\n this.tf.dispose(data);\n // log('Input:', expanded);\n res = await this.detect(expanded, this.config);\n this.tf.dispose(expanded);\n } else {\n if (this.config.debug) log('Warmup tfjs-node not loaded');\n /*\n const input = await canvasJS.loadImage(img);\n const canvas = canvasJS.createCanvas(input.width, input.height);\n const ctx = canvas.getContext('2d');\n ctx.drawImage(img, 0, 0, input.width, input.height);\n res = await this.detect(input, this.config);\n */\n }\n return res;\n }\n\n /** Warmup metho pre-initializes all models for faster inference\n * - can take significant time on startup\n * - only used for `webgl` and `humangl` backends\n */\n async warmup(userConfig: Config | Object = {}): Promise {\n const t0 = now();\n if (userConfig) this.config = mergeDeep(this.config, userConfig);\n if (!this.config.warmup || this.config.warmup === 'none') return { error: 'null' };\n const save = this.config.videoOptimized;\n this.config.videoOptimized = false;\n let res;\n if (typeof createImageBitmap === 'function') res = await this.#warmupBitmap();\n else if (typeof Image !== 'undefined') res = await this.#warmupCanvas();\n else res = await this.#warmupNode();\n this.config.videoOptimized = save;\n const t1 = now();\n if (this.config.debug) log('Warmup', this.config.warmup, Math.round(t1 - t0), 'ms', res);\n return res;\n }\n}\n\n/**\n * Class Human is also available as default export\n */\nexport { Human as default };\n"], + "mappings": "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,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,eAAiB,kBAClB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,iBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,eAAiB,kBAClB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,eAAiB,kBAClB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,eAAiB,kBAClB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,eAAiB,iBAClB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,eAAiB,kBAClB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,iBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,gBAAkB,kBACnB,CAAC,cAAgB,kBACjB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,gBAAkB,kBACnB,CAAC,eAAiB,kBAClB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,kBACpB,CAAC,iBAAmB,mBAGT,GAAS,CACpB,IAAK,GAAI,IAAK,GAAI,EAAG,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,EACtJ,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,GAAI,GAClJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,EAAG,IAAK,GAAI,GAAI,GAAI,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,GACrJ,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,EAAG,IAC7I,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAClJ,IAAK,IAAK,GAAI,GAAI,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,GAAI,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,GACrJ,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,GACpJ,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,GACjJ,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,EAAG,EAAG,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,EAAG,IAC/I,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,IAAK,EAAG,GAAI,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IACnJ,IAAK,GAAI,EAAG,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IACnJ,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,EAAG,IAAK,IAAK,GAAI,EAAG,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAC9I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,EAAG,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GACtJ,GAAI,GAAI,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,GAClJ,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,EAAG,EAAG,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GACnJ,IAAK,IAAK,IAAK,GAAI,GAAI,EAAG,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GACrJ,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IACpJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,EAAG,IAClJ,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,EAAG,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACnJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,GAAI,IAAK,IAAK,IAAK,IACnJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IACnJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAChJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,EAAG,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAChJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAC7I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAClJ,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAC7I,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,EAAG,IAAK,GAAI,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GACnJ,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,EAAG,GAAI,EAAG,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GACpJ,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,GAAI,IAAK,GAAI,IAAK,EAAG,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAClJ,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAClJ,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,GAAI,GAAI,EAAG,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAChJ,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IACpJ,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GACrJ,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,GAAI,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,GACpJ,IAAK,GAAI,IAAK,IAAK,EAAG,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,EAAG,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAC/I,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,EAAG,IAAK,GAAI,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAC9I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GACpJ,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GACrJ,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IACpJ,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,EAAG,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,EACpJ,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAC9I,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,EAAG,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,EAAG,GAAI,IAClJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAC9I,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAChJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAChJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAC9I,IAAK,GAAI,IAAK,EAAG,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAChJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK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EL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,QACH,EAAG,SAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,OACH,EAAG,QAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OAEL,CACE,EAAG,MACH,EAAG,OA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AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;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", "names": [] } diff --git a/dist/human.esm.js b/dist/human.esm.js index 65c16b0e..1a740566 100644 --- a/dist/human.esm.js +++ b/dist/human.esm.js @@ -5,41 +5,41 @@ author: ' */ -var P9=Object.defineProperty;var Fa=(e,t)=>{for(var n in t)P9(e,n,{get:t[n],enumerable:!0})};var _g=(e,t,n)=>{if(!t.has(e))throw TypeError("Cannot "+n)};var aa=(e,t,n)=>(_g(e,t,"read from private field"),n?n.call(e):t.get(e)),rs=(e,t,n,a)=>(_g(e,t,"write to private field"),a?a.call(e,n):t.set(e,n),n);function Jt(e,t){let n=e.endsWith("/")?"":"/",r=t.startsWith(".")||t.startsWith("/")||t.startsWith("http:")||t.startsWith("https:")||t.startsWith("file:")?`${t}`:`${e}${n}${t}`;if(!r.toLocaleLowerCase().includes(".json"))throw new Error(`Human: ModelPath Error: ${r} Expecting JSON file`);return r}function he(...e){let t=new Date,n=`${t.getHours().toString().padStart(2,"0")}:${t.getMinutes().toString().padStart(2,"0")}:${t.getSeconds().toString().padStart(2,"0")}.${t.getMilliseconds().toString().padStart(3,"0")}`;e&&console.log(n,"Human:",...e)}var it=()=>typeof performance!="undefined"?performance.now():parseInt((Number(process.hrtime.bigint())/1e3/1e3).toString());function Gn(...e){let t=n=>n&&typeof n=="object";return e.reduce((n,a)=>(Object.keys(a||{}).forEach(r=>{let s=n[r],i=a[r];Array.isArray(s)&&Array.isArray(i)?n[r]=s.concat(...i):t(s)&&t(i)?n[r]=Gn(s,i):n[r]=i}),n),{})}function Pg(){let e,t;if(typeof navigator!="undefined"){let n=navigator.userAgent.match(/\(([^()]+)\)/g);if(n&&n[0]){let a=n[0].match(/\(([^()]+)\)/g);e=a?a[0].replace(/\(|\)/g,""):"",t=navigator.userAgent.replace(n[0],""),e[1]&&(t=t.replace(n[1],"")),t=t.replace(/ /g," ")}}else typeof process!="undefined"&&(e=`${process.platform} ${process.arch}`,t=`NodeJS ${process.version}`);return{platform:e,agent:t}}var pu={};Fa(pu,{Abs:()=>eo,Acos:()=>to,Acosh:()=>no,AdadeltaOptimizer:()=>Kc,AdagradOptimizer:()=>Zc,AdamOptimizer:()=>Yc,AdamaxOptimizer:()=>Jc,Add:()=>kr,AddN:()=>os,All:()=>ao,Any:()=>ro,ArgMax:()=>ls,ArgMin:()=>Au,Asin:()=>so,Asinh:()=>io,Atan:()=>oo,Atan2:()=>uo,Atanh:()=>lo,AvgPool:()=>us,AvgPool3D:()=>yu,AvgPool3DGrad:()=>Cp,AvgPoolGrad:()=>Ep,BackendWasm:()=>d6,BatchMatMul:()=>ds,BatchToSpaceND:()=>gu,Bincount:()=>Rp,BroadcastTo:()=>Rx,Callback:()=>n8,CallbackList:()=>Q6,Cast:()=>ps,Ceil:()=>cs,ClipByValue:()=>Ir,Complex:()=>Mp,ComplexAbs:()=>xu,Concat:()=>po,Conv2D:()=>hs,Conv2DBackpropFilter:()=>Fp,Conv2DBackpropInput:()=>fs,Conv3D:()=>bu,Conv3DBackpropFilterV2:()=>$p,Conv3DBackpropInputV2:()=>Dp,Cos:()=>ms,Cosh:()=>co,CropAndResize:()=>ho,Cumsum:()=>As,CustomCallback:()=>t4,DataStorage:()=>Ip,DenseBincount:()=>Op,DepthToSpace:()=>fo,DepthwiseConv2dNative:()=>ys,DepthwiseConv2dNativeBackpropFilter:()=>zp,DepthwiseConv2dNativeBackpropInput:()=>_p,Diag:()=>Pp,Dilation2D:()=>vu,Dilation2DBackpropFilter:()=>Wp,Dilation2DBackpropInput:()=>Lp,ENV:()=>ma,EarlyStopping:()=>r8,Einsum:()=>Bp,Elu:()=>mo,EluGrad:()=>Vp,Environment:()=>Ex,Equal:()=>yo,Erf:()=>Ao,Exp:()=>xs,ExpandDims:()=>go,Expm1:()=>xo,FFT:()=>jp,Fill:()=>wu,FlipLeftRight:()=>bo,Floor:()=>bs,FloorDiv:()=>vs,FromPixels:()=>sc,FusedBatchNorm:()=>ws,FusedConv2D:()=>ni,FusedDepthwiseConv2D:()=>ai,GPGPUContext:()=>mh,GatherNd:()=>wo,GatherV2:()=>vo,GraphModel:()=>D8,Greater:()=>ko,GreaterEqual:()=>ks,History:()=>e4,IFFT:()=>Up,Identity:()=>Is,Imag:()=>Hp,InputSpec:()=>Ft,IsFinite:()=>Io,IsInf:()=>So,IsNan:()=>No,KernelBackend:()=>hu,LRN:()=>Su,LRNGrad:()=>qp,LayerVariable:()=>X6,LayersModel:()=>pr,LeakyRelu:()=>Ss,Less:()=>To,LessEqual:()=>Eo,LinSpace:()=>Gp,Log:()=>Ns,Log1p:()=>Co,LogSoftmax:()=>Mx,LogicalAnd:()=>Ro,LogicalNot:()=>ku,LogicalOr:()=>Iu,MathBackendCPU:()=>nh,MathBackendWebGL:()=>zl,Max:()=>Ts,MaxPool:()=>Cs,MaxPool3D:()=>Nu,MaxPool3DGrad:()=>Kp,MaxPoolGrad:()=>Xp,MaxPoolWithArgmax:()=>Zp,Maximum:()=>Es,Mean:()=>Rs,Min:()=>Ms,Minimum:()=>Fs,MirrorPad:()=>$s,Mod:()=>Mo,MomentumOptimizer:()=>Qc,Multinomial:()=>Yp,Multiply:()=>Ds,Neg:()=>Fo,NonMaxSuppressionV3:()=>Do,NonMaxSuppressionV4:()=>Oo,NonMaxSuppressionV5:()=>zo,NotEqual:()=>$o,OP_SCOPE_SUFFIX:()=>Vx,OneHot:()=>Os,OnesLike:()=>_o,Optimizer:()=>or,Pack:()=>Po,PadV2:()=>zs,Pool:()=>LI,Pow:()=>_s,Prelu:()=>Ps,Prod:()=>Lo,RMSPropOptimizer:()=>eh,RNN:()=>Ha,Range:()=>Tu,Rank:()=>Sm,Real:()=>Jp,RealDiv:()=>gs,Reciprocal:()=>Wo,Reduction:()=>dn,Relu:()=>Ls,Relu6:()=>Bs,Reshape:()=>Bo,ResizeBilinear:()=>Ws,ResizeBilinearGrad:()=>ec,ResizeNearestNeighbor:()=>Eu,ResizeNearestNeighborGrad:()=>Qp,Reverse:()=>Vs,RotateWithOffset:()=>tl,Round:()=>js,Rsqrt:()=>Us,SGDOptimizer:()=>sd,ScatterNd:()=>Vo,Select:()=>jo,Selu:()=>Uo,Sequential:()=>Hl,Sigmoid:()=>Gs,Sign:()=>qo,Sin:()=>Hs,Sinh:()=>Go,Slice:()=>Ho,Softmax:()=>Ks,Softplus:()=>Xo,SpaceToBatchND:()=>Cu,SparseFillEmptyRows:()=>tc,SparseReshape:()=>nc,SparseToDense:()=>ac,SplitV:()=>Ko,Sqrt:()=>qs,Square:()=>Ru,SquaredDifference:()=>Zs,Step:()=>Nr,StridedSlice:()=>Zo,Sub:()=>Ys,Sum:()=>Xs,SymbolicTensor:()=>Sa,Tan:()=>Js,Tanh:()=>Qs,Tensor:()=>Le,TensorBuffer:()=>Ot,Tile:()=>Sr,TopK:()=>Yo,Transform:()=>Jo,Transpose:()=>ei,Unique:()=>rc,Unpack:()=>Qo,UnsortedSegmentSum:()=>Mu,Variable:()=>Pu,ZerosLike:()=>el,_FusedMatMul:()=>ti,abs:()=>zt,acos:()=>Ym,acosh:()=>Jm,add:()=>se,addN:()=>yc,all:()=>gc,any:()=>ju,argMax:()=>Uu,argMin:()=>Qm,asin:()=>eA,asinh:()=>tA,atan:()=>nA,atan2:()=>aA,atanh:()=>rA,avgPool:()=>Gu,avgPool3d:()=>oA,backend:()=>kb,backend_util:()=>C,basicLSTMCell:()=>gT,batchNorm:()=>ci,batchNorm2d:()=>Tb,batchNorm3d:()=>Eb,batchNorm4d:()=>Cb,batchToSpaceND:()=>qu,bincount:()=>lA,booleanMaskAsync:()=>IR,broadcastTo:()=>cl,browser:()=>li,buffer:()=>We,callbacks:()=>Ore,cast:()=>fe,ceil:()=>uA,clipByValue:()=>In,clone:()=>Oa,complex:()=>Tr,concat:()=>ot,concat1d:()=>Rb,concat2d:()=>hl,concat3d:()=>Mb,concat4d:()=>Fb,constraints:()=>v6,conv1d:()=>bc,conv2d:()=>ar,conv2dTranspose:()=>vc,conv3d:()=>pA,conv3dTranspose:()=>Db,copyRegisteredKernels:()=>VI,cos:()=>Xu,cosh:()=>wc,cosineWindow:()=>PA,cumsum:()=>kc,customGrad:()=>_a,data:()=>O8,denseBincount:()=>Ob,deprecationWarn:()=>Km,depthToSpace:()=>cA,depthwiseConv2d:()=>fl,deregisterOp:()=>_re,device_util:()=>Wu,diag:()=>qT,dilation2d:()=>hA,disableDeprecationWarnings:()=>MN,dispose:()=>Ee,disposeVariables:()=>FN,div:()=>me,divNoNan:()=>fA,dot:()=>zb,dropout:()=>a3,einsum:()=>_b,elu:()=>ml,enableDebugMode:()=>RN,enableProdMode:()=>CN,enclosingPowerOfTwo:()=>r3,engine:()=>nr,env:()=>J,equal:()=>Fr,erf:()=>mA,exp:()=>Xn,expandDims:()=>un,expm1:()=>AA,eye:()=>yA,fft:()=>ad,fill:()=>Al,findBackend:()=>Zm,findBackendFactory:()=>LN,floor:()=>yl,floorDiv:()=>Ac,forceHalfFloat:()=>vv,fused:()=>_r,gather:()=>hi,gatherND:()=>n3,gather_util:()=>Vm,getBackend:()=>_N,getGradient:()=>wm,getKernel:()=>ic,getKernelsForBackend:()=>al,gpgpu_util:()=>H7,grad:()=>kE,grads:()=>IE,greater:()=>Fn,greaterEqual:()=>Dr,ifft:()=>wl,imag:()=>Ic,image:()=>Ye,inTopKAsync:()=>OR,initializers:()=>E6,input:()=>B6,io:()=>wn,irfft:()=>Wc,isFinite:()=>Pb,isInf:()=>Lb,isNaN:()=>gA,keep:()=>Ut,kernel_impls:()=>Wa,layers:()=>W6,leakyRelu:()=>Ku,less:()=>Sc,lessEqual:()=>Or,linalg:()=>A3,linspace:()=>Wb,loadGraphModel:()=>qt,loadLayersModel:()=>tre,localResponseNormalization:()=>xA,log:()=>$n,log1p:()=>Nc,logSigmoid:()=>Vb,logSoftmax:()=>Ec,logSumExp:()=>wA,logicalAnd:()=>la,logicalNot:()=>Zu,logicalOr:()=>Cc,logicalXor:()=>Gb,losses:()=>sF,matMul:()=>Be,math:()=>rb,max:()=>Kn,maxPool:()=>Yu,maxPool3d:()=>kA,maxPoolWithArgmax:()=>qb,maximum:()=>Pa,mean:()=>kt,memory:()=>mc,meshgrid:()=>GE,metrics:()=>Q4,min:()=>gl,minimum:()=>xl,mirrorPad:()=>IA,mod:()=>SA,model:()=>Qae,models:()=>e8,moments:()=>Rc,movingAverage:()=>TR,mul:()=>_,multiRNNCell:()=>eC,multinomial:()=>Xb,neg:()=>wt,nextFrame:()=>th,norm:()=>Uc,notEqual:()=>Ai,oneHot:()=>ll,ones:()=>Dn,onesLike:()=>On,op:()=>O,outerProduct:()=>sC,pad:()=>rr,pad1d:()=>lC,pad2d:()=>dC,pad3d:()=>cC,pad4d:()=>fC,pool:()=>Kb,pow:()=>sr,prelu:()=>Qu,print:()=>Jx,prod:()=>Mc,profile:()=>$N,rand:()=>kC,randomGamma:()=>TC,randomNormal:()=>Zb,randomUniform:()=>bl,range:()=>vl,ready:()=>zN,real:()=>ed,reciprocal:()=>EA,registerBackend:()=>dl,registerCallbackConstructor:()=>nre,registerGradient:()=>Fx,registerKernel:()=>ri,registerOp:()=>zre,regularizers:()=>t8,relu:()=>La,relu6:()=>Fc,removeBackend:()=>PN,reshape:()=>H,reverse:()=>zn,reverse1d:()=>zC,reverse2d:()=>PC,reverse3d:()=>WC,reverse4d:()=>VC,rfft:()=>rd,round:()=>$c,rsqrt:()=>Dc,scalar:()=>Se,scatterND:()=>t3,scatter_util:()=>jm,selu:()=>Oc,separableConv2d:()=>CA,sequential:()=>ere,serialization:()=>ae,setBackend:()=>ON,setPlatform:()=>WN,setWasmPath:()=>KJ,setWasmPaths:()=>ZJ,setWebGLContext:()=>ph,setdiff1dAsync:()=>Yb,shared:()=>jA,sigmoid:()=>kn,sign:()=>RA,signal:()=>rF,sin:()=>zc,sinh:()=>_c,slice:()=>Re,slice1d:()=>Pc,slice2d:()=>MA,slice3d:()=>Lc,slice4d:()=>td,slice_util:()=>ln,softmax:()=>nd,softplus:()=>fi,spaceToBatchND:()=>Ju,sparse:()=>y3,sparseToDense:()=>_A,spectral:()=>aF,split:()=>rn,sqrt:()=>Qt,square:()=>st,squaredDifference:()=>Bc,squeeze:()=>zr,stack:()=>_n,step:()=>kl,stridedSlice:()=>FA,sub:()=>ge,sum:()=>ke,sumOutType:()=>dc,tan:()=>$A,tanh:()=>pi,tensor:()=>oa,tensor1d:()=>Et,tensor2d:()=>ga,tensor3d:()=>hc,tensor4d:()=>fR,tensor5d:()=>mR,tensor6d:()=>AR,tensor_util:()=>Aa,test_util:()=>bb,tidy:()=>W,tile:()=>$r,time:()=>DN,topk:()=>DA,train:()=>gi,transpose:()=>Ze,truncatedNormal:()=>Vc,unique:()=>jc,unregisterGradient:()=>BI,unregisterKernel:()=>WI,unsortedSegmentSum:()=>OA,unstack:()=>ua,upcastType:()=>ia,util:()=>k,valueAndGrad:()=>SE,valueAndGrads:()=>NE,variable:()=>Jb,variableGrads:()=>Bb,version:()=>kie,version_converter:()=>_se,version_core:()=>EN,version_cpu:()=>Y3,version_layers:()=>ly,version_wasm:()=>c6,version_webgl:()=>bv,webgl:()=>GW,webgl_util:()=>x7,where:()=>an,whereAsync:()=>zA,zeros:()=>Rt,zerosLike:()=>Ue});var L9=Object.create,kp=Object.defineProperty,W9=Object.getPrototypeOf,B9=Object.prototype.hasOwnProperty,V9=Object.getOwnPropertyNames,j9=Object.getOwnPropertyDescriptor,U9=e=>kp(e,"__esModule",{value:!0}),bt=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),Fe=(e,t)=>{for(var n in t)kp(e,n,{get:t[n],enumerable:!0})},H9=(e,t,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of V9(t))!B9.call(e,a)&&a!=="default"&&kp(e,a,{get:()=>t[a],enumerable:!(n=j9(t,a))||n.enumerable});return e},Yi=e=>H9(U9(kp(e!=null?L9(W9(e)):{},"default",e&&e.__esModule&&"default"in e?{get:()=>e.default,enumerable:!0}:{value:e,enumerable:!0})),e),G9=bt(()=>{}),q9=bt((e,t)=>{(function(n,a,r){function s(d){var u=this,p=l();u.next=function(){var c=2091639*u.s0+u.c*23283064365386963e-26;return u.s0=u.s1,u.s1=u.s2,u.s2=c-(u.c=c|0)},u.c=1,u.s0=p(" "),u.s1=p(" "),u.s2=p(" "),u.s0-=p(d),u.s0<0&&(u.s0+=1),u.s1-=p(d),u.s1<0&&(u.s1+=1),u.s2-=p(d),u.s2<0&&(u.s2+=1),p=null}function i(d,u){return u.c=d.c,u.s0=d.s0,u.s1=d.s1,u.s2=d.s2,u}function o(d,u){var p=new s(d),c=u&&u.state,h=p.next;return h.int32=function(){return p.next()*4294967296|0},h.double=function(){return h()+(h()*2097152|0)*11102230246251565e-32},h.quick=h,c&&(typeof c=="object"&&i(c,p),h.state=function(){return i(p,{})}),h}function l(){var d=4022871197,u=function(p){p=p.toString();for(var c=0;c>>0,h-=d,h*=d,d=h>>>0,h-=d,d+=h*4294967296}return(d>>>0)*23283064365386963e-26};return u}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.alea=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),X9=bt((e,t)=>{(function(n,a,r){function s(l){var d=this,u="";d.x=0,d.y=0,d.z=0,d.w=0,d.next=function(){var c=d.x^d.x<<11;return d.x=d.y,d.y=d.z,d.z=d.w,d.w^=d.w>>>19^c^c>>>8},l===(l|0)?d.x=l:u+=l;for(var p=0;p>>0)/4294967296};return c.double=function(){do var h=u.next()>>>11,m=(u.next()>>>0)/4294967296,f=(h+m)/(1<<21);while(f===0);return f},c.int32=u.next,c.quick=c,p&&(typeof p=="object"&&i(p,u),c.state=function(){return i(u,{})}),c}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.xor128=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),K9=bt((e,t)=>{(function(n,a,r){function s(l){var d=this,u="";d.next=function(){var c=d.x^d.x>>>2;return d.x=d.y,d.y=d.z,d.z=d.w,d.w=d.v,(d.d=d.d+362437|0)+(d.v=d.v^d.v<<4^(c^c<<1))|0},d.x=0,d.y=0,d.z=0,d.w=0,d.v=0,l===(l|0)?d.x=l:u+=l;for(var p=0;p>>4),d.next()}function i(l,d){return d.x=l.x,d.y=l.y,d.z=l.z,d.w=l.w,d.v=l.v,d.d=l.d,d}function o(l,d){var u=new s(l),p=d&&d.state,c=function(){return(u.next()>>>0)/4294967296};return c.double=function(){do var h=u.next()>>>11,m=(u.next()>>>0)/4294967296,f=(h+m)/(1<<21);while(f===0);return f},c.int32=u.next,c.quick=c,p&&(typeof p=="object"&&i(p,u),c.state=function(){return i(u,{})}),c}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.xorwow=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),Z9=bt((e,t)=>{(function(n,a,r){function s(l){var d=this;d.next=function(){var p=d.x,c=d.i,h,m,f;return h=p[c],h^=h>>>7,m=h^h<<24,h=p[c+1&7],m^=h^h>>>10,h=p[c+3&7],m^=h^h>>>3,h=p[c+4&7],m^=h^h<<7,h=p[c+7&7],h=h^h<<13,m^=h^h<<9,p[c]=m,d.i=c+1&7,m};function u(p,c){var h,m,f=[];if(c===(c|0))m=f[0]=c;else for(c=""+c,h=0;h0;--h)p.next()}u(d,l)}function i(l,d){return d.x=l.x.slice(),d.i=l.i,d}function o(l,d){l==null&&(l=+new Date);var u=new s(l),p=d&&d.state,c=function(){return(u.next()>>>0)/4294967296};return c.double=function(){do var h=u.next()>>>11,m=(u.next()>>>0)/4294967296,f=(h+m)/(1<<21);while(f===0);return f},c.int32=u.next,c.quick=c,p&&(p.x&&i(p,u),c.state=function(){return i(u,{})}),c}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.xorshift7=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),Y9=bt((e,t)=>{(function(n,a,r){function s(l){var d=this;d.next=function(){var p=d.w,c=d.X,h=d.i,m,f;return d.w=p=p+1640531527|0,f=c[h+34&127],m=c[h=h+1&127],f^=f<<13,m^=m<<17,f^=f>>>15,m^=m>>>12,f=c[h]=f^m,d.i=h,f+(p^p>>>16)|0};function u(p,c){var h,m,f,A,y,g=[],x=128;for(c===(c|0)?(m=c,c=null):(c=c+"\0",m=0,x=Math.max(x,c.length)),f=0,A=-32;A>>15,m^=m<<4,m^=m>>>13,A>=0&&(y=y+1640531527|0,h=g[A&127]^=m+y,f=h==0?f+1:0);for(f>=128&&(g[(c&&c.length||0)&127]=-1),f=127,A=4*128;A>0;--A)m=g[f+34&127],h=g[f=f+1&127],m^=m<<13,h^=h<<17,m^=m>>>15,h^=h>>>12,g[f]=m^h;p.w=y,p.X=g,p.i=f}u(d,l)}function i(l,d){return d.i=l.i,d.w=l.w,d.X=l.X.slice(),d}function o(l,d){l==null&&(l=+new Date);var u=new s(l),p=d&&d.state,c=function(){return(u.next()>>>0)/4294967296};return c.double=function(){do var h=u.next()>>>11,m=(u.next()>>>0)/4294967296,f=(h+m)/(1<<21);while(f===0);return f},c.int32=u.next,c.quick=c,p&&(p.X&&i(p,u),c.state=function(){return i(u,{})}),c}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.xor4096=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),J9=bt((e,t)=>{(function(n,a,r){function s(l){var d=this,u="";d.next=function(){var c=d.b,h=d.c,m=d.d,f=d.a;return c=c<<25^c>>>7^h,h=h-m|0,m=m<<24^m>>>8^f,f=f-c|0,d.b=c=c<<20^c>>>12^h,d.c=h=h-m|0,d.d=m<<16^h>>>16^f,d.a=f-c|0},d.a=0,d.b=0,d.c=2654435769|0,d.d=1367130551,l===Math.floor(l)?(d.a=l/4294967296|0,d.b=l|0):u+=l;for(var p=0;p>>0)/4294967296};return c.double=function(){do var h=u.next()>>>11,m=(u.next()>>>0)/4294967296,f=(h+m)/(1<<21);while(f===0);return f},c.int32=u.next,c.quick=c,p&&(typeof p=="object"&&i(p,u),c.state=function(){return i(u,{})}),c}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.tychei=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),Lg=bt(()=>{}),Q9=bt((e,t)=>{(function(n,a){var r=this,s=256,i=6,o=52,l="random",d=a.pow(s,i),u=a.pow(2,o),p=u*2,c=s-1,h;function m(b,v,N){var T=[];v=v==!0?{entropy:!0}:v||{};var R=g(y(v.entropy?[b,w(n)]:b==null?x():b,3),T),$=new f(T),z=function(){for(var P=$.g(i),V=d,j=0;P=p;)P/=2,V/=2,j>>>=1;return(P+j)/V};return z.int32=function(){return $.g(4)|0},z.quick=function(){return $.g(4)/4294967296},z.double=z,g(w($.S),n),(v.pass||N||function(P,V,j,U){return U&&(U.S&&A(U,$),P.state=function(){return A($,{})}),j?(a[l]=P,V):P})(z,R,"global"in v?v.global:this==a,v.state)}a["seed"+l]=m;function f(b){var v,N=b.length,T=this,R=0,$=T.i=T.j=0,z=T.S=[];for(N||(b=[N++]);R{var n=q9(),a=X9(),r=K9(),s=Z9(),i=Y9(),o=J9(),l=Q9();l.alea=n,l.xor128=a,l.xorwow=r,l.xorshift7=s,l.xor4096=i,l.tychei=o,t.exports=l}),cu=bt(()=>{}),eI=bt(()=>{}),tI=bt(()=>{}),nI=bt((e,t)=>{var n=function(){var a=typeof document!="undefined"&&document.currentScript?document.currentScript.src:void 0;return typeof __filename!="undefined"&&(a=a||__filename),function(r){r=r||{};function s(){return Q.buffer!=Ve&&Zt(Q.buffer),yn}function i(){return Q.buffer!=Ve&&Zt(Q.buffer),xt}function o(){return Q.buffer!=Ve&&Zt(Q.buffer),gn}function l(){return Q.buffer!=Ve&&Zt(Q.buffer),Un}function d(){return Q.buffer!=Ve&&Zt(Q.buffer),sn}var u=typeof r!="undefined"?r:{},p,c;u.ready=new Promise(function(S,E){p=S,c=E});var h={},m;for(m in u)u.hasOwnProperty(m)&&(h[m]=u[m]);var f=[],A="./this.program",y=function(S,E){throw E},g=!1,x=!1,w=!1,b=!1;g=typeof window=="object",x=typeof importScripts=="function",w=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",b=!g&&!w&&!x;var v=u.ENVIRONMENT_IS_PTHREAD||!1;v&&(Ve=u.buffer);var N="";function T(S){return u.locateFile?u.locateFile(S,N):N+S}var R,$,z,P,V,j;if(w){x?N=cu().dirname(N)+"/":N=__dirname+"/",R=function(S,E){return V||(V=require("fs")),j||(j=cu()),S=j.normalize(S),V.readFileSync(S,E?null:"utf8")},z=function(S){var E=R(S,!0);return E.buffer||(E=new Uint8Array(E)),ce(E.buffer),E},process.argv.length>1&&(A=process.argv[1].replace(/\\/g,"/")),f=process.argv.slice(2),process.on("uncaughtException",function(S){if(!(S instanceof du))throw S}),process.on("unhandledRejection",Ya),y=function(S){process.exit(S)},u.inspect=function(){return"[Emscripten Module object]"};var U;try{U=eI()}catch(S){throw console.error('The "worker_threads" module is not supported in this node.js build - perhaps a newer version is needed?'),S}global.Worker=U.Worker}else b?(typeof read!="undefined"&&(R=function(S){return read(S)}),z=function(S){var E;return typeof readbuffer=="function"?new Uint8Array(readbuffer(S)):(E=read(S,"binary"),ce(typeof E=="object"),E)},typeof scriptArgs!="undefined"?f=scriptArgs:typeof arguments!="undefined"&&(f=arguments),typeof quit=="function"&&(y=function(S){quit(S)}),typeof print!="undefined"&&(typeof console=="undefined"&&(console={}),console.log=print,console.warn=console.error=typeof printErr!="undefined"?printErr:print)):(g||x)&&(x?N=self.location.href:typeof document!="undefined"&&document.currentScript&&(N=document.currentScript.src),typeof a!="undefined"&&a&&(N=a),N.indexOf("blob:")!==0?N=N.substr(0,N.lastIndexOf("/")+1):N="",w?(R=function(S,E){return V||(V=require("fs")),j||(j=cu()),S=j.normalize(S),V.readFileSync(S,E?null:"utf8")},z=function(S){var E=R(S,!0);return E.buffer||(E=new Uint8Array(E)),ce(E.buffer),E}):(R=function(S){var E=new XMLHttpRequest;return E.open("GET",S,!1),E.send(null),E.responseText},x&&(z=function(S){var E=new XMLHttpRequest;return E.open("GET",S,!1),E.responseType="arraybuffer",E.send(null),new Uint8Array(E.response)}),$=function(S,E,L){var q=new XMLHttpRequest;q.open("GET",S,!0),q.responseType="arraybuffer",q.onload=function(){if(q.status==200||q.status==0&&q.response){E(q.response);return}L()},q.onerror=L,q.send(null)}),P=function(S){document.title=S});w&&typeof performance=="undefined"&&(global.performance=tI().performance);var X=u.print||console.log.bind(console),G=u.printErr||console.warn.bind(console);for(m in h)h.hasOwnProperty(m)&&(u[m]=h[m]);h=null,u.arguments&&(f=u.arguments),u.thisProgram&&(A=u.thisProgram),u.quit&&(y=u.quit);var ee=Atomics.load,Y=Atomics.store,re=Atomics.compareExchange,ne;u.wasmBinary&&(ne=u.wasmBinary);var ie=u.noExitRuntime||!0;typeof WebAssembly!="object"&&Ya("no native wasm support detected");var Q,de,oe=!1,ye;function ce(S,E){S||Ya("Assertion failed: "+E)}function Ie(S){var E=u["_"+S];return ce(E,"Cannot call unknown function "+S+", make sure it is exported"),E}function Ne(S,E,L,q,pe){var le={string:function(vn){var Zi=0;if(vn!=null&&vn!==0){var zg=(vn.length<<2)+1;Zi=qi(zg),et(vn,Zi,zg)}return Zi},array:function(vn){var Zi=qi(vn.length);return Xe(vn,Zi),Zi}};function ue(vn){return E==="string"?De(vn):E==="boolean"?Boolean(vn):vn}var be=Ie(S),tt=[],Vt=0;if(q)for(var Dt=0;Dt=q);){var le=S[E++];if(!le)return pe;if(!(le&128)){pe+=String.fromCharCode(le);continue}var ue=S[E++]&63;if((le&224)==192){pe+=String.fromCharCode((le&31)<<6|ue);continue}var be=S[E++]&63;if((le&240)==224?le=(le&15)<<12|ue<<6|be:le=(le&7)<<18|ue<<12|be<<6|S[E++]&63,le<65536)pe+=String.fromCharCode(le);else{var tt=le-65536;pe+=String.fromCharCode(55296|tt>>10,56320|tt&1023)}}return pe}function De(S,E){return S?ze(i(),S,E):""}function Qe(S,E,L,q){if(!(q>0))return 0;for(var pe=L,le=L+q-1,ue=0;ue=55296&&be<=57343){var tt=S.charCodeAt(++ue);be=65536+((be&1023)<<10)|tt&1023}if(be<=127){if(L>=le)break;E[L++]=be}else if(be<=2047){if(L+1>=le)break;E[L++]=192|be>>6,E[L++]=128|be&63}else if(be<=65535){if(L+2>=le)break;E[L++]=224|be>>12,E[L++]=128|be>>6&63,E[L++]=128|be&63}else{if(L+3>=le)break;E[L++]=240|be>>18,E[L++]=128|be>>12&63,E[L++]=128|be>>6&63,E[L++]=128|be&63}}return E[L]=0,L-pe}function et(S,E,L){return Qe(S,i(),E,L)}function rt(S){for(var E=0,L=0;L=55296&&q<=57343&&(q=65536+((q&1023)<<10)|S.charCodeAt(++L)&1023),q<=127?++E:q<=2047?E+=2:q<=65535?E+=3:E+=4}return E}function Xe(S,E){s().set(S,E)}function pt(S,E){return S%E>0&&(S+=E-S%E),S}var Ve,yn,xt,jn,Kt,gn,Un,Mn,sn;function Zt(S){Ve=S,u.HEAP8=yn=new Int8Array(S),u.HEAP16=jn=new Int16Array(S),u.HEAP32=gn=new Int32Array(S),u.HEAPU8=xt=new Uint8Array(S),u.HEAPU16=Kt=new Uint16Array(S),u.HEAPU32=Un=new Uint32Array(S),u.HEAPF32=Mn=new Float32Array(S),u.HEAPF64=sn=new Float64Array(S)}var Ra=u.INITIAL_MEMORY||16777216;if(v)Q=u.wasmMemory,Ve=u.buffer;else if(u.wasmMemory)Q=u.wasmMemory;else if(Q=new WebAssembly.Memory({initial:Ra/65536,maximum:2147483648/65536,shared:!0}),!(Q.buffer instanceof SharedArrayBuffer))throw G("requested a shared WebAssembly.Memory but the returned buffer is not a SharedArrayBuffer, indicating that while the browser has SharedArrayBuffer it does not have WebAssembly threads support - you may need to set a flag"),w&&console.log("(on node you may need: --experimental-wasm-threads --experimental-wasm-bulk-memory and also use a recent version)"),Error("bad memory");Q&&(Ve=Q.buffer),Ra=Ve.byteLength,Zt(Ve);var ta,na=[],fr=[],Ka=[],mr=[],Wi=[],Ma=!1,tp=!1;v||fr.push({func:function(){Ap()}});function L0(){if(!v){if(u.preRun)for(typeof u.preRun=="function"&&(u.preRun=[u.preRun]);u.preRun.length;)ap(u.preRun.shift());Vi(na)}}function eu(){Ma=!0,!v&&Vi(fr)}function W0(){v||Vi(Ka)}function np(){v||(tp=!0)}function xn(){if(!v){if(u.postRun)for(typeof u.postRun=="function"&&(u.postRun=[u.postRun]);u.postRun.length;)B0(u.postRun.shift());Vi(Wi)}}function ap(S){na.unshift(S)}function B0(S){Wi.unshift(S)}var Za=0,Ar=null,ts=null;function V0(S){ce(!v,"addRunDependency cannot be used in a pthread worker"),Za++,u.monitorRunDependencies&&u.monitorRunDependencies(Za)}function j0(S){if(Za--,u.monitorRunDependencies&&u.monitorRunDependencies(Za),Za==0&&(Ar!==null&&(clearInterval(Ar),Ar=null),ts)){var E=ts;ts=null,E()}}u.preloadedImages={},u.preloadedAudios={};function Ya(S){u.onAbort&&u.onAbort(S),v&&console.error("Pthread aborting at "+new Error().stack),S+="",G(S),oe=!0,ye=1,S="abort("+S+"). Build with -s ASSERTIONS=1 for more info.";var E=new WebAssembly.RuntimeError(S);throw c(E),E}function rp(S,E){return String.prototype.startsWith?S.startsWith(E):S.indexOf(E)===0}var Bi="data:application/octet-stream;base64,";function sp(S){return rp(S,Bi)}var U0="file://";function ip(S){return rp(S,U0)}var bn="tfjs-backend-wasm-threaded-simd.wasm";sp(bn)||(bn=T(bn));function op(S){try{if(S==bn&&ne)return new Uint8Array(ne);if(z)return z(S);throw"both async and sync fetching of the wasm failed"}catch(E){Ya(E)}}function H0(){if(!ne&&(g||x)){if(typeof fetch=="function"&&!ip(bn))return fetch(bn,{credentials:"same-origin"}).then(function(S){if(!S.ok)throw"failed to load wasm binary file at '"+bn+"'";return S.arrayBuffer()}).catch(function(){return op(bn)});if($)return new Promise(function(S,E){$(bn,function(L){S(new Uint8Array(L))},E)})}return Promise.resolve().then(function(){return op(bn)})}function G0(){var S={a:_f};function E(ue,be){var tt=ue.exports;if(u.asm=tt,ta=u.asm.F,de=be,!v){var Vt=we.unusedWorkers.length;we.unusedWorkers.forEach(function(Dt){we.loadWasmModuleToWorker(Dt,function(){--Vt||j0("wasm-instantiate")})})}}v||V0("wasm-instantiate");function L(ue){E(ue.instance,ue.module)}function q(ue){return H0().then(function(be){return WebAssembly.instantiate(be,S)}).then(ue,function(be){G("failed to asynchronously prepare wasm: "+be),Ya(be)})}function pe(){return!ne&&typeof WebAssembly.instantiateStreaming=="function"&&!sp(bn)&&!ip(bn)&&typeof fetch=="function"?fetch(bn,{credentials:"same-origin"}).then(function(ue){var be=WebAssembly.instantiateStreaming(ue,S);return be.then(L,function(tt){return G("wasm streaming compile failed: "+tt),G("falling back to ArrayBuffer instantiation"),q(L)})}):q(L)}if(u.instantiateWasm)try{var le=u.instantiateWasm(S,E);return le}catch(ue){return G("Module.instantiateWasm callback failed with error: "+ue),!1}return pe().catch(c),{}}var q0={9816:function(){throw"Canceled!"},9834:function(S,E){setTimeout(function(){Rg(S,E)},0)}};function lp(){we.initRuntime()}function Vi(S){for(;S.length>0;){var E=S.shift();if(typeof E=="function"){E(u);continue}var L=E.func;typeof L=="number"?E.arg===void 0?ta.get(L)():ta.get(L)(E.arg):L(E.arg===void 0?null:E.arg)}}function tu(S,E){if(S<=0||S>s().length||S&!0||E<0)return-28;if(E==0)return 0;E>=2147483647&&(E=Infinity);var L=Atomics.load(o(),Xi>>2),q=0;if(L==S){var pe=Atomics.compareExchange(o(),Xi>>2,L,0);if(pe==L&&(--E,q=1,E<=0))return 1}var le=Atomics.notify(o(),S>>2,E);if(le>=0)return le+q;throw"Atomics.notify returned an unexpected value "+le}u._emscripten_futex_wake=tu;function X0(S){if(v)throw"Internal Error! killThread() can only ever be called from main application thread!";if(!S)throw"Internal Error! Null pthread_ptr in killThread!";o()[S+12>>2]=0;var E=we.pthreads[S];E.worker.terminate(),we.freeThreadData(E),we.runningWorkers.splice(we.runningWorkers.indexOf(E.worker),1),E.worker.pthread=void 0}function K0(S){if(v)throw"Internal Error! cancelThread() can only ever be called from main application thread!";if(!S)throw"Internal Error! Null pthread_ptr in cancelThread!";var E=we.pthreads[S];E.worker.postMessage({cmd:"cancel"})}function Z0(S){if(v)throw"Internal Error! cleanupThread() can only ever be called from main application thread!";if(!S)throw"Internal Error! Null pthread_ptr in cleanupThread!";var E=we.pthreads[S];if(E){o()[S+12>>2]=0;var L=E.worker;we.returnWorkerToPool(L)}}var we={unusedWorkers:[],runningWorkers:[],initMainThreadBlock:function(){for(var S=Math.min(4,Math.max(1,(navigator.hardwareConcurrency||1)/2)),E=0;E>2]=S;var L=S+152;o()[L>>2]=L;for(var q=as(512),E=0;E<128;++E)l()[q/4+E]=0;Atomics.store(l(),S+100>>2,q),Atomics.store(l(),S+40>>2,S),lm(S,!x,1),Cg(S)},initWorker:function(){},pthreads:{},threadExitHandlers:[],setThreadStatus:function(){},runExitHandlers:function(){for(;we.threadExitHandlers.length>0;)we.threadExitHandlers.pop()();v&&Hi()&&Eg()},runExitHandlersAndDeinitThread:function(S,E){Atomics.store(l(),S+56>>2,1),Atomics.store(l(),S+60>>2,0),we.runExitHandlers(),Atomics.store(l(),S+4>>2,E),Atomics.store(l(),S+0>>2,1),tu(S+0,2147483647),lm(0,0,0)},threadExit:function(S){var E=Hi();E&&(we.runExitHandlersAndDeinitThread(E,S),v&&postMessage({cmd:"exit"}))},threadCancel:function(){we.runExitHandlersAndDeinitThread(Hi(),-1),postMessage({cmd:"cancelDone"})},terminateAllThreads:function(){for(var S in we.pthreads){var E=we.pthreads[S];E&&E.worker&&we.returnWorkerToPool(E.worker)}we.pthreads={};for(var L=0;L>2];o()[S.threadInfoStruct+100>>2]=0,lu(E),lu(S.threadInfoStruct)}S.threadInfoStruct=0,S.allocatedOwnStack&&S.stackBase&&lu(S.stackBase),S.stackBase=0,S.worker&&(S.worker.pthread=null)}},returnWorkerToPool:function(S){we.runWithoutMainThreadQueuedCalls(function(){delete we.pthreads[S.pthread.threadInfoStruct],we.unusedWorkers.push(S),we.runningWorkers.splice(we.runningWorkers.indexOf(S),1),we.freeThreadData(S.pthread),S.pthread=void 0})},runWithoutMainThreadQueuedCalls:function(S){o()[Og>>2]=0;try{S()}finally{o()[Og>>2]=1}},receiveObjectTransfer:function(S){},loadWasmModuleToWorker:function(S,E){S.onmessage=function(L){var q=L.data,pe=q.cmd;if(S.pthread&&(we.currentProxiedOperationCallerThread=S.pthread.threadInfoStruct),q.targetThread&&q.targetThread!=Hi()){var le=we.pthreads[q.targetThread];le?le.worker.postMessage(L.data,q.transferList):console.error('Internal error! Worker sent a message "'+pe+'" to target pthread '+q.targetThread+", but that thread no longer exists!"),we.currentProxiedOperationCallerThread=void 0;return}if(pe==="processQueuedMainThreadWork")im();else if(pe==="spawnThread")fp(L.data);else if(pe==="cleanupThread")Z0(q.thread);else if(pe==="killThread")X0(q.thread);else if(pe==="cancelThread")K0(q.thread);else if(pe==="loaded")S.loaded=!0,E&&E(S),S.runPthread&&(S.runPthread(),delete S.runPthread);else if(pe==="print")X("Thread "+q.threadId+": "+q.text);else if(pe==="printErr")G("Thread "+q.threadId+": "+q.text);else if(pe==="alert")alert("Thread "+q.threadId+": "+q.text);else if(pe==="exit"){var ue=S.pthread&&Atomics.load(l(),S.pthread.threadInfoStruct+64>>2);ue&&we.returnWorkerToPool(S)}else if(pe==="exitProcess")try{_9(q.returnCode)}catch(be){if(be instanceof du)return;throw be}else pe==="cancelDone"?we.returnWorkerToPool(S):pe==="objectTransfer"?we.receiveObjectTransfer(L.data):L.data.target==="setimmediate"?S.postMessage(L.data):G("worker sent an unknown command "+pe);we.currentProxiedOperationCallerThread=void 0},S.onerror=function(L){G("pthread sent an error! "+L.filename+":"+L.lineno+": "+L.message)},w&&(S.on("message",function(L){S.onmessage({data:L})}),S.on("error",function(L){S.onerror(L)}),S.on("exit",function(L){})),S.postMessage({cmd:"load",urlOrBlob:u.mainScriptUrlOrBlob||a,wasmMemory:Q,wasmModule:de})},allocateUnusedWorker:function(){var S=T("tfjs-backend-wasm-threaded-simd.worker.js");we.unusedWorkers.push(new Worker(S))},getNewWorker:function(){return we.unusedWorkers.length==0&&(we.allocateUnusedWorker(),we.loadWasmModuleToWorker(we.unusedWorkers[0])),we.unusedWorkers.length>0?we.unusedWorkers.pop():null},busySpinWait:function(S){for(var E=performance.now()+S;performance.now()>2]=S,S}function af(S,E){if(v)return yr(1,1,S,E)}function rf(S,E){if(S==E)postMessage({cmd:"processQueuedMainThreadWork"});else if(v)postMessage({targetThread:S,cmd:"processThreadQueue"});else{var L=we.pthreads[S],q=L&&L.worker;if(!q)return;q.postMessage({cmd:"processThreadQueue"})}return 1}function sf(){Ya()}function of(S,E,L){var q=cf(E,L);return q0[S].apply(null,q)}function lf(S,E){}function uf(S,E,L){if(S<=0||S>s().length||S&!0)return-28;if(g){if(Atomics.load(o(),S>>2)!=E)return-6;for(var q=performance.now(),pe=q+L,le=Atomics.exchange(o(),Xi>>2,S);;){if(q=performance.now(),q>pe)return le=Atomics.exchange(o(),Xi>>2,0),-73;if(le=Atomics.exchange(o(),Xi>>2,0),le==0)break;if(im(),Atomics.load(o(),S>>2)!=E)return-6;le=Atomics.exchange(o(),Xi>>2,S)}return 0}else{var ue=Atomics.wait(o(),S>>2,E,L);if(ue==="timed-out")return-73;if(ue==="not-equal")return-6;if(ue==="ok")return 0;throw"Atomics.wait returned an unexpected value "+ue}}function df(S,E,L){i().copyWithin(S,E,E+L)}function pf(){return w?require("os").cpus().length:navigator.hardwareConcurrency}function yr(S,E){for(var L=arguments.length-2,q=uu(),pe=L,le=qi(pe*8),ue=le>>3,be=0;be>=2;L=i()[S++];){var q=L<105;q&&E&1&&E++,au.push(q?d()[E++>>1]:o()[E]),++E}return au}function hf(S,E,L){nu.length=E;for(var q=L>>3,pe=0;pe>>16),Zt(Q.buffer),1}catch(E){}}function Af(S){var E=ff();if(S<=E)return!1;var L=2147483648;if(S>L)return!1;for(var q=1;q<=4;q*=2){var pe=E*(1+.2/q);pe=Math.min(pe,S+100663296);var le=Math.min(L,pt(Math.max(S,pe),65536)),ue=mf(le);if(ue)return!0}return!1}var Pe={inEventHandler:0,removeAllEventListeners:function(){for(var S=Pe.eventHandlers.length-1;S>=0;--S)Pe._removeHandler(S);Pe.eventHandlers=[],Pe.deferredCalls=[]},registerRemoveEventListeners:function(){Pe.removeEventListenersRegistered||(mr.push(Pe.removeAllEventListeners),Pe.removeEventListenersRegistered=!0)},deferredCalls:[],deferCall:function(S,E,L){function q(ue,be){if(ue.length!=be.length)return!1;for(var tt in ue)if(ue[tt]!=be[tt])return!1;return!0}for(var pe in Pe.deferredCalls){var le=Pe.deferredCalls[pe];if(le.targetFunction==S&&q(le.argsList,L))return}Pe.deferredCalls.push({targetFunction:S,precedence:E,argsList:L}),Pe.deferredCalls.sort(function(ue,be){return ue.precedence>2]=L,o()[ue+4>>2]=q,o()[ue+8>>2]=pe,om(0,S,637534208,E,q,ue),Gi(le)},getTargetThreadForEventCallback:function(S){switch(S){case 1:return 0;case 2:return we.currentProxiedOperationCallerThread;default:return S}},getNodeNameForTarget:function(S){return S?S==window?"#window":S==screen?"#screen":S&&S.nodeName?S.nodeName:"":""},fullscreenEnabled:function(){return document.fullscreenEnabled||document.webkitFullscreenEnabled}};function yf(S){var E=rt(S)+1,L=as(E);return et(S,L,E),L}function gf(S,E,L,q){var pe=uu(),le=qi(12),ue=0;E&&(ue=yf(E)),o()[le>>2]=ue,o()[le+4>>2]=L,o()[le+8>>2]=q,om(0,S,657457152,0,ue,le),Gi(pe)}function xf(S,E,L,q){E=E?De(E):"",gf(S,E,L,q)}function bf(S){return S>2?De(S):S}var vf=[0,typeof document!="undefined"?document:0,typeof window!="undefined"?window:0];function wf(S){S=bf(S);var E=vf[S]||(typeof document!="undefined"?document.querySelector(S):void 0);return E}function ru(S){return wf(S)}function up(S,E,L){var q=ru(S);if(!q)return-4;if(q.canvasSharedPtr&&(o()[q.canvasSharedPtr>>2]=E,o()[q.canvasSharedPtr+4>>2]=L),q.offscreenCanvas||!q.controlTransferredOffscreen){q.offscreenCanvas&&(q=q.offscreenCanvas);var pe=!1;if(q.GLctxObject&&q.GLctxObject.GLctx){var le=q.GLctxObject.GLctx.getParameter(2978);pe=le[0]===0&&le[1]===0&&le[2]===q.width&&le[3]===q.height}q.width=E,q.height=L,pe&&q.GLctxObject.GLctx.viewport(0,0,E,L)}else if(q.canvasSharedPtr){var ue=o()[q.canvasSharedPtr+8>>2];return xf(ue,S,E,L),1}else return-4;return 0}function dp(S,E,L){return v?yr(2,1,S,E,L):up(S,E,L)}function kf(S,E,L){var q=ru(S);return q?up(S,E,L):dp(S,E,L)}function If(S){}function Sf(S,E){}function Nf(S){var E=S.getExtension("ANGLE_instanced_arrays");if(E)return S.vertexAttribDivisor=function(L,q){E.vertexAttribDivisorANGLE(L,q)},S.drawArraysInstanced=function(L,q,pe,le){E.drawArraysInstancedANGLE(L,q,pe,le)},S.drawElementsInstanced=function(L,q,pe,le,ue){E.drawElementsInstancedANGLE(L,q,pe,le,ue)},1}function Tf(S){var E=S.getExtension("OES_vertex_array_object");if(E)return S.createVertexArray=function(){return E.createVertexArrayOES()},S.deleteVertexArray=function(L){E.deleteVertexArrayOES(L)},S.bindVertexArray=function(L){E.bindVertexArrayOES(L)},S.isVertexArray=function(L){return E.isVertexArrayOES(L)},1}function Ef(S){var E=S.getExtension("WEBGL_draw_buffers");if(E)return S.drawBuffers=function(L,q){E.drawBuffersWEBGL(L,q)},1}function Cf(S){return!!(S.multiDrawWebgl=S.getExtension("WEBGL_multi_draw"))}var Je={counter:1,buffers:[],programs:[],framebuffers:[],renderbuffers:[],textures:[],uniforms:[],shaders:[],vaos:[],contexts:{},offscreenCanvases:{},timerQueriesEXT:[],programInfos:{},stringCache:{},unpackAlignment:4,recordError:function(S){Je.lastError||(Je.lastError=S)},getNewId:function(S){for(var E=Je.counter++,L=S.length;L>2]:-1;pe+=De(o()[L+le*4>>2],ue<0?void 0:ue)}return pe},createContext:function(S,E){var L=S.getContext("webgl",E);if(!L)return 0;var q=Je.registerContext(L,E);return q},registerContext:function(S,E){var L=as(8);o()[L+4>>2]=Hi();var q={handle:L,attributes:E,version:E.majorVersion,GLctx:S};return S.canvas&&(S.canvas.GLctxObject=q),Je.contexts[L]=q,(typeof E.enableExtensionsByDefault=="undefined"||E.enableExtensionsByDefault)&&Je.initExtensions(q),L},makeContextCurrent:function(S){return Je.currentContext=Je.contexts[S],u.ctx=gr=Je.currentContext&&Je.currentContext.GLctx,!(S&&!gr)},getContext:function(S){return Je.contexts[S]},deleteContext:function(S){Je.currentContext===Je.contexts[S]&&(Je.currentContext=null),typeof Pe=="object"&&Pe.removeAllHandlersOnTarget(Je.contexts[S].GLctx.canvas),Je.contexts[S]&&Je.contexts[S].GLctx.canvas&&(Je.contexts[S].GLctx.canvas.GLctxObject=void 0),lu(Je.contexts[S].handle),Je.contexts[S]=null},initExtensions:function(S){if(S||(S=Je.currentContext),!S.initExtensionsDone){S.initExtensionsDone=!0;var E=S.GLctx;Nf(E),Tf(E),Ef(E),E.disjointTimerQueryExt=E.getExtension("EXT_disjoint_timer_query"),Cf(E);var L=E.getSupportedExtensions()||[];L.forEach(function(q){q.indexOf("lose_context")<0&&q.indexOf("debug")<0&&E.getExtension(q)})}},populateUniformTable:function(S){for(var E=Je.programs[S],L=Je.programInfos[S]={uniforms:{},maxUniformLength:0,maxAttributeLength:-1,maxUniformBlockNameLength:-1},q=L.uniforms,pe=gr.getProgramParameter(E,35718),le=0;le>2,q=o()[L+(24>>2)],pe={alpha:!!o()[L+(0>>2)],depth:!!o()[L+(4>>2)],stencil:!!o()[L+(8>>2)],antialias:!!o()[L+(12>>2)],premultipliedAlpha:!!o()[L+(16>>2)],preserveDrawingBuffer:!!o()[L+(20>>2)],powerPreference:Rf[q],failIfMajorPerformanceCaveat:!!o()[L+(28>>2)],majorVersion:o()[L+(32>>2)],minorVersion:o()[L+(36>>2)],enableExtensionsByDefault:o()[L+(40>>2)],explicitSwapControl:o()[L+(44>>2)],proxyContextToMainThread:o()[L+(48>>2)],renderViaOffscreenBackBuffer:o()[L+(52>>2)]},le=ru(S);if(!le||pe.explicitSwapControl)return 0;var ue=Je.createContext(le,pe);return ue}function Ff(S,E){return Mf(S,E)}var ji={mappings:{},buffers:[null,[],[]],printChar:function(S,E){var L=ji.buffers[S];E===0||E===10?((S===1?X:G)(ze(L,0)),L.length=0):L.push(E)},varargs:void 0,get:function(){ji.varargs+=4;var S=o()[ji.varargs-4>>2];return S},getStr:function(S){var E=De(S);return E},get64:function(S,E){return S}};function pp(S){return v?yr(3,1,S):0}function cp(S,E,L,q,pe){if(v)return yr(4,1,S,E,L,q,pe)}function hp(S,E,L,q){if(v)return yr(5,1,S,E,L,q);for(var pe=0,le=0;le>2],be=o()[E+(le*8+4)>>2],tt=0;tt>2]=pe,0}function $f(S){var E=we.threadExitHandlers.pop();S&&E()}function Df(S,E){we.threadExitHandlers.push(function(){ta.get(S)(E)})}function fp(S){if(v)throw"Internal Error! spawnThread() can only ever be called from main application thread!";var E=we.getNewWorker();if(E.pthread!==void 0)throw"Internal error!";if(!S.pthread_ptr)throw"Internal error, no pthread ptr!";we.runningWorkers.push(E);for(var L=as(128*4),q=0;q<128;++q)o()[L+q*4>>2]=0;var pe=S.stackBase+S.stackSize,le=we.pthreads[S.pthread_ptr]={worker:E,stackBase:S.stackBase,stackSize:S.stackSize,allocatedOwnStack:S.allocatedOwnStack,threadInfoStruct:S.pthread_ptr},ue=le.threadInfoStruct>>2;Atomics.store(l(),ue+(64>>2),S.detached),Atomics.store(l(),ue+(100>>2),L),Atomics.store(l(),ue+(40>>2),le.threadInfoStruct),Atomics.store(l(),ue+(80>>2),S.stackSize),Atomics.store(l(),ue+(76>>2),pe),Atomics.store(l(),ue+(104>>2),S.stackSize),Atomics.store(l(),ue+(104+8>>2),pe),Atomics.store(l(),ue+(104+12>>2),S.detached);var be=Tg(),tt=be+40;Atomics.store(l(),ue+(172>>2),tt),E.pthread=le;var Vt={cmd:"run",start_routine:S.startRoutine,arg:S.arg,threadInfoStruct:S.pthread_ptr,stackBase:S.stackBase,stackSize:S.stackSize};E.runPthread=function(){Vt.time=performance.now(),E.postMessage(Vt,S.transferList)},E.loaded&&(E.runPthread(),delete E.runPthread)}function Of(S,E,L,q){if(typeof SharedArrayBuffer=="undefined")return G("Current environment does not support SharedArrayBuffer, pthreads are not available!"),6;if(!S)return G("pthread_create called with a null thread pointer!"),28;var pe=[],le=0;if(v&&(pe.length===0||le))return Mg(687865856,S,E,L,q);if(le)return le;var ue=0,be=0,tt=0;E&&E!=-1?(ue=o()[E>>2],ue+=81920,be=o()[E+8>>2],tt=o()[E+12>>2]!==0):ue=2097152;var Vt=be==0;Vt?be=Dg(16,ue):(be-=ue,ce(be>0));for(var Dt=as(228),br=0;br<228>>2;++br)l()[(Dt>>2)+br]=0;o()[S>>2]=Dt,o()[Dt+12>>2]=Dt;var Ki=Dt+152;o()[Ki>>2]=Ki;var vn={stackBase:be,stackSize:ue,allocatedOwnStack:Vt,detached:tt,startRoutine:L,pthread_ptr:Dt,arg:q,transferList:pe};return v?(vn.cmd="spawnThread",postMessage(vn,pe)):fp(vn),0}function mp(S){if(v)return yr(6,1,S);switch(S){case 30:return 16384;case 85:var E=2147483648;return E/16384;case 132:case 133:case 12:case 137:case 138:case 15:case 235:case 16:case 17:case 18:case 19:case 20:case 149:case 13:case 10:case 236:case 153:case 9:case 21:case 22:case 159:case 154:case 14:case 77:case 78:case 139:case 82:case 68:case 67:case 164:case 11:case 29:case 47:case 48:case 95:case 52:case 51:case 46:return 200809;case 27:case 246:case 127:case 128:case 23:case 24:case 160:case 161:case 181:case 182:case 242:case 183:case 184:case 243:case 244:case 245:case 165:case 178:case 179:case 49:case 50:case 168:case 169:case 175:case 170:case 171:case 172:case 97:case 76:case 32:case 173:case 35:case 80:case 81:case 79:return-1;case 176:case 177:case 7:case 155:case 8:case 157:case 125:case 126:case 92:case 93:case 129:case 130:case 131:case 94:case 91:return 1;case 74:case 60:case 69:case 70:case 4:return 1024;case 31:case 42:case 72:return 32;case 87:case 26:case 33:return 2147483647;case 34:case 1:return 47839;case 38:case 36:return 99;case 43:case 37:return 2048;case 0:return 2097152;case 3:return 65536;case 28:return 32768;case 44:return 32767;case 75:return 16384;case 39:return 1e3;case 89:return 700;case 71:return 256;case 40:return 255;case 2:return 100;case 180:return 64;case 25:return 20;case 5:return 16;case 6:return 6;case 73:return 4;case 84:return typeof navigator=="object"&&navigator.hardwareConcurrency||1}return nf(28),-1}v||we.initMainThreadBlock();var gr,zf=[null,af,dp,pp,cp,hp,mp],_f={e:ef,r:tf,x:rf,b:sf,y:of,j:lf,c:uf,d:tu,f:ns,p:df,z:pf,u:hf,q:Af,v:kf,i:If,t:Sf,w:Ff,m:pp,n:cp,g:hp,o:lp,a:Q||u.wasmMemory,k:$f,l:Df,h:Of,s:mp},Sg=G0(),Ap=u.___wasm_call_ctors=function(){return(Ap=u.___wasm_call_ctors=u.asm.A).apply(null,arguments)},Pf=u._init=function(){return(Pf=u._init=u.asm.B).apply(null,arguments)},Lf=u._register_tensor=function(){return(Lf=u._register_tensor=u.asm.C).apply(null,arguments)},Wf=u._dispose_data=function(){return(Wf=u._dispose_data=u.asm.D).apply(null,arguments)},Bf=u._dispose=function(){return(Bf=u._dispose=u.asm.E).apply(null,arguments)},Vf=u._Abs=function(){return(Vf=u._Abs=u.asm.G).apply(null,arguments)},jf=u._Add=function(){return(jf=u._Add=u.asm.H).apply(null,arguments)},Uf=u._AddN=function(){return(Uf=u._AddN=u.asm.I).apply(null,arguments)},Hf=u._All=function(){return(Hf=u._All=u.asm.J).apply(null,arguments)},Gf=u._Any=function(){return(Gf=u._Any=u.asm.K).apply(null,arguments)},qf=u._ArgMax=function(){return(qf=u._ArgMax=u.asm.L).apply(null,arguments)},Xf=u._AvgPool=function(){return(Xf=u._AvgPool=u.asm.M).apply(null,arguments)},Kf=u._BatchMatMul=function(){return(Kf=u._BatchMatMul=u.asm.N).apply(null,arguments)},Zf=u._Ceil=function(){return(Zf=u._Ceil=u.asm.O).apply(null,arguments)},Yf=u._ClipByValue=function(){return(Yf=u._ClipByValue=u.asm.P).apply(null,arguments)},Jf=u._Conv2D=function(){return(Jf=u._Conv2D=u.asm.Q).apply(null,arguments)},Qf=u._Conv2DBackpropInput=function(){return(Qf=u._Conv2DBackpropInput=u.asm.R).apply(null,arguments)},em=u._Cos=function(){return(em=u._Cos=u.asm.S).apply(null,arguments)},tm=u._CropAndResize=function(){return(tm=u._CropAndResize=u.asm.T).apply(null,arguments)},nm=u._Cumsum=function(){return(nm=u._Cumsum=u.asm.U).apply(null,arguments)},am=u._DepthToSpace=function(){return(am=u._DepthToSpace=u.asm.V).apply(null,arguments)},rm=u._DepthwiseConv2dNative=function(){return(rm=u._DepthwiseConv2dNative=u.asm.W).apply(null,arguments)},yp=u._Equal=function(){return(yp=u._Equal=u.asm.X).apply(null,arguments)},gp=u._Exp=function(){return(gp=u._Exp=u.asm.Y).apply(null,arguments)},xp=u._FlipLeftRight=function(){return(xp=u._FlipLeftRight=u.asm.Z).apply(null,arguments)},su=u._Floor=function(){return(su=u._Floor=u.asm._).apply(null,arguments)},Ui=u._FloorDiv=function(){return(Ui=u._FloorDiv=u.asm.$).apply(null,arguments)},sm=u._FusedBatchNorm=function(){return(sm=u._FusedBatchNorm=u.asm.aa).apply(null,arguments)},iu=u._FusedConv2D=function(){return(iu=u._FusedConv2D=u.asm.ba).apply(null,arguments)},K=u._FusedDepthwiseConv2D=function(){return(K=u._FusedDepthwiseConv2D=u.asm.ca).apply(null,arguments)},te=u._Gather=function(){return(te=u._Gather=u.asm.da).apply(null,arguments)},Te=u._GatherNd=function(){return(Te=u._GatherNd=u.asm.ea).apply(null,arguments)},Ke=u._Greater=function(){return(Ke=u._Greater=u.asm.fa).apply(null,arguments)},St=u._GreaterEqual=function(){return(St=u._GreaterEqual=u.asm.ga).apply(null,arguments)},mt=u._LeakyRelu=function(){return(mt=u._LeakyRelu=u.asm.ha).apply(null,arguments)},je=u._Less=function(){return(je=u._Less=u.asm.ia).apply(null,arguments)},He=u._LessEqual=function(){return(He=u._LessEqual=u.asm.ja).apply(null,arguments)},Yt=u._Log=function(){return(Yt=u._Log=u.asm.ka).apply(null,arguments)},Ja=u._LogicalAnd=function(){return(Ja=u._LogicalAnd=u.asm.la).apply(null,arguments)},Qa=u._Max=function(){return(Qa=u._Max=u.asm.ma).apply(null,arguments)},bp=u._MaxPool=function(){return(bp=u._MaxPool=u.asm.na).apply(null,arguments)},ou=u._Maximum=function(){return(ou=u._Maximum=u.asm.oa).apply(null,arguments)},Hn=u._Mean=function(){return(Hn=u._Mean=u.asm.pa).apply(null,arguments)},xr=u._Min=function(){return(xr=u._Min=u.asm.qa).apply(null,arguments)},vp=u._Minimum=function(){return(vp=u._Minimum=u.asm.ra).apply(null,arguments)},Zk=u._MirrorPad=function(){return(Zk=u._MirrorPad=u.asm.sa).apply(null,arguments)},Yk=u._Multiply=function(){return(Yk=u._Multiply=u.asm.ta).apply(null,arguments)},Jk=u._Neg=function(){return(Jk=u._Neg=u.asm.ua).apply(null,arguments)},Qk=u._NonMaxSuppressionV3=function(){return(Qk=u._NonMaxSuppressionV3=u.asm.va).apply(null,arguments)},e9=u._NonMaxSuppressionV4=function(){return(e9=u._NonMaxSuppressionV4=u.asm.wa).apply(null,arguments)},t9=u._NonMaxSuppressionV5=function(){return(t9=u._NonMaxSuppressionV5=u.asm.xa).apply(null,arguments)},n9=u._NotEqual=function(){return(n9=u._NotEqual=u.asm.ya).apply(null,arguments)},a9=u._OneHot=function(){return(a9=u._OneHot=u.asm.za).apply(null,arguments)},r9=u._PadV2=function(){return(r9=u._PadV2=u.asm.Aa).apply(null,arguments)},s9=u._Pow=function(){return(s9=u._Pow=u.asm.Ba).apply(null,arguments)},i9=u._Prelu=function(){return(i9=u._Prelu=u.asm.Ca).apply(null,arguments)},o9=u._Prod=function(){return(o9=u._Prod=u.asm.Da).apply(null,arguments)},l9=u._RealDiv=function(){return(l9=u._RealDiv=u.asm.Ea).apply(null,arguments)},u9=u._Relu=function(){return(u9=u._Relu=u.asm.Fa).apply(null,arguments)},d9=u._Relu6=function(){return(d9=u._Relu6=u.asm.Ga).apply(null,arguments)},p9=u._ResizeBilinear=function(){return(p9=u._ResizeBilinear=u.asm.Ha).apply(null,arguments)},c9=u._Reverse=function(){return(c9=u._Reverse=u.asm.Ia).apply(null,arguments)},h9=u._RotateWithOffset=function(){return(h9=u._RotateWithOffset=u.asm.Ja).apply(null,arguments)},f9=u._Round=function(){return(f9=u._Round=u.asm.Ka).apply(null,arguments)},m9=u._Rsqrt=function(){return(m9=u._Rsqrt=u.asm.La).apply(null,arguments)},A9=u._ScatterNd=function(){return(A9=u._ScatterNd=u.asm.Ma).apply(null,arguments)},y9=u._SelectV2=function(){return(y9=u._SelectV2=u.asm.Na).apply(null,arguments)},g9=u._Sigmoid=function(){return(g9=u._Sigmoid=u.asm.Oa).apply(null,arguments)},x9=u._Sin=function(){return(x9=u._Sin=u.asm.Pa).apply(null,arguments)},b9=u._Softmax=function(){return(b9=u._Softmax=u.asm.Qa).apply(null,arguments)},v9=u._Sqrt=function(){return(v9=u._Sqrt=u.asm.Ra).apply(null,arguments)},w9=u._Square=function(){return(w9=u._Square=u.asm.Sa).apply(null,arguments)},k9=u._SquaredDifference=function(){return(k9=u._SquaredDifference=u.asm.Ta).apply(null,arguments)},I9=u._Step=function(){return(I9=u._Step=u.asm.Ua).apply(null,arguments)},S9=u._StridedSlice=function(){return(S9=u._StridedSlice=u.asm.Va).apply(null,arguments)},N9=u._Sub=function(){return(N9=u._Sub=u.asm.Wa).apply(null,arguments)},T9=u._Sum=function(){return(T9=u._Sum=u.asm.Xa).apply(null,arguments)},E9=u._Tan=function(){return(E9=u._Tan=u.asm.Ya).apply(null,arguments)},C9=u._Tanh=function(){return(C9=u._Tanh=u.asm.Za).apply(null,arguments)},R9=u._Tile=function(){return(R9=u._Tile=u.asm._a).apply(null,arguments)},M9=u._TopK=function(){return(M9=u._TopK=u.asm.$a).apply(null,arguments)},F9=u._Transform=function(){return(F9=u._Transform=u.asm.ab).apply(null,arguments)},$9=u._Transpose=function(){return($9=u._Transpose=u.asm.bb).apply(null,arguments)},D9=u.__FusedMatMul=function(){return(D9=u.__FusedMatMul=u.asm.cb).apply(null,arguments)},as=u._malloc=function(){return(as=u._malloc=u.asm.db).apply(null,arguments)},lu=u._free=function(){return(lu=u._free=u.asm.eb).apply(null,arguments)},Ng=u.___errno_location=function(){return(Ng=u.___errno_location=u.asm.fb).apply(null,arguments)},Tg=u._emscripten_get_global_libc=function(){return(Tg=u._emscripten_get_global_libc=u.asm.gb).apply(null,arguments)},Hi=u._pthread_self=function(){return(Hi=u._pthread_self=u.asm.hb).apply(null,arguments)},Eg=u.___pthread_tsd_run_dtors=function(){return(Eg=u.___pthread_tsd_run_dtors=u.asm.ib).apply(null,arguments)},im=u._emscripten_main_thread_process_queued_calls=function(){return(im=u._emscripten_main_thread_process_queued_calls=u.asm.jb).apply(null,arguments)},O9=u._emscripten_current_thread_process_queued_calls=function(){return(O9=u._emscripten_current_thread_process_queued_calls=u.asm.kb).apply(null,arguments)},Cg=u._emscripten_register_main_browser_thread_id=function(){return(Cg=u._emscripten_register_main_browser_thread_id=u.asm.lb).apply(null,arguments)},Rg=u.__emscripten_do_dispatch_to_thread=function(){return(Rg=u.__emscripten_do_dispatch_to_thread=u.asm.mb).apply(null,arguments)},Mg=u._emscripten_sync_run_in_main_thread_4=function(){return(Mg=u._emscripten_sync_run_in_main_thread_4=u.asm.nb).apply(null,arguments)},Fg=u._emscripten_run_in_main_runtime_thread_js=function(){return(Fg=u._emscripten_run_in_main_runtime_thread_js=u.asm.ob).apply(null,arguments)},om=u.__emscripten_call_on_thread=function(){return(om=u.__emscripten_call_on_thread=u.asm.pb).apply(null,arguments)},z9=u._emscripten_tls_init=function(){return(z9=u._emscripten_tls_init=u.asm.qb).apply(null,arguments)},lm=u.__emscripten_thread_init=function(){return(lm=u.__emscripten_thread_init=u.asm.rb).apply(null,arguments)},uu=u.stackSave=function(){return(uu=u.stackSave=u.asm.sb).apply(null,arguments)},Gi=u.stackRestore=function(){return(Gi=u.stackRestore=u.asm.tb).apply(null,arguments)},qi=u.stackAlloc=function(){return(qi=u.stackAlloc=u.asm.ub).apply(null,arguments)},$g=u._emscripten_stack_set_limits=function(){return($g=u._emscripten_stack_set_limits=u.asm.vb).apply(null,arguments)},Dg=u._memalign=function(){return(Dg=u._memalign=u.asm.wb).apply(null,arguments)},Og=u.__emscripten_allow_main_runtime_queued_calls=9808,Xi=u.__emscripten_main_thread_futex=11432;u.cwrap=$e,u.PThread=we,u.PThread=we,u.wasmMemory=Q,u.ExitStatus=du;var wp;function du(S){this.name="ExitStatus",this.message="Program terminated with exit("+S+")",this.status=S}ts=function S(){wp||um(),wp||(ts=S)};function um(S){if(S=S||f,Za>0)return;if(v){p(u),eu(),postMessage({cmd:"loaded"});return}if(L0(),Za>0)return;function E(){wp||(wp=!0,u.calledRun=!0,!oe&&(eu(),W0(),p(u),u.onRuntimeInitialized&&u.onRuntimeInitialized(),xn()))}u.setStatus?(u.setStatus("Running..."),setTimeout(function(){setTimeout(function(){u.setStatus("")},1),E()},1)):E()}u.run=um;function _9(S,E){if(!(E&&ie&&S===0)){if(!E&&v)throw postMessage({cmd:"exitProcess",returnCode:S}),new du(S);ie||(we.terminateAllThreads(),ye=S,np(),u.onExit&&u.onExit(S),oe=!0),y(S,new du(S))}}if(u.preInit)for(typeof u.preInit=="function"&&(u.preInit=[u.preInit]);u.preInit.length>0;)u.preInit.pop()();return v&&(ie=!1,we.initWorker()),um(),r.ready}}();typeof e=="object"&&typeof t=="object"?t.exports=n:typeof define=="function"&&define.amd?define([],function(){return n}):typeof e=="object"&&(e.WasmBackendModuleThreadedSimd=n)}),aI=bt((e,t)=>{var n=function(){var a=typeof document!="undefined"&&document.currentScript?document.currentScript.src:void 0;return typeof __filename!="undefined"&&(a=a||__filename),function(r){r=r||{};var s=typeof r!="undefined"?r:{},i,o;s.ready=new Promise(function(K,te){i=K,o=te});var l={},d;for(d in s)s.hasOwnProperty(d)&&(l[d]=s[d]);var u=[],p="./this.program",c=function(K,te){throw te},h=!1,m=!1,f=!1,A=!1;h=typeof window=="object",m=typeof importScripts=="function",f=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",A=!h&&!f&&!m;var y="";function g(K){return s.locateFile?s.locateFile(K,y):y+K}var x,w,b,v,N,T;f?(m?y=cu().dirname(y)+"/":y=__dirname+"/",x=function(K,te){return N||(N=require("fs")),T||(T=cu()),K=T.normalize(K),N.readFileSync(K,te?null:"utf8")},b=function(K){var te=x(K,!0);return te.buffer||(te=new Uint8Array(te)),X(te.buffer),te},process.argv.length>1&&(p=process.argv[1].replace(/\\/g,"/")),u=process.argv.slice(2),process.on("uncaughtException",function(K){if(!(K instanceof sm))throw K}),process.on("unhandledRejection",Ma),c=function(K){process.exit(K)},s.inspect=function(){return"[Emscripten Module object]"}):A?(typeof read!="undefined"&&(x=function(K){return read(K)}),b=function(K){var te;return typeof readbuffer=="function"?new Uint8Array(readbuffer(K)):(te=read(K,"binary"),X(typeof te=="object"),te)},typeof scriptArgs!="undefined"?u=scriptArgs:typeof arguments!="undefined"&&(u=arguments),typeof quit=="function"&&(c=function(K){quit(K)}),typeof print!="undefined"&&(typeof console=="undefined"&&(console={}),console.log=print,console.warn=console.error=typeof printErr!="undefined"?printErr:print)):(h||m)&&(m?y=self.location.href:typeof document!="undefined"&&document.currentScript&&(y=document.currentScript.src),a&&(y=a),y.indexOf("blob:")!==0?y=y.substr(0,y.lastIndexOf("/")+1):y="",x=function(K){var te=new XMLHttpRequest;return te.open("GET",K,!1),te.send(null),te.responseText},m&&(b=function(K){var te=new XMLHttpRequest;return te.open("GET",K,!1),te.responseType="arraybuffer",te.send(null),new Uint8Array(te.response)}),w=function(K,te,Te){var Ke=new XMLHttpRequest;Ke.open("GET",K,!0),Ke.responseType="arraybuffer",Ke.onload=function(){if(Ke.status==200||Ke.status==0&&Ke.response){te(Ke.response);return}Te()},Ke.onerror=Te,Ke.send(null)},v=function(K){document.title=K});var R=s.print||console.log.bind(console),$=s.printErr||console.warn.bind(console);for(d in l)l.hasOwnProperty(d)&&(s[d]=l[d]);l=null,s.arguments&&(u=s.arguments),s.thisProgram&&(p=s.thisProgram),s.quit&&(c=s.quit);var z;s.wasmBinary&&(z=s.wasmBinary);var P=s.noExitRuntime||!0;typeof WebAssembly!="object"&&Ma("no native wasm support detected");var V,j=!1,U;function X(K,te){K||Ma("Assertion failed: "+te)}function G(K){var te=s["_"+K];return X(te,"Cannot call unknown function "+K+", make sure it is exported"),te}function ee(K,te,Te,Ke,St){var mt={string:function(Hn){var xr=0;if(Hn!=null&&Hn!==0){var vp=(Hn.length<<2)+1;xr=su(vp),de(Hn,xr,vp)}return xr},array:function(Hn){var xr=su(Hn.length);return oe(Hn,xr),xr}};function je(Hn){return te==="string"?ie(Hn):te==="boolean"?Boolean(Hn):Hn}var He=G(K),Yt=[],Ja=0;if(Ke)for(var Qa=0;Qa=Ke);)++St;if(St-te>16&&K.subarray&&re)return re.decode(K.subarray(te,St));for(var mt="";te>10,56320|Ja&1023)}}return mt}function ie(K,te){return K?ne(Ne,K,te):""}function Q(K,te,Te,Ke){if(!(Ke>0))return 0;for(var St=Te,mt=Te+Ke-1,je=0;je=55296&&He<=57343){var Yt=K.charCodeAt(++je);He=65536+((He&1023)<<10)|Yt&1023}if(He<=127){if(Te>=mt)break;te[Te++]=He}else if(He<=2047){if(Te+1>=mt)break;te[Te++]=192|He>>6,te[Te++]=128|He&63}else if(He<=65535){if(Te+2>=mt)break;te[Te++]=224|He>>12,te[Te++]=128|He>>6&63,te[Te++]=128|He&63}else{if(Te+3>=mt)break;te[Te++]=240|He>>18,te[Te++]=128|He>>12&63,te[Te++]=128|He>>6&63,te[Te++]=128|He&63}}return te[Te]=0,Te-St}function de(K,te,Te){return Q(K,Ne,te,Te)}function oe(K,te){Ie.set(K,te)}function ye(K,te){return K%te>0&&(K+=te-K%te),K}var ce,Ie,Ne,$e,ze,De,Qe,et,rt;function Xe(K){ce=K,s.HEAP8=Ie=new Int8Array(K),s.HEAP16=$e=new Int16Array(K),s.HEAP32=De=new Int32Array(K),s.HEAPU8=Ne=new Uint8Array(K),s.HEAPU16=ze=new Uint16Array(K),s.HEAPU32=Qe=new Uint32Array(K),s.HEAPF32=et=new Float32Array(K),s.HEAPF64=rt=new Float64Array(K)}var pt=s.INITIAL_MEMORY||16777216,Ve,yn=[],xt=[],jn=[],Kt=[],gn=!1;xt.push({func:function(){lp()}});function Un(){if(s.preRun)for(typeof s.preRun=="function"&&(s.preRun=[s.preRun]);s.preRun.length;)Ra(s.preRun.shift());Ar(yn)}function Mn(){gn=!0,Ar(xt)}function sn(){Ar(jn)}function Zt(){if(s.postRun)for(typeof s.postRun=="function"&&(s.postRun=[s.postRun]);s.postRun.length;)ta(s.postRun.shift());Ar(Kt)}function Ra(K){yn.unshift(K)}function ta(K){Kt.unshift(K)}var na=0,fr=null,Ka=null;function mr(K){na++,s.monitorRunDependencies&&s.monitorRunDependencies(na)}function Wi(K){if(na--,s.monitorRunDependencies&&s.monitorRunDependencies(na),na==0&&(fr!==null&&(clearInterval(fr),fr=null),Ka)){var te=Ka;Ka=null,te()}}s.preloadedImages={},s.preloadedAudios={};function Ma(K){s.onAbort&&s.onAbort(K),K+="",$(K),j=!0,U=1,K="abort("+K+"). Build with -s ASSERTIONS=1 for more info.";var te=new WebAssembly.RuntimeError(K);throw o(te),te}function tp(K,te){return String.prototype.startsWith?K.startsWith(te):K.indexOf(te)===0}var L0="data:application/octet-stream;base64,";function eu(K){return tp(K,L0)}var W0="file://";function np(K){return tp(K,W0)}var xn="tfjs-backend-wasm.wasm";eu(xn)||(xn=g(xn));function ap(K){try{if(K==xn&&z)return new Uint8Array(z);if(b)return b(K);throw"both async and sync fetching of the wasm failed"}catch(te){Ma(te)}}function B0(){if(!z&&(h||m)){if(typeof fetch=="function"&&!np(xn))return fetch(xn,{credentials:"same-origin"}).then(function(K){if(!K.ok)throw"failed to load wasm binary file at '"+xn+"'";return K.arrayBuffer()}).catch(function(){return ap(xn)});if(w)return new Promise(function(K,te){w(xn,function(Te){K(new Uint8Array(Te))},te)})}return Promise.resolve().then(function(){return ap(xn)})}function Za(){var K={a:G0};function te(je,He){var Yt=je.exports;s.asm=Yt,V=s.asm.i,Xe(V.buffer),Ve=s.asm.o,Wi("wasm-instantiate")}mr("wasm-instantiate");function Te(je){te(je.instance)}function Ke(je){return B0().then(function(He){return WebAssembly.instantiate(He,K)}).then(je,function(He){$("failed to asynchronously prepare wasm: "+He),Ma(He)})}function St(){return!z&&typeof WebAssembly.instantiateStreaming=="function"&&!eu(xn)&&!np(xn)&&typeof fetch=="function"?fetch(xn,{credentials:"same-origin"}).then(function(je){var He=WebAssembly.instantiateStreaming(je,K);return He.then(Te,function(Yt){return $("wasm streaming compile failed: "+Yt),$("falling back to ArrayBuffer instantiation"),Ke(Te)})}):Ke(Te)}if(s.instantiateWasm)try{var mt=s.instantiateWasm(K,te);return mt}catch(je){return $("Module.instantiateWasm callback failed with error: "+je),!1}return St().catch(o),{}}function Ar(K){for(;K.length>0;){var te=K.shift();if(typeof te=="function"){te(s);continue}var Te=te.func;typeof Te=="number"?te.arg===void 0?Ve.get(Te)():Ve.get(Te)(te.arg):Te(te.arg===void 0?null:te.arg)}}function ts(){Ma()}function V0(K,te,Te){Ne.copyWithin(K,te,te+Te)}function j0(){return Ne.length}function Ya(K){try{return V.grow(K-ce.byteLength+65535>>>16),Xe(V.buffer),1}catch(te){}}function rp(K){var te=j0(),Te=2147483648;if(K>Te)return!1;for(var Ke=1;Ke<=4;Ke*=2){var St=te*(1+.2/Ke);St=Math.min(St,K+100663296);var mt=Math.min(Te,ye(Math.max(K,St),65536)),je=Ya(mt);if(je)return!0}return!1}var Bi={mappings:{},buffers:[null,[],[]],printChar:function(K,te){var Te=Bi.buffers[K];te===0||te===10?((K===1?R:$)(ne(Te,0)),Te.length=0):Te.push(te)},varargs:void 0,get:function(){Bi.varargs+=4;var K=De[Bi.varargs-4>>2];return K},getStr:function(K){var te=ie(K);return te},get64:function(K,te){return K}};function sp(K){return 0}function U0(K,te,Te,Ke,St){}function ip(K,te,Te,Ke){for(var St=0,mt=0;mt>2],He=De[te+(mt*8+4)>>2],Yt=0;Yt>2]=St,0}function bn(){return 6}function op(K){return De[yp()>>2]=K,K}function H0(K){switch(K){case 30:return 16384;case 85:var te=2147483648;return te/16384;case 132:case 133:case 12:case 137:case 138:case 15:case 235:case 16:case 17:case 18:case 19:case 20:case 149:case 13:case 10:case 236:case 153:case 9:case 21:case 22:case 159:case 154:case 14:case 77:case 78:case 139:case 82:case 68:case 67:case 164:case 11:case 29:case 47:case 48:case 95:case 52:case 51:case 46:return 200809;case 27:case 246:case 127:case 128:case 23:case 24:case 160:case 161:case 181:case 182:case 242:case 183:case 184:case 243:case 244:case 245:case 165:case 178:case 179:case 49:case 50:case 168:case 169:case 175:case 170:case 171:case 172:case 97:case 76:case 32:case 173:case 35:case 80:case 81:case 79:return-1;case 176:case 177:case 7:case 155:case 8:case 157:case 125:case 126:case 92:case 93:case 129:case 130:case 131:case 94:case 91:return 1;case 74:case 60:case 69:case 70:case 4:return 1024;case 31:case 42:case 72:return 32;case 87:case 26:case 33:return 2147483647;case 34:case 1:return 47839;case 38:case 36:return 99;case 43:case 37:return 2048;case 0:return 2097152;case 3:return 65536;case 28:return 32768;case 44:return 32767;case 75:return 16384;case 39:return 1e3;case 89:return 700;case 71:return 256;case 40:return 255;case 2:return 100;case 180:return 64;case 25:return 20;case 5:return 16;case 6:return 6;case 73:return 4;case 84:return typeof navigator=="object"&&navigator.hardwareConcurrency||1}return op(28),-1}var G0={a:ts,d:V0,e:rp,f:sp,c:U0,b:ip,g:bn,h:H0},q0=Za(),lp=s.___wasm_call_ctors=function(){return(lp=s.___wasm_call_ctors=s.asm.j).apply(null,arguments)},Vi=s._init=function(){return(Vi=s._init=s.asm.k).apply(null,arguments)},tu=s._register_tensor=function(){return(tu=s._register_tensor=s.asm.l).apply(null,arguments)},X0=s._dispose_data=function(){return(X0=s._dispose_data=s.asm.m).apply(null,arguments)},K0=s._dispose=function(){return(K0=s._dispose=s.asm.n).apply(null,arguments)},Z0=s._Abs=function(){return(Z0=s._Abs=s.asm.p).apply(null,arguments)},we=s._Add=function(){return(we=s._Add=s.asm.q).apply(null,arguments)},Y0=s._AddN=function(){return(Y0=s._AddN=s.asm.r).apply(null,arguments)},J0=s._All=function(){return(J0=s._All=s.asm.s).apply(null,arguments)},Q0=s._Any=function(){return(Q0=s._Any=s.asm.t).apply(null,arguments)},ef=s._ArgMax=function(){return(ef=s._ArgMax=s.asm.u).apply(null,arguments)},tf=s._AvgPool=function(){return(tf=s._AvgPool=s.asm.v).apply(null,arguments)},ns=s._BatchMatMul=function(){return(ns=s._BatchMatMul=s.asm.w).apply(null,arguments)},nf=s._Ceil=function(){return(nf=s._Ceil=s.asm.x).apply(null,arguments)},af=s._ClipByValue=function(){return(af=s._ClipByValue=s.asm.y).apply(null,arguments)},rf=s._Conv2D=function(){return(rf=s._Conv2D=s.asm.z).apply(null,arguments)},sf=s._Conv2DBackpropInput=function(){return(sf=s._Conv2DBackpropInput=s.asm.A).apply(null,arguments)},of=s._Cos=function(){return(of=s._Cos=s.asm.B).apply(null,arguments)},lf=s._CropAndResize=function(){return(lf=s._CropAndResize=s.asm.C).apply(null,arguments)},uf=s._Cumsum=function(){return(uf=s._Cumsum=s.asm.D).apply(null,arguments)},df=s._DepthToSpace=function(){return(df=s._DepthToSpace=s.asm.E).apply(null,arguments)},pf=s._DepthwiseConv2dNative=function(){return(pf=s._DepthwiseConv2dNative=s.asm.F).apply(null,arguments)},yr=s._Equal=function(){return(yr=s._Equal=s.asm.G).apply(null,arguments)},nu=s._Exp=function(){return(nu=s._Exp=s.asm.H).apply(null,arguments)},au=s._FlipLeftRight=function(){return(au=s._FlipLeftRight=s.asm.I).apply(null,arguments)},cf=s._Floor=function(){return(cf=s._Floor=s.asm.J).apply(null,arguments)},hf=s._FloorDiv=function(){return(hf=s._FloorDiv=s.asm.K).apply(null,arguments)},ff=s._FusedBatchNorm=function(){return(ff=s._FusedBatchNorm=s.asm.L).apply(null,arguments)},mf=s._FusedConv2D=function(){return(mf=s._FusedConv2D=s.asm.M).apply(null,arguments)},Af=s._FusedDepthwiseConv2D=function(){return(Af=s._FusedDepthwiseConv2D=s.asm.N).apply(null,arguments)},Pe=s._Gather=function(){return(Pe=s._Gather=s.asm.O).apply(null,arguments)},yf=s._GatherNd=function(){return(yf=s._GatherNd=s.asm.P).apply(null,arguments)},gf=s._Greater=function(){return(gf=s._Greater=s.asm.Q).apply(null,arguments)},xf=s._GreaterEqual=function(){return(xf=s._GreaterEqual=s.asm.R).apply(null,arguments)},bf=s._LeakyRelu=function(){return(bf=s._LeakyRelu=s.asm.S).apply(null,arguments)},vf=s._Less=function(){return(vf=s._Less=s.asm.T).apply(null,arguments)},wf=s._LessEqual=function(){return(wf=s._LessEqual=s.asm.U).apply(null,arguments)},ru=s._Log=function(){return(ru=s._Log=s.asm.V).apply(null,arguments)},up=s._LogicalAnd=function(){return(up=s._LogicalAnd=s.asm.W).apply(null,arguments)},dp=s._Max=function(){return(dp=s._Max=s.asm.X).apply(null,arguments)},kf=s._MaxPool=function(){return(kf=s._MaxPool=s.asm.Y).apply(null,arguments)},If=s._Maximum=function(){return(If=s._Maximum=s.asm.Z).apply(null,arguments)},Sf=s._Mean=function(){return(Sf=s._Mean=s.asm._).apply(null,arguments)},Nf=s._Min=function(){return(Nf=s._Min=s.asm.$).apply(null,arguments)},Tf=s._Minimum=function(){return(Tf=s._Minimum=s.asm.aa).apply(null,arguments)},Ef=s._MirrorPad=function(){return(Ef=s._MirrorPad=s.asm.ba).apply(null,arguments)},Cf=s._Multiply=function(){return(Cf=s._Multiply=s.asm.ca).apply(null,arguments)},Je=s._Neg=function(){return(Je=s._Neg=s.asm.da).apply(null,arguments)},Rf=s._NonMaxSuppressionV3=function(){return(Rf=s._NonMaxSuppressionV3=s.asm.ea).apply(null,arguments)},Mf=s._NonMaxSuppressionV4=function(){return(Mf=s._NonMaxSuppressionV4=s.asm.fa).apply(null,arguments)},Ff=s._NonMaxSuppressionV5=function(){return(Ff=s._NonMaxSuppressionV5=s.asm.ga).apply(null,arguments)},ji=s._NotEqual=function(){return(ji=s._NotEqual=s.asm.ha).apply(null,arguments)},pp=s._OneHot=function(){return(pp=s._OneHot=s.asm.ia).apply(null,arguments)},cp=s._PadV2=function(){return(cp=s._PadV2=s.asm.ja).apply(null,arguments)},hp=s._Pow=function(){return(hp=s._Pow=s.asm.ka).apply(null,arguments)},$f=s._Prelu=function(){return($f=s._Prelu=s.asm.la).apply(null,arguments)},Df=s._Prod=function(){return(Df=s._Prod=s.asm.ma).apply(null,arguments)},fp=s._RealDiv=function(){return(fp=s._RealDiv=s.asm.na).apply(null,arguments)},Of=s._Relu=function(){return(Of=s._Relu=s.asm.oa).apply(null,arguments)},mp=s._Relu6=function(){return(mp=s._Relu6=s.asm.pa).apply(null,arguments)},gr=s._ResizeBilinear=function(){return(gr=s._ResizeBilinear=s.asm.qa).apply(null,arguments)},zf=s._Reverse=function(){return(zf=s._Reverse=s.asm.ra).apply(null,arguments)},_f=s._RotateWithOffset=function(){return(_f=s._RotateWithOffset=s.asm.sa).apply(null,arguments)},Sg=s._Round=function(){return(Sg=s._Round=s.asm.ta).apply(null,arguments)},Ap=s._Rsqrt=function(){return(Ap=s._Rsqrt=s.asm.ua).apply(null,arguments)},Pf=s._ScatterNd=function(){return(Pf=s._ScatterNd=s.asm.va).apply(null,arguments)},Lf=s._SelectV2=function(){return(Lf=s._SelectV2=s.asm.wa).apply(null,arguments)},Wf=s._Sigmoid=function(){return(Wf=s._Sigmoid=s.asm.xa).apply(null,arguments)},Bf=s._Sin=function(){return(Bf=s._Sin=s.asm.ya).apply(null,arguments)},Vf=s._Softmax=function(){return(Vf=s._Softmax=s.asm.za).apply(null,arguments)},jf=s._Sqrt=function(){return(jf=s._Sqrt=s.asm.Aa).apply(null,arguments)},Uf=s._Square=function(){return(Uf=s._Square=s.asm.Ba).apply(null,arguments)},Hf=s._SquaredDifference=function(){return(Hf=s._SquaredDifference=s.asm.Ca).apply(null,arguments)},Gf=s._Step=function(){return(Gf=s._Step=s.asm.Da).apply(null,arguments)},qf=s._StridedSlice=function(){return(qf=s._StridedSlice=s.asm.Ea).apply(null,arguments)},Xf=s._Sub=function(){return(Xf=s._Sub=s.asm.Fa).apply(null,arguments)},Kf=s._Sum=function(){return(Kf=s._Sum=s.asm.Ga).apply(null,arguments)},Zf=s._Tan=function(){return(Zf=s._Tan=s.asm.Ha).apply(null,arguments)},Yf=s._Tanh=function(){return(Yf=s._Tanh=s.asm.Ia).apply(null,arguments)},Jf=s._Tile=function(){return(Jf=s._Tile=s.asm.Ja).apply(null,arguments)},Qf=s._TopK=function(){return(Qf=s._TopK=s.asm.Ka).apply(null,arguments)},em=s._Transform=function(){return(em=s._Transform=s.asm.La).apply(null,arguments)},tm=s._Transpose=function(){return(tm=s._Transpose=s.asm.Ma).apply(null,arguments)},nm=s.__FusedMatMul=function(){return(nm=s.__FusedMatMul=s.asm.Na).apply(null,arguments)},am=s._malloc=function(){return(am=s._malloc=s.asm.Oa).apply(null,arguments)},rm=s._free=function(){return(rm=s._free=s.asm.Pa).apply(null,arguments)},yp=s.___errno_location=function(){return(yp=s.___errno_location=s.asm.Qa).apply(null,arguments)},gp=s.stackSave=function(){return(gp=s.stackSave=s.asm.Ra).apply(null,arguments)},xp=s.stackRestore=function(){return(xp=s.stackRestore=s.asm.Sa).apply(null,arguments)},su=s.stackAlloc=function(){return(su=s.stackAlloc=s.asm.Ta).apply(null,arguments)};s.cwrap=Y;var Ui;function sm(K){this.name="ExitStatus",this.message="Program terminated with exit("+K+")",this.status=K}Ka=function K(){Ui||iu(),Ui||(Ka=K)};function iu(K){if(K=K||u,na>0||(Un(),na>0))return;function te(){Ui||(Ui=!0,s.calledRun=!0,!j&&(Mn(),sn(),i(s),s.onRuntimeInitialized&&s.onRuntimeInitialized(),Zt()))}s.setStatus?(s.setStatus("Running..."),setTimeout(function(){setTimeout(function(){s.setStatus("")},1),te()},1)):te()}if(s.run=iu,s.preInit)for(typeof s.preInit=="function"&&(s.preInit=[s.preInit]);s.preInit.length>0;)s.preInit.pop()();return iu(),r.ready}}();typeof e=="object"&&typeof t=="object"?t.exports=n:typeof define=="function"&&define.amd?define([],function(){return n}):typeof e=="object"&&(e.WasmBackendModule=n)}),rI=bt((e,t)=>{(function(n,a,r){function s(d){var u=this,p=l();u.next=function(){var c=2091639*u.s0+u.c*23283064365386963e-26;return u.s0=u.s1,u.s1=u.s2,u.s2=c-(u.c=c|0)},u.c=1,u.s0=p(" "),u.s1=p(" "),u.s2=p(" "),u.s0-=p(d),u.s0<0&&(u.s0+=1),u.s1-=p(d),u.s1<0&&(u.s1+=1),u.s2-=p(d),u.s2<0&&(u.s2+=1),p=null}function i(d,u){return u.c=d.c,u.s0=d.s0,u.s1=d.s1,u.s2=d.s2,u}function o(d,u){var p=new s(d),c=u&&u.state,h=p.next;return h.int32=function(){return p.next()*4294967296|0},h.double=function(){return h()+(h()*2097152|0)*11102230246251565e-32},h.quick=h,c&&(typeof c=="object"&&i(c,p),h.state=function(){return i(p,{})}),h}function l(){var d=4022871197,u=function(p){p=String(p);for(var c=0;c>>0,h-=d,h*=d,d=h>>>0,h-=d,d+=h*4294967296}return(d>>>0)*23283064365386963e-26};return u}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.alea=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),sI=bt((e,t)=>{(function(n,a,r){function s(l){var d=this,u="";d.x=0,d.y=0,d.z=0,d.w=0,d.next=function(){var c=d.x^d.x<<11;return d.x=d.y,d.y=d.z,d.z=d.w,d.w^=d.w>>>19^c^c>>>8},l===(l|0)?d.x=l:u+=l;for(var p=0;p>>0)/4294967296};return c.double=function(){do var h=u.next()>>>11,m=(u.next()>>>0)/4294967296,f=(h+m)/(1<<21);while(f===0);return f},c.int32=u.next,c.quick=c,p&&(typeof p=="object"&&i(p,u),c.state=function(){return i(u,{})}),c}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.xor128=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),iI=bt((e,t)=>{(function(n,a,r){function s(l){var d=this,u="";d.next=function(){var c=d.x^d.x>>>2;return d.x=d.y,d.y=d.z,d.z=d.w,d.w=d.v,(d.d=d.d+362437|0)+(d.v=d.v^d.v<<4^(c^c<<1))|0},d.x=0,d.y=0,d.z=0,d.w=0,d.v=0,l===(l|0)?d.x=l:u+=l;for(var p=0;p>>4),d.next()}function i(l,d){return d.x=l.x,d.y=l.y,d.z=l.z,d.w=l.w,d.v=l.v,d.d=l.d,d}function o(l,d){var u=new s(l),p=d&&d.state,c=function(){return(u.next()>>>0)/4294967296};return c.double=function(){do var h=u.next()>>>11,m=(u.next()>>>0)/4294967296,f=(h+m)/(1<<21);while(f===0);return f},c.int32=u.next,c.quick=c,p&&(typeof p=="object"&&i(p,u),c.state=function(){return i(u,{})}),c}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.xorwow=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),oI=bt((e,t)=>{(function(n,a,r){function s(l){var d=this;d.next=function(){var p=d.x,c=d.i,h,m,f;return h=p[c],h^=h>>>7,m=h^h<<24,h=p[c+1&7],m^=h^h>>>10,h=p[c+3&7],m^=h^h>>>3,h=p[c+4&7],m^=h^h<<7,h=p[c+7&7],h=h^h<<13,m^=h^h<<9,p[c]=m,d.i=c+1&7,m};function u(p,c){var h,m,f=[];if(c===(c|0))m=f[0]=c;else for(c=""+c,h=0;h0;--h)p.next()}u(d,l)}function i(l,d){return d.x=l.x.slice(),d.i=l.i,d}function o(l,d){l==null&&(l=+new Date);var u=new s(l),p=d&&d.state,c=function(){return(u.next()>>>0)/4294967296};return c.double=function(){do var h=u.next()>>>11,m=(u.next()>>>0)/4294967296,f=(h+m)/(1<<21);while(f===0);return f},c.int32=u.next,c.quick=c,p&&(p.x&&i(p,u),c.state=function(){return i(u,{})}),c}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.xorshift7=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),lI=bt((e,t)=>{(function(n,a,r){function s(l){var d=this;d.next=function(){var p=d.w,c=d.X,h=d.i,m,f;return d.w=p=p+1640531527|0,f=c[h+34&127],m=c[h=h+1&127],f^=f<<13,m^=m<<17,f^=f>>>15,m^=m>>>12,f=c[h]=f^m,d.i=h,f+(p^p>>>16)|0};function u(p,c){var h,m,f,A,y,g=[],x=128;for(c===(c|0)?(m=c,c=null):(c=c+"\0",m=0,x=Math.max(x,c.length)),f=0,A=-32;A>>15,m^=m<<4,m^=m>>>13,A>=0&&(y=y+1640531527|0,h=g[A&127]^=m+y,f=h==0?f+1:0);for(f>=128&&(g[(c&&c.length||0)&127]=-1),f=127,A=4*128;A>0;--A)m=g[f+34&127],h=g[f=f+1&127],m^=m<<13,h^=h<<17,m^=m>>>15,h^=h>>>12,g[f]=m^h;p.w=y,p.X=g,p.i=f}u(d,l)}function i(l,d){return d.i=l.i,d.w=l.w,d.X=l.X.slice(),d}function o(l,d){l==null&&(l=+new Date);var u=new s(l),p=d&&d.state,c=function(){return(u.next()>>>0)/4294967296};return c.double=function(){do var h=u.next()>>>11,m=(u.next()>>>0)/4294967296,f=(h+m)/(1<<21);while(f===0);return f},c.int32=u.next,c.quick=c,p&&(p.X&&i(p,u),c.state=function(){return i(u,{})}),c}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.xor4096=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),uI=bt((e,t)=>{(function(n,a,r){function s(l){var d=this,u="";d.next=function(){var c=d.b,h=d.c,m=d.d,f=d.a;return c=c<<25^c>>>7^h,h=h-m|0,m=m<<24^m>>>8^f,f=f-c|0,d.b=c=c<<20^c>>>12^h,d.c=h=h-m|0,d.d=m<<16^h>>>16^f,d.a=f-c|0},d.a=0,d.b=0,d.c=2654435769|0,d.d=1367130551,l===Math.floor(l)?(d.a=l/4294967296|0,d.b=l|0):u+=l;for(var p=0;p>>0)/4294967296};return c.double=function(){do var h=u.next()>>>11,m=(u.next()>>>0)/4294967296,f=(h+m)/(1<<21);while(f===0);return f},c.int32=u.next,c.quick=c,p&&(typeof p=="object"&&i(p,u),c.state=function(){return i(u,{})}),c}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.tychei=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),dI=bt((e,t)=>{(function(n,a,r){var s=256,i=6,o=52,l="random",d=r.pow(s,i),u=r.pow(2,o),p=u*2,c=s-1,h;function m(b,v,N){var T=[];v=v==!0?{entropy:!0}:v||{};var R=g(y(v.entropy?[b,w(a)]:b==null?x():b,3),T),$=new f(T),z=function(){for(var P=$.g(i),V=d,j=0;P=p;)P/=2,V/=2,j>>>=1;return(P+j)/V};return z.int32=function(){return $.g(4)|0},z.quick=function(){return $.g(4)/4294967296},z.double=z,g(w($.S),a),(v.pass||N||function(P,V,j,U){return U&&(U.S&&A(U,$),P.state=function(){return A($,{})}),j?(r[l]=P,V):P})(z,R,"global"in v?v.global:this==r,v.state)}function f(b){var v,N=b.length,T=this,R=0,$=T.i=T.j=0,z=T.S=[];for(N||(b=[N++]);R{var n=rI(),a=sI(),r=iI(),s=oI(),i=lI(),o=uI(),l=dI();l.alea=n,l.xor128=a,l.xorwow=r,l.xorshift7=s,l.xor4096=i,l.tychei=o,t.exports=l}),pI=bt(()=>{}),dm={};Fe(dm,{bin:()=>Jg,browser:()=>r5,default:()=>cI,dependencies:()=>a5,description:()=>Ug,devDependencies:()=>t5,jsdelivr:()=>Xg,license:()=>e5,main:()=>Gg,miniprogram:()=>Yg,module:()=>qg,name:()=>Vg,private:()=>Hg,repository:()=>Qg,scripts:()=>n5,types:()=>Zg,unpkg:()=>Kg,version:()=>jg});var Vg="@tensorflow/tfjs",jg="3.6.0",Ug="An open-source machine learning framework.",Hg=!1,Gg="dist/tf.node.js",qg="dist/index.js",Xg="dist/tf.min.js",Kg="dist/tf.min.js",Zg="dist/index.d.ts",Yg="dist/miniprogram",Jg={"tfjs-custom-module":"dist/tools/custom_module/cli.js"},Qg={type:"git",url:"https://github.com/tensorflow/tfjs.git"},e5="Apache-2.0",t5={"@babel/core":"^7.9.0","@babel/polyfill":"^7.10.4","@babel/preset-env":"^7.9.5","@rollup/plugin-commonjs":"^11.0.2","@rollup/plugin-node-resolve":"^7.1.1","@rollup/plugin-typescript":"^3.0.0","@types/argparse":"^1.0.38","@types/jasmine":"2.8.7","@types/node":"~10.17.50","@types/shelljs":"^0.8.4","@types/yargs":"^15.0.7","clang-format":"~1.2.2",commander:"~2.14.1",jasmine:"3.1.0","jasmine-core":"~3.1.0",karma:"~6.3.2","karma-browserstack-launcher":"~1.6.0","karma-chrome-launcher":"~2.2.0","karma-firefox-launcher":"~1.1.0","karma-jasmine":"~1.1.1","karma-typescript":"~5.5.1","karma-typescript-es6-transform":"^5.5.1","npm-run-all":"~4.1.3",rimraf:"~2.6.2",rollup:"~2.3.2","rollup-plugin-babel":"^4.4.0","rollup-plugin-terser":"~7.0.2","rollup-plugin-visualizer":"~4.2.2",shelljs:"~0.8.1","ts-node":"~8.8.2",tslint:"~5.11.0","tslint-no-circular-imports":"~0.5.0",typescript:"3.5.3",yalc:"1.0.0-pre.50"},n5={build:"tsc && yarn build-cli && yarn bundle","build-ci":"tsc && yarn build-cli && yarn bundle-ci",bundle:"rollup -c","bundle-ci":"rollup -c --ci","build-core":"cd ../tfjs-core && yarn && yarn build","build-core-ci":"cd ../tfjs-core && yarn && yarn build-ci","build-layers":"cd ../tfjs-layers && yarn && yarn build","build-layers-ci":"cd ../tfjs-layers && yarn && yarn build-ci","build-converter":"cd ../tfjs-converter && yarn && yarn build","build-converter-ci":"cd ../tfjs-converter && yarn && yarn build-ci","build-data":"cd ../tfjs-data && yarn && yarn build","build-data-ci":"cd ../tfjs-data && yarn && yarn build-ci","build-backend-cpu":"cd ../tfjs-backend-cpu && yarn && yarn build","build-backend-cpu-ci":"cd ../tfjs-backend-cpu && yarn && yarn build-ci","build-backend-webgl":"cd ../tfjs-backend-webgl && yarn && yarn build","build-backend-webgl-ci":"cd ../tfjs-backend-webgl && yarn && yarn build-ci","build-deps":"yarn build-core && yarn build-layers && yarn build-converter && yarn build-data && yarn build-backend-cpu && yarn build-backend-webgl","build-deps-ci":"yarn build-core-ci && yarn build-layers-ci && yarn build-converter-ci && yarn build-data-ci && yarn build-backend-cpu-ci && yarn build-backend-webgl-ci","build-cli":"tsc --project ./tools/custom_module/tsconfig.json && chmod +x ./dist/tools/custom_module/cli.js","run-custom-build":"ts-node -s ./tools/custom_module/cli.ts","build-npm":"./scripts/build-npm.sh","link-local":"yalc link","publish-local":"yarn build-npm && yalc push","publish-npm":"npm publish",lint:"tslint -p . -t verbose",coverage:"KARMA_COVERAGE=1 karma start --browsers='Chrome' --singleRun",test:"yarn && yarn build-deps && yarn build && karma start","test-dev":"karma start","test-tools":"ts-node --project ./tools/custom_module/tsconfig.json run_tools_tests.ts","test-ci":"./scripts/test-ci.sh"},a5={"@tensorflow/tfjs-backend-cpu":"3.6.0","@tensorflow/tfjs-backend-webgl":"3.6.0","@tensorflow/tfjs-converter":"3.6.0","@tensorflow/tfjs-core":"3.6.0","@tensorflow/tfjs-data":"3.6.0","@tensorflow/tfjs-layers":"3.6.0",argparse:"^1.0.10",chalk:"^4.1.0","core-js":"3","regenerator-runtime":"^0.13.5",yargs:"^16.0.3"},r5={"node-fetch":!1,util:!1,crypto:!1},cI={name:Vg,version:jg,description:Ug,private:Hg,main:Gg,module:qg,jsdelivr:Xg,unpkg:Kg,types:Zg,miniprogram:Yg,bin:Jg,repository:Qg,license:e5,devDependencies:t5,scripts:n5,dependencies:a5,browser:r5},pm={};Fe(pm,{browser:()=>w5,default:()=>hI,dependencies:()=>v5,description:()=>o5,devDependencies:()=>x5,engines:()=>A5,jsdelivr:()=>d5,"jsnext:main":()=>h5,license:()=>g5,main:()=>u5,miniprogram:()=>m5,module:()=>f5,name:()=>s5,private:()=>l5,repository:()=>y5,scripts:()=>b5,sideEffects:()=>k5,types:()=>c5,unpkg:()=>p5,version:()=>i5});var s5="@tensorflow/tfjs-core",i5="3.6.0",o5="Hardware-accelerated JavaScript library for machine intelligence",l5=!1,u5="dist/tf-core.node.js",d5="dist/tf-core.min.js",p5="dist/tf-core.min.js",c5="dist/index.d.ts",h5="dist/index.js",f5="dist/index.js",m5="dist/miniprogram",A5={yarn:">= 1.3.2"},y5={type:"git",url:"https://github.com/tensorflow/tfjs-core.git"},g5="Apache-2.0",x5={"@bazel/bazelisk":"^1.3.0","@bazel/typescript":"^0.27.8","@rollup/plugin-commonjs":"^11.0.2","@rollup/plugin-node-resolve":"^7.1.1","@rollup/plugin-typescript":"^3.0.0","@tensorflow/tfjs-backend-cpu":"link:../tfjs-backend-cpu","@types/jasmine":"~3.0.0","@types/node":"~9.6.0","@types/node-fetch":"~2.1.2","clang-format":"~1.2.4",jasmine:"~3.1.0","jasmine-core":"~3.1.0",karma:"6.3.2","karma-browserstack-launcher":"~1.6.0","karma-chrome-launcher":"~3.1.0","karma-jasmine":"~4.0.1","karma-typescript":"~5.5.1","npm-run-all":"~4.1.3",rimraf:"~2.6.2",rollup:"~2.3.2","rollup-plugin-terser":"~5.3.0","rollup-plugin-visualizer":"~3.3.2",shelljs:"~0.8.3","ts-node":"~8.8.2",tslint:"~5.11.0","tslint-no-circular-imports":"~0.5.0",typescript:"3.5.3",yalc:"~1.0.0-pre.21",yargs:"~13.2.2"},b5={"build-ci":"./scripts/enumerate-tests.js --ci && tsc && yarn bundle-ci && yarn build-test-snippets",build:"node ./scripts/enumerate-tests.js && tsc && yarn bundle",bundle:"rollup -c","bundle-ci":"rollup -c --ci","build-npm":"./scripts/build-npm.sh","build-deps":"yarn build && yarn build-cpu-backend","build-cpu-backend":"cd ../tfjs-backend-cpu && yarn && yarn build","build-cpu-backend-ci":"cd ../tfjs-backend-cpu && yarn && yarn build-ci","build:bazel":"bazelisk build //...","build-test-snippets":"yarn tsc --project ./scripts/test_snippets/tsconfig.json","format-all":"clang-format -i -style=Google --glob=src/**/*.ts","link-local":"yalc link","publish-local":"rimraf dist/ && yarn build && rollup -c && yalc push","publish-npm":"npm publish",lint:"tslint -p . -t verbose",coverage:"KARMA_COVERAGE=1 karma start --browsers='Chrome' --singleRun",test:"yarn && yarn build-deps && karma start","test-dev":"karma start","test-ci":"./scripts/test-ci.sh","test-webworker":"karma start --worker","run-browserstack":"karma start --browserstack","test-bundle-size":"./scripts/test-bundle-size.js","test-node":"rimraf dist/ && yarn build-deps && yarn build && ts-node --transpile-only --skip-ignore -P tsconfig.test.json dist/test_node.js","test-node-dev":"tsc && ts-node --transpile-only --skip-ignore -P tsconfig.test.json dist/test_node.js","test-node-ci":"ts-node --transpile-only -P tsconfig.test.json dist/test_node.js","test-async-backends":"rimraf dist/ && yarn build && ts-node --transpile-only -P tsconfig.test.json dist/test_async_backends.js","test-async-backends-ci":"ts-node --transpile-only -P tsconfig.test.json dist/test_async_backends.js","test-snippets":"yarn build && yarn build-cpu-backend && ts-node -P tsconfig.test.json ./scripts/test_snippets/test_snippets.ts","test-snippets-ci":"ts-node -P tsconfig.test.json ./scripts/test_snippets/test_snippets.ts"},v5={"@types/offscreencanvas":"~2019.3.0","@types/seedrandom":"2.4.27","@types/webgl-ext":"0.0.30","node-fetch":"~2.6.1",seedrandom:"2.4.3"},w5={"node-fetch":!1,util:!1,crypto:!1,worker_threads:!1},k5=["./dist/index.js","./dist/engine.js","./dist/tensor.js","./dist/base_side_effects.js","./dist/flags.js","./dist/platforms/*.js","./dist/register_all_gradients.js","./dist/public/chained_ops/*.js","./dist/io/*.js"],hI={name:s5,version:i5,description:o5,private:l5,main:u5,jsdelivr:d5,unpkg:p5,types:c5,"jsnext:main":h5,module:f5,miniprogram:m5,engines:A5,repository:y5,license:g5,devDependencies:x5,scripts:b5,dependencies:v5,browser:w5,sideEffects:k5},cm={};Fe(cm,{browser:()=>W5,default:()=>fI,dependencies:()=>L5,description:()=>N5,devDependencies:()=>z5,jsdelivr:()=>C5,"jsnext:main":()=>F5,license:()=>O5,main:()=>E5,miniprogram:()=>D5,module:()=>$5,name:()=>I5,peerDependencies:()=>P5,private:()=>T5,scripts:()=>_5,types:()=>M5,unpkg:()=>R5,version:()=>S5});var I5="@tensorflow/tfjs-data",S5="3.6.0",N5="TensorFlow Data API in JavaScript",T5=!1,E5="dist/tf-data.node.js",C5="dist/tf-data.min.js",R5="dist/tf-data.min.js",M5="dist/index.d.ts",F5="dist/index.js",$5="dist/index.js",D5="dist/miniprogram",O5="Apache-2.0",z5={"@rollup/plugin-commonjs":"^11.0.2","@rollup/plugin-node-resolve":"^7.1.1","@rollup/plugin-typescript":"^3.0.0","@tensorflow/tfjs-backend-cpu":"3.6.0","@tensorflow/tfjs-core":"3.6.0","@tensorflow/tfjs-layers":"3.6.0","@types/jasmine":"~2.5.53","@types/seedrandom":"^2.4.27","@types/utf8":"~2.1.6","clang-format":"~1.2.2","http-server":"~0.12.3",jasmine:"3.1.0","jasmine-core":"~3.1.0",karma:"~6.3.1","karma-chrome-launcher":"~2.2.0","karma-firefox-launcher":"~1.1.0","karma-jasmine":"~1.1.1","karma-typescript":"~5.5.1","karma-typescript-es6-transform":"^5.0.2",nyc:"^15.1.0",rimraf:"~2.6.2",rollup:"~2.3.2","rollup-plugin-terser":"~7.0.2","rollup-plugin-visualizer":"~3.3.2","ts-node":"~7.0.0",tslint:"~6.1.3","tslint-no-circular-imports":"^0.7.0",typescript:"3.5.3",yalc:"^1.0.0-pre.50"},_5={build:"tsc && yarn bundle","build-ci":"tsc && yarn bundle-ci",bundle:"rollup -c","bundle-ci":"rollup -c --ci","build-core":"cd ../tfjs-core && yarn && yarn build","build-core-ci":"cd ../tfjs-core && yarn && yarn build-ci","build-layers":"cd ../tfjs-layers && yarn && yarn build","build-backend-cpu":"cd ../tfjs-backend-cpu && yarn && yarn build","build-backend-cpu-ci":"cd ../tfjs-backend-cpu && yarn && yarn build-ci","build-layers-ci":"cd ../tfjs-layers && yarn && yarn build-ci","build-deps":"yarn build-core && yarn build-layers && yarn build-backend-cpu","build-deps-ci":"yarn build-core-ci && yarn build-layers-ci && yarn build-backend-cpu-ci","build-npm":"./scripts/build-npm.sh","link-local":"yalc link","publish-local":"rimraf dist/ && yarn build-npm && yalc push","publish-npm":"npm publish",test:"yarn && yarn build-deps && yarn build && ts-node --transpile-only --project tsconfig.test.json src/test_node.ts","test-dev":"tsc && ts-node --transpile-only --project tsconfig.test.json src/test_node.ts","test-browsers":"karma start --browsers='Chrome,Firefox'","test-ci":"ts-node --transpile-only --skip-ignore -P tsconfig.test.json src/test_node.ts","test-snippets":"yarn && yarn build-deps && yarn build && ts-node --skip-ignore --project tsconfig.test.json ./scripts/test_snippets.ts","test-snippets-ci":"ts-node --skip-ignore --project tsconfig.test.json ./scripts/test_snippets.ts",coverage:"yarn nyc yarn ts-node --transpile-only -P tsconfig.test.json src/test_node.ts",lint:"tslint -p . -t verbose"},P5={"@tensorflow/tfjs-core":"3.6.0",seedrandom:"~2.4.3"},L5={"@types/node-fetch":"^2.1.2","node-fetch":"~2.6.1"},W5={fs:!1,"node-fetch":!1,string_decoder:!1,crypto:!1},fI={name:I5,version:S5,description:N5,private:T5,main:E5,jsdelivr:C5,unpkg:R5,types:M5,"jsnext:main":F5,module:$5,miniprogram:D5,license:O5,devDependencies:z5,scripts:_5,peerDependencies:P5,dependencies:L5,browser:W5},hm={};Fe(hm,{default:()=>mI,description:()=>j5,devDependencies:()=>Q5,jsdelivr:()=>Z5,"jsnext:main":()=>X5,license:()=>U5,main:()=>G5,miniprogram:()=>J5,module:()=>K5,name:()=>B5,peerDependencies:()=>tx,private:()=>H5,scripts:()=>ex,types:()=>q5,unpkg:()=>Y5,version:()=>V5});var B5="@tensorflow/tfjs-layers",V5="3.6.0",j5="TensorFlow layers API in JavaScript",U5="Apache-2.0 AND MIT",H5=!1,G5="dist/tf-layers.node.js",q5="dist/index.d.ts",X5="dist/index.js",K5="dist/index.js",Z5="dist/tf-layers.min.js",Y5="dist/tf-layers.min.js",J5="dist/miniprogram",Q5={"@babel/polyfill":"^7.8.7","@rollup/plugin-commonjs":"^11.0.2","@rollup/plugin-node-resolve":"^7.1.1","@rollup/plugin-typescript":"^3.0.0","@tensorflow/tfjs-backend-cpu":"3.6.0","@tensorflow/tfjs-backend-webgl":"3.6.0","@tensorflow/tfjs-core":"3.6.0","@types/jasmine":"~2.5.53","clang-format":"~1.2.2","http-server":"~0.12.3",jasmine:"~3.1.0","jasmine-core":"~3.1.0",karma:"~6.3.1","karma-browserstack-launcher":"~1.6.0","karma-chrome-launcher":"~2.2.0","karma-firefox-launcher":"~1.1.0","karma-jasmine":"~1.1.1","karma-typescript":"~5.5.1","karma-typescript-es6-transform":"^5.0.2",rimraf:"~2.6.2",rollup:"~2.3.2","rollup-plugin-terser":"~7.0.2","rollup-plugin-visualizer":"~3.3.2","ts-node":"~8.8.2",tslint:"~6.1.3","tslint-no-circular-imports":"^0.7.0",typescript:"3.5.3",yalc:"~1.0.0-pre.50"},ex={prep:"yarn install && yarn build-ci",build:"tsc && yarn bundle","build-ci":"tsc && yarn bundle-ci",bundle:"rollup -c","bundle-ci":"rollup -c --ci","build-core":"cd ../tfjs-core && yarn && yarn build","build-backend-cpu":"cd ../tfjs-backend-cpu && yarn && yarn build","build-backend-cpu-ci":"cd ../tfjs-backend-cpu && yarn && yarn build-ci","build-backend-webgl":"cd ../tfjs-backend-webgl && yarn && yarn build","build-backend-webgl-ci":"cd ../tfjs-backend-webgl && yarn && yarn build-ci","build-core-ci":"cd ../tfjs-core && yarn && yarn build-ci","build-deps":"yarn build-core && yarn build-backend-cpu && yarn build-backend-webgl","build-deps-ci":"yarn build-core-ci && yarn build-backend-cpu-ci && yarn build-backend-webgl-ci","build-npm":"./scripts/build-npm.sh",format:"./tools/clang_format_ts.sh","link-local":"yalc link","publish-local":"yarn build-npm && yalc push","publish-npm":"npm publish",coverage:"KARMA_COVERAGE=1 karma start --browsers='Chrome' --singleRun",test:"yarn && yarn build-deps && karma start","test-dev":"karma start","test-ci":"./scripts/test-ci.sh","test-snippets":"yarn && yarn build-deps && yarn build && ts-node --skip-ignore -s ./scripts/test_snippets.ts","test-snippets-ci":"ts-node --skip-ignore -s ./scripts/test_snippets.ts","run-browserstack":"karma start --browsers='bs_chrome_mac' --singleRun --reporters='dots,karma-typescript'",lint:"tslint -p . -t verbose"},tx={"@tensorflow/tfjs-core":"3.6.0"},mI={name:B5,version:V5,description:j5,license:U5,private:H5,main:G5,types:q5,"jsnext:main":X5,module:K5,jsdelivr:Z5,unpkg:Y5,miniprogram:J5,devDependencies:Q5,scripts:ex,peerDependencies:tx},fm={};Fe(fm,{default:()=>AI,description:()=>rx,devDependencies:()=>mx,jsdelivr:()=>dx,"jsnext:main":()=>ix,license:()=>hx,main:()=>sx,miniprogram:()=>px,module:()=>ox,name:()=>nx,peerDependencies:()=>fx,repository:()=>cx,scripts:()=>Ax,types:()=>lx,unpkg:()=>ux,version:()=>ax});var nx="@tensorflow/tfjs-converter",ax="3.6.0",rx="Tensorflow model converter for javascript",sx="dist/tf-converter.node.js",ix="dist/index.js",ox="dist/index.js",lx="dist/index.d.ts",ux="dist/tf-converter.min.js",dx="dist/tf-converter.min.js",px="dist/miniprogram",cx={type:"git",url:"https://github.com/tensorflow/tfjs-converter.git"},hx="Apache-2.0",fx={"@tensorflow/tfjs-core":"3.6.0"},mx={"@rollup/plugin-commonjs":"^11.0.2","@rollup/plugin-node-resolve":"^7.1.1","@rollup/plugin-replace":"^2.3.3","@rollup/plugin-typescript":"^3.0.0","@tensorflow/tfjs-backend-cpu":"3.6.0","@tensorflow/tfjs-core":"3.6.0","@types/argparse":"^1.0.38","@types/deep-equal":"^1.0.1","@types/jasmine":"~2.8.6","@types/long":"~3.0.32","@types/node-fetch":"1.6.9",ajv:"~6.3.0",argparse:"^1.0.10","babel-core":"~6.26.3","babel-plugin-external-helpers":"~6.22.0","babel-preset-env":"~1.7.0","clang-format":"~1.2.2",copyfiles:"~1.2.0","deep-equal":"^1.0.1","jasmine-core":"~3.5.0","node-fetch":"~2.6.1",opn:"~5.1.0",protobufjs:"~6.8.6",rimraf:"~2.6.2",rollup:"~2.3.2","rollup-plugin-terser":"~7.0.2","rollup-plugin-visualizer":"~3.3.2","ts-morph":"^7.1.3","ts-node":"~8.8.2",tslint:"~6.1.3","tslint-no-circular-imports":"~0.7.0",typescript:"3.5.3",yalc:"~1.0.0-pre.50"},Ax={build:"yarn gen-json --test && yarn gen-kernel2ops && tsc && yarn bundle","build-ci":"yarn gen-json --test && yarn gen-kernel2ops && tsc && yarn bundle-ci",bundle:"rollup -c","bundle-ci":"rollup -c --ci","build-core":"cd ../tfjs-core && yarn && yarn build","build-backend-cpu":"cd ../tfjs-backend-cpu && yarn && yarn build","build-backend-cpu-ci":"cd ../tfjs-backend-cpu && yarn && yarn build-ci","build-core-ci":"cd ../tfjs-core && yarn && yarn build-ci","build-deps":"yarn build-core && yarn build-backend-cpu","build-deps-ci":"yarn build-core-ci && yarn build-backend-cpu","build-npm":"./scripts/build-npm.sh","link-local":"yalc link","publish-local":"yarn build-npm && yalc push","publish-npm":"npm publish",test:"yarn && yarn build-deps && yarn build && yarn gen-json --test && yarn gen-kernel2ops && ts-node --transpile-only -P tsconfig.test.json src/run_tests.ts","test-ci":"ts-node --transpile-only --skip-ignore -P tsconfig.test.json src/run_tests.ts","test-dev":"tsc && ts-node --transpile-only -P tsconfig.test.json src/run_tests.ts","test-snippets":"yarn && yarn build-deps && yarn build && ts-node --skip-ignore -s ./scripts/test_snippets.ts","test-snippets-ci":"ts-node --skip-ignore -s ./scripts/test_snippets.ts",lint:"tslint -p . -t verbose","make-version":"sh -c ./scripts/make-version","gen-doc":"ts-node -s ./scripts/gen_doc.ts","gen-json":"ts-node -s ./scripts/gen_json.ts","model-summary":"ts-node -s ./tools/model_summary.ts",pb2json:"ts-node -s ./tools/pb2json_converter.ts","build-pip-package":"yarn gen-json --test && cd python && ./build-pip-package.sh --test /tmp/tfjs-pips","run-python-tests":"yarn gen-json --test && cd python && ./run-python-tests.sh","gen-kernel2ops":"ts-node -s scripts/kernels_to_ops.ts --out metadata/kernel2op.json"},AI={name:nx,version:ax,description:rx,main:sx,"jsnext:main":ix,module:ox,types:lx,unpkg:ux,jsdelivr:dx,miniprogram:px,repository:cx,license:hx,peerDependencies:fx,devDependencies:mx,scripts:Ax},yI=1e-7,gI=1e-4,Ip=class{constructor(e,t){this.backend=e,this.dataMover=t,this.data=new WeakMap,this.dataIdsCount=0}get(e){return this.data.has(e)||this.dataMover.moveData(this.backend,e),this.data.get(e)}set(e,t){this.dataIdsCount++,this.data.set(e,t)}has(e){return this.data.has(e)}delete(e){return this.dataIdsCount--,this.data.delete(e)}numDataIds(){return this.dataIdsCount}},hu=class{refCount(e){return ra("refCount")}incRef(e){return ra("incRef")}timerAvailable(){return!0}time(e){return ra("time")}read(e){return ra("read")}readSync(e){return ra("readSync")}numDataIds(){return ra("numDataIds")}disposeData(e,t){return ra("disposeData")}write(e,t,n){return ra("write")}move(e,t,n,a,r){return ra("move")}memory(){return ra("memory")}floatPrecision(){return ra("floatPrecision")}epsilon(){return this.floatPrecision()===32?yI:gI}dispose(){return ra("dispose")}};function ra(e){throw new Error(`'${e}' not yet implemented or not found in the registry. This kernel may not be supported by the tfjs backend you have chosen`)}function yx(e){let t=e.length,n=0,a=0;for(;t>0;)a=Math.random()*t|0,t--,n=e[t],e[t]=e[a],e[a]=n}function xI(e,t){if(e.length!==t.length)throw new Error(`Array sizes must match to be shuffled together First array length was ${e.length}Second array length was ${t.length}`);let n=e.length,a,r,s=0;for(;n>0;)s=Math.random()*n|0,n--,a=e[n],r=t[n],e[n]=e[s],t[n]=t[s],e[s]=a,t[s]=r}function fu(e,t,n){return Math.max(e,Math.min(t,n))}function bI(e){return e%2==0?e:e+1}function vI(e){let t=0;for(let n=0;nn+` Shapes ${e} and ${t} must match`)}function ss(e){F(e!=null,()=>"The input to the tensor constructor must be a non-null value.")}function is(e,t=[],n=!1){if(t==null&&(t=[]),Array.isArray(e)||nn(e)&&!n)for(let a=0;a0,n){return new Promise((a,r)=>{let s=0,i=()=>{if(e()){a();return}s++;let o=t(s);if(n!=null&&s>=n){r();return}setTimeout(i,o)};i()})}function CI(e,t){let n=1,a=-1;for(let s=0;s=0)n*=e[s];else if(e[s]===-1){if(a!==-1)throw Error(`Shapes can only have 1 implicit size. Found -1 at dim ${a} and dim ${s}`);a=s}else if(e[s]<0)throw Error(`Shapes can not be < 0. Found ${e[s]} at dim ${s}`);if(a===-1){if(t>0&&t!==n)throw Error(`Size(${t}) must match the product of shape ${e}`);return e}if(n===0)throw Error(`Cannot infer the missing size in [${e}] when there are 0 elements`);if(t%n!=0)throw Error(`The implicit shape can't be a fractional number. Got ${t} / ${n}`);let r=e.slice();return r[a]=t/n,r}function sa(e,t){let n=t.length;return e=e==null?t.map((a,r)=>r):[].concat(e),F(e.every(a=>a>=-n&&a`All values in axis param must be in range [-${n}, ${n}) but got axis ${e}`),F(e.every(a=>jt(a)),()=>`All values in axis param must be integers but got axis ${e}`),e.map(a=>a<0?n+a:a)}function gx(e,t){let n=[],a=[],r=t!=null&&Array.isArray(t)&&t.length===0,s=t==null||r?null:sa(t,e).sort(),i=0;for(let o=0;oo)&&e[o]===1&&(n.push(e[o]),a.push(o)),s[i]<=o&&i++}e[o]!==1&&(n.push(e[o]),a.push(o))}return{newShape:n,keptDims:a}}function xx(e,t){let n=null;if(e==null||e==="float32")n=new Float32Array(t);else if(e==="int32")n=new Int32Array(t);else if(e==="bool")n=new Uint8Array(t);else throw new Error(`Unknown data type ${e}`);return n}function bx(e,t){let n=null;if(e==null||e==="float32")n=new Float32Array(t);else if(e==="int32")n=new Int32Array(t);else if(e==="bool")n=new Uint8Array(t);else if(e==="string")n=new Array(t);else throw new Error(`Unknown data type ${e}`);return n}function vx(e,t){for(let n=0;nt+=n.length),t}function vr(e){return typeof e=="string"||e instanceof String}function Ix(e){return typeof e=="boolean"}function Sx(e){return typeof e=="number"}function Sp(e){return Array.isArray(e)?Sp(e[0]):e instanceof Float32Array?"float32":e instanceof Int32Array||e instanceof Uint8Array?"int32":Sx(e)?"float32":vr(e)?"string":Ix(e)?"bool":"float32"}function wr(e){return!!(e&&e.constructor&&e.call&&e.apply)}function Np(e,t){for(let n=t;n=0;--a)n[a]=n[a+1]*e[a+1];return n}function Nx(e,t,n,a=!1){let r=new Array;if(t.length===1){let s=t[0]*(a?2:1);for(let i=0;il*d)*(a?2:1);for(let l=0;lr*s)*(n?2:1);if(a===0)return[];if(a!==t.length)throw new Error(`[${e}] does not match the input size ${t.length}${n?" for a complex tensor":""}.`);return Nx(0,e,t,n)}function Am(e,t){let n=Tp(e,t);for(let a=0;aa*r,1);if(t==null||t==="float32")return Qi(e,new Float32Array(n));if(t==="int32")return Qi(e,new Int32Array(n));if(t==="bool")return Qi(e,new Uint8Array(n));throw new Error(`Unknown data type ${t}`)}function ym(e){e.forEach(t=>{F(Number.isInteger(t)&&t>=0,()=>`Tensor must have a shape comprised of positive integers but got shape [${e}].`)})}function FI(e,t,n){if(t===0)return 0;if(t===1)return e[0];let a=e[e.length-1];for(let r=0;r{let[n,a]=t.split(":");this.urlFlags[n]=OI(n,a)})}};function DI(e){let t={};return e.replace(/[?&]([^=?&]+)(?:=([^&]*))?/g,(n,...a)=>(zI(t,a[0],a[1]),a.join("="))),t}function zI(e,t,n){e[decodeURIComponent(t)]=decodeURIComponent(n||"")}function OI(e,t){if(t=t.toLowerCase(),t==="true"||t==="false")return t==="true";if(`${+t}`===t)return+t;throw new Error(`Could not parse value flag value ${t} for flag ${e}.`)}function J(){return ma}var ma=null;function _I(e){ma=e}var xm;function Cx(){if(xm==null){let e;if(typeof window!="undefined")e=window;else if(typeof global!="undefined")e=global;else if(typeof process!="undefined")e=process;else if(typeof self!="undefined")e=self;else throw new Error("Could not find a global object");xm=e}return xm}function PI(){let e=Cx();return e._tfGlobals==null&&(e._tfGlobals=new Map),e._tfGlobals}function bm(e,t){let n=PI();if(n.has(e))return n.get(e);{let a=t();return n.set(e,a),n.get(e)}}var eo="Abs",to="Acos",no="Acosh",kr="Add",os="AddN",ao="All",ro="Any",ls="ArgMax",Au="ArgMin",so="Asin",io="Asinh",oo="Atan",lo="Atanh",uo="Atan2",us="AvgPool",Ep="AvgPoolGrad",yu="AvgPool3D",Cp="AvgPool3DGrad",ds="BatchMatMul",gu="BatchToSpaceND",Rp="Bincount",Rx="BroadcastTo",ps="Cast",cs="Ceil",Ir="ClipByValue",Mp="Complex",xu="ComplexAbs",po="Concat",hs="Conv2D",Fp="Conv2DBackpropFilter",fs="Conv2DBackpropInput",bu="Conv3D",$p="Conv3DBackpropFilterV2",Dp="Conv3DBackpropInputV2",ms="Cos",co="Cosh",As="Cumsum",ho="CropAndResize",Op="DenseBincount",fo="DepthToSpace",ys="DepthwiseConv2dNative",zp="DepthwiseConv2dNativeBackpropFilter",_p="DepthwiseConv2dNativeBackpropInput",Pp="Diag",vu="Dilation2D",Lp="Dilation2DBackpropInput",Wp="Dilation2DBackpropFilter",gs="RealDiv",Bp="Einsum",mo="Elu",Vp="EluGrad",Ao="Erf",yo="Equal",xs="Exp",go="ExpandDims",xo="Expm1",jp="FFT",wu="Fill",bo="FlipLeftRight",bs="Floor",vs="FloorDiv",ws="FusedBatchNorm",vo="GatherV2",wo="GatherNd",ko="Greater",ks="GreaterEqual",Is="Identity",Up="IFFT",Hp="Imag",Io="IsFinite",So="IsInf",No="IsNan",Ss="LeakyRelu",To="Less",Eo="LessEqual",Gp="LinSpace",Ns="Log",Co="Log1p",Ro="LogicalAnd",ku="LogicalNot",Iu="LogicalOr",Mx="LogSoftmax",Su="LRN",qp="LRNGrad",Ts="Max",Es="Maximum",Cs="MaxPool",Xp="MaxPoolGrad",Nu="MaxPool3D",Kp="MaxPool3DGrad",Zp="MaxPoolWithArgmax",Rs="Mean",Ms="Min",Fs="Minimum",$s="MirrorPad",Mo="Mod",Yp="Multinomial",Ds="Multiply",Fo="Neg",$o="NotEqual",Do="NonMaxSuppressionV3",Oo="NonMaxSuppressionV4",zo="NonMaxSuppressionV5",_o="OnesLike",Os="OneHot",Po="Pack",zs="PadV2",LI="Pool",_s="Pow",Ps="Prelu",Lo="Prod",Tu="Range",Jp="Real",Wo="Reciprocal",Ls="Relu",Bo="Reshape",Eu="ResizeNearestNeighbor",Qp="ResizeNearestNeighborGrad",Ws="ResizeBilinear",ec="ResizeBilinearGrad",Bs="Relu6",Vs="Reverse",js="Round",Us="Rsqrt",Vo="ScatterNd",jo="Select",Uo="Selu",Ho="Slice",Hs="Sin",Go="Sinh",qo="Sign",Gs="Sigmoid",Xo="Softplus",qs="Sqrt",Xs="Sum",Cu="SpaceToBatchND",Ko="SplitV",Ks="Softmax",tc="SparseFillEmptyRows",nc="SparseReshape",ac="SparseToDense",Zs="SquaredDifference",Ru="Square",Zo="StridedSlice",Ys="Sub",Js="Tan",Qs="Tanh",Sr="Tile",Yo="TopK",Jo="Transform",ei="Transpose",rc="Unique",Qo="Unpack",Mu="UnsortedSegmentSum",el="ZerosLike",Nr="Step",sc="FromPixels",tl="RotateWithOffset",ti="_FusedMatMul",ni="FusedConv2D",ai="FusedDepthwiseConv2D",nl=bm("kernelRegistry",()=>new Map),Fu=bm("gradRegistry",()=>new Map);function ic(e,t){let n=vm(e,t);return nl.get(n)}function wm(e){return Fu.get(e)}function al(e){let t=nl.entries(),n=[];for(;;){let{done:a,value:r}=t.next();if(a)break;let[s,i]=r,[o]=s.split("_");o===e&&n.push(i)}return n}function ri(e){let{kernelName:t,backendName:n}=e,a=vm(t,n);nl.has(a)&&console.warn(`The kernel '${t}' for backend '${n}' is already registered`),nl.set(a,e)}function Fx(e){let{kernelName:t}=e;Fu.has(t)&&J().getBool("DEBUG")&&console.warn(`Overriding the gradient for '${t}'`),Fu.set(t,e)}function WI(e,t){let n=vm(e,t);if(!nl.has(n))throw new Error(`The kernel '${e}' for backend '${t}' is not registered`);nl.delete(n)}function BI(e){if(!Fu.has(e))throw new Error(`The gradient '${e}' for backend is not registered`);Fu.delete(e)}function VI(e,t){al(e).forEach(n=>{let a=Object.assign({},n,{backendName:t});ri(a)})}function vm(e,t){return`${t}_${e}`}var k={};Fe(k,{arraysEqual:()=>er,assert:()=>F,assertNonNegativeIntegerDimensions:()=>ym,assertNonNull:()=>ss,assertShapesMatch:()=>on,bytesFromStringArray:()=>kx,bytesPerElement:()=>mm,checkConversionForErrors:()=>vx,clamp:()=>fu,computeStrides:()=>Ji,createScalarValue:()=>jI,createShuffledIndices:()=>TI,decodeString:()=>lc,distSquared:()=>kI,encodeString:()=>Du,fetch:()=>UI,flatten:()=>is,getArrayFromDType:()=>bx,getTypedArrayFromDType:()=>xx,hasEncodingLoss:()=>RI,indexToLoc:()=>$I,inferDtype:()=>Sp,inferFromImplicitShape:()=>CI,isBoolean:()=>Ix,isFunction:()=>wr,isInt:()=>jt,isNumber:()=>Sx,isPromise:()=>gm,isScalarShape:()=>II,isString:()=>vr,isTypedArray:()=>nn,isValidDtype:()=>wx,locToIndex:()=>FI,makeOnesTypedArray:()=>Am,makeZerosNestedTypedArray:()=>MI,makeZerosTypedArray:()=>Tp,nearestDivisor:()=>Np,nearestLargerEven:()=>bI,now:()=>$u,parseAxisParam:()=>sa,randUniform:()=>wI,repeatedTry:()=>EI,rightPad:()=>mu,shuffle:()=>yx,shuffleCombo:()=>xI,sizeFromShape:()=>Tt,sizeToSquarishShape:()=>NI,squeezeShape:()=>gx,sum:()=>vI,tanh:()=>SI,toNestedArray:()=>Qi,toTypedArray:()=>oc});function jI(e,t){return t==="string"?Du(e):oc([e],t)}function HI(e,t){return e instanceof Float32Array&&t==="float32"||e instanceof Int32Array&&t==="int32"||e instanceof Uint8Array&&t==="bool"}function oc(e,t){if(t==="string")throw new Error("Cannot convert a string[] to a TypedArray");if(Array.isArray(e)&&(e=is(e)),J().getBool("DEBUG")&&vx(e,t),HI(e,t))return e;if(t==null||t==="float32"||t==="complex64")return new Float32Array(e);if(t==="int32")return new Int32Array(e);if(t==="bool"){let n=new Uint8Array(e.length);for(let a=0;a{a=n()},s,i=$u();if(this.backendTimer.timerAvailable())s=this.backendTimer.time(r);else{r();for(let o of a)o.dataSync();s=Promise.resolve({kernelMs:$u()-i})}if(J().getBool("CHECK_COMPUTATION_FOR_ERRORS"))for(let o=0;o{GI(d,l.dtype,e)})}return{kernelName:e,outputs:a,inputs:t,timeMs:s.then(o=>o.kernelMs),extraInfo:s.then(o=>o.getExtraProfileInfo!=null?o.getExtraProfileInfo():"")}}logKernelProfile(e){let{kernelName:t,outputs:n,timeMs:a,inputs:r,extraInfo:s}=e;n.forEach(i=>{Promise.all([i.data(),a,s]).then(o=>{this.logger.logKernelProfile(t,i,o[0],o[1],r,o[2])})})}};function GI(e,t,n){if(t!=="float32")return!1;for(let a=0;a0?m:""} `}}console.log(`%c${o} %c${i} %c${l}D ${u} %c${d} %c${p} %c${s}`,"font-weight:bold","color:red","color:blue","color: orange","color: green","color: steelblue")}};function KI(e,t,n){let a={},r={};for(let l=0;la[f.id]=!0),h=!0,r[d.id]=!0;break}if(h)break}}let s={};s[n.id]=!0;let i={};for(let l=e.length-1;l>=0;l--){let d=e[l],u=d.inputs;for(let p=0;p=0;r--){let s=t[r],i=[];if(s.outputs.forEach(l=>{let d=e[l.id];d!=null?i.push(d):i.push(null)}),s.gradient==null)throw new Error(`Cannot compute gradient: gradient function not found for ${s.kernelName}.`);let o=s.gradient(i);for(let l in s.inputs){if(!(l in o))throw new Error(`Cannot backprop through input ${l}. Available gradients found: ${Object.keys(o)}.`);let d=n(()=>o[l]());if(d.dtype!=="float32")throw new Error(`Error in gradient for op ${s.kernelName}. The gradient of input ${l} must have 'float32' dtype, but has '${d.dtype}'`);let u=s.inputs[l];if(!er(d.shape,u.shape))throw new Error(`Error in gradient for op ${s.kernelName}. The gradient of input '${l}' has shape '${d.shape}', which does not match the shape of the input '${u.shape}'`);if(e[u.id]==null)e[u.id]=d;else{let p=e[u.id];e[u.id]=a(p,d),p.dispose()}}}}var $x=20,Ou=3,km=7;function JI(e,t,n,a){let r=Ji(t),s=YI(e,t,n,r),i=t.length,o=uc(e,t,n,r,s),l=["Tensor"];return a&&(l.push(` dtype: ${n}`),l.push(` rank: ${i}`),l.push(` shape: [${t}]`),l.push(" values:")),l.push(o.map(d=>" "+d).join(` +var P9=Object.defineProperty;var Ma=(e,t)=>{for(var n in t)P9(e,n,{get:t[n],enumerable:!0})};var _g=(e,t,n)=>{if(!t.has(e))throw TypeError("Cannot "+n)};var na=(e,t,n)=>(_g(e,t,"read from private field"),n?n.call(e):t.get(e)),as=(e,t,n,a)=>(_g(e,t,"write to private field"),a?a.call(e,n):t.set(e,n),n);function Yt(e,t){let n=e.endsWith("/")?"":"/",r=t.startsWith(".")||t.startsWith("/")||t.startsWith("http:")||t.startsWith("https:")||t.startsWith("file:")?`${t}`:`${e}${n}${t}`;if(!r.toLocaleLowerCase().includes(".json"))throw new Error(`Human: ModelPath Error: ${r} Expecting JSON file`);return r}function he(...e){let t=new Date,n=`${t.getHours().toString().padStart(2,"0")}:${t.getMinutes().toString().padStart(2,"0")}:${t.getSeconds().toString().padStart(2,"0")}.${t.getMilliseconds().toString().padStart(3,"0")}`;e&&console.log(n,"Human:",...e)}var it=()=>typeof performance!="undefined"?performance.now():parseInt((Number(process.hrtime.bigint())/1e3/1e3).toString());function Hn(...e){let t=n=>n&&typeof n=="object";return e.reduce((n,a)=>(Object.keys(a||{}).forEach(r=>{let s=n[r],i=a[r];Array.isArray(s)&&Array.isArray(i)?n[r]=s.concat(...i):t(s)&&t(i)?n[r]=Hn(s,i):n[r]=i}),n),{})}function Pg(){let e,t;if(typeof navigator!="undefined"){let n=navigator.userAgent.match(/\(([^()]+)\)/g);if(n&&n[0]){let a=n[0].match(/\(([^()]+)\)/g);e=a?a[0].replace(/\(|\)/g,""):"",t=navigator.userAgent.replace(n[0],""),e[1]&&(t=t.replace(n[1],"")),t=t.replace(/ /g," ")}}else typeof process!="undefined"&&(e=`${process.platform} ${process.arch}`,t=`NodeJS ${process.version}`);return{platform:e,agent:t}}var pu={};Ma(pu,{Abs:()=>Qi,Acos:()=>eo,Acosh:()=>to,AdadeltaOptimizer:()=>Kc,AdagradOptimizer:()=>Zc,AdamOptimizer:()=>Yc,AdamaxOptimizer:()=>Jc,Add:()=>wr,AddN:()=>is,All:()=>no,Any:()=>ao,ArgMax:()=>os,ArgMin:()=>Au,Asin:()=>ro,Asinh:()=>so,Atan:()=>io,Atan2:()=>lo,Atanh:()=>oo,AvgPool:()=>ls,AvgPool3D:()=>yu,AvgPool3DGrad:()=>Cp,AvgPoolGrad:()=>Ep,BackendWasm:()=>d6,BatchMatMul:()=>us,BatchToSpaceND:()=>gu,Bincount:()=>Rp,BroadcastTo:()=>Rx,Callback:()=>n8,CallbackList:()=>Q6,Cast:()=>ds,Ceil:()=>ps,ClipByValue:()=>kr,Complex:()=>Mp,ComplexAbs:()=>xu,Concat:()=>uo,Conv2D:()=>cs,Conv2DBackpropFilter:()=>Fp,Conv2DBackpropInput:()=>hs,Conv3D:()=>bu,Conv3DBackpropFilterV2:()=>$p,Conv3DBackpropInputV2:()=>Dp,Cos:()=>fs,Cosh:()=>po,CropAndResize:()=>co,Cumsum:()=>ms,CustomCallback:()=>t4,DataStorage:()=>Ip,DenseBincount:()=>Op,DepthToSpace:()=>ho,DepthwiseConv2dNative:()=>As,DepthwiseConv2dNativeBackpropFilter:()=>zp,DepthwiseConv2dNativeBackpropInput:()=>_p,Diag:()=>Pp,Dilation2D:()=>vu,Dilation2DBackpropFilter:()=>Wp,Dilation2DBackpropInput:()=>Lp,ENV:()=>fa,EarlyStopping:()=>r8,Einsum:()=>Bp,Elu:()=>fo,EluGrad:()=>Vp,Environment:()=>Ex,Equal:()=>Ao,Erf:()=>mo,Exp:()=>gs,ExpandDims:()=>yo,Expm1:()=>go,FFT:()=>jp,Fill:()=>wu,FlipLeftRight:()=>xo,Floor:()=>xs,FloorDiv:()=>bs,FromPixels:()=>sc,FusedBatchNorm:()=>vs,FusedConv2D:()=>ti,FusedDepthwiseConv2D:()=>ni,GPGPUContext:()=>mh,GatherNd:()=>vo,GatherV2:()=>bo,GraphModel:()=>D8,Greater:()=>wo,GreaterEqual:()=>ws,History:()=>e4,IFFT:()=>Up,Identity:()=>ks,Imag:()=>Hp,InputSpec:()=>Mt,IsFinite:()=>ko,IsInf:()=>Io,IsNan:()=>So,KernelBackend:()=>hu,LRN:()=>Su,LRNGrad:()=>qp,LayerVariable:()=>X6,LayersModel:()=>dr,LeakyRelu:()=>Is,Less:()=>No,LessEqual:()=>To,LinSpace:()=>Gp,Log:()=>Ss,Log1p:()=>Eo,LogSoftmax:()=>Mx,LogicalAnd:()=>Co,LogicalNot:()=>ku,LogicalOr:()=>Iu,MathBackendCPU:()=>nh,MathBackendWebGL:()=>Ol,Max:()=>Ns,MaxPool:()=>Es,MaxPool3D:()=>Nu,MaxPool3DGrad:()=>Kp,MaxPoolGrad:()=>Xp,MaxPoolWithArgmax:()=>Zp,Maximum:()=>Ts,Mean:()=>Cs,Min:()=>Rs,Minimum:()=>Ms,MirrorPad:()=>Fs,Mod:()=>Ro,MomentumOptimizer:()=>Qc,Multinomial:()=>Yp,Multiply:()=>$s,Neg:()=>Mo,NonMaxSuppressionV3:()=>$o,NonMaxSuppressionV4:()=>Do,NonMaxSuppressionV5:()=>Oo,NotEqual:()=>Fo,OP_SCOPE_SUFFIX:()=>Vx,OneHot:()=>Ds,OnesLike:()=>zo,Optimizer:()=>ir,Pack:()=>_o,PadV2:()=>Os,Pool:()=>LI,Pow:()=>zs,Prelu:()=>_s,Prod:()=>Po,RMSPropOptimizer:()=>eh,RNN:()=>Ua,Range:()=>Tu,Rank:()=>Sm,Real:()=>Jp,RealDiv:()=>ys,Reciprocal:()=>Lo,Reduction:()=>un,Relu:()=>Ps,Relu6:()=>Ws,Reshape:()=>Wo,ResizeBilinear:()=>Ls,ResizeBilinearGrad:()=>ec,ResizeNearestNeighbor:()=>Eu,ResizeNearestNeighborGrad:()=>Qp,Reverse:()=>Bs,RotateWithOffset:()=>el,Round:()=>Vs,Rsqrt:()=>js,SGDOptimizer:()=>sd,ScatterNd:()=>Bo,Select:()=>Vo,Selu:()=>jo,Sequential:()=>Ul,Sigmoid:()=>Hs,Sign:()=>Go,Sin:()=>Us,Sinh:()=>Ho,Slice:()=>Uo,Softmax:()=>Xs,Softplus:()=>qo,SpaceToBatchND:()=>Cu,SparseFillEmptyRows:()=>tc,SparseReshape:()=>nc,SparseToDense:()=>ac,SplitV:()=>Xo,Sqrt:()=>Gs,Square:()=>Ru,SquaredDifference:()=>Ks,Step:()=>Sr,StridedSlice:()=>Ko,Sub:()=>Zs,Sum:()=>qs,SymbolicTensor:()=>Ia,Tan:()=>Ys,Tanh:()=>Js,Tensor:()=>Le,TensorBuffer:()=>Dt,Tile:()=>Ir,TopK:()=>Zo,Transform:()=>Yo,Transpose:()=>Qs,Unique:()=>rc,Unpack:()=>Jo,UnsortedSegmentSum:()=>Mu,Variable:()=>Pu,ZerosLike:()=>Qo,_FusedMatMul:()=>ei,abs:()=>Ot,acos:()=>Ym,acosh:()=>Jm,add:()=>se,addN:()=>yc,all:()=>gc,any:()=>ju,argMax:()=>Uu,argMin:()=>Qm,asin:()=>eA,asinh:()=>tA,atan:()=>nA,atan2:()=>aA,atanh:()=>rA,avgPool:()=>Gu,avgPool3d:()=>oA,backend:()=>kb,backend_util:()=>C,basicLSTMCell:()=>gT,batchNorm:()=>pi,batchNorm2d:()=>Tb,batchNorm3d:()=>Eb,batchNorm4d:()=>Cb,batchToSpaceND:()=>qu,bincount:()=>lA,booleanMaskAsync:()=>IR,broadcastTo:()=>pl,browser:()=>oi,buffer:()=>We,callbacks:()=>Ore,cast:()=>fe,ceil:()=>uA,clipByValue:()=>kn,clone:()=>Da,complex:()=>Nr,concat:()=>ot,concat1d:()=>Rb,concat2d:()=>cl,concat3d:()=>Mb,concat4d:()=>Fb,constraints:()=>v6,conv1d:()=>bc,conv2d:()=>nr,conv2dTranspose:()=>vc,conv3d:()=>pA,conv3dTranspose:()=>Db,copyRegisteredKernels:()=>VI,cos:()=>Xu,cosh:()=>wc,cosineWindow:()=>PA,cumsum:()=>kc,customGrad:()=>za,data:()=>O8,denseBincount:()=>Ob,deprecationWarn:()=>Km,depthToSpace:()=>cA,depthwiseConv2d:()=>hl,deregisterOp:()=>_re,device_util:()=>Wu,diag:()=>qT,dilation2d:()=>hA,disableDeprecationWarnings:()=>MN,dispose:()=>Ee,disposeVariables:()=>FN,div:()=>me,divNoNan:()=>fA,dot:()=>zb,dropout:()=>a3,einsum:()=>_b,elu:()=>fl,enableDebugMode:()=>RN,enableProdMode:()=>CN,enclosingPowerOfTwo:()=>r3,engine:()=>tr,env:()=>J,equal:()=>Mr,erf:()=>mA,exp:()=>qn,expandDims:()=>ln,expm1:()=>AA,eye:()=>yA,fft:()=>ad,fill:()=>ml,findBackend:()=>Zm,findBackendFactory:()=>LN,floor:()=>Al,floorDiv:()=>Ac,forceHalfFloat:()=>vv,fused:()=>zr,gather:()=>ci,gatherND:()=>n3,gather_util:()=>Vm,getBackend:()=>_N,getGradient:()=>wm,getKernel:()=>ic,getKernelsForBackend:()=>nl,gpgpu_util:()=>H7,grad:()=>kE,grads:()=>IE,greater:()=>Mn,greaterEqual:()=>$r,ifft:()=>vl,imag:()=>Ic,image:()=>Ye,inTopKAsync:()=>OR,initializers:()=>E6,input:()=>B6,io:()=>vn,irfft:()=>Wc,isFinite:()=>Pb,isInf:()=>Lb,isNaN:()=>gA,keep:()=>jt,kernel_impls:()=>La,layers:()=>W6,leakyRelu:()=>Ku,less:()=>Sc,lessEqual:()=>Dr,linalg:()=>A3,linspace:()=>Wb,loadGraphModel:()=>Gt,loadLayersModel:()=>tre,localResponseNormalization:()=>xA,log:()=>Fn,log1p:()=>Nc,logSigmoid:()=>Vb,logSoftmax:()=>Ec,logSumExp:()=>wA,logicalAnd:()=>oa,logicalNot:()=>Zu,logicalOr:()=>Cc,logicalXor:()=>Gb,losses:()=>sF,matMul:()=>Be,math:()=>rb,max:()=>Xn,maxPool:()=>Yu,maxPool3d:()=>kA,maxPoolWithArgmax:()=>qb,maximum:()=>_a,mean:()=>wt,memory:()=>mc,meshgrid:()=>GE,metrics:()=>Q4,min:()=>yl,minimum:()=>gl,mirrorPad:()=>IA,mod:()=>SA,model:()=>Qae,models:()=>e8,moments:()=>Rc,movingAverage:()=>TR,mul:()=>_,multiRNNCell:()=>eC,multinomial:()=>Xb,neg:()=>vt,nextFrame:()=>th,norm:()=>Uc,notEqual:()=>mi,oneHot:()=>ol,ones:()=>$n,onesLike:()=>Dn,op:()=>O,outerProduct:()=>sC,pad:()=>ar,pad1d:()=>lC,pad2d:()=>dC,pad3d:()=>cC,pad4d:()=>fC,pool:()=>Kb,pow:()=>rr,prelu:()=>Qu,print:()=>Jx,prod:()=>Mc,profile:()=>$N,rand:()=>kC,randomGamma:()=>TC,randomNormal:()=>Zb,randomUniform:()=>xl,range:()=>bl,ready:()=>zN,real:()=>ed,reciprocal:()=>EA,registerBackend:()=>ul,registerCallbackConstructor:()=>nre,registerGradient:()=>Fx,registerKernel:()=>ai,registerOp:()=>zre,regularizers:()=>t8,relu:()=>Pa,relu6:()=>Fc,removeBackend:()=>PN,reshape:()=>H,reverse:()=>On,reverse1d:()=>zC,reverse2d:()=>PC,reverse3d:()=>WC,reverse4d:()=>VC,rfft:()=>rd,round:()=>$c,rsqrt:()=>Dc,scalar:()=>Se,scatterND:()=>t3,scatter_util:()=>jm,selu:()=>Oc,separableConv2d:()=>CA,sequential:()=>ere,serialization:()=>ae,setBackend:()=>ON,setPlatform:()=>WN,setWasmPath:()=>KJ,setWasmPaths:()=>ZJ,setWebGLContext:()=>ph,setdiff1dAsync:()=>Yb,shared:()=>jA,sigmoid:()=>wn,sign:()=>RA,signal:()=>rF,sin:()=>zc,sinh:()=>_c,slice:()=>Re,slice1d:()=>Pc,slice2d:()=>MA,slice3d:()=>Lc,slice4d:()=>td,slice_util:()=>on,softmax:()=>nd,softplus:()=>hi,spaceToBatchND:()=>Ju,sparse:()=>y3,sparseToDense:()=>_A,spectral:()=>aF,split:()=>an,sqrt:()=>Jt,square:()=>st,squaredDifference:()=>Bc,squeeze:()=>Or,stack:()=>zn,step:()=>wl,stridedSlice:()=>FA,sub:()=>ge,sum:()=>ke,sumOutType:()=>dc,tan:()=>$A,tanh:()=>di,tensor:()=>ia,tensor1d:()=>Tt,tensor2d:()=>ya,tensor3d:()=>hc,tensor4d:()=>fR,tensor5d:()=>mR,tensor6d:()=>AR,tensor_util:()=>ma,test_util:()=>bb,tidy:()=>W,tile:()=>Fr,time:()=>DN,topk:()=>DA,train:()=>yi,transpose:()=>Ze,truncatedNormal:()=>Vc,unique:()=>jc,unregisterGradient:()=>BI,unregisterKernel:()=>WI,unsortedSegmentSum:()=>OA,unstack:()=>la,upcastType:()=>sa,util:()=>k,valueAndGrad:()=>SE,valueAndGrads:()=>NE,variable:()=>Jb,variableGrads:()=>Bb,version:()=>kie,version_converter:()=>_se,version_core:()=>EN,version_cpu:()=>Y3,version_layers:()=>ly,version_wasm:()=>c6,version_webgl:()=>bv,webgl:()=>GW,webgl_util:()=>x7,where:()=>nn,whereAsync:()=>zA,zeros:()=>Ct,zerosLike:()=>Ue});var L9=Object.create,kp=Object.defineProperty,W9=Object.getPrototypeOf,B9=Object.prototype.hasOwnProperty,V9=Object.getOwnPropertyNames,j9=Object.getOwnPropertyDescriptor,U9=e=>kp(e,"__esModule",{value:!0}),xt=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),Fe=(e,t)=>{for(var n in t)kp(e,n,{get:t[n],enumerable:!0})},H9=(e,t,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of V9(t))!B9.call(e,a)&&a!=="default"&&kp(e,a,{get:()=>t[a],enumerable:!(n=j9(t,a))||n.enumerable});return e},Zi=e=>H9(U9(kp(e!=null?L9(W9(e)):{},"default",e&&e.__esModule&&"default"in e?{get:()=>e.default,enumerable:!0}:{value:e,enumerable:!0})),e),G9=xt(()=>{}),q9=xt((e,t)=>{(function(n,a,r){function s(d){var u=this,p=l();u.next=function(){var c=2091639*u.s0+u.c*23283064365386963e-26;return u.s0=u.s1,u.s1=u.s2,u.s2=c-(u.c=c|0)},u.c=1,u.s0=p(" "),u.s1=p(" "),u.s2=p(" "),u.s0-=p(d),u.s0<0&&(u.s0+=1),u.s1-=p(d),u.s1<0&&(u.s1+=1),u.s2-=p(d),u.s2<0&&(u.s2+=1),p=null}function i(d,u){return u.c=d.c,u.s0=d.s0,u.s1=d.s1,u.s2=d.s2,u}function o(d,u){var p=new s(d),c=u&&u.state,h=p.next;return h.int32=function(){return p.next()*4294967296|0},h.double=function(){return h()+(h()*2097152|0)*11102230246251565e-32},h.quick=h,c&&(typeof c=="object"&&i(c,p),h.state=function(){return i(p,{})}),h}function l(){var d=4022871197,u=function(p){p=p.toString();for(var c=0;c>>0,h-=d,h*=d,d=h>>>0,h-=d,d+=h*4294967296}return(d>>>0)*23283064365386963e-26};return u}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.alea=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),X9=xt((e,t)=>{(function(n,a,r){function s(l){var d=this,u="";d.x=0,d.y=0,d.z=0,d.w=0,d.next=function(){var c=d.x^d.x<<11;return d.x=d.y,d.y=d.z,d.z=d.w,d.w^=d.w>>>19^c^c>>>8},l===(l|0)?d.x=l:u+=l;for(var p=0;p>>0)/4294967296};return c.double=function(){do var h=u.next()>>>11,m=(u.next()>>>0)/4294967296,f=(h+m)/(1<<21);while(f===0);return f},c.int32=u.next,c.quick=c,p&&(typeof p=="object"&&i(p,u),c.state=function(){return i(u,{})}),c}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.xor128=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),K9=xt((e,t)=>{(function(n,a,r){function s(l){var d=this,u="";d.next=function(){var c=d.x^d.x>>>2;return d.x=d.y,d.y=d.z,d.z=d.w,d.w=d.v,(d.d=d.d+362437|0)+(d.v=d.v^d.v<<4^(c^c<<1))|0},d.x=0,d.y=0,d.z=0,d.w=0,d.v=0,l===(l|0)?d.x=l:u+=l;for(var p=0;p>>4),d.next()}function i(l,d){return d.x=l.x,d.y=l.y,d.z=l.z,d.w=l.w,d.v=l.v,d.d=l.d,d}function o(l,d){var u=new s(l),p=d&&d.state,c=function(){return(u.next()>>>0)/4294967296};return c.double=function(){do var h=u.next()>>>11,m=(u.next()>>>0)/4294967296,f=(h+m)/(1<<21);while(f===0);return f},c.int32=u.next,c.quick=c,p&&(typeof p=="object"&&i(p,u),c.state=function(){return i(u,{})}),c}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.xorwow=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),Z9=xt((e,t)=>{(function(n,a,r){function s(l){var d=this;d.next=function(){var p=d.x,c=d.i,h,m,f;return h=p[c],h^=h>>>7,m=h^h<<24,h=p[c+1&7],m^=h^h>>>10,h=p[c+3&7],m^=h^h>>>3,h=p[c+4&7],m^=h^h<<7,h=p[c+7&7],h=h^h<<13,m^=h^h<<9,p[c]=m,d.i=c+1&7,m};function u(p,c){var h,m,f=[];if(c===(c|0))m=f[0]=c;else for(c=""+c,h=0;h0;--h)p.next()}u(d,l)}function i(l,d){return d.x=l.x.slice(),d.i=l.i,d}function o(l,d){l==null&&(l=+new Date);var u=new s(l),p=d&&d.state,c=function(){return(u.next()>>>0)/4294967296};return c.double=function(){do var h=u.next()>>>11,m=(u.next()>>>0)/4294967296,f=(h+m)/(1<<21);while(f===0);return f},c.int32=u.next,c.quick=c,p&&(p.x&&i(p,u),c.state=function(){return i(u,{})}),c}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.xorshift7=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),Y9=xt((e,t)=>{(function(n,a,r){function s(l){var d=this;d.next=function(){var p=d.w,c=d.X,h=d.i,m,f;return d.w=p=p+1640531527|0,f=c[h+34&127],m=c[h=h+1&127],f^=f<<13,m^=m<<17,f^=f>>>15,m^=m>>>12,f=c[h]=f^m,d.i=h,f+(p^p>>>16)|0};function u(p,c){var h,m,f,A,y,g=[],x=128;for(c===(c|0)?(m=c,c=null):(c=c+"\0",m=0,x=Math.max(x,c.length)),f=0,A=-32;A>>15,m^=m<<4,m^=m>>>13,A>=0&&(y=y+1640531527|0,h=g[A&127]^=m+y,f=h==0?f+1:0);for(f>=128&&(g[(c&&c.length||0)&127]=-1),f=127,A=4*128;A>0;--A)m=g[f+34&127],h=g[f=f+1&127],m^=m<<13,h^=h<<17,m^=m>>>15,h^=h>>>12,g[f]=m^h;p.w=y,p.X=g,p.i=f}u(d,l)}function i(l,d){return d.i=l.i,d.w=l.w,d.X=l.X.slice(),d}function o(l,d){l==null&&(l=+new Date);var u=new s(l),p=d&&d.state,c=function(){return(u.next()>>>0)/4294967296};return c.double=function(){do var h=u.next()>>>11,m=(u.next()>>>0)/4294967296,f=(h+m)/(1<<21);while(f===0);return f},c.int32=u.next,c.quick=c,p&&(p.X&&i(p,u),c.state=function(){return i(u,{})}),c}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.xor4096=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),J9=xt((e,t)=>{(function(n,a,r){function s(l){var d=this,u="";d.next=function(){var c=d.b,h=d.c,m=d.d,f=d.a;return c=c<<25^c>>>7^h,h=h-m|0,m=m<<24^m>>>8^f,f=f-c|0,d.b=c=c<<20^c>>>12^h,d.c=h=h-m|0,d.d=m<<16^h>>>16^f,d.a=f-c|0},d.a=0,d.b=0,d.c=2654435769|0,d.d=1367130551,l===Math.floor(l)?(d.a=l/4294967296|0,d.b=l|0):u+=l;for(var p=0;p>>0)/4294967296};return c.double=function(){do var h=u.next()>>>11,m=(u.next()>>>0)/4294967296,f=(h+m)/(1<<21);while(f===0);return f},c.int32=u.next,c.quick=c,p&&(typeof p=="object"&&i(p,u),c.state=function(){return i(u,{})}),c}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.tychei=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),Lg=xt(()=>{}),Q9=xt((e,t)=>{(function(n,a){var r=this,s=256,i=6,o=52,l="random",d=a.pow(s,i),u=a.pow(2,o),p=u*2,c=s-1,h;function m(b,v,N){var T=[];v=v==!0?{entropy:!0}:v||{};var R=g(y(v.entropy?[b,w(n)]:b==null?x():b,3),T),$=new f(T),z=function(){for(var P=$.g(i),V=d,j=0;P=p;)P/=2,V/=2,j>>>=1;return(P+j)/V};return z.int32=function(){return $.g(4)|0},z.quick=function(){return $.g(4)/4294967296},z.double=z,g(w($.S),n),(v.pass||N||function(P,V,j,U){return U&&(U.S&&A(U,$),P.state=function(){return A($,{})}),j?(a[l]=P,V):P})(z,R,"global"in v?v.global:this==a,v.state)}a["seed"+l]=m;function f(b){var v,N=b.length,T=this,R=0,$=T.i=T.j=0,z=T.S=[];for(N||(b=[N++]);R{var n=q9(),a=X9(),r=K9(),s=Z9(),i=Y9(),o=J9(),l=Q9();l.alea=n,l.xor128=a,l.xorwow=r,l.xorshift7=s,l.xor4096=i,l.tychei=o,t.exports=l}),cu=xt(()=>{}),eI=xt(()=>{}),tI=xt(()=>{}),nI=xt((e,t)=>{var n=function(){var a=typeof document!="undefined"&&document.currentScript?document.currentScript.src:void 0;return typeof __filename!="undefined"&&(a=a||__filename),function(r){r=r||{};function s(){return Q.buffer!=Ve&&Kt(Q.buffer),An}function i(){return Q.buffer!=Ve&&Kt(Q.buffer),gt}function o(){return Q.buffer!=Ve&&Kt(Q.buffer),yn}function l(){return Q.buffer!=Ve&&Kt(Q.buffer),jn}function d(){return Q.buffer!=Ve&&Kt(Q.buffer),rn}var u=typeof r!="undefined"?r:{},p,c;u.ready=new Promise(function(S,E){p=S,c=E});var h={},m;for(m in u)u.hasOwnProperty(m)&&(h[m]=u[m]);var f=[],A="./this.program",y=function(S,E){throw E},g=!1,x=!1,w=!1,b=!1;g=typeof window=="object",x=typeof importScripts=="function",w=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",b=!g&&!w&&!x;var v=u.ENVIRONMENT_IS_PTHREAD||!1;v&&(Ve=u.buffer);var N="";function T(S){return u.locateFile?u.locateFile(S,N):N+S}var R,$,z,P,V,j;if(w){x?N=cu().dirname(N)+"/":N=__dirname+"/",R=function(S,E){return V||(V=require("fs")),j||(j=cu()),S=j.normalize(S),V.readFileSync(S,E?null:"utf8")},z=function(S){var E=R(S,!0);return E.buffer||(E=new Uint8Array(E)),ce(E.buffer),E},process.argv.length>1&&(A=process.argv[1].replace(/\\/g,"/")),f=process.argv.slice(2),process.on("uncaughtException",function(S){if(!(S instanceof du))throw S}),process.on("unhandledRejection",Za),y=function(S){process.exit(S)},u.inspect=function(){return"[Emscripten Module object]"};var U;try{U=eI()}catch(S){throw console.error('The "worker_threads" module is not supported in this node.js build - perhaps a newer version is needed?'),S}global.Worker=U.Worker}else b?(typeof read!="undefined"&&(R=function(S){return read(S)}),z=function(S){var E;return typeof readbuffer=="function"?new Uint8Array(readbuffer(S)):(E=read(S,"binary"),ce(typeof E=="object"),E)},typeof scriptArgs!="undefined"?f=scriptArgs:typeof arguments!="undefined"&&(f=arguments),typeof quit=="function"&&(y=function(S){quit(S)}),typeof print!="undefined"&&(typeof console=="undefined"&&(console={}),console.log=print,console.warn=console.error=typeof printErr!="undefined"?printErr:print)):(g||x)&&(x?N=self.location.href:typeof document!="undefined"&&document.currentScript&&(N=document.currentScript.src),typeof a!="undefined"&&a&&(N=a),N.indexOf("blob:")!==0?N=N.substr(0,N.lastIndexOf("/")+1):N="",w?(R=function(S,E){return V||(V=require("fs")),j||(j=cu()),S=j.normalize(S),V.readFileSync(S,E?null:"utf8")},z=function(S){var E=R(S,!0);return E.buffer||(E=new Uint8Array(E)),ce(E.buffer),E}):(R=function(S){var E=new XMLHttpRequest;return E.open("GET",S,!1),E.send(null),E.responseText},x&&(z=function(S){var E=new XMLHttpRequest;return E.open("GET",S,!1),E.responseType="arraybuffer",E.send(null),new Uint8Array(E.response)}),$=function(S,E,L){var q=new XMLHttpRequest;q.open("GET",S,!0),q.responseType="arraybuffer",q.onload=function(){if(q.status==200||q.status==0&&q.response){E(q.response);return}L()},q.onerror=L,q.send(null)}),P=function(S){document.title=S});w&&typeof performance=="undefined"&&(global.performance=tI().performance);var X=u.print||console.log.bind(console),G=u.printErr||console.warn.bind(console);for(m in h)h.hasOwnProperty(m)&&(u[m]=h[m]);h=null,u.arguments&&(f=u.arguments),u.thisProgram&&(A=u.thisProgram),u.quit&&(y=u.quit);var ee=Atomics.load,Y=Atomics.store,re=Atomics.compareExchange,ne;u.wasmBinary&&(ne=u.wasmBinary);var ie=u.noExitRuntime||!0;typeof WebAssembly!="object"&&Za("no native wasm support detected");var Q,de,oe=!1,ye;function ce(S,E){S||Za("Assertion failed: "+E)}function Ie(S){var E=u["_"+S];return ce(E,"Cannot call unknown function "+S+", make sure it is exported"),E}function Ne(S,E,L,q,pe){var le={string:function(bn){var Ki=0;if(bn!=null&&bn!==0){var zg=(bn.length<<2)+1;Ki=Gi(zg),et(bn,Ki,zg)}return Ki},array:function(bn){var Ki=Gi(bn.length);return Xe(bn,Ki),Ki}};function ue(bn){return E==="string"?De(bn):E==="boolean"?Boolean(bn):bn}var be=Ie(S),tt=[],Bt=0;if(q)for(var $t=0;$t=q);){var le=S[E++];if(!le)return pe;if(!(le&128)){pe+=String.fromCharCode(le);continue}var ue=S[E++]&63;if((le&224)==192){pe+=String.fromCharCode((le&31)<<6|ue);continue}var be=S[E++]&63;if((le&240)==224?le=(le&15)<<12|ue<<6|be:le=(le&7)<<18|ue<<12|be<<6|S[E++]&63,le<65536)pe+=String.fromCharCode(le);else{var tt=le-65536;pe+=String.fromCharCode(55296|tt>>10,56320|tt&1023)}}return pe}function De(S,E){return S?ze(i(),S,E):""}function Qe(S,E,L,q){if(!(q>0))return 0;for(var pe=L,le=L+q-1,ue=0;ue=55296&&be<=57343){var tt=S.charCodeAt(++ue);be=65536+((be&1023)<<10)|tt&1023}if(be<=127){if(L>=le)break;E[L++]=be}else if(be<=2047){if(L+1>=le)break;E[L++]=192|be>>6,E[L++]=128|be&63}else if(be<=65535){if(L+2>=le)break;E[L++]=224|be>>12,E[L++]=128|be>>6&63,E[L++]=128|be&63}else{if(L+3>=le)break;E[L++]=240|be>>18,E[L++]=128|be>>12&63,E[L++]=128|be>>6&63,E[L++]=128|be&63}}return E[L]=0,L-pe}function et(S,E,L){return Qe(S,i(),E,L)}function rt(S){for(var E=0,L=0;L=55296&&q<=57343&&(q=65536+((q&1023)<<10)|S.charCodeAt(++L)&1023),q<=127?++E:q<=2047?E+=2:q<=65535?E+=3:E+=4}return E}function Xe(S,E){s().set(S,E)}function dt(S,E){return S%E>0&&(S+=E-S%E),S}var Ve,An,gt,Vn,Xt,yn,jn,Rn,rn;function Kt(S){Ve=S,u.HEAP8=An=new Int8Array(S),u.HEAP16=Vn=new Int16Array(S),u.HEAP32=yn=new Int32Array(S),u.HEAPU8=gt=new Uint8Array(S),u.HEAPU16=Xt=new Uint16Array(S),u.HEAPU32=jn=new Uint32Array(S),u.HEAPF32=Rn=new Float32Array(S),u.HEAPF64=rn=new Float64Array(S)}var Ca=u.INITIAL_MEMORY||16777216;if(v)Q=u.wasmMemory,Ve=u.buffer;else if(u.wasmMemory)Q=u.wasmMemory;else if(Q=new WebAssembly.Memory({initial:Ca/65536,maximum:2147483648/65536,shared:!0}),!(Q.buffer instanceof SharedArrayBuffer))throw G("requested a shared WebAssembly.Memory but the returned buffer is not a SharedArrayBuffer, indicating that while the browser has SharedArrayBuffer it does not have WebAssembly threads support - you may need to set a flag"),w&&console.log("(on node you may need: --experimental-wasm-threads --experimental-wasm-bulk-memory and also use a recent version)"),Error("bad memory");Q&&(Ve=Q.buffer),Ca=Ve.byteLength,Kt(Ve);var ea,ta=[],hr=[],Xa=[],fr=[],Li=[],Ra=!1,tp=!1;v||hr.push({func:function(){Ap()}});function L0(){if(!v){if(u.preRun)for(typeof u.preRun=="function"&&(u.preRun=[u.preRun]);u.preRun.length;)ap(u.preRun.shift());Bi(ta)}}function eu(){Ra=!0,!v&&Bi(hr)}function W0(){v||Bi(Xa)}function np(){v||(tp=!0)}function gn(){if(!v){if(u.postRun)for(typeof u.postRun=="function"&&(u.postRun=[u.postRun]);u.postRun.length;)B0(u.postRun.shift());Bi(Li)}}function ap(S){ta.unshift(S)}function B0(S){Li.unshift(S)}var Ka=0,mr=null,es=null;function V0(S){ce(!v,"addRunDependency cannot be used in a pthread worker"),Ka++,u.monitorRunDependencies&&u.monitorRunDependencies(Ka)}function j0(S){if(Ka--,u.monitorRunDependencies&&u.monitorRunDependencies(Ka),Ka==0&&(mr!==null&&(clearInterval(mr),mr=null),es)){var E=es;es=null,E()}}u.preloadedImages={},u.preloadedAudios={};function Za(S){u.onAbort&&u.onAbort(S),v&&console.error("Pthread aborting at "+new Error().stack),S+="",G(S),oe=!0,ye=1,S="abort("+S+"). Build with -s ASSERTIONS=1 for more info.";var E=new WebAssembly.RuntimeError(S);throw c(E),E}function rp(S,E){return String.prototype.startsWith?S.startsWith(E):S.indexOf(E)===0}var Wi="data:application/octet-stream;base64,";function sp(S){return rp(S,Wi)}var U0="file://";function ip(S){return rp(S,U0)}var xn="tfjs-backend-wasm-threaded-simd.wasm";sp(xn)||(xn=T(xn));function op(S){try{if(S==xn&&ne)return new Uint8Array(ne);if(z)return z(S);throw"both async and sync fetching of the wasm failed"}catch(E){Za(E)}}function H0(){if(!ne&&(g||x)){if(typeof fetch=="function"&&!ip(xn))return fetch(xn,{credentials:"same-origin"}).then(function(S){if(!S.ok)throw"failed to load wasm binary file at '"+xn+"'";return S.arrayBuffer()}).catch(function(){return op(xn)});if($)return new Promise(function(S,E){$(xn,function(L){S(new Uint8Array(L))},E)})}return Promise.resolve().then(function(){return op(xn)})}function G0(){var S={a:_f};function E(ue,be){var tt=ue.exports;if(u.asm=tt,ea=u.asm.F,de=be,!v){var Bt=we.unusedWorkers.length;we.unusedWorkers.forEach(function($t){we.loadWasmModuleToWorker($t,function(){--Bt||j0("wasm-instantiate")})})}}v||V0("wasm-instantiate");function L(ue){E(ue.instance,ue.module)}function q(ue){return H0().then(function(be){return WebAssembly.instantiate(be,S)}).then(ue,function(be){G("failed to asynchronously prepare wasm: "+be),Za(be)})}function pe(){return!ne&&typeof WebAssembly.instantiateStreaming=="function"&&!sp(xn)&&!ip(xn)&&typeof fetch=="function"?fetch(xn,{credentials:"same-origin"}).then(function(ue){var be=WebAssembly.instantiateStreaming(ue,S);return be.then(L,function(tt){return G("wasm streaming compile failed: "+tt),G("falling back to ArrayBuffer instantiation"),q(L)})}):q(L)}if(u.instantiateWasm)try{var le=u.instantiateWasm(S,E);return le}catch(ue){return G("Module.instantiateWasm callback failed with error: "+ue),!1}return pe().catch(c),{}}var q0={9816:function(){throw"Canceled!"},9834:function(S,E){setTimeout(function(){Rg(S,E)},0)}};function lp(){we.initRuntime()}function Bi(S){for(;S.length>0;){var E=S.shift();if(typeof E=="function"){E(u);continue}var L=E.func;typeof L=="number"?E.arg===void 0?ea.get(L)():ea.get(L)(E.arg):L(E.arg===void 0?null:E.arg)}}function tu(S,E){if(S<=0||S>s().length||S&!0||E<0)return-28;if(E==0)return 0;E>=2147483647&&(E=Infinity);var L=Atomics.load(o(),qi>>2),q=0;if(L==S){var pe=Atomics.compareExchange(o(),qi>>2,L,0);if(pe==L&&(--E,q=1,E<=0))return 1}var le=Atomics.notify(o(),S>>2,E);if(le>=0)return le+q;throw"Atomics.notify returned an unexpected value "+le}u._emscripten_futex_wake=tu;function X0(S){if(v)throw"Internal Error! killThread() can only ever be called from main application thread!";if(!S)throw"Internal Error! Null pthread_ptr in killThread!";o()[S+12>>2]=0;var E=we.pthreads[S];E.worker.terminate(),we.freeThreadData(E),we.runningWorkers.splice(we.runningWorkers.indexOf(E.worker),1),E.worker.pthread=void 0}function K0(S){if(v)throw"Internal Error! cancelThread() can only ever be called from main application thread!";if(!S)throw"Internal Error! Null pthread_ptr in cancelThread!";var E=we.pthreads[S];E.worker.postMessage({cmd:"cancel"})}function Z0(S){if(v)throw"Internal Error! cleanupThread() can only ever be called from main application thread!";if(!S)throw"Internal Error! Null pthread_ptr in cleanupThread!";var E=we.pthreads[S];if(E){o()[S+12>>2]=0;var L=E.worker;we.returnWorkerToPool(L)}}var we={unusedWorkers:[],runningWorkers:[],initMainThreadBlock:function(){for(var S=Math.min(4,Math.max(1,(navigator.hardwareConcurrency||1)/2)),E=0;E>2]=S;var L=S+152;o()[L>>2]=L;for(var q=ns(512),E=0;E<128;++E)l()[q/4+E]=0;Atomics.store(l(),S+100>>2,q),Atomics.store(l(),S+40>>2,S),lm(S,!x,1),Cg(S)},initWorker:function(){},pthreads:{},threadExitHandlers:[],setThreadStatus:function(){},runExitHandlers:function(){for(;we.threadExitHandlers.length>0;)we.threadExitHandlers.pop()();v&&Ui()&&Eg()},runExitHandlersAndDeinitThread:function(S,E){Atomics.store(l(),S+56>>2,1),Atomics.store(l(),S+60>>2,0),we.runExitHandlers(),Atomics.store(l(),S+4>>2,E),Atomics.store(l(),S+0>>2,1),tu(S+0,2147483647),lm(0,0,0)},threadExit:function(S){var E=Ui();E&&(we.runExitHandlersAndDeinitThread(E,S),v&&postMessage({cmd:"exit"}))},threadCancel:function(){we.runExitHandlersAndDeinitThread(Ui(),-1),postMessage({cmd:"cancelDone"})},terminateAllThreads:function(){for(var S in we.pthreads){var E=we.pthreads[S];E&&E.worker&&we.returnWorkerToPool(E.worker)}we.pthreads={};for(var L=0;L>2];o()[S.threadInfoStruct+100>>2]=0,lu(E),lu(S.threadInfoStruct)}S.threadInfoStruct=0,S.allocatedOwnStack&&S.stackBase&&lu(S.stackBase),S.stackBase=0,S.worker&&(S.worker.pthread=null)}},returnWorkerToPool:function(S){we.runWithoutMainThreadQueuedCalls(function(){delete we.pthreads[S.pthread.threadInfoStruct],we.unusedWorkers.push(S),we.runningWorkers.splice(we.runningWorkers.indexOf(S),1),we.freeThreadData(S.pthread),S.pthread=void 0})},runWithoutMainThreadQueuedCalls:function(S){o()[Og>>2]=0;try{S()}finally{o()[Og>>2]=1}},receiveObjectTransfer:function(S){},loadWasmModuleToWorker:function(S,E){S.onmessage=function(L){var q=L.data,pe=q.cmd;if(S.pthread&&(we.currentProxiedOperationCallerThread=S.pthread.threadInfoStruct),q.targetThread&&q.targetThread!=Ui()){var le=we.pthreads[q.targetThread];le?le.worker.postMessage(L.data,q.transferList):console.error('Internal error! Worker sent a message "'+pe+'" to target pthread '+q.targetThread+", but that thread no longer exists!"),we.currentProxiedOperationCallerThread=void 0;return}if(pe==="processQueuedMainThreadWork")im();else if(pe==="spawnThread")fp(L.data);else if(pe==="cleanupThread")Z0(q.thread);else if(pe==="killThread")X0(q.thread);else if(pe==="cancelThread")K0(q.thread);else if(pe==="loaded")S.loaded=!0,E&&E(S),S.runPthread&&(S.runPthread(),delete S.runPthread);else if(pe==="print")X("Thread "+q.threadId+": "+q.text);else if(pe==="printErr")G("Thread "+q.threadId+": "+q.text);else if(pe==="alert")alert("Thread "+q.threadId+": "+q.text);else if(pe==="exit"){var ue=S.pthread&&Atomics.load(l(),S.pthread.threadInfoStruct+64>>2);ue&&we.returnWorkerToPool(S)}else if(pe==="exitProcess")try{_9(q.returnCode)}catch(be){if(be instanceof du)return;throw be}else pe==="cancelDone"?we.returnWorkerToPool(S):pe==="objectTransfer"?we.receiveObjectTransfer(L.data):L.data.target==="setimmediate"?S.postMessage(L.data):G("worker sent an unknown command "+pe);we.currentProxiedOperationCallerThread=void 0},S.onerror=function(L){G("pthread sent an error! "+L.filename+":"+L.lineno+": "+L.message)},w&&(S.on("message",function(L){S.onmessage({data:L})}),S.on("error",function(L){S.onerror(L)}),S.on("exit",function(L){})),S.postMessage({cmd:"load",urlOrBlob:u.mainScriptUrlOrBlob||a,wasmMemory:Q,wasmModule:de})},allocateUnusedWorker:function(){var S=T("tfjs-backend-wasm-threaded-simd.worker.js");we.unusedWorkers.push(new Worker(S))},getNewWorker:function(){return we.unusedWorkers.length==0&&(we.allocateUnusedWorker(),we.loadWasmModuleToWorker(we.unusedWorkers[0])),we.unusedWorkers.length>0?we.unusedWorkers.pop():null},busySpinWait:function(S){for(var E=performance.now()+S;performance.now()>2]=S,S}function af(S,E){if(v)return Ar(1,1,S,E)}function rf(S,E){if(S==E)postMessage({cmd:"processQueuedMainThreadWork"});else if(v)postMessage({targetThread:S,cmd:"processThreadQueue"});else{var L=we.pthreads[S],q=L&&L.worker;if(!q)return;q.postMessage({cmd:"processThreadQueue"})}return 1}function sf(){Za()}function of(S,E,L){var q=cf(E,L);return q0[S].apply(null,q)}function lf(S,E){}function uf(S,E,L){if(S<=0||S>s().length||S&!0)return-28;if(g){if(Atomics.load(o(),S>>2)!=E)return-6;for(var q=performance.now(),pe=q+L,le=Atomics.exchange(o(),qi>>2,S);;){if(q=performance.now(),q>pe)return le=Atomics.exchange(o(),qi>>2,0),-73;if(le=Atomics.exchange(o(),qi>>2,0),le==0)break;if(im(),Atomics.load(o(),S>>2)!=E)return-6;le=Atomics.exchange(o(),qi>>2,S)}return 0}else{var ue=Atomics.wait(o(),S>>2,E,L);if(ue==="timed-out")return-73;if(ue==="not-equal")return-6;if(ue==="ok")return 0;throw"Atomics.wait returned an unexpected value "+ue}}function df(S,E,L){i().copyWithin(S,E,E+L)}function pf(){return w?require("os").cpus().length:navigator.hardwareConcurrency}function Ar(S,E){for(var L=arguments.length-2,q=uu(),pe=L,le=Gi(pe*8),ue=le>>3,be=0;be>=2;L=i()[S++];){var q=L<105;q&&E&1&&E++,au.push(q?d()[E++>>1]:o()[E]),++E}return au}function hf(S,E,L){nu.length=E;for(var q=L>>3,pe=0;pe>>16),Kt(Q.buffer),1}catch(E){}}function Af(S){var E=ff();if(S<=E)return!1;var L=2147483648;if(S>L)return!1;for(var q=1;q<=4;q*=2){var pe=E*(1+.2/q);pe=Math.min(pe,S+100663296);var le=Math.min(L,dt(Math.max(S,pe),65536)),ue=mf(le);if(ue)return!0}return!1}var Pe={inEventHandler:0,removeAllEventListeners:function(){for(var S=Pe.eventHandlers.length-1;S>=0;--S)Pe._removeHandler(S);Pe.eventHandlers=[],Pe.deferredCalls=[]},registerRemoveEventListeners:function(){Pe.removeEventListenersRegistered||(fr.push(Pe.removeAllEventListeners),Pe.removeEventListenersRegistered=!0)},deferredCalls:[],deferCall:function(S,E,L){function q(ue,be){if(ue.length!=be.length)return!1;for(var tt in ue)if(ue[tt]!=be[tt])return!1;return!0}for(var pe in Pe.deferredCalls){var le=Pe.deferredCalls[pe];if(le.targetFunction==S&&q(le.argsList,L))return}Pe.deferredCalls.push({targetFunction:S,precedence:E,argsList:L}),Pe.deferredCalls.sort(function(ue,be){return ue.precedence>2]=L,o()[ue+4>>2]=q,o()[ue+8>>2]=pe,om(0,S,637534208,E,q,ue),Hi(le)},getTargetThreadForEventCallback:function(S){switch(S){case 1:return 0;case 2:return we.currentProxiedOperationCallerThread;default:return S}},getNodeNameForTarget:function(S){return S?S==window?"#window":S==screen?"#screen":S&&S.nodeName?S.nodeName:"":""},fullscreenEnabled:function(){return document.fullscreenEnabled||document.webkitFullscreenEnabled}};function yf(S){var E=rt(S)+1,L=ns(E);return et(S,L,E),L}function gf(S,E,L,q){var pe=uu(),le=Gi(12),ue=0;E&&(ue=yf(E)),o()[le>>2]=ue,o()[le+4>>2]=L,o()[le+8>>2]=q,om(0,S,657457152,0,ue,le),Hi(pe)}function xf(S,E,L,q){E=E?De(E):"",gf(S,E,L,q)}function bf(S){return S>2?De(S):S}var vf=[0,typeof document!="undefined"?document:0,typeof window!="undefined"?window:0];function wf(S){S=bf(S);var E=vf[S]||(typeof document!="undefined"?document.querySelector(S):void 0);return E}function ru(S){return wf(S)}function up(S,E,L){var q=ru(S);if(!q)return-4;if(q.canvasSharedPtr&&(o()[q.canvasSharedPtr>>2]=E,o()[q.canvasSharedPtr+4>>2]=L),q.offscreenCanvas||!q.controlTransferredOffscreen){q.offscreenCanvas&&(q=q.offscreenCanvas);var pe=!1;if(q.GLctxObject&&q.GLctxObject.GLctx){var le=q.GLctxObject.GLctx.getParameter(2978);pe=le[0]===0&&le[1]===0&&le[2]===q.width&&le[3]===q.height}q.width=E,q.height=L,pe&&q.GLctxObject.GLctx.viewport(0,0,E,L)}else if(q.canvasSharedPtr){var ue=o()[q.canvasSharedPtr+8>>2];return xf(ue,S,E,L),1}else return-4;return 0}function dp(S,E,L){return v?Ar(2,1,S,E,L):up(S,E,L)}function kf(S,E,L){var q=ru(S);return q?up(S,E,L):dp(S,E,L)}function If(S){}function Sf(S,E){}function Nf(S){var E=S.getExtension("ANGLE_instanced_arrays");if(E)return S.vertexAttribDivisor=function(L,q){E.vertexAttribDivisorANGLE(L,q)},S.drawArraysInstanced=function(L,q,pe,le){E.drawArraysInstancedANGLE(L,q,pe,le)},S.drawElementsInstanced=function(L,q,pe,le,ue){E.drawElementsInstancedANGLE(L,q,pe,le,ue)},1}function Tf(S){var E=S.getExtension("OES_vertex_array_object");if(E)return S.createVertexArray=function(){return E.createVertexArrayOES()},S.deleteVertexArray=function(L){E.deleteVertexArrayOES(L)},S.bindVertexArray=function(L){E.bindVertexArrayOES(L)},S.isVertexArray=function(L){return E.isVertexArrayOES(L)},1}function Ef(S){var E=S.getExtension("WEBGL_draw_buffers");if(E)return S.drawBuffers=function(L,q){E.drawBuffersWEBGL(L,q)},1}function Cf(S){return!!(S.multiDrawWebgl=S.getExtension("WEBGL_multi_draw"))}var Je={counter:1,buffers:[],programs:[],framebuffers:[],renderbuffers:[],textures:[],uniforms:[],shaders:[],vaos:[],contexts:{},offscreenCanvases:{},timerQueriesEXT:[],programInfos:{},stringCache:{},unpackAlignment:4,recordError:function(S){Je.lastError||(Je.lastError=S)},getNewId:function(S){for(var E=Je.counter++,L=S.length;L>2]:-1;pe+=De(o()[L+le*4>>2],ue<0?void 0:ue)}return pe},createContext:function(S,E){var L=S.getContext("webgl",E);if(!L)return 0;var q=Je.registerContext(L,E);return q},registerContext:function(S,E){var L=ns(8);o()[L+4>>2]=Ui();var q={handle:L,attributes:E,version:E.majorVersion,GLctx:S};return S.canvas&&(S.canvas.GLctxObject=q),Je.contexts[L]=q,(typeof E.enableExtensionsByDefault=="undefined"||E.enableExtensionsByDefault)&&Je.initExtensions(q),L},makeContextCurrent:function(S){return Je.currentContext=Je.contexts[S],u.ctx=yr=Je.currentContext&&Je.currentContext.GLctx,!(S&&!yr)},getContext:function(S){return Je.contexts[S]},deleteContext:function(S){Je.currentContext===Je.contexts[S]&&(Je.currentContext=null),typeof Pe=="object"&&Pe.removeAllHandlersOnTarget(Je.contexts[S].GLctx.canvas),Je.contexts[S]&&Je.contexts[S].GLctx.canvas&&(Je.contexts[S].GLctx.canvas.GLctxObject=void 0),lu(Je.contexts[S].handle),Je.contexts[S]=null},initExtensions:function(S){if(S||(S=Je.currentContext),!S.initExtensionsDone){S.initExtensionsDone=!0;var E=S.GLctx;Nf(E),Tf(E),Ef(E),E.disjointTimerQueryExt=E.getExtension("EXT_disjoint_timer_query"),Cf(E);var L=E.getSupportedExtensions()||[];L.forEach(function(q){q.indexOf("lose_context")<0&&q.indexOf("debug")<0&&E.getExtension(q)})}},populateUniformTable:function(S){for(var E=Je.programs[S],L=Je.programInfos[S]={uniforms:{},maxUniformLength:0,maxAttributeLength:-1,maxUniformBlockNameLength:-1},q=L.uniforms,pe=yr.getProgramParameter(E,35718),le=0;le>2,q=o()[L+(24>>2)],pe={alpha:!!o()[L+(0>>2)],depth:!!o()[L+(4>>2)],stencil:!!o()[L+(8>>2)],antialias:!!o()[L+(12>>2)],premultipliedAlpha:!!o()[L+(16>>2)],preserveDrawingBuffer:!!o()[L+(20>>2)],powerPreference:Rf[q],failIfMajorPerformanceCaveat:!!o()[L+(28>>2)],majorVersion:o()[L+(32>>2)],minorVersion:o()[L+(36>>2)],enableExtensionsByDefault:o()[L+(40>>2)],explicitSwapControl:o()[L+(44>>2)],proxyContextToMainThread:o()[L+(48>>2)],renderViaOffscreenBackBuffer:o()[L+(52>>2)]},le=ru(S);if(!le||pe.explicitSwapControl)return 0;var ue=Je.createContext(le,pe);return ue}function Ff(S,E){return Mf(S,E)}var Vi={mappings:{},buffers:[null,[],[]],printChar:function(S,E){var L=Vi.buffers[S];E===0||E===10?((S===1?X:G)(ze(L,0)),L.length=0):L.push(E)},varargs:void 0,get:function(){Vi.varargs+=4;var S=o()[Vi.varargs-4>>2];return S},getStr:function(S){var E=De(S);return E},get64:function(S,E){return S}};function pp(S){return v?Ar(3,1,S):0}function cp(S,E,L,q,pe){if(v)return Ar(4,1,S,E,L,q,pe)}function hp(S,E,L,q){if(v)return Ar(5,1,S,E,L,q);for(var pe=0,le=0;le>2],be=o()[E+(le*8+4)>>2],tt=0;tt>2]=pe,0}function $f(S){var E=we.threadExitHandlers.pop();S&&E()}function Df(S,E){we.threadExitHandlers.push(function(){ea.get(S)(E)})}function fp(S){if(v)throw"Internal Error! spawnThread() can only ever be called from main application thread!";var E=we.getNewWorker();if(E.pthread!==void 0)throw"Internal error!";if(!S.pthread_ptr)throw"Internal error, no pthread ptr!";we.runningWorkers.push(E);for(var L=ns(128*4),q=0;q<128;++q)o()[L+q*4>>2]=0;var pe=S.stackBase+S.stackSize,le=we.pthreads[S.pthread_ptr]={worker:E,stackBase:S.stackBase,stackSize:S.stackSize,allocatedOwnStack:S.allocatedOwnStack,threadInfoStruct:S.pthread_ptr},ue=le.threadInfoStruct>>2;Atomics.store(l(),ue+(64>>2),S.detached),Atomics.store(l(),ue+(100>>2),L),Atomics.store(l(),ue+(40>>2),le.threadInfoStruct),Atomics.store(l(),ue+(80>>2),S.stackSize),Atomics.store(l(),ue+(76>>2),pe),Atomics.store(l(),ue+(104>>2),S.stackSize),Atomics.store(l(),ue+(104+8>>2),pe),Atomics.store(l(),ue+(104+12>>2),S.detached);var be=Tg(),tt=be+40;Atomics.store(l(),ue+(172>>2),tt),E.pthread=le;var Bt={cmd:"run",start_routine:S.startRoutine,arg:S.arg,threadInfoStruct:S.pthread_ptr,stackBase:S.stackBase,stackSize:S.stackSize};E.runPthread=function(){Bt.time=performance.now(),E.postMessage(Bt,S.transferList)},E.loaded&&(E.runPthread(),delete E.runPthread)}function Of(S,E,L,q){if(typeof SharedArrayBuffer=="undefined")return G("Current environment does not support SharedArrayBuffer, pthreads are not available!"),6;if(!S)return G("pthread_create called with a null thread pointer!"),28;var pe=[],le=0;if(v&&(pe.length===0||le))return Mg(687865856,S,E,L,q);if(le)return le;var ue=0,be=0,tt=0;E&&E!=-1?(ue=o()[E>>2],ue+=81920,be=o()[E+8>>2],tt=o()[E+12>>2]!==0):ue=2097152;var Bt=be==0;Bt?be=Dg(16,ue):(be-=ue,ce(be>0));for(var $t=ns(228),xr=0;xr<228>>2;++xr)l()[($t>>2)+xr]=0;o()[S>>2]=$t,o()[$t+12>>2]=$t;var Xi=$t+152;o()[Xi>>2]=Xi;var bn={stackBase:be,stackSize:ue,allocatedOwnStack:Bt,detached:tt,startRoutine:L,pthread_ptr:$t,arg:q,transferList:pe};return v?(bn.cmd="spawnThread",postMessage(bn,pe)):fp(bn),0}function mp(S){if(v)return Ar(6,1,S);switch(S){case 30:return 16384;case 85:var E=2147483648;return E/16384;case 132:case 133:case 12:case 137:case 138:case 15:case 235:case 16:case 17:case 18:case 19:case 20:case 149:case 13:case 10:case 236:case 153:case 9:case 21:case 22:case 159:case 154:case 14:case 77:case 78:case 139:case 82:case 68:case 67:case 164:case 11:case 29:case 47:case 48:case 95:case 52:case 51:case 46:return 200809;case 27:case 246:case 127:case 128:case 23:case 24:case 160:case 161:case 181:case 182:case 242:case 183:case 184:case 243:case 244:case 245:case 165:case 178:case 179:case 49:case 50:case 168:case 169:case 175:case 170:case 171:case 172:case 97:case 76:case 32:case 173:case 35:case 80:case 81:case 79:return-1;case 176:case 177:case 7:case 155:case 8:case 157:case 125:case 126:case 92:case 93:case 129:case 130:case 131:case 94:case 91:return 1;case 74:case 60:case 69:case 70:case 4:return 1024;case 31:case 42:case 72:return 32;case 87:case 26:case 33:return 2147483647;case 34:case 1:return 47839;case 38:case 36:return 99;case 43:case 37:return 2048;case 0:return 2097152;case 3:return 65536;case 28:return 32768;case 44:return 32767;case 75:return 16384;case 39:return 1e3;case 89:return 700;case 71:return 256;case 40:return 255;case 2:return 100;case 180:return 64;case 25:return 20;case 5:return 16;case 6:return 6;case 73:return 4;case 84:return typeof navigator=="object"&&navigator.hardwareConcurrency||1}return nf(28),-1}v||we.initMainThreadBlock();var yr,zf=[null,af,dp,pp,cp,hp,mp],_f={e:ef,r:tf,x:rf,b:sf,y:of,j:lf,c:uf,d:tu,f:ts,p:df,z:pf,u:hf,q:Af,v:kf,i:If,t:Sf,w:Ff,m:pp,n:cp,g:hp,o:lp,a:Q||u.wasmMemory,k:$f,l:Df,h:Of,s:mp},Sg=G0(),Ap=u.___wasm_call_ctors=function(){return(Ap=u.___wasm_call_ctors=u.asm.A).apply(null,arguments)},Pf=u._init=function(){return(Pf=u._init=u.asm.B).apply(null,arguments)},Lf=u._register_tensor=function(){return(Lf=u._register_tensor=u.asm.C).apply(null,arguments)},Wf=u._dispose_data=function(){return(Wf=u._dispose_data=u.asm.D).apply(null,arguments)},Bf=u._dispose=function(){return(Bf=u._dispose=u.asm.E).apply(null,arguments)},Vf=u._Abs=function(){return(Vf=u._Abs=u.asm.G).apply(null,arguments)},jf=u._Add=function(){return(jf=u._Add=u.asm.H).apply(null,arguments)},Uf=u._AddN=function(){return(Uf=u._AddN=u.asm.I).apply(null,arguments)},Hf=u._All=function(){return(Hf=u._All=u.asm.J).apply(null,arguments)},Gf=u._Any=function(){return(Gf=u._Any=u.asm.K).apply(null,arguments)},qf=u._ArgMax=function(){return(qf=u._ArgMax=u.asm.L).apply(null,arguments)},Xf=u._AvgPool=function(){return(Xf=u._AvgPool=u.asm.M).apply(null,arguments)},Kf=u._BatchMatMul=function(){return(Kf=u._BatchMatMul=u.asm.N).apply(null,arguments)},Zf=u._Ceil=function(){return(Zf=u._Ceil=u.asm.O).apply(null,arguments)},Yf=u._ClipByValue=function(){return(Yf=u._ClipByValue=u.asm.P).apply(null,arguments)},Jf=u._Conv2D=function(){return(Jf=u._Conv2D=u.asm.Q).apply(null,arguments)},Qf=u._Conv2DBackpropInput=function(){return(Qf=u._Conv2DBackpropInput=u.asm.R).apply(null,arguments)},em=u._Cos=function(){return(em=u._Cos=u.asm.S).apply(null,arguments)},tm=u._CropAndResize=function(){return(tm=u._CropAndResize=u.asm.T).apply(null,arguments)},nm=u._Cumsum=function(){return(nm=u._Cumsum=u.asm.U).apply(null,arguments)},am=u._DepthToSpace=function(){return(am=u._DepthToSpace=u.asm.V).apply(null,arguments)},rm=u._DepthwiseConv2dNative=function(){return(rm=u._DepthwiseConv2dNative=u.asm.W).apply(null,arguments)},yp=u._Equal=function(){return(yp=u._Equal=u.asm.X).apply(null,arguments)},gp=u._Exp=function(){return(gp=u._Exp=u.asm.Y).apply(null,arguments)},xp=u._FlipLeftRight=function(){return(xp=u._FlipLeftRight=u.asm.Z).apply(null,arguments)},su=u._Floor=function(){return(su=u._Floor=u.asm._).apply(null,arguments)},ji=u._FloorDiv=function(){return(ji=u._FloorDiv=u.asm.$).apply(null,arguments)},sm=u._FusedBatchNorm=function(){return(sm=u._FusedBatchNorm=u.asm.aa).apply(null,arguments)},iu=u._FusedConv2D=function(){return(iu=u._FusedConv2D=u.asm.ba).apply(null,arguments)},K=u._FusedDepthwiseConv2D=function(){return(K=u._FusedDepthwiseConv2D=u.asm.ca).apply(null,arguments)},te=u._Gather=function(){return(te=u._Gather=u.asm.da).apply(null,arguments)},Te=u._GatherNd=function(){return(Te=u._GatherNd=u.asm.ea).apply(null,arguments)},Ke=u._Greater=function(){return(Ke=u._Greater=u.asm.fa).apply(null,arguments)},It=u._GreaterEqual=function(){return(It=u._GreaterEqual=u.asm.ga).apply(null,arguments)},ft=u._LeakyRelu=function(){return(ft=u._LeakyRelu=u.asm.ha).apply(null,arguments)},je=u._Less=function(){return(je=u._Less=u.asm.ia).apply(null,arguments)},He=u._LessEqual=function(){return(He=u._LessEqual=u.asm.ja).apply(null,arguments)},Zt=u._Log=function(){return(Zt=u._Log=u.asm.ka).apply(null,arguments)},Ya=u._LogicalAnd=function(){return(Ya=u._LogicalAnd=u.asm.la).apply(null,arguments)},Ja=u._Max=function(){return(Ja=u._Max=u.asm.ma).apply(null,arguments)},bp=u._MaxPool=function(){return(bp=u._MaxPool=u.asm.na).apply(null,arguments)},ou=u._Maximum=function(){return(ou=u._Maximum=u.asm.oa).apply(null,arguments)},Un=u._Mean=function(){return(Un=u._Mean=u.asm.pa).apply(null,arguments)},gr=u._Min=function(){return(gr=u._Min=u.asm.qa).apply(null,arguments)},vp=u._Minimum=function(){return(vp=u._Minimum=u.asm.ra).apply(null,arguments)},Zk=u._MirrorPad=function(){return(Zk=u._MirrorPad=u.asm.sa).apply(null,arguments)},Yk=u._Multiply=function(){return(Yk=u._Multiply=u.asm.ta).apply(null,arguments)},Jk=u._Neg=function(){return(Jk=u._Neg=u.asm.ua).apply(null,arguments)},Qk=u._NonMaxSuppressionV3=function(){return(Qk=u._NonMaxSuppressionV3=u.asm.va).apply(null,arguments)},e9=u._NonMaxSuppressionV4=function(){return(e9=u._NonMaxSuppressionV4=u.asm.wa).apply(null,arguments)},t9=u._NonMaxSuppressionV5=function(){return(t9=u._NonMaxSuppressionV5=u.asm.xa).apply(null,arguments)},n9=u._NotEqual=function(){return(n9=u._NotEqual=u.asm.ya).apply(null,arguments)},a9=u._OneHot=function(){return(a9=u._OneHot=u.asm.za).apply(null,arguments)},r9=u._PadV2=function(){return(r9=u._PadV2=u.asm.Aa).apply(null,arguments)},s9=u._Pow=function(){return(s9=u._Pow=u.asm.Ba).apply(null,arguments)},i9=u._Prelu=function(){return(i9=u._Prelu=u.asm.Ca).apply(null,arguments)},o9=u._Prod=function(){return(o9=u._Prod=u.asm.Da).apply(null,arguments)},l9=u._RealDiv=function(){return(l9=u._RealDiv=u.asm.Ea).apply(null,arguments)},u9=u._Relu=function(){return(u9=u._Relu=u.asm.Fa).apply(null,arguments)},d9=u._Relu6=function(){return(d9=u._Relu6=u.asm.Ga).apply(null,arguments)},p9=u._ResizeBilinear=function(){return(p9=u._ResizeBilinear=u.asm.Ha).apply(null,arguments)},c9=u._Reverse=function(){return(c9=u._Reverse=u.asm.Ia).apply(null,arguments)},h9=u._RotateWithOffset=function(){return(h9=u._RotateWithOffset=u.asm.Ja).apply(null,arguments)},f9=u._Round=function(){return(f9=u._Round=u.asm.Ka).apply(null,arguments)},m9=u._Rsqrt=function(){return(m9=u._Rsqrt=u.asm.La).apply(null,arguments)},A9=u._ScatterNd=function(){return(A9=u._ScatterNd=u.asm.Ma).apply(null,arguments)},y9=u._SelectV2=function(){return(y9=u._SelectV2=u.asm.Na).apply(null,arguments)},g9=u._Sigmoid=function(){return(g9=u._Sigmoid=u.asm.Oa).apply(null,arguments)},x9=u._Sin=function(){return(x9=u._Sin=u.asm.Pa).apply(null,arguments)},b9=u._Softmax=function(){return(b9=u._Softmax=u.asm.Qa).apply(null,arguments)},v9=u._Sqrt=function(){return(v9=u._Sqrt=u.asm.Ra).apply(null,arguments)},w9=u._Square=function(){return(w9=u._Square=u.asm.Sa).apply(null,arguments)},k9=u._SquaredDifference=function(){return(k9=u._SquaredDifference=u.asm.Ta).apply(null,arguments)},I9=u._Step=function(){return(I9=u._Step=u.asm.Ua).apply(null,arguments)},S9=u._StridedSlice=function(){return(S9=u._StridedSlice=u.asm.Va).apply(null,arguments)},N9=u._Sub=function(){return(N9=u._Sub=u.asm.Wa).apply(null,arguments)},T9=u._Sum=function(){return(T9=u._Sum=u.asm.Xa).apply(null,arguments)},E9=u._Tan=function(){return(E9=u._Tan=u.asm.Ya).apply(null,arguments)},C9=u._Tanh=function(){return(C9=u._Tanh=u.asm.Za).apply(null,arguments)},R9=u._Tile=function(){return(R9=u._Tile=u.asm._a).apply(null,arguments)},M9=u._TopK=function(){return(M9=u._TopK=u.asm.$a).apply(null,arguments)},F9=u._Transform=function(){return(F9=u._Transform=u.asm.ab).apply(null,arguments)},$9=u._Transpose=function(){return($9=u._Transpose=u.asm.bb).apply(null,arguments)},D9=u.__FusedMatMul=function(){return(D9=u.__FusedMatMul=u.asm.cb).apply(null,arguments)},ns=u._malloc=function(){return(ns=u._malloc=u.asm.db).apply(null,arguments)},lu=u._free=function(){return(lu=u._free=u.asm.eb).apply(null,arguments)},Ng=u.___errno_location=function(){return(Ng=u.___errno_location=u.asm.fb).apply(null,arguments)},Tg=u._emscripten_get_global_libc=function(){return(Tg=u._emscripten_get_global_libc=u.asm.gb).apply(null,arguments)},Ui=u._pthread_self=function(){return(Ui=u._pthread_self=u.asm.hb).apply(null,arguments)},Eg=u.___pthread_tsd_run_dtors=function(){return(Eg=u.___pthread_tsd_run_dtors=u.asm.ib).apply(null,arguments)},im=u._emscripten_main_thread_process_queued_calls=function(){return(im=u._emscripten_main_thread_process_queued_calls=u.asm.jb).apply(null,arguments)},O9=u._emscripten_current_thread_process_queued_calls=function(){return(O9=u._emscripten_current_thread_process_queued_calls=u.asm.kb).apply(null,arguments)},Cg=u._emscripten_register_main_browser_thread_id=function(){return(Cg=u._emscripten_register_main_browser_thread_id=u.asm.lb).apply(null,arguments)},Rg=u.__emscripten_do_dispatch_to_thread=function(){return(Rg=u.__emscripten_do_dispatch_to_thread=u.asm.mb).apply(null,arguments)},Mg=u._emscripten_sync_run_in_main_thread_4=function(){return(Mg=u._emscripten_sync_run_in_main_thread_4=u.asm.nb).apply(null,arguments)},Fg=u._emscripten_run_in_main_runtime_thread_js=function(){return(Fg=u._emscripten_run_in_main_runtime_thread_js=u.asm.ob).apply(null,arguments)},om=u.__emscripten_call_on_thread=function(){return(om=u.__emscripten_call_on_thread=u.asm.pb).apply(null,arguments)},z9=u._emscripten_tls_init=function(){return(z9=u._emscripten_tls_init=u.asm.qb).apply(null,arguments)},lm=u.__emscripten_thread_init=function(){return(lm=u.__emscripten_thread_init=u.asm.rb).apply(null,arguments)},uu=u.stackSave=function(){return(uu=u.stackSave=u.asm.sb).apply(null,arguments)},Hi=u.stackRestore=function(){return(Hi=u.stackRestore=u.asm.tb).apply(null,arguments)},Gi=u.stackAlloc=function(){return(Gi=u.stackAlloc=u.asm.ub).apply(null,arguments)},$g=u._emscripten_stack_set_limits=function(){return($g=u._emscripten_stack_set_limits=u.asm.vb).apply(null,arguments)},Dg=u._memalign=function(){return(Dg=u._memalign=u.asm.wb).apply(null,arguments)},Og=u.__emscripten_allow_main_runtime_queued_calls=9808,qi=u.__emscripten_main_thread_futex=11432;u.cwrap=$e,u.PThread=we,u.PThread=we,u.wasmMemory=Q,u.ExitStatus=du;var wp;function du(S){this.name="ExitStatus",this.message="Program terminated with exit("+S+")",this.status=S}es=function S(){wp||um(),wp||(es=S)};function um(S){if(S=S||f,Ka>0)return;if(v){p(u),eu(),postMessage({cmd:"loaded"});return}if(L0(),Ka>0)return;function E(){wp||(wp=!0,u.calledRun=!0,!oe&&(eu(),W0(),p(u),u.onRuntimeInitialized&&u.onRuntimeInitialized(),gn()))}u.setStatus?(u.setStatus("Running..."),setTimeout(function(){setTimeout(function(){u.setStatus("")},1),E()},1)):E()}u.run=um;function _9(S,E){if(!(E&&ie&&S===0)){if(!E&&v)throw postMessage({cmd:"exitProcess",returnCode:S}),new du(S);ie||(we.terminateAllThreads(),ye=S,np(),u.onExit&&u.onExit(S),oe=!0),y(S,new du(S))}}if(u.preInit)for(typeof u.preInit=="function"&&(u.preInit=[u.preInit]);u.preInit.length>0;)u.preInit.pop()();return v&&(ie=!1,we.initWorker()),um(),r.ready}}();typeof e=="object"&&typeof t=="object"?t.exports=n:typeof define=="function"&&define.amd?define([],function(){return n}):typeof e=="object"&&(e.WasmBackendModuleThreadedSimd=n)}),aI=xt((e,t)=>{var n=function(){var a=typeof document!="undefined"&&document.currentScript?document.currentScript.src:void 0;return typeof __filename!="undefined"&&(a=a||__filename),function(r){r=r||{};var s=typeof r!="undefined"?r:{},i,o;s.ready=new Promise(function(K,te){i=K,o=te});var l={},d;for(d in s)s.hasOwnProperty(d)&&(l[d]=s[d]);var u=[],p="./this.program",c=function(K,te){throw te},h=!1,m=!1,f=!1,A=!1;h=typeof window=="object",m=typeof importScripts=="function",f=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",A=!h&&!f&&!m;var y="";function g(K){return s.locateFile?s.locateFile(K,y):y+K}var x,w,b,v,N,T;f?(m?y=cu().dirname(y)+"/":y=__dirname+"/",x=function(K,te){return N||(N=require("fs")),T||(T=cu()),K=T.normalize(K),N.readFileSync(K,te?null:"utf8")},b=function(K){var te=x(K,!0);return te.buffer||(te=new Uint8Array(te)),X(te.buffer),te},process.argv.length>1&&(p=process.argv[1].replace(/\\/g,"/")),u=process.argv.slice(2),process.on("uncaughtException",function(K){if(!(K instanceof sm))throw K}),process.on("unhandledRejection",Ra),c=function(K){process.exit(K)},s.inspect=function(){return"[Emscripten Module object]"}):A?(typeof read!="undefined"&&(x=function(K){return read(K)}),b=function(K){var te;return typeof readbuffer=="function"?new Uint8Array(readbuffer(K)):(te=read(K,"binary"),X(typeof te=="object"),te)},typeof scriptArgs!="undefined"?u=scriptArgs:typeof arguments!="undefined"&&(u=arguments),typeof quit=="function"&&(c=function(K){quit(K)}),typeof print!="undefined"&&(typeof console=="undefined"&&(console={}),console.log=print,console.warn=console.error=typeof printErr!="undefined"?printErr:print)):(h||m)&&(m?y=self.location.href:typeof document!="undefined"&&document.currentScript&&(y=document.currentScript.src),a&&(y=a),y.indexOf("blob:")!==0?y=y.substr(0,y.lastIndexOf("/")+1):y="",x=function(K){var te=new XMLHttpRequest;return te.open("GET",K,!1),te.send(null),te.responseText},m&&(b=function(K){var te=new XMLHttpRequest;return te.open("GET",K,!1),te.responseType="arraybuffer",te.send(null),new Uint8Array(te.response)}),w=function(K,te,Te){var Ke=new XMLHttpRequest;Ke.open("GET",K,!0),Ke.responseType="arraybuffer",Ke.onload=function(){if(Ke.status==200||Ke.status==0&&Ke.response){te(Ke.response);return}Te()},Ke.onerror=Te,Ke.send(null)},v=function(K){document.title=K});var R=s.print||console.log.bind(console),$=s.printErr||console.warn.bind(console);for(d in l)l.hasOwnProperty(d)&&(s[d]=l[d]);l=null,s.arguments&&(u=s.arguments),s.thisProgram&&(p=s.thisProgram),s.quit&&(c=s.quit);var z;s.wasmBinary&&(z=s.wasmBinary);var P=s.noExitRuntime||!0;typeof WebAssembly!="object"&&Ra("no native wasm support detected");var V,j=!1,U;function X(K,te){K||Ra("Assertion failed: "+te)}function G(K){var te=s["_"+K];return X(te,"Cannot call unknown function "+K+", make sure it is exported"),te}function ee(K,te,Te,Ke,It){var ft={string:function(Un){var gr=0;if(Un!=null&&Un!==0){var vp=(Un.length<<2)+1;gr=su(vp),de(Un,gr,vp)}return gr},array:function(Un){var gr=su(Un.length);return oe(Un,gr),gr}};function je(Un){return te==="string"?ie(Un):te==="boolean"?Boolean(Un):Un}var He=G(K),Zt=[],Ya=0;if(Ke)for(var Ja=0;Ja=Ke);)++It;if(It-te>16&&K.subarray&&re)return re.decode(K.subarray(te,It));for(var ft="";te>10,56320|Ya&1023)}}return ft}function ie(K,te){return K?ne(Ne,K,te):""}function Q(K,te,Te,Ke){if(!(Ke>0))return 0;for(var It=Te,ft=Te+Ke-1,je=0;je=55296&&He<=57343){var Zt=K.charCodeAt(++je);He=65536+((He&1023)<<10)|Zt&1023}if(He<=127){if(Te>=ft)break;te[Te++]=He}else if(He<=2047){if(Te+1>=ft)break;te[Te++]=192|He>>6,te[Te++]=128|He&63}else if(He<=65535){if(Te+2>=ft)break;te[Te++]=224|He>>12,te[Te++]=128|He>>6&63,te[Te++]=128|He&63}else{if(Te+3>=ft)break;te[Te++]=240|He>>18,te[Te++]=128|He>>12&63,te[Te++]=128|He>>6&63,te[Te++]=128|He&63}}return te[Te]=0,Te-It}function de(K,te,Te){return Q(K,Ne,te,Te)}function oe(K,te){Ie.set(K,te)}function ye(K,te){return K%te>0&&(K+=te-K%te),K}var ce,Ie,Ne,$e,ze,De,Qe,et,rt;function Xe(K){ce=K,s.HEAP8=Ie=new Int8Array(K),s.HEAP16=$e=new Int16Array(K),s.HEAP32=De=new Int32Array(K),s.HEAPU8=Ne=new Uint8Array(K),s.HEAPU16=ze=new Uint16Array(K),s.HEAPU32=Qe=new Uint32Array(K),s.HEAPF32=et=new Float32Array(K),s.HEAPF64=rt=new Float64Array(K)}var dt=s.INITIAL_MEMORY||16777216,Ve,An=[],gt=[],Vn=[],Xt=[],yn=!1;gt.push({func:function(){lp()}});function jn(){if(s.preRun)for(typeof s.preRun=="function"&&(s.preRun=[s.preRun]);s.preRun.length;)Ca(s.preRun.shift());mr(An)}function Rn(){yn=!0,mr(gt)}function rn(){mr(Vn)}function Kt(){if(s.postRun)for(typeof s.postRun=="function"&&(s.postRun=[s.postRun]);s.postRun.length;)ea(s.postRun.shift());mr(Xt)}function Ca(K){An.unshift(K)}function ea(K){Xt.unshift(K)}var ta=0,hr=null,Xa=null;function fr(K){ta++,s.monitorRunDependencies&&s.monitorRunDependencies(ta)}function Li(K){if(ta--,s.monitorRunDependencies&&s.monitorRunDependencies(ta),ta==0&&(hr!==null&&(clearInterval(hr),hr=null),Xa)){var te=Xa;Xa=null,te()}}s.preloadedImages={},s.preloadedAudios={};function Ra(K){s.onAbort&&s.onAbort(K),K+="",$(K),j=!0,U=1,K="abort("+K+"). Build with -s ASSERTIONS=1 for more info.";var te=new WebAssembly.RuntimeError(K);throw o(te),te}function tp(K,te){return String.prototype.startsWith?K.startsWith(te):K.indexOf(te)===0}var L0="data:application/octet-stream;base64,";function eu(K){return tp(K,L0)}var W0="file://";function np(K){return tp(K,W0)}var gn="tfjs-backend-wasm.wasm";eu(gn)||(gn=g(gn));function ap(K){try{if(K==gn&&z)return new Uint8Array(z);if(b)return b(K);throw"both async and sync fetching of the wasm failed"}catch(te){Ra(te)}}function B0(){if(!z&&(h||m)){if(typeof fetch=="function"&&!np(gn))return fetch(gn,{credentials:"same-origin"}).then(function(K){if(!K.ok)throw"failed to load wasm binary file at '"+gn+"'";return K.arrayBuffer()}).catch(function(){return ap(gn)});if(w)return new Promise(function(K,te){w(gn,function(Te){K(new Uint8Array(Te))},te)})}return Promise.resolve().then(function(){return ap(gn)})}function Ka(){var K={a:G0};function te(je,He){var Zt=je.exports;s.asm=Zt,V=s.asm.i,Xe(V.buffer),Ve=s.asm.o,Li("wasm-instantiate")}fr("wasm-instantiate");function Te(je){te(je.instance)}function Ke(je){return B0().then(function(He){return WebAssembly.instantiate(He,K)}).then(je,function(He){$("failed to asynchronously prepare wasm: "+He),Ra(He)})}function It(){return!z&&typeof WebAssembly.instantiateStreaming=="function"&&!eu(gn)&&!np(gn)&&typeof fetch=="function"?fetch(gn,{credentials:"same-origin"}).then(function(je){var He=WebAssembly.instantiateStreaming(je,K);return He.then(Te,function(Zt){return $("wasm streaming compile failed: "+Zt),$("falling back to ArrayBuffer instantiation"),Ke(Te)})}):Ke(Te)}if(s.instantiateWasm)try{var ft=s.instantiateWasm(K,te);return ft}catch(je){return $("Module.instantiateWasm callback failed with error: "+je),!1}return It().catch(o),{}}function mr(K){for(;K.length>0;){var te=K.shift();if(typeof te=="function"){te(s);continue}var Te=te.func;typeof Te=="number"?te.arg===void 0?Ve.get(Te)():Ve.get(Te)(te.arg):Te(te.arg===void 0?null:te.arg)}}function es(){Ra()}function V0(K,te,Te){Ne.copyWithin(K,te,te+Te)}function j0(){return Ne.length}function Za(K){try{return V.grow(K-ce.byteLength+65535>>>16),Xe(V.buffer),1}catch(te){}}function rp(K){var te=j0(),Te=2147483648;if(K>Te)return!1;for(var Ke=1;Ke<=4;Ke*=2){var It=te*(1+.2/Ke);It=Math.min(It,K+100663296);var ft=Math.min(Te,ye(Math.max(K,It),65536)),je=Za(ft);if(je)return!0}return!1}var Wi={mappings:{},buffers:[null,[],[]],printChar:function(K,te){var Te=Wi.buffers[K];te===0||te===10?((K===1?R:$)(ne(Te,0)),Te.length=0):Te.push(te)},varargs:void 0,get:function(){Wi.varargs+=4;var K=De[Wi.varargs-4>>2];return K},getStr:function(K){var te=ie(K);return te},get64:function(K,te){return K}};function sp(K){return 0}function U0(K,te,Te,Ke,It){}function ip(K,te,Te,Ke){for(var It=0,ft=0;ft>2],He=De[te+(ft*8+4)>>2],Zt=0;Zt>2]=It,0}function xn(){return 6}function op(K){return De[yp()>>2]=K,K}function H0(K){switch(K){case 30:return 16384;case 85:var te=2147483648;return te/16384;case 132:case 133:case 12:case 137:case 138:case 15:case 235:case 16:case 17:case 18:case 19:case 20:case 149:case 13:case 10:case 236:case 153:case 9:case 21:case 22:case 159:case 154:case 14:case 77:case 78:case 139:case 82:case 68:case 67:case 164:case 11:case 29:case 47:case 48:case 95:case 52:case 51:case 46:return 200809;case 27:case 246:case 127:case 128:case 23:case 24:case 160:case 161:case 181:case 182:case 242:case 183:case 184:case 243:case 244:case 245:case 165:case 178:case 179:case 49:case 50:case 168:case 169:case 175:case 170:case 171:case 172:case 97:case 76:case 32:case 173:case 35:case 80:case 81:case 79:return-1;case 176:case 177:case 7:case 155:case 8:case 157:case 125:case 126:case 92:case 93:case 129:case 130:case 131:case 94:case 91:return 1;case 74:case 60:case 69:case 70:case 4:return 1024;case 31:case 42:case 72:return 32;case 87:case 26:case 33:return 2147483647;case 34:case 1:return 47839;case 38:case 36:return 99;case 43:case 37:return 2048;case 0:return 2097152;case 3:return 65536;case 28:return 32768;case 44:return 32767;case 75:return 16384;case 39:return 1e3;case 89:return 700;case 71:return 256;case 40:return 255;case 2:return 100;case 180:return 64;case 25:return 20;case 5:return 16;case 6:return 6;case 73:return 4;case 84:return typeof navigator=="object"&&navigator.hardwareConcurrency||1}return op(28),-1}var G0={a:es,d:V0,e:rp,f:sp,c:U0,b:ip,g:xn,h:H0},q0=Ka(),lp=s.___wasm_call_ctors=function(){return(lp=s.___wasm_call_ctors=s.asm.j).apply(null,arguments)},Bi=s._init=function(){return(Bi=s._init=s.asm.k).apply(null,arguments)},tu=s._register_tensor=function(){return(tu=s._register_tensor=s.asm.l).apply(null,arguments)},X0=s._dispose_data=function(){return(X0=s._dispose_data=s.asm.m).apply(null,arguments)},K0=s._dispose=function(){return(K0=s._dispose=s.asm.n).apply(null,arguments)},Z0=s._Abs=function(){return(Z0=s._Abs=s.asm.p).apply(null,arguments)},we=s._Add=function(){return(we=s._Add=s.asm.q).apply(null,arguments)},Y0=s._AddN=function(){return(Y0=s._AddN=s.asm.r).apply(null,arguments)},J0=s._All=function(){return(J0=s._All=s.asm.s).apply(null,arguments)},Q0=s._Any=function(){return(Q0=s._Any=s.asm.t).apply(null,arguments)},ef=s._ArgMax=function(){return(ef=s._ArgMax=s.asm.u).apply(null,arguments)},tf=s._AvgPool=function(){return(tf=s._AvgPool=s.asm.v).apply(null,arguments)},ts=s._BatchMatMul=function(){return(ts=s._BatchMatMul=s.asm.w).apply(null,arguments)},nf=s._Ceil=function(){return(nf=s._Ceil=s.asm.x).apply(null,arguments)},af=s._ClipByValue=function(){return(af=s._ClipByValue=s.asm.y).apply(null,arguments)},rf=s._Conv2D=function(){return(rf=s._Conv2D=s.asm.z).apply(null,arguments)},sf=s._Conv2DBackpropInput=function(){return(sf=s._Conv2DBackpropInput=s.asm.A).apply(null,arguments)},of=s._Cos=function(){return(of=s._Cos=s.asm.B).apply(null,arguments)},lf=s._CropAndResize=function(){return(lf=s._CropAndResize=s.asm.C).apply(null,arguments)},uf=s._Cumsum=function(){return(uf=s._Cumsum=s.asm.D).apply(null,arguments)},df=s._DepthToSpace=function(){return(df=s._DepthToSpace=s.asm.E).apply(null,arguments)},pf=s._DepthwiseConv2dNative=function(){return(pf=s._DepthwiseConv2dNative=s.asm.F).apply(null,arguments)},Ar=s._Equal=function(){return(Ar=s._Equal=s.asm.G).apply(null,arguments)},nu=s._Exp=function(){return(nu=s._Exp=s.asm.H).apply(null,arguments)},au=s._FlipLeftRight=function(){return(au=s._FlipLeftRight=s.asm.I).apply(null,arguments)},cf=s._Floor=function(){return(cf=s._Floor=s.asm.J).apply(null,arguments)},hf=s._FloorDiv=function(){return(hf=s._FloorDiv=s.asm.K).apply(null,arguments)},ff=s._FusedBatchNorm=function(){return(ff=s._FusedBatchNorm=s.asm.L).apply(null,arguments)},mf=s._FusedConv2D=function(){return(mf=s._FusedConv2D=s.asm.M).apply(null,arguments)},Af=s._FusedDepthwiseConv2D=function(){return(Af=s._FusedDepthwiseConv2D=s.asm.N).apply(null,arguments)},Pe=s._Gather=function(){return(Pe=s._Gather=s.asm.O).apply(null,arguments)},yf=s._GatherNd=function(){return(yf=s._GatherNd=s.asm.P).apply(null,arguments)},gf=s._Greater=function(){return(gf=s._Greater=s.asm.Q).apply(null,arguments)},xf=s._GreaterEqual=function(){return(xf=s._GreaterEqual=s.asm.R).apply(null,arguments)},bf=s._LeakyRelu=function(){return(bf=s._LeakyRelu=s.asm.S).apply(null,arguments)},vf=s._Less=function(){return(vf=s._Less=s.asm.T).apply(null,arguments)},wf=s._LessEqual=function(){return(wf=s._LessEqual=s.asm.U).apply(null,arguments)},ru=s._Log=function(){return(ru=s._Log=s.asm.V).apply(null,arguments)},up=s._LogicalAnd=function(){return(up=s._LogicalAnd=s.asm.W).apply(null,arguments)},dp=s._Max=function(){return(dp=s._Max=s.asm.X).apply(null,arguments)},kf=s._MaxPool=function(){return(kf=s._MaxPool=s.asm.Y).apply(null,arguments)},If=s._Maximum=function(){return(If=s._Maximum=s.asm.Z).apply(null,arguments)},Sf=s._Mean=function(){return(Sf=s._Mean=s.asm._).apply(null,arguments)},Nf=s._Min=function(){return(Nf=s._Min=s.asm.$).apply(null,arguments)},Tf=s._Minimum=function(){return(Tf=s._Minimum=s.asm.aa).apply(null,arguments)},Ef=s._MirrorPad=function(){return(Ef=s._MirrorPad=s.asm.ba).apply(null,arguments)},Cf=s._Multiply=function(){return(Cf=s._Multiply=s.asm.ca).apply(null,arguments)},Je=s._Neg=function(){return(Je=s._Neg=s.asm.da).apply(null,arguments)},Rf=s._NonMaxSuppressionV3=function(){return(Rf=s._NonMaxSuppressionV3=s.asm.ea).apply(null,arguments)},Mf=s._NonMaxSuppressionV4=function(){return(Mf=s._NonMaxSuppressionV4=s.asm.fa).apply(null,arguments)},Ff=s._NonMaxSuppressionV5=function(){return(Ff=s._NonMaxSuppressionV5=s.asm.ga).apply(null,arguments)},Vi=s._NotEqual=function(){return(Vi=s._NotEqual=s.asm.ha).apply(null,arguments)},pp=s._OneHot=function(){return(pp=s._OneHot=s.asm.ia).apply(null,arguments)},cp=s._PadV2=function(){return(cp=s._PadV2=s.asm.ja).apply(null,arguments)},hp=s._Pow=function(){return(hp=s._Pow=s.asm.ka).apply(null,arguments)},$f=s._Prelu=function(){return($f=s._Prelu=s.asm.la).apply(null,arguments)},Df=s._Prod=function(){return(Df=s._Prod=s.asm.ma).apply(null,arguments)},fp=s._RealDiv=function(){return(fp=s._RealDiv=s.asm.na).apply(null,arguments)},Of=s._Relu=function(){return(Of=s._Relu=s.asm.oa).apply(null,arguments)},mp=s._Relu6=function(){return(mp=s._Relu6=s.asm.pa).apply(null,arguments)},yr=s._ResizeBilinear=function(){return(yr=s._ResizeBilinear=s.asm.qa).apply(null,arguments)},zf=s._Reverse=function(){return(zf=s._Reverse=s.asm.ra).apply(null,arguments)},_f=s._RotateWithOffset=function(){return(_f=s._RotateWithOffset=s.asm.sa).apply(null,arguments)},Sg=s._Round=function(){return(Sg=s._Round=s.asm.ta).apply(null,arguments)},Ap=s._Rsqrt=function(){return(Ap=s._Rsqrt=s.asm.ua).apply(null,arguments)},Pf=s._ScatterNd=function(){return(Pf=s._ScatterNd=s.asm.va).apply(null,arguments)},Lf=s._SelectV2=function(){return(Lf=s._SelectV2=s.asm.wa).apply(null,arguments)},Wf=s._Sigmoid=function(){return(Wf=s._Sigmoid=s.asm.xa).apply(null,arguments)},Bf=s._Sin=function(){return(Bf=s._Sin=s.asm.ya).apply(null,arguments)},Vf=s._Softmax=function(){return(Vf=s._Softmax=s.asm.za).apply(null,arguments)},jf=s._Sqrt=function(){return(jf=s._Sqrt=s.asm.Aa).apply(null,arguments)},Uf=s._Square=function(){return(Uf=s._Square=s.asm.Ba).apply(null,arguments)},Hf=s._SquaredDifference=function(){return(Hf=s._SquaredDifference=s.asm.Ca).apply(null,arguments)},Gf=s._Step=function(){return(Gf=s._Step=s.asm.Da).apply(null,arguments)},qf=s._StridedSlice=function(){return(qf=s._StridedSlice=s.asm.Ea).apply(null,arguments)},Xf=s._Sub=function(){return(Xf=s._Sub=s.asm.Fa).apply(null,arguments)},Kf=s._Sum=function(){return(Kf=s._Sum=s.asm.Ga).apply(null,arguments)},Zf=s._Tan=function(){return(Zf=s._Tan=s.asm.Ha).apply(null,arguments)},Yf=s._Tanh=function(){return(Yf=s._Tanh=s.asm.Ia).apply(null,arguments)},Jf=s._Tile=function(){return(Jf=s._Tile=s.asm.Ja).apply(null,arguments)},Qf=s._TopK=function(){return(Qf=s._TopK=s.asm.Ka).apply(null,arguments)},em=s._Transform=function(){return(em=s._Transform=s.asm.La).apply(null,arguments)},tm=s._Transpose=function(){return(tm=s._Transpose=s.asm.Ma).apply(null,arguments)},nm=s.__FusedMatMul=function(){return(nm=s.__FusedMatMul=s.asm.Na).apply(null,arguments)},am=s._malloc=function(){return(am=s._malloc=s.asm.Oa).apply(null,arguments)},rm=s._free=function(){return(rm=s._free=s.asm.Pa).apply(null,arguments)},yp=s.___errno_location=function(){return(yp=s.___errno_location=s.asm.Qa).apply(null,arguments)},gp=s.stackSave=function(){return(gp=s.stackSave=s.asm.Ra).apply(null,arguments)},xp=s.stackRestore=function(){return(xp=s.stackRestore=s.asm.Sa).apply(null,arguments)},su=s.stackAlloc=function(){return(su=s.stackAlloc=s.asm.Ta).apply(null,arguments)};s.cwrap=Y;var ji;function sm(K){this.name="ExitStatus",this.message="Program terminated with exit("+K+")",this.status=K}Xa=function K(){ji||iu(),ji||(Xa=K)};function iu(K){if(K=K||u,ta>0||(jn(),ta>0))return;function te(){ji||(ji=!0,s.calledRun=!0,!j&&(Rn(),rn(),i(s),s.onRuntimeInitialized&&s.onRuntimeInitialized(),Kt()))}s.setStatus?(s.setStatus("Running..."),setTimeout(function(){setTimeout(function(){s.setStatus("")},1),te()},1)):te()}if(s.run=iu,s.preInit)for(typeof s.preInit=="function"&&(s.preInit=[s.preInit]);s.preInit.length>0;)s.preInit.pop()();return iu(),r.ready}}();typeof e=="object"&&typeof t=="object"?t.exports=n:typeof define=="function"&&define.amd?define([],function(){return n}):typeof e=="object"&&(e.WasmBackendModule=n)}),rI=xt((e,t)=>{(function(n,a,r){function s(d){var u=this,p=l();u.next=function(){var c=2091639*u.s0+u.c*23283064365386963e-26;return u.s0=u.s1,u.s1=u.s2,u.s2=c-(u.c=c|0)},u.c=1,u.s0=p(" "),u.s1=p(" "),u.s2=p(" "),u.s0-=p(d),u.s0<0&&(u.s0+=1),u.s1-=p(d),u.s1<0&&(u.s1+=1),u.s2-=p(d),u.s2<0&&(u.s2+=1),p=null}function i(d,u){return u.c=d.c,u.s0=d.s0,u.s1=d.s1,u.s2=d.s2,u}function o(d,u){var p=new s(d),c=u&&u.state,h=p.next;return h.int32=function(){return p.next()*4294967296|0},h.double=function(){return h()+(h()*2097152|0)*11102230246251565e-32},h.quick=h,c&&(typeof c=="object"&&i(c,p),h.state=function(){return i(p,{})}),h}function l(){var d=4022871197,u=function(p){p=String(p);for(var c=0;c>>0,h-=d,h*=d,d=h>>>0,h-=d,d+=h*4294967296}return(d>>>0)*23283064365386963e-26};return u}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.alea=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),sI=xt((e,t)=>{(function(n,a,r){function s(l){var d=this,u="";d.x=0,d.y=0,d.z=0,d.w=0,d.next=function(){var c=d.x^d.x<<11;return d.x=d.y,d.y=d.z,d.z=d.w,d.w^=d.w>>>19^c^c>>>8},l===(l|0)?d.x=l:u+=l;for(var p=0;p>>0)/4294967296};return c.double=function(){do var h=u.next()>>>11,m=(u.next()>>>0)/4294967296,f=(h+m)/(1<<21);while(f===0);return f},c.int32=u.next,c.quick=c,p&&(typeof p=="object"&&i(p,u),c.state=function(){return i(u,{})}),c}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.xor128=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),iI=xt((e,t)=>{(function(n,a,r){function s(l){var d=this,u="";d.next=function(){var c=d.x^d.x>>>2;return d.x=d.y,d.y=d.z,d.z=d.w,d.w=d.v,(d.d=d.d+362437|0)+(d.v=d.v^d.v<<4^(c^c<<1))|0},d.x=0,d.y=0,d.z=0,d.w=0,d.v=0,l===(l|0)?d.x=l:u+=l;for(var p=0;p>>4),d.next()}function i(l,d){return d.x=l.x,d.y=l.y,d.z=l.z,d.w=l.w,d.v=l.v,d.d=l.d,d}function o(l,d){var u=new s(l),p=d&&d.state,c=function(){return(u.next()>>>0)/4294967296};return c.double=function(){do var h=u.next()>>>11,m=(u.next()>>>0)/4294967296,f=(h+m)/(1<<21);while(f===0);return f},c.int32=u.next,c.quick=c,p&&(typeof p=="object"&&i(p,u),c.state=function(){return i(u,{})}),c}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.xorwow=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),oI=xt((e,t)=>{(function(n,a,r){function s(l){var d=this;d.next=function(){var p=d.x,c=d.i,h,m,f;return h=p[c],h^=h>>>7,m=h^h<<24,h=p[c+1&7],m^=h^h>>>10,h=p[c+3&7],m^=h^h>>>3,h=p[c+4&7],m^=h^h<<7,h=p[c+7&7],h=h^h<<13,m^=h^h<<9,p[c]=m,d.i=c+1&7,m};function u(p,c){var h,m,f=[];if(c===(c|0))m=f[0]=c;else for(c=""+c,h=0;h0;--h)p.next()}u(d,l)}function i(l,d){return d.x=l.x.slice(),d.i=l.i,d}function o(l,d){l==null&&(l=+new Date);var u=new s(l),p=d&&d.state,c=function(){return(u.next()>>>0)/4294967296};return c.double=function(){do var h=u.next()>>>11,m=(u.next()>>>0)/4294967296,f=(h+m)/(1<<21);while(f===0);return f},c.int32=u.next,c.quick=c,p&&(p.x&&i(p,u),c.state=function(){return i(u,{})}),c}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.xorshift7=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),lI=xt((e,t)=>{(function(n,a,r){function s(l){var d=this;d.next=function(){var p=d.w,c=d.X,h=d.i,m,f;return d.w=p=p+1640531527|0,f=c[h+34&127],m=c[h=h+1&127],f^=f<<13,m^=m<<17,f^=f>>>15,m^=m>>>12,f=c[h]=f^m,d.i=h,f+(p^p>>>16)|0};function u(p,c){var h,m,f,A,y,g=[],x=128;for(c===(c|0)?(m=c,c=null):(c=c+"\0",m=0,x=Math.max(x,c.length)),f=0,A=-32;A>>15,m^=m<<4,m^=m>>>13,A>=0&&(y=y+1640531527|0,h=g[A&127]^=m+y,f=h==0?f+1:0);for(f>=128&&(g[(c&&c.length||0)&127]=-1),f=127,A=4*128;A>0;--A)m=g[f+34&127],h=g[f=f+1&127],m^=m<<13,h^=h<<17,m^=m>>>15,h^=h>>>12,g[f]=m^h;p.w=y,p.X=g,p.i=f}u(d,l)}function i(l,d){return d.i=l.i,d.w=l.w,d.X=l.X.slice(),d}function o(l,d){l==null&&(l=+new Date);var u=new s(l),p=d&&d.state,c=function(){return(u.next()>>>0)/4294967296};return c.double=function(){do var h=u.next()>>>11,m=(u.next()>>>0)/4294967296,f=(h+m)/(1<<21);while(f===0);return f},c.int32=u.next,c.quick=c,p&&(p.X&&i(p,u),c.state=function(){return i(u,{})}),c}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.xor4096=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),uI=xt((e,t)=>{(function(n,a,r){function s(l){var d=this,u="";d.next=function(){var c=d.b,h=d.c,m=d.d,f=d.a;return c=c<<25^c>>>7^h,h=h-m|0,m=m<<24^m>>>8^f,f=f-c|0,d.b=c=c<<20^c>>>12^h,d.c=h=h-m|0,d.d=m<<16^h>>>16^f,d.a=f-c|0},d.a=0,d.b=0,d.c=2654435769|0,d.d=1367130551,l===Math.floor(l)?(d.a=l/4294967296|0,d.b=l|0):u+=l;for(var p=0;p>>0)/4294967296};return c.double=function(){do var h=u.next()>>>11,m=(u.next()>>>0)/4294967296,f=(h+m)/(1<<21);while(f===0);return f},c.int32=u.next,c.quick=c,p&&(typeof p=="object"&&i(p,u),c.state=function(){return i(u,{})}),c}a&&a.exports?a.exports=o:r&&r.amd?r(function(){return o}):this.tychei=o})(e,typeof t=="object"&&t,typeof define=="function"&&define)}),dI=xt((e,t)=>{(function(n,a,r){var s=256,i=6,o=52,l="random",d=r.pow(s,i),u=r.pow(2,o),p=u*2,c=s-1,h;function m(b,v,N){var T=[];v=v==!0?{entropy:!0}:v||{};var R=g(y(v.entropy?[b,w(a)]:b==null?x():b,3),T),$=new f(T),z=function(){for(var P=$.g(i),V=d,j=0;P=p;)P/=2,V/=2,j>>>=1;return(P+j)/V};return z.int32=function(){return $.g(4)|0},z.quick=function(){return $.g(4)/4294967296},z.double=z,g(w($.S),a),(v.pass||N||function(P,V,j,U){return U&&(U.S&&A(U,$),P.state=function(){return A($,{})}),j?(r[l]=P,V):P})(z,R,"global"in v?v.global:this==r,v.state)}function f(b){var v,N=b.length,T=this,R=0,$=T.i=T.j=0,z=T.S=[];for(N||(b=[N++]);R{var n=rI(),a=sI(),r=iI(),s=oI(),i=lI(),o=uI(),l=dI();l.alea=n,l.xor128=a,l.xorwow=r,l.xorshift7=s,l.xor4096=i,l.tychei=o,t.exports=l}),pI=xt(()=>{}),dm={};Fe(dm,{bin:()=>Jg,browser:()=>r5,default:()=>cI,dependencies:()=>a5,description:()=>Ug,devDependencies:()=>t5,jsdelivr:()=>Xg,license:()=>e5,main:()=>Gg,miniprogram:()=>Yg,module:()=>qg,name:()=>Vg,private:()=>Hg,repository:()=>Qg,scripts:()=>n5,types:()=>Zg,unpkg:()=>Kg,version:()=>jg});var Vg="@tensorflow/tfjs",jg="3.6.0",Ug="An open-source machine learning framework.",Hg=!1,Gg="dist/tf.node.js",qg="dist/index.js",Xg="dist/tf.min.js",Kg="dist/tf.min.js",Zg="dist/index.d.ts",Yg="dist/miniprogram",Jg={"tfjs-custom-module":"dist/tools/custom_module/cli.js"},Qg={type:"git",url:"https://github.com/tensorflow/tfjs.git"},e5="Apache-2.0",t5={"@babel/core":"^7.9.0","@babel/polyfill":"^7.10.4","@babel/preset-env":"^7.9.5","@rollup/plugin-commonjs":"^11.0.2","@rollup/plugin-node-resolve":"^7.1.1","@rollup/plugin-typescript":"^3.0.0","@types/argparse":"^1.0.38","@types/jasmine":"2.8.7","@types/node":"~10.17.50","@types/shelljs":"^0.8.4","@types/yargs":"^15.0.7","clang-format":"~1.2.2",commander:"~2.14.1",jasmine:"3.1.0","jasmine-core":"~3.1.0",karma:"~6.3.2","karma-browserstack-launcher":"~1.6.0","karma-chrome-launcher":"~2.2.0","karma-firefox-launcher":"~1.1.0","karma-jasmine":"~1.1.1","karma-typescript":"~5.5.1","karma-typescript-es6-transform":"^5.5.1","npm-run-all":"~4.1.3",rimraf:"~2.6.2",rollup:"~2.3.2","rollup-plugin-babel":"^4.4.0","rollup-plugin-terser":"~7.0.2","rollup-plugin-visualizer":"~4.2.2",shelljs:"~0.8.1","ts-node":"~8.8.2",tslint:"~5.11.0","tslint-no-circular-imports":"~0.5.0",typescript:"3.5.3",yalc:"1.0.0-pre.50"},n5={build:"tsc && yarn build-cli && yarn bundle","build-ci":"tsc && yarn build-cli && yarn bundle-ci",bundle:"rollup -c","bundle-ci":"rollup -c --ci","build-core":"cd ../tfjs-core && yarn && yarn build","build-core-ci":"cd ../tfjs-core && yarn && yarn build-ci","build-layers":"cd ../tfjs-layers && yarn && yarn build","build-layers-ci":"cd ../tfjs-layers && yarn && yarn build-ci","build-converter":"cd ../tfjs-converter && yarn && yarn build","build-converter-ci":"cd ../tfjs-converter && yarn && yarn build-ci","build-data":"cd ../tfjs-data && yarn && yarn build","build-data-ci":"cd ../tfjs-data && yarn && yarn build-ci","build-backend-cpu":"cd ../tfjs-backend-cpu && yarn && yarn build","build-backend-cpu-ci":"cd ../tfjs-backend-cpu && yarn && yarn build-ci","build-backend-webgl":"cd ../tfjs-backend-webgl && yarn && yarn build","build-backend-webgl-ci":"cd ../tfjs-backend-webgl && yarn && yarn build-ci","build-deps":"yarn build-core && yarn build-layers && yarn build-converter && yarn build-data && yarn build-backend-cpu && yarn build-backend-webgl","build-deps-ci":"yarn build-core-ci && yarn build-layers-ci && yarn build-converter-ci && yarn build-data-ci && yarn build-backend-cpu-ci && yarn build-backend-webgl-ci","build-cli":"tsc --project ./tools/custom_module/tsconfig.json && chmod +x ./dist/tools/custom_module/cli.js","run-custom-build":"ts-node -s ./tools/custom_module/cli.ts","build-npm":"./scripts/build-npm.sh","link-local":"yalc link","publish-local":"yarn build-npm && yalc push","publish-npm":"npm publish",lint:"tslint -p . -t verbose",coverage:"KARMA_COVERAGE=1 karma start --browsers='Chrome' --singleRun",test:"yarn && yarn build-deps && yarn build && karma start","test-dev":"karma start","test-tools":"ts-node --project ./tools/custom_module/tsconfig.json run_tools_tests.ts","test-ci":"./scripts/test-ci.sh"},a5={"@tensorflow/tfjs-backend-cpu":"3.6.0","@tensorflow/tfjs-backend-webgl":"3.6.0","@tensorflow/tfjs-converter":"3.6.0","@tensorflow/tfjs-core":"3.6.0","@tensorflow/tfjs-data":"3.6.0","@tensorflow/tfjs-layers":"3.6.0",argparse:"^1.0.10",chalk:"^4.1.0","core-js":"3","regenerator-runtime":"^0.13.5",yargs:"^16.0.3"},r5={"node-fetch":!1,util:!1,crypto:!1},cI={name:Vg,version:jg,description:Ug,private:Hg,main:Gg,module:qg,jsdelivr:Xg,unpkg:Kg,types:Zg,miniprogram:Yg,bin:Jg,repository:Qg,license:e5,devDependencies:t5,scripts:n5,dependencies:a5,browser:r5},pm={};Fe(pm,{browser:()=>w5,default:()=>hI,dependencies:()=>v5,description:()=>o5,devDependencies:()=>x5,engines:()=>A5,jsdelivr:()=>d5,"jsnext:main":()=>h5,license:()=>g5,main:()=>u5,miniprogram:()=>m5,module:()=>f5,name:()=>s5,private:()=>l5,repository:()=>y5,scripts:()=>b5,sideEffects:()=>k5,types:()=>c5,unpkg:()=>p5,version:()=>i5});var s5="@tensorflow/tfjs-core",i5="3.6.0",o5="Hardware-accelerated JavaScript library for machine intelligence",l5=!1,u5="dist/tf-core.node.js",d5="dist/tf-core.min.js",p5="dist/tf-core.min.js",c5="dist/index.d.ts",h5="dist/index.js",f5="dist/index.js",m5="dist/miniprogram",A5={yarn:">= 1.3.2"},y5={type:"git",url:"https://github.com/tensorflow/tfjs-core.git"},g5="Apache-2.0",x5={"@bazel/bazelisk":"^1.3.0","@bazel/typescript":"^0.27.8","@rollup/plugin-commonjs":"^11.0.2","@rollup/plugin-node-resolve":"^7.1.1","@rollup/plugin-typescript":"^3.0.0","@tensorflow/tfjs-backend-cpu":"link:../tfjs-backend-cpu","@types/jasmine":"~3.0.0","@types/node":"~9.6.0","@types/node-fetch":"~2.1.2","clang-format":"~1.2.4",jasmine:"~3.1.0","jasmine-core":"~3.1.0",karma:"6.3.2","karma-browserstack-launcher":"~1.6.0","karma-chrome-launcher":"~3.1.0","karma-jasmine":"~4.0.1","karma-typescript":"~5.5.1","npm-run-all":"~4.1.3",rimraf:"~2.6.2",rollup:"~2.3.2","rollup-plugin-terser":"~5.3.0","rollup-plugin-visualizer":"~3.3.2",shelljs:"~0.8.3","ts-node":"~8.8.2",tslint:"~5.11.0","tslint-no-circular-imports":"~0.5.0",typescript:"3.5.3",yalc:"~1.0.0-pre.21",yargs:"~13.2.2"},b5={"build-ci":"./scripts/enumerate-tests.js --ci && tsc && yarn bundle-ci && yarn build-test-snippets",build:"node ./scripts/enumerate-tests.js && tsc && yarn bundle",bundle:"rollup -c","bundle-ci":"rollup -c --ci","build-npm":"./scripts/build-npm.sh","build-deps":"yarn build && yarn build-cpu-backend","build-cpu-backend":"cd ../tfjs-backend-cpu && yarn && yarn build","build-cpu-backend-ci":"cd ../tfjs-backend-cpu && yarn && yarn build-ci","build:bazel":"bazelisk build //...","build-test-snippets":"yarn tsc --project ./scripts/test_snippets/tsconfig.json","format-all":"clang-format -i -style=Google --glob=src/**/*.ts","link-local":"yalc link","publish-local":"rimraf dist/ && yarn build && rollup -c && yalc push","publish-npm":"npm publish",lint:"tslint -p . -t verbose",coverage:"KARMA_COVERAGE=1 karma start --browsers='Chrome' --singleRun",test:"yarn && yarn build-deps && karma start","test-dev":"karma start","test-ci":"./scripts/test-ci.sh","test-webworker":"karma start --worker","run-browserstack":"karma start --browserstack","test-bundle-size":"./scripts/test-bundle-size.js","test-node":"rimraf dist/ && yarn build-deps && yarn build && ts-node --transpile-only --skip-ignore -P tsconfig.test.json dist/test_node.js","test-node-dev":"tsc && ts-node --transpile-only --skip-ignore -P tsconfig.test.json dist/test_node.js","test-node-ci":"ts-node --transpile-only -P tsconfig.test.json dist/test_node.js","test-async-backends":"rimraf dist/ && yarn build && ts-node --transpile-only -P tsconfig.test.json dist/test_async_backends.js","test-async-backends-ci":"ts-node --transpile-only -P tsconfig.test.json dist/test_async_backends.js","test-snippets":"yarn build && yarn build-cpu-backend && ts-node -P tsconfig.test.json ./scripts/test_snippets/test_snippets.ts","test-snippets-ci":"ts-node -P tsconfig.test.json ./scripts/test_snippets/test_snippets.ts"},v5={"@types/offscreencanvas":"~2019.3.0","@types/seedrandom":"2.4.27","@types/webgl-ext":"0.0.30","node-fetch":"~2.6.1",seedrandom:"2.4.3"},w5={"node-fetch":!1,util:!1,crypto:!1,worker_threads:!1},k5=["./dist/index.js","./dist/engine.js","./dist/tensor.js","./dist/base_side_effects.js","./dist/flags.js","./dist/platforms/*.js","./dist/register_all_gradients.js","./dist/public/chained_ops/*.js","./dist/io/*.js"],hI={name:s5,version:i5,description:o5,private:l5,main:u5,jsdelivr:d5,unpkg:p5,types:c5,"jsnext:main":h5,module:f5,miniprogram:m5,engines:A5,repository:y5,license:g5,devDependencies:x5,scripts:b5,dependencies:v5,browser:w5,sideEffects:k5},cm={};Fe(cm,{browser:()=>W5,default:()=>fI,dependencies:()=>L5,description:()=>N5,devDependencies:()=>z5,jsdelivr:()=>C5,"jsnext:main":()=>F5,license:()=>O5,main:()=>E5,miniprogram:()=>D5,module:()=>$5,name:()=>I5,peerDependencies:()=>P5,private:()=>T5,scripts:()=>_5,types:()=>M5,unpkg:()=>R5,version:()=>S5});var I5="@tensorflow/tfjs-data",S5="3.6.0",N5="TensorFlow Data API in JavaScript",T5=!1,E5="dist/tf-data.node.js",C5="dist/tf-data.min.js",R5="dist/tf-data.min.js",M5="dist/index.d.ts",F5="dist/index.js",$5="dist/index.js",D5="dist/miniprogram",O5="Apache-2.0",z5={"@rollup/plugin-commonjs":"^11.0.2","@rollup/plugin-node-resolve":"^7.1.1","@rollup/plugin-typescript":"^3.0.0","@tensorflow/tfjs-backend-cpu":"3.6.0","@tensorflow/tfjs-core":"3.6.0","@tensorflow/tfjs-layers":"3.6.0","@types/jasmine":"~2.5.53","@types/seedrandom":"^2.4.27","@types/utf8":"~2.1.6","clang-format":"~1.2.2","http-server":"~0.12.3",jasmine:"3.1.0","jasmine-core":"~3.1.0",karma:"~6.3.1","karma-chrome-launcher":"~2.2.0","karma-firefox-launcher":"~1.1.0","karma-jasmine":"~1.1.1","karma-typescript":"~5.5.1","karma-typescript-es6-transform":"^5.0.2",nyc:"^15.1.0",rimraf:"~2.6.2",rollup:"~2.3.2","rollup-plugin-terser":"~7.0.2","rollup-plugin-visualizer":"~3.3.2","ts-node":"~7.0.0",tslint:"~6.1.3","tslint-no-circular-imports":"^0.7.0",typescript:"3.5.3",yalc:"^1.0.0-pre.50"},_5={build:"tsc && yarn bundle","build-ci":"tsc && yarn bundle-ci",bundle:"rollup -c","bundle-ci":"rollup -c --ci","build-core":"cd ../tfjs-core && yarn && yarn build","build-core-ci":"cd ../tfjs-core && yarn && yarn build-ci","build-layers":"cd ../tfjs-layers && yarn && yarn build","build-backend-cpu":"cd ../tfjs-backend-cpu && yarn && yarn build","build-backend-cpu-ci":"cd ../tfjs-backend-cpu && yarn && yarn build-ci","build-layers-ci":"cd ../tfjs-layers && yarn && yarn build-ci","build-deps":"yarn build-core && yarn build-layers && yarn build-backend-cpu","build-deps-ci":"yarn build-core-ci && yarn build-layers-ci && yarn build-backend-cpu-ci","build-npm":"./scripts/build-npm.sh","link-local":"yalc link","publish-local":"rimraf dist/ && yarn build-npm && yalc push","publish-npm":"npm publish",test:"yarn && yarn build-deps && yarn build && ts-node --transpile-only --project tsconfig.test.json src/test_node.ts","test-dev":"tsc && ts-node --transpile-only --project tsconfig.test.json src/test_node.ts","test-browsers":"karma start --browsers='Chrome,Firefox'","test-ci":"ts-node --transpile-only --skip-ignore -P tsconfig.test.json src/test_node.ts","test-snippets":"yarn && yarn build-deps && yarn build && ts-node --skip-ignore --project tsconfig.test.json ./scripts/test_snippets.ts","test-snippets-ci":"ts-node --skip-ignore --project tsconfig.test.json ./scripts/test_snippets.ts",coverage:"yarn nyc yarn ts-node --transpile-only -P tsconfig.test.json src/test_node.ts",lint:"tslint -p . -t verbose"},P5={"@tensorflow/tfjs-core":"3.6.0",seedrandom:"~2.4.3"},L5={"@types/node-fetch":"^2.1.2","node-fetch":"~2.6.1"},W5={fs:!1,"node-fetch":!1,string_decoder:!1,crypto:!1},fI={name:I5,version:S5,description:N5,private:T5,main:E5,jsdelivr:C5,unpkg:R5,types:M5,"jsnext:main":F5,module:$5,miniprogram:D5,license:O5,devDependencies:z5,scripts:_5,peerDependencies:P5,dependencies:L5,browser:W5},hm={};Fe(hm,{default:()=>mI,description:()=>j5,devDependencies:()=>Q5,jsdelivr:()=>Z5,"jsnext:main":()=>X5,license:()=>U5,main:()=>G5,miniprogram:()=>J5,module:()=>K5,name:()=>B5,peerDependencies:()=>tx,private:()=>H5,scripts:()=>ex,types:()=>q5,unpkg:()=>Y5,version:()=>V5});var B5="@tensorflow/tfjs-layers",V5="3.6.0",j5="TensorFlow layers API in JavaScript",U5="Apache-2.0 AND MIT",H5=!1,G5="dist/tf-layers.node.js",q5="dist/index.d.ts",X5="dist/index.js",K5="dist/index.js",Z5="dist/tf-layers.min.js",Y5="dist/tf-layers.min.js",J5="dist/miniprogram",Q5={"@babel/polyfill":"^7.8.7","@rollup/plugin-commonjs":"^11.0.2","@rollup/plugin-node-resolve":"^7.1.1","@rollup/plugin-typescript":"^3.0.0","@tensorflow/tfjs-backend-cpu":"3.6.0","@tensorflow/tfjs-backend-webgl":"3.6.0","@tensorflow/tfjs-core":"3.6.0","@types/jasmine":"~2.5.53","clang-format":"~1.2.2","http-server":"~0.12.3",jasmine:"~3.1.0","jasmine-core":"~3.1.0",karma:"~6.3.1","karma-browserstack-launcher":"~1.6.0","karma-chrome-launcher":"~2.2.0","karma-firefox-launcher":"~1.1.0","karma-jasmine":"~1.1.1","karma-typescript":"~5.5.1","karma-typescript-es6-transform":"^5.0.2",rimraf:"~2.6.2",rollup:"~2.3.2","rollup-plugin-terser":"~7.0.2","rollup-plugin-visualizer":"~3.3.2","ts-node":"~8.8.2",tslint:"~6.1.3","tslint-no-circular-imports":"^0.7.0",typescript:"3.5.3",yalc:"~1.0.0-pre.50"},ex={prep:"yarn install && yarn build-ci",build:"tsc && yarn bundle","build-ci":"tsc && yarn bundle-ci",bundle:"rollup -c","bundle-ci":"rollup -c --ci","build-core":"cd ../tfjs-core && yarn && yarn build","build-backend-cpu":"cd ../tfjs-backend-cpu && yarn && yarn build","build-backend-cpu-ci":"cd ../tfjs-backend-cpu && yarn && yarn build-ci","build-backend-webgl":"cd ../tfjs-backend-webgl && yarn && yarn build","build-backend-webgl-ci":"cd ../tfjs-backend-webgl && yarn && yarn build-ci","build-core-ci":"cd ../tfjs-core && yarn && yarn build-ci","build-deps":"yarn build-core && yarn build-backend-cpu && yarn build-backend-webgl","build-deps-ci":"yarn build-core-ci && yarn build-backend-cpu-ci && yarn build-backend-webgl-ci","build-npm":"./scripts/build-npm.sh",format:"./tools/clang_format_ts.sh","link-local":"yalc link","publish-local":"yarn build-npm && yalc push","publish-npm":"npm publish",coverage:"KARMA_COVERAGE=1 karma start --browsers='Chrome' --singleRun",test:"yarn && yarn build-deps && karma start","test-dev":"karma start","test-ci":"./scripts/test-ci.sh","test-snippets":"yarn && yarn build-deps && yarn build && ts-node --skip-ignore -s ./scripts/test_snippets.ts","test-snippets-ci":"ts-node --skip-ignore -s ./scripts/test_snippets.ts","run-browserstack":"karma start --browsers='bs_chrome_mac' --singleRun --reporters='dots,karma-typescript'",lint:"tslint -p . -t verbose"},tx={"@tensorflow/tfjs-core":"3.6.0"},mI={name:B5,version:V5,description:j5,license:U5,private:H5,main:G5,types:q5,"jsnext:main":X5,module:K5,jsdelivr:Z5,unpkg:Y5,miniprogram:J5,devDependencies:Q5,scripts:ex,peerDependencies:tx},fm={};Fe(fm,{default:()=>AI,description:()=>rx,devDependencies:()=>mx,jsdelivr:()=>dx,"jsnext:main":()=>ix,license:()=>hx,main:()=>sx,miniprogram:()=>px,module:()=>ox,name:()=>nx,peerDependencies:()=>fx,repository:()=>cx,scripts:()=>Ax,types:()=>lx,unpkg:()=>ux,version:()=>ax});var nx="@tensorflow/tfjs-converter",ax="3.6.0",rx="Tensorflow model converter for javascript",sx="dist/tf-converter.node.js",ix="dist/index.js",ox="dist/index.js",lx="dist/index.d.ts",ux="dist/tf-converter.min.js",dx="dist/tf-converter.min.js",px="dist/miniprogram",cx={type:"git",url:"https://github.com/tensorflow/tfjs-converter.git"},hx="Apache-2.0",fx={"@tensorflow/tfjs-core":"3.6.0"},mx={"@rollup/plugin-commonjs":"^11.0.2","@rollup/plugin-node-resolve":"^7.1.1","@rollup/plugin-replace":"^2.3.3","@rollup/plugin-typescript":"^3.0.0","@tensorflow/tfjs-backend-cpu":"3.6.0","@tensorflow/tfjs-core":"3.6.0","@types/argparse":"^1.0.38","@types/deep-equal":"^1.0.1","@types/jasmine":"~2.8.6","@types/long":"~3.0.32","@types/node-fetch":"1.6.9",ajv:"~6.3.0",argparse:"^1.0.10","babel-core":"~6.26.3","babel-plugin-external-helpers":"~6.22.0","babel-preset-env":"~1.7.0","clang-format":"~1.2.2",copyfiles:"~1.2.0","deep-equal":"^1.0.1","jasmine-core":"~3.5.0","node-fetch":"~2.6.1",opn:"~5.1.0",protobufjs:"~6.8.6",rimraf:"~2.6.2",rollup:"~2.3.2","rollup-plugin-terser":"~7.0.2","rollup-plugin-visualizer":"~3.3.2","ts-morph":"^7.1.3","ts-node":"~8.8.2",tslint:"~6.1.3","tslint-no-circular-imports":"~0.7.0",typescript:"3.5.3",yalc:"~1.0.0-pre.50"},Ax={build:"yarn gen-json --test && yarn gen-kernel2ops && tsc && yarn bundle","build-ci":"yarn gen-json --test && yarn gen-kernel2ops && tsc && yarn bundle-ci",bundle:"rollup -c","bundle-ci":"rollup -c --ci","build-core":"cd ../tfjs-core && yarn && yarn build","build-backend-cpu":"cd ../tfjs-backend-cpu && yarn && yarn build","build-backend-cpu-ci":"cd ../tfjs-backend-cpu && yarn && yarn build-ci","build-core-ci":"cd ../tfjs-core && yarn && yarn build-ci","build-deps":"yarn build-core && yarn build-backend-cpu","build-deps-ci":"yarn build-core-ci && yarn build-backend-cpu","build-npm":"./scripts/build-npm.sh","link-local":"yalc link","publish-local":"yarn build-npm && yalc push","publish-npm":"npm publish",test:"yarn && yarn build-deps && yarn build && yarn gen-json --test && yarn gen-kernel2ops && ts-node --transpile-only -P tsconfig.test.json src/run_tests.ts","test-ci":"ts-node --transpile-only --skip-ignore -P tsconfig.test.json src/run_tests.ts","test-dev":"tsc && ts-node --transpile-only -P tsconfig.test.json src/run_tests.ts","test-snippets":"yarn && yarn build-deps && yarn build && ts-node --skip-ignore -s ./scripts/test_snippets.ts","test-snippets-ci":"ts-node --skip-ignore -s ./scripts/test_snippets.ts",lint:"tslint -p . -t verbose","make-version":"sh -c ./scripts/make-version","gen-doc":"ts-node -s ./scripts/gen_doc.ts","gen-json":"ts-node -s ./scripts/gen_json.ts","model-summary":"ts-node -s ./tools/model_summary.ts",pb2json:"ts-node -s ./tools/pb2json_converter.ts","build-pip-package":"yarn gen-json --test && cd python && ./build-pip-package.sh --test /tmp/tfjs-pips","run-python-tests":"yarn gen-json --test && cd python && ./run-python-tests.sh","gen-kernel2ops":"ts-node -s scripts/kernels_to_ops.ts --out metadata/kernel2op.json"},AI={name:nx,version:ax,description:rx,main:sx,"jsnext:main":ix,module:ox,types:lx,unpkg:ux,jsdelivr:dx,miniprogram:px,repository:cx,license:hx,peerDependencies:fx,devDependencies:mx,scripts:Ax},yI=1e-7,gI=1e-4,Ip=class{constructor(e,t){this.backend=e,this.dataMover=t,this.data=new WeakMap,this.dataIdsCount=0}get(e){return this.data.has(e)||this.dataMover.moveData(this.backend,e),this.data.get(e)}set(e,t){this.dataIdsCount++,this.data.set(e,t)}has(e){return this.data.has(e)}delete(e){return this.dataIdsCount--,this.data.delete(e)}numDataIds(){return this.dataIdsCount}},hu=class{refCount(e){return aa("refCount")}incRef(e){return aa("incRef")}timerAvailable(){return!0}time(e){return aa("time")}read(e){return aa("read")}readSync(e){return aa("readSync")}numDataIds(){return aa("numDataIds")}disposeData(e,t){return aa("disposeData")}write(e,t,n){return aa("write")}move(e,t,n,a,r){return aa("move")}memory(){return aa("memory")}floatPrecision(){return aa("floatPrecision")}epsilon(){return this.floatPrecision()===32?yI:gI}dispose(){return aa("dispose")}};function aa(e){throw new Error(`'${e}' not yet implemented or not found in the registry. This kernel may not be supported by the tfjs backend you have chosen`)}function yx(e){let t=e.length,n=0,a=0;for(;t>0;)a=Math.random()*t|0,t--,n=e[t],e[t]=e[a],e[a]=n}function xI(e,t){if(e.length!==t.length)throw new Error(`Array sizes must match to be shuffled together First array length was ${e.length}Second array length was ${t.length}`);let n=e.length,a,r,s=0;for(;n>0;)s=Math.random()*n|0,n--,a=e[n],r=t[n],e[n]=e[s],t[n]=t[s],e[s]=a,t[s]=r}function fu(e,t,n){return Math.max(e,Math.min(t,n))}function bI(e){return e%2==0?e:e+1}function vI(e){let t=0;for(let n=0;nn+` Shapes ${e} and ${t} must match`)}function rs(e){F(e!=null,()=>"The input to the tensor constructor must be a non-null value.")}function ss(e,t=[],n=!1){if(t==null&&(t=[]),Array.isArray(e)||tn(e)&&!n)for(let a=0;a0,n){return new Promise((a,r)=>{let s=0,i=()=>{if(e()){a();return}s++;let o=t(s);if(n!=null&&s>=n){r();return}setTimeout(i,o)};i()})}function CI(e,t){let n=1,a=-1;for(let s=0;s=0)n*=e[s];else if(e[s]===-1){if(a!==-1)throw Error(`Shapes can only have 1 implicit size. Found -1 at dim ${a} and dim ${s}`);a=s}else if(e[s]<0)throw Error(`Shapes can not be < 0. Found ${e[s]} at dim ${s}`);if(a===-1){if(t>0&&t!==n)throw Error(`Size(${t}) must match the product of shape ${e}`);return e}if(n===0)throw Error(`Cannot infer the missing size in [${e}] when there are 0 elements`);if(t%n!=0)throw Error(`The implicit shape can't be a fractional number. Got ${t} / ${n}`);let r=e.slice();return r[a]=t/n,r}function ra(e,t){let n=t.length;return e=e==null?t.map((a,r)=>r):[].concat(e),F(e.every(a=>a>=-n&&a`All values in axis param must be in range [-${n}, ${n}) but got axis ${e}`),F(e.every(a=>Vt(a)),()=>`All values in axis param must be integers but got axis ${e}`),e.map(a=>a<0?n+a:a)}function gx(e,t){let n=[],a=[],r=t!=null&&Array.isArray(t)&&t.length===0,s=t==null||r?null:ra(t,e).sort(),i=0;for(let o=0;oo)&&e[o]===1&&(n.push(e[o]),a.push(o)),s[i]<=o&&i++}e[o]!==1&&(n.push(e[o]),a.push(o))}return{newShape:n,keptDims:a}}function xx(e,t){let n=null;if(e==null||e==="float32")n=new Float32Array(t);else if(e==="int32")n=new Int32Array(t);else if(e==="bool")n=new Uint8Array(t);else throw new Error(`Unknown data type ${e}`);return n}function bx(e,t){let n=null;if(e==null||e==="float32")n=new Float32Array(t);else if(e==="int32")n=new Int32Array(t);else if(e==="bool")n=new Uint8Array(t);else if(e==="string")n=new Array(t);else throw new Error(`Unknown data type ${e}`);return n}function vx(e,t){for(let n=0;nt+=n.length),t}function br(e){return typeof e=="string"||e instanceof String}function Ix(e){return typeof e=="boolean"}function Sx(e){return typeof e=="number"}function Sp(e){return Array.isArray(e)?Sp(e[0]):e instanceof Float32Array?"float32":e instanceof Int32Array||e instanceof Uint8Array?"int32":Sx(e)?"float32":br(e)?"string":Ix(e)?"bool":"float32"}function vr(e){return!!(e&&e.constructor&&e.call&&e.apply)}function Np(e,t){for(let n=t;n=0;--a)n[a]=n[a+1]*e[a+1];return n}function Nx(e,t,n,a=!1){let r=new Array;if(t.length===1){let s=t[0]*(a?2:1);for(let i=0;il*d)*(a?2:1);for(let l=0;lr*s)*(n?2:1);if(a===0)return[];if(a!==t.length)throw new Error(`[${e}] does not match the input size ${t.length}${n?" for a complex tensor":""}.`);return Nx(0,e,t,n)}function Am(e,t){let n=Tp(e,t);for(let a=0;aa*r,1);if(t==null||t==="float32")return Ji(e,new Float32Array(n));if(t==="int32")return Ji(e,new Int32Array(n));if(t==="bool")return Ji(e,new Uint8Array(n));throw new Error(`Unknown data type ${t}`)}function ym(e){e.forEach(t=>{F(Number.isInteger(t)&&t>=0,()=>`Tensor must have a shape comprised of positive integers but got shape [${e}].`)})}function FI(e,t,n){if(t===0)return 0;if(t===1)return e[0];let a=e[e.length-1];for(let r=0;r{let[n,a]=t.split(":");this.urlFlags[n]=OI(n,a)})}};function DI(e){let t={};return e.replace(/[?&]([^=?&]+)(?:=([^&]*))?/g,(n,...a)=>(zI(t,a[0],a[1]),a.join("="))),t}function zI(e,t,n){e[decodeURIComponent(t)]=decodeURIComponent(n||"")}function OI(e,t){if(t=t.toLowerCase(),t==="true"||t==="false")return t==="true";if(`${+t}`===t)return+t;throw new Error(`Could not parse value flag value ${t} for flag ${e}.`)}function J(){return fa}var fa=null;function _I(e){fa=e}var xm;function Cx(){if(xm==null){let e;if(typeof window!="undefined")e=window;else if(typeof global!="undefined")e=global;else if(typeof process!="undefined")e=process;else if(typeof self!="undefined")e=self;else throw new Error("Could not find a global object");xm=e}return xm}function PI(){let e=Cx();return e._tfGlobals==null&&(e._tfGlobals=new Map),e._tfGlobals}function bm(e,t){let n=PI();if(n.has(e))return n.get(e);{let a=t();return n.set(e,a),n.get(e)}}var Qi="Abs",eo="Acos",to="Acosh",wr="Add",is="AddN",no="All",ao="Any",os="ArgMax",Au="ArgMin",ro="Asin",so="Asinh",io="Atan",oo="Atanh",lo="Atan2",ls="AvgPool",Ep="AvgPoolGrad",yu="AvgPool3D",Cp="AvgPool3DGrad",us="BatchMatMul",gu="BatchToSpaceND",Rp="Bincount",Rx="BroadcastTo",ds="Cast",ps="Ceil",kr="ClipByValue",Mp="Complex",xu="ComplexAbs",uo="Concat",cs="Conv2D",Fp="Conv2DBackpropFilter",hs="Conv2DBackpropInput",bu="Conv3D",$p="Conv3DBackpropFilterV2",Dp="Conv3DBackpropInputV2",fs="Cos",po="Cosh",ms="Cumsum",co="CropAndResize",Op="DenseBincount",ho="DepthToSpace",As="DepthwiseConv2dNative",zp="DepthwiseConv2dNativeBackpropFilter",_p="DepthwiseConv2dNativeBackpropInput",Pp="Diag",vu="Dilation2D",Lp="Dilation2DBackpropInput",Wp="Dilation2DBackpropFilter",ys="RealDiv",Bp="Einsum",fo="Elu",Vp="EluGrad",mo="Erf",Ao="Equal",gs="Exp",yo="ExpandDims",go="Expm1",jp="FFT",wu="Fill",xo="FlipLeftRight",xs="Floor",bs="FloorDiv",vs="FusedBatchNorm",bo="GatherV2",vo="GatherNd",wo="Greater",ws="GreaterEqual",ks="Identity",Up="IFFT",Hp="Imag",ko="IsFinite",Io="IsInf",So="IsNan",Is="LeakyRelu",No="Less",To="LessEqual",Gp="LinSpace",Ss="Log",Eo="Log1p",Co="LogicalAnd",ku="LogicalNot",Iu="LogicalOr",Mx="LogSoftmax",Su="LRN",qp="LRNGrad",Ns="Max",Ts="Maximum",Es="MaxPool",Xp="MaxPoolGrad",Nu="MaxPool3D",Kp="MaxPool3DGrad",Zp="MaxPoolWithArgmax",Cs="Mean",Rs="Min",Ms="Minimum",Fs="MirrorPad",Ro="Mod",Yp="Multinomial",$s="Multiply",Mo="Neg",Fo="NotEqual",$o="NonMaxSuppressionV3",Do="NonMaxSuppressionV4",Oo="NonMaxSuppressionV5",zo="OnesLike",Ds="OneHot",_o="Pack",Os="PadV2",LI="Pool",zs="Pow",_s="Prelu",Po="Prod",Tu="Range",Jp="Real",Lo="Reciprocal",Ps="Relu",Wo="Reshape",Eu="ResizeNearestNeighbor",Qp="ResizeNearestNeighborGrad",Ls="ResizeBilinear",ec="ResizeBilinearGrad",Ws="Relu6",Bs="Reverse",Vs="Round",js="Rsqrt",Bo="ScatterNd",Vo="Select",jo="Selu",Uo="Slice",Us="Sin",Ho="Sinh",Go="Sign",Hs="Sigmoid",qo="Softplus",Gs="Sqrt",qs="Sum",Cu="SpaceToBatchND",Xo="SplitV",Xs="Softmax",tc="SparseFillEmptyRows",nc="SparseReshape",ac="SparseToDense",Ks="SquaredDifference",Ru="Square",Ko="StridedSlice",Zs="Sub",Ys="Tan",Js="Tanh",Ir="Tile",Zo="TopK",Yo="Transform",Qs="Transpose",rc="Unique",Jo="Unpack",Mu="UnsortedSegmentSum",Qo="ZerosLike",Sr="Step",sc="FromPixels",el="RotateWithOffset",ei="_FusedMatMul",ti="FusedConv2D",ni="FusedDepthwiseConv2D",tl=bm("kernelRegistry",()=>new Map),Fu=bm("gradRegistry",()=>new Map);function ic(e,t){let n=vm(e,t);return tl.get(n)}function wm(e){return Fu.get(e)}function nl(e){let t=tl.entries(),n=[];for(;;){let{done:a,value:r}=t.next();if(a)break;let[s,i]=r,[o]=s.split("_");o===e&&n.push(i)}return n}function ai(e){let{kernelName:t,backendName:n}=e,a=vm(t,n);tl.has(a)&&console.warn(`The kernel '${t}' for backend '${n}' is already registered`),tl.set(a,e)}function Fx(e){let{kernelName:t}=e;Fu.has(t)&&J().getBool("DEBUG")&&console.warn(`Overriding the gradient for '${t}'`),Fu.set(t,e)}function WI(e,t){let n=vm(e,t);if(!tl.has(n))throw new Error(`The kernel '${e}' for backend '${t}' is not registered`);tl.delete(n)}function BI(e){if(!Fu.has(e))throw new Error(`The gradient '${e}' for backend is not registered`);Fu.delete(e)}function VI(e,t){nl(e).forEach(n=>{let a=Object.assign({},n,{backendName:t});ai(a)})}function vm(e,t){return`${t}_${e}`}var k={};Fe(k,{arraysEqual:()=>Qa,assert:()=>F,assertNonNegativeIntegerDimensions:()=>ym,assertNonNull:()=>rs,assertShapesMatch:()=>sn,bytesFromStringArray:()=>kx,bytesPerElement:()=>mm,checkConversionForErrors:()=>vx,clamp:()=>fu,computeStrides:()=>Yi,createScalarValue:()=>jI,createShuffledIndices:()=>TI,decodeString:()=>lc,distSquared:()=>kI,encodeString:()=>Du,fetch:()=>UI,flatten:()=>ss,getArrayFromDType:()=>bx,getTypedArrayFromDType:()=>xx,hasEncodingLoss:()=>RI,indexToLoc:()=>$I,inferDtype:()=>Sp,inferFromImplicitShape:()=>CI,isBoolean:()=>Ix,isFunction:()=>vr,isInt:()=>Vt,isNumber:()=>Sx,isPromise:()=>gm,isScalarShape:()=>II,isString:()=>br,isTypedArray:()=>tn,isValidDtype:()=>wx,locToIndex:()=>FI,makeOnesTypedArray:()=>Am,makeZerosNestedTypedArray:()=>MI,makeZerosTypedArray:()=>Tp,nearestDivisor:()=>Np,nearestLargerEven:()=>bI,now:()=>$u,parseAxisParam:()=>ra,randUniform:()=>wI,repeatedTry:()=>EI,rightPad:()=>mu,shuffle:()=>yx,shuffleCombo:()=>xI,sizeFromShape:()=>Nt,sizeToSquarishShape:()=>NI,squeezeShape:()=>gx,sum:()=>vI,tanh:()=>SI,toNestedArray:()=>Ji,toTypedArray:()=>oc});function jI(e,t){return t==="string"?Du(e):oc([e],t)}function HI(e,t){return e instanceof Float32Array&&t==="float32"||e instanceof Int32Array&&t==="int32"||e instanceof Uint8Array&&t==="bool"}function oc(e,t){if(t==="string")throw new Error("Cannot convert a string[] to a TypedArray");if(Array.isArray(e)&&(e=ss(e)),J().getBool("DEBUG")&&vx(e,t),HI(e,t))return e;if(t==null||t==="float32"||t==="complex64")return new Float32Array(e);if(t==="int32")return new Int32Array(e);if(t==="bool"){let n=new Uint8Array(e.length);for(let a=0;a{a=n()},s,i=$u();if(this.backendTimer.timerAvailable())s=this.backendTimer.time(r);else{r();for(let o of a)o.dataSync();s=Promise.resolve({kernelMs:$u()-i})}if(J().getBool("CHECK_COMPUTATION_FOR_ERRORS"))for(let o=0;o{GI(d,l.dtype,e)})}return{kernelName:e,outputs:a,inputs:t,timeMs:s.then(o=>o.kernelMs),extraInfo:s.then(o=>o.getExtraProfileInfo!=null?o.getExtraProfileInfo():"")}}logKernelProfile(e){let{kernelName:t,outputs:n,timeMs:a,inputs:r,extraInfo:s}=e;n.forEach(i=>{Promise.all([i.data(),a,s]).then(o=>{this.logger.logKernelProfile(t,i,o[0],o[1],r,o[2])})})}};function GI(e,t,n){if(t!=="float32")return!1;for(let a=0;a0?m:""} `}}console.log(`%c${o} %c${i} %c${l}D ${u} %c${d} %c${p} %c${s}`,"font-weight:bold","color:red","color:blue","color: orange","color: green","color: steelblue")}};function KI(e,t,n){let a={},r={};for(let l=0;la[f.id]=!0),h=!0,r[d.id]=!0;break}if(h)break}}let s={};s[n.id]=!0;let i={};for(let l=e.length-1;l>=0;l--){let d=e[l],u=d.inputs;for(let p=0;p=0;r--){let s=t[r],i=[];if(s.outputs.forEach(l=>{let d=e[l.id];d!=null?i.push(d):i.push(null)}),s.gradient==null)throw new Error(`Cannot compute gradient: gradient function not found for ${s.kernelName}.`);let o=s.gradient(i);for(let l in s.inputs){if(!(l in o))throw new Error(`Cannot backprop through input ${l}. Available gradients found: ${Object.keys(o)}.`);let d=n(()=>o[l]());if(d.dtype!=="float32")throw new Error(`Error in gradient for op ${s.kernelName}. The gradient of input ${l} must have 'float32' dtype, but has '${d.dtype}'`);let u=s.inputs[l];if(!Qa(d.shape,u.shape))throw new Error(`Error in gradient for op ${s.kernelName}. The gradient of input '${l}' has shape '${d.shape}', which does not match the shape of the input '${u.shape}'`);if(e[u.id]==null)e[u.id]=d;else{let p=e[u.id];e[u.id]=a(p,d),p.dispose()}}}}var $x=20,Ou=3,km=7;function JI(e,t,n,a){let r=Yi(t),s=YI(e,t,n,r),i=t.length,o=uc(e,t,n,r,s),l=["Tensor"];return a&&(l.push(` dtype: ${n}`),l.push(` rank: ${i}`),l.push(` shape: [${t}]`),l.push(" values:")),l.push(o.map(d=>" "+d).join(` `)),l.join(` -`)}function YI(e,t,n,a){let r=Tt(t),s=a[a.length-1],i=new Array(s).fill(0),o=t.length,l=n==="complex64"?_u(e):e;if(o>1)for(let d=0;d$x){let A=Ou*i,y=Array.from(e.slice(0,A)),g=Array.from(e.slice((o-Ou)*i,o*i));return n==="complex64"&&(y=_u(y),g=_u(g)),["["+y.map((x,w)=>zu(x,r[w],n)).join(", ")+", ..., "+g.map((x,w)=>zu(x,r[o-Ou+w],n)).join(", ")+"]"]}let f=n==="complex64"?_u(e):Array.from(e);return["["+f.map((A,y)=>zu(A,r[y],n)).join(", ")+"]"]}let d=t.slice(1),u=a.slice(1),p=a[0]*i,c=[];if(o>$x){for(let f=0;f1)for(let d=0;d$x){let A=Ou*i,y=Array.from(e.slice(0,A)),g=Array.from(e.slice((o-Ou)*i,o*i));return n==="complex64"&&(y=_u(y),g=_u(g)),["["+y.map((x,w)=>zu(x,r[w],n)).join(", ")+", ..., "+g.map((x,w)=>zu(x,r[o-Ou+w],n)).join(", ")+"]"]}let f=n==="complex64"?_u(e):Array.from(e);return["["+f.map((A,y)=>zu(A,r[y],n)).join(", ")+"]"]}let d=t.slice(1),u=a.slice(1),p=a[0]*i,c=[];if(o>$x){for(let f=0;f`Length of values '${a}' does not match the size inferred by the shape '${this.size}'.`)}if(t==="complex64")throw new Error("complex64 dtype TensorBuffers are not supported. Please create a TensorBuffer for the real and imaginary parts separately and call tf.complex(real, imag).");this.values=n||bx(t,this.size),this.strides=Ji(e)}set(e,...t){t.length===0&&(t=[0]),F(t.length===this.rank,()=>`The number of provided coordinates (${t.length}) must match the rank (${this.rank})`);let n=this.locToIndex(t);this.values[n]=e}get(...e){e.length===0&&(e=[0]);let t=0;for(let a of e){if(a<0||a>=this.shape[t]){let r=`Requested out of range element at ${e}. Buffer shape=${this.shape}`;throw new Error(r)}t++}let n=e[e.length-1];for(let a=0;alc(n))}catch(n){throw new Error("Failed to decode the string bytes into utf-8. To get the original bytes, call tensor.bytes().")}}return e}dataSync(){this.throwIfDisposed();let e=$a().readSync(this.dataId);if(this.dtype==="string")try{return e.map(t=>lc(t))}catch(t){throw new Error("Failed to decode the string bytes into utf-8. To get the original bytes, call tensor.bytes().")}return e}async bytes(){this.throwIfDisposed();let e=await $a().read(this.dataId);return this.dtype==="string"?e:new Uint8Array(e.buffer)}dispose(){this.isDisposed||($a().disposeTensor(this),this.isDisposedInternal=!0)}get isDisposed(){return this.isDisposedInternal}throwIfDisposed(){if(this.isDisposed)throw new Error("Tensor is disposed.")}print(e=!1){return rl.print(this,e)}clone(){return this.throwIfDisposed(),rl.clone(this)}toString(e=!1){let t=this.dataSync();return JI(t,this.shape,this.dtype,e)}cast(e){return this.throwIfDisposed(),rl.cast(this,e)}variable(e=!0,t,n){return this.throwIfDisposed(),$a().makeVariable(this,e,t,n)}};Object.defineProperty(Le,Symbol.hasInstance,{value:e=>!!e&&e.data!=null&&e.dataSync!=null&&e.throwIfDisposed!=null});function Z(){return bm("Tensor",()=>Le)}Z();var Pu=class extends Le{constructor(e,t,n,a){super(e.shape,e.dtype,e.dataId,a);this.trainable=t,this.name=n}assign(e){if(e.dtype!==this.dtype)throw new Error(`dtype of the new value (${e.dtype}) and previous value (${this.dtype}) must match`);if(!er(e.shape,this.shape))throw new Error(`shape of the new value (${e.shape}) and previous value (${this.shape}) must match`);$a().disposeTensor(this),this.dataId=e.dataId,$a().incRef(this,null)}dispose(){$a().disposeVariable(this),this.isDisposedInternal=!0}};Object.defineProperty(Pu,Symbol.hasInstance,{value:e=>e instanceof Le&&e.assign!=null&&e.assign instanceof Function});var Aa={};Fe(Aa,{assertTypesMatch:()=>Ox,getTensorsInContainer:()=>Im,isTensorInList:()=>aS,makeTypesMatch:()=>vt});var Sm;(function(e){e.R0="R0",e.R1="R1",e.R2="R2",e.R3="R3",e.R4="R4",e.R5="R5",e.R6="R6"})(Sm||(Sm={}));var Nm;(function(e){e.float32="float32",e.int32="int32",e.bool="int32",e.complex64="complex64"})(Nm||(Nm={}));var Tm;(function(e){e.float32="float32",e.int32="int32",e.bool="bool",e.complex64="complex64"})(Tm||(Tm={}));var Em;(function(e){e.float32="float32",e.int32="float32",e.bool="float32",e.complex64="complex64"})(Em||(Em={}));var Cm;(function(e){e.float32="complex64",e.int32="complex64",e.bool="complex64",e.complex64="complex64"})(Cm||(Cm={}));var rS={float32:Em,int32:Nm,bool:Tm,complex64:Cm};function ia(e,t){if(e==="string"||t==="string"){if(e==="string"&&t==="string")return"string";throw new Error(`Can not upcast ${e} with ${t}`)}return rS[e][t]}function dc(e){return ia(e,"int32")}function vt(e,t){if(e.dtype===t.dtype)return[e,t];let n=ia(e.dtype,t.dtype);return[e.cast(n),t.cast(n)]}function Ox(e,t){F(e.dtype===t.dtype,()=>`The dtypes of the first(${e.dtype}) and second(${t.dtype}) input must match`)}function aS(e,t){return t.some(n=>n.id===e.id)}function Im(e){let t=[],n=new Set;return zx(e,t,n),t}function zx(e,t,n){if(e==null)return;if(e instanceof Le){t.push(e);return}if(!sS(e))return;let a=e;for(let r in a){let s=a[r];n.has(s)||(n.add(s),zx(s,t,n))}}function sS(e){return Array.isArray(e)||typeof e=="object"}function Rm(e){return e.kernelName!=null}var _x=class{constructor(){this.registeredVariables={},this.nextTapeNodeId=0,this.numBytes=0,this.numTensors=0,this.numStringTensors=0,this.numDataBuffers=0,this.gradientDepth=0,this.kernelDepth=0,this.scopeStack=[],this.numDataMovesStack=[],this.nextScopeId=0,this.tensorInfo=new WeakMap,this.profiling=!1,this.activeProfile={newBytes:0,newTensors:0,peakBytes:0,kernels:[],result:null,get kernelNames(){return Array.from(new Set(this.kernels.map(e=>e.name)))}}}dispose(){for(let e in this.registeredVariables)this.registeredVariables[e].dispose()}},Lu=class{constructor(e){this.ENV=e,this.registry={},this.registryFactory={},this.pendingBackendInitId=0,this.state=new _x}async ready(){if(this.pendingBackendInit!=null)return this.pendingBackendInit.then(()=>{});if(this.backendInstance!=null)return;let e=this.getSortedBackends();for(let t=0;t{e.setupFunc!=null&&e.setupFunc(this.backendInstance)})}disposeRegisteredKernels(e){al(e).forEach(t=>{t.disposeFunc!=null&&t.disposeFunc(this.registry[e])})}initializeBackend(e){let t=this.registryFactory[e];if(t==null)throw new Error(`Cannot initialize backend ${e}, no registration found.`);try{let n=t.factory();if(n&&!(n instanceof hu)&&typeof n.then=="function"){let a=++this.pendingBackendInitId,r=n.then(s=>a(athis.registryFactory[t].priority-this.registryFactory[e].priority)}initializeBackendsAndReturnBest(){let e=this.getSortedBackends();for(let t=0;tthis.startScope(n),()=>this.endScope(a),()=>(a=t(),a instanceof Promise&&console.error("Cannot return a Promise inside of tidy."),a))}scopedRun(e,t,n){e();try{let a=n();return t(),a}catch(a){throw t(),a}}nextTensorId(){return Lu.nextTensorId++}nextVariableId(){return Lu.nextVariableId++}clone(e){let t=D.runKernel(Is,{x:e}),n={x:e},a=s=>({x:()=>{let i="float32",o={x:s},l={dtype:i};return D.runKernel(ps,o,l)}}),r=[];return this.addTapeNode(this.state.activeScope.name,n,[t],a,r,{}),t}runKernel(e,t,n){if(ic(e,this.backendName)==null)throw new Error(`Kernel '${e}' not registered for backend '${this.backendName}'`);return this.runKernelFunc({kernelName:e,inputs:t,attrs:n})}shouldCheckForMemLeaks(){return this.ENV.getBool("IS_TEST")}checkKernelForMemLeak(e,t,n){let a=this.backend.numDataIds(),r=0;n.forEach(o=>{r+=o.dtype==="complex64"?3:1});let s=this.state.numDataMovesStack[this.state.numDataMovesStack.length-1],i=a-t-r-s;if(i>0)throw new Error(`Backend '${this.backendName}' has an internal memory leak (${i} data ids) after running '${e}'`)}runKernelFunc(e){let t,n=[],a=this.isTapeOn(),r=this.state.numBytes,s=this.state.numTensors;this.shouldCheckForMemLeaks()&&this.state.numDataMovesStack.push(0);let i;this.backendName==null&&this.backend;let o,l=Rm(e)?e.kernelName:this.state.activeScope!=null?this.state.activeScope.name:"";if(Rm(e)){let{kernelName:h,inputs:m,attrs:f}=e;this.backendName==null&&this.backend;let A=ic(h,this.backendName);F(A!=null,()=>`Cannot find registered kernel '${h}' for backend '${this.backendName}'`),i=()=>{let y=this.backend.numDataIds();o=A.kernelFunc({inputs:m,attrs:f,backend:this.backend});let g=Array.isArray(o)?o:[o];this.shouldCheckForMemLeaks()&&this.checkKernelForMemLeak(h,y,g);let x=g.map(w=>{if(w.rank!=null)return w;let{dataId:b,shape:v,dtype:N}=w;return this.makeTensorFromDataId(b,v,N)});if(a){let w=this.getTensorsForGradient(h,m,x);n=this.saveTensorsForBackwardMode(w)}return x}}else{let{forwardFunc:h}=e,m=f=>{!a||(n=f.map(A=>this.keep(this.clone(A))))};i=()=>{let f=this.backend.numDataIds();o=this.tidy(()=>h(this.backend,m));let A=Array.isArray(o)?o:[o];return this.shouldCheckForMemLeaks()&&this.checkKernelForMemLeak(l,f,A),A}}let{inputs:d,attrs:u}=e,p=Rm(e)?null:e.backwardsFunc,c;return this.scopedRun(()=>this.state.kernelDepth++,()=>this.state.kernelDepth--,()=>{!this.ENV.getBool("DEBUG")&&!this.state.profiling?t=i():(c=this.profiler.profileKernel(l,d,()=>i()),this.ENV.getBool("DEBUG")&&this.profiler.logKernelProfile(c),t=c.outputs)}),a&&this.addTapeNode(l,d,t,p,n,u),this.state.profiling&&this.state.activeProfile.kernels.push({name:l,bytesAdded:this.state.numBytes-r,totalBytesSnapshot:this.state.numBytes,tensorsAdded:this.state.numTensors-s,totalTensorsSnapshot:this.state.numTensors,inputShapes:Object.keys(d).map(h=>d[h]!=null?d[h].shape:null),outputShapes:t.map(h=>h.shape),kernelTimeMs:c.timeMs,extraInfo:c.extraInfo}),Array.isArray(o)?t:t[0]}saveTensorsForBackwardMode(e){return e.map(t=>this.keep(this.clone(t)))}getTensorsForGradient(e,t,n){let a=wm(e);if(a!=null){let r=a.inputsToSave||[],s=a.outputsToSave||[],i;a.saveAllInputs?(F(Array.isArray(t),()=>"saveAllInputs is true, expected inputs to be an array."),i=Object.keys(t).map(l=>t[l])):i=r.map(l=>t[l]);let o=n.filter((l,d)=>s[d]);return i.concat(o)}return[]}makeTensor(e,t,n,a){if(e==null)throw new Error("Values passed to engine.makeTensor() are null");n=n||"float32",a=a||this.backend;let r=e;n==="string"&&vr(e[0])&&(r=e.map(o=>Du(o)));let s=a.write(r,t,n),i=new Le(t,n,s,this.nextTensorId());if(this.trackTensor(i,a),n==="string"){let o=this.state.tensorInfo.get(s),l=kx(r);this.state.numBytes+=l-o.bytes,o.bytes=l}return i}makeTensorFromDataId(e,t,n,a){n=n||"float32";let r=new Le(t,n,e,this.nextTensorId());return this.trackTensor(r,a),r}makeVariable(e,t=!0,n,a){n=n||this.nextVariableId().toString(),a!=null&&a!==e.dtype&&(e=e.cast(a));let r=new Pu(e,t,n,this.nextTensorId());if(this.state.registeredVariables[r.name]!=null)throw new Error(`Variable with name ${r.name} was already registered`);return this.state.registeredVariables[r.name]=r,this.incRef(r,this.backend),r}trackTensor(e,t){this.state.numTensors++,e.dtype==="string"&&this.state.numStringTensors++;let n=0;e.dtype!=="complex64"&&e.dtype!=="string"&&(n=e.size*mm(e.dtype)),this.state.numBytes+=n,this.state.tensorInfo.has(e.dataId)||(this.state.numDataBuffers++,this.state.tensorInfo.set(e.dataId,{backend:t||this.backend,dtype:e.dtype,shape:e.shape,bytes:n})),e instanceof Pu||this.track(e)}incRef(e,t){this.trackTensor(e,t),this.backend.incRef(e.dataId)}removeDataId(e,t){this.state.tensorInfo.has(e)&&this.state.tensorInfo.get(e).backend===t&&(this.state.tensorInfo.delete(e),this.state.numDataBuffers--)}disposeTensor(e){if(!this.state.tensorInfo.has(e.dataId))return;let t=this.state.tensorInfo.get(e.dataId);if(this.state.numTensors--,e.dtype==="string"&&(this.state.numStringTensors--,this.state.numBytes-=t.bytes),e.dtype!=="complex64"&&e.dtype!=="string"){let n=e.size*mm(e.dtype);this.state.numBytes-=n}t.backend.disposeData(e.dataId)&&this.removeDataId(e.dataId,t.backend)}disposeVariables(){for(let e in this.state.registeredVariables){let t=this.state.registeredVariables[e];this.disposeVariable(t)}}disposeVariable(e){this.disposeTensor(e),this.state.registeredVariables[e.name]!=null&&delete this.state.registeredVariables[e.name]}memory(){let e=this.backend.memory();return e.numTensors=this.state.numTensors,e.numDataBuffers=this.state.numDataBuffers,e.numBytes=this.state.numBytes,this.state.numStringTensors>0&&(e.unreliable=!0,e.reasons==null&&(e.reasons=[]),e.reasons.push("Memory usage by string tensors is approximate (2 bytes per character)")),e}async profile(e){this.state.profiling=!0;let t=this.state.numBytes,n=this.state.numTensors;this.state.activeProfile.kernels=[],this.state.activeProfile.result=await e(),this.state.profiling=!1,this.state.activeProfile.peakBytes=Math.max(...this.state.activeProfile.kernels.map(a=>a.totalBytesSnapshot)),this.state.activeProfile.newBytes=this.state.numBytes-t,this.state.activeProfile.newTensors=this.state.numTensors-n;for(let a of this.state.activeProfile.kernels)a.kernelTimeMs=await a.kernelTimeMs,a.extraInfo=await a.extraInfo;return this.state.activeProfile}isTapeOn(){return this.state.gradientDepth>0&&this.state.kernelDepth===0}addTapeNode(e,t,n,a,r,s){let i={id:this.state.nextTapeNodeId++,kernelName:e,inputs:t,outputs:n,saved:r},o=wm(e);o!=null&&(a=o.gradFunc),a!=null&&(i.gradient=l=>(l=l.map((d,u)=>{if(d==null){let p=n[u],c=Tp(p.size,p.dtype);return this.makeTensor(c,p.shape,p.dtype)}return d}),a(l.length>1?l:l[0],r,s))),this.state.activeTape.push(i)}keep(e){return e.kept=!0,e}startTape(){this.state.gradientDepth===0&&(this.state.activeTape=[]),this.state.gradientDepth++}endTape(){this.state.gradientDepth--}startScope(e){let t={track:[],name:"unnamed scope",id:this.state.nextScopeId++};e&&(t.name=e),this.state.scopeStack.push(t),this.state.activeScope=t}endScope(e){let t=Im(e),n=new Set(t.map(r=>r.id));for(let r=0;r{!r.kept&&r.scopeId===a.id&&this.track(r)})}gradients(e,t,n,a=!1){if(F(t.length>0,()=>"gradients() received an empty list of xs."),n!=null&&n.dtype!=="float32")throw new Error(`dy must have 'float32' dtype, but has '${n.dtype}'`);let r=this.scopedRun(()=>this.startTape(),()=>this.endTape(),()=>this.tidy("forward",e));F(r instanceof Le,()=>"The result y returned by f() must be a tensor.");let s=KI(this.state.activeTape,t,r);if(!a&&s.length===0&&t.length>0)throw new Error("Cannot compute gradient of y=f(x) with respect to x. Make sure that the f you passed encloses all operations that lead from x to y.");return this.tidy("backward",()=>{let i={};i[r.id]=n==null?iS(r.shape):n,ZI(i,s,l=>this.tidy(l),oS);let o=t.map(l=>i[l.id]);return this.state.gradientDepth===0&&(this.state.activeTape.forEach(l=>{for(let d of l.saved)d.dispose()}),this.state.activeTape=null),{value:r,grads:o}})}customGrad(e){return F(wr(e),()=>"The f passed in customGrad(f) must be a function."),(...t)=>{F(t.every(i=>i instanceof Le),()=>"The args passed in customGrad(f)(x1, x2,...) must all be tensors");let n,a={};t.forEach((i,o)=>{a[o]=i});let r=(i,o)=>(n=e(...t,o),F(n.value instanceof Le,()=>"The function f passed in customGrad(f) must return an object where `obj.value` is a tensor"),F(wr(n.gradFunc),()=>"The function f passed in customGrad(f) must return an object where `obj.gradFunc` is a function."),n.value),s=(i,o)=>{let l=n.gradFunc(i,o),d=Array.isArray(l)?l:[l];F(d.length===t.length,()=>"The function f passed in customGrad(f) must return an object where `obj.gradFunc` is a function that returns the same number of tensors as inputs passed to f(...)."),F(d.every(p=>p instanceof Le),()=>"The function f passed in customGrad(f) must return an object where `obj.gradFunc` is a function that returns a list of only tensors.");let u={};return d.forEach((p,c)=>{u[c]=()=>p}),u};return this.runKernelFunc({forwardFunc:r,backwardsFunc:s,inputs:a})}}readSync(e){return this.state.tensorInfo.get(e).backend.readSync(e)}read(e){return this.state.tensorInfo.get(e).backend.read(e)}async time(e){let t=$u(),n=await this.backend.time(e);return n.wallMs=$u()-t,n}track(e){return this.state.activeScope!=null&&(e.scopeId=this.state.activeScope.id,this.state.activeScope.track.push(e)),e}get registeredVariables(){return this.state.registeredVariables}reset(){this.pendingBackendInitId++,this.state.dispose(),this.ENV.reset(),this.state=new _x;for(let e in this.registry)this.disposeRegisteredKernels(e),this.registry[e].dispose(),delete this.registry[e];this.backendName=null,this.backendInstance=null,this.pendingBackendInit=null}};Lu.nextTensorId=0;Lu.nextVariableId=0;function iS(e){let t=Am(Tt(e),"float32");return D.makeTensor(t,e,"float32")}function Px(){let e=Cx();if(e._tfengine==null){let t=new Ex(e);e._tfengine=new Lu(t)}return _I(e._tfengine.ENV),eS(()=>e._tfengine),e._tfengine}var D=Px();function oS(e,t){let n={a:e,b:t};return D.runKernel(kr,n)}var Wu={};Fe(Wu,{isBrowser:()=>Lx,isMobile:()=>lS});function uS(){return typeof navigator!="undefined"&&navigator!=null}function lS(e){if(e||uS()){if(e||(e=navigator),e.product==="ReactNative")return!0;let t=e.userAgent||e.vendor||window.opera;return/(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows ce|xda|xiino/i.test(t)||/1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i.test(t.substr(0,4))}return!1}function Lx(){return typeof window!="undefined"&&window.document!=null||typeof WorkerGlobalScope!="undefined"}var ya=J();ya.registerFlag("DEBUG",()=>!1,e=>{e&&console.warn("Debugging mode is ON. The output of every math call will be downloaded to CPU and checked for NaNs. This significantly impacts performance.")});ya.registerFlag("IS_BROWSER",()=>Lx());ya.registerFlag("IS_NODE",()=>typeof process!="undefined"&&typeof process.versions!="undefined"&&typeof process.versions.node!="undefined");ya.registerFlag("IS_CHROME",()=>typeof navigator!="undefined"&&navigator!=null&&navigator.userAgent!=null&&/Chrome/.test(navigator.userAgent)&&/Google Inc/.test(navigator.vendor));ya.registerFlag("PROD",()=>!1);ya.registerFlag("TENSORLIKE_CHECK_SHAPE_CONSISTENCY",()=>ya.getBool("DEBUG"));ya.registerFlag("DEPRECATION_WARNINGS_ENABLED",()=>!0);ya.registerFlag("IS_TEST",()=>!1);ya.registerFlag("CHECK_COMPUTATION_FOR_ERRORS",()=>!0);ya.registerFlag("WRAP_TO_IMAGEBITMAP",()=>!1);function Da(e,t){let n=e;if(nn(e))return t==="string"?[]:[e.length];if(!Array.isArray(e))return[];let a=[];for(;Array.isArray(n)||nn(n)&&t!=="string";)a.push(n.length),n=n[0];return Array.isArray(e)&&J().getBool("TENSORLIKE_CHECK_SHAPE_CONSISTENCY")&&Wx(e,a,[]),a}function Wx(e,t,n){if(n=n||[],!Array.isArray(e)&&!nn(e)){F(t.length===0,()=>`Element arr[${n.join("][")}] is a primitive, but should be an array/TypedArray of ${t[0]} elements`);return}F(t.length>0,()=>`Element arr[${n.join("][")}] should be a primitive, but is an array of ${e.length} elements`),F(e.length===t[0],()=>`Element arr[${n.join("][")}] should have ${t[0]} elements, but has ${e.length} elements`);let a=t.slice(1);for(let r=0;r=0&&(r=a),Bx(a,r,t,n),e==null||!nn(e)&&!Array.isArray(e)&&typeof e!="number"&&typeof e!="boolean"&&typeof e!="string"){let o=e==null?"null":e.constructor.name;throw new Error(`Argument '${t}' passed to '${n}' must be a Tensor or TensorLike, but got '${o}'`)}let s=Da(e,r);!nn(e)&&!Array.isArray(e)&&(e=[e]);let i=r!=="string"?oc(e,r):is(e,[],!0);return D.makeTensor(i,s,r)}function Bu(e,t,n,a="numeric"){if(!Array.isArray(e))throw new Error(`Argument ${t} passed to ${n} must be a \`Tensor[]\` or \`TensorLike[]\``);return e.map((r,s)=>M(r,`${t}[${s}]`,n,a))}var Vx="__op";function O(e){let t=Object.keys(e);if(t.length!==1)throw new Error(`Please provide an object with a single key (operation name) mapping to a function. Got an object with ${t.length} keys.`);let n=t[0],a=e[n];n.endsWith("_")&&(n=n.substring(0,n.length-1)),n=n+Vx;let r=(...s)=>{D.startScope(n);try{let i=a(...s);return gm(i)&&console.error("Cannot return a Promise inside of tidy."),D.endScope(i),i}catch(i){throw D.endScope(null),i}};return Object.defineProperty(r,"name",{value:n,configurable:!0}),r}function dS(e,t){let n=M(e,"real","complex"),a=M(t,"imag","complex");on(n.shape,a.shape,`real and imag shapes, ${n.shape} and ${a.shape}, must match in call to tf.complex().`);let r={real:n,imag:a};return D.runKernel(Mp,r)}var Tr=O({complex_:dS});function Er(e,t,n,a){if(a==null&&(a=Sp(e)),a==="complex64")throw new Error("Cannot construct a complex64 tensor directly. Please use tf.complex(real, imag).");if(!nn(e)&&!Array.isArray(e)&&typeof e!="number"&&typeof e!="boolean"&&typeof e!="string")throw new Error("values passed to tensor(values) must be a number/boolean/string or an array of numbers/booleans/strings, or a TypedArray");if(t!=null){ym(t);let r=Tt(t),s=Tt(n);F(r===s,()=>`Based on the provided shape, [${t}], the tensor should have ${r} values but has ${s}`);for(let i=0;i`Error creating a new Tensor. Inferred shape (${n}) does not match the provided shape (${t}). `)}}return!nn(e)&&!Array.isArray(e)&&(e=[e]),t=t||n,e=a!=="string"?oc(e,a):is(e,[],!0),D.makeTensor(e,t,a)}function oa(e,t,n){let a=Da(e,n);return Er(e,t,a,n)}var Mm={float32:4,float16:2,int32:4,uint16:2,uint8:1,bool:1,complex64:8},pc=4;async function cS(e,t){let n=[],a=[],r=Array.isArray(e)?e.map(i=>i.name):Object.keys(e);for(let i=0;i{let c=await l.bytes(),h=c.reduce((A,y)=>A+y.length,0)+pc*c.length,m=new Uint8Array(h),f=0;for(let A=0;A{if(t+=s.byteLength,n.push(s.byteLength===s.buffer.byteLength?s:new s.constructor(s)),!(s instanceof Float32Array||s instanceof Int32Array||s instanceof Uint8Array))throw new Error(`Unsupported TypedArray subtype: ${s.constructor.name}`)});let a=new Uint8Array(t),r=0;return n.forEach(s=>{a.set(new Uint8Array(s.buffer),r),r+=s.byteLength}),a.buffer}var Fm=typeof Buffer!="undefined"&&(typeof Blob=="undefined"||typeof atob=="undefined"||typeof btoa=="undefined");function Ux(e){return Fm?Buffer.byteLength(e):new Blob([e]).size}function fS(e){if(Fm)return Buffer.from(e).toString("base64");let t=new Uint8Array(e),n="";for(let a=0,r=t.length;a{t+=r.byteLength});let n=new Uint8Array(t),a=0;return e.forEach(r=>{n.set(new Uint8Array(r),a),a+=r.byteLength}),n.buffer}function Hx(e){let t="/";for(e=e.trim();e.endsWith(t);)e=e.slice(0,e.length-1);let n=e.split(t);return n[n.length-1]}function Vu(e){if(e.modelTopology instanceof ArrayBuffer)throw new Error("Expected JSON model topology, received ArrayBuffer.");return{dateSaved:new Date,modelTopologyType:"JSON",modelTopologyBytes:e.modelTopology==null?0:Ux(JSON.stringify(e.modelTopology)),weightSpecsBytes:e.weightSpecs==null?0:Ux(JSON.stringify(e.weightSpecs)),weightDataBytes:e.weightData==null?0:e.weightData.byteLength}}function AS(){let e=n=>{let a=n<<13,r=0;for(;(a&8388608)==0;)r-=8388608,a<<=1;return a&=~8388608,r+=947912704,a|r},t=new Uint32Array(2048);t[0]=0;for(let n=1;n<1024;n++)t[n]=e(n);for(let n=1024;n<2048;n++)t[n]=939524096+(n-1024<<13);return t}function yS(){let e=new Uint32Array(64);e[0]=0,e[31]=1199570944,e[32]=2147483648,e[63]=3347054592;for(let t=1;t<31;t++)e[t]=t<<23;for(let t=33;t<63;t++)e[t]=2147483648+(t-32<<23);return e}function gS(){let e=new Uint32Array(64);for(let t=0;t<64;t++)e[t]=1024;return e[0]=e[32]=0,e}function hS(){let e=AS(),t=yS(),n=gS();return a=>{let r=new ArrayBuffer(4*a.length),s=new Uint32Array(r);for(let i=0;i>10]+(o&1023)]+t[o>>10];s[i]=l}return new Float32Array(r)}}var Nt=class{constructor(){this.saveRouters=[],this.loadRouters=[]}static getInstance(){return Nt.instance==null&&(Nt.instance=new Nt),Nt.instance}static registerSaveRouter(e){Nt.getInstance().saveRouters.push(e)}static registerLoadRouter(e){Nt.getInstance().loadRouters.push(e)}static getSaveHandlers(e){return Nt.getHandlers(e,"save")}static getLoadHandlers(e,t){return Nt.getHandlers(e,"load",t)}static getHandlers(e,t,n){let a=[];return(t==="load"?Nt.getInstance().loadRouters:Nt.getInstance().saveRouters).forEach(r=>{let s=r(e,n);s!==null&&a.push(s)}),a}},xS=e=>Nt.registerSaveRouter(e),bS=e=>Nt.registerLoadRouter(e),vS=e=>Nt.getSaveHandlers(e),wS=(e,t)=>Nt.getLoadHandlers(e,t),Dm="tensorflowjs",Om=1,si="models_store",Cr="model_info_store";function Gx(){if(!J().getBool("IS_BROWSER"))throw new Error("Failed to obtain IndexedDB factory because the current environmentis not a web browser.");let e=typeof window=="undefined"?self:window,t=e.indexedDB||e.mozIndexedDB||e.webkitIndexedDB||e.msIndexedDB||e.shimIndexedDB;if(t==null)throw new Error("The current browser does not appear to support IndexedDB.");return t}function zm(e){let t=e.result;t.createObjectStore(si,{keyPath:"modelPath"}),t.createObjectStore(Cr,{keyPath:"modelPath"})}var ii=class{constructor(e){if(this.indexedDB=Gx(),e==null||!e)throw new Error("For IndexedDB, modelPath must not be null, undefined or empty.");this.modelPath=e}async save(e){if(e.modelTopology instanceof ArrayBuffer)throw new Error("BrowserLocalStorage.save() does not support saving model topology in binary formats yet.");return this.databaseAction(this.modelPath,e)}async load(){return this.databaseAction(this.modelPath)}databaseAction(e,t){return new Promise((n,a)=>{let r=this.indexedDB.open(Dm,Om);r.onupgradeneeded=()=>zm(r),r.onsuccess=()=>{let s=r.result;if(t==null){let i=s.transaction(si,"readonly"),o=i.objectStore(si).get(this.modelPath);o.onsuccess=()=>{if(o.result==null)return s.close(),a(new Error(`Cannot find model with path '${this.modelPath}' in IndexedDB.`));n(o.result.modelArtifacts)},o.onerror=l=>(s.close(),a(o.error)),i.oncomplete=()=>s.close()}else{let i=Vu(t),o=s.transaction(Cr,"readwrite"),l=o.objectStore(Cr),d=l.put({modelPath:this.modelPath,modelArtifactsInfo:i}),u;d.onsuccess=()=>{u=s.transaction(si,"readwrite");let p=u.objectStore(si).put({modelPath:this.modelPath,modelArtifacts:t,modelArtifactsInfo:i});p.onsuccess=()=>n({modelArtifactsInfo:i}),p.onerror=c=>{l=o.objectStore(Cr);let h=l.delete(this.modelPath);h.onsuccess=()=>(s.close(),a(p.error)),h.onerror=m=>(s.close(),a(p.error))}},d.onerror=p=>(s.close(),a(d.error)),o.oncomplete=()=>{u==null?s.close():u.oncomplete=()=>s.close()}}},r.onerror=s=>a(r.error)})}};ii.URL_SCHEME="indexeddb://";var qx=e=>J().getBool("IS_BROWSER")&&!Array.isArray(e)&&e.startsWith(ii.URL_SCHEME)?kS(e.slice(ii.URL_SCHEME.length)):null;Nt.registerSaveRouter(qx);Nt.registerLoadRouter(qx);function kS(e){return new ii(e)}function IS(e){return e.startsWith(ii.URL_SCHEME)?e.slice(ii.URL_SCHEME.length):e}var SS=class{constructor(){this.indexedDB=Gx()}async listModels(){return new Promise((e,t)=>{let n=this.indexedDB.open(Dm,Om);n.onupgradeneeded=()=>zm(n),n.onsuccess=()=>{let a=n.result,r=a.transaction(Cr,"readonly"),s=r.objectStore(Cr).getAll();s.onsuccess=()=>{let i={};for(let o of s.result)i[o.modelPath]=o.modelArtifactsInfo;e(i)},s.onerror=i=>(a.close(),t(s.error)),r.oncomplete=()=>a.close()},n.onerror=a=>t(n.error)})}async removeModel(e){return e=IS(e),new Promise((t,n)=>{let a=this.indexedDB.open(Dm,Om);a.onupgradeneeded=()=>zm(a),a.onsuccess=()=>{let r=a.result,s=r.transaction(Cr,"readwrite"),i=s.objectStore(Cr),o=i.get(e),l;o.onsuccess=()=>{if(o.result==null)return r.close(),n(new Error(`Cannot find model with path '${e}' in IndexedDB.`));{let d=i.delete(e),u=()=>{l=r.transaction(si,"readwrite");let p=l.objectStore(si).delete(e);p.onsuccess=()=>t(o.result.modelArtifactsInfo),p.onerror=c=>n(o.error)};d.onsuccess=u,d.onerror=p=>(u(),r.close(),n(o.error))}},o.onerror=d=>(r.close(),n(o.error)),s.oncomplete=()=>{l==null?r.close():l.oncomplete=()=>r.close()}},a.onerror=r=>n(a.error)})}},tr="/",sl="tensorflowjs_models",Xx="info",NS="model_topology",TS="weight_specs",ES="weight_data",CS="model_metadata";function Kx(e){return{info:[sl,e,Xx].join(tr),topology:[sl,e,NS].join(tr),weightSpecs:[sl,e,TS].join(tr),weightData:[sl,e,ES].join(tr),modelMetadata:[sl,e,CS].join(tr)}}function RS(e){let t=e.split(tr);if(t.length<3)throw new Error(`Invalid key format: ${e}`);return t.slice(1,t.length-1).join(tr)}function MS(e){return e.startsWith(oi.URL_SCHEME)?e.slice(oi.URL_SCHEME.length):e}var oi=class{constructor(e){if(!J().getBool("IS_BROWSER")||typeof window=="undefined"||typeof window.localStorage=="undefined")throw new Error("The current environment does not support local storage.");if(this.LS=window.localStorage,e==null||!e)throw new Error("For local storage, modelPath must not be null, undefined or empty.");this.modelPath=e,this.keys=Kx(this.modelPath)}async save(e){if(e.modelTopology instanceof ArrayBuffer)throw new Error("BrowserLocalStorage.save() does not support saving model topology in binary formats yet.");{let t=JSON.stringify(e.modelTopology),n=JSON.stringify(e.weightSpecs),a=Vu(e);try{this.LS.setItem(this.keys.info,JSON.stringify(a)),this.LS.setItem(this.keys.topology,t),this.LS.setItem(this.keys.weightSpecs,n),this.LS.setItem(this.keys.weightData,fS(e.weightData));let r={format:e.format,generatedBy:e.generatedBy,convertedBy:e.convertedBy};return e.signature!=null&&(r.signature=e.signature),e.userDefinedMetadata!=null&&(r.userDefinedMetadata=e.userDefinedMetadata),e.modelInitializer!=null&&(r.modelInitializer=e.modelInitializer),this.LS.setItem(this.keys.modelMetadata,JSON.stringify(r)),{modelArtifactsInfo:a}}catch(r){throw this.LS.removeItem(this.keys.info),this.LS.removeItem(this.keys.topology),this.LS.removeItem(this.keys.weightSpecs),this.LS.removeItem(this.keys.weightData),this.LS.removeItem(this.keys.modelMetadata),new Error(`Failed to save model '${this.modelPath}' to local storage: size quota being exceeded is a possible cause of this failure: modelTopologyBytes=${a.modelTopologyBytes}, weightSpecsBytes=${a.weightSpecsBytes}, weightDataBytes=${a.weightDataBytes}.`)}}}async load(){let e=JSON.parse(this.LS.getItem(this.keys.info));if(e==null)throw new Error(`In local storage, there is no model with name '${this.modelPath}'`);if(e.modelTopologyType!=="JSON")throw new Error("BrowserLocalStorage does not support loading non-JSON model topology yet.");let t={},n=JSON.parse(this.LS.getItem(this.keys.topology));if(n==null)throw new Error(`In local storage, the topology of model '${this.modelPath}' is missing.`);t.modelTopology=n;let a=JSON.parse(this.LS.getItem(this.keys.weightSpecs));if(a==null)throw new Error(`In local storage, the weight specs of model '${this.modelPath}' are missing.`);t.weightSpecs=a;let r=this.LS.getItem(this.keys.modelMetadata);if(r!=null){let i=JSON.parse(r);t.format=i.format,t.generatedBy=i.generatedBy,t.convertedBy=i.convertedBy,i.signature!=null&&(t.signature=i.signature),i.userDefinedMetadata!=null&&(t.userDefinedMetadata=i.userDefinedMetadata),i.modelInitializer!=null&&(t.modelInitializer=i.modelInitializer)}let s=this.LS.getItem(this.keys.weightData);if(s==null)throw new Error(`In local storage, the binary weight values of model '${this.modelPath}' are missing.`);return t.weightData=mS(s),t}};oi.URL_SCHEME="localstorage://";var Zx=e=>J().getBool("IS_BROWSER")&&!Array.isArray(e)&&e.startsWith(oi.URL_SCHEME)?FS(e.slice(oi.URL_SCHEME.length)):null;Nt.registerSaveRouter(Zx);Nt.registerLoadRouter(Zx);function FS(e){return new oi(e)}var $S=class{constructor(){F(J().getBool("IS_BROWSER"),()=>"Current environment is not a web browser"),F(typeof window=="undefined"||typeof window.localStorage!="undefined",()=>"Current browser does not appear to support localStorage"),this.LS=window.localStorage}async listModels(){let e={},t=sl+tr,n=tr+Xx;for(let a=0;a"scheme must not be undefined or null."),e.endsWith(il)&&(e=e.slice(0,e.indexOf(il))),F(e.length>0,()=>"scheme must not be an empty string.");let n=qn.getInstance();F(n.managers[e]==null,()=>`A model store manager is already registered for scheme '${e}'.`),n.managers[e]=t}static getManager(e){let t=this.getInstance().managers[e];if(t==null)throw new Error(`Cannot find model manager for scheme '${e}'`);return t}static getSchemes(){return Object.keys(this.getInstance().managers)}};function cc(e){if(e.indexOf(il)===-1)throw new Error(`The url string provided does not contain a scheme. Supported schemes are: ${qn.getSchemes().join(",")}`);return{scheme:e.split(il)[0],path:e.split(il)[1]}}async function Yx(e,t,n=!1){F(e!==t,()=>`Old path and new path are the same: '${e}'`);let a=Nt.getLoadHandlers(e);F(a.length>0,()=>`Copying failed because no load handler is found for source URL ${e}.`),F(a.length<2,()=>`Copying failed because more than one (${a.length}) load handlers for source URL ${e}.`);let r=a[0],s=Nt.getSaveHandlers(t);F(s.length>0,()=>`Copying failed because no save handler is found for destination URL ${t}.`),F(s.length<2,()=>`Copying failed because more than one (${a.length}) save handlers for destination URL ${t}.`);let i=s[0],o=cc(e).scheme,l=cc(e).path,d=o===cc(e).scheme,u=await r.load();n&&d&&await qn.getManager(o).removeModel(l);let p=await i.save(u);return n&&!d&&await qn.getManager(o).removeModel(l),p.modelArtifactsInfo}async function DS(){let e=qn.getSchemes(),t={};for(let n of e){let a=await qn.getManager(n).listModels();for(let r in a){let s=n+il+r;t[s]=a[r]}}return t}async function OS(e){let t=cc(e);return qn.getManager(t.scheme).removeModel(t.path)}async function zS(e,t){return Yx(e,t,!1)}async function _S(e,t){return Yx(e,t,!0)}var PS=class{fetch(e,t){return fetch(e,t)}now(){return performance.now()}encode(e,t){if(t!=="utf-8"&&t!=="utf8")throw new Error(`Browser's encoder only supports utf-8, but got ${t}`);return this.textEncoder==null&&(this.textEncoder=new TextEncoder),this.textEncoder.encode(e)}decode(e,t){return new TextDecoder(t).decode(e)}};if(J().get("IS_BROWSER")){J().setPlatform("browser",new PS);try{qn.registerManager(oi.URL_SCHEME,new $S)}catch(e){}try{qn.registerManager(ii.URL_SCHEME,new SS)}catch(e){}}var LS={importFetch:()=>G9()},_m,WS=class{constructor(){this.util=require("util"),this.textEncoder=new this.util.TextEncoder}fetch(e,t){return J().global.fetch!=null?J().global.fetch(e,t):(_m==null&&(_m=LS.importFetch()),_m(e,t))}now(){let e=process.hrtime();return e[0]*1e3+e[1]/1e6}encode(e,t){if(t!=="utf-8"&&t!=="utf8")throw new Error(`Node built-in encoder only supports utf-8, but got ${t}`);return this.textEncoder.encode(e)}decode(e,t){return e.length===0?"":new this.util.TextDecoder(t).decode(e)}};J().get("IS_NODE")&&J().setPlatform("node",new WS);function We(e,t="float32",n){return t=t||"float32",ym(e),new Ot(e,t,n)}function BS(e,t){let n=M(e,"x","cast");if(!wx(t))throw new Error(`Failed to cast to unknown dtype ${t}`);if(t==="string"&&n.dtype!=="string"||t!=="string"&&n.dtype==="string")throw new Error("Only strings can be casted to strings");let a={x:n},r={dtype:t};return D.runKernel(ps,a,r)}var fe=O({cast_:BS});function VS(e){let t={x:M(e,"x","clone","string_or_numeric")};return D.runKernel(Is,t)}var Oa=O({clone_:VS});function Jx(e,t=!1){console.log(e.toString(t))}Px();var jS={buffer:We,cast:fe,clone:Oa,print:Jx};tS(jS);var wn={};Fe(wn,{browserFiles:()=>US,browserHTTPRequest:()=>GS,concatenateArrayBuffers:()=>$m,copyModel:()=>zS,decodeWeights:()=>jx,encodeWeights:()=>cS,fromMemory:()=>qS,getLoadHandlers:()=>wS,getModelArtifactsInfoForJSON:()=>Vu,getSaveHandlers:()=>vS,http:()=>Lm,isHTTPScheme:()=>Pm,listModels:()=>DS,loadWeights:()=>HS,moveModel:()=>_S,registerLoadRouter:()=>bS,registerSaveRouter:()=>xS,removeModel:()=>OS,weightsLoaderFactory:()=>Qx,withSaveHandler:()=>XS});var KS="model",ZS=".json",YS=".weights.bin";function eb(e){return new Promise(t=>setTimeout(t)).then(e)}var ol=class{constructor(e){if(!J().getBool("IS_BROWSER"))throw new Error("browserDownloads() cannot proceed because the current environment is not a browser.");e.startsWith(ol.URL_SCHEME)&&(e=e.slice(ol.URL_SCHEME.length)),(e==null||e.length===0)&&(e=KS),this.modelTopologyFileName=e+ZS,this.weightDataFileName=e+YS}async save(e){if(typeof document=="undefined")throw new Error("Browser downloads are not supported in this environment since `document` is not present");let t=window.URL.createObjectURL(new Blob([e.weightData],{type:"application/octet-stream"}));if(e.modelTopology instanceof ArrayBuffer)throw new Error("BrowserDownloads.save() does not support saving model topology in binary formats yet.");{let n=[{paths:["./"+this.weightDataFileName],weights:e.weightSpecs}],a={modelTopology:e.modelTopology,format:e.format,generatedBy:e.generatedBy,convertedBy:e.convertedBy,weightsManifest:n};e.signature!=null&&(a.signature=e.signature),e.userDefinedMetadata!=null&&(a.userDefinedMetadata=e.userDefinedMetadata),e.modelInitializer!=null&&(a.modelInitializer=e.modelInitializer);let r=window.URL.createObjectURL(new Blob([JSON.stringify(a)],{type:"application/json"})),s=this.jsonAnchor==null?document.createElement("a"):this.jsonAnchor;if(s.download=this.modelTopologyFileName,s.href=r,await eb(()=>s.dispatchEvent(new MouseEvent("click"))),e.weightData!=null){let i=this.weightDataAnchor==null?document.createElement("a"):this.weightDataAnchor;i.download=this.weightDataFileName,i.href=t,await eb(()=>i.dispatchEvent(new MouseEvent("click")))}return{modelArtifactsInfo:Vu(e)}}}};ol.URL_SCHEME="downloads://";var JS=class{constructor(e){if(e==null||e.length<1)throw new Error(`When calling browserFiles, at least 1 file is required, but received ${e}`);this.files=e}async load(){let e=this.files[0],t=this.files.slice(1);return new Promise((n,a)=>{let r=new FileReader;r.onload=s=>{let i=JSON.parse(s.target.result),o=i.modelTopology;if(o==null){a(new Error(`modelTopology field is missing from file ${e.name}`));return}t.length===0&&n({modelTopology:o});let l=i.weightsManifest;if(l==null){a(new Error(`weightManifest field is missing from file ${e.name}`));return}let d;try{d=this.checkManifestAndWeightFiles(l,t)}catch(h){a(h);return}let u=[],p=[],c=[];l.forEach(h=>{h.paths.forEach(m=>{p.push(m),c.push(null)}),u.push(...h.weights)}),l.forEach(h=>{h.paths.forEach(m=>{let f=new FileReader;f.onload=A=>{let y=A.target.result,g=p.indexOf(m);if(c[g]=y,c.indexOf(null)===-1){let x={modelTopology:o,weightSpecs:u,weightData:$m(c),format:i.format,generatedBy:i.generatedBy,convertedBy:i.convertedBy};i.signature!=null&&(x.signature=i.signature),i.userDefinedMetadata!=null&&(x.userDefinedMetadata=i.userDefinedMetadata),i.modelInitializer!=null&&(x.modelInitializer=i.modelInitializer),n(x)}},f.onerror=A=>a(`Failed to weights data from file of path '${m}'.`),f.readAsArrayBuffer(d[m])})})},r.onerror=s=>a(`Failed to read model topology and weights manifest JSON from file '${e.name}'. BrowserFiles supports loading Keras-style tf.Model artifacts only.`),r.readAsText(e)})}checkManifestAndWeightFiles(e,t){let n=[],a=t.map(s=>Hx(s.name)),r={};for(let s of e)s.paths.forEach(i=>{let o=Hx(i);if(n.indexOf(o)!==-1)throw new Error(`Duplicate file basename found in weights manifest: '${o}'`);if(n.push(o),a.indexOf(o)===-1)throw new Error(`Weight file with basename '${o}' is not provided.`);r[i]=t[a.indexOf(o)]});if(n.length!==t.length)throw new Error(`Mismatch in the number of files in weights manifest (${n.length}) and the number of weight files provided (${t.length}).`);return r}},eN=e=>J().getBool("IS_BROWSER")&&!Array.isArray(e)&&e.startsWith(ol.URL_SCHEME)?QS(e.slice(ol.URL_SCHEME.length)):null;Nt.registerSaveRouter(eN);function QS(e="model"){return new ol(e)}function US(e){return new JS(e)}function tb(e,t,n,a){i(e),n=n==null?0:n,a=a==null?1:a,o(n,a);let r=0,s=l=>(l.then(d=>{let u=n+ ++r/e.length*(a-n);return t(u),d}),l);function i(l){F(l!=null&&Array.isArray(l)&&l.length>0,()=>"promises must be a none empty array")}function o(l,d){F(l>=0&&l<=1,()=>`Progress fraction must be in range [0, 1], but got startFraction ${l}`),F(d>=0&&d<=1,()=>`Progress fraction must be in range [0, 1], but got endFraction ${d}`),F(d>=l,()=>`startFraction must be no more than endFraction, but got startFraction ${l} and endFraction ${d}`)}return Promise.all(e.map(s))}async function nb(e,t){t==null&&(t={});let n=t.fetchFunc==null?J().platform.fetch:t.fetchFunc,a=e.map(d=>n(d,t.requestInit,{isBinary:!0})),r=0,s=.5,i=(t.onProgress==null?await Promise.all(a):await tb(a,t.onProgress,r,s)).map(d=>d.arrayBuffer()),o=.5,l=1;return t.onProgress==null?await Promise.all(i):await tb(i,t.onProgress,o,l)}async function HS(e,t="",n,a){return Qx(r=>nb(r,{requestInit:a}))(e,t,n)}function Qx(e){return async(t,n="",a)=>{let r=t.map(()=>!1),s={},i=a!=null?a.map(()=>!1):[],o=[];if(t.forEach((h,m)=>{let f=0;h.weights.forEach(A=>{let y="quantization"in A?A.quantization.dtype:A.dtype,g=Mm[y]*Tt(A.shape),x=()=>{r[m]=!0,s[m]==null&&(s[m]=[]),s[m].push({manifestEntry:A,groupOffset:f,sizeBytes:g})};a!=null?a.forEach((w,b)=>{w===A.name&&(x(),i[b]=!0)}):x(),o.push(A.name),f+=g})}),!i.every(h=>h)){let h=a.filter((m,f)=>!i[f]);throw new Error(`Could not find weights in manifest with names: ${h.join(", ")}. -Manifest JSON has weights with names: ${o.join(", ")}.`)}let l=r.reduce((h,m,f)=>(m&&h.push(f),h),[]),d=[];l.forEach(h=>{t[h].paths.forEach(m=>{let f=n+(n.endsWith("/")?"":"/")+m;d.push(f)})});let u=await e(d),p={},c=0;return l.forEach(h=>{let m=t[h].paths.length,f=0;for(let x=0;x{let w=A.slice(x.groupOffset,x.groupOffset+x.sizeBytes),b=jx(w,[x.manifestEntry]);for(let v in b)p[v]=b[v]}),c+=m}),p}}var tN="application/octet-stream",nN="application/json",Wm=class{constructor(e,t){if(this.DEFAULT_METHOD="POST",t==null&&(t={}),this.weightPathPrefix=t.weightPathPrefix,this.onProgress=t.onProgress,this.weightUrlConverter=t.weightUrlConverter,t.fetchFunc!=null?(F(typeof t.fetchFunc=="function",()=>"Must pass a function that matches the signature of `fetch` (see https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API)"),this.fetch=t.fetchFunc):this.fetch=J().platform.fetch,F(e!=null&&e.length>0,()=>"URL path for http must not be null, undefined or empty."),Array.isArray(e)&&F(e.length===2,()=>`URL paths for http must have a length of 2, (actual length is ${e.length}).`),this.path=e,t.requestInit!=null&&t.requestInit.body!=null)throw new Error("requestInit is expected to have no pre-existing body, but has one.");this.requestInit=t.requestInit||{}}async save(e){if(e.modelTopology instanceof ArrayBuffer)throw new Error("BrowserHTTPRequest.save() does not support saving model topology in binary formats yet.");let t=Object.assign({method:this.DEFAULT_METHOD},this.requestInit);t.body=new FormData;let n=[{paths:["./model.weights.bin"],weights:e.weightSpecs}],a={modelTopology:e.modelTopology,format:e.format,generatedBy:e.generatedBy,convertedBy:e.convertedBy,weightsManifest:n};e.signature!=null&&(a.signature=e.signature),e.userDefinedMetadata!=null&&(a.userDefinedMetadata=e.userDefinedMetadata),e.modelInitializer!=null&&(a.modelInitializer=e.modelInitializer),t.body.append("model.json",new Blob([JSON.stringify(a)],{type:nN}),"model.json"),e.weightData!=null&&t.body.append("model.weights.bin",new Blob([e.weightData],{type:tN}),"model.weights.bin");let r=await this.fetch(this.path,t);if(r.ok)return{modelArtifactsInfo:Vu(e),responses:[r]};throw new Error(`BrowserHTTPRequest.save() failed due to HTTP response status ${r.status}.`)}async load(){let e=await this.fetch(this.path,this.requestInit);if(!e.ok)throw new Error(`Request to ${this.path} failed with status code ${e.status}. Please verify this URL points to the model JSON of the model to load.`);let t;try{t=await e.json()}catch(h){let m=`Failed to parse model JSON of response from ${this.path}.`;throw this.path.endsWith(".pb")?m+=" Your path contains a .pb file extension. Support for .pb models have been removed in TensorFlow.js 1.0 in favor of .json models. You can re-convert your Python TensorFlow model using the TensorFlow.js 1.0 conversion scripts or you can convert your.pb models with the 'pb2json'NPM script in the tensorflow/tfjs-converter repository.":m+=" Please make sure the server is serving valid JSON for this request.",new Error(m)}let n=t.modelTopology,a=t.weightsManifest,r=t.generatedBy,s=t.convertedBy,i=t.format,o=t.signature,l=t.userDefinedMetadata;if(n==null&&a==null)throw new Error(`The JSON from HTTP path ${this.path} contains neither model topology or manifest for weights.`);let d,u;a!=null&&([d,u]=await this.loadWeights(a));let p={modelTopology:n,weightSpecs:d,weightData:u,generatedBy:r,convertedBy:s,format:i};o!=null&&(p.signature=o),l!=null&&(p.userDefinedMetadata=l);let c=t.modelInitializer;return c&&(p.modelInitializer=c),p}async loadWeights(e){let t=Array.isArray(this.path)?this.path[1]:this.path,[n,a]=aN(t),r=this.weightPathPrefix||n,s=[];for(let d of e)s.push(...d.weights);let i=[],o=[];for(let d of e)for(let u of d.paths)this.weightUrlConverter!=null?o.push(this.weightUrlConverter(u)):i.push(r+u+a);this.weightUrlConverter&&i.push(...await Promise.all(o));let l=await nb(i,{requestInit:this.requestInit,fetchFunc:this.fetch,onProgress:this.onProgress});return[s,$m(l)]}};Wm.URL_SCHEME_REGEX=/^https?:\/\//;function aN(e){let t=e.lastIndexOf("/"),n=e.lastIndexOf("?"),a=e.substring(0,t),r=n>t?e.substring(n):"";return[a+"/",r]}function Pm(e){return e.match(Wm.URL_SCHEME_REGEX)!=null}var ab=(e,t)=>{if(typeof fetch=="undefined"&&(t==null||t.fetchFunc==null))return null;{let n=!0;if(Array.isArray(e)?n=e.every(a=>Pm(a)):n=Pm(e),n)return Lm(e,t)}return null};Nt.registerSaveRouter(ab);Nt.registerLoadRouter(ab);function Lm(e,t){return new Wm(e,t)}function GS(e,t){return Lm(e,t)}var Bm=class{constructor(e){this.modelArtifacts=e}async load(){return this.modelArtifacts}},rN=class{constructor(e){this.saveHandler=e}async save(e){return this.saveHandler(e)}};function qS(e,t,n,a){return arguments.length===1?e.modelTopology!=null||e.weightSpecs!=null?new Bm(e):(console.warn("Please call tf.io.fromMemory() with only one argument. The argument should be of type ModelArtifacts. The multi-argument signature of tf.io.fromMemory() has been deprecated and will be removed in a future release."),new Bm({modelTopology:e})):(console.warn("Please call tf.io.fromMemory() with only one argument. The argument should be of type ModelArtifacts. The multi-argument signature of tf.io.fromMemory() has been deprecated and will be removed in a future release."),new Bm({modelTopology:e,weightSpecs:t,weightData:n,trainingConfig:a}))}function XS(e){return new rN(e)}var rb={};Fe(rb,{confusionMatrix:()=>sN});function iN(e,t,n=!1,a=!1){let r=M(e,"a","matMul"),s=M(t,"b","matMul");[r,s]=vt(r,s);let i={a:r,b:s},o={transposeA:n,transposeB:a};return D.runKernel(ds,i,o)}var Be=O({matMul_:iN});function oN(e,t,n=1,a=0){if(t<2)throw new Error(`Error in oneHot: depth must be >=2, but it is ${t}`);let r={indices:M(e,"indices","oneHot","int32")},s={depth:t,onValue:n,offValue:a};return D.runKernel(Os,r,s)}var ll=O({oneHot_:oN});function lN(e,t){let n=M(e,"x","transpose");if(t==null&&(t=n.shape.map((s,i)=>i).reverse()),F(n.rank===t.length,()=>`Error in transpose: rank of input ${n.rank} must match length of perm ${t}.`),t.forEach(s=>{F(s>=0&&s`All entries in 'perm' must be between 0 and ${n.rank-1} but got ${t}`)}),n.rank<=1)return n.clone();let a={x:n},r={perm:t};return D.runKernel(ei,a,r)}var Ze=O({transpose_:lN});function uN(e,t,n){let a=M(e,"labels","confusionMatrix"),r=M(t,"predictions","confusionMatrix");F(n==null||n>0&&Number.isInteger(n),()=>`If provided, numClasses must be a positive integer, but got ${n}`),F(a.rank===1,()=>`Expected the rank of labels to be 1, but got ${a.rank}`),F(r.rank===1,()=>`Expected the rank of predictions to be 1, but got ${r.rank}`),F(a.shape[0]===r.shape[0],()=>`Mismatch in the number of examples: ${a.shape[0]} vs. ${r.shape[0]}. Labels and predictions should have the same number of elements.`),F(n>0&&Number.isInteger(n),()=>`numClasses is required to be a positive integer, but got ${n}`);let s=ll(fe(a,"int32"),n),i=ll(fe(r,"int32"),n),o=Ze(s),l=Be(o,i);return fe(l,"int32")}var sN=O({confusionMatrix_:uN}),li={};Fe(li,{fromPixels:()=>cN,fromPixelsAsync:()=>dN,toPixels:()=>pN});function hc(e,t,n){if(ss(e),t!=null&&t.length!==3)throw new Error("tensor3d() requires shape to have three numbers");let a=Da(e,n);if(a.length!==3&&a.length!==1)throw new Error("tensor3d() requires values to be number[][][] or flat/TypedArray");if(a.length===1&&t==null)throw new Error("tensor3d() requires shape to be provided when `values` are a flat array");return Er(e,t,a,n)}var ul;function sb(e,t=3){if(t>4)throw new Error("Cannot construct Tensor with more than 4 channels from pixels.");if(e==null)throw new Error("pixels passed to tf.browser.fromPixels() can not be null");let n=!1,a=!1,r=!1,s=!1,i=!1,o=!1;if(e.data instanceof Uint8Array)n=!0;else if(typeof ImageData!="undefined"&&e instanceof ImageData)a=!0;else if(typeof HTMLVideoElement!="undefined"&&e instanceof HTMLVideoElement)r=!0;else if(typeof HTMLImageElement!="undefined"&&e instanceof HTMLImageElement)s=!0;else if(e.getContext!=null)i=!0;else if(typeof ImageBitmap!="undefined"&&e instanceof ImageBitmap)o=!0;else throw new Error(`pixels passed to tf.browser.fromPixels() must be either an HTMLVideoElement, HTMLImageElement, HTMLCanvasElement, ImageData in browser, or OffscreenCanvas, ImageData in webworker or {data: Uint32Array, width: number, height: number}, but was ${e.constructor.name}`);if(r){let c=2;if(r&&e.readyState element.")}if(ic(sc,D.backendName)!=null){let c={pixels:e},h={numChannels:t};return D.runKernel(sc,c,h)}let[l,d]=r?[e.videoWidth,e.videoHeight]:[e.width,e.height],u;i?u=e.getContext("2d").getImageData(0,0,l,d).data:a||n?u=e.data:(s||r||o)&&(ul==null&&(ul=document.createElement("canvas").getContext("2d")),ul.canvas.width=l,ul.canvas.height=d,ul.drawImage(e,0,0,l,d),u=ul.getImageData(0,0,l,d).data);let p;if(t===4)p=new Int32Array(u);else{let c=l*d;p=new Int32Array(c*t);for(let h=0;h4||s===2)throw new Error(`toPixels only supports depth of size 1, 3 or 4 but got ${s}`);if(n.dtype!=="float32"&&n.dtype!=="int32")throw new Error(`Unsupported type for toPixels: ${n.dtype}. Please use float32 or int32 tensors.`);let i=await n.data(),o=n.dtype==="float32"?255:1,l=new Uint8ClampedArray(r*a*4);for(let d=0;d1)throw new Error(`Tensor values for a float32 Tensor must be in the range [0 - 1] but encountered ${h}.`)}else if(n.dtype==="int32"&&(h<0||h>255))throw new Error(`Tensor values for a int32 Tensor must be in the range [0 - 255] but encountered ${h}.`);s===1?(u[0]=h*o,u[1]=h*o,u[2]=h*o):u[c]=h*o}let p=d*4;l[p+0]=Math.round(u[0]),l[p+1]=Math.round(u[1]),l[p+2]=Math.round(u[2]),l[p+3]=Math.round(u[3])}if(t!=null){t.width=r,t.height=a;let d=t.getContext("2d"),u=new ImageData(l,r,a);d.putImageData(u,0,0)}return n!==e&&n.dispose(),l}var cN=O({fromPixels_:sb}),Vm={};Fe(Vm,{prepareAndValidate:()=>ib});function ib(e,t){let n=e.shape.length,a=t.shape.length;if(n<1)throw new Error(`tf.gatherND() expects the input to be rank 1 or higher, but the rank was ${n}.`);if(a<1)throw new Error(`tf.gatherND() expects the indices to be rank 1 or higher, but the rank was ${a}.`);if(t.dtype!=="int32")throw new Error(`tf.gatherND() expects the indices to be int32 type, but the dtype was ${t.dtype}.`);if(t.shape[a-1]>n)throw new Error(`index innermost dimension length must be <= tensor rank; saw: ${t.shape[a-1]} vs. ${n}`);if(Tt(e.shape)===0)throw new Error(`Requested more than 0 entries, but input is empty. Input shape: ${e.shape}.`);let r=t.shape,s=r[r.length-1],i=1;for(let p=0;pp/d),1].slice(0,s);return[l,i,d,u]}var jm={};Fe(jm,{calculateShapes:()=>ob,validateInput:()=>Hm,validateUpdateShape:()=>Um});function Um(e,t,n){let a=t.rank>1?t.shape[t.rank-1]:1,r=t.rank>1?t.rank-1:1,s=`Must have updates.shape = indices.shape[:batchDim] + shape[sliceDim:], got updates.shape: ${n.shape}, indices.shape: ${t.shape}, shape: ${e}, sliceDim: ${a}, and batchDim: ${r}.`;if(n.rank1?t.shape[a-1]:1,s=n.length,i=1;for(let p=r;pyN,computeFlatOffset:()=>xN,computeOutShape:()=>lb,getNormalizedAxes:()=>db,isSliceContinous:()=>gN,maskToAxes:()=>fc,parseSliceParams:()=>Ab,sliceInfo:()=>bN,startForAxis:()=>fb,startIndicesWithElidedDims:()=>pb,stopForAxis:()=>mb,stopIndicesWithElidedDims:()=>cb,stridesForAxis:()=>hb,stridesWithElidedDims:()=>ub});function yN(e,t,n){let a=e.shape.length;F(a===t.length,()=>`Error in slice${a}D: Length of begin ${t} must match the rank of the array (${a}).`),F(a===n.length,()=>`Error in slice${a}D: Length of size ${n} must match the rank of the array (${a}).`);for(let r=0;r`Error in slice${a}D: begin[${r}] + size[${r}] (${t[r]+n[r]}) would overflow input.shape[${r}] (${e.shape[r]})`)}function fc(e){let t=[],n=0;for(;e>0;)e&1&&t.push(n),e/=2,n++;return t}function lb(e,t,n){let a=[];for(let r=0;r0){let h=t[0],m=n+1;u=pb(i,h,m,a,e),p=cb(o,h,m,r,e),c=ub(s,h,m,e)}else for(let h=0;h-1)s[o]=0;else{let l=yb(t,n,o),d=a[l];e&1<-1)s[o]=Number.MAX_SAFE_INTEGER;else{let l=yb(t,n,o),d=a[l];e&1<0?i=Number.MIN_SAFE_INTEGER:i=Number.MAX_SAFE_INTEGER);let l=a[r];return i<0&&(i+=l),i=fu(0,i,l-1),i}function mb(e,t,n,a,r,s){let i=t[r],o=n[r]||1;(e&1<0?i=Number.MAX_SAFE_INTEGER:i=Number.MIN_SAFE_INTEGER);let l=a[r];return i<0&&(i+=l),o>0?i=fu(0,i,l):i=fu(-1,i,l-1),i}function gN(e,t,n){let a=n.length;for(let r=0;r1){a=r;break}for(let r=a+1;r0||n[r]!==e[r])return!1;return!0}function xN(e,t){let n=e.length>0?e[e.length-1]:1;for(let a=0;a{F(i!==-1,()=>"slice() does not support negative begin indexing.")});let s;return n==null?s=new Array(r).fill(-1):typeof n=="number"?s=[n,...new Array(r-1).fill(-1)]:n.lengthi>=0?i:(F(i===-1,()=>`Negative size values should be exactly -1 but got ${i} for the slice() size at index ${o}.`),e.shape[o]-a[o])),[a,s]}function bN(e,t,n,a,r,s,i,o,l){let d=t.slice(),u=n.slice(),p=a;a==null&&(p=new Array(d.length));let c=fc(i);if(c.length>1)throw new Error("Multiple ellipses in slice is not allowed.");if(i!==0&&o!==0)throw new Error("Using both ellipsisMask and newAxisMask is not yet supported.");if(i!==0&&l!==0)throw new Error("Using both ellipsisMask and shrinkAxisMask is not yet supported.");let h=e.length-d.length,m=fc(o),f=e.slice();m.forEach(v=>{d[v]=0,u[v]=1,f.splice(v,0,1)});let{begin:A,end:y,strides:g}=db(f,c,h,d,u,p,r,s,i);d=A,u=y,p=g;let x=fc(l);x.forEach(v=>{u[v]=d[v]+1,p[v]=1});let w=lb(d,u,p),b=w.filter((v,N)=>x.indexOf(N)===-1);return{nonStrided:p.every(v=>v===1),$begin:d,$end:u,$strides:p,size:w,newShape:f,outShape:b}}var ae={};Fe(ae,{Serializable:()=>xb,SerializationMap:()=>ui,registerClass:()=>Rr});var xb=class{getClassName(){return this.constructor.className}static fromConfig(e,t){return new e(t)}},ui=class{constructor(){this.classNameMap={}}static getMap(){return ui.instance==null&&(ui.instance=new ui),ui.instance}static register(e){ui.getMap().classNameMap[e.className]=[e,e.fromConfig]}};function Rr(e){F(e.className!=null,()=>"Class being registered does not have the static className property defined."),F(typeof e.className=="string",()=>"className is required to be a string, but got type "+typeof e.className),F(e.className.length>0,()=>"Class being registered has an empty-string as its className, which is disallowed."),ui.register(e)}var bb={};Fe(bb,{TEST_EPSILON_FLOAT16:()=>vb,encodeStrings:()=>wb,expectArrayBuffersEqual:()=>NN,expectArraysClose:()=>vN,expectArraysEqual:()=>kN,expectNumbersClose:()=>IN,expectPromiseToFail:()=>wN,expectValuesInRange:()=>SN,testEpsilon:()=>Gm});var TN=.001,vb=.1;function vN(e,t,n){return n==null&&(n=Gm()),qm(e,t,(a,r)=>Xm(a,r,n))}function Gm(){return D.backend.floatPrecision()===32?TN:vb}function qm(e,t,n){let a=!0;if((nn(e)||nn(t))&&(a=!1),nn(e)&&nn(t)&&(a=!0),a){let i=e.constructor.name,o=t.constructor.name;if(i!==o)throw new Error(`Arrays are of different type. Actual: ${i}. Expected: ${o}`)}if(Array.isArray(e)&&Array.isArray(t)){let i=Da(e),o=Da(t);if(!er(i,o))throw new Error(`Arrays have different shapes. Actual: [${i}]. Expected: [${o}]`)}let r=nn(e)?e:is(e),s=nn(t)?t:is(t);if(r.length!==s.length)throw new Error(`Arrays have different lengths actual: ${r.length} vs expected: ${s.length}. +`;return c[c.length-1]=" "+c[c.length-1]+"]"+(s?"":m),c}function _u(e){let t=[];for(let n=0;n`Length of values '${a}' does not match the size inferred by the shape '${this.size}'.`)}if(t==="complex64")throw new Error("complex64 dtype TensorBuffers are not supported. Please create a TensorBuffer for the real and imaginary parts separately and call tf.complex(real, imag).");this.values=n||bx(t,this.size),this.strides=Yi(e)}set(e,...t){t.length===0&&(t=[0]),F(t.length===this.rank,()=>`The number of provided coordinates (${t.length}) must match the rank (${this.rank})`);let n=this.locToIndex(t);this.values[n]=e}get(...e){e.length===0&&(e=[0]);let t=0;for(let a of e){if(a<0||a>=this.shape[t]){let r=`Requested out of range element at ${e}. Buffer shape=${this.shape}`;throw new Error(r)}t++}let n=e[e.length-1];for(let a=0;alc(n))}catch(n){throw new Error("Failed to decode the string bytes into utf-8. To get the original bytes, call tensor.bytes().")}}return e}dataSync(){this.throwIfDisposed();let e=Fa().readSync(this.dataId);if(this.dtype==="string")try{return e.map(t=>lc(t))}catch(t){throw new Error("Failed to decode the string bytes into utf-8. To get the original bytes, call tensor.bytes().")}return e}async bytes(){this.throwIfDisposed();let e=await Fa().read(this.dataId);return this.dtype==="string"?e:new Uint8Array(e.buffer)}dispose(){this.isDisposed||(Fa().disposeTensor(this),this.isDisposedInternal=!0)}get isDisposed(){return this.isDisposedInternal}throwIfDisposed(){if(this.isDisposed)throw new Error("Tensor is disposed.")}print(e=!1){return al.print(this,e)}clone(){return this.throwIfDisposed(),al.clone(this)}toString(e=!1){let t=this.dataSync();return JI(t,this.shape,this.dtype,e)}cast(e){return this.throwIfDisposed(),al.cast(this,e)}variable(e=!0,t,n){return this.throwIfDisposed(),Fa().makeVariable(this,e,t,n)}};Object.defineProperty(Le,Symbol.hasInstance,{value:e=>!!e&&e.data!=null&&e.dataSync!=null&&e.throwIfDisposed!=null});function Z(){return bm("Tensor",()=>Le)}Z();var Pu=class extends Le{constructor(e,t,n,a){super(e.shape,e.dtype,e.dataId,a);this.trainable=t,this.name=n}assign(e){if(e.dtype!==this.dtype)throw new Error(`dtype of the new value (${e.dtype}) and previous value (${this.dtype}) must match`);if(!Qa(e.shape,this.shape))throw new Error(`shape of the new value (${e.shape}) and previous value (${this.shape}) must match`);Fa().disposeTensor(this),this.dataId=e.dataId,Fa().incRef(this,null)}dispose(){Fa().disposeVariable(this),this.isDisposedInternal=!0}};Object.defineProperty(Pu,Symbol.hasInstance,{value:e=>e instanceof Le&&e.assign!=null&&e.assign instanceof Function});var ma={};Fe(ma,{assertTypesMatch:()=>Ox,getTensorsInContainer:()=>Im,isTensorInList:()=>aS,makeTypesMatch:()=>bt});var Sm;(function(e){e.R0="R0",e.R1="R1",e.R2="R2",e.R3="R3",e.R4="R4",e.R5="R5",e.R6="R6"})(Sm||(Sm={}));var Nm;(function(e){e.float32="float32",e.int32="int32",e.bool="int32",e.complex64="complex64"})(Nm||(Nm={}));var Tm;(function(e){e.float32="float32",e.int32="int32",e.bool="bool",e.complex64="complex64"})(Tm||(Tm={}));var Em;(function(e){e.float32="float32",e.int32="float32",e.bool="float32",e.complex64="complex64"})(Em||(Em={}));var Cm;(function(e){e.float32="complex64",e.int32="complex64",e.bool="complex64",e.complex64="complex64"})(Cm||(Cm={}));var rS={float32:Em,int32:Nm,bool:Tm,complex64:Cm};function sa(e,t){if(e==="string"||t==="string"){if(e==="string"&&t==="string")return"string";throw new Error(`Can not upcast ${e} with ${t}`)}return rS[e][t]}function dc(e){return sa(e,"int32")}function bt(e,t){if(e.dtype===t.dtype)return[e,t];let n=sa(e.dtype,t.dtype);return[e.cast(n),t.cast(n)]}function Ox(e,t){F(e.dtype===t.dtype,()=>`The dtypes of the first(${e.dtype}) and second(${t.dtype}) input must match`)}function aS(e,t){return t.some(n=>n.id===e.id)}function Im(e){let t=[],n=new Set;return zx(e,t,n),t}function zx(e,t,n){if(e==null)return;if(e instanceof Le){t.push(e);return}if(!sS(e))return;let a=e;for(let r in a){let s=a[r];n.has(s)||(n.add(s),zx(s,t,n))}}function sS(e){return Array.isArray(e)||typeof e=="object"}function Rm(e){return e.kernelName!=null}var _x=class{constructor(){this.registeredVariables={},this.nextTapeNodeId=0,this.numBytes=0,this.numTensors=0,this.numStringTensors=0,this.numDataBuffers=0,this.gradientDepth=0,this.kernelDepth=0,this.scopeStack=[],this.numDataMovesStack=[],this.nextScopeId=0,this.tensorInfo=new WeakMap,this.profiling=!1,this.activeProfile={newBytes:0,newTensors:0,peakBytes:0,kernels:[],result:null,get kernelNames(){return Array.from(new Set(this.kernels.map(e=>e.name)))}}}dispose(){for(let e in this.registeredVariables)this.registeredVariables[e].dispose()}},Lu=class{constructor(e){this.ENV=e,this.registry={},this.registryFactory={},this.pendingBackendInitId=0,this.state=new _x}async ready(){if(this.pendingBackendInit!=null)return this.pendingBackendInit.then(()=>{});if(this.backendInstance!=null)return;let e=this.getSortedBackends();for(let t=0;t{e.setupFunc!=null&&e.setupFunc(this.backendInstance)})}disposeRegisteredKernels(e){nl(e).forEach(t=>{t.disposeFunc!=null&&t.disposeFunc(this.registry[e])})}initializeBackend(e){let t=this.registryFactory[e];if(t==null)throw new Error(`Cannot initialize backend ${e}, no registration found.`);try{let n=t.factory();if(n&&!(n instanceof hu)&&typeof n.then=="function"){let a=++this.pendingBackendInitId,r=n.then(s=>a(athis.registryFactory[t].priority-this.registryFactory[e].priority)}initializeBackendsAndReturnBest(){let e=this.getSortedBackends();for(let t=0;tthis.startScope(n),()=>this.endScope(a),()=>(a=t(),a instanceof Promise&&console.error("Cannot return a Promise inside of tidy."),a))}scopedRun(e,t,n){e();try{let a=n();return t(),a}catch(a){throw t(),a}}nextTensorId(){return Lu.nextTensorId++}nextVariableId(){return Lu.nextVariableId++}clone(e){let t=D.runKernel(ks,{x:e}),n={x:e},a=s=>({x:()=>{let i="float32",o={x:s},l={dtype:i};return D.runKernel(ds,o,l)}}),r=[];return this.addTapeNode(this.state.activeScope.name,n,[t],a,r,{}),t}runKernel(e,t,n){if(ic(e,this.backendName)==null)throw new Error(`Kernel '${e}' not registered for backend '${this.backendName}'`);return this.runKernelFunc({kernelName:e,inputs:t,attrs:n})}shouldCheckForMemLeaks(){return this.ENV.getBool("IS_TEST")}checkKernelForMemLeak(e,t,n){let a=this.backend.numDataIds(),r=0;n.forEach(o=>{r+=o.dtype==="complex64"?3:1});let s=this.state.numDataMovesStack[this.state.numDataMovesStack.length-1],i=a-t-r-s;if(i>0)throw new Error(`Backend '${this.backendName}' has an internal memory leak (${i} data ids) after running '${e}'`)}runKernelFunc(e){let t,n=[],a=this.isTapeOn(),r=this.state.numBytes,s=this.state.numTensors;this.shouldCheckForMemLeaks()&&this.state.numDataMovesStack.push(0);let i;this.backendName==null&&this.backend;let o,l=Rm(e)?e.kernelName:this.state.activeScope!=null?this.state.activeScope.name:"";if(Rm(e)){let{kernelName:h,inputs:m,attrs:f}=e;this.backendName==null&&this.backend;let A=ic(h,this.backendName);F(A!=null,()=>`Cannot find registered kernel '${h}' for backend '${this.backendName}'`),i=()=>{let y=this.backend.numDataIds();o=A.kernelFunc({inputs:m,attrs:f,backend:this.backend});let g=Array.isArray(o)?o:[o];this.shouldCheckForMemLeaks()&&this.checkKernelForMemLeak(h,y,g);let x=g.map(w=>{if(w.rank!=null)return w;let{dataId:b,shape:v,dtype:N}=w;return this.makeTensorFromDataId(b,v,N)});if(a){let w=this.getTensorsForGradient(h,m,x);n=this.saveTensorsForBackwardMode(w)}return x}}else{let{forwardFunc:h}=e,m=f=>{!a||(n=f.map(A=>this.keep(this.clone(A))))};i=()=>{let f=this.backend.numDataIds();o=this.tidy(()=>h(this.backend,m));let A=Array.isArray(o)?o:[o];return this.shouldCheckForMemLeaks()&&this.checkKernelForMemLeak(l,f,A),A}}let{inputs:d,attrs:u}=e,p=Rm(e)?null:e.backwardsFunc,c;return this.scopedRun(()=>this.state.kernelDepth++,()=>this.state.kernelDepth--,()=>{!this.ENV.getBool("DEBUG")&&!this.state.profiling?t=i():(c=this.profiler.profileKernel(l,d,()=>i()),this.ENV.getBool("DEBUG")&&this.profiler.logKernelProfile(c),t=c.outputs)}),a&&this.addTapeNode(l,d,t,p,n,u),this.state.profiling&&this.state.activeProfile.kernels.push({name:l,bytesAdded:this.state.numBytes-r,totalBytesSnapshot:this.state.numBytes,tensorsAdded:this.state.numTensors-s,totalTensorsSnapshot:this.state.numTensors,inputShapes:Object.keys(d).map(h=>d[h]!=null?d[h].shape:null),outputShapes:t.map(h=>h.shape),kernelTimeMs:c.timeMs,extraInfo:c.extraInfo}),Array.isArray(o)?t:t[0]}saveTensorsForBackwardMode(e){return e.map(t=>this.keep(this.clone(t)))}getTensorsForGradient(e,t,n){let a=wm(e);if(a!=null){let r=a.inputsToSave||[],s=a.outputsToSave||[],i;a.saveAllInputs?(F(Array.isArray(t),()=>"saveAllInputs is true, expected inputs to be an array."),i=Object.keys(t).map(l=>t[l])):i=r.map(l=>t[l]);let o=n.filter((l,d)=>s[d]);return i.concat(o)}return[]}makeTensor(e,t,n,a){if(e==null)throw new Error("Values passed to engine.makeTensor() are null");n=n||"float32",a=a||this.backend;let r=e;n==="string"&&br(e[0])&&(r=e.map(o=>Du(o)));let s=a.write(r,t,n),i=new Le(t,n,s,this.nextTensorId());if(this.trackTensor(i,a),n==="string"){let o=this.state.tensorInfo.get(s),l=kx(r);this.state.numBytes+=l-o.bytes,o.bytes=l}return i}makeTensorFromDataId(e,t,n,a){n=n||"float32";let r=new Le(t,n,e,this.nextTensorId());return this.trackTensor(r,a),r}makeVariable(e,t=!0,n,a){n=n||this.nextVariableId().toString(),a!=null&&a!==e.dtype&&(e=e.cast(a));let r=new Pu(e,t,n,this.nextTensorId());if(this.state.registeredVariables[r.name]!=null)throw new Error(`Variable with name ${r.name} was already registered`);return this.state.registeredVariables[r.name]=r,this.incRef(r,this.backend),r}trackTensor(e,t){this.state.numTensors++,e.dtype==="string"&&this.state.numStringTensors++;let n=0;e.dtype!=="complex64"&&e.dtype!=="string"&&(n=e.size*mm(e.dtype)),this.state.numBytes+=n,this.state.tensorInfo.has(e.dataId)||(this.state.numDataBuffers++,this.state.tensorInfo.set(e.dataId,{backend:t||this.backend,dtype:e.dtype,shape:e.shape,bytes:n})),e instanceof Pu||this.track(e)}incRef(e,t){this.trackTensor(e,t),this.backend.incRef(e.dataId)}removeDataId(e,t){this.state.tensorInfo.has(e)&&this.state.tensorInfo.get(e).backend===t&&(this.state.tensorInfo.delete(e),this.state.numDataBuffers--)}disposeTensor(e){if(!this.state.tensorInfo.has(e.dataId))return;let t=this.state.tensorInfo.get(e.dataId);if(this.state.numTensors--,e.dtype==="string"&&(this.state.numStringTensors--,this.state.numBytes-=t.bytes),e.dtype!=="complex64"&&e.dtype!=="string"){let n=e.size*mm(e.dtype);this.state.numBytes-=n}t.backend.disposeData(e.dataId)&&this.removeDataId(e.dataId,t.backend)}disposeVariables(){for(let e in this.state.registeredVariables){let t=this.state.registeredVariables[e];this.disposeVariable(t)}}disposeVariable(e){this.disposeTensor(e),this.state.registeredVariables[e.name]!=null&&delete this.state.registeredVariables[e.name]}memory(){let e=this.backend.memory();return e.numTensors=this.state.numTensors,e.numDataBuffers=this.state.numDataBuffers,e.numBytes=this.state.numBytes,this.state.numStringTensors>0&&(e.unreliable=!0,e.reasons==null&&(e.reasons=[]),e.reasons.push("Memory usage by string tensors is approximate (2 bytes per character)")),e}async profile(e){this.state.profiling=!0;let t=this.state.numBytes,n=this.state.numTensors;this.state.activeProfile.kernels=[],this.state.activeProfile.result=await e(),this.state.profiling=!1,this.state.activeProfile.peakBytes=Math.max(...this.state.activeProfile.kernels.map(a=>a.totalBytesSnapshot)),this.state.activeProfile.newBytes=this.state.numBytes-t,this.state.activeProfile.newTensors=this.state.numTensors-n;for(let a of this.state.activeProfile.kernels)a.kernelTimeMs=await a.kernelTimeMs,a.extraInfo=await a.extraInfo;return this.state.activeProfile}isTapeOn(){return this.state.gradientDepth>0&&this.state.kernelDepth===0}addTapeNode(e,t,n,a,r,s){let i={id:this.state.nextTapeNodeId++,kernelName:e,inputs:t,outputs:n,saved:r},o=wm(e);o!=null&&(a=o.gradFunc),a!=null&&(i.gradient=l=>(l=l.map((d,u)=>{if(d==null){let p=n[u],c=Tp(p.size,p.dtype);return this.makeTensor(c,p.shape,p.dtype)}return d}),a(l.length>1?l:l[0],r,s))),this.state.activeTape.push(i)}keep(e){return e.kept=!0,e}startTape(){this.state.gradientDepth===0&&(this.state.activeTape=[]),this.state.gradientDepth++}endTape(){this.state.gradientDepth--}startScope(e){let t={track:[],name:"unnamed scope",id:this.state.nextScopeId++};e&&(t.name=e),this.state.scopeStack.push(t),this.state.activeScope=t}endScope(e){let t=Im(e),n=new Set(t.map(r=>r.id));for(let r=0;r{!r.kept&&r.scopeId===a.id&&this.track(r)})}gradients(e,t,n,a=!1){if(F(t.length>0,()=>"gradients() received an empty list of xs."),n!=null&&n.dtype!=="float32")throw new Error(`dy must have 'float32' dtype, but has '${n.dtype}'`);let r=this.scopedRun(()=>this.startTape(),()=>this.endTape(),()=>this.tidy("forward",e));F(r instanceof Le,()=>"The result y returned by f() must be a tensor.");let s=KI(this.state.activeTape,t,r);if(!a&&s.length===0&&t.length>0)throw new Error("Cannot compute gradient of y=f(x) with respect to x. Make sure that the f you passed encloses all operations that lead from x to y.");return this.tidy("backward",()=>{let i={};i[r.id]=n==null?iS(r.shape):n,ZI(i,s,l=>this.tidy(l),oS);let o=t.map(l=>i[l.id]);return this.state.gradientDepth===0&&(this.state.activeTape.forEach(l=>{for(let d of l.saved)d.dispose()}),this.state.activeTape=null),{value:r,grads:o}})}customGrad(e){return F(vr(e),()=>"The f passed in customGrad(f) must be a function."),(...t)=>{F(t.every(i=>i instanceof Le),()=>"The args passed in customGrad(f)(x1, x2,...) must all be tensors");let n,a={};t.forEach((i,o)=>{a[o]=i});let r=(i,o)=>(n=e(...t,o),F(n.value instanceof Le,()=>"The function f passed in customGrad(f) must return an object where `obj.value` is a tensor"),F(vr(n.gradFunc),()=>"The function f passed in customGrad(f) must return an object where `obj.gradFunc` is a function."),n.value),s=(i,o)=>{let l=n.gradFunc(i,o),d=Array.isArray(l)?l:[l];F(d.length===t.length,()=>"The function f passed in customGrad(f) must return an object where `obj.gradFunc` is a function that returns the same number of tensors as inputs passed to f(...)."),F(d.every(p=>p instanceof Le),()=>"The function f passed in customGrad(f) must return an object where `obj.gradFunc` is a function that returns a list of only tensors.");let u={};return d.forEach((p,c)=>{u[c]=()=>p}),u};return this.runKernelFunc({forwardFunc:r,backwardsFunc:s,inputs:a})}}readSync(e){return this.state.tensorInfo.get(e).backend.readSync(e)}read(e){return this.state.tensorInfo.get(e).backend.read(e)}async time(e){let t=$u(),n=await this.backend.time(e);return n.wallMs=$u()-t,n}track(e){return this.state.activeScope!=null&&(e.scopeId=this.state.activeScope.id,this.state.activeScope.track.push(e)),e}get registeredVariables(){return this.state.registeredVariables}reset(){this.pendingBackendInitId++,this.state.dispose(),this.ENV.reset(),this.state=new _x;for(let e in this.registry)this.disposeRegisteredKernels(e),this.registry[e].dispose(),delete this.registry[e];this.backendName=null,this.backendInstance=null,this.pendingBackendInit=null}};Lu.nextTensorId=0;Lu.nextVariableId=0;function iS(e){let t=Am(Nt(e),"float32");return D.makeTensor(t,e,"float32")}function Px(){let e=Cx();if(e._tfengine==null){let t=new Ex(e);e._tfengine=new Lu(t)}return _I(e._tfengine.ENV),eS(()=>e._tfengine),e._tfengine}var D=Px();function oS(e,t){let n={a:e,b:t};return D.runKernel(wr,n)}var Wu={};Fe(Wu,{isBrowser:()=>Lx,isMobile:()=>lS});function uS(){return typeof navigator!="undefined"&&navigator!=null}function lS(e){if(e||uS()){if(e||(e=navigator),e.product==="ReactNative")return!0;let t=e.userAgent||e.vendor||window.opera;return/(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows ce|xda|xiino/i.test(t)||/1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i.test(t.substr(0,4))}return!1}function Lx(){return typeof window!="undefined"&&window.document!=null||typeof WorkerGlobalScope!="undefined"}var Aa=J();Aa.registerFlag("DEBUG",()=>!1,e=>{e&&console.warn("Debugging mode is ON. The output of every math call will be downloaded to CPU and checked for NaNs. This significantly impacts performance.")});Aa.registerFlag("IS_BROWSER",()=>Lx());Aa.registerFlag("IS_NODE",()=>typeof process!="undefined"&&typeof process.versions!="undefined"&&typeof process.versions.node!="undefined");Aa.registerFlag("IS_CHROME",()=>typeof navigator!="undefined"&&navigator!=null&&navigator.userAgent!=null&&/Chrome/.test(navigator.userAgent)&&/Google Inc/.test(navigator.vendor));Aa.registerFlag("PROD",()=>!1);Aa.registerFlag("TENSORLIKE_CHECK_SHAPE_CONSISTENCY",()=>Aa.getBool("DEBUG"));Aa.registerFlag("DEPRECATION_WARNINGS_ENABLED",()=>!0);Aa.registerFlag("IS_TEST",()=>!1);Aa.registerFlag("CHECK_COMPUTATION_FOR_ERRORS",()=>!0);Aa.registerFlag("WRAP_TO_IMAGEBITMAP",()=>!1);function $a(e,t){let n=e;if(tn(e))return t==="string"?[]:[e.length];if(!Array.isArray(e))return[];let a=[];for(;Array.isArray(n)||tn(n)&&t!=="string";)a.push(n.length),n=n[0];return Array.isArray(e)&&J().getBool("TENSORLIKE_CHECK_SHAPE_CONSISTENCY")&&Wx(e,a,[]),a}function Wx(e,t,n){if(n=n||[],!Array.isArray(e)&&!tn(e)){F(t.length===0,()=>`Element arr[${n.join("][")}] is a primitive, but should be an array/TypedArray of ${t[0]} elements`);return}F(t.length>0,()=>`Element arr[${n.join("][")}] should be a primitive, but is an array of ${e.length} elements`),F(e.length===t[0],()=>`Element arr[${n.join("][")}] should have ${t[0]} elements, but has ${e.length} elements`);let a=t.slice(1);for(let r=0;r=0&&(r=a),Bx(a,r,t,n),e==null||!tn(e)&&!Array.isArray(e)&&typeof e!="number"&&typeof e!="boolean"&&typeof e!="string"){let o=e==null?"null":e.constructor.name;throw new Error(`Argument '${t}' passed to '${n}' must be a Tensor or TensorLike, but got '${o}'`)}let s=$a(e,r);!tn(e)&&!Array.isArray(e)&&(e=[e]);let i=r!=="string"?oc(e,r):ss(e,[],!0);return D.makeTensor(i,s,r)}function Bu(e,t,n,a="numeric"){if(!Array.isArray(e))throw new Error(`Argument ${t} passed to ${n} must be a \`Tensor[]\` or \`TensorLike[]\``);return e.map((r,s)=>M(r,`${t}[${s}]`,n,a))}var Vx="__op";function O(e){let t=Object.keys(e);if(t.length!==1)throw new Error(`Please provide an object with a single key (operation name) mapping to a function. Got an object with ${t.length} keys.`);let n=t[0],a=e[n];n.endsWith("_")&&(n=n.substring(0,n.length-1)),n=n+Vx;let r=(...s)=>{D.startScope(n);try{let i=a(...s);return gm(i)&&console.error("Cannot return a Promise inside of tidy."),D.endScope(i),i}catch(i){throw D.endScope(null),i}};return Object.defineProperty(r,"name",{value:n,configurable:!0}),r}function dS(e,t){let n=M(e,"real","complex"),a=M(t,"imag","complex");sn(n.shape,a.shape,`real and imag shapes, ${n.shape} and ${a.shape}, must match in call to tf.complex().`);let r={real:n,imag:a};return D.runKernel(Mp,r)}var Nr=O({complex_:dS});function Tr(e,t,n,a){if(a==null&&(a=Sp(e)),a==="complex64")throw new Error("Cannot construct a complex64 tensor directly. Please use tf.complex(real, imag).");if(!tn(e)&&!Array.isArray(e)&&typeof e!="number"&&typeof e!="boolean"&&typeof e!="string")throw new Error("values passed to tensor(values) must be a number/boolean/string or an array of numbers/booleans/strings, or a TypedArray");if(t!=null){ym(t);let r=Nt(t),s=Nt(n);F(r===s,()=>`Based on the provided shape, [${t}], the tensor should have ${r} values but has ${s}`);for(let i=0;i`Error creating a new Tensor. Inferred shape (${n}) does not match the provided shape (${t}). `)}}return!tn(e)&&!Array.isArray(e)&&(e=[e]),t=t||n,e=a!=="string"?oc(e,a):ss(e,[],!0),D.makeTensor(e,t,a)}function ia(e,t,n){let a=$a(e,n);return Tr(e,t,a,n)}var Mm={float32:4,float16:2,int32:4,uint16:2,uint8:1,bool:1,complex64:8},pc=4;async function cS(e,t){let n=[],a=[],r=Array.isArray(e)?e.map(i=>i.name):Object.keys(e);for(let i=0;i{let c=await l.bytes(),h=c.reduce((A,y)=>A+y.length,0)+pc*c.length,m=new Uint8Array(h),f=0;for(let A=0;A{if(t+=s.byteLength,n.push(s.byteLength===s.buffer.byteLength?s:new s.constructor(s)),!(s instanceof Float32Array||s instanceof Int32Array||s instanceof Uint8Array))throw new Error(`Unsupported TypedArray subtype: ${s.constructor.name}`)});let a=new Uint8Array(t),r=0;return n.forEach(s=>{a.set(new Uint8Array(s.buffer),r),r+=s.byteLength}),a.buffer}var Fm=typeof Buffer!="undefined"&&(typeof Blob=="undefined"||typeof atob=="undefined"||typeof btoa=="undefined");function Ux(e){return Fm?Buffer.byteLength(e):new Blob([e]).size}function fS(e){if(Fm)return Buffer.from(e).toString("base64");let t=new Uint8Array(e),n="";for(let a=0,r=t.length;a{t+=r.byteLength});let n=new Uint8Array(t),a=0;return e.forEach(r=>{n.set(new Uint8Array(r),a),a+=r.byteLength}),n.buffer}function Hx(e){let t="/";for(e=e.trim();e.endsWith(t);)e=e.slice(0,e.length-1);let n=e.split(t);return n[n.length-1]}function Vu(e){if(e.modelTopology instanceof ArrayBuffer)throw new Error("Expected JSON model topology, received ArrayBuffer.");return{dateSaved:new Date,modelTopologyType:"JSON",modelTopologyBytes:e.modelTopology==null?0:Ux(JSON.stringify(e.modelTopology)),weightSpecsBytes:e.weightSpecs==null?0:Ux(JSON.stringify(e.weightSpecs)),weightDataBytes:e.weightData==null?0:e.weightData.byteLength}}function AS(){let e=n=>{let a=n<<13,r=0;for(;(a&8388608)==0;)r-=8388608,a<<=1;return a&=~8388608,r+=947912704,a|r},t=new Uint32Array(2048);t[0]=0;for(let n=1;n<1024;n++)t[n]=e(n);for(let n=1024;n<2048;n++)t[n]=939524096+(n-1024<<13);return t}function yS(){let e=new Uint32Array(64);e[0]=0,e[31]=1199570944,e[32]=2147483648,e[63]=3347054592;for(let t=1;t<31;t++)e[t]=t<<23;for(let t=33;t<63;t++)e[t]=2147483648+(t-32<<23);return e}function gS(){let e=new Uint32Array(64);for(let t=0;t<64;t++)e[t]=1024;return e[0]=e[32]=0,e}function hS(){let e=AS(),t=yS(),n=gS();return a=>{let r=new ArrayBuffer(4*a.length),s=new Uint32Array(r);for(let i=0;i>10]+(o&1023)]+t[o>>10];s[i]=l}return new Float32Array(r)}}var St=class{constructor(){this.saveRouters=[],this.loadRouters=[]}static getInstance(){return St.instance==null&&(St.instance=new St),St.instance}static registerSaveRouter(e){St.getInstance().saveRouters.push(e)}static registerLoadRouter(e){St.getInstance().loadRouters.push(e)}static getSaveHandlers(e){return St.getHandlers(e,"save")}static getLoadHandlers(e,t){return St.getHandlers(e,"load",t)}static getHandlers(e,t,n){let a=[];return(t==="load"?St.getInstance().loadRouters:St.getInstance().saveRouters).forEach(r=>{let s=r(e,n);s!==null&&a.push(s)}),a}},xS=e=>St.registerSaveRouter(e),bS=e=>St.registerLoadRouter(e),vS=e=>St.getSaveHandlers(e),wS=(e,t)=>St.getLoadHandlers(e,t),Dm="tensorflowjs",Om=1,ri="models_store",Er="model_info_store";function Gx(){if(!J().getBool("IS_BROWSER"))throw new Error("Failed to obtain IndexedDB factory because the current environmentis not a web browser.");let e=typeof window=="undefined"?self:window,t=e.indexedDB||e.mozIndexedDB||e.webkitIndexedDB||e.msIndexedDB||e.shimIndexedDB;if(t==null)throw new Error("The current browser does not appear to support IndexedDB.");return t}function zm(e){let t=e.result;t.createObjectStore(ri,{keyPath:"modelPath"}),t.createObjectStore(Er,{keyPath:"modelPath"})}var si=class{constructor(e){if(this.indexedDB=Gx(),e==null||!e)throw new Error("For IndexedDB, modelPath must not be null, undefined or empty.");this.modelPath=e}async save(e){if(e.modelTopology instanceof ArrayBuffer)throw new Error("BrowserLocalStorage.save() does not support saving model topology in binary formats yet.");return this.databaseAction(this.modelPath,e)}async load(){return this.databaseAction(this.modelPath)}databaseAction(e,t){return new Promise((n,a)=>{let r=this.indexedDB.open(Dm,Om);r.onupgradeneeded=()=>zm(r),r.onsuccess=()=>{let s=r.result;if(t==null){let i=s.transaction(ri,"readonly"),o=i.objectStore(ri).get(this.modelPath);o.onsuccess=()=>{if(o.result==null)return s.close(),a(new Error(`Cannot find model with path '${this.modelPath}' in IndexedDB.`));n(o.result.modelArtifacts)},o.onerror=l=>(s.close(),a(o.error)),i.oncomplete=()=>s.close()}else{let i=Vu(t),o=s.transaction(Er,"readwrite"),l=o.objectStore(Er),d=l.put({modelPath:this.modelPath,modelArtifactsInfo:i}),u;d.onsuccess=()=>{u=s.transaction(ri,"readwrite");let p=u.objectStore(ri).put({modelPath:this.modelPath,modelArtifacts:t,modelArtifactsInfo:i});p.onsuccess=()=>n({modelArtifactsInfo:i}),p.onerror=c=>{l=o.objectStore(Er);let h=l.delete(this.modelPath);h.onsuccess=()=>(s.close(),a(p.error)),h.onerror=m=>(s.close(),a(p.error))}},d.onerror=p=>(s.close(),a(d.error)),o.oncomplete=()=>{u==null?s.close():u.oncomplete=()=>s.close()}}},r.onerror=s=>a(r.error)})}};si.URL_SCHEME="indexeddb://";var qx=e=>J().getBool("IS_BROWSER")&&!Array.isArray(e)&&e.startsWith(si.URL_SCHEME)?kS(e.slice(si.URL_SCHEME.length)):null;St.registerSaveRouter(qx);St.registerLoadRouter(qx);function kS(e){return new si(e)}function IS(e){return e.startsWith(si.URL_SCHEME)?e.slice(si.URL_SCHEME.length):e}var SS=class{constructor(){this.indexedDB=Gx()}async listModels(){return new Promise((e,t)=>{let n=this.indexedDB.open(Dm,Om);n.onupgradeneeded=()=>zm(n),n.onsuccess=()=>{let a=n.result,r=a.transaction(Er,"readonly"),s=r.objectStore(Er).getAll();s.onsuccess=()=>{let i={};for(let o of s.result)i[o.modelPath]=o.modelArtifactsInfo;e(i)},s.onerror=i=>(a.close(),t(s.error)),r.oncomplete=()=>a.close()},n.onerror=a=>t(n.error)})}async removeModel(e){return e=IS(e),new Promise((t,n)=>{let a=this.indexedDB.open(Dm,Om);a.onupgradeneeded=()=>zm(a),a.onsuccess=()=>{let r=a.result,s=r.transaction(Er,"readwrite"),i=s.objectStore(Er),o=i.get(e),l;o.onsuccess=()=>{if(o.result==null)return r.close(),n(new Error(`Cannot find model with path '${e}' in IndexedDB.`));{let d=i.delete(e),u=()=>{l=r.transaction(ri,"readwrite");let p=l.objectStore(ri).delete(e);p.onsuccess=()=>t(o.result.modelArtifactsInfo),p.onerror=c=>n(o.error)};d.onsuccess=u,d.onerror=p=>(u(),r.close(),n(o.error))}},o.onerror=d=>(r.close(),n(o.error)),s.oncomplete=()=>{l==null?r.close():l.oncomplete=()=>r.close()}},a.onerror=r=>n(a.error)})}},er="/",rl="tensorflowjs_models",Xx="info",NS="model_topology",TS="weight_specs",ES="weight_data",CS="model_metadata";function Kx(e){return{info:[rl,e,Xx].join(er),topology:[rl,e,NS].join(er),weightSpecs:[rl,e,TS].join(er),weightData:[rl,e,ES].join(er),modelMetadata:[rl,e,CS].join(er)}}function RS(e){let t=e.split(er);if(t.length<3)throw new Error(`Invalid key format: ${e}`);return t.slice(1,t.length-1).join(er)}function MS(e){return e.startsWith(ii.URL_SCHEME)?e.slice(ii.URL_SCHEME.length):e}var ii=class{constructor(e){if(!J().getBool("IS_BROWSER")||typeof window=="undefined"||typeof window.localStorage=="undefined")throw new Error("The current environment does not support local storage.");if(this.LS=window.localStorage,e==null||!e)throw new Error("For local storage, modelPath must not be null, undefined or empty.");this.modelPath=e,this.keys=Kx(this.modelPath)}async save(e){if(e.modelTopology instanceof ArrayBuffer)throw new Error("BrowserLocalStorage.save() does not support saving model topology in binary formats yet.");{let t=JSON.stringify(e.modelTopology),n=JSON.stringify(e.weightSpecs),a=Vu(e);try{this.LS.setItem(this.keys.info,JSON.stringify(a)),this.LS.setItem(this.keys.topology,t),this.LS.setItem(this.keys.weightSpecs,n),this.LS.setItem(this.keys.weightData,fS(e.weightData));let r={format:e.format,generatedBy:e.generatedBy,convertedBy:e.convertedBy};return e.signature!=null&&(r.signature=e.signature),e.userDefinedMetadata!=null&&(r.userDefinedMetadata=e.userDefinedMetadata),e.modelInitializer!=null&&(r.modelInitializer=e.modelInitializer),this.LS.setItem(this.keys.modelMetadata,JSON.stringify(r)),{modelArtifactsInfo:a}}catch(r){throw this.LS.removeItem(this.keys.info),this.LS.removeItem(this.keys.topology),this.LS.removeItem(this.keys.weightSpecs),this.LS.removeItem(this.keys.weightData),this.LS.removeItem(this.keys.modelMetadata),new Error(`Failed to save model '${this.modelPath}' to local storage: size quota being exceeded is a possible cause of this failure: modelTopologyBytes=${a.modelTopologyBytes}, weightSpecsBytes=${a.weightSpecsBytes}, weightDataBytes=${a.weightDataBytes}.`)}}}async load(){let e=JSON.parse(this.LS.getItem(this.keys.info));if(e==null)throw new Error(`In local storage, there is no model with name '${this.modelPath}'`);if(e.modelTopologyType!=="JSON")throw new Error("BrowserLocalStorage does not support loading non-JSON model topology yet.");let t={},n=JSON.parse(this.LS.getItem(this.keys.topology));if(n==null)throw new Error(`In local storage, the topology of model '${this.modelPath}' is missing.`);t.modelTopology=n;let a=JSON.parse(this.LS.getItem(this.keys.weightSpecs));if(a==null)throw new Error(`In local storage, the weight specs of model '${this.modelPath}' are missing.`);t.weightSpecs=a;let r=this.LS.getItem(this.keys.modelMetadata);if(r!=null){let i=JSON.parse(r);t.format=i.format,t.generatedBy=i.generatedBy,t.convertedBy=i.convertedBy,i.signature!=null&&(t.signature=i.signature),i.userDefinedMetadata!=null&&(t.userDefinedMetadata=i.userDefinedMetadata),i.modelInitializer!=null&&(t.modelInitializer=i.modelInitializer)}let s=this.LS.getItem(this.keys.weightData);if(s==null)throw new Error(`In local storage, the binary weight values of model '${this.modelPath}' are missing.`);return t.weightData=mS(s),t}};ii.URL_SCHEME="localstorage://";var Zx=e=>J().getBool("IS_BROWSER")&&!Array.isArray(e)&&e.startsWith(ii.URL_SCHEME)?FS(e.slice(ii.URL_SCHEME.length)):null;St.registerSaveRouter(Zx);St.registerLoadRouter(Zx);function FS(e){return new ii(e)}var $S=class{constructor(){F(J().getBool("IS_BROWSER"),()=>"Current environment is not a web browser"),F(typeof window=="undefined"||typeof window.localStorage!="undefined",()=>"Current browser does not appear to support localStorage"),this.LS=window.localStorage}async listModels(){let e={},t=rl+er,n=er+Xx;for(let a=0;a"scheme must not be undefined or null."),e.endsWith(sl)&&(e=e.slice(0,e.indexOf(sl))),F(e.length>0,()=>"scheme must not be an empty string.");let n=Gn.getInstance();F(n.managers[e]==null,()=>`A model store manager is already registered for scheme '${e}'.`),n.managers[e]=t}static getManager(e){let t=this.getInstance().managers[e];if(t==null)throw new Error(`Cannot find model manager for scheme '${e}'`);return t}static getSchemes(){return Object.keys(this.getInstance().managers)}};function cc(e){if(e.indexOf(sl)===-1)throw new Error(`The url string provided does not contain a scheme. Supported schemes are: ${Gn.getSchemes().join(",")}`);return{scheme:e.split(sl)[0],path:e.split(sl)[1]}}async function Yx(e,t,n=!1){F(e!==t,()=>`Old path and new path are the same: '${e}'`);let a=St.getLoadHandlers(e);F(a.length>0,()=>`Copying failed because no load handler is found for source URL ${e}.`),F(a.length<2,()=>`Copying failed because more than one (${a.length}) load handlers for source URL ${e}.`);let r=a[0],s=St.getSaveHandlers(t);F(s.length>0,()=>`Copying failed because no save handler is found for destination URL ${t}.`),F(s.length<2,()=>`Copying failed because more than one (${a.length}) save handlers for destination URL ${t}.`);let i=s[0],o=cc(e).scheme,l=cc(e).path,d=o===cc(e).scheme,u=await r.load();n&&d&&await Gn.getManager(o).removeModel(l);let p=await i.save(u);return n&&!d&&await Gn.getManager(o).removeModel(l),p.modelArtifactsInfo}async function DS(){let e=Gn.getSchemes(),t={};for(let n of e){let a=await Gn.getManager(n).listModels();for(let r in a){let s=n+sl+r;t[s]=a[r]}}return t}async function OS(e){let t=cc(e);return Gn.getManager(t.scheme).removeModel(t.path)}async function zS(e,t){return Yx(e,t,!1)}async function _S(e,t){return Yx(e,t,!0)}var PS=class{fetch(e,t){return fetch(e,t)}now(){return performance.now()}encode(e,t){if(t!=="utf-8"&&t!=="utf8")throw new Error(`Browser's encoder only supports utf-8, but got ${t}`);return this.textEncoder==null&&(this.textEncoder=new TextEncoder),this.textEncoder.encode(e)}decode(e,t){return new TextDecoder(t).decode(e)}};if(J().get("IS_BROWSER")){J().setPlatform("browser",new PS);try{Gn.registerManager(ii.URL_SCHEME,new $S)}catch(e){}try{Gn.registerManager(si.URL_SCHEME,new SS)}catch(e){}}var LS={importFetch:()=>G9()},_m,WS=class{constructor(){this.util=require("util"),this.textEncoder=new this.util.TextEncoder}fetch(e,t){return J().global.fetch!=null?J().global.fetch(e,t):(_m==null&&(_m=LS.importFetch()),_m(e,t))}now(){let e=process.hrtime();return e[0]*1e3+e[1]/1e6}encode(e,t){if(t!=="utf-8"&&t!=="utf8")throw new Error(`Node built-in encoder only supports utf-8, but got ${t}`);return this.textEncoder.encode(e)}decode(e,t){return e.length===0?"":new this.util.TextDecoder(t).decode(e)}};J().get("IS_NODE")&&J().setPlatform("node",new WS);function We(e,t="float32",n){return t=t||"float32",ym(e),new Dt(e,t,n)}function BS(e,t){let n=M(e,"x","cast");if(!wx(t))throw new Error(`Failed to cast to unknown dtype ${t}`);if(t==="string"&&n.dtype!=="string"||t!=="string"&&n.dtype==="string")throw new Error("Only strings can be casted to strings");let a={x:n},r={dtype:t};return D.runKernel(ds,a,r)}var fe=O({cast_:BS});function VS(e){let t={x:M(e,"x","clone","string_or_numeric")};return D.runKernel(ks,t)}var Da=O({clone_:VS});function Jx(e,t=!1){console.log(e.toString(t))}Px();var jS={buffer:We,cast:fe,clone:Da,print:Jx};tS(jS);var vn={};Fe(vn,{browserFiles:()=>US,browserHTTPRequest:()=>GS,concatenateArrayBuffers:()=>$m,copyModel:()=>zS,decodeWeights:()=>jx,encodeWeights:()=>cS,fromMemory:()=>qS,getLoadHandlers:()=>wS,getModelArtifactsInfoForJSON:()=>Vu,getSaveHandlers:()=>vS,http:()=>Lm,isHTTPScheme:()=>Pm,listModels:()=>DS,loadWeights:()=>HS,moveModel:()=>_S,registerLoadRouter:()=>bS,registerSaveRouter:()=>xS,removeModel:()=>OS,weightsLoaderFactory:()=>Qx,withSaveHandler:()=>XS});var KS="model",ZS=".json",YS=".weights.bin";function eb(e){return new Promise(t=>setTimeout(t)).then(e)}var il=class{constructor(e){if(!J().getBool("IS_BROWSER"))throw new Error("browserDownloads() cannot proceed because the current environment is not a browser.");e.startsWith(il.URL_SCHEME)&&(e=e.slice(il.URL_SCHEME.length)),(e==null||e.length===0)&&(e=KS),this.modelTopologyFileName=e+ZS,this.weightDataFileName=e+YS}async save(e){if(typeof document=="undefined")throw new Error("Browser downloads are not supported in this environment since `document` is not present");let t=window.URL.createObjectURL(new Blob([e.weightData],{type:"application/octet-stream"}));if(e.modelTopology instanceof ArrayBuffer)throw new Error("BrowserDownloads.save() does not support saving model topology in binary formats yet.");{let n=[{paths:["./"+this.weightDataFileName],weights:e.weightSpecs}],a={modelTopology:e.modelTopology,format:e.format,generatedBy:e.generatedBy,convertedBy:e.convertedBy,weightsManifest:n};e.signature!=null&&(a.signature=e.signature),e.userDefinedMetadata!=null&&(a.userDefinedMetadata=e.userDefinedMetadata),e.modelInitializer!=null&&(a.modelInitializer=e.modelInitializer);let r=window.URL.createObjectURL(new Blob([JSON.stringify(a)],{type:"application/json"})),s=this.jsonAnchor==null?document.createElement("a"):this.jsonAnchor;if(s.download=this.modelTopologyFileName,s.href=r,await eb(()=>s.dispatchEvent(new MouseEvent("click"))),e.weightData!=null){let i=this.weightDataAnchor==null?document.createElement("a"):this.weightDataAnchor;i.download=this.weightDataFileName,i.href=t,await eb(()=>i.dispatchEvent(new MouseEvent("click")))}return{modelArtifactsInfo:Vu(e)}}}};il.URL_SCHEME="downloads://";var JS=class{constructor(e){if(e==null||e.length<1)throw new Error(`When calling browserFiles, at least 1 file is required, but received ${e}`);this.files=e}async load(){let e=this.files[0],t=this.files.slice(1);return new Promise((n,a)=>{let r=new FileReader;r.onload=s=>{let i=JSON.parse(s.target.result),o=i.modelTopology;if(o==null){a(new Error(`modelTopology field is missing from file ${e.name}`));return}t.length===0&&n({modelTopology:o});let l=i.weightsManifest;if(l==null){a(new Error(`weightManifest field is missing from file ${e.name}`));return}let d;try{d=this.checkManifestAndWeightFiles(l,t)}catch(h){a(h);return}let u=[],p=[],c=[];l.forEach(h=>{h.paths.forEach(m=>{p.push(m),c.push(null)}),u.push(...h.weights)}),l.forEach(h=>{h.paths.forEach(m=>{let f=new FileReader;f.onload=A=>{let y=A.target.result,g=p.indexOf(m);if(c[g]=y,c.indexOf(null)===-1){let x={modelTopology:o,weightSpecs:u,weightData:$m(c),format:i.format,generatedBy:i.generatedBy,convertedBy:i.convertedBy};i.signature!=null&&(x.signature=i.signature),i.userDefinedMetadata!=null&&(x.userDefinedMetadata=i.userDefinedMetadata),i.modelInitializer!=null&&(x.modelInitializer=i.modelInitializer),n(x)}},f.onerror=A=>a(`Failed to weights data from file of path '${m}'.`),f.readAsArrayBuffer(d[m])})})},r.onerror=s=>a(`Failed to read model topology and weights manifest JSON from file '${e.name}'. BrowserFiles supports loading Keras-style tf.Model artifacts only.`),r.readAsText(e)})}checkManifestAndWeightFiles(e,t){let n=[],a=t.map(s=>Hx(s.name)),r={};for(let s of e)s.paths.forEach(i=>{let o=Hx(i);if(n.indexOf(o)!==-1)throw new Error(`Duplicate file basename found in weights manifest: '${o}'`);if(n.push(o),a.indexOf(o)===-1)throw new Error(`Weight file with basename '${o}' is not provided.`);r[i]=t[a.indexOf(o)]});if(n.length!==t.length)throw new Error(`Mismatch in the number of files in weights manifest (${n.length}) and the number of weight files provided (${t.length}).`);return r}},eN=e=>J().getBool("IS_BROWSER")&&!Array.isArray(e)&&e.startsWith(il.URL_SCHEME)?QS(e.slice(il.URL_SCHEME.length)):null;St.registerSaveRouter(eN);function QS(e="model"){return new il(e)}function US(e){return new JS(e)}function tb(e,t,n,a){i(e),n=n==null?0:n,a=a==null?1:a,o(n,a);let r=0,s=l=>(l.then(d=>{let u=n+ ++r/e.length*(a-n);return t(u),d}),l);function i(l){F(l!=null&&Array.isArray(l)&&l.length>0,()=>"promises must be a none empty array")}function o(l,d){F(l>=0&&l<=1,()=>`Progress fraction must be in range [0, 1], but got startFraction ${l}`),F(d>=0&&d<=1,()=>`Progress fraction must be in range [0, 1], but got endFraction ${d}`),F(d>=l,()=>`startFraction must be no more than endFraction, but got startFraction ${l} and endFraction ${d}`)}return Promise.all(e.map(s))}async function nb(e,t){t==null&&(t={});let n=t.fetchFunc==null?J().platform.fetch:t.fetchFunc,a=e.map(d=>n(d,t.requestInit,{isBinary:!0})),r=0,s=.5,i=(t.onProgress==null?await Promise.all(a):await tb(a,t.onProgress,r,s)).map(d=>d.arrayBuffer()),o=.5,l=1;return t.onProgress==null?await Promise.all(i):await tb(i,t.onProgress,o,l)}async function HS(e,t="",n,a){return Qx(r=>nb(r,{requestInit:a}))(e,t,n)}function Qx(e){return async(t,n="",a)=>{let r=t.map(()=>!1),s={},i=a!=null?a.map(()=>!1):[],o=[];if(t.forEach((h,m)=>{let f=0;h.weights.forEach(A=>{let y="quantization"in A?A.quantization.dtype:A.dtype,g=Mm[y]*Nt(A.shape),x=()=>{r[m]=!0,s[m]==null&&(s[m]=[]),s[m].push({manifestEntry:A,groupOffset:f,sizeBytes:g})};a!=null?a.forEach((w,b)=>{w===A.name&&(x(),i[b]=!0)}):x(),o.push(A.name),f+=g})}),!i.every(h=>h)){let h=a.filter((m,f)=>!i[f]);throw new Error(`Could not find weights in manifest with names: ${h.join(", ")}. +Manifest JSON has weights with names: ${o.join(", ")}.`)}let l=r.reduce((h,m,f)=>(m&&h.push(f),h),[]),d=[];l.forEach(h=>{t[h].paths.forEach(m=>{let f=n+(n.endsWith("/")?"":"/")+m;d.push(f)})});let u=await e(d),p={},c=0;return l.forEach(h=>{let m=t[h].paths.length,f=0;for(let x=0;x{let w=A.slice(x.groupOffset,x.groupOffset+x.sizeBytes),b=jx(w,[x.manifestEntry]);for(let v in b)p[v]=b[v]}),c+=m}),p}}var tN="application/octet-stream",nN="application/json",Wm=class{constructor(e,t){if(this.DEFAULT_METHOD="POST",t==null&&(t={}),this.weightPathPrefix=t.weightPathPrefix,this.onProgress=t.onProgress,this.weightUrlConverter=t.weightUrlConverter,t.fetchFunc!=null?(F(typeof t.fetchFunc=="function",()=>"Must pass a function that matches the signature of `fetch` (see https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API)"),this.fetch=t.fetchFunc):this.fetch=J().platform.fetch,F(e!=null&&e.length>0,()=>"URL path for http must not be null, undefined or empty."),Array.isArray(e)&&F(e.length===2,()=>`URL paths for http must have a length of 2, (actual length is ${e.length}).`),this.path=e,t.requestInit!=null&&t.requestInit.body!=null)throw new Error("requestInit is expected to have no pre-existing body, but has one.");this.requestInit=t.requestInit||{}}async save(e){if(e.modelTopology instanceof ArrayBuffer)throw new Error("BrowserHTTPRequest.save() does not support saving model topology in binary formats yet.");let t=Object.assign({method:this.DEFAULT_METHOD},this.requestInit);t.body=new FormData;let n=[{paths:["./model.weights.bin"],weights:e.weightSpecs}],a={modelTopology:e.modelTopology,format:e.format,generatedBy:e.generatedBy,convertedBy:e.convertedBy,weightsManifest:n};e.signature!=null&&(a.signature=e.signature),e.userDefinedMetadata!=null&&(a.userDefinedMetadata=e.userDefinedMetadata),e.modelInitializer!=null&&(a.modelInitializer=e.modelInitializer),t.body.append("model.json",new Blob([JSON.stringify(a)],{type:nN}),"model.json"),e.weightData!=null&&t.body.append("model.weights.bin",new Blob([e.weightData],{type:tN}),"model.weights.bin");let r=await this.fetch(this.path,t);if(r.ok)return{modelArtifactsInfo:Vu(e),responses:[r]};throw new Error(`BrowserHTTPRequest.save() failed due to HTTP response status ${r.status}.`)}async load(){let e=await this.fetch(this.path,this.requestInit);if(!e.ok)throw new Error(`Request to ${this.path} failed with status code ${e.status}. Please verify this URL points to the model JSON of the model to load.`);let t;try{t=await e.json()}catch(h){let m=`Failed to parse model JSON of response from ${this.path}.`;throw this.path.endsWith(".pb")?m+=" Your path contains a .pb file extension. Support for .pb models have been removed in TensorFlow.js 1.0 in favor of .json models. You can re-convert your Python TensorFlow model using the TensorFlow.js 1.0 conversion scripts or you can convert your.pb models with the 'pb2json'NPM script in the tensorflow/tfjs-converter repository.":m+=" Please make sure the server is serving valid JSON for this request.",new Error(m)}let n=t.modelTopology,a=t.weightsManifest,r=t.generatedBy,s=t.convertedBy,i=t.format,o=t.signature,l=t.userDefinedMetadata;if(n==null&&a==null)throw new Error(`The JSON from HTTP path ${this.path} contains neither model topology or manifest for weights.`);let d,u;a!=null&&([d,u]=await this.loadWeights(a));let p={modelTopology:n,weightSpecs:d,weightData:u,generatedBy:r,convertedBy:s,format:i};o!=null&&(p.signature=o),l!=null&&(p.userDefinedMetadata=l);let c=t.modelInitializer;return c&&(p.modelInitializer=c),p}async loadWeights(e){let t=Array.isArray(this.path)?this.path[1]:this.path,[n,a]=aN(t),r=this.weightPathPrefix||n,s=[];for(let d of e)s.push(...d.weights);let i=[],o=[];for(let d of e)for(let u of d.paths)this.weightUrlConverter!=null?o.push(this.weightUrlConverter(u)):i.push(r+u+a);this.weightUrlConverter&&i.push(...await Promise.all(o));let l=await nb(i,{requestInit:this.requestInit,fetchFunc:this.fetch,onProgress:this.onProgress});return[s,$m(l)]}};Wm.URL_SCHEME_REGEX=/^https?:\/\//;function aN(e){let t=e.lastIndexOf("/"),n=e.lastIndexOf("?"),a=e.substring(0,t),r=n>t?e.substring(n):"";return[a+"/",r]}function Pm(e){return e.match(Wm.URL_SCHEME_REGEX)!=null}var ab=(e,t)=>{if(typeof fetch=="undefined"&&(t==null||t.fetchFunc==null))return null;{let n=!0;if(Array.isArray(e)?n=e.every(a=>Pm(a)):n=Pm(e),n)return Lm(e,t)}return null};St.registerSaveRouter(ab);St.registerLoadRouter(ab);function Lm(e,t){return new Wm(e,t)}function GS(e,t){return Lm(e,t)}var Bm=class{constructor(e){this.modelArtifacts=e}async load(){return this.modelArtifacts}},rN=class{constructor(e){this.saveHandler=e}async save(e){return this.saveHandler(e)}};function qS(e,t,n,a){return arguments.length===1?e.modelTopology!=null||e.weightSpecs!=null?new Bm(e):(console.warn("Please call tf.io.fromMemory() with only one argument. The argument should be of type ModelArtifacts. The multi-argument signature of tf.io.fromMemory() has been deprecated and will be removed in a future release."),new Bm({modelTopology:e})):(console.warn("Please call tf.io.fromMemory() with only one argument. The argument should be of type ModelArtifacts. The multi-argument signature of tf.io.fromMemory() has been deprecated and will be removed in a future release."),new Bm({modelTopology:e,weightSpecs:t,weightData:n,trainingConfig:a}))}function XS(e){return new rN(e)}var rb={};Fe(rb,{confusionMatrix:()=>sN});function iN(e,t,n=!1,a=!1){let r=M(e,"a","matMul"),s=M(t,"b","matMul");[r,s]=bt(r,s);let i={a:r,b:s},o={transposeA:n,transposeB:a};return D.runKernel(us,i,o)}var Be=O({matMul_:iN});function oN(e,t,n=1,a=0){if(t<2)throw new Error(`Error in oneHot: depth must be >=2, but it is ${t}`);let r={indices:M(e,"indices","oneHot","int32")},s={depth:t,onValue:n,offValue:a};return D.runKernel(Ds,r,s)}var ol=O({oneHot_:oN});function lN(e,t){let n=M(e,"x","transpose");if(t==null&&(t=n.shape.map((s,i)=>i).reverse()),F(n.rank===t.length,()=>`Error in transpose: rank of input ${n.rank} must match length of perm ${t}.`),t.forEach(s=>{F(s>=0&&s`All entries in 'perm' must be between 0 and ${n.rank-1} but got ${t}`)}),n.rank<=1)return n.clone();let a={x:n},r={perm:t};return D.runKernel(Qs,a,r)}var Ze=O({transpose_:lN});function uN(e,t,n){let a=M(e,"labels","confusionMatrix"),r=M(t,"predictions","confusionMatrix");F(n==null||n>0&&Number.isInteger(n),()=>`If provided, numClasses must be a positive integer, but got ${n}`),F(a.rank===1,()=>`Expected the rank of labels to be 1, but got ${a.rank}`),F(r.rank===1,()=>`Expected the rank of predictions to be 1, but got ${r.rank}`),F(a.shape[0]===r.shape[0],()=>`Mismatch in the number of examples: ${a.shape[0]} vs. ${r.shape[0]}. Labels and predictions should have the same number of elements.`),F(n>0&&Number.isInteger(n),()=>`numClasses is required to be a positive integer, but got ${n}`);let s=ol(fe(a,"int32"),n),i=ol(fe(r,"int32"),n),o=Ze(s),l=Be(o,i);return fe(l,"int32")}var sN=O({confusionMatrix_:uN}),oi={};Fe(oi,{fromPixels:()=>cN,fromPixelsAsync:()=>dN,toPixels:()=>pN});function hc(e,t,n){if(rs(e),t!=null&&t.length!==3)throw new Error("tensor3d() requires shape to have three numbers");let a=$a(e,n);if(a.length!==3&&a.length!==1)throw new Error("tensor3d() requires values to be number[][][] or flat/TypedArray");if(a.length===1&&t==null)throw new Error("tensor3d() requires shape to be provided when `values` are a flat array");return Tr(e,t,a,n)}var ll;function sb(e,t=3){if(t>4)throw new Error("Cannot construct Tensor with more than 4 channels from pixels.");if(e==null)throw new Error("pixels passed to tf.browser.fromPixels() can not be null");let n=!1,a=!1,r=!1,s=!1,i=!1,o=!1;if(e.data instanceof Uint8Array)n=!0;else if(typeof ImageData!="undefined"&&e instanceof ImageData)a=!0;else if(typeof HTMLVideoElement!="undefined"&&e instanceof HTMLVideoElement)r=!0;else if(typeof HTMLImageElement!="undefined"&&e instanceof HTMLImageElement)s=!0;else if(e.getContext!=null)i=!0;else if(typeof ImageBitmap!="undefined"&&e instanceof ImageBitmap)o=!0;else throw new Error(`pixels passed to tf.browser.fromPixels() must be either an HTMLVideoElement, HTMLImageElement, HTMLCanvasElement, ImageData in browser, or OffscreenCanvas, ImageData in webworker or {data: Uint32Array, width: number, height: number}, but was ${e.constructor.name}`);if(r){let c=2;if(r&&e.readyState element.")}if(ic(sc,D.backendName)!=null){let c={pixels:e},h={numChannels:t};return D.runKernel(sc,c,h)}let[l,d]=r?[e.videoWidth,e.videoHeight]:[e.width,e.height],u;i?u=e.getContext("2d").getImageData(0,0,l,d).data:a||n?u=e.data:(s||r||o)&&(ll==null&&(ll=document.createElement("canvas").getContext("2d")),ll.canvas.width=l,ll.canvas.height=d,ll.drawImage(e,0,0,l,d),u=ll.getImageData(0,0,l,d).data);let p;if(t===4)p=new Int32Array(u);else{let c=l*d;p=new Int32Array(c*t);for(let h=0;h4||s===2)throw new Error(`toPixels only supports depth of size 1, 3 or 4 but got ${s}`);if(n.dtype!=="float32"&&n.dtype!=="int32")throw new Error(`Unsupported type for toPixels: ${n.dtype}. Please use float32 or int32 tensors.`);let i=await n.data(),o=n.dtype==="float32"?255:1,l=new Uint8ClampedArray(r*a*4);for(let d=0;d1)throw new Error(`Tensor values for a float32 Tensor must be in the range [0 - 1] but encountered ${h}.`)}else if(n.dtype==="int32"&&(h<0||h>255))throw new Error(`Tensor values for a int32 Tensor must be in the range [0 - 255] but encountered ${h}.`);s===1?(u[0]=h*o,u[1]=h*o,u[2]=h*o):u[c]=h*o}let p=d*4;l[p+0]=Math.round(u[0]),l[p+1]=Math.round(u[1]),l[p+2]=Math.round(u[2]),l[p+3]=Math.round(u[3])}if(t!=null){t.width=r,t.height=a;let d=t.getContext("2d"),u=new ImageData(l,r,a);d.putImageData(u,0,0)}return n!==e&&n.dispose(),l}var cN=O({fromPixels_:sb}),Vm={};Fe(Vm,{prepareAndValidate:()=>ib});function ib(e,t){let n=e.shape.length,a=t.shape.length;if(n<1)throw new Error(`tf.gatherND() expects the input to be rank 1 or higher, but the rank was ${n}.`);if(a<1)throw new Error(`tf.gatherND() expects the indices to be rank 1 or higher, but the rank was ${a}.`);if(t.dtype!=="int32")throw new Error(`tf.gatherND() expects the indices to be int32 type, but the dtype was ${t.dtype}.`);if(t.shape[a-1]>n)throw new Error(`index innermost dimension length must be <= tensor rank; saw: ${t.shape[a-1]} vs. ${n}`);if(Nt(e.shape)===0)throw new Error(`Requested more than 0 entries, but input is empty. Input shape: ${e.shape}.`);let r=t.shape,s=r[r.length-1],i=1;for(let p=0;pp/d),1].slice(0,s);return[l,i,d,u]}var jm={};Fe(jm,{calculateShapes:()=>ob,validateInput:()=>Hm,validateUpdateShape:()=>Um});function Um(e,t,n){let a=t.rank>1?t.shape[t.rank-1]:1,r=t.rank>1?t.rank-1:1,s=`Must have updates.shape = indices.shape[:batchDim] + shape[sliceDim:], got updates.shape: ${n.shape}, indices.shape: ${t.shape}, shape: ${e}, sliceDim: ${a}, and batchDim: ${r}.`;if(n.rank1?t.shape[a-1]:1,s=n.length,i=1;for(let p=r;pyN,computeFlatOffset:()=>xN,computeOutShape:()=>lb,getNormalizedAxes:()=>db,isSliceContinous:()=>gN,maskToAxes:()=>fc,parseSliceParams:()=>Ab,sliceInfo:()=>bN,startForAxis:()=>fb,startIndicesWithElidedDims:()=>pb,stopForAxis:()=>mb,stopIndicesWithElidedDims:()=>cb,stridesForAxis:()=>hb,stridesWithElidedDims:()=>ub});function yN(e,t,n){let a=e.shape.length;F(a===t.length,()=>`Error in slice${a}D: Length of begin ${t} must match the rank of the array (${a}).`),F(a===n.length,()=>`Error in slice${a}D: Length of size ${n} must match the rank of the array (${a}).`);for(let r=0;r`Error in slice${a}D: begin[${r}] + size[${r}] (${t[r]+n[r]}) would overflow input.shape[${r}] (${e.shape[r]})`)}function fc(e){let t=[],n=0;for(;e>0;)e&1&&t.push(n),e/=2,n++;return t}function lb(e,t,n){let a=[];for(let r=0;r0){let h=t[0],m=n+1;u=pb(i,h,m,a,e),p=cb(o,h,m,r,e),c=ub(s,h,m,e)}else for(let h=0;h-1)s[o]=0;else{let l=yb(t,n,o),d=a[l];e&1<-1)s[o]=Number.MAX_SAFE_INTEGER;else{let l=yb(t,n,o),d=a[l];e&1<0?i=Number.MIN_SAFE_INTEGER:i=Number.MAX_SAFE_INTEGER);let l=a[r];return i<0&&(i+=l),i=fu(0,i,l-1),i}function mb(e,t,n,a,r,s){let i=t[r],o=n[r]||1;(e&1<0?i=Number.MAX_SAFE_INTEGER:i=Number.MIN_SAFE_INTEGER);let l=a[r];return i<0&&(i+=l),o>0?i=fu(0,i,l):i=fu(-1,i,l-1),i}function gN(e,t,n){let a=n.length;for(let r=0;r1){a=r;break}for(let r=a+1;r0||n[r]!==e[r])return!1;return!0}function xN(e,t){let n=e.length>0?e[e.length-1]:1;for(let a=0;a{F(i!==-1,()=>"slice() does not support negative begin indexing.")});let s;return n==null?s=new Array(r).fill(-1):typeof n=="number"?s=[n,...new Array(r-1).fill(-1)]:n.lengthi>=0?i:(F(i===-1,()=>`Negative size values should be exactly -1 but got ${i} for the slice() size at index ${o}.`),e.shape[o]-a[o])),[a,s]}function bN(e,t,n,a,r,s,i,o,l){let d=t.slice(),u=n.slice(),p=a;a==null&&(p=new Array(d.length));let c=fc(i);if(c.length>1)throw new Error("Multiple ellipses in slice is not allowed.");if(i!==0&&o!==0)throw new Error("Using both ellipsisMask and newAxisMask is not yet supported.");if(i!==0&&l!==0)throw new Error("Using both ellipsisMask and shrinkAxisMask is not yet supported.");let h=e.length-d.length,m=fc(o),f=e.slice();m.forEach(v=>{d[v]=0,u[v]=1,f.splice(v,0,1)});let{begin:A,end:y,strides:g}=db(f,c,h,d,u,p,r,s,i);d=A,u=y,p=g;let x=fc(l);x.forEach(v=>{u[v]=d[v]+1,p[v]=1});let w=lb(d,u,p),b=w.filter((v,N)=>x.indexOf(N)===-1);return{nonStrided:p.every(v=>v===1),$begin:d,$end:u,$strides:p,size:w,newShape:f,outShape:b}}var ae={};Fe(ae,{Serializable:()=>xb,SerializationMap:()=>li,registerClass:()=>Cr});var xb=class{getClassName(){return this.constructor.className}static fromConfig(e,t){return new e(t)}},li=class{constructor(){this.classNameMap={}}static getMap(){return li.instance==null&&(li.instance=new li),li.instance}static register(e){li.getMap().classNameMap[e.className]=[e,e.fromConfig]}};function Cr(e){F(e.className!=null,()=>"Class being registered does not have the static className property defined."),F(typeof e.className=="string",()=>"className is required to be a string, but got type "+typeof e.className),F(e.className.length>0,()=>"Class being registered has an empty-string as its className, which is disallowed."),li.register(e)}var bb={};Fe(bb,{TEST_EPSILON_FLOAT16:()=>vb,encodeStrings:()=>wb,expectArrayBuffersEqual:()=>NN,expectArraysClose:()=>vN,expectArraysEqual:()=>kN,expectNumbersClose:()=>IN,expectPromiseToFail:()=>wN,expectValuesInRange:()=>SN,testEpsilon:()=>Gm});var TN=.001,vb=.1;function vN(e,t,n){return n==null&&(n=Gm()),qm(e,t,(a,r)=>Xm(a,r,n))}function Gm(){return D.backend.floatPrecision()===32?TN:vb}function qm(e,t,n){let a=!0;if((tn(e)||tn(t))&&(a=!1),tn(e)&&tn(t)&&(a=!0),a){let i=e.constructor.name,o=t.constructor.name;if(i!==o)throw new Error(`Arrays are of different type. Actual: ${i}. Expected: ${o}`)}if(Array.isArray(e)&&Array.isArray(t)){let i=$a(e),o=$a(t);if(!Qa(i,o))throw new Error(`Arrays have different shapes. Actual: [${i}]. Expected: [${o}]`)}let r=tn(e)?e:ss(e),s=tn(t)?t:ss(t);if(r.length!==s.length)throw new Error(`Arrays have different lengths actual: ${r.length} vs expected: ${s.length}. Actual: ${r}. Expected: ${s}.`);for(let i=0;it.fail(),()=>t())}function kN(e,t){let n=typeof t=="string"||typeof t=="number"||typeof t=="boolean"?[t]:t;return vr(e)||vr(e[0])||vr(t)||vr(t[0])?qm(e,n,(a,r)=>a==r):qm(e,t,(a,r)=>Xm(a,r,0))}function IN(e,t,n){if(n==null&&(n=Gm()),!Xm(e,t,n))throw new Error(`Numbers differ: actual === ${e}, expected === ${t}`)}function Xm(e,t,n){return!isFinite(e)&&!isFinite(t)?!0:!(isNaN(e)||isNaN(t)||Math.abs(e-t)>n)}function SN(e,t,n){for(let a=0;an)throw new Error(`Value out of range:${e[a]} low: ${t}, high: ${n}`)}function NN(e,t){expect(new Float32Array(e)).toEqual(new Float32Array(t))}function wb(e){for(let t=0;tt.dispose())}function Ut(e){return D.keep(e)}function DN(e){return D.time(e)}function ON(e){return D.setBackend(e)}function zN(){return D.ready()}function _N(){return D.backendName}function PN(e){D.removeBackend(e)}function Zm(e){return D.findBackend(e)}function LN(e){return D.findBackendFactory(e)}function dl(e,t,n=1){return D.registerBackend(e,t,n)}function kb(){return D.backend}function WN(e,t){J().setPlatform(e,t)}function BN(e,t){let n=M(e,"a","add"),a=M(t,"b","add");[n,a]=vt(n,a);let r={a:n,b:a};return D.runKernel(kr,r)}var se=O({add_:BN});function VN(e,t){let n=M(e,"a","floorDiv"),a=M(t,"b","floorDiv");[n,a]=vt(n,a);let r={a:n,b:a};return D.runKernel(vs,r)}var Ac=O({floorDiv_:VN});function jN(e,t){let n=M(e,"a","div"),a=M(t,"b","div");if([n,a]=vt(n,a),n.dtype==="int32"&&a.dtype==="int32")return Ac(n,a);let r={a:n,b:a},s={};return D.runKernel(gs,r,s)}var me=O({div_:jN});function UN(e,t){let n=M(e,"a","mul"),a=M(t,"b","mul");[n,a]=vt(n,a);let r={a:n,b:a};return D.runKernel(Ds,r)}var _=O({mul_:UN});function HN(e){let t=M(e,"x","abs");if(t.dtype==="complex64"){let n={x:t};return D.runKernel(xu,n)}else{let n={x:t};return D.runKernel(eo,n)}}var zt=O({abs_:HN});function GN(e){let t={x:M(e,"x","acos")};return D.runKernel(to,t)}var Ym=O({acos_:GN});function qN(e){let t={x:M(e,"x","acosh")};return D.runKernel(no,t)}var Jm=O({acosh_:qN});function XN(e){F(Array.isArray(e),()=>"The argument passed to tf.addN() must be a list of tensors"),F(e.length>=1,()=>`Must pass at least one tensor to tf.addN(), but got ${e.length}`);let t=e.map((r,s)=>M(r,`tensors${s}`,"addN")),n=t[0];t.forEach(r=>{if(r.dtype!==n.dtype)throw new Error("All tensors passed to tf.addN() must have the same dtype")}),t.forEach(r=>{if(!er(r.shape,n.shape))throw new Error("All tensors passed to tf.addN() must have the same shape")});let a=t;return D.runKernel(os,a)}var yc=O({addN_:XN});function KN(e,t=null,n=!1){let a={x:M(e,"x","all","bool")},r={axis:t,keepDims:n};return D.runKernel(ao,a,r)}var gc=O({all_:KN});function ZN(e,t=null,n=!1){let a={x:M(e,"x","any","bool")},r={axis:t,keepDims:n};return D.runKernel(ro,a,r)}var ju=O({any_:ZN});function YN(e,t=0){let n={x:M(e,"x","argMax")},a={axis:t};return D.runKernel(ls,n,a)}var Uu=O({argMax_:YN});function JN(e,t=0){let n={x:M(e,"x","argMin")},a={axis:t};return D.runKernel(Au,n,a)}var Qm=O({argMin_:JN});function QN(e){let t={x:M(e,"x","asin")};return D.runKernel(so,t)}var eA=O({asin_:QN});function eT(e){let t={x:M(e,"x","asinh")};return D.runKernel(io,t)}var tA=O({asinh_:eT});function tT(e){let t={x:M(e,"x","atan")};return D.runKernel(oo,t)}var nA=O({atan_:tT});function nT(e,t){let n=M(e,"a","atan2"),a=M(t,"b","atan2");[n,a]=vt(n,a);let r={a:n,b:a};return D.runKernel(uo,r)}var aA=O({atan2_:nT});function aT(e){let t={x:M(e,"x","atanh")};return D.runKernel(lo,t)}var rA=O({atanh_:aT});function rT(e,t,n,a,r="NHWC",s){let i=e[3],o=[...t,i],l=Ib(r);return Hu(e,o,n,s,a,null,null,l)}function Sb(e,t,n,a,r,s,i="channelsLast"){let[o,l]=xc(t),d;if(i==="channelsLast")d=[o,l,e[3],e[3]];else if(i==="channelsFirst")d=[o,l,e[1],e[1]];else throw new Error(`Unknown dataFormat ${i}`);return Hu(e,d,n,a,r,s,!1,i)}function sT(e,t,n,a,r,s,i="NDHWC"){let[o,l,d]=sA(t),u,p;if(i==="NDHWC")p="channelsLast",u=[o,l,d,e[4],e[4]];else if(i==="NCDHW")p="channelsFirst",u=[o,l,d,e[1],e[1]];else throw new Error(`Unknown dataFormat ${i}`);return Nb(e,u,n,a,r,!1,p,s)}function Hu(e,t,n,a,r,s,i=!1,o="channelsLast"){let[l,d,u,p]=[-1,-1,-1,-1];if(o==="channelsLast")[l,d,u,p]=e;else if(o==="channelsFirst")[l,p,d,u]=e;else throw new Error(`Unknown dataFormat ${o}`);let[c,h,,m]=t,[f,A]=xc(n),[y,g]=xc(a),x=pl(c,y),w=pl(h,g),{padInfo:b,outHeight:v,outWidth:N}=iT(r,d,u,f,A,x,w,s,o),T=i?m*p:m,R;return o==="channelsFirst"?R=[l,T,v,N]:o==="channelsLast"&&(R=[l,v,N,T]),{batchSize:l,dataFormat:o,inHeight:d,inWidth:u,inChannels:p,outHeight:v,outWidth:N,outChannels:T,padInfo:b,strideHeight:f,strideWidth:A,filterHeight:c,filterWidth:h,effectiveFilterHeight:x,effectiveFilterWidth:w,dilationHeight:y,dilationWidth:g,inShape:e,outShape:R,filterShape:t}}function Nb(e,t,n,a,r,s=!1,i="channelsLast",o){let[l,d,u,p,c]=[-1,-1,-1,-1,-1];if(i==="channelsLast")[l,d,u,p,c]=e;else if(i==="channelsFirst")[l,c,d,u,p]=e;else throw new Error(`Unknown dataFormat ${i}`);let[h,m,f,,A]=t,[y,g,x]=sA(n),[w,b,v]=sA(a),N=pl(h,w),T=pl(m,b),R=pl(f,v),{padInfo:$,outDepth:z,outHeight:P,outWidth:V}=oT(r,d,u,p,y,g,x,N,T,R,o),j=s?A*c:A,U;return i==="channelsFirst"?U=[l,j,z,P,V]:i==="channelsLast"&&(U=[l,z,P,V,j]),{batchSize:l,dataFormat:i,inDepth:d,inHeight:u,inWidth:p,inChannels:c,outDepth:z,outHeight:P,outWidth:V,outChannels:j,padInfo:$,strideDepth:y,strideHeight:g,strideWidth:x,filterDepth:h,filterHeight:m,filterWidth:f,effectiveFilterDepth:N,effectiveFilterHeight:T,effectiveFilterWidth:R,dilationDepth:w,dilationHeight:b,dilationWidth:v,inShape:e,outShape:U,filterShape:t}}function lT(e,t,n,a,r){a==null&&(a=iA(e,t,n));let s=e[0],i=e[1],o=di((s-t+2*a)/n+1,r),l=di((i-t+2*a)/n+1,r);return[o,l]}function uT(e,t,n,a,r,s){r==null&&(r=iA(e,t,a));let i=e[0],o=e[1],l=e[2],d=di((i-t+2*r)/a+1,s),u=di((o-t+2*r)/a+1,s),p=di((l-t+2*r)/a+1,s);return[d,u,p,n]}function iA(e,t,n,a=1){let r=pl(t,a);return Math.floor((e[0]*(n-1)-n+r)/2)}function xc(e){return typeof e=="number"?[e,e,e]:e.length===2?[e[0],e[1],1]:e}function sA(e){return typeof e=="number"?[e,e,e]:e}function pl(e,t){return t<=1?e:e+(e-1)*(t-1)}function iT(e,t,n,a,r,s,i,o,l){let d,u,p;if(typeof e=="number"){d={top:e,bottom:e,left:e,right:e,type:e===0?"VALID":"NUMBER"};let c=lT([t,n],s,a,e,o);u=c[0],p=c[1]}else if(e==="same"){u=Math.ceil(t/a),p=Math.ceil(n/r);let c=Math.max(0,(u-1)*a+s-t),h=Math.max(0,(p-1)*r+i-n),m=Math.floor(c/2),f=c-m,A=Math.floor(h/2),y=h-A;d={top:m,bottom:f,left:A,right:y,type:"SAME"}}else if(e==="valid")d={top:0,bottom:0,left:0,right:0,type:"VALID"},u=Math.ceil((t-s+1)/a),p=Math.ceil((n-i+1)/r);else if(typeof e=="object"){let c=l==="channelsLast"?e[1][0]:e[2][0],h=l==="channelsLast"?e[1][1]:e[2][1],m=l==="channelsLast"?e[2][0]:e[3][0],f=l==="channelsLast"?e[2][1]:e[3][1];d={top:c,bottom:h,left:m,right:f,type:c===0&&h===0&&m===0&&f===0?"VALID":"EXPLICIT"},u=di((t-s+c+h)/a+1,o),p=di((n-i+m+f)/r+1,o)}else throw Error(`Unknown padding parameter: ${e}`);return{padInfo:d,outHeight:u,outWidth:p}}function oT(e,t,n,a,r,s,i,o,l,d,u){let p,c,h,m;if(typeof e=="number"){p={top:e,bottom:e,left:e,right:e,front:e,back:e,type:e===0?"VALID":"NUMBER"};let f=uT([t,n,a,1],o,1,r,e,u);c=f[0],h=f[1],m=f[2]}else if(e==="same"){c=Math.ceil(t/r),h=Math.ceil(n/s),m=Math.ceil(a/i);let f=(c-1)*r+o-t,A=(h-1)*s+l-n,y=(m-1)*i+d-a,g=Math.floor(f/2),x=f-g,w=Math.floor(A/2),b=A-w,v=Math.floor(y/2),N=y-v;p={top:w,bottom:b,left:v,right:N,front:g,back:x,type:"SAME"}}else if(e==="valid")p={top:0,bottom:0,left:0,right:0,front:0,back:0,type:"VALID"},c=Math.ceil((t-o+1)/r),h=Math.ceil((n-l+1)/s),m=Math.ceil((a-d+1)/i);else throw Error(`Unknown padding parameter: ${e}`);return{padInfo:p,outDepth:c,outHeight:h,outWidth:m}}function di(e,t){if(!t)return Math.trunc(e);switch(t){case"round":return Math.round(e);case"ceil":return Math.ceil(e);case"floor":return Math.floor(e);default:throw new Error(`Unknown roundingMode ${t}`)}}function Mr(e){let[t,n,a]=xc(e);return t===1&&n===1&&a===1}function za(e,t){return Mr(e)||Mr(t)}function Ib(e){if(e==="NHWC")return"channelsLast";if(e==="NCHW")return"channelsFirst";throw new Error(`Unknown dataFormat ${e}`)}function dT(e,t){let n={x:M(e,"x","reshape","string_or_numeric")},a={shape:t};return D.runKernel(Bo,n,a)}var H=O({reshape_:dT});function pT(e,t,n,a,r){let s=M(e,"x","avgPool","float32"),i=1;F(za(n,i),()=>`Error in avgPool: Either strides or dilations must be 1. Got strides ${n} and dilations '${i}'`);let o=s,l=!1;s.rank===3&&(l=!0,o=H(s,[1,s.shape[0],s.shape[1],s.shape[2]])),F(o.rank===4,()=>`Error in avgPool: x must be rank 4 but got rank ${o.rank}.`),r!=null&&F(jt(a),()=>`Error in avgPool: pad must be an integer when using, dimRoundingMode ${r} but got pad ${a}.`);let d={x:o},u={filterSize:t,strides:n,pad:a,dimRoundingMode:r},p=D.runKernel(us,d,u);return p=fe(p,s.dtype),l?H(p,[p.shape[1],p.shape[2],p.shape[3]]):p}var Gu=O({avgPool_:pT});function cT(e,t,n,a,r,s="NDHWC"){let i=M(e,"x","avgPool3d","float32"),o=i,l=!1;i.rank===4&&(l=!0,o=H(i,[1,i.shape[0],i.shape[1],i.shape[2],i.shape[3]])),F(o.rank===5,()=>`Error in avgPool3d: x must be rank 5 but got rank ${o.rank}.`),F(s==="NDHWC",()=>`Error in avgPool3d: Only NDHWC is currently supported, but got dataFormat of ${s}`),r!=null&&F(jt(a),()=>`Error in avgPool3d: pad must be an integer when using, dimRoundingMode ${r} but got pad ${a}.`);let d={x:o},u={filterSize:t,strides:n,pad:a,dimRoundingMode:r,dataFormat:s},p=D.runKernel(yu,d,u);return p=fe(p,o.dtype),l?H(p,[p.shape[1],p.shape[2],p.shape[3],p.shape[4]]):p}var oA=O({avgPool3d_:cT});function hT(e,t=0){F(e.length>=1,()=>"Pass at least one tensor to concat");let n=Bu(e,"tensors","concat","string_or_numeric");if(n[0].dtype==="complex64"&&n.forEach(s=>{if(s.dtype!=="complex64")throw new Error(`Cannot concatenate complex64 tensors with a tensor - with dtype ${s.dtype}. `)}),n.length===1)return Oa(n[0]);let a=n,r={axis:t};return D.runKernel(po,a,r)}var ot=O({concat_:hT});function fT(e){let t={x:M(e,"x","sigmoid")};return D.runKernel(Gs,t)}var kn=O({sigmoid_:fT});function mT(e,t,n){let a=M(e,"x","slice","string_or_numeric");if(a.rank===0)throw new Error("Slicing scalar is not possible");let r={x:a},s={begin:t,size:n};return D.runKernel(Ho,r,s)}var Re=O({slice_:mT});function AT(e){let t={x:M(e,"x","tanh")};return D.runKernel(Qs,t)}var pi=O({tanh_:AT});function yT(e,t,n,a,r,s){let i=M(e,"forgetBias","basicLSTMCell"),o=M(t,"lstmKernel","basicLSTMCell"),l=M(n,"lstmBias","basicLSTMCell"),d=M(a,"data","basicLSTMCell"),u=M(r,"c","basicLSTMCell"),p=M(s,"h","basicLSTMCell"),c=ot([d,p],1),h=Be(c,o),m=se(h,l),f=m.shape[0],A=m.shape[1]/4,y=[f,A],g=Re(m,[0,0],y),x=Re(m,[0,A],y),w=Re(m,[0,A*2],y),b=Re(m,[0,A*3],y),v=se(_(kn(g),pi(x)),_(u,kn(se(i,w)))),N=_(pi(v),kn(b));return[v,N]}var gT=O({basicLSTMCell_:yT});function xT(e,t,n){let a=M(e,"x","batchToSpaceND"),r=t.reduce((o,l)=>o*l);F(a.rank>=1+t.length,()=>`input rank is ${a.rank} but should be > than blockShape.length ${t.length}`),F(n.length===t.length,()=>`crops.length is ${n.length} but should be equal to blockShape.length ${t.length}`),F(a.shape[0]%r==0,()=>`input tensor batch is ${a.shape[0]} but is not divisible by the product of the elements of blockShape ${t.join(" * ")} === ${r}`);let s={x:a},i={blockShape:t,crops:n};return D.runKernel(gu,s,i)}var qu=O({batchToSpaceND_:xT});function bT(e){let t;return e.rank===0||e.rank===1?t=H(e,[1,1,1,e.size]):e.rank===2?t=H(e,[1,1,e.shape[0],e.shape[1]]):e.rank===3?t=H(e,[1,e.shape[0],e.shape[1],e.shape[2]]):t=e,t}function vT(e,t,n,a,r,s){s==null&&(s=.001);let i=M(e,"x","batchNorm"),o=M(t,"mean","batchNorm"),l=M(n,"variance","batchNorm"),d;r!=null&&(d=M(r,"scale","batchNorm"));let u;a!=null&&(u=M(a,"offset","batchNorm")),F(o.rank===l.rank,()=>"Batch normalization gradient requires mean and variance to have equal ranks."),F(u==null||o.rank===u.rank,()=>"Batch normalization gradient requires mean and offset to have equal ranks."),F(d==null||o.rank===d.rank,()=>"Batch normalization gradient requires mean and scale to have equal ranks.");let p={x:bT(i),scale:d,offset:u,mean:o,variance:l},c={varianceEpsilon:s},h=D.runKernel(ws,p,c);return H(h,i.shape)}var ci=O({batchNorm_:vT});function wT(e,t,n,a,r,s){let i=M(e,"x","batchNorm"),o=M(t,"mean","batchNorm"),l=M(n,"variance","batchNorm"),d;r!=null&&(d=M(r,"scale","batchNorm"));let u;return a!=null&&(u=M(a,"offset","batchNorm")),F(i.rank===2,()=>`Error in batchNorm2D: x must be rank 2 but got rank ${i.rank}.`),F(o.rank===2||o.rank===1,()=>`Error in batchNorm2D: mean must be rank 2 or rank 1 but got rank ${o.rank}.`),F(l.rank===2||l.rank===1,()=>`Error in batchNorm2D: variance must be rank 2 or rank 1 but got rank ${l.rank}.`),d!=null&&F(d.rank===2||d.rank===1,()=>`Error in batchNorm2D: scale must be rank 2 or rank 1 but got rank ${d.rank}.`),u!=null&&F(u.rank===2||u.rank===1,()=>`Error in batchNorm2D: offset must be rank 2 or rank 1 but got rank ${u.rank}.`),ci(i,o,l,u,d,s)}var Tb=O({batchNorm2d_:wT});function kT(e,t,n,a,r,s){let i=M(e,"x","batchNorm"),o=M(t,"mean","batchNorm"),l=M(n,"variance","batchNorm"),d;r!=null&&(d=M(r,"scale","batchNorm"));let u;return a!=null&&(u=M(a,"offset","batchNorm")),F(i.rank===3,()=>`Error in batchNorm3D: x must be rank 3 but got rank ${i.rank}.`),F(o.rank===3||o.rank===1,()=>`Error in batchNorm3D: mean must be rank 3 or rank 1 but got rank ${o.rank}.`),F(l.rank===3||l.rank===1,()=>`Error in batchNorm3D: variance must be rank 3 or rank 1 but got rank ${l.rank}.`),d!=null&&F(d.rank===3||d.rank===1,()=>`Error in batchNorm3D: scale must be rank 3 or rank 1 but got rank ${d.rank}.`),u!=null&&F(u.rank===3||u.rank===1,()=>`Error in batchNorm3D: offset must be rank 3 or rank 1 but got rank ${u.rank}.`),ci(i,o,l,u,d,s)}var Eb=O({batchNorm3d_:kT});function IT(e,t,n,a,r,s){let i=M(e,"x","batchNorm"),o=M(t,"mean","batchNorm"),l=M(n,"variance","batchNorm"),d;r!=null&&(d=M(r,"scale","batchNorm"));let u;return a!=null&&(u=M(a,"offset","batchNorm")),F(i.rank===4,()=>`Error in batchNorm4D: x must be rank 4 but got rank ${i.rank}.`),F(o.rank===4||o.rank===1,()=>`Error in batchNorm4D: mean must be rank 4 or rank 1 but got rank ${o.rank}.`),F(l.rank===4||l.rank===1,()=>`Error in batchNorm4D: variance must be rank 4 or rank 1 but got rank ${l.rank}.`),d!=null&&F(d.rank===4||d.rank===1,()=>`Error in batchNorm4D: scale must be rank 4 or rank 1 but got rank ${d.rank}.`),u!=null&&F(u.rank===4||u.rank===1,()=>`Error in batchNorm4D: offset must be rank 4 or rank 1 but got rank ${u.rank}.`),ci(i,o,l,u,d,s)}var Cb=O({batchNorm4d_:IT});function ST(e,t,n){let a=M(e,"x","bincount"),r=M(t,"weights","bincount");F(a.dtype==="int32",()=>`Error in bincount: input dtype must be int32, but got ${a.dtype}`),F(n>=0,()=>`size must be non-negative, but got ${n}.`),F(r.size===a.size||r.size===0,()=>`Error in bincount: weights must have the same size as input or0-length, but got input shape: ${a.shape}, weights shape: ${r.shape}.`);let s={x:a,weights:r},i={size:n};return D.runKernel(Rp,s,i)}var lA=O({bincount_:ST});function NT(e,t){let n=M(e,"broadcastTo","x"),a=n.shape;if(t.some(l=>!(l>0)||l%1!=0))throw new Error(`broadcastTo(): Invalid broadcast shape [${t}].`);if(t.lengthn.rank){let l=n.shape.slice();for(;l.length=0;l--)if(r[l]===t[l])s[l]=1;else if(n.shape[l]!==1)throw new Error(`broadcastTo(): [${a}] cannot be broadcast to [${t}].`);if(s.map((l,d)=>l>1?d:-1).filter(l=>l>=0).length===0)return Oa(n);let i={x:n},o={reps:s};return D.runKernel(Sr,i,o)}var cl=O({broadcastTo_:NT});function TT(e){let t={x:M(e,"x","ceil")};return D.runKernel(cs,t)}var uA=O({ceil_:TT});function ET(e,t,n){let a=M(e,"x","clipByValue");F(t<=n,()=>`Error in clip: min (${t}) must be less than or equal to max (${n}).`);let r={x:a},s={clipValueMin:t,clipValueMax:n};return D.runKernel(Ir,r,s)}var In=O({clipByValue_:ET});function CT(e){return ot(e,0)}var Rb=O({concat1d_:CT});function RT(e,t){return ot(e,t)}var hl=O({concat2d_:RT});function MT(e,t){return ot(e,t)}var Mb=O({concat3d_:MT});function FT(e,t){return ot(e,t)}var Fb=O({concat4d_:FT});function $T(e,t,n,a,r="NHWC",s=[1,1],i){let o=M(e,"x","conv2d"),l=M(t,"filter","conv2d"),d=o,u=!1;o.rank===3&&(u=!0,d=H(o,[1,o.shape[0],o.shape[1],o.shape[2]])),F(d.rank===4,()=>`Error in conv2d: input must be rank 4, but got rank ${d.rank}.`),F(l.rank===4,()=>`Error in conv2d: filter must be rank 4, but got rank ${l.rank}.`),i!=null&&F(jt(a),()=>`Error in conv2d: pad must be an integer when using, dimRoundingMode ${i} but got pad ${a}.`);let p=r==="NHWC"?d.shape[3]:d.shape[1];F(p===l.shape[2],()=>`Error in conv2d: depth of input (${p}) must match input depth for filter ${l.shape[2]}.`),F(za(n,s),()=>`Error in conv2D: Either strides or dilations must be 1. Got strides ${n} and dilations '${s}'`);let c={x:d,filter:l},h={strides:n,pad:a,dataFormat:r,dilations:s,dimRoundingMode:i},m=D.runKernel(hs,c,h);return u?H(m,[m.shape[1],m.shape[2],m.shape[3]]):m}var ar=O({conv2d_:$T});function DT(e,t,n,a,r="NWC",s=1,i){let o=M(e,"x","conv1d"),l=M(t,"filter","conv1d"),d=o,u=!1;o.rank===2&&(u=!0,d=H(o,[1,o.shape[0],o.shape[1]])),F(d.rank===3,()=>`Error in conv1d: input must be rank 3, but got rank ${d.rank}.`),F(l.rank===3,()=>`Error in conv1d: filter must be rank 3, but got rank ${l.rank}.`),i!=null&&F(jt(a),()=>`Error in conv1d: pad must be an integer when using, dimRoundingMode ${i} but got pad ${a}.`),F(d.shape[2]===l.shape[1],()=>`Error in conv1d: depth of input (${d.shape[2]}) must match input depth for filter ${l.shape[1]}.`),F(za(n,s),()=>`Error in conv1D: Either stride or dilation must be 1. Got stride ${n} and dilation '${s}'`),F(r==="NWC",()=>`Error in conv1d: got dataFormat of ${r} but only NWC is currently supported.`);let p=H(l,[1,l.shape[0],l.shape[1],l.shape[2]]),c=H(d,[d.shape[0],1,d.shape[1],d.shape[2]]),h=ar(c,p,[1,n],a,"NHWC",[1,s],i);return u?H(h,[h.shape[2],h.shape[3]]):H(h,[h.shape[0],h.shape[2],h.shape[3]])}var bc=O({conv1d_:DT});function OT(e,t,n,a,r,s="NHWC",i){F(e.length===t.rank,()=>`Length of inShape (${e.length}) and rank of dy (${t.rank}) must match`);let o=e,l=t,d=!1;t.rank===3&&(d=!0,l=H(t,[1,t.shape[0],t.shape[1],t.shape[2]]),o=[1,e[0],e[1],e[2]]),F(o.length===4,()=>`Error in conv2dDerInput: inShape must be length 4, but got length ${o.length}.`),F(l.rank===4,()=>`Error in conv2dDerInput: dy must be rank 4, but got rank ${l.rank}`),F(n.rank===4,()=>`Error in conv2dDerInput: filter must be rank 4, but got rank ${n.rank}`);let u=s==="NHWC"?o[3]:o[1],p=s==="NHWC"?l.shape[3]:l.shape[1];F(u===n.shape[2],()=>`Error in conv2dDerInput: depth of input (${u}) must match input depth for filter ${n.shape[2]}.`),F(p===n.shape[3],()=>`Error in conv2dDerInput: depth of output (${p}) must match output depth for filter ${n.shape[3]}.`),i!=null&&F(jt(r),()=>`Error in conv2dDerInput: pad must be an integer when using, dimRoundingMode ${i} but got pad ${r}.`);let c={dy:l,filter:n},h={strides:a,pad:r,dataFormat:s,dimRoundingMode:i,inputShape:o},m=D.runKernel(fs,c,h);return d?H(m,[m.shape[1],m.shape[2],m.shape[3]]):m}var dA=O({conv2DBackpropInput_:OT});function zT(e,t,n,a,r,s){let i=M(e,"x","conv2dTranspose"),o=M(t,"filter","conv2dTranspose");return dA(n,i,o,a,r,"NHWC",s)}var vc=O({conv2dTranspose_:zT});function _T(e,t,n,a,r="NDHWC",s=[1,1,1]){let i=M(e,"x","conv3d"),o=M(t,"filter","conv3d"),l=i,d=!1;i.rank===4&&(d=!0,l=H(i,[1,i.shape[0],i.shape[1],i.shape[2],i.shape[3]])),F(l.rank===5,()=>`Error in conv3d: input must be rank 5, but got rank ${l.rank}.`),F(o.rank===5,()=>`Error in conv3d: filter must be rank 5, but got rank ${o.rank}.`),F(l.shape[4]===o.shape[3],()=>`Error in conv3d: depth of input (${l.shape[4]}) must match input depth for filter ${o.shape[3]}.`),F(za(n,s),()=>`Error in conv3D: Either strides or dilations must be 1. Got strides ${n} and dilations '${s}'`),F(r==="NDHWC",()=>`Error in conv3d: got dataFormat of ${r} but only NDHWC is currently supported.`);let u={x:l,filter:o},p={strides:n,pad:a,dataFormat:r,dilations:s},c=D.runKernel(bu,u,p);return d?H(c,[c.shape[1],c.shape[2],c.shape[3],c.shape[4]]):c}var pA=O({conv3d_:_T});function PT(e,t,n,a,r){F(e.length===t.rank,()=>`Length of inShape (${e.length}) and rank of dy (${t.rank}) must match`);let s=e,i=t,o=!1;t.rank===4&&(o=!0,i=H(t,[1,t.shape[0],t.shape[1],t.shape[2],t.shape[3]]),s=[1,e[0],e[1],e[2],e[3]]);let l=s[4],d=i.shape[4];F(s.length===5,()=>`Error in conv3dDerInput: inShape must be length 5, but got length ${s.length}.`),F(i.rank===5,()=>`Error in conv3dDerInput: dy must be rank 5, but got rank ${i.rank}`),F(n.rank===5,()=>`Error in conv3dDerInput: filter must be rank 5, but got rank ${n.rank}`),F(l===n.shape[3],()=>`Error in conv3dDerInput: depth of input (${l}) must match input depth for filter ${n.shape[3]}.`),F(d===n.shape[4],()=>`Error in conv3dDerInput: depth of output (${d}) must match output depth for filter ${n.shape[4]}.`);let u={dy:i,filter:n},p={pad:r,strides:a,inputShape:s},c=D.runKernel(Dp,u,p);return o?H(c,[c.shape[1],c.shape[2],c.shape[3],c.shape[4]]):c}var $b=O({conv3DBackpropInput_:PT});function LT(e,t,n,a,r){let s=M(e,"x","conv3dTranspose"),i=M(t,"filter","conv3dTranspose");return $b(n,s,i,a,r)}var Db=O({conv3dTranspose_:LT});function WT(e){let t={x:M(e,"x","cos")};return D.runKernel(ms,t)}var Xu=O({cos_:WT});function BT(e){let t={x:M(e,"x","cosh")};return D.runKernel(co,t)}var wc=O({cosh_:BT});function VT(e,t=0,n=!1,a=!1){let r={x:M(e,"x","cumsum")},s={axis:t,exclusive:n,reverse:a};return D.runKernel(As,r,s)}var kc=O({cumsum_:VT});function jT(e,t,n,a=!1){let r=M(e,"x","denseBincount"),s=M(t,"weights","denseBincount");F(r.dtype==="int32",()=>`Error in denseBincount: input dtype must be int32, but got ${r.dtype}`),F(r.rank<=2,()=>`Error in denseBincount: input must be at most rank 2, but got rank ${r.rank}.`),F(n>=0,()=>`size must be non-negative, but got ${n}.`),F(s.size===r.size||s.size===0,()=>`Error in denseBincount: weights must have the same shape as x or 0-length, but got x shape: ${r.shape}, weights shape: ${s.shape}.`);let i={x:r,weights:s},o={size:n,binaryOutput:a};return D.runKernel(Op,i,o)}var Ob=O({denseBincount_:jT});function UT(e,t,n="NHWC"){let a=M(e,"x","depthToSpace"),r=n==="NHWC"?a.shape[1]:a.shape[2],s=n==="NHWC"?a.shape[2]:a.shape[3],i=n==="NHWC"?a.shape[3]:a.shape[1];F(r*t>=0,()=>`Negative dimension size caused by overflow when multiplying +Expected: ${s}.`)}}function wN(e,t){e().then(()=>t.fail(),()=>t())}function kN(e,t){let n=typeof t=="string"||typeof t=="number"||typeof t=="boolean"?[t]:t;return br(e)||br(e[0])||br(t)||br(t[0])?qm(e,n,(a,r)=>a==r):qm(e,t,(a,r)=>Xm(a,r,0))}function IN(e,t,n){if(n==null&&(n=Gm()),!Xm(e,t,n))throw new Error(`Numbers differ: actual === ${e}, expected === ${t}`)}function Xm(e,t,n){return!isFinite(e)&&!isFinite(t)?!0:!(isNaN(e)||isNaN(t)||Math.abs(e-t)>n)}function SN(e,t,n){for(let a=0;an)throw new Error(`Value out of range:${e[a]} low: ${t}, high: ${n}`)}function NN(e,t){expect(new Float32Array(e)).toEqual(new Float32Array(t))}function wb(e){for(let t=0;tt.dispose())}function jt(e){return D.keep(e)}function DN(e){return D.time(e)}function ON(e){return D.setBackend(e)}function zN(){return D.ready()}function _N(){return D.backendName}function PN(e){D.removeBackend(e)}function Zm(e){return D.findBackend(e)}function LN(e){return D.findBackendFactory(e)}function ul(e,t,n=1){return D.registerBackend(e,t,n)}function kb(){return D.backend}function WN(e,t){J().setPlatform(e,t)}function BN(e,t){let n=M(e,"a","add"),a=M(t,"b","add");[n,a]=bt(n,a);let r={a:n,b:a};return D.runKernel(wr,r)}var se=O({add_:BN});function VN(e,t){let n=M(e,"a","floorDiv"),a=M(t,"b","floorDiv");[n,a]=bt(n,a);let r={a:n,b:a};return D.runKernel(bs,r)}var Ac=O({floorDiv_:VN});function jN(e,t){let n=M(e,"a","div"),a=M(t,"b","div");if([n,a]=bt(n,a),n.dtype==="int32"&&a.dtype==="int32")return Ac(n,a);let r={a:n,b:a},s={};return D.runKernel(ys,r,s)}var me=O({div_:jN});function UN(e,t){let n=M(e,"a","mul"),a=M(t,"b","mul");[n,a]=bt(n,a);let r={a:n,b:a};return D.runKernel($s,r)}var _=O({mul_:UN});function HN(e){let t=M(e,"x","abs");if(t.dtype==="complex64"){let n={x:t};return D.runKernel(xu,n)}else{let n={x:t};return D.runKernel(Qi,n)}}var Ot=O({abs_:HN});function GN(e){let t={x:M(e,"x","acos")};return D.runKernel(eo,t)}var Ym=O({acos_:GN});function qN(e){let t={x:M(e,"x","acosh")};return D.runKernel(to,t)}var Jm=O({acosh_:qN});function XN(e){F(Array.isArray(e),()=>"The argument passed to tf.addN() must be a list of tensors"),F(e.length>=1,()=>`Must pass at least one tensor to tf.addN(), but got ${e.length}`);let t=e.map((r,s)=>M(r,`tensors${s}`,"addN")),n=t[0];t.forEach(r=>{if(r.dtype!==n.dtype)throw new Error("All tensors passed to tf.addN() must have the same dtype")}),t.forEach(r=>{if(!Qa(r.shape,n.shape))throw new Error("All tensors passed to tf.addN() must have the same shape")});let a=t;return D.runKernel(is,a)}var yc=O({addN_:XN});function KN(e,t=null,n=!1){let a={x:M(e,"x","all","bool")},r={axis:t,keepDims:n};return D.runKernel(no,a,r)}var gc=O({all_:KN});function ZN(e,t=null,n=!1){let a={x:M(e,"x","any","bool")},r={axis:t,keepDims:n};return D.runKernel(ao,a,r)}var ju=O({any_:ZN});function YN(e,t=0){let n={x:M(e,"x","argMax")},a={axis:t};return D.runKernel(os,n,a)}var Uu=O({argMax_:YN});function JN(e,t=0){let n={x:M(e,"x","argMin")},a={axis:t};return D.runKernel(Au,n,a)}var Qm=O({argMin_:JN});function QN(e){let t={x:M(e,"x","asin")};return D.runKernel(ro,t)}var eA=O({asin_:QN});function eT(e){let t={x:M(e,"x","asinh")};return D.runKernel(so,t)}var tA=O({asinh_:eT});function tT(e){let t={x:M(e,"x","atan")};return D.runKernel(io,t)}var nA=O({atan_:tT});function nT(e,t){let n=M(e,"a","atan2"),a=M(t,"b","atan2");[n,a]=bt(n,a);let r={a:n,b:a};return D.runKernel(lo,r)}var aA=O({atan2_:nT});function aT(e){let t={x:M(e,"x","atanh")};return D.runKernel(oo,t)}var rA=O({atanh_:aT});function rT(e,t,n,a,r="NHWC",s){let i=e[3],o=[...t,i],l=Ib(r);return Hu(e,o,n,s,a,null,null,l)}function Sb(e,t,n,a,r,s,i="channelsLast"){let[o,l]=xc(t),d;if(i==="channelsLast")d=[o,l,e[3],e[3]];else if(i==="channelsFirst")d=[o,l,e[1],e[1]];else throw new Error(`Unknown dataFormat ${i}`);return Hu(e,d,n,a,r,s,!1,i)}function sT(e,t,n,a,r,s,i="NDHWC"){let[o,l,d]=sA(t),u,p;if(i==="NDHWC")p="channelsLast",u=[o,l,d,e[4],e[4]];else if(i==="NCDHW")p="channelsFirst",u=[o,l,d,e[1],e[1]];else throw new Error(`Unknown dataFormat ${i}`);return Nb(e,u,n,a,r,!1,p,s)}function Hu(e,t,n,a,r,s,i=!1,o="channelsLast"){let[l,d,u,p]=[-1,-1,-1,-1];if(o==="channelsLast")[l,d,u,p]=e;else if(o==="channelsFirst")[l,p,d,u]=e;else throw new Error(`Unknown dataFormat ${o}`);let[c,h,,m]=t,[f,A]=xc(n),[y,g]=xc(a),x=dl(c,y),w=dl(h,g),{padInfo:b,outHeight:v,outWidth:N}=iT(r,d,u,f,A,x,w,s,o),T=i?m*p:m,R;return o==="channelsFirst"?R=[l,T,v,N]:o==="channelsLast"&&(R=[l,v,N,T]),{batchSize:l,dataFormat:o,inHeight:d,inWidth:u,inChannels:p,outHeight:v,outWidth:N,outChannels:T,padInfo:b,strideHeight:f,strideWidth:A,filterHeight:c,filterWidth:h,effectiveFilterHeight:x,effectiveFilterWidth:w,dilationHeight:y,dilationWidth:g,inShape:e,outShape:R,filterShape:t}}function Nb(e,t,n,a,r,s=!1,i="channelsLast",o){let[l,d,u,p,c]=[-1,-1,-1,-1,-1];if(i==="channelsLast")[l,d,u,p,c]=e;else if(i==="channelsFirst")[l,c,d,u,p]=e;else throw new Error(`Unknown dataFormat ${i}`);let[h,m,f,,A]=t,[y,g,x]=sA(n),[w,b,v]=sA(a),N=dl(h,w),T=dl(m,b),R=dl(f,v),{padInfo:$,outDepth:z,outHeight:P,outWidth:V}=oT(r,d,u,p,y,g,x,N,T,R,o),j=s?A*c:A,U;return i==="channelsFirst"?U=[l,j,z,P,V]:i==="channelsLast"&&(U=[l,z,P,V,j]),{batchSize:l,dataFormat:i,inDepth:d,inHeight:u,inWidth:p,inChannels:c,outDepth:z,outHeight:P,outWidth:V,outChannels:j,padInfo:$,strideDepth:y,strideHeight:g,strideWidth:x,filterDepth:h,filterHeight:m,filterWidth:f,effectiveFilterDepth:N,effectiveFilterHeight:T,effectiveFilterWidth:R,dilationDepth:w,dilationHeight:b,dilationWidth:v,inShape:e,outShape:U,filterShape:t}}function lT(e,t,n,a,r){a==null&&(a=iA(e,t,n));let s=e[0],i=e[1],o=ui((s-t+2*a)/n+1,r),l=ui((i-t+2*a)/n+1,r);return[o,l]}function uT(e,t,n,a,r,s){r==null&&(r=iA(e,t,a));let i=e[0],o=e[1],l=e[2],d=ui((i-t+2*r)/a+1,s),u=ui((o-t+2*r)/a+1,s),p=ui((l-t+2*r)/a+1,s);return[d,u,p,n]}function iA(e,t,n,a=1){let r=dl(t,a);return Math.floor((e[0]*(n-1)-n+r)/2)}function xc(e){return typeof e=="number"?[e,e,e]:e.length===2?[e[0],e[1],1]:e}function sA(e){return typeof e=="number"?[e,e,e]:e}function dl(e,t){return t<=1?e:e+(e-1)*(t-1)}function iT(e,t,n,a,r,s,i,o,l){let d,u,p;if(typeof e=="number"){d={top:e,bottom:e,left:e,right:e,type:e===0?"VALID":"NUMBER"};let c=lT([t,n],s,a,e,o);u=c[0],p=c[1]}else if(e==="same"){u=Math.ceil(t/a),p=Math.ceil(n/r);let c=Math.max(0,(u-1)*a+s-t),h=Math.max(0,(p-1)*r+i-n),m=Math.floor(c/2),f=c-m,A=Math.floor(h/2),y=h-A;d={top:m,bottom:f,left:A,right:y,type:"SAME"}}else if(e==="valid")d={top:0,bottom:0,left:0,right:0,type:"VALID"},u=Math.ceil((t-s+1)/a),p=Math.ceil((n-i+1)/r);else if(typeof e=="object"){let c=l==="channelsLast"?e[1][0]:e[2][0],h=l==="channelsLast"?e[1][1]:e[2][1],m=l==="channelsLast"?e[2][0]:e[3][0],f=l==="channelsLast"?e[2][1]:e[3][1];d={top:c,bottom:h,left:m,right:f,type:c===0&&h===0&&m===0&&f===0?"VALID":"EXPLICIT"},u=ui((t-s+c+h)/a+1,o),p=ui((n-i+m+f)/r+1,o)}else throw Error(`Unknown padding parameter: ${e}`);return{padInfo:d,outHeight:u,outWidth:p}}function oT(e,t,n,a,r,s,i,o,l,d,u){let p,c,h,m;if(typeof e=="number"){p={top:e,bottom:e,left:e,right:e,front:e,back:e,type:e===0?"VALID":"NUMBER"};let f=uT([t,n,a,1],o,1,r,e,u);c=f[0],h=f[1],m=f[2]}else if(e==="same"){c=Math.ceil(t/r),h=Math.ceil(n/s),m=Math.ceil(a/i);let f=(c-1)*r+o-t,A=(h-1)*s+l-n,y=(m-1)*i+d-a,g=Math.floor(f/2),x=f-g,w=Math.floor(A/2),b=A-w,v=Math.floor(y/2),N=y-v;p={top:w,bottom:b,left:v,right:N,front:g,back:x,type:"SAME"}}else if(e==="valid")p={top:0,bottom:0,left:0,right:0,front:0,back:0,type:"VALID"},c=Math.ceil((t-o+1)/r),h=Math.ceil((n-l+1)/s),m=Math.ceil((a-d+1)/i);else throw Error(`Unknown padding parameter: ${e}`);return{padInfo:p,outDepth:c,outHeight:h,outWidth:m}}function ui(e,t){if(!t)return Math.trunc(e);switch(t){case"round":return Math.round(e);case"ceil":return Math.ceil(e);case"floor":return Math.floor(e);default:throw new Error(`Unknown roundingMode ${t}`)}}function Rr(e){let[t,n,a]=xc(e);return t===1&&n===1&&a===1}function Oa(e,t){return Rr(e)||Rr(t)}function Ib(e){if(e==="NHWC")return"channelsLast";if(e==="NCHW")return"channelsFirst";throw new Error(`Unknown dataFormat ${e}`)}function dT(e,t){let n={x:M(e,"x","reshape","string_or_numeric")},a={shape:t};return D.runKernel(Wo,n,a)}var H=O({reshape_:dT});function pT(e,t,n,a,r){let s=M(e,"x","avgPool","float32"),i=1;F(Oa(n,i),()=>`Error in avgPool: Either strides or dilations must be 1. Got strides ${n} and dilations '${i}'`);let o=s,l=!1;s.rank===3&&(l=!0,o=H(s,[1,s.shape[0],s.shape[1],s.shape[2]])),F(o.rank===4,()=>`Error in avgPool: x must be rank 4 but got rank ${o.rank}.`),r!=null&&F(Vt(a),()=>`Error in avgPool: pad must be an integer when using, dimRoundingMode ${r} but got pad ${a}.`);let d={x:o},u={filterSize:t,strides:n,pad:a,dimRoundingMode:r},p=D.runKernel(ls,d,u);return p=fe(p,s.dtype),l?H(p,[p.shape[1],p.shape[2],p.shape[3]]):p}var Gu=O({avgPool_:pT});function cT(e,t,n,a,r,s="NDHWC"){let i=M(e,"x","avgPool3d","float32"),o=i,l=!1;i.rank===4&&(l=!0,o=H(i,[1,i.shape[0],i.shape[1],i.shape[2],i.shape[3]])),F(o.rank===5,()=>`Error in avgPool3d: x must be rank 5 but got rank ${o.rank}.`),F(s==="NDHWC",()=>`Error in avgPool3d: Only NDHWC is currently supported, but got dataFormat of ${s}`),r!=null&&F(Vt(a),()=>`Error in avgPool3d: pad must be an integer when using, dimRoundingMode ${r} but got pad ${a}.`);let d={x:o},u={filterSize:t,strides:n,pad:a,dimRoundingMode:r,dataFormat:s},p=D.runKernel(yu,d,u);return p=fe(p,o.dtype),l?H(p,[p.shape[1],p.shape[2],p.shape[3],p.shape[4]]):p}var oA=O({avgPool3d_:cT});function hT(e,t=0){F(e.length>=1,()=>"Pass at least one tensor to concat");let n=Bu(e,"tensors","concat","string_or_numeric");if(n[0].dtype==="complex64"&&n.forEach(s=>{if(s.dtype!=="complex64")throw new Error(`Cannot concatenate complex64 tensors with a tensor + with dtype ${s.dtype}. `)}),n.length===1)return Da(n[0]);let a=n,r={axis:t};return D.runKernel(uo,a,r)}var ot=O({concat_:hT});function fT(e){let t={x:M(e,"x","sigmoid")};return D.runKernel(Hs,t)}var wn=O({sigmoid_:fT});function mT(e,t,n){let a=M(e,"x","slice","string_or_numeric");if(a.rank===0)throw new Error("Slicing scalar is not possible");let r={x:a},s={begin:t,size:n};return D.runKernel(Uo,r,s)}var Re=O({slice_:mT});function AT(e){let t={x:M(e,"x","tanh")};return D.runKernel(Js,t)}var di=O({tanh_:AT});function yT(e,t,n,a,r,s){let i=M(e,"forgetBias","basicLSTMCell"),o=M(t,"lstmKernel","basicLSTMCell"),l=M(n,"lstmBias","basicLSTMCell"),d=M(a,"data","basicLSTMCell"),u=M(r,"c","basicLSTMCell"),p=M(s,"h","basicLSTMCell"),c=ot([d,p],1),h=Be(c,o),m=se(h,l),f=m.shape[0],A=m.shape[1]/4,y=[f,A],g=Re(m,[0,0],y),x=Re(m,[0,A],y),w=Re(m,[0,A*2],y),b=Re(m,[0,A*3],y),v=se(_(wn(g),di(x)),_(u,wn(se(i,w)))),N=_(di(v),wn(b));return[v,N]}var gT=O({basicLSTMCell_:yT});function xT(e,t,n){let a=M(e,"x","batchToSpaceND"),r=t.reduce((o,l)=>o*l);F(a.rank>=1+t.length,()=>`input rank is ${a.rank} but should be > than blockShape.length ${t.length}`),F(n.length===t.length,()=>`crops.length is ${n.length} but should be equal to blockShape.length ${t.length}`),F(a.shape[0]%r==0,()=>`input tensor batch is ${a.shape[0]} but is not divisible by the product of the elements of blockShape ${t.join(" * ")} === ${r}`);let s={x:a},i={blockShape:t,crops:n};return D.runKernel(gu,s,i)}var qu=O({batchToSpaceND_:xT});function bT(e){let t;return e.rank===0||e.rank===1?t=H(e,[1,1,1,e.size]):e.rank===2?t=H(e,[1,1,e.shape[0],e.shape[1]]):e.rank===3?t=H(e,[1,e.shape[0],e.shape[1],e.shape[2]]):t=e,t}function vT(e,t,n,a,r,s){s==null&&(s=.001);let i=M(e,"x","batchNorm"),o=M(t,"mean","batchNorm"),l=M(n,"variance","batchNorm"),d;r!=null&&(d=M(r,"scale","batchNorm"));let u;a!=null&&(u=M(a,"offset","batchNorm")),F(o.rank===l.rank,()=>"Batch normalization gradient requires mean and variance to have equal ranks."),F(u==null||o.rank===u.rank,()=>"Batch normalization gradient requires mean and offset to have equal ranks."),F(d==null||o.rank===d.rank,()=>"Batch normalization gradient requires mean and scale to have equal ranks.");let p={x:bT(i),scale:d,offset:u,mean:o,variance:l},c={varianceEpsilon:s},h=D.runKernel(vs,p,c);return H(h,i.shape)}var pi=O({batchNorm_:vT});function wT(e,t,n,a,r,s){let i=M(e,"x","batchNorm"),o=M(t,"mean","batchNorm"),l=M(n,"variance","batchNorm"),d;r!=null&&(d=M(r,"scale","batchNorm"));let u;return a!=null&&(u=M(a,"offset","batchNorm")),F(i.rank===2,()=>`Error in batchNorm2D: x must be rank 2 but got rank ${i.rank}.`),F(o.rank===2||o.rank===1,()=>`Error in batchNorm2D: mean must be rank 2 or rank 1 but got rank ${o.rank}.`),F(l.rank===2||l.rank===1,()=>`Error in batchNorm2D: variance must be rank 2 or rank 1 but got rank ${l.rank}.`),d!=null&&F(d.rank===2||d.rank===1,()=>`Error in batchNorm2D: scale must be rank 2 or rank 1 but got rank ${d.rank}.`),u!=null&&F(u.rank===2||u.rank===1,()=>`Error in batchNorm2D: offset must be rank 2 or rank 1 but got rank ${u.rank}.`),pi(i,o,l,u,d,s)}var Tb=O({batchNorm2d_:wT});function kT(e,t,n,a,r,s){let i=M(e,"x","batchNorm"),o=M(t,"mean","batchNorm"),l=M(n,"variance","batchNorm"),d;r!=null&&(d=M(r,"scale","batchNorm"));let u;return a!=null&&(u=M(a,"offset","batchNorm")),F(i.rank===3,()=>`Error in batchNorm3D: x must be rank 3 but got rank ${i.rank}.`),F(o.rank===3||o.rank===1,()=>`Error in batchNorm3D: mean must be rank 3 or rank 1 but got rank ${o.rank}.`),F(l.rank===3||l.rank===1,()=>`Error in batchNorm3D: variance must be rank 3 or rank 1 but got rank ${l.rank}.`),d!=null&&F(d.rank===3||d.rank===1,()=>`Error in batchNorm3D: scale must be rank 3 or rank 1 but got rank ${d.rank}.`),u!=null&&F(u.rank===3||u.rank===1,()=>`Error in batchNorm3D: offset must be rank 3 or rank 1 but got rank ${u.rank}.`),pi(i,o,l,u,d,s)}var Eb=O({batchNorm3d_:kT});function IT(e,t,n,a,r,s){let i=M(e,"x","batchNorm"),o=M(t,"mean","batchNorm"),l=M(n,"variance","batchNorm"),d;r!=null&&(d=M(r,"scale","batchNorm"));let u;return a!=null&&(u=M(a,"offset","batchNorm")),F(i.rank===4,()=>`Error in batchNorm4D: x must be rank 4 but got rank ${i.rank}.`),F(o.rank===4||o.rank===1,()=>`Error in batchNorm4D: mean must be rank 4 or rank 1 but got rank ${o.rank}.`),F(l.rank===4||l.rank===1,()=>`Error in batchNorm4D: variance must be rank 4 or rank 1 but got rank ${l.rank}.`),d!=null&&F(d.rank===4||d.rank===1,()=>`Error in batchNorm4D: scale must be rank 4 or rank 1 but got rank ${d.rank}.`),u!=null&&F(u.rank===4||u.rank===1,()=>`Error in batchNorm4D: offset must be rank 4 or rank 1 but got rank ${u.rank}.`),pi(i,o,l,u,d,s)}var Cb=O({batchNorm4d_:IT});function ST(e,t,n){let a=M(e,"x","bincount"),r=M(t,"weights","bincount");F(a.dtype==="int32",()=>`Error in bincount: input dtype must be int32, but got ${a.dtype}`),F(n>=0,()=>`size must be non-negative, but got ${n}.`),F(r.size===a.size||r.size===0,()=>`Error in bincount: weights must have the same size as input or0-length, but got input shape: ${a.shape}, weights shape: ${r.shape}.`);let s={x:a,weights:r},i={size:n};return D.runKernel(Rp,s,i)}var lA=O({bincount_:ST});function NT(e,t){let n=M(e,"broadcastTo","x"),a=n.shape;if(t.some(l=>!(l>0)||l%1!=0))throw new Error(`broadcastTo(): Invalid broadcast shape [${t}].`);if(t.lengthn.rank){let l=n.shape.slice();for(;l.length=0;l--)if(r[l]===t[l])s[l]=1;else if(n.shape[l]!==1)throw new Error(`broadcastTo(): [${a}] cannot be broadcast to [${t}].`);if(s.map((l,d)=>l>1?d:-1).filter(l=>l>=0).length===0)return Da(n);let i={x:n},o={reps:s};return D.runKernel(Ir,i,o)}var pl=O({broadcastTo_:NT});function TT(e){let t={x:M(e,"x","ceil")};return D.runKernel(ps,t)}var uA=O({ceil_:TT});function ET(e,t,n){let a=M(e,"x","clipByValue");F(t<=n,()=>`Error in clip: min (${t}) must be less than or equal to max (${n}).`);let r={x:a},s={clipValueMin:t,clipValueMax:n};return D.runKernel(kr,r,s)}var kn=O({clipByValue_:ET});function CT(e){return ot(e,0)}var Rb=O({concat1d_:CT});function RT(e,t){return ot(e,t)}var cl=O({concat2d_:RT});function MT(e,t){return ot(e,t)}var Mb=O({concat3d_:MT});function FT(e,t){return ot(e,t)}var Fb=O({concat4d_:FT});function $T(e,t,n,a,r="NHWC",s=[1,1],i){let o=M(e,"x","conv2d"),l=M(t,"filter","conv2d"),d=o,u=!1;o.rank===3&&(u=!0,d=H(o,[1,o.shape[0],o.shape[1],o.shape[2]])),F(d.rank===4,()=>`Error in conv2d: input must be rank 4, but got rank ${d.rank}.`),F(l.rank===4,()=>`Error in conv2d: filter must be rank 4, but got rank ${l.rank}.`),i!=null&&F(Vt(a),()=>`Error in conv2d: pad must be an integer when using, dimRoundingMode ${i} but got pad ${a}.`);let p=r==="NHWC"?d.shape[3]:d.shape[1];F(p===l.shape[2],()=>`Error in conv2d: depth of input (${p}) must match input depth for filter ${l.shape[2]}.`),F(Oa(n,s),()=>`Error in conv2D: Either strides or dilations must be 1. Got strides ${n} and dilations '${s}'`);let c={x:d,filter:l},h={strides:n,pad:a,dataFormat:r,dilations:s,dimRoundingMode:i},m=D.runKernel(cs,c,h);return u?H(m,[m.shape[1],m.shape[2],m.shape[3]]):m}var nr=O({conv2d_:$T});function DT(e,t,n,a,r="NWC",s=1,i){let o=M(e,"x","conv1d"),l=M(t,"filter","conv1d"),d=o,u=!1;o.rank===2&&(u=!0,d=H(o,[1,o.shape[0],o.shape[1]])),F(d.rank===3,()=>`Error in conv1d: input must be rank 3, but got rank ${d.rank}.`),F(l.rank===3,()=>`Error in conv1d: filter must be rank 3, but got rank ${l.rank}.`),i!=null&&F(Vt(a),()=>`Error in conv1d: pad must be an integer when using, dimRoundingMode ${i} but got pad ${a}.`),F(d.shape[2]===l.shape[1],()=>`Error in conv1d: depth of input (${d.shape[2]}) must match input depth for filter ${l.shape[1]}.`),F(Oa(n,s),()=>`Error in conv1D: Either stride or dilation must be 1. Got stride ${n} and dilation '${s}'`),F(r==="NWC",()=>`Error in conv1d: got dataFormat of ${r} but only NWC is currently supported.`);let p=H(l,[1,l.shape[0],l.shape[1],l.shape[2]]),c=H(d,[d.shape[0],1,d.shape[1],d.shape[2]]),h=nr(c,p,[1,n],a,"NHWC",[1,s],i);return u?H(h,[h.shape[2],h.shape[3]]):H(h,[h.shape[0],h.shape[2],h.shape[3]])}var bc=O({conv1d_:DT});function OT(e,t,n,a,r,s="NHWC",i){F(e.length===t.rank,()=>`Length of inShape (${e.length}) and rank of dy (${t.rank}) must match`);let o=e,l=t,d=!1;t.rank===3&&(d=!0,l=H(t,[1,t.shape[0],t.shape[1],t.shape[2]]),o=[1,e[0],e[1],e[2]]),F(o.length===4,()=>`Error in conv2dDerInput: inShape must be length 4, but got length ${o.length}.`),F(l.rank===4,()=>`Error in conv2dDerInput: dy must be rank 4, but got rank ${l.rank}`),F(n.rank===4,()=>`Error in conv2dDerInput: filter must be rank 4, but got rank ${n.rank}`);let u=s==="NHWC"?o[3]:o[1],p=s==="NHWC"?l.shape[3]:l.shape[1];F(u===n.shape[2],()=>`Error in conv2dDerInput: depth of input (${u}) must match input depth for filter ${n.shape[2]}.`),F(p===n.shape[3],()=>`Error in conv2dDerInput: depth of output (${p}) must match output depth for filter ${n.shape[3]}.`),i!=null&&F(Vt(r),()=>`Error in conv2dDerInput: pad must be an integer when using, dimRoundingMode ${i} but got pad ${r}.`);let c={dy:l,filter:n},h={strides:a,pad:r,dataFormat:s,dimRoundingMode:i,inputShape:o},m=D.runKernel(hs,c,h);return d?H(m,[m.shape[1],m.shape[2],m.shape[3]]):m}var dA=O({conv2DBackpropInput_:OT});function zT(e,t,n,a,r,s){let i=M(e,"x","conv2dTranspose"),o=M(t,"filter","conv2dTranspose");return dA(n,i,o,a,r,"NHWC",s)}var vc=O({conv2dTranspose_:zT});function _T(e,t,n,a,r="NDHWC",s=[1,1,1]){let i=M(e,"x","conv3d"),o=M(t,"filter","conv3d"),l=i,d=!1;i.rank===4&&(d=!0,l=H(i,[1,i.shape[0],i.shape[1],i.shape[2],i.shape[3]])),F(l.rank===5,()=>`Error in conv3d: input must be rank 5, but got rank ${l.rank}.`),F(o.rank===5,()=>`Error in conv3d: filter must be rank 5, but got rank ${o.rank}.`),F(l.shape[4]===o.shape[3],()=>`Error in conv3d: depth of input (${l.shape[4]}) must match input depth for filter ${o.shape[3]}.`),F(Oa(n,s),()=>`Error in conv3D: Either strides or dilations must be 1. Got strides ${n} and dilations '${s}'`),F(r==="NDHWC",()=>`Error in conv3d: got dataFormat of ${r} but only NDHWC is currently supported.`);let u={x:l,filter:o},p={strides:n,pad:a,dataFormat:r,dilations:s},c=D.runKernel(bu,u,p);return d?H(c,[c.shape[1],c.shape[2],c.shape[3],c.shape[4]]):c}var pA=O({conv3d_:_T});function PT(e,t,n,a,r){F(e.length===t.rank,()=>`Length of inShape (${e.length}) and rank of dy (${t.rank}) must match`);let s=e,i=t,o=!1;t.rank===4&&(o=!0,i=H(t,[1,t.shape[0],t.shape[1],t.shape[2],t.shape[3]]),s=[1,e[0],e[1],e[2],e[3]]);let l=s[4],d=i.shape[4];F(s.length===5,()=>`Error in conv3dDerInput: inShape must be length 5, but got length ${s.length}.`),F(i.rank===5,()=>`Error in conv3dDerInput: dy must be rank 5, but got rank ${i.rank}`),F(n.rank===5,()=>`Error in conv3dDerInput: filter must be rank 5, but got rank ${n.rank}`),F(l===n.shape[3],()=>`Error in conv3dDerInput: depth of input (${l}) must match input depth for filter ${n.shape[3]}.`),F(d===n.shape[4],()=>`Error in conv3dDerInput: depth of output (${d}) must match output depth for filter ${n.shape[4]}.`);let u={dy:i,filter:n},p={pad:r,strides:a,inputShape:s},c=D.runKernel(Dp,u,p);return o?H(c,[c.shape[1],c.shape[2],c.shape[3],c.shape[4]]):c}var $b=O({conv3DBackpropInput_:PT});function LT(e,t,n,a,r){let s=M(e,"x","conv3dTranspose"),i=M(t,"filter","conv3dTranspose");return $b(n,s,i,a,r)}var Db=O({conv3dTranspose_:LT});function WT(e){let t={x:M(e,"x","cos")};return D.runKernel(fs,t)}var Xu=O({cos_:WT});function BT(e){let t={x:M(e,"x","cosh")};return D.runKernel(po,t)}var wc=O({cosh_:BT});function VT(e,t=0,n=!1,a=!1){let r={x:M(e,"x","cumsum")},s={axis:t,exclusive:n,reverse:a};return D.runKernel(ms,r,s)}var kc=O({cumsum_:VT});function jT(e,t,n,a=!1){let r=M(e,"x","denseBincount"),s=M(t,"weights","denseBincount");F(r.dtype==="int32",()=>`Error in denseBincount: input dtype must be int32, but got ${r.dtype}`),F(r.rank<=2,()=>`Error in denseBincount: input must be at most rank 2, but got rank ${r.rank}.`),F(n>=0,()=>`size must be non-negative, but got ${n}.`),F(s.size===r.size||s.size===0,()=>`Error in denseBincount: weights must have the same shape as x or 0-length, but got x shape: ${r.shape}, weights shape: ${s.shape}.`);let i={x:r,weights:s},o={size:n,binaryOutput:a};return D.runKernel(Op,i,o)}var Ob=O({denseBincount_:jT});function UT(e,t,n="NHWC"){let a=M(e,"x","depthToSpace"),r=n==="NHWC"?a.shape[1]:a.shape[2],s=n==="NHWC"?a.shape[2]:a.shape[3],i=n==="NHWC"?a.shape[3]:a.shape[1];F(r*t>=0,()=>`Negative dimension size caused by overflow when multiplying ${r} and ${t} for depthToSpace with input shape ${a.shape}`),F(s*t>=0,()=>`Negative dimension size caused by overflow when multiplying ${s} and ${t} for depthToSpace with input shape - ${a.shape}`),F(i%(t*t)==0,()=>`Dimension size must be evenly divisible by ${t*t} but is ${i} for depthToSpace with input shape ${a.shape}`);let o={x:a},l={blockSize:t,dataFormat:n};return D.runKernel(fo,o,l)}var cA=O({depthToSpace_:UT});function HT(e,t,n,a,r="NHWC",s=[1,1],i){let o=M(e,"x","depthwiseConv2d"),l=M(t,"filter","depthwiseConv2d"),d=o,u=!1;o.rank===3&&(u=!0,d=H(o,[1,o.shape[0],o.shape[1],o.shape[2]])),F(d.rank===4,()=>`Error in depthwiseConv2d: input must be rank 4, but got rank ${d.rank}.`),F(l.rank===4,()=>`Error in depthwiseConv2d: filter must be rank 4, but got rank ${l.rank}.`),F(d.shape[3]===l.shape[2],()=>`Error in depthwiseConv2d: number of input channels (${d.shape[3]}) must match the inChannels dimension in filter ${l.shape[2]}.`),i!=null&&F(jt(a),()=>`Error in depthwiseConv2d: pad must be an integer when using, dimRoundingMode ${i} but got pad ${a}.`);let p={x:d,filter:l},c={strides:n,pad:a,dataFormat:r,dilations:s,dimRoundingMode:i},h=D.runKernel(ys,p,c);return u?H(h,[h.shape[1],h.shape[2],h.shape[3]]):h}var fl=O({depthwiseConv2d_:HT});function GT(e){let t={x:M(e,"x","diag")};return D.runKernel(Pp,t)}var qT=O({diag_:GT});function XT(e,t,n,a,r=[1,1],s="NHWC"){let i=M(e,"x","dilation2d"),o=M(t,"filter","dilation2d");F(i.rank===3||i.rank===4,()=>`Error in dilation2d: input must be rank 3 or 4, but got rank ${i.rank}.`),F(o.rank===3,()=>`Error in dilation2d: filter must be rank 3, but got rank ${o.rank}.`),F(s==="NHWC",()=>`Error in dilation2d: Only NHWC is currently supported, but got dataFormat of ${s}`);let l=i,d=!1;i.rank===3&&(l=H(i,[1,i.shape[0],i.shape[1],i.shape[2]]),d=!0);let u={x:l,filter:o},p={strides:n,pad:a,dilations:r},c=D.runKernel(vu,u,p);return d?H(c,[c.shape[1],c.shape[2],c.shape[3]]):c}var hA=O({dilation2d_:XT});function KT(e,t){let n=e.length,a=[];for(let r=0;r1&&i===1&&a.unshift(s)}return a}function _t(e,t){let n=[];for(let a=0;a1)&&n.unshift(s)}return n}function ct(e,t){let n=[],a=Math.max(e.length,t.length);for(let r=0;r`Error in dot: inputs must all be rank 1 or 2, but got ranks ${n.rank} and ${a.rank}.`);let r=n.rank===1?n.size:n.shape[1],s=a.rank===1?a.size:a.shape[0];if(F(r===s,()=>`Error in dot: inner dimensions of inputs must match, but got ${r} and ${s}.`),n.rank===1&&a.rank===1){let i=H(n,[1,-1]),o=H(a,[-1,1]),l=Be(i,o);return H(l,[])}else if(n.rank===1&&a.rank===2){let i=H(n,[1,-1]),o=H(a,[a.shape[0],a.shape[1]]),l=Be(i,o);return H(l,[l.size])}else if(n.rank===2&&a.rank===1){let i=H(a,[-1,1]),o=Be(n,i);return H(o,[o.size])}else{let i=H(a,[a.shape[0],a.shape[1]]);return Be(n,i)}}var zb=O({dot_:eE});function tE(e,...t){let n=t.map((r,s)=>M(r,`tensors${s}`,"einsum")),a={equation:e};return D.runKernel(Bp,n,a)}var _b=O({einsum_:tE});function nE(e){let t={x:M(e,"x","elu")};return D.runKernel(mo,t)}var ml=O({elu_:nE});function aE(e){let t=M(e,"x","erf");F(t.dtype==="int32"||t.dtype==="float32",()=>"Input dtype must be `int32` or `float32`."),t.dtype==="int32"&&(t=fe(t,"float32"));let n={x:t};return D.runKernel(Ao,n)}var mA=O({erf_:aE});function rE(e){let t={x:M(e,"x","exp")};return D.runKernel(xs,t)}var Xn=O({exp_:rE});function sE(e,t=0){let n=M(e,"x","expandDims","string_or_numeric");F(t<=n.rank,()=>"Axis must be <= rank of the tensor");let a={input:n},r={dim:t};return D.runKernel(go,a,r)}var un=O({expandDims_:sE});function iE(e){let t={x:M(e,"x","expm1")};return D.runKernel(xo,t)}var AA=O({expm1_:iE});function oE(e,t){let n=M(e,"x","tile","string_or_numeric");F(n.rank===t.length,()=>`Error in transpose: rank of input ${n.rank} must match length of reps ${t}.`);let a={x:n},r={reps:t};return D.runKernel(Sr,a,r)}var $r=O({tile_:oE});function lE(e,t,n,a="float32"){t==null&&(t=e);let r=We([e,t],a),s=e<=t?e:t;for(let o=0;o`Error in localResponseNormalization: x must be rank 3 or 4 but got - rank ${s.rank}.`),F(jt(t),()=>`Error in localResponseNormalization: depthRadius must be an integer but got depthRadius ${t}.`);let i=s,o=!1;s.rank===3&&(o=!0,i=H(s,[1,s.shape[0],s.shape[1],s.shape[2]]));let l={x:i},d={depthRadius:t,bias:n,alpha:a,beta:r},u=D.runKernel(Su,l,d);return o?H(u,[u.shape[1],u.shape[2],u.shape[3]]):u}var xA=O({localResponseNormalization_:bE});function vE(e){let t={x:M(e,"x","log")};return D.runKernel(Ns,t)}var $n=O({log_:vE});function wE(e){let t={x:M(e,"x","log1p")};return D.runKernel(Co,t)}var Nc=O({log1p_:wE});function kE(e){return F(wr(e),()=>"The f passed in grad(f) must be a function"),(t,n)=>{let a=M(t,"x","tf.grad","string_or_numeric"),r=n!=null?M(n,"dy","tf.grad"):null;return D.tidy(()=>{let{value:s,grads:i}=D.gradients(()=>e(a),[a],r);return r!=null&&on(s.shape,r.shape,"The shape of dy passed in grad(f)(x, dy) must match the shape returned by f(x)"),Tc(i),i[0]})}}function IE(e){return F(wr(e),()=>"The f passed in grads(f) must be a function"),(t,n)=>{F(Array.isArray(t),()=>"The args passed in grads(f)(args) must be an array of `Tensor`s or `TensorLike`s");let a=Bu(t,"args","tf.grads","string_or_numeric"),r=n!=null?M(n,"dy","tf.grads"):null;return D.tidy(()=>{let{value:s,grads:i}=D.gradients(()=>e(...a),a,r);return r!=null&&on(s.shape,r.shape,"The shape of dy passed in grads(f)([x1,...], dy) must match the shape returned by f([x1,...])"),Tc(i),i})}}function SE(e){return F(wr(e),()=>"The f passed in valueAndGrad(f) must be a function"),(t,n)=>{F(t instanceof Le,()=>"The x passed in valueAndGrad(f)(x) must be a tensor"),F(n==null||n instanceof Le,()=>"The dy passed in valueAndGrad(f)(x, dy) must be a tensor");let{grads:a,value:r}=D.gradients(()=>e(t),[t],n);return Tc(a),{grad:a[0],value:r}}}function NE(e){return F(wr(e),()=>"The f passed in valueAndGrads(f) must be a function"),(t,n)=>{F(Array.isArray(t)&&t.every(r=>r instanceof Le),()=>"The args passed in valueAndGrads(f)(args) must be array of tensors"),F(n==null||n instanceof Le,()=>"The dy passed in valueAndGrads(f)(args, dy) must be a tensor");let a=D.gradients(()=>e(...t),t,n);return n!=null&&on(a.value.shape,n.shape,"The shape of dy passed in valueAndGrads(f)([x1,...], dy) must match the shape returned by f([x1,...])"),Tc(a.grads),a}}function Bb(e,t){F(wr(e),()=>"The f passed in variableGrads(f) must be a function"),F(t==null||Array.isArray(t)&&t.every(d=>d instanceof Pu),()=>"The varList passed in variableGrads(f, varList) must be an array of variables");let n=t!=null;if(!n){t=[];for(let d in D.registeredVariables)t.push(D.registeredVariables[d])}let a=n?t.filter(d=>!d.trainable):null,r=t.length;t=t.filter(d=>d.trainable),F(t.length>0,()=>`variableGrads() expects at least one of the input variables to be trainable, but none of the ${r} variables is trainable.`);let s=!0,{value:i,grads:o}=D.gradients(e,t,null,s);F(o.some(d=>d!=null),()=>"Cannot find a connection between any variable and the result of the loss function y=f(x). Please make sure the operations that use variables are inside the function f passed to minimize()."),F(i.rank===0,()=>`The f passed in variableGrads(f) must return a scalar, but it returned a rank-${i.rank} tensor`);let l={};return t.forEach((d,u)=>{o[u]!=null&&(l[d.name]=o[u])}),a!=null&&a.forEach(d=>l[d.name]=null),{value:i,grads:l}}function _a(e){return D.customGrad(e)}function Tc(e){if(e.filter(t=>t==null).length>0)throw new Error(`Cannot compute gradient of y=f(x) with respect to x. Make sure that - the f you passed encloses all operations that lead from x to y.`)}function TE(e){let t={x:M(e,"x","neg")};return D.runKernel(Fo,t)}var wt=O({neg_:TE});function EE(e){let t={x:M(e,"x","softplus")};return D.runKernel(Xo,t)}var fi=O({softplus_:EE});function CE(e){let t=M(e,"x","logSigmoid");return _a(n=>({value:wt(fi(wt(n))),gradFunc:a=>_(a,kn(wt(n)))}))(t)}var Vb=O({logSigmoid_:CE});function RE(e,t=null,n=!1){let a={x:M(e,"x","max")},r={reductionIndices:t,keepDims:n};return D.runKernel(Ts,a,r)}var Kn=O({max_:RE});function ME(e,t){let n=M(e,"a","sub"),a=M(t,"b","sub");[n,a]=vt(n,a);let r={a:n,b:a};return D.runKernel(Ys,r)}var ge=O({sub_:ME});function FE(e,t=null,n=!1){let a=M(e,"x","sum");a.dtype==="bool"&&(a=fe(a,"int32"));let r={x:a},s={axis:t,keepDims:n};return D.runKernel(Xs,r,s)}var ke=O({sum_:FE});function $E(e,t=-1){let n=M(e,"logits","logSoftmax");if(t===-1&&(t=n.rank-1),t!==n.rank-1)throw Error(`Log Softmax along a non-last dimension is not yet supported. Logits was rank ${n.rank} and axis was ${t}`);return _a((a,r)=>{let s=!0,i=Kn(a,t,!0),o=ge(a,i),l=ge(fe(o,"float32"),$n(ke(Xn(o),t,s)));return r([l]),{value:l,gradFunc:(d,u)=>{let[p]=u,c=!0,h=Xn(p);return ge(d,_(ke(d,t,c),h))}}})(n)}var Ec=O({logSoftmax_:$E});function bA(e,t){for(let n=0;ne[s]);return[n,r]}function mi(e,t){let n=t.map(a=>1);return jb(e,n,t)}function DE(e,t,n){F(bA(t,n),()=>`${e} supports only inner-most axes for now. Got axes ${t} and rank-${n} input.`)}function Hb(e,t){if(bA(e,t))return null;let n=[];for(let a=0;an.push(a)),n}function vA(e){return e.map((t,n)=>[n,t]).sort((t,n)=>t[1]-n[1]).map(t=>t[0])}function OE(e,t){let n=[];for(let a=t-e;a`Error in maxPool: input must be rank 4 but got rank ${o.rank}.`),F(za(n,i),()=>`Error in maxPool: Either strides or dilations must be 1. Got strides ${n} and dilations '${i}'`),r!=null&&F(jt(a),()=>`Error in maxPool: pad must be an integer when using, dimRoundingMode ${r} but got pad ${a}.`);let d={x:o},u={filterSize:t,strides:n,pad:a,dimRoundingMode:r},p=D.runKernel(Cs,d,u);return l?H(p,[p.shape[1],p.shape[2],p.shape[3]]):p}var Yu=O({maxPool_:BE});function VE(e,t=[1,1,1],n,a,r,s="NDHWC"){let i=M(e,"x","maxPool3d"),o=i,l=!1;i.rank===4&&(l=!0,o=H(i,[1,i.shape[0],i.shape[1],i.shape[2],i.shape[3]])),F(o.rank===5,()=>`Error in maxPool3d: x must be rank 5 but got rank ${o.rank}.`),F(s==="NDHWC",()=>`Error in maxPool3d: Only NDHWC is currently supported, but got dataFormat of ${s}`),r!=null&&F(jt(a),()=>`Error in maxPool3d: pad must be an integer when using, dimRoundingMode ${r} but got pad ${a}.`);let d={x:o},u={filterSize:t,strides:n,pad:a,dimRoundingMode:r,dataFormat:s},p=D.runKernel(Nu,d,u);return l?H(p,[p.shape[1],p.shape[2],p.shape[3],p.shape[4]]):p}var kA=O({maxPool3d_:VE});function jE(e,t,n,a,r=!1){let s={x:M(e,"x","maxPoolWithArgmax")},i={filterSize:t,strides:n,pad:a,includeBatchInIndex:r},o=D.runKernel(Zp,s,i);return{result:o[0],indexes:o[1]}}var qb=O({maxPoolWithArgmax_:jE});function UE(e,t){let n=M(e,"a","maximum"),a=M(t,"b","maximum");[n,a]=vt(n,a),n.dtype==="bool"&&(n=fe(n,"int32"),a=fe(a,"int32")),ct(n.shape,a.shape);let r={a:n,b:a};return D.runKernel(Es,r)}var Pa=O({maximum_:UE});function HE(e,t=null,n=!1){let a={x:M(e,"x","mean")},r={axis:t,keepDims:n};return D.runKernel(Rs,a,r)}var kt=O({mean_:HE});function Rt(e,t="float32"){if(t==="complex64"){let a=Rt(e,"float32"),r=Rt(e,"float32");return Tr(a,r)}let n=Tp(Tt(e),t);return D.makeTensor(n,e,t)}function Dn(e,t="float32"){if(t==="complex64"){let a=Dn(e,"float32"),r=Rt(e,"float32");return Tr(a,r)}let n=Am(Tt(e),t);return D.makeTensor(n,e,t)}function GE(e,t,{indexing:n="xy"}={}){if(n!=="xy"&&n!=="ij")throw new TypeError(`${n} is not a valid third argument to meshgrid`);if(e===void 0)return[];let a=M(e,"x","meshgrid",e instanceof Le?e.dtype:"float32");if(t===void 0)return[a];let r=M(t,"y","meshgrid",t instanceof Le?t.dtype:"float32"),s=Tt(a.shape),i=Tt(r.shape);return n==="xy"?(a=H(a,[1,-1]),r=H(r,[-1,1]),[Be(Dn([i,1],a.dtype),a),Be(r,Dn([1,s],r.dtype))]):(a=H(a,[-1,1]),r=H(r,[1,-1]),[Be(a,Dn([1,i],a.dtype)),Be(Dn([s,1],r.dtype),r)])}function qE(e,t=null,n=!1){let a={x:M(e,"x","min")},r={axis:t,keepDims:n};return D.runKernel(Ms,a,r)}var gl=O({min_:qE});function XE(e,t){let n=M(e,"a","minimum"),a=M(t,"b","minimum");[n,a]=vt(n,a),n.dtype==="bool"&&(n=fe(n,"int32"),a=fe(a,"int32")),ct(n.shape,a.shape);let r={a:n,b:a};return D.runKernel(Fs,r)}var xl=O({minimum_:XE});function KE(e,t,n){F(n==="reflect"||n==="symmetric",()=>`Invalid mode. Mode must be either reflect or symmetric. Got ${n}.`);let a=M(e,"x","mirrorPad");if(a.rank===0)throw new Error("mirrorPad(scalar) is not defined. Pass non-scalar to mirrorPad");F(t.length===a.rank,()=>`Padding doesn't match input. Must be ${a.rank}. Got ${t.length}.`);let r=n==="reflect"?1:0;for(let o=0;o"Invalid number of paddings. Must be length of 2 each."),F(t[o][0]>=0&&t[o][0]<=a.shape[o]-r&&t[o][1]>=0&&t[o][1]<=a.shape[o]-r,()=>`Padding in dimension ${o} cannot be greater than or equal to ${a.shape[o]-r} or less than 0 for input of shape ${a.shape}`);let s={paddings:t,mode:n},i={x:a};return D.runKernel($s,i,s)}var IA=O({mirrorPad_:KE});function ZE(e,t){let n=M(e,"a","mod"),a=M(t,"b","mod");[n,a]=vt(n,a);let r={a:n,b:a};return D.runKernel(Mo,r)}var SA=O({mod_:ZE});function YE(e){let t=M(e,"x","square"),n={};return D.runKernel("Square",{x:t},n)}var st=O({square_:YE});function JE(e,t=null,n=!1){e=M(e,"x","moments");let a=sa(t,e.shape),r=kt(e,a,n),s=r.shape;n||(s=mi(r.shape,a));let i=st(ge(fe(e,"float32"),H(r,s))),o=kt(i,a,n);return{mean:r,variance:o}}var Rc=O({moments_:JE});function QE(e,t,n,a){let r=M(t,"data","multiRNNCell"),s=Bu(n,"c","multiRNNCell"),i=Bu(a,"h","multiRNNCell"),o=r,l=[];for(let p=0;p2)throw new Error(`Rank of probabilities must be 1 or 2, but is ${i}`);n=n||Math.random();let o={logits:i===1?H(r,[1,-1]):r},l={numSamples:t,seed:n,normalized:a},d=D.runKernel(Yp,o,l);return i===1?H(d,[d.size]):d}var Xb=O({multinomial_:tC});function nC(e,t){let n=M(e,"a","notEqual"),a=M(t,"b","notEqual");[n,a]=vt(n,a),ct(n.shape,a.shape);let r={a:n,b:a};return D.runKernel($o,r)}var Ai=O({notEqual_:nC});function aC(e){let t={x:M(e,"x","onesLike")};return D.runKernel(_o,t)}var On=O({onesLike_:aC});function rC(e,t){let n=M(e,"v1","outerProduct"),a=M(t,"v2","outerProduct");F(n.rank===1&&a.rank===1,()=>`Error in outerProduct: inputs must be rank 1, but got ranks ${n.rank} and ${a.rank}.`);let r=H(n,[-1,1]),s=H(a,[1,-1]);return Be(r,s)}var sC=O({outerProduct_:rC});function iC(e,t,n=0){let a=M(e,"x","pad");if(a.rank===0)throw new Error("pad(scalar) is not defined. Pass non-scalar to pad");let r={paddings:t,constantValue:n},s={x:a};return D.runKernel(zs,s,r)}var rr=O({pad_:iC});function oC(e,t,n=0){return F(t.length===2,()=>"Invalid number of paddings. Must be length of 2."),rr(e,[t],n)}var lC=O({pad1d_:oC});function uC(e,t,n=0){return F(t.length===2&&t[0].length===2&&t[1].length===2,()=>"Invalid number of paddings. Must be length of 2 each."),rr(e,t,n)}var dC=O({pad2d_:uC});function pC(e,t,n=0){return F(t.length===3&&t[0].length===2&&t[1].length===2&&t[2].length===2,()=>"Invalid number of paddings. Must be length of 2 each."),rr(e,t,n)}var cC=O({pad3d_:pC});function hC(e,t,n=0){return F(t.length===4&&t[0].length===2&&t[1].length===2&&t[2].length===2&&t[3].length===2,()=>"Invalid number of paddings. Must be length of 2 each."),rr(e,t,n)}var fC=O({pad4d_:hC});function mC(e,t,n){let a=M(e,"x","spaceToBatchND");F(a.rank>=1+t.length,()=>`input rank ${a.rank} should be > than [blockShape] ${t.length}`),F(n.length===t.length,()=>`paddings.shape[0] ${n.length} must be equal to [blockShape] ${t.length}`),F(a.shape.reduce((i,o,l)=>l>0&&l<=t.length?i&&(o+n[l-1][0]+n[l-1][1])%t[l-1]==0:i,!0),()=>`input spatial dimensions ${a.shape.slice(1)} with paddings ${n.toString()} must be divisible by blockShapes ${t.toString()}`);let r={x:a},s={blockShape:t,paddings:n};return D.runKernel(Cu,r,s)}var Ju=O({spaceToBatchND_:mC});function gC(e,t,n,a,r,s){r==null&&(r=[1,1]),s==null&&(s=1),a===0&&(a="valid");let i=M(e,"x","maxPool"),o=i,l=!1;i.rank===3&&(l=!0,o=H(i,[1,i.shape[0],i.shape[1],i.shape[2]])),F(za(s,r),()=>`Error in pool: Either strides or dilations must be 1. Got strides ${s} and dilations '${r}'`);let d=Sb(o.shape,t,s,r,a),u=[d.dilationHeight,d.dilationWidth],p;a==="same"?p=yC([d.filterHeight,d.filterWidth],u):p=[[0,0],[0,0]];let c=u[0]===1&&u[1]===1,[h,m]=AC([d.inHeight,d.inWidth],u,p),f=c?a:"valid",A=c?o:Ju(o,u,h),y=(n==="avg"?()=>Gu(A,t,s,f):()=>Yu(A,t,s,f))(),g=c?y:qu(y,u,m);return l?H(g,[g.shape[1],g.shape[2],g.shape[3]]):g}function AC(e,t,n){let a=n.map(u=>u[0]),r=n.map(u=>u[1]),s=e.concat(a,r),i=t.map((u,p)=>(u-s[p]%u)%u),o=r.map((u,p)=>u+i[p]),l=t.map((u,p)=>[a[p],o[p]]),d=t.map((u,p)=>[0,i[p]]);return[l,d]}function yC(e,t){let n=e.map((s,i)=>s+(s-1)*(t[i]-1)).map(s=>s-1),a=n.map(s=>Math.floor(s/2)),r=n.map((s,i)=>s-a[i]);return n.map((s,i)=>[a[i],r[i]])}var Kb=O({pool_:gC});function xC(e,t){let n=M(e,"base","pow"),a=M(t,"exp","pow");[n,a]=vt(n,a);let r={a:n,b:a};return D.runKernel(_s,r)}var sr=O({pow_:xC});function bC(e,t){let n=M(e,"x","prelu"),a=M(t,"alpha","prelu"),r={x:n,alpha:a};return D.runKernel(Ps,r)}var Qu=O({prelu_:bC});function vC(e,t=null,n=!1){let a=M(e,"x","prod");a.dtype==="bool"&&(a=fe(a,"int32"));let r={x:a},s={axis:t,keepDims:n};return D.runKernel(Lo,r,s)}var Mc=O({prod_:vC});function wC(e,t,n){let a=Tt(e),r=null;if(n==null||n==="float32")r=new Float32Array(a);else if(n==="int32")r=new Int32Array(a);else if(n==="bool")r=new Uint8Array(a);else throw new Error(`Unknown data type ${n}`);for(let s=0;s=1||s===0);let i=Math.sqrt(-2*Math.log(s)/s);e=this.mean+this.stdDev*a*i,t=this.mean+this.stdDev*r*i,(!this.truncated||this.isValidTruncated(e))&&(n=!0)}return(!this.truncated||this.isValidTruncated(t))&&(this.nextVal=this.convertValue(t)),this.convertValue(e)}convertValue(e){return this.dtype==null||this.dtype==="float32"?e:Math.round(e)}isValidTruncated(e){return e<=this.upper&&e>=this.lower}},IC=class{constructor(e,t,n,a){this.alpha=e,this.beta=1/t,this.dtype=n;let r=a||Math.random();this.randu=NA.alea(r.toString()),this.randn=new TA(0,1,n,!1,this.randu()),e<1?this.d=e+2/3:this.d=e-1/3,this.c=1/Math.sqrt(9*this.d)}nextValue(){let e,t,n,a,r,s;for(;;){do a=this.randn.nextValue(),s=1+this.c*a;while(s<=0);if(s*=s*s,e=a*a,t=1-.331*e*e,n=.5*e+this.d*(1-s+Math.log(s)),r=this.randu(),rthis.dtype==null||this.dtype==="float32",this.min=e,this.range=t-e,this.dtype=n,a==null&&(a=Math.random()),typeof a=="number"&&(a=a.toString()),!this.canReturnFloat()&&this.range<=1)throw new Error(`The difference between ${e} - ${t} <= 1 and dtype is not float`);this.random=NA.alea(a)}convertValue(e){return this.canReturnFloat()?e:Math.round(e)}nextValue(){return this.convertValue(this.min+this.range*this.random())}};function NC(e,t,n=1,a="float32",r){if(n==null&&(n=1),a==null&&(a="float32"),a!=="float32"&&a!=="int32")throw new Error(`Unsupported data type ${a}`);let s=new IC(t,n,a,r),i=We(e,a);for(let o=0;o`Error in reverse1D: x must be rank 1 but got rank ${t.rank}.`),zn(t,0)}var zC=O({reverse1d_:OC});function _C(e,t){let n=M(e,"x","reverse");return F(n.rank===2,()=>`Error in reverse2D: x must be rank 2 but got rank ${n.rank}.`),zn(n,t)}var PC=O({reverse2d_:_C});function LC(e,t){let n=M(e,"x","reverse");return F(n.rank===3,()=>`Error in reverse3D: x must be rank 3 but got rank ${n.rank}.`),zn(n,t)}var WC=O({reverse3d_:LC});function BC(e,t){let n=M(e,"x","reverse");return F(n.rank===4,()=>`Error in reverse4D: x must be rank 4 but got rank ${n.rank}.`),zn(n,t)}var VC=O({reverse4d_:BC});function jC(e){let t={x:M(e,"x","round")};return D.runKernel(js,t)}var $c=O({round_:jC});function UC(e){let t={x:M(e,"x","rsqrt")};return D.runKernel(Us,t)}var Dc=O({rsqrt_:UC});function Se(e,t){if((nn(e)&&t!=="string"||Array.isArray(e))&&t!=="complex64")throw new Error("Error creating a new Scalar: value must be a primitive (number|boolean|string)");if(t==="string"&&nn(e)&&!(e instanceof Uint8Array))throw new Error("When making a scalar from encoded string, the value must be `Uint8Array`.");return Er(e,[],[],t)}function HC(e){let t={x:M(e,"x","selu")};return D.runKernel(Uo,t)}var Oc=O({selu_:HC});function GC(e,t,n,a,r,s=[1,1],i="NHWC"){let o=M(e,"x","separableConv2d"),l=M(t,"depthwiseFilter","separableConv2d"),d=M(n,"pointwiseFilter","separableConv2d"),u=o,p=!1;if(o.rank===3&&(p=!0,u=H(o,[1,o.shape[0],o.shape[1],o.shape[2]])),i==="NCHW")throw new Error("separableConv2d currently does not support dataFormat NCHW; only NHWC is supported");F(u.rank===4,()=>`Error in separableConv2d: input must be rank 4, but got rank ${u.rank}.`),F(l.rank===4,()=>`Error in separableConv2d: depthwise filter must be rank 4, but got rank ${l.rank}.`),F(d.rank===4,()=>`Error in separableConv2d: pointwise filter must be rank 4, but got rank ${l.rank}.`),F(d.shape[0]===1,()=>`Error in separableConv2d: the first dimension of pointwise filter must be 1, but got ${d.shape[0]}.`),F(d.shape[1]===1,()=>`Error in separableConv2d: the second dimension of pointwise filter must be 1, but got ${d.shape[1]}.`);let c=l.shape[2],h=l.shape[3];F(d.shape[2]===c*h,()=>`Error in separableConv2d: the third dimension of pointwise filter must be ${c*h}, but got ${d.shape[2]}.`);let m=fl(u,l,a,r,i,s),f=ar(m,d,1,"valid",i);return p?H(f,[f.shape[1],f.shape[2],f.shape[3]]):f}var CA=O({separableConv2d_:GC});async function qC(e,t){let n=M(e,"x","setdiff1d"),a=M(t,"y","setdiff1d");F(n.dtype===a.dtype,()=>`x and y should have the same dtype, but got x (${n.dtype}) and y (${a.dtype}).`),F(n.rank===1,()=>`x should be 1D tensor, but got x (${n.shape}).`),F(a.rank===1,()=>`y should be 1D tensor, but got y (${a.shape}).`);let r=await n.data(),s=await a.data(),i=new Set(s),o=0;for(let u=0;u`slice1d expects a rank-1 tensor, but got a rank-${a.rank} tensor`),Re(a,[t],[n])}var Pc=O({slice1d_:YC});function JC(e,t,n){let a=M(e,"x","slice2d");return F(a.rank===2,()=>`slice2d expects a rank-2 tensor, but got a rank-${a.rank} tensor`),Re(a,t,n)}var MA=O({slice2d_:JC});function QC(e,t,n){let a=M(e,"x","slice3d");return F(a.rank===3,()=>`slice3d expects a rank-3 tensor, but got a rank-${a.rank} tensor`),Re(a,t,n)}var Lc=O({slice3d_:QC});function eR(e,t,n){let a=M(e,"x","slice4d");return F(a.rank===4,()=>`slice4d expects a rank-4 tensor, but got a rank-${a.rank} tensor`),Re(a,t,n)}var td=O({slice4d_:eR});function tR(e,t=-1){let n=M(e,"logits","softmax","float32");if(t===-1&&(t=n.rank-1),t!==n.rank-1)throw Error(`Softmax along a non-last dimension is not yet supported. Logits was rank ${n.rank} and dim was ${t}`);let a={logits:n},r={dim:t};return D.runKernel(Ks,a,r)}var nd=O({softmax_:tR});function nR(e){F(e.dtype==="complex64",()=>`The dtype for tf.spectral.fft() must be complex64 but got ${e.dtype}.`);let t={input:e};return D.runKernel(jp,t)}var ad=O({fft_:nR});function aR(e){F(e.dtype==="complex64",()=>`The dtype for tf.spectral.ifft() must be complex64 but got ${e.dtype}.`);let t={input:e};return D.runKernel(Up,t)}var wl=O({ifft_:aR});function rR(e){let t=e.shape[e.shape.length-1],n=e.size/t,a;if(t<=2){let r=H(e,[n,t]);a=wl(r)}else{let r=[n,2*(t-1)],s=H(ed(e),[n,t]),i=H(Ic(e),[n,t]),o=zn(Re(s,[0,1],[n,t-2]),1),l=_(zn(Re(i,[0,1],[n,t-2]),1),Se(-1)),d=ot([s,o],1),u=ot([i,l],1),p=H(Tr(d,u),[r[0],r[1]]);a=wl(p)}if(a=ed(a),e.rank===3&&e.shape[0]!==0){let r=a,s=e.shape[0];a=H(a,[s,a.shape[0]/s,a.shape[1]]),r.dispose()}return a}var Wc=O({irfft_:rR});function sR(e,t,n=0){let a={x:M(e,"x","split")},r={numOrSizeSplits:t,axis:n};return D.runKernel(Ko,a,r)}var rn=O({split_:sR});function iR(e,t){F(e.dtype==="float32",()=>`The dtype for rfft() must be real value but got ${e.dtype}`);let n=e.shape[e.shape.length-1],a=e.size/n,r;if(t!=null&&t0),f=e.shape.map(A=>A);f[e.shape.length-1]=t,r=Re(e,m,f),n=t}else if(t!=null&&t>n){let m=e.shape.map(f=>f);m[e.shape.length-1]=t-n,r=ot([e,Rt(m)],e.shape.length-1),n=t}else r=e;let s=Ue(r),i=H(Tr(r,s),[a,n]),o=ad(i),l=Math.floor(n/2)+1,d=ed(o),u=Ic(o),p=rn(d,[l,n-l],d.shape.length-1),c=rn(u,[l,n-l],u.shape.length-1),h=r.shape.slice();return h[r.shape.length-1]=l,H(Tr(p[0],c[0]),h)}var rd=O({rfft_:iR});function oR(e){let t={x:M(e,"x","sqrt")};return D.runKernel(qs,t)}var Qt=O({sqrt_:oR});function lR(e,t){let n=M(e,"a","squaredDifference"),a=M(t,"b","squaredDifference");[n,a]=vt(n,a),ct(n.shape,a.shape);let r={a:n,b:a},s={};return D.runKernel(Zs,r,s)}var Bc=O({squaredDifference_:lR});function uR(e,t){let n=M(e,"x","squeeze");return H(n,gx(n.shape,t).newShape)}var zr=O({squeeze_:uR});function dR(e,t=0){let n=Bu(e,"tensors","stack","string_or_numeric");F(n.length>=1,()=>"Pass at least one tensor to tf.stack"),n.length>0&&F(t<=n[0].rank,()=>"Axis must be <= rank of the tensor");let a=n,r={axis:t};return D.runKernel(Po,a,r)}var _n=O({stack_:dR});function pR(e,t=0){let n={x:M(e,"x","step")},a={alpha:t};return D.runKernel(Nr,n,a)}var kl=O({step_:pR});function cR(e,t,n,a,r=0,s=0,i=0,o=0,l=0){let d={x:M(e,"x","stridedSlice")},u={begin:t,end:n,strides:a,beginMask:r,endMask:s,ellipsisMask:i,newAxisMask:o,shrinkAxisMask:l};return D.runKernel(Zo,d,u)}var FA=O({stridedSlice_:cR});function hR(e){let t={x:M(e,"x","tan")};return D.runKernel(Js,t)}var $A=O({tan_:hR});function Et(e,t){ss(e);let n=Da(e,t);if(n.length!==1)throw new Error("tensor1d() requires values to be a flat/TypedArray");return Er(e,null,n,t)}function ga(e,t,n){if(ss(e),t!=null&&t.length!==2)throw new Error("tensor2d() requires shape to have two numbers");let a=Da(e,n);if(a.length!==2&&a.length!==1)throw new Error("tensor2d() requires values to be number[][] or flat/TypedArray");if(a.length===1&&t==null)throw new Error("tensor2d() requires shape to be provided when `values` are a flat/TypedArray");return Er(e,t,a,n)}function fR(e,t,n){if(ss(e),t!=null&&t.length!==4)throw new Error("tensor4d() requires shape to have four numbers");let a=Da(e,n);if(a.length!==4&&a.length!==1)throw new Error("tensor4d() requires values to be number[][][][] or flat/TypedArray");if(a.length===1&&t==null)throw new Error("tensor4d() requires shape to be provided when `values` are a flat array");return Er(e,t,a,n)}function mR(e,t,n){if(ss(e),t!=null&&t.length!==5)throw new Error("tensor5d() requires shape to have five numbers");let a=Da(e,n);if(a.length!==5&&a.length!==1)throw new Error("tensor5d() requires values to be number[][][][][] or flat/TypedArray");if(a.length===1&&t==null)throw new Error("tensor5d() requires shape to be provided when `values` are a flat array");return Er(e,t,a,n)}function AR(e,t,n){if(ss(e),t!=null&&t.length!==6)throw new Error("tensor6d() requires shape to have six numbers");let a=Da(e,n);if(a.length!==6&&a.length!==1)throw new Error("tensor6d() requires values to be number[][][][][][] or flat/TypedArray");if(a.length===1&&t==null)throw new Error("tensor6d() requires shape to be provided when `values` are a flat array");return t=t||a,Er(e,t,a,n)}function yR(e,t=1,n=!0){let a=M(e,"x","topk");if(a.rank===0)throw new Error("topk() expects the input to be of rank 1 or higher");let r=a.shape[a.shape.length-1];if(t>r)throw new Error(`'k' passed to topk() must be <= the last dimension (${r}) but got ${t}`);let s={x:a},i={k:t,sorted:n},[o,l]=D.runKernel(Yo,s,i);return{values:o,indices:l}}var DA=O({topk_:yR});function gR(e,t=0,n=1,a,r){if(a!=null&&a==="bool")throw new Error("Unsupported data type $ { dtype }");let s=new TA(t,n,a,!0,r),i=We(e,a);for(let o=0;o0,()=>"The input tensor must be at least 1D");let a={x:n},r={axis:t},[s,i]=D.runKernel(rc,a,r);return{values:s,indices:i}}var jc=O({unique_:xR});function bR(e,t,n){let a=M(e,"x","unsortedSegmentSum"),r=M(t,"segmentIds","unsortedSegmentSum","int32");F(jt(n),()=>"numSegments must be of dtype int");let s={x:a,segmentIds:r},i={numSegments:n};return D.runKernel(Mu,s,i)}var OA=O({unsortedSegmentSum_:bR});function vR(e,t=0){let n=M(e,"x","unstack","string_or_numeric");F(t>=-n.shape.length&&t`Axis = ${t} is not in [-${n.shape.length}, ${n.shape.length})`);let a={value:n},r={axis:t};return D.runKernel(Qo,a,r)}var ua=O({unstack_:vR});function Jb(e,t=!0,n,a){return D.makeVariable(e,t,n,a)}function Qb(e,t){let n=[];for(let s=0;s0,()=>"mask cannot be scalar"),on(o.slice(s,s+i),r.shape,"mask's shape must match the first K dimensions of tensor's shape,");let l=1;for(let f=s;f"Shape mismatch in v and x");let l=Se(1),d=ge(l,o),u=_(ge(i,s),d);if(r){F(a!=null,()=>"When using zeroDebias: true, step is required.");let p=M(a,"step","movingAverage");u=me(u,ge(l,sr(o,p)))}return se(s,u)}var TR=O({movingAverage_:NR});function ER(e,t,n){let a=M(e,"indices","scatterND","int32"),r=M(t,"updates","scatterND");Hm(r,a,n);let s={indices:a,updates:r},i={shape:n};return D.runKernel(Vo,s,i)}var t3=O({scatterND_:ER});function CR(e,t,n,a){if(e.dtype!=="int32")throw new Error(`tf.sparseToDense() expects the indices to be int32 type, but the dtype was ${e.dtype}.`);if(e.rank>2)throw new Error(`sparseIndices should be a scalar, vector, or matrix, but got shape ${e.shape}.`);let r=e.rank>0?e.shape[0]:1,s=e.rank>1?e.shape[1]:1;if(n.length!==s)throw new Error(`outputShape has incorrect number of elements:, ${n.length}, should be: ${s}.`);let i=t.size;if(!(t.rank===0||t.rank===1&&i===r))throw new Error(`sparseValues has incorrect shape ${t.shape}, should be [] or [${r}]`);if(t.dtype!==a.dtype)throw new Error("sparseValues.dtype must match defaultValues.dtype")}function RR(e,t,n,a=0){let r=M(e,"sparseIndices","sparseToDense","int32"),s=M(t,"sparseValues","sparseToDense"),i=M(a,"defaultValue","sparseToDense",s.dtype);CR(r,s,n,i);let o={sparseIndices:r,sparseValues:s,defaultValue:i},l={outputShape:n};return D.runKernel(ac,o,l)}var _A=O({sparseToDense_:RR});function MR(e,t){let n=M(t,"indices","gatherND","int32"),a={params:M(e,"x","gatherND"),indices:n};return D.runKernel(wo,a)}var n3=O({gatherND_:MR});function FR(e,t){if(t==null)return e.shape.slice();if(er(e.shape,t))return t;if(e.shape.length===t.length){let n=[];for(let a=0;a`x has to be a floating point tensor since it's going to be scaled, but got a ${r.dtype} tensor instead.`),F(t>=0&&t<1,()=>`rate must be a float in the range [0, 1), but got ${t}.`),t===0)return e instanceof Le?r.clone():r;let s=FR(r,n),i=1-t,o=me(yl(se(bl(s,0,1,"float32",a),i)),i);return _(r,o)}var a3=O({dropout_:$R});function r3(e){return Math.floor(Math.pow(2,Math.ceil(Math.log(e)/Math.log(2))))}function PA(e,t,n){let a=1-e%2,r=new Float32Array(e);for(let s=0;s1,()=>`inTopK() expects the predictions to be of rank 2 or higher, but got ${a.rank}`),F(a.rank-1===r.rank,()=>`predictions rank should be 1 larger than targets rank, but got predictions rank ${a.rank} and targets rank ${r.rank}`),on(a.shape.slice(0,a.shape.length-1),r.shape,"predictions's shape should be align with the targets' shape, except the last dimension.");let s=a.shape[a.shape.length-1];F(n>0&&n<=s,()=>`'k' passed to inTopK() must be > 0 && <= the predictions last dimension (${s}), but got ${n}`);let i=await a.data(),o=await r.data(),[l,d]=[i.length/s,s],u=xx("bool",l);for(let p=0;pA.value-f.value),u[p]=0;for(let f=0;fzR,depthwiseConv2d:()=>_R,matMul:()=>PR});function LR(e,t,n,a,r,s="NHWC",i){let o=e;e.rank===3&&(o=H(e,[1,e.shape[0],e.shape[1],e.shape[2]]));let l=t;l.rank===3&&(l=H(t,[1,t.shape[0],t.shape[1],t.shape[2]])),F(o.rank===4,()=>`Error in conv2dDerFilter: input must be rank 4, but got shape ${o.shape}.`),F(l.rank===4,()=>`Error in conv2dDerFilter: dy must be rank 4, but got shape ${l.shape}.`),F(n.length===4,()=>`Error in conv2dDerFilter: filterShape must be length 4, but got ${n}.`);let d=s==="NHWC"?o.shape[3]:o.shape[1],u=s==="NHWC"?l.shape[3]:l.shape[1];F(d===n[2],()=>`Error in conv2dDerFilter: depth of input ${d}) must match input depth in filter (${n[2]}.`),F(u===n[3],()=>`Error in conv2dDerFilter: depth of dy (${u}) must match output depth for filter (${n[3]}).`),i!=null&&F(jt(r),()=>`Error in conv2dDerFilter: pad must be an integer when using, dimRoundingMode ${i} but got pad ${r}.`);let p={x:o,dy:l},c={strides:a,pad:r,dataFormat:s,dimRoundingMode:i,filterShape:n};return D.runKernel(Fp,p,c)}var LA=O({conv2DBackpropFilter_:LR});function Hc(e,t,n){if(n==null||n==="linear")return e;if(n==="relu")return _(e,kl(t));throw new Error(`Cannot compute gradient for fused activation ${n}.`)}function Gc(e,t){let n=t,a=_t(e.shape,t.shape);return a.length>0&&(n=ke(n,a)),H(n,e.shape)}function qc(e,t,n,a){if(t==="linear")return e;if(t==="relu")return La(e);if(t==="elu")return ml(e);if(t==="relu6")return Fc(e);if(t==="prelu")return Qu(e,n);if(t==="leakyrelu")return Ku(e,a);if(t==="sigmoid")return kn(e);throw new Error(`Unknown fused activation ${t}.`)}var Xc=(e,t)=>!(e>0)||t==="linear";function WR({x:e,filter:t,strides:n,pad:a,dataFormat:r="NHWC",dilations:s=[1,1],dimRoundingMode:i,bias:o,activation:l="linear",preluActivationWeights:d,leakyreluAlpha:u}){if(l=l||"linear",Xc(D.state.gradientDepth,l)===!1){let b=ar(e,t,n,a,r,s,i);return o!=null&&(b=se(b,o)),qc(b,l,d,u)}let p=M(e,"x","conv2d"),c=M(t,"filter","conv2d"),h=p,m=!1;p.rank===3&&(m=!0,h=H(p,[1,p.shape[0],p.shape[1],p.shape[2]])),F(h.rank===4,()=>`Error in fused conv2d: input must be rank 4, but got rank ${h.rank}.`),F(c.rank===4,()=>`Error in fused conv2d: filter must be rank 4, but got rank ${c.rank}.`),i!=null&&F(jt(a),()=>`Error in fused conv2d: pad must be an integer when using, dimRoundingMode ${i} but got pad ${a}.`),F(h.shape[3]===c.shape[2],()=>`Error in conv2d: depth of input (${h.shape[3]}) must match input depth for filter ${c.shape[2]}.`),F(za(n,s),()=>`Error in conv2D: Either strides or dilations must be 1. Got strides ${n} and dilations '${s}'`),F(r==="NHWC",()=>`Error in conv2d: got dataFormat of ${r} but only NHWC is currently supported.`);let f=Hu(h.shape,c.shape,n,s,a,i),A;o!=null&&(A=M(o,"bias","fused conv2d"),[A]=vt(A,p),ct(f.outShape,A.shape));let y;d!=null&&(y=M(d,"prelu weights","fused conv2d"));let g=(b,v)=>{let[N,T,R,$]=v,z=Hc(b,R,l);F(Mr(s),()=>`Error in gradient of fused conv2D: dilation rates greater than 1 are not yet supported in gradients. Got dilations '${s}'`);let P=dA(T.shape,z,N,n,a),V=LA(T,z,N.shape,n,a),j=[P,V];if($!=null){let U=Gc($,z);j.push(U)}return j},x={x:h,filter:c,bias:A,preluActivationWeights:y},w={strides:n,pad:a,dataFormat:r,dilations:s,dimRoundingMode:i,activation:l,leakyreluAlpha:u};return o==null?_a((b,v,N)=>{let T=D.runKernel(ni,x,w);return N([v,b,T]),m&&(T=H(T,[T.shape[1],T.shape[2],T.shape[3]])),{value:T,gradFunc:g}})(h,c):_a((b,v,N,T)=>{let R=D.runKernel(ni,x,w);return T([v,b,R,N]),m&&(R=H(R,[R.shape[1],R.shape[2],R.shape[3]])),{value:R,gradFunc:g}})(h,c,A)}var zR=O({fusedConv2d_:WR});function BR(e,t,n,a,r,s=[1,1],i){let o=e;e.rank===3&&(o=H(e,[1,e.shape[0],e.shape[1],e.shape[2]]));let l=t;l.rank===3&&(l=H(t,[1,t.shape[0],t.shape[1],t.shape[2]]));let d={x:o,dy:l},u={strides:a,pad:r,dimRoundingMode:i,dilations:s,filterShape:n};return D.runKernel(zp,d,u)}var s3=O({depthwiseConv2dNativeBackpropFilter_:BR});function VR(e,t,n,a,r,s=[1,1],i){let o=t,l=!1;t.rank===3&&(l=!0,o=H(t,[1,t.shape[0],t.shape[1],t.shape[2]]));let d={dy:o,filter:n},u={strides:a,pad:r,dimRoundingMode:i,dilations:s,inputShape:e},p=D.runKernel(_p,d,u);return l?H(p,[p.shape[1],p.shape[2],p.shape[3]]):p}var i3=O({depthwiseConv2dNativeBackpropInput_:VR});function jR({x:e,filter:t,strides:n,pad:a,dataFormat:r="NHWC",dilations:s=[1,1],dimRoundingMode:i,bias:o,activation:l="linear",preluActivationWeights:d,leakyreluAlpha:u}){if(Xc(D.state.gradientDepth,l)===!1){let b=fl(e,t,n,a,r,s,i);return o!=null&&(b=se(b,o)),qc(b,l,d,u)}let p=M(e,"x","depthwiseConv2d"),c=M(t,"filter","depthwiseConv2d"),h=p,m=!1;p.rank===3&&(m=!0,h=H(p,[1,p.shape[0],p.shape[1],p.shape[2]])),F(h.rank===4,()=>`Error in fused depthwiseConv2d: input must be rank 4, but got rank ${h.rank}.`),F(c.rank===4,()=>`Error in fused depthwiseConv2d: filter must be rank 4, but got rank ${c.rank}.`),F(h.shape[3]===c.shape[2],()=>`Error in fused depthwiseConv2d: number of input channels (${h.shape[3]}) must match the inChannels dimension in filter ${c.shape[2]}.`),s==null&&(s=[1,1]),F(za(n,s),()=>`Error in fused depthwiseConv2d: Either strides or dilations must be 1. Got strides ${n} and dilations '${s}'`),i!=null&&F(jt(a),()=>`Error in fused depthwiseConv2d: pad must be an integer when using dimRoundingMode ${i} but got pad ${a}.`);let f=Hu(h.shape,c.shape,n,s,a,i,!0),A;o!=null&&(A=M(o,"bias","fused conv2d"),[A]=vt(A,p),ct(f.outShape,A.shape));let y;d!=null&&(y=M(d,"prelu weights","fused depthwiseConv2d"));let g=(b,v)=>{F(Mr(s),()=>`Error in gradient of fused depthwiseConv2d: dilation rates greater than 1 are not yet supported. Got dilations '${s}'`);let[N,T,R,$]=v,z=Hc(b,R,l),P=i3(T.shape,z,N,n,a,s,i),V=s3(T,z,N.shape,n,a,s,i);if($!=null){let j=Gc(A,z);return[P,V,j]}return[P,V]},x={x:h,filter:c,bias:A,preluActivationWeights:y},w={strides:n,pad:a,dataFormat:r,dilations:s,dimRoundingMode:i,activation:l,leakyreluAlpha:u};return o==null?_a((b,v,N)=>{let T=D.runKernel(ai,x,w);return N([v,b,T]),m&&(T=H(T,[T.shape[1],T.shape[2],T.shape[3]])),{value:T,gradFunc:g}})(h,c):_a((b,v,N,T)=>{let R=D.runKernel(ai,x,w);return T([v,b,R,N]),m&&(R=H(R,[R.shape[1],R.shape[2],R.shape[3]])),{value:R,gradFunc:g}})(h,c,A)}var _R=O({fusedDepthwiseConv2d_:jR});function UR({a:e,b:t,transposeA:n=!1,transposeB:a=!1,bias:r,activation:s="linear",preluActivationWeights:i,leakyreluAlpha:o}){if(Xc(D.state.gradientDepth,s)===!1){let $=Be(e,t,n,a);return r!=null&&($=se($,r)),qc($,s,i,o)}let l=M(e,"a","fused matMul"),d=M(t,"b","fused matMul");[l,d]=vt(l,d);let u=n?l.shape[l.rank-2]:l.shape[l.rank-1],p=a?d.shape[d.rank-1]:d.shape[d.rank-2],c=n?l.shape[l.rank-1]:l.shape[l.rank-2],h=a?d.shape[d.rank-2]:d.shape[d.rank-1],m=l.shape.slice(0,-2),f=d.shape.slice(0,-2),A=Tt(m),y=Tt(f);F(l.rank>=2&&d.rank>=2&&l.rank===d.rank,()=>`Error in fused matMul: inputs must have the same rank of at least 2, got ranks ${l.rank} and ${d.rank}.`),F(er(m,f),()=>`Error in fused matMul: outer dimensions (${m}) and (${f}) of Tensors with shapes ${l.shape} and ${d.shape} must match.`),F(u===p,()=>`Error in fused matMul: inner shapes (${u}) and (${p}) of Tensors with shapes ${l.shape} and ${d.shape} and transposeA=${n} and transposeB=${a} must match.`);let g=l.shape.slice(0,-2).concat([c,h]),x=n?H(l,[A,u,c]):H(l,[A,c,u]),w=a?H(d,[y,h,p]):H(d,[y,p,h]),b;r!=null&&(b=M(r,"bias","fused matMul"),[b]=vt(b,l),ct(g,b.shape));let v;i!=null&&(v=M(i,"prelu weights","fused matMul"));let N=($,z)=>{let[P,V,j,U]=z,X=Hc(H($,j.shape),j,s),G,ee;if(!n&&!a?(G=Be(X,V,!1,!0),ee=Be(P,X,!0,!1)):!n&&a?(G=Be(X,V,!1,!1),ee=Be(X,P,!0,!1)):n&&!a?(G=Be(V,X,!1,!0),ee=Be(P,X,!1,!1)):(G=Be(V,X,!0,!0),ee=Be(X,P,!0,!0)),r!=null){let Y=Gc(U,X);return[G,ee,Y]}else return[G,ee]},T={a:x,b:w,bias:b,preluActivationWeights:v},R={transposeA:n,transposeB:a,activation:s,leakyreluAlpha:o};return r==null?_a(($,z,P)=>{let V=D.runKernel(ti,T,R);return P([$,z,V]),{value:H(V,g),gradFunc:N}})(x,w):_a(($,z,P,V)=>{let j=D.runKernel(ti,T,R);return V([$,z,j,P]),{value:H(j,g),gradFunc:N}})(x,w,b)}var PR=O({fusedMatMul_:UR});function HR(e){return PA(e,.54,.46)}var GR=O({hammingWindow_:HR});function qR(e){return PA(e,.5,.5)}var o3=O({hannWindow_:qR});function XR(e,t,n,a=!1,r=0){let s=0,i=[];for(;s+t<=e.size;)i.push(Re(e,s,t)),s+=n;if(a)for(;s`Error in cropAndResize: image must be rank 4,but got rank ${i.rank}.`),F(o.rank===2&&o.shape[1]===4,()=>`Error in cropAndResize: boxes must be have size [${d},4] but had shape ${o.shape}.`),F(l.rank===1&&l.shape[0]===d,()=>`Error in cropAndResize: boxInd must be have size [${d}] but had shape ${o.shape}.`),F(a.length===2,()=>`Error in cropAndResize: cropSize must be of length 2, but got length ${a.length}.`),F(a[0]>=1&&a[1]>=1,()=>`cropSize must be atleast [1,1], but was ${a}`),F(r==="bilinear"||r==="nearest",()=>`method must be bilinear or nearest, but was ${r}`);let u={image:i,boxes:o,boxInd:l},p={method:r,extrapolationValue:s,cropSize:a};return D.runKernel(ho,u,p)}var JR=O({cropAndResize_:YR});function QR(e){let t=M(e,"image","flipLeftRight","float32");F(t.rank===4,()=>`Error in flipLeftRight: image must be rank 4,but got rank ${t.rank}.`);let n={image:t};return D.runKernel(bo,n,{})}var eM=O({flipLeftRight_:QR});function tM(e,t,n=0,a=.5){let r=M(e,"image","rotateWithOffset","float32");F(r.rank===4,()=>`Error in rotateWithOffset: image must be rank 4,but got rank ${r.rank}.`);let s={image:r},i={radians:t,fillValue:n,center:a};return D.runKernel(tl,s,i)}var nM=O({rotateWithOffset_:tM});function Il(e,t,n,a,r,s){a==null&&(a=.5),r==null&&(r=Number.NEGATIVE_INFINITY),s==null&&(s=0);let i=e.shape[0];return n=Math.min(n,i),F(0<=a&&a<=1,()=>`iouThreshold must be in [0, 1], but was '${a}'`),F(e.rank===2,()=>`boxes must be a 2D tensor, but was of rank '${e.rank}'`),F(e.shape[1]===4,()=>`boxes must have 4 columns, but 2nd dimension was ${e.shape[1]}`),F(t.rank===1,()=>"scores must be a 1D tensor"),F(t.shape[0]===i,()=>`scores has incompatible shape with boxes. Expected ${i}, but was ${t.shape[0]}`),F(0<=s&&s<=1,()=>`softNmsSigma must be in [0, 1], but was '${s}'`),{maxOutputSize:n,iouThreshold:a,scoreThreshold:r,softNmsSigma:s}}function aM(e,t,n,a=.5,r=Number.NEGATIVE_INFINITY){let s=M(e,"boxes","nonMaxSuppression"),i=M(t,"scores","nonMaxSuppression"),o=Il(s,i,n,a,r);n=o.maxOutputSize,a=o.iouThreshold,r=o.scoreThreshold;let l={maxOutputSize:n,iouThreshold:a,scoreThreshold:r};return D.runKernel(Do,{boxes:s,scores:i},l)}var rM=O({nonMaxSuppression_:aM});function iM(e,t,n){let a=sM(e,t,n),r=a<0?-(a+1):a;e.splice(r,0,t)}function sM(e,t,n){return lM(e,t,n||oM)}function oM(e,t){return e>t?1:e>>1);let o=n(t,e[s]);o>0?a=s+1:(r=s,i=!o)}return i?a:-a-1}function u3(e,t,n,a,r){return WA(e,t,n,a,r,0)}function d3(e,t,n,a,r,s){return WA(e,t,n,a,r,0,!1,s,!0)}function p3(e,t,n,a,r,s){return WA(e,t,n,a,r,s,!0)}function WA(e,t,n,a,r,s,i=!1,o=!1,l=!1){let d=[];for(let A=0;Ar&&d.push({score:t[A],boxIndex:A,suppressBeginIndex:0});d.sort(c3);let u=s>0?-.5/s:0,p=[],c=[];for(;p.length0;){let A=d.pop(),{score:y,boxIndex:g,suppressBeginIndex:x}=A;if(y=x;--b){let v=uM(e,g,p[b]);if(v>=a){w=!0;break}if(A.score=A.score*dM(a,u,v),A.score<=r)break}A.suppressBeginIndex=p.length,w||(A.score===y?(p.push(g),c.push(A.score)):A.score>r&&iM(d,A,c3))}let h=p.length,m=n-h;o&&m>0&&(p.push(...new Array(m).fill(0)),c.push(...new Array(m).fill(0)));let f={selectedIndices:p};return i&&(f.selectedScores=c),l&&(f.validOutputs=h),f}function uM(e,t,n){let a=e.subarray(t*4,t*4+4),r=e.subarray(n*4,n*4+4),s=Math.min(a[0],a[2]),i=Math.min(a[1],a[3]),o=Math.max(a[0],a[2]),l=Math.max(a[1],a[3]),d=Math.min(r[0],r[2]),u=Math.min(r[1],r[3]),p=Math.max(r[0],r[2]),c=Math.max(r[1],r[3]),h=(o-s)*(l-i),m=(p-d)*(c-u);if(h<=0||m<=0)return 0;let f=Math.max(s,d),A=Math.max(i,u),y=Math.min(o,p),g=Math.min(l,c),x=Math.max(y-f,0)*Math.max(g-A,0);return x/(h+m-x)}function dM(e,t,n){let a=Math.exp(t*n*n);return n<=e?a:0}function c3(e,t){return e.score-t.score||e.score===t.score&&t.boxIndex-e.boxIndex}async function pM(e,t,n,a=.5,r=Number.NEGATIVE_INFINITY){let s=M(e,"boxes","nonMaxSuppressionAsync"),i=M(t,"scores","nonMaxSuppressionAsync"),o=Il(s,i,n,a,r);n=o.maxOutputSize,a=o.iouThreshold,r=o.scoreThreshold;let l=await Promise.all([s.data(),i.data()]),d=l[0],u=l[1],{selectedIndices:p}=u3(d,u,n,a,r);return s!==e&&s.dispose(),i!==t&&i.dispose(),Et(p,"int32")}var cM=pM;function hM(e,t,n,a=.5,r=Number.NEGATIVE_INFINITY,s=0){let i=M(e,"boxes","nonMaxSuppression"),o=M(t,"scores","nonMaxSuppression"),l=Il(i,o,n,a,r,s);n=l.maxOutputSize,a=l.iouThreshold,r=l.scoreThreshold,s=l.softNmsSigma;let d={boxes:i,scores:o},u={maxOutputSize:n,iouThreshold:a,scoreThreshold:r,softNmsSigma:s},p=D.runKernel(zo,d,u);return{selectedIndices:p[0],selectedScores:p[1]}}var fM=O({nonMaxSuppressionWithScore_:hM});async function mM(e,t,n,a=.5,r=Number.NEGATIVE_INFINITY,s=0){let i=M(e,"boxes","nonMaxSuppressionAsync"),o=M(t,"scores","nonMaxSuppressionAsync"),l=Il(i,o,n,a,r,s);n=l.maxOutputSize,a=l.iouThreshold,r=l.scoreThreshold,s=l.softNmsSigma;let d=await Promise.all([i.data(),o.data()]),u=d[0],p=d[1],{selectedIndices:c,selectedScores:h}=p3(u,p,n,a,r,s);return i!==e&&i.dispose(),o!==t&&o.dispose(),{selectedIndices:Et(c,"int32"),selectedScores:Et(h)}}var AM=mM;function yM(e,t,n,a=.5,r=Number.NEGATIVE_INFINITY,s=!1){let i=M(e,"boxes","nonMaxSuppression"),o=M(t,"scores","nonMaxSuppression"),l=Il(i,o,n,a,r,null),d=l.maxOutputSize,u=l.iouThreshold,p=l.scoreThreshold,c={boxes:i,scores:o},h={maxOutputSize:d,iouThreshold:u,scoreThreshold:p,padToMaxOutputSize:s},m=D.runKernel(Oo,c,h);return{selectedIndices:m[0],validOutputs:m[1]}}var gM=O({nonMaxSuppressionPadded_:yM});async function xM(e,t,n,a=.5,r=Number.NEGATIVE_INFINITY,s=!1){let i=M(e,"boxes","nonMaxSuppressionAsync"),o=M(t,"scores","nonMaxSuppressionAsync"),l=Il(i,o,n,a,r,null),d=l.maxOutputSize,u=l.iouThreshold,p=l.scoreThreshold,[c,h]=await Promise.all([i.data(),o.data()]),{selectedIndices:m,validOutputs:f}=d3(c,h,d,u,p,s);return i!==e&&i.dispose(),o!==t&&o.dispose(),{selectedIndices:Et(m,"int32"),validOutputs:Se(f,"int32")}}var bM=xM;function vM(e,t,n=!1,a=!1){let r=M(e,"images","resizeBilinear");F(r.rank===3||r.rank===4,()=>`Error in resizeBilinear: x must be rank 3 or 4, but got rank ${r.rank}.`),F(t.length===2,()=>`Error in resizeBilinear: new shape must 2D, but got shape ${t}.`),F(a===!1||n===!1,()=>"Error in resizeBilinear: If halfPixelCenters is true, alignCorners must be false.");let s=r,i=!1;r.rank===3&&(i=!0,s=H(r,[1,r.shape[0],r.shape[1],r.shape[2]]));let[]=t,o={images:s},l={alignCorners:n,halfPixelCenters:a,size:t},d=D.runKernel(Ws,o,l);return i?H(d,[d.shape[1],d.shape[2],d.shape[3]]):d}var h3=O({resizeBilinear_:vM});function wM(e,t,n=!1,a=!1){let r=M(e,"images","resizeNearestNeighbor");F(r.rank===3||r.rank===4,()=>`Error in resizeNearestNeighbor: x must be rank 3 or 4, but got rank ${r.rank}.`),F(t.length===2,()=>`Error in resizeNearestNeighbor: new shape must 2D, but got shape ${t}.`),F(r.dtype==="float32"||r.dtype==="int32",()=>"`images` must have `int32` or `float32` as dtype"),F(a===!1||n===!1,()=>"Error in resizeNearestNeighbor: If halfPixelCenters is true, alignCorners must be false.");let s=r,i=!1;r.rank===3&&(i=!0,s=H(r,[1,r.shape[0],r.shape[1],r.shape[2]]));let[]=t,o={images:s},l={alignCorners:n,halfPixelCenters:a,size:t},d=D.runKernel(Eu,o,l);return i?H(d,[d.shape[1],d.shape[2],d.shape[3]]):d}var f3=O({resizeNearestNeighbor_:wM});function IM(e,t="binary",n=!1,a=.5){let r=M(e,"image","threshold"),s=.2989,i=.587,o=.114,l=r.shape[0]*r.shape[1],d=_(Et([a]),255),u,p,c,h;if(F(r.rank===3,()=>`Error in threshold: image must be rank 3,but got rank ${r.rank}.`),F(r.shape[2]===3||r.shape[2]===1,()=>`Error in threshold: image color channel must be equal to 3 or 1but got ${r.shape[2]}.`),F(r.dtype==="int32"||r.dtype==="float32",()=>`Error in dtype: image dtype must be int32 or float32,but got dtype ${r.dtype}.`),F(t==="otsu"||t==="binary",()=>`Method must be binary or otsu, but was ${t}`),r.shape[2]===3){[u,p,c]=rn(r,[1,1,1],-1);let f=_(u,s),A=_(p,i),y=_(c,o);h=se(se(f,A),y)}else h=e;if(t==="otsu"){let f=lA(fe($c(h),"int32"),oa([]),256);d=kM(f,l)}let m=n?Or(h,d):Fn(h,d);return fe(_(m,255),"int32")}function kM(e,t){let n=Et([-1]),a=Et([0]),r=Et([0]),s,i,o,l,d,u;for(let p=0;p`Error in transform: image must be rank 4,but got rank ${i.rank}.`),F(o.rank===2&&(o.shape[0]===i.shape[0]||o.shape[0]===1)&&o.shape[1]===8,()=>"Error in transform: Input transform should be batch x 8 or 1 x 8"),F(s==null||s.length===2,()=>`Error in transform: outputShape must be [height, width] or null, but got ${s}.`);let l={image:i,transforms:o},d={interpolation:n,fillMode:a,fillValue:r,outputShape:s};return D.runKernel(Jo,l,d)}var TM=O({transform_:NM});function EM(e,t,n){F(t%1==0,()=>`bandPart(): numLower must be an integer, got ${t}.`),F(n%1==0,()=>`bandPart(): numUpper must be an integer, got ${n}.`);let a=M(e,"a","bandPart");F(a.rank>=2,()=>`bandPart(): Rank must be at least 2, got ${a.rank}.`);let r=a.shape,[s,i]=a.shape.slice(-2);if(!(t<=s))throw new Error(`bandPart(): numLower (${t}) must not be greater than the number of rows (${s}).`);if(!(n<=i))throw new Error(`bandPart(): numUpper (${n}) must not be greater than the number of columns (${i}).`);t<0&&(t=s),n<0&&(n=i);let o=H(vl(0,s,1,"int32"),[-1,1]),l=vl(0,i,1,"int32"),d=ge(o,l),u=la(Or(d,Se(+t,"int32")),Dr(d,Se(-n,"int32"))),p=Rt([s,i],a.dtype);return H(_n(ua(H(a,[-1,s,i])).map(c=>an(u,c,p))),r)}var CM=O({bandPart_:EM});function RM(e){let t;if(Array.isArray(e)){t=!1,F(e!=null&&e.length>0,()=>"Gram-Schmidt process: input must not be null, undefined, or empty");let r=e[0].shape[0];for(let s=1;s`Gram-Schmidt: Non-unique lengths found in the input vectors: (${e[s].shape[0]} vs. ${r})`)}else t=!0,e=rn(e,e.shape[0],0).map(r=>zr(r,[0]));F(e.length<=e[0].shape[0],()=>`Gram-Schmidt: Number of vectors (${e.length}) exceeds number of dimensions (${e[0].shape[0]}).`);let n=[],a=e;for(let r=0;r{let s=a[r];if(r>0)for(let i=0;i=2,()=>`qr() requires input tensor to have a rank >= 2, but got rank ${e.rank}`),e.rank===2)return m3(e,t);{let n=e.shape.slice(0,e.shape.length-2).reduce((l,d)=>l*d),a=ua(H(e,[n,e.shape[e.shape.length-2],e.shape[e.shape.length-1]]),0),r=[],s=[];a.forEach(l=>{let[d,u]=m3(l,t);r.push(d),s.push(u)});let i=H(_n(r,0),e.shape),o=H(_n(s,0),e.shape);return[i,o]}}function m3(e,t=!1){return D.tidy(()=>{F(e.shape.length===2,()=>`qr2d() requires a 2D Tensor, but got a ${e.shape.length}D Tensor.`);let n=e.shape[0],a=e.shape[1],r=yA(n),s=Oa(e),i=ga([[1]],[1,1]),o=Oa(i),l=n>=a?a:n;for(let d=0;d{let h=Re(s,[d,d],[n-d,1]),m=Uc(h),f=Re(s,[d,d],[1,1]),A=an(Fn(f,0),ga([[-1]]),ga([[1]])),y=ge(f,_(A,m)),g=me(h,y);g.shape[0]===1?o=Oa(i):o=ot([i,Re(g,[1,0],[g.shape[0]-1,g.shape[1]])],0);let x=wt(me(Be(A,y),m)),w=Re(s,[d,0],[n-d,a]),b=_(x,o),v=Ze(o);if(d===0)s=ge(w,Be(b,Be(v,w)));else{let R=ge(w,Be(b,Be(v,w)));s=ot([Re(s,[0,0],[d,a]),R],0)}let N=Ze(b),T=Re(r,[0,d],[n,r.shape[1]-d]);if(d===0)r=ge(T,Be(Be(T,o),N));else{let R=ge(T,Be(Be(T,o),N));r=ot([Re(r,[0,0],[n,d]),R],1)}return[o,s,r]}),Ee([u,p,c])}return!t&&n>a&&(r=Re(r,[0,0],[n,a]),s=Re(s,[0,0],[a,a])),[r,s]})}var $M=O({qr_:FM}),dn;(function(e){e[e.NONE=0]="NONE",e[e.MEAN=1]="MEAN",e[e.SUM=2]="SUM",e[e.SUM_BY_NONZERO_WEIGHTS=3]="SUM_BY_NONZERO_WEIGHTS"})(dn||(dn={}));function DM(e,t,n=dn.SUM_BY_NONZERO_WEIGHTS){let a=M(e,"losses","computeWeightedLoss"),r=null;t!=null&&(r=M(t,"weights","computeWeightedLoss"));let s=r==null?a:_(a,r);if(n===dn.NONE)return s;if(n===dn.SUM)return ke(s);if(n===dn.MEAN){if(r==null)return kt(s);{let i=a.size/r.size,o=me(ke(s),ke(r));return i>1?me(o,Se(i)):o}}if(n===dn.SUM_BY_NONZERO_WEIGHTS){if(r==null)return me(ke(s),Se(a.size));{let i=_(r,Dn(a.shape)),o=fe(ke(Ai(i,Se(0))),"float32");return me(ke(s),o)}}throw Error(`Unknown reduction: ${n}`)}var ir=O({computeWeightedLoss_:DM});function OM(e,t,n,a=dn.SUM_BY_NONZERO_WEIGHTS){let r=M(e,"labels","absoluteDifference"),s=M(t,"predictions","absoluteDifference"),i=null;n!=null&&(i=M(n,"weights","absoluteDifference")),on(r.shape,s.shape,"Error in absoluteDifference: ");let o=zt(ge(r,s));return ir(o,i,a)}var zM=O({absoluteDifference_:OM});function _M(e,t,n,a,r=dn.SUM_BY_NONZERO_WEIGHTS){let s=M(e,"labels","cosineDistance"),i=M(t,"predictions","cosineDistance"),o=null;a!=null&&(o=M(a,"weights","cosineDistance")),on(s.shape,i.shape,"Error in cosineDistance: ");let l=Se(1),d=ge(l,ke(_(s,i),n,!0));return ir(d,o,r)}var PM=O({cosineDistance_:_M});function LM(e,t,n,a=dn.SUM_BY_NONZERO_WEIGHTS){let r=M(e,"labels","hingeLoss"),s=M(t,"predictions","hingeLoss"),i=null;n!=null&&(i=M(n,"weights","hingeLoss")),on(r.shape,s.shape,"Error in hingeLoss: ");let o=Se(1);r=ge(_(Se(2),r),o);let l=La(ge(o,_(r,s)));return ir(l,i,a)}var WM=O({hingeLoss_:LM});function BM(e,t,n,a=1,r=dn.SUM_BY_NONZERO_WEIGHTS){let s=M(e,"labels","huberLoss"),i=M(t,"predictions","huberLoss"),o=null;n!=null&&(o=M(n,"weights","huberLoss")),on(s.shape,i.shape,"Error in huberLoss: ");let l=Se(a),d=zt(ge(i,s)),u=xl(d,l),p=ge(d,u),c=se(_(Se(.5),st(u)),_(l,p));return ir(c,o,r)}var VM=O({huberLoss_:BM});function jM(e,t,n,a=1e-7,r=dn.SUM_BY_NONZERO_WEIGHTS){let s=M(e,"labels","logLoss"),i=M(t,"predictions","logLoss"),o=null;n!=null&&(o=M(n,"weights","logLoss")),on(s.shape,i.shape,"Error in logLoss: ");let l=Se(1),d=Se(a),u=wt(_(s,$n(se(i,d)))),p=_(ge(l,s),$n(se(ge(l,i),d))),c=ge(u,p);return ir(c,o,r)}var UM=O({logLoss_:jM});function HM(e,t,n,a=dn.SUM_BY_NONZERO_WEIGHTS){let r=M(e,"labels","meanSquaredError"),s=M(t,"predictions","meanSquaredError"),i=null;n!=null&&(i=M(n,"weights","meanSquaredError")),on(r.shape,s.shape,"Error in meanSquaredError: ");let o=Bc(r,s);return ir(o,i,a)}var GM=O({meanSquaredError_:HM});function qM(e,t){let n=M(e,"labels","sigmoidCrossEntropyWithLogits"),a=M(t,"logits","sigmoidCrossEntropyWithLogits");on(n.shape,a.shape,"Error in sigmoidCrossEntropyWithLogits: ");let r=La(a),s=_(a,n),i=Nc(Xn(wt(zt(a))));return se(ge(r,s),i)}function XM(e,t,n,a=0,r=dn.SUM_BY_NONZERO_WEIGHTS){let s=M(e,"multiClassLabels","sigmoidCrossEntropy"),i=M(t,"logits","sigmoidCrossEntropy"),o=null;if(n!=null&&(o=M(n,"weights","sigmoidCrossEntropy")),on(s.shape,i.shape,"Error in sigmoidCrossEntropy: "),a>0){let d=Se(a),u=Se(1),p=Se(.5);s=se(_(s,ge(u,d)),_(p,d))}let l=qM(s,i);return ir(l,o,r)}var KM=O({sigmoidCrossEntropy_:XM});function ZM(e,t,n=-1){if(n===-1&&(n=t.rank-1),n!==t.rank-1)throw Error(`Softmax cross entropy along a non-last dimension is not yet supported. Labels / logits was rank ${t.rank} and dim was ${n}`);return _a((a,r,s)=>{let i=wA(r,[n],!0),o=ge(fe(r,"float32"),i);s([a,o]);let l=wt(_(o,a));return{value:ke(l,[n]),gradFunc:(d,u)=>{let[p,c]=u,h=mi(d.shape,[n]);return[_(H(d,h),ge(fe(p,"float32"),Xn(c))),_(H(d,h),ge(Xn(c),fe(p,"float32")))]}}})(e,t)}function YM(e,t,n,a=0,r=dn.SUM_BY_NONZERO_WEIGHTS){let s=M(e,"onehotLabels","softmaxCrossEntropy"),i=M(t,"logits","softmaxCrossEntropy"),o=null;if(n!=null&&(o=M(n,"weights","softmaxCrossEntropy")),on(s.shape,i.shape,"Error in softmaxCrossEntropy: "),a>0){let d=Se(a),u=Se(1),p=Se(s.shape[1]);s=se(_(s,ge(u,d)),me(d,p))}let l=ZM(s,i);return ir(l,o,r)}var JM=O({softmaxCrossEntropy_:YM});function QM(e,t,n,a){let r=M(e,"indices","sparseFillEmptyRows"),s=M(t,"values","sparseFillEmptyRows"),i=M(n,"denseShape","sparseFillEmptyRows"),o=M(a,"defaultValue","sparseFillEmptyRows",s.dtype);if(r.rank!==2)throw new Error(`Indices should be Tensor2D but received shape + ${a.shape}`),F(i%(t*t)==0,()=>`Dimension size must be evenly divisible by ${t*t} but is ${i} for depthToSpace with input shape ${a.shape}`);let o={x:a},l={blockSize:t,dataFormat:n};return D.runKernel(ho,o,l)}var cA=O({depthToSpace_:UT});function HT(e,t,n,a,r="NHWC",s=[1,1],i){let o=M(e,"x","depthwiseConv2d"),l=M(t,"filter","depthwiseConv2d"),d=o,u=!1;o.rank===3&&(u=!0,d=H(o,[1,o.shape[0],o.shape[1],o.shape[2]])),F(d.rank===4,()=>`Error in depthwiseConv2d: input must be rank 4, but got rank ${d.rank}.`),F(l.rank===4,()=>`Error in depthwiseConv2d: filter must be rank 4, but got rank ${l.rank}.`),F(d.shape[3]===l.shape[2],()=>`Error in depthwiseConv2d: number of input channels (${d.shape[3]}) must match the inChannels dimension in filter ${l.shape[2]}.`),i!=null&&F(Vt(a),()=>`Error in depthwiseConv2d: pad must be an integer when using, dimRoundingMode ${i} but got pad ${a}.`);let p={x:d,filter:l},c={strides:n,pad:a,dataFormat:r,dilations:s,dimRoundingMode:i},h=D.runKernel(As,p,c);return u?H(h,[h.shape[1],h.shape[2],h.shape[3]]):h}var hl=O({depthwiseConv2d_:HT});function GT(e){let t={x:M(e,"x","diag")};return D.runKernel(Pp,t)}var qT=O({diag_:GT});function XT(e,t,n,a,r=[1,1],s="NHWC"){let i=M(e,"x","dilation2d"),o=M(t,"filter","dilation2d");F(i.rank===3||i.rank===4,()=>`Error in dilation2d: input must be rank 3 or 4, but got rank ${i.rank}.`),F(o.rank===3,()=>`Error in dilation2d: filter must be rank 3, but got rank ${o.rank}.`),F(s==="NHWC",()=>`Error in dilation2d: Only NHWC is currently supported, but got dataFormat of ${s}`);let l=i,d=!1;i.rank===3&&(l=H(i,[1,i.shape[0],i.shape[1],i.shape[2]]),d=!0);let u={x:l,filter:o},p={strides:n,pad:a,dilations:r},c=D.runKernel(vu,u,p);return d?H(c,[c.shape[1],c.shape[2],c.shape[3]]):c}var hA=O({dilation2d_:XT});function KT(e,t){let n=e.length,a=[];for(let r=0;r1&&i===1&&a.unshift(s)}return a}function zt(e,t){let n=[];for(let a=0;a1)&&n.unshift(s)}return n}function pt(e,t){let n=[],a=Math.max(e.length,t.length);for(let r=0;r`Error in dot: inputs must all be rank 1 or 2, but got ranks ${n.rank} and ${a.rank}.`);let r=n.rank===1?n.size:n.shape[1],s=a.rank===1?a.size:a.shape[0];if(F(r===s,()=>`Error in dot: inner dimensions of inputs must match, but got ${r} and ${s}.`),n.rank===1&&a.rank===1){let i=H(n,[1,-1]),o=H(a,[-1,1]),l=Be(i,o);return H(l,[])}else if(n.rank===1&&a.rank===2){let i=H(n,[1,-1]),o=H(a,[a.shape[0],a.shape[1]]),l=Be(i,o);return H(l,[l.size])}else if(n.rank===2&&a.rank===1){let i=H(a,[-1,1]),o=Be(n,i);return H(o,[o.size])}else{let i=H(a,[a.shape[0],a.shape[1]]);return Be(n,i)}}var zb=O({dot_:eE});function tE(e,...t){let n=t.map((r,s)=>M(r,`tensors${s}`,"einsum")),a={equation:e};return D.runKernel(Bp,n,a)}var _b=O({einsum_:tE});function nE(e){let t={x:M(e,"x","elu")};return D.runKernel(fo,t)}var fl=O({elu_:nE});function aE(e){let t=M(e,"x","erf");F(t.dtype==="int32"||t.dtype==="float32",()=>"Input dtype must be `int32` or `float32`."),t.dtype==="int32"&&(t=fe(t,"float32"));let n={x:t};return D.runKernel(mo,n)}var mA=O({erf_:aE});function rE(e){let t={x:M(e,"x","exp")};return D.runKernel(gs,t)}var qn=O({exp_:rE});function sE(e,t=0){let n=M(e,"x","expandDims","string_or_numeric");F(t<=n.rank,()=>"Axis must be <= rank of the tensor");let a={input:n},r={dim:t};return D.runKernel(yo,a,r)}var ln=O({expandDims_:sE});function iE(e){let t={x:M(e,"x","expm1")};return D.runKernel(go,t)}var AA=O({expm1_:iE});function oE(e,t){let n=M(e,"x","tile","string_or_numeric");F(n.rank===t.length,()=>`Error in transpose: rank of input ${n.rank} must match length of reps ${t}.`);let a={x:n},r={reps:t};return D.runKernel(Ir,a,r)}var Fr=O({tile_:oE});function lE(e,t,n,a="float32"){t==null&&(t=e);let r=We([e,t],a),s=e<=t?e:t;for(let o=0;o`Error in localResponseNormalization: x must be rank 3 or 4 but got + rank ${s.rank}.`),F(Vt(t),()=>`Error in localResponseNormalization: depthRadius must be an integer but got depthRadius ${t}.`);let i=s,o=!1;s.rank===3&&(o=!0,i=H(s,[1,s.shape[0],s.shape[1],s.shape[2]]));let l={x:i},d={depthRadius:t,bias:n,alpha:a,beta:r},u=D.runKernel(Su,l,d);return o?H(u,[u.shape[1],u.shape[2],u.shape[3]]):u}var xA=O({localResponseNormalization_:bE});function vE(e){let t={x:M(e,"x","log")};return D.runKernel(Ss,t)}var Fn=O({log_:vE});function wE(e){let t={x:M(e,"x","log1p")};return D.runKernel(Eo,t)}var Nc=O({log1p_:wE});function kE(e){return F(vr(e),()=>"The f passed in grad(f) must be a function"),(t,n)=>{let a=M(t,"x","tf.grad","string_or_numeric"),r=n!=null?M(n,"dy","tf.grad"):null;return D.tidy(()=>{let{value:s,grads:i}=D.gradients(()=>e(a),[a],r);return r!=null&&sn(s.shape,r.shape,"The shape of dy passed in grad(f)(x, dy) must match the shape returned by f(x)"),Tc(i),i[0]})}}function IE(e){return F(vr(e),()=>"The f passed in grads(f) must be a function"),(t,n)=>{F(Array.isArray(t),()=>"The args passed in grads(f)(args) must be an array of `Tensor`s or `TensorLike`s");let a=Bu(t,"args","tf.grads","string_or_numeric"),r=n!=null?M(n,"dy","tf.grads"):null;return D.tidy(()=>{let{value:s,grads:i}=D.gradients(()=>e(...a),a,r);return r!=null&&sn(s.shape,r.shape,"The shape of dy passed in grads(f)([x1,...], dy) must match the shape returned by f([x1,...])"),Tc(i),i})}}function SE(e){return F(vr(e),()=>"The f passed in valueAndGrad(f) must be a function"),(t,n)=>{F(t instanceof Le,()=>"The x passed in valueAndGrad(f)(x) must be a tensor"),F(n==null||n instanceof Le,()=>"The dy passed in valueAndGrad(f)(x, dy) must be a tensor");let{grads:a,value:r}=D.gradients(()=>e(t),[t],n);return Tc(a),{grad:a[0],value:r}}}function NE(e){return F(vr(e),()=>"The f passed in valueAndGrads(f) must be a function"),(t,n)=>{F(Array.isArray(t)&&t.every(r=>r instanceof Le),()=>"The args passed in valueAndGrads(f)(args) must be array of tensors"),F(n==null||n instanceof Le,()=>"The dy passed in valueAndGrads(f)(args, dy) must be a tensor");let a=D.gradients(()=>e(...t),t,n);return n!=null&&sn(a.value.shape,n.shape,"The shape of dy passed in valueAndGrads(f)([x1,...], dy) must match the shape returned by f([x1,...])"),Tc(a.grads),a}}function Bb(e,t){F(vr(e),()=>"The f passed in variableGrads(f) must be a function"),F(t==null||Array.isArray(t)&&t.every(d=>d instanceof Pu),()=>"The varList passed in variableGrads(f, varList) must be an array of variables");let n=t!=null;if(!n){t=[];for(let d in D.registeredVariables)t.push(D.registeredVariables[d])}let a=n?t.filter(d=>!d.trainable):null,r=t.length;t=t.filter(d=>d.trainable),F(t.length>0,()=>`variableGrads() expects at least one of the input variables to be trainable, but none of the ${r} variables is trainable.`);let s=!0,{value:i,grads:o}=D.gradients(e,t,null,s);F(o.some(d=>d!=null),()=>"Cannot find a connection between any variable and the result of the loss function y=f(x). Please make sure the operations that use variables are inside the function f passed to minimize()."),F(i.rank===0,()=>`The f passed in variableGrads(f) must return a scalar, but it returned a rank-${i.rank} tensor`);let l={};return t.forEach((d,u)=>{o[u]!=null&&(l[d.name]=o[u])}),a!=null&&a.forEach(d=>l[d.name]=null),{value:i,grads:l}}function za(e){return D.customGrad(e)}function Tc(e){if(e.filter(t=>t==null).length>0)throw new Error(`Cannot compute gradient of y=f(x) with respect to x. Make sure that + the f you passed encloses all operations that lead from x to y.`)}function TE(e){let t={x:M(e,"x","neg")};return D.runKernel(Mo,t)}var vt=O({neg_:TE});function EE(e){let t={x:M(e,"x","softplus")};return D.runKernel(qo,t)}var hi=O({softplus_:EE});function CE(e){let t=M(e,"x","logSigmoid");return za(n=>({value:vt(hi(vt(n))),gradFunc:a=>_(a,wn(vt(n)))}))(t)}var Vb=O({logSigmoid_:CE});function RE(e,t=null,n=!1){let a={x:M(e,"x","max")},r={reductionIndices:t,keepDims:n};return D.runKernel(Ns,a,r)}var Xn=O({max_:RE});function ME(e,t){let n=M(e,"a","sub"),a=M(t,"b","sub");[n,a]=bt(n,a);let r={a:n,b:a};return D.runKernel(Zs,r)}var ge=O({sub_:ME});function FE(e,t=null,n=!1){let a=M(e,"x","sum");a.dtype==="bool"&&(a=fe(a,"int32"));let r={x:a},s={axis:t,keepDims:n};return D.runKernel(qs,r,s)}var ke=O({sum_:FE});function $E(e,t=-1){let n=M(e,"logits","logSoftmax");if(t===-1&&(t=n.rank-1),t!==n.rank-1)throw Error(`Log Softmax along a non-last dimension is not yet supported. Logits was rank ${n.rank} and axis was ${t}`);return za((a,r)=>{let s=!0,i=Xn(a,t,!0),o=ge(a,i),l=ge(fe(o,"float32"),Fn(ke(qn(o),t,s)));return r([l]),{value:l,gradFunc:(d,u)=>{let[p]=u,c=!0,h=qn(p);return ge(d,_(ke(d,t,c),h))}}})(n)}var Ec=O({logSoftmax_:$E});function bA(e,t){for(let n=0;ne[s]);return[n,r]}function fi(e,t){let n=t.map(a=>1);return jb(e,n,t)}function DE(e,t,n){F(bA(t,n),()=>`${e} supports only inner-most axes for now. Got axes ${t} and rank-${n} input.`)}function Hb(e,t){if(bA(e,t))return null;let n=[];for(let a=0;an.push(a)),n}function vA(e){return e.map((t,n)=>[n,t]).sort((t,n)=>t[1]-n[1]).map(t=>t[0])}function OE(e,t){let n=[];for(let a=t-e;a`Error in maxPool: input must be rank 4 but got rank ${o.rank}.`),F(Oa(n,i),()=>`Error in maxPool: Either strides or dilations must be 1. Got strides ${n} and dilations '${i}'`),r!=null&&F(Vt(a),()=>`Error in maxPool: pad must be an integer when using, dimRoundingMode ${r} but got pad ${a}.`);let d={x:o},u={filterSize:t,strides:n,pad:a,dimRoundingMode:r},p=D.runKernel(Es,d,u);return l?H(p,[p.shape[1],p.shape[2],p.shape[3]]):p}var Yu=O({maxPool_:BE});function VE(e,t=[1,1,1],n,a,r,s="NDHWC"){let i=M(e,"x","maxPool3d"),o=i,l=!1;i.rank===4&&(l=!0,o=H(i,[1,i.shape[0],i.shape[1],i.shape[2],i.shape[3]])),F(o.rank===5,()=>`Error in maxPool3d: x must be rank 5 but got rank ${o.rank}.`),F(s==="NDHWC",()=>`Error in maxPool3d: Only NDHWC is currently supported, but got dataFormat of ${s}`),r!=null&&F(Vt(a),()=>`Error in maxPool3d: pad must be an integer when using, dimRoundingMode ${r} but got pad ${a}.`);let d={x:o},u={filterSize:t,strides:n,pad:a,dimRoundingMode:r,dataFormat:s},p=D.runKernel(Nu,d,u);return l?H(p,[p.shape[1],p.shape[2],p.shape[3],p.shape[4]]):p}var kA=O({maxPool3d_:VE});function jE(e,t,n,a,r=!1){let s={x:M(e,"x","maxPoolWithArgmax")},i={filterSize:t,strides:n,pad:a,includeBatchInIndex:r},o=D.runKernel(Zp,s,i);return{result:o[0],indexes:o[1]}}var qb=O({maxPoolWithArgmax_:jE});function UE(e,t){let n=M(e,"a","maximum"),a=M(t,"b","maximum");[n,a]=bt(n,a),n.dtype==="bool"&&(n=fe(n,"int32"),a=fe(a,"int32")),pt(n.shape,a.shape);let r={a:n,b:a};return D.runKernel(Ts,r)}var _a=O({maximum_:UE});function HE(e,t=null,n=!1){let a={x:M(e,"x","mean")},r={axis:t,keepDims:n};return D.runKernel(Cs,a,r)}var wt=O({mean_:HE});function Ct(e,t="float32"){if(t==="complex64"){let a=Ct(e,"float32"),r=Ct(e,"float32");return Nr(a,r)}let n=Tp(Nt(e),t);return D.makeTensor(n,e,t)}function $n(e,t="float32"){if(t==="complex64"){let a=$n(e,"float32"),r=Ct(e,"float32");return Nr(a,r)}let n=Am(Nt(e),t);return D.makeTensor(n,e,t)}function GE(e,t,{indexing:n="xy"}={}){if(n!=="xy"&&n!=="ij")throw new TypeError(`${n} is not a valid third argument to meshgrid`);if(e===void 0)return[];let a=M(e,"x","meshgrid",e instanceof Le?e.dtype:"float32");if(t===void 0)return[a];let r=M(t,"y","meshgrid",t instanceof Le?t.dtype:"float32"),s=Nt(a.shape),i=Nt(r.shape);return n==="xy"?(a=H(a,[1,-1]),r=H(r,[-1,1]),[Be($n([i,1],a.dtype),a),Be(r,$n([1,s],r.dtype))]):(a=H(a,[-1,1]),r=H(r,[1,-1]),[Be(a,$n([1,i],a.dtype)),Be($n([s,1],r.dtype),r)])}function qE(e,t=null,n=!1){let a={x:M(e,"x","min")},r={axis:t,keepDims:n};return D.runKernel(Rs,a,r)}var yl=O({min_:qE});function XE(e,t){let n=M(e,"a","minimum"),a=M(t,"b","minimum");[n,a]=bt(n,a),n.dtype==="bool"&&(n=fe(n,"int32"),a=fe(a,"int32")),pt(n.shape,a.shape);let r={a:n,b:a};return D.runKernel(Ms,r)}var gl=O({minimum_:XE});function KE(e,t,n){F(n==="reflect"||n==="symmetric",()=>`Invalid mode. Mode must be either reflect or symmetric. Got ${n}.`);let a=M(e,"x","mirrorPad");if(a.rank===0)throw new Error("mirrorPad(scalar) is not defined. Pass non-scalar to mirrorPad");F(t.length===a.rank,()=>`Padding doesn't match input. Must be ${a.rank}. Got ${t.length}.`);let r=n==="reflect"?1:0;for(let o=0;o"Invalid number of paddings. Must be length of 2 each."),F(t[o][0]>=0&&t[o][0]<=a.shape[o]-r&&t[o][1]>=0&&t[o][1]<=a.shape[o]-r,()=>`Padding in dimension ${o} cannot be greater than or equal to ${a.shape[o]-r} or less than 0 for input of shape ${a.shape}`);let s={paddings:t,mode:n},i={x:a};return D.runKernel(Fs,i,s)}var IA=O({mirrorPad_:KE});function ZE(e,t){let n=M(e,"a","mod"),a=M(t,"b","mod");[n,a]=bt(n,a);let r={a:n,b:a};return D.runKernel(Ro,r)}var SA=O({mod_:ZE});function YE(e){let t=M(e,"x","square"),n={};return D.runKernel("Square",{x:t},n)}var st=O({square_:YE});function JE(e,t=null,n=!1){e=M(e,"x","moments");let a=ra(t,e.shape),r=wt(e,a,n),s=r.shape;n||(s=fi(r.shape,a));let i=st(ge(fe(e,"float32"),H(r,s))),o=wt(i,a,n);return{mean:r,variance:o}}var Rc=O({moments_:JE});function QE(e,t,n,a){let r=M(t,"data","multiRNNCell"),s=Bu(n,"c","multiRNNCell"),i=Bu(a,"h","multiRNNCell"),o=r,l=[];for(let p=0;p2)throw new Error(`Rank of probabilities must be 1 or 2, but is ${i}`);n=n||Math.random();let o={logits:i===1?H(r,[1,-1]):r},l={numSamples:t,seed:n,normalized:a},d=D.runKernel(Yp,o,l);return i===1?H(d,[d.size]):d}var Xb=O({multinomial_:tC});function nC(e,t){let n=M(e,"a","notEqual"),a=M(t,"b","notEqual");[n,a]=bt(n,a),pt(n.shape,a.shape);let r={a:n,b:a};return D.runKernel(Fo,r)}var mi=O({notEqual_:nC});function aC(e){let t={x:M(e,"x","onesLike")};return D.runKernel(zo,t)}var Dn=O({onesLike_:aC});function rC(e,t){let n=M(e,"v1","outerProduct"),a=M(t,"v2","outerProduct");F(n.rank===1&&a.rank===1,()=>`Error in outerProduct: inputs must be rank 1, but got ranks ${n.rank} and ${a.rank}.`);let r=H(n,[-1,1]),s=H(a,[1,-1]);return Be(r,s)}var sC=O({outerProduct_:rC});function iC(e,t,n=0){let a=M(e,"x","pad");if(a.rank===0)throw new Error("pad(scalar) is not defined. Pass non-scalar to pad");let r={paddings:t,constantValue:n},s={x:a};return D.runKernel(Os,s,r)}var ar=O({pad_:iC});function oC(e,t,n=0){return F(t.length===2,()=>"Invalid number of paddings. Must be length of 2."),ar(e,[t],n)}var lC=O({pad1d_:oC});function uC(e,t,n=0){return F(t.length===2&&t[0].length===2&&t[1].length===2,()=>"Invalid number of paddings. Must be length of 2 each."),ar(e,t,n)}var dC=O({pad2d_:uC});function pC(e,t,n=0){return F(t.length===3&&t[0].length===2&&t[1].length===2&&t[2].length===2,()=>"Invalid number of paddings. Must be length of 2 each."),ar(e,t,n)}var cC=O({pad3d_:pC});function hC(e,t,n=0){return F(t.length===4&&t[0].length===2&&t[1].length===2&&t[2].length===2&&t[3].length===2,()=>"Invalid number of paddings. Must be length of 2 each."),ar(e,t,n)}var fC=O({pad4d_:hC});function mC(e,t,n){let a=M(e,"x","spaceToBatchND");F(a.rank>=1+t.length,()=>`input rank ${a.rank} should be > than [blockShape] ${t.length}`),F(n.length===t.length,()=>`paddings.shape[0] ${n.length} must be equal to [blockShape] ${t.length}`),F(a.shape.reduce((i,o,l)=>l>0&&l<=t.length?i&&(o+n[l-1][0]+n[l-1][1])%t[l-1]==0:i,!0),()=>`input spatial dimensions ${a.shape.slice(1)} with paddings ${n.toString()} must be divisible by blockShapes ${t.toString()}`);let r={x:a},s={blockShape:t,paddings:n};return D.runKernel(Cu,r,s)}var Ju=O({spaceToBatchND_:mC});function gC(e,t,n,a,r,s){r==null&&(r=[1,1]),s==null&&(s=1),a===0&&(a="valid");let i=M(e,"x","maxPool"),o=i,l=!1;i.rank===3&&(l=!0,o=H(i,[1,i.shape[0],i.shape[1],i.shape[2]])),F(Oa(s,r),()=>`Error in pool: Either strides or dilations must be 1. Got strides ${s} and dilations '${r}'`);let d=Sb(o.shape,t,s,r,a),u=[d.dilationHeight,d.dilationWidth],p;a==="same"?p=yC([d.filterHeight,d.filterWidth],u):p=[[0,0],[0,0]];let c=u[0]===1&&u[1]===1,[h,m]=AC([d.inHeight,d.inWidth],u,p),f=c?a:"valid",A=c?o:Ju(o,u,h),y=(n==="avg"?()=>Gu(A,t,s,f):()=>Yu(A,t,s,f))(),g=c?y:qu(y,u,m);return l?H(g,[g.shape[1],g.shape[2],g.shape[3]]):g}function AC(e,t,n){let a=n.map(u=>u[0]),r=n.map(u=>u[1]),s=e.concat(a,r),i=t.map((u,p)=>(u-s[p]%u)%u),o=r.map((u,p)=>u+i[p]),l=t.map((u,p)=>[a[p],o[p]]),d=t.map((u,p)=>[0,i[p]]);return[l,d]}function yC(e,t){let n=e.map((s,i)=>s+(s-1)*(t[i]-1)).map(s=>s-1),a=n.map(s=>Math.floor(s/2)),r=n.map((s,i)=>s-a[i]);return n.map((s,i)=>[a[i],r[i]])}var Kb=O({pool_:gC});function xC(e,t){let n=M(e,"base","pow"),a=M(t,"exp","pow");[n,a]=bt(n,a);let r={a:n,b:a};return D.runKernel(zs,r)}var rr=O({pow_:xC});function bC(e,t){let n=M(e,"x","prelu"),a=M(t,"alpha","prelu"),r={x:n,alpha:a};return D.runKernel(_s,r)}var Qu=O({prelu_:bC});function vC(e,t=null,n=!1){let a=M(e,"x","prod");a.dtype==="bool"&&(a=fe(a,"int32"));let r={x:a},s={axis:t,keepDims:n};return D.runKernel(Po,r,s)}var Mc=O({prod_:vC});function wC(e,t,n){let a=Nt(e),r=null;if(n==null||n==="float32")r=new Float32Array(a);else if(n==="int32")r=new Int32Array(a);else if(n==="bool")r=new Uint8Array(a);else throw new Error(`Unknown data type ${n}`);for(let s=0;s=1||s===0);let i=Math.sqrt(-2*Math.log(s)/s);e=this.mean+this.stdDev*a*i,t=this.mean+this.stdDev*r*i,(!this.truncated||this.isValidTruncated(e))&&(n=!0)}return(!this.truncated||this.isValidTruncated(t))&&(this.nextVal=this.convertValue(t)),this.convertValue(e)}convertValue(e){return this.dtype==null||this.dtype==="float32"?e:Math.round(e)}isValidTruncated(e){return e<=this.upper&&e>=this.lower}},IC=class{constructor(e,t,n,a){this.alpha=e,this.beta=1/t,this.dtype=n;let r=a||Math.random();this.randu=NA.alea(r.toString()),this.randn=new TA(0,1,n,!1,this.randu()),e<1?this.d=e+2/3:this.d=e-1/3,this.c=1/Math.sqrt(9*this.d)}nextValue(){let e,t,n,a,r,s;for(;;){do a=this.randn.nextValue(),s=1+this.c*a;while(s<=0);if(s*=s*s,e=a*a,t=1-.331*e*e,n=.5*e+this.d*(1-s+Math.log(s)),r=this.randu(),rthis.dtype==null||this.dtype==="float32",this.min=e,this.range=t-e,this.dtype=n,a==null&&(a=Math.random()),typeof a=="number"&&(a=a.toString()),!this.canReturnFloat()&&this.range<=1)throw new Error(`The difference between ${e} - ${t} <= 1 and dtype is not float`);this.random=NA.alea(a)}convertValue(e){return this.canReturnFloat()?e:Math.round(e)}nextValue(){return this.convertValue(this.min+this.range*this.random())}};function NC(e,t,n=1,a="float32",r){if(n==null&&(n=1),a==null&&(a="float32"),a!=="float32"&&a!=="int32")throw new Error(`Unsupported data type ${a}`);let s=new IC(t,n,a,r),i=We(e,a);for(let o=0;o`Error in reverse1D: x must be rank 1 but got rank ${t.rank}.`),On(t,0)}var zC=O({reverse1d_:OC});function _C(e,t){let n=M(e,"x","reverse");return F(n.rank===2,()=>`Error in reverse2D: x must be rank 2 but got rank ${n.rank}.`),On(n,t)}var PC=O({reverse2d_:_C});function LC(e,t){let n=M(e,"x","reverse");return F(n.rank===3,()=>`Error in reverse3D: x must be rank 3 but got rank ${n.rank}.`),On(n,t)}var WC=O({reverse3d_:LC});function BC(e,t){let n=M(e,"x","reverse");return F(n.rank===4,()=>`Error in reverse4D: x must be rank 4 but got rank ${n.rank}.`),On(n,t)}var VC=O({reverse4d_:BC});function jC(e){let t={x:M(e,"x","round")};return D.runKernel(Vs,t)}var $c=O({round_:jC});function UC(e){let t={x:M(e,"x","rsqrt")};return D.runKernel(js,t)}var Dc=O({rsqrt_:UC});function Se(e,t){if((tn(e)&&t!=="string"||Array.isArray(e))&&t!=="complex64")throw new Error("Error creating a new Scalar: value must be a primitive (number|boolean|string)");if(t==="string"&&tn(e)&&!(e instanceof Uint8Array))throw new Error("When making a scalar from encoded string, the value must be `Uint8Array`.");return Tr(e,[],[],t)}function HC(e){let t={x:M(e,"x","selu")};return D.runKernel(jo,t)}var Oc=O({selu_:HC});function GC(e,t,n,a,r,s=[1,1],i="NHWC"){let o=M(e,"x","separableConv2d"),l=M(t,"depthwiseFilter","separableConv2d"),d=M(n,"pointwiseFilter","separableConv2d"),u=o,p=!1;if(o.rank===3&&(p=!0,u=H(o,[1,o.shape[0],o.shape[1],o.shape[2]])),i==="NCHW")throw new Error("separableConv2d currently does not support dataFormat NCHW; only NHWC is supported");F(u.rank===4,()=>`Error in separableConv2d: input must be rank 4, but got rank ${u.rank}.`),F(l.rank===4,()=>`Error in separableConv2d: depthwise filter must be rank 4, but got rank ${l.rank}.`),F(d.rank===4,()=>`Error in separableConv2d: pointwise filter must be rank 4, but got rank ${l.rank}.`),F(d.shape[0]===1,()=>`Error in separableConv2d: the first dimension of pointwise filter must be 1, but got ${d.shape[0]}.`),F(d.shape[1]===1,()=>`Error in separableConv2d: the second dimension of pointwise filter must be 1, but got ${d.shape[1]}.`);let c=l.shape[2],h=l.shape[3];F(d.shape[2]===c*h,()=>`Error in separableConv2d: the third dimension of pointwise filter must be ${c*h}, but got ${d.shape[2]}.`);let m=hl(u,l,a,r,i,s),f=nr(m,d,1,"valid",i);return p?H(f,[f.shape[1],f.shape[2],f.shape[3]]):f}var CA=O({separableConv2d_:GC});async function qC(e,t){let n=M(e,"x","setdiff1d"),a=M(t,"y","setdiff1d");F(n.dtype===a.dtype,()=>`x and y should have the same dtype, but got x (${n.dtype}) and y (${a.dtype}).`),F(n.rank===1,()=>`x should be 1D tensor, but got x (${n.shape}).`),F(a.rank===1,()=>`y should be 1D tensor, but got y (${a.shape}).`);let r=await n.data(),s=await a.data(),i=new Set(s),o=0;for(let u=0;u`slice1d expects a rank-1 tensor, but got a rank-${a.rank} tensor`),Re(a,[t],[n])}var Pc=O({slice1d_:YC});function JC(e,t,n){let a=M(e,"x","slice2d");return F(a.rank===2,()=>`slice2d expects a rank-2 tensor, but got a rank-${a.rank} tensor`),Re(a,t,n)}var MA=O({slice2d_:JC});function QC(e,t,n){let a=M(e,"x","slice3d");return F(a.rank===3,()=>`slice3d expects a rank-3 tensor, but got a rank-${a.rank} tensor`),Re(a,t,n)}var Lc=O({slice3d_:QC});function eR(e,t,n){let a=M(e,"x","slice4d");return F(a.rank===4,()=>`slice4d expects a rank-4 tensor, but got a rank-${a.rank} tensor`),Re(a,t,n)}var td=O({slice4d_:eR});function tR(e,t=-1){let n=M(e,"logits","softmax","float32");if(t===-1&&(t=n.rank-1),t!==n.rank-1)throw Error(`Softmax along a non-last dimension is not yet supported. Logits was rank ${n.rank} and dim was ${t}`);let a={logits:n},r={dim:t};return D.runKernel(Xs,a,r)}var nd=O({softmax_:tR});function nR(e){F(e.dtype==="complex64",()=>`The dtype for tf.spectral.fft() must be complex64 but got ${e.dtype}.`);let t={input:e};return D.runKernel(jp,t)}var ad=O({fft_:nR});function aR(e){F(e.dtype==="complex64",()=>`The dtype for tf.spectral.ifft() must be complex64 but got ${e.dtype}.`);let t={input:e};return D.runKernel(Up,t)}var vl=O({ifft_:aR});function rR(e){let t=e.shape[e.shape.length-1],n=e.size/t,a;if(t<=2){let r=H(e,[n,t]);a=vl(r)}else{let r=[n,2*(t-1)],s=H(ed(e),[n,t]),i=H(Ic(e),[n,t]),o=On(Re(s,[0,1],[n,t-2]),1),l=_(On(Re(i,[0,1],[n,t-2]),1),Se(-1)),d=ot([s,o],1),u=ot([i,l],1),p=H(Nr(d,u),[r[0],r[1]]);a=vl(p)}if(a=ed(a),e.rank===3&&e.shape[0]!==0){let r=a,s=e.shape[0];a=H(a,[s,a.shape[0]/s,a.shape[1]]),r.dispose()}return a}var Wc=O({irfft_:rR});function sR(e,t,n=0){let a={x:M(e,"x","split")},r={numOrSizeSplits:t,axis:n};return D.runKernel(Xo,a,r)}var an=O({split_:sR});function iR(e,t){F(e.dtype==="float32",()=>`The dtype for rfft() must be real value but got ${e.dtype}`);let n=e.shape[e.shape.length-1],a=e.size/n,r;if(t!=null&&t0),f=e.shape.map(A=>A);f[e.shape.length-1]=t,r=Re(e,m,f),n=t}else if(t!=null&&t>n){let m=e.shape.map(f=>f);m[e.shape.length-1]=t-n,r=ot([e,Ct(m)],e.shape.length-1),n=t}else r=e;let s=Ue(r),i=H(Nr(r,s),[a,n]),o=ad(i),l=Math.floor(n/2)+1,d=ed(o),u=Ic(o),p=an(d,[l,n-l],d.shape.length-1),c=an(u,[l,n-l],u.shape.length-1),h=r.shape.slice();return h[r.shape.length-1]=l,H(Nr(p[0],c[0]),h)}var rd=O({rfft_:iR});function oR(e){let t={x:M(e,"x","sqrt")};return D.runKernel(Gs,t)}var Jt=O({sqrt_:oR});function lR(e,t){let n=M(e,"a","squaredDifference"),a=M(t,"b","squaredDifference");[n,a]=bt(n,a),pt(n.shape,a.shape);let r={a:n,b:a},s={};return D.runKernel(Ks,r,s)}var Bc=O({squaredDifference_:lR});function uR(e,t){let n=M(e,"x","squeeze");return H(n,gx(n.shape,t).newShape)}var Or=O({squeeze_:uR});function dR(e,t=0){let n=Bu(e,"tensors","stack","string_or_numeric");F(n.length>=1,()=>"Pass at least one tensor to tf.stack"),n.length>0&&F(t<=n[0].rank,()=>"Axis must be <= rank of the tensor");let a=n,r={axis:t};return D.runKernel(_o,a,r)}var zn=O({stack_:dR});function pR(e,t=0){let n={x:M(e,"x","step")},a={alpha:t};return D.runKernel(Sr,n,a)}var wl=O({step_:pR});function cR(e,t,n,a,r=0,s=0,i=0,o=0,l=0){let d={x:M(e,"x","stridedSlice")},u={begin:t,end:n,strides:a,beginMask:r,endMask:s,ellipsisMask:i,newAxisMask:o,shrinkAxisMask:l};return D.runKernel(Ko,d,u)}var FA=O({stridedSlice_:cR});function hR(e){let t={x:M(e,"x","tan")};return D.runKernel(Ys,t)}var $A=O({tan_:hR});function Tt(e,t){rs(e);let n=$a(e,t);if(n.length!==1)throw new Error("tensor1d() requires values to be a flat/TypedArray");return Tr(e,null,n,t)}function ya(e,t,n){if(rs(e),t!=null&&t.length!==2)throw new Error("tensor2d() requires shape to have two numbers");let a=$a(e,n);if(a.length!==2&&a.length!==1)throw new Error("tensor2d() requires values to be number[][] or flat/TypedArray");if(a.length===1&&t==null)throw new Error("tensor2d() requires shape to be provided when `values` are a flat/TypedArray");return Tr(e,t,a,n)}function fR(e,t,n){if(rs(e),t!=null&&t.length!==4)throw new Error("tensor4d() requires shape to have four numbers");let a=$a(e,n);if(a.length!==4&&a.length!==1)throw new Error("tensor4d() requires values to be number[][][][] or flat/TypedArray");if(a.length===1&&t==null)throw new Error("tensor4d() requires shape to be provided when `values` are a flat array");return Tr(e,t,a,n)}function mR(e,t,n){if(rs(e),t!=null&&t.length!==5)throw new Error("tensor5d() requires shape to have five numbers");let a=$a(e,n);if(a.length!==5&&a.length!==1)throw new Error("tensor5d() requires values to be number[][][][][] or flat/TypedArray");if(a.length===1&&t==null)throw new Error("tensor5d() requires shape to be provided when `values` are a flat array");return Tr(e,t,a,n)}function AR(e,t,n){if(rs(e),t!=null&&t.length!==6)throw new Error("tensor6d() requires shape to have six numbers");let a=$a(e,n);if(a.length!==6&&a.length!==1)throw new Error("tensor6d() requires values to be number[][][][][][] or flat/TypedArray");if(a.length===1&&t==null)throw new Error("tensor6d() requires shape to be provided when `values` are a flat array");return t=t||a,Tr(e,t,a,n)}function yR(e,t=1,n=!0){let a=M(e,"x","topk");if(a.rank===0)throw new Error("topk() expects the input to be of rank 1 or higher");let r=a.shape[a.shape.length-1];if(t>r)throw new Error(`'k' passed to topk() must be <= the last dimension (${r}) but got ${t}`);let s={x:a},i={k:t,sorted:n},[o,l]=D.runKernel(Zo,s,i);return{values:o,indices:l}}var DA=O({topk_:yR});function gR(e,t=0,n=1,a,r){if(a!=null&&a==="bool")throw new Error("Unsupported data type $ { dtype }");let s=new TA(t,n,a,!0,r),i=We(e,a);for(let o=0;o0,()=>"The input tensor must be at least 1D");let a={x:n},r={axis:t},[s,i]=D.runKernel(rc,a,r);return{values:s,indices:i}}var jc=O({unique_:xR});function bR(e,t,n){let a=M(e,"x","unsortedSegmentSum"),r=M(t,"segmentIds","unsortedSegmentSum","int32");F(Vt(n),()=>"numSegments must be of dtype int");let s={x:a,segmentIds:r},i={numSegments:n};return D.runKernel(Mu,s,i)}var OA=O({unsortedSegmentSum_:bR});function vR(e,t=0){let n=M(e,"x","unstack","string_or_numeric");F(t>=-n.shape.length&&t`Axis = ${t} is not in [-${n.shape.length}, ${n.shape.length})`);let a={value:n},r={axis:t};return D.runKernel(Jo,a,r)}var la=O({unstack_:vR});function Jb(e,t=!0,n,a){return D.makeVariable(e,t,n,a)}function Qb(e,t){let n=[];for(let s=0;s0,()=>"mask cannot be scalar"),sn(o.slice(s,s+i),r.shape,"mask's shape must match the first K dimensions of tensor's shape,");let l=1;for(let f=s;f"Shape mismatch in v and x");let l=Se(1),d=ge(l,o),u=_(ge(i,s),d);if(r){F(a!=null,()=>"When using zeroDebias: true, step is required.");let p=M(a,"step","movingAverage");u=me(u,ge(l,rr(o,p)))}return se(s,u)}var TR=O({movingAverage_:NR});function ER(e,t,n){let a=M(e,"indices","scatterND","int32"),r=M(t,"updates","scatterND");Hm(r,a,n);let s={indices:a,updates:r},i={shape:n};return D.runKernel(Bo,s,i)}var t3=O({scatterND_:ER});function CR(e,t,n,a){if(e.dtype!=="int32")throw new Error(`tf.sparseToDense() expects the indices to be int32 type, but the dtype was ${e.dtype}.`);if(e.rank>2)throw new Error(`sparseIndices should be a scalar, vector, or matrix, but got shape ${e.shape}.`);let r=e.rank>0?e.shape[0]:1,s=e.rank>1?e.shape[1]:1;if(n.length!==s)throw new Error(`outputShape has incorrect number of elements:, ${n.length}, should be: ${s}.`);let i=t.size;if(!(t.rank===0||t.rank===1&&i===r))throw new Error(`sparseValues has incorrect shape ${t.shape}, should be [] or [${r}]`);if(t.dtype!==a.dtype)throw new Error("sparseValues.dtype must match defaultValues.dtype")}function RR(e,t,n,a=0){let r=M(e,"sparseIndices","sparseToDense","int32"),s=M(t,"sparseValues","sparseToDense"),i=M(a,"defaultValue","sparseToDense",s.dtype);CR(r,s,n,i);let o={sparseIndices:r,sparseValues:s,defaultValue:i},l={outputShape:n};return D.runKernel(ac,o,l)}var _A=O({sparseToDense_:RR});function MR(e,t){let n=M(t,"indices","gatherND","int32"),a={params:M(e,"x","gatherND"),indices:n};return D.runKernel(vo,a)}var n3=O({gatherND_:MR});function FR(e,t){if(t==null)return e.shape.slice();if(Qa(e.shape,t))return t;if(e.shape.length===t.length){let n=[];for(let a=0;a`x has to be a floating point tensor since it's going to be scaled, but got a ${r.dtype} tensor instead.`),F(t>=0&&t<1,()=>`rate must be a float in the range [0, 1), but got ${t}.`),t===0)return e instanceof Le?r.clone():r;let s=FR(r,n),i=1-t,o=me(Al(se(xl(s,0,1,"float32",a),i)),i);return _(r,o)}var a3=O({dropout_:$R});function r3(e){return Math.floor(Math.pow(2,Math.ceil(Math.log(e)/Math.log(2))))}function PA(e,t,n){let a=1-e%2,r=new Float32Array(e);for(let s=0;s1,()=>`inTopK() expects the predictions to be of rank 2 or higher, but got ${a.rank}`),F(a.rank-1===r.rank,()=>`predictions rank should be 1 larger than targets rank, but got predictions rank ${a.rank} and targets rank ${r.rank}`),sn(a.shape.slice(0,a.shape.length-1),r.shape,"predictions's shape should be align with the targets' shape, except the last dimension.");let s=a.shape[a.shape.length-1];F(n>0&&n<=s,()=>`'k' passed to inTopK() must be > 0 && <= the predictions last dimension (${s}), but got ${n}`);let i=await a.data(),o=await r.data(),[l,d]=[i.length/s,s],u=xx("bool",l);for(let p=0;pA.value-f.value),u[p]=0;for(let f=0;fzR,depthwiseConv2d:()=>_R,matMul:()=>PR});function LR(e,t,n,a,r,s="NHWC",i){let o=e;e.rank===3&&(o=H(e,[1,e.shape[0],e.shape[1],e.shape[2]]));let l=t;l.rank===3&&(l=H(t,[1,t.shape[0],t.shape[1],t.shape[2]])),F(o.rank===4,()=>`Error in conv2dDerFilter: input must be rank 4, but got shape ${o.shape}.`),F(l.rank===4,()=>`Error in conv2dDerFilter: dy must be rank 4, but got shape ${l.shape}.`),F(n.length===4,()=>`Error in conv2dDerFilter: filterShape must be length 4, but got ${n}.`);let d=s==="NHWC"?o.shape[3]:o.shape[1],u=s==="NHWC"?l.shape[3]:l.shape[1];F(d===n[2],()=>`Error in conv2dDerFilter: depth of input ${d}) must match input depth in filter (${n[2]}.`),F(u===n[3],()=>`Error in conv2dDerFilter: depth of dy (${u}) must match output depth for filter (${n[3]}).`),i!=null&&F(Vt(r),()=>`Error in conv2dDerFilter: pad must be an integer when using, dimRoundingMode ${i} but got pad ${r}.`);let p={x:o,dy:l},c={strides:a,pad:r,dataFormat:s,dimRoundingMode:i,filterShape:n};return D.runKernel(Fp,p,c)}var LA=O({conv2DBackpropFilter_:LR});function Hc(e,t,n){if(n==null||n==="linear")return e;if(n==="relu")return _(e,wl(t));throw new Error(`Cannot compute gradient for fused activation ${n}.`)}function Gc(e,t){let n=t,a=zt(e.shape,t.shape);return a.length>0&&(n=ke(n,a)),H(n,e.shape)}function qc(e,t,n,a){if(t==="linear")return e;if(t==="relu")return Pa(e);if(t==="elu")return fl(e);if(t==="relu6")return Fc(e);if(t==="prelu")return Qu(e,n);if(t==="leakyrelu")return Ku(e,a);if(t==="sigmoid")return wn(e);throw new Error(`Unknown fused activation ${t}.`)}var Xc=(e,t)=>!(e>0)||t==="linear";function WR({x:e,filter:t,strides:n,pad:a,dataFormat:r="NHWC",dilations:s=[1,1],dimRoundingMode:i,bias:o,activation:l="linear",preluActivationWeights:d,leakyreluAlpha:u}){if(l=l||"linear",Xc(D.state.gradientDepth,l)===!1){let b=nr(e,t,n,a,r,s,i);return o!=null&&(b=se(b,o)),qc(b,l,d,u)}let p=M(e,"x","conv2d"),c=M(t,"filter","conv2d"),h=p,m=!1;p.rank===3&&(m=!0,h=H(p,[1,p.shape[0],p.shape[1],p.shape[2]])),F(h.rank===4,()=>`Error in fused conv2d: input must be rank 4, but got rank ${h.rank}.`),F(c.rank===4,()=>`Error in fused conv2d: filter must be rank 4, but got rank ${c.rank}.`),i!=null&&F(Vt(a),()=>`Error in fused conv2d: pad must be an integer when using, dimRoundingMode ${i} but got pad ${a}.`),F(h.shape[3]===c.shape[2],()=>`Error in conv2d: depth of input (${h.shape[3]}) must match input depth for filter ${c.shape[2]}.`),F(Oa(n,s),()=>`Error in conv2D: Either strides or dilations must be 1. Got strides ${n} and dilations '${s}'`),F(r==="NHWC",()=>`Error in conv2d: got dataFormat of ${r} but only NHWC is currently supported.`);let f=Hu(h.shape,c.shape,n,s,a,i),A;o!=null&&(A=M(o,"bias","fused conv2d"),[A]=bt(A,p),pt(f.outShape,A.shape));let y;d!=null&&(y=M(d,"prelu weights","fused conv2d"));let g=(b,v)=>{let[N,T,R,$]=v,z=Hc(b,R,l);F(Rr(s),()=>`Error in gradient of fused conv2D: dilation rates greater than 1 are not yet supported in gradients. Got dilations '${s}'`);let P=dA(T.shape,z,N,n,a),V=LA(T,z,N.shape,n,a),j=[P,V];if($!=null){let U=Gc($,z);j.push(U)}return j},x={x:h,filter:c,bias:A,preluActivationWeights:y},w={strides:n,pad:a,dataFormat:r,dilations:s,dimRoundingMode:i,activation:l,leakyreluAlpha:u};return o==null?za((b,v,N)=>{let T=D.runKernel(ti,x,w);return N([v,b,T]),m&&(T=H(T,[T.shape[1],T.shape[2],T.shape[3]])),{value:T,gradFunc:g}})(h,c):za((b,v,N,T)=>{let R=D.runKernel(ti,x,w);return T([v,b,R,N]),m&&(R=H(R,[R.shape[1],R.shape[2],R.shape[3]])),{value:R,gradFunc:g}})(h,c,A)}var zR=O({fusedConv2d_:WR});function BR(e,t,n,a,r,s=[1,1],i){let o=e;e.rank===3&&(o=H(e,[1,e.shape[0],e.shape[1],e.shape[2]]));let l=t;l.rank===3&&(l=H(t,[1,t.shape[0],t.shape[1],t.shape[2]]));let d={x:o,dy:l},u={strides:a,pad:r,dimRoundingMode:i,dilations:s,filterShape:n};return D.runKernel(zp,d,u)}var s3=O({depthwiseConv2dNativeBackpropFilter_:BR});function VR(e,t,n,a,r,s=[1,1],i){let o=t,l=!1;t.rank===3&&(l=!0,o=H(t,[1,t.shape[0],t.shape[1],t.shape[2]]));let d={dy:o,filter:n},u={strides:a,pad:r,dimRoundingMode:i,dilations:s,inputShape:e},p=D.runKernel(_p,d,u);return l?H(p,[p.shape[1],p.shape[2],p.shape[3]]):p}var i3=O({depthwiseConv2dNativeBackpropInput_:VR});function jR({x:e,filter:t,strides:n,pad:a,dataFormat:r="NHWC",dilations:s=[1,1],dimRoundingMode:i,bias:o,activation:l="linear",preluActivationWeights:d,leakyreluAlpha:u}){if(Xc(D.state.gradientDepth,l)===!1){let b=hl(e,t,n,a,r,s,i);return o!=null&&(b=se(b,o)),qc(b,l,d,u)}let p=M(e,"x","depthwiseConv2d"),c=M(t,"filter","depthwiseConv2d"),h=p,m=!1;p.rank===3&&(m=!0,h=H(p,[1,p.shape[0],p.shape[1],p.shape[2]])),F(h.rank===4,()=>`Error in fused depthwiseConv2d: input must be rank 4, but got rank ${h.rank}.`),F(c.rank===4,()=>`Error in fused depthwiseConv2d: filter must be rank 4, but got rank ${c.rank}.`),F(h.shape[3]===c.shape[2],()=>`Error in fused depthwiseConv2d: number of input channels (${h.shape[3]}) must match the inChannels dimension in filter ${c.shape[2]}.`),s==null&&(s=[1,1]),F(Oa(n,s),()=>`Error in fused depthwiseConv2d: Either strides or dilations must be 1. Got strides ${n} and dilations '${s}'`),i!=null&&F(Vt(a),()=>`Error in fused depthwiseConv2d: pad must be an integer when using dimRoundingMode ${i} but got pad ${a}.`);let f=Hu(h.shape,c.shape,n,s,a,i,!0),A;o!=null&&(A=M(o,"bias","fused conv2d"),[A]=bt(A,p),pt(f.outShape,A.shape));let y;d!=null&&(y=M(d,"prelu weights","fused depthwiseConv2d"));let g=(b,v)=>{F(Rr(s),()=>`Error in gradient of fused depthwiseConv2d: dilation rates greater than 1 are not yet supported. Got dilations '${s}'`);let[N,T,R,$]=v,z=Hc(b,R,l),P=i3(T.shape,z,N,n,a,s,i),V=s3(T,z,N.shape,n,a,s,i);if($!=null){let j=Gc(A,z);return[P,V,j]}return[P,V]},x={x:h,filter:c,bias:A,preluActivationWeights:y},w={strides:n,pad:a,dataFormat:r,dilations:s,dimRoundingMode:i,activation:l,leakyreluAlpha:u};return o==null?za((b,v,N)=>{let T=D.runKernel(ni,x,w);return N([v,b,T]),m&&(T=H(T,[T.shape[1],T.shape[2],T.shape[3]])),{value:T,gradFunc:g}})(h,c):za((b,v,N,T)=>{let R=D.runKernel(ni,x,w);return T([v,b,R,N]),m&&(R=H(R,[R.shape[1],R.shape[2],R.shape[3]])),{value:R,gradFunc:g}})(h,c,A)}var _R=O({fusedDepthwiseConv2d_:jR});function UR({a:e,b:t,transposeA:n=!1,transposeB:a=!1,bias:r,activation:s="linear",preluActivationWeights:i,leakyreluAlpha:o}){if(Xc(D.state.gradientDepth,s)===!1){let $=Be(e,t,n,a);return r!=null&&($=se($,r)),qc($,s,i,o)}let l=M(e,"a","fused matMul"),d=M(t,"b","fused matMul");[l,d]=bt(l,d);let u=n?l.shape[l.rank-2]:l.shape[l.rank-1],p=a?d.shape[d.rank-1]:d.shape[d.rank-2],c=n?l.shape[l.rank-1]:l.shape[l.rank-2],h=a?d.shape[d.rank-2]:d.shape[d.rank-1],m=l.shape.slice(0,-2),f=d.shape.slice(0,-2),A=Nt(m),y=Nt(f);F(l.rank>=2&&d.rank>=2&&l.rank===d.rank,()=>`Error in fused matMul: inputs must have the same rank of at least 2, got ranks ${l.rank} and ${d.rank}.`),F(Qa(m,f),()=>`Error in fused matMul: outer dimensions (${m}) and (${f}) of Tensors with shapes ${l.shape} and ${d.shape} must match.`),F(u===p,()=>`Error in fused matMul: inner shapes (${u}) and (${p}) of Tensors with shapes ${l.shape} and ${d.shape} and transposeA=${n} and transposeB=${a} must match.`);let g=l.shape.slice(0,-2).concat([c,h]),x=n?H(l,[A,u,c]):H(l,[A,c,u]),w=a?H(d,[y,h,p]):H(d,[y,p,h]),b;r!=null&&(b=M(r,"bias","fused matMul"),[b]=bt(b,l),pt(g,b.shape));let v;i!=null&&(v=M(i,"prelu weights","fused matMul"));let N=($,z)=>{let[P,V,j,U]=z,X=Hc(H($,j.shape),j,s),G,ee;if(!n&&!a?(G=Be(X,V,!1,!0),ee=Be(P,X,!0,!1)):!n&&a?(G=Be(X,V,!1,!1),ee=Be(X,P,!0,!1)):n&&!a?(G=Be(V,X,!1,!0),ee=Be(P,X,!1,!1)):(G=Be(V,X,!0,!0),ee=Be(X,P,!0,!0)),r!=null){let Y=Gc(U,X);return[G,ee,Y]}else return[G,ee]},T={a:x,b:w,bias:b,preluActivationWeights:v},R={transposeA:n,transposeB:a,activation:s,leakyreluAlpha:o};return r==null?za(($,z,P)=>{let V=D.runKernel(ei,T,R);return P([$,z,V]),{value:H(V,g),gradFunc:N}})(x,w):za(($,z,P,V)=>{let j=D.runKernel(ei,T,R);return V([$,z,j,P]),{value:H(j,g),gradFunc:N}})(x,w,b)}var PR=O({fusedMatMul_:UR});function HR(e){return PA(e,.54,.46)}var GR=O({hammingWindow_:HR});function qR(e){return PA(e,.5,.5)}var o3=O({hannWindow_:qR});function XR(e,t,n,a=!1,r=0){let s=0,i=[];for(;s+t<=e.size;)i.push(Re(e,s,t)),s+=n;if(a)for(;s`Error in cropAndResize: image must be rank 4,but got rank ${i.rank}.`),F(o.rank===2&&o.shape[1]===4,()=>`Error in cropAndResize: boxes must be have size [${d},4] but had shape ${o.shape}.`),F(l.rank===1&&l.shape[0]===d,()=>`Error in cropAndResize: boxInd must be have size [${d}] but had shape ${o.shape}.`),F(a.length===2,()=>`Error in cropAndResize: cropSize must be of length 2, but got length ${a.length}.`),F(a[0]>=1&&a[1]>=1,()=>`cropSize must be atleast [1,1], but was ${a}`),F(r==="bilinear"||r==="nearest",()=>`method must be bilinear or nearest, but was ${r}`);let u={image:i,boxes:o,boxInd:l},p={method:r,extrapolationValue:s,cropSize:a};return D.runKernel(co,u,p)}var JR=O({cropAndResize_:YR});function QR(e){let t=M(e,"image","flipLeftRight","float32");F(t.rank===4,()=>`Error in flipLeftRight: image must be rank 4,but got rank ${t.rank}.`);let n={image:t};return D.runKernel(xo,n,{})}var eM=O({flipLeftRight_:QR});function tM(e,t,n=0,a=.5){let r=M(e,"image","rotateWithOffset","float32");F(r.rank===4,()=>`Error in rotateWithOffset: image must be rank 4,but got rank ${r.rank}.`);let s={image:r},i={radians:t,fillValue:n,center:a};return D.runKernel(el,s,i)}var nM=O({rotateWithOffset_:tM});function kl(e,t,n,a,r,s){a==null&&(a=.5),r==null&&(r=Number.NEGATIVE_INFINITY),s==null&&(s=0);let i=e.shape[0];return n=Math.min(n,i),F(0<=a&&a<=1,()=>`iouThreshold must be in [0, 1], but was '${a}'`),F(e.rank===2,()=>`boxes must be a 2D tensor, but was of rank '${e.rank}'`),F(e.shape[1]===4,()=>`boxes must have 4 columns, but 2nd dimension was ${e.shape[1]}`),F(t.rank===1,()=>"scores must be a 1D tensor"),F(t.shape[0]===i,()=>`scores has incompatible shape with boxes. Expected ${i}, but was ${t.shape[0]}`),F(0<=s&&s<=1,()=>`softNmsSigma must be in [0, 1], but was '${s}'`),{maxOutputSize:n,iouThreshold:a,scoreThreshold:r,softNmsSigma:s}}function aM(e,t,n,a=.5,r=Number.NEGATIVE_INFINITY){let s=M(e,"boxes","nonMaxSuppression"),i=M(t,"scores","nonMaxSuppression"),o=kl(s,i,n,a,r);n=o.maxOutputSize,a=o.iouThreshold,r=o.scoreThreshold;let l={maxOutputSize:n,iouThreshold:a,scoreThreshold:r};return D.runKernel($o,{boxes:s,scores:i},l)}var rM=O({nonMaxSuppression_:aM});function iM(e,t,n){let a=sM(e,t,n),r=a<0?-(a+1):a;e.splice(r,0,t)}function sM(e,t,n){return lM(e,t,n||oM)}function oM(e,t){return e>t?1:e>>1);let o=n(t,e[s]);o>0?a=s+1:(r=s,i=!o)}return i?a:-a-1}function u3(e,t,n,a,r){return WA(e,t,n,a,r,0)}function d3(e,t,n,a,r,s){return WA(e,t,n,a,r,0,!1,s,!0)}function p3(e,t,n,a,r,s){return WA(e,t,n,a,r,s,!0)}function WA(e,t,n,a,r,s,i=!1,o=!1,l=!1){let d=[];for(let A=0;Ar&&d.push({score:t[A],boxIndex:A,suppressBeginIndex:0});d.sort(c3);let u=s>0?-.5/s:0,p=[],c=[];for(;p.length0;){let A=d.pop(),{score:y,boxIndex:g,suppressBeginIndex:x}=A;if(y=x;--b){let v=uM(e,g,p[b]);if(v>=a){w=!0;break}if(A.score=A.score*dM(a,u,v),A.score<=r)break}A.suppressBeginIndex=p.length,w||(A.score===y?(p.push(g),c.push(A.score)):A.score>r&&iM(d,A,c3))}let h=p.length,m=n-h;o&&m>0&&(p.push(...new Array(m).fill(0)),c.push(...new Array(m).fill(0)));let f={selectedIndices:p};return i&&(f.selectedScores=c),l&&(f.validOutputs=h),f}function uM(e,t,n){let a=e.subarray(t*4,t*4+4),r=e.subarray(n*4,n*4+4),s=Math.min(a[0],a[2]),i=Math.min(a[1],a[3]),o=Math.max(a[0],a[2]),l=Math.max(a[1],a[3]),d=Math.min(r[0],r[2]),u=Math.min(r[1],r[3]),p=Math.max(r[0],r[2]),c=Math.max(r[1],r[3]),h=(o-s)*(l-i),m=(p-d)*(c-u);if(h<=0||m<=0)return 0;let f=Math.max(s,d),A=Math.max(i,u),y=Math.min(o,p),g=Math.min(l,c),x=Math.max(y-f,0)*Math.max(g-A,0);return x/(h+m-x)}function dM(e,t,n){let a=Math.exp(t*n*n);return n<=e?a:0}function c3(e,t){return e.score-t.score||e.score===t.score&&t.boxIndex-e.boxIndex}async function pM(e,t,n,a=.5,r=Number.NEGATIVE_INFINITY){let s=M(e,"boxes","nonMaxSuppressionAsync"),i=M(t,"scores","nonMaxSuppressionAsync"),o=kl(s,i,n,a,r);n=o.maxOutputSize,a=o.iouThreshold,r=o.scoreThreshold;let l=await Promise.all([s.data(),i.data()]),d=l[0],u=l[1],{selectedIndices:p}=u3(d,u,n,a,r);return s!==e&&s.dispose(),i!==t&&i.dispose(),Tt(p,"int32")}var cM=pM;function hM(e,t,n,a=.5,r=Number.NEGATIVE_INFINITY,s=0){let i=M(e,"boxes","nonMaxSuppression"),o=M(t,"scores","nonMaxSuppression"),l=kl(i,o,n,a,r,s);n=l.maxOutputSize,a=l.iouThreshold,r=l.scoreThreshold,s=l.softNmsSigma;let d={boxes:i,scores:o},u={maxOutputSize:n,iouThreshold:a,scoreThreshold:r,softNmsSigma:s},p=D.runKernel(Oo,d,u);return{selectedIndices:p[0],selectedScores:p[1]}}var fM=O({nonMaxSuppressionWithScore_:hM});async function mM(e,t,n,a=.5,r=Number.NEGATIVE_INFINITY,s=0){let i=M(e,"boxes","nonMaxSuppressionAsync"),o=M(t,"scores","nonMaxSuppressionAsync"),l=kl(i,o,n,a,r,s);n=l.maxOutputSize,a=l.iouThreshold,r=l.scoreThreshold,s=l.softNmsSigma;let d=await Promise.all([i.data(),o.data()]),u=d[0],p=d[1],{selectedIndices:c,selectedScores:h}=p3(u,p,n,a,r,s);return i!==e&&i.dispose(),o!==t&&o.dispose(),{selectedIndices:Tt(c,"int32"),selectedScores:Tt(h)}}var AM=mM;function yM(e,t,n,a=.5,r=Number.NEGATIVE_INFINITY,s=!1){let i=M(e,"boxes","nonMaxSuppression"),o=M(t,"scores","nonMaxSuppression"),l=kl(i,o,n,a,r,null),d=l.maxOutputSize,u=l.iouThreshold,p=l.scoreThreshold,c={boxes:i,scores:o},h={maxOutputSize:d,iouThreshold:u,scoreThreshold:p,padToMaxOutputSize:s},m=D.runKernel(Do,c,h);return{selectedIndices:m[0],validOutputs:m[1]}}var gM=O({nonMaxSuppressionPadded_:yM});async function xM(e,t,n,a=.5,r=Number.NEGATIVE_INFINITY,s=!1){let i=M(e,"boxes","nonMaxSuppressionAsync"),o=M(t,"scores","nonMaxSuppressionAsync"),l=kl(i,o,n,a,r,null),d=l.maxOutputSize,u=l.iouThreshold,p=l.scoreThreshold,[c,h]=await Promise.all([i.data(),o.data()]),{selectedIndices:m,validOutputs:f}=d3(c,h,d,u,p,s);return i!==e&&i.dispose(),o!==t&&o.dispose(),{selectedIndices:Tt(m,"int32"),validOutputs:Se(f,"int32")}}var bM=xM;function vM(e,t,n=!1,a=!1){let r=M(e,"images","resizeBilinear");F(r.rank===3||r.rank===4,()=>`Error in resizeBilinear: x must be rank 3 or 4, but got rank ${r.rank}.`),F(t.length===2,()=>`Error in resizeBilinear: new shape must 2D, but got shape ${t}.`),F(a===!1||n===!1,()=>"Error in resizeBilinear: If halfPixelCenters is true, alignCorners must be false.");let s=r,i=!1;r.rank===3&&(i=!0,s=H(r,[1,r.shape[0],r.shape[1],r.shape[2]]));let[]=t,o={images:s},l={alignCorners:n,halfPixelCenters:a,size:t},d=D.runKernel(Ls,o,l);return i?H(d,[d.shape[1],d.shape[2],d.shape[3]]):d}var h3=O({resizeBilinear_:vM});function wM(e,t,n=!1,a=!1){let r=M(e,"images","resizeNearestNeighbor");F(r.rank===3||r.rank===4,()=>`Error in resizeNearestNeighbor: x must be rank 3 or 4, but got rank ${r.rank}.`),F(t.length===2,()=>`Error in resizeNearestNeighbor: new shape must 2D, but got shape ${t}.`),F(r.dtype==="float32"||r.dtype==="int32",()=>"`images` must have `int32` or `float32` as dtype"),F(a===!1||n===!1,()=>"Error in resizeNearestNeighbor: If halfPixelCenters is true, alignCorners must be false.");let s=r,i=!1;r.rank===3&&(i=!0,s=H(r,[1,r.shape[0],r.shape[1],r.shape[2]]));let[]=t,o={images:s},l={alignCorners:n,halfPixelCenters:a,size:t},d=D.runKernel(Eu,o,l);return i?H(d,[d.shape[1],d.shape[2],d.shape[3]]):d}var f3=O({resizeNearestNeighbor_:wM});function IM(e,t="binary",n=!1,a=.5){let r=M(e,"image","threshold"),s=.2989,i=.587,o=.114,l=r.shape[0]*r.shape[1],d=_(Tt([a]),255),u,p,c,h;if(F(r.rank===3,()=>`Error in threshold: image must be rank 3,but got rank ${r.rank}.`),F(r.shape[2]===3||r.shape[2]===1,()=>`Error in threshold: image color channel must be equal to 3 or 1but got ${r.shape[2]}.`),F(r.dtype==="int32"||r.dtype==="float32",()=>`Error in dtype: image dtype must be int32 or float32,but got dtype ${r.dtype}.`),F(t==="otsu"||t==="binary",()=>`Method must be binary or otsu, but was ${t}`),r.shape[2]===3){[u,p,c]=an(r,[1,1,1],-1);let f=_(u,s),A=_(p,i),y=_(c,o);h=se(se(f,A),y)}else h=e;if(t==="otsu"){let f=lA(fe($c(h),"int32"),ia([]),256);d=kM(f,l)}let m=n?Dr(h,d):Mn(h,d);return fe(_(m,255),"int32")}function kM(e,t){let n=Tt([-1]),a=Tt([0]),r=Tt([0]),s,i,o,l,d,u;for(let p=0;p`Error in transform: image must be rank 4,but got rank ${i.rank}.`),F(o.rank===2&&(o.shape[0]===i.shape[0]||o.shape[0]===1)&&o.shape[1]===8,()=>"Error in transform: Input transform should be batch x 8 or 1 x 8"),F(s==null||s.length===2,()=>`Error in transform: outputShape must be [height, width] or null, but got ${s}.`);let l={image:i,transforms:o},d={interpolation:n,fillMode:a,fillValue:r,outputShape:s};return D.runKernel(Yo,l,d)}var TM=O({transform_:NM});function EM(e,t,n){F(t%1==0,()=>`bandPart(): numLower must be an integer, got ${t}.`),F(n%1==0,()=>`bandPart(): numUpper must be an integer, got ${n}.`);let a=M(e,"a","bandPart");F(a.rank>=2,()=>`bandPart(): Rank must be at least 2, got ${a.rank}.`);let r=a.shape,[s,i]=a.shape.slice(-2);if(!(t<=s))throw new Error(`bandPart(): numLower (${t}) must not be greater than the number of rows (${s}).`);if(!(n<=i))throw new Error(`bandPart(): numUpper (${n}) must not be greater than the number of columns (${i}).`);t<0&&(t=s),n<0&&(n=i);let o=H(bl(0,s,1,"int32"),[-1,1]),l=bl(0,i,1,"int32"),d=ge(o,l),u=oa(Dr(d,Se(+t,"int32")),$r(d,Se(-n,"int32"))),p=Ct([s,i],a.dtype);return H(zn(la(H(a,[-1,s,i])).map(c=>nn(u,c,p))),r)}var CM=O({bandPart_:EM});function RM(e){let t;if(Array.isArray(e)){t=!1,F(e!=null&&e.length>0,()=>"Gram-Schmidt process: input must not be null, undefined, or empty");let r=e[0].shape[0];for(let s=1;s`Gram-Schmidt: Non-unique lengths found in the input vectors: (${e[s].shape[0]} vs. ${r})`)}else t=!0,e=an(e,e.shape[0],0).map(r=>Or(r,[0]));F(e.length<=e[0].shape[0],()=>`Gram-Schmidt: Number of vectors (${e.length}) exceeds number of dimensions (${e[0].shape[0]}).`);let n=[],a=e;for(let r=0;r{let s=a[r];if(r>0)for(let i=0;i=2,()=>`qr() requires input tensor to have a rank >= 2, but got rank ${e.rank}`),e.rank===2)return m3(e,t);{let n=e.shape.slice(0,e.shape.length-2).reduce((l,d)=>l*d),a=la(H(e,[n,e.shape[e.shape.length-2],e.shape[e.shape.length-1]]),0),r=[],s=[];a.forEach(l=>{let[d,u]=m3(l,t);r.push(d),s.push(u)});let i=H(zn(r,0),e.shape),o=H(zn(s,0),e.shape);return[i,o]}}function m3(e,t=!1){return D.tidy(()=>{F(e.shape.length===2,()=>`qr2d() requires a 2D Tensor, but got a ${e.shape.length}D Tensor.`);let n=e.shape[0],a=e.shape[1],r=yA(n),s=Da(e),i=ya([[1]],[1,1]),o=Da(i),l=n>=a?a:n;for(let d=0;d{let h=Re(s,[d,d],[n-d,1]),m=Uc(h),f=Re(s,[d,d],[1,1]),A=nn(Mn(f,0),ya([[-1]]),ya([[1]])),y=ge(f,_(A,m)),g=me(h,y);g.shape[0]===1?o=Da(i):o=ot([i,Re(g,[1,0],[g.shape[0]-1,g.shape[1]])],0);let x=vt(me(Be(A,y),m)),w=Re(s,[d,0],[n-d,a]),b=_(x,o),v=Ze(o);if(d===0)s=ge(w,Be(b,Be(v,w)));else{let R=ge(w,Be(b,Be(v,w)));s=ot([Re(s,[0,0],[d,a]),R],0)}let N=Ze(b),T=Re(r,[0,d],[n,r.shape[1]-d]);if(d===0)r=ge(T,Be(Be(T,o),N));else{let R=ge(T,Be(Be(T,o),N));r=ot([Re(r,[0,0],[n,d]),R],1)}return[o,s,r]}),Ee([u,p,c])}return!t&&n>a&&(r=Re(r,[0,0],[n,a]),s=Re(s,[0,0],[a,a])),[r,s]})}var $M=O({qr_:FM}),un;(function(e){e[e.NONE=0]="NONE",e[e.MEAN=1]="MEAN",e[e.SUM=2]="SUM",e[e.SUM_BY_NONZERO_WEIGHTS=3]="SUM_BY_NONZERO_WEIGHTS"})(un||(un={}));function DM(e,t,n=un.SUM_BY_NONZERO_WEIGHTS){let a=M(e,"losses","computeWeightedLoss"),r=null;t!=null&&(r=M(t,"weights","computeWeightedLoss"));let s=r==null?a:_(a,r);if(n===un.NONE)return s;if(n===un.SUM)return ke(s);if(n===un.MEAN){if(r==null)return wt(s);{let i=a.size/r.size,o=me(ke(s),ke(r));return i>1?me(o,Se(i)):o}}if(n===un.SUM_BY_NONZERO_WEIGHTS){if(r==null)return me(ke(s),Se(a.size));{let i=_(r,$n(a.shape)),o=fe(ke(mi(i,Se(0))),"float32");return me(ke(s),o)}}throw Error(`Unknown reduction: ${n}`)}var sr=O({computeWeightedLoss_:DM});function OM(e,t,n,a=un.SUM_BY_NONZERO_WEIGHTS){let r=M(e,"labels","absoluteDifference"),s=M(t,"predictions","absoluteDifference"),i=null;n!=null&&(i=M(n,"weights","absoluteDifference")),sn(r.shape,s.shape,"Error in absoluteDifference: ");let o=Ot(ge(r,s));return sr(o,i,a)}var zM=O({absoluteDifference_:OM});function _M(e,t,n,a,r=un.SUM_BY_NONZERO_WEIGHTS){let s=M(e,"labels","cosineDistance"),i=M(t,"predictions","cosineDistance"),o=null;a!=null&&(o=M(a,"weights","cosineDistance")),sn(s.shape,i.shape,"Error in cosineDistance: ");let l=Se(1),d=ge(l,ke(_(s,i),n,!0));return sr(d,o,r)}var PM=O({cosineDistance_:_M});function LM(e,t,n,a=un.SUM_BY_NONZERO_WEIGHTS){let r=M(e,"labels","hingeLoss"),s=M(t,"predictions","hingeLoss"),i=null;n!=null&&(i=M(n,"weights","hingeLoss")),sn(r.shape,s.shape,"Error in hingeLoss: ");let o=Se(1);r=ge(_(Se(2),r),o);let l=Pa(ge(o,_(r,s)));return sr(l,i,a)}var WM=O({hingeLoss_:LM});function BM(e,t,n,a=1,r=un.SUM_BY_NONZERO_WEIGHTS){let s=M(e,"labels","huberLoss"),i=M(t,"predictions","huberLoss"),o=null;n!=null&&(o=M(n,"weights","huberLoss")),sn(s.shape,i.shape,"Error in huberLoss: ");let l=Se(a),d=Ot(ge(i,s)),u=gl(d,l),p=ge(d,u),c=se(_(Se(.5),st(u)),_(l,p));return sr(c,o,r)}var VM=O({huberLoss_:BM});function jM(e,t,n,a=1e-7,r=un.SUM_BY_NONZERO_WEIGHTS){let s=M(e,"labels","logLoss"),i=M(t,"predictions","logLoss"),o=null;n!=null&&(o=M(n,"weights","logLoss")),sn(s.shape,i.shape,"Error in logLoss: ");let l=Se(1),d=Se(a),u=vt(_(s,Fn(se(i,d)))),p=_(ge(l,s),Fn(se(ge(l,i),d))),c=ge(u,p);return sr(c,o,r)}var UM=O({logLoss_:jM});function HM(e,t,n,a=un.SUM_BY_NONZERO_WEIGHTS){let r=M(e,"labels","meanSquaredError"),s=M(t,"predictions","meanSquaredError"),i=null;n!=null&&(i=M(n,"weights","meanSquaredError")),sn(r.shape,s.shape,"Error in meanSquaredError: ");let o=Bc(r,s);return sr(o,i,a)}var GM=O({meanSquaredError_:HM});function qM(e,t){let n=M(e,"labels","sigmoidCrossEntropyWithLogits"),a=M(t,"logits","sigmoidCrossEntropyWithLogits");sn(n.shape,a.shape,"Error in sigmoidCrossEntropyWithLogits: ");let r=Pa(a),s=_(a,n),i=Nc(qn(vt(Ot(a))));return se(ge(r,s),i)}function XM(e,t,n,a=0,r=un.SUM_BY_NONZERO_WEIGHTS){let s=M(e,"multiClassLabels","sigmoidCrossEntropy"),i=M(t,"logits","sigmoidCrossEntropy"),o=null;if(n!=null&&(o=M(n,"weights","sigmoidCrossEntropy")),sn(s.shape,i.shape,"Error in sigmoidCrossEntropy: "),a>0){let d=Se(a),u=Se(1),p=Se(.5);s=se(_(s,ge(u,d)),_(p,d))}let l=qM(s,i);return sr(l,o,r)}var KM=O({sigmoidCrossEntropy_:XM});function ZM(e,t,n=-1){if(n===-1&&(n=t.rank-1),n!==t.rank-1)throw Error(`Softmax cross entropy along a non-last dimension is not yet supported. Labels / logits was rank ${t.rank} and dim was ${n}`);return za((a,r,s)=>{let i=wA(r,[n],!0),o=ge(fe(r,"float32"),i);s([a,o]);let l=vt(_(o,a));return{value:ke(l,[n]),gradFunc:(d,u)=>{let[p,c]=u,h=fi(d.shape,[n]);return[_(H(d,h),ge(fe(p,"float32"),qn(c))),_(H(d,h),ge(qn(c),fe(p,"float32")))]}}})(e,t)}function YM(e,t,n,a=0,r=un.SUM_BY_NONZERO_WEIGHTS){let s=M(e,"onehotLabels","softmaxCrossEntropy"),i=M(t,"logits","softmaxCrossEntropy"),o=null;if(n!=null&&(o=M(n,"weights","softmaxCrossEntropy")),sn(s.shape,i.shape,"Error in softmaxCrossEntropy: "),a>0){let d=Se(a),u=Se(1),p=Se(s.shape[1]);s=se(_(s,ge(u,d)),me(d,p))}let l=ZM(s,i);return sr(l,o,r)}var JM=O({softmaxCrossEntropy_:YM});function QM(e,t,n,a){let r=M(e,"indices","sparseFillEmptyRows"),s=M(t,"values","sparseFillEmptyRows"),i=M(n,"denseShape","sparseFillEmptyRows"),o=M(a,"defaultValue","sparseFillEmptyRows",s.dtype);if(r.rank!==2)throw new Error(`Indices should be Tensor2D but received shape ${r.shape}`);if(s.rank!==1)throw new Error(`Values should be Tensor1D but received shape ${s.shape}`);if(i.rank!==1)throw new Error(`Dense shape should be Tensor1D but received shape ${i.shape}`);if(o.rank!==0)throw new Error(`Default value should be a scalar but received shape ${o.shape}`);let l={indices:r,values:s,denseShape:i,defaultValue:o},d=D.runKernel(tc,l);return{outputIndices:d[0],outputValues:d[1],emptyRowIndicator:d[2],reverseIndexMap:d[3]}}var eF=O({sparseFillEmptyRows_:QM});function tF(e,t,n){let a=M(e,"inputIndices","sparseReshape"),r=M(t,"inputShape","sparseReshape"),s=M(n,"newShape","sparseReshape");if(a.rank!==2)throw new Error(`Input indices should be Tensor2D but received shape - ${a.shape}`);if(r.rank!==1)throw new Error(`Input shape should be Tensor1D but received shape ${r.shape}`);if(s.rank!==1)throw new Error(`New shape should be Tensor1D but received shape ${s.shape}`);let i={inputIndices:a,inputShape:r,newShape:s},o=D.runKernel(nc,i);return{outputIndices:o[0],outputShape:o[1]}}var nF=O({sparseReshape_:tF}),aF={fft:ad,ifft:wl,rfft:rd,irfft:Wc},rF={hammingWindow:GR,hannWindow:o3,frame:l3,stft:ZR},Ye={flipLeftRight:eM,resizeNearestNeighbor:f3,resizeBilinear:h3,rotateWithOffset:nM,cropAndResize:JR,nonMaxSuppression:rM,nonMaxSuppressionAsync:cM,nonMaxSuppressionWithScore:fM,nonMaxSuppressionWithScoreAsync:AM,nonMaxSuppressionPadded:gM,nonMaxSuppressionPaddedAsync:bM,threshold:SM,transform:TM},A3={bandPart:CM,gramSchmidt:MM,qr:$M},sF={absoluteDifference:zM,computeWeightedLoss:ir,cosineDistance:PM,hingeLoss:WM,huberLoss:VM,logLoss:UM,meanSquaredError:GM,sigmoidCrossEntropy:KM,softmaxCrossEntropy:JM},y3={sparseFillEmptyRows:eF,sparseReshape:nF},or=class extends xb{minimize(e,t=!1,n){let{value:a,grads:r}=this.computeGradients(e,n);if(n!=null){let s=n.map(i=>({name:i.name,tensor:r[i.name]}));this.applyGradients(s)}else this.applyGradients(r);return Ee(r),t?a:(a.dispose(),null)}get iterations(){return this.iterations_==null&&(this.iterations_=0),this.iterations_}incrementIterations(){this.iterations_=this.iterations+1}computeGradients(e,t){return Bb(e,t)}dispose(){this.iterations_!=null&&Ee(this.iterations_)}async saveIterations(){return this.iterations_==null&&(this.iterations_=0),{name:"iter",tensor:Se(this.iterations_,"int32")}}async getWeights(){throw new Error("getWeights() is not implemented for this optimizer yet.")}async setWeights(e){throw new Error(`setWeights() is not implemented for this optimizer class ${this.getClassName()}`)}async extractIterations(e){return this.iterations_=(await e[0].tensor.data())[0],e.slice(1)}};Object.defineProperty(or,Symbol.hasInstance,{value:e=>e.minimize!=null&&e.computeGradients!=null&&e.applyGradients!=null});var Kc=class extends or{constructor(e,t,n=null){super();this.learningRate=e,this.rho=t,this.epsilon=n,this.accumulatedGrads=[],this.accumulatedUpdates=[],n==null&&(this.epsilon=D.backend.epsilon())}applyGradients(e){(Array.isArray(e)?e.map(t=>t.name):Object.keys(e)).forEach((t,n)=>{let a=D.registeredVariables[t],r=!1;this.accumulatedGrads[n]==null&&(this.accumulatedGrads[n]={originalName:`${t}/accum_grad`,variable:W(()=>Ue(a).variable(r))}),this.accumulatedUpdates[n]==null&&(this.accumulatedUpdates[n]={originalName:`${t}/accum_var`,variable:W(()=>Ue(a).variable(r))});let s=Array.isArray(e)?e[n].tensor:e[t];if(s==null)return;let i=this.accumulatedGrads[n].variable,o=this.accumulatedUpdates[n].variable;W(()=>{let l=se(_(i,this.rho),_(st(s),1-this.rho)),d=_(me(Qt(se(o,this.epsilon)),Qt(se(i,this.epsilon))),s),u=se(_(o,this.rho),_(st(d),1-this.rho));i.assign(l),o.assign(u);let p=se(_(d,-this.learningRate),a);a.assign(p)})}),this.incrementIterations()}dispose(){this.accumulatedUpdates!=null&&(Ee(this.accumulatedGrads.map(e=>e.variable)),Ee(this.accumulatedUpdates.map(e=>e.variable)))}async getWeights(){let e=[...this.accumulatedGrads,...this.accumulatedUpdates];return[await this.saveIterations()].concat(e.map(t=>({name:t.originalName,tensor:t.variable})))}async setWeights(e){e=await this.extractIterations(e);let t=e.length/2,n=!1;this.accumulatedGrads=e.slice(0,t).map(a=>({originalName:a.name,variable:a.tensor.variable(n)})),this.accumulatedUpdates=e.slice(t,t*2).map(a=>({originalName:a.name,variable:a.tensor.variable(n)}))}getConfig(){return{learningRate:this.learningRate,rho:this.rho,epsilon:this.epsilon}}static fromConfig(e,t){return new e(t.learningRate,t.rho,t.epsilon)}};Kc.className="Adadelta";Rr(Kc);var Zc=class extends or{constructor(e,t=.1){super();this.learningRate=e,this.initialAccumulatorValue=t,this.accumulatedGrads=[]}applyGradients(e){(Array.isArray(e)?e.map(t=>t.name):Object.keys(e)).forEach((t,n)=>{let a=D.registeredVariables[t];if(this.accumulatedGrads[n]==null){let i=!1;this.accumulatedGrads[n]={originalName:`${t}/accumulator`,variable:W(()=>Al(a.shape,this.initialAccumulatorValue).variable(i))}}let r=Array.isArray(e)?e[n].tensor:e[t];if(r==null)return;let s=this.accumulatedGrads[n].variable;W(()=>{let i=se(s,st(r));s.assign(i);let o=se(_(me(r,Qt(se(i,D.backend.epsilon()))),-this.learningRate),a);a.assign(o)})}),this.incrementIterations()}dispose(){this.accumulatedGrads!=null&&Ee(this.accumulatedGrads.map(e=>e.variable))}async getWeights(){return[await this.saveIterations()].concat(this.accumulatedGrads.map(e=>({name:e.originalName,tensor:e.variable})))}async setWeights(e){e=await this.extractIterations(e);let t=!1;this.accumulatedGrads=e.map(n=>({originalName:n.name,variable:n.tensor.variable(t)}))}getConfig(){return{learningRate:this.learningRate,initialAccumulatorValue:this.initialAccumulatorValue}}static fromConfig(e,t){return new e(t.learningRate,t.initialAccumulatorValue)}};Zc.className="Adagrad";Rr(Zc);var Yc=class extends or{constructor(e,t,n,a=null){super();this.learningRate=e,this.beta1=t,this.beta2=n,this.epsilon=a,this.accumulatedFirstMoment=[],this.accumulatedSecondMoment=[],W(()=>{this.accBeta1=Se(t).variable(),this.accBeta2=Se(n).variable()}),a==null&&(this.epsilon=D.backend.epsilon())}applyGradients(e){let t=Array.isArray(e)?e.map(n=>n.name):Object.keys(e);W(()=>{let n=ge(1,this.accBeta1),a=ge(1,this.accBeta2);t.forEach((r,s)=>{let i=D.registeredVariables[r],o=!1;this.accumulatedFirstMoment[s]==null&&(this.accumulatedFirstMoment[s]={originalName:`${r}/m`,variable:W(()=>Ue(i).variable(o))}),this.accumulatedSecondMoment[s]==null&&(this.accumulatedSecondMoment[s]={originalName:`${r}/v`,variable:W(()=>Ue(i).variable(o))});let l=Array.isArray(e)?e[s].tensor:e[r];if(l==null)return;let d=this.accumulatedFirstMoment[s].variable,u=this.accumulatedSecondMoment[s].variable,p=se(_(d,this.beta1),_(l,1-this.beta1)),c=se(_(u,this.beta2),_(st(l),1-this.beta2)),h=me(p,n),m=me(c,a);d.assign(p),u.assign(c);let f=se(_(me(h,se(Qt(m),this.epsilon)),-this.learningRate),i);i.assign(f)}),this.accBeta1.assign(_(this.accBeta1,this.beta1)),this.accBeta2.assign(_(this.accBeta2,this.beta2))}),this.incrementIterations()}dispose(){this.accBeta1.dispose(),this.accBeta2.dispose(),this.accumulatedFirstMoment!=null&&Ee(this.accumulatedFirstMoment.map(e=>e.variable)),this.accumulatedSecondMoment!=null&&Ee(this.accumulatedSecondMoment.map(e=>e.variable))}async getWeights(){let e=[...this.accumulatedFirstMoment,...this.accumulatedSecondMoment];return[await this.saveIterations()].concat(e.map(t=>({name:t.originalName,tensor:t.variable})))}async setWeights(e){e=await this.extractIterations(e),W(()=>{this.accBeta1.assign(sr(this.beta1,this.iterations_+1)),this.accBeta2.assign(sr(this.beta2,this.iterations_+1))});let t=e.length/2,n=!1;this.accumulatedFirstMoment=e.slice(0,t).map(a=>({originalName:a.name,variable:a.tensor.variable(n)})),this.accumulatedSecondMoment=e.slice(t,t*2).map(a=>({originalName:a.name,variable:a.tensor.variable(n)}))}getConfig(){return{learningRate:this.learningRate,beta1:this.beta1,beta2:this.beta2,epsilon:this.epsilon}}static fromConfig(e,t){return new e(t.learningRate,t.beta1,t.beta2,t.epsilon)}};Yc.className="Adam";Rr(Yc);var Jc=class extends or{constructor(e,t,n,a=null,r=0){super();this.learningRate=e,this.beta1=t,this.beta2=n,this.epsilon=a,this.decay=r,this.accumulatedFirstMoment=[],this.accumulatedWeightedInfNorm=[],W(()=>{this.iteration=Se(0).variable(),this.accBeta1=Se(t).variable()}),a==null&&(this.epsilon=D.backend.epsilon())}applyGradients(e){let t=Array.isArray(e)?e.map(n=>n.name):Object.keys(e);W(()=>{let n=ge(1,this.accBeta1),a=me(-this.learningRate,se(_(this.iteration,this.decay),1));t.forEach((r,s)=>{let i=D.registeredVariables[r],o=!1;this.accumulatedFirstMoment[s]==null&&(this.accumulatedFirstMoment[s]={originalName:`${r}/m`,variable:Ue(i).variable(o)}),this.accumulatedWeightedInfNorm[s]==null&&(this.accumulatedWeightedInfNorm[s]={originalName:`${r}/v`,variable:Ue(i).variable(o)});let l=Array.isArray(e)?e[s].tensor:e[r];if(l==null)return;let d=this.accumulatedFirstMoment[s].variable,u=this.accumulatedWeightedInfNorm[s].variable,p=se(_(d,this.beta1),_(l,1-this.beta1)),c=_(u,this.beta2),h=zt(l),m=Pa(c,h);d.assign(p),u.assign(m);let f=se(_(me(a,n),me(p,se(m,this.epsilon))),i);i.assign(f)}),this.iteration.assign(se(this.iteration,1)),this.accBeta1.assign(_(this.accBeta1,this.beta1))}),this.incrementIterations()}dispose(){this.accBeta1.dispose(),this.iteration.dispose(),this.accumulatedFirstMoment!=null&&Ee(this.accumulatedFirstMoment.map(e=>e.variable)),this.accumulatedWeightedInfNorm!=null&&Ee(this.accumulatedWeightedInfNorm.map(e=>e.variable))}async getWeights(){throw new Error("getWeights() is not implemented for Adamax yet.")}async setWeights(e){throw new Error("setWeights() is not implemented for Adamax yet.")}getConfig(){return{learningRate:this.learningRate,beta1:this.beta1,beta2:this.beta2,epsilon:this.epsilon,decay:this.decay}}static fromConfig(e,t){return new e(t.learningRate,t.beta1,t.beta2,t.epsilon,t.decay)}};Jc.className="Adamax";Rr(Jc);var sd=class extends or{constructor(e){super();this.learningRate=e,this.setLearningRate(e)}applyGradients(e){(Array.isArray(e)?e.map(t=>t.name):Object.keys(e)).forEach((t,n)=>{let a=Array.isArray(e)?e[n].tensor:e[t];if(a==null)return;let r=D.registeredVariables[t];W(()=>{let s=se(_(this.c,a),r);r.assign(s)})}),this.incrementIterations()}setLearningRate(e){this.learningRate=e,this.c!=null&&this.c.dispose(),this.c=Ut(Se(-e))}dispose(){this.c.dispose()}async getWeights(){return[await this.saveIterations()]}async setWeights(e){if(e=await this.extractIterations(e),e.length!==0)throw new Error("SGD optimizer does not have settable weights.")}getConfig(){return{learningRate:this.learningRate}}static fromConfig(e,t){return new e(t.learningRate)}};sd.className="SGD";Rr(sd);var Qc=class extends sd{constructor(e,t,n=!1){super(e);this.learningRate=e,this.momentum=t,this.useNesterov=n,this.accumulations=[],this.m=Se(this.momentum)}applyGradients(e){(Array.isArray(e)?e.map(t=>t.name):Object.keys(e)).forEach((t,n)=>{let a=D.registeredVariables[t];if(this.accumulations[n]==null){let i=!1;this.accumulations[n]={originalName:`${t}/momentum`,variable:W(()=>Ue(a).variable(i))}}let r=this.accumulations[n].variable,s=Array.isArray(e)?e[n].tensor:e[t];s!=null&&W(()=>{let i,o=se(_(this.m,r),s);this.useNesterov?i=se(_(this.c,se(s,_(o,this.m))),a):i=se(_(this.c,o),a),r.assign(o),a.assign(i)})}),this.incrementIterations()}dispose(){this.m.dispose(),this.accumulations!=null&&Ee(this.accumulations.map(e=>e.variable))}setMomentum(e){this.momentum=e}async getWeights(){return[await this.saveIterations()].concat(this.accumulations.map(e=>({name:e.originalName,tensor:e.variable})))}async setWeights(e){e=await this.extractIterations(e);let t=!1;this.accumulations=e.map(n=>({originalName:n.name,variable:n.tensor.variable(t)}))}getConfig(){return{learningRate:this.learningRate,momentum:this.momentum,useNesterov:this.useNesterov}}static fromConfig(e,t){return new e(t.learningRate,t.momentum,t.useNesterov)}};Qc.className="Momentum";Rr(Qc);var eh=class extends or{constructor(e,t=.9,n=0,a=null,r=!1){super();if(this.learningRate=e,this.decay=t,this.momentum=n,this.epsilon=a,this.accumulatedMeanSquares=[],this.accumulatedMoments=[],this.accumulatedMeanGrads=[],this.centered=r,a==null&&(this.epsilon=D.backend.epsilon()),e==null)throw new Error("learningRate for RMSPropOptimizer must be defined.")}applyGradients(e){(Array.isArray(e)?e.map(t=>t.name):Object.keys(e)).forEach((t,n)=>{let a=D.registeredVariables[t],r=!1;this.accumulatedMeanSquares[n]==null&&(this.accumulatedMeanSquares[n]={originalName:`${t}/rms`,variable:W(()=>Ue(a).variable(r))}),this.accumulatedMoments[n]==null&&(this.accumulatedMoments[n]={originalName:`${t}/momentum`,variable:W(()=>Ue(a).variable(r))}),this.accumulatedMeanGrads[n]==null&&this.centered&&(this.accumulatedMeanGrads[n]={originalName:`${t}/mg`,variable:W(()=>Ue(a).variable(r))});let s=Array.isArray(e)?e[n].tensor:e[t];if(s==null)return;let i=this.accumulatedMeanSquares[n].variable,o=this.accumulatedMoments[n].variable;W(()=>{let l=se(_(i,this.decay),_(st(s),1-this.decay));if(this.centered){let d=this.accumulatedMeanGrads[n].variable,u=se(_(d,this.decay),_(s,1-this.decay)),p=me(_(s,this.learningRate),Qt(ge(l,se(st(u),this.epsilon)))),c=se(_(o,this.momentum),p);i.assign(l),d.assign(u),o.assign(c);let h=ge(a,c);a.assign(h)}else{let d=se(_(i,this.decay),_(st(s),1-this.decay)),u=se(_(o,this.momentum),me(_(s,this.learningRate),Qt(se(d,this.epsilon))));i.assign(d),o.assign(u);let p=ge(a,u);a.assign(p)}})}),this.incrementIterations()}dispose(){this.accumulatedMeanSquares!=null&&Ee(this.accumulatedMeanSquares.map(e=>e.variable)),this.accumulatedMeanGrads!=null&&this.centered&&Ee(this.accumulatedMeanGrads.map(e=>e.variable)),this.accumulatedMoments!=null&&Ee(this.accumulatedMoments.map(e=>e.variable))}async getWeights(){let e=[...this.accumulatedMeanSquares,...this.accumulatedMoments];return this.centered&&e.push(...this.accumulatedMeanGrads),[await this.saveIterations()].concat(e.map(t=>({name:t.originalName,tensor:t.variable})))}async setWeights(e){e=await this.extractIterations(e);let t=this.centered?e.length/3:e.length/2,n=!1;this.accumulatedMeanSquares=e.slice(0,t).map(a=>({originalName:a.name,variable:a.tensor.variable(n)})),this.accumulatedMoments=e.slice(t,t*2).map(a=>({originalName:a.name,variable:a.tensor.variable(n)})),this.centered&&(this.accumulatedMeanGrads=e.slice(t*2,t*3).map(a=>({originalName:a.name,variable:a.tensor.variable(n)})))}getConfig(){return{learningRate:this.learningRate,decay:this.decay,momentum:this.momentum,epsilon:this.epsilon,centered:this.centered}}static fromConfig(e,t){return new e(t.learningRate,t.decay,t.momentum,t.epsilon,t.centered)}};eh.className="RMSProp";Rr(eh);var yi=class{static sgd(e){return new sd(e)}static momentum(e,t,n=!1){return new Qc(e,t,n)}static rmsprop(e,t=.9,n=0,a=null,r=!1){return new eh(e,t,n,a,r)}static adam(e=.001,t=.9,n=.999,a=null){return new Yc(e,t,n,a)}static adadelta(e=.001,t=.95,n=null){return new Kc(e,t,n)}static adamax(e=.002,t=.9,n=.999,a=null,r=0){return new Jc(e,t,n,a,r)}static adagrad(e,t=.1){return new Zc(e,t)}},gi={sgd:yi.sgd,momentum:yi.momentum,adadelta:yi.adadelta,adagrad:yi.adagrad,rmsprop:yi.rmsprop,adamax:yi.adamax,adam:yi.adam},iF=(()=>typeof requestAnimationFrame!="undefined"?requestAnimationFrame:typeof setImmediate!="undefined"?setImmediate:e=>e())();function th(){return new Promise(e=>iF(()=>e()))}var C={};Fe(C,{ERF_A1:()=>yF,ERF_A2:()=>gF,ERF_A3:()=>xF,ERF_A4:()=>bF,ERF_A5:()=>vF,ERF_P:()=>AF,PARALLELIZE_THRESHOLD:()=>BA,SELU_SCALE:()=>x3,SELU_SCALEALPHA:()=>g3,applyActivation:()=>qc,assertAndGetBroadcastShape:()=>ct,assertAxesAreInnerMostDims:()=>DE,assertParamsConsistent:()=>oF,assignToTypedArray:()=>CF,axesAreInnerMostDims:()=>bA,calculateShapes:()=>ob,checkEinsumDimSizes:()=>DF,combineLocations:()=>jb,complexWithEvenIndex:()=>NF,complexWithOddIndex:()=>TF,computeConv2DInfo:()=>Hu,computeConv3DInfo:()=>Nb,computeDefaultPad:()=>iA,computeDilation2DInfo:()=>rT,computeOptimalWindowSize:()=>uF,computeOutAndReduceShapes:()=>Ub,computeOutShape:()=>lF,computePool2DInfo:()=>Sb,computePool3DInfo:()=>sT,convertConv2DDataFormat:()=>Ib,decodeEinsumEquation:()=>FF,eitherStridesOrDilationsAreOne:()=>za,expandShapeToKeepDim:()=>mi,exponent:()=>MF,exponents:()=>RF,fromStringArrayToUint8:()=>LF,fromUint8ToStringArray:()=>PF,getAxesPermutation:()=>Hb,getBroadcastDims:()=>KT,getComplexWithIndex:()=>EF,getEinsumComputePath:()=>OF,getEinsumPermutation:()=>$F,getFusedBiasGradient:()=>Gc,getFusedDyActivation:()=>Hc,getImageCenter:()=>dF,getInnerMostAxes:()=>OE,getPermuted:()=>cF,getReductionAxes:()=>_t,getReshaped:()=>pF,getReshapedPermuted:()=>hF,getSliceBeginCoords:()=>fF,getSliceSize:()=>mF,getUndoAxesPermutation:()=>vA,isIdentityPermutation:()=>zF,log:()=>kF,mergeRealAndImagArrays:()=>IF,prepareAndValidate:()=>ib,prepareSplitSize:()=>_F,segment_util:()=>b3,shouldFuse:()=>Xc,slice_util:()=>ln,splitRealAndImagArrays:()=>SF,tupleValuesAreOne:()=>Mr,upcastType:()=>ia,validateInput:()=>Hm,validateUpdateShape:()=>Um,warn:()=>wF});function oF(e,t){let n=e[0].length;e.forEach((r,s)=>{F(r.length===n,()=>`Error in concat${n}D: rank of tensors[${s}] must be the same as the rank of the rest (${n})`)}),F(t>=0&&t`Error in concat${n}D: axis must be between 0 and ${n-1}.`);let a=e[0];e.forEach((r,s)=>{for(let i=0;i`Error in concat${n}D: Shape of tensors[${s}] (${r}) does not match the shape of the rest (${a}) along the non-concatenated axis ${s}.`)})}function lF(e,t){let n=e[0].slice();for(let a=1;a=t*2+1||i%2==1?s.push(i):r.push(i);a.push(...r),a.push(0),a.push(...s)}return a}function hF(e,t,n,a=!0){let r=[];a?r.push(e[0]/n):r.push(e[0]*n);for(let s=1;s/g,v3=",",w3="...";function FF(e,t){e=e.replace(/\s/g,"");let n=(e.length-e.replace(WF,"").length)/VA.length;if(n<1)throw new Error("Equations without an arrow are not supported.");if(n>1)throw new Error(`Equation must contain exactly one arrow ("${VA}").`);let[a,r]=e.split(VA);F(a.indexOf(w3)===-1,()=>`The ellipsis notation ("${w3}") is not supported yet.`);let s=a.split(v3),i=s.length;if(t!==i)throw new Error(`Expected ${i} input tensors, received ${t}`);if(i>2)throw new Error("Support for more than 2 input tensors is not implemented yet.");let o=[];for(let c=0;cm.indexOf(h)!==-1))throw new Error(`Output subscripts contain the label ${h} not present in the input subscripts.`);o.indexOf(h)===-1&&o.push(h)}for(let c=0;cr!==-1),{permutationIndices:n,expandDims:a}}function DF(e,t,n){let a=new Array(e);for(let r=0;r`Expected dimension ${a[t[r][i]]} at axis ${i} of input shaped ${JSON.stringify(s)}, but got dimension ${s[i]}`)}}function OF(e,t){let n=e,a=[],r=0;e.length===0&&n.push(-1),r=e.length+1;for(let i=0;it===n)}function BF(e,t){let n=[];for(let a=0;a"Number of splits must evenly divide the axis."),a=new Array(t).fill(e.shape[n]/t);else{let r=t.reduce((i,o)=>(o===-1&&(i+=1),i),0);F(r<=1,()=>"There should be only one negative value in split array.");let s=t.indexOf(-1);if(s!==-1){let i=t.reduce((o,l)=>l>0?o+l:o);t[s]=e.shape[n]-i}F(e.shape[n]===t.reduce((i,o)=>i+o),()=>"The sum of sizes must match the size of the axis dimension."),a=t}return a}var b3={};Fe(b3,{collectGatherOpShapeInfo:()=>UF,computeOutShape:()=>jF,segOpComputeOptimalWindowSize:()=>VF});function VF(e,t){let n=!1,a;for(e<=BA?(a=e,n=!0):a=Np(e,Math.floor(Math.sqrt(e)));!n;)a>t||a===e?n=!0:a=Np(e,a+1);return a}function jF(e,t,n){let a=[],r=e.length;for(let s=0;sr))throw new Error(`Expect batchDims in the range of [-${r}, ${r}], but got ${a}`);if(a<0&&(a+=r),a>s)throw new Error(`batchDims (${a}) must be less than rank(x) ( - ${s}).`);if(nlc(t))}catch(t){throw new Error(`Failed to decode encoded string bytes into utf-8, error: ${t}`)}}function LF(e){return e.map(t=>Du(t))}var Wa={};Fe(Wa,{nonMaxSuppressionV3Impl:()=>u3,nonMaxSuppressionV4Impl:()=>d3,nonMaxSuppressionV5Impl:()=>p3,whereImpl:()=>Qb});function ve(e,t){Array.isArray(e)||(e=[e]),e.forEach(n=>{n!=null&&k.assert(n.dtype!=="complex64",()=>`${t} does not support complex64 tensors in the CPU backend.`)})}var HF=Wa.whereImpl,nh=class extends hu{constructor(){super();this.blockSize=48,this.firstUse=!0,this.data=new Ip(this,nr())}nextDataId(){return nh.nextDataId++}write(e,t,n){this.firstUse&&(this.firstUse=!1,J().get("IS_NODE")&&C.warn(` + ${a.shape}`);if(r.rank!==1)throw new Error(`Input shape should be Tensor1D but received shape ${r.shape}`);if(s.rank!==1)throw new Error(`New shape should be Tensor1D but received shape ${s.shape}`);let i={inputIndices:a,inputShape:r,newShape:s},o=D.runKernel(nc,i);return{outputIndices:o[0],outputShape:o[1]}}var nF=O({sparseReshape_:tF}),aF={fft:ad,ifft:vl,rfft:rd,irfft:Wc},rF={hammingWindow:GR,hannWindow:o3,frame:l3,stft:ZR},Ye={flipLeftRight:eM,resizeNearestNeighbor:f3,resizeBilinear:h3,rotateWithOffset:nM,cropAndResize:JR,nonMaxSuppression:rM,nonMaxSuppressionAsync:cM,nonMaxSuppressionWithScore:fM,nonMaxSuppressionWithScoreAsync:AM,nonMaxSuppressionPadded:gM,nonMaxSuppressionPaddedAsync:bM,threshold:SM,transform:TM},A3={bandPart:CM,gramSchmidt:MM,qr:$M},sF={absoluteDifference:zM,computeWeightedLoss:sr,cosineDistance:PM,hingeLoss:WM,huberLoss:VM,logLoss:UM,meanSquaredError:GM,sigmoidCrossEntropy:KM,softmaxCrossEntropy:JM},y3={sparseFillEmptyRows:eF,sparseReshape:nF},ir=class extends xb{minimize(e,t=!1,n){let{value:a,grads:r}=this.computeGradients(e,n);if(n!=null){let s=n.map(i=>({name:i.name,tensor:r[i.name]}));this.applyGradients(s)}else this.applyGradients(r);return Ee(r),t?a:(a.dispose(),null)}get iterations(){return this.iterations_==null&&(this.iterations_=0),this.iterations_}incrementIterations(){this.iterations_=this.iterations+1}computeGradients(e,t){return Bb(e,t)}dispose(){this.iterations_!=null&&Ee(this.iterations_)}async saveIterations(){return this.iterations_==null&&(this.iterations_=0),{name:"iter",tensor:Se(this.iterations_,"int32")}}async getWeights(){throw new Error("getWeights() is not implemented for this optimizer yet.")}async setWeights(e){throw new Error(`setWeights() is not implemented for this optimizer class ${this.getClassName()}`)}async extractIterations(e){return this.iterations_=(await e[0].tensor.data())[0],e.slice(1)}};Object.defineProperty(ir,Symbol.hasInstance,{value:e=>e.minimize!=null&&e.computeGradients!=null&&e.applyGradients!=null});var Kc=class extends ir{constructor(e,t,n=null){super();this.learningRate=e,this.rho=t,this.epsilon=n,this.accumulatedGrads=[],this.accumulatedUpdates=[],n==null&&(this.epsilon=D.backend.epsilon())}applyGradients(e){(Array.isArray(e)?e.map(t=>t.name):Object.keys(e)).forEach((t,n)=>{let a=D.registeredVariables[t],r=!1;this.accumulatedGrads[n]==null&&(this.accumulatedGrads[n]={originalName:`${t}/accum_grad`,variable:W(()=>Ue(a).variable(r))}),this.accumulatedUpdates[n]==null&&(this.accumulatedUpdates[n]={originalName:`${t}/accum_var`,variable:W(()=>Ue(a).variable(r))});let s=Array.isArray(e)?e[n].tensor:e[t];if(s==null)return;let i=this.accumulatedGrads[n].variable,o=this.accumulatedUpdates[n].variable;W(()=>{let l=se(_(i,this.rho),_(st(s),1-this.rho)),d=_(me(Jt(se(o,this.epsilon)),Jt(se(i,this.epsilon))),s),u=se(_(o,this.rho),_(st(d),1-this.rho));i.assign(l),o.assign(u);let p=se(_(d,-this.learningRate),a);a.assign(p)})}),this.incrementIterations()}dispose(){this.accumulatedUpdates!=null&&(Ee(this.accumulatedGrads.map(e=>e.variable)),Ee(this.accumulatedUpdates.map(e=>e.variable)))}async getWeights(){let e=[...this.accumulatedGrads,...this.accumulatedUpdates];return[await this.saveIterations()].concat(e.map(t=>({name:t.originalName,tensor:t.variable})))}async setWeights(e){e=await this.extractIterations(e);let t=e.length/2,n=!1;this.accumulatedGrads=e.slice(0,t).map(a=>({originalName:a.name,variable:a.tensor.variable(n)})),this.accumulatedUpdates=e.slice(t,t*2).map(a=>({originalName:a.name,variable:a.tensor.variable(n)}))}getConfig(){return{learningRate:this.learningRate,rho:this.rho,epsilon:this.epsilon}}static fromConfig(e,t){return new e(t.learningRate,t.rho,t.epsilon)}};Kc.className="Adadelta";Cr(Kc);var Zc=class extends ir{constructor(e,t=.1){super();this.learningRate=e,this.initialAccumulatorValue=t,this.accumulatedGrads=[]}applyGradients(e){(Array.isArray(e)?e.map(t=>t.name):Object.keys(e)).forEach((t,n)=>{let a=D.registeredVariables[t];if(this.accumulatedGrads[n]==null){let i=!1;this.accumulatedGrads[n]={originalName:`${t}/accumulator`,variable:W(()=>ml(a.shape,this.initialAccumulatorValue).variable(i))}}let r=Array.isArray(e)?e[n].tensor:e[t];if(r==null)return;let s=this.accumulatedGrads[n].variable;W(()=>{let i=se(s,st(r));s.assign(i);let o=se(_(me(r,Jt(se(i,D.backend.epsilon()))),-this.learningRate),a);a.assign(o)})}),this.incrementIterations()}dispose(){this.accumulatedGrads!=null&&Ee(this.accumulatedGrads.map(e=>e.variable))}async getWeights(){return[await this.saveIterations()].concat(this.accumulatedGrads.map(e=>({name:e.originalName,tensor:e.variable})))}async setWeights(e){e=await this.extractIterations(e);let t=!1;this.accumulatedGrads=e.map(n=>({originalName:n.name,variable:n.tensor.variable(t)}))}getConfig(){return{learningRate:this.learningRate,initialAccumulatorValue:this.initialAccumulatorValue}}static fromConfig(e,t){return new e(t.learningRate,t.initialAccumulatorValue)}};Zc.className="Adagrad";Cr(Zc);var Yc=class extends ir{constructor(e,t,n,a=null){super();this.learningRate=e,this.beta1=t,this.beta2=n,this.epsilon=a,this.accumulatedFirstMoment=[],this.accumulatedSecondMoment=[],W(()=>{this.accBeta1=Se(t).variable(),this.accBeta2=Se(n).variable()}),a==null&&(this.epsilon=D.backend.epsilon())}applyGradients(e){let t=Array.isArray(e)?e.map(n=>n.name):Object.keys(e);W(()=>{let n=ge(1,this.accBeta1),a=ge(1,this.accBeta2);t.forEach((r,s)=>{let i=D.registeredVariables[r],o=!1;this.accumulatedFirstMoment[s]==null&&(this.accumulatedFirstMoment[s]={originalName:`${r}/m`,variable:W(()=>Ue(i).variable(o))}),this.accumulatedSecondMoment[s]==null&&(this.accumulatedSecondMoment[s]={originalName:`${r}/v`,variable:W(()=>Ue(i).variable(o))});let l=Array.isArray(e)?e[s].tensor:e[r];if(l==null)return;let d=this.accumulatedFirstMoment[s].variable,u=this.accumulatedSecondMoment[s].variable,p=se(_(d,this.beta1),_(l,1-this.beta1)),c=se(_(u,this.beta2),_(st(l),1-this.beta2)),h=me(p,n),m=me(c,a);d.assign(p),u.assign(c);let f=se(_(me(h,se(Jt(m),this.epsilon)),-this.learningRate),i);i.assign(f)}),this.accBeta1.assign(_(this.accBeta1,this.beta1)),this.accBeta2.assign(_(this.accBeta2,this.beta2))}),this.incrementIterations()}dispose(){this.accBeta1.dispose(),this.accBeta2.dispose(),this.accumulatedFirstMoment!=null&&Ee(this.accumulatedFirstMoment.map(e=>e.variable)),this.accumulatedSecondMoment!=null&&Ee(this.accumulatedSecondMoment.map(e=>e.variable))}async getWeights(){let e=[...this.accumulatedFirstMoment,...this.accumulatedSecondMoment];return[await this.saveIterations()].concat(e.map(t=>({name:t.originalName,tensor:t.variable})))}async setWeights(e){e=await this.extractIterations(e),W(()=>{this.accBeta1.assign(rr(this.beta1,this.iterations_+1)),this.accBeta2.assign(rr(this.beta2,this.iterations_+1))});let t=e.length/2,n=!1;this.accumulatedFirstMoment=e.slice(0,t).map(a=>({originalName:a.name,variable:a.tensor.variable(n)})),this.accumulatedSecondMoment=e.slice(t,t*2).map(a=>({originalName:a.name,variable:a.tensor.variable(n)}))}getConfig(){return{learningRate:this.learningRate,beta1:this.beta1,beta2:this.beta2,epsilon:this.epsilon}}static fromConfig(e,t){return new e(t.learningRate,t.beta1,t.beta2,t.epsilon)}};Yc.className="Adam";Cr(Yc);var Jc=class extends ir{constructor(e,t,n,a=null,r=0){super();this.learningRate=e,this.beta1=t,this.beta2=n,this.epsilon=a,this.decay=r,this.accumulatedFirstMoment=[],this.accumulatedWeightedInfNorm=[],W(()=>{this.iteration=Se(0).variable(),this.accBeta1=Se(t).variable()}),a==null&&(this.epsilon=D.backend.epsilon())}applyGradients(e){let t=Array.isArray(e)?e.map(n=>n.name):Object.keys(e);W(()=>{let n=ge(1,this.accBeta1),a=me(-this.learningRate,se(_(this.iteration,this.decay),1));t.forEach((r,s)=>{let i=D.registeredVariables[r],o=!1;this.accumulatedFirstMoment[s]==null&&(this.accumulatedFirstMoment[s]={originalName:`${r}/m`,variable:Ue(i).variable(o)}),this.accumulatedWeightedInfNorm[s]==null&&(this.accumulatedWeightedInfNorm[s]={originalName:`${r}/v`,variable:Ue(i).variable(o)});let l=Array.isArray(e)?e[s].tensor:e[r];if(l==null)return;let d=this.accumulatedFirstMoment[s].variable,u=this.accumulatedWeightedInfNorm[s].variable,p=se(_(d,this.beta1),_(l,1-this.beta1)),c=_(u,this.beta2),h=Ot(l),m=_a(c,h);d.assign(p),u.assign(m);let f=se(_(me(a,n),me(p,se(m,this.epsilon))),i);i.assign(f)}),this.iteration.assign(se(this.iteration,1)),this.accBeta1.assign(_(this.accBeta1,this.beta1))}),this.incrementIterations()}dispose(){this.accBeta1.dispose(),this.iteration.dispose(),this.accumulatedFirstMoment!=null&&Ee(this.accumulatedFirstMoment.map(e=>e.variable)),this.accumulatedWeightedInfNorm!=null&&Ee(this.accumulatedWeightedInfNorm.map(e=>e.variable))}async getWeights(){throw new Error("getWeights() is not implemented for Adamax yet.")}async setWeights(e){throw new Error("setWeights() is not implemented for Adamax yet.")}getConfig(){return{learningRate:this.learningRate,beta1:this.beta1,beta2:this.beta2,epsilon:this.epsilon,decay:this.decay}}static fromConfig(e,t){return new e(t.learningRate,t.beta1,t.beta2,t.epsilon,t.decay)}};Jc.className="Adamax";Cr(Jc);var sd=class extends ir{constructor(e){super();this.learningRate=e,this.setLearningRate(e)}applyGradients(e){(Array.isArray(e)?e.map(t=>t.name):Object.keys(e)).forEach((t,n)=>{let a=Array.isArray(e)?e[n].tensor:e[t];if(a==null)return;let r=D.registeredVariables[t];W(()=>{let s=se(_(this.c,a),r);r.assign(s)})}),this.incrementIterations()}setLearningRate(e){this.learningRate=e,this.c!=null&&this.c.dispose(),this.c=jt(Se(-e))}dispose(){this.c.dispose()}async getWeights(){return[await this.saveIterations()]}async setWeights(e){if(e=await this.extractIterations(e),e.length!==0)throw new Error("SGD optimizer does not have settable weights.")}getConfig(){return{learningRate:this.learningRate}}static fromConfig(e,t){return new e(t.learningRate)}};sd.className="SGD";Cr(sd);var Qc=class extends sd{constructor(e,t,n=!1){super(e);this.learningRate=e,this.momentum=t,this.useNesterov=n,this.accumulations=[],this.m=Se(this.momentum)}applyGradients(e){(Array.isArray(e)?e.map(t=>t.name):Object.keys(e)).forEach((t,n)=>{let a=D.registeredVariables[t];if(this.accumulations[n]==null){let i=!1;this.accumulations[n]={originalName:`${t}/momentum`,variable:W(()=>Ue(a).variable(i))}}let r=this.accumulations[n].variable,s=Array.isArray(e)?e[n].tensor:e[t];s!=null&&W(()=>{let i,o=se(_(this.m,r),s);this.useNesterov?i=se(_(this.c,se(s,_(o,this.m))),a):i=se(_(this.c,o),a),r.assign(o),a.assign(i)})}),this.incrementIterations()}dispose(){this.m.dispose(),this.accumulations!=null&&Ee(this.accumulations.map(e=>e.variable))}setMomentum(e){this.momentum=e}async getWeights(){return[await this.saveIterations()].concat(this.accumulations.map(e=>({name:e.originalName,tensor:e.variable})))}async setWeights(e){e=await this.extractIterations(e);let t=!1;this.accumulations=e.map(n=>({originalName:n.name,variable:n.tensor.variable(t)}))}getConfig(){return{learningRate:this.learningRate,momentum:this.momentum,useNesterov:this.useNesterov}}static fromConfig(e,t){return new e(t.learningRate,t.momentum,t.useNesterov)}};Qc.className="Momentum";Cr(Qc);var eh=class extends ir{constructor(e,t=.9,n=0,a=null,r=!1){super();if(this.learningRate=e,this.decay=t,this.momentum=n,this.epsilon=a,this.accumulatedMeanSquares=[],this.accumulatedMoments=[],this.accumulatedMeanGrads=[],this.centered=r,a==null&&(this.epsilon=D.backend.epsilon()),e==null)throw new Error("learningRate for RMSPropOptimizer must be defined.")}applyGradients(e){(Array.isArray(e)?e.map(t=>t.name):Object.keys(e)).forEach((t,n)=>{let a=D.registeredVariables[t],r=!1;this.accumulatedMeanSquares[n]==null&&(this.accumulatedMeanSquares[n]={originalName:`${t}/rms`,variable:W(()=>Ue(a).variable(r))}),this.accumulatedMoments[n]==null&&(this.accumulatedMoments[n]={originalName:`${t}/momentum`,variable:W(()=>Ue(a).variable(r))}),this.accumulatedMeanGrads[n]==null&&this.centered&&(this.accumulatedMeanGrads[n]={originalName:`${t}/mg`,variable:W(()=>Ue(a).variable(r))});let s=Array.isArray(e)?e[n].tensor:e[t];if(s==null)return;let i=this.accumulatedMeanSquares[n].variable,o=this.accumulatedMoments[n].variable;W(()=>{let l=se(_(i,this.decay),_(st(s),1-this.decay));if(this.centered){let d=this.accumulatedMeanGrads[n].variable,u=se(_(d,this.decay),_(s,1-this.decay)),p=me(_(s,this.learningRate),Jt(ge(l,se(st(u),this.epsilon)))),c=se(_(o,this.momentum),p);i.assign(l),d.assign(u),o.assign(c);let h=ge(a,c);a.assign(h)}else{let d=se(_(i,this.decay),_(st(s),1-this.decay)),u=se(_(o,this.momentum),me(_(s,this.learningRate),Jt(se(d,this.epsilon))));i.assign(d),o.assign(u);let p=ge(a,u);a.assign(p)}})}),this.incrementIterations()}dispose(){this.accumulatedMeanSquares!=null&&Ee(this.accumulatedMeanSquares.map(e=>e.variable)),this.accumulatedMeanGrads!=null&&this.centered&&Ee(this.accumulatedMeanGrads.map(e=>e.variable)),this.accumulatedMoments!=null&&Ee(this.accumulatedMoments.map(e=>e.variable))}async getWeights(){let e=[...this.accumulatedMeanSquares,...this.accumulatedMoments];return this.centered&&e.push(...this.accumulatedMeanGrads),[await this.saveIterations()].concat(e.map(t=>({name:t.originalName,tensor:t.variable})))}async setWeights(e){e=await this.extractIterations(e);let t=this.centered?e.length/3:e.length/2,n=!1;this.accumulatedMeanSquares=e.slice(0,t).map(a=>({originalName:a.name,variable:a.tensor.variable(n)})),this.accumulatedMoments=e.slice(t,t*2).map(a=>({originalName:a.name,variable:a.tensor.variable(n)})),this.centered&&(this.accumulatedMeanGrads=e.slice(t*2,t*3).map(a=>({originalName:a.name,variable:a.tensor.variable(n)})))}getConfig(){return{learningRate:this.learningRate,decay:this.decay,momentum:this.momentum,epsilon:this.epsilon,centered:this.centered}}static fromConfig(e,t){return new e(t.learningRate,t.decay,t.momentum,t.epsilon,t.centered)}};eh.className="RMSProp";Cr(eh);var Ai=class{static sgd(e){return new sd(e)}static momentum(e,t,n=!1){return new Qc(e,t,n)}static rmsprop(e,t=.9,n=0,a=null,r=!1){return new eh(e,t,n,a,r)}static adam(e=.001,t=.9,n=.999,a=null){return new Yc(e,t,n,a)}static adadelta(e=.001,t=.95,n=null){return new Kc(e,t,n)}static adamax(e=.002,t=.9,n=.999,a=null,r=0){return new Jc(e,t,n,a,r)}static adagrad(e,t=.1){return new Zc(e,t)}},yi={sgd:Ai.sgd,momentum:Ai.momentum,adadelta:Ai.adadelta,adagrad:Ai.adagrad,rmsprop:Ai.rmsprop,adamax:Ai.adamax,adam:Ai.adam},iF=(()=>typeof requestAnimationFrame!="undefined"?requestAnimationFrame:typeof setImmediate!="undefined"?setImmediate:e=>e())();function th(){return new Promise(e=>iF(()=>e()))}var C={};Fe(C,{ERF_A1:()=>yF,ERF_A2:()=>gF,ERF_A3:()=>xF,ERF_A4:()=>bF,ERF_A5:()=>vF,ERF_P:()=>AF,PARALLELIZE_THRESHOLD:()=>BA,SELU_SCALE:()=>x3,SELU_SCALEALPHA:()=>g3,applyActivation:()=>qc,assertAndGetBroadcastShape:()=>pt,assertAxesAreInnerMostDims:()=>DE,assertParamsConsistent:()=>oF,assignToTypedArray:()=>CF,axesAreInnerMostDims:()=>bA,calculateShapes:()=>ob,checkEinsumDimSizes:()=>DF,combineLocations:()=>jb,complexWithEvenIndex:()=>NF,complexWithOddIndex:()=>TF,computeConv2DInfo:()=>Hu,computeConv3DInfo:()=>Nb,computeDefaultPad:()=>iA,computeDilation2DInfo:()=>rT,computeOptimalWindowSize:()=>uF,computeOutAndReduceShapes:()=>Ub,computeOutShape:()=>lF,computePool2DInfo:()=>Sb,computePool3DInfo:()=>sT,convertConv2DDataFormat:()=>Ib,decodeEinsumEquation:()=>FF,eitherStridesOrDilationsAreOne:()=>Oa,expandShapeToKeepDim:()=>fi,exponent:()=>MF,exponents:()=>RF,fromStringArrayToUint8:()=>LF,fromUint8ToStringArray:()=>PF,getAxesPermutation:()=>Hb,getBroadcastDims:()=>KT,getComplexWithIndex:()=>EF,getEinsumComputePath:()=>OF,getEinsumPermutation:()=>$F,getFusedBiasGradient:()=>Gc,getFusedDyActivation:()=>Hc,getImageCenter:()=>dF,getInnerMostAxes:()=>OE,getPermuted:()=>cF,getReductionAxes:()=>zt,getReshaped:()=>pF,getReshapedPermuted:()=>hF,getSliceBeginCoords:()=>fF,getSliceSize:()=>mF,getUndoAxesPermutation:()=>vA,isIdentityPermutation:()=>zF,log:()=>kF,mergeRealAndImagArrays:()=>IF,prepareAndValidate:()=>ib,prepareSplitSize:()=>_F,segment_util:()=>b3,shouldFuse:()=>Xc,slice_util:()=>on,splitRealAndImagArrays:()=>SF,tupleValuesAreOne:()=>Rr,upcastType:()=>sa,validateInput:()=>Hm,validateUpdateShape:()=>Um,warn:()=>wF});function oF(e,t){let n=e[0].length;e.forEach((r,s)=>{F(r.length===n,()=>`Error in concat${n}D: rank of tensors[${s}] must be the same as the rank of the rest (${n})`)}),F(t>=0&&t`Error in concat${n}D: axis must be between 0 and ${n-1}.`);let a=e[0];e.forEach((r,s)=>{for(let i=0;i`Error in concat${n}D: Shape of tensors[${s}] (${r}) does not match the shape of the rest (${a}) along the non-concatenated axis ${s}.`)})}function lF(e,t){let n=e[0].slice();for(let a=1;a=t*2+1||i%2==1?s.push(i):r.push(i);a.push(...r),a.push(0),a.push(...s)}return a}function hF(e,t,n,a=!0){let r=[];a?r.push(e[0]/n):r.push(e[0]*n);for(let s=1;s/g,v3=",",w3="...";function FF(e,t){e=e.replace(/\s/g,"");let n=(e.length-e.replace(WF,"").length)/VA.length;if(n<1)throw new Error("Equations without an arrow are not supported.");if(n>1)throw new Error(`Equation must contain exactly one arrow ("${VA}").`);let[a,r]=e.split(VA);F(a.indexOf(w3)===-1,()=>`The ellipsis notation ("${w3}") is not supported yet.`);let s=a.split(v3),i=s.length;if(t!==i)throw new Error(`Expected ${i} input tensors, received ${t}`);if(i>2)throw new Error("Support for more than 2 input tensors is not implemented yet.");let o=[];for(let c=0;cm.indexOf(h)!==-1))throw new Error(`Output subscripts contain the label ${h} not present in the input subscripts.`);o.indexOf(h)===-1&&o.push(h)}for(let c=0;cr!==-1),{permutationIndices:n,expandDims:a}}function DF(e,t,n){let a=new Array(e);for(let r=0;r`Expected dimension ${a[t[r][i]]} at axis ${i} of input shaped ${JSON.stringify(s)}, but got dimension ${s[i]}`)}}function OF(e,t){let n=e,a=[],r=0;e.length===0&&n.push(-1),r=e.length+1;for(let i=0;it===n)}function BF(e,t){let n=[];for(let a=0;a"Number of splits must evenly divide the axis."),a=new Array(t).fill(e.shape[n]/t);else{let r=t.reduce((i,o)=>(o===-1&&(i+=1),i),0);F(r<=1,()=>"There should be only one negative value in split array.");let s=t.indexOf(-1);if(s!==-1){let i=t.reduce((o,l)=>l>0?o+l:o);t[s]=e.shape[n]-i}F(e.shape[n]===t.reduce((i,o)=>i+o),()=>"The sum of sizes must match the size of the axis dimension."),a=t}return a}var b3={};Fe(b3,{collectGatherOpShapeInfo:()=>UF,computeOutShape:()=>jF,segOpComputeOptimalWindowSize:()=>VF});function VF(e,t){let n=!1,a;for(e<=BA?(a=e,n=!0):a=Np(e,Math.floor(Math.sqrt(e)));!n;)a>t||a===e?n=!0:a=Np(e,a+1);return a}function jF(e,t,n){let a=[],r=e.length;for(let s=0;sr))throw new Error(`Expect batchDims in the range of [-${r}, ${r}], but got ${a}`);if(a<0&&(a+=r),a>s)throw new Error(`batchDims (${a}) must be less than rank(x) ( + ${s}).`);if(nlc(t))}catch(t){throw new Error(`Failed to decode encoded string bytes into utf-8, error: ${t}`)}}function LF(e){return e.map(t=>Du(t))}var La={};Fe(La,{nonMaxSuppressionV3Impl:()=>u3,nonMaxSuppressionV4Impl:()=>d3,nonMaxSuppressionV5Impl:()=>p3,whereImpl:()=>Qb});function ve(e,t){Array.isArray(e)||(e=[e]),e.forEach(n=>{n!=null&&k.assert(n.dtype!=="complex64",()=>`${t} does not support complex64 tensors in the CPU backend.`)})}var HF=La.whereImpl,nh=class extends hu{constructor(){super();this.blockSize=48,this.firstUse=!0,this.data=new Ip(this,tr())}nextDataId(){return nh.nextDataId++}write(e,t,n){this.firstUse&&(this.firstUse=!1,J().get("IS_NODE")&&C.warn(` ============================ Hi there \u{1F44B}. Looks like you are running TensorFlow.js in Node.js. To speed things up dramatically, install our node backend, which binds to TensorFlow C++, by running npm i @tensorflow/tfjs-node, or npm i @tensorflow/tfjs-node-gpu if you have CUDA. Then call require('@tensorflow/tfjs-node'); (-gpu suffix for CUDA) at the start of your program. Visit https://github.com/tensorflow/tfjs-node for more details. -============================`));let a={id:this.nextDataId()};return this.data.set(a,{values:e,dtype:n,refCount:1}),a}makeTensorInfo(e,t,n){let a;if(t==="string"&&n!=null&&n.length>0&&k.isString(n[0])){let r=n.map(s=>k.encodeString(s));a=this.write(r,e,t)}else a=this.write(n,e,t);return{dataId:a,shape:e,dtype:t}}refCount(e){return this.data.has(e)?this.data.get(e).refCount:0}incRef(e){let t=this.data.get(e);t.refCount++}decRef(e){if(this.data.has(e)){let t=this.data.get(e);t.refCount--}}move(e,t,n,a,r){this.data.set(e,{values:t,dtype:a,refCount:r})}numDataIds(){return this.data.numDataIds()}async read(e){return this.readSync(e)}readSync(e){let{dtype:t,complexTensorInfos:n}=this.data.get(e);if(t==="complex64"){let a=this.readSync(n.real.dataId),r=this.readSync(n.imag.dataId);return C.mergeRealAndImagArrays(a,r)}return this.data.get(e).values}bufferSync(e){let t=this.readSync(e.dataId),n=t;if(e.dtype==="string")try{n=t.map(a=>k.decodeString(a))}catch(a){throw new Error("Failed to decode encoded string bytes into utf-8")}return We(e.shape,e.dtype,n)}makeOutput(e,t,n){let a=this.write(e,t,n);return nr().makeTensorFromDataId(a,t,n,this)}disposeData(e,t=!1){if(this.data.has(e)){if(this.data.get(e).refCount--,!t&&this.data.get(e).refCount>0)return!1;let{complexTensorInfos:n}=this.data.get(e);n!=null&&(this.disposeData(n.real.dataId,!0),this.disposeData(n.imag.dataId,!0)),this.data.delete(e)}return!0}disposeIntermediateTensorInfo(e){this.disposeData(e.dataId)}async time(e){let t=k.now();return e(),{kernelMs:k.now()-t}}memory(){return{unreliable:!0,reasons:["The reported memory is an upper bound. Due to automatic garbage collection, the true allocated memory may be less."]}}where(e){ve([e],"where");let t=this.readSync(e.dataId);return HF(e.shape,t)}dispose(){}floatPrecision(){return 32}epsilon(){return super.epsilon()}};nh.nextDataId=0;var jA={};Fe(jA,{addImpl:()=>I3,bincountImpl:()=>UA,bincountReduceImpl:()=>S3,ceilImpl:()=>N3,concatImpl:()=>HA,expImpl:()=>T3,expm1Impl:()=>E3,floorImpl:()=>C3,gatherV2Impl:()=>R3,greaterImpl:()=>M3,lessImpl:()=>F3,linSpaceImpl:()=>$3,logImpl:()=>D3,maxImpl:()=>O3,maximumImpl:()=>z3,minimumImpl:()=>_3,multiplyImpl:()=>GA,negImpl:()=>P3,notEqualImpl:()=>L3,prodImpl:()=>W3,rangeImpl:()=>XA,rsqrtImpl:()=>B3,simpleAbsImpl:()=>k3,sliceImpl:()=>ah,sparseFillEmptyRowsImpl:()=>V3,sparseReshapeImpl:()=>j3,squaredDifferenceImpl:()=>U3,stridedSliceImpl:()=>H3,subImpl:()=>G3,tileImpl:()=>q3,topKImpl:()=>X3,transposeImpl:()=>qA,uniqueImpl:()=>K3});function k3(e){let t=new Float32Array(e.length);for(let n=0;n{let{x:t}=e.inputs,n=e.backend;ve(t,"abs");let a=new Float32Array(k.sizeFromShape(t.shape)),r=n.data.get(t.dataId).values;return a=k3(r),n.makeOutput(a,t.shape,"float32")},qF={kernelName:eo,backendName:"cpu",kernelFunc:GF};function Mt(e){return(t,n,a,r,s)=>{let i=C.assertAndGetBroadcastShape(t,n),o=i.length,l=k.computeStrides(i),d=k.sizeFromShape(i),u=k.getTypedArrayFromDType(s,d),p=t.length,c=n.length,h=k.computeStrides(t),m=k.computeStrides(n),f=C.getBroadcastDims(t,i),A=C.getBroadcastDims(n,i);if(f.length+A.length===0)for(let y=0;yx[N]=0);let w=k.locToIndex(x,p,h),b=g.slice(-c);A.forEach(N=>b[N]=0);let v=k.locToIndex(b,c,m);u[y]=e(a[w],r[v])}return[u,i]}}function Pn(e){let{inputs:t,backend:n}=e,{real:a,imag:r}=t,s=n.data.get(a.dataId).values,i=n.data.get(r.dataId).values,o=n.makeTensorInfo(a.shape,"complex64"),l=n.data.get(o.dataId);return l.complexTensorInfos={real:n.makeTensorInfo(a.shape,"float32",s),imag:n.makeTensorInfo(r.shape,"float32",i)},o}var XF={kernelName:Mp,backendName:"cpu",kernelFunc:Pn};function rh(e,t,n="float32"){if(n==="complex64"){let r=rh(e,t,"float32"),s=rh(e,t,"float32");return Pn({inputs:{real:r,imag:s},backend:e})}let a=k.makeZerosTypedArray(k.sizeFromShape(t),n);return e.makeTensorInfo(t,n,a)}function Ba(e){let{inputs:t,backend:n}=e,{x:a}=t;return n.incRef(a.dataId),{dataId:a.dataId,shape:a.shape,dtype:a.dtype}}var KF={kernelName:Is,backendName:"cpu",kernelFunc:Ba};function xi(e){let{inputs:t,backend:n}=e,{input:a}=t,r=n.data.get(a.dataId).complexTensorInfos.real,s=n.data.get(r.dataId).values;return n.makeTensorInfo(r.shape,r.dtype,s)}var ZF={kernelName:Jp,backendName:"cpu",kernelFunc:xi};function Pr(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{dtype:s}=a;if(s==="complex64"){if(r.dtype==="complex64")return Ba({inputs:{x:r},backend:n});let i=rh(n,r.shape,r.dtype),o=Pr({inputs:{x:r},backend:n,attrs:{dtype:"float32"}}),l=Pn({inputs:{real:o,imag:i},backend:n});return n.disposeIntermediateTensorInfo(i),n.disposeIntermediateTensorInfo(o),l}if(r.dtype==="complex64"){let i=xi({inputs:{input:r},backend:n}),o=Pr({inputs:{x:i},backend:n,attrs:{dtype:s}});return n.disposeIntermediateTensorInfo(i),o}if(!k.hasEncodingLoss(r.dtype,s)){let i=Ba({inputs:{x:r},backend:n});return{dataId:i.dataId,shape:i.shape,dtype:s}}if(s==="int32"){let i=n.data.get(r.dataId).values,o=Int32Array.from(i);return n.makeTensorInfo(r.shape,"int32",o)}if(s==="bool"){let i=n.data.get(r.dataId).values,o=k.toTypedArray([0],r.dtype),[l,d]=Mt((u,p)=>u!==p?1:0)(r.shape,[],i,o,"bool");return n.makeTensorInfo(d,"bool",l)}throw new Error(`Error in Cast: failed to cast ${r.dtype} to ${s}`)}var YF={kernelName:ps,backendName:"cpu",kernelFunc:Pr};function Ht(e,t,n,a){return n==null?({inputs:r,backend:s})=>{let{a:i,b:o}=r,l=s;ve([i,o],e);let d=l.data.get(i.dataId).values,u=l.data.get(o.dataId).values,p=a||i.dtype,[c,h]=t(i.shape,o.shape,d,u,p);return l.makeTensorInfo(h,p,c)}:({inputs:r,backend:s})=>{let{a:i,b:o}=r,l=s;if(i.dtype==="complex64"||o.dtype==="complex64"){let d=Pr({inputs:{x:i},backend:l,attrs:{dtype:"complex64"}}),u=l.data.get(d.dataId),p=u.complexTensorInfos.real,c=u.complexTensorInfos.imag,h=l.data.get(p.dataId).values,m=l.data.get(c.dataId).values,f=Pr({inputs:{x:o},backend:l,attrs:{dtype:"complex64"}}),A=l.data.get(f.dataId),y=A.complexTensorInfos.real,g=A.complexTensorInfos.imag,x=l.data.get(y.dataId).values,w=l.data.get(g.dataId).values,[b,v,N]=n(i.shape,o.shape,h,m,x,w),T=l.makeTensorInfo(N,"float32",b),R=l.makeTensorInfo(N,"float32",v),$=Pn({inputs:{real:T,imag:R},backend:l});return l.disposeIntermediateTensorInfo(d),l.disposeIntermediateTensorInfo(f),l.disposeIntermediateTensorInfo(T),l.disposeIntermediateTensorInfo(R),$}else{let d=l.data.get(i.dataId).values,u=l.data.get(o.dataId).values,p=a||i.dtype,[c,h]=t(i.shape,o.shape,d,u,p);return l.makeTensorInfo(h,p,c)}}}function KA(e){return(t,n,a,r,s,i)=>{let o=C.assertAndGetBroadcastShape(t,n),l=k.sizeFromShape(o),d=o.length,u=k.computeStrides(o),p=k.getTypedArrayFromDType("float32",l),c=k.getTypedArrayFromDType("float32",l),h=C.getBroadcastDims(t,o),m=C.getBroadcastDims(n,o),f=C.mergeRealAndImagArrays(a,r),A=C.mergeRealAndImagArrays(s,i),y=t.length,g=k.computeStrides(t),x=n.length,w=k.computeStrides(n);if(h.length+m.length===0)for(let b=0;bN[P]=0);let T=k.locToIndex(N,y,g),R=v.slice(-x);m.forEach(P=>R[P]=0);let $=k.locToIndex(R,x,w),z=e(f[T*2],f[T*2+1],A[$*2],A[$*2+1]);p[b]=z.real,c[b]=z.imag}return[p,c,o]}}var I3=Mt((e,t)=>e+t),JF=KA((e,t,n,a)=>({real:e+n,imag:t+a})),id=Ht(kr,I3,JF),QF={kernelName:kr,backendName:"cpu",kernelFunc:id};function UA(e,t,n,a,r){let s=k.sizeFromShape(a),i=k.makeZerosTypedArray(r,n);for(let o=0;o=r||(s>0?i[l]+=t[o]:i[l]+=1)}return i}function S3(e,t,n,a=!1){let r=e.shape[0],s=e.shape[1],i=We([r,n],t.dtype);for(let o=0;o=n||(a?i.set(1,o,d):t.size>0?i.set(i.get(o,d)+t.get(o,l),o,d):i.set(i.get(o,d)+1,o,d))}return i}function Sl(e){return(t,n,a)=>{let r=k.getTypedArrayFromDType(n,t.length);for(let s=0;s{let{x:i}=a;if(ve(i,e),i.dtype==="string"||n==="string")throw new Error("unaryKernelFunc does not support string input/output");let o=s,l=o.data.get(i.dataId).values,d=k.sizeFromShape(i.shape),u=n||i.dtype,p=k.getArrayFromDType(u,d);for(let c=0;c{let{x:i}=a;if(ve(i,e),i.dtype==="string"||n==="string")throw new Error("unaryKernelFunc does not support string input/output");let o=s,l=o.data.get(i.dataId).values,d=n||i.dtype,u=t(l,d,r);return o.makeTensorInfo(i.shape,d,u)}}var N3=Sl(e=>Math.ceil(e)),e$=Nl(cs,N3),t$={kernelName:cs,backendName:"cpu",kernelFunc:e$};function HA(e,t,n,a){let r=k.getArrayFromDType(n,k.sizeFromShape(t));if(a&&n!=="string"){let s=0;e.forEach(i=>{let o=k.sizeFromShape(i.shape);r.set(i.vals,s),s+=o})}else{let s=0;e.forEach(i=>{let o=n==="string"?C.fromUint8ToStringArray(i.vals):i.vals,l=0;for(let d=0;dMath.exp(e)),Z3=Nl(xs,T3),n$={kernelName:xs,backendName:"cpu",kernelFunc:Z3},E3=Sl(e=>Math.expm1(e)),a$=Nl(xo,E3),r$={kernelName:xo,backendName:"cpu",kernelFunc:a$},C3=Sl(e=>Math.floor(e)),s$=Nl(bs,C3),i$={kernelName:bs,backendName:"cpu",kernelFunc:s$};function R3(e,t,n){let a=We(n,e.dtype);for(let r=0;re>t?1:0),o$=Ht(ko,M3,null,"bool"),l$={kernelName:ko,backendName:"cpu",kernelFunc:o$},F3=Mt((e,t)=>eMath.log(e)),p$=Nl(Ns,D3),c$={kernelName:Ns,backendName:"cpu",kernelFunc:p$};function O3(e,t,n,a){let r=k.getTypedArrayFromDType(a,k.sizeFromShape(n));for(let s=0;so&&(o=d)}r[s]=o}return r}var z3=Mt((e,t)=>Math.max(e,t)),h$=Ht(Es,z3),f$={kernelName:Es,backendName:"cpu",kernelFunc:h$},_3=Mt((e,t)=>Math.min(e,t)),m$=Ht(Fs,_3),A$={kernelName:Fs,backendName:"cpu",kernelFunc:m$},GA=Mt((e,t)=>e*t),y$=KA((e,t,n,a)=>({real:e*n-t*a,imag:e*a+t*n})),sh=Ht(Ds,GA,y$),g$={kernelName:Ds,backendName:"cpu",kernelFunc:sh};function P3(e,t,n){let a=k.createScalarValue(-1,n);return GA([],t,a,e,n)}function x$(e){let{inputs:t,backend:n}=e,{x:a}=t;ve(a,"neg");let r=n.data.get(a.dataId).values,[s,i]=P3(r,a.shape,a.dtype);return n.makeTensorInfo(i,a.dtype,s)}var b$={kernelName:Fo,backendName:"cpu",kernelFunc:x$},L3=Mt((e,t)=>e!==t?1:0),v$=Ht($o,L3,null,"bool"),w$={kernelName:$o,backendName:"cpu",kernelFunc:v$};function qA(e,t,n,a,r){let s=t.length,i=k.sizeFromShape(t),o=k.computeStrides(t),l=k.computeStrides(r),d=k.getTypedArrayFromDType(n,k.sizeFromShape(r));for(let u=0;un.disposeIntermediateTensorInfo(g)),n.makeTensorInfo(y,A,m)}var S$={kernelName:Lo,backendName:"cpu",kernelFunc:I$};function XA(e,t,n,a){let r=e===t,s=e1;if(r||s||i)return k.makeZerosTypedArray(0,a);let o=Math.abs(Math.ceil((t-e)/n)),l=k.makeZerosTypedArray(o,a);t1/Math.sqrt(e)),N$=Nl(Us,B3),T$={kernelName:Us,backendName:"cpu",kernelFunc:N$};function ah(e,t,n,a,r){let s=ln.isSliceContinous(a,t,n),i=k.sizeFromShape(n),o=k.computeStrides(a);if(s){let p=ln.computeFlatOffset(t,o);return r==="string"?e.slice(p,p+i):e.subarray(p,p+i)}let l=r==="string"?C.fromUint8ToStringArray(e):e,d=We(a,r,l),u=We(n,r);for(let p=0;pm+t[f]);u.set(d.get(...h),...c)}return r==="string"?C.fromStringArrayToUint8(u.values):u.values}function bi(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{begin:s,size:i}=a;ve(r,"slice");let[o,l]=ln.parseSliceParams(r,s,i);ln.assertParamsValid(r,o,l);let d=n.data.get(r.dataId).values,u=ah(d,o,l,r.shape,r.dtype);return n.makeTensorInfo(l,r.dtype,u)}var E$={kernelName:Ho,backendName:"cpu",kernelFunc:bi};function V3(e,t,n,a,r,s,i){let o=t[0],l=s[0],d=new Array(l),u=new Array(o),p=t[1];if(l===0){if(o!==0)throw new Error(`Received SparseTensor with denseShape[0] = 0 but +============================`));let a={id:this.nextDataId()};return this.data.set(a,{values:e,dtype:n,refCount:1}),a}makeTensorInfo(e,t,n){let a;if(t==="string"&&n!=null&&n.length>0&&k.isString(n[0])){let r=n.map(s=>k.encodeString(s));a=this.write(r,e,t)}else a=this.write(n,e,t);return{dataId:a,shape:e,dtype:t}}refCount(e){return this.data.has(e)?this.data.get(e).refCount:0}incRef(e){let t=this.data.get(e);t.refCount++}decRef(e){if(this.data.has(e)){let t=this.data.get(e);t.refCount--}}move(e,t,n,a,r){this.data.set(e,{values:t,dtype:a,refCount:r})}numDataIds(){return this.data.numDataIds()}async read(e){return this.readSync(e)}readSync(e){let{dtype:t,complexTensorInfos:n}=this.data.get(e);if(t==="complex64"){let a=this.readSync(n.real.dataId),r=this.readSync(n.imag.dataId);return C.mergeRealAndImagArrays(a,r)}return this.data.get(e).values}bufferSync(e){let t=this.readSync(e.dataId),n=t;if(e.dtype==="string")try{n=t.map(a=>k.decodeString(a))}catch(a){throw new Error("Failed to decode encoded string bytes into utf-8")}return We(e.shape,e.dtype,n)}makeOutput(e,t,n){let a=this.write(e,t,n);return tr().makeTensorFromDataId(a,t,n,this)}disposeData(e,t=!1){if(this.data.has(e)){if(this.data.get(e).refCount--,!t&&this.data.get(e).refCount>0)return!1;let{complexTensorInfos:n}=this.data.get(e);n!=null&&(this.disposeData(n.real.dataId,!0),this.disposeData(n.imag.dataId,!0)),this.data.delete(e)}return!0}disposeIntermediateTensorInfo(e){this.disposeData(e.dataId)}async time(e){let t=k.now();return e(),{kernelMs:k.now()-t}}memory(){return{unreliable:!0,reasons:["The reported memory is an upper bound. Due to automatic garbage collection, the true allocated memory may be less."]}}where(e){ve([e],"where");let t=this.readSync(e.dataId);return HF(e.shape,t)}dispose(){}floatPrecision(){return 32}epsilon(){return super.epsilon()}};nh.nextDataId=0;var jA={};Fe(jA,{addImpl:()=>I3,bincountImpl:()=>UA,bincountReduceImpl:()=>S3,ceilImpl:()=>N3,concatImpl:()=>HA,expImpl:()=>T3,expm1Impl:()=>E3,floorImpl:()=>C3,gatherV2Impl:()=>R3,greaterImpl:()=>M3,lessImpl:()=>F3,linSpaceImpl:()=>$3,logImpl:()=>D3,maxImpl:()=>O3,maximumImpl:()=>z3,minimumImpl:()=>_3,multiplyImpl:()=>GA,negImpl:()=>P3,notEqualImpl:()=>L3,prodImpl:()=>W3,rangeImpl:()=>XA,rsqrtImpl:()=>B3,simpleAbsImpl:()=>k3,sliceImpl:()=>ah,sparseFillEmptyRowsImpl:()=>V3,sparseReshapeImpl:()=>j3,squaredDifferenceImpl:()=>U3,stridedSliceImpl:()=>H3,subImpl:()=>G3,tileImpl:()=>q3,topKImpl:()=>X3,transposeImpl:()=>qA,uniqueImpl:()=>K3});function k3(e){let t=new Float32Array(e.length);for(let n=0;n{let{x:t}=e.inputs,n=e.backend;ve(t,"abs");let a=new Float32Array(k.sizeFromShape(t.shape)),r=n.data.get(t.dataId).values;return a=k3(r),n.makeOutput(a,t.shape,"float32")},qF={kernelName:Qi,backendName:"cpu",kernelFunc:GF};function Rt(e){return(t,n,a,r,s)=>{let i=C.assertAndGetBroadcastShape(t,n),o=i.length,l=k.computeStrides(i),d=k.sizeFromShape(i),u=k.getTypedArrayFromDType(s,d),p=t.length,c=n.length,h=k.computeStrides(t),m=k.computeStrides(n),f=C.getBroadcastDims(t,i),A=C.getBroadcastDims(n,i);if(f.length+A.length===0)for(let y=0;yx[N]=0);let w=k.locToIndex(x,p,h),b=g.slice(-c);A.forEach(N=>b[N]=0);let v=k.locToIndex(b,c,m);u[y]=e(a[w],r[v])}return[u,i]}}function _n(e){let{inputs:t,backend:n}=e,{real:a,imag:r}=t,s=n.data.get(a.dataId).values,i=n.data.get(r.dataId).values,o=n.makeTensorInfo(a.shape,"complex64"),l=n.data.get(o.dataId);return l.complexTensorInfos={real:n.makeTensorInfo(a.shape,"float32",s),imag:n.makeTensorInfo(r.shape,"float32",i)},o}var XF={kernelName:Mp,backendName:"cpu",kernelFunc:_n};function rh(e,t,n="float32"){if(n==="complex64"){let r=rh(e,t,"float32"),s=rh(e,t,"float32");return _n({inputs:{real:r,imag:s},backend:e})}let a=k.makeZerosTypedArray(k.sizeFromShape(t),n);return e.makeTensorInfo(t,n,a)}function Wa(e){let{inputs:t,backend:n}=e,{x:a}=t;return n.incRef(a.dataId),{dataId:a.dataId,shape:a.shape,dtype:a.dtype}}var KF={kernelName:ks,backendName:"cpu",kernelFunc:Wa};function gi(e){let{inputs:t,backend:n}=e,{input:a}=t,r=n.data.get(a.dataId).complexTensorInfos.real,s=n.data.get(r.dataId).values;return n.makeTensorInfo(r.shape,r.dtype,s)}var ZF={kernelName:Jp,backendName:"cpu",kernelFunc:gi};function _r(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{dtype:s}=a;if(s==="complex64"){if(r.dtype==="complex64")return Wa({inputs:{x:r},backend:n});let i=rh(n,r.shape,r.dtype),o=_r({inputs:{x:r},backend:n,attrs:{dtype:"float32"}}),l=_n({inputs:{real:o,imag:i},backend:n});return n.disposeIntermediateTensorInfo(i),n.disposeIntermediateTensorInfo(o),l}if(r.dtype==="complex64"){let i=gi({inputs:{input:r},backend:n}),o=_r({inputs:{x:i},backend:n,attrs:{dtype:s}});return n.disposeIntermediateTensorInfo(i),o}if(!k.hasEncodingLoss(r.dtype,s)){let i=Wa({inputs:{x:r},backend:n});return{dataId:i.dataId,shape:i.shape,dtype:s}}if(s==="int32"){let i=n.data.get(r.dataId).values,o=Int32Array.from(i);return n.makeTensorInfo(r.shape,"int32",o)}if(s==="bool"){let i=n.data.get(r.dataId).values,o=k.toTypedArray([0],r.dtype),[l,d]=Rt((u,p)=>u!==p?1:0)(r.shape,[],i,o,"bool");return n.makeTensorInfo(d,"bool",l)}throw new Error(`Error in Cast: failed to cast ${r.dtype} to ${s}`)}var YF={kernelName:ds,backendName:"cpu",kernelFunc:_r};function Ut(e,t,n,a){return n==null?({inputs:r,backend:s})=>{let{a:i,b:o}=r,l=s;ve([i,o],e);let d=l.data.get(i.dataId).values,u=l.data.get(o.dataId).values,p=a||i.dtype,[c,h]=t(i.shape,o.shape,d,u,p);return l.makeTensorInfo(h,p,c)}:({inputs:r,backend:s})=>{let{a:i,b:o}=r,l=s;if(i.dtype==="complex64"||o.dtype==="complex64"){let d=_r({inputs:{x:i},backend:l,attrs:{dtype:"complex64"}}),u=l.data.get(d.dataId),p=u.complexTensorInfos.real,c=u.complexTensorInfos.imag,h=l.data.get(p.dataId).values,m=l.data.get(c.dataId).values,f=_r({inputs:{x:o},backend:l,attrs:{dtype:"complex64"}}),A=l.data.get(f.dataId),y=A.complexTensorInfos.real,g=A.complexTensorInfos.imag,x=l.data.get(y.dataId).values,w=l.data.get(g.dataId).values,[b,v,N]=n(i.shape,o.shape,h,m,x,w),T=l.makeTensorInfo(N,"float32",b),R=l.makeTensorInfo(N,"float32",v),$=_n({inputs:{real:T,imag:R},backend:l});return l.disposeIntermediateTensorInfo(d),l.disposeIntermediateTensorInfo(f),l.disposeIntermediateTensorInfo(T),l.disposeIntermediateTensorInfo(R),$}else{let d=l.data.get(i.dataId).values,u=l.data.get(o.dataId).values,p=a||i.dtype,[c,h]=t(i.shape,o.shape,d,u,p);return l.makeTensorInfo(h,p,c)}}}function KA(e){return(t,n,a,r,s,i)=>{let o=C.assertAndGetBroadcastShape(t,n),l=k.sizeFromShape(o),d=o.length,u=k.computeStrides(o),p=k.getTypedArrayFromDType("float32",l),c=k.getTypedArrayFromDType("float32",l),h=C.getBroadcastDims(t,o),m=C.getBroadcastDims(n,o),f=C.mergeRealAndImagArrays(a,r),A=C.mergeRealAndImagArrays(s,i),y=t.length,g=k.computeStrides(t),x=n.length,w=k.computeStrides(n);if(h.length+m.length===0)for(let b=0;bN[P]=0);let T=k.locToIndex(N,y,g),R=v.slice(-x);m.forEach(P=>R[P]=0);let $=k.locToIndex(R,x,w),z=e(f[T*2],f[T*2+1],A[$*2],A[$*2+1]);p[b]=z.real,c[b]=z.imag}return[p,c,o]}}var I3=Rt((e,t)=>e+t),JF=KA((e,t,n,a)=>({real:e+n,imag:t+a})),id=Ut(wr,I3,JF),QF={kernelName:wr,backendName:"cpu",kernelFunc:id};function UA(e,t,n,a,r){let s=k.sizeFromShape(a),i=k.makeZerosTypedArray(r,n);for(let o=0;o=r||(s>0?i[l]+=t[o]:i[l]+=1)}return i}function S3(e,t,n,a=!1){let r=e.shape[0],s=e.shape[1],i=We([r,n],t.dtype);for(let o=0;o=n||(a?i.set(1,o,d):t.size>0?i.set(i.get(o,d)+t.get(o,l),o,d):i.set(i.get(o,d)+1,o,d))}return i}function Il(e){return(t,n,a)=>{let r=k.getTypedArrayFromDType(n,t.length);for(let s=0;s{let{x:i}=a;if(ve(i,e),i.dtype==="string"||n==="string")throw new Error("unaryKernelFunc does not support string input/output");let o=s,l=o.data.get(i.dataId).values,d=k.sizeFromShape(i.shape),u=n||i.dtype,p=k.getArrayFromDType(u,d);for(let c=0;c{let{x:i}=a;if(ve(i,e),i.dtype==="string"||n==="string")throw new Error("unaryKernelFunc does not support string input/output");let o=s,l=o.data.get(i.dataId).values,d=n||i.dtype,u=t(l,d,r);return o.makeTensorInfo(i.shape,d,u)}}var N3=Il(e=>Math.ceil(e)),e$=Sl(ps,N3),t$={kernelName:ps,backendName:"cpu",kernelFunc:e$};function HA(e,t,n,a){let r=k.getArrayFromDType(n,k.sizeFromShape(t));if(a&&n!=="string"){let s=0;e.forEach(i=>{let o=k.sizeFromShape(i.shape);r.set(i.vals,s),s+=o})}else{let s=0;e.forEach(i=>{let o=n==="string"?C.fromUint8ToStringArray(i.vals):i.vals,l=0;for(let d=0;dMath.exp(e)),Z3=Sl(gs,T3),n$={kernelName:gs,backendName:"cpu",kernelFunc:Z3},E3=Il(e=>Math.expm1(e)),a$=Sl(go,E3),r$={kernelName:go,backendName:"cpu",kernelFunc:a$},C3=Il(e=>Math.floor(e)),s$=Sl(xs,C3),i$={kernelName:xs,backendName:"cpu",kernelFunc:s$};function R3(e,t,n){let a=We(n,e.dtype);for(let r=0;re>t?1:0),o$=Ut(wo,M3,null,"bool"),l$={kernelName:wo,backendName:"cpu",kernelFunc:o$},F3=Rt((e,t)=>eMath.log(e)),p$=Sl(Ss,D3),c$={kernelName:Ss,backendName:"cpu",kernelFunc:p$};function O3(e,t,n,a){let r=k.getTypedArrayFromDType(a,k.sizeFromShape(n));for(let s=0;so&&(o=d)}r[s]=o}return r}var z3=Rt((e,t)=>Math.max(e,t)),h$=Ut(Ts,z3),f$={kernelName:Ts,backendName:"cpu",kernelFunc:h$},_3=Rt((e,t)=>Math.min(e,t)),m$=Ut(Ms,_3),A$={kernelName:Ms,backendName:"cpu",kernelFunc:m$},GA=Rt((e,t)=>e*t),y$=KA((e,t,n,a)=>({real:e*n-t*a,imag:e*a+t*n})),sh=Ut($s,GA,y$),g$={kernelName:$s,backendName:"cpu",kernelFunc:sh};function P3(e,t,n){let a=k.createScalarValue(-1,n);return GA([],t,a,e,n)}function x$(e){let{inputs:t,backend:n}=e,{x:a}=t;ve(a,"neg");let r=n.data.get(a.dataId).values,[s,i]=P3(r,a.shape,a.dtype);return n.makeTensorInfo(i,a.dtype,s)}var b$={kernelName:Mo,backendName:"cpu",kernelFunc:x$},L3=Rt((e,t)=>e!==t?1:0),v$=Ut(Fo,L3,null,"bool"),w$={kernelName:Fo,backendName:"cpu",kernelFunc:v$};function qA(e,t,n,a,r){let s=t.length,i=k.sizeFromShape(t),o=k.computeStrides(t),l=k.computeStrides(r),d=k.getTypedArrayFromDType(n,k.sizeFromShape(r));for(let u=0;un.disposeIntermediateTensorInfo(g)),n.makeTensorInfo(y,A,m)}var S$={kernelName:Po,backendName:"cpu",kernelFunc:I$};function XA(e,t,n,a){let r=e===t,s=e1;if(r||s||i)return k.makeZerosTypedArray(0,a);let o=Math.abs(Math.ceil((t-e)/n)),l=k.makeZerosTypedArray(o,a);t1/Math.sqrt(e)),N$=Sl(js,B3),T$={kernelName:js,backendName:"cpu",kernelFunc:N$};function ah(e,t,n,a,r){let s=on.isSliceContinous(a,t,n),i=k.sizeFromShape(n),o=k.computeStrides(a);if(s){let p=on.computeFlatOffset(t,o);return r==="string"?e.slice(p,p+i):e.subarray(p,p+i)}let l=r==="string"?C.fromUint8ToStringArray(e):e,d=We(a,r,l),u=We(n,r);for(let p=0;pm+t[f]);u.set(d.get(...h),...c)}return r==="string"?C.fromStringArrayToUint8(u.values):u.values}function xi(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{begin:s,size:i}=a;ve(r,"slice");let[o,l]=on.parseSliceParams(r,s,i);on.assertParamsValid(r,o,l);let d=n.data.get(r.dataId).values,u=ah(d,o,l,r.shape,r.dtype);return n.makeTensorInfo(l,r.dtype,u)}var E$={kernelName:Uo,backendName:"cpu",kernelFunc:xi};function V3(e,t,n,a,r,s,i){let o=t[0],l=s[0],d=new Array(l),u=new Array(o),p=t[1];if(l===0){if(o!==0)throw new Error(`Received SparseTensor with denseShape[0] = 0 but indices.shape[0] = ${o}`);let A=k.getArrayFromDType(n,0),y=k.getArrayFromDType(r,0);return[A,[0,p],y,d,u]}let c=!0,h=0,m=new Array(l).fill(0);for(let A=0;A=l)throw new Error(`indices(${A}, 0) is invalid: ${y} >= ${l}`);++m[y],c=c&&y>=h,h=y}let f=!0;for(let A=0;A0&&(m[A]+=m[A-1])}if(f&&c){let A=e,y=a;for(let g=0;g0){h[c-1]=1;for(let A=c-2;A>=0;--A)h[A]=h[A+1]*a[A+1]}let m=[];if(o>0){m[o-1]=1;for(let A=o-2;A>=0;--A)m[A]=m[A+1]*l[A+1]}let f=k.getArrayFromDType(n,i*o);for(let A=0;A{let n=e-t;return n*n}),C$=Ht(Zs,U3),R$={kernelName:Zs,backendName:"cpu",kernelFunc:C$};function H3(e,t,n,a){let r=We(e,t.dtype);for(let s=0;se-t),M$=KA((e,t,n,a)=>({real:e-n,imag:t-a})),ZA=Ht(Ys,G3,M$),F$={kernelName:Ys,backendName:"cpu",kernelFunc:ZA};function q3(e,t){let n=new Array(e.rank);for(let r=0;rx.value-g.value);let f=p*a,A=l.subarray(f,f+a),y=d.subarray(f,f+a);for(let g=0;g{for(let A=0;Anew nh,1);var J3=nt(mo,e=>e>=0?e:Math.exp(e)-1),$$={kernelName:mo,backendName:"cpu",kernelFunc:J3};function Q3(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{alpha:s}=a;ve([r],"leakyRelu");let i=k.sizeFromShape(r.shape),o=n.data.get(r.dataId).values,l=k.getTypedArrayFromDType("float32",i);for(let d=0;de<0?t*e:e);function e7(e){let{inputs:t,backend:n}=e,{x:a,alpha:r}=t;ve([a,r],"prelu");let s=n.data.get(a.dataId).values,i=n.data.get(r.dataId).values,[o,l]=O$(a.shape,r.shape,s,i,a.dtype);return n.makeTensorInfo(l,a.dtype,o)}var z$={kernelName:Ps,backendName:"cpu",kernelFunc:e7},t7=nt(Ls,e=>Math.max(0,e)),_$={kernelName:Ls,backendName:"cpu",kernelFunc:t7},n7=nt(Bs,e=>Math.min(Math.max(0,e),6)),P$={kernelName:Bs,backendName:"cpu",kernelFunc:n7},a7=nt(Gs,e=>1/(1+Math.exp(-e))),L$={kernelName:Gs,backendName:"cpu",kernelFunc:a7};function YA(e,t,n,a,r){if(n==="linear")return Ba({inputs:{x:t},backend:e});if(n==="relu")return t7({inputs:{x:t},backend:e});if(n==="elu")return J3({inputs:{x:t},backend:e});if(n==="relu6")return n7({inputs:{x:t},backend:e});if(n==="prelu")return e7({inputs:{x:t,alpha:a},backend:e});if(n==="leakyrelu")return Q3({inputs:{x:t},backend:e,attrs:{alpha:r}});if(n==="sigmoid")return a7({inputs:{x:t},backend:e});throw new Error(`Activation ${n} has not been implemented for the CPU backend.`)}function ht(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{shape:s}=a,i=k.sizeFromShape(r.shape),o=k.inferFromImplicitShape(s,i),l=k.sizeFromShape(o);k.assert(i===l,()=>`The new shape (${o}) has ${l} elements and the old shape (${r.shape}) has ${i} elements. The new shape and old shape must have the same number of elements.`),n.incRef(r.dataId);let d=n.data.get(r.dataId);if(d.complexTensorInfos!=null){let u=d.complexTensorInfos.real,p=d.complexTensorInfos.imag;u.shape=o,p.shape=o}return{dataId:r.dataId,shape:o,dtype:r.dtype}}var W$={kernelName:Bo,backendName:"cpu",kernelFunc:ht};function r7(e){let{inputs:t,backend:n,attrs:a}=e,{a:r,b:s}=t,{transposeA:i,transposeB:o}=a;ve([r,s],"matMul");let l=r.shape.length,d=s.shape.length,u=i?r.shape[l-2]:r.shape[l-1],p=o?s.shape[d-1]:s.shape[d-2],c=i?r.shape[l-1]:r.shape[l-2],h=o?s.shape[d-2]:s.shape[d-1],m=r.shape.slice(0,-2),f=s.shape.slice(0,-2),A=k.sizeFromShape(m),y=k.sizeFromShape(f),g=A===y||A===1||y===1;k.assert(l>=2&&d>=2&&g,()=>`Error in matMul: the input batch dimensions must either be the same or at least one input batch dimension must be 1. Got input batch dimensions of (${m}) and (${f}).`);let x=(A>y?r.shape.slice(0,-2):s.shape.slice(0,-2)).concat([c,h]);k.assert(u===p,()=>`Error in matMul: inner shapes (${u}) and (${p}) of Tensors with shapes ${r.shape} and ${s.shape} and transposeA=${i} and transposeB=${o} must match.`);let w=i?[A,u,c]:[A,c,u],b=o?[y,h,p]:[y,p,h],v=ht({inputs:{x:r},backend:n,attrs:{shape:w}}),N=ht({inputs:{x:s},backend:n,attrs:{shape:b}}),T=i?v.shape[1]:v.shape[2],R=i?v.shape[2]:v.shape[1],$=o?N.shape[1]:N.shape[2],z=Math.max(A,y),P=n.data.get(v.dataId).values,V=n.data.get(N.dataId).values,j=k.computeStrides(v.shape),U=k.computeStrides(N.shape),[X,G,ee]=i?[j[0],1,j[1]]:[j[0],j[1],1],[Y,re,ne]=o?[1,U[1],U[0]]:[U[1],1,U[0]],ie=R*$,Q=We([z,R,$],v.dtype),de=Q.values,oe=n.blockSize;for(let ye=0;yeMath.acos(e)),H$={kernelName:to,backendName:"cpu",kernelFunc:U$},G$=nt(no,e=>Math.acosh(e)),q$={kernelName:no,backendName:"cpu",kernelFunc:G$};function X$(e){let{inputs:t,backend:n}=e,a=t;ve(t,"addN");let r=a.map(o=>n.data.get(o.dataId).values),s=We(a[0].shape,a[0].dtype),i=s.values;for(let o=0;og&&(g=b,x=w)}h[A]=x}return d.forEach(A=>n.disposeIntermediateTensorInfo(A)),n.makeTensorInfo(u,"int32",h)}var tD={kernelName:ls,backendName:"cpu",kernelFunc:eD};function nD(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{axis:s}=a;ve(r,"argMin");let i=k.parseAxisParam(s,r.shape),o=C.getAxesPermutation(i,r.shape.length),l=r,d=[];o!=null&&(l=Zn({inputs:{x:r},backend:n,attrs:{perm:o}}),d.push(l),i=C.getInnerMostAxes(i.length,l.shape.length)),i=[i[0]],C.assertAxesAreInnerMostDims("argMin",i,l.shape.length);let[u,p]=C.computeOutAndReduceShapes(l.shape,i),c=k.sizeFromShape(u),h=k.makeZerosTypedArray(c,"int32"),m=k.sizeFromShape(p),f=n.data.get(l.dataId).values;for(let A=0;An.disposeIntermediateTensorInfo(A)),n.makeTensorInfo(u,"int32",h)}var aD={kernelName:Au,backendName:"cpu",kernelFunc:nD},rD=nt(so,e=>Math.asin(e)),sD={kernelName:so,backendName:"cpu",kernelFunc:rD},iD=nt(io,e=>Math.asinh(e)),oD={kernelName:io,backendName:"cpu",kernelFunc:iD},lD=nt(oo,e=>Math.atan(e)),uD={kernelName:oo,backendName:"cpu",kernelFunc:lD},dD=Mt((e,t)=>Math.atan2(e,t)),pD=Ht(uo,dD),cD={kernelName:uo,backendName:"cpu",kernelFunc:pD},hD=nt(lo,e=>Math.atanh(e)),fD={kernelName:lo,backendName:"cpu",kernelFunc:hD};function JA(e,t,n,a,r,s){let i=r.strideHeight,o=r.strideWidth,l=r.dilationHeight,d=r.dilationWidth,u=r.effectiveFilterHeight,p=r.effectiveFilterWidth,c=r.padInfo.top,h=r.padInfo.left,m=s==="max"?Number.NEGATIVE_INFINITY:Number.POSITIVE_INFINITY,f=We(r.outShape,n),A=f.values,y=r.outShape[1]*r.outShape[2]*r.outShape[3],g=r.outShape[2]*r.outShape[3],x=r.outShape[3];for(let w=0;wG?G=oe:s==="avg"&&(ee+=oe,Y++)}if(isNaN(G))break}let re=P+V*x+N;A[re]=s==="avg"?ee/Y:G}}}return f}function s7(e,t,n,a,r=!1,s=!1){let i=We(a.outShape,"int32"),o=a.strideHeight,l=a.strideWidth,d=a.dilationHeight,u=a.dilationWidth,p=a.effectiveFilterHeight,c=a.effectiveFilterWidth,h=a.padInfo.top,m=a.padInfo.left,f=We(t,n,e);for(let A=0;A$&&($=X,r?z=s?((A*a.inHeight+P)*a.inWidth+j)*a.inChannels+y:(P*a.inWidth+j)*a.inChannels+y:z=V*c+U)}}i.set(z,A,g,v,y)}}return i}function i7(e,t,n,a,r,s){let i=r.strideDepth,o=r.strideHeight,l=r.strideWidth,d=r.dilationDepth,u=r.dilationHeight,p=r.dilationWidth,c=r.effectiveFilterDepth,h=r.effectiveFilterHeight,m=r.effectiveFilterWidth,f=r.padInfo.front,A=r.padInfo.top,y=r.padInfo.left,g=s==="max"?Number.NEGATIVE_INFINITY:Number.POSITIVE_INFINITY,x=We(r.outShape,n),w=x.values,b=r.outShape[1]*r.outShape[2]*r.outShape[3]*r.outShape[4],v=r.outShape[2]*r.outShape[3]*r.outShape[4],N=r.outShape[3]*r.outShape[4],T=r.outShape[4];for(let R=0;RIe?Ie=Ve:s==="avg"&&(Ne+=Ve,$e++),isNaN(Ie))break}if(isNaN(Ie))break}if(isNaN(Ie))break}let ze=ce+P;w[ze]=s==="avg"?Ne/$e:Ie}}}}return x}function mD(e,t){let n=We(t.outShape,"int32"),a=t.strideDepth,r=t.strideHeight,s=t.strideWidth,i=t.dilationDepth,o=t.dilationHeight,l=t.dilationWidth,d=t.effectiveFilterDepth,u=t.effectiveFilterHeight,p=t.effectiveFilterWidth,c=t.padInfo.front,h=t.padInfo.top,m=t.padInfo.left;for(let f=0;f=V&&(V=ne,j=X*u*p+ee*u+re)}}}n.set(j,f,y,b,R,A)}}}return n}function AD(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t;ve(r,"avgPool");let{filterSize:s,strides:i,pad:o,dimRoundingMode:l}=a,d=1;k.assert(C.eitherStridesOrDilationsAreOne(i,d),()=>`Error in avgPool: Either strides or dilations must be 1. Got strides ${i} and dilations '${d}'`);let u=C.computePool2DInfo(r.shape,s,i,d,o,l),p;if(u.filterWidth===1&&u.filterHeight===1&&k.arraysEqual(u.inShape,u.outShape))p=Ba({inputs:{x:r},backend:n});else{let c=n.data.get(r.dataId).values,h=k.computeStrides(r.shape),m=JA(c,r.shape,r.dtype,h,u,"avg");p=n.makeTensorInfo(u.outShape,r.dtype,m.values)}return p}var yD={kernelName:us,backendName:"cpu",kernelFunc:AD};function gD(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{filterSize:s,strides:i,pad:o,dimRoundingMode:l,dataFormat:d}=a;ve(r,"avgPool3d");let u=C.computePool3DInfo(r.shape,s,i,1,o,l,d),p=n.data.get(r.dataId).values,c=i7(p,r.shape,r.dtype,k.computeStrides(r.shape),u,"avg");return n.makeTensorInfo(c.shape,"float32",c.values)}var xD={kernelName:yu,backendName:"cpu",kernelFunc:gD};function bD(e){let{inputs:t,backend:n,attrs:a}=e,{dy:r,input:s}=t,{filterSize:i,strides:o,pad:l,dimRoundingMode:d}=a;ve([r,s],"avgPool3DGrad");let u=C.computePool3DInfo(s.shape,i,o,1,l,d),p=u.strideDepth,c=u.strideHeight,h=u.strideWidth,m=u.filterDepth,f=u.filterHeight,A=u.filterWidth,y=u.dilationDepth,g=u.dilationHeight,x=u.dilationWidth,w=u.effectiveFilterDepth,b=u.effectiveFilterHeight,v=u.effectiveFilterWidth,N=w-1-u.padInfo.front,T=v-1-u.padInfo.left,R=b-1-u.padInfo.top,$=We(s.shape,"float32"),z=1/(m*f*A),P=n.bufferSync(r);for(let V=0;V=u.outDepth||Math.floor(Q)!==Q))for(let de=0;de=u.outHeight||Math.floor(oe)!==oe))for(let ye=0;ye=u.outWidth||Math.floor(ce)!==ce||(ne+=P.get(V,Q,oe,ce,j))}}}$.set(ne*z,V,U,X,G,j)}return n.makeTensorInfo($.shape,$.dtype,$.values)}var vD={kernelName:Cp,backendName:"cpu",kernelFunc:bD};function wD(e){let{inputs:t,backend:n,attrs:a}=e,{dy:r,input:s}=t,i=s;ve([r,s],"avgPoolGrad");let{filterSize:o,strides:l,pad:d}=a,u=C.computePool2DInfo(i.shape,o,l,1,d),p=u.strideHeight,c=u.strideWidth,h=u.filterHeight,m=u.filterWidth,f=u.dilationHeight,A=u.dilationWidth,y=u.effectiveFilterHeight,g=u.effectiveFilterWidth,x=g-1-u.padInfo.left,w=y-1-u.padInfo.top,b=We(i.shape,"float32"),v=1/(h*m),N=n.data.get(r.dataId).values,T=We(r.shape,"float32",N);for(let R=0;R=u.outHeight||Math.floor(G)!==G))for(let ee=0;ee=u.outWidth||Math.floor(Y)!==Y||(U+=T.get(R,G,Y,$))}}b.set(U*v,R,z,P,$)}return n.makeTensorInfo(b.shape,b.dtype,b.values)}var kD={kernelName:Ep,backendName:"cpu",kernelFunc:wD};function ID(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,scale:s,offset:i,mean:o,variance:l}=t;k.assert(o.shape.length===l.shape.length,()=>"Batch normalization gradient requires mean and variance to have equal ranks."),k.assert(i==null||o.shape.length===i.shape.length,()=>"Batch normalization gradient requires mean and offset to have equal ranks."),k.assert(s==null||o.shape.length===s.shape.length,()=>"Batch normalization gradient requires mean and scale to have equal ranks."),ve([r,o,l,s,i],"batchNorm");let{varianceEpsilon:d}=a;d==null&&(d=.001);let u=n.data.get(r.dataId).values,p=n.data.get(o.dataId).values,c=n.data.get(l.dataId).values,h=s?n.data.get(s.dataId).values:new Float32Array([1]),m=i?n.data.get(i.dataId).values:new Float32Array([0]),f=new Float32Array(u.length),A=m.length,y=h.length,g=c.length,x=p.length,w=0,b=0,v=0,N=0;for(let T=0;T=A&&(w=0),b>=x&&(b=0),v>=y&&(v=0),N>=g&&(N=0);return n.makeTensorInfo(r.shape,r.dtype,f)}var SD={kernelName:ws,backendName:"cpu",kernelFunc:ID};function ND(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{blockShape:s,crops:i}=a;ve([r],"batchToSpaceND");let o=s.reduce((y,g)=>y*g),l=C.getReshaped(r.shape,s,o),d=C.getPermuted(l.length,s.length),u=C.getReshapedPermuted(r.shape,s,o),p=C.getSliceBeginCoords(i,s.length),c=C.getSliceSize(u,i,s.length),h=ht({inputs:{x:r},backend:n,attrs:{shape:l}}),m=Zn({inputs:{x:h},backend:n,attrs:{perm:d}}),f=ht({inputs:{x:m},backend:n,attrs:{shape:u}}),A=bi({inputs:{x:f},backend:n,attrs:{begin:p,size:c}});return n.disposeIntermediateTensorInfo(h),n.disposeIntermediateTensorInfo(m),n.disposeIntermediateTensorInfo(f),A}var TD={kernelName:gu,backendName:"cpu",kernelFunc:ND};function ED(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,weights:s}=t,{size:i}=a,o=n.data.get(r.dataId).values,l=n.data.get(s.dataId).values,d=UA(o,l,s.dtype,s.shape,i);return n.makeTensorInfo([i],s.dtype,d)}var CD={kernelName:Rp,backendName:"cpu",kernelFunc:ED},RD=nt(Ir,(e,t)=>{let n=t;return e>n.clipValueMax?n.clipValueMax:e{let{x:t}=e.inputs,n=e.backend,a=new Float32Array(k.sizeFromShape(t.shape)),r=n.data.get(t.dataId),s=r.complexTensorInfos.real,i=r.complexTensorInfos.imag,o=n.data.get(s.dataId).values,l=n.data.get(i.dataId).values;for(let d=0;df.shape),s);if(k.sizeFromShape(i)===0)return n.makeTensorInfo(i,t[0].dtype,[]);let o=t.filter(f=>k.sizeFromShape(f.shape)>0);if(o.length===1)return Ba({inputs:{x:o[0]},backend:n});let l=o.map(f=>f.shape);if(C.assertParamsConsistent(l,s),o[0].dtype==="complex64"){let f=o.map(w=>xi({inputs:{input:w},backend:n})),A=o.map(w=>Tl({inputs:{input:w},backend:n})),y=El({inputs:f,backend:n,attrs:{axis:s}}),g=El({inputs:A,backend:n,attrs:{axis:s}}),x=Pn({inputs:{real:y,imag:g},backend:n});return f.forEach(w=>n.disposeIntermediateTensorInfo(w)),A.forEach(w=>n.disposeIntermediateTensorInfo(w)),n.disposeIntermediateTensorInfo(y),n.disposeIntermediateTensorInfo(g),x}let d=o.map(f=>{let A=k.sizeFromShape(f.shape.slice(s));return ht({inputs:{x:f},backend:n,attrs:{shape:[-1,A]}})}),u=d.map(f=>({vals:n.data.get(f.dataId).values,shape:f.shape}));i=C.computeOutShape(d.map(f=>f.shape),1);let p=d[0].shape[0]===1,c=HA(u,i,t[0].dtype,p),h=C.computeOutShape(o.map(f=>f.shape),s),m=n.makeTensorInfo(h,t[0].dtype,c);return d.forEach(f=>n.disposeIntermediateTensorInfo(f)),m}var OD={kernelName:po,backendName:"cpu",kernelFunc:El};function o7(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,filter:s}=t,{strides:i,pad:o,dataFormat:l,dilations:d,dimRoundingMode:u}=a;ve([r,s],"conv2d");let p=C.convertConv2DDataFormat(l),c=C.computeConv2DInfo(r.shape,s.shape,i,d,o,u,!1,p),h=c.filterHeight,m=c.filterWidth,f=c.dilationHeight,A=c.dilationWidth,y=c.padInfo.left,g=c.padInfo.top,x=c.dataFormat==="channelsLast",w=new Ot(c.outShape,r.dtype),b=k.computeStrides(r.shape),v=k.computeStrides(s.shape),N=b[0],T=x?b[1]:b[2],R=x?b[2]:1,$=x?1:b[1],z=w.strides[0],P=x?w.strides[1]:w.strides[2],V=x?w.strides[2]:1,j=x?1:w.strides[1],U=n.data.get(r.dataId).values,X=n.data.get(s.dataId).values,G=w.values;for(let ee=0;ee=c.inHeight)continue;let ye=de*v[0],ce=Y+oe*T;for(let Ie=0;Ie=c.inWidth)continue;let Qe=ye+ze*v[1],et=ce+De*R,rt=Qe;for(let Xe=0;Xe=d.inDepth)continue;let ee=X*R[0],Y=z+G*T[1];for(let re=0;re=d.inHeight)continue;let oe=ee+Q*R[1],ye=Y+de*T[2];for(let ce=0;ce=d.inWidth)continue;let De=oe+$e*R[2],Qe=ye+ze*d.inChannels,et=De;for(let rt=0;rtMath.cos(e)),XD={kernelName:ms,backendName:"cpu",kernelFunc:qD},KD=nt(co,e=>Math.cosh(e)),ZD={kernelName:co,backendName:"cpu",kernelFunc:KD};function YD(e){let{inputs:t,backend:n,attrs:a}=e,{image:r,boxes:s,boxInd:i}=t,{cropSize:o,method:l,extrapolationValue:d}=a,[u,p,c,h]=r.shape,m=s.shape[0],[f,A]=o,y=We([m,f,A,h],"float32"),g=n.data.get(s.dataId).values,x=n.data.get(i.dataId).values,w=n.data.get(r.dataId).values,b=k.computeStrides(r.shape),v=k.computeStrides(y.shape);for(let N=0;N=u)continue;let j=f>1?(z-R)*(p-1)/(f-1):0,U=A>1?(P-$)*(c-1)/(A-1):0;for(let X=0;X1?R*(p-1)+X*j:.5*(R+z)*(p-1);if(G<0||G>p-1){for(let ee=0;ee1?$*(c-1)+ne*U:.5*($+P)*(c-1);if(ie<0||ie>c-1){for(let ye=0;ye1?$*(c-1)+ee*U:.5*($+P)*(c-1);if(Y<0||Y>c-1){for(let ie=0;iey+m-g-1:(y,g)=>y+g;for(let y=0;y`Only NHWC dataFormat supported on CPU for depthToSpace. Got ${i}`),k.assert(s>1,()=>`blockSize should be > 1 for depthToSpace, but was: ${s}`);let o=r.shape[0],l=r.shape[1],d=r.shape[2],u=r.shape[3],p=l*s,c=d*s,h=u/(s*s),m=n.data.get(r.dataId).values,f=new Float32Array(o*p*c*h),A=0;for(let y=0;y`Error in depthwiseConv2d: Either strides or dilations must be 1. Got strides ${i} and dilations '${c}'`);let h=C.computeConv2DInfo(r.shape,s.shape,i,c,o,d,!0),{filterHeight:m,filterWidth:f,dilationHeight:A,dilationWidth:y,padInfo:g}=h,x=g.left,w=g.top,b=h.outChannels/h.inChannels,v=new Ot(h.outShape,r.dtype),N=n.data.get(r.dataId).values,T=n.data.get(s.dataId).values,R=v.values;for(let $=0;$=h.inHeight)continue;let ee=X*p[0],Y=z+G*u[1];for(let re=0;re=h.inWidth)continue;let oe=ee+Q*p[1],ye=Y+de*h.inChannels,ce=ne,Ie=oe;for(let Ne=0;Ne{let{x:a,filter:r}=e,{strides:s,pad:i,dilations:o}=n,l=t,d=l.data.get(a.dataId).values,u=a.shape.length,p=l.data.get(r.dataId).values,c=r.shape.length,{batchSize:h,inHeight:m,inWidth:f,inChannels:A,outHeight:y,outWidth:g,padInfo:x,strideHeight:w,strideWidth:b,filterHeight:v,filterWidth:N,dilationHeight:T,dilationWidth:R,outShape:$}=C.computeDilation2DInfo(a.shape,r.shape,s,i,"NHWC",o),z=k.sizeFromShape($),P=$.length,V=k.getArrayFromDType(a.dtype,z);for(let j=0;j=0&&Q=0&&oere&&(re=Ie)}}}let ne=k.locToIndex([j,U,G,Y],P,k.computeStrides($));V[ne]=re}}}return{dataId:l.write(k.toTypedArray(V,a.dtype),$,a.dtype),shape:$,dtype:a.dtype}}},hO={kernelName:Wp,backendName:"cpu",kernelFunc:({inputs:e,backend:t,attrs:n})=>{let{x:a,filter:r,dy:s}=e,{strides:i,pad:o,dilations:l}=n,d=t,u=k.toNestedArray(a.shape,d.data.get(a.dataId).values),p=k.toNestedArray(r.shape,d.data.get(r.dataId).values),{batchSize:c,inHeight:h,inWidth:m,inChannels:f,outHeight:A,outWidth:y,padInfo:g,strideHeight:x,strideWidth:w,filterHeight:b,filterWidth:v,dilationHeight:N,dilationWidth:T,outShape:R}=C.computeDilation2DInfo(a.shape,r.shape,i,o,"NHWC",l);k.assert(s.rank===R.length,()=>`Error in ${Wp}, dy must have the same rank as output ${R.length}, but got ${s.rank}`);let $=k.toNestedArray(R,d.data.get(s.dataId).values),z=k.makeZerosNestedTypedArray(r.shape,r.dtype);for(let P=0;P=0&&ie=0&&deee&&(ee=oe,Y=ne,re=Q)}}}z[Y][re][G]+=$[P][V][U][G]}}}return{dataId:d.write(k.toTypedArray(z,a.dtype),r.shape,r.dtype),shape:r.shape,dtype:r.dtype}}},fO={kernelName:Lp,backendName:"cpu",kernelFunc:({inputs:e,backend:t,attrs:n})=>{let{x:a,filter:r,dy:s}=e,{strides:i,pad:o,dilations:l}=n,d=t,u=k.toNestedArray(a.shape,d.data.get(a.dataId).values),p=k.toNestedArray(r.shape,d.data.get(r.dataId).values),{batchSize:c,inHeight:h,inWidth:m,inChannels:f,outHeight:A,outWidth:y,padInfo:g,strideHeight:x,strideWidth:w,filterHeight:b,filterWidth:v,dilationHeight:N,dilationWidth:T,outShape:R}=C.computeDilation2DInfo(a.shape,r.shape,i,o,"NHWC",l);k.assert(s.rank===R.length,()=>`Error in ${Lp}, dy must have the same rank as output ${R.length}, but got ${s.rank}`);let $=k.toNestedArray(R,d.data.get(s.dataId).values),z=k.makeZerosNestedTypedArray(a.shape,a.dtype);for(let P=0;P=0&&ie=0&&deee&&(ee=oe,Y=ie,re=de)}}}z[P][Y][re][G]+=$[P][V][U][G]}}}return{dataId:d.write(k.toTypedArray(z,a.dtype),a.shape,a.dtype),shape:a.shape,dtype:a.dtype}}};function od(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{axis:s,keepDims:i}=a;ve(r,"sum");let o;r.dtype==="bool"?o=Pr({inputs:{x:r},backend:n,attrs:{dtype:"int32"}}):o=Ba({inputs:{x:r},backend:n});let l=o.shape.length,d=k.parseAxisParam(s,o.shape),u=C.getAxesPermutation(d,l),p=d,c=o;u!=null&&(c=Zn({inputs:{x:o},backend:n,attrs:{perm:u}}),p=C.getInnerMostAxes(p.length,l)),C.assertAxesAreInnerMostDims("sum",p,c.shape.length);let[h,m]=C.computeOutAndReduceShapes(c.shape,p),f=C.upcastType(c.dtype,"int32"),A=rh(n,h,f),y=k.sizeFromShape(m),g=n.data.get(A.dataId).values,x=n.data.get(c.dataId).values;for(let w=0;w=0&&(c=od({inputs:{x:c},backend:n,attrs:{axis:d[f]-(i.length-h),keepDims:!1}}),m.push(c)),h--)}for(let f of m)f!==c&&n.disposeIntermediateTensorInfo(f);return c}var yO={kernelName:Bp,backendName:"cpu",kernelFunc:AO};function gO(e){let{inputs:t,backend:n}=e,{dy:a,y:r}=t;ve([a,r],"eluGrad");let s=new Float32Array(k.sizeFromShape(r.shape)),i=n.data.get(r.dataId).values,o=n.data.get(a.dataId).values;for(let l=0;l=1?s[l]=o[l]:s[l]=o[l]*(d+1)}return n.makeTensorInfo(r.shape,"float32",s)}var xO={kernelName:Vp,backendName:"cpu",kernelFunc:gO},bO=Mt((e,t)=>e===t?1:0),u7=Ht(yo,bO,null,"bool"),vO={kernelName:yo,backendName:"cpu",kernelFunc:u7},wO=C.ERF_P,kO=C.ERF_A1,IO=C.ERF_A2,SO=C.ERF_A3,NO=C.ERF_A4,TO=C.ERF_A5,EO=nt(Ao,e=>{let t=Math.sign(e),n=Math.abs(e),a=1/(1+wO*n);return t*(1-((((TO*a+NO)*a+SO)*a+IO)*a+kO)*a*Math.exp(-n*n))}),CO={kernelName:Ao,backendName:"cpu",kernelFunc:EO};function ih(e){let{inputs:t,backend:n,attrs:a}=e,{input:r}=t,{dim:s}=a,i=r.shape.length,o=r.shape.slice(),l=s;return s<0&&(k.assert(-(i+1)<=s,()=>`Axis must be in the interval [${-(i+1)}, ${i}]`),l=i+s+1),o.splice(l,0,1),ht({inputs:{x:r},backend:n,attrs:{shape:o}})}var RO={kernelName:go,backendName:"cpu",kernelFunc:ih},MO=Mt((e,t)=>e/t),QA=Ht(gs,MO),e1={kernelName:gs,backendName:"cpu",kernelFunc:QA};function d7(e,t,n){let a=e.shape,r=a[0],s=a[1],i=n.data.get(e.dataId),o=i.complexTensorInfos.real,l=i.complexTensorInfos.imag,d=[r,s],u=k.sizeFromShape(d),p=k.getTypedArrayFromDType("float32",u),c=k.getTypedArrayFromDType("float32",u);for(let A=0;A{let{image:a}=e,r=n,s=k.getTypedArrayFromDType(a.dtype,k.sizeFromShape(a.shape)),[i,o,l,d]=a.shape,u=r.data.get(a.dataId).values;for(let p=0;p=0&&xMath.floor(e/t)),BO=Ht(vs,WO,null,"int32"),VO={kernelName:vs,backendName:"cpu",kernelFunc:BO};function jO(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,filter:s,bias:i,preluActivationWeights:o}=t,{strides:l,pad:d,dataFormat:u,dilations:p,dimRoundingMode:c,activation:h,leakyreluAlpha:m}=a,f=o7({inputs:{x:r,filter:s},backend:n,attrs:{strides:l,pad:d,dataFormat:u,dilations:p,dimRoundingMode:c}});if(i){let A=f;f=id({inputs:{a:f,b:i},backend:n}),n.disposeIntermediateTensorInfo(A)}if(h){let A=f;f=YA(n,f,h,o,m),n.disposeIntermediateTensorInfo(A)}return f}var UO={kernelName:ni,backendName:"cpu",kernelFunc:jO};function HO(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,filter:s,bias:i,preluActivationWeights:o}=t,{strides:l,pad:d,dataFormat:u,dilations:p,dimRoundingMode:c,activation:h,leakyreluAlpha:m}=a,f=l7({inputs:{x:r,filter:s},backend:n,attrs:{strides:l,pad:d,dataFormat:u,dilations:p,dimRoundingMode:c}});if(i){let A=f;f=id({inputs:{a:f,b:i},backend:n}),n.disposeIntermediateTensorInfo(A)}if(h){let A=f;f=YA(n,f,h,o,m),n.disposeIntermediateTensorInfo(A)}return f}var GO={kernelName:ai,backendName:"cpu",kernelFunc:HO};function qO(e){let{inputs:t,backend:n}=e,{params:a,indices:r}=t,s=k.sizeFromShape(a.shape),i=r.shape,o=i[i.length-1],[l,d,u,p]=C.prepareAndValidate(a,r);if(d===0)return n.makeTensorInfo(l,a.dtype,[]);let c=We([d,u],a.dtype),h=n.data.get(r.dataId).values,m=n.data.get(a.dataId).values;for(let f=0;f=s/u)throw new Error(`Invalid indices: ${A} does not index into ${a.shape}`);for(let g=0;ge>=t?1:0),JO=Ht(ks,YO,null,"bool"),QO={kernelName:ks,backendName:"cpu",kernelFunc:JO};function ez(e){let{inputs:t,backend:n}=e,{input:a}=t,r=k.sizeFromShape(a.shape),s=a.shape[a.shape.length-1],i=r/s,o=ht({inputs:{x:a},backend:n,attrs:{shape:[i,s]}}),l=d7(o,!0,n),d=ht({inputs:{x:l},backend:n,attrs:{shape:a.shape}});return n.disposeIntermediateTensorInfo(o),n.disposeIntermediateTensorInfo(l),d}var tz={kernelName:Up,backendName:"cpu",kernelFunc:ez},nz=nt(Io,e=>Number.isFinite(e)?1:0,"bool"),az={kernelName:Io,backendName:"cpu",kernelFunc:nz},rz=nt(So,e=>Math.abs(e)===Infinity?1:0,"bool"),sz={kernelName:So,backendName:"cpu",kernelFunc:rz},iz=nt(No,e=>Number.isNaN(e)?1:0,"bool"),oz={kernelName:No,backendName:"cpu",kernelFunc:iz},lz=Mt((e,t)=>e<=t?1:0),uz=Ht(Eo,lz,null,"bool"),dz={kernelName:Eo,backendName:"cpu",kernelFunc:uz};function pz(e){let{backend:t,attrs:n}=e,{start:a,stop:r,num:s}=n,i=$3(a,r,s);return t.makeTensorInfo([i.length],"float32",i)}var cz={kernelName:Gp,backendName:"cpu",kernelFunc:pz},hz=nt(Co,e=>Math.log1p(e)),fz={kernelName:Co,backendName:"cpu",kernelFunc:hz},mz=Mt((e,t)=>e&&t),Az=Ht(Ro,mz,null,"bool"),yz={kernelName:Ro,backendName:"cpu",kernelFunc:Az},gz=nt(ku,e=>e?0:1,"bool"),xz={kernelName:ku,backendName:"cpu",kernelFunc:gz},bz=Mt((e,t)=>e||t),vz=Ht(Iu,bz,null,"bool"),wz={kernelName:Iu,backendName:"cpu",kernelFunc:vz};function kz(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{depthRadius:s,bias:i,alpha:o,beta:l}=a;ve(r,"LRN");let d=r.shape[3],u=d-1,p=n.data.get(r.dataId).values,c=k.sizeFromShape(r.shape),h=new Float32Array(c);function m(f){let A=f%d,y=f-A+Math.max(0,A-s),g=f-A+Math.min(A+s,u),x=0;for(;y<=g;y++){let w=p[y];x+=w*w}return x}for(let f=0;f`Error in maxPool: Either strides or dilations must be 1. Got strides ${i} and dilations '${d}'`);let u=C.computePool2DInfo(r.shape,s,i,d,o,l),p;if(u.filterWidth===1&&u.filterHeight===1&&k.arraysEqual(u.inShape,u.outShape))p=Ba({inputs:{x:r},backend:n});else{let c=n.data.get(r.dataId).values,h=k.computeStrides(r.shape),m=JA(c,r.shape,r.dtype,h,u,"max");p=n.makeTensorInfo(u.outShape,r.dtype,m.values)}return p}var Cz={kernelName:Cs,backendName:"cpu",kernelFunc:Ez};function Rz(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{filterSize:s,strides:i,pad:o,dimRoundingMode:l,dataFormat:d}=a;ve(r,"maxPool3d");let u=C.computePool3DInfo(r.shape,s,i,1,o,l,d),p=n.data.get(r.dataId).values,c=i7(p,r.shape,r.dtype,k.computeStrides(r.shape),u,"max");return n.makeTensorInfo(c.shape,"float32",c.values)}var Mz={kernelName:Nu,backendName:"cpu",kernelFunc:Rz};function Fz(e){let{inputs:t,backend:n,attrs:a}=e,{dy:r,input:s}=t,{filterSize:i,strides:o,pad:l,dimRoundingMode:d}=a;ve([r,s],"maxPool3DGrad");let u=C.computePool3DInfo(s.shape,i,o,1,l,d),p=n.bufferSync(s),c=mD(p,u),h=u.strideDepth,m=u.strideHeight,f=u.strideWidth,A=u.dilationDepth,y=u.dilationHeight,g=u.dilationWidth,x=u.effectiveFilterDepth,w=u.effectiveFilterHeight,b=u.effectiveFilterWidth,v=x-1-u.padInfo.front,N=b-1-u.padInfo.left,T=w-1-u.padInfo.top,R=We(s.shape,"float32"),$=n.bufferSync(r);for(let z=0;z=u.outDepth||Math.floor(ne)!==ne))for(let ie=0;ie=u.outHeight||Math.floor(Q)!==Q))for(let de=0;de=u.outWidth||Math.floor(oe)!==oe)continue;let ye=x*w*b-1-c.get(z,ne,Q,oe,P),ce=re*w*b+ie*b+de,Ie=ye===ce?1:0;Ie!==0&&(Y+=$.get(z,ne,Q,oe,P)*Ie)}}}R.set(Y,z,V,j,U,P)}return n.makeTensorInfo(R.shape,R.dtype,R.values)}var $z={kernelName:Kp,backendName:"cpu",kernelFunc:Fz};function Dz(e){let{inputs:t,backend:n,attrs:a}=e,{dy:r,input:s,output:i}=t,o=s;ve([s,i],"maxPoolGrad");let{filterSize:l,strides:d,pad:u,dimRoundingMode:p}=a,c=C.computePool2DInfo(o.shape,l,d,1,u,p),h=n.data.get(o.dataId).values,m=We(c.outShape,o.dtype,s7(h,o.shape,o.dtype,c).values),f=c.strideHeight,A=c.strideWidth,y=c.dilationHeight,g=c.dilationWidth,x=c.effectiveFilterHeight,w=c.effectiveFilterWidth,b=w-1-c.padInfo.left,v=x-1-c.padInfo.top,N=We(o.shape,"float32"),T=n.data.get(r.dataId).values,R=We(r.shape,"float32",T);for(let $=0;$=c.outHeight||Math.floor(ee)!==ee))for(let Y=0;Y=c.outWidth||Math.floor(re)!==re)continue;let ne=x*w-1-m.get($,ee,re,z),ie=G*w+Y,Q=ne===ie?1:0;Q!==0&&(X+=R.get($,ee,re,z)*Q)}}N.set(X,$,P,V,z)}return n.makeTensorInfo(N.shape,N.dtype,N.values)}var Oz={kernelName:Xp,backendName:"cpu",kernelFunc:Dz};function zz(e,t,n,a,r){let s=k.computeStrides(t),i=JA(e,t,n,s,r,"max"),o=s7(e,t,n,r,!0,a);return[i.values,o.values]}var _z={kernelName:Zp,backendName:"cpu",kernelFunc:({inputs:e,attrs:t,backend:n})=>{let{x:a}=e,{filterSize:r,strides:s,pad:i,includeBatchInIndex:o}=t,l=n;ve(a,"MaxPoolWithArgmax");let d=l.data.get(a.dataId).values,u=C.computePool2DInfo(a.shape,r,s,[1,1],i),[p,c]=zz(d,a.shape,a.dtype,o,u),h=l.write(p,u.outShape,a.dtype),m=l.write(c,u.outShape,a.dtype);return[{dataId:h,shape:u.outShape,dtype:a.dtype},{dataId:m,shape:u.outShape,dtype:"int32"}]}};function Pz(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{axis:s,keepDims:i}=a,o=k.parseAxisParam(s,r.shape),l=C.computeOutAndReduceShapes(r.shape,o)[1],d=k.sizeFromShape(l),u=[],p=n.makeTensorInfo([],"float32",new Float32Array([d]));u.push(p);let c=Pr({inputs:{x:r},backend:n,attrs:{dtype:"float32"}});u.push(c);let h=QA({inputs:{a:c,b:p},backend:n});u.push(h);let m=od({inputs:{x:h},backend:n,attrs:{axis:s,keepDims:i}});return u.forEach(f=>n.disposeIntermediateTensorInfo(f)),m}var Lz={kernelName:Rs,backendName:"cpu",kernelFunc:Pz};function Wz(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{axis:s,keepDims:i}=a;ve(r,"min");let o=k.parseAxisParam(s,r.shape),l=o,d=C.getAxesPermutation(l,r.shape.length),u=r;d!=null&&(u=Zn({inputs:{x:r},backend:n,attrs:{perm:d}}),l=C.getInnerMostAxes(l.length,r.shape.length)),C.assertAxesAreInnerMostDims("min",l,u.shape.length);let[p,c]=C.computeOutAndReduceShapes(u.shape,l),h=k.sizeFromShape(c),m=k.makeZerosTypedArray(k.sizeFromShape(p),u.dtype),f=n.data.get(u.dataId).values;for(let y=0;yg[0]+r.shape[x]+g[1]),l=s.map(g=>g[0]),d=s.map((g,x)=>g[0]+r.shape[x]),u=i==="reflect"?0:1,p=n.data.get(r.dataId).values,c=r.shape.length,h=k.computeStrides(r.shape),m=k.sizeFromShape(o),f=o.length,A=k.computeStrides(o),y=k.getTypedArrayFromDType(r.dtype,m);for(let g=0;g=d[b]&&(x[b]=(d[b]-1)*2-x[b]+u);x=x.map((b,v)=>b-l[v]);let w=k.locToIndex(x,c,h);y[g]=p[w]}return{dataId:n.write(y,o,r.dtype),shape:o,dtype:r.dtype}}var jz={kernelName:$s,backendName:"cpu",kernelFunc:Vz},Uz=Mt((e,t)=>{let n=e%t;return e<0&&t<0||e>=0&&t>=0?n:(n+t)%t}),Hz=Ht(Mo,Uz),Gz={kernelName:Mo,backendName:"cpu",kernelFunc:Hz},qz=Yi(Wg());function c7(e){let{inputs:t,backend:n,attrs:a}=e,{logits:r}=t,{dim:s}=a,i=r.shape.length,o=s;if(o===-1&&(o=i-1),o!==i-1)throw Error(`Softmax along a non-last dimension is not yet supported. Logits was rank ${i} and dim was ${o}`);let l=k.parseAxisParam([o],r.shape),d=p7({inputs:{x:r},backend:n,attrs:{reductionIndices:l,keepDims:!1}}),u=C.expandShapeToKeepDim(d.shape,l),p=ht({inputs:{x:d},backend:n,attrs:{shape:u}}),c=ZA({inputs:{a:r,b:p},backend:n}),h=Z3({inputs:{x:c},backend:n}),m=od({inputs:{x:h},backend:n,attrs:{axis:l,keepDims:!1}}),f=ht({inputs:{x:m},backend:n,attrs:{shape:u}}),A=QA({inputs:{a:h,b:f},backend:n});return n.disposeIntermediateTensorInfo(d),n.disposeIntermediateTensorInfo(p),n.disposeIntermediateTensorInfo(c),n.disposeIntermediateTensorInfo(h),n.disposeIntermediateTensorInfo(m),n.disposeIntermediateTensorInfo(f),A}var Xz={kernelName:Ks,backendName:"cpu",kernelFunc:c7};function Kz(e){let{inputs:t,backend:n,attrs:a}=e,{logits:r}=t,{numSamples:s,seed:i,normalized:o}=a;ve(r,"multinomial");let l=o?r:c7({inputs:{logits:r},backend:n,attrs:{dim:-1}}),d=l.shape[0],u=l.shape[1],p=n.data.get(l.dataId).values,c=[d,s],h=k.makeZerosTypedArray(k.sizeFromShape(c),"int32");for(let m=0;m=0&&u[p]{k.assertShapesMatch(s,u.shape,"All tensors passed to stack must have matching shapes"),k.assert(i===u.dtype,()=>"All tensors passed to stack must have matching dtypes")});let o=[],l=t.map(u=>{let p=ih({inputs:{input:u},backend:n,attrs:{dim:r}});return o.push(p),p}),d=El({inputs:l,backend:n,attrs:{axis:r}});return o.forEach(u=>n.disposeIntermediateTensorInfo(u)),d}var d_={kernelName:Po,backendName:"cpu",kernelFunc:f7};function p_(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{paddings:s,constantValue:i}=a;ve(r,"pad");let o=s.map((y,g)=>y[0]+r.shape[g]+y[1]),l=s.map(y=>y[0]),d=n.data.get(r.dataId).values,u=k.sizeFromShape(r.shape),p=r.shape.length,c=k.computeStrides(r.shape),h=k.sizeFromShape(o),m=o.length,f=k.computeStrides(o),A=k.getTypedArrayFromDType(r.dtype,h);i!==0&&A.fill(i);for(let y=0;yw+l[b]),x=k.locToIndex(g,m,f);A[x]=d[y]}return{dataId:n.write(A,o,r.dtype),shape:o,dtype:r.dtype}}var m7={kernelName:zs,backendName:"cpu",kernelFunc:p_},c_=Mt((e,t)=>Math.pow(e,t)),h_=Ht(_s,c_),f_={kernelName:_s,backendName:"cpu",kernelFunc:h_};function m_(e){let{backend:t,attrs:n}=e,{start:a,stop:r,dtype:s,step:i}=n,o=XA(a,r,i,s);return t.makeTensorInfo([o.length],s,o)}var A_={kernelName:Tu,backendName:"cpu",kernelFunc:m_},y_=nt(Wo,e=>1/e),g_={kernelName:Wo,backendName:"cpu",kernelFunc:y_};function x_(e){let{inputs:t,backend:n,attrs:a}=e,{images:r}=t,{alignCorners:s,halfPixelCenters:i,size:o}=a;ve(r,"resizeBilinear");let l=k.computeStrides(r.shape),[d,u]=o,[p,c,h,m]=r.shape,f=n.data.get(r.dataId).values,A=new Float32Array(k.sizeFromShape([p,d,u,m])),y=[s&&d>1?c-1:c,s&&u>1?h-1:h],g=[s&&d>1?d-1:d,s&&u>1?u-1:u],x=0,w=y[0]/g[0],b=y[1]/g[1];for(let v=0;v1?d-1:d,i&&h>1?u-1:u],A=[i&&c>1?c-1:c,i&&h>1?h-1:h],y=f[0]/A[0],g=f[1]/A[1],x=n.data.get(s.dataId).values,w=0;for(let b=0;b1?c-1:c,s&&u>1?h-1:h],g=[s&&d>1?d-1:d,s&&u>1?u-1:u],x=y[0]/g[0],w=y[1]/g[1],b=0;for(let v=0;v1?u-1:u,i&&m>1?p-1:p],g=[i&&h>1?h-1:h,i&&m>1?m-1:m],x=y[0]/g[0],w=y[1]/g[1],b=1/x,v=1/w,N=Math.ceil(b)*2+2,T=Math.ceil(v)*2+2;for(let R=0;R=h)continue;let Q=$+ie*l[1],de=ie*x,oe=Math.min(u-1,i?Math.round(de):Math.floor(de));if(z===oe)for(let ye=0;ye=m)continue;let Ie=Q+ce*l[2],Ne=ce*w,$e=Math.min(p-1,i?Math.round(Ne):Math.floor(Ne));U===$e&&(re+=A[Ie+Y])}}f[X+Y]=re}}}}return n.makeTensorInfo(r.shape,r.dtype,f)}var N_={kernelName:Qp,backendName:"cpu",kernelFunc:S_};function T_(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{dims:s}=a;ve(r,"reverse");let i=r.shape.length,o=k.parseAxisParam(s,r.shape);if(i===0)return Ba({inputs:{x:r},backend:n});let l=new Ot(r.shape,r.dtype),d=n.bufferSync(r);for(let u=0;uc[h]=r.shape[h]-1-c[h]),l.set(d.get(...c),...p)}return n.makeTensorInfo(l.shape,l.dtype,l.values)}var E_={kernelName:Vs,backendName:"cpu",kernelFunc:T_},C_={kernelName:tl,backendName:"cpu",kernelFunc:({inputs:e,attrs:t,backend:n})=>{let{image:a}=e,{radians:r,fillValue:s,center:i}=t,o=n,l=k.getTypedArrayFromDType(a.dtype,k.sizeFromShape(a.shape)),[d,u,p,c]=a.shape,[h,m]=C.getImageCenter(i,u,p),f=255,A=Math.sin(r),y=Math.cos(r),g=o.data.get(a.dataId).values;for(let x=0;x=0&&V=0&&j{let t=Math.floor(e);return e-t<.5?Math.floor(e):e-t>.5?Math.ceil(e):t%2==0?t:t+1}),M_={kernelName:js,backendName:"cpu",kernelFunc:R_};function A7(e,t,n,a,r,s,i,o,l,d){let u=[a/r,r],p=e.values,c=t.values;if(a===0)return We(n,t.dtype);let h=We(u,t.dtype);h.values.fill(l);for(let m=0;m=a/r)throw new Error(`Invalid indices: ${f} does not index into ${n}`);for(let y=0;y1||r.shape.length===1?1:k.sizeFromShape(r.shape.slice(1));for(let m=0;me>=0?__*e:z_*(Math.exp(e)-1)),L_={kernelName:Uo,backendName:"cpu",kernelFunc:P_},W_=nt(qo,e=>e<0?-1:e>0?1:0),B_={kernelName:qo,backendName:"cpu",kernelFunc:W_},V_=nt(Hs,e=>Math.sin(e)),j_={kernelName:Hs,backendName:"cpu",kernelFunc:V_},U_=nt(Go,e=>Math.sinh(e)),H_={kernelName:Go,backendName:"cpu",kernelFunc:U_},G_=11920928955078125e-23,y7=Math.log(G_)+2,q_=nt(Xo,e=>{let t=e>-y7,n=e0){h[c-1]=1;for(let A=c-2;A>=0;--A)h[A]=h[A+1]*a[A+1]}let m=[];if(o>0){m[o-1]=1;for(let A=o-2;A>=0;--A)m[A]=m[A+1]*l[A+1]}let f=k.getArrayFromDType(n,i*o);for(let A=0;A{let n=e-t;return n*n}),C$=Ut(Ks,U3),R$={kernelName:Ks,backendName:"cpu",kernelFunc:C$};function H3(e,t,n,a){let r=We(e,t.dtype);for(let s=0;se-t),M$=KA((e,t,n,a)=>({real:e-n,imag:t-a})),ZA=Ut(Zs,G3,M$),F$={kernelName:Zs,backendName:"cpu",kernelFunc:ZA};function q3(e,t){let n=new Array(e.rank);for(let r=0;rx.value-g.value);let f=p*a,A=l.subarray(f,f+a),y=d.subarray(f,f+a);for(let g=0;g{for(let A=0;Anew nh,1);var J3=nt(fo,e=>e>=0?e:Math.exp(e)-1),$$={kernelName:fo,backendName:"cpu",kernelFunc:J3};function Q3(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{alpha:s}=a;ve([r],"leakyRelu");let i=k.sizeFromShape(r.shape),o=n.data.get(r.dataId).values,l=k.getTypedArrayFromDType("float32",i);for(let d=0;de<0?t*e:e);function e7(e){let{inputs:t,backend:n}=e,{x:a,alpha:r}=t;ve([a,r],"prelu");let s=n.data.get(a.dataId).values,i=n.data.get(r.dataId).values,[o,l]=O$(a.shape,r.shape,s,i,a.dtype);return n.makeTensorInfo(l,a.dtype,o)}var z$={kernelName:_s,backendName:"cpu",kernelFunc:e7},t7=nt(Ps,e=>Math.max(0,e)),_$={kernelName:Ps,backendName:"cpu",kernelFunc:t7},n7=nt(Ws,e=>Math.min(Math.max(0,e),6)),P$={kernelName:Ws,backendName:"cpu",kernelFunc:n7},a7=nt(Hs,e=>1/(1+Math.exp(-e))),L$={kernelName:Hs,backendName:"cpu",kernelFunc:a7};function YA(e,t,n,a,r){if(n==="linear")return Wa({inputs:{x:t},backend:e});if(n==="relu")return t7({inputs:{x:t},backend:e});if(n==="elu")return J3({inputs:{x:t},backend:e});if(n==="relu6")return n7({inputs:{x:t},backend:e});if(n==="prelu")return e7({inputs:{x:t,alpha:a},backend:e});if(n==="leakyrelu")return Q3({inputs:{x:t},backend:e,attrs:{alpha:r}});if(n==="sigmoid")return a7({inputs:{x:t},backend:e});throw new Error(`Activation ${n} has not been implemented for the CPU backend.`)}function ct(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{shape:s}=a,i=k.sizeFromShape(r.shape),o=k.inferFromImplicitShape(s,i),l=k.sizeFromShape(o);k.assert(i===l,()=>`The new shape (${o}) has ${l} elements and the old shape (${r.shape}) has ${i} elements. The new shape and old shape must have the same number of elements.`),n.incRef(r.dataId);let d=n.data.get(r.dataId);if(d.complexTensorInfos!=null){let u=d.complexTensorInfos.real,p=d.complexTensorInfos.imag;u.shape=o,p.shape=o}return{dataId:r.dataId,shape:o,dtype:r.dtype}}var W$={kernelName:Wo,backendName:"cpu",kernelFunc:ct};function r7(e){let{inputs:t,backend:n,attrs:a}=e,{a:r,b:s}=t,{transposeA:i,transposeB:o}=a;ve([r,s],"matMul");let l=r.shape.length,d=s.shape.length,u=i?r.shape[l-2]:r.shape[l-1],p=o?s.shape[d-1]:s.shape[d-2],c=i?r.shape[l-1]:r.shape[l-2],h=o?s.shape[d-2]:s.shape[d-1],m=r.shape.slice(0,-2),f=s.shape.slice(0,-2),A=k.sizeFromShape(m),y=k.sizeFromShape(f),g=A===y||A===1||y===1;k.assert(l>=2&&d>=2&&g,()=>`Error in matMul: the input batch dimensions must either be the same or at least one input batch dimension must be 1. Got input batch dimensions of (${m}) and (${f}).`);let x=(A>y?r.shape.slice(0,-2):s.shape.slice(0,-2)).concat([c,h]);k.assert(u===p,()=>`Error in matMul: inner shapes (${u}) and (${p}) of Tensors with shapes ${r.shape} and ${s.shape} and transposeA=${i} and transposeB=${o} must match.`);let w=i?[A,u,c]:[A,c,u],b=o?[y,h,p]:[y,p,h],v=ct({inputs:{x:r},backend:n,attrs:{shape:w}}),N=ct({inputs:{x:s},backend:n,attrs:{shape:b}}),T=i?v.shape[1]:v.shape[2],R=i?v.shape[2]:v.shape[1],$=o?N.shape[1]:N.shape[2],z=Math.max(A,y),P=n.data.get(v.dataId).values,V=n.data.get(N.dataId).values,j=k.computeStrides(v.shape),U=k.computeStrides(N.shape),[X,G,ee]=i?[j[0],1,j[1]]:[j[0],j[1],1],[Y,re,ne]=o?[1,U[1],U[0]]:[U[1],1,U[0]],ie=R*$,Q=We([z,R,$],v.dtype),de=Q.values,oe=n.blockSize;for(let ye=0;yeMath.acos(e)),H$={kernelName:eo,backendName:"cpu",kernelFunc:U$},G$=nt(to,e=>Math.acosh(e)),q$={kernelName:to,backendName:"cpu",kernelFunc:G$};function X$(e){let{inputs:t,backend:n}=e,a=t;ve(t,"addN");let r=a.map(o=>n.data.get(o.dataId).values),s=We(a[0].shape,a[0].dtype),i=s.values;for(let o=0;og&&(g=b,x=w)}h[A]=x}return d.forEach(A=>n.disposeIntermediateTensorInfo(A)),n.makeTensorInfo(u,"int32",h)}var tD={kernelName:os,backendName:"cpu",kernelFunc:eD};function nD(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{axis:s}=a;ve(r,"argMin");let i=k.parseAxisParam(s,r.shape),o=C.getAxesPermutation(i,r.shape.length),l=r,d=[];o!=null&&(l=Kn({inputs:{x:r},backend:n,attrs:{perm:o}}),d.push(l),i=C.getInnerMostAxes(i.length,l.shape.length)),i=[i[0]],C.assertAxesAreInnerMostDims("argMin",i,l.shape.length);let[u,p]=C.computeOutAndReduceShapes(l.shape,i),c=k.sizeFromShape(u),h=k.makeZerosTypedArray(c,"int32"),m=k.sizeFromShape(p),f=n.data.get(l.dataId).values;for(let A=0;An.disposeIntermediateTensorInfo(A)),n.makeTensorInfo(u,"int32",h)}var aD={kernelName:Au,backendName:"cpu",kernelFunc:nD},rD=nt(ro,e=>Math.asin(e)),sD={kernelName:ro,backendName:"cpu",kernelFunc:rD},iD=nt(so,e=>Math.asinh(e)),oD={kernelName:so,backendName:"cpu",kernelFunc:iD},lD=nt(io,e=>Math.atan(e)),uD={kernelName:io,backendName:"cpu",kernelFunc:lD},dD=Rt((e,t)=>Math.atan2(e,t)),pD=Ut(lo,dD),cD={kernelName:lo,backendName:"cpu",kernelFunc:pD},hD=nt(oo,e=>Math.atanh(e)),fD={kernelName:oo,backendName:"cpu",kernelFunc:hD};function JA(e,t,n,a,r,s){let i=r.strideHeight,o=r.strideWidth,l=r.dilationHeight,d=r.dilationWidth,u=r.effectiveFilterHeight,p=r.effectiveFilterWidth,c=r.padInfo.top,h=r.padInfo.left,m=s==="max"?Number.NEGATIVE_INFINITY:Number.POSITIVE_INFINITY,f=We(r.outShape,n),A=f.values,y=r.outShape[1]*r.outShape[2]*r.outShape[3],g=r.outShape[2]*r.outShape[3],x=r.outShape[3];for(let w=0;wG?G=oe:s==="avg"&&(ee+=oe,Y++)}if(isNaN(G))break}let re=P+V*x+N;A[re]=s==="avg"?ee/Y:G}}}return f}function s7(e,t,n,a,r=!1,s=!1){let i=We(a.outShape,"int32"),o=a.strideHeight,l=a.strideWidth,d=a.dilationHeight,u=a.dilationWidth,p=a.effectiveFilterHeight,c=a.effectiveFilterWidth,h=a.padInfo.top,m=a.padInfo.left,f=We(t,n,e);for(let A=0;A$&&($=X,r?z=s?((A*a.inHeight+P)*a.inWidth+j)*a.inChannels+y:(P*a.inWidth+j)*a.inChannels+y:z=V*c+U)}}i.set(z,A,g,v,y)}}return i}function i7(e,t,n,a,r,s){let i=r.strideDepth,o=r.strideHeight,l=r.strideWidth,d=r.dilationDepth,u=r.dilationHeight,p=r.dilationWidth,c=r.effectiveFilterDepth,h=r.effectiveFilterHeight,m=r.effectiveFilterWidth,f=r.padInfo.front,A=r.padInfo.top,y=r.padInfo.left,g=s==="max"?Number.NEGATIVE_INFINITY:Number.POSITIVE_INFINITY,x=We(r.outShape,n),w=x.values,b=r.outShape[1]*r.outShape[2]*r.outShape[3]*r.outShape[4],v=r.outShape[2]*r.outShape[3]*r.outShape[4],N=r.outShape[3]*r.outShape[4],T=r.outShape[4];for(let R=0;RIe?Ie=Ve:s==="avg"&&(Ne+=Ve,$e++),isNaN(Ie))break}if(isNaN(Ie))break}if(isNaN(Ie))break}let ze=ce+P;w[ze]=s==="avg"?Ne/$e:Ie}}}}return x}function mD(e,t){let n=We(t.outShape,"int32"),a=t.strideDepth,r=t.strideHeight,s=t.strideWidth,i=t.dilationDepth,o=t.dilationHeight,l=t.dilationWidth,d=t.effectiveFilterDepth,u=t.effectiveFilterHeight,p=t.effectiveFilterWidth,c=t.padInfo.front,h=t.padInfo.top,m=t.padInfo.left;for(let f=0;f=V&&(V=ne,j=X*u*p+ee*u+re)}}}n.set(j,f,y,b,R,A)}}}return n}function AD(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t;ve(r,"avgPool");let{filterSize:s,strides:i,pad:o,dimRoundingMode:l}=a,d=1;k.assert(C.eitherStridesOrDilationsAreOne(i,d),()=>`Error in avgPool: Either strides or dilations must be 1. Got strides ${i} and dilations '${d}'`);let u=C.computePool2DInfo(r.shape,s,i,d,o,l),p;if(u.filterWidth===1&&u.filterHeight===1&&k.arraysEqual(u.inShape,u.outShape))p=Wa({inputs:{x:r},backend:n});else{let c=n.data.get(r.dataId).values,h=k.computeStrides(r.shape),m=JA(c,r.shape,r.dtype,h,u,"avg");p=n.makeTensorInfo(u.outShape,r.dtype,m.values)}return p}var yD={kernelName:ls,backendName:"cpu",kernelFunc:AD};function gD(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{filterSize:s,strides:i,pad:o,dimRoundingMode:l,dataFormat:d}=a;ve(r,"avgPool3d");let u=C.computePool3DInfo(r.shape,s,i,1,o,l,d),p=n.data.get(r.dataId).values,c=i7(p,r.shape,r.dtype,k.computeStrides(r.shape),u,"avg");return n.makeTensorInfo(c.shape,"float32",c.values)}var xD={kernelName:yu,backendName:"cpu",kernelFunc:gD};function bD(e){let{inputs:t,backend:n,attrs:a}=e,{dy:r,input:s}=t,{filterSize:i,strides:o,pad:l,dimRoundingMode:d}=a;ve([r,s],"avgPool3DGrad");let u=C.computePool3DInfo(s.shape,i,o,1,l,d),p=u.strideDepth,c=u.strideHeight,h=u.strideWidth,m=u.filterDepth,f=u.filterHeight,A=u.filterWidth,y=u.dilationDepth,g=u.dilationHeight,x=u.dilationWidth,w=u.effectiveFilterDepth,b=u.effectiveFilterHeight,v=u.effectiveFilterWidth,N=w-1-u.padInfo.front,T=v-1-u.padInfo.left,R=b-1-u.padInfo.top,$=We(s.shape,"float32"),z=1/(m*f*A),P=n.bufferSync(r);for(let V=0;V=u.outDepth||Math.floor(Q)!==Q))for(let de=0;de=u.outHeight||Math.floor(oe)!==oe))for(let ye=0;ye=u.outWidth||Math.floor(ce)!==ce||(ne+=P.get(V,Q,oe,ce,j))}}}$.set(ne*z,V,U,X,G,j)}return n.makeTensorInfo($.shape,$.dtype,$.values)}var vD={kernelName:Cp,backendName:"cpu",kernelFunc:bD};function wD(e){let{inputs:t,backend:n,attrs:a}=e,{dy:r,input:s}=t,i=s;ve([r,s],"avgPoolGrad");let{filterSize:o,strides:l,pad:d}=a,u=C.computePool2DInfo(i.shape,o,l,1,d),p=u.strideHeight,c=u.strideWidth,h=u.filterHeight,m=u.filterWidth,f=u.dilationHeight,A=u.dilationWidth,y=u.effectiveFilterHeight,g=u.effectiveFilterWidth,x=g-1-u.padInfo.left,w=y-1-u.padInfo.top,b=We(i.shape,"float32"),v=1/(h*m),N=n.data.get(r.dataId).values,T=We(r.shape,"float32",N);for(let R=0;R=u.outHeight||Math.floor(G)!==G))for(let ee=0;ee=u.outWidth||Math.floor(Y)!==Y||(U+=T.get(R,G,Y,$))}}b.set(U*v,R,z,P,$)}return n.makeTensorInfo(b.shape,b.dtype,b.values)}var kD={kernelName:Ep,backendName:"cpu",kernelFunc:wD};function ID(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,scale:s,offset:i,mean:o,variance:l}=t;k.assert(o.shape.length===l.shape.length,()=>"Batch normalization gradient requires mean and variance to have equal ranks."),k.assert(i==null||o.shape.length===i.shape.length,()=>"Batch normalization gradient requires mean and offset to have equal ranks."),k.assert(s==null||o.shape.length===s.shape.length,()=>"Batch normalization gradient requires mean and scale to have equal ranks."),ve([r,o,l,s,i],"batchNorm");let{varianceEpsilon:d}=a;d==null&&(d=.001);let u=n.data.get(r.dataId).values,p=n.data.get(o.dataId).values,c=n.data.get(l.dataId).values,h=s?n.data.get(s.dataId).values:new Float32Array([1]),m=i?n.data.get(i.dataId).values:new Float32Array([0]),f=new Float32Array(u.length),A=m.length,y=h.length,g=c.length,x=p.length,w=0,b=0,v=0,N=0;for(let T=0;T=A&&(w=0),b>=x&&(b=0),v>=y&&(v=0),N>=g&&(N=0);return n.makeTensorInfo(r.shape,r.dtype,f)}var SD={kernelName:vs,backendName:"cpu",kernelFunc:ID};function ND(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{blockShape:s,crops:i}=a;ve([r],"batchToSpaceND");let o=s.reduce((y,g)=>y*g),l=C.getReshaped(r.shape,s,o),d=C.getPermuted(l.length,s.length),u=C.getReshapedPermuted(r.shape,s,o),p=C.getSliceBeginCoords(i,s.length),c=C.getSliceSize(u,i,s.length),h=ct({inputs:{x:r},backend:n,attrs:{shape:l}}),m=Kn({inputs:{x:h},backend:n,attrs:{perm:d}}),f=ct({inputs:{x:m},backend:n,attrs:{shape:u}}),A=xi({inputs:{x:f},backend:n,attrs:{begin:p,size:c}});return n.disposeIntermediateTensorInfo(h),n.disposeIntermediateTensorInfo(m),n.disposeIntermediateTensorInfo(f),A}var TD={kernelName:gu,backendName:"cpu",kernelFunc:ND};function ED(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,weights:s}=t,{size:i}=a,o=n.data.get(r.dataId).values,l=n.data.get(s.dataId).values,d=UA(o,l,s.dtype,s.shape,i);return n.makeTensorInfo([i],s.dtype,d)}var CD={kernelName:Rp,backendName:"cpu",kernelFunc:ED},RD=nt(kr,(e,t)=>{let n=t;return e>n.clipValueMax?n.clipValueMax:e{let{x:t}=e.inputs,n=e.backend,a=new Float32Array(k.sizeFromShape(t.shape)),r=n.data.get(t.dataId),s=r.complexTensorInfos.real,i=r.complexTensorInfos.imag,o=n.data.get(s.dataId).values,l=n.data.get(i.dataId).values;for(let d=0;df.shape),s);if(k.sizeFromShape(i)===0)return n.makeTensorInfo(i,t[0].dtype,[]);let o=t.filter(f=>k.sizeFromShape(f.shape)>0);if(o.length===1)return Wa({inputs:{x:o[0]},backend:n});let l=o.map(f=>f.shape);if(C.assertParamsConsistent(l,s),o[0].dtype==="complex64"){let f=o.map(w=>gi({inputs:{input:w},backend:n})),A=o.map(w=>Nl({inputs:{input:w},backend:n})),y=Tl({inputs:f,backend:n,attrs:{axis:s}}),g=Tl({inputs:A,backend:n,attrs:{axis:s}}),x=_n({inputs:{real:y,imag:g},backend:n});return f.forEach(w=>n.disposeIntermediateTensorInfo(w)),A.forEach(w=>n.disposeIntermediateTensorInfo(w)),n.disposeIntermediateTensorInfo(y),n.disposeIntermediateTensorInfo(g),x}let d=o.map(f=>{let A=k.sizeFromShape(f.shape.slice(s));return ct({inputs:{x:f},backend:n,attrs:{shape:[-1,A]}})}),u=d.map(f=>({vals:n.data.get(f.dataId).values,shape:f.shape}));i=C.computeOutShape(d.map(f=>f.shape),1);let p=d[0].shape[0]===1,c=HA(u,i,t[0].dtype,p),h=C.computeOutShape(o.map(f=>f.shape),s),m=n.makeTensorInfo(h,t[0].dtype,c);return d.forEach(f=>n.disposeIntermediateTensorInfo(f)),m}var OD={kernelName:uo,backendName:"cpu",kernelFunc:Tl};function o7(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,filter:s}=t,{strides:i,pad:o,dataFormat:l,dilations:d,dimRoundingMode:u}=a;ve([r,s],"conv2d");let p=C.convertConv2DDataFormat(l),c=C.computeConv2DInfo(r.shape,s.shape,i,d,o,u,!1,p),h=c.filterHeight,m=c.filterWidth,f=c.dilationHeight,A=c.dilationWidth,y=c.padInfo.left,g=c.padInfo.top,x=c.dataFormat==="channelsLast",w=new Dt(c.outShape,r.dtype),b=k.computeStrides(r.shape),v=k.computeStrides(s.shape),N=b[0],T=x?b[1]:b[2],R=x?b[2]:1,$=x?1:b[1],z=w.strides[0],P=x?w.strides[1]:w.strides[2],V=x?w.strides[2]:1,j=x?1:w.strides[1],U=n.data.get(r.dataId).values,X=n.data.get(s.dataId).values,G=w.values;for(let ee=0;ee=c.inHeight)continue;let ye=de*v[0],ce=Y+oe*T;for(let Ie=0;Ie=c.inWidth)continue;let Qe=ye+ze*v[1],et=ce+De*R,rt=Qe;for(let Xe=0;Xe=d.inDepth)continue;let ee=X*R[0],Y=z+G*T[1];for(let re=0;re=d.inHeight)continue;let oe=ee+Q*R[1],ye=Y+de*T[2];for(let ce=0;ce=d.inWidth)continue;let De=oe+$e*R[2],Qe=ye+ze*d.inChannels,et=De;for(let rt=0;rtMath.cos(e)),XD={kernelName:fs,backendName:"cpu",kernelFunc:qD},KD=nt(po,e=>Math.cosh(e)),ZD={kernelName:po,backendName:"cpu",kernelFunc:KD};function YD(e){let{inputs:t,backend:n,attrs:a}=e,{image:r,boxes:s,boxInd:i}=t,{cropSize:o,method:l,extrapolationValue:d}=a,[u,p,c,h]=r.shape,m=s.shape[0],[f,A]=o,y=We([m,f,A,h],"float32"),g=n.data.get(s.dataId).values,x=n.data.get(i.dataId).values,w=n.data.get(r.dataId).values,b=k.computeStrides(r.shape),v=k.computeStrides(y.shape);for(let N=0;N=u)continue;let j=f>1?(z-R)*(p-1)/(f-1):0,U=A>1?(P-$)*(c-1)/(A-1):0;for(let X=0;X1?R*(p-1)+X*j:.5*(R+z)*(p-1);if(G<0||G>p-1){for(let ee=0;ee1?$*(c-1)+ne*U:.5*($+P)*(c-1);if(ie<0||ie>c-1){for(let ye=0;ye1?$*(c-1)+ee*U:.5*($+P)*(c-1);if(Y<0||Y>c-1){for(let ie=0;iey+m-g-1:(y,g)=>y+g;for(let y=0;y`Only NHWC dataFormat supported on CPU for depthToSpace. Got ${i}`),k.assert(s>1,()=>`blockSize should be > 1 for depthToSpace, but was: ${s}`);let o=r.shape[0],l=r.shape[1],d=r.shape[2],u=r.shape[3],p=l*s,c=d*s,h=u/(s*s),m=n.data.get(r.dataId).values,f=new Float32Array(o*p*c*h),A=0;for(let y=0;y`Error in depthwiseConv2d: Either strides or dilations must be 1. Got strides ${i} and dilations '${c}'`);let h=C.computeConv2DInfo(r.shape,s.shape,i,c,o,d,!0),{filterHeight:m,filterWidth:f,dilationHeight:A,dilationWidth:y,padInfo:g}=h,x=g.left,w=g.top,b=h.outChannels/h.inChannels,v=new Dt(h.outShape,r.dtype),N=n.data.get(r.dataId).values,T=n.data.get(s.dataId).values,R=v.values;for(let $=0;$=h.inHeight)continue;let ee=X*p[0],Y=z+G*u[1];for(let re=0;re=h.inWidth)continue;let oe=ee+Q*p[1],ye=Y+de*h.inChannels,ce=ne,Ie=oe;for(let Ne=0;Ne{let{x:a,filter:r}=e,{strides:s,pad:i,dilations:o}=n,l=t,d=l.data.get(a.dataId).values,u=a.shape.length,p=l.data.get(r.dataId).values,c=r.shape.length,{batchSize:h,inHeight:m,inWidth:f,inChannels:A,outHeight:y,outWidth:g,padInfo:x,strideHeight:w,strideWidth:b,filterHeight:v,filterWidth:N,dilationHeight:T,dilationWidth:R,outShape:$}=C.computeDilation2DInfo(a.shape,r.shape,s,i,"NHWC",o),z=k.sizeFromShape($),P=$.length,V=k.getArrayFromDType(a.dtype,z);for(let j=0;j=0&&Q=0&&oere&&(re=Ie)}}}let ne=k.locToIndex([j,U,G,Y],P,k.computeStrides($));V[ne]=re}}}return{dataId:l.write(k.toTypedArray(V,a.dtype),$,a.dtype),shape:$,dtype:a.dtype}}},hO={kernelName:Wp,backendName:"cpu",kernelFunc:({inputs:e,backend:t,attrs:n})=>{let{x:a,filter:r,dy:s}=e,{strides:i,pad:o,dilations:l}=n,d=t,u=k.toNestedArray(a.shape,d.data.get(a.dataId).values),p=k.toNestedArray(r.shape,d.data.get(r.dataId).values),{batchSize:c,inHeight:h,inWidth:m,inChannels:f,outHeight:A,outWidth:y,padInfo:g,strideHeight:x,strideWidth:w,filterHeight:b,filterWidth:v,dilationHeight:N,dilationWidth:T,outShape:R}=C.computeDilation2DInfo(a.shape,r.shape,i,o,"NHWC",l);k.assert(s.rank===R.length,()=>`Error in ${Wp}, dy must have the same rank as output ${R.length}, but got ${s.rank}`);let $=k.toNestedArray(R,d.data.get(s.dataId).values),z=k.makeZerosNestedTypedArray(r.shape,r.dtype);for(let P=0;P=0&&ie=0&&deee&&(ee=oe,Y=ne,re=Q)}}}z[Y][re][G]+=$[P][V][U][G]}}}return{dataId:d.write(k.toTypedArray(z,a.dtype),r.shape,r.dtype),shape:r.shape,dtype:r.dtype}}},fO={kernelName:Lp,backendName:"cpu",kernelFunc:({inputs:e,backend:t,attrs:n})=>{let{x:a,filter:r,dy:s}=e,{strides:i,pad:o,dilations:l}=n,d=t,u=k.toNestedArray(a.shape,d.data.get(a.dataId).values),p=k.toNestedArray(r.shape,d.data.get(r.dataId).values),{batchSize:c,inHeight:h,inWidth:m,inChannels:f,outHeight:A,outWidth:y,padInfo:g,strideHeight:x,strideWidth:w,filterHeight:b,filterWidth:v,dilationHeight:N,dilationWidth:T,outShape:R}=C.computeDilation2DInfo(a.shape,r.shape,i,o,"NHWC",l);k.assert(s.rank===R.length,()=>`Error in ${Lp}, dy must have the same rank as output ${R.length}, but got ${s.rank}`);let $=k.toNestedArray(R,d.data.get(s.dataId).values),z=k.makeZerosNestedTypedArray(a.shape,a.dtype);for(let P=0;P=0&&ie=0&&deee&&(ee=oe,Y=ie,re=de)}}}z[P][Y][re][G]+=$[P][V][U][G]}}}return{dataId:d.write(k.toTypedArray(z,a.dtype),a.shape,a.dtype),shape:a.shape,dtype:a.dtype}}};function od(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{axis:s,keepDims:i}=a;ve(r,"sum");let o;r.dtype==="bool"?o=_r({inputs:{x:r},backend:n,attrs:{dtype:"int32"}}):o=Wa({inputs:{x:r},backend:n});let l=o.shape.length,d=k.parseAxisParam(s,o.shape),u=C.getAxesPermutation(d,l),p=d,c=o;u!=null&&(c=Kn({inputs:{x:o},backend:n,attrs:{perm:u}}),p=C.getInnerMostAxes(p.length,l)),C.assertAxesAreInnerMostDims("sum",p,c.shape.length);let[h,m]=C.computeOutAndReduceShapes(c.shape,p),f=C.upcastType(c.dtype,"int32"),A=rh(n,h,f),y=k.sizeFromShape(m),g=n.data.get(A.dataId).values,x=n.data.get(c.dataId).values;for(let w=0;w=0&&(c=od({inputs:{x:c},backend:n,attrs:{axis:d[f]-(i.length-h),keepDims:!1}}),m.push(c)),h--)}for(let f of m)f!==c&&n.disposeIntermediateTensorInfo(f);return c}var yO={kernelName:Bp,backendName:"cpu",kernelFunc:AO};function gO(e){let{inputs:t,backend:n}=e,{dy:a,y:r}=t;ve([a,r],"eluGrad");let s=new Float32Array(k.sizeFromShape(r.shape)),i=n.data.get(r.dataId).values,o=n.data.get(a.dataId).values;for(let l=0;l=1?s[l]=o[l]:s[l]=o[l]*(d+1)}return n.makeTensorInfo(r.shape,"float32",s)}var xO={kernelName:Vp,backendName:"cpu",kernelFunc:gO},bO=Rt((e,t)=>e===t?1:0),u7=Ut(Ao,bO,null,"bool"),vO={kernelName:Ao,backendName:"cpu",kernelFunc:u7},wO=C.ERF_P,kO=C.ERF_A1,IO=C.ERF_A2,SO=C.ERF_A3,NO=C.ERF_A4,TO=C.ERF_A5,EO=nt(mo,e=>{let t=Math.sign(e),n=Math.abs(e),a=1/(1+wO*n);return t*(1-((((TO*a+NO)*a+SO)*a+IO)*a+kO)*a*Math.exp(-n*n))}),CO={kernelName:mo,backendName:"cpu",kernelFunc:EO};function ih(e){let{inputs:t,backend:n,attrs:a}=e,{input:r}=t,{dim:s}=a,i=r.shape.length,o=r.shape.slice(),l=s;return s<0&&(k.assert(-(i+1)<=s,()=>`Axis must be in the interval [${-(i+1)}, ${i}]`),l=i+s+1),o.splice(l,0,1),ct({inputs:{x:r},backend:n,attrs:{shape:o}})}var RO={kernelName:yo,backendName:"cpu",kernelFunc:ih},MO=Rt((e,t)=>e/t),QA=Ut(ys,MO),e1={kernelName:ys,backendName:"cpu",kernelFunc:QA};function d7(e,t,n){let a=e.shape,r=a[0],s=a[1],i=n.data.get(e.dataId),o=i.complexTensorInfos.real,l=i.complexTensorInfos.imag,d=[r,s],u=k.sizeFromShape(d),p=k.getTypedArrayFromDType("float32",u),c=k.getTypedArrayFromDType("float32",u);for(let A=0;A{let{image:a}=e,r=n,s=k.getTypedArrayFromDType(a.dtype,k.sizeFromShape(a.shape)),[i,o,l,d]=a.shape,u=r.data.get(a.dataId).values;for(let p=0;p=0&&xMath.floor(e/t)),BO=Ut(bs,WO,null,"int32"),VO={kernelName:bs,backendName:"cpu",kernelFunc:BO};function jO(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,filter:s,bias:i,preluActivationWeights:o}=t,{strides:l,pad:d,dataFormat:u,dilations:p,dimRoundingMode:c,activation:h,leakyreluAlpha:m}=a,f=o7({inputs:{x:r,filter:s},backend:n,attrs:{strides:l,pad:d,dataFormat:u,dilations:p,dimRoundingMode:c}});if(i){let A=f;f=id({inputs:{a:f,b:i},backend:n}),n.disposeIntermediateTensorInfo(A)}if(h){let A=f;f=YA(n,f,h,o,m),n.disposeIntermediateTensorInfo(A)}return f}var UO={kernelName:ti,backendName:"cpu",kernelFunc:jO};function HO(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,filter:s,bias:i,preluActivationWeights:o}=t,{strides:l,pad:d,dataFormat:u,dilations:p,dimRoundingMode:c,activation:h,leakyreluAlpha:m}=a,f=l7({inputs:{x:r,filter:s},backend:n,attrs:{strides:l,pad:d,dataFormat:u,dilations:p,dimRoundingMode:c}});if(i){let A=f;f=id({inputs:{a:f,b:i},backend:n}),n.disposeIntermediateTensorInfo(A)}if(h){let A=f;f=YA(n,f,h,o,m),n.disposeIntermediateTensorInfo(A)}return f}var GO={kernelName:ni,backendName:"cpu",kernelFunc:HO};function qO(e){let{inputs:t,backend:n}=e,{params:a,indices:r}=t,s=k.sizeFromShape(a.shape),i=r.shape,o=i[i.length-1],[l,d,u,p]=C.prepareAndValidate(a,r);if(d===0)return n.makeTensorInfo(l,a.dtype,[]);let c=We([d,u],a.dtype),h=n.data.get(r.dataId).values,m=n.data.get(a.dataId).values;for(let f=0;f=s/u)throw new Error(`Invalid indices: ${A} does not index into ${a.shape}`);for(let g=0;ge>=t?1:0),JO=Ut(ws,YO,null,"bool"),QO={kernelName:ws,backendName:"cpu",kernelFunc:JO};function ez(e){let{inputs:t,backend:n}=e,{input:a}=t,r=k.sizeFromShape(a.shape),s=a.shape[a.shape.length-1],i=r/s,o=ct({inputs:{x:a},backend:n,attrs:{shape:[i,s]}}),l=d7(o,!0,n),d=ct({inputs:{x:l},backend:n,attrs:{shape:a.shape}});return n.disposeIntermediateTensorInfo(o),n.disposeIntermediateTensorInfo(l),d}var tz={kernelName:Up,backendName:"cpu",kernelFunc:ez},nz=nt(ko,e=>Number.isFinite(e)?1:0,"bool"),az={kernelName:ko,backendName:"cpu",kernelFunc:nz},rz=nt(Io,e=>Math.abs(e)===Infinity?1:0,"bool"),sz={kernelName:Io,backendName:"cpu",kernelFunc:rz},iz=nt(So,e=>Number.isNaN(e)?1:0,"bool"),oz={kernelName:So,backendName:"cpu",kernelFunc:iz},lz=Rt((e,t)=>e<=t?1:0),uz=Ut(To,lz,null,"bool"),dz={kernelName:To,backendName:"cpu",kernelFunc:uz};function pz(e){let{backend:t,attrs:n}=e,{start:a,stop:r,num:s}=n,i=$3(a,r,s);return t.makeTensorInfo([i.length],"float32",i)}var cz={kernelName:Gp,backendName:"cpu",kernelFunc:pz},hz=nt(Eo,e=>Math.log1p(e)),fz={kernelName:Eo,backendName:"cpu",kernelFunc:hz},mz=Rt((e,t)=>e&&t),Az=Ut(Co,mz,null,"bool"),yz={kernelName:Co,backendName:"cpu",kernelFunc:Az},gz=nt(ku,e=>e?0:1,"bool"),xz={kernelName:ku,backendName:"cpu",kernelFunc:gz},bz=Rt((e,t)=>e||t),vz=Ut(Iu,bz,null,"bool"),wz={kernelName:Iu,backendName:"cpu",kernelFunc:vz};function kz(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{depthRadius:s,bias:i,alpha:o,beta:l}=a;ve(r,"LRN");let d=r.shape[3],u=d-1,p=n.data.get(r.dataId).values,c=k.sizeFromShape(r.shape),h=new Float32Array(c);function m(f){let A=f%d,y=f-A+Math.max(0,A-s),g=f-A+Math.min(A+s,u),x=0;for(;y<=g;y++){let w=p[y];x+=w*w}return x}for(let f=0;f`Error in maxPool: Either strides or dilations must be 1. Got strides ${i} and dilations '${d}'`);let u=C.computePool2DInfo(r.shape,s,i,d,o,l),p;if(u.filterWidth===1&&u.filterHeight===1&&k.arraysEqual(u.inShape,u.outShape))p=Wa({inputs:{x:r},backend:n});else{let c=n.data.get(r.dataId).values,h=k.computeStrides(r.shape),m=JA(c,r.shape,r.dtype,h,u,"max");p=n.makeTensorInfo(u.outShape,r.dtype,m.values)}return p}var Cz={kernelName:Es,backendName:"cpu",kernelFunc:Ez};function Rz(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{filterSize:s,strides:i,pad:o,dimRoundingMode:l,dataFormat:d}=a;ve(r,"maxPool3d");let u=C.computePool3DInfo(r.shape,s,i,1,o,l,d),p=n.data.get(r.dataId).values,c=i7(p,r.shape,r.dtype,k.computeStrides(r.shape),u,"max");return n.makeTensorInfo(c.shape,"float32",c.values)}var Mz={kernelName:Nu,backendName:"cpu",kernelFunc:Rz};function Fz(e){let{inputs:t,backend:n,attrs:a}=e,{dy:r,input:s}=t,{filterSize:i,strides:o,pad:l,dimRoundingMode:d}=a;ve([r,s],"maxPool3DGrad");let u=C.computePool3DInfo(s.shape,i,o,1,l,d),p=n.bufferSync(s),c=mD(p,u),h=u.strideDepth,m=u.strideHeight,f=u.strideWidth,A=u.dilationDepth,y=u.dilationHeight,g=u.dilationWidth,x=u.effectiveFilterDepth,w=u.effectiveFilterHeight,b=u.effectiveFilterWidth,v=x-1-u.padInfo.front,N=b-1-u.padInfo.left,T=w-1-u.padInfo.top,R=We(s.shape,"float32"),$=n.bufferSync(r);for(let z=0;z=u.outDepth||Math.floor(ne)!==ne))for(let ie=0;ie=u.outHeight||Math.floor(Q)!==Q))for(let de=0;de=u.outWidth||Math.floor(oe)!==oe)continue;let ye=x*w*b-1-c.get(z,ne,Q,oe,P),ce=re*w*b+ie*b+de,Ie=ye===ce?1:0;Ie!==0&&(Y+=$.get(z,ne,Q,oe,P)*Ie)}}}R.set(Y,z,V,j,U,P)}return n.makeTensorInfo(R.shape,R.dtype,R.values)}var $z={kernelName:Kp,backendName:"cpu",kernelFunc:Fz};function Dz(e){let{inputs:t,backend:n,attrs:a}=e,{dy:r,input:s,output:i}=t,o=s;ve([s,i],"maxPoolGrad");let{filterSize:l,strides:d,pad:u,dimRoundingMode:p}=a,c=C.computePool2DInfo(o.shape,l,d,1,u,p),h=n.data.get(o.dataId).values,m=We(c.outShape,o.dtype,s7(h,o.shape,o.dtype,c).values),f=c.strideHeight,A=c.strideWidth,y=c.dilationHeight,g=c.dilationWidth,x=c.effectiveFilterHeight,w=c.effectiveFilterWidth,b=w-1-c.padInfo.left,v=x-1-c.padInfo.top,N=We(o.shape,"float32"),T=n.data.get(r.dataId).values,R=We(r.shape,"float32",T);for(let $=0;$=c.outHeight||Math.floor(ee)!==ee))for(let Y=0;Y=c.outWidth||Math.floor(re)!==re)continue;let ne=x*w-1-m.get($,ee,re,z),ie=G*w+Y,Q=ne===ie?1:0;Q!==0&&(X+=R.get($,ee,re,z)*Q)}}N.set(X,$,P,V,z)}return n.makeTensorInfo(N.shape,N.dtype,N.values)}var Oz={kernelName:Xp,backendName:"cpu",kernelFunc:Dz};function zz(e,t,n,a,r){let s=k.computeStrides(t),i=JA(e,t,n,s,r,"max"),o=s7(e,t,n,r,!0,a);return[i.values,o.values]}var _z={kernelName:Zp,backendName:"cpu",kernelFunc:({inputs:e,attrs:t,backend:n})=>{let{x:a}=e,{filterSize:r,strides:s,pad:i,includeBatchInIndex:o}=t,l=n;ve(a,"MaxPoolWithArgmax");let d=l.data.get(a.dataId).values,u=C.computePool2DInfo(a.shape,r,s,[1,1],i),[p,c]=zz(d,a.shape,a.dtype,o,u),h=l.write(p,u.outShape,a.dtype),m=l.write(c,u.outShape,a.dtype);return[{dataId:h,shape:u.outShape,dtype:a.dtype},{dataId:m,shape:u.outShape,dtype:"int32"}]}};function Pz(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{axis:s,keepDims:i}=a,o=k.parseAxisParam(s,r.shape),l=C.computeOutAndReduceShapes(r.shape,o)[1],d=k.sizeFromShape(l),u=[],p=n.makeTensorInfo([],"float32",new Float32Array([d]));u.push(p);let c=_r({inputs:{x:r},backend:n,attrs:{dtype:"float32"}});u.push(c);let h=QA({inputs:{a:c,b:p},backend:n});u.push(h);let m=od({inputs:{x:h},backend:n,attrs:{axis:s,keepDims:i}});return u.forEach(f=>n.disposeIntermediateTensorInfo(f)),m}var Lz={kernelName:Cs,backendName:"cpu",kernelFunc:Pz};function Wz(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{axis:s,keepDims:i}=a;ve(r,"min");let o=k.parseAxisParam(s,r.shape),l=o,d=C.getAxesPermutation(l,r.shape.length),u=r;d!=null&&(u=Kn({inputs:{x:r},backend:n,attrs:{perm:d}}),l=C.getInnerMostAxes(l.length,r.shape.length)),C.assertAxesAreInnerMostDims("min",l,u.shape.length);let[p,c]=C.computeOutAndReduceShapes(u.shape,l),h=k.sizeFromShape(c),m=k.makeZerosTypedArray(k.sizeFromShape(p),u.dtype),f=n.data.get(u.dataId).values;for(let y=0;yg[0]+r.shape[x]+g[1]),l=s.map(g=>g[0]),d=s.map((g,x)=>g[0]+r.shape[x]),u=i==="reflect"?0:1,p=n.data.get(r.dataId).values,c=r.shape.length,h=k.computeStrides(r.shape),m=k.sizeFromShape(o),f=o.length,A=k.computeStrides(o),y=k.getTypedArrayFromDType(r.dtype,m);for(let g=0;g=d[b]&&(x[b]=(d[b]-1)*2-x[b]+u);x=x.map((b,v)=>b-l[v]);let w=k.locToIndex(x,c,h);y[g]=p[w]}return{dataId:n.write(y,o,r.dtype),shape:o,dtype:r.dtype}}var jz={kernelName:Fs,backendName:"cpu",kernelFunc:Vz},Uz=Rt((e,t)=>{let n=e%t;return e<0&&t<0||e>=0&&t>=0?n:(n+t)%t}),Hz=Ut(Ro,Uz),Gz={kernelName:Ro,backendName:"cpu",kernelFunc:Hz},qz=Zi(Wg());function c7(e){let{inputs:t,backend:n,attrs:a}=e,{logits:r}=t,{dim:s}=a,i=r.shape.length,o=s;if(o===-1&&(o=i-1),o!==i-1)throw Error(`Softmax along a non-last dimension is not yet supported. Logits was rank ${i} and dim was ${o}`);let l=k.parseAxisParam([o],r.shape),d=p7({inputs:{x:r},backend:n,attrs:{reductionIndices:l,keepDims:!1}}),u=C.expandShapeToKeepDim(d.shape,l),p=ct({inputs:{x:d},backend:n,attrs:{shape:u}}),c=ZA({inputs:{a:r,b:p},backend:n}),h=Z3({inputs:{x:c},backend:n}),m=od({inputs:{x:h},backend:n,attrs:{axis:l,keepDims:!1}}),f=ct({inputs:{x:m},backend:n,attrs:{shape:u}}),A=QA({inputs:{a:h,b:f},backend:n});return n.disposeIntermediateTensorInfo(d),n.disposeIntermediateTensorInfo(p),n.disposeIntermediateTensorInfo(c),n.disposeIntermediateTensorInfo(h),n.disposeIntermediateTensorInfo(m),n.disposeIntermediateTensorInfo(f),A}var Xz={kernelName:Xs,backendName:"cpu",kernelFunc:c7};function Kz(e){let{inputs:t,backend:n,attrs:a}=e,{logits:r}=t,{numSamples:s,seed:i,normalized:o}=a;ve(r,"multinomial");let l=o?r:c7({inputs:{logits:r},backend:n,attrs:{dim:-1}}),d=l.shape[0],u=l.shape[1],p=n.data.get(l.dataId).values,c=[d,s],h=k.makeZerosTypedArray(k.sizeFromShape(c),"int32");for(let m=0;m=0&&u[p]{k.assertShapesMatch(s,u.shape,"All tensors passed to stack must have matching shapes"),k.assert(i===u.dtype,()=>"All tensors passed to stack must have matching dtypes")});let o=[],l=t.map(u=>{let p=ih({inputs:{input:u},backend:n,attrs:{dim:r}});return o.push(p),p}),d=Tl({inputs:l,backend:n,attrs:{axis:r}});return o.forEach(u=>n.disposeIntermediateTensorInfo(u)),d}var d_={kernelName:_o,backendName:"cpu",kernelFunc:f7};function p_(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{paddings:s,constantValue:i}=a;ve(r,"pad");let o=s.map((y,g)=>y[0]+r.shape[g]+y[1]),l=s.map(y=>y[0]),d=n.data.get(r.dataId).values,u=k.sizeFromShape(r.shape),p=r.shape.length,c=k.computeStrides(r.shape),h=k.sizeFromShape(o),m=o.length,f=k.computeStrides(o),A=k.getTypedArrayFromDType(r.dtype,h);i!==0&&A.fill(i);for(let y=0;yw+l[b]),x=k.locToIndex(g,m,f);A[x]=d[y]}return{dataId:n.write(A,o,r.dtype),shape:o,dtype:r.dtype}}var m7={kernelName:Os,backendName:"cpu",kernelFunc:p_},c_=Rt((e,t)=>Math.pow(e,t)),h_=Ut(zs,c_),f_={kernelName:zs,backendName:"cpu",kernelFunc:h_};function m_(e){let{backend:t,attrs:n}=e,{start:a,stop:r,dtype:s,step:i}=n,o=XA(a,r,i,s);return t.makeTensorInfo([o.length],s,o)}var A_={kernelName:Tu,backendName:"cpu",kernelFunc:m_},y_=nt(Lo,e=>1/e),g_={kernelName:Lo,backendName:"cpu",kernelFunc:y_};function x_(e){let{inputs:t,backend:n,attrs:a}=e,{images:r}=t,{alignCorners:s,halfPixelCenters:i,size:o}=a;ve(r,"resizeBilinear");let l=k.computeStrides(r.shape),[d,u]=o,[p,c,h,m]=r.shape,f=n.data.get(r.dataId).values,A=new Float32Array(k.sizeFromShape([p,d,u,m])),y=[s&&d>1?c-1:c,s&&u>1?h-1:h],g=[s&&d>1?d-1:d,s&&u>1?u-1:u],x=0,w=y[0]/g[0],b=y[1]/g[1];for(let v=0;v1?d-1:d,i&&h>1?u-1:u],A=[i&&c>1?c-1:c,i&&h>1?h-1:h],y=f[0]/A[0],g=f[1]/A[1],x=n.data.get(s.dataId).values,w=0;for(let b=0;b1?c-1:c,s&&u>1?h-1:h],g=[s&&d>1?d-1:d,s&&u>1?u-1:u],x=y[0]/g[0],w=y[1]/g[1],b=0;for(let v=0;v1?u-1:u,i&&m>1?p-1:p],g=[i&&h>1?h-1:h,i&&m>1?m-1:m],x=y[0]/g[0],w=y[1]/g[1],b=1/x,v=1/w,N=Math.ceil(b)*2+2,T=Math.ceil(v)*2+2;for(let R=0;R=h)continue;let Q=$+ie*l[1],de=ie*x,oe=Math.min(u-1,i?Math.round(de):Math.floor(de));if(z===oe)for(let ye=0;ye=m)continue;let Ie=Q+ce*l[2],Ne=ce*w,$e=Math.min(p-1,i?Math.round(Ne):Math.floor(Ne));U===$e&&(re+=A[Ie+Y])}}f[X+Y]=re}}}}return n.makeTensorInfo(r.shape,r.dtype,f)}var N_={kernelName:Qp,backendName:"cpu",kernelFunc:S_};function T_(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{dims:s}=a;ve(r,"reverse");let i=r.shape.length,o=k.parseAxisParam(s,r.shape);if(i===0)return Wa({inputs:{x:r},backend:n});let l=new Dt(r.shape,r.dtype),d=n.bufferSync(r);for(let u=0;uc[h]=r.shape[h]-1-c[h]),l.set(d.get(...c),...p)}return n.makeTensorInfo(l.shape,l.dtype,l.values)}var E_={kernelName:Bs,backendName:"cpu",kernelFunc:T_},C_={kernelName:el,backendName:"cpu",kernelFunc:({inputs:e,attrs:t,backend:n})=>{let{image:a}=e,{radians:r,fillValue:s,center:i}=t,o=n,l=k.getTypedArrayFromDType(a.dtype,k.sizeFromShape(a.shape)),[d,u,p,c]=a.shape,[h,m]=C.getImageCenter(i,u,p),f=255,A=Math.sin(r),y=Math.cos(r),g=o.data.get(a.dataId).values;for(let x=0;x=0&&V=0&&j{let t=Math.floor(e);return e-t<.5?Math.floor(e):e-t>.5?Math.ceil(e):t%2==0?t:t+1}),M_={kernelName:Vs,backendName:"cpu",kernelFunc:R_};function A7(e,t,n,a,r,s,i,o,l,d){let u=[a/r,r],p=e.values,c=t.values;if(a===0)return We(n,t.dtype);let h=We(u,t.dtype);h.values.fill(l);for(let m=0;m=a/r)throw new Error(`Invalid indices: ${f} does not index into ${n}`);for(let y=0;y1||r.shape.length===1?1:k.sizeFromShape(r.shape.slice(1));for(let m=0;me>=0?__*e:z_*(Math.exp(e)-1)),L_={kernelName:jo,backendName:"cpu",kernelFunc:P_},W_=nt(Go,e=>e<0?-1:e>0?1:0),B_={kernelName:Go,backendName:"cpu",kernelFunc:W_},V_=nt(Us,e=>Math.sin(e)),j_={kernelName:Us,backendName:"cpu",kernelFunc:V_},U_=nt(Ho,e=>Math.sinh(e)),H_={kernelName:Ho,backendName:"cpu",kernelFunc:U_},G_=11920928955078125e-23,y7=Math.log(G_)+2,q_=nt(qo,e=>{let t=e>-y7,n=eNumber(A)))),n.makeTensorInfo([f.length],a.dtype,new Int32Array(f))]}var J_={kernelName:tc,backendName:"cpu",kernelFunc:Y_};function Q_(e){let{inputs:t,backend:n}=e,{inputIndices:a,inputShape:r,newShape:s}=t;if(a.shape.length!==2)throw new Error(`Input indices should be a matrix but received shape ${a.shape}`);if(r.shape.length!==1)throw new Error(`Input shape should be a vector but received shape - ${r.shape}`);if(s.shape.length!==1)throw new Error(`Target shape should be a vector but received shape ${s.shape}`);let i=Array.from(n.data.get(r.dataId).values),o=n.data.get(a.dataId).values,l=Array.from(n.data.get(s.dataId).values),[d,u,p]=j3(o,a.shape,a.dtype,i,l);return[n.makeTensorInfo(u,a.dtype,d),n.makeTensorInfo([p.length],s.dtype,new Int32Array(p))]}var eP={kernelName:nc,backendName:"cpu",kernelFunc:Q_};function tP(e){let{inputs:t,backend:n,attrs:a}=e,{sparseIndices:r,sparseValues:s,defaultValue:i}=t,{outputShape:o}=a,{sliceRank:l,numUpdates:d,sliceSize:u,strides:p,outputSize:c}=C.calculateShapes(s,r,o),h=!1,m=n.bufferSync(r),f=n.bufferSync(s),A=n.data.get(i.dataId).values[0],y=A7(m,f,o,c,u,d,l,p,A,h);return n.makeTensorInfo(o,y.dtype,y.values)}var nP={kernelName:ac,backendName:"cpu",kernelFunc:tP};function aP(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{numOrSizeSplits:s,axis:i}=a,o=k.parseAxisParam(i,r.shape)[0],l=C.prepareSplitSize(r,s,o),d=new Array(r.shape.length).fill(0),u=r.shape.slice();return l.map(p=>{let c=[...u];c[o]=p;let h=bi({inputs:{x:r},backend:n,attrs:{begin:d,size:c}});return d[o]+=p,h})}var rP={kernelName:Ko,backendName:"cpu",kernelFunc:aP},sP=nt(qs,e=>Math.sqrt(e)),iP={kernelName:qs,backendName:"cpu",kernelFunc:sP},oP={kernelName:Ru,backendName:"cpu",kernelFunc:({inputs:e,backend:t})=>{let{x:n}=e,a=t;ve(n,"square");let r=a.data.get(n.dataId).values,s=new Float32Array(r.length);for(let i=0;i{let n=t;return isNaN(e)?NaN:e>0?1:n.alpha}),uP={kernelName:Nr,backendName:"cpu",kernelFunc:lP};function dP(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{begin:s,end:i,strides:o,beginMask:l,endMask:d,ellipsisMask:u,newAxisMask:p,shrinkAxisMask:c}=a;ve(r,"stridedSlice");let{nonStrided:h,$begin:m,$strides:f,size:A,newShape:y,outShape:g}=ln.sliceInfo(r.shape,s,i,o,l,d,u,p,c),x=ht({inputs:{x:r},backend:n,attrs:{shape:y}}),w;if(h){let v=bi({inputs:{x},backend:n,attrs:{begin:m,size:A}});w=ht({inputs:{x:v},backend:n,attrs:{shape:g}}),n.disposeIntermediateTensorInfo(v)}else if(g.some(v=>v===0))w=n.makeTensorInfo(g,r.dtype,[]);else{let v=n.bufferSync(x),N=H3(g,v,f,m);w=n.makeTensorInfo(N.shape,N.dtype,N.values)}let b=ht({inputs:{x:w},backend:n,attrs:{shape:g}});return n.disposeIntermediateTensorInfo(x),n.disposeIntermediateTensorInfo(w),b}var pP={kernelName:Zo,backendName:"cpu",kernelFunc:dP},cP=nt(Js,e=>Math.tan(e)),hP={kernelName:Js,backendName:"cpu",kernelFunc:cP},fP=nt(Qs,e=>Math.tanh(e)),mP={kernelName:Qs,backendName:"cpu",kernelFunc:fP};function AP(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{reps:s}=a;ve(r,"tile");let i=q3(n.bufferSync(r),s);return n.makeTensorInfo(i.shape,i.dtype,i.values)}var yP={kernelName:Sr,backendName:"cpu",kernelFunc:AP};function gP(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{k:s,sorted:i}=a;ve(r,"topk");let o=n.data.get(r.dataId).values,[l,d]=X3(o,r.shape,r.dtype,s,i);return[n.makeTensorInfo(l.shape,l.dtype,l.values),n.makeTensorInfo(d.shape,d.dtype,d.values)]}var xP={kernelName:Yo,backendName:"cpu",kernelFunc:gP};function wP(e){let{inputs:t,attrs:n,backend:a}=e,{image:r,transforms:s}=t,{interpolation:i,fillMode:o,fillValue:l,outputShape:d}=n,[u,p,c,h]=r.shape,[m,f]=d!=null?d:[p,c],A=[u,m,f,h],y=k.computeStrides(r.shape),g=y[0],x=y[1],w=y[2],b=k.getTypedArrayFromDType(r.dtype,k.sizeFromShape(A));b.fill(l);let v=a.data.get(r.dataId).values,N=a.data.get(s.dataId).values;for(let T=0;Tt-1)if(t<=1)n=0;else{let a=2*t;n-=a*Math.trunc(n/a),n>=t&&(n=a-n-1)}return k.clamp(0,n,t-1)}function SP(e,t){let n=e;if(n<0)if(t<=1)n=0;else{let a=t-1;n+=t*(Math.trunc(-n/a)+1)}else if(n>t-1)if(t<=1)n=0;else{let a=t-1;n-=t*Math.trunc(n/a)}return k.clamp(0,n,t-1)}function NP(e,t){return e}function TP(e,t){return k.clamp(0,e,t-1)}function ld(e,t,n,a,r,s,i,o,l,d,u){let p=i*a+o*r+l*s+d;return 0<=o&&on.disposeIntermediateTensorInfo(m)),h}var $P={kernelName:Mu,backendName:"cpu",kernelFunc:FP},DP=[j$,qF,H$,q$,QF,K$,Y$,Q$,tD,aD,sD,oD,uD,cD,fD,yD,xD,vD,kD,B$,SD,TD,CD,YF,t$,MD,XF,$D,OD,PD,WD,zD,UD,GD,VD,XD,ZD,JD,eO,nO,rO,sO,oO,uO,pO,cO,fO,hO,e1,yO,$$,xO,vO,CO,n$,RO,r$,zO,PO,LO,i$,VO,UO,GO,XO,ZO,l$,QO,KF,tz,DD,az,sz,oz,D$,d$,dz,cz,c$,fz,yz,xz,wz,Iz,Nz,f$,Cz,Mz,$z,Oz,_z,Tz,Lz,Bz,A$,jz,Gz,Zz,g$,b$,Qz,n_,s_,w$,o_,u_,d_,m7,f_,z$,S$,A_,ZF,g_,_$,P$,W$,b_,w_,I_,N_,E_,C_,M_,T$,$_,O_,L_,L$,B_,j_,H_,E$,Xz,X_,Z_,J_,eP,nP,rP,iP,oP,R$,uP,pP,F$,mO,hP,mP,yP,xP,k$,kP,CP,MP,$P,l_];for(let e of DP)ri(e);var x7={};Fe(x7,{assertNotComplex:()=>Cl,bindCanvasToFramebuffer:()=>_P,bindColorTextureToFramebuffer:()=>uh,bindTextureToProgramUniformSampler:()=>D7,bindTextureUnit:()=>M7,bindVertexBufferToProgramAttribute:()=>a1,callAndCheck:()=>xe,canBeRepresented:()=>b7,createFragmentShader:()=>k7,createFramebuffer:()=>R7,createProgram:()=>I7,createStaticIndexBuffer:()=>T7,createStaticVertexBuffer:()=>N7,createTexture:()=>E7,createVertexShader:()=>w7,getBatchDim:()=>vi,getExtensionOrThrow:()=>ud,getFramebufferErrorMessage:()=>O7,getMaxTexturesInShader:()=>P7,getNumChannels:()=>OP,getProgramUniformLocation:()=>$7,getProgramUniformLocationOrThrow:()=>F7,getRowsCols:()=>wi,getShapeAs3D:()=>dh,getTextureShapeFromLogicalShape:()=>z7,getWebGLDisjointQueryTimerVersion:()=>L7,getWebGLErrorMessage:()=>v7,getWebGLMaxTextureSize:()=>_7,hasExtension:()=>Yn,isCapableOfRenderingToFloatTexture:()=>W7,isDownloadFloatTextureEnabled:()=>B7,isReshapeFree:()=>pd,isWebGLFenceEnabled:()=>V7,isWebGLVersionEnabled:()=>s1,linkProgram:()=>S7,resetMaxTextureSize:()=>PP,resetMaxTexturesInShader:()=>LP,unbindColorTextureFromFramebuffer:()=>r1,unbindTextureUnit:()=>zP,validateFramebuffer:()=>dd,validateProgram:()=>lh,validateTextureSize:()=>C7});var ki={},i1={alpha:!1,antialias:!1,premultipliedAlpha:!1,preserveDrawingBuffer:!1,depth:!1,stencil:!1,failIfMajorPerformanceCaveat:!0};function ph(e,t){ki[e]=t}function Va(e){if(!(e in ki)){let n=WP(e);if(n!==null)ki[e]=n;else return console.log("Could not get context for WebGL version",e),null}let t=ki[e];return t.isContextLost()?(delete ki[e],Va(e)):(t.disable(t.DEPTH_TEST),t.disable(t.STENCIL_TEST),t.disable(t.BLEND),t.disable(t.DITHER),t.disable(t.POLYGON_OFFSET_FILL),t.disable(t.SAMPLE_COVERAGE),t.enable(t.SCISSOR_TEST),t.enable(t.CULL_FACE),t.cullFace(t.BACK),ki[e])}function BP(e){if(typeof OffscreenCanvas!="undefined"&&e===2)return new OffscreenCanvas(300,150);if(typeof document!="undefined")return document.createElement("canvas");throw new Error("Cannot create a canvas in this context")}function WP(e){if(e!==1&&e!==2)throw new Error("Cannot get WebGL rendering context, WebGL is disabled.");let t=BP(e);return t.addEventListener("webglcontextlost",n=>{n.preventDefault(),delete ki[e]},!1),e===1?t.getContext("webgl",i1)||t.getContext("experimental-webgl",i1):t.getContext("webgl2",i1)}var cd;(function(e){e[e.DENSE=0]="DENSE",e[e.SHARED_BATCH=1]="SHARED_BATCH"})(cd||(cd={}));var Jn;(function(e){e[e.RENDER=0]="RENDER",e[e.UPLOAD=1]="UPLOAD",e[e.PIXELS=2]="PIXELS",e[e.DOWNLOAD=3]="DOWNLOAD"})(Jn||(Jn={}));var en;(function(e){e[e.UNPACKED_FLOAT16=0]="UNPACKED_FLOAT16",e[e.UNPACKED_FLOAT32=1]="UNPACKED_FLOAT32",e[e.PACKED_4X1_UNSIGNED_BYTE=2]="PACKED_4X1_UNSIGNED_BYTE",e[e.PACKED_2X2_FLOAT32=3]="PACKED_2X2_FLOAT32",e[e.PACKED_2X2_FLOAT16=4]="PACKED_2X2_FLOAT16"})(en||(en={}));function hd(e,t){return[t,e]}function VP(e,t){return e*t}function fd(e){let t=k.sizeFromShape(e),n=Math.ceil(t/4);return k.sizeToSquarishShape(n)}function Rl(e,t){return[Math.max(1,Math.ceil(t/2)),Math.max(1,Math.ceil(e/2))]}function jP(e,t){let[n,a]=Rl(e,t);return n*a*4}function o1(e,t){let n=e,a,r,s,i,o,l,d,u,p,c;return J().getNumber("WEBGL_VERSION")===2?(a=n.R32F,r=n.R16F,s=n.RGBA16F,i=n.RGBA32F,o=n.RED,d=4,u=1,p=n.HALF_FLOAT,c=n.FLOAT):(a=e.RGBA,r=e.RGBA,s=e.RGBA,i=n.RGBA,o=e.RGBA,d=4,u=4,p=t!=null?t.HALF_FLOAT_OES:null,c=e.FLOAT),l=e.RGBA,{internalFormatFloat:a,internalFormatHalfFloat:r,internalFormatPackedHalfFloat:s,internalFormatPackedFloat:i,textureFormatFloat:o,downloadTextureFormat:l,downloadUnpackNumChannels:d,defaultNumChannels:u,textureTypeHalfFloat:p,textureTypeFloat:c}}function xe(e,t){let n=t();return J().getBool("DEBUG")&&UP(e),n}function UP(e){let t=e.getError();if(t!==e.NO_ERROR)throw new Error("WebGL Error: "+v7(e,t))}var HP=596e-10,GP=65504;function b7(e){return!!(J().getBool("WEBGL_RENDER_FLOAT32_ENABLED")||e===0||HPe.getExtension(t),'Extension "'+t+'" not supported on this browser.')}function w7(e,t){let n=lr(e,()=>e.createShader(e.VERTEX_SHADER),"Unable to create vertex WebGLShader.");if(xe(e,()=>e.shaderSource(n,t)),xe(e,()=>e.compileShader(n)),e.getShaderParameter(n,e.COMPILE_STATUS)===!1)throw console.log(e.getShaderInfoLog(n)),new Error("Failed to compile vertex shader.");return n}function k7(e,t){let n=lr(e,()=>e.createShader(e.FRAGMENT_SHADER),"Unable to create fragment WebGLShader.");if(xe(e,()=>e.shaderSource(n,t)),xe(e,()=>e.compileShader(n)),e.getShaderParameter(n,e.COMPILE_STATUS)===!1)throw qP(t,e.getShaderInfoLog(n)),new Error("Failed to compile fragment shader.");return n}var XP=/ERROR: [0-9]+:([0-9]+):/g;function qP(e,t){let n=XP.exec(t);if(n==null){console.log(`Couldn't parse line number in error: ${t}`),console.log(e);return}let a=+n[1],r=e.split(` + ${r.shape}`);if(s.shape.length!==1)throw new Error(`Target shape should be a vector but received shape ${s.shape}`);let i=Array.from(n.data.get(r.dataId).values),o=n.data.get(a.dataId).values,l=Array.from(n.data.get(s.dataId).values),[d,u,p]=j3(o,a.shape,a.dtype,i,l);return[n.makeTensorInfo(u,a.dtype,d),n.makeTensorInfo([p.length],s.dtype,new Int32Array(p))]}var eP={kernelName:nc,backendName:"cpu",kernelFunc:Q_};function tP(e){let{inputs:t,backend:n,attrs:a}=e,{sparseIndices:r,sparseValues:s,defaultValue:i}=t,{outputShape:o}=a,{sliceRank:l,numUpdates:d,sliceSize:u,strides:p,outputSize:c}=C.calculateShapes(s,r,o),h=!1,m=n.bufferSync(r),f=n.bufferSync(s),A=n.data.get(i.dataId).values[0],y=A7(m,f,o,c,u,d,l,p,A,h);return n.makeTensorInfo(o,y.dtype,y.values)}var nP={kernelName:ac,backendName:"cpu",kernelFunc:tP};function aP(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{numOrSizeSplits:s,axis:i}=a,o=k.parseAxisParam(i,r.shape)[0],l=C.prepareSplitSize(r,s,o),d=new Array(r.shape.length).fill(0),u=r.shape.slice();return l.map(p=>{let c=[...u];c[o]=p;let h=xi({inputs:{x:r},backend:n,attrs:{begin:d,size:c}});return d[o]+=p,h})}var rP={kernelName:Xo,backendName:"cpu",kernelFunc:aP},sP=nt(Gs,e=>Math.sqrt(e)),iP={kernelName:Gs,backendName:"cpu",kernelFunc:sP},oP={kernelName:Ru,backendName:"cpu",kernelFunc:({inputs:e,backend:t})=>{let{x:n}=e,a=t;ve(n,"square");let r=a.data.get(n.dataId).values,s=new Float32Array(r.length);for(let i=0;i{let n=t;return isNaN(e)?NaN:e>0?1:n.alpha}),uP={kernelName:Sr,backendName:"cpu",kernelFunc:lP};function dP(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{begin:s,end:i,strides:o,beginMask:l,endMask:d,ellipsisMask:u,newAxisMask:p,shrinkAxisMask:c}=a;ve(r,"stridedSlice");let{nonStrided:h,$begin:m,$strides:f,size:A,newShape:y,outShape:g}=on.sliceInfo(r.shape,s,i,o,l,d,u,p,c),x=ct({inputs:{x:r},backend:n,attrs:{shape:y}}),w;if(h){let v=xi({inputs:{x},backend:n,attrs:{begin:m,size:A}});w=ct({inputs:{x:v},backend:n,attrs:{shape:g}}),n.disposeIntermediateTensorInfo(v)}else if(g.some(v=>v===0))w=n.makeTensorInfo(g,r.dtype,[]);else{let v=n.bufferSync(x),N=H3(g,v,f,m);w=n.makeTensorInfo(N.shape,N.dtype,N.values)}let b=ct({inputs:{x:w},backend:n,attrs:{shape:g}});return n.disposeIntermediateTensorInfo(x),n.disposeIntermediateTensorInfo(w),b}var pP={kernelName:Ko,backendName:"cpu",kernelFunc:dP},cP=nt(Ys,e=>Math.tan(e)),hP={kernelName:Ys,backendName:"cpu",kernelFunc:cP},fP=nt(Js,e=>Math.tanh(e)),mP={kernelName:Js,backendName:"cpu",kernelFunc:fP};function AP(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{reps:s}=a;ve(r,"tile");let i=q3(n.bufferSync(r),s);return n.makeTensorInfo(i.shape,i.dtype,i.values)}var yP={kernelName:Ir,backendName:"cpu",kernelFunc:AP};function gP(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{k:s,sorted:i}=a;ve(r,"topk");let o=n.data.get(r.dataId).values,[l,d]=X3(o,r.shape,r.dtype,s,i);return[n.makeTensorInfo(l.shape,l.dtype,l.values),n.makeTensorInfo(d.shape,d.dtype,d.values)]}var xP={kernelName:Zo,backendName:"cpu",kernelFunc:gP};function wP(e){let{inputs:t,attrs:n,backend:a}=e,{image:r,transforms:s}=t,{interpolation:i,fillMode:o,fillValue:l,outputShape:d}=n,[u,p,c,h]=r.shape,[m,f]=d!=null?d:[p,c],A=[u,m,f,h],y=k.computeStrides(r.shape),g=y[0],x=y[1],w=y[2],b=k.getTypedArrayFromDType(r.dtype,k.sizeFromShape(A));b.fill(l);let v=a.data.get(r.dataId).values,N=a.data.get(s.dataId).values;for(let T=0;Tt-1)if(t<=1)n=0;else{let a=2*t;n-=a*Math.trunc(n/a),n>=t&&(n=a-n-1)}return k.clamp(0,n,t-1)}function SP(e,t){let n=e;if(n<0)if(t<=1)n=0;else{let a=t-1;n+=t*(Math.trunc(-n/a)+1)}else if(n>t-1)if(t<=1)n=0;else{let a=t-1;n-=t*Math.trunc(n/a)}return k.clamp(0,n,t-1)}function NP(e,t){return e}function TP(e,t){return k.clamp(0,e,t-1)}function ld(e,t,n,a,r,s,i,o,l,d,u){let p=i*a+o*r+l*s+d;return 0<=o&&on.disposeIntermediateTensorInfo(m)),h}var $P={kernelName:Mu,backendName:"cpu",kernelFunc:FP},DP=[j$,qF,H$,q$,QF,K$,Y$,Q$,tD,aD,sD,oD,uD,cD,fD,yD,xD,vD,kD,B$,SD,TD,CD,YF,t$,MD,XF,$D,OD,PD,WD,zD,UD,GD,VD,XD,ZD,JD,eO,nO,rO,sO,oO,uO,pO,cO,fO,hO,e1,yO,$$,xO,vO,CO,n$,RO,r$,zO,PO,LO,i$,VO,UO,GO,XO,ZO,l$,QO,KF,tz,DD,az,sz,oz,D$,d$,dz,cz,c$,fz,yz,xz,wz,Iz,Nz,f$,Cz,Mz,$z,Oz,_z,Tz,Lz,Bz,A$,jz,Gz,Zz,g$,b$,Qz,n_,s_,w$,o_,u_,d_,m7,f_,z$,S$,A_,ZF,g_,_$,P$,W$,b_,w_,I_,N_,E_,C_,M_,T$,$_,O_,L_,L$,B_,j_,H_,E$,Xz,X_,Z_,J_,eP,nP,rP,iP,oP,R$,uP,pP,F$,mO,hP,mP,yP,xP,k$,kP,CP,MP,$P,l_];for(let e of DP)ai(e);var x7={};Fe(x7,{assertNotComplex:()=>El,bindCanvasToFramebuffer:()=>_P,bindColorTextureToFramebuffer:()=>uh,bindTextureToProgramUniformSampler:()=>D7,bindTextureUnit:()=>M7,bindVertexBufferToProgramAttribute:()=>a1,callAndCheck:()=>xe,canBeRepresented:()=>b7,createFragmentShader:()=>k7,createFramebuffer:()=>R7,createProgram:()=>I7,createStaticIndexBuffer:()=>T7,createStaticVertexBuffer:()=>N7,createTexture:()=>E7,createVertexShader:()=>w7,getBatchDim:()=>bi,getExtensionOrThrow:()=>ud,getFramebufferErrorMessage:()=>O7,getMaxTexturesInShader:()=>P7,getNumChannels:()=>OP,getProgramUniformLocation:()=>$7,getProgramUniformLocationOrThrow:()=>F7,getRowsCols:()=>vi,getShapeAs3D:()=>dh,getTextureShapeFromLogicalShape:()=>z7,getWebGLDisjointQueryTimerVersion:()=>L7,getWebGLErrorMessage:()=>v7,getWebGLMaxTextureSize:()=>_7,hasExtension:()=>Zn,isCapableOfRenderingToFloatTexture:()=>W7,isDownloadFloatTextureEnabled:()=>B7,isReshapeFree:()=>pd,isWebGLFenceEnabled:()=>V7,isWebGLVersionEnabled:()=>s1,linkProgram:()=>S7,resetMaxTextureSize:()=>PP,resetMaxTexturesInShader:()=>LP,unbindColorTextureFromFramebuffer:()=>r1,unbindTextureUnit:()=>zP,validateFramebuffer:()=>dd,validateProgram:()=>lh,validateTextureSize:()=>C7});var wi={},i1={alpha:!1,antialias:!1,premultipliedAlpha:!1,preserveDrawingBuffer:!1,depth:!1,stencil:!1,failIfMajorPerformanceCaveat:!0};function ph(e,t){wi[e]=t}function Ba(e){if(!(e in wi)){let n=WP(e);if(n!==null)wi[e]=n;else return console.log("Could not get context for WebGL version",e),null}let t=wi[e];return t.isContextLost()?(delete wi[e],Ba(e)):(t.disable(t.DEPTH_TEST),t.disable(t.STENCIL_TEST),t.disable(t.BLEND),t.disable(t.DITHER),t.disable(t.POLYGON_OFFSET_FILL),t.disable(t.SAMPLE_COVERAGE),t.enable(t.SCISSOR_TEST),t.enable(t.CULL_FACE),t.cullFace(t.BACK),wi[e])}function BP(e){if(typeof OffscreenCanvas!="undefined"&&e===2)return new OffscreenCanvas(300,150);if(typeof document!="undefined")return document.createElement("canvas");throw new Error("Cannot create a canvas in this context")}function WP(e){if(e!==1&&e!==2)throw new Error("Cannot get WebGL rendering context, WebGL is disabled.");let t=BP(e);return t.addEventListener("webglcontextlost",n=>{n.preventDefault(),delete wi[e]},!1),e===1?t.getContext("webgl",i1)||t.getContext("experimental-webgl",i1):t.getContext("webgl2",i1)}var cd;(function(e){e[e.DENSE=0]="DENSE",e[e.SHARED_BATCH=1]="SHARED_BATCH"})(cd||(cd={}));var Yn;(function(e){e[e.RENDER=0]="RENDER",e[e.UPLOAD=1]="UPLOAD",e[e.PIXELS=2]="PIXELS",e[e.DOWNLOAD=3]="DOWNLOAD"})(Yn||(Yn={}));var Qt;(function(e){e[e.UNPACKED_FLOAT16=0]="UNPACKED_FLOAT16",e[e.UNPACKED_FLOAT32=1]="UNPACKED_FLOAT32",e[e.PACKED_4X1_UNSIGNED_BYTE=2]="PACKED_4X1_UNSIGNED_BYTE",e[e.PACKED_2X2_FLOAT32=3]="PACKED_2X2_FLOAT32",e[e.PACKED_2X2_FLOAT16=4]="PACKED_2X2_FLOAT16"})(Qt||(Qt={}));function hd(e,t){return[t,e]}function VP(e,t){return e*t}function fd(e){let t=k.sizeFromShape(e),n=Math.ceil(t/4);return k.sizeToSquarishShape(n)}function Cl(e,t){return[Math.max(1,Math.ceil(t/2)),Math.max(1,Math.ceil(e/2))]}function jP(e,t){let[n,a]=Cl(e,t);return n*a*4}function o1(e,t){let n=e,a,r,s,i,o,l,d,u,p,c;return J().getNumber("WEBGL_VERSION")===2?(a=n.R32F,r=n.R16F,s=n.RGBA16F,i=n.RGBA32F,o=n.RED,d=4,u=1,p=n.HALF_FLOAT,c=n.FLOAT):(a=e.RGBA,r=e.RGBA,s=e.RGBA,i=n.RGBA,o=e.RGBA,d=4,u=4,p=t!=null?t.HALF_FLOAT_OES:null,c=e.FLOAT),l=e.RGBA,{internalFormatFloat:a,internalFormatHalfFloat:r,internalFormatPackedHalfFloat:s,internalFormatPackedFloat:i,textureFormatFloat:o,downloadTextureFormat:l,downloadUnpackNumChannels:d,defaultNumChannels:u,textureTypeHalfFloat:p,textureTypeFloat:c}}function xe(e,t){let n=t();return J().getBool("DEBUG")&&UP(e),n}function UP(e){let t=e.getError();if(t!==e.NO_ERROR)throw new Error("WebGL Error: "+v7(e,t))}var HP=596e-10,GP=65504;function b7(e){return!!(J().getBool("WEBGL_RENDER_FLOAT32_ENABLED")||e===0||HPe.getExtension(t),'Extension "'+t+'" not supported on this browser.')}function w7(e,t){let n=or(e,()=>e.createShader(e.VERTEX_SHADER),"Unable to create vertex WebGLShader.");if(xe(e,()=>e.shaderSource(n,t)),xe(e,()=>e.compileShader(n)),e.getShaderParameter(n,e.COMPILE_STATUS)===!1)throw console.log(e.getShaderInfoLog(n)),new Error("Failed to compile vertex shader.");return n}function k7(e,t){let n=or(e,()=>e.createShader(e.FRAGMENT_SHADER),"Unable to create fragment WebGLShader.");if(xe(e,()=>e.shaderSource(n,t)),xe(e,()=>e.compileShader(n)),e.getShaderParameter(n,e.COMPILE_STATUS)===!1)throw qP(t,e.getShaderInfoLog(n)),new Error("Failed to compile fragment shader.");return n}var XP=/ERROR: [0-9]+:([0-9]+):/g;function qP(e,t){let n=XP.exec(t);if(n==null){console.log(`Couldn't parse line number in error: ${t}`),console.log(e);return}let a=+n[1],r=e.split(` `),s=r.length.toString().length+2,i=r.map((p,c)=>k.rightPad((c+1).toString(),s)+p),o=0;for(let p=0;pe.createProgram(),"Unable to create WebGLProgram.")}function S7(e,t){if(xe(e,()=>e.linkProgram(t)),e.getProgramParameter(t,e.LINK_STATUS)===!1)throw console.log(e.getProgramInfoLog(t)),new Error("Failed to link vertex and fragment shaders.")}function lh(e,t){if(xe(e,()=>e.validateProgram(t)),e.getProgramParameter(t,e.VALIDATE_STATUS)===!1)throw console.log(e.getProgramInfoLog(t)),new Error("Shader program validation failed.")}function N7(e,t){let n=lr(e,()=>e.createBuffer(),"Unable to create WebGLBuffer");return xe(e,()=>e.bindBuffer(e.ARRAY_BUFFER,n)),xe(e,()=>e.bufferData(e.ARRAY_BUFFER,t,e.STATIC_DRAW)),n}function T7(e,t){let n=lr(e,()=>e.createBuffer(),"Unable to create WebGLBuffer");return xe(e,()=>e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,n)),xe(e,()=>e.bufferData(e.ELEMENT_ARRAY_BUFFER,t,e.STATIC_DRAW)),n}function OP(){return J().getNumber("WEBGL_VERSION")===2?1:4}function E7(e){return lr(e,()=>e.createTexture(),"Unable to create WebGLTexture.")}function C7(e,t){let n=J().getNumber("WEBGL_MAX_TEXTURE_SIZE");if(e<=0||t<=0){let a=`[${e}x${t}]`;throw new Error("Requested texture size "+a+" is invalid.")}if(e>n||t>n){let a=`[${e}x${t}]`,r=`[${n}x${n}]`;throw new Error("Requested texture size "+a+" greater than WebGL maximum on this browser / GPU "+r+".")}}function R7(e){return lr(e,()=>e.createFramebuffer(),"Unable to create WebGLFramebuffer.")}function a1(e,t,n,a,r,s,i){let o=e.getAttribLocation(t,n);return o===-1?!1:(xe(e,()=>e.bindBuffer(e.ARRAY_BUFFER,a)),xe(e,()=>e.vertexAttribPointer(o,r,e.FLOAT,!1,s,i)),xe(e,()=>e.enableVertexAttribArray(o)),!0)}function M7(e,t,n){j7(e,n),xe(e,()=>e.activeTexture(e.TEXTURE0+n)),xe(e,()=>e.bindTexture(e.TEXTURE_2D,t))}function zP(e,t){j7(e,t),xe(e,()=>e.activeTexture(e.TEXTURE0+t)),xe(e,()=>e.bindTexture(e.TEXTURE_2D,null))}function F7(e,t,n){return lr(e,()=>e.getUniformLocation(t,n),'uniform "'+n+'" not present in program.')}function $7(e,t,n){return e.getUniformLocation(t,n)}function D7(e,t,n,a){xe(e,()=>M7(e,t,a)),xe(e,()=>e.uniform1i(n,a))}function _P(e){xe(e,()=>e.bindFramebuffer(e.FRAMEBUFFER,null)),xe(e,()=>e.viewport(0,0,e.canvas.width,e.canvas.height)),xe(e,()=>e.scissor(0,0,e.canvas.width,e.canvas.height))}function uh(e,t,n){xe(e,()=>e.bindFramebuffer(e.FRAMEBUFFER,n)),xe(e,()=>e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,t,0))}function r1(e,t){xe(e,()=>e.bindFramebuffer(e.FRAMEBUFFER,t)),xe(e,()=>e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,null,0))}function dd(e){let t=e.checkFramebufferStatus(e.FRAMEBUFFER);if(t!==e.FRAMEBUFFER_COMPLETE)throw new Error("Error binding framebuffer: "+O7(e,t))}function O7(e,t){switch(t){case e.FRAMEBUFFER_INCOMPLETE_ATTACHMENT:return"FRAMEBUFFER_INCOMPLETE_ATTACHMENT";case e.FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT:return"FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT";case e.FRAMEBUFFER_INCOMPLETE_DIMENSIONS:return"FRAMEBUFFER_INCOMPLETE_DIMENSIONS";case e.FRAMEBUFFER_UNSUPPORTED:return"FRAMEBUFFER_UNSUPPORTED";default:return`unknown error ${t}`}}function lr(e,t,n){let a=xe(e,()=>t());if(a==null)throw new Error(n);return a}function j7(e,t){let n=e.MAX_COMBINED_TEXTURE_IMAGE_UNITS-1,a=t+e.TEXTURE0;if(an){let r=`[gl.TEXTURE0, gl.TEXTURE${n}]`;throw new Error(`textureUnit must be in ${r}.`)}}function vi(e,t=2){return k.sizeFromShape(e.slice(0,e.length-t))}function wi(e){if(e.length===0)throw Error("Cannot get rows and columns of an empty shape array.");return[e.length>1?e[e.length-2]:1,e[e.length-1]]}function dh(e){let t=[1,1,1];return e.length===0||e.length===1&&e[0]===1||(t=[vi(e),...wi(e)]),t}function z7(e,t=!1){let n=J().getNumber("WEBGL_MAX_TEXTURE_SIZE");t&&(n=n*2,e=e.map((r,s)=>s>=e.length-2?k.nearestLargerEven(e[s]):e[s]),e.length===1&&(e=[2,e[0]])),e.length!==2&&(e=k.squeezeShape(e).newShape);let a=k.sizeFromShape(e);if(e.length<=1&&a<=n)return[1,a];if(e.length===2&&e[0]<=n&&e[1]<=n)return e;if(e.length===3&&e[0]*e[1]<=n&&e[2]<=n)return[e[0]*e[1],e[2]];if(e.length===3&&e[0]<=n&&e[1]*e[2]<=n)return[e[0],e[1]*e[2]];if(e.length===4&&e[0]*e[1]*e[2]<=n&&e[3]<=n)return[e[0]*e[1]*e[2],e[3]];if(e.length===4&&e[0]<=n&&e[1]*e[2]*e[3]<=n)return[e[0],e[1]*e[2]*e[3]];if(t){let r=vi(e),s=2,i=2;return e.length&&([s,i]=wi(e)),a=r*(s/2)*(i/2),k.sizeToSquarishShape(a).map(o=>o*2)}return k.sizeToSquarishShape(a)}function ch(e){return e%2==0}function pd(e,t){if(e=e.slice(-2),t=t.slice(-2),k.arraysEqual(e,t)||!e.length||!t.length||e[0]===0||e[1]===0||t[0]===0||t[1]===0)return!0;if(e.length!==t.length){let n=e.slice(-1)[0],a=t.slice(-1)[0];if(n===a||ch(n)&&ch(a)&&(e[0]===1||t[0]===1))return!0}return e[1]===t[1]&&ch(e[0])&&ch(t[0])}var hh,fh;function _7(e){if(hh==null){let t=Va(e);hh=t.getParameter(t.MAX_TEXTURE_SIZE)}return hh}function PP(){hh=null}function LP(){fh=null}function P7(e){if(fh==null){let t=Va(e);fh=t.getParameter(t.MAX_TEXTURE_IMAGE_UNITS)}return Math.min(16,fh)}function L7(e){if(e===0)return 0;let t,n=Va(e);return Yn(n,"EXT_disjoint_timer_query_webgl2")&&e===2?t=2:Yn(n,"EXT_disjoint_timer_query")?t=1:t=0,t}function Yn(e,t){return e.getExtension(t)!=null}function s1(e){try{if(Va(e)!=null)return!0}catch(t){return console.log("Error when getting WebGL context: ",t),!1}return!1}function W7(e){if(e===0)return!1;let t=Va(e);if(e===1){if(!Yn(t,"OES_texture_float"))return!1}else if(!Yn(t,"EXT_color_buffer_float"))return!1;return l1(t)}function B7(e){if(e===0)return!1;let t=Va(e);if(e===1){if(!Yn(t,"OES_texture_float")||!Yn(t,"WEBGL_color_buffer_float"))return!1}else{if(Yn(t,"EXT_color_buffer_float"))return l1(t);let n="EXT_color_buffer_half_float";if(Yn(t,n)){let a=t.getExtension(n);return KP(t,a)}return!1}return l1(t)}function l1(e){let t=o1(e),n=e.createTexture();e.bindTexture(e.TEXTURE_2D,n);let a=1,r=1;e.texImage2D(e.TEXTURE_2D,0,t.internalFormatFloat,a,r,0,t.textureFormatFloat,t.textureTypeFloat,null);let s=e.createFramebuffer();e.bindFramebuffer(e.FRAMEBUFFER,s),e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,n,0);let i=e.checkFramebufferStatus(e.FRAMEBUFFER)===e.FRAMEBUFFER_COMPLETE;return e.bindTexture(e.TEXTURE_2D,null),e.bindFramebuffer(e.FRAMEBUFFER,null),e.deleteTexture(n),e.deleteFramebuffer(s),i}function KP(e,t){let n=o1(e,t),a=e.createTexture();e.bindTexture(e.TEXTURE_2D,a);let r=1,s=1;e.texImage2D(e.TEXTURE_2D,0,n.internalFormatHalfFloat,r,s,0,n.textureFormatFloat,n.textureTypeHalfFloat,null);let i=e.createFramebuffer();e.bindFramebuffer(e.FRAMEBUFFER,i),e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,a,0);let o=e.checkFramebufferStatus(e.FRAMEBUFFER)===e.FRAMEBUFFER_COMPLETE;return e.bindTexture(e.TEXTURE_2D,null),e.bindFramebuffer(e.FRAMEBUFFER,null),e.deleteTexture(a),e.deleteFramebuffer(i),o}function V7(e){return e!==2?!1:Va(e).fenceSync!=null}function Cl(e,t){Array.isArray(e)||(e=[e]),e.forEach(n=>{n!=null&&k.assert(n.dtype!=="complex64",()=>`${t} does not support complex64 tensors in the WebGL backend.`)})}var Me=J();Me.registerFlag("HAS_WEBGL",()=>Me.getNumber("WEBGL_VERSION")>0);Me.registerFlag("WEBGL_VERSION",()=>s1(2)?2:s1(1)?1:0);Me.registerFlag("WEBGL_CHECK_NUMERICAL_PROBLEMS",()=>!1);Me.registerFlag("WEBGL_BUFFER_SUPPORTED",()=>Me.get("WEBGL_VERSION")===2);Me.registerFlag("WEBGL_CPU_FORWARD",()=>!0);Me.registerFlag("WEBGL_FORCE_F16_TEXTURES",()=>!1);Me.registerFlag("WEBGL_PACK",()=>Me.getBool("HAS_WEBGL"));Me.registerFlag("WEBGL_PACK_NORMALIZATION",()=>Me.getBool("WEBGL_PACK"));Me.registerFlag("WEBGL_PACK_CLIP",()=>Me.getBool("WEBGL_PACK"));Me.registerFlag("WEBGL_PACK_DEPTHWISECONV",()=>Me.getBool("WEBGL_PACK"));Me.registerFlag("WEBGL_PACK_BINARY_OPERATIONS",()=>Me.getBool("WEBGL_PACK"));Me.registerFlag("WEBGL_PACK_UNARY_OPERATIONS",()=>Me.getBool("WEBGL_PACK"));Me.registerFlag("WEBGL_PACK_ARRAY_OPERATIONS",()=>Me.getBool("WEBGL_PACK"));Me.registerFlag("WEBGL_PACK_IMAGE_OPERATIONS",()=>Me.getBool("WEBGL_PACK"));Me.registerFlag("WEBGL_PACK_REDUCE",()=>Me.getBool("WEBGL_PACK"));Me.registerFlag("WEBGL_LAZILY_UNPACK",()=>Me.getBool("WEBGL_PACK"));Me.registerFlag("WEBGL_CONV_IM2COL",()=>Me.getBool("WEBGL_PACK"));Me.registerFlag("WEBGL_MAX_TEXTURE_SIZE",()=>_7(Me.getNumber("WEBGL_VERSION")));Me.registerFlag("WEBGL_MAX_TEXTURES_IN_SHADER",()=>P7(Me.getNumber("WEBGL_VERSION")));Me.registerFlag("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION",()=>{let e=Me.getNumber("WEBGL_VERSION");return e===0?0:L7(e)});Me.registerFlag("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE",()=>Me.getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")>0&&!Wu.isMobile());Me.registerFlag("WEBGL_RENDER_FLOAT32_CAPABLE",()=>W7(Me.getNumber("WEBGL_VERSION")));Me.registerFlag("WEBGL_RENDER_FLOAT32_ENABLED",()=>Me.getBool("WEBGL_FORCE_F16_TEXTURES")?!1:Me.getBool("WEBGL_RENDER_FLOAT32_CAPABLE"));Me.registerFlag("WEBGL_DOWNLOAD_FLOAT_ENABLED",()=>B7(Me.getNumber("WEBGL_VERSION")));Me.registerFlag("WEBGL_FENCE_API_ENABLED",()=>V7(Me.getNumber("WEBGL_VERSION")));Me.registerFlag("WEBGL_SIZE_UPLOAD_UNIFORM",()=>Me.getBool("WEBGL_RENDER_FLOAT32_ENABLED")?4:0);Me.registerFlag("WEBGL_DELETE_TEXTURE_THRESHOLD",()=>-1,e=>{if(e<0&&e!==-1)throw new Error(`WEBGL_DELETE_TEXTURE_THRESHOLD must be -1 (indicating never delete) or at least 0, but got ${e}.`)});Me.registerFlag("WEBGL_FLUSH_THRESHOLD",()=>Wu.isMobile()&&Me.getBool("IS_CHROME")?1:-1,e=>{if(e<0&&e!==-1)throw new Error(`WEBGL_FLUSH_THRESHOLD must be -1 (indicating never manual flush) or at least 0, but got ${e}.`)});function pn(){let e,t,n,a,r,s,i,o,l,d;return J().getNumber("WEBGL_VERSION")===2?(e="#version 300 es",t="in",n="out",a="in",r="texture",s="outputColor",i="out vec4 outputColor;",o=` +`))}function I7(e){return or(e,()=>e.createProgram(),"Unable to create WebGLProgram.")}function S7(e,t){if(xe(e,()=>e.linkProgram(t)),e.getProgramParameter(t,e.LINK_STATUS)===!1)throw console.log(e.getProgramInfoLog(t)),new Error("Failed to link vertex and fragment shaders.")}function lh(e,t){if(xe(e,()=>e.validateProgram(t)),e.getProgramParameter(t,e.VALIDATE_STATUS)===!1)throw console.log(e.getProgramInfoLog(t)),new Error("Shader program validation failed.")}function N7(e,t){let n=or(e,()=>e.createBuffer(),"Unable to create WebGLBuffer");return xe(e,()=>e.bindBuffer(e.ARRAY_BUFFER,n)),xe(e,()=>e.bufferData(e.ARRAY_BUFFER,t,e.STATIC_DRAW)),n}function T7(e,t){let n=or(e,()=>e.createBuffer(),"Unable to create WebGLBuffer");return xe(e,()=>e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,n)),xe(e,()=>e.bufferData(e.ELEMENT_ARRAY_BUFFER,t,e.STATIC_DRAW)),n}function OP(){return J().getNumber("WEBGL_VERSION")===2?1:4}function E7(e){return or(e,()=>e.createTexture(),"Unable to create WebGLTexture.")}function C7(e,t){let n=J().getNumber("WEBGL_MAX_TEXTURE_SIZE");if(e<=0||t<=0){let a=`[${e}x${t}]`;throw new Error("Requested texture size "+a+" is invalid.")}if(e>n||t>n){let a=`[${e}x${t}]`,r=`[${n}x${n}]`;throw new Error("Requested texture size "+a+" greater than WebGL maximum on this browser / GPU "+r+".")}}function R7(e){return or(e,()=>e.createFramebuffer(),"Unable to create WebGLFramebuffer.")}function a1(e,t,n,a,r,s,i){let o=e.getAttribLocation(t,n);return o===-1?!1:(xe(e,()=>e.bindBuffer(e.ARRAY_BUFFER,a)),xe(e,()=>e.vertexAttribPointer(o,r,e.FLOAT,!1,s,i)),xe(e,()=>e.enableVertexAttribArray(o)),!0)}function M7(e,t,n){j7(e,n),xe(e,()=>e.activeTexture(e.TEXTURE0+n)),xe(e,()=>e.bindTexture(e.TEXTURE_2D,t))}function zP(e,t){j7(e,t),xe(e,()=>e.activeTexture(e.TEXTURE0+t)),xe(e,()=>e.bindTexture(e.TEXTURE_2D,null))}function F7(e,t,n){return or(e,()=>e.getUniformLocation(t,n),'uniform "'+n+'" not present in program.')}function $7(e,t,n){return e.getUniformLocation(t,n)}function D7(e,t,n,a){xe(e,()=>M7(e,t,a)),xe(e,()=>e.uniform1i(n,a))}function _P(e){xe(e,()=>e.bindFramebuffer(e.FRAMEBUFFER,null)),xe(e,()=>e.viewport(0,0,e.canvas.width,e.canvas.height)),xe(e,()=>e.scissor(0,0,e.canvas.width,e.canvas.height))}function uh(e,t,n){xe(e,()=>e.bindFramebuffer(e.FRAMEBUFFER,n)),xe(e,()=>e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,t,0))}function r1(e,t){xe(e,()=>e.bindFramebuffer(e.FRAMEBUFFER,t)),xe(e,()=>e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,null,0))}function dd(e){let t=e.checkFramebufferStatus(e.FRAMEBUFFER);if(t!==e.FRAMEBUFFER_COMPLETE)throw new Error("Error binding framebuffer: "+O7(e,t))}function O7(e,t){switch(t){case e.FRAMEBUFFER_INCOMPLETE_ATTACHMENT:return"FRAMEBUFFER_INCOMPLETE_ATTACHMENT";case e.FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT:return"FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT";case e.FRAMEBUFFER_INCOMPLETE_DIMENSIONS:return"FRAMEBUFFER_INCOMPLETE_DIMENSIONS";case e.FRAMEBUFFER_UNSUPPORTED:return"FRAMEBUFFER_UNSUPPORTED";default:return`unknown error ${t}`}}function or(e,t,n){let a=xe(e,()=>t());if(a==null)throw new Error(n);return a}function j7(e,t){let n=e.MAX_COMBINED_TEXTURE_IMAGE_UNITS-1,a=t+e.TEXTURE0;if(an){let r=`[gl.TEXTURE0, gl.TEXTURE${n}]`;throw new Error(`textureUnit must be in ${r}.`)}}function bi(e,t=2){return k.sizeFromShape(e.slice(0,e.length-t))}function vi(e){if(e.length===0)throw Error("Cannot get rows and columns of an empty shape array.");return[e.length>1?e[e.length-2]:1,e[e.length-1]]}function dh(e){let t=[1,1,1];return e.length===0||e.length===1&&e[0]===1||(t=[bi(e),...vi(e)]),t}function z7(e,t=!1){let n=J().getNumber("WEBGL_MAX_TEXTURE_SIZE");t&&(n=n*2,e=e.map((r,s)=>s>=e.length-2?k.nearestLargerEven(e[s]):e[s]),e.length===1&&(e=[2,e[0]])),e.length!==2&&(e=k.squeezeShape(e).newShape);let a=k.sizeFromShape(e);if(e.length<=1&&a<=n)return[1,a];if(e.length===2&&e[0]<=n&&e[1]<=n)return e;if(e.length===3&&e[0]*e[1]<=n&&e[2]<=n)return[e[0]*e[1],e[2]];if(e.length===3&&e[0]<=n&&e[1]*e[2]<=n)return[e[0],e[1]*e[2]];if(e.length===4&&e[0]*e[1]*e[2]<=n&&e[3]<=n)return[e[0]*e[1]*e[2],e[3]];if(e.length===4&&e[0]<=n&&e[1]*e[2]*e[3]<=n)return[e[0],e[1]*e[2]*e[3]];if(t){let r=bi(e),s=2,i=2;return e.length&&([s,i]=vi(e)),a=r*(s/2)*(i/2),k.sizeToSquarishShape(a).map(o=>o*2)}return k.sizeToSquarishShape(a)}function ch(e){return e%2==0}function pd(e,t){if(e=e.slice(-2),t=t.slice(-2),k.arraysEqual(e,t)||!e.length||!t.length||e[0]===0||e[1]===0||t[0]===0||t[1]===0)return!0;if(e.length!==t.length){let n=e.slice(-1)[0],a=t.slice(-1)[0];if(n===a||ch(n)&&ch(a)&&(e[0]===1||t[0]===1))return!0}return e[1]===t[1]&&ch(e[0])&&ch(t[0])}var hh,fh;function _7(e){if(hh==null){let t=Ba(e);hh=t.getParameter(t.MAX_TEXTURE_SIZE)}return hh}function PP(){hh=null}function LP(){fh=null}function P7(e){if(fh==null){let t=Ba(e);fh=t.getParameter(t.MAX_TEXTURE_IMAGE_UNITS)}return Math.min(16,fh)}function L7(e){if(e===0)return 0;let t,n=Ba(e);return Zn(n,"EXT_disjoint_timer_query_webgl2")&&e===2?t=2:Zn(n,"EXT_disjoint_timer_query")?t=1:t=0,t}function Zn(e,t){return e.getExtension(t)!=null}function s1(e){try{if(Ba(e)!=null)return!0}catch(t){return console.log("Error when getting WebGL context: ",t),!1}return!1}function W7(e){if(e===0)return!1;let t=Ba(e);if(e===1){if(!Zn(t,"OES_texture_float"))return!1}else if(!Zn(t,"EXT_color_buffer_float"))return!1;return l1(t)}function B7(e){if(e===0)return!1;let t=Ba(e);if(e===1){if(!Zn(t,"OES_texture_float")||!Zn(t,"WEBGL_color_buffer_float"))return!1}else{if(Zn(t,"EXT_color_buffer_float"))return l1(t);let n="EXT_color_buffer_half_float";if(Zn(t,n)){let a=t.getExtension(n);return KP(t,a)}return!1}return l1(t)}function l1(e){let t=o1(e),n=e.createTexture();e.bindTexture(e.TEXTURE_2D,n);let a=1,r=1;e.texImage2D(e.TEXTURE_2D,0,t.internalFormatFloat,a,r,0,t.textureFormatFloat,t.textureTypeFloat,null);let s=e.createFramebuffer();e.bindFramebuffer(e.FRAMEBUFFER,s),e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,n,0);let i=e.checkFramebufferStatus(e.FRAMEBUFFER)===e.FRAMEBUFFER_COMPLETE;return e.bindTexture(e.TEXTURE_2D,null),e.bindFramebuffer(e.FRAMEBUFFER,null),e.deleteTexture(n),e.deleteFramebuffer(s),i}function KP(e,t){let n=o1(e,t),a=e.createTexture();e.bindTexture(e.TEXTURE_2D,a);let r=1,s=1;e.texImage2D(e.TEXTURE_2D,0,n.internalFormatHalfFloat,r,s,0,n.textureFormatFloat,n.textureTypeHalfFloat,null);let i=e.createFramebuffer();e.bindFramebuffer(e.FRAMEBUFFER,i),e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,a,0);let o=e.checkFramebufferStatus(e.FRAMEBUFFER)===e.FRAMEBUFFER_COMPLETE;return e.bindTexture(e.TEXTURE_2D,null),e.bindFramebuffer(e.FRAMEBUFFER,null),e.deleteTexture(a),e.deleteFramebuffer(i),o}function V7(e){return e!==2?!1:Ba(e).fenceSync!=null}function El(e,t){Array.isArray(e)||(e=[e]),e.forEach(n=>{n!=null&&k.assert(n.dtype!=="complex64",()=>`${t} does not support complex64 tensors in the WebGL backend.`)})}var Me=J();Me.registerFlag("HAS_WEBGL",()=>Me.getNumber("WEBGL_VERSION")>0);Me.registerFlag("WEBGL_VERSION",()=>s1(2)?2:s1(1)?1:0);Me.registerFlag("WEBGL_CHECK_NUMERICAL_PROBLEMS",()=>!1);Me.registerFlag("WEBGL_BUFFER_SUPPORTED",()=>Me.get("WEBGL_VERSION")===2);Me.registerFlag("WEBGL_CPU_FORWARD",()=>!0);Me.registerFlag("WEBGL_FORCE_F16_TEXTURES",()=>!1);Me.registerFlag("WEBGL_PACK",()=>Me.getBool("HAS_WEBGL"));Me.registerFlag("WEBGL_PACK_NORMALIZATION",()=>Me.getBool("WEBGL_PACK"));Me.registerFlag("WEBGL_PACK_CLIP",()=>Me.getBool("WEBGL_PACK"));Me.registerFlag("WEBGL_PACK_DEPTHWISECONV",()=>Me.getBool("WEBGL_PACK"));Me.registerFlag("WEBGL_PACK_BINARY_OPERATIONS",()=>Me.getBool("WEBGL_PACK"));Me.registerFlag("WEBGL_PACK_UNARY_OPERATIONS",()=>Me.getBool("WEBGL_PACK"));Me.registerFlag("WEBGL_PACK_ARRAY_OPERATIONS",()=>Me.getBool("WEBGL_PACK"));Me.registerFlag("WEBGL_PACK_IMAGE_OPERATIONS",()=>Me.getBool("WEBGL_PACK"));Me.registerFlag("WEBGL_PACK_REDUCE",()=>Me.getBool("WEBGL_PACK"));Me.registerFlag("WEBGL_LAZILY_UNPACK",()=>Me.getBool("WEBGL_PACK"));Me.registerFlag("WEBGL_CONV_IM2COL",()=>Me.getBool("WEBGL_PACK"));Me.registerFlag("WEBGL_MAX_TEXTURE_SIZE",()=>_7(Me.getNumber("WEBGL_VERSION")));Me.registerFlag("WEBGL_MAX_TEXTURES_IN_SHADER",()=>P7(Me.getNumber("WEBGL_VERSION")));Me.registerFlag("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION",()=>{let e=Me.getNumber("WEBGL_VERSION");return e===0?0:L7(e)});Me.registerFlag("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE",()=>Me.getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")>0&&!Wu.isMobile());Me.registerFlag("WEBGL_RENDER_FLOAT32_CAPABLE",()=>W7(Me.getNumber("WEBGL_VERSION")));Me.registerFlag("WEBGL_RENDER_FLOAT32_ENABLED",()=>Me.getBool("WEBGL_FORCE_F16_TEXTURES")?!1:Me.getBool("WEBGL_RENDER_FLOAT32_CAPABLE"));Me.registerFlag("WEBGL_DOWNLOAD_FLOAT_ENABLED",()=>B7(Me.getNumber("WEBGL_VERSION")));Me.registerFlag("WEBGL_FENCE_API_ENABLED",()=>V7(Me.getNumber("WEBGL_VERSION")));Me.registerFlag("WEBGL_SIZE_UPLOAD_UNIFORM",()=>Me.getBool("WEBGL_RENDER_FLOAT32_ENABLED")?4:0);Me.registerFlag("WEBGL_DELETE_TEXTURE_THRESHOLD",()=>-1,e=>{if(e<0&&e!==-1)throw new Error(`WEBGL_DELETE_TEXTURE_THRESHOLD must be -1 (indicating never delete) or at least 0, but got ${e}.`)});Me.registerFlag("WEBGL_FLUSH_THRESHOLD",()=>Wu.isMobile()&&Me.getBool("IS_CHROME")?1:-1,e=>{if(e<0&&e!==-1)throw new Error(`WEBGL_FLUSH_THRESHOLD must be -1 (indicating never manual flush) or at least 0, but got ${e}.`)});function dn(){let e,t,n,a,r,s,i,o,l,d;return J().getNumber("WEBGL_VERSION")===2?(e="#version 300 es",t="in",n="out",a="in",r="texture",s="outputColor",i="out vec4 outputColor;",o=` bool isnan_custom(float val) { return (val > 0.0 || val < 0.0) ? false : val != 0.0; } @@ -84,7 +84,7 @@ Hi there \u{1F44B}. Looks like you are running TensorFlow.js in Node.js. To spee ivec4 round(vec4 value) { return ivec4(floor(value + vec4(0.5))); } - `),{version:e,attribute:t,varyingVs:n,varyingFs:a,texture2D:r,output:s,defineOutput:i,defineSpecialNaN:o,defineSpecialInf:l,defineRound:d}}function Ii(e,t,n="index"){let a=k.computeStrides(t);return a.map((r,s)=>{let i=`int ${e[s]} = ${n} / ${r}`,o=s===a.length-1?`int ${e[s+1]} = ${n} - ${e[s]} * ${r}`:`index -= ${e[s]} * ${r}`;return`${i}; ${o};`}).join("")}function u1(e){let t=k.computeStrides(e).map(n=>n.toString());return` + `),{version:e,attribute:t,varyingVs:n,varyingFs:a,texture2D:r,output:s,defineOutput:i,defineSpecialNaN:o,defineSpecialInf:l,defineRound:d}}function ki(e,t,n="index"){let a=k.computeStrides(t);return a.map((r,s)=>{let i=`int ${e[s]} = ${n} / ${r}`,o=s===a.length-1?`int ${e[s+1]} = ${n} - ${e[s]} * ${r}`:`index -= ${e[s]} * ${r}`;return`${i}; ${o};`}).join("")}function u1(e){let t=k.computeStrides(e).map(n=>n.toString());return` int getFlatIndex(ivec3 coords) { return coords.x * ${t[0]} + coords.y * ${t[1]} + coords.z; } @@ -127,9 +127,9 @@ Hi there \u{1F44B}. Looks like you are running TensorFlow.js in Node.js. To spee return c / 255.0; } -`,ZP=class{constructor(e){this.variableNames=["A"],this.packedInputs=!1,this.packedOutput=!0,this.outPackingScheme=cd.DENSE;let t=fd(e),n=pn();this.outputShape=e,this.userCode=` +`,ZP=class{constructor(e){this.variableNames=["A"],this.packedInputs=!1,this.packedOutput=!0,this.outPackingScheme=cd.DENSE;let t=fd(e),n=dn();this.outputShape=e,this.userCode=` ivec3 outCoordsFromFlatIndex(int index) { - ${Ii(["r","c","d"],e)} + ${ki(["r","c","d"],e)} return ivec3(r, c, d); } @@ -148,9 +148,9 @@ Hi there \u{1F44B}. Looks like you are running TensorFlow.js in Node.js. To spee ${n.output} = result; } - `}},YP=class{constructor(e){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!0,this.outPackingScheme=cd.DENSE;let t=fd(e),n=pn();this.outputShape=e,this.userCode=` + `}},YP=class{constructor(e){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!0,this.outPackingScheme=cd.DENSE;let t=fd(e),n=dn();this.outputShape=e,this.userCode=` ivec3 outCoordsFromFlatIndex(int index) { - ${Ii(["r","c","d"],e)} + ${ki(["r","c","d"],e)} return ivec3(r, c, d); } @@ -169,14 +169,14 @@ Hi there \u{1F44B}. Looks like you are running TensorFlow.js in Node.js. To spee ${n.output} = result; } - `}},JP=class{constructor(e){this.variableNames=["A"],this.outTexUsage=Jn.DOWNLOAD;let t=pn();this.outputShape=e,this.userCode=` + `}},JP=class{constructor(e){this.variableNames=["A"],this.outTexUsage=Yn.DOWNLOAD;let t=dn();this.outputShape=e,this.userCode=` ${U7} void main() { float x = getAAtOutCoords(); ${t.output} = encode_float(x); } - `}},QP=class{constructor(e){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!1,this.outTexUsage=Jn.DOWNLOAD;let t=pn();this.outputShape=e,this.userCode=` + `}},QP=class{constructor(e){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!1,this.outTexUsage=Yn.DOWNLOAD;let t=dn();this.outputShape=e,this.userCode=` ${U7} void main() { @@ -184,7 +184,7 @@ Hi there \u{1F44B}. Looks like you are running TensorFlow.js in Node.js. To spee float x = getChannel(getAAtOutCoords(), vec2(coords.y, coords.z)); ${t.output} = encode_float(x); } - `}},eL=class{constructor(e,t,n=!1){this.variableNames=["A"];let a=pn(),[r,s]=t;this.outputShape=e;let i="result";n&&(i="floor(result * 255. + 0.5)"),this.userCode=` + `}},eL=class{constructor(e,t,n=!1){this.variableNames=["A"];let a=dn(),[r,s]=t;this.outputShape=e;let i="result";n&&(i="floor(result * 255. + 0.5)"),this.userCode=` ${u1(e)} void main() { @@ -214,7 +214,7 @@ Hi there \u{1F44B}. Looks like you are running TensorFlow.js in Node.js. To spee ${a.output} = vec4(${i}, 0., 0., 0.); } - `}},tL=class{constructor(e,t,n=!1){this.variableNames=["A"],this.packedInputs=!1,this.packedOutput=!0;let a=pn(),[r,s]=t;this.outputShape=e;let i="",o="result";n&&(o="floor(result * 255. + 0.5)");for(let l=0;l<=1;l++)for(let d=0;d<=1;d++){let u=l*2+d;i+=` + `}},tL=class{constructor(e,t,n=!1){this.variableNames=["A"],this.packedInputs=!1,this.packedOutput=!0;let a=dn(),[r,s]=t;this.outputShape=e;let i="",o="result";n&&(o="floor(result * 255. + 0.5)");for(let l=0;l<=1;l++)for(let d=0;d<=1;d++){let u=l*2+d;i+=` localCoords = coords; if(localCoords[2] + ${d} < ${e[2]}) { localCoords[2] += ${d}; @@ -258,7 +258,7 @@ Hi there \u{1F44B}. Looks like you are running TensorFlow.js in Node.js. To spee ${a.output} = ${o}; } - `}},H7={};Fe(H7,{bindVertexProgramAttributeStreams:()=>ev,createBufferFromOutputTexture:()=>av,createFloat16MatrixTexture:()=>Z7,createFloat16PackedMatrixTexture:()=>Q7,createFloat32MatrixTexture:()=>K7,createIndexBuffer:()=>X7,createPackedMatrixTexture:()=>J7,createUnsignedBytesMatrixTexture:()=>Y7,createVertexBuffer:()=>q7,createVertexShader:()=>G7,downloadByteEncodedFloatMatrixFromOutputTexture:()=>sv,downloadFloat32MatrixFromBuffer:()=>rv,downloadMatrixFromPackedOutputTexture:()=>ov,downloadPackedMatrixFromBuffer:()=>iv,getInternalFormatForFloat16MatrixTexture:()=>p1,getInternalFormatForFloat16PackedMatrixTexture:()=>f1,getInternalFormatForFloat32MatrixTexture:()=>d1,getInternalFormatForPackedMatrixTexture:()=>h1,getInternalFormatForUnsignedBytesMatrixTexture:()=>c1,uploadDenseMatrixToTexture:()=>tv,uploadPixelDataToTexture:()=>nv});function G7(e){let t=pn(),n=`${t.version} + `}},H7={};Fe(H7,{bindVertexProgramAttributeStreams:()=>ev,createBufferFromOutputTexture:()=>av,createFloat16MatrixTexture:()=>Z7,createFloat16PackedMatrixTexture:()=>Q7,createFloat32MatrixTexture:()=>K7,createIndexBuffer:()=>X7,createPackedMatrixTexture:()=>J7,createUnsignedBytesMatrixTexture:()=>Y7,createVertexBuffer:()=>q7,createVertexShader:()=>G7,downloadByteEncodedFloatMatrixFromOutputTexture:()=>sv,downloadFloat32MatrixFromBuffer:()=>rv,downloadMatrixFromPackedOutputTexture:()=>ov,downloadPackedMatrixFromBuffer:()=>iv,getInternalFormatForFloat16MatrixTexture:()=>p1,getInternalFormatForFloat16PackedMatrixTexture:()=>f1,getInternalFormatForFloat32MatrixTexture:()=>d1,getInternalFormatForPackedMatrixTexture:()=>h1,getInternalFormatForUnsignedBytesMatrixTexture:()=>c1,uploadDenseMatrixToTexture:()=>tv,uploadPixelDataToTexture:()=>nv});function G7(e){let t=dn(),n=`${t.version} precision highp float; ${t.attribute} vec3 clipSpacePos; ${t.attribute} vec2 uv; @@ -267,10 +267,10 @@ Hi there \u{1F44B}. Looks like you are running TensorFlow.js in Node.js. To spee void main() { gl_Position = vec4(clipSpacePos, 1); resultUV = uv; - }`;return w7(e,n)}function q7(e){let t=new Float32Array([-1,1,0,0,1,-1,-1,0,0,0,1,1,0,1,1,1,-1,0,1,0]);return N7(e,t)}function X7(e){let t=new Uint16Array([0,1,2,2,1,3]);return T7(e,t)}function md(e,t,n,a,r,s){C7(t,n);let i=E7(e),o=e.TEXTURE_2D;return xe(e,()=>e.bindTexture(o,i)),xe(e,()=>e.texParameteri(o,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE)),xe(e,()=>e.texParameteri(o,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE)),xe(e,()=>e.texParameteri(o,e.TEXTURE_MIN_FILTER,e.NEAREST)),xe(e,()=>e.texParameteri(o,e.TEXTURE_MAG_FILTER,e.NEAREST)),xe(e,()=>e.texImage2D(o,0,a,t,n,0,r,s,null)),xe(e,()=>e.bindTexture(e.TEXTURE_2D,null)),i}function d1(e){return e.internalFormatFloat}function K7(e,t,n,a){let[r,s]=hd(t,n);return md(e,r,s,d1(a),a.textureFormatFloat,e.FLOAT)}function p1(e){return e.internalFormatHalfFloat}function Z7(e,t,n,a){let[r,s]=hd(t,n);return md(e,r,s,p1(a),a.textureFormatFloat,a.textureTypeHalfFloat)}function c1(e){return e.downloadTextureFormat}function Y7(e,t,n,a){let[r,s]=hd(t,n);return md(e,r,s,c1(a),e.RGBA,e.UNSIGNED_BYTE)}function h1(e){return e.internalFormatPackedFloat}function J7(e,t,n,a){let[r,s]=Rl(t,n);return md(e,r,s,h1(a),e.RGBA,e.FLOAT)}function f1(e){return e.internalFormatPackedHalfFloat}function Q7(e,t,n,a){let[r,s]=Rl(t,n);return md(e,r,s,f1(a),e.RGBA,a.textureTypeHalfFloat)}function ev(e,t,n){let a=0,r=3*4,s=3*4+2*4;return xe(e,()=>e.bindBuffer(e.ARRAY_BUFFER,n)),a1(e,t,"clipSpacePos",n,3,s,a)&&a1(e,t,"uv",n,2,s,r)}function tv(e,t,n,a,r,s){xe(e,()=>e.bindTexture(e.TEXTURE_2D,t));let i,o,l;r instanceof Uint8Array?(i=new Uint8Array(n*a*4),o=e.UNSIGNED_BYTE,l=e.RGBA):(i=new Float32Array(n*a*4),o=e.FLOAT,l=s.internalFormatPackedFloat),i.set(r),xe(e,()=>e.texImage2D(e.TEXTURE_2D,0,l,n,a,0,e.RGBA,o,i)),xe(e,()=>e.bindTexture(e.TEXTURE_2D,null))}function nv(e,t,n){xe(e,()=>e.bindTexture(e.TEXTURE_2D,t)),n.data instanceof Uint8Array?xe(e,()=>e.texImage2D(e.TEXTURE_2D,0,e.RGBA,n.width,n.height,0,e.RGBA,e.UNSIGNED_BYTE,n.data)):xe(e,()=>e.texImage2D(e.TEXTURE_2D,0,e.RGBA,e.RGBA,e.UNSIGNED_BYTE,n)),xe(e,()=>e.bindTexture(e.TEXTURE_2D,null))}function av(e,t,n,a){let r=e.createBuffer();xe(e,()=>e.bindBuffer(e.PIXEL_PACK_BUFFER,r));let s=4*4*t*n;return xe(e,()=>e.bufferData(e.PIXEL_PACK_BUFFER,s,e.STREAM_READ)),xe(e,()=>e.readPixels(0,0,n,t,e.RGBA,e.FLOAT,0)),xe(e,()=>e.bindBuffer(e.PIXEL_PACK_BUFFER,null)),r}function rv(e,t,n){let a=e,r=new Float32Array(n);return a.bindBuffer(a.PIXEL_PACK_BUFFER,t),a.getBufferSubData(a.PIXEL_PACK_BUFFER,0,r),a.bindBuffer(a.PIXEL_PACK_BUFFER,null),r}function sv(e,t,n,a){let[r,s]=hd(t,n),i=4,o=new Uint8Array(VP(t*n,i));return xe(e,()=>e.readPixels(0,0,r,s,a.downloadTextureFormat,e.UNSIGNED_BYTE,o)),new Float32Array(o.buffer)}function iv(e,t,n,a,r,s,i,o){let l=e,d=new Float32Array(jP(s,i));return l.bindBuffer(l.PIXEL_PACK_BUFFER,t),l.getBufferSubData(l.PIXEL_PACK_BUFFER,0,d),l.bindBuffer(l.PIXEL_PACK_BUFFER,null),d}function ov(e,t,n){let a=new Float32Array(t*n*4);return xe(e,()=>e.readPixels(0,0,n,t,e.RGBA,e.FLOAT,a)),a}var mh=class{constructor(e){this.outputTexture=null,this.program=null,this.disposed=!1,this.vertexAttrsAreBound=!1,this.itemsToPoll=[];let t=J().getNumber("WEBGL_VERSION");e!=null?(this.gl=e,ph(t,e)):this.gl=Va(t);let n="WEBGL_color_buffer_float",a="EXT_color_buffer_half_float";if(J().getNumber("WEBGL_VERSION")===1){let r="OES_texture_float",s="OES_texture_half_float";if(this.textureFloatExtension=ud(this.gl,r),Yn(this.gl,s))this.textureHalfFloatExtension=ud(this.gl,s);else if(J().get("WEBGL_FORCE_F16_TEXTURES"))throw new Error("GL context does not support half float textures, yet the environment flag WEBGL_FORCE_F16_TEXTURES is set to true.");if(this.colorBufferFloatExtension=this.gl.getExtension(n),Yn(this.gl,a))this.colorBufferHalfFloatExtension=ud(this.gl,a);else if(J().get("WEBGL_FORCE_F16_TEXTURES"))throw new Error("GL context does not support color renderable half floats, yet the environment flag WEBGL_FORCE_F16_TEXTURES is set to true.")}else if(n="EXT_color_buffer_float",Yn(this.gl,n))this.colorBufferFloatExtension=this.gl.getExtension(n);else if(Yn(this.gl,a))this.colorBufferHalfFloatExtension=this.gl.getExtension(a);else throw new Error("GL context does not support color renderable floats");this.vertexBuffer=q7(this.gl),this.indexBuffer=X7(this.gl),this.framebuffer=R7(this.gl),this.textureConfig=o1(this.gl,this.textureHalfFloatExtension)}get debug(){return J().getBool("DEBUG")}dispose(){if(this.disposed)return;this.program!=null&&console.warn("Disposing a GPGPUContext that still has a bound WebGLProgram. This is probably a resource leak, delete the program with GPGPUContext.deleteProgram before disposing."),this.outputTexture!=null&&console.warn("Disposing a GPGPUContext that still has a bound output matrix texture. This is probably a resource leak, delete the output matrix texture with GPGPUContext.deleteMatrixTexture before disposing.");let e=this.gl;xe(e,()=>e.finish()),xe(e,()=>e.bindFramebuffer(e.FRAMEBUFFER,null)),xe(e,()=>e.deleteFramebuffer(this.framebuffer)),xe(e,()=>e.bindBuffer(e.ARRAY_BUFFER,null)),xe(e,()=>e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,null)),xe(e,()=>e.deleteBuffer(this.indexBuffer)),this.disposed=!0}createFloat32MatrixTexture(e,t){return this.throwIfDisposed(),K7(this.gl,e,t,this.textureConfig)}createFloat16MatrixTexture(e,t){return this.throwIfDisposed(),Z7(this.gl,e,t,this.textureConfig)}createUnsignedBytesMatrixTexture(e,t){return this.throwIfDisposed(),Y7(this.gl,e,t,this.textureConfig)}uploadPixelDataToTexture(e,t){this.throwIfDisposed(),nv(this.gl,e,t)}uploadDenseMatrixToTexture(e,t,n,a){this.throwIfDisposed(),tv(this.gl,e,t,n,a,this.textureConfig)}createFloat16PackedMatrixTexture(e,t){return this.throwIfDisposed(),Q7(this.gl,e,t,this.textureConfig)}createPackedMatrixTexture(e,t){return this.throwIfDisposed(),J7(this.gl,e,t,this.textureConfig)}deleteMatrixTexture(e){this.throwIfDisposed(),this.outputTexture===e&&(r1(this.gl,this.framebuffer),this.outputTexture=null),xe(this.gl,()=>this.gl.deleteTexture(e))}downloadByteEncodedFloatMatrixFromOutputTexture(e,t,n){return this.downloadMatrixDriver(e,()=>sv(this.gl,t,n,this.textureConfig))}downloadPackedMatrixFromBuffer(e,t,n,a,r,s){return iv(this.gl,e,t,n,a,r,s,this.textureConfig)}downloadFloat32MatrixFromBuffer(e,t){return rv(this.gl,e,t)}createBufferFromTexture(e,t,n){this.bindTextureToFrameBuffer(e);let a=av(this.gl,t,n,this.textureConfig);return this.unbindTextureToFrameBuffer(),a}createAndWaitForFence(){let e=this.createFence(this.gl);return this.pollFence(e)}createFence(e){let t,n;if(J().getBool("WEBGL_FENCE_API_ENABLED")){let a=e,r=a.fenceSync(a.SYNC_GPU_COMMANDS_COMPLETE,0);e.flush(),n=()=>{let s=a.clientWaitSync(r,0,0);return s===a.ALREADY_SIGNALED||s===a.CONDITION_SATISFIED},t=r}else J().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")>0?(t=this.beginQuery(),this.endQuery(),n=()=>this.isQueryAvailable(t,J().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION"))):n=()=>!0;return{query:t,isFencePassed:n}}downloadMatrixFromPackedTexture(e,t,n){return this.downloadMatrixDriver(e,()=>ov(this.gl,t,n))}createProgram(e){this.throwIfDisposed();let t=this.gl,n=k7(t,e);this.vertexShader==null&&(this.vertexShader=G7(t));let a=I7(t);return xe(t,()=>t.attachShader(a,this.vertexShader)),xe(t,()=>t.attachShader(a,n)),S7(t,a),this.debug&&lh(t,a),this.vertexAttrsAreBound||(this.setProgram(a),this.vertexAttrsAreBound=ev(t,this.program,this.vertexBuffer)),a}deleteProgram(e){this.throwIfDisposed(),e===this.program&&(this.program=null),e!=null&&xe(this.gl,()=>this.gl.deleteProgram(e))}setProgram(e){this.throwIfDisposed(),this.program=e,this.program!=null&&this.debug&&lh(this.gl,this.program),xe(this.gl,()=>this.gl.useProgram(e))}getUniformLocation(e,t,n=!0){return this.throwIfDisposed(),n?F7(this.gl,e,t):$7(this.gl,e,t)}getAttributeLocation(e,t){return this.throwIfDisposed(),xe(this.gl,()=>this.gl.getAttribLocation(e,t))}getUniformLocationNoThrow(e,t){return this.throwIfDisposed(),this.gl.getUniformLocation(e,t)}setInputMatrixTexture(e,t,n){this.throwIfDisposed(),this.throwIfNoProgram(),D7(this.gl,e,t,n)}setOutputMatrixTexture(e,t,n){this.setOutputMatrixTextureDriver(e,n,t)}setOutputPackedMatrixTexture(e,t,n){this.throwIfDisposed();let[a,r]=Rl(t,n);this.setOutputMatrixTextureDriver(e,a,r)}setOutputMatrixWriteRegion(e,t,n,a){this.setOutputMatrixWriteRegionDriver(n,e,a,t)}setOutputPackedMatrixWriteRegion(e,t,n,a){throw new Error("setOutputPackedMatrixWriteRegion not implemented.")}debugValidate(){this.program!=null&&lh(this.gl,this.program),dd(this.gl)}executeProgram(){this.throwIfDisposed(),this.throwIfNoProgram();let e=this.gl;this.debug&&this.debugValidate(),xe(e,()=>e.drawElements(e.TRIANGLES,6,e.UNSIGNED_SHORT,0))}blockUntilAllProgramsCompleted(){this.throwIfDisposed(),xe(this.gl,()=>this.gl.finish())}getQueryTimerExtension(){return this.disjointQueryTimerExtension==null&&(this.disjointQueryTimerExtension=ud(this.gl,J().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")===2?"EXT_disjoint_timer_query_webgl2":"EXT_disjoint_timer_query")),this.disjointQueryTimerExtension}getQueryTimerExtensionWebGL2(){return this.getQueryTimerExtension()}getQueryTimerExtensionWebGL1(){return this.getQueryTimerExtension()}beginQuery(){if(J().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")===2){let n=this.gl,a=this.getQueryTimerExtensionWebGL2(),r=n.createQuery();return n.beginQuery(a.TIME_ELAPSED_EXT,r),r}let e=this.getQueryTimerExtensionWebGL1(),t=e.createQueryEXT();return e.beginQueryEXT(e.TIME_ELAPSED_EXT,t),t}endQuery(){if(J().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")===2){let t=this.gl,n=this.getQueryTimerExtensionWebGL2();t.endQuery(n.TIME_ELAPSED_EXT);return}let e=this.getQueryTimerExtensionWebGL1();e.endQueryEXT(e.TIME_ELAPSED_EXT)}async waitForQueryAndGetTime(e){return await k.repeatedTry(()=>this.disposed||this.isQueryAvailable(e,J().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION"))),this.getQueryTime(e,J().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION"))}getQueryTime(e,t){if(t===0)return null;if(t===2){let n=this.gl;return n.getQueryParameter(e,n.QUERY_RESULT)/1e6}else{let n=this.getQueryTimerExtensionWebGL1();return n.getQueryObjectEXT(e,n.QUERY_RESULT_EXT)/1e6}}isQueryAvailable(e,t){if(t===0)return!0;if(t===2){let n=this.gl,a=this.getQueryTimerExtensionWebGL2(),r=n.getQueryParameter(e,n.QUERY_RESULT_AVAILABLE);return this.disjoint==null&&(this.disjoint=this.gl.getParameter(a.GPU_DISJOINT_EXT)),r&&!this.disjoint}else{let n=this.getQueryTimerExtensionWebGL1(),a=n.getQueryObjectEXT(e,n.QUERY_RESULT_AVAILABLE_EXT);return this.disjoint==null&&(this.disjoint=this.gl.getParameter(n.GPU_DISJOINT_EXT)),a&&!this.disjoint}}pollFence(e){return new Promise(t=>{this.addItemToPoll(()=>e.isFencePassed(),()=>t())})}pollItems(){let e=nL(this.itemsToPoll.map(t=>t.isDoneFn));for(let t=0;t<=e;++t){let{resolveFn:n}=this.itemsToPoll[t];n()}this.itemsToPoll=this.itemsToPoll.slice(e+1)}addItemToPoll(e,t){this.itemsToPoll.push({isDoneFn:e,resolveFn:t}),!(this.itemsToPoll.length>1)&&k.repeatedTry(()=>(this.pollItems(),this.itemsToPoll.length===0))}bindTextureToFrameBuffer(e){this.throwIfDisposed(),uh(this.gl,e,this.framebuffer),this.debug&&dd(this.gl)}unbindTextureToFrameBuffer(){this.outputTexture!=null?(uh(this.gl,this.outputTexture,this.framebuffer),this.debug&&dd(this.gl)):r1(this.gl,this.framebuffer)}downloadMatrixDriver(e,t){this.bindTextureToFrameBuffer(e);let n=t();return this.unbindTextureToFrameBuffer(),n}setOutputMatrixTextureDriver(e,t,n){this.throwIfDisposed();let a=this.gl;uh(a,e,this.framebuffer),this.debug&&dd(a),this.outputTexture=e,xe(a,()=>a.viewport(0,0,t,n)),xe(a,()=>a.scissor(0,0,t,n))}setOutputMatrixWriteRegionDriver(e,t,n,a){this.throwIfDisposed(),xe(this.gl,()=>this.gl.scissor(e,t,n,a))}throwIfDisposed(){if(this.disposed)throw new Error("Attempted to use disposed GPGPUContext.")}throwIfNoProgram(){if(this.program==null)throw new Error("No GPU program is currently set.")}};function nL(e){let t=0;for(;t{let m=k.sizeFromShape(h.shapeInfo.logicalShape);h.shapeInfo.isUniform?r.push(`uniform float ${h.name}${m>1?`[${m}]`:""};`):(r.push(`uniform sampler2D ${h.name};`),r.push(`uniform int offset${h.name};`))});let s=r.join(` + }`;return w7(e,n)}function q7(e){let t=new Float32Array([-1,1,0,0,1,-1,-1,0,0,0,1,1,0,1,1,1,-1,0,1,0]);return N7(e,t)}function X7(e){let t=new Uint16Array([0,1,2,2,1,3]);return T7(e,t)}function md(e,t,n,a,r,s){C7(t,n);let i=E7(e),o=e.TEXTURE_2D;return xe(e,()=>e.bindTexture(o,i)),xe(e,()=>e.texParameteri(o,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE)),xe(e,()=>e.texParameteri(o,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE)),xe(e,()=>e.texParameteri(o,e.TEXTURE_MIN_FILTER,e.NEAREST)),xe(e,()=>e.texParameteri(o,e.TEXTURE_MAG_FILTER,e.NEAREST)),xe(e,()=>e.texImage2D(o,0,a,t,n,0,r,s,null)),xe(e,()=>e.bindTexture(e.TEXTURE_2D,null)),i}function d1(e){return e.internalFormatFloat}function K7(e,t,n,a){let[r,s]=hd(t,n);return md(e,r,s,d1(a),a.textureFormatFloat,e.FLOAT)}function p1(e){return e.internalFormatHalfFloat}function Z7(e,t,n,a){let[r,s]=hd(t,n);return md(e,r,s,p1(a),a.textureFormatFloat,a.textureTypeHalfFloat)}function c1(e){return e.downloadTextureFormat}function Y7(e,t,n,a){let[r,s]=hd(t,n);return md(e,r,s,c1(a),e.RGBA,e.UNSIGNED_BYTE)}function h1(e){return e.internalFormatPackedFloat}function J7(e,t,n,a){let[r,s]=Cl(t,n);return md(e,r,s,h1(a),e.RGBA,e.FLOAT)}function f1(e){return e.internalFormatPackedHalfFloat}function Q7(e,t,n,a){let[r,s]=Cl(t,n);return md(e,r,s,f1(a),e.RGBA,a.textureTypeHalfFloat)}function ev(e,t,n){let a=0,r=3*4,s=3*4+2*4;return xe(e,()=>e.bindBuffer(e.ARRAY_BUFFER,n)),a1(e,t,"clipSpacePos",n,3,s,a)&&a1(e,t,"uv",n,2,s,r)}function tv(e,t,n,a,r,s){xe(e,()=>e.bindTexture(e.TEXTURE_2D,t));let i,o,l;r instanceof Uint8Array?(i=new Uint8Array(n*a*4),o=e.UNSIGNED_BYTE,l=e.RGBA):(i=new Float32Array(n*a*4),o=e.FLOAT,l=s.internalFormatPackedFloat),i.set(r),xe(e,()=>e.texImage2D(e.TEXTURE_2D,0,l,n,a,0,e.RGBA,o,i)),xe(e,()=>e.bindTexture(e.TEXTURE_2D,null))}function nv(e,t,n){xe(e,()=>e.bindTexture(e.TEXTURE_2D,t)),n.data instanceof Uint8Array?xe(e,()=>e.texImage2D(e.TEXTURE_2D,0,e.RGBA,n.width,n.height,0,e.RGBA,e.UNSIGNED_BYTE,n.data)):xe(e,()=>e.texImage2D(e.TEXTURE_2D,0,e.RGBA,e.RGBA,e.UNSIGNED_BYTE,n)),xe(e,()=>e.bindTexture(e.TEXTURE_2D,null))}function av(e,t,n,a){let r=e.createBuffer();xe(e,()=>e.bindBuffer(e.PIXEL_PACK_BUFFER,r));let s=4*4*t*n;return xe(e,()=>e.bufferData(e.PIXEL_PACK_BUFFER,s,e.STREAM_READ)),xe(e,()=>e.readPixels(0,0,n,t,e.RGBA,e.FLOAT,0)),xe(e,()=>e.bindBuffer(e.PIXEL_PACK_BUFFER,null)),r}function rv(e,t,n){let a=e,r=new Float32Array(n);return a.bindBuffer(a.PIXEL_PACK_BUFFER,t),a.getBufferSubData(a.PIXEL_PACK_BUFFER,0,r),a.bindBuffer(a.PIXEL_PACK_BUFFER,null),r}function sv(e,t,n,a){let[r,s]=hd(t,n),i=4,o=new Uint8Array(VP(t*n,i));return xe(e,()=>e.readPixels(0,0,r,s,a.downloadTextureFormat,e.UNSIGNED_BYTE,o)),new Float32Array(o.buffer)}function iv(e,t,n,a,r,s,i,o){let l=e,d=new Float32Array(jP(s,i));return l.bindBuffer(l.PIXEL_PACK_BUFFER,t),l.getBufferSubData(l.PIXEL_PACK_BUFFER,0,d),l.bindBuffer(l.PIXEL_PACK_BUFFER,null),d}function ov(e,t,n){let a=new Float32Array(t*n*4);return xe(e,()=>e.readPixels(0,0,n,t,e.RGBA,e.FLOAT,a)),a}var mh=class{constructor(e){this.outputTexture=null,this.program=null,this.disposed=!1,this.vertexAttrsAreBound=!1,this.itemsToPoll=[];let t=J().getNumber("WEBGL_VERSION");e!=null?(this.gl=e,ph(t,e)):this.gl=Ba(t);let n="WEBGL_color_buffer_float",a="EXT_color_buffer_half_float";if(J().getNumber("WEBGL_VERSION")===1){let r="OES_texture_float",s="OES_texture_half_float";if(this.textureFloatExtension=ud(this.gl,r),Zn(this.gl,s))this.textureHalfFloatExtension=ud(this.gl,s);else if(J().get("WEBGL_FORCE_F16_TEXTURES"))throw new Error("GL context does not support half float textures, yet the environment flag WEBGL_FORCE_F16_TEXTURES is set to true.");if(this.colorBufferFloatExtension=this.gl.getExtension(n),Zn(this.gl,a))this.colorBufferHalfFloatExtension=ud(this.gl,a);else if(J().get("WEBGL_FORCE_F16_TEXTURES"))throw new Error("GL context does not support color renderable half floats, yet the environment flag WEBGL_FORCE_F16_TEXTURES is set to true.")}else if(n="EXT_color_buffer_float",Zn(this.gl,n))this.colorBufferFloatExtension=this.gl.getExtension(n);else if(Zn(this.gl,a))this.colorBufferHalfFloatExtension=this.gl.getExtension(a);else throw new Error("GL context does not support color renderable floats");this.vertexBuffer=q7(this.gl),this.indexBuffer=X7(this.gl),this.framebuffer=R7(this.gl),this.textureConfig=o1(this.gl,this.textureHalfFloatExtension)}get debug(){return J().getBool("DEBUG")}dispose(){if(this.disposed)return;this.program!=null&&console.warn("Disposing a GPGPUContext that still has a bound WebGLProgram. This is probably a resource leak, delete the program with GPGPUContext.deleteProgram before disposing."),this.outputTexture!=null&&console.warn("Disposing a GPGPUContext that still has a bound output matrix texture. This is probably a resource leak, delete the output matrix texture with GPGPUContext.deleteMatrixTexture before disposing.");let e=this.gl;xe(e,()=>e.finish()),xe(e,()=>e.bindFramebuffer(e.FRAMEBUFFER,null)),xe(e,()=>e.deleteFramebuffer(this.framebuffer)),xe(e,()=>e.bindBuffer(e.ARRAY_BUFFER,null)),xe(e,()=>e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,null)),xe(e,()=>e.deleteBuffer(this.indexBuffer)),this.disposed=!0}createFloat32MatrixTexture(e,t){return this.throwIfDisposed(),K7(this.gl,e,t,this.textureConfig)}createFloat16MatrixTexture(e,t){return this.throwIfDisposed(),Z7(this.gl,e,t,this.textureConfig)}createUnsignedBytesMatrixTexture(e,t){return this.throwIfDisposed(),Y7(this.gl,e,t,this.textureConfig)}uploadPixelDataToTexture(e,t){this.throwIfDisposed(),nv(this.gl,e,t)}uploadDenseMatrixToTexture(e,t,n,a){this.throwIfDisposed(),tv(this.gl,e,t,n,a,this.textureConfig)}createFloat16PackedMatrixTexture(e,t){return this.throwIfDisposed(),Q7(this.gl,e,t,this.textureConfig)}createPackedMatrixTexture(e,t){return this.throwIfDisposed(),J7(this.gl,e,t,this.textureConfig)}deleteMatrixTexture(e){this.throwIfDisposed(),this.outputTexture===e&&(r1(this.gl,this.framebuffer),this.outputTexture=null),xe(this.gl,()=>this.gl.deleteTexture(e))}downloadByteEncodedFloatMatrixFromOutputTexture(e,t,n){return this.downloadMatrixDriver(e,()=>sv(this.gl,t,n,this.textureConfig))}downloadPackedMatrixFromBuffer(e,t,n,a,r,s){return iv(this.gl,e,t,n,a,r,s,this.textureConfig)}downloadFloat32MatrixFromBuffer(e,t){return rv(this.gl,e,t)}createBufferFromTexture(e,t,n){this.bindTextureToFrameBuffer(e);let a=av(this.gl,t,n,this.textureConfig);return this.unbindTextureToFrameBuffer(),a}createAndWaitForFence(){let e=this.createFence(this.gl);return this.pollFence(e)}createFence(e){let t,n;if(J().getBool("WEBGL_FENCE_API_ENABLED")){let a=e,r=a.fenceSync(a.SYNC_GPU_COMMANDS_COMPLETE,0);e.flush(),n=()=>{let s=a.clientWaitSync(r,0,0);return s===a.ALREADY_SIGNALED||s===a.CONDITION_SATISFIED},t=r}else J().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")>0?(t=this.beginQuery(),this.endQuery(),n=()=>this.isQueryAvailable(t,J().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION"))):n=()=>!0;return{query:t,isFencePassed:n}}downloadMatrixFromPackedTexture(e,t,n){return this.downloadMatrixDriver(e,()=>ov(this.gl,t,n))}createProgram(e){this.throwIfDisposed();let t=this.gl,n=k7(t,e);this.vertexShader==null&&(this.vertexShader=G7(t));let a=I7(t);return xe(t,()=>t.attachShader(a,this.vertexShader)),xe(t,()=>t.attachShader(a,n)),S7(t,a),this.debug&&lh(t,a),this.vertexAttrsAreBound||(this.setProgram(a),this.vertexAttrsAreBound=ev(t,this.program,this.vertexBuffer)),a}deleteProgram(e){this.throwIfDisposed(),e===this.program&&(this.program=null),e!=null&&xe(this.gl,()=>this.gl.deleteProgram(e))}setProgram(e){this.throwIfDisposed(),this.program=e,this.program!=null&&this.debug&&lh(this.gl,this.program),xe(this.gl,()=>this.gl.useProgram(e))}getUniformLocation(e,t,n=!0){return this.throwIfDisposed(),n?F7(this.gl,e,t):$7(this.gl,e,t)}getAttributeLocation(e,t){return this.throwIfDisposed(),xe(this.gl,()=>this.gl.getAttribLocation(e,t))}getUniformLocationNoThrow(e,t){return this.throwIfDisposed(),this.gl.getUniformLocation(e,t)}setInputMatrixTexture(e,t,n){this.throwIfDisposed(),this.throwIfNoProgram(),D7(this.gl,e,t,n)}setOutputMatrixTexture(e,t,n){this.setOutputMatrixTextureDriver(e,n,t)}setOutputPackedMatrixTexture(e,t,n){this.throwIfDisposed();let[a,r]=Cl(t,n);this.setOutputMatrixTextureDriver(e,a,r)}setOutputMatrixWriteRegion(e,t,n,a){this.setOutputMatrixWriteRegionDriver(n,e,a,t)}setOutputPackedMatrixWriteRegion(e,t,n,a){throw new Error("setOutputPackedMatrixWriteRegion not implemented.")}debugValidate(){this.program!=null&&lh(this.gl,this.program),dd(this.gl)}executeProgram(){this.throwIfDisposed(),this.throwIfNoProgram();let e=this.gl;this.debug&&this.debugValidate(),xe(e,()=>e.drawElements(e.TRIANGLES,6,e.UNSIGNED_SHORT,0))}blockUntilAllProgramsCompleted(){this.throwIfDisposed(),xe(this.gl,()=>this.gl.finish())}getQueryTimerExtension(){return this.disjointQueryTimerExtension==null&&(this.disjointQueryTimerExtension=ud(this.gl,J().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")===2?"EXT_disjoint_timer_query_webgl2":"EXT_disjoint_timer_query")),this.disjointQueryTimerExtension}getQueryTimerExtensionWebGL2(){return this.getQueryTimerExtension()}getQueryTimerExtensionWebGL1(){return this.getQueryTimerExtension()}beginQuery(){if(J().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")===2){let n=this.gl,a=this.getQueryTimerExtensionWebGL2(),r=n.createQuery();return n.beginQuery(a.TIME_ELAPSED_EXT,r),r}let e=this.getQueryTimerExtensionWebGL1(),t=e.createQueryEXT();return e.beginQueryEXT(e.TIME_ELAPSED_EXT,t),t}endQuery(){if(J().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")===2){let t=this.gl,n=this.getQueryTimerExtensionWebGL2();t.endQuery(n.TIME_ELAPSED_EXT);return}let e=this.getQueryTimerExtensionWebGL1();e.endQueryEXT(e.TIME_ELAPSED_EXT)}async waitForQueryAndGetTime(e){return await k.repeatedTry(()=>this.disposed||this.isQueryAvailable(e,J().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION"))),this.getQueryTime(e,J().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION"))}getQueryTime(e,t){if(t===0)return null;if(t===2){let n=this.gl;return n.getQueryParameter(e,n.QUERY_RESULT)/1e6}else{let n=this.getQueryTimerExtensionWebGL1();return n.getQueryObjectEXT(e,n.QUERY_RESULT_EXT)/1e6}}isQueryAvailable(e,t){if(t===0)return!0;if(t===2){let n=this.gl,a=this.getQueryTimerExtensionWebGL2(),r=n.getQueryParameter(e,n.QUERY_RESULT_AVAILABLE);return this.disjoint==null&&(this.disjoint=this.gl.getParameter(a.GPU_DISJOINT_EXT)),r&&!this.disjoint}else{let n=this.getQueryTimerExtensionWebGL1(),a=n.getQueryObjectEXT(e,n.QUERY_RESULT_AVAILABLE_EXT);return this.disjoint==null&&(this.disjoint=this.gl.getParameter(n.GPU_DISJOINT_EXT)),a&&!this.disjoint}}pollFence(e){return new Promise(t=>{this.addItemToPoll(()=>e.isFencePassed(),()=>t())})}pollItems(){let e=nL(this.itemsToPoll.map(t=>t.isDoneFn));for(let t=0;t<=e;++t){let{resolveFn:n}=this.itemsToPoll[t];n()}this.itemsToPoll=this.itemsToPoll.slice(e+1)}addItemToPoll(e,t){this.itemsToPoll.push({isDoneFn:e,resolveFn:t}),!(this.itemsToPoll.length>1)&&k.repeatedTry(()=>(this.pollItems(),this.itemsToPoll.length===0))}bindTextureToFrameBuffer(e){this.throwIfDisposed(),uh(this.gl,e,this.framebuffer),this.debug&&dd(this.gl)}unbindTextureToFrameBuffer(){this.outputTexture!=null?(uh(this.gl,this.outputTexture,this.framebuffer),this.debug&&dd(this.gl)):r1(this.gl,this.framebuffer)}downloadMatrixDriver(e,t){this.bindTextureToFrameBuffer(e);let n=t();return this.unbindTextureToFrameBuffer(),n}setOutputMatrixTextureDriver(e,t,n){this.throwIfDisposed();let a=this.gl;uh(a,e,this.framebuffer),this.debug&&dd(a),this.outputTexture=e,xe(a,()=>a.viewport(0,0,t,n)),xe(a,()=>a.scissor(0,0,t,n))}setOutputMatrixWriteRegionDriver(e,t,n,a){this.throwIfDisposed(),xe(this.gl,()=>this.gl.scissor(e,t,n,a))}throwIfDisposed(){if(this.disposed)throw new Error("Attempted to use disposed GPGPUContext.")}throwIfNoProgram(){if(this.program==null)throw new Error("No GPU program is currently set.")}};function nL(e){let t=0;for(;t{let m=k.sizeFromShape(h.shapeInfo.logicalShape);h.shapeInfo.isUniform?r.push(`uniform float ${h.name}${m>1?`[${m}]`:""};`):(r.push(`uniform sampler2D ${h.name};`),r.push(`uniform int offset${h.name};`))});let s=r.join(` `),i=e.map(h=>aL(h,t,a)).join(` -`),o=t.texShape,l=pn(),d=iL(l),u,p,c=uL(l);return t.isPacked?(u=rL(t.logicalShape,o),p=lL(l)):(u=sL(t.logicalShape,o),p=oL(l)),a&&(c+=dL),[c,d,p,s,u,i,n].join(` -`)}function Ml(e){let t=e.shapeInfo.logicalShape;switch(t.length){case 0:return cL(e);case 1:return hL(e);case 2:return fL(e);case 3:return mL(e);case 4:return AL(e);case 5:return yL(e);case 6:return gL(e);default:throw new Error(`${t.length}-D input sampling is not yet supported`)}}function uv(e){switch(e.shapeInfo.logicalShape.length){case 0:return xL(e);case 1:return bL(e);case 2:return vL(e);case 3:return wL(e);default:return kL(e)}}function aL(e,t,n=!1){let a="";n?a+=uv(e):a+=Ml(e);let r=e.shapeInfo.logicalShape,s=t.logicalShape;return r.length<=s.length&&(n?a+=IL(e,t):a+=SL(e,t)),a}function rL(e,t){switch(e.length){case 0:return dv();case 1:return NL(e,t);case 2:return CL(e,t);case 3:return TL(e,t);default:return EL(e,t)}}function sL(e,t){switch(e.length){case 0:return dv();case 1:return RL(e,t);case 2:return OL(e,t);case 3:return ML(e,t);case 4:return FL(e,t);case 5:return $L(e,t);case 6:return DL(e,t);default:throw new Error(`${e.length}-D output sampling is not yet supported`)}}function iL(e){return` +`),o=t.texShape,l=dn(),d=iL(l),u,p,c=uL(l);return t.isPacked?(u=rL(t.logicalShape,o),p=lL(l)):(u=sL(t.logicalShape,o),p=oL(l)),a&&(c+=dL),[c,d,p,s,u,i,n].join(` +`)}function Rl(e){let t=e.shapeInfo.logicalShape;switch(t.length){case 0:return cL(e);case 1:return hL(e);case 2:return fL(e);case 3:return mL(e);case 4:return AL(e);case 5:return yL(e);case 6:return gL(e);default:throw new Error(`${t.length}-D input sampling is not yet supported`)}}function uv(e){switch(e.shapeInfo.logicalShape.length){case 0:return xL(e);case 1:return bL(e);case 2:return vL(e);case 3:return wL(e);default:return kL(e)}}function aL(e,t,n=!1){let a="";n?a+=uv(e):a+=Rl(e);let r=e.shapeInfo.logicalShape,s=t.logicalShape;return r.length<=s.length&&(n?a+=IL(e,t):a+=SL(e,t)),a}function rL(e,t){switch(e.length){case 0:return dv();case 1:return NL(e,t);case 2:return CL(e,t);case 3:return TL(e,t);default:return EL(e,t)}}function sL(e,t){switch(e.length){case 0:return dv();case 1:return RL(e,t);case 2:return OL(e,t);case 3:return ML(e,t);case 4:return FL(e,t);case 5:return $L(e,t);case 6:return DL(e,t);default:throw new Error(`${e.length}-D output sampling is not yet supported`)}}function iL(e){return` float sampleTexture(sampler2D textureSampler, vec2 uv) { return ${e.texture2D}(textureSampler, uv).r; } @@ -426,7 +426,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, return ivec3(b, r, c); } - `}function ML(e,t){let n=Ii(["r","c","d"],e);return` + `}function ML(e,t){let n=ki(["r","c","d"],e);return` ivec3 getOutputCoords() { ivec2 resTexRC = ivec2(resultUV.yx * vec2(${t[0]}, ${t[1]})); @@ -453,7 +453,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, return ivec${e.length}(${o}); } - `}function FL(e,t){let n=Ii(["r","c","d","d2"],e);return` + `}function FL(e,t){let n=ki(["r","c","d","d2"],e);return` ivec4 getOutputCoords() { ivec2 resTexRC = ivec2(resultUV.yx * vec2(${t[0]}, ${t[1]})); @@ -461,7 +461,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, ${n} return ivec4(r, c, d, d2); } - `}function $L(e,t){let n=Ii(["r","c","d","d2","d3"],e);return` + `}function $L(e,t){let n=ki(["r","c","d","d2","d3"],e);return` ivec5 getOutputCoords() { ivec2 resTexRC = ivec2(resultUV.yx * vec2(${t[0]}, ${t[1]})); @@ -473,7 +473,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, ivec5 outShape = ivec5(r, c, d, d2, d3); return outShape; } - `}function DL(e,t){let n=Ii(["r","c","d","d2","d3","d4"],e);return` + `}function DL(e,t){let n=ki(["r","c","d","d2","d3","d4"],e);return` ivec6 getOutputCoords() { ivec2 resTexRC = ivec2(resultUV.yx * vec2(${t[0]}, ${t[1]})); @@ -526,7 +526,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, int c = index - r * ${e[1]}; return ivec2(r, c); } - `}function Si(e){return`offset${e}`}function xL(e){let t=e.name,n="get"+t.charAt(0).toUpperCase()+t.slice(1),a=pn();return` + `}function Ii(e){return`offset${e}`}function xL(e){let t=e.name,n="get"+t.charAt(0).toUpperCase()+t.slice(1),a=dn();return` vec4 ${n}() { return ${a.texture2D}(${t}, halfCR); } @@ -534,12 +534,12 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, float ${n}() { return sampleTexture(${t}, halfCR); } - `;let[s,i]=e.shapeInfo.texShape,o=Si(t);return` + `;let[s,i]=e.shapeInfo.texShape,o=Ii(t);return` float ${n}() { vec2 uv = uvFromFlat(${s}, ${i}, ${o}); return sampleTexture(${t}, uv); } - `}function bL(e){let t=e.name,n="get"+t.charAt(0).toUpperCase()+t.slice(1),a=e.shapeInfo.texShape,r=[Math.ceil(a[0]/2),Math.ceil(a[1]/2)],s=pn();return` + `}function bL(e){let t=e.name,n="get"+t.charAt(0).toUpperCase()+t.slice(1),a=e.shapeInfo.texShape,r=[Math.ceil(a[0]/2),Math.ceil(a[1]/2)],s=dn();return` vec4 ${n}(int index) { vec2 uv = packedUVfrom1D( ${r[0]}, ${r[1]}, index); @@ -547,13 +547,13 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, } `}function hL(e){let t=e.name,n="get"+t.charAt(0).toUpperCase()+t.slice(1);if(e.shapeInfo.isUniform)return` float ${n}(int index) { - ${Fl(e)} + ${Ml(e)} } `;let a=e.shapeInfo.texShape,r=a[0],s=a[1];if(s===1&&r===1)return` float ${n}(int index) { return sampleTexture(${t}, halfCR); } - `;let i=Si(t);return s===1?` + `;let i=Ii(t);return s===1?` float ${n}(int index) { vec2 uv = vec2(0.5, (float(index + ${i}) + 0.5) / ${r}.0); return sampleTexture(${t}, uv); @@ -568,7 +568,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, vec2 uv = uvFromFlat(${r}, ${s}, index + ${i}); return sampleTexture(${t}, uv); } - `}function vL(e){let t=e.shapeInfo.logicalShape,n=e.name,a="get"+n.charAt(0).toUpperCase()+n.slice(1),r=e.shapeInfo.texShape,s=r[0],i=r[1],o=pn();if(r!=null&&k.arraysEqual(t,r))return` + `}function vL(e){let t=e.shapeInfo.logicalShape,n=e.name,a="get"+n.charAt(0).toUpperCase()+n.slice(1),r=e.shapeInfo.texShape,s=r[0],i=r[1],o=dn();if(r!=null&&k.arraysEqual(t,r))return` vec4 ${a}(int row, int col) { vec2 uv = (vec2(col, row) + halfCR) / vec2(${i}.0, ${s}.0); @@ -584,17 +584,17 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, vec2 uv = (vec2(col, row) + halfCR) / vec2(${c}.0, ${p}.0); return sampleTexture(${n}, uv); } - `}let{newShape:s,keptDims:i}=k.squeezeShape(t),o=s;if(o.lengthe[n]).join(", ")}function LL(e,t,n,a){let r=t.userCode,s=n.map((h,m)=>{let f={logicalShape:h.shape,texShape:h.isUniform?null:h.texData.texShape,isUniform:h.isUniform,isPacked:h.isUniform?!1:h.texData.isPacked,flatOffset:null};return h.texData!=null&&h.texData.slice!=null&&h.texData.slice.flatOffset>0&&(f.flatOffset=h.texData.slice.flatOffset),{name:t.variableNames[m],shapeInfo:f}}),i=s.map(h=>h.shapeInfo),o={logicalShape:a.shape,texShape:a.texData.texShape,isUniform:!1,isPacked:a.texData.isPacked,flatOffset:null},l=pL(s,o,r,t.packedInputs),d=e.createProgram(l),u=null,p=e.getUniformLocation(d,"NAN",!1);J().getNumber("WEBGL_VERSION")===1&&(u=e.getUniformLocation(d,"INFINITY",!1));let c={};for(let h=0;h{let r=n.logicalShape,s=t[a],i=s.shape;if(!k.arraysEqual(r,i))throw Error(`Binary was compiled with different shapes than the current args. Shapes ${r} and ${i} must match`);if(n.isUniform&&s.isUniform)return;let o=n.texShape,l=s.isUniform?null:s.texData.texShape;if(!k.arraysEqual(o,l))throw Error(`Binary was compiled with different texture shapes than the current args. Shape ${o} and ${l} must match`)})}function WL(e,t,n,a,r){pv(t.inShapeInfos,n),pv([t.outShapeInfo],[a]);let s=a.texData.texture,i=a.texData.texShape;a.texData.isPacked?e.setOutputPackedMatrixTexture(s,i[0],i[1]):e.setOutputMatrixTexture(s,i[0],i[1]),e.setProgram(t.webGLProgram),J().getNumber("WEBGL_VERSION")===1&&t.infLoc!==null&&e.gl.uniform1f(t.infLoc,Infinity),t.nanLoc!==null&&e.gl.uniform1f(t.nanLoc,NaN),n.forEach((o,l)=>{let d=t.program.variableNames[l],u=t.uniformLocations[d],p=t.uniformLocations[`offset${d}`];if(u!=null){if(o.isUniform){if(k.sizeFromShape(o.shape)<2)e.gl.uniform1f(u,o.uniformValues[0]);else{let c=o.uniformValues;c instanceof Float32Array||(c=new Float32Array(c)),e.gl.uniform1fv(u,c)}return}o.texData.slice!=null&&p!=null&&e.gl.uniform1i(p,o.texData.slice.flatOffset),e.setInputMatrixTexture(o.texData.texture,u,l)}}),r!=null&&r(e,t.webGLProgram),e.executeProgram()}function BL(e,t,n){let a="";t.concat(n).forEach(i=>{let o=i.texData!=null&&i.texData.slice!=null&&i.texData.slice.flatOffset>0,l=i.isUniform?"uniform":i.texData.texShape;a+=`${i.shape}_${l}_${o}`});let r=e.userCode,s=e.constructor.name;return s+="_"+a+"_"+r,s}var{addImpl:VL,bincountImpl:cv,bincountReduceImpl:jL,ceilImpl:UL,concatImpl:HL,expImpl:GL,expm1Impl:qL,floorImpl:XL,gatherV2Impl:KL,greaterImpl:ZL,lessImpl:YL,linSpaceImpl:JL,logImpl:QL,maxImpl:eW,maximumImpl:tW,minimumImpl:nW,multiplyImpl:aW,negImpl:rW,prodImpl:sW,rangeImpl:iW,rsqrtImpl:oW,simpleAbsImpl:hv,sliceImpl:lW,sparseFillEmptyRowsImpl:uW,sparseReshapeImpl:dW,stridedSliceImpl:pW,subImpl:cW,tileImpl:hW,topKImpl:fW,transposeImpl:m1,uniqueImpl:mW}=jA;function fv(e,t){return["x","y","z","w","u","v"].slice(0,t).map(n=>`${e}.${n}`)}function cn(e,t){return t===1?[e]:fv(e,t)}function AW(e,t){if(e===1)return"rc";let n="";for(let a=0;ae[n]).join(", ")}function LL(e,t,n,a){let r=t.userCode,s=n.map((h,m)=>{let f={logicalShape:h.shape,texShape:h.isUniform?null:h.texData.texShape,isUniform:h.isUniform,isPacked:h.isUniform?!1:h.texData.isPacked,flatOffset:null};return h.texData!=null&&h.texData.slice!=null&&h.texData.slice.flatOffset>0&&(f.flatOffset=h.texData.slice.flatOffset),{name:t.variableNames[m],shapeInfo:f}}),i=s.map(h=>h.shapeInfo),o={logicalShape:a.shape,texShape:a.texData.texShape,isUniform:!1,isPacked:a.texData.isPacked,flatOffset:null},l=pL(s,o,r,t.packedInputs),d=e.createProgram(l),u=null,p=e.getUniformLocation(d,"NAN",!1);J().getNumber("WEBGL_VERSION")===1&&(u=e.getUniformLocation(d,"INFINITY",!1));let c={};for(let h=0;h{let r=n.logicalShape,s=t[a],i=s.shape;if(!k.arraysEqual(r,i))throw Error(`Binary was compiled with different shapes than the current args. Shapes ${r} and ${i} must match`);if(n.isUniform&&s.isUniform)return;let o=n.texShape,l=s.isUniform?null:s.texData.texShape;if(!k.arraysEqual(o,l))throw Error(`Binary was compiled with different texture shapes than the current args. Shape ${o} and ${l} must match`)})}function WL(e,t,n,a,r){pv(t.inShapeInfos,n),pv([t.outShapeInfo],[a]);let s=a.texData.texture,i=a.texData.texShape;a.texData.isPacked?e.setOutputPackedMatrixTexture(s,i[0],i[1]):e.setOutputMatrixTexture(s,i[0],i[1]),e.setProgram(t.webGLProgram),J().getNumber("WEBGL_VERSION")===1&&t.infLoc!==null&&e.gl.uniform1f(t.infLoc,Infinity),t.nanLoc!==null&&e.gl.uniform1f(t.nanLoc,NaN),n.forEach((o,l)=>{let d=t.program.variableNames[l],u=t.uniformLocations[d],p=t.uniformLocations[`offset${d}`];if(u!=null){if(o.isUniform){if(k.sizeFromShape(o.shape)<2)e.gl.uniform1f(u,o.uniformValues[0]);else{let c=o.uniformValues;c instanceof Float32Array||(c=new Float32Array(c)),e.gl.uniform1fv(u,c)}return}o.texData.slice!=null&&p!=null&&e.gl.uniform1i(p,o.texData.slice.flatOffset),e.setInputMatrixTexture(o.texData.texture,u,l)}}),r!=null&&r(e,t.webGLProgram),e.executeProgram()}function BL(e,t,n){let a="";t.concat(n).forEach(i=>{let o=i.texData!=null&&i.texData.slice!=null&&i.texData.slice.flatOffset>0,l=i.isUniform?"uniform":i.texData.texShape;a+=`${i.shape}_${l}_${o}`});let r=e.userCode,s=e.constructor.name;return s+="_"+a+"_"+r,s}var{addImpl:VL,bincountImpl:cv,bincountReduceImpl:jL,ceilImpl:UL,concatImpl:HL,expImpl:GL,expm1Impl:qL,floorImpl:XL,gatherV2Impl:KL,greaterImpl:ZL,lessImpl:YL,linSpaceImpl:JL,logImpl:QL,maxImpl:eW,maximumImpl:tW,minimumImpl:nW,multiplyImpl:aW,negImpl:rW,prodImpl:sW,rangeImpl:iW,rsqrtImpl:oW,simpleAbsImpl:hv,sliceImpl:lW,sparseFillEmptyRowsImpl:uW,sparseReshapeImpl:dW,stridedSliceImpl:pW,subImpl:cW,tileImpl:hW,topKImpl:fW,transposeImpl:m1,uniqueImpl:mW}=jA;function fv(e,t){return["x","y","z","w","u","v"].slice(0,t).map(n=>`${e}.${n}`)}function pn(e,t){return t===1?[e]:fv(e,t)}function AW(e,t){if(e===1)return"rc";let n="";for(let a=0;a0){this.numFreeTextures--,this.numUsedTextures++,this._numBytesFree-=s,this.log();let o=this.freeTextures[r].shift();return this.usedTextures[r].push(o),o}let i;return a===en.PACKED_2X2_FLOAT32?i=this.gpgpu.createPackedMatrixTexture(e[0],e[1]):a===en.PACKED_2X2_FLOAT16?i=this.gpgpu.createFloat16PackedMatrixTexture(e[0],e[1]):a===en.UNPACKED_FLOAT32?i=this.gpgpu.createFloat32MatrixTexture(e[0],e[1]):a===en.UNPACKED_FLOAT16?i=this.gpgpu.createFloat16MatrixTexture(e[0],e[1]):a===en.PACKED_4X1_UNSIGNED_BYTE&&(i=this.gpgpu.createUnsignedBytesMatrixTexture(e[0],e[1])),this.usedTextures[r].push(i),this.numUsedTextures++,this._numBytesAllocated+=s,this.log(),i}releaseTexture(e,t,n,a){if(this.freeTextures==null)return;let r=yv(n,a),s=gv(t,r,a);s in this.freeTextures||(this.freeTextures[s]=[]);let i=Av(t,r,this.gpgpu.gl,this.gpgpu.textureConfig,a),o=J().get("WEBGL_DELETE_TEXTURE_THRESHOLD");o!==-1&&this._numBytesAllocated>o?(this.gpgpu.deleteMatrixTexture(e),this._numBytesAllocated-=i):(this.freeTextures[s].push(e),this.numFreeTextures++,this._numBytesFree+=i),this.numUsedTextures--;let l=this.usedTextures[s],d=l.indexOf(e);if(d<0)throw new Error("Cannot release a texture that was never provided by this texture manager");l.splice(d,1),this.log()}log(){if(!this.logEnabled)return;let e=this.numFreeTextures+this.numUsedTextures;console.log("Free/Used",`${this.numFreeTextures} / ${this.numUsedTextures}`,`(${e})`);let t=this._numBytesFree/this._numBytesAllocated;console.log(`Bytes allocated: ${this._numBytesAllocated}`),console.log(`Bytes unused: ${this._numBytesFree} (${Math.round(100*t)}%)`)}get numBytesAllocated(){return this._numBytesAllocated}get numBytesFree(){return this._numBytesFree}getNumUsedTextures(){return this.numUsedTextures}getNumFreeTextures(){return this.numFreeTextures}dispose(){if(this.freeTextures!=null){for(let e in this.freeTextures)this.freeTextures[e].forEach(t=>{this.gpgpu.deleteMatrixTexture(t)});for(let e in this.usedTextures)this.usedTextures[e].forEach(t=>{this.gpgpu.deleteMatrixTexture(t)});this.freeTextures=null,this.usedTextures=null,this.numUsedTextures=0,this.numFreeTextures=0,this._numBytesAllocated=0,this._numBytesFree=0}}};function IW(e,t){let n=e;if(t===n.R32F)return 4;if(t===n.R16F)return 2;if(t===n.RGBA32F||t===e.RGBA)return 16;if(t===n.RGBA16F)return 8;throw new Error(`Unknown internal format ${t}`)}function Av(e,t,n,a,r){let s=SW(t,a),i;if(r){let[l,d]=Rl(e[0],e[1]);i=l*d}else{let[l,d]=hd(e[0],e[1]);i=l*d}let o=IW(n,s);return i*o}function SW(e,t){switch(e){case en.PACKED_2X2_FLOAT32:return h1(t);case en.PACKED_2X2_FLOAT16:return f1(t);case en.UNPACKED_FLOAT32:return d1(t);case en.UNPACKED_FLOAT16:return p1(t);case en.PACKED_4X1_UNSIGNED_BYTE:return c1(t);default:throw new Error(`Unknown physical texture type ${e}`)}}function NW(e){return J().getBool("WEBGL_RENDER_FLOAT32_ENABLED")?e?en.PACKED_2X2_FLOAT32:en.UNPACKED_FLOAT32:e?en.PACKED_2X2_FLOAT16:en.UNPACKED_FLOAT16}function yv(e,t){if(e===Jn.UPLOAD)return en.PACKED_2X2_FLOAT32;if(e===Jn.RENDER||e==null)return NW(t);if(e===Jn.DOWNLOAD||e===Jn.PIXELS)return en.PACKED_4X1_UNSIGNED_BYTE;throw new Error(`Unknown logical texture type ${e}`)}function gv(e,t,n){return`${e[0]}_${e[1]}_${t}_${n}`}var Lr=class{constructor(e,t){this.variableNames=["A"],this.outputShape=e,this.userCode=` + `}var kW=class{constructor(e){this.gpgpu=e,this.numUsedTextures=0,this.numFreeTextures=0,this._numBytesAllocated=0,this._numBytesFree=0,this.freeTextures={},this.logEnabled=!1,this.usedTextures={}}acquireTexture(e,t,n){let a=yv(t,n),r=gv(e,a,n);r in this.freeTextures||(this.freeTextures[r]=[]),r in this.usedTextures||(this.usedTextures[r]=[]);let s=Av(e,a,this.gpgpu.gl,this.gpgpu.textureConfig,n);if(this.freeTextures[r].length>0){this.numFreeTextures--,this.numUsedTextures++,this._numBytesFree-=s,this.log();let o=this.freeTextures[r].shift();return this.usedTextures[r].push(o),o}let i;return a===Qt.PACKED_2X2_FLOAT32?i=this.gpgpu.createPackedMatrixTexture(e[0],e[1]):a===Qt.PACKED_2X2_FLOAT16?i=this.gpgpu.createFloat16PackedMatrixTexture(e[0],e[1]):a===Qt.UNPACKED_FLOAT32?i=this.gpgpu.createFloat32MatrixTexture(e[0],e[1]):a===Qt.UNPACKED_FLOAT16?i=this.gpgpu.createFloat16MatrixTexture(e[0],e[1]):a===Qt.PACKED_4X1_UNSIGNED_BYTE&&(i=this.gpgpu.createUnsignedBytesMatrixTexture(e[0],e[1])),this.usedTextures[r].push(i),this.numUsedTextures++,this._numBytesAllocated+=s,this.log(),i}releaseTexture(e,t,n,a){if(this.freeTextures==null)return;let r=yv(n,a),s=gv(t,r,a);s in this.freeTextures||(this.freeTextures[s]=[]);let i=Av(t,r,this.gpgpu.gl,this.gpgpu.textureConfig,a),o=J().get("WEBGL_DELETE_TEXTURE_THRESHOLD");o!==-1&&this._numBytesAllocated>o?(this.gpgpu.deleteMatrixTexture(e),this._numBytesAllocated-=i):(this.freeTextures[s].push(e),this.numFreeTextures++,this._numBytesFree+=i),this.numUsedTextures--;let l=this.usedTextures[s],d=l.indexOf(e);if(d<0)throw new Error("Cannot release a texture that was never provided by this texture manager");l.splice(d,1),this.log()}log(){if(!this.logEnabled)return;let e=this.numFreeTextures+this.numUsedTextures;console.log("Free/Used",`${this.numFreeTextures} / ${this.numUsedTextures}`,`(${e})`);let t=this._numBytesFree/this._numBytesAllocated;console.log(`Bytes allocated: ${this._numBytesAllocated}`),console.log(`Bytes unused: ${this._numBytesFree} (${Math.round(100*t)}%)`)}get numBytesAllocated(){return this._numBytesAllocated}get numBytesFree(){return this._numBytesFree}getNumUsedTextures(){return this.numUsedTextures}getNumFreeTextures(){return this.numFreeTextures}dispose(){if(this.freeTextures!=null){for(let e in this.freeTextures)this.freeTextures[e].forEach(t=>{this.gpgpu.deleteMatrixTexture(t)});for(let e in this.usedTextures)this.usedTextures[e].forEach(t=>{this.gpgpu.deleteMatrixTexture(t)});this.freeTextures=null,this.usedTextures=null,this.numUsedTextures=0,this.numFreeTextures=0,this._numBytesAllocated=0,this._numBytesFree=0}}};function IW(e,t){let n=e;if(t===n.R32F)return 4;if(t===n.R16F)return 2;if(t===n.RGBA32F||t===e.RGBA)return 16;if(t===n.RGBA16F)return 8;throw new Error(`Unknown internal format ${t}`)}function Av(e,t,n,a,r){let s=SW(t,a),i;if(r){let[l,d]=Cl(e[0],e[1]);i=l*d}else{let[l,d]=hd(e[0],e[1]);i=l*d}let o=IW(n,s);return i*o}function SW(e,t){switch(e){case Qt.PACKED_2X2_FLOAT32:return h1(t);case Qt.PACKED_2X2_FLOAT16:return f1(t);case Qt.UNPACKED_FLOAT32:return d1(t);case Qt.UNPACKED_FLOAT16:return p1(t);case Qt.PACKED_4X1_UNSIGNED_BYTE:return c1(t);default:throw new Error(`Unknown physical texture type ${e}`)}}function NW(e){return J().getBool("WEBGL_RENDER_FLOAT32_ENABLED")?e?Qt.PACKED_2X2_FLOAT32:Qt.UNPACKED_FLOAT32:e?Qt.PACKED_2X2_FLOAT16:Qt.UNPACKED_FLOAT16}function yv(e,t){if(e===Yn.UPLOAD)return Qt.PACKED_2X2_FLOAT32;if(e===Yn.RENDER||e==null)return NW(t);if(e===Yn.DOWNLOAD||e===Yn.PIXELS)return Qt.PACKED_4X1_UNSIGNED_BYTE;throw new Error(`Unknown logical texture type ${e}`)}function gv(e,t,n){return`${e[0]}_${e[1]}_${t}_${n}`}var Pr=class{constructor(e,t){this.variableNames=["A"],this.outputShape=e,this.userCode=` float unaryOperation(float x) { ${t} } @@ -898,9 +898,9 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, setOutput(y); } - `}},xa="if (isnan(x)) return x;",TW="return x;",xv="return abs(x);",EW="return (x >= 0.0) ? x : (exp(x) - 1.0);",CW=xa+` + `}},ga="if (isnan(x)) return x;",TW="return x;",xv="return abs(x);",EW="return (x >= 0.0) ? x : (exp(x) - 1.0);",CW=ga+` return (x < 0.0) ? 0.0 : x; -`,RW=xa+` +`,RW=ga+` return (x < 0.0) ? 0.0 : min(6.0, x); `,Ah="return x;",MW="return 1.0 / (1.0 + exp(-1.0 * x));",FW="return x;",$W=` vec4 result; @@ -931,7 +931,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, result.a = isNaN.a ? x.a : result.a; return result; -`,zW="return 1.0 / (1.0 + exp(-1.0 * x));",Ol=class{constructor(e,t){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=e,this.userCode=` +`,zW="return 1.0 / (1.0 + exp(-1.0 * x));",Dl=class{constructor(e,t){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=e,this.userCode=` vec4 unaryOperation(vec4 x) { ${t} } @@ -942,17 +942,17 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, setOutput(y); } - `}},_W=class{constructor(e){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!1,this.outputShape=e;let t=e.length,n=cn("rc",t),a=lt(t),r=AW(t,n),s=n.slice(-2),i=t<=1?"rc":`vec2(${s.join(",")})`;this.userCode=` + `}},_W=class{constructor(e){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!1,this.outputShape=e;let t=e.length,n=pn("rc",t),a=lt(t),r=AW(t,n),s=n.slice(-2),i=t<=1?"rc":`vec2(${s.join(",")})`;this.userCode=` void main() { ${a} rc = getOutputCoords(); vec4 packedInput = getA(${r}); setOutput(getChannel(packedInput, ${i})); } - `}},PW=Wa.whereImpl,LW=1e-7,WW=1e-4,A1={};function BW(e){return e in A1||(A1[e]={}),A1[e]}var VW=128,jW=600;function UW(){return J().global.screen==null?1024:J().global.screen.height*J().global.screen.width*window.devicePixelRatio*jW/1024/1024}var zl=class extends hu{constructor(e){super();if(this.pendingRead=new WeakMap,this.pendingDisposal=new WeakSet,this.dataRefCount=new WeakMap,this.numBytesInGPU=0,this.uploadWaitMs=0,this.downloadWaitMs=0,this.lastGlFlushTime=0,this.warnedAboutMemory=!1,this.pendingDeletes=0,this.disposed=!1,!J().getBool("HAS_WEBGL"))throw new Error("WebGL is not supported on this device");if(e==null){let t=Va(J().getNumber("WEBGL_VERSION"));this.binaryCache=BW(J().getNumber("WEBGL_VERSION")),this.gpgpu=new mh(t),this.canvas=t.canvas,this.gpgpuCreatedLocally=!0}else this.gpgpu=e,this.binaryCache={},this.gpgpuCreatedLocally=!1,this.canvas=e.gl.canvas;this.textureManager=new kW(this.gpgpu),this.numMBBeforeWarning=UW(),this.texData=new Ip(this,nr())}nextDataId(){return zl.nextDataId++}numDataIds(){return this.texData.numDataIds()-this.pendingDeletes}write(e,t,n){if((J().getBool("WEBGL_CHECK_NUMERICAL_PROBLEMS")||J().getBool("DEBUG"))&&this.checkNumericalProblems(e),n==="complex64"&&e!=null)throw new Error("Cannot write to a complex64 dtype. Please use tf.complex(real, imag).");let a={id:this.nextDataId()};return this.texData.set(a,{shape:t,dtype:n,values:e,usage:Jn.UPLOAD,refCount:1}),a}refCount(e){return this.texData.has(e)?this.texData.get(e).refCount:0}incRef(e){let t=this.texData.get(e);t.refCount++}decRef(e){if(this.texData.has(e)){let t=this.texData.get(e);t.refCount--}}move(e,t,n,a,r){if(J().getBool("DEBUG")&&this.checkNumericalProblems(t),a==="complex64")throw new Error("Cannot write to a complex64 dtype. Please use tf.complex(real, imag).");this.texData.set(e,{shape:n,dtype:a,values:t,usage:Jn.UPLOAD,refCount:r})}disposeIntermediateTensorInfo(e){this.disposeData(e.dataId)}readSync(e){let t=this.texData.get(e),{values:n,dtype:a,complexTensorInfos:r,slice:s,shape:i,isPacked:o}=t;if(s!=null){let p;o?p=new Ol(i,Ah):p=new Lr(i,Ah);let c=this.runWebGLProgram(p,[{dataId:e,shape:i,dtype:a}],a),h=this.readSync(c.dataId);return this.disposeIntermediateTensorInfo(c),h}if(n!=null)return this.convertAndCacheOnCPU(e);if(a==="string")return n;let l=this.activeTimers!=null,d;l&&(d=k.now());let u;if(a==="complex64"){let p=this.readSync(r.real.dataId),c=this.readSync(r.imag.dataId);u=C.mergeRealAndImagArrays(p,c)}else u=this.getValuesFromTexture(e);return l&&(this.downloadWaitMs+=k.now()-d),this.convertAndCacheOnCPU(e,u)}async read(e){if(this.pendingRead.has(e)){let h=this.pendingRead.get(e);return new Promise(m=>h.push(m))}let t=this.texData.get(e),{values:n,shape:a,slice:r,dtype:s,complexTensorInfos:i,isPacked:o}=t;if(r!=null){let h;o?h=new Ol(a,Ah):h=new Lr(a,Ah);let m=this.runWebGLProgram(h,[{dataId:e,shape:a,dtype:s}],s),f=this.read(m.dataId);return this.disposeIntermediateTensorInfo(m),f}if(n!=null)return this.convertAndCacheOnCPU(e);if(!J().getBool("WEBGL_DOWNLOAD_FLOAT_ENABLED")&&J().getNumber("WEBGL_VERSION")===2)throw new Error("tensor.data() with WEBGL_DOWNLOAD_FLOAT_ENABLED=false and WEBGL_VERSION=2 not yet supported.");let l=null,d;if(s!=="complex64"&&J().get("WEBGL_BUFFER_SUPPORTED")){d=this.decode(e);let h=this.texData.get(d.dataId);l=this.gpgpu.createBufferFromTexture(h.texture,...fd(a))}this.pendingRead.set(e,[]),s!=="complex64"&&await this.gpgpu.createAndWaitForFence();let u;if(s==="complex64"){let h=await Promise.all([this.read(i.real.dataId),this.read(i.imag.dataId)]),m=h[0],f=h[1];u=C.mergeRealAndImagArrays(m,f)}else if(l==null)u=this.getValuesFromTexture(e);else{let h=k.sizeFromShape(a);u=this.gpgpu.downloadFloat32MatrixFromBuffer(l,h)}d!=null&&this.disposeIntermediateTensorInfo(d);let p=this.convertAndCacheOnCPU(e,u),c=this.pendingRead.get(e);return this.pendingRead.delete(e),c.forEach(h=>h(p)),this.pendingDisposal.has(e)&&(this.pendingDisposal.delete(e),this.disposeData(e)&&nr().removeDataId(e,this),this.pendingDeletes--),p}bufferSync(e){let t=this.readSync(e.dataId),n=t;if(e.dtype==="string")try{n=t.map(a=>k.decodeString(a))}catch(a){throw new Error("Failed to decode encoded string bytes into utf-8")}return We(e.shape,e.dtype,n)}checkNumericalProblems(e){if(e!=null)for(let t=0;t0}async time(e){let t=this.activeTimers,n=[],a=!1;this.programTimersStack==null?(this.programTimersStack=n,a=!0):this.activeTimers.push(n),this.activeTimers=n,e();let r=k.flatten(this.activeTimers.map(o=>o.query)).filter(o=>o!=null),s=k.flatten(this.activeTimers.map(o=>o.name)).filter(o=>o!=null);this.activeTimers=t,a&&(this.programTimersStack=null);let i={uploadWaitMs:this.uploadWaitMs,downloadWaitMs:this.downloadWaitMs,kernelMs:null,wallMs:null};if(J().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE")>0){let o=await Promise.all(r);i.kernelMs=k.sum(o),i.getExtraProfileInfo=()=>o.map((l,d)=>({name:s[d],ms:l})).map(l=>`${l.name}: ${l.ms}`).join(", ")}else i.kernelMs={error:"WebGL query timers are not supported in this environment."};return this.uploadWaitMs=0,this.downloadWaitMs=0,i}memory(){return{unreliable:!1,numBytesInGPU:this.numBytesInGPU,numBytesInGPUAllocated:this.textureManager.numBytesAllocated,numBytesInGPUFree:this.textureManager.numBytesFree}}startTimer(){return J().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE")>0?this.gpgpu.beginQuery():{startMs:k.now(),endMs:null}}endTimer(e){return J().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE")>0?(this.gpgpu.endQuery(),e):(e.endMs=k.now(),e)}async getQueryTime(e){if(J().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE")>0)return this.gpgpu.waitForQueryAndGetTime(e);let t=e;return t.endMs-t.startMs}disposeData(e,t=!1){if(this.pendingDisposal.has(e))return!1;if(!this.texData.has(e))return!0;if(t?this.texData.get(e).refCount=0:this.texData.get(e).refCount--,!t&&this.texData.get(e).refCount>0)return!1;if(this.pendingRead.has(e))return this.pendingDisposal.add(e),this.pendingDeletes++,!1;this.releaseGPUData(e);let{complexTensorInfos:n}=this.texData.get(e);return n!=null&&(this.disposeData(n.real.dataId,t),this.disposeData(n.imag.dataId,t)),this.texData.delete(e),!0}releaseGPUData(e){let{texture:t,dtype:n,texShape:a,usage:r,isPacked:s,slice:i}=this.texData.get(e),o=i&&i.origDataId||e,l=this.dataRefCount.get(o);l>1?this.dataRefCount.set(o,l-1):(this.dataRefCount.delete(o),t!=null&&(this.numBytesInGPU-=this.computeBytes(a,n),this.textureManager.releaseTexture(t,a,r,s)));let d=this.texData.get(e);d.texture=null,d.texShape=null,d.isPacked=!1,d.slice=null}getTexture(e){return this.uploadToGPU(e),this.texData.get(e).texture}getDataInfo(e){return this.texData.get(e)}shouldExecuteOnCPU(e,t=VW){return J().getBool("WEBGL_CPU_FORWARD")&&e.every(n=>this.texData.get(n.dataId).texture==null&&k.sizeFromShape(n.shape)0&&k.isString(n[0])){let r=n.map(s=>k.encodeString(s));a=this.write(r,e,t)}else a=this.write(n,e,t);return this.texData.get(a).usage=null,{dataId:a,shape:e,dtype:t}}makeOutput(e,t,n){let{dataId:a}=this.makeTensorInfo(e,t,n);return nr().makeTensorFromDataId(a,e,t,this)}unpackTensor(e){let t=new _W(e.shape);return this.runWebGLProgram(t,[e],e.dtype)}packTensor(e){let t=new bW(e.shape),n=!0;return this.runWebGLProgram(t,[e],e.dtype,null,n)}packedReshape(e,t){let n=[vi(e.shape),...wi(e.shape)],a={dtype:e.dtype,shape:n,dataId:e.dataId},r=[vi(t),...wi(t)],s=new mv(r,n),i=!0,o=this.runWebGLProgram(s,[a],e.dtype,null,i);return{dataId:o.dataId,shape:t,dtype:o.dtype}}decode(e){let t=this.texData.get(e),{isPacked:n,shape:a,dtype:r}=t,s=dh(a),i;n?i=new YP(s):i=new ZP(s);let o=!0,l=this.runWebGLProgram(i,[{shape:s,dtype:r,dataId:e}],r,null,o);return{dtype:r,shape:a,dataId:l.dataId}}runWebGLProgram(e,t,n,a,r=!1){let s=this.makeTensorInfo(e.outputShape,n),i=this.texData.get(s.dataId);if(e.packedOutput&&(i.isPacked=!0),e.outPackingScheme===cd.DENSE){let f=fd(e.outputShape);i.texShape=f.map(A=>A*2)}if(e.outTexUsage!=null&&(i.usage=e.outTexUsage),k.sizeFromShape(s.shape)===0)return i.values=k.getTypedArrayFromDType(s.dtype,0),s;let o=[],l=t.map(f=>{if(f.dtype==="complex64")throw new Error("GPGPUProgram does not support complex64 input. For complex64 dtypes, please separate the program into real and imaginary parts.");let A=this.texData.get(f.dataId);if(A.texture==null){if(!e.packedInputs&&k.sizeFromShape(f.shape)<=J().getNumber("WEBGL_SIZE_UPLOAD_UNIFORM"))return{shape:f.shape,texData:null,isUniform:!0,uniformValues:A.values};e.packedInputs&&(A.isPacked=!0,A.shape=f.shape)}else if(!!A.isPacked!=!!e.packedInputs)f=A.isPacked?this.unpackTensor(f):this.packTensor(f),o.push(f),A=this.texData.get(f.dataId);else if(A.isPacked&&!pd(A.shape,f.shape)){let y=f,g=f.shape;f.shape=A.shape,f=this.packedReshape(f,g),o.push(f),A=this.texData.get(f.dataId),y.shape=g}return this.uploadToGPU(f.dataId),{shape:f.shape,texData:A,isUniform:!1}});this.uploadToGPU(s.dataId);let d={shape:s.shape,texData:i,isUniform:!1},u=BL(e,l,d),p=this.getAndSaveBinary(u,()=>LL(this.gpgpu,e,l,d)),c=this.activeTimers!=null,h;c&&(h=this.startTimer()),WL(this.gpgpu,p,l,d,a),o.forEach(f=>this.disposeIntermediateTensorInfo(f)),c&&(h=this.endTimer(h),this.activeTimers.push({name:e.constructor.name,query:this.getQueryTime(h)}));let m=J().get("WEBGL_FLUSH_THRESHOLD");if(m>0){let f=k.now();f-this.lastGlFlushTime>m&&(this.gpgpu.gl.flush(),this.lastGlFlushTime=f)}if(!J().getBool("WEBGL_LAZILY_UNPACK")&&i.isPacked&&r===!1){let f=this.unpackTensor(s);return this.disposeIntermediateTensorInfo(s),f}return s}compileAndRun(e,t,n,a,r=!1){return n=n||t[0].dtype,this.runWebGLProgram(e,t,n,a,r)}getAndSaveBinary(e,t){return e in this.binaryCache||(this.binaryCache[e]=t()),this.binaryCache[e]}getTextureManager(){return this.textureManager}dispose(){this.disposed||(J().getBool("IS_TEST")||Object.keys(this.binaryCache).forEach(e=>{this.gpgpu.deleteProgram(this.binaryCache[e].webGLProgram),delete this.binaryCache[e]}),this.textureManager.dispose(),this.canvas!=null&&typeof HTMLCanvasElement!="undefined"&&this.canvas instanceof HTMLCanvasElement?this.canvas.remove():this.canvas=null,this.gpgpuCreatedLocally&&(this.gpgpu.program=null,this.gpgpu.dispose()),this.disposed=!0)}floatPrecision(){return this.floatPrecisionValue==null&&(this.floatPrecisionValue=W(()=>{if(!J().get("WEBGL_RENDER_FLOAT32_ENABLED")){let e=J().getBool("DEBUG");J().set("DEBUG",!1);let t=this.abs(Se(1e-8)).dataSync()[0];if(J().set("DEBUG",e),t>0)return 32}return 16})),this.floatPrecisionValue}epsilon(){return this.floatPrecision()===32?LW:WW}uploadToGPU(e){let t=this.texData.get(e),{shape:n,dtype:a,values:r,texture:s,usage:i,isPacked:o}=t;if(s!=null)return;let l=this.activeTimers!=null,d;l&&(d=k.now());let u=t.texShape;if(u==null&&(u=z7(n,o),t.texShape=u),r!=null){let p=dh(n),c,h=u[1],m=u[0],f=r instanceof Uint8Array;o?([h,m]=Rl(u[0],u[1]),c=new tL(p,[m,h],f)):c=new eL(p,[m,h],f);let A=this.makeTensorInfo([m,h],a);f?this.texData.get(A.dataId).usage=Jn.PIXELS:this.texData.get(A.dataId).usage=Jn.UPLOAD,this.gpgpu.uploadDenseMatrixToTexture(this.getTexture(A.dataId),h,m,r);let y=!0,g=this.runWebGLProgram(c,[A],a,null,y),x=this.texData.get(g.dataId);t.texture=x.texture,t.texShape=x.texShape,t.isPacked=x.isPacked,t.usage=x.usage,this.disposeIntermediateTensorInfo(A),this.texData.delete(g.dataId),t.values=null,l&&(this.uploadWaitMs+=k.now()-d)}else{let p=this.acquireTexture(u,i,a,o);t.texture=p}}convertAndCacheOnCPU(e,t){let n=this.texData.get(e),{dtype:a}=n;return this.releaseGPUData(e),t!=null&&(n.values=HW(t,a)),n.values}acquireTexture(e,t,n,a){if(this.numBytesInGPU+=this.computeBytes(e,n),!this.warnedAboutMemory&&this.numBytesInGPU>this.numMBBeforeWarning*1024*1024){let r=(this.numBytesInGPU/1024/1024).toFixed(2);this.warnedAboutMemory=!0,console.warn(`High memory usage in GPU: ${r} MB, most likely due to a memory leak`)}return this.textureManager.acquireTexture(e,t,a)}computeBytes(e,t){return e[0]*e[1]*k.bytesPerElement(t)}};zl.nextDataId=0;function HW(e,t){if(t==="float32"||t==="complex64")return e;if(t==="int32"||t==="bool"){let n=t==="int32"?new Int32Array(e.length):new Uint8Array(e.length);for(let a=0;anew zl,2);var GW={forceHalfFloat:vv},wv=` + `}},PW=La.whereImpl,LW=1e-7,WW=1e-4,A1={};function BW(e){return e in A1||(A1[e]={}),A1[e]}var VW=128,jW=600;function UW(){return J().global.screen==null?1024:J().global.screen.height*J().global.screen.width*window.devicePixelRatio*jW/1024/1024}var Ol=class extends hu{constructor(e){super();if(this.pendingRead=new WeakMap,this.pendingDisposal=new WeakSet,this.dataRefCount=new WeakMap,this.numBytesInGPU=0,this.uploadWaitMs=0,this.downloadWaitMs=0,this.lastGlFlushTime=0,this.warnedAboutMemory=!1,this.pendingDeletes=0,this.disposed=!1,!J().getBool("HAS_WEBGL"))throw new Error("WebGL is not supported on this device");if(e==null){let t=Ba(J().getNumber("WEBGL_VERSION"));this.binaryCache=BW(J().getNumber("WEBGL_VERSION")),this.gpgpu=new mh(t),this.canvas=t.canvas,this.gpgpuCreatedLocally=!0}else this.gpgpu=e,this.binaryCache={},this.gpgpuCreatedLocally=!1,this.canvas=e.gl.canvas;this.textureManager=new kW(this.gpgpu),this.numMBBeforeWarning=UW(),this.texData=new Ip(this,tr())}nextDataId(){return Ol.nextDataId++}numDataIds(){return this.texData.numDataIds()-this.pendingDeletes}write(e,t,n){if((J().getBool("WEBGL_CHECK_NUMERICAL_PROBLEMS")||J().getBool("DEBUG"))&&this.checkNumericalProblems(e),n==="complex64"&&e!=null)throw new Error("Cannot write to a complex64 dtype. Please use tf.complex(real, imag).");let a={id:this.nextDataId()};return this.texData.set(a,{shape:t,dtype:n,values:e,usage:Yn.UPLOAD,refCount:1}),a}refCount(e){return this.texData.has(e)?this.texData.get(e).refCount:0}incRef(e){let t=this.texData.get(e);t.refCount++}decRef(e){if(this.texData.has(e)){let t=this.texData.get(e);t.refCount--}}move(e,t,n,a,r){if(J().getBool("DEBUG")&&this.checkNumericalProblems(t),a==="complex64")throw new Error("Cannot write to a complex64 dtype. Please use tf.complex(real, imag).");this.texData.set(e,{shape:n,dtype:a,values:t,usage:Yn.UPLOAD,refCount:r})}disposeIntermediateTensorInfo(e){this.disposeData(e.dataId)}readSync(e){let t=this.texData.get(e),{values:n,dtype:a,complexTensorInfos:r,slice:s,shape:i,isPacked:o}=t;if(s!=null){let p;o?p=new Dl(i,Ah):p=new Pr(i,Ah);let c=this.runWebGLProgram(p,[{dataId:e,shape:i,dtype:a}],a),h=this.readSync(c.dataId);return this.disposeIntermediateTensorInfo(c),h}if(n!=null)return this.convertAndCacheOnCPU(e);if(a==="string")return n;let l=this.activeTimers!=null,d;l&&(d=k.now());let u;if(a==="complex64"){let p=this.readSync(r.real.dataId),c=this.readSync(r.imag.dataId);u=C.mergeRealAndImagArrays(p,c)}else u=this.getValuesFromTexture(e);return l&&(this.downloadWaitMs+=k.now()-d),this.convertAndCacheOnCPU(e,u)}async read(e){if(this.pendingRead.has(e)){let h=this.pendingRead.get(e);return new Promise(m=>h.push(m))}let t=this.texData.get(e),{values:n,shape:a,slice:r,dtype:s,complexTensorInfos:i,isPacked:o}=t;if(r!=null){let h;o?h=new Dl(a,Ah):h=new Pr(a,Ah);let m=this.runWebGLProgram(h,[{dataId:e,shape:a,dtype:s}],s),f=this.read(m.dataId);return this.disposeIntermediateTensorInfo(m),f}if(n!=null)return this.convertAndCacheOnCPU(e);if(!J().getBool("WEBGL_DOWNLOAD_FLOAT_ENABLED")&&J().getNumber("WEBGL_VERSION")===2)throw new Error("tensor.data() with WEBGL_DOWNLOAD_FLOAT_ENABLED=false and WEBGL_VERSION=2 not yet supported.");let l=null,d;if(s!=="complex64"&&J().get("WEBGL_BUFFER_SUPPORTED")){d=this.decode(e);let h=this.texData.get(d.dataId);l=this.gpgpu.createBufferFromTexture(h.texture,...fd(a))}this.pendingRead.set(e,[]),s!=="complex64"&&await this.gpgpu.createAndWaitForFence();let u;if(s==="complex64"){let h=await Promise.all([this.read(i.real.dataId),this.read(i.imag.dataId)]),m=h[0],f=h[1];u=C.mergeRealAndImagArrays(m,f)}else if(l==null)u=this.getValuesFromTexture(e);else{let h=k.sizeFromShape(a);u=this.gpgpu.downloadFloat32MatrixFromBuffer(l,h)}d!=null&&this.disposeIntermediateTensorInfo(d);let p=this.convertAndCacheOnCPU(e,u),c=this.pendingRead.get(e);return this.pendingRead.delete(e),c.forEach(h=>h(p)),this.pendingDisposal.has(e)&&(this.pendingDisposal.delete(e),this.disposeData(e)&&tr().removeDataId(e,this),this.pendingDeletes--),p}bufferSync(e){let t=this.readSync(e.dataId),n=t;if(e.dtype==="string")try{n=t.map(a=>k.decodeString(a))}catch(a){throw new Error("Failed to decode encoded string bytes into utf-8")}return We(e.shape,e.dtype,n)}checkNumericalProblems(e){if(e!=null)for(let t=0;t0}async time(e){let t=this.activeTimers,n=[],a=!1;this.programTimersStack==null?(this.programTimersStack=n,a=!0):this.activeTimers.push(n),this.activeTimers=n,e();let r=k.flatten(this.activeTimers.map(o=>o.query)).filter(o=>o!=null),s=k.flatten(this.activeTimers.map(o=>o.name)).filter(o=>o!=null);this.activeTimers=t,a&&(this.programTimersStack=null);let i={uploadWaitMs:this.uploadWaitMs,downloadWaitMs:this.downloadWaitMs,kernelMs:null,wallMs:null};if(J().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE")>0){let o=await Promise.all(r);i.kernelMs=k.sum(o),i.getExtraProfileInfo=()=>o.map((l,d)=>({name:s[d],ms:l})).map(l=>`${l.name}: ${l.ms}`).join(", ")}else i.kernelMs={error:"WebGL query timers are not supported in this environment."};return this.uploadWaitMs=0,this.downloadWaitMs=0,i}memory(){return{unreliable:!1,numBytesInGPU:this.numBytesInGPU,numBytesInGPUAllocated:this.textureManager.numBytesAllocated,numBytesInGPUFree:this.textureManager.numBytesFree}}startTimer(){return J().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE")>0?this.gpgpu.beginQuery():{startMs:k.now(),endMs:null}}endTimer(e){return J().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE")>0?(this.gpgpu.endQuery(),e):(e.endMs=k.now(),e)}async getQueryTime(e){if(J().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE")>0)return this.gpgpu.waitForQueryAndGetTime(e);let t=e;return t.endMs-t.startMs}disposeData(e,t=!1){if(this.pendingDisposal.has(e))return!1;if(!this.texData.has(e))return!0;if(t?this.texData.get(e).refCount=0:this.texData.get(e).refCount--,!t&&this.texData.get(e).refCount>0)return!1;if(this.pendingRead.has(e))return this.pendingDisposal.add(e),this.pendingDeletes++,!1;this.releaseGPUData(e);let{complexTensorInfos:n}=this.texData.get(e);return n!=null&&(this.disposeData(n.real.dataId,t),this.disposeData(n.imag.dataId,t)),this.texData.delete(e),!0}releaseGPUData(e){let{texture:t,dtype:n,texShape:a,usage:r,isPacked:s,slice:i}=this.texData.get(e),o=i&&i.origDataId||e,l=this.dataRefCount.get(o);l>1?this.dataRefCount.set(o,l-1):(this.dataRefCount.delete(o),t!=null&&(this.numBytesInGPU-=this.computeBytes(a,n),this.textureManager.releaseTexture(t,a,r,s)));let d=this.texData.get(e);d.texture=null,d.texShape=null,d.isPacked=!1,d.slice=null}getTexture(e){return this.uploadToGPU(e),this.texData.get(e).texture}getDataInfo(e){return this.texData.get(e)}shouldExecuteOnCPU(e,t=VW){return J().getBool("WEBGL_CPU_FORWARD")&&e.every(n=>this.texData.get(n.dataId).texture==null&&k.sizeFromShape(n.shape)0&&k.isString(n[0])){let r=n.map(s=>k.encodeString(s));a=this.write(r,e,t)}else a=this.write(n,e,t);return this.texData.get(a).usage=null,{dataId:a,shape:e,dtype:t}}makeOutput(e,t,n){let{dataId:a}=this.makeTensorInfo(e,t,n);return tr().makeTensorFromDataId(a,e,t,this)}unpackTensor(e){let t=new _W(e.shape);return this.runWebGLProgram(t,[e],e.dtype)}packTensor(e){let t=new bW(e.shape),n=!0;return this.runWebGLProgram(t,[e],e.dtype,null,n)}packedReshape(e,t){let n=[bi(e.shape),...vi(e.shape)],a={dtype:e.dtype,shape:n,dataId:e.dataId},r=[bi(t),...vi(t)],s=new mv(r,n),i=!0,o=this.runWebGLProgram(s,[a],e.dtype,null,i);return{dataId:o.dataId,shape:t,dtype:o.dtype}}decode(e){let t=this.texData.get(e),{isPacked:n,shape:a,dtype:r}=t,s=dh(a),i;n?i=new YP(s):i=new ZP(s);let o=!0,l=this.runWebGLProgram(i,[{shape:s,dtype:r,dataId:e}],r,null,o);return{dtype:r,shape:a,dataId:l.dataId}}runWebGLProgram(e,t,n,a,r=!1){let s=this.makeTensorInfo(e.outputShape,n),i=this.texData.get(s.dataId);if(e.packedOutput&&(i.isPacked=!0),e.outPackingScheme===cd.DENSE){let f=fd(e.outputShape);i.texShape=f.map(A=>A*2)}if(e.outTexUsage!=null&&(i.usage=e.outTexUsage),k.sizeFromShape(s.shape)===0)return i.values=k.getTypedArrayFromDType(s.dtype,0),s;let o=[],l=t.map(f=>{if(f.dtype==="complex64")throw new Error("GPGPUProgram does not support complex64 input. For complex64 dtypes, please separate the program into real and imaginary parts.");let A=this.texData.get(f.dataId);if(A.texture==null){if(!e.packedInputs&&k.sizeFromShape(f.shape)<=J().getNumber("WEBGL_SIZE_UPLOAD_UNIFORM"))return{shape:f.shape,texData:null,isUniform:!0,uniformValues:A.values};e.packedInputs&&(A.isPacked=!0,A.shape=f.shape)}else if(!!A.isPacked!=!!e.packedInputs)f=A.isPacked?this.unpackTensor(f):this.packTensor(f),o.push(f),A=this.texData.get(f.dataId);else if(A.isPacked&&!pd(A.shape,f.shape)){let y=f,g=f.shape;f.shape=A.shape,f=this.packedReshape(f,g),o.push(f),A=this.texData.get(f.dataId),y.shape=g}return this.uploadToGPU(f.dataId),{shape:f.shape,texData:A,isUniform:!1}});this.uploadToGPU(s.dataId);let d={shape:s.shape,texData:i,isUniform:!1},u=BL(e,l,d),p=this.getAndSaveBinary(u,()=>LL(this.gpgpu,e,l,d)),c=this.activeTimers!=null,h;c&&(h=this.startTimer()),WL(this.gpgpu,p,l,d,a),o.forEach(f=>this.disposeIntermediateTensorInfo(f)),c&&(h=this.endTimer(h),this.activeTimers.push({name:e.constructor.name,query:this.getQueryTime(h)}));let m=J().get("WEBGL_FLUSH_THRESHOLD");if(m>0){let f=k.now();f-this.lastGlFlushTime>m&&(this.gpgpu.gl.flush(),this.lastGlFlushTime=f)}if(!J().getBool("WEBGL_LAZILY_UNPACK")&&i.isPacked&&r===!1){let f=this.unpackTensor(s);return this.disposeIntermediateTensorInfo(s),f}return s}compileAndRun(e,t,n,a,r=!1){return n=n||t[0].dtype,this.runWebGLProgram(e,t,n,a,r)}getAndSaveBinary(e,t){return e in this.binaryCache||(this.binaryCache[e]=t()),this.binaryCache[e]}getTextureManager(){return this.textureManager}dispose(){this.disposed||(J().getBool("IS_TEST")||Object.keys(this.binaryCache).forEach(e=>{this.gpgpu.deleteProgram(this.binaryCache[e].webGLProgram),delete this.binaryCache[e]}),this.textureManager.dispose(),this.canvas!=null&&typeof HTMLCanvasElement!="undefined"&&this.canvas instanceof HTMLCanvasElement?this.canvas.remove():this.canvas=null,this.gpgpuCreatedLocally&&(this.gpgpu.program=null,this.gpgpu.dispose()),this.disposed=!0)}floatPrecision(){return this.floatPrecisionValue==null&&(this.floatPrecisionValue=W(()=>{if(!J().get("WEBGL_RENDER_FLOAT32_ENABLED")){let e=J().getBool("DEBUG");J().set("DEBUG",!1);let t=this.abs(Se(1e-8)).dataSync()[0];if(J().set("DEBUG",e),t>0)return 32}return 16})),this.floatPrecisionValue}epsilon(){return this.floatPrecision()===32?LW:WW}uploadToGPU(e){let t=this.texData.get(e),{shape:n,dtype:a,values:r,texture:s,usage:i,isPacked:o}=t;if(s!=null)return;let l=this.activeTimers!=null,d;l&&(d=k.now());let u=t.texShape;if(u==null&&(u=z7(n,o),t.texShape=u),r!=null){let p=dh(n),c,h=u[1],m=u[0],f=r instanceof Uint8Array;o?([h,m]=Cl(u[0],u[1]),c=new tL(p,[m,h],f)):c=new eL(p,[m,h],f);let A=this.makeTensorInfo([m,h],a);f?this.texData.get(A.dataId).usage=Yn.PIXELS:this.texData.get(A.dataId).usage=Yn.UPLOAD,this.gpgpu.uploadDenseMatrixToTexture(this.getTexture(A.dataId),h,m,r);let y=!0,g=this.runWebGLProgram(c,[A],a,null,y),x=this.texData.get(g.dataId);t.texture=x.texture,t.texShape=x.texShape,t.isPacked=x.isPacked,t.usage=x.usage,this.disposeIntermediateTensorInfo(A),this.texData.delete(g.dataId),t.values=null,l&&(this.uploadWaitMs+=k.now()-d)}else{let p=this.acquireTexture(u,i,a,o);t.texture=p}}convertAndCacheOnCPU(e,t){let n=this.texData.get(e),{dtype:a}=n;return this.releaseGPUData(e),t!=null&&(n.values=HW(t,a)),n.values}acquireTexture(e,t,n,a){if(this.numBytesInGPU+=this.computeBytes(e,n),!this.warnedAboutMemory&&this.numBytesInGPU>this.numMBBeforeWarning*1024*1024){let r=(this.numBytesInGPU/1024/1024).toFixed(2);this.warnedAboutMemory=!0,console.warn(`High memory usage in GPU: ${r} MB, most likely due to a memory leak`)}return this.textureManager.acquireTexture(e,t,a)}computeBytes(e,t){return e[0]*e[1]*k.bytesPerElement(t)}};Ol.nextDataId=0;function HW(e,t){if(t==="float32"||t==="complex64")return e;if(t==="int32"||t==="bool"){let n=t==="int32"?new Int32Array(e.length):new Uint8Array(e.length);for(let a=0;anew Ol,2);var GW={forceHalfFloat:vv},wv=` if (isnan(a)) return a; if (isnan(b)) return b; -`,_l=class{constructor(e,t,n){this.variableNames=["A","B"],this.outputShape=C.assertAndGetBroadcastShape(t,n),this.userCode=` +`,zl=class{constructor(e,t,n){this.variableNames=["A","B"],this.outputShape=C.assertAndGetBroadcastShape(t,n),this.userCode=` float binaryOperation(float a, float b) { ${e} } @@ -977,7 +977,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, result.y = (coords + 1) >= ${this.outputShape[0]} ? 0. : result.y; result.z = 0.; result.w = 0.; - `;else{let i=cn("coords",r);s+=` + `;else{let i=pn("coords",r);s+=` bool nextRowOutOfBounds = (${i[r-2]} + 1) >= ${this.outputShape[r-2]}; bool nextColOutOfBounds = @@ -999,13 +999,13 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, setOutput(result); } - `}};function Ln(e){let{inputs:t,backend:n}=e,{x:a}=t;return n.incRef(a.dataId),{dataId:a.dataId,shape:a.shape,dtype:a.dtype}}var qW={kernelName:Is,backendName:"webgl",kernelFunc:Ln};function Wr(e){let{inputs:t,backend:n}=e,{real:a,imag:r}=t,s=n.makeTensorInfo(a.shape,"complex64"),i=n.texData.get(s.dataId),o=Ln({inputs:{x:a},backend:n}),l=Ln({inputs:{x:r},backend:n});return i.complexTensorInfos={real:o,imag:l},s}var XW={kernelName:Mp,backendName:"webgl",kernelFunc:Wr},kv="return (a < 0.) ? b * a : a;",Iv=` + `}};function Pn(e){let{inputs:t,backend:n}=e,{x:a}=t;return n.incRef(a.dataId),{dataId:a.dataId,shape:a.shape,dtype:a.dtype}}var qW={kernelName:ks,backendName:"webgl",kernelFunc:Pn};function Lr(e){let{inputs:t,backend:n}=e,{real:a,imag:r}=t,s=n.makeTensorInfo(a.shape,"complex64"),i=n.texData.get(s.dataId),o=Pn({inputs:{x:a},backend:n}),l=Pn({inputs:{x:r},backend:n});return i.complexTensorInfos={real:o,imag:l},s}var XW={kernelName:Mp,backendName:"webgl",kernelFunc:Lr},kv="return (a < 0.) ? b * a : a;",Iv=` vec4 aLessThanZero = vec4(lessThan(a, vec4(0.))); return (aLessThanZero * (b * a)) + ((vec4(1.0) - aLessThanZero) * a); -`;function KW(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{alpha:s}=a,i=n.makeTensorInfo([],"float32",k.createScalarValue(s,"float32")),o=J().getBool("WEBGL_PACK_BINARY_OPERATIONS")?new Ad(Iv,r.shape,i.shape):new _l(kv,r.shape,i.shape),l=n.runWebGLProgram(o,[r,i],r.dtype);return n.disposeIntermediateTensorInfo(i),l}var ZW={kernelName:Ss,backendName:"webgl",kernelFunc:KW},Sv="return (a < 0.) ? b * a : a;",Nv=` +`;function KW(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{alpha:s}=a,i=n.makeTensorInfo([],"float32",k.createScalarValue(s,"float32")),o=J().getBool("WEBGL_PACK_BINARY_OPERATIONS")?new Ad(Iv,r.shape,i.shape):new zl(kv,r.shape,i.shape),l=n.runWebGLProgram(o,[r,i],r.dtype);return n.disposeIntermediateTensorInfo(i),l}var ZW={kernelName:Is,backendName:"webgl",kernelFunc:KW},Sv="return (a < 0.) ? b * a : a;",Nv=` vec4 aLessThanZero = vec4(lessThan(a, vec4(0.))); return (aLessThanZero * (b * a)) + ((vec4(1.0) - aLessThanZero) * a); -`;function YW(e){let{inputs:t,backend:n}=e,{x:a,alpha:r}=t,s=J().getBool("WEBGL_PACK_BINARY_OPERATIONS")?new Ad(Nv,a.shape,r.shape):new _l(Sv,a.shape,r.shape);return n.runWebGLProgram(s,[a,r],a.dtype)}var JW={kernelName:Ps,backendName:"webgl",kernelFunc:YW},Tv="if (isnan(x)) return x;",QW=` +`;function YW(e){let{inputs:t,backend:n}=e,{x:a,alpha:r}=t,s=J().getBool("WEBGL_PACK_BINARY_OPERATIONS")?new Ad(Nv,a.shape,r.shape):new zl(Sv,a.shape,r.shape);return n.runWebGLProgram(s,[a,r],a.dtype)}var JW={kernelName:_s,backendName:"webgl",kernelFunc:YW},Tv="if (isnan(x)) return x;",QW=` if (isnan(a)) return a; if (isnan(b)) return b; `,eB=` @@ -1013,7 +1013,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, result.g = isNaN.g > 0. ? NAN : result.g; result.b = isNaN.b > 0. ? NAN : result.b; result.a = isNaN.a > 0. ? NAN : result.a; -`;function qe({opSnippet:e,packedOpSnippet:t,cpuKernelImpl:n,dtype:a}){return({inputs:r,backend:s})=>{let{x:i}=r,o=s,l=a||i.dtype;if(o.shouldExecuteOnCPU([i])&&n!=null){let p=o.texData.get(i.dataId),c=n(p.values,l);return o.makeTensorInfo(i.shape,l,c)}let d=J().getBool("WEBGL_PACK_UNARY_OPERATIONS")&&t!=null,u;return d?u=new Ol(i.shape,t):u=new Lr(i.shape,e),o.runWebGLProgram(u,[i],l)}}function tn({opSnippet:e,packedOpSnippet:t,checkOutOfBounds:n=!1,supportsComplex:a=!1,cpuKernelImpl:r,dtype:s}){return({inputs:i,backend:o})=>{let{a:l,b:d}=i,u=o;if(a&&l.dtype==="complex64"){let m=u.texData.get(l.dataId),f=u.texData.get(d.dataId),[A,y]=[[m.complexTensorInfos.real,f.complexTensorInfos.real],[m.complexTensorInfos.imag,f.complexTensorInfos.imag]].map(x=>{let[w,b]=x,v={dataId:w.dataId,dtype:w.dtype,shape:l.shape},N={dataId:b.dataId,dtype:b.dtype,shape:d.shape},T=new _l(e,l.shape,d.shape);return u.runWebGLProgram(T,[v,N],ia(w.dtype,b.dtype))}),g=Wr({inputs:{real:A,imag:y},backend:u});return u.disposeIntermediateTensorInfo(A),u.disposeIntermediateTensorInfo(y),g}let p=s||ia(l.dtype,d.dtype);if(u.shouldExecuteOnCPU([l,d])&&r!=null){let m=u.texData.get(l.dataId),f=u.texData.get(d.dataId),[A,y]=r(l.shape,d.shape,m.values,f.values,p),g=u.makeTensorInfo(y,p),x=u.texData.get(g.dataId);return x.values=A,g}let c=J().getBool("WEBGL_PACK_BINARY_OPERATIONS")&&t!=null,h;return c?h=new Ad(t,l.shape,d.shape,n):h=new _l(e,l.shape,d.shape),u.runWebGLProgram(h,[l,d],p)}}function gh(e,t=!1){if(e==="linear")return t?FW:TW;if(e==="relu")return t?DW:CW;if(e==="elu")return t?$W:EW;if(e==="relu6")return t?OW:RW;if(e==="prelu")return t?Nv:Sv;if(e==="leakyrelu")return t?Iv:kv;if(e==="sigmoid")return t?zW:MW;throw new Error(`Activation ${e} has not been implemented for the WebGL backend.`)}var Ev=class{constructor(e,t,n,a=!1,r=!1,s=!1,i=null,o=!1,l=!1){this.variableNames=["matrixA","matrixB"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=n;let d=a?e[1]:e[2],u=Math.ceil(d/2),p=a?"i * 2, rc.y":"rc.y, i * 2",c=r?"rc.z, i * 2":"i * 2, rc.z",h=a?["a.xxyy","a.zzww"]:["a.xxzz","a.yyww"],m=r?["b.xzxz","b.ywyw"]:["b.xyxy","b.zwzw"],f="",A="";i&&(o?f=`vec4 activation(vec4 a) { +`;function qe({opSnippet:e,packedOpSnippet:t,cpuKernelImpl:n,dtype:a}){return({inputs:r,backend:s})=>{let{x:i}=r,o=s,l=a||i.dtype;if(o.shouldExecuteOnCPU([i])&&n!=null){let p=o.texData.get(i.dataId),c=n(p.values,l);return o.makeTensorInfo(i.shape,l,c)}let d=J().getBool("WEBGL_PACK_UNARY_OPERATIONS")&&t!=null,u;return d?u=new Dl(i.shape,t):u=new Pr(i.shape,e),o.runWebGLProgram(u,[i],l)}}function en({opSnippet:e,packedOpSnippet:t,checkOutOfBounds:n=!1,supportsComplex:a=!1,cpuKernelImpl:r,dtype:s}){return({inputs:i,backend:o})=>{let{a:l,b:d}=i,u=o;if(a&&l.dtype==="complex64"){let m=u.texData.get(l.dataId),f=u.texData.get(d.dataId),[A,y]=[[m.complexTensorInfos.real,f.complexTensorInfos.real],[m.complexTensorInfos.imag,f.complexTensorInfos.imag]].map(x=>{let[w,b]=x,v={dataId:w.dataId,dtype:w.dtype,shape:l.shape},N={dataId:b.dataId,dtype:b.dtype,shape:d.shape},T=new zl(e,l.shape,d.shape);return u.runWebGLProgram(T,[v,N],sa(w.dtype,b.dtype))}),g=Lr({inputs:{real:A,imag:y},backend:u});return u.disposeIntermediateTensorInfo(A),u.disposeIntermediateTensorInfo(y),g}let p=s||sa(l.dtype,d.dtype);if(u.shouldExecuteOnCPU([l,d])&&r!=null){let m=u.texData.get(l.dataId),f=u.texData.get(d.dataId),[A,y]=r(l.shape,d.shape,m.values,f.values,p),g=u.makeTensorInfo(y,p),x=u.texData.get(g.dataId);return x.values=A,g}let c=J().getBool("WEBGL_PACK_BINARY_OPERATIONS")&&t!=null,h;return c?h=new Ad(t,l.shape,d.shape,n):h=new zl(e,l.shape,d.shape),u.runWebGLProgram(h,[l,d],p)}}function gh(e,t=!1){if(e==="linear")return t?FW:TW;if(e==="relu")return t?DW:CW;if(e==="elu")return t?$W:EW;if(e==="relu6")return t?OW:RW;if(e==="prelu")return t?Nv:Sv;if(e==="leakyrelu")return t?Iv:kv;if(e==="sigmoid")return t?zW:MW;throw new Error(`Activation ${e} has not been implemented for the WebGL backend.`)}var Ev=class{constructor(e,t,n,a=!1,r=!1,s=!1,i=null,o=!1,l=!1){this.variableNames=["matrixA","matrixB"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=n;let d=a?e[1]:e[2],u=Math.ceil(d/2),p=a?"i * 2, rc.y":"rc.y, i * 2",c=r?"rc.z, i * 2":"i * 2, rc.z",h=a?["a.xxyy","a.zzww"]:["a.xxzz","a.yyww"],m=r?["b.xzxz","b.ywyw"]:["b.xyxy","b.zwzw"],f="",A="";i&&(o?f=`vec4 activation(vec4 a) { vec4 b = getPreluActivationWeightsAtOutCoords(); ${i} }`:l?f=`vec4 activation(vec4 a) { @@ -1065,7 +1065,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, float bimag = getBImagAtOutCoords(); setOutput(binaryOpComplex(areal, aimag, breal, bimag)); } - `}},Mv="return a * b;";function y1(e){let{inputs:t,backend:n}=e,{a,b:r}=t,s=C.upcastType(a.dtype,r.dtype);if(a.dtype==="complex64"){let o=n.texData.get(a.dataId),l=n.texData.get(r.dataId),d=new Rv(Cv.REAL,a.shape,r.shape),u=new Rv(Cv.IMAG,a.shape,r.shape),p=[{dataId:o.complexTensorInfos.real.dataId,dtype:o.complexTensorInfos.real.dtype,shape:a.shape},{dataId:o.complexTensorInfos.imag.dataId,dtype:o.complexTensorInfos.imag.dtype,shape:a.shape},{dataId:l.complexTensorInfos.real.dataId,dtype:l.complexTensorInfos.real.dtype,shape:r.shape},{dataId:l.complexTensorInfos.imag.dataId,dtype:l.complexTensorInfos.imag.dtype,shape:r.shape}],c=n.runWebGLProgram(d,p,"float32"),h=n.runWebGLProgram(u,p,"float32"),m=Wr({inputs:{real:c,imag:h},backend:n});return n.disposeIntermediateTensorInfo(c),n.disposeIntermediateTensorInfo(h),m}if(n.shouldExecuteOnCPU([a,r])){let o=n.texData.get(a.dataId),l=n.texData.get(r.dataId),[d,u]=aW(a.shape,r.shape,o.values,l.values,s),p=n.makeTensorInfo(u,s),c=n.texData.get(p.dataId);return c.values=d,p}let i;return J().getBool("WEBGL_PACK_BINARY_OPERATIONS")?i=new Ad(Mv,a.shape,r.shape):i=new _l(Mv,a.shape,r.shape),n.runWebGLProgram(i,[a,r],s)}var tB={kernelName:Ds,backendName:"webgl",kernelFunc:y1};function nB(e,t,n){let a=[vi(e.shape),...wi(e.shape)],r={dtype:e.dtype,shape:a,dataId:e.dataId},s=[vi(t),...wi(t)],i=new mv(s,a),o=!0,l=n.runWebGLProgram(i,[r],e.dtype,null,o);return{dataId:l.dataId,shape:t,dtype:l.dtype}}function Ae(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{shape:s}=a,i=n,o=k.sizeFromShape(r.shape),l=k.inferFromImplicitShape(s,o),d=k.sizeFromShape(l);k.assert(o===d,()=>`The new shape (${l}) has ${d} elements and the old shape (${r.shape}) has ${o} elements. The new shape and old shape must have the same number of elements.`);let u=i.texData.get(r.dataId);return u.isPacked&&!pd(r.shape,l)&&!(u.texture!==null&&pd(u.shape,l))?nB(r,l,i):(i.incRef(r.dataId),{dataId:r.dataId,shape:l,dtype:r.dtype})}var aB={kernelName:Bo,backendName:"webgl",kernelFunc:Ae},Fv=class{constructor(e,t){this.variableNames=["x"];let{windowSize:n,batchSize:a,inSize:r,outSize:s}=e;this.outputShape=[a,s];let i=Math.floor(n/4)*4,o=n%4,l="sumValue += dot(values, ones);";if(t!=null){let u=1/t;l=`sumValue += dot(values * ${k.isInt(u)?u.toPrecision(2):u}, ones);`}let d="";r%n>0&&(d=` + `}},Mv="return a * b;";function y1(e){let{inputs:t,backend:n}=e,{a,b:r}=t,s=C.upcastType(a.dtype,r.dtype);if(a.dtype==="complex64"){let o=n.texData.get(a.dataId),l=n.texData.get(r.dataId),d=new Rv(Cv.REAL,a.shape,r.shape),u=new Rv(Cv.IMAG,a.shape,r.shape),p=[{dataId:o.complexTensorInfos.real.dataId,dtype:o.complexTensorInfos.real.dtype,shape:a.shape},{dataId:o.complexTensorInfos.imag.dataId,dtype:o.complexTensorInfos.imag.dtype,shape:a.shape},{dataId:l.complexTensorInfos.real.dataId,dtype:l.complexTensorInfos.real.dtype,shape:r.shape},{dataId:l.complexTensorInfos.imag.dataId,dtype:l.complexTensorInfos.imag.dtype,shape:r.shape}],c=n.runWebGLProgram(d,p,"float32"),h=n.runWebGLProgram(u,p,"float32"),m=Lr({inputs:{real:c,imag:h},backend:n});return n.disposeIntermediateTensorInfo(c),n.disposeIntermediateTensorInfo(h),m}if(n.shouldExecuteOnCPU([a,r])){let o=n.texData.get(a.dataId),l=n.texData.get(r.dataId),[d,u]=aW(a.shape,r.shape,o.values,l.values,s),p=n.makeTensorInfo(u,s),c=n.texData.get(p.dataId);return c.values=d,p}let i;return J().getBool("WEBGL_PACK_BINARY_OPERATIONS")?i=new Ad(Mv,a.shape,r.shape):i=new zl(Mv,a.shape,r.shape),n.runWebGLProgram(i,[a,r],s)}var tB={kernelName:$s,backendName:"webgl",kernelFunc:y1};function nB(e,t,n){let a=[bi(e.shape),...vi(e.shape)],r={dtype:e.dtype,shape:a,dataId:e.dataId},s=[bi(t),...vi(t)],i=new mv(s,a),o=!0,l=n.runWebGLProgram(i,[r],e.dtype,null,o);return{dataId:l.dataId,shape:t,dtype:l.dtype}}function Ae(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{shape:s}=a,i=n,o=k.sizeFromShape(r.shape),l=k.inferFromImplicitShape(s,o),d=k.sizeFromShape(l);k.assert(o===d,()=>`The new shape (${l}) has ${d} elements and the old shape (${r.shape}) has ${o} elements. The new shape and old shape must have the same number of elements.`);let u=i.texData.get(r.dataId);return u.isPacked&&!pd(r.shape,l)&&!(u.texture!==null&&pd(u.shape,l))?nB(r,l,i):(i.incRef(r.dataId),{dataId:r.dataId,shape:l,dtype:r.dtype})}var aB={kernelName:Wo,backendName:"webgl",kernelFunc:Ae},Fv=class{constructor(e,t){this.variableNames=["x"];let{windowSize:n,batchSize:a,inSize:r,outSize:s}=e;this.outputShape=[a,s];let i=Math.floor(n/4)*4,o=n%4,l="sumValue += dot(values, ones);";if(t!=null){let u=1/t;l=`sumValue += dot(values * ${k.isInt(u)?u.toPrecision(2):u}, ones);`}let d="";r%n>0&&(d=` if (inIdx < 0 || inIdx >= ${r}) { return 0.0; } @@ -1203,7 +1203,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, } setOutput(${l}); } - `}};function sB(e){let t=[];for(;t.length===0||t[t.length-1].outSize!==1;){let n=t.length?t[t.length-1].outSize:e[1],a=C.computeOptimalWindowSize(n);t.push({inSize:n,windowSize:a,outSize:Math.ceil(n/a)})}return t}function Ni(e,t,n,a){let r=sB(e.shape),s=e;for(let i=0;i=2&&u>=2&&x,()=>`Error in matMul: the input batch dimensions must either be the same or at least one input batch dimension must be 1. Got input batch dimensions of (${f}) and (${A}).`);let w=(y>g?e.shape.slice(0,-2):t.shape.slice(0,-2)).concat([h,m]);k.assert(p===c,()=>`Error in matMul: inner shapes (${p}) and (${c}) of Tensors with shapes ${e.shape} and ${t.shape} and transposeA=${n} and transposeB=${a} must match.`);let b=n?[y,p,h]:[y,h,p],v=a?[g,m,c]:[g,c,m],N=Ae({inputs:{x:e},backend:r,attrs:{shape:b}}),T=Ae({inputs:{x:t},backend:r,attrs:{shape:v}}),R=[N,T],$=Math.max(y,g),z=n?N.shape[1]:N.shape[2],P=s!=null,V=i!=null,j=l==="leakyrelu",U=l!=null?gh(l,!0):null,X=P||V||j||U!=null,G;if((h===1||m===1)&&z>$v&&X===!1){let Y=N,re=T;n&&(Y=hn({inputs:{x:N},backend:r,attrs:{perm:[0,2,1]}}),R.push(Y)),a&&(re=hn({inputs:{x:T},backend:r,attrs:{perm:[0,2,1]}}),R.push(re));let ne=m!==1,ie=m===1,Q=Y;ne&&(Q=Ae({inputs:{x:Y},backend:r,attrs:{shape:[$,z,1]}}),R.push(Q));let de=m===1?2:1,oe=re;ie&&(oe=Ae({inputs:{x:re},backend:r,attrs:{shape:[$,1,z]}}),R.push(oe));let ye=y1({inputs:{a:Q,b:oe},backend:r});G=bh({inputs:{x:ye},backend:r,attrs:{axis:de,keepDims:!0}}),R.push(ye)}else{let Y=ia(e.dtype,t.dtype),re=new Ev(b,v,[$,h,m],n,a,P,U,V,j),ne=[N,T];if(s!=null&&ne.push(s),V&&ne.push(i),j){let ie=r.makeTensorInfo([],"float32",k.createScalarValue(o,"float32"));ne.push(ie),R.push(ie)}G=r.runWebGLProgram(re,ne,Y)}let ee=Ae({inputs:{x:G},backend:r,attrs:{shape:w}});R.push(G);for(let Y of R)r.disposeIntermediateTensorInfo(Y);return ee}function cB(e){let{inputs:t,backend:n,attrs:a}=e,{a:r,b:s,bias:i,preluActivationWeights:o}=t,{transposeA:l,transposeB:d,activation:u,leakyreluAlpha:p}=a;return vh({a:r,b:s,transposeA:l,transposeB:d,backend:n,bias:i,preluActivationWeights:o,leakyreluAlpha:p,activation:u})}var hB={kernelName:ti,backendName:"webgl",kernelFunc:cB},Dv="return abs(x);";function fB(e){let{inputs:t,backend:n}=e,{x:a}=t;if(n.shouldExecuteOnCPU([a])&&a.dtype!=="complex64"){let s=n.texData.get(a.dataId),i=hv(s.values);return n.makeTensorInfo(a.shape,a.dtype,i)}let r;return J().getBool("WEBGL_PACK_UNARY_OPERATIONS")?r=new Ol(a.shape,Dv):r=new Lr(a.shape,Dv),n.runWebGLProgram(r,[a],a.dtype)}var mB={kernelName:eo,backendName:"webgl",kernelFunc:fB},AB=xa+` + `}};function xh(e,t,n){let a=J().getBool("WEBGL_PACK_ARRAY_OPERATIONS")?new lB(e.shape,t):new oB(e.shape,t);return n.runWebGLProgram(a,[e],e.dtype)}function uB(e,t,n,a){let r=t,s=e.shape.length,i=k.parseAxisParam(r,e.shape),o=i,l=C.getAxesPermutation(o,s),d=l!=null,u=e;d&&(u=xh(e,l,a),o=C.getInnerMostAxes(o.length,s)),C.assertAxesAreInnerMostDims("sum",o,s);let[p,c]=C.computeOutAndReduceShapes(u.shape,o),h=p;n&&(h=C.expandShapeToKeepDim(p,i));let m=k.sizeFromShape(c),f=k.sizeFromShape(e.shape)/m,A=Ae({inputs:{x:u},attrs:{shape:[f,m]},backend:a}),y=dc(e.dtype),g=Si(A,y,"sum",a),x=Ae({inputs:{x:g},attrs:{shape:h},backend:a});return a.disposeIntermediateTensorInfo(A),a.disposeIntermediateTensorInfo(g),d&&a.disposeIntermediateTensorInfo(u),x}function bh(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{axis:s,keepDims:i}=a;return uB(r,s,i,n)}var dB={kernelName:qs,backendName:"webgl",kernelFunc:bh};function cn(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{perm:s}=a,i=n,o=r.shape.length,l=new Array(o);for(let u=0;u=2&&u>=2&&x,()=>`Error in matMul: the input batch dimensions must either be the same or at least one input batch dimension must be 1. Got input batch dimensions of (${f}) and (${A}).`);let w=(y>g?e.shape.slice(0,-2):t.shape.slice(0,-2)).concat([h,m]);k.assert(p===c,()=>`Error in matMul: inner shapes (${p}) and (${c}) of Tensors with shapes ${e.shape} and ${t.shape} and transposeA=${n} and transposeB=${a} must match.`);let b=n?[y,p,h]:[y,h,p],v=a?[g,m,c]:[g,c,m],N=Ae({inputs:{x:e},backend:r,attrs:{shape:b}}),T=Ae({inputs:{x:t},backend:r,attrs:{shape:v}}),R=[N,T],$=Math.max(y,g),z=n?N.shape[1]:N.shape[2],P=s!=null,V=i!=null,j=l==="leakyrelu",U=l!=null?gh(l,!0):null,X=P||V||j||U!=null,G;if((h===1||m===1)&&z>$v&&X===!1){let Y=N,re=T;n&&(Y=cn({inputs:{x:N},backend:r,attrs:{perm:[0,2,1]}}),R.push(Y)),a&&(re=cn({inputs:{x:T},backend:r,attrs:{perm:[0,2,1]}}),R.push(re));let ne=m!==1,ie=m===1,Q=Y;ne&&(Q=Ae({inputs:{x:Y},backend:r,attrs:{shape:[$,z,1]}}),R.push(Q));let de=m===1?2:1,oe=re;ie&&(oe=Ae({inputs:{x:re},backend:r,attrs:{shape:[$,1,z]}}),R.push(oe));let ye=y1({inputs:{a:Q,b:oe},backend:r});G=bh({inputs:{x:ye},backend:r,attrs:{axis:de,keepDims:!0}}),R.push(ye)}else{let Y=sa(e.dtype,t.dtype),re=new Ev(b,v,[$,h,m],n,a,P,U,V,j),ne=[N,T];if(s!=null&&ne.push(s),V&&ne.push(i),j){let ie=r.makeTensorInfo([],"float32",k.createScalarValue(o,"float32"));ne.push(ie),R.push(ie)}G=r.runWebGLProgram(re,ne,Y)}let ee=Ae({inputs:{x:G},backend:r,attrs:{shape:w}});R.push(G);for(let Y of R)r.disposeIntermediateTensorInfo(Y);return ee}function cB(e){let{inputs:t,backend:n,attrs:a}=e,{a:r,b:s,bias:i,preluActivationWeights:o}=t,{transposeA:l,transposeB:d,activation:u,leakyreluAlpha:p}=a;return vh({a:r,b:s,transposeA:l,transposeB:d,backend:n,bias:i,preluActivationWeights:o,leakyreluAlpha:p,activation:u})}var hB={kernelName:ei,backendName:"webgl",kernelFunc:cB},Dv="return abs(x);";function fB(e){let{inputs:t,backend:n}=e,{x:a}=t;if(n.shouldExecuteOnCPU([a])&&a.dtype!=="complex64"){let s=n.texData.get(a.dataId),i=hv(s.values);return n.makeTensorInfo(a.shape,a.dtype,i)}let r;return J().getBool("WEBGL_PACK_UNARY_OPERATIONS")?r=new Dl(a.shape,Dv):r=new Pr(a.shape,Dv),n.runWebGLProgram(r,[a],a.dtype)}var mB={kernelName:Qi,backendName:"webgl",kernelFunc:fB},AB=ga+` if (abs(x) > 1.) { return NAN; } return acos(x); -`,yB=qe({opSnippet:AB}),gB={kernelName:to,backendName:"webgl",kernelFunc:yB},xB=xa+` +`,yB=qe({opSnippet:AB}),gB={kernelName:eo,backendName:"webgl",kernelFunc:yB},xB=ga+` if (x < 1.0) return NAN; -return log(x + sqrt(x * x - 1.0));`,bB=qe({opSnippet:xB}),vB={kernelName:no,backendName:"webgl",kernelFunc:bB},Ov="return a + b;",wB=tn({opSnippet:Ov,packedOpSnippet:Ov,supportsComplex:!0,cpuKernelImpl:VL}),kB={kernelName:kr,backendName:"webgl",kernelFunc:wB},IB=class{constructor(e,t){this.outputShape=[],this.outputShape=e,this.variableNames=t.map((r,s)=>`T${s}`);let n=[];this.variableNames.forEach(r=>{n.push(`float v${r} = get${r}AtOutCoords();`)});let a=this.variableNames.map(r=>`v${r}`).join(" + ");this.userCode=` +return log(x + sqrt(x * x - 1.0));`,bB=qe({opSnippet:xB}),vB={kernelName:to,backendName:"webgl",kernelFunc:bB},Ov="return a + b;",wB=en({opSnippet:Ov,packedOpSnippet:Ov,supportsComplex:!0,cpuKernelImpl:VL}),kB={kernelName:wr,backendName:"webgl",kernelFunc:wB},IB=class{constructor(e,t){this.outputShape=[],this.outputShape=e,this.variableNames=t.map((r,s)=>`T${s}`);let n=[];this.variableNames.forEach(r=>{n.push(`float v${r} = get${r}AtOutCoords();`)});let a=this.variableNames.map(r=>`v${r}`).join(" + ");this.userCode=` void main() { ${n.join(` `)} @@ -1248,7 +1248,7 @@ return log(x + sqrt(x * x - 1.0));`,bB=qe({opSnippet:xB}),vB={kernelName:no,back vec4 result = ${a}; setOutput(result); } - `}};function wh(e){let{inputs:t,backend:n}=e,a=t;if(a.length===1)return Ln({inputs:{x:a[0]},backend:n});if(a.length>J().get("WEBGL_MAX_TEXTURES_IN_SHADER")){let o=Math.floor(a.length/2),l=wh({inputs:a.slice(0,o),backend:n}),d=wh({inputs:a.slice(o),backend:n});return wh({inputs:[l,d],backend:n})}let r=a.map(o=>o.dtype).reduce((o,l)=>ia(o,l)),s=a.map(o=>o.shape),i=J().getBool("WEBGL_PACK")?new SB(a[0].shape,s):new IB(a[0].shape,s);return n.runWebGLProgram(i,a,r)}var NB={kernelName:os,backendName:"webgl",kernelFunc:wh};function TB(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{axis:s,keepDims:i}=a,o=r.shape.length,l=k.parseAxisParam(s,r.shape),d=l,u=C.getAxesPermutation(d,o),p=r;u!=null&&(p=hn({inputs:{x:r},backend:n,attrs:{perm:u}}),d=C.getInnerMostAxes(d.length,o)),C.assertAxesAreInnerMostDims("all",d,o);let[c,h]=C.computeOutAndReduceShapes(p.shape,d),m=k.sizeFromShape(h),f=Ae({inputs:{x:p},backend:n,attrs:{shape:[-1,m]}}),A=Ni(f,f.dtype,"all",n),y;if(i){let g=C.expandShapeToKeepDim(c,l);y=Ae({inputs:{x:A},backend:n,attrs:{shape:g}})}else y=Ae({inputs:{x:A},backend:n,attrs:{shape:c}});return n.disposeIntermediateTensorInfo(f),n.disposeIntermediateTensorInfo(A),u!=null&&n.disposeIntermediateTensorInfo(p),y}var EB={kernelName:ao,backendName:"webgl",kernelFunc:TB};function CB(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{axis:s,keepDims:i}=a,o=r.shape.length,l=k.parseAxisParam(s,r.shape),d=l,u=C.getAxesPermutation(d,o),p=r;u!=null&&(p=hn({inputs:{x:r},backend:n,attrs:{perm:u}}),d=C.getInnerMostAxes(d.length,o)),C.assertAxesAreInnerMostDims("any",d,o);let[c,h]=C.computeOutAndReduceShapes(p.shape,d),m=k.sizeFromShape(h),f=Ae({inputs:{x:p},backend:n,attrs:{shape:[-1,m]}}),A=Ni(f,f.dtype,"any",n),y;if(i){let g=C.expandShapeToKeepDim(c,l);y=Ae({inputs:{x:A},backend:n,attrs:{shape:g}})}else y=Ae({inputs:{x:A},backend:n,attrs:{shape:c}});return n.disposeIntermediateTensorInfo(f),n.disposeIntermediateTensorInfo(A),u!=null&&n.disposeIntermediateTensorInfo(p),y}var RB={kernelName:ro,backendName:"webgl",kernelFunc:CB},MB=class{constructor(e,t,n){this.variableNames=["A"];let{windowSize:a,batchSize:r,outSize:s}=e;n||this.variableNames.push("bestIndicesA"),this.outputShape=[r,s];let i=t==="max"?">":"<",o=n?"inOffset + i;":"round(getBestIndicesA(batch, inOffset + i));";this.userCode=` + `}};function wh(e){let{inputs:t,backend:n}=e,a=t;if(a.length===1)return Pn({inputs:{x:a[0]},backend:n});if(a.length>J().get("WEBGL_MAX_TEXTURES_IN_SHADER")){let o=Math.floor(a.length/2),l=wh({inputs:a.slice(0,o),backend:n}),d=wh({inputs:a.slice(o),backend:n});return wh({inputs:[l,d],backend:n})}let r=a.map(o=>o.dtype).reduce((o,l)=>sa(o,l)),s=a.map(o=>o.shape),i=J().getBool("WEBGL_PACK")?new SB(a[0].shape,s):new IB(a[0].shape,s);return n.runWebGLProgram(i,a,r)}var NB={kernelName:is,backendName:"webgl",kernelFunc:wh};function TB(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{axis:s,keepDims:i}=a,o=r.shape.length,l=k.parseAxisParam(s,r.shape),d=l,u=C.getAxesPermutation(d,o),p=r;u!=null&&(p=cn({inputs:{x:r},backend:n,attrs:{perm:u}}),d=C.getInnerMostAxes(d.length,o)),C.assertAxesAreInnerMostDims("all",d,o);let[c,h]=C.computeOutAndReduceShapes(p.shape,d),m=k.sizeFromShape(h),f=Ae({inputs:{x:p},backend:n,attrs:{shape:[-1,m]}}),A=Si(f,f.dtype,"all",n),y;if(i){let g=C.expandShapeToKeepDim(c,l);y=Ae({inputs:{x:A},backend:n,attrs:{shape:g}})}else y=Ae({inputs:{x:A},backend:n,attrs:{shape:c}});return n.disposeIntermediateTensorInfo(f),n.disposeIntermediateTensorInfo(A),u!=null&&n.disposeIntermediateTensorInfo(p),y}var EB={kernelName:no,backendName:"webgl",kernelFunc:TB};function CB(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{axis:s,keepDims:i}=a,o=r.shape.length,l=k.parseAxisParam(s,r.shape),d=l,u=C.getAxesPermutation(d,o),p=r;u!=null&&(p=cn({inputs:{x:r},backend:n,attrs:{perm:u}}),d=C.getInnerMostAxes(d.length,o)),C.assertAxesAreInnerMostDims("any",d,o);let[c,h]=C.computeOutAndReduceShapes(p.shape,d),m=k.sizeFromShape(h),f=Ae({inputs:{x:p},backend:n,attrs:{shape:[-1,m]}}),A=Si(f,f.dtype,"any",n),y;if(i){let g=C.expandShapeToKeepDim(c,l);y=Ae({inputs:{x:A},backend:n,attrs:{shape:g}})}else y=Ae({inputs:{x:A},backend:n,attrs:{shape:c}});return n.disposeIntermediateTensorInfo(f),n.disposeIntermediateTensorInfo(A),u!=null&&n.disposeIntermediateTensorInfo(p),y}var RB={kernelName:ao,backendName:"webgl",kernelFunc:CB},MB=class{constructor(e,t,n){this.variableNames=["A"];let{windowSize:a,batchSize:r,outSize:s}=e;n||this.variableNames.push("bestIndicesA"),this.outputShape=[r,s];let i=t==="max"?">":"<",o=n?"inOffset + i;":"round(getBestIndicesA(batch, inOffset + i));";this.userCode=` void main() { ivec2 coords = getOutputCoords(); int batch = coords[0]; @@ -1268,7 +1268,7 @@ return log(x + sqrt(x * x - 1.0));`,bB=qe({opSnippet:xB}),vB={kernelName:no,back } setOutput(float(bestIndex)); } - `}},FB=class{constructor(e,t,n,a){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!0,k.assert(e.length>2,()=>`Packed arg${n.charAt(0).toUpperCase()+n.slice(1)} supports only inputs with rank above 2.`);let r=e[e.length-1],s=Math.ceil(r/t);this.outputShape=e.slice(0,-1),s>1&&this.outputShape.push(s),a||this.variableNames.push("bestIndicesA");let i=this.outputShape,o=i.length,l=lt(o),d=cn("coords",o),u,p;if(s===1){p=o+1;let N=lt(p);u=` + `}},FB=class{constructor(e,t,n,a){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!0,k.assert(e.length>2,()=>`Packed arg${n.charAt(0).toUpperCase()+n.slice(1)} supports only inputs with rank above 2.`);let r=e[e.length-1],s=Math.ceil(r/t);this.outputShape=e.slice(0,-1),s>1&&this.outputShape.push(s),a||this.variableNames.push("bestIndicesA");let i=this.outputShape,o=i.length,l=lt(o),d=pn("coords",o),u,p;if(s===1){p=o+1;let N=lt(p);u=` ${N} sourceLocR = ${N}(${d.join()}, 0); ++${d[o-1]}; ${N} sourceLocG = ${N}(${d.join()}, 0); @@ -1284,7 +1284,7 @@ return log(x + sqrt(x * x - 1.0));`,bB=qe({opSnippet:xB}),vB={kernelName:no,back ${l} sourceLocA = coords; --${d[o-1]}; ${l} sourceLocB = coords; - --${d[o-2]};`;let c=["x","y","z","w","u","v"].slice(0,p),h="."+c[p-1],m=c.map(N=>"int "+N),f=cn("sourceLocR",p-1).concat("inIdx.r"),A=cn("sourceLocG",p-1).concat("inIdx.g"),y=cn("sourceLocB",p-1).concat("inIdx.b"),g=cn("sourceLocA",p-1).concat("inIdx.a"),x=n==="max"?"greaterThan":"lessThan",w=a?"":` + --${d[o-2]};`;let c=["x","y","z","w","u","v"].slice(0,p),h="."+c[p-1],m=c.map(N=>"int "+N),f=pn("sourceLocR",p-1).concat("inIdx.r"),A=pn("sourceLocG",p-1).concat("inIdx.g"),y=pn("sourceLocB",p-1).concat("inIdx.b"),g=pn("sourceLocA",p-1).concat("inIdx.a"),x=n==="max"?"greaterThan":"lessThan",w=a?"":` inIdx = round(vec4(getBestIndicesAChannel(${f.join()}), getBestIndicesAChannel(${A.join()}), getBestIndicesAChannel(${y.join()}), @@ -1330,23 +1330,23 @@ return log(x + sqrt(x * x - 1.0));`,bB=qe({opSnippet:xB}),vB={kernelName:no,back } setOutput(bestIndex); } - `}};function zv(e,t,n,a=null){let r=t.shape[0],s=t.shape[1];a!=null&&(r=a.shape[0],s=a.shape[1]);let i=C.computeOptimalWindowSize(s),o={windowSize:i,inSize:s,batchSize:r,outSize:Math.ceil(s/i)},l=new MB(o,n,a==null),d=[t];a!=null&&d.push(a);let u=e.runWebGLProgram(l,d,"int32");if(u.shape[1]===1)return u;let p=zv(e,t,n,u);return e.disposeIntermediateTensorInfo(u),p}function _v(e,t,n,a=null){let r=a!=null?a.shape:t.shape,s=r[r.length-1],i=C.computeOptimalWindowSize(s),o=new FB(r,i,n,a==null),l=a==null?[t]:[t,a],d=e.runWebGLProgram(o,l,"int32");if(d.shape.length===t.shape.length){let u=_v(e,t,n,d);return e.disposeIntermediateTensorInfo(d),u}return d}function Pv(e,t,n,a){let r=[n];if(C.assertAxesAreInnerMostDims("arg"+a.charAt(0).toUpperCase()+a.slice(1),r,t.shape.length),!J().getBool("WEBGL_PACK_REDUCE")||t.shape.length<=2){let s=[],[i,o]=C.computeOutAndReduceShapes(t.shape,r),l=k.sizeFromShape(o),d=Ae({inputs:{x:t},backend:e,attrs:{shape:[-1,l]}});s.push(d);let u=zv(e,d,a);s.push(u);let p=Ae({inputs:{x:u},backend:e,attrs:{shape:i}});return s.forEach(c=>e.disposeIntermediateTensorInfo(c)),p}return _v(e,t,a)}function $B(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{axis:s}=a,i=k.parseAxisParam(s,r.shape),o=C.getAxesPermutation(i,r.shape.length),l=r,d=[];o!=null&&(l=hn({inputs:{x:r},backend:n,attrs:{perm:o}}),d.push(l),i=C.getInnerMostAxes(i.length,l.shape.length)),C.assertAxesAreInnerMostDims("argMax",[i[0]],l.shape.length);let u=Pv(n,l,i[0],"max");return d.forEach(p=>n.disposeIntermediateTensorInfo(p)),u}var DB={kernelName:ls,backendName:"webgl",kernelFunc:$B};function OB(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{axis:s}=a,i=k.parseAxisParam(s,r.shape),o=C.getAxesPermutation(i,r.shape.length),l=r,d=[];o!=null&&(l=hn({inputs:{x:r},backend:n,attrs:{perm:o}}),d.push(l),i=C.getInnerMostAxes(i.length,l.shape.length)),C.assertAxesAreInnerMostDims("argMin",[i[0]],l.shape.length);let u=Pv(n,l,i[0],"min");return d.forEach(p=>n.disposeIntermediateTensorInfo(p)),u}var zB={kernelName:Au,backendName:"webgl",kernelFunc:OB},_B=xa+` + `}};function zv(e,t,n,a=null){let r=t.shape[0],s=t.shape[1];a!=null&&(r=a.shape[0],s=a.shape[1]);let i=C.computeOptimalWindowSize(s),o={windowSize:i,inSize:s,batchSize:r,outSize:Math.ceil(s/i)},l=new MB(o,n,a==null),d=[t];a!=null&&d.push(a);let u=e.runWebGLProgram(l,d,"int32");if(u.shape[1]===1)return u;let p=zv(e,t,n,u);return e.disposeIntermediateTensorInfo(u),p}function _v(e,t,n,a=null){let r=a!=null?a.shape:t.shape,s=r[r.length-1],i=C.computeOptimalWindowSize(s),o=new FB(r,i,n,a==null),l=a==null?[t]:[t,a],d=e.runWebGLProgram(o,l,"int32");if(d.shape.length===t.shape.length){let u=_v(e,t,n,d);return e.disposeIntermediateTensorInfo(d),u}return d}function Pv(e,t,n,a){let r=[n];if(C.assertAxesAreInnerMostDims("arg"+a.charAt(0).toUpperCase()+a.slice(1),r,t.shape.length),!J().getBool("WEBGL_PACK_REDUCE")||t.shape.length<=2){let s=[],[i,o]=C.computeOutAndReduceShapes(t.shape,r),l=k.sizeFromShape(o),d=Ae({inputs:{x:t},backend:e,attrs:{shape:[-1,l]}});s.push(d);let u=zv(e,d,a);s.push(u);let p=Ae({inputs:{x:u},backend:e,attrs:{shape:i}});return s.forEach(c=>e.disposeIntermediateTensorInfo(c)),p}return _v(e,t,a)}function $B(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{axis:s}=a,i=k.parseAxisParam(s,r.shape),o=C.getAxesPermutation(i,r.shape.length),l=r,d=[];o!=null&&(l=cn({inputs:{x:r},backend:n,attrs:{perm:o}}),d.push(l),i=C.getInnerMostAxes(i.length,l.shape.length)),C.assertAxesAreInnerMostDims("argMax",[i[0]],l.shape.length);let u=Pv(n,l,i[0],"max");return d.forEach(p=>n.disposeIntermediateTensorInfo(p)),u}var DB={kernelName:os,backendName:"webgl",kernelFunc:$B};function OB(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{axis:s}=a,i=k.parseAxisParam(s,r.shape),o=C.getAxesPermutation(i,r.shape.length),l=r,d=[];o!=null&&(l=cn({inputs:{x:r},backend:n,attrs:{perm:o}}),d.push(l),i=C.getInnerMostAxes(i.length,l.shape.length)),C.assertAxesAreInnerMostDims("argMin",[i[0]],l.shape.length);let u=Pv(n,l,i[0],"min");return d.forEach(p=>n.disposeIntermediateTensorInfo(p)),u}var zB={kernelName:Au,backendName:"webgl",kernelFunc:OB},_B=ga+` if (abs(x) > 1.) { return NAN; } return asin(x); -`,PB=qe({opSnippet:_B}),LB={kernelName:so,backendName:"webgl",kernelFunc:PB},WB=xa+"return log(x + sqrt(x * x + 1.0));",BB=qe({opSnippet:WB}),VB={kernelName:io,backendName:"webgl",kernelFunc:BB},jB=xa+` +`,PB=qe({opSnippet:_B}),LB={kernelName:ro,backendName:"webgl",kernelFunc:PB},WB=ga+"return log(x + sqrt(x * x + 1.0));",BB=qe({opSnippet:WB}),VB={kernelName:so,backendName:"webgl",kernelFunc:BB},jB=ga+` return atan(x); -`,UB=qe({opSnippet:jB}),HB={kernelName:oo,backendName:"webgl",kernelFunc:UB},GB=QW+` +`,UB=qe({opSnippet:jB}),HB={kernelName:io,backendName:"webgl",kernelFunc:UB},GB=QW+` return atan(a, b); `,qB=` vec4 result = atan(a, b); vec4 isNaN = min(vec4(isnan(a)) + vec4(isnan(b)), vec4(1.0)); `+eB+` return result; -`,XB=tn({opSnippet:GB,packedOpSnippet:qB}),KB={kernelName:uo,backendName:"webgl",kernelFunc:XB},ZB=xa+` +`,XB=en({opSnippet:GB,packedOpSnippet:qB}),KB={kernelName:lo,backendName:"webgl",kernelFunc:XB},ZB=ga+` if ((x < -1.0) || (x > 1.0)) return NAN; -return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelName:lo,backendName:"webgl",kernelFunc:YB},yd=class{constructor(e,t,n,a=!1,r=!1){if(this.variableNames=["x"],t==="avg"&&n)throw new Error("Cannot compute positions for average pool.");let s=e.filterWidth,i=e.strideHeight,o=e.strideWidth,l=e.dilationHeight,d=e.dilationWidth,u=e.effectiveFilterHeight,p=e.effectiveFilterWidth,c=e.padInfo.top,h=e.padInfo.left;this.outputShape=e.outShape;let m=t==="avg",f=`((batch * ${e.inHeight} + xR) * ${e.inWidth} + xC) * ${e.inChannels} + d`,A=`(xR * ${e.inWidth} + xC) * ${e.inChannels} + d`,y="0.0";if(m||(y="-1.0 / 1e-20"),n){let N=">=";this.userCode=` +return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelName:oo,backendName:"webgl",kernelFunc:YB},yd=class{constructor(e,t,n,a=!1,r=!1){if(this.variableNames=["x"],t==="avg"&&n)throw new Error("Cannot compute positions for average pool.");let s=e.filterWidth,i=e.strideHeight,o=e.strideWidth,l=e.dilationHeight,d=e.dilationWidth,u=e.effectiveFilterHeight,p=e.effectiveFilterWidth,c=e.padInfo.top,h=e.padInfo.left;this.outputShape=e.outShape;let m=t==="avg",f=`((batch * ${e.inHeight} + xR) * ${e.inWidth} + xC) * ${e.inChannels} + d`,A=`(xR * ${e.inWidth} + xC) * ${e.inChannels} + d`,y="0.0";if(m||(y="-1.0 / 1e-20"),n){let N=">=";this.userCode=` const ivec2 strides = ivec2(${i}, ${o}); const ivec2 pads = ivec2(${c}, ${h}); @@ -1650,7 +1650,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam setOutput(${b}); } } - `}};function QB(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t;Cl(r,"avgPool");let{filterSize:s,strides:i,pad:o,dimRoundingMode:l}=a,d=1;k.assert(C.eitherStridesOrDilationsAreOne(i,d),()=>`Error in avgPool: Either strides or dilations must be 1. Got strides ${i} and dilations '${d}'`);let u=C.computePool2DInfo(r.shape,s,i,d,o,l);if(u.filterWidth===1&&u.filterHeight===1&&k.arraysEqual(u.inShape,u.outShape))return Ln({inputs:{x:r},backend:n});let p=new yd(u,"avg",!1);return n.runWebGLProgram(p,[r],"float32")}var eV={kernelName:us,backendName:"webgl",kernelFunc:QB};function tV(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{filterSize:s,strides:i,pad:o,dimRoundingMode:l,dataFormat:d}=a,u=[1,1,1],p=C.computePool3DInfo(r.shape,s,i,u,o,l,d),c=new g1(p,"avg",!1);return n.runWebGLProgram(c,[r],"float32")}var nV={kernelName:yu,backendName:"webgl",kernelFunc:tV},aV=class{constructor(e){this.variableNames=["dy"],this.outputShape=e.inShape;let t=e.filterHeight,n=e.filterWidth,a=e.strideHeight,r=e.strideWidth,s=e.dilationHeight,i=e.dilationWidth,o=e.effectiveFilterHeight,l=e.effectiveFilterWidth,d=o-1-e.padInfo.top,u=l-1-e.padInfo.left,p=1/(t*n);this.userCode=` + `}};function QB(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t;El(r,"avgPool");let{filterSize:s,strides:i,pad:o,dimRoundingMode:l}=a,d=1;k.assert(C.eitherStridesOrDilationsAreOne(i,d),()=>`Error in avgPool: Either strides or dilations must be 1. Got strides ${i} and dilations '${d}'`);let u=C.computePool2DInfo(r.shape,s,i,d,o,l);if(u.filterWidth===1&&u.filterHeight===1&&k.arraysEqual(u.inShape,u.outShape))return Pn({inputs:{x:r},backend:n});let p=new yd(u,"avg",!1);return n.runWebGLProgram(p,[r],"float32")}var eV={kernelName:ls,backendName:"webgl",kernelFunc:QB};function tV(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{filterSize:s,strides:i,pad:o,dimRoundingMode:l,dataFormat:d}=a,u=[1,1,1],p=C.computePool3DInfo(r.shape,s,i,u,o,l,d),c=new g1(p,"avg",!1);return n.runWebGLProgram(c,[r],"float32")}var nV={kernelName:yu,backendName:"webgl",kernelFunc:tV},aV=class{constructor(e){this.variableNames=["dy"],this.outputShape=e.inShape;let t=e.filterHeight,n=e.filterWidth,a=e.strideHeight,r=e.strideWidth,s=e.dilationHeight,i=e.dilationWidth,o=e.effectiveFilterHeight,l=e.effectiveFilterWidth,d=o-1-e.padInfo.top,u=l-1-e.padInfo.left,p=1/(t*n);this.userCode=` const ivec2 pads = ivec2(${d}, ${u}); const float avgMultiplier = float(${p}); @@ -1748,7 +1748,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam } setOutput(dotProd); } - `}};function sV(e){let{inputs:t,backend:n,attrs:a}=e,{dy:r,input:s}=t,i=s,{filterSize:o,strides:l,pad:d,dimRoundingMode:u}=a,p=[1,1,1],c=C.computePool3DInfo(i.shape,o,l,p,d,u),h=new rV(c);return n.runWebGLProgram(h,[r],i.dtype)}var iV={kernelName:Cp,backendName:"webgl",kernelFunc:sV};function oV(e){let{inputs:t,backend:n,attrs:a}=e,{dy:r,input:s}=t,i=s;Cl([r,s],"avgPoolGrad");let{filterSize:o,strides:l,pad:d}=a,u=C.computePool2DInfo(i.shape,o,l,1,d),p=new aV(u);return n.runWebGLProgram(p,[r],i.dtype)}var lV={kernelName:Ep,backendName:"webgl",kernelFunc:oV};function uV(e){let{inputs:t,backend:n,attrs:a}=e,{a:r,b:s}=t,{transposeA:i,transposeB:o}=a;return vh({a:r,b:s,transposeA:i,transposeB:o,backend:n})}var dV={kernelName:ds,backendName:"webgl",kernelFunc:uV},pV=class{constructor(e,t,n,a,r,s){this.outputShape=[],this.variableNames=["x","mean","variance"],C.assertAndGetBroadcastShape(e,t),C.assertAndGetBroadcastShape(e,n);let i="0.0";a!=null&&(C.assertAndGetBroadcastShape(e,a),this.variableNames.push("offset"),i="getOffsetAtOutCoords()");let o="1.0";r!=null&&(C.assertAndGetBroadcastShape(e,r),this.variableNames.push("scale"),o="getScaleAtOutCoords()"),this.outputShape=e,this.userCode=` + `}};function sV(e){let{inputs:t,backend:n,attrs:a}=e,{dy:r,input:s}=t,i=s,{filterSize:o,strides:l,pad:d,dimRoundingMode:u}=a,p=[1,1,1],c=C.computePool3DInfo(i.shape,o,l,p,d,u),h=new rV(c);return n.runWebGLProgram(h,[r],i.dtype)}var iV={kernelName:Cp,backendName:"webgl",kernelFunc:sV};function oV(e){let{inputs:t,backend:n,attrs:a}=e,{dy:r,input:s}=t,i=s;El([r,s],"avgPoolGrad");let{filterSize:o,strides:l,pad:d}=a,u=C.computePool2DInfo(i.shape,o,l,1,d),p=new aV(u);return n.runWebGLProgram(p,[r],i.dtype)}var lV={kernelName:Ep,backendName:"webgl",kernelFunc:oV};function uV(e){let{inputs:t,backend:n,attrs:a}=e,{a:r,b:s}=t,{transposeA:i,transposeB:o}=a;return vh({a:r,b:s,transposeA:i,transposeB:o,backend:n})}var dV={kernelName:us,backendName:"webgl",kernelFunc:uV},pV=class{constructor(e,t,n,a,r,s){this.outputShape=[],this.variableNames=["x","mean","variance"],C.assertAndGetBroadcastShape(e,t),C.assertAndGetBroadcastShape(e,n);let i="0.0";a!=null&&(C.assertAndGetBroadcastShape(e,a),this.variableNames.push("offset"),i="getOffsetAtOutCoords()");let o="1.0";r!=null&&(C.assertAndGetBroadcastShape(e,r),this.variableNames.push("scale"),o="getScaleAtOutCoords()"),this.outputShape=e,this.userCode=` void main() { float x = getXAtOutCoords(); float mean = getMeanAtOutCoords(); @@ -1771,7 +1771,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam setOutput((x - mean) * inv + offset); } - `}},hV=({inputs:e,backend:t,attrs:n})=>{let{x:a,mean:r,variance:s,offset:i,scale:o}=e;k.assert(r.shape.length===s.shape.length,()=>"Batch normalization gradient requires mean and variance to have equal ranks."),k.assert(i==null||r.shape.length===i.shape.length,()=>"Batch normalization gradient requires mean and offset to have equal ranks."),k.assert(o==null||r.shape.length===o.shape.length,()=>"Batch normalization gradient requires mean and scale to have equal ranks.");let{varianceEpsilon:l}=n;l==null&&(l=.001);let d=[a,r,s],u=null;i!=null&&(u=i.shape,d.push(i));let p=null;o!=null&&(p=o.shape,d.push(o));let c=J().getBool("WEBGL_PACK_NORMALIZATION")?new cV(a.shape,r.shape,s.shape,u,p,l):new pV(a.shape,r.shape,s.shape,u,p,l);return t.runWebGLProgram(c,d,d[0].dtype)},fV={kernelName:ws,backendName:"webgl",kernelFunc:hV},AV=class{constructor(e){this.variableNames=["source"],this.outputShape=e,this.rank=e.length;let t=lt(this.rank),n=`uniform int start[${this.rank}];`,a=mV(this.rank),r,s=e.map((i,o)=>`sourceLoc.${x1[o]} = start[${o}] + coords.${x1[o]};`);r=` + `}},hV=({inputs:e,backend:t,attrs:n})=>{let{x:a,mean:r,variance:s,offset:i,scale:o}=e;k.assert(r.shape.length===s.shape.length,()=>"Batch normalization gradient requires mean and variance to have equal ranks."),k.assert(i==null||r.shape.length===i.shape.length,()=>"Batch normalization gradient requires mean and offset to have equal ranks."),k.assert(o==null||r.shape.length===o.shape.length,()=>"Batch normalization gradient requires mean and scale to have equal ranks.");let{varianceEpsilon:l}=n;l==null&&(l=.001);let d=[a,r,s],u=null;i!=null&&(u=i.shape,d.push(i));let p=null;o!=null&&(p=o.shape,d.push(o));let c=J().getBool("WEBGL_PACK_NORMALIZATION")?new cV(a.shape,r.shape,s.shape,u,p,l):new pV(a.shape,r.shape,s.shape,u,p,l);return t.runWebGLProgram(c,d,d[0].dtype)},fV={kernelName:vs,backendName:"webgl",kernelFunc:hV},AV=class{constructor(e){this.variableNames=["source"],this.outputShape=e,this.rank=e.length;let t=lt(this.rank),n=`uniform int start[${this.rank}];`,a=mV(this.rank),r,s=e.map((i,o)=>`sourceLoc.${x1[o]} = start[${o}] + coords.${x1[o]};`);r=` ${t} sourceLoc; ${t} coords = getOutputCoords(); ${s.join(` @@ -1782,7 +1782,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam ${r} setOutput(getSource(${a})); } - `}getCustomSetupFunc(e){if(e.length!==this.rank)throw Error(`The rank (${this.rank}) of the program must match the length of start (${e.length})`);return(t,n)=>{this.startLoc==null&&(this.startLoc=t.getUniformLocationNoThrow(n,"start"),this.startLoc==null)||t.gl.uniform1iv(this.startLoc,e)}}},x1=["x","y","z","w","u","v"];function mV(e){if(e===1)return"sourceLoc";if(e<=6)return x1.slice(0,e).map(t=>"sourceLoc."+t).join(",");throw Error(`Slicing for rank ${e} is not yet supported`)}var yV=class{constructor(e){this.variableNames=["source"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=e,this.rank=e.length;let t=lt(this.rank),n=cn("coords",this.rank),a=cn("sourceLoc",this.rank),r=this.rank===1?"sourceLoc":`vec2(${a.slice(-2).join()})`,s=`getChannel(getSource(${a.join()}), ${r})`,i=` + `}getCustomSetupFunc(e){if(e.length!==this.rank)throw Error(`The rank (${this.rank}) of the program must match the length of start (${e.length})`);return(t,n)=>{this.startLoc==null&&(this.startLoc=t.getUniformLocationNoThrow(n,"start"),this.startLoc==null)||t.gl.uniform1iv(this.startLoc,e)}}},x1=["x","y","z","w","u","v"];function mV(e){if(e===1)return"sourceLoc";if(e<=6)return x1.slice(0,e).map(t=>"sourceLoc."+t).join(",");throw Error(`Slicing for rank ${e} is not yet supported`)}var yV=class{constructor(e){this.variableNames=["source"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=e,this.rank=e.length;let t=lt(this.rank),n=pn("coords",this.rank),a=pn("sourceLoc",this.rank),r=this.rank===1?"sourceLoc":`vec2(${a.slice(-2).join()})`,s=`getChannel(getSource(${a.join()}), ${r})`,i=` result.x = ${s}; if (++${n[this.rank-1]} < ${e[this.rank-1]}) { ++${a[this.rank-1]}; @@ -1812,7 +1812,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam ${o} setOutput(result); } - `}getCustomSetupFunc(e){if(e.length!==this.rank)throw Error(`The rank (${this.rank}) of the program must match the length of start (${e.length})`);return(t,n)=>{this.startLoc==null&&(this.startLoc=t.getUniformLocationNoThrow(n,"start"),this.startLoc==null)||t.gl.uniform1iv(this.startLoc,e)}}};function gV(e,t,n,a){let r=a.texData.get(e.dataId),s=a.makeTensorInfo(n,e.dtype),i=a.texData.get(s.dataId);Object.assign(i,r),i.refCount=1,i.shape=n,i.dtype=e.dtype;let o=ln.computeFlatOffset(t,k.computeStrides(e.shape));r.slice&&(o+=r.slice.flatOffset),i.slice={flatOffset:o,origDataId:r.slice&&r.slice.origDataId||e.dataId};let l=a.dataRefCount.get(i.slice.origDataId)||1;return a.dataRefCount.set(i.slice.origDataId,l+1),s}function gd(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{begin:s,size:i}=a,[o,l]=ln.parseSliceParams(r,s,i);if(ln.assertParamsValid(r,o,l),k.sizeFromShape(l)===0)return n.makeTensorInfo(l,r.dtype,[]);if(n.shouldExecuteOnCPU([r])||r.dtype==="string"){let p=n.texData.get(r.dataId),c=lW(p.values,o,l,r.shape,r.dtype);return n.makeTensorInfo(l,r.dtype,c)}let{isPacked:d}=n.texData.get(r.dataId),u=ln.isSliceContinous(r.shape,o,l);if(d||!u){let p=J().getBool("WEBGL_PACK_ARRAY_OPERATIONS")?new yV(l):new AV(l),c=p.getCustomSetupFunc(o);return n.runWebGLProgram(p,[r],r.dtype,c)}return n.uploadToGPU(r.dataId),gV(r,o,l,n)}var xV={kernelName:Ho,backendName:"webgl",kernelFunc:gd},bV=e=>{let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{blockShape:s,crops:i}=a;k.assert(r.shape.length<=4,()=>"batchToSpaceND for rank > 4 with a WebGL backend not implemented yet");let o=s.reduce((g,x)=>g*x),l=C.getReshaped(r.shape,s,o),d=C.getPermuted(l.length,s.length),u=C.getReshapedPermuted(r.shape,s,o),p=C.getSliceBeginCoords(i,s.length),c=C.getSliceSize(u,i,s.length),h=[],m=Ae({inputs:{x:r},backend:n,attrs:{shape:l}}),f=hn({inputs:{x:m},backend:n,attrs:{perm:d}}),A=Ae({inputs:{x:f},backend:n,attrs:{shape:u}}),y=gd({inputs:{x:A},backend:n,attrs:{begin:p,size:c}});return h.push(m),h.push(f),h.push(A),h.forEach(g=>n.disposeIntermediateTensorInfo(g)),y},vV={kernelName:gu,backendName:"webgl",kernelFunc:bV};function wV(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,weights:s}=t,{size:i}=a,o=n.readSync(r.dataId),l=n.readSync(s.dataId),d=cv(o,l,s.dtype,s.shape,i);return n.makeTensorInfo([i],s.dtype,d)}var kV={kernelName:Rp,backendName:"webgl",kernelFunc:wV},IV="return float(a != b);",Lv=tn({opSnippet:IV,dtype:"bool"}),SV={kernelName:$o,backendName:"webgl",kernelFunc:Lv};function xd(e){let{inputs:t,backend:n}=e,{input:a}=t,r=n.texData.get(a.dataId);return Ln({inputs:{x:r.complexTensorInfos.real},backend:n})}var NV={kernelName:Jp,backendName:"webgl",kernelFunc:xd},TV="return float(int(x));";function EV(e,t){let n=new Lr(e.shape,TV),a=t.runWebGLProgram(n,[e],"int32");return{dataId:a.dataId,shape:a.shape,dtype:a.dtype}}function b1(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{dtype:s}=a;if(s==="complex64"){if(r.dtype==="complex64")return Ln({inputs:{x:r},backend:n});let i=Rt(r.shape),o=b1({inputs:{x:r},backend:n,attrs:{dtype:"float32"}}),l=Wr({inputs:{real:o,imag:i},backend:n});return i.dispose(),n.disposeIntermediateTensorInfo(o),l}if(r.dtype==="complex64"){let i=xd({inputs:{input:r},backend:n}),o=b1({inputs:{x:i},backend:n,attrs:{dtype:s}});return n.disposeIntermediateTensorInfo(i),o}if(!k.hasEncodingLoss(r.dtype,s)){let i=Ln({inputs:{x:r},backend:n});return{dataId:i.dataId,shape:i.shape,dtype:s}}if(s==="int32")return EV(r,n);if(s==="bool"){let i=n.makeTensorInfo([],"bool",k.getTypedArrayFromDType("bool",1)),o=Lv({inputs:{a:r,b:i},backend:n});return n.disposeIntermediateTensorInfo(i),o}throw new Error(`Error in Cast: failed to cast ${r.dtype} to ${s}`)}var CV={kernelName:ps,backendName:"webgl",kernelFunc:b1},Wv="return ceil(x);",RV=qe({opSnippet:Wv,packedOpSnippet:Wv,cpuKernelImpl:UL}),MV={kernelName:cs,backendName:"webgl",kernelFunc:RV},FV=class{constructor(e){this.variableNames=["A"],this.outputShape=e,this.userCode=` + `}getCustomSetupFunc(e){if(e.length!==this.rank)throw Error(`The rank (${this.rank}) of the program must match the length of start (${e.length})`);return(t,n)=>{this.startLoc==null&&(this.startLoc=t.getUniformLocationNoThrow(n,"start"),this.startLoc==null)||t.gl.uniform1iv(this.startLoc,e)}}};function gV(e,t,n,a){let r=a.texData.get(e.dataId),s=a.makeTensorInfo(n,e.dtype),i=a.texData.get(s.dataId);Object.assign(i,r),i.refCount=1,i.shape=n,i.dtype=e.dtype;let o=on.computeFlatOffset(t,k.computeStrides(e.shape));r.slice&&(o+=r.slice.flatOffset),i.slice={flatOffset:o,origDataId:r.slice&&r.slice.origDataId||e.dataId};let l=a.dataRefCount.get(i.slice.origDataId)||1;return a.dataRefCount.set(i.slice.origDataId,l+1),s}function gd(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{begin:s,size:i}=a,[o,l]=on.parseSliceParams(r,s,i);if(on.assertParamsValid(r,o,l),k.sizeFromShape(l)===0)return n.makeTensorInfo(l,r.dtype,[]);if(n.shouldExecuteOnCPU([r])||r.dtype==="string"){let p=n.texData.get(r.dataId),c=lW(p.values,o,l,r.shape,r.dtype);return n.makeTensorInfo(l,r.dtype,c)}let{isPacked:d}=n.texData.get(r.dataId),u=on.isSliceContinous(r.shape,o,l);if(d||!u){let p=J().getBool("WEBGL_PACK_ARRAY_OPERATIONS")?new yV(l):new AV(l),c=p.getCustomSetupFunc(o);return n.runWebGLProgram(p,[r],r.dtype,c)}return n.uploadToGPU(r.dataId),gV(r,o,l,n)}var xV={kernelName:Uo,backendName:"webgl",kernelFunc:gd},bV=e=>{let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{blockShape:s,crops:i}=a;k.assert(r.shape.length<=4,()=>"batchToSpaceND for rank > 4 with a WebGL backend not implemented yet");let o=s.reduce((g,x)=>g*x),l=C.getReshaped(r.shape,s,o),d=C.getPermuted(l.length,s.length),u=C.getReshapedPermuted(r.shape,s,o),p=C.getSliceBeginCoords(i,s.length),c=C.getSliceSize(u,i,s.length),h=[],m=Ae({inputs:{x:r},backend:n,attrs:{shape:l}}),f=cn({inputs:{x:m},backend:n,attrs:{perm:d}}),A=Ae({inputs:{x:f},backend:n,attrs:{shape:u}}),y=gd({inputs:{x:A},backend:n,attrs:{begin:p,size:c}});return h.push(m),h.push(f),h.push(A),h.forEach(g=>n.disposeIntermediateTensorInfo(g)),y},vV={kernelName:gu,backendName:"webgl",kernelFunc:bV};function wV(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,weights:s}=t,{size:i}=a,o=n.readSync(r.dataId),l=n.readSync(s.dataId),d=cv(o,l,s.dtype,s.shape,i);return n.makeTensorInfo([i],s.dtype,d)}var kV={kernelName:Rp,backendName:"webgl",kernelFunc:wV},IV="return float(a != b);",Lv=en({opSnippet:IV,dtype:"bool"}),SV={kernelName:Fo,backendName:"webgl",kernelFunc:Lv};function xd(e){let{inputs:t,backend:n}=e,{input:a}=t,r=n.texData.get(a.dataId);return Pn({inputs:{x:r.complexTensorInfos.real},backend:n})}var NV={kernelName:Jp,backendName:"webgl",kernelFunc:xd},TV="return float(int(x));";function EV(e,t){let n=new Pr(e.shape,TV),a=t.runWebGLProgram(n,[e],"int32");return{dataId:a.dataId,shape:a.shape,dtype:a.dtype}}function b1(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{dtype:s}=a;if(s==="complex64"){if(r.dtype==="complex64")return Pn({inputs:{x:r},backend:n});let i=Ct(r.shape),o=b1({inputs:{x:r},backend:n,attrs:{dtype:"float32"}}),l=Lr({inputs:{real:o,imag:i},backend:n});return i.dispose(),n.disposeIntermediateTensorInfo(o),l}if(r.dtype==="complex64"){let i=xd({inputs:{input:r},backend:n}),o=b1({inputs:{x:i},backend:n,attrs:{dtype:s}});return n.disposeIntermediateTensorInfo(i),o}if(!k.hasEncodingLoss(r.dtype,s)){let i=Pn({inputs:{x:r},backend:n});return{dataId:i.dataId,shape:i.shape,dtype:s}}if(s==="int32")return EV(r,n);if(s==="bool"){let i=n.makeTensorInfo([],"bool",k.getTypedArrayFromDType("bool",1)),o=Lv({inputs:{a:r,b:i},backend:n});return n.disposeIntermediateTensorInfo(i),o}throw new Error(`Error in Cast: failed to cast ${r.dtype} to ${s}`)}var CV={kernelName:ds,backendName:"webgl",kernelFunc:b1},Wv="return ceil(x);",RV=qe({opSnippet:Wv,packedOpSnippet:Wv,cpuKernelImpl:UL}),MV={kernelName:ps,backendName:"webgl",kernelFunc:RV},FV=class{constructor(e){this.variableNames=["A"],this.outputShape=e,this.userCode=` uniform float minVal; uniform float maxVal; @@ -1839,7 +1839,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam setOutput(clamp(value, vec4(minVal), vec4(maxVal))); } - `}getCustomSetupFunc(e,t){return(n,a)=>{this.minLoc==null&&(this.minLoc=n.getUniformLocationNoThrow(a,"minVal"),this.maxLoc=n.getUniformLocationNoThrow(a,"maxVal")),n.gl.uniform1f(this.minLoc,e),n.gl.uniform1f(this.maxLoc,t)}}};function DV(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{clipValueMin:s,clipValueMax:i}=a,o;J().getBool("WEBGL_PACK_CLIP")?o=new $V(r.shape):o=new FV(r.shape);let l=o.getCustomSetupFunc(s,i);return n.runWebGLProgram(o,[r],r.dtype,l)}var OV={kernelName:Ir,backendName:"webgl",kernelFunc:DV},zV=class{constructor(e){this.variableNames=["real","imag"],this.outputShape=e,this.userCode=` + `}getCustomSetupFunc(e,t){return(n,a)=>{this.minLoc==null&&(this.minLoc=n.getUniformLocationNoThrow(a,"minVal"),this.maxLoc=n.getUniformLocationNoThrow(a,"maxVal")),n.gl.uniform1f(this.minLoc,e),n.gl.uniform1f(this.maxLoc,t)}}};function DV(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{clipValueMin:s,clipValueMax:i}=a,o;J().getBool("WEBGL_PACK_CLIP")?o=new $V(r.shape):o=new FV(r.shape);let l=o.getCustomSetupFunc(s,i);return n.runWebGLProgram(o,[r],r.dtype,l)}var OV={kernelName:kr,backendName:"webgl",kernelFunc:DV},zV=class{constructor(e){this.variableNames=["real","imag"],this.outputShape=e,this.userCode=` void main() { float re = abs(getRealAtOutCoords()); float im = abs(getImagAtOutCoords()); @@ -1861,7 +1861,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam ${n.join(` `)} } - `}},WV=class{constructor(e,t){this.packedInputs=!0,this.packedOutput=!0,this.outputShape=[],this.outputShape=C.computeOutShape(e,t);let n=this.outputShape,a=n.length,r=lt(a),s=cn("coords",a),i=["x","y","z","w","u","v"].slice(0,a);this.variableNames=e.map((m,f)=>`T${f}`);let o=new Array(e.length-1);o[0]=e[0][t];for(let m=1;m`T${f}`);let o=new Array(e.length-1);o[0]=e[0][t];for(let m=1;ms===a?`${r} - ${n}`:r).join()}function Ih(e){let{inputs:t,backend:n}=e,{input:a}=t,r=n.texData.get(a.dataId);return Ln({inputs:{x:r.complexTensorInfos.imag},backend:n})}var BV={kernelName:Hp,backendName:"webgl",kernelFunc:Ih};function Pl(e,t,n){let a=e[0].dtype;if(a==="complex64"){let u=e.map(f=>xd({inputs:{input:f},backend:n})),p=e.map(f=>Ih({inputs:{input:f},backend:n})),c=Pl(u,t,n),h=Pl(p,t,n),m=Wr({inputs:{real:c,imag:h},backend:n});return u.forEach(f=>n.disposeIntermediateTensorInfo(f)),p.forEach(f=>n.disposeIntermediateTensorInfo(f)),n.disposeIntermediateTensorInfo(c),n.disposeIntermediateTensorInfo(h),m}let r=n.shouldExecuteOnCPU(e);if(a==="string"&&(r=!0),r){let u=e.map(y=>{let g=k.sizeFromShape(y.shape.slice(t));return Ae({inputs:{x:y},backend:n,attrs:{shape:[-1,g]}})}),p=u.map(y=>({vals:n.readSync(y.dataId),shape:y.shape})),c=C.computeOutShape(u.map(y=>y.shape),1),h=u[0].shape[0]===1,m=HL(p,c,a,h),f=C.computeOutShape(e.map(y=>y.shape),t),A=n.makeTensorInfo(f,a,m);return u.forEach(y=>n.disposeIntermediateTensorInfo(y)),A}if(e.length>J().getNumber("WEBGL_MAX_TEXTURES_IN_SHADER")){let u=Math.floor(e.length/2),p=Pl(e.slice(0,u),t,n),c=Pl(e.slice(u),t,n),h=Pl([p,c],t,n);return n.disposeIntermediateTensorInfo(p),n.disposeIntermediateTensorInfo(c),h}if(J().getBool("WEBGL_PACK_ARRAY_OPERATIONS")&&e[0].shape.length>1){let u=new WV(e.map(p=>p.shape),t);return n.runWebGLProgram(u,e,a)}let{tensors2D:s,outShape:i}=VV(e,t,n),o=new LV(s.map(u=>u.shape)),l=n.runWebGLProgram(o,s,a);s.forEach(u=>n.disposeIntermediateTensorInfo(u));let d=Ae({inputs:{x:l},attrs:{shape:i},backend:n});return n.disposeIntermediateTensorInfo(l),d}function VV(e,t,n){let a=C.computeOutShape(e.map(r=>r.shape),t);return{tensors2D:e.map(r=>Ae({inputs:{x:r},attrs:{shape:[-1,k.sizeFromShape(r.shape.slice(t))]},backend:n})),outShape:a}}function Vv(e){let{inputs:t,backend:n,attrs:a}=e,{axis:r}=a,s=k.parseAxisParam(r,t[0].shape)[0],i=C.computeOutShape(t.map(d=>d.shape),s);if(k.sizeFromShape(i)===0)return n.makeTensorInfo(i,t[0].dtype,[]);let o=t.filter(d=>k.sizeFromShape(d.shape)>0);if(o.length===1)return Ln({inputs:{x:o[0]},backend:n});let l=o.map(d=>d.shape);return C.assertParamsConsistent(l,s),Pl(o,s,n)}var jV={kernelName:po,backendName:"webgl",kernelFunc:Vv},jv=class{constructor(e,t=!1,n=null,a=!1,r=!1){this.variableNames=["x","W"],this.outputShape=e.outShape;let s=e.padInfo.top,i=e.padInfo.left,o=e.strideHeight,l=e.strideWidth,d=e.dilationHeight,u=e.dilationWidth,p=e.filterHeight,c=e.filterWidth,h=Math.floor(e.inChannels/4)*4,m=e.inChannels%4,f=e.dataFormat==="channelsLast",A=f?1:2,y=f?2:3,g=f?3:1,x="",w="";n&&(a?x=`float activation(float a) { + `}};function kh(e,t,n){let a=e.indexOf(t);return e.map((r,s)=>s===a?`${r} - ${n}`:r).join()}function Ih(e){let{inputs:t,backend:n}=e,{input:a}=t,r=n.texData.get(a.dataId);return Pn({inputs:{x:r.complexTensorInfos.imag},backend:n})}var BV={kernelName:Hp,backendName:"webgl",kernelFunc:Ih};function _l(e,t,n){let a=e[0].dtype;if(a==="complex64"){let u=e.map(f=>xd({inputs:{input:f},backend:n})),p=e.map(f=>Ih({inputs:{input:f},backend:n})),c=_l(u,t,n),h=_l(p,t,n),m=Lr({inputs:{real:c,imag:h},backend:n});return u.forEach(f=>n.disposeIntermediateTensorInfo(f)),p.forEach(f=>n.disposeIntermediateTensorInfo(f)),n.disposeIntermediateTensorInfo(c),n.disposeIntermediateTensorInfo(h),m}let r=n.shouldExecuteOnCPU(e);if(a==="string"&&(r=!0),r){let u=e.map(y=>{let g=k.sizeFromShape(y.shape.slice(t));return Ae({inputs:{x:y},backend:n,attrs:{shape:[-1,g]}})}),p=u.map(y=>({vals:n.readSync(y.dataId),shape:y.shape})),c=C.computeOutShape(u.map(y=>y.shape),1),h=u[0].shape[0]===1,m=HL(p,c,a,h),f=C.computeOutShape(e.map(y=>y.shape),t),A=n.makeTensorInfo(f,a,m);return u.forEach(y=>n.disposeIntermediateTensorInfo(y)),A}if(e.length>J().getNumber("WEBGL_MAX_TEXTURES_IN_SHADER")){let u=Math.floor(e.length/2),p=_l(e.slice(0,u),t,n),c=_l(e.slice(u),t,n),h=_l([p,c],t,n);return n.disposeIntermediateTensorInfo(p),n.disposeIntermediateTensorInfo(c),h}if(J().getBool("WEBGL_PACK_ARRAY_OPERATIONS")&&e[0].shape.length>1){let u=new WV(e.map(p=>p.shape),t);return n.runWebGLProgram(u,e,a)}let{tensors2D:s,outShape:i}=VV(e,t,n),o=new LV(s.map(u=>u.shape)),l=n.runWebGLProgram(o,s,a);s.forEach(u=>n.disposeIntermediateTensorInfo(u));let d=Ae({inputs:{x:l},attrs:{shape:i},backend:n});return n.disposeIntermediateTensorInfo(l),d}function VV(e,t,n){let a=C.computeOutShape(e.map(r=>r.shape),t);return{tensors2D:e.map(r=>Ae({inputs:{x:r},attrs:{shape:[-1,k.sizeFromShape(r.shape.slice(t))]},backend:n})),outShape:a}}function Vv(e){let{inputs:t,backend:n,attrs:a}=e,{axis:r}=a,s=k.parseAxisParam(r,t[0].shape)[0],i=C.computeOutShape(t.map(d=>d.shape),s);if(k.sizeFromShape(i)===0)return n.makeTensorInfo(i,t[0].dtype,[]);let o=t.filter(d=>k.sizeFromShape(d.shape)>0);if(o.length===1)return Pn({inputs:{x:o[0]},backend:n});let l=o.map(d=>d.shape);return C.assertParamsConsistent(l,s),_l(o,s,n)}var jV={kernelName:uo,backendName:"webgl",kernelFunc:Vv},jv=class{constructor(e,t=!1,n=null,a=!1,r=!1){this.variableNames=["x","W"],this.outputShape=e.outShape;let s=e.padInfo.top,i=e.padInfo.left,o=e.strideHeight,l=e.strideWidth,d=e.dilationHeight,u=e.dilationWidth,p=e.filterHeight,c=e.filterWidth,h=Math.floor(e.inChannels/4)*4,m=e.inChannels%4,f=e.dataFormat==="channelsLast",A=f?1:2,y=f?2:3,g=f?3:1,x="",w="";n&&(a?x=`float activation(float a) { float b = getPreluActivationWeightsAtOutCoords(); ${n} }`:r?x=`float activation(float a) { @@ -2120,7 +2120,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam } setOutput(dotProd); } - `}},HV=class{constructor(e,t,n){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=e;let{filterWidth:a,inChannels:r,strideWidth:s,strideHeight:i,padInfo:o,outWidth:l,dilationWidth:d,dilationHeight:u,dataFormat:p}=n,{left:c,top:h}=o,m=r*a,f=pn(),A=p==="channelsLast",y=A?0:1,g=A?1:2,x="";for(let w=0;w<=1;w++)for(let b=0;b<=1;b++)x+=` + `}},HV=class{constructor(e,t,n){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=e;let{filterWidth:a,inChannels:r,strideWidth:s,strideHeight:i,padInfo:o,outWidth:l,dilationWidth:d,dilationHeight:u,dataFormat:p}=n,{left:c,top:h}=o,m=r*a,f=dn(),A=p==="channelsLast",y=A?0:1,g=A?1:2,x="";for(let w=0;w<=1;w++)for(let b=0;b<=1;b++)x+=` blockIndex = rc.y + ${b}; pos = rc.x + ${w}; @@ -2164,7 +2164,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam ${f.output} = result; } - `}};function Uv({x:e,filter:t,convInfo:n,backend:a,bias:r=null,preluActivationWeights:s=null,leakyreluAlpha:i=0,activation:o=null}){let l=e.shape,d=a.texData.get(e.dataId),u=n.inChannels,p=l[0]*l[1]*l[2],c=n.outChannels,h=n.dataFormat==="channelsLast",m=!1,f=!1,A,y=[],g=(p===1||c===1)&&u>$v,x=l[2]%2!=0&&!!d.isPacked;if(g||!J().getBool("WEBGL_LAZILY_UNPACK")||!J().getBool("WEBGL_PACK_BINARY_OPERATIONS")||!x){let w=h?l[0]*l[1]*l[2]:l[0]*l[2]*l[3],b=Ae({inputs:{x:e},backend:a,attrs:{shape:[1,w,n.inChannels]}}),v=Ae({inputs:{x:t},backend:a,attrs:{shape:[1,n.inChannels,n.outChannels]}}),N=vh({a:b,b:v,transposeA:m,transposeB:f,backend:a,bias:r,activation:o,preluActivationWeights:s,leakyreluAlpha:i});A=Ae({inputs:{x:N},backend:a,attrs:{shape:n.outShape}}),y.push(b),y.push(v),y.push(N)}else{let w=h?l[0]*l[1]*(l[2]+1):l[0]*l[2]*(l[3]+1),b={dataId:e.dataId,shape:[1,w,n.inChannels],dtype:e.dtype},v=d.shape;d.shape=d.shape.slice(),d.shape[d.shape.length-2]++,k.assert(pd(d.shape,b.shape),()=>`packed reshape ${d.shape} to ${b.shape} isn't free`);let N=Ae({inputs:{x:t},backend:a,attrs:{shape:[1,n.inChannels,n.outChannels]}});y.push(N);let T=vh({a:b,b:N,backend:a,transposeA:m,transposeB:f,bias:r,activation:o,preluActivationWeights:s,leakyreluAlpha:i}),R=a.texData.get(T.dataId);k.assert(R.isPacked,()=>"batchMatMul result is expected to be packed"),d.shape=v,R.shape=n.outShape,A=Ln({inputs:{x:T},backend:a}),A.shape=n.outShape,y.push(T)}for(let w of y)a.disposeIntermediateTensorInfo(w);return A}function Hv({x:e,filter:t,convInfo:n,backend:a,bias:r=null,preluActivationWeights:s=null,leakyreluAlpha:i=0,activation:o=null}){let{filterWidth:l,filterHeight:d,inChannels:u,outWidth:p,outHeight:c,dataFormat:h}=n,m=h==="channelsLast",f=l*d*u,A=c*p,y=[f,A],g=!0,x=!1,w=[],b=Ae({inputs:{x:e},backend:a,attrs:{shape:e.shape.slice(1)}}),v=Ae({inputs:{x:t},backend:a,attrs:{shape:[1,f,k.sizeFromShape(t.shape)/f]}});w.push(b),w.push(v);let N=new HV(y,b.shape,n),T=a.runWebGLProgram(N,[b],"float32"),R=Ae({inputs:{x:T},backend:a,attrs:{shape:[1,y[0],y[1]]}});w.push(T),w.push(R);let $=r!=null,z=s!=null,P=o==="leakyrelu",V=o?gh(o,!0):null,j=new Ev(R.shape,v.shape,[1,A,n.outChannels],g,x,$,V,z,P),U=[R,v];if(r&&U.push(r),z&&U.push(s),P){let Y=a.makeTensorInfo([],"float32",k.createScalarValue(i,"float32"));U.push(Y),w.push(Y)}let X=a.runWebGLProgram(j,U,"float32"),G=m?[1,c,p,n.outChannels]:[1,n.outChannels,c,p],ee=Ae({inputs:{x:X},backend:a,attrs:{shape:G}});w.push(X);for(let Y of w)a.disposeIntermediateTensorInfo(Y);return ee}function GV(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,filter:s}=t,{strides:i,pad:o,dataFormat:l,dilations:d,dimRoundingMode:u}=a,p=C.convertConv2DDataFormat(l),c=C.computeConv2DInfo(r.shape,s.shape,i,d,o,u,!1,p),h;if(c.filterHeight===1&&c.filterWidth===1&&c.dilationHeight===1&&c.dilationWidth===1&&c.strideHeight===1&&c.strideWidth===1&&(c.padInfo.type==="SAME"||c.padInfo.type==="VALID"))h=Uv({x:r,filter:s,convInfo:c,backend:n});else if(J().getBool("WEBGL_CONV_IM2COL")&&r.shape[0]===1)h=Hv({x:r,filter:s,convInfo:c,backend:n});else{let f=new jv(c);h=n.runWebGLProgram(f,[r,s],"float32")}let m=Ae({inputs:{x:h},backend:n,attrs:{shape:c.outShape}});return n.disposeIntermediateTensorInfo(h),m}var qV={kernelName:hs,backendName:"webgl",kernelFunc:GV},XV=class{constructor(e){this.variableNames=["x","dy"],this.outputShape=e.filterShape;let t=e.strideHeight,n=e.strideWidth,a=e.padInfo.top,r=e.padInfo.left,s=e.dataFormat==="channelsLast";this.userCode=` + `}};function Uv({x:e,filter:t,convInfo:n,backend:a,bias:r=null,preluActivationWeights:s=null,leakyreluAlpha:i=0,activation:o=null}){let l=e.shape,d=a.texData.get(e.dataId),u=n.inChannels,p=l[0]*l[1]*l[2],c=n.outChannels,h=n.dataFormat==="channelsLast",m=!1,f=!1,A,y=[],g=(p===1||c===1)&&u>$v,x=l[2]%2!=0&&!!d.isPacked;if(g||!J().getBool("WEBGL_LAZILY_UNPACK")||!J().getBool("WEBGL_PACK_BINARY_OPERATIONS")||!x){let w=h?l[0]*l[1]*l[2]:l[0]*l[2]*l[3],b=Ae({inputs:{x:e},backend:a,attrs:{shape:[1,w,n.inChannels]}}),v=Ae({inputs:{x:t},backend:a,attrs:{shape:[1,n.inChannels,n.outChannels]}}),N=vh({a:b,b:v,transposeA:m,transposeB:f,backend:a,bias:r,activation:o,preluActivationWeights:s,leakyreluAlpha:i});A=Ae({inputs:{x:N},backend:a,attrs:{shape:n.outShape}}),y.push(b),y.push(v),y.push(N)}else{let w=h?l[0]*l[1]*(l[2]+1):l[0]*l[2]*(l[3]+1),b={dataId:e.dataId,shape:[1,w,n.inChannels],dtype:e.dtype},v=d.shape;d.shape=d.shape.slice(),d.shape[d.shape.length-2]++,k.assert(pd(d.shape,b.shape),()=>`packed reshape ${d.shape} to ${b.shape} isn't free`);let N=Ae({inputs:{x:t},backend:a,attrs:{shape:[1,n.inChannels,n.outChannels]}});y.push(N);let T=vh({a:b,b:N,backend:a,transposeA:m,transposeB:f,bias:r,activation:o,preluActivationWeights:s,leakyreluAlpha:i}),R=a.texData.get(T.dataId);k.assert(R.isPacked,()=>"batchMatMul result is expected to be packed"),d.shape=v,R.shape=n.outShape,A=Pn({inputs:{x:T},backend:a}),A.shape=n.outShape,y.push(T)}for(let w of y)a.disposeIntermediateTensorInfo(w);return A}function Hv({x:e,filter:t,convInfo:n,backend:a,bias:r=null,preluActivationWeights:s=null,leakyreluAlpha:i=0,activation:o=null}){let{filterWidth:l,filterHeight:d,inChannels:u,outWidth:p,outHeight:c,dataFormat:h}=n,m=h==="channelsLast",f=l*d*u,A=c*p,y=[f,A],g=!0,x=!1,w=[],b=Ae({inputs:{x:e},backend:a,attrs:{shape:e.shape.slice(1)}}),v=Ae({inputs:{x:t},backend:a,attrs:{shape:[1,f,k.sizeFromShape(t.shape)/f]}});w.push(b),w.push(v);let N=new HV(y,b.shape,n),T=a.runWebGLProgram(N,[b],"float32"),R=Ae({inputs:{x:T},backend:a,attrs:{shape:[1,y[0],y[1]]}});w.push(T),w.push(R);let $=r!=null,z=s!=null,P=o==="leakyrelu",V=o?gh(o,!0):null,j=new Ev(R.shape,v.shape,[1,A,n.outChannels],g,x,$,V,z,P),U=[R,v];if(r&&U.push(r),z&&U.push(s),P){let Y=a.makeTensorInfo([],"float32",k.createScalarValue(i,"float32"));U.push(Y),w.push(Y)}let X=a.runWebGLProgram(j,U,"float32"),G=m?[1,c,p,n.outChannels]:[1,n.outChannels,c,p],ee=Ae({inputs:{x:X},backend:a,attrs:{shape:G}});w.push(X);for(let Y of w)a.disposeIntermediateTensorInfo(Y);return ee}function GV(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,filter:s}=t,{strides:i,pad:o,dataFormat:l,dilations:d,dimRoundingMode:u}=a,p=C.convertConv2DDataFormat(l),c=C.computeConv2DInfo(r.shape,s.shape,i,d,o,u,!1,p),h;if(c.filterHeight===1&&c.filterWidth===1&&c.dilationHeight===1&&c.dilationWidth===1&&c.strideHeight===1&&c.strideWidth===1&&(c.padInfo.type==="SAME"||c.padInfo.type==="VALID"))h=Uv({x:r,filter:s,convInfo:c,backend:n});else if(J().getBool("WEBGL_CONV_IM2COL")&&r.shape[0]===1)h=Hv({x:r,filter:s,convInfo:c,backend:n});else{let f=new jv(c);h=n.runWebGLProgram(f,[r,s],"float32")}let m=Ae({inputs:{x:h},backend:n,attrs:{shape:c.outShape}});return n.disposeIntermediateTensorInfo(h),m}var qV={kernelName:cs,backendName:"webgl",kernelFunc:GV},XV=class{constructor(e){this.variableNames=["x","dy"],this.outputShape=e.filterShape;let t=e.strideHeight,n=e.strideWidth,a=e.padInfo.top,r=e.padInfo.left,s=e.dataFormat==="channelsLast";this.userCode=` void main() { ivec4 coords = getOutputCoords(); int wR = coords.x; @@ -2358,12 +2358,12 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam } setOutput(dotProd); } - `}};function JV(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,dy:s}=t,{strides:i,pad:o,dataFormat:l,dimRoundingMode:d,filterShape:u}=a,p=C.convertConv2DDataFormat(l),c=C.computeConv2DInfo(r.shape,u,i,1,o,d,!1,p),h=new XV(c);return n.runWebGLProgram(h,[r,s],"float32")}var QV={kernelName:Fp,backendName:"webgl",kernelFunc:JV};function ej(e){let{inputs:t,backend:n,attrs:a}=e,{dy:r,filter:s}=t,{inputShape:i,strides:o,pad:l,dataFormat:d,dimRoundingMode:u}=a,p=C.convertConv2DDataFormat(d),c=C.computeConv2DInfo(i,s.shape,o,1,l,u,!1,p),h=new KV(c);return n.runWebGLProgram(h,[r,s],"float32")}var tj={kernelName:fs,backendName:"webgl",kernelFunc:ej};function nj(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,filter:s}=t,{strides:i,pad:o,dilations:l}=a,d=C.computeConv3DInfo(r.shape,s.shape,i,l,o),u=new UV(d);return n.runWebGLProgram(u,[r,s],"float32")}var aj={kernelName:bu,backendName:"webgl",kernelFunc:nj};function rj(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,dy:s}=t,{strides:i,pad:o,filterShape:l}=a,d=C.computeConv3DInfo(r.shape,l,i,1,o),u=new ZV(d);return n.runWebGLProgram(u,[r,s],"float32")}var sj={kernelName:$p,backendName:"webgl",kernelFunc:rj};function ij(e){let{inputs:t,backend:n,attrs:a}=e,{dy:r,filter:s}=t,{pad:i,strides:o,inputShape:l}=a,d=C.computeConv3DInfo(l,s.shape,o,1,i),u=new YV(d);return n.runWebGLProgram(u,[r,s],"float32")}var oj={kernelName:Dp,backendName:"webgl",kernelFunc:ij},lj=Tv+` + `}};function JV(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,dy:s}=t,{strides:i,pad:o,dataFormat:l,dimRoundingMode:d,filterShape:u}=a,p=C.convertConv2DDataFormat(l),c=C.computeConv2DInfo(r.shape,u,i,1,o,d,!1,p),h=new XV(c);return n.runWebGLProgram(h,[r,s],"float32")}var QV={kernelName:Fp,backendName:"webgl",kernelFunc:JV};function ej(e){let{inputs:t,backend:n,attrs:a}=e,{dy:r,filter:s}=t,{inputShape:i,strides:o,pad:l,dataFormat:d,dimRoundingMode:u}=a,p=C.convertConv2DDataFormat(d),c=C.computeConv2DInfo(i,s.shape,o,1,l,u,!1,p),h=new KV(c);return n.runWebGLProgram(h,[r,s],"float32")}var tj={kernelName:hs,backendName:"webgl",kernelFunc:ej};function nj(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,filter:s}=t,{strides:i,pad:o,dilations:l}=a,d=C.computeConv3DInfo(r.shape,s.shape,i,l,o),u=new UV(d);return n.runWebGLProgram(u,[r,s],"float32")}var aj={kernelName:bu,backendName:"webgl",kernelFunc:nj};function rj(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,dy:s}=t,{strides:i,pad:o,filterShape:l}=a,d=C.computeConv3DInfo(r.shape,l,i,1,o),u=new ZV(d);return n.runWebGLProgram(u,[r,s],"float32")}var sj={kernelName:$p,backendName:"webgl",kernelFunc:rj};function ij(e){let{inputs:t,backend:n,attrs:a}=e,{dy:r,filter:s}=t,{pad:i,strides:o,inputShape:l}=a,d=C.computeConv3DInfo(l,s.shape,o,1,i),u=new YV(d);return n.runWebGLProgram(u,[r,s],"float32")}var oj={kernelName:Dp,backendName:"webgl",kernelFunc:ij},lj=Tv+` return cos(x); -`,uj=qe({opSnippet:lj}),dj={kernelName:ms,backendName:"webgl",kernelFunc:uj},pj=` +`,uj=qe({opSnippet:lj}),dj={kernelName:fs,backendName:"webgl",kernelFunc:uj},pj=` float e2x = exp(-x); return (e2x + 1.0 / e2x) / 2.0; -`,cj=qe({opSnippet:pj}),hj={kernelName:co,backendName:"webgl",kernelFunc:cj},fj=class{constructor(e,t,n,a,r){this.variableNames=["Image","Boxes","BoxInd"],this.outputShape=[];let[s,i,o,l]=e,[d]=t,[u,p]=n;this.outputShape=[d,u,p,l];let c=a==="bilinear"?1:0,[h,m]=[`${i-1}.0`,`${o-1}.0`],[f,A,y]=u>1?[`${(i-1)/(u-1)}`,"(y2-y1) * height_ratio",`y1*${h} + float(y)*(height_scale)`]:["0.0","0.0",`0.5 * (y1+y2) * ${h}`],[g,x,w]=p>1?[`${(o-1)/(p-1)}`,"(x2-x1) * width_ratio",`x1*${m} + float(x)*(width_scale)`]:["0.0","0.0",`0.5 * (x1+x2) * ${m}`];this.userCode=` +`,cj=qe({opSnippet:pj}),hj={kernelName:po,backendName:"webgl",kernelFunc:cj},fj=class{constructor(e,t,n,a,r){this.variableNames=["Image","Boxes","BoxInd"],this.outputShape=[];let[s,i,o,l]=e,[d]=t,[u,p]=n;this.outputShape=[d,u,p,l];let c=a==="bilinear"?1:0,[h,m]=[`${i-1}.0`,`${o-1}.0`],[f,A,y]=u>1?[`${(i-1)/(u-1)}`,"(y2-y1) * height_ratio",`y1*${h} + float(y)*(height_scale)`]:["0.0","0.0",`0.5 * (y1+y2) * ${h}`],[g,x,w]=p>1?[`${(o-1)/(p-1)}`,"(x2-x1) * width_ratio",`x1*${m} + float(x)*(width_scale)`]:["0.0","0.0",`0.5 * (x1+x2) * ${m}`];this.userCode=` const float height_ratio = float(${f}); const float width_ratio = float(${g}); void main() { @@ -2424,7 +2424,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam setOutput(newValue); } } - `}},mj=e=>{let{inputs:t,backend:n,attrs:a}=e,{image:r,boxes:s,boxInd:i}=t,{cropSize:o,method:l,extrapolationValue:d}=a,u=new fj(r.shape,s.shape,o,l,d);return n.runWebGLProgram(u,[r,s,i],"float32")},Aj={kernelName:ho,backendName:"webgl",kernelFunc:mj},Xv=class{constructor(e,t,n){this.variableNames=["x"],this.outputShape=e;let a=e.length,r=t?"0.0":`getX(${Gv(a,"coords")})`,s=e[e.length-1],i="",o="";t?(i=n?`end != ${s-1}`:"end != 0",o=n?"end + 1":"end - 1"):(i=n?`end + pow2 < ${s}`:"end >= pow2",o=n?"end + pow2":"end - pow2"),this.userCode=` + `}},mj=e=>{let{inputs:t,backend:n,attrs:a}=e,{image:r,boxes:s,boxInd:i}=t,{cropSize:o,method:l,extrapolationValue:d}=a,u=new fj(r.shape,s.shape,o,l,d);return n.runWebGLProgram(u,[r,s,i],"float32")},Aj={kernelName:co,backendName:"webgl",kernelFunc:mj},Xv=class{constructor(e,t,n){this.variableNames=["x"],this.outputShape=e;let a=e.length,r=t?"0.0":`getX(${Gv(a,"coords")})`,s=e[e.length-1],i="",o="";t?(i=n?`end != ${s-1}`:"end != 0",o=n?"end + 1":"end - 1"):(i=n?`end + pow2 < ${s}`:"end >= pow2",o=n?"end + pow2":"end - pow2"),this.userCode=` uniform float index; void main() { ${lt(a)} coords = getOutputCoords(); @@ -2438,7 +2438,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam } setOutput(val); } - `}getCustomSetupFunc(e){return(t,n)=>{this.index==null&&(this.index=t.getUniformLocation(n,"index")),t.gl.uniform1f(this.index,e)}}};function Gv(e,t){if(e===1)return`${t}`;if(e===2)return`${t}.x, ${t}.y`;if(e===3)return`${t}.x, ${t}.y, ${t}.z`;if(e===4)return`${t}.x, ${t}.y, ${t}.z, ${t}.w`;throw Error(`Cumulative sum for rank ${e} is not yet supported`)}function qv(e,t){if(e===1)return`${t}`;if(e===2)return`${t}.y`;if(e===3)return`${t}.z`;if(e===4)return`${t}.w`;throw Error(`Cumulative sum for rank ${e} is not yet supported`)}function yj(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{axis:s,exclusive:i,reverse:o}=a,l=r.shape.length,d=C.getAxesPermutation([s],l),u=r;d!=null&&(u=hn({inputs:{x:r},backend:n,attrs:{perm:d}}));let p=C.getInnerMostAxes(1,l)[0];if(p!==l-1)throw new Error(`WebGL cumsum shader expects an inner-most axis=${r.shape.length-1} but got axis=${s}`);let c=u.shape[p],h=Ln({inputs:{x:u},backend:n});for(let m=0;m<=Math.ceil(Math.log2(c))-1;m++){let f=new Xv(u.shape,!1,o),A=f.getCustomSetupFunc(m),y=h;h=n.runWebGLProgram(f,[h],h.dtype,A),n.disposeIntermediateTensorInfo(y)}if(i){let m=new Xv(u.shape,i,o),f=h;h=n.runWebGLProgram(m,[h],h.dtype),n.disposeIntermediateTensorInfo(f)}if(d!=null){let m=C.getUndoAxesPermutation(d),f=hn({inputs:{x:h},backend:n,attrs:{perm:m}});return n.disposeIntermediateTensorInfo(h),n.disposeIntermediateTensorInfo(u),f}return h}var gj={kernelName:As,backendName:"webgl",kernelFunc:yj};function xj(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,weights:s}=t,{size:i,binaryOutput:o}=a;if(r.shape.length===1){let l=n.readSync(r.dataId),d=n.readSync(s.dataId),u=cv(l,d,s.dtype,s.shape,i);return n.makeTensorInfo([i],s.dtype,u)}else if(r.shape.length===2){let l=n.bufferSync(r),d=n.bufferSync(s),u=jL(l,d,i,o);return n.makeTensorInfo(u.shape,s.dtype,u.values)}throw new Error(`Error in denseBincount: input must be at most rank 2, but got rank${r.shape.length}.`)}var bj={kernelName:Op,backendName:"webgl",kernelFunc:xj},vj=class{constructor(e,t,n){this.variableNames=["x"],this.outputShape=[],this.outputShape=e,this.blockSize=t,this.dataFormat=n,this.userCode=` + `}getCustomSetupFunc(e){return(t,n)=>{this.index==null&&(this.index=t.getUniformLocation(n,"index")),t.gl.uniform1f(this.index,e)}}};function Gv(e,t){if(e===1)return`${t}`;if(e===2)return`${t}.x, ${t}.y`;if(e===3)return`${t}.x, ${t}.y, ${t}.z`;if(e===4)return`${t}.x, ${t}.y, ${t}.z, ${t}.w`;throw Error(`Cumulative sum for rank ${e} is not yet supported`)}function qv(e,t){if(e===1)return`${t}`;if(e===2)return`${t}.y`;if(e===3)return`${t}.z`;if(e===4)return`${t}.w`;throw Error(`Cumulative sum for rank ${e} is not yet supported`)}function yj(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{axis:s,exclusive:i,reverse:o}=a,l=r.shape.length,d=C.getAxesPermutation([s],l),u=r;d!=null&&(u=cn({inputs:{x:r},backend:n,attrs:{perm:d}}));let p=C.getInnerMostAxes(1,l)[0];if(p!==l-1)throw new Error(`WebGL cumsum shader expects an inner-most axis=${r.shape.length-1} but got axis=${s}`);let c=u.shape[p],h=Pn({inputs:{x:u},backend:n});for(let m=0;m<=Math.ceil(Math.log2(c))-1;m++){let f=new Xv(u.shape,!1,o),A=f.getCustomSetupFunc(m),y=h;h=n.runWebGLProgram(f,[h],h.dtype,A),n.disposeIntermediateTensorInfo(y)}if(i){let m=new Xv(u.shape,i,o),f=h;h=n.runWebGLProgram(m,[h],h.dtype),n.disposeIntermediateTensorInfo(f)}if(d!=null){let m=C.getUndoAxesPermutation(d),f=cn({inputs:{x:h},backend:n,attrs:{perm:m}});return n.disposeIntermediateTensorInfo(h),n.disposeIntermediateTensorInfo(u),f}return h}var gj={kernelName:ms,backendName:"webgl",kernelFunc:yj};function xj(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,weights:s}=t,{size:i,binaryOutput:o}=a;if(r.shape.length===1){let l=n.readSync(r.dataId),d=n.readSync(s.dataId),u=cv(l,d,s.dtype,s.shape,i);return n.makeTensorInfo([i],s.dtype,u)}else if(r.shape.length===2){let l=n.bufferSync(r),d=n.bufferSync(s),u=jL(l,d,i,o);return n.makeTensorInfo(u.shape,s.dtype,u.values)}throw new Error(`Error in denseBincount: input must be at most rank 2, but got rank${r.shape.length}.`)}var bj={kernelName:Op,backendName:"webgl",kernelFunc:xj},vj=class{constructor(e,t,n){this.variableNames=["x"],this.outputShape=[],this.outputShape=e,this.blockSize=t,this.dataFormat=n,this.userCode=` void main() { ivec4 coords = getOutputCoords(); int b = coords[0]; @@ -2457,7 +2457,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam float result = ${this.getInputSamplingString()}; setOutput(result); } - `}getHeightCoordString(){return this.dataFormat==="NHWC"?"coords[1]":"coords[2]"}getWidthCoordString(){return this.dataFormat==="NHWC"?"coords[2]":"coords[3]"}getDepthCoordString(){return this.dataFormat==="NHWC"?"coords[3]":"coords[1]"}getOutputDepthSize(){return this.dataFormat==="NHWC"?this.outputShape[3]:this.outputShape[1]}getInputSamplingString(){return this.dataFormat==="NHWC"?"getX(b, in_h, in_w, in_d)":"getX(b, in_d, in_h, in_w)"}};function wj(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{blockSize:s,dataFormat:i}=a;k.assert(s>1,()=>`blockSize should be > 1 for depthToSpace, but was: ${s}`);let o=r.shape[0],l=i==="NHWC"?r.shape[1]:r.shape[2],d=i==="NHWC"?r.shape[2]:r.shape[3],u=i==="NHWC"?r.shape[3]:r.shape[1],p=l*s,c=d*s,h=u/(s*s),m=i==="NHWC"?[o,p,c,h]:[o,h,p,c],f=new vj(m,s,i);return n.runWebGLProgram(f,[r],r.dtype)}var kj={kernelName:fo,backendName:"webgl",kernelFunc:wj},Kv=class{constructor(e,t=!1,n=null,a=!1,r=!1){this.variableNames=["x","W"],this.outputShape=e.outShape;let s=e.inHeight,i=e.inWidth,o=e.padInfo.top,l=e.padInfo.left,d=e.strideHeight,u=e.strideWidth,p=e.dilationHeight,c=e.dilationWidth,h=e.filterHeight,m=e.filterWidth,f=e.outChannels/e.inChannels,A="",y="";n&&(a?A=`float activation(float a) { + `}getHeightCoordString(){return this.dataFormat==="NHWC"?"coords[1]":"coords[2]"}getWidthCoordString(){return this.dataFormat==="NHWC"?"coords[2]":"coords[3]"}getDepthCoordString(){return this.dataFormat==="NHWC"?"coords[3]":"coords[1]"}getOutputDepthSize(){return this.dataFormat==="NHWC"?this.outputShape[3]:this.outputShape[1]}getInputSamplingString(){return this.dataFormat==="NHWC"?"getX(b, in_h, in_w, in_d)":"getX(b, in_d, in_h, in_w)"}};function wj(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{blockSize:s,dataFormat:i}=a;k.assert(s>1,()=>`blockSize should be > 1 for depthToSpace, but was: ${s}`);let o=r.shape[0],l=i==="NHWC"?r.shape[1]:r.shape[2],d=i==="NHWC"?r.shape[2]:r.shape[3],u=i==="NHWC"?r.shape[3]:r.shape[1],p=l*s,c=d*s,h=u/(s*s),m=i==="NHWC"?[o,p,c,h]:[o,h,p,c],f=new vj(m,s,i);return n.runWebGLProgram(f,[r],r.dtype)}var kj={kernelName:ho,backendName:"webgl",kernelFunc:wj},Kv=class{constructor(e,t=!1,n=null,a=!1,r=!1){this.variableNames=["x","W"],this.outputShape=e.outShape;let s=e.inHeight,i=e.inWidth,o=e.padInfo.top,l=e.padInfo.left,d=e.strideHeight,u=e.strideWidth,p=e.dilationHeight,c=e.dilationWidth,h=e.filterHeight,m=e.filterWidth,f=e.outChannels/e.inChannels,A="",y="";n&&(a?A=`float activation(float a) { float b = getPreluActivationWeightsAtOutCoords(); ${n} }`:r?A=`float activation(float a) { @@ -2696,7 +2696,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam ${x} setOutput(result); } - `}};function Ij(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,filter:s}=t,{strides:i,pad:o,dilations:l,dimRoundingMode:d}=a,u=l;u==null&&(u=[1,1]),k.assert(C.eitherStridesOrDilationsAreOne(i,u),()=>`Error in depthwiseConv2d: Either strides or dilations must be 1. Got strides ${i} and dilations '${u}'`);let p=C.computeConv2DInfo(r.shape,s.shape,i,u,o,d,!0),c;return J().getBool("WEBGL_PACK_DEPTHWISECONV")&&p.strideWidth<=2&&p.outChannels/p.inChannels==1?c=new Zv(p):c=new Kv(p),n.runWebGLProgram(c,[r,s],"float32")}var Sj={kernelName:ys,backendName:"webgl",kernelFunc:Ij},Nj=class{constructor(e){this.variableNames=["x","dy"],this.outputShape=e.filterShape;let t=e.strideHeight,n=e.strideWidth,a=e.padInfo.top,r=e.padInfo.left,s=e.outChannels/e.inChannels;this.userCode=` + `}};function Ij(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,filter:s}=t,{strides:i,pad:o,dilations:l,dimRoundingMode:d}=a,u=l;u==null&&(u=[1,1]),k.assert(C.eitherStridesOrDilationsAreOne(i,u),()=>`Error in depthwiseConv2d: Either strides or dilations must be 1. Got strides ${i} and dilations '${u}'`);let p=C.computeConv2DInfo(r.shape,s.shape,i,u,o,d,!0),c;return J().getBool("WEBGL_PACK_DEPTHWISECONV")&&p.strideWidth<=2&&p.outChannels/p.inChannels==1?c=new Zv(p):c=new Kv(p),n.runWebGLProgram(c,[r,s],"float32")}var Sj={kernelName:As,backendName:"webgl",kernelFunc:Ij},Nj=class{constructor(e){this.variableNames=["x","dy"],this.outputShape=e.filterShape;let t=e.strideHeight,n=e.strideWidth,a=e.padInfo.top,r=e.padInfo.left,s=e.outChannels/e.inChannels;this.userCode=` void main() { ivec4 coords = getOutputCoords(); int wR = coords.x; @@ -2820,7 +2820,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam float result = curVal; setOutput(result); } - `}};function zj(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,filter:s}=t,{strides:i,pad:o,dilations:l}=a,d=C.computeDilation2DInfo(r.shape,s.shape,i,o,"NHWC",l),u,p=new Oj(d);u=n.runWebGLProgram(p,[r,s],"float32");let c=Ae({inputs:{x:u},backend:n,attrs:{shape:d.outShape}});return n.disposeIntermediateTensorInfo(u),c}var _j={kernelName:vu,backendName:"webgl",kernelFunc:zj};function Pj(e){let{inputs:t,backend:n,attrs:a}=e,{equation:r}=a,s=t,{allDims:i,summedDims:o,idDims:l}=C.decodeEinsumEquation(r,s.length);C.checkEinsumDimSizes(i.length,l,s);let{path:d,steps:u}=C.getEinsumComputePath(o,l),p=u.length,c=null,h=i.length,m=[];for(let f=0;f=0&&(c=bh({inputs:{x:c},backend:n,attrs:{axis:d[f]-(i.length-h),keepDims:!1}}),m.push(c)),h--)}for(let f of m)f!==c&&n.disposeIntermediateTensorInfo(f);return c}var Lj={kernelName:Bp,backendName:"webgl",kernelFunc:Pj},Wj="return (x >= 0.0) ? x : (exp(x) - 1.0);",Bj=` + `}};function zj(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,filter:s}=t,{strides:i,pad:o,dilations:l}=a,d=C.computeDilation2DInfo(r.shape,s.shape,i,o,"NHWC",l),u,p=new Oj(d);u=n.runWebGLProgram(p,[r,s],"float32");let c=Ae({inputs:{x:u},backend:n,attrs:{shape:d.outShape}});return n.disposeIntermediateTensorInfo(u),c}var _j={kernelName:vu,backendName:"webgl",kernelFunc:zj};function Pj(e){let{inputs:t,backend:n,attrs:a}=e,{equation:r}=a,s=t,{allDims:i,summedDims:o,idDims:l}=C.decodeEinsumEquation(r,s.length);C.checkEinsumDimSizes(i.length,l,s);let{path:d,steps:u}=C.getEinsumComputePath(o,l),p=u.length,c=null,h=i.length,m=[];for(let f=0;f=0&&(c=bh({inputs:{x:c},backend:n,attrs:{axis:d[f]-(i.length-h),keepDims:!1}}),m.push(c)),h--)}for(let f of m)f!==c&&n.disposeIntermediateTensorInfo(f);return c}var Lj={kernelName:Bp,backendName:"webgl",kernelFunc:Pj},Wj="return (x >= 0.0) ? x : (exp(x) - 1.0);",Bj=` vec4 result; result.r = (x.r >= 0.0) ? x.r : (exp(x.r) - 1.0); @@ -2829,12 +2829,12 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam result.a = (x.a >= 0.0) ? x.a : (exp(x.a) - 1.0); return result; -`,Vj=qe({opSnippet:Wj,packedOpSnippet:Bj}),jj={kernelName:mo,backendName:"webgl",kernelFunc:Vj},Uj="return (b >= 1.0) ? a : a * (b + 1.0);",Hj=` +`,Vj=qe({opSnippet:Wj,packedOpSnippet:Bj}),jj={kernelName:fo,backendName:"webgl",kernelFunc:Vj},Uj="return (b >= 1.0) ? a : a * (b + 1.0);",Hj=` vec4 bGTEZero = vec4(greaterThanEqual(b, vec4(0.))); return (bGTEZero * a) + ((vec4(1.0) - bGTEZero) * (a * (b + vec4(1.0)))); -`,Gj=e=>{let{inputs:t,backend:n}=e,{dy:a,y:r}=t,s=J().getBool("WEBGL_PACK_BINARY_OPERATIONS")?new Ad(Hj,a.shape,r.shape):new _l(Uj,a.shape,r.shape);return n.runWebGLProgram(s,[a,r],a.dtype)},qj={kernelName:Vp,backendName:"webgl",kernelFunc:Gj},Xj=` +`,Gj=e=>{let{inputs:t,backend:n}=e,{dy:a,y:r}=t,s=J().getBool("WEBGL_PACK_BINARY_OPERATIONS")?new Ad(Hj,a.shape,r.shape):new zl(Uj,a.shape,r.shape);return n.runWebGLProgram(s,[a,r],a.dtype)},qj={kernelName:Vp,backendName:"webgl",kernelFunc:Gj},Xj=` return vec4(equal(a, b)); -`,Kj="return float(a == b);",Zj=tn({opSnippet:Kj,packedOpSnippet:Xj,dtype:"bool"}),Yj={kernelName:yo,backendName:"webgl",kernelFunc:Zj},Jj=` +`,Kj="return float(a == b);",Zj=en({opSnippet:Kj,packedOpSnippet:Xj,dtype:"bool"}),Yj={kernelName:Ao,backendName:"webgl",kernelFunc:Zj},Jj=` // Error function is calculated approximately with elementary function. // See "Handbook of Mathematical Functions with Formulas, // Graphs, and Mathematical Tables", Abramowitz and Stegun. @@ -2849,7 +2849,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam x = abs(x); float t = 1.0 / (1.0 + p * x); return sign * (1.0 - (((((a5*t + a4)*t) + a3)*t + a2)*t + a1)*t*exp(-x*x)); -`,Qj=qe({opSnippet:Jj}),eU={kernelName:Ao,backendName:"webgl",kernelFunc:Qj},Yv="return exp(x);",Jv=qe({opSnippet:Yv,packedOpSnippet:Yv,cpuKernelImpl:GL}),tU={kernelName:xs,backendName:"webgl",kernelFunc:Jv};function v1(e){let{inputs:t,attrs:n,backend:a}=e,{dim:r}=n,{input:s}=t,i=s.shape.length,o=s.shape.slice(),l=r;return r<0&&(k.assert(-(i+1)<=r,()=>`Axis must be in the interval [${-(i+1)}, ${i}]`),l=i+r+1),o.splice(l,0,1),Ae({inputs:{x:s},backend:a,attrs:{shape:o}})}var nU={kernelName:go,backendName:"webgl",kernelFunc:v1},Qv="return exp(x) - 1.0;",aU=qe({opSnippet:Qv,packedOpSnippet:Qv,cpuKernelImpl:qL}),rU={kernelName:xo,backendName:"webgl",kernelFunc:aU},ew=class{constructor(e,t,n){this.variableNames=["real","imag"];let a=t[1];this.outputShape=t;let r=n?`2.0 * ${Math.PI}`:`-2.0 * ${Math.PI}`,s=n?`${a}.0`:"1.0",i;if(e==="real")i="return real * expR - imag * expI;";else if(e==="imag")i="return real * expI + imag * expR;";else throw new Error(`FFT component must be either "real" or "imag", got ${e}.`);this.userCode=` +`,Qj=qe({opSnippet:Jj}),eU={kernelName:mo,backendName:"webgl",kernelFunc:Qj},Yv="return exp(x);",Jv=qe({opSnippet:Yv,packedOpSnippet:Yv,cpuKernelImpl:GL}),tU={kernelName:gs,backendName:"webgl",kernelFunc:Jv};function v1(e){let{inputs:t,attrs:n,backend:a}=e,{dim:r}=n,{input:s}=t,i=s.shape.length,o=s.shape.slice(),l=r;return r<0&&(k.assert(-(i+1)<=r,()=>`Axis must be in the interval [${-(i+1)}, ${i}]`),l=i+r+1),o.splice(l,0,1),Ae({inputs:{x:s},backend:a,attrs:{shape:o}})}var nU={kernelName:yo,backendName:"webgl",kernelFunc:v1},Qv="return exp(x) - 1.0;",aU=qe({opSnippet:Qv,packedOpSnippet:Qv,cpuKernelImpl:qL}),rU={kernelName:go,backendName:"webgl",kernelFunc:aU},ew=class{constructor(e,t,n){this.variableNames=["real","imag"];let a=t[1];this.outputShape=t;let r=n?`2.0 * ${Math.PI}`:`-2.0 * ${Math.PI}`,s=n?`${a}.0`:"1.0",i;if(e==="real")i="return real * expR - imag * expI;";else if(e==="imag")i="return real * expI + imag * expR;";else throw new Error(`FFT component must be either "real" or "imag", got ${e}.`);this.userCode=` const float exponentMultiplier = ${r}; float unaryOpComplex(float real, float expR, float imag, float expI) { @@ -2882,7 +2882,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam ivec2 coords = getOutputCoords(); setOutput(mulMatDFT(coords[0], coords[1])); } - `}};function tw(e,t,n){let a=n.texData.get(e.dataId),r=k.sizeFromShape(e.shape),s=e.shape[e.shape.length-1],i=r/s,o=Ae({inputs:{x:e},backend:n,attrs:{shape:[i,s]}}),l=o.shape,d=new ew("real",l,t),u=new ew("imag",l,t),p=[{dataId:a.complexTensorInfos.real.dataId,dtype:a.complexTensorInfos.real.dtype,shape:l},{dataId:a.complexTensorInfos.imag.dataId,dtype:a.complexTensorInfos.imag.dtype,shape:l}],c=n.runWebGLProgram(d,p,"float32"),h=n.runWebGLProgram(u,p,"float32"),m=Wr({inputs:{real:c,imag:h},backend:n});n.disposeIntermediateTensorInfo(c),n.disposeIntermediateTensorInfo(h);let f=Ae({inputs:{x:m},backend:n,attrs:{shape:e.shape}});return n.disposeIntermediateTensorInfo(o),n.disposeIntermediateTensorInfo(m),f}function sU(e){let{inputs:t,backend:n}=e,{input:a}=t;return tw(a,!1,n)}var iU={kernelName:jp,backendName:"webgl",kernelFunc:sU},oU=class{constructor(e,t){this.outputShape=[],this.variableNames=["x"],this.outputShape=e,this.userCode=` + `}};function tw(e,t,n){let a=n.texData.get(e.dataId),r=k.sizeFromShape(e.shape),s=e.shape[e.shape.length-1],i=r/s,o=Ae({inputs:{x:e},backend:n,attrs:{shape:[i,s]}}),l=o.shape,d=new ew("real",l,t),u=new ew("imag",l,t),p=[{dataId:a.complexTensorInfos.real.dataId,dtype:a.complexTensorInfos.real.dtype,shape:l},{dataId:a.complexTensorInfos.imag.dataId,dtype:a.complexTensorInfos.imag.dtype,shape:l}],c=n.runWebGLProgram(d,p,"float32"),h=n.runWebGLProgram(u,p,"float32"),m=Lr({inputs:{real:c,imag:h},backend:n});n.disposeIntermediateTensorInfo(c),n.disposeIntermediateTensorInfo(h);let f=Ae({inputs:{x:m},backend:n,attrs:{shape:e.shape}});return n.disposeIntermediateTensorInfo(o),n.disposeIntermediateTensorInfo(m),f}function sU(e){let{inputs:t,backend:n}=e,{input:a}=t;return tw(a,!1,n)}var iU={kernelName:jp,backendName:"webgl",kernelFunc:sU},oU=class{constructor(e,t){this.outputShape=[],this.variableNames=["x"],this.outputShape=e,this.userCode=` uniform float value; void main() { // Input can be obtained from uniform value. @@ -2902,7 +2902,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam } setOutput(outputValue); } - `}},dU={kernelName:bo,backendName:"webgl",kernelFunc:({inputs:e,backend:t})=>{let{image:n}=e,a=t,r=new uU(n.shape);return a.runWebGLProgram(r,[n],n.dtype)}},nw="return floor(x);",pU=qe({opSnippet:nw,packedOpSnippet:nw,cpuKernelImpl:XL}),cU={kernelName:bs,backendName:"webgl",kernelFunc:pU},hU=` + `}},dU={kernelName:xo,backendName:"webgl",kernelFunc:({inputs:e,backend:t})=>{let{image:n}=e,a=t,r=new uU(n.shape);return a.runWebGLProgram(r,[n],n.dtype)}},nw="return floor(x);",pU=qe({opSnippet:nw,packedOpSnippet:nw,cpuKernelImpl:XL}),cU={kernelName:xs,backendName:"webgl",kernelFunc:pU},hU=` float s = sign(a) * sign(b); int ia = round(a); int ib = round(b); @@ -2933,7 +2933,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam result[3] = idiv(ia[3], ib[3], s[3]); } return vec4(result); -`,mU=tn({opSnippet:hU,packedOpSnippet:fU,dtype:"int32"}),AU={kernelName:vs,backendName:"webgl",kernelFunc:mU},yU=class{constructor(e){this.variableNames=["A"];let t=pn(),[n,a]=e;this.outputShape=e,this.userCode=` +`,mU=en({opSnippet:hU,packedOpSnippet:fU,dtype:"int32"}),AU={kernelName:bs,backendName:"webgl",kernelFunc:mU},yU=class{constructor(e){this.variableNames=["A"];let t=dn(),[n,a]=e;this.outputShape=e,this.userCode=` void main() { ivec3 coords = getOutputCoords(); int texR = coords[0]; @@ -2955,7 +2955,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam setOutput(floor(value * 255.0 + 0.5)); } - `}},gU=class{constructor(e){this.variableNames=["A"],this.packedInputs=!1,this.packedOutput=!0;let t=pn(),[n,a]=e;this.outputShape=e,this.userCode=` + `}},gU=class{constructor(e){this.variableNames=["A"],this.packedInputs=!1,this.packedOutput=!0;let t=dn(),[n,a]=e;this.outputShape=e,this.userCode=` void main() { ivec3 coords = getOutputCoords(); int texR = coords[0]; @@ -2989,7 +2989,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam ${t.output} = result; } - `}},bU={kernelName:sc,backendName:"webgl",kernelFunc:xU},Ll;function xU(e){let{inputs:t,backend:n,attrs:a}=e,{pixels:r}=t,{numChannels:s}=a,i=typeof HTMLVideoElement!="undefined"&&r instanceof HTMLVideoElement,o=typeof HTMLImageElement!="undefined"&&r instanceof HTMLImageElement,[l,d]=i?[r.videoWidth,r.videoHeight]:[r.width,r.height],u=[d,l],p=[d,l,s];(o||i)&&(Ll==null&&(Ll=document.createElement("canvas").getContext("2d")),Ll.canvas.width=l,Ll.canvas.height=d,Ll.drawImage(r,0,0,l,d),r=Ll.canvas);let c=n.makeTensorInfo(u,"int32");n.texData.get(c.dataId).usage=Jn.PIXELS,n.gpgpu.uploadPixelDataToTexture(n.getTexture(c.dataId),r);let h=J().getBool("WEBGL_PACK")?new gU(p):new yU(p),m=n.runWebGLProgram(h,[c],"int32");return n.disposeData(c.dataId),m}function vU(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,filter:s,bias:i,preluActivationWeights:o}=t,{strides:l,pad:d,dataFormat:u,dilations:p,dimRoundingMode:c,activation:h,leakyreluAlpha:m}=a,f=C.convertConv2DDataFormat(u),A=C.computeConv2DInfo(r.shape,s.shape,l,p,d,c,!1,f),y,g=[];if(A.filterHeight===1&&A.filterWidth===1&&A.dilationHeight===1&&A.dilationWidth===1&&A.strideHeight===1&&A.strideWidth===1&&(A.padInfo.type==="SAME"||A.padInfo.type==="VALID"))y=Uv({x:r,filter:s,convInfo:A,backend:n,bias:i,activation:h,preluActivationWeights:o,leakyreluAlpha:m});else if(J().getBool("WEBGL_CONV_IM2COL")&&r.shape[0]===1)y=Hv({x:r,filter:s,convInfo:A,backend:n,bias:i,activation:h,preluActivationWeights:o,leakyreluAlpha:m});else{let w=i!=null,b=o!=null,v=h==="leakyrelu",N=h?gh(h,!1):null,T=new jv(A,w,N,b,v),R=[r,s];if(i&&R.push(i),o&&R.push(o),v){let $=n.makeTensorInfo([],"float32",k.createScalarValue(m,"float32"));R.push($),g.push($)}y=n.runWebGLProgram(T,R,"float32")}let x=Ae({inputs:{x:y},backend:n,attrs:{shape:A.outShape}});return g.push(y),g.forEach(w=>n.disposeIntermediateTensorInfo(w)),x}var wU={kernelName:ni,backendName:"webgl",kernelFunc:vU};function kU(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,filter:s,bias:i,preluActivationWeights:o}=t,{strides:l,pad:d,dilations:u,dimRoundingMode:p,activation:c,leakyreluAlpha:h}=a,m=[],f=u;f==null&&(f=[1,1]),k.assert(C.eitherStridesOrDilationsAreOne(l,f),()=>`Error in depthwiseConv2d: Either strides or dilations must be 1. Got strides ${l} and dilations '${f}'`);let A=C.computeConv2DInfo(r.shape,s.shape,l,f,d,p,!0),y=J().getBool("WEBGL_PACK_DEPTHWISECONV")&&A.strideWidth<=2&&A.outChannels/A.inChannels==1,g=c?gh(c,y):null,x=[r,s],w=i!=null,b=o!=null,v=c==="leakyrelu";if(w&&x.push(i),b&&x.push(o),v){let R=n.makeTensorInfo([],"float32",k.createScalarValue(h,"float32"));x.push(R),m.push(R)}let N;y?N=new Zv(A,w,g,b,v):N=new Kv(A,w,g,b,v);let T=n.runWebGLProgram(N,x,"float32");return m.forEach(R=>n.disposeIntermediateTensorInfo(R)),T}var IU={kernelName:ai,backendName:"webgl",kernelFunc:kU},SU=class{constructor(e,t,n){this.sliceDim=e,this.strides=t,this.variableNames=["x","indices"],this.outputShape=n;let a=lt(t.length),r=lt(n.length),s=this.sliceDim>1?"strides[j]":"strides";this.userCode=` + `}},bU={kernelName:sc,backendName:"webgl",kernelFunc:xU},Pl;function xU(e){let{inputs:t,backend:n,attrs:a}=e,{pixels:r}=t,{numChannels:s}=a,i=typeof HTMLVideoElement!="undefined"&&r instanceof HTMLVideoElement,o=typeof HTMLImageElement!="undefined"&&r instanceof HTMLImageElement,[l,d]=i?[r.videoWidth,r.videoHeight]:[r.width,r.height],u=[d,l],p=[d,l,s];(o||i)&&(Pl==null&&(Pl=document.createElement("canvas").getContext("2d")),Pl.canvas.width=l,Pl.canvas.height=d,Pl.drawImage(r,0,0,l,d),r=Pl.canvas);let c=n.makeTensorInfo(u,"int32");n.texData.get(c.dataId).usage=Yn.PIXELS,n.gpgpu.uploadPixelDataToTexture(n.getTexture(c.dataId),r);let h=J().getBool("WEBGL_PACK")?new gU(p):new yU(p),m=n.runWebGLProgram(h,[c],"int32");return n.disposeData(c.dataId),m}function vU(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,filter:s,bias:i,preluActivationWeights:o}=t,{strides:l,pad:d,dataFormat:u,dilations:p,dimRoundingMode:c,activation:h,leakyreluAlpha:m}=a,f=C.convertConv2DDataFormat(u),A=C.computeConv2DInfo(r.shape,s.shape,l,p,d,c,!1,f),y,g=[];if(A.filterHeight===1&&A.filterWidth===1&&A.dilationHeight===1&&A.dilationWidth===1&&A.strideHeight===1&&A.strideWidth===1&&(A.padInfo.type==="SAME"||A.padInfo.type==="VALID"))y=Uv({x:r,filter:s,convInfo:A,backend:n,bias:i,activation:h,preluActivationWeights:o,leakyreluAlpha:m});else if(J().getBool("WEBGL_CONV_IM2COL")&&r.shape[0]===1)y=Hv({x:r,filter:s,convInfo:A,backend:n,bias:i,activation:h,preluActivationWeights:o,leakyreluAlpha:m});else{let w=i!=null,b=o!=null,v=h==="leakyrelu",N=h?gh(h,!1):null,T=new jv(A,w,N,b,v),R=[r,s];if(i&&R.push(i),o&&R.push(o),v){let $=n.makeTensorInfo([],"float32",k.createScalarValue(m,"float32"));R.push($),g.push($)}y=n.runWebGLProgram(T,R,"float32")}let x=Ae({inputs:{x:y},backend:n,attrs:{shape:A.outShape}});return g.push(y),g.forEach(w=>n.disposeIntermediateTensorInfo(w)),x}var wU={kernelName:ti,backendName:"webgl",kernelFunc:vU};function kU(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,filter:s,bias:i,preluActivationWeights:o}=t,{strides:l,pad:d,dilations:u,dimRoundingMode:p,activation:c,leakyreluAlpha:h}=a,m=[],f=u;f==null&&(f=[1,1]),k.assert(C.eitherStridesOrDilationsAreOne(l,f),()=>`Error in depthwiseConv2d: Either strides or dilations must be 1. Got strides ${l} and dilations '${f}'`);let A=C.computeConv2DInfo(r.shape,s.shape,l,f,d,p,!0),y=J().getBool("WEBGL_PACK_DEPTHWISECONV")&&A.strideWidth<=2&&A.outChannels/A.inChannels==1,g=c?gh(c,y):null,x=[r,s],w=i!=null,b=o!=null,v=c==="leakyrelu";if(w&&x.push(i),b&&x.push(o),v){let R=n.makeTensorInfo([],"float32",k.createScalarValue(h,"float32"));x.push(R),m.push(R)}let N;y?N=new Zv(A,w,g,b,v):N=new Kv(A,w,g,b,v);let T=n.runWebGLProgram(N,x,"float32");return m.forEach(R=>n.disposeIntermediateTensorInfo(R)),T}var IU={kernelName:ni,backendName:"webgl",kernelFunc:kU},SU=class{constructor(e,t,n){this.sliceDim=e,this.strides=t,this.variableNames=["x","indices"],this.outputShape=n;let a=lt(t.length),r=lt(n.length),s=this.sliceDim>1?"strides[j]":"strides";this.userCode=` ${a} strides = ${a}(${this.strides}); void main() { ${r} coords = getOutputCoords(); @@ -3000,20 +3000,20 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam } setOutput(getX(flattenIndex, coords[1])); } - `}};function NU(e){let{inputs:t,backend:n}=e,{params:a,indices:r}=t,s=r.shape,i=s[s.length-1],[o,l,d,u]=C.prepareAndValidate(a,r),p=Ae({inputs:{x:r},backend:n,attrs:{shape:[l,i]}}),c=Ae({inputs:{x:a},backend:n,attrs:{shape:[k.sizeFromShape(a.shape)/d,d]}}),h=new SU(i,u,[l,d]),m=n.runWebGLProgram(h,[c,p],c.dtype),f=Ae({inputs:{x:m},backend:n,attrs:{shape:o}});return n.disposeIntermediateTensorInfo(p),n.disposeIntermediateTensorInfo(c),n.disposeIntermediateTensorInfo(m),f}var TU={kernelName:wo,backendName:"webgl",kernelFunc:NU},CU=class{constructor(e,t){this.variableNames=["A","indices"],this.outputShape=t,this.rank=t.length;let n=lt(this.rank),a=EU(e,2);this.userCode=` + `}};function NU(e){let{inputs:t,backend:n}=e,{params:a,indices:r}=t,s=r.shape,i=s[s.length-1],[o,l,d,u]=C.prepareAndValidate(a,r),p=Ae({inputs:{x:r},backend:n,attrs:{shape:[l,i]}}),c=Ae({inputs:{x:a},backend:n,attrs:{shape:[k.sizeFromShape(a.shape)/d,d]}}),h=new SU(i,u,[l,d]),m=n.runWebGLProgram(h,[c,p],c.dtype),f=Ae({inputs:{x:m},backend:n,attrs:{shape:o}});return n.disposeIntermediateTensorInfo(p),n.disposeIntermediateTensorInfo(c),n.disposeIntermediateTensorInfo(m),f}var TU={kernelName:vo,backendName:"webgl",kernelFunc:NU},CU=class{constructor(e,t){this.variableNames=["A","indices"],this.outputShape=t,this.rank=t.length;let n=lt(this.rank),a=EU(e,2);this.userCode=` void main() { ${n} resRC = getOutputCoords(); setOutput(getA(${a})); } - `}};function EU(e,t){let n=["resRC.x","resRC.y","resRC.z","resRC.w"],a=[];for(let r=0;rn.disposeIntermediateTensorInfo(b)),n.makeTensorInfo(d.outputShape,w.dtype,w.values)}let f=new CU(c.shape,m),A=n.runWebGLProgram(f,[c,h],c.dtype);p.push(A);let y=Ae({inputs:{x:A},backend:n,attrs:{shape:d.outputShape}});return p.forEach(g=>n.disposeIntermediateTensorInfo(g)),y}var MU={kernelName:vo,backendName:"webgl",kernelFunc:RU},FU="return float(a > b);",$U=` + `}};function EU(e,t){let n=["resRC.x","resRC.y","resRC.z","resRC.w"],a=[];for(let r=0;rn.disposeIntermediateTensorInfo(b)),n.makeTensorInfo(d.outputShape,w.dtype,w.values)}let f=new CU(c.shape,m),A=n.runWebGLProgram(f,[c,h],c.dtype);p.push(A);let y=Ae({inputs:{x:A},backend:n,attrs:{shape:d.outputShape}});return p.forEach(g=>n.disposeIntermediateTensorInfo(g)),y}var MU={kernelName:bo,backendName:"webgl",kernelFunc:RU},FU="return float(a > b);",$U=` return vec4(greaterThan(a, b)); -`,DU=tn({opSnippet:FU,packedOpSnippet:$U,cpuKernelImpl:ZL,dtype:"bool"}),OU={kernelName:ko,backendName:"webgl",kernelFunc:DU},zU="return float(a >= b);",_U=` +`,DU=en({opSnippet:FU,packedOpSnippet:$U,cpuKernelImpl:ZL,dtype:"bool"}),OU={kernelName:wo,backendName:"webgl",kernelFunc:DU},zU="return float(a >= b);",_U=` return vec4(greaterThanEqual(a, b)); -`,PU=tn({opSnippet:zU,packedOpSnippet:_U,dtype:"bool"}),LU={kernelName:ks,backendName:"webgl",kernelFunc:PU};function WU(e){let{inputs:t,backend:n}=e,{input:a}=t;return tw(a,!0,n)}var BU={kernelName:Up,backendName:"webgl",kernelFunc:WU},VU="return float(!isnan(x) && !isinf(x));",jU=qe({opSnippet:VU,dtype:"bool"}),UU={kernelName:Io,backendName:"webgl",kernelFunc:jU},HU="return float(isinf(x));",GU=qe({opSnippet:HU,dtype:"bool"}),qU={kernelName:So,backendName:"webgl",kernelFunc:GU},XU="return float(isnan(x));",KU=qe({opSnippet:XU,dtype:"bool"}),ZU={kernelName:No,backendName:"webgl",kernelFunc:KU},YU="return float(a < b);",JU=` +`,PU=en({opSnippet:zU,packedOpSnippet:_U,dtype:"bool"}),LU={kernelName:ws,backendName:"webgl",kernelFunc:PU};function WU(e){let{inputs:t,backend:n}=e,{input:a}=t;return tw(a,!0,n)}var BU={kernelName:Up,backendName:"webgl",kernelFunc:WU},VU="return float(!isnan(x) && !isinf(x));",jU=qe({opSnippet:VU,dtype:"bool"}),UU={kernelName:ko,backendName:"webgl",kernelFunc:jU},HU="return float(isinf(x));",GU=qe({opSnippet:HU,dtype:"bool"}),qU={kernelName:Io,backendName:"webgl",kernelFunc:GU},XU="return float(isnan(x));",KU=qe({opSnippet:XU,dtype:"bool"}),ZU={kernelName:So,backendName:"webgl",kernelFunc:KU},YU="return float(a < b);",JU=` return vec4(lessThan(a, b)); -`,QU=tn({opSnippet:YU,packedOpSnippet:JU,cpuKernelImpl:YL,dtype:"bool"}),eH={kernelName:To,backendName:"webgl",kernelFunc:QU},tH="return float(a <= b);",nH=` +`,QU=en({opSnippet:YU,packedOpSnippet:JU,cpuKernelImpl:YL,dtype:"bool"}),eH={kernelName:No,backendName:"webgl",kernelFunc:QU},tH="return float(a <= b);",nH=` return vec4(lessThanEqual(a, b)); -`,aH=tn({opSnippet:tH,packedOpSnippet:nH,dtype:"bool"}),rH={kernelName:Eo,backendName:"webgl",kernelFunc:aH};function sH(e){let{backend:t,attrs:n}=e,{start:a,stop:r,num:s}=n,i=JL(a,r,s);return t.makeTensorInfo([i.length],"float32",i)}var iH={kernelName:Gp,backendName:"webgl",kernelFunc:sH},oH=`if (x < 0.0) return NAN; +`,aH=en({opSnippet:tH,packedOpSnippet:nH,dtype:"bool"}),rH={kernelName:To,backendName:"webgl",kernelFunc:aH};function sH(e){let{backend:t,attrs:n}=e,{start:a,stop:r,num:s}=n,i=JL(a,r,s);return t.makeTensorInfo([i.length],"float32",i)}var iH={kernelName:Gp,backendName:"webgl",kernelFunc:sH},oH=`if (x < 0.0) return NAN; return log(x);`,lH=` vec4 result = log(x); vec4 isNaN = vec4(lessThan(x, vec4(0.0))); @@ -3023,16 +3023,16 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam result.a = isNaN.a == 1.0 ? NAN : result.a; return result; -`,uH=qe({opSnippet:oH,packedOpSnippet:lH,cpuKernelImpl:QL}),dH={kernelName:Ns,backendName:"webgl",kernelFunc:uH},pH="return log(1.0 + x);",cH=qe({opSnippet:pH}),hH={kernelName:Co,backendName:"webgl",kernelFunc:cH},fH="return float(a >= 1.0 && b >= 1.0);",mH=` +`,uH=qe({opSnippet:oH,packedOpSnippet:lH,cpuKernelImpl:QL}),dH={kernelName:Ss,backendName:"webgl",kernelFunc:uH},pH="return log(1.0 + x);",cH=qe({opSnippet:pH}),hH={kernelName:Eo,backendName:"webgl",kernelFunc:cH},fH="return float(a >= 1.0 && b >= 1.0);",mH=` return vec4( vec4(greaterThanEqual(a, vec4(1.0))) * vec4(greaterThanEqual(b, vec4(1.0)))); -`,AH=tn({opSnippet:fH,packedOpSnippet:mH,dtype:"bool"}),yH={kernelName:Ro,backendName:"webgl",kernelFunc:AH},gH="return float(!(x >= 1.0));",xH=qe({opSnippet:gH}),bH={kernelName:ku,backendName:"webgl",kernelFunc:xH},vH="return float(a >= 1.0 || b >= 1.0);",wH=` +`,AH=en({opSnippet:fH,packedOpSnippet:mH,dtype:"bool"}),yH={kernelName:Co,backendName:"webgl",kernelFunc:AH},gH="return float(!(x >= 1.0));",xH=qe({opSnippet:gH}),bH={kernelName:ku,backendName:"webgl",kernelFunc:xH},vH="return float(a >= 1.0 || b >= 1.0);",wH=` return min( vec4(greaterThanEqual(a, vec4(1.0))) + vec4(greaterThanEqual(b, vec4(1.0))), vec4(1.0)); -`,kH=tn({opSnippet:vH,packedOpSnippet:wH,dtype:"bool"}),IH={kernelName:Iu,backendName:"webgl",kernelFunc:kH},SH=class{constructor(e,t,n,a,r){this.variableNames=["x"],this.outputShape=[];let s=t,i=e[3]-1;this.outputShape=e;let o,l=`float(${n}) + float(${a}) * sum`;r===.5?o=`inversesqrt(${l})`:r===1?o=`1.0/(${l})`:o=`exp(log(${l}) * float(-${r}));`,this.userCode=` +`,kH=en({opSnippet:vH,packedOpSnippet:wH,dtype:"bool"}),IH={kernelName:Iu,backendName:"webgl",kernelFunc:kH},SH=class{constructor(e,t,n,a,r){this.variableNames=["x"],this.outputShape=[];let s=t,i=e[3]-1;this.outputShape=e;let o,l=`float(${n}) + float(${a}) * sum`;r===.5?o=`inversesqrt(${l})`:r===1?o=`1.0/(${l})`:o=`exp(log(${l}) * float(-${r}));`,this.userCode=` void main() { ivec4 coords = getOutputCoords(); int b = coords[0]; @@ -3168,14 +3168,14 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam } setOutput(result); } - `}},RH=e=>{let{inputs:t,backend:n,attrs:a}=e,{x:r,y:s,dy:i}=t,{depthRadius:o,bias:l,alpha:d,beta:u}=a,p=new CH(r.shape,o,l,d,u);return n.runWebGLProgram(p,[r,s,i],r.dtype)},MH={kernelName:qp,backendName:"webgl",kernelFunc:RH};function FH(e,t,n,a){let r=k.sizeFromShape(t),s=k.sizeFromShape(e.shape)/r,i=Ae({inputs:{x:e},attrs:{shape:[s,r]},backend:a}),o=Ni(i,e.dtype,"max",a),l=Ae({inputs:{x:o},attrs:{shape:n},backend:a});return a.disposeIntermediateTensorInfo(i),a.disposeIntermediateTensorInfo(o),l}function aw(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{reductionIndices:s,keepDims:i}=a,o=r.shape.length,l=k.parseAxisParam(s,r.shape),d=l,u=C.getAxesPermutation(d,o),p=u!=null,c=n.shouldExecuteOnCPU([r]),h=r;if(p){if(c){let g=n.texData.get(h.dataId).values,x=new Array(o);for(let v=0;v{let{inputs:t,backend:n,attrs:a}=e,{x:r,y:s,dy:i}=t,{depthRadius:o,bias:l,alpha:d,beta:u}=a,p=new CH(r.shape,o,l,d,u);return n.runWebGLProgram(p,[r,s,i],r.dtype)},MH={kernelName:qp,backendName:"webgl",kernelFunc:RH};function FH(e,t,n,a){let r=k.sizeFromShape(t),s=k.sizeFromShape(e.shape)/r,i=Ae({inputs:{x:e},attrs:{shape:[s,r]},backend:a}),o=Si(i,e.dtype,"max",a),l=Ae({inputs:{x:o},attrs:{shape:n},backend:a});return a.disposeIntermediateTensorInfo(i),a.disposeIntermediateTensorInfo(o),l}function aw(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{reductionIndices:s,keepDims:i}=a,o=r.shape.length,l=k.parseAxisParam(s,r.shape),d=l,u=C.getAxesPermutation(d,o),p=u!=null,c=n.shouldExecuteOnCPU([r]),h=r;if(p){if(c){let g=n.texData.get(h.dataId).values,x=new Array(o);for(let v=0;v`Error in maxPool: Either strides or dilations must be 1. Got strides ${i} and dilations '${d}'`);let u=C.computePool2DInfo(r.shape,s,i,d,o,l);if(u.filterWidth===1&&u.filterHeight===1&&k.arraysEqual(u.inShape,u.outShape))return Ln({inputs:{x:r},backend:n});let p=new yd(u,"max",!1);return n.runWebGLProgram(p,[r],r.dtype)}var LH={kernelName:Cs,backendName:"webgl",kernelFunc:PH};function WH(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{filterSize:s,strides:i,pad:o,dataFormat:l,dimRoundingMode:d}=a,u=[1,1,1],p=C.computePool3DInfo(r.shape,s,i,u,o,d,l),c=new g1(p,"max",!1);return n.runWebGLProgram(c,[r],r.dtype)}var BH={kernelName:Nu,backendName:"webgl",kernelFunc:WH},VH=class{constructor(e){this.variableNames=["dy","maxPos"],this.outputShape=e.inShape;let t=e.strideHeight,n=e.strideWidth,a=e.dilationHeight,r=e.effectiveFilterHeight,s=e.effectiveFilterWidth,i=r-1-e.padInfo.top,o=s-1-e.padInfo.left,l=r*s-1;this.userCode=` +`,zH=en({opSnippet:DH,packedOpSnippet:OH,cpuKernelImpl:tW}),_H={kernelName:Ts,backendName:"webgl",kernelFunc:zH};function PH(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t;El(r,"maxPool");let{filterSize:s,strides:i,pad:o,dimRoundingMode:l}=a,d=1;k.assert(C.eitherStridesOrDilationsAreOne(i,d),()=>`Error in maxPool: Either strides or dilations must be 1. Got strides ${i} and dilations '${d}'`);let u=C.computePool2DInfo(r.shape,s,i,d,o,l);if(u.filterWidth===1&&u.filterHeight===1&&k.arraysEqual(u.inShape,u.outShape))return Pn({inputs:{x:r},backend:n});let p=new yd(u,"max",!1);return n.runWebGLProgram(p,[r],r.dtype)}var LH={kernelName:Es,backendName:"webgl",kernelFunc:PH};function WH(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{filterSize:s,strides:i,pad:o,dataFormat:l,dimRoundingMode:d}=a,u=[1,1,1],p=C.computePool3DInfo(r.shape,s,i,u,o,d,l),c=new g1(p,"max",!1);return n.runWebGLProgram(c,[r],r.dtype)}var BH={kernelName:Nu,backendName:"webgl",kernelFunc:WH},VH=class{constructor(e){this.variableNames=["dy","maxPos"],this.outputShape=e.inShape;let t=e.strideHeight,n=e.strideWidth,a=e.dilationHeight,r=e.effectiveFilterHeight,s=e.effectiveFilterWidth,i=r-1-e.padInfo.top,o=s-1-e.padInfo.left,l=r*s-1;this.userCode=` const ivec2 pads = ivec2(${i}, ${o}); void main() { @@ -3285,14 +3285,14 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam } setOutput(dotProd); } - `}};function UH(e){let{inputs:t,backend:n,attrs:a}=e,{dy:r,input:s}=t,i=s,{filterSize:o,strides:l,pad:d,dimRoundingMode:u}=a,p=[1,1,1],c=C.computePool3DInfo(i.shape,o,l,p,d,u),h=new g1(c,"max",!0),m=n.runWebGLProgram(h,[i],i.dtype),f=new jH(c),A=n.runWebGLProgram(f,[r,m],i.dtype);return n.disposeIntermediateTensorInfo(m),A}var HH={kernelName:Kp,backendName:"webgl",kernelFunc:UH};function GH(e){let{inputs:t,backend:n,attrs:a}=e,{dy:r,input:s,output:i}=t,o=s;Cl([s,i],"maxPoolGrad");let{filterSize:l,strides:d,pad:u,dimRoundingMode:p}=a,c=C.computePool2DInfo(o.shape,l,d,1,u,p),h=!0,m=new yd(c,"max",h),f=n.runWebGLProgram(m,[o],o.dtype),A=new VH(c),y=n.runWebGLProgram(A,[r,f],o.dtype);return n.disposeIntermediateTensorInfo(f),y}var qH={kernelName:Xp,backendName:"webgl",kernelFunc:GH};function XH(e,t,n,a){let r=new yd(n,"max",!1),s=a.runWebGLProgram(r,[e],"float32");r=new yd(n,"max",!0,!0,t);let i=a.runWebGLProgram(r,[e],"float32");return[s,i]}var KH={kernelName:Zp,backendName:"webgl",kernelFunc:({inputs:e,attrs:t,backend:n})=>{let{x:a}=e,{filterSize:r,strides:s,pad:i,includeBatchInIndex:o}=t,l=n;k.assert(a.shape.length===4,()=>`Error in maxPool: input must be rank 4 but got rank ${a.shape.length}.`);let d=[1,1];k.assert(C.eitherStridesOrDilationsAreOne(s,d),()=>`Error in maxPool: Either strides or dilations must be 1. Got strides ${s} and dilations '${d}'`);let u=C.computePool2DInfo(a.shape,r,s,d,i),[p,c]=XH(a,o,u,l);return[p,c]}};function ZH(e,t,n,a){let r=k.sizeFromShape(t),s=k.sizeFromShape(e.shape)/r,i=Ae({inputs:{x:e},attrs:{shape:[s,r]},backend:a}),o=Ni(i,"float32","mean",a),l=Ae({inputs:{x:o},attrs:{shape:n},backend:a});return a.disposeIntermediateTensorInfo(i),a.disposeIntermediateTensorInfo(o),l}var YH={kernelName:Rs,backendName:"webgl",kernelFunc:({inputs:e,attrs:t,backend:n})=>{let{x:a}=e,{keepDims:r,axis:s}=t,i=n,o=a.shape.length,l=k.parseAxisParam(s,a.shape),d=l,u=C.getAxesPermutation(d,o),p=u!=null,c=i.shouldExecuteOnCPU([a]),h=[],m=a;if(p){if(c){let x=i.texData.get(m.dataId).values,w=new Array(o);for(let N=0;N{let{x:a}=e,{filterSize:r,strides:s,pad:i,includeBatchInIndex:o}=t,l=n;k.assert(a.shape.length===4,()=>`Error in maxPool: input must be rank 4 but got rank ${a.shape.length}.`);let d=[1,1];k.assert(C.eitherStridesOrDilationsAreOne(s,d),()=>`Error in maxPool: Either strides or dilations must be 1. Got strides ${s} and dilations '${d}'`);let u=C.computePool2DInfo(a.shape,r,s,d,i),[p,c]=XH(a,o,u,l);return[p,c]}};function ZH(e,t,n,a){let r=k.sizeFromShape(t),s=k.sizeFromShape(e.shape)/r,i=Ae({inputs:{x:e},attrs:{shape:[s,r]},backend:a}),o=Si(i,"float32","mean",a),l=Ae({inputs:{x:o},attrs:{shape:n},backend:a});return a.disposeIntermediateTensorInfo(i),a.disposeIntermediateTensorInfo(o),l}var YH={kernelName:Cs,backendName:"webgl",kernelFunc:({inputs:e,attrs:t,backend:n})=>{let{x:a}=e,{keepDims:r,axis:s}=t,i=n,o=a.shape.length,l=k.parseAxisParam(s,a.shape),d=l,u=C.getAxesPermutation(d,o),p=u!=null,c=i.shouldExecuteOnCPU([a]),h=[],m=a;if(p){if(c){let x=i.texData.get(m.dataId).values,w=new Array(o);for(let N=0;Nd[0]+e[u]+d[1]);let a=e.length,r=lt(a),s=t.map(d=>d[0]).join(","),i=t.map((d,u)=>d[0]+e[u]).join(","),o=["coords[0]","coords[1]","coords[2]","coords[3]"].slice(0,a),l=n==="reflect"?0:1;if(a===1){this.userCode=` +`,nG=en({opSnippet:eG,packedOpSnippet:tG,cpuKernelImpl:nW}),aG={kernelName:Ms,backendName:"webgl",kernelFunc:nG},rG=class{constructor(e,t,n){this.variableNames=["x"],this.outputShape=t.map((d,u)=>d[0]+e[u]+d[1]);let a=e.length,r=lt(a),s=t.map(d=>d[0]).join(","),i=t.map((d,u)=>d[0]+e[u]).join(","),o=["coords[0]","coords[1]","coords[2]","coords[3]"].slice(0,a),l=n==="reflect"?0:1;if(a===1){this.userCode=` int start = ${s}; int end = ${i}; @@ -3321,7 +3321,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam ${r} coords = outC - start; setOutput(getX(${o})); } - `}},sG=class{constructor(e,t,n){this.variableNames=["x"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=t.map((h,m)=>h[0]+e[m]+h[1]);let a=e.length,r=lt(a),s=t.map(h=>h[0]).join(","),i=t.map((h,m)=>h[0]+e[m]).join(","),o=cn("rc",a),l=cn("source",a),d=`${o[a-1]} < ${this.outputShape[a-1]}`,u=a===1?"source":`vec2(${l.slice(-2).join()})`,p=n==="reflect"?0:1,c="";if(a===1){let h=` + `}},sG=class{constructor(e,t,n){this.variableNames=["x"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=t.map((h,m)=>h[0]+e[m]+h[1]);let a=e.length,r=lt(a),s=t.map(h=>h[0]).join(","),i=t.map((h,m)=>h[0]+e[m]).join(","),o=pn("rc",a),l=pn("source",a),d=`${o[a-1]} < ${this.outputShape[a-1]}`,u=a===1?"source":`vec2(${l.slice(-2).join()})`,p=n==="reflect"?0:1,c="";if(a===1){let h=` ${r} source = rc; if (source < start) { source = start * 2 - source - ${p}; @@ -3377,13 +3377,13 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,YB=qe({opSnippet:ZB}),JB={kernelNam ${c} setOutput(result); } - `}},iG=({inputs:e,backend:t,attrs:n})=>{let{x:a}=e,{paddings:r,mode:s}=n,i=J().getBool("WEBGL_PACK_ARRAY_OPERATIONS")?new sG(a.shape,r,s):new rG(a.shape,r,s);return t.runWebGLProgram(i,[a],a.dtype)},oG={kernelName:$s,backendName:"webgl",kernelFunc:iG},lG=`if (b == 0.0) return NAN; + `}},iG=({inputs:e,backend:t,attrs:n})=>{let{x:a}=e,{paddings:r,mode:s}=n,i=J().getBool("WEBGL_PACK_ARRAY_OPERATIONS")?new sG(a.shape,r,s):new rG(a.shape,r,s);return t.runWebGLProgram(i,[a],a.dtype)},oG={kernelName:Fs,backendName:"webgl",kernelFunc:iG},lG=`if (b == 0.0) return NAN; return mod(a, b);`,uG=` vec4 result = mod(a, b); vec4 isNaN = vec4(equal(b, vec4(0.0))); `+yh+` return result; -`,dG=tn({opSnippet:lG,packedOpSnippet:uG}),pG={kernelName:Mo,backendName:"webgl",kernelFunc:dG},cG=class{constructor(e,t,n){this.variableNames=["probs"],this.outputShape=[e,n],this.userCode=` +`,dG=en({opSnippet:lG,packedOpSnippet:uG}),pG={kernelName:Ro,backendName:"webgl",kernelFunc:dG},cG=class{constructor(e,t,n){this.variableNames=["probs"],this.outputShape=[e,n],this.userCode=` uniform float seed; void main() { @@ -3427,14 +3427,14 @@ return a / b;`,fG=` } return result; -`,rw=tn({opSnippet:hG,packedOpSnippet:fG,checkOutOfBounds:!0}),mG={kernelName:gs,backendName:"webgl",kernelFunc:rw},sw="return a - b;",iw=tn({opSnippet:sw,packedOpSnippet:sw,supportsComplex:!0,cpuKernelImpl:cW}),AG={kernelName:Ys,backendName:"webgl",kernelFunc:iw};function ow(e){let{inputs:t,backend:n,attrs:a}=e,{logits:r}=t,{dim:s}=a,i=k.parseAxisParam([s],r.shape),o=aw({inputs:{x:r},backend:n,attrs:{reductionIndices:i,keepDims:!1}}),l=C.expandShapeToKeepDim(o.shape,i),d=Ae({inputs:{x:o},backend:n,attrs:{shape:l}}),u=iw({inputs:{a:r,b:d},backend:n}),p=Jv({inputs:{x:u},backend:n}),c=bh({inputs:{x:p},backend:n,attrs:{axis:i,keepDims:!1}}),h=Ae({inputs:{x:c},backend:n,attrs:{shape:l}}),m=rw({inputs:{a:p,b:h},backend:n});return n.disposeIntermediateTensorInfo(o),n.disposeIntermediateTensorInfo(d),n.disposeIntermediateTensorInfo(u),n.disposeIntermediateTensorInfo(p),n.disposeIntermediateTensorInfo(c),n.disposeIntermediateTensorInfo(h),m}var yG={kernelName:Ks,backendName:"webgl",kernelFunc:ow};function gG(e){let{inputs:t,backend:n,attrs:a}=e,{logits:r}=t,{numSamples:s,seed:i,normalized:o}=a,l=o?r:ow({inputs:{logits:r},backend:n,attrs:{dim:r.shape.length-1}}),d=l.shape[0],u=l.shape[1],p=new cG(d,u,s),c=p.getCustomSetupFunc(i),h=n.runWebGLProgram(p,[l],"int32",c);return o||n.disposeIntermediateTensorInfo(l),h}var xG={kernelName:Yp,backendName:"webgl",kernelFunc:gG},lw="return -x;";function bG(e){let{inputs:t,backend:n}=e,{x:a}=t;if(n.shouldExecuteOnCPU([a])){let s=n.texData.get(a.dataId),[i,o]=rW(s.values,a.shape,a.dtype);return n.makeTensorInfo(o,a.dtype,i)}let r;return J().getBool("WEBGL_PACK_UNARY_OPERATIONS")?r=new Ol(a.shape,lw):r=new Lr(a.shape,lw),n.runWebGLProgram(r,[a],a.dtype)}var vG={kernelName:Fo,backendName:"webgl",kernelFunc:bG},wG=Wa.nonMaxSuppressionV3Impl;function kG(e){C.warn("tf.nonMaxSuppression() in webgl locks the UI thread. Call tf.nonMaxSuppressionAsync() instead");let{inputs:t,backend:n,attrs:a}=e,{boxes:r,scores:s}=t,{maxOutputSize:i,iouThreshold:o,scoreThreshold:l}=a,d=n.readSync(r.dataId),u=n.readSync(s.dataId),{selectedIndices:p}=wG(d,u,i,o,l);return n.makeTensorInfo([p.length],"int32",new Int32Array(p))}var IG={kernelName:Do,backendName:"webgl",kernelFunc:kG},SG=Wa.nonMaxSuppressionV4Impl;function NG(e){C.warn("tf.nonMaxSuppression() in webgl locks the UI thread. Call tf.nonMaxSuppressionAsync() instead");let{inputs:t,backend:n,attrs:a}=e,{boxes:r,scores:s}=t,{maxOutputSize:i,iouThreshold:o,scoreThreshold:l,padToMaxOutputSize:d}=a,u=n.readSync(r.dataId),p=n.readSync(s.dataId),{selectedIndices:c,validOutputs:h}=SG(u,p,i,o,l,d);return[n.makeTensorInfo([c.length],"int32",new Int32Array(c)),n.makeTensorInfo([],"int32",new Int32Array([h]))]}var TG={kernelName:Oo,backendName:"webgl",kernelFunc:NG},EG=Wa.nonMaxSuppressionV5Impl;function CG(e){C.warn("tf.nonMaxSuppression() in webgl locks the UI thread. Call tf.nonMaxSuppressionAsync() instead");let{inputs:t,backend:n,attrs:a}=e,{boxes:r,scores:s}=t,{maxOutputSize:i,iouThreshold:o,scoreThreshold:l,softNmsSigma:d}=a,u=n.readSync(r.dataId),p=n.readSync(s.dataId),c=i,h=o,m=l,f=d,{selectedIndices:A,selectedScores:y}=EG(u,p,c,h,m,f);return[n.makeTensorInfo([A.length],"int32",new Int32Array(A)),n.makeTensorInfo([y.length],"float32",new Float32Array(y))]}var RG={kernelName:zo,backendName:"webgl",kernelFunc:CG},MG=class{constructor(e,t,n,a){this.variableNames=["indices"],this.outputShape=[e,t],this.userCode=` +`,rw=en({opSnippet:hG,packedOpSnippet:fG,checkOutOfBounds:!0}),mG={kernelName:ys,backendName:"webgl",kernelFunc:rw},sw="return a - b;",iw=en({opSnippet:sw,packedOpSnippet:sw,supportsComplex:!0,cpuKernelImpl:cW}),AG={kernelName:Zs,backendName:"webgl",kernelFunc:iw};function ow(e){let{inputs:t,backend:n,attrs:a}=e,{logits:r}=t,{dim:s}=a,i=k.parseAxisParam([s],r.shape),o=aw({inputs:{x:r},backend:n,attrs:{reductionIndices:i,keepDims:!1}}),l=C.expandShapeToKeepDim(o.shape,i),d=Ae({inputs:{x:o},backend:n,attrs:{shape:l}}),u=iw({inputs:{a:r,b:d},backend:n}),p=Jv({inputs:{x:u},backend:n}),c=bh({inputs:{x:p},backend:n,attrs:{axis:i,keepDims:!1}}),h=Ae({inputs:{x:c},backend:n,attrs:{shape:l}}),m=rw({inputs:{a:p,b:h},backend:n});return n.disposeIntermediateTensorInfo(o),n.disposeIntermediateTensorInfo(d),n.disposeIntermediateTensorInfo(u),n.disposeIntermediateTensorInfo(p),n.disposeIntermediateTensorInfo(c),n.disposeIntermediateTensorInfo(h),m}var yG={kernelName:Xs,backendName:"webgl",kernelFunc:ow};function gG(e){let{inputs:t,backend:n,attrs:a}=e,{logits:r}=t,{numSamples:s,seed:i,normalized:o}=a,l=o?r:ow({inputs:{logits:r},backend:n,attrs:{dim:r.shape.length-1}}),d=l.shape[0],u=l.shape[1],p=new cG(d,u,s),c=p.getCustomSetupFunc(i),h=n.runWebGLProgram(p,[l],"int32",c);return o||n.disposeIntermediateTensorInfo(l),h}var xG={kernelName:Yp,backendName:"webgl",kernelFunc:gG},lw="return -x;";function bG(e){let{inputs:t,backend:n}=e,{x:a}=t;if(n.shouldExecuteOnCPU([a])){let s=n.texData.get(a.dataId),[i,o]=rW(s.values,a.shape,a.dtype);return n.makeTensorInfo(o,a.dtype,i)}let r;return J().getBool("WEBGL_PACK_UNARY_OPERATIONS")?r=new Dl(a.shape,lw):r=new Pr(a.shape,lw),n.runWebGLProgram(r,[a],a.dtype)}var vG={kernelName:Mo,backendName:"webgl",kernelFunc:bG},wG=La.nonMaxSuppressionV3Impl;function kG(e){C.warn("tf.nonMaxSuppression() in webgl locks the UI thread. Call tf.nonMaxSuppressionAsync() instead");let{inputs:t,backend:n,attrs:a}=e,{boxes:r,scores:s}=t,{maxOutputSize:i,iouThreshold:o,scoreThreshold:l}=a,d=n.readSync(r.dataId),u=n.readSync(s.dataId),{selectedIndices:p}=wG(d,u,i,o,l);return n.makeTensorInfo([p.length],"int32",new Int32Array(p))}var IG={kernelName:$o,backendName:"webgl",kernelFunc:kG},SG=La.nonMaxSuppressionV4Impl;function NG(e){C.warn("tf.nonMaxSuppression() in webgl locks the UI thread. Call tf.nonMaxSuppressionAsync() instead");let{inputs:t,backend:n,attrs:a}=e,{boxes:r,scores:s}=t,{maxOutputSize:i,iouThreshold:o,scoreThreshold:l,padToMaxOutputSize:d}=a,u=n.readSync(r.dataId),p=n.readSync(s.dataId),{selectedIndices:c,validOutputs:h}=SG(u,p,i,o,l,d);return[n.makeTensorInfo([c.length],"int32",new Int32Array(c)),n.makeTensorInfo([],"int32",new Int32Array([h]))]}var TG={kernelName:Do,backendName:"webgl",kernelFunc:NG},EG=La.nonMaxSuppressionV5Impl;function CG(e){C.warn("tf.nonMaxSuppression() in webgl locks the UI thread. Call tf.nonMaxSuppressionAsync() instead");let{inputs:t,backend:n,attrs:a}=e,{boxes:r,scores:s}=t,{maxOutputSize:i,iouThreshold:o,scoreThreshold:l,softNmsSigma:d}=a,u=n.readSync(r.dataId),p=n.readSync(s.dataId),c=i,h=o,m=l,f=d,{selectedIndices:A,selectedScores:y}=EG(u,p,c,h,m,f);return[n.makeTensorInfo([A.length],"int32",new Int32Array(A)),n.makeTensorInfo([y.length],"float32",new Float32Array(y))]}var RG={kernelName:Oo,backendName:"webgl",kernelFunc:CG},MG=class{constructor(e,t,n,a){this.variableNames=["indices"],this.outputShape=[e,t],this.userCode=` void main() { ivec2 coords = getOutputCoords(); int index = round(getIndices(coords.x)); setOutput(mix(float(${a}), float(${n}), float(index == coords.y))); } - `}},FG=e=>{let{inputs:t,backend:n,attrs:a}=e,{indices:r}=t,{depth:s,onValue:i,offValue:o}=a,l=k.sizeFromShape(r.shape),d=new MG(l,s,i,o),u=Ae({inputs:{x:r},backend:n,attrs:{shape:[l]}}),p=n.runWebGLProgram(d,[u],r.dtype);n.disposeIntermediateTensorInfo(u);let c=[...r.shape,s],h=Ae({inputs:{x:p},backend:n,attrs:{shape:c}});return n.disposeIntermediateTensorInfo(p),h},$G={kernelName:Os,backendName:"webgl",kernelFunc:FG};function Sh(e){let{inputs:t,backend:n}=e,{x:a}=t;if(a.dtype==="complex64"){let r=xd({inputs:{input:a},backend:n}),s=Sh({inputs:{x:r},backend:n}),i=Ih({inputs:{input:a},backend:n}),o=Sh({inputs:{x:i},backend:n}),l=Wr({inputs:{real:s,imag:o},backend:n});return n.disposeIntermediateTensorInfo(r),n.disposeIntermediateTensorInfo(s),n.disposeIntermediateTensorInfo(i),n.disposeIntermediateTensorInfo(o),l}else return w1({attrs:{shape:a.shape,dtype:a.dtype,value:a.dtype==="string"?"":0},backend:n})}var DG={kernelName:el,backendName:"webgl",kernelFunc:Sh};function uw(e){let{inputs:t,backend:n}=e,{x:a}=t;if(a.dtype==="string")throw new Error("onesLike is not supported under string dtype");if(a.dtype==="complex64"){let r=xd({inputs:{input:a},backend:n}),s=uw({inputs:{x:r},backend:n}),i=Ih({inputs:{input:a},backend:n}),o=Sh({inputs:{x:i},backend:n}),l=Wr({inputs:{real:s,imag:o},backend:n});return n.disposeIntermediateTensorInfo(r),n.disposeIntermediateTensorInfo(s),n.disposeIntermediateTensorInfo(i),n.disposeIntermediateTensorInfo(o),l}else return w1({attrs:{shape:a.shape,dtype:a.dtype,value:1},backend:n})}var OG={kernelName:_o,backendName:"webgl",kernelFunc:uw};function zG(e){let{inputs:t,backend:n,attrs:a}=e,{axis:r}=a;if(t.length===1)return v1({inputs:{input:t[0]},backend:n,attrs:{dim:r}});let s=t[0].shape,i=t[0].dtype;t.forEach(u=>{k.assertShapesMatch(s,u.shape,"All tensors passed to stack must have matching shapes"),k.assert(i===u.dtype,()=>"All tensors passed to stack must have matching dtypes")});let o=[],l=t.map(u=>{let p=v1({inputs:{input:u},backend:n,attrs:{dim:r}});return o.push(p),p}),d=Vv({inputs:l,backend:n,attrs:{axis:r}});return o.forEach(u=>n.disposeIntermediateTensorInfo(u)),d}var _G={kernelName:Po,backendName:"webgl",kernelFunc:zG},PG=class{constructor(e,t,n){this.variableNames=["x"],this.outputShape=t.map((l,d)=>l[0]+e[d]+l[1]);let a=e.length,r=lt(a),s=t.map(l=>l[0]).join(","),i=t.map((l,d)=>l[0]+e[d]).join(","),o=["coords[0]","coords[1]","coords[2]","coords[3]"].slice(0,a);if(a===1){this.userCode=` + `}},FG=e=>{let{inputs:t,backend:n,attrs:a}=e,{indices:r}=t,{depth:s,onValue:i,offValue:o}=a,l=k.sizeFromShape(r.shape),d=new MG(l,s,i,o),u=Ae({inputs:{x:r},backend:n,attrs:{shape:[l]}}),p=n.runWebGLProgram(d,[u],r.dtype);n.disposeIntermediateTensorInfo(u);let c=[...r.shape,s],h=Ae({inputs:{x:p},backend:n,attrs:{shape:c}});return n.disposeIntermediateTensorInfo(p),h},$G={kernelName:Ds,backendName:"webgl",kernelFunc:FG};function Sh(e){let{inputs:t,backend:n}=e,{x:a}=t;if(a.dtype==="complex64"){let r=xd({inputs:{input:a},backend:n}),s=Sh({inputs:{x:r},backend:n}),i=Ih({inputs:{input:a},backend:n}),o=Sh({inputs:{x:i},backend:n}),l=Lr({inputs:{real:s,imag:o},backend:n});return n.disposeIntermediateTensorInfo(r),n.disposeIntermediateTensorInfo(s),n.disposeIntermediateTensorInfo(i),n.disposeIntermediateTensorInfo(o),l}else return w1({attrs:{shape:a.shape,dtype:a.dtype,value:a.dtype==="string"?"":0},backend:n})}var DG={kernelName:Qo,backendName:"webgl",kernelFunc:Sh};function uw(e){let{inputs:t,backend:n}=e,{x:a}=t;if(a.dtype==="string")throw new Error("onesLike is not supported under string dtype");if(a.dtype==="complex64"){let r=xd({inputs:{input:a},backend:n}),s=uw({inputs:{x:r},backend:n}),i=Ih({inputs:{input:a},backend:n}),o=Sh({inputs:{x:i},backend:n}),l=Lr({inputs:{real:s,imag:o},backend:n});return n.disposeIntermediateTensorInfo(r),n.disposeIntermediateTensorInfo(s),n.disposeIntermediateTensorInfo(i),n.disposeIntermediateTensorInfo(o),l}else return w1({attrs:{shape:a.shape,dtype:a.dtype,value:1},backend:n})}var OG={kernelName:zo,backendName:"webgl",kernelFunc:uw};function zG(e){let{inputs:t,backend:n,attrs:a}=e,{axis:r}=a;if(t.length===1)return v1({inputs:{input:t[0]},backend:n,attrs:{dim:r}});let s=t[0].shape,i=t[0].dtype;t.forEach(u=>{k.assertShapesMatch(s,u.shape,"All tensors passed to stack must have matching shapes"),k.assert(i===u.dtype,()=>"All tensors passed to stack must have matching dtypes")});let o=[],l=t.map(u=>{let p=v1({inputs:{input:u},backend:n,attrs:{dim:r}});return o.push(p),p}),d=Vv({inputs:l,backend:n,attrs:{axis:r}});return o.forEach(u=>n.disposeIntermediateTensorInfo(u)),d}var _G={kernelName:_o,backendName:"webgl",kernelFunc:zG},PG=class{constructor(e,t,n){this.variableNames=["x"],this.outputShape=t.map((l,d)=>l[0]+e[d]+l[1]);let a=e.length,r=lt(a),s=t.map(l=>l[0]).join(","),i=t.map((l,d)=>l[0]+e[d]).join(","),o=["coords[0]","coords[1]","coords[2]","coords[3]"].slice(0,a);if(a===1){this.userCode=` int start = ${s}; int end = ${i}; uniform float value; @@ -3461,7 +3461,7 @@ return a / b;`,fG=` setOutput(getX(${o})); } } - `}getCustomSetupFunc(e){return(t,n)=>{this.valueLoc==null&&(this.valueLoc=t.getUniformLocationNoThrow(n,"value")),t.gl.uniform1f(this.valueLoc,e)}}},LG=class{constructor(e,t,n){this.variableNames=["x"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=t.map((m,f)=>m[0]+e[f]+m[1]);let a=e.length,r=lt(a),s=t.map(m=>m[0]).join(","),i=t.map((m,f)=>m[0]+e[f]).join(","),o=cn("rc",a),l=cn("source",a),d=`${o[a-1]} < ${this.outputShape[a-1]}`,u=a===1?"source":`vec2(${l.slice(-2).join()})`,p=[`${r} rc = outputLoc;`,`${o[a-1]} += 1; + `}getCustomSetupFunc(e){return(t,n)=>{this.valueLoc==null&&(this.valueLoc=t.getUniformLocationNoThrow(n,"value")),t.gl.uniform1f(this.valueLoc,e)}}},LG=class{constructor(e,t,n){this.variableNames=["x"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=t.map((m,f)=>m[0]+e[f]+m[1]);let a=e.length,r=lt(a),s=t.map(m=>m[0]).join(","),i=t.map((m,f)=>m[0]+e[f]).join(","),o=pn("rc",a),l=pn("source",a),d=`${o[a-1]} < ${this.outputShape[a-1]}`,u=a===1?"source":`vec2(${l.slice(-2).join()})`,p=[`${r} rc = outputLoc;`,`${o[a-1]} += 1; if(${d}) { `,a===1?"":`} rc = outputLoc; @@ -3486,7 +3486,7 @@ return a / b;`,fG=` ${h} setOutput(result); } - `}getCustomSetupFunc(e){return(t,n)=>{this.valueLoc==null&&(this.valueLoc=t.getUniformLocationNoThrow(n,"value")),t.gl.uniform1f(this.valueLoc,e)}}},dw=e=>{let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{paddings:s,constantValue:i}=a,o=J().getBool("WEBGL_PACK_ARRAY_OPERATIONS")?new LG(r.shape,s,i):new PG(r.shape,s,i),l=o.getCustomSetupFunc(i);return n.runWebGLProgram(o,[r],r.dtype,l)},WG={kernelName:zs,backendName:"webgl",kernelFunc:dw},BG=` + `}getCustomSetupFunc(e){return(t,n)=>{this.valueLoc==null&&(this.valueLoc=t.getUniformLocationNoThrow(n,"value")),t.gl.uniform1f(this.valueLoc,e)}}},dw=e=>{let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{paddings:s,constantValue:i}=a,o=J().getBool("WEBGL_PACK_ARRAY_OPERATIONS")?new LG(r.shape,s,i):new PG(r.shape,s,i),l=o.getCustomSetupFunc(i);return n.runWebGLProgram(o,[r],r.dtype,l)},WG={kernelName:Os,backendName:"webgl",kernelFunc:dw},BG=` if(a < 0.0 && floor(b) < b){ return NAN; } @@ -3511,7 +3511,7 @@ return a / b;`,fG=` vec4 isNaN = vec4(lessThan(a, vec4(0.0))) * vec4(lessThan(floor(b), b)); `+yh+` return result; -`,jG=tn({opSnippet:BG,packedOpSnippet:VG}),UG={kernelName:_s,backendName:"webgl",kernelFunc:jG};function HG(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{axis:s,keepDims:i}=a,o=r.shape.length,l=[],d=k.parseAxisParam(s,r.shape),u=d,p=C.getAxesPermutation(u,o),c=r;p!=null&&(c=hn({inputs:{x:r},backend:n,attrs:{perm:p}}),u=C.getInnerMostAxes(u.length,o),l.push(c)),C.assertAxesAreInnerMostDims("prod",u,o);let h;if(n.shouldExecuteOnCPU([c])){let m=n.texData.get(c.dataId).values,{outVals:f,outShape:A,outDtype:y}=sW(c.shape,c.dtype,m,u);h=n.makeTensorInfo(A,y,f)}else{let[m,f]=C.computeOutAndReduceShapes(c.shape,u),A=k.sizeFromShape(f),y=Ae({inputs:{x:c},backend:n,attrs:{shape:[-1,A]}}),g=dc(r.dtype),x=Ni(y,g,"prod",n);h=Ae({inputs:{x},backend:n,attrs:{shape:m}}),l.push(y),l.push(x)}if(i){l.push(h);let m=C.expandShapeToKeepDim(h.shape,d);h=Ae({inputs:{x:h},backend:n,attrs:{shape:m}})}return l.forEach(m=>n.disposeIntermediateTensorInfo(m)),h}var GG={kernelName:Lo,backendName:"webgl",kernelFunc:HG},pw=e=>{let{backend:t,attrs:n}=e,{start:a,stop:r,step:s,dtype:i}=n,o=iW(a,r,s,i);return t.makeTensorInfo([o.length],i,o)},qG={kernelName:Tu,backendName:"webgl",kernelFunc:pw},XG="return 1.0 / x;",KG=qe({opSnippet:XG}),ZG={kernelName:Wo,backendName:"webgl",kernelFunc:KG},YG=xa+` +`,jG=en({opSnippet:BG,packedOpSnippet:VG}),UG={kernelName:zs,backendName:"webgl",kernelFunc:jG};function HG(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{axis:s,keepDims:i}=a,o=r.shape.length,l=[],d=k.parseAxisParam(s,r.shape),u=d,p=C.getAxesPermutation(u,o),c=r;p!=null&&(c=cn({inputs:{x:r},backend:n,attrs:{perm:p}}),u=C.getInnerMostAxes(u.length,o),l.push(c)),C.assertAxesAreInnerMostDims("prod",u,o);let h;if(n.shouldExecuteOnCPU([c])){let m=n.texData.get(c.dataId).values,{outVals:f,outShape:A,outDtype:y}=sW(c.shape,c.dtype,m,u);h=n.makeTensorInfo(A,y,f)}else{let[m,f]=C.computeOutAndReduceShapes(c.shape,u),A=k.sizeFromShape(f),y=Ae({inputs:{x:c},backend:n,attrs:{shape:[-1,A]}}),g=dc(r.dtype),x=Si(y,g,"prod",n);h=Ae({inputs:{x},backend:n,attrs:{shape:m}}),l.push(y),l.push(x)}if(i){l.push(h);let m=C.expandShapeToKeepDim(h.shape,d);h=Ae({inputs:{x:h},backend:n,attrs:{shape:m}})}return l.forEach(m=>n.disposeIntermediateTensorInfo(m)),h}var GG={kernelName:Po,backendName:"webgl",kernelFunc:HG},pw=e=>{let{backend:t,attrs:n}=e,{start:a,stop:r,step:s,dtype:i}=n,o=iW(a,r,s,i);return t.makeTensorInfo([o.length],i,o)},qG={kernelName:Tu,backendName:"webgl",kernelFunc:pw},XG="return 1.0 / x;",KG=qe({opSnippet:XG}),ZG={kernelName:Lo,backendName:"webgl",kernelFunc:KG},YG=ga+` return (x < 0.0) ? 0.0 : x; `,JG=` vec4 result = x * vec4(greaterThanEqual(x, vec4(0.0))); @@ -3523,7 +3523,7 @@ return a / b;`,fG=` result.a = isNaN.a ? x.a : result.a; return result; -`,QG=qe({opSnippet:YG,packedOpSnippet:JG}),eq={kernelName:Ls,backendName:"webgl",kernelFunc:QG},tq=xa+` +`,QG=qe({opSnippet:YG,packedOpSnippet:JG}),eq={kernelName:Ps,backendName:"webgl",kernelFunc:QG},tq=ga+` return (x < 0.0) ? 0.0 : min(6.0, x); `,nq=` vec4 result = min(x, vec4(6.)) * vec4(greaterThanEqual(x, vec4(0.0))); @@ -3535,7 +3535,7 @@ return a / b;`,fG=` result.a = isNaN.a ? x.a : result.a; return result; -`,aq=qe({opSnippet:tq,packedOpSnippet:nq}),rq={kernelName:Bs,backendName:"webgl",kernelFunc:aq},sq=class{constructor(e,t,n,a,r){this.variableNames=["A"],this.outputShape=[];let[s,i,o,l]=e;this.outputShape=[s,t,n,l];let d=[a&&t>1?i-1:i,a&&n>1?o-1:o],u=[a&&t>1?t-1:t,a&&n>1?n-1:n],p;r?p="(vec2(yRC) + vec2(0.5)) * effectiveInputOverOutputRatioRC - vec2(0.5)":p="vec2(yRC) * effectiveInputOverOutputRatioRC",this.userCode=` +`,aq=qe({opSnippet:tq,packedOpSnippet:nq}),rq={kernelName:Ws,backendName:"webgl",kernelFunc:aq},sq=class{constructor(e,t,n,a,r){this.variableNames=["A"],this.outputShape=[];let[s,i,o,l]=e;this.outputShape=[s,t,n,l];let d=[a&&t>1?i-1:i,a&&n>1?o-1:o],u=[a&&t>1?t-1:t,a&&n>1?n-1:n],p;r?p="(vec2(yRC) + vec2(0.5)) * effectiveInputOverOutputRatioRC - vec2(0.5)":p="vec2(yRC) * effectiveInputOverOutputRatioRC",this.userCode=` const vec2 effectiveInputOverOutputRatioRC = vec2( ${d[0]/u[0]}, ${d[1]/u[1]}); @@ -3645,7 +3645,7 @@ return a / b;`,fG=` setOutput(newValue); } - `}};function oq(e){let{inputs:t,backend:n,attrs:a}=e,{images:r}=t,{alignCorners:s,halfPixelCenters:i,size:o}=a,[l,d]=o,u=J().getBool("WEBGL_PACK_IMAGE_OPERATIONS")?new iq(r.shape,l,d,s,i):new sq(r.shape,l,d,s,i);return n.runWebGLProgram(u,[r],"float32")}var lq={kernelName:Ws,backendName:"webgl",kernelFunc:oq},uq=class{constructor(e,t,n){this.variableNames=["dy"],this.outputShape=[],this.outputShape=t;let[,a,r]=t,[,s,i]=e,o=[n&&s>1?a-1:a,n&&i>1?r-1:r],l=[n&&s>1?s-1:s,n&&i>1?i-1:i],d=o[0]/l[0],u=o[1]/l[1],p=1/d,c=1/u,h=Math.ceil(p)*2+2,m=Math.ceil(c)*2+2;this.userCode=` + `}};function oq(e){let{inputs:t,backend:n,attrs:a}=e,{images:r}=t,{alignCorners:s,halfPixelCenters:i,size:o}=a,[l,d]=o,u=J().getBool("WEBGL_PACK_IMAGE_OPERATIONS")?new iq(r.shape,l,d,s,i):new sq(r.shape,l,d,s,i);return n.runWebGLProgram(u,[r],"float32")}var lq={kernelName:Ls,backendName:"webgl",kernelFunc:oq},uq=class{constructor(e,t,n){this.variableNames=["dy"],this.outputShape=[],this.outputShape=t;let[,a,r]=t,[,s,i]=e,o=[n&&s>1?a-1:a,n&&i>1?r-1:r],l=[n&&s>1?s-1:s,n&&i>1?i-1:i],d=o[0]/l[0],u=o[1]/l[1],p=1/d,c=1/u,h=Math.ceil(p)*2+2,m=Math.ceil(c)*2+2;this.userCode=` void main() { ivec4 coords = getOutputCoords(); int b = coords[0]; @@ -3869,7 +3869,7 @@ return a / b;`,fG=` ${s} coords = getOutputCoords(); setOutput(getX(${r})); } - `}},bq=class{constructor(e,t){this.variableNames=["x"],this.packedInputs=!0,this.packedOutput=!0;let n=e.length;if(n>4)throw new Error(`WebGL backend: Reverse of rank-${n} tensor is not yet supported`);this.outputShape=e;let a=cn("rc",n),r=`${a[n-1]} + 1 < ${this.outputShape[n-1]}`,s=`${a[n-2]} + 1 < ${this.outputShape[n-2]}`,i=lt(n);n===1?this.userCode=` + `}},bq=class{constructor(e,t){this.variableNames=["x"],this.packedInputs=!0,this.packedOutput=!0;let n=e.length;if(n>4)throw new Error(`WebGL backend: Reverse of rank-${n} tensor is not yet supported`);this.outputShape=e;let a=pn("rc",n),r=`${a[n-1]} + 1 < ${this.outputShape[n-1]}`,s=`${a[n-2]} + 1 < ${this.outputShape[n-2]}`,i=lt(n);n===1?this.userCode=` void main(){ int rc = getOutputCoords(); vec4 result = vec4(0.); @@ -3897,7 +3897,7 @@ return a / b;`,fG=` } setOutput(result); } - `;function o(h){return p(h)}function l(h){return h[n-1]="("+h[n-1]+" + 1)",p(h)}function d(h){return h[n-2]="("+h[n-2]+" + 1)",p(h)}function u(h){return h[n-1]="("+h[n-1]+" + 1)",h[n-2]="("+h[n-2]+" + 1)",p(h)}function p(h){let m=e.map((y,g)=>c(g,h)),f=m.join(","),A=m.slice(-2).join(",");return`getChannel(getX(${f}), vec2(${A}))`}function c(h,m){return t.indexOf(h)!==-1&&e[h]!==1?`${e[h]} - ${m[h]} - 1`:`${m[h]}`}}};function vq(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{dims:s}=a,i=r.shape.length,o=k.parseAxisParam(s,r.shape);if(i===0)return Ln({inputs:{x:r},backend:n});let l=J().getBool("WEBGL_PACK_ARRAY_OPERATIONS")?new bq(r.shape,o):new xq(r.shape,o);return n.runWebGLProgram(l,[r],r.dtype)}var wq={kernelName:Vs,backendName:"webgl",kernelFunc:vq},kq=class{constructor(e,t){this.variableNames=["Image"],this.outputShape=[];let n=e[1],a=e[2];this.outputShape=e;let r="";typeof t=="number"?r=`float outputValue = ${t.toFixed(2)};`:r=` + `;function o(h){return p(h)}function l(h){return h[n-1]="("+h[n-1]+" + 1)",p(h)}function d(h){return h[n-2]="("+h[n-2]+" + 1)",p(h)}function u(h){return h[n-1]="("+h[n-1]+" + 1)",h[n-2]="("+h[n-2]+" + 1)",p(h)}function p(h){let m=e.map((y,g)=>c(g,h)),f=m.join(","),A=m.slice(-2).join(",");return`getChannel(getX(${f}), vec2(${A}))`}function c(h,m){return t.indexOf(h)!==-1&&e[h]!==1?`${e[h]} - ${m[h]} - 1`:`${m[h]}`}}};function vq(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{dims:s}=a,i=r.shape.length,o=k.parseAxisParam(s,r.shape);if(i===0)return Pn({inputs:{x:r},backend:n});let l=J().getBool("WEBGL_PACK_ARRAY_OPERATIONS")?new bq(r.shape,o):new xq(r.shape,o);return n.runWebGLProgram(l,[r],r.dtype)}var wq={kernelName:Bs,backendName:"webgl",kernelFunc:vq},kq=class{constructor(e,t){this.variableNames=["Image"],this.outputShape=[];let n=e[1],a=e[2];this.outputShape=e;let r="";typeof t=="number"?r=`float outputValue = ${t.toFixed(2)};`:r=` vec3 fill = vec3(${t.join(",")}); float outputValue = fill[coords[3]];`,this.userCode=` uniform vec4 params; @@ -3917,7 +3917,7 @@ return a / b;`,fG=` } setOutput(outputValue); } - `}getCustomSetupFunc(e,t,n,a){return(r,s)=>{this.paramsLoc==null&&(this.paramsLoc=r.getUniformLocationNoThrow(s,"params")),r.gl.uniform4f(this.paramsLoc,e,t,n,a)}}},Iq={kernelName:tl,backendName:"webgl",kernelFunc:({inputs:e,attrs:t,backend:n})=>{let{image:a}=e,{radians:r,fillValue:s,center:i}=t,o=n,l=new kq(a.shape,s),[d,u]=C.getImageCenter(i,a.shape[1],a.shape[2]),p=l.getCustomSetupFunc(d,u,Math.sin(r),Math.cos(r));return o.runWebGLProgram(l,[a],a.dtype,p)}},Sq=` + `}getCustomSetupFunc(e,t,n,a){return(r,s)=>{this.paramsLoc==null&&(this.paramsLoc=r.getUniformLocationNoThrow(s,"params")),r.gl.uniform4f(this.paramsLoc,e,t,n,a)}}},Iq={kernelName:el,backendName:"webgl",kernelFunc:({inputs:e,attrs:t,backend:n})=>{let{image:a}=e,{radians:r,fillValue:s,center:i}=t,o=n,l=new kq(a.shape,s),[d,u]=C.getImageCenter(i,a.shape[1],a.shape[2]),p=l.getCustomSetupFunc(d,u,Math.sin(r),Math.cos(r));return o.runWebGLProgram(l,[a],a.dtype,p)}},Sq=` // OpenGL ES does not support round function. // The algorithm is based on banker's rounding. float base = floor(x); @@ -3932,7 +3932,7 @@ return a / b;`,fG=` return base + 1.0; } } -`,Nq=qe({opSnippet:Sq}),Tq={kernelName:js,backendName:"webgl",kernelFunc:Nq},Eq="return inversesqrt(x);",Cq=qe({opSnippet:Eq,cpuKernelImpl:oW}),Rq={kernelName:Us,backendName:"webgl",kernelFunc:Cq},cw=class{constructor(e,t,n,a,r,s,i=!0){this.variableNames=["updates","indices","defaultValue"],this.outputShape=s;let o=lt(r.length),l=lt(s.length),d="";n===1?d="i":n===2&&(d="i, j");let u=`getIndices(${d})`,p="";a===1?p="i":a===2&&(p="i, coords[1]");let c=`getUpdates(${p})`,h=t>1?"strides[j]":"strides";this.userCode=` +`,Nq=qe({opSnippet:Sq}),Tq={kernelName:Vs,backendName:"webgl",kernelFunc:Nq},Eq="return inversesqrt(x);",Cq=qe({opSnippet:Eq,cpuKernelImpl:oW}),Rq={kernelName:js,backendName:"webgl",kernelFunc:Cq},cw=class{constructor(e,t,n,a,r,s,i=!0){this.variableNames=["updates","indices","defaultValue"],this.outputShape=s;let o=lt(r.length),l=lt(s.length),d="";n===1?d="i":n===2&&(d="i, j");let u=`getIndices(${d})`,p="";a===1?p="i":a===2&&(p="i, coords[1]");let c=`getUpdates(${p})`,h=t>1?"strides[j]":"strides";this.userCode=` ${o} strides = ${o}(${r}); void main() { @@ -3952,7 +3952,7 @@ return a / b;`,fG=` } setOutput(mix(getDefaultValue(), sum, float(found))); } - `}};function Mq(e){let{inputs:t,backend:n,attrs:a}=e,{indices:r,updates:s}=t,{shape:i}=a,{sliceRank:o,numUpdates:l,sliceSize:d,strides:u,outputSize:p}=C.calculateShapes(s,r,i),c=[p/d,d];if(p===0)return n.makeTensorInfo(i,r.dtype);let h=Ae({inputs:{x:r},backend:n,attrs:{shape:[l,o]}}),m=Ae({inputs:{x:s},backend:n,attrs:{shape:[l,d]}}),f=n.makeTensorInfo([],"float32",new Float32Array([0])),A=new cw(l,o,h.shape.length,m.shape.length,u,c),y=n.runWebGLProgram(A,[m,h,f],m.dtype),g=Ae({inputs:{x:y},backend:n,attrs:{shape:i}});return n.disposeIntermediateTensorInfo(h),n.disposeIntermediateTensorInfo(m),n.disposeIntermediateTensorInfo(y),n.disposeIntermediateTensorInfo(f),g}var Fq={kernelName:Vo,backendName:"webgl",kernelFunc:Mq},$q=class{constructor(e,t,n){this.variableNames=["c","a","b"],this.outputShape=t;let a,r;if(n>4)throw Error(`Where for rank ${n} is not yet supported`);if(n===1)r="resRC",a="resRC";else{let i=["resRC.x","resRC.y","resRC.z","resRC.w"],o=[],l=[];for(let d=0;d4)throw Error(`Where for rank ${n} is not yet supported`);if(n===1)r="resRC",a="resRC";else{let i=["resRC.x","resRC.y","resRC.z","resRC.w"],o=[],l=[];for(let d=0;d= 0.0) ? scale * x : scaleAlpha * (exp(x) - 1.0); -`,_q=qe({opSnippet:zq}),Pq={kernelName:Uo,backendName:"webgl",kernelFunc:_q},Lq="return 1.0 / (1.0 + exp(-1.0 * x));",Wq=qe({opSnippet:Lq}),Bq={kernelName:Gs,backendName:"webgl",kernelFunc:Wq},Vq=` +`,_q=qe({opSnippet:zq}),Pq={kernelName:jo,backendName:"webgl",kernelFunc:_q},Lq="return 1.0 / (1.0 + exp(-1.0 * x));",Wq=qe({opSnippet:Lq}),Bq={kernelName:Hs,backendName:"webgl",kernelFunc:Wq},Vq=` if (isnan(x)) { return 0.0; } return sign(x); -`,jq=qe({opSnippet:Vq}),Uq={kernelName:qo,backendName:"webgl",kernelFunc:jq},Hq=Tv+` +`,jq=qe({opSnippet:Vq}),Uq={kernelName:Go,backendName:"webgl",kernelFunc:jq},Hq=Tv+` return sin(x); -`,Gq=qe({opSnippet:Hq}),qq={kernelName:Hs,backendName:"webgl",kernelFunc:Gq},Xq=` +`,Gq=qe({opSnippet:Hq}),qq={kernelName:Us,backendName:"webgl",kernelFunc:Gq},Xq=` float e2x = exp(x); return (e2x - 1.0 / e2x) / 2.0; -`,Kq=qe({opSnippet:Xq}),Zq={kernelName:Go,backendName:"webgl",kernelFunc:Kq},Yq=` +`,Kq=qe({opSnippet:Xq}),Zq={kernelName:Ho,backendName:"webgl",kernelFunc:Kq},Yq=` float epsilon = 1.1920928955078125e-7; float threshold = log(epsilon) + 2.0; @@ -3996,13 +3996,13 @@ return a / b;`,fG=` result = log(exp_x + 1.0); } return result; -`,Jq=qe({opSnippet:Yq}),Qq={kernelName:Xo,backendName:"webgl",kernelFunc:Jq},eX=e=>{let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{blockShape:s,paddings:i}=a;k.assert(r.shape.length<=4,()=>"spaceToBatchND for rank > 4 with a WebGL backend not implemented yet");let o=s.reduce((y,g)=>y*g),l=[[0,0]];l.push(...i);for(let y=1+s.length;yn.disposeIntermediateTensorInfo(y)),A},tX={kernelName:Cu,backendName:"webgl",kernelFunc:eX};function nX(e){let{inputs:t,backend:n}=e,{indices:a,values:r,denseShape:s,defaultValue:i}=t;if(s.shape.length!==1)throw new Error(`Dense shape must be a vector, saw: +`,Jq=qe({opSnippet:Yq}),Qq={kernelName:qo,backendName:"webgl",kernelFunc:Jq},eX=e=>{let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{blockShape:s,paddings:i}=a;k.assert(r.shape.length<=4,()=>"spaceToBatchND for rank > 4 with a WebGL backend not implemented yet");let o=s.reduce((y,g)=>y*g),l=[[0,0]];l.push(...i);for(let y=1+s.length;yn.disposeIntermediateTensorInfo(y)),A},tX={kernelName:Cu,backendName:"webgl",kernelFunc:eX};function nX(e){let{inputs:t,backend:n}=e,{indices:a,values:r,denseShape:s,defaultValue:i}=t;if(s.shape.length!==1)throw new Error(`Dense shape must be a vector, saw: ${s.shape}`);if(a.shape.length!==2)throw new Error(`Indices must be a matrix, saw: ${a.shape}`);if(r.shape.length!==1)throw new Error(`Values must be a vector, saw: ${r.shape}`);if(i.shape.length!==0)throw new Error(`Default value must be a scalar, saw: - ${i.shape}`);let o=n.readSync(a.dataId),l=n.readSync(r.dataId),d=n.readSync(s.dataId),u=n.readSync(i.dataId)[0],[p,c,h,m,f]=uW(o,a.shape,a.dtype,l,r.dtype,d,u);return[n.makeTensorInfo(c,a.dtype,p),n.makeTensorInfo([c[0]],r.dtype,h),n.makeTensorInfo([m.length],"bool",new Uint8Array(m.map(A=>Number(A)))),n.makeTensorInfo([f.length],a.dtype,new Int32Array(f))]}var aX={kernelName:tc,backendName:"webgl",kernelFunc:nX};function rX(e){let{inputs:t,backend:n}=e,{inputIndices:a,inputShape:r,newShape:s}=t;if(a.shape.length!==2)throw new Error(`Input indices should be a matrix but received shape ${a.shape}`);if(r.shape.length!==1)throw new Error(`Input shape should be a vector but received shape ${r.shape}`);if(s.shape.length!==1)throw new Error(`Target shape should be a vector but received shape ${s.shape}`);let i=Array.from(n.readSync(r.dataId)),o=n.readSync(a.dataId),l=Array.from(n.readSync(s.dataId)),[d,u,p]=dW(o,a.shape,a.dtype,i,l);return[n.makeTensorInfo(u,a.dtype,d),n.makeTensorInfo([p.length],s.dtype,new Int32Array(p))]}var sX={kernelName:nc,backendName:"webgl",kernelFunc:rX};function iX(e){let{inputs:t,backend:n,attrs:a}=e,{sparseIndices:r,sparseValues:s,defaultValue:i}=t,{outputShape:o}=a,{sliceRank:l,numUpdates:d,strides:u,outputSize:p}=C.calculateShapes(s,r,o),c=!1,h=new cw(d,l,r.shape.length,s.shape.length,u,[p,1],c),m=n.runWebGLProgram(h,[s,r,i],s.dtype),f=Ae({inputs:{x:m},backend:n,attrs:{shape:o}});return n.disposeIntermediateTensorInfo(m),f}var oX={kernelName:ac,backendName:"webgl",kernelFunc:iX};function lX(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{numOrSizeSplits:s,axis:i}=a,o=k.parseAxisParam(i,r.shape)[0],l=C.prepareSplitSize(r,s,o),d=r.shape.length,u=new Array(d).fill(0),p=r.shape.slice();return l.map(c=>{let h=[...p];h[o]=c;let m=gd({inputs:{x:r},backend:n,attrs:{begin:u,size:h}});return u[o]+=c,m})}var uX={kernelName:Ko,backendName:"webgl",kernelFunc:lX},dX="return sqrt(x);",pX=qe({opSnippet:dX}),cX={kernelName:qs,backendName:"webgl",kernelFunc:pX},hX="return x * x;",fX=qe({opSnippet:hX}),mX={kernelName:Ru,backendName:"webgl",kernelFunc:fX},hw="return (a - b) * (a - b);",AX=tn({opSnippet:hw,packedOpSnippet:hw}),yX={kernelName:Zs,backendName:"webgl",kernelFunc:AX};function gX({inputs:e,attrs:t,backend:n}){let{x:a}=e,r=xa+` + ${i.shape}`);let o=n.readSync(a.dataId),l=n.readSync(r.dataId),d=n.readSync(s.dataId),u=n.readSync(i.dataId)[0],[p,c,h,m,f]=uW(o,a.shape,a.dtype,l,r.dtype,d,u);return[n.makeTensorInfo(c,a.dtype,p),n.makeTensorInfo([c[0]],r.dtype,h),n.makeTensorInfo([m.length],"bool",new Uint8Array(m.map(A=>Number(A)))),n.makeTensorInfo([f.length],a.dtype,new Int32Array(f))]}var aX={kernelName:tc,backendName:"webgl",kernelFunc:nX};function rX(e){let{inputs:t,backend:n}=e,{inputIndices:a,inputShape:r,newShape:s}=t;if(a.shape.length!==2)throw new Error(`Input indices should be a matrix but received shape ${a.shape}`);if(r.shape.length!==1)throw new Error(`Input shape should be a vector but received shape ${r.shape}`);if(s.shape.length!==1)throw new Error(`Target shape should be a vector but received shape ${s.shape}`);let i=Array.from(n.readSync(r.dataId)),o=n.readSync(a.dataId),l=Array.from(n.readSync(s.dataId)),[d,u,p]=dW(o,a.shape,a.dtype,i,l);return[n.makeTensorInfo(u,a.dtype,d),n.makeTensorInfo([p.length],s.dtype,new Int32Array(p))]}var sX={kernelName:nc,backendName:"webgl",kernelFunc:rX};function iX(e){let{inputs:t,backend:n,attrs:a}=e,{sparseIndices:r,sparseValues:s,defaultValue:i}=t,{outputShape:o}=a,{sliceRank:l,numUpdates:d,strides:u,outputSize:p}=C.calculateShapes(s,r,o),c=!1,h=new cw(d,l,r.shape.length,s.shape.length,u,[p,1],c),m=n.runWebGLProgram(h,[s,r,i],s.dtype),f=Ae({inputs:{x:m},backend:n,attrs:{shape:o}});return n.disposeIntermediateTensorInfo(m),f}var oX={kernelName:ac,backendName:"webgl",kernelFunc:iX};function lX(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{numOrSizeSplits:s,axis:i}=a,o=k.parseAxisParam(i,r.shape)[0],l=C.prepareSplitSize(r,s,o),d=r.shape.length,u=new Array(d).fill(0),p=r.shape.slice();return l.map(c=>{let h=[...p];h[o]=c;let m=gd({inputs:{x:r},backend:n,attrs:{begin:u,size:h}});return u[o]+=c,m})}var uX={kernelName:Xo,backendName:"webgl",kernelFunc:lX},dX="return sqrt(x);",pX=qe({opSnippet:dX}),cX={kernelName:Gs,backendName:"webgl",kernelFunc:pX},hX="return x * x;",fX=qe({opSnippet:hX}),mX={kernelName:Ru,backendName:"webgl",kernelFunc:fX},hw="return (a - b) * (a - b);",AX=en({opSnippet:hw,packedOpSnippet:hw}),yX={kernelName:Ks,backendName:"webgl",kernelFunc:AX};function gX({inputs:e,attrs:t,backend:n}){let{x:a}=e,r=ga+` return x > 0.0 ? 1.0 : float(${t.alpha}); - `,s=new Lr(a.shape,r);return n.runWebGLProgram(s,[a],a.dtype)}var xX={kernelName:Nr,backendName:"webgl",kernelFunc:gX},bX=class{constructor(e,t,n){this.variableNames=["x"],this.outputShape=n;let a=n.length,r=lt(n.length),s=lt(n.length),i="";if(a===1)i="coords * strides + begin";else{let o=0;i=n.map((l,d)=>(o++,n.length===1?`coords * strides[${d}] + begin[${d}]`:`coords[${o-1}] * strides[${d}] + begin[${d}]`)).join(",")}this.userCode=` + `,s=new Pr(a.shape,r);return n.runWebGLProgram(s,[a],a.dtype)}var xX={kernelName:Sr,backendName:"webgl",kernelFunc:gX},bX=class{constructor(e,t,n){this.variableNames=["x"],this.outputShape=n;let a=n.length,r=lt(n.length),s=lt(n.length),i="";if(a===1)i="coords * strides + begin";else{let o=0;i=n.map((l,d)=>(o++,n.length===1?`coords * strides[${d}] + begin[${d}]`:`coords[${o-1}] * strides[${d}] + begin[${d}]`)).join(",")}this.userCode=` ${r} begin = ${r}(${e}); ${r} strides = ${r}(${t}); @@ -4010,15 +4010,15 @@ return a / b;`,fG=` ${s} coords = getOutputCoords(); setOutput(getX(${i})); } - `}};function vX(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{begin:s,end:i,strides:o,beginMask:l,endMask:d,ellipsisMask:u,newAxisMask:p,shrinkAxisMask:c}=a,{nonStrided:h,$begin:m,$strides:f,size:A,newShape:y,outShape:g}=ln.sliceInfo(r.shape,s,i,o,l,d,u,p,c),x=Ae({inputs:{x:r},backend:n,attrs:{shape:y}}),w;if(h){let v=gd({inputs:{x},backend:n,attrs:{begin:m,size:A}});w=Ae({inputs:{x:v},backend:n,attrs:{shape:g}}),n.disposeIntermediateTensorInfo(v)}else if(g.some(v=>v===0))w=n.makeTensorInfo(g,r.dtype,[]);else if(n.shouldExecuteOnCPU([x])){let v=n.texData.get(x.dataId).values,N=We(x.shape,x.dtype,v),T=pW(g,N,f,m);w=n.makeTensorInfo(g,x.dtype,T.values)}else{let v=new bX(m,f,g);w=n.runWebGLProgram(v,[x],x.dtype)}let b=Ae({inputs:{x:w},backend:n,attrs:{shape:g}});return n.disposeIntermediateTensorInfo(x),n.disposeIntermediateTensorInfo(w),b}var wX={kernelName:Zo,backendName:"webgl",kernelFunc:vX},kX="return tan(x);",IX=qe({opSnippet:kX}),SX={kernelName:Js,backendName:"webgl",kernelFunc:IX},NX=` + `}};function vX(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{begin:s,end:i,strides:o,beginMask:l,endMask:d,ellipsisMask:u,newAxisMask:p,shrinkAxisMask:c}=a,{nonStrided:h,$begin:m,$strides:f,size:A,newShape:y,outShape:g}=on.sliceInfo(r.shape,s,i,o,l,d,u,p,c),x=Ae({inputs:{x:r},backend:n,attrs:{shape:y}}),w;if(h){let v=gd({inputs:{x},backend:n,attrs:{begin:m,size:A}});w=Ae({inputs:{x:v},backend:n,attrs:{shape:g}}),n.disposeIntermediateTensorInfo(v)}else if(g.some(v=>v===0))w=n.makeTensorInfo(g,r.dtype,[]);else if(n.shouldExecuteOnCPU([x])){let v=n.texData.get(x.dataId).values,N=We(x.shape,x.dtype,v),T=pW(g,N,f,m);w=n.makeTensorInfo(g,x.dtype,T.values)}else{let v=new bX(m,f,g);w=n.runWebGLProgram(v,[x],x.dtype)}let b=Ae({inputs:{x:w},backend:n,attrs:{shape:g}});return n.disposeIntermediateTensorInfo(x),n.disposeIntermediateTensorInfo(w),b}var wX={kernelName:Ko,backendName:"webgl",kernelFunc:vX},kX="return tan(x);",IX=qe({opSnippet:kX}),SX={kernelName:Ys,backendName:"webgl",kernelFunc:IX},NX=` float e2x = exp(-2.0 * abs(x)); return sign(x) * (1.0 - e2x) / (1.0 + e2x); -`,TX=qe({opSnippet:NX}),EX={kernelName:Qs,backendName:"webgl",kernelFunc:TX},RX=class{constructor(e,t){this.variableNames=["A"];let n=new Array(e.length);for(let s=0;s5)throw Error(`Tile for rank ${t} is not yet supported`);if(t===1)return`imod(resRC, ${e[0]})`;let n=["resRC.x","resRC.y","resRC.z","resRC.w","resRC.u"],a=[];for(let r=0;r5){let o=n.readSync(r.dataId),l=r.dtype==="string"?o.map(p=>k.decodeString(p)):o,d=We(r.shape,r.dtype,l),u=hW(d,s);return n.makeTensorInfo(u.shape,u.dtype,u.values)}let i=new RX(r.shape,s);return n.runWebGLProgram(i,[r],r.dtype)}var MX={kernelName:Sr,backendName:"webgl",kernelFunc:fw};function FX(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{k:s,sorted:i}=a,o=n.readSync(r.dataId),[l,d]=fW(o,r.shape,r.dtype,s,i);return[n.makeTensorInfo(l.shape,l.dtype,l.values),n.makeTensorInfo(d.shape,d.dtype,d.values)]}var $X={kernelName:Yo,backendName:"webgl",kernelFunc:FX},DX=class{constructor(e,t,n,a,r,s){this.variableNames=["Image","Transforms"],this.outputShape=s;let i=n==="nearest"?1:2,o;switch(a){case"constant":o=1;break;case"reflect":o=2;break;case"wrap":o=3;break;case"nearest":o=4;break;default:o=1;break}this.userCode=` + `}};function CX(e){let t=e.length;if(t>5)throw Error(`Tile for rank ${t} is not yet supported`);if(t===1)return`imod(resRC, ${e[0]})`;let n=["resRC.x","resRC.y","resRC.z","resRC.w","resRC.u"],a=[];for(let r=0;r5){let o=n.readSync(r.dataId),l=r.dtype==="string"?o.map(p=>k.decodeString(p)):o,d=We(r.shape,r.dtype,l),u=hW(d,s);return n.makeTensorInfo(u.shape,u.dtype,u.values)}let i=new RX(r.shape,s);return n.runWebGLProgram(i,[r],r.dtype)}var MX={kernelName:Ir,backendName:"webgl",kernelFunc:fw};function FX(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{k:s,sorted:i}=a,o=n.readSync(r.dataId),[l,d]=fW(o,r.shape,r.dtype,s,i);return[n.makeTensorInfo(l.shape,l.dtype,l.values),n.makeTensorInfo(d.shape,d.dtype,d.values)]}var $X={kernelName:Zo,backendName:"webgl",kernelFunc:FX},DX=class{constructor(e,t,n,a,r,s){this.variableNames=["Image","Transforms"],this.outputShape=s;let i=n==="nearest"?1:2,o;switch(a){case"constant":o=1;break;case"reflect":o=2;break;case"wrap":o=3;break;case"nearest":o=4;break;default:o=1;break}this.userCode=` float mapCoord(float outCoord, float len) { float inCoord = outCoord; if(${o} == 2) { @@ -4130,7 +4130,7 @@ return a / b;`,fG=` } setOutput(outputValue); } - `}};function OX(e){let{inputs:t,backend:n,attrs:a}=e,{image:r,transforms:s}=t,{interpolation:i,fillMode:o,fillValue:l,outputShape:d}=a,[u,p,c,h]=r.shape,[m,f]=d!=null?d:[p,c],A=[u,m,f,h],y=new DX(p,c,i,o,l,A);return n.runWebGLProgram(y,[r,s],"float32")}var zX={kernelName:Jo,backendName:"webgl",kernelFunc:OX};function _X(e){let{inputs:t,attrs:n,backend:a}=e,{axis:r}=n,{x:s}=t;Cl(s,"unique"),console.warn("WARNING: ","UI might be locked temporarily as data is being downloaded");let i=a.readSync(s.dataId),{outputValues:o,outputShape:l,indices:d}=mW(i,r,s.shape,s.dtype);return[a.makeTensorInfo(l,s.dtype,o),a.makeTensorInfo([d.length],"int32",d)]}var PX={kernelName:rc,backendName:"webgl",kernelFunc:_X};function LX(e){let{inputs:t,backend:n,attrs:a}=e,{value:r}=t,{axis:s}=a;s<0&&(s+=r.shape.length);let i=r,o=i.shape.length,l=r.shape[s],d=new Array(o-1),u=0;for(let f=0;fn.disposeIntermediateTensorInfo(f)),m}var WX={kernelName:Qo,backendName:"webgl",kernelFunc:LX},BX=class{constructor(e,t){this.variableNames=["x","segmentIds"];let n=e.windowSize,a=e.batchSize,r=e.inSize,s=e.numSegments,i=s*Math.ceil(r/n);this.outputShape=[a,i];let o="0.0",l="sumValue",d=Math.floor(n/4)*4,u=n%4,p=` + `}};function OX(e){let{inputs:t,backend:n,attrs:a}=e,{image:r,transforms:s}=t,{interpolation:i,fillMode:o,fillValue:l,outputShape:d}=a,[u,p,c,h]=r.shape,[m,f]=d!=null?d:[p,c],A=[u,m,f,h],y=new DX(p,c,i,o,l,A);return n.runWebGLProgram(y,[r,s],"float32")}var zX={kernelName:Yo,backendName:"webgl",kernelFunc:OX};function _X(e){let{inputs:t,attrs:n,backend:a}=e,{axis:r}=n,{x:s}=t;El(s,"unique"),console.warn("WARNING: ","UI might be locked temporarily as data is being downloaded");let i=a.readSync(s.dataId),{outputValues:o,outputShape:l,indices:d}=mW(i,r,s.shape,s.dtype);return[a.makeTensorInfo(l,s.dtype,o),a.makeTensorInfo([d.length],"int32",d)]}var PX={kernelName:rc,backendName:"webgl",kernelFunc:_X};function LX(e){let{inputs:t,backend:n,attrs:a}=e,{value:r}=t,{axis:s}=a;s<0&&(s+=r.shape.length);let i=r,o=i.shape.length,l=r.shape[s],d=new Array(o-1),u=0;for(let f=0;fn.disposeIntermediateTensorInfo(f)),m}var WX={kernelName:Jo,backendName:"webgl",kernelFunc:LX},BX=class{constructor(e,t){this.variableNames=["x","segmentIds"];let n=e.windowSize,a=e.batchSize,r=e.inSize,s=e.numSegments,i=s*Math.ceil(r/n);this.outputShape=[a,i];let o="0.0",l="sumValue",d=Math.floor(n/4)*4,u=n%4,p=` sumValue += dot(values, segFilter); `,c="";r%n>0&&(c=` if (inIdx < 0 || inIdx >= ${r}) { @@ -4236,26 +4236,26 @@ return a / b;`,fG=` } setOutput(${l}); } - `}};function VX(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,segmentIds:s}=t,{numSegments:i}=a,o=r.shape.length,l=[],d=0,u=C.getAxesPermutation([d],o),p=r;u!=null&&(p=hn({inputs:{x:r},backend:n,attrs:{perm:u}}),l.push(p),d=C.getInnerMostAxes(1,o)[0]);let c=C.segment_util.computeOutShape(p.shape,d,i),h=k.sizeFromShape([p.shape[d]]),m=Ae({inputs:{x:p},backend:n,attrs:{shape:[-1,h]}});l.push(m);let f=dc(r.dtype),A=(w,b,v,N,T)=>{let R=w.shape[0],$=w.shape[1],z=C.segment_util.segOpComputeOptimalWindowSize($,T),P={windowSize:z,inSize:$,batchSize:R,numSegments:T},V=new BX(P,b),j=n.compileAndRun(V,[w,v],N);if(l.push(j),j.shape[1]===T)return j;let U=pw({backend:n,attrs:{start:0,stop:T,step:1,dtype:"float32"}}),X=fw({inputs:{x:U},backend:n,attrs:{reps:[$/z]}});return l.push(U),l.push(X),A(j,b,X,N,T)},y=A(m,"unsortedSegmentSum",s,f,i),g=Ae({inputs:{x:y},backend:n,attrs:{shape:c}}),x=g;if(u!=null){l.push(g);let w=C.getUndoAxesPermutation(u);x=hn({inputs:{x},backend:n,attrs:{perm:w}})}return l.forEach(w=>n.disposeIntermediateTensorInfo(w)),x}var jX={kernelName:Mu,backendName:"webgl",kernelFunc:VX},UX=[EH,MH,hB,mB,gB,vB,kB,NB,EB,RB,DB,zB,LB,VB,KB,HB,JB,nV,eV,iV,lV,dV,fV,vV,kV,CV,MV,OV,PV,XW,jV,QV,tj,qV,sj,oj,aj,dj,hj,Aj,gj,bj,kj,Cj,Mj,Sj,Dj,_j,Lj,jj,qj,Yj,eU,tU,nU,rU,iU,lU,dU,cU,AU,bU,wU,IU,TU,MU,OU,LU,qW,BU,BV,UU,qU,ZU,ZW,eH,rH,iH,hH,dH,yH,bH,IH,$H,BH,LH,HH,qH,KH,_H,YH,QH,aG,oG,pG,xG,tB,vG,IG,TG,RG,SV,$G,OG,_G,WG,UG,JW,GG,qG,NV,mG,ZG,rq,eq,aB,lq,pq,mq,gq,wq,Iq,Tq,Rq,Fq,Oq,Pq,Bq,Uq,qq,Zq,xV,yG,Qq,tX,aX,sX,oX,uX,cX,mX,yX,xX,wX,AG,dB,SX,EX,MX,$X,zX,pB,PX,WX,jX,DG];for(let e of UX)ri(e);var Sn;(function(e){e[e.float32=0]="float32",e[e.int32=1]="int32",e[e.bool=2]="bool",e[e.string=3]="string",e[e.complex64=4]="complex64"})(Sn||(Sn={}));var bd;(function(e){e[e.linear=0]="linear",e[e.relu=1]="relu",e[e.relu6=2]="relu6",e[e.prelu=3]="prelu",e[e.leakyrelu=4]="leakyrelu",e[e.sigmoid=5]="sigmoid"})(bd||(bd={}));var mw;function HX(e){mw=e.wasm.cwrap(ti,null,["number","array","number","number","array","number","number","number","number","number","number","number","number"])}function GX(e){let{inputs:t,backend:n,attrs:a}=e,{a:r,b:s,bias:i,preluActivationWeights:o}=t;if(r.dtype!=="float32"||s.dtype!=="float32")throw new Error("_FusedMatMul for non non-float32 tensors not yet supported.");let{transposeA:l,transposeB:d,activation:u,leakyreluAlpha:p}=a,c=n.dataIdMap.get(r.dataId).id,h=n.dataIdMap.get(s.dataId).id,m=0;if(i!=null){let T=n.dataIdMap.get(i.dataId);if(T.shape.length!==1)throw new Error(`_FusedMatMul only supports rank-1 bias but got rank ${T.shape.length}.`);m=T.id}let f=o==null?0:n.dataIdMap.get(o.dataId).id,A=bd[u];if(A==null)throw new Error(`${u} activation not yet supported for FusedConv2D in the wasm backend.`);let y=l?r.shape[2]:r.shape[1],g=d?s.shape[1]:s.shape[2],x=r.shape[0],w=n.makeOutput([x,y,g],r.dtype),b=n.dataIdMap.get(w.dataId).id,v=new Uint8Array(new Int32Array(r.shape).buffer),N=new Uint8Array(new Int32Array(s.shape).buffer);return mw(c,v,r.shape.length,h,N,s.shape.length,l,d,A,m,f,p||0,b),w}var qX={kernelName:ti,backendName:"wasm",setupFunc:HX,kernelFunc:GX};function fn(e){let t;function n(r){t=r.wasm.cwrap(e,null,["number","number"])}function a(r){let{backend:s,inputs:{x:i}}=r,o=s.dataIdMap.get(i.dataId).id,l=s.makeOutput(i.shape,i.dtype),d=s.dataIdMap.get(l.dataId).id;return k.sizeFromShape(l.shape)===0||t(o,d),l}return{kernelName:e,backendName:"wasm",setupFunc:n,kernelFunc:a}}var XX=fn(eo);function mn(e,t,n){let a;function r(i){a=i.wasm.cwrap(e,null,["number","array","number","number","array","number","number","number"])}function s(i){let{backend:o,inputs:l}=i,{a:d,b:u}=l,p=o.dataIdMap.get(d.dataId).id,c=o.dataIdMap.get(u.dataId).id,h=n!=null?n:d.dtype,m=C.assertAndGetBroadcastShape(d.shape,u.shape),f=o.makeOutput(m,h);if(k.sizeFromShape(m)===0)return f;let A=new Uint8Array(new Int32Array(d.shape).buffer),y=new Uint8Array(new Int32Array(u.shape).buffer),g=o.dataIdMap.get(f.dataId).id,x=()=>a(p,A,d.shape.length,c,y,u.shape.length,Sn[d.dtype],g);if(t&&d.dtype==="float32")return x(),f;let w=C.getBroadcastDims(d.shape,m),b=C.getBroadcastDims(u.shape,m),v=w.every((T,R)=>T===R),N=b.every((T,R)=>T===R);if(v&&N)return x(),f;throw new Error(`Broadcasting along outer dims is not yet supported for ${d.dtype} ${e}.`)}return{kernelName:e,backendName:"wasm",setupFunc:r,kernelFunc:s}}var KX=!0,ZX=mn(kr,KX),Aw;function YX(e){Aw=e.wasm.cwrap(os,null,["array","number","number","number"])}function JX(e){let{inputs:t,backend:n}=e,a=n.makeOutput(t[0].shape,t[0].dtype);if(k.sizeFromShape(a.shape)===0)return a;let r=t.map(o=>n.dataIdMap.get(o.dataId).id),s=new Uint8Array(new Int32Array(r).buffer),i=n.dataIdMap.get(a.dataId).id;return Aw(s,r.length,Sn[a.dtype],i),a}var QX={kernelName:os,backendName:"wasm",setupFunc:YX,kernelFunc:JX};function Nh(e){let{inputs:{x:t},backend:n}=e,a=n.makeOutput(t.shape,t.dtype),r=n.typedArrayFromHeap(t);return n.typedArrayFromHeap(a).set(r),a}var eK={kernelName:Is,backendName:"wasm",kernelFunc:Nh},yw;function tK(e){yw=e.wasm.cwrap(ei,null,["number","array","number","number","number","array","number"])}function Th(e){let{inputs:t,backend:n,attrs:a}=e,[r,s]=aK(t.x.shape,a.perm),i=!0;for(let m=0;m=r&&(s===-1||a[s]>a[i])&&(s=i);a[s]=r}return[n,a]}var rK={kernelName:ei,backendName:"wasm",kernelFunc:Th,setupFunc:tK};function Br(e,t,n){let a=e.shape,r=e.shape.length,s=k.parseAxisParam(t,a),i=s,o=C.getAxesPermutation(i,r),l=null,d=!1;if(o!=null){let u=new Array(r);for(let c=0;c`new shape: ${i}, old shape: ${a.shape}. New shape and old shape must have the same number of elements.`),e.backend.incRef(a.dataId),{dataId:a.dataId,shape:i,dtype:a.dtype}}var yK={kernelName:Bo,backendName:"wasm",kernelFunc:ba},ww;function gK(e){ww=e.wasm.cwrap(ds,null,["number","array","number","number","array","number","number","number","number"])}function xK(e){let{inputs:t,backend:n,attrs:a}=e,{a:r,b:s}=t,{transposeA:i,transposeB:o}=a;if(r.dtype!=="float32"||s.dtype!=="float32")throw new Error("BatchMatMul for non non-float32 tensors not yet supported.");let l=r.shape.length,d=s.shape.length,u=i?r.shape[l-2]:r.shape[l-1],p=o?s.shape[d-1]:s.shape[d-2],c=i?r.shape[l-1]:r.shape[l-2],h=o?s.shape[d-2]:s.shape[d-1],m=r.shape.slice(0,-2),f=s.shape.slice(0,-2),A=k.sizeFromShape(m),y=k.sizeFromShape(f),g=A===y||A===1||y===1;k.assert(l>=2&&d>=2&&g,()=>`Error in matMul: the input batch dimensions must either be the same or at least one input batch dimension must be 1. Got input batch dimensions of (${m}) and (${f}).`);let x=(A>y?r.shape.slice(0,-2):s.shape.slice(0,-2)).concat([c,h]);k.assert(u===p,()=>`Error in matMul: inner shapes (${u}) and (${p}) of Tensors with shapes ${r.shape} and ${s.shape} and transposeA=${i} and transposeB=${o} must match.`);let w=i?[A,u,c]:[A,c,u],b=o?[y,h,p]:[y,p,h],v=ba({inputs:{x:r},backend:n,attrs:{shape:w}}),N=ba({inputs:{x:s},backend:n,attrs:{shape:b}}),T=n.dataIdMap.get(v.dataId).id,R=n.dataIdMap.get(N.dataId).id,$=i?v.shape[2]:v.shape[1],z=o?N.shape[1]:N.shape[2],P=Math.max(A,y),V=n.makeOutput([P,$,z],v.dtype),j=n.dataIdMap.get(V.dataId).id,U=new Uint8Array(new Int32Array(v.shape).buffer),X=new Uint8Array(new Int32Array(N.shape).buffer);return ww(T,U,v.shape.length,R,X,N.shape.length,i,o,j),n.disposeData(v.dataId),n.disposeData(N.dataId),V.shape=x,V}var bK={kernelName:ds,backendName:"wasm",setupFunc:gK,kernelFunc:xK};function Eh(e){let{inputs:{x:t},attrs:{dtype:n},backend:a}=e,r=a.makeOutput(t.shape,n),s=a.typedArrayFromHeap(t);return a.typedArrayFromHeap(r).set(s),r}var vK={kernelName:ps,backendName:"wasm",kernelFunc:Eh},wK=fn(cs),kw;function kK(e){kw=e.wasm.cwrap(Ir,null,["number","number","number","number"])}function IK(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{clipValueMin:s,clipValueMax:i}=a,o=n.dataIdMap.get(r.dataId).id,l=n.makeOutput(r.shape,r.dtype),d=n.dataIdMap.get(l.dataId).id;return kw(o,s,i,d),l}var SK={kernelName:Ir,backendName:"wasm",setupFunc:kK,kernelFunc:IK};function Iw(e){let{inputs:t,backend:n}=e,a=k.parseAxisParam(e.attrs.axis,t[0].shape)[0],r=C.computeOutShape(t.map(h=>h.shape),a),s=t.filter(h=>k.sizeFromShape(h.shape)>0);if(s.length===1)return Nh({inputs:{x:s[0]},backend:n});let i=n.makeOutput(r,t[0].dtype);if(k.sizeFromShape(r)===0)return i;let o=s.map(h=>h.shape);if(C.assertParamsConsistent(o,a),s[0].dtype==="string"){let h=s.map(x=>{let w=k.sizeFromShape(x.shape.slice(a));return ba({inputs:{x},backend:n,attrs:{shape:[-1,w]}})}),m=h.map(x=>({vals:n.readSync(x.dataId),shape:x.shape}));r=C.computeOutShape(h.map(x=>x.shape),1);let f=h[0].shape[0]===1,A=HA(m,r,t[0].dtype,f),y=C.computeOutShape(s.map(x=>x.shape),a);i.shape=y;let g=n.dataIdMap.get(i.dataId);return g.stringBytes=C.fromStringArrayToUint8(A),h.forEach(x=>n.disposeData(x.dataId)),i}let l=k.sizeFromShape(s[0].shape.slice(0,a)),d=0,u=s.map(h=>{let m=k.sizeFromShape(h.shape.slice(a));return d+=m,m}),p=s.map(h=>n.typedArrayFromHeap(h)),c=n.typedArrayFromHeap(i);for(let h=0;h`cumsum does not support ${r.dtype} tensors in the WASM backend`);let d=C.getAxesPermutation([s],l),u=r;d!==null&&(u=Th({inputs:{x:r},attrs:{perm:d},backend:n}));let p=C.getInnerMostAxes(1,l)[0];C.assertAxesAreInnerMostDims("cumsum",[p],l);let c=n.makeOutput(u.shape,u.dtype),h=u.shape[p],m=n.dataIdMap.get(u.dataId).id,f=n.dataIdMap.get(c.dataId).id;Ew(m,i?1:0,o?1:0,h,f,Sn[r.dtype]);let A=c;if(d!==null){let y=C.getUndoAxesPermutation(d);A=Th({inputs:{x:c},attrs:{perm:y},backend:n}),n.disposeData(u.dataId),n.disposeData(c.dataId)}return A}var LK={kernelName:As,backendName:"wasm",setupFunc:_K,kernelFunc:PK},Cw;function WK(e){Cw=e.wasm.cwrap(fo,null,["number","number","number","array","number","array","array","number","number"])}function BK(e){let{backend:t,inputs:n,attrs:a}=e,{x:r}=n,{blockSize:s,dataFormat:i}=a;k.assert(s>1,()=>`blockSize should be > 1 for depthToSpace, but was: ${s}`);let o=r.shape[0],l=i==="NHWC"?r.shape[1]:r.shape[2],d=i==="NHWC"?r.shape[2]:r.shape[3],u=i==="NHWC"?r.shape[3]:r.shape[1],p=l*s,c=d*s,h=u/(s*s),m=i==="NHWC"?[o,p,c,h]:[o,h,p,c],f=t.makeOutput(m,"float32"),A=t.dataIdMap.get(r.dataId).id,y=new Uint8Array(new Int32Array(k.computeStrides(r.shape)).buffer),g=new Uint8Array(new Int32Array(m).buffer),x=new Uint8Array(new Int32Array(k.computeStrides(m)).buffer),w=t.dataIdMap.get(f.dataId).id;return Cw(A,s,i==="NHWC"?1:0,y,r.shape.length-1,g,x,m.length,w),f}var VK={kernelName:fo,backendName:"wasm",setupFunc:WK,kernelFunc:BK},Rw;function jK(e){Rw=e.wasm.cwrap(ys,null,["number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number"])}function UK(e){let{inputs:t,attrs:n,backend:a}=e,{x:r,filter:s}=t,i=a.dataIdMap.get(r.dataId).id,o=a.dataIdMap.get(s.dataId).id,{strides:l,dilations:d,pad:u,dimRoundingMode:p}=n,c=d==null?[1,1]:d,h=C.computeConv2DInfo(r.shape,s.shape,l,c,u,p,!0),m=h.filterHeight,f=h.filterWidth,A=h.padInfo.top,y=h.padInfo.right,g=h.padInfo.bottom,x=h.padInfo.left,w=h.dilationHeight,b=h.dilationWidth,v=h.strideHeight,N=h.strideWidth,T=h.inChannels,R=h.outChannels,$=h.padInfo.type==="SAME"?1:0;if(h.dataFormat!=="channelsLast")throw new Error(`wasm backend DepthwiseConv2dNative does not support dataFormat:'${h.dataFormat}'. Please use 'channelsLast'.`);let z=a.makeOutput(h.outShape,"float32"),P=a.dataIdMap.get(z.dataId).id;return Rw(i,r.shape[0],r.shape[1],r.shape[2],o,m,f,A,y,g,x,$,w,b,v,N,T,R,P),z}var HK={kernelName:ys,backendName:"wasm",setupFunc:jK,kernelFunc:UK},GK=!1,qK=mn(yo,GK,"bool"),XK=fn(xs);function I1(e){let{inputs:t,attrs:n,backend:a}=e,{input:r}=t,{dim:s}=n,i=r.shape.length,o=r.shape.slice(),l=s;return s<0&&(k.assert(-(i+1)<=s,()=>`Axis must be in the interval [${-(i+1)}, ${i}]`),l=i+s+1),o.splice(l,0,1),ba({inputs:{x:r},backend:a,attrs:{shape:o}})}var KK={kernelName:go,backendName:"wasm",kernelFunc:I1};function ZK(e){let{attrs:{shape:t,value:n,dtype:a},backend:r}=e,s=r.makeOutput(t,a);return r.typedArrayFromHeap(s).fill(n),s}var YK={kernelName:wu,backendName:"wasm",kernelFunc:ZK},Mw;function JK(e){Mw=e.wasm.cwrap(bo,null,["number","number","number","number","number","number"])}function QK(e){let{inputs:t,backend:n}=e,{image:a}=t,r=n.makeOutput(a.shape,a.dtype),s=n.dataIdMap.get(a.dataId).id,i=n.dataIdMap.get(r.dataId).id,[o,l,d,u]=a.shape;return Mw(s,o,l,d,u,i),r}var eZ={kernelName:bo,backendName:"wasm",kernelFunc:QK,setupFunc:JK},tZ=fn(bs),nZ=!1,aZ=mn(vs,nZ),Fw;function rZ(e){Fw=e.wasm.cwrap(ws,null,["number","number","number","number","number","number","number"])}function sZ(e){let{backend:t,inputs:n,attrs:a}=e,{varianceEpsilon:r}=a,{x:s,mean:i,variance:o,offset:l,scale:d}=n,u=t.dataIdMap.get(s.dataId).id,p=t.dataIdMap.get(i.dataId).id,c=t.dataIdMap.get(o.dataId).id,h=l!=null?t.dataIdMap.get(l.dataId).id:0,m=d!=null?t.dataIdMap.get(d.dataId).id:0,f=t.makeOutput(s.shape,s.dtype);if(k.sizeFromShape(s.shape)===0)return f;let A=t.dataIdMap.get(f.dataId).id;return Fw(u,p,c,h,m,r,A),f}var iZ={kernelName:ws,backendName:"wasm",setupFunc:rZ,kernelFunc:sZ},$w;function oZ(e){$w=e.wasm.cwrap(ni,null,["number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number"])}function lZ(e){let{inputs:t,attrs:n,backend:a}=e,{x:r,filter:s,bias:i,preluActivationWeights:o}=t,{strides:l,pad:d,dilations:u,dataFormat:p,dimRoundingMode:c,activation:h,leakyreluAlpha:m}=n,f=C.computeConv2DInfo(r.shape,s.shape,l,u,d,c),A=bd[h];if(A==null)throw new Error(`${h} activation not yet supported for FusedConv2D in the wasm backend.`);let y=a.dataIdMap.get(r.dataId).id,g=a.dataIdMap.get(s.dataId).id,x=f.outChannels,w=0;if(i!=null){let Q=a.dataIdMap.get(i.dataId);if(Q.shape.length!==1)throw new Error(`FusedConv2D only supports rank-1 bias but got rank ${Q.shape.length}.`);if(Q.shape[0]!==x)throw new Error(`FusedConv2D bias shape (${Q.shape}) does not match the number of output channels (${x})`);w=Q.id}let b=f.filterHeight,v=f.filterWidth,N=f.padInfo.top,T=f.padInfo.right,R=f.padInfo.bottom,$=f.padInfo.left,z=f.dilationHeight,P=f.dilationWidth,V=f.strideHeight,j=f.strideWidth,U=f.inChannels,X=f.padInfo.type==="SAME"?1:0,G=f.batchSize,ee=f.inHeight,Y=f.inWidth;if(p!=="NHWC")throw new Error(`wasm backend FusedConv2D does not support dataFormat:'${p}'. Please use 'NHWC'.`);let re=a.makeOutput(f.outShape,"float32"),ne=a.dataIdMap.get(re.dataId).id,ie=o==null?0:a.dataIdMap.get(o.dataId).id;return $w(y,G,ee,Y,g,b,v,w,N,T,R,$,X,z,P,V,j,U,x,A,ie,m||0,ne),re}var uZ={kernelName:ni,backendName:"wasm",setupFunc:oZ,kernelFunc:lZ},Dw;function dZ(e){Dw=e.wasm.cwrap(ai,null,["number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number"])}function pZ(e){let{inputs:t,attrs:n,backend:a}=e,{x:r,filter:s,bias:i,preluActivationWeights:o}=t,{strides:l,pad:d,dilations:u,dataFormat:p,dimRoundingMode:c,activation:h,leakyreluAlpha:m}=n,f=C.computeConv2DInfo(r.shape,s.shape,l,u,d,c,!0),A=bd[h];if(A==null)throw new Error(`${h} activation not yet supported for FusedDepthwiseConv2D in the wasm backend.`);let y=a.dataIdMap.get(r.dataId).id,g=a.dataIdMap.get(s.dataId).id,x=f.outChannels,w=0;if(i!=null){let Q=a.dataIdMap.get(i.dataId);if(Q.shape.length!==1)throw new Error(`FusedDepthwiseConv2D only supports rank-1 bias but got rank ${Q.shape.length}.`);if(Q.shape[0]!==x)throw new Error(`FusedDepthwiseConv2D bias shape (${Q.shape}) does not match the number of output channels (${x})`);w=Q.id}let b=f.filterHeight,v=f.filterWidth,N=f.padInfo.top,T=f.padInfo.right,R=f.padInfo.bottom,$=f.padInfo.left,z=f.dilationHeight,P=f.dilationWidth,V=f.strideHeight,j=f.strideWidth,U=f.inChannels,X=f.padInfo.type==="SAME"?1:0,G=f.batchSize,ee=f.inHeight,Y=f.inWidth;if(p!=="NHWC")throw new Error(`wasm backend FusedDepthwiseConv2D does not support dataFormat:'${p}'. Please use 'NHWC'.`);let re=a.makeOutput(f.outShape,"float32"),ne=a.dataIdMap.get(re.dataId).id,ie=o==null?0:a.dataIdMap.get(o.dataId).id;return Dw(y,G,ee,Y,g,b,v,w,N,T,R,$,X,z,P,V,j,U,x,A,ie,m||0,ne),re}var cZ={kernelName:ai,backendName:"wasm",setupFunc:dZ,kernelFunc:pZ},Ow;function hZ(e){Ow=e.wasm.cwrap(wo,null,["number","number","number","number","number","number","array","number"])}function fZ(e){let{backend:t,inputs:n}=e,{params:a,indices:r}=n,[s,i,o,l]=Vm.prepareAndValidate(a,r),d=t.makeOutput(s,a.dtype);if(i===0)return d;let u=r.shape,p=u[u.length-1],c=t.dataIdMap.get(a.dataId).id,h=t.dataIdMap.get(r.dataId).id,m=new Uint8Array(new Int32Array(l).buffer),f=t.dataIdMap.get(d.dataId).id;return Ow(c,Sn[a.dtype],h,i,p,o,m,f),d}var mZ={kernelName:wo,backendName:"wasm",setupFunc:hZ,kernelFunc:fZ},zw;function AZ(e){zw=e.wasm.cwrap("Gather",null,["number","number","array","number","number","number","array","number"])}function yZ(e){let{backend:t,inputs:n,attrs:a}=e,{x:r,indices:s}=n,{axis:i,batchDims:o}=a,l=k.parseAxisParam(i,r.shape)[0],d=C.segment_util.collectGatherOpShapeInfo(r,s,l,o),u=ba({inputs:{x:r},attrs:{shape:[d.batchSize,d.outerSize,d.dimSize,d.sliceSize]},backend:t}),p=k.sizeFromShape(s.shape),c=ba({inputs:{x:s},attrs:{shape:[d.batchSize,p/d.batchSize]},backend:t}),h=[d.batchSize,d.outerSize,p/d.batchSize,d.sliceSize],m=t.makeOutput(h,r.dtype);if(k.sizeFromShape(r.shape)===0)return m;let f=u.shape.length-1,A=t.dataIdMap.get(u.dataId).id,y=t.dataIdMap.get(c.dataId).id,g=t.dataIdMap.get(m.dataId).id,x=new Uint8Array(new Int32Array(k.computeStrides(u.shape)).buffer),w=new Uint8Array(new Int32Array(k.computeStrides(h)).buffer);return zw(A,Sn[r.dtype],x,f,y,d.batchSize,w,g),t.disposeData(u.dataId),t.disposeData(c.dataId),m.shape=d.outputShape,m}var gZ={kernelName:vo,backendName:"wasm",setupFunc:AZ,kernelFunc:yZ},xZ=!1,bZ=mn(ko,xZ,"bool"),vZ=!1,wZ=mn(ks,vZ,"bool"),_w;function kZ(e){_w=e.wasm.cwrap(Ss,null,["number","number","number"])}function IZ(e){let{inputs:{x:t},attrs:{alpha:n},backend:a}=e,r=a.dataIdMap.get(t.dataId).id,s=a.makeOutput(t.shape,t.dtype);if(k.sizeFromShape(t.shape)!==0){let i=a.dataIdMap.get(s.dataId).id;_w(r,n,i)}return s}var SZ={kernelName:Ss,backendName:"wasm",setupFunc:kZ,kernelFunc:IZ},NZ=!1,TZ=mn(To,NZ,"bool"),EZ=!1,CZ=mn(Eo,EZ,"bool"),RZ=fn(Ns),MZ=!1,FZ=mn(Ro,MZ,"bool"),Pw;function $Z(e){Pw=e.wasm.cwrap(Ts,null,["number, number, number"])}function DZ(e){let{backend:t,inputs:n,attrs:a}=e,{reductionIndices:r,keepDims:s}=a,{x:i}=n,o=t.dataIdMap.get(i.dataId).id,l=i,{transposed:d,axes:u,originalAxes:p,inputWasTransposed:c}=Br(i,r,t);if(c){let g=t.dataIdMap.get(d.dataId).id;l=d,o=g}let h=l.shape.length;C.assertAxesAreInnerMostDims("max",u,h);let[m,f]=C.computeOutAndReduceShapes(l.shape,u),A=k.sizeFromShape(f),y=t.makeOutput(m,i.dtype);if(k.sizeFromShape(l.shape)!==0){let g=t.dataIdMap.get(y.dataId).id;Pw(o,A,g)}if(c&&t.disposeData(d.dataId),s){let g=C.expandShapeToKeepDim(y.shape,p);y.shape=g}return y}var OZ={kernelName:Ts,backendName:"wasm",setupFunc:$Z,kernelFunc:DZ},zZ=!1,_Z=mn(Es,zZ),Lw;function PZ(e){Lw=e.wasm.cwrap(Cs,null,["number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number"])}function LZ(e){let{inputs:t,attrs:n,backend:a}=e,r=t.x,s=a.dataIdMap.get(r.dataId).id,{filterSize:i,strides:o,pad:l,dimRoundingMode:d}=n,u=C.computePool2DInfo(r.shape,i,o,1,l,d),p=u.filterHeight,c=u.filterWidth,h=u.padInfo.top,m=u.padInfo.right,f=u.padInfo.bottom,A=u.padInfo.left,y=u.dilationHeight,g=u.dilationWidth,x=u.strideHeight,w=u.strideWidth,b=u.inChannels,v=u.outChannels;if(u.dataFormat!=="channelsLast")throw new Error(`wasm backend does not support dataFormat:'${u.dataFormat}'. Please use 'channelsLast'.`);let N=a.makeOutput(u.outShape,"float32"),T=a.dataIdMap.get(N.dataId).id;return Lw(s,r.shape[0],r.shape[1],r.shape[2],p,c,h,m,f,A,y,g,x,w,b,v,T),N}var WZ={kernelName:Cs,backendName:"wasm",setupFunc:PZ,kernelFunc:LZ},Ww;function BZ(e){Ww=e.wasm.cwrap(Rs,null,["number, number, number"])}function VZ(e){let{backend:t,inputs:n,attrs:a}=e,{axis:r,keepDims:s}=a,{x:i}=n,o=t.dataIdMap.get(i.dataId).id,l=o,d=i,{transposed:u,axes:p,originalAxes:c,inputWasTransposed:h}=Br(i,r,t),m=p;if(h){let w=t.dataIdMap.get(u.dataId).id;w!==o&&(d=u,l=w,m=C.getInnerMostAxes(m.length,d.shape.length))}C.assertAxesAreInnerMostDims("mean",m,d.shape.length);let[f,A]=C.computeOutAndReduceShapes(d.shape,m),y=k.sizeFromShape(A),g=d;d.dtype!=="float32"&&(g=Eh({backend:t,inputs:{x:d},attrs:{dtype:"float32"}}),l=t.dataIdMap.get(g.dataId).id);let x=t.makeOutput(f,"float32");if(k.sizeFromShape(d.shape)!==0){let w=t.dataIdMap.get(x.dataId).id;Ww(l,y,w)}if(h&&t.disposeData(u.dataId),s){let w=C.expandShapeToKeepDim(x.shape,c);x.shape=w}return d.dtype!=="float32"&&t.disposeData(g.dataId),x}var jZ={kernelName:Rs,backendName:"wasm",setupFunc:BZ,kernelFunc:VZ},Bw;function UZ(e){Bw=e.wasm.cwrap(Ms,null,["number, number, number"])}function HZ(e){let{backend:t,inputs:n,attrs:a}=e,{axis:r,keepDims:s}=a,{x:i}=n,o=t.dataIdMap.get(i.dataId).id,l=o,d=i,{transposed:u,axes:p,originalAxes:c,inputWasTransposed:h}=Br(i,r,t);if(h){let x=t.dataIdMap.get(u.dataId).id;x!==o&&(d=u,l=x)}let m=d.shape.length;C.assertAxesAreInnerMostDims("min",p,m);let[f,A]=C.computeOutAndReduceShapes(d.shape,p),y=k.sizeFromShape(A),g=t.makeOutput(f,d.dtype);if(k.sizeFromShape(d.shape)!==0){let x=t.dataIdMap.get(g.dataId).id;Bw(l,y,x)}if(h&&t.disposeData(u.dataId),s){let x=C.expandShapeToKeepDim(g.shape,c);g.shape=x}return g}var GZ={kernelName:Ms,backendName:"wasm",setupFunc:UZ,kernelFunc:HZ},qZ=!1,XZ=mn(Fs,qZ),S1;(function(e){e[e.reflect=0]="reflect",e[e.symmetric=1]="symmetric"})(S1||(S1={}));var Vw;function KZ(e){Vw=e.wasm.cwrap($s,null,["number","array","number","number","array","array","number","number"])}function ZZ(e){let{inputs:{x:t},backend:n,attrs:{paddings:a,mode:r}}=e,s=a.map((m,f)=>m[0]+t.shape[f]+m[1]),i=n.dataIdMap.get(t.dataId).id,o=n.makeOutput(s,t.dtype),l=n.dataIdMap.get(o.dataId).id,d=new Uint8Array(new Int32Array(t.shape).buffer),u=a.map(m=>m[0]),p=a.map(m=>m[1]),c=new Uint8Array(new Int32Array(u).buffer),h=new Uint8Array(new Int32Array(p).buffer);return Vw(i,d,t.shape.length,Sn[t.dtype],c,h,S1[r],l),o}var YZ={kernelName:$s,backendName:"wasm",kernelFunc:ZZ,setupFunc:KZ},JZ=!0,QZ=mn(Ds,JZ),eY=fn(Fo);function N1(e,t){let n=new Int32Array(e.wasm.HEAPU8.buffer,t,4),a=n[0],r=n[1],s=n[2],i=n[3];return e.wasm._free(t),{pSelectedIndices:a,selectedSize:r,pSelectedScores:s,pValidOutputs:i}}var jw;function tY(e){jw=e.wasm.cwrap(Do,"number",["number","number","number","number","number"])}function nY(e){let{backend:t,inputs:n,attrs:a}=e,{iouThreshold:r,maxOutputSize:s,scoreThreshold:i}=a,{boxes:o,scores:l}=n,d=t.dataIdMap.get(o.dataId).id,u=t.dataIdMap.get(l.dataId).id,p=jw(d,u,s,r,i),{pSelectedIndices:c,selectedSize:h,pSelectedScores:m,pValidOutputs:f}=N1(t,p);return t.wasm._free(m),t.wasm._free(f),t.makeOutput([h],"int32",c)}var aY={kernelName:Do,backendName:"wasm",setupFunc:tY,kernelFunc:nY},Uw;function rY(e){Uw=e.wasm.cwrap(Oo,"number",["number","number","number","number","number","bool"])}function sY(e){let{backend:t,inputs:n,attrs:a}=e,{iouThreshold:r,maxOutputSize:s,scoreThreshold:i,padToMaxOutputSize:o}=a,{boxes:l,scores:d}=n,u=t.dataIdMap.get(l.dataId).id,p=t.dataIdMap.get(d.dataId).id,c=Uw(u,p,s,r,i,o),{pSelectedIndices:h,selectedSize:m,pSelectedScores:f,pValidOutputs:A}=N1(t,c);t.wasm._free(f);let y=t.makeOutput([m],"int32",h),g=t.makeOutput([],"int32",A);return[y,g]}var iY={kernelName:Oo,backendName:"wasm",setupFunc:rY,kernelFunc:sY},Hw;function oY(e){Hw=e.wasm.cwrap(zo,"number",["number","number","number","number","number","number"])}function lY(e){let{backend:t,inputs:n,attrs:a}=e,{iouThreshold:r,maxOutputSize:s,scoreThreshold:i,softNmsSigma:o}=a,{boxes:l,scores:d}=n,u=t.dataIdMap.get(l.dataId).id,p=t.dataIdMap.get(d.dataId).id,c=Hw(u,p,s,r,i,o),{pSelectedIndices:h,selectedSize:m,pSelectedScores:f,pValidOutputs:A}=N1(t,c);t.wasm._free(A);let y=t.makeOutput([m],"int32",h),g=t.makeOutput([m],"float32",f);return[y,g]}var uY={kernelName:zo,backendName:"wasm",setupFunc:oY,kernelFunc:lY},dY=!1,pY=mn($o,dY,"bool"),Gw;function cY(e){Gw=e.wasm.cwrap(Os,null,["number","number","number","number","number"])}function hY(e){let{inputs:t,backend:n,attrs:a}=e,{indices:r}=t,{depth:s,onValue:i,offValue:o}=a,l=n.makeOutput([...r.shape,s],"int32"),d=n.dataIdMap.get(l.dataId).id,u=n.dataIdMap.get(r.dataId).id;return Gw(u,s,i,o,d),l}var fY={kernelName:Os,backendName:"wasm",setupFunc:cY,kernelFunc:hY};function mY(e){let{inputs:{x:t},backend:n}=e,a=n.makeOutput(t.shape,t.dtype);return n.typedArrayFromHeap(a).fill(1),a}var AY={kernelName:_o,backendName:"wasm",kernelFunc:mY};function yY(e){let{inputs:t,backend:n,attrs:a}=e,{axis:r}=a;if(t.length===1)return I1({inputs:{input:t[0]},backend:n,attrs:{dim:r}});let s=t[0].shape,i=t[0].dtype;t.forEach(u=>{k.assertShapesMatch(s,u.shape,"All tensors passed to stack must have matching shapes"),k.assert(i===u.dtype,()=>"All tensors passed to stack must have matching dtypes")});let o=[],l=t.map(u=>{let p=I1({inputs:{input:u},backend:n,attrs:{dim:r}});return o.push(p),p}),d=Iw({inputs:l,backend:n,attrs:{axis:r}});return o.forEach(u=>n.disposeData(u.dataId)),d}var gY={kernelName:Po,backendName:"wasm",kernelFunc:yY},qw;function xY(e){qw=e.wasm.cwrap(zs,null,["number","array","number","number","array","array","number","number"])}function bY(e){let{inputs:{x:t},backend:n,attrs:{paddings:a,constantValue:r}}=e,s=a.map((m,f)=>m[0]+t.shape[f]+m[1]),i=n.dataIdMap.get(t.dataId).id,o=n.makeOutput(s,t.dtype),l=n.dataIdMap.get(o.dataId).id,d=new Uint8Array(new Int32Array(t.shape).buffer),u=a.map(m=>m[0]),p=a.map(m=>m[1]),c=new Uint8Array(new Int32Array(u).buffer),h=new Uint8Array(new Int32Array(p).buffer);return qw(i,d,t.shape.length,Sn[t.dtype],c,h,r,l),o}var vY={kernelName:zs,backendName:"wasm",kernelFunc:bY,setupFunc:xY},wY=!1,kY=mn(_s,wY),Xw;function IY(e){Xw=e.wasm.cwrap(Ps,null,["number","number","number"])}function SY(e){let{inputs:t,backend:n}=e,{x:a,alpha:r}=t,s=n.dataIdMap.get(a.dataId).id,i=n.dataIdMap.get(r.dataId).id,o=n.makeOutput(a.shape,"float32"),l=n.dataIdMap.get(o.dataId).id;return Xw(s,i,l),o}var NY={kernelName:Ps,backendName:"wasm",setupFunc:IY,kernelFunc:SY},Kw;function TY(e){Kw=e.wasm.cwrap(Lo,null,["number","number","number","number"])}function EY(e){let{backend:t,inputs:n,attrs:a}=e,{axis:r,keepDims:s}=a,{x:i}=n,o=t.dataIdMap.get(i.dataId).id,l=o,d=i,{transposed:u,axes:p,originalAxes:c,inputWasTransposed:h}=Br(i,r,t),m=p;if(h){let x=t.dataIdMap.get(u.dataId).id;x!==o&&(d=u,l=x,m=C.getInnerMostAxes(m.length,d.shape.length))}C.assertAxesAreInnerMostDims("prod",m,d.shape.length);let[f,A]=C.computeOutAndReduceShapes(d.shape,m),y=k.sizeFromShape(A),g=t.makeOutput(f,d.dtype);if(k.sizeFromShape(d.shape)!==0){let x=t.dataIdMap.get(g.dataId).id;Kw(l,y,Sn[g.dtype],x)}if(h&&t.disposeData(u.dataId),s){let x=C.expandShapeToKeepDim(g.shape,c);g.shape=x}return g}var CY={kernelName:Lo,backendName:"wasm",setupFunc:TY,kernelFunc:EY},RY=e=>{let{backend:t,attrs:n}=e,{start:a,stop:r,step:s,dtype:i}=n,o=XA(a,r,s,i),l=t.makeOutput([o.length],i);return t.typedArrayFromHeap(l).set(o),l},MY={kernelName:Tu,backendName:"wasm",kernelFunc:RY},FY=!0,$Y=mn(gs,FY),DY=fn(Ls),OY=fn(Bs),Zw;function zY(e){Zw=e.wasm.cwrap(Ws,null,["number","number","number","number","number","number","number","number","number","number"])}function _Y(e){let{backend:t,inputs:n,attrs:a}=e,{images:r}=n,{alignCorners:s,halfPixelCenters:i,size:o}=a,[l,d]=o,[u,p,c,h]=r.shape,m=[u,l,d,h],f=t.dataIdMap.get(r.dataId),A;f.dtype!=="float32"&&(A=Eh({backend:t,inputs:{x:r},attrs:{dtype:"float32"}}),f=t.dataIdMap.get(A.dataId));let y=f.id,g=t.makeOutput(m,"float32");if(k.sizeFromShape(r.shape)===0)return g;let x=t.dataIdMap.get(g.dataId).id;return Zw(y,u,p,c,h,l,d,s?1:0,i?1:0,x),A!=null&&t.disposeData(A.dataId),g}var PY={kernelName:Ws,backendName:"wasm",setupFunc:zY,kernelFunc:_Y},Yw;function LY(e){Yw=e.wasm.cwrap(Vs,null,["number","array","number","array","number","number"])}function WY(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{dims:s}=a,i=k.parseAxisParam(s,r.shape);if(r.shape.length===0)return Nh({inputs:{x:r},backend:n});let o=n.makeOutput(r.shape,r.dtype),l=n.dataIdMap.get(r.dataId).id,d=n.dataIdMap.get(o.dataId).id,u=new Uint8Array(new Int32Array(i).buffer),p=new Uint8Array(new Int32Array(r.shape).buffer);Yw(l,u,i.length,p,r.shape.length,d);let c=ba({inputs:{x:o},attrs:{shape:r.shape},backend:n});return n.disposeData(o.dataId),c}var BY={kernelName:Vs,backendName:"wasm",kernelFunc:WY,setupFunc:LY},Jw;function VY(e){Jw=e.wasm.cwrap(tl,null,["number","number","number","number","number","number","number","number","array","number","number"])}function jY(e){let{inputs:t,backend:n,attrs:a}=e,{image:r}=t,{radians:s,fillValue:i,center:o}=a,l=n.makeOutput(r.shape,r.dtype),d=n.dataIdMap.get(r.dataId).id,u=n.dataIdMap.get(l.dataId).id,[p,c,h,m]=r.shape,[f,A]=C.getImageCenter(o,c,h),y=i===0,g=255,x=typeof i=="number"?[i,i,i,y?0:g]:[...i,g],w=new Uint8Array(new Int32Array(x).buffer);return Jw(d,p,c,h,m,s,f,A,w,x.length,u),l}var UY={kernelName:tl,backendName:"wasm",kernelFunc:jY,setupFunc:VY},HY=fn(js),GY=fn(Us),Qw;function qY(e){Qw=e.wasm.cwrap(Vo,null,["number","number","number","number","number","number","array","number","number"])}function XY(e){let{backend:t,inputs:n,attrs:a}=e,{indices:r,updates:s}=n,{shape:i}=a,o=t.makeOutput(i,s.dtype);if(k.sizeFromShape(i)===0)return o;let{sliceRank:l,numUpdates:d,sliceSize:u,strides:p,outputSize:c}=jm.calculateShapes(s,r,i),h=t.dataIdMap.get(r.dataId).id,m=t.dataIdMap.get(s.dataId).id,f=new Uint8Array(new Int32Array(p).buffer),A=t.dataIdMap.get(o.dataId).id;return Qw(h,m,Sn[s.dtype],l,d,u,f,c,A),o}var KY={kernelName:Vo,backendName:"wasm",setupFunc:qY,kernelFunc:XY},e6;function ZY(e){e6=e.wasm.cwrap("SelectV2",null,["number","number","number","number","number"])}function YY(e){let{inputs:t,backend:n}=e,{condition:a,t:r,e:s}=t,i=n.dataIdMap.get(a.dataId).id,o=n.dataIdMap.get(r.dataId).id,l=n.dataIdMap.get(s.dataId).id,d=n.makeOutput(r.shape,r.dtype),u=n.dataIdMap.get(d.dataId).id,p=a.shape.length,c=r.shape.length,h=p===0||p>1||c===1?1:k.sizeFromShape(r.shape.slice(1));return e6(i,o,l,h,u),d}var JY={kernelName:jo,backendName:"wasm",kernelFunc:YY,setupFunc:ZY},t6;function QY(e){t6=e.wasm.cwrap(Gs,null,["number","number"])}function eJ(e){let{backend:t,inputs:{x:n}}=e,a=t.dataIdMap.get(n.dataId).id,r=t.makeOutput(n.shape,n.dtype),s=t.dataIdMap.get(r.dataId).id;return k.sizeFromShape(r.shape)===0||t6(a,s),r}var tJ={kernelName:"Sigmoid",backendName:"wasm",setupFunc:QY,kernelFunc:eJ},nJ=fn(Hs);function Ch(e){let{inputs:{x:t},attrs:{begin:n,size:a},backend:r}=e,[s,i]=ln.parseSliceParams(t,n,a),o=ln.isSliceContinous(t.shape,s,i),l=r.readSync(t.dataId),d=r.makeOutput(i,t.dtype),u=k.computeStrides(t.shape),p=r.dataIdMap.get(d.dataId);if(o){let m=ln.computeFlatOffset(s,u);return t.dtype==="string"?p.stringBytes=l.slice(m,m+k.sizeFromShape(i)):r.typedArrayFromHeap(d).set(l.subarray(m,m+k.sizeFromShape(i))),d}if(t.dtype==="string"){let m=ah(l,s,i,t.shape,t.dtype);return p.stringBytes=m,d}let c=r.typedArrayFromHeap(d),h=t.shape.length;if(h===2)aJ(l,u[0],c,s,i);else if(h===3)rJ(l,u[0],u[1],c,s,i);else if(h===4)sJ(l,u[0],u[1],u[2],c,s,i);else{let m=ah(l,s,i,t.shape,t.dtype);c.set(m)}return d}function aJ(e,t,n,a,r){let s=0,i=a[0],o=a[1],l=i+r[0];for(let d=i;d{let c=[...u];c[o]=p;let h=Ch({inputs:{x:r},attrs:{begin:d,size:c},backend:a});return d[o]+=p,h})}var pJ={kernelName:Ko,backendName:"wasm",kernelFunc:dJ},cJ=fn(qs),hJ=fn(Ru),fJ=!0,mJ=mn(Zs,fJ),a6;function AJ(e){a6=e.wasm.cwrap(Nr,null,["number","number","number"])}function yJ(e){let{backend:t,inputs:n,attrs:a}=e,{alpha:r}=a,{x:s}=n,i=t.dataIdMap.get(s.dataId).id,o=t.makeOutput(s.shape,s.dtype),l=t.dataIdMap.get(o.dataId).id;return a6(i,r,l),o}var gJ={kernelName:Nr,backendName:"wasm",setupFunc:AJ,kernelFunc:yJ},r6;function xJ(e){r6=e.wasm.cwrap(Zo,null,["number","array","number","array","array","array","array","array","number","number"])}function bJ(e){let{backend:t,inputs:n,attrs:a}=e,{x:r}=n,{begin:s,end:i,strides:o}=a;o==null&&(o=new Array(s.length));let{beginMask:l,endMask:d,ellipsisMask:u,newAxisMask:p,shrinkAxisMask:c}=a,h=C.slice_util.maskToAxes(u);if(h.length>1)throw new Error("Multiple ellipses in slice is not allowed.");if(u!==0&&p!==0)throw new Error("Using both ellipsisMask and newAxisMask is not yet supported.");if(u!==0&&c!==0)throw new Error("Using both ellipsisMask and shrinkAxisMask is not yet supported.");let m=r.shape.length-s.length,f=C.slice_util.maskToAxes(p),A=r.shape.slice();f.forEach($=>{s[$]=0,i[$]=1,A.splice($,0,1)});let y=ba({inputs:{x:r},attrs:{shape:A},backend:t}),{begin:g,end:x,strides:w}=C.slice_util.getNormalizedAxes(y.shape,h,m,s,i,o,l,d,u);s=g,i=x,o=w;let b=C.slice_util.maskToAxes(c);b.forEach($=>{i[$]=s[$]+1,o[$]=1});let v=C.slice_util.computeOutShape(s,i,o),N=v.filter(($,z)=>b.indexOf(z)===-1);if(o.every($=>$===1)){let $=Ch({inputs:{x:y},attrs:{begin:s,size:v},backend:t});t.disposeData(y.dataId);let z=ba({inputs:{x:$},attrs:{shape:N},backend:t});return t.disposeData($.dataId),z}let T=t.makeOutput(N,"float32");if(!N.some($=>$===0)){let $=t.dataIdMap.get(y.dataId).id,z=new Uint8Array(new Int32Array(k.computeStrides(y.shape)).buffer),P=new Uint8Array(new Int32Array(s).buffer),V=new Uint8Array(new Int32Array(i).buffer),j=new Uint8Array(new Int32Array(o).buffer),U=new Uint8Array(new Int32Array(N).buffer),X=new Uint8Array(new Int32Array(k.computeStrides(N)).buffer),G=t.dataIdMap.get(T.dataId).id;r6($,z,y.shape.length,P,V,j,U,X,N.length,G)}t.disposeData(y.dataId);let R=ba({inputs:{x:T},attrs:{shape:N},backend:t});return t.disposeData(T.dataId),R}var vJ={kernelName:Zo,backendName:"wasm",setupFunc:xJ,kernelFunc:bJ},wJ=!0,kJ=mn(Ys,wJ),s6;function IJ(e){s6=e.wasm.cwrap(Xs,null,["number, number, number"])}function SJ(e){let{backend:t,inputs:n,attrs:a}=e,{axis:r,keepDims:s}=a,{x:i}=n,o=t.dataIdMap.get(i.dataId).id,l=o,d=i,{transposed:u,axes:p,originalAxes:c,inputWasTransposed:h}=Br(i,r,t),m=p;if(h){let x=t.dataIdMap.get(u.dataId).id;x!==o&&(d=u,l=x,m=C.getInnerMostAxes(m.length,d.shape.length))}C.assertAxesAreInnerMostDims("sum",m,d.shape.length);let[f,A]=C.computeOutAndReduceShapes(d.shape,m),y=k.sizeFromShape(A),g=t.makeOutput(f,d.dtype);if(k.sizeFromShape(d.shape)!==0){let x=t.dataIdMap.get(g.dataId).id;s6(l,y,x)}if(h&&t.disposeData(u.dataId),s){let x=C.expandShapeToKeepDim(g.shape,c);g.shape=x}return g}var NJ={kernelName:Xs,backendName:"wasm",setupFunc:IJ,kernelFunc:SJ},TJ=fn(Js),EJ=fn(Qs),i6;function CJ(e){i6=e.wasm.cwrap(Sr,null,["number","array","number","array","number","number"])}function RJ(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,s=n.dataIdMap.get(r.dataId).id,{reps:i}=a,o=new Array(r.shape.length);for(let c=0;c{let{x:a}=e,{k:r,sorted:s}=n,i=t.dataIdMap.get(a.dataId).id,o=new Uint8Array(new Int32Array(a.shape).buffer),l=a.shape.slice();l[l.length-1]=r;let d=t.makeOutput(l,a.dtype),u=t.dataIdMap.get(d.dataId).id,p=t.makeOutput(l,"int32"),c=t.dataIdMap.get(p.dataId).id;return o6(i,o,a.shape.length,Sn[a.dtype],r,s,u,c),[d,p]},DJ={kernelName:Yo,backendName:"wasm",setupFunc:FJ,kernelFunc:$J},l6;function OJ(e){l6=e.wasm.cwrap(Jo,null,["number","number","bool","number","number","number","number","number","number","array","number","number","number","number","number"])}function zJ(e){let{backend:t,inputs:n,attrs:a}=e,{image:r,transforms:s}=n,{interpolation:i,fillMode:o,fillValue:l,outputShape:d}=a,[u,p,c,h]=r.shape,[m,f]=d!=null?d:[p,c],A=[u,m,f,h],y=new Uint8Array(new Int32Array(k.computeStrides(r.shape)).buffer),g=t.makeOutput(A,r.dtype),x=t.dataIdMap.get(g.dataId).id,w=t.dataIdMap.get(r.dataId).id,b=t.dataIdMap.get(s.dataId).id,v=i==="nearest"?1:2,N;switch(o){case"constant":N=1;break;case"reflect":N=2;break;case"wrap":N=3;break;case"nearest":N=4;break;default:N=1;break}return l6(w,b,s.shape[0]>1,u,m,f,h,c,p,y,r.shape.length-1,v,N,l,x),g}var _J={kernelName:Jo,backendName:"wasm",setupFunc:OJ,kernelFunc:zJ};function PJ(e){let{inputs:t,backend:n,attrs:a}=e,{value:r}=t,{axis:s}=a;s<0&&(s+=r.shape.length);let i=r.shape[s],o=r.shape.length,l=new Array(o-1),d=0;for(let h=0;h({dataId:h,dtype:m,shape:l}))}var LJ={kernelName:Qo,backendName:"wasm",kernelFunc:PJ};function WJ(e){let{inputs:{x:t},backend:n}=e,a=n.makeOutput(t.shape,t.dtype);return n.typedArrayFromHeap(a).fill(0),a}var BJ={kernelName:el,backendName:"wasm",kernelFunc:WJ},VJ=[XX,ZX,QX,oK,dK,hK,AK,bK,vK,wK,SK,NK,CK,FK,$K,zK,LK,VK,HK,qK,XK,KK,YK,eZ,tZ,aZ,qX,iZ,uZ,cZ,mZ,gZ,bZ,wZ,eK,SZ,TZ,CZ,RZ,FZ,OZ,_Z,WZ,jZ,GZ,XZ,YZ,QZ,eY,aY,iY,uY,pY,fY,AY,gY,vY,kY,NY,CY,MY,$Y,DY,OY,yK,PY,BY,UY,GY,HY,KY,JY,tJ,nJ,iJ,uJ,pJ,cJ,hJ,mJ,gJ,vJ,kJ,NJ,TJ,EJ,MJ,DJ,_J,rK,LJ,BJ];for(let e of VJ)ri(e);var T1=J();T1.registerFlag("WASM_HAS_SIMD_SUPPORT",async()=>WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,2,1,0,10,9,1,7,0,65,0,253,15,26,11])));T1.registerFlag("WASM_HAS_MULTITHREAD_SUPPORT",async()=>{if(T1.get("IS_NODE"))return!1;try{return new MessageChannel().port1.postMessage(new SharedArrayBuffer(1)),WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,2,1,0,5,4,1,3,1,1,10,11,1,9,0,65,0,254,16,2,0,26,11]))}catch(e){return!1}});var u6=Yi(nI()),jJ='var Module={};function threadPrintErr(){var text=Array.prototype.slice.call(arguments).join(" ");console.error(text)}function threadAlert(){var text=Array.prototype.slice.call(arguments).join(" ");postMessage({cmd:"alert",text:text,threadId:Module["_pthread_self"]()})}var err=threadPrintErr;this.alert=threadAlert;Module["instantiateWasm"]=function(info,receiveInstance){var instance=new WebAssembly.Instance(Module["wasmModule"],info);Module["wasmModule"]=null;receiveInstance(instance);return instance.exports};function moduleLoaded(){}this.onmessage=function(e){try{if(e.data.cmd==="load"){Module["wasmModule"]=e.data.wasmModule;Module["wasmMemory"]=e.data.wasmMemory;Module["buffer"]=Module["wasmMemory"].buffer;Module["ENVIRONMENT_IS_PTHREAD"]=true;if(typeof e.data.urlOrBlob==="string"){importScripts(e.data.urlOrBlob)}else{var objectUrl=URL.createObjectURL(e.data.urlOrBlob);importScripts(objectUrl);URL.revokeObjectURL(objectUrl)}WasmBackendModuleThreadedSimd(Module).then(function(instance){Module=instance;moduleLoaded()})}else if(e.data.cmd==="objectTransfer"){Module["PThread"].receiveObjectTransfer(e.data)}else if(e.data.cmd==="run"){Module["__performance_now_clock_drift"]=performance.now()-e.data.time;Module["__emscripten_thread_init"](e.data.threadInfoStruct,0,0);var max=e.data.stackBase;var top=e.data.stackBase+e.data.stackSize;Module["establishStackSpace"](top,max);Module["_emscripten_tls_init"]();Module["PThread"].receiveObjectTransfer(e.data);Module["PThread"].setThreadStatus(Module["_pthread_self"](),1);try{var result=Module["invokeEntryPoint"](e.data.start_routine,e.data.arg);if(!Module["getNoExitRuntime"]())Module["PThread"].threadExit(result)}catch(ex){if(ex==="Canceled!"){Module["PThread"].threadCancel()}else if(ex!="unwind"){if(ex instanceof Module["ExitStatus"]){if(Module["getNoExitRuntime"]()){}else{Module["PThread"].threadExit(ex.status)}}else{Module["PThread"].threadExit(-2);throw ex}}}}else if(e.data.cmd==="cancel"){if(Module["_pthread_self"]()){Module["PThread"].threadCancel()}}else if(e.data.target==="setimmediate"){}else if(e.data.cmd==="processThreadQueue"){if(Module["_pthread_self"]()){Module["_emscripten_current_thread_process_queued_calls"]()}}else{err("worker.js received unknown command "+e.data.cmd);err(e.data)}}catch(ex){err("worker.js onmessage() captured an uncaught exception: "+ex);if(ex&&ex.stack)err(ex.stack);throw ex}};if(typeof process==="object"&&typeof process.versions==="object"&&typeof process.versions.node==="string"){self={location:{href:__filename}};var onmessage=this.onmessage;var nodeWorkerThreads=require("worker_threads");global.Worker=nodeWorkerThreads.Worker;var parentPort=nodeWorkerThreads.parentPort;parentPort.on("message",function(data){onmessage({data:data})});var nodeFS=require("fs");var nodeRead=function(filename){return nodeFS.readFileSync(filename,"utf8")};function globalEval(x){global.require=require;global.Module=Module;eval.call(null,x)}importScripts=function(f){globalEval(nodeRead(f))};postMessage=function(msg){parentPort.postMessage(msg)};if(typeof performance==="undefined"){performance={now:function(){return Date.now()}}}}',UJ=Yi(aI()),d6=class extends hu{constructor(e){super();this.wasm=e,this.dataIdNextNumber=1,this.wasm.tfjs.init(),this.dataIdMap=new Ip(this,nr())}write(e,t,n){let a={id:this.dataIdNextNumber++};return this.move(a,e,t,n,1),a}numDataIds(){return this.dataIdMap.numDataIds()}async time(e){let t=k.now();return e(),{kernelMs:k.now()-t}}move(e,t,n,a,r){let s=this.dataIdNextNumber++;if(a==="string"){let d=t;this.dataIdMap.set(e,{id:s,stringBytes:d,shape:n,dtype:a,memoryOffset:null,refCount:r});return}let i=k.sizeFromShape(n),o=i*k.bytesPerElement(a),l=this.wasm._malloc(o);this.dataIdMap.set(e,{id:s,memoryOffset:l,shape:n,dtype:a,refCount:r}),this.wasm.tfjs.registerTensor(s,i,l),t!=null&&this.wasm.HEAPU8.set(new Uint8Array(t.buffer,t.byteOffset,o),l)}async read(e){return this.readSync(e)}readSync(e){let{memoryOffset:t,dtype:n,shape:a,stringBytes:r}=this.dataIdMap.get(e);if(n==="string")return r;let s=this.wasm.HEAPU8.slice(t,t+k.sizeFromShape(a)*k.bytesPerElement(n));return HJ(s.buffer,n)}disposeData(e,t=!1){if(this.dataIdMap.has(e)){let n=this.dataIdMap.get(e);if(n.refCount--,!t&&n.refCount>0)return!1;this.wasm._free(n.memoryOffset),this.wasm.tfjs.disposeData(n.id),this.dataIdMap.delete(e)}return!0}refCount(e){return this.dataIdMap.has(e)?this.dataIdMap.get(e).refCount:0}incRef(e){let t=this.dataIdMap.get(e);t!=null&&t.refCount++}floatPrecision(){return 32}getMemoryOffset(e){return this.dataIdMap.get(e).memoryOffset}dispose(){this.wasm.tfjs.dispose(),"PThread"in this.wasm&&this.wasm.PThread.terminateAllThreads(),this.wasm=null}memory(){return{unreliable:!1}}makeOutput(e,t,n){let a;if(n==null)a=this.write(null,e,t);else{let r=this.dataIdNextNumber++;a={id:r},this.dataIdMap.set(a,{id:r,memoryOffset:n,shape:e,dtype:t,refCount:1});let s=k.sizeFromShape(e);this.wasm.tfjs.registerTensor(r,s,n)}return{dataId:a,shape:e,dtype:t}}typedArrayFromHeap({shape:e,dtype:t,dataId:n}){let a=this.wasm.HEAPU8.buffer,{memoryOffset:r}=this.dataIdMap.get(n),s=k.sizeFromShape(e);switch(t){case"float32":return new Float32Array(a,r,s);case"int32":return new Int32Array(a,r,s);case"bool":return new Uint8Array(a,r,s);default:throw new Error(`Unknown dtype ${t}`)}}};function GJ(e){return(t,n)=>(k.fetch(e,{credentials:"same-origin"}).then(a=>{a.ok||t.env.a(`failed to load wasm binary file at '${e}'`),a.arrayBuffer().then(r=>{WebAssembly.instantiate(r,t).then(s=>{n(s.instance,s.module)})})}),{})}function p6(e,t,n){if(Rh!=null)return Rh;let a="tfjs-backend-wasm.wasm";return e&&t?a="tfjs-backend-wasm-threaded-simd.wasm":e&&(a="tfjs-backend-wasm-simd.wasm"),vd!=null&&vd[a]!=null?vd[a]:n+a}async function qJ(){let[e,t]=await Promise.all([J().getAsync("WASM_HAS_SIMD_SUPPORT"),J().getAsync("WASM_HAS_MULTITHREAD_SUPPORT")]);return new Promise((n,a)=>{let r={};r.locateFile=(o,l)=>{if(o.endsWith(".worker.js")){let d=jJ,u=new Blob([d],{type:"application/javascript"});return URL.createObjectURL(u)}return o.endsWith(".wasm")?p6(e,t,wd!=null?wd:l):l+o},E1&&(r.instantiateWasm=GJ(p6(e,t,wd!=null?wd:"")));let s=!1;r.onAbort=()=>{s||kd||(kd=!0,a({message:"Make sure the server can serve the `.wasm` file relative to the bundled js file. For more details see https://github.com/tensorflow/tfjs/blob/master/tfjs-backend-wasm/README.md#using-bundlers"}))};let i;t&&e&&Rh==null?(r.mainScriptUrlOrBlob=new Blob(["var WasmBackendModuleThreadedSimd = "+u6.default.toString()],{type:"text/javascript"}),i=(0,u6.default)(r)):i=(0,UJ.default)(r),i.then(o=>{s=!0,kd=!1;let l=null;o.tfjs={init:o.cwrap("init",null,[]),registerTensor:o.cwrap("register_tensor",null,["number","number","number"]),disposeData:o.cwrap("dispose_data",l,["number"]),dispose:o.cwrap("dispose",l,[])},n({wasm:o})})})}function HJ(e,t){switch(t){case"float32":return new Float32Array(e);case"int32":return new Int32Array(e);case"bool":return new Uint8Array(e);default:throw new Error(`Unknown dtype ${t}`)}}var XJ=["tfjs-backend-wasm.wasm","tfjs-backend-wasm-simd.wasm","tfjs-backend-wasm-threaded-simd.wasm"],Rh=null,wd=null,vd={},kd=!1,E1=!1;function KJ(e,t=!1){if(Km("setWasmPath has been deprecated in favor of setWasmPaths and will be removed in a future release."),kd)throw new Error("The WASM backend was already initialized. Make sure you call `setWasmPath()` before you call `tf.setBackend()` or `tf.ready()`");Rh=e,E1=t}function ZJ(e,t=!1){if(kd)throw new Error("The WASM backend was already initialized. Make sure you call `setWasmPaths()` before you call `tf.setBackend()` or `tf.ready()`");if(typeof e=="string")wd=e;else{vd=e;let n=XJ.filter(a=>vd[a]==null);if(n.length>0)throw new Error(`There were no entries found for the following binaries: ${n.join(",")}. Please either call setWasmPaths with a map providing a path for each binary, or with a string indicating the directory where all the binaries can be found.`)}E1=t}var c6="3.6.0",YJ=2;dl("wasm",async()=>{let{wasm:e}=await qJ();return new d6(e)},YJ);Z().prototype.abs=function(){return this.throwIfDisposed(),zt(this)};Z().prototype.acos=function(){return this.throwIfDisposed(),Ym(this)};Z().prototype.acosh=function(){return this.throwIfDisposed(),Jm(this)};Z().prototype.add=function(e){return this.throwIfDisposed(),se(this,e)};Z().prototype.all=function(e,t){return this.throwIfDisposed(),gc(this,e,t)};Z().prototype.any=function(e,t){return this.throwIfDisposed(),ju(this,e,t)};Z().prototype.argMax=function(e){return this.throwIfDisposed(),Uu(this,e)};Z().prototype.argMin=function(e){return this.throwIfDisposed(),Qm(this,e)};Z().prototype.asScalar=function(){return this.throwIfDisposed(),F(this.size===1,()=>"The array must have only 1 element."),H(this,[])};Z().prototype.asType=function(e){return this.throwIfDisposed(),fe(this,e)};Z().prototype.as1D=function(){return this.throwIfDisposed(),H(this,[this.size])};Z().prototype.as2D=function(e,t){return this.throwIfDisposed(),H(this,[e,t])};Z().prototype.as3D=function(e,t,n){return this.throwIfDisposed(),H(this,[e,t,n])};Z().prototype.as4D=function(e,t,n,a){return this.throwIfDisposed(),H(this,[e,t,n,a])};Z().prototype.as5D=function(e,t,n,a,r){return this.throwIfDisposed(),H(this,[e,t,n,a,r])};Z().prototype.asin=function(){return this.throwIfDisposed(),eA(this)};Z().prototype.asinh=function(){return this.throwIfDisposed(),tA(this)};Z().prototype.atan=function(){return this.throwIfDisposed(),nA(this)};Z().prototype.atan2=function(e){return this.throwIfDisposed(),aA(this,e)};Z().prototype.atanh=function(){return this.throwIfDisposed(),rA(this)};Z().prototype.avgPool=function(e,t,n,a){return this.throwIfDisposed(),Gu(this,e,t,n,a)};Z().prototype.batchToSpaceND=function(e,t){return this.throwIfDisposed(),qu(this,e,t)};Z().prototype.batchNorm=function(e,t,n,a,r){return this.throwIfDisposed(),ci(this,e,t,n,a,r)};Z().prototype.broadcastTo=function(e){return this.throwIfDisposed(),cl(this,e)};Z().prototype.cast=function(e){return this.throwIfDisposed(),fe(this,e)};Z().prototype.ceil=function(){return this.throwIfDisposed(),uA(this)};Z().prototype.clipByValue=function(e,t){return this.throwIfDisposed(),In(this,e,t)};Z().prototype.concat=function(e,t){return this.throwIfDisposed(),e instanceof Le&&(e=[e]),ot([this,...e],t)};Z().prototype.conv1d=function(e,t,n,a,r,s){return this.throwIfDisposed(),bc(this,e,t,n,a,r,s)};Z().prototype.conv2dTranspose=function(e,t,n,a,r){return this.throwIfDisposed(),vc(this,e,t,n,a,r)};Z().prototype.conv2d=function(e,t,n,a,r,s){return this.throwIfDisposed(),ar(this,e,t,n,a,r,s)};Z().prototype.cos=function(){return this.throwIfDisposed(),Xu(this)};Z().prototype.cosh=function(){return this.throwIfDisposed(),wc(this)};Z().prototype.cumsum=function(e,t,n){return this.throwIfDisposed(),kc(this,e,t,n)};Z().prototype.depthToSpace=function(e,t){return this.throwIfDisposed(),cA(this,e,t)};Z().prototype.depthwiseConv2d=function(e,t,n,a,r,s){return this.throwIfDisposed(),fl(this,e,t,n,a,r,s)};Z().prototype.dilation2d=function(e,t,n,a,r){return this.throwIfDisposed(),hA(this,e,t,n,a,r)};Z().prototype.divNoNan=function(e){return this.throwIfDisposed(),fA(this,e)};Z().prototype.div=function(e){return this.throwIfDisposed(),me(this,e)};Z().prototype.dot=function(e){return this.throwIfDisposed(),zb(this,e)};Z().prototype.elu=function(){return this.throwIfDisposed(),ml(this)};Z().prototype.equal=function(e){return this.throwIfDisposed(),Fr(this,e)};Z().prototype.erf=function(){return this.throwIfDisposed(),mA(this)};Z().prototype.exp=function(){return this.throwIfDisposed(),Xn(this)};Z().prototype.expandDims=function(e){return this.throwIfDisposed(),un(this,e)};Z().prototype.expm1=function(){return this.throwIfDisposed(),AA(this)};Z().prototype.fft=function(){return this.throwIfDisposed(),ad(this)};Z().prototype.flatten=function(){return this.throwIfDisposed(),H(this,[this.size])};Z().prototype.floor=function(){return this.throwIfDisposed(),yl(this)};Z().prototype.floorDiv=function(e){return this.throwIfDisposed(),Ac(this,e)};Z().prototype.gather=function(e,t){return this.throwIfDisposed(),hi(this,e,t)};Z().prototype.greaterEqual=function(e){return this.throwIfDisposed(),Dr(this,e)};Z().prototype.greater=function(e){return this.throwIfDisposed(),Fn(this,e)};Z().prototype.ifft=function(){return this.throwIfDisposed(),wl(this)};Z().prototype.irfft=function(){return this.throwIfDisposed(),Wc(this)};Z().prototype.isFinite=function(){return this.throwIfDisposed(),Pb(this)};Z().prototype.isInf=function(){return this.throwIfDisposed(),Lb(this)};Z().prototype.isNaN=function(){return this.throwIfDisposed(),gA(this)};Z().prototype.leakyRelu=function(e){return this.throwIfDisposed(),Ku(this,e)};Z().prototype.lessEqual=function(e){return this.throwIfDisposed(),Or(this,e)};Z().prototype.less=function(e){return this.throwIfDisposed(),Sc(this,e)};Z().prototype.localResponseNormalization=function(e,t,n,a){return this.throwIfDisposed(),xA(this,e,t,n,a)};Z().prototype.logSigmoid=function(){return this.throwIfDisposed(),Vb(this)};Z().prototype.logSoftmax=function(e){return this.throwIfDisposed(),Ec(this,e)};Z().prototype.logSumExp=function(e,t){return this.throwIfDisposed(),wA(this,e,t)};Z().prototype.log=function(){return this.throwIfDisposed(),$n(this)};Z().prototype.log1p=function(){return this.throwIfDisposed(),Nc(this)};Z().prototype.logicalAnd=function(e){return this.throwIfDisposed(),la(this,e)};Z().prototype.logicalNot=function(){return this.throwIfDisposed(),Zu(this)};Z().prototype.logicalOr=function(e){return this.throwIfDisposed(),Cc(this,e)};Z().prototype.logicalXor=function(e){return this.throwIfDisposed(),Gb(this,e)};Z().prototype.matMul=function(e,t,n){return this.throwIfDisposed(),Be(this,e,t,n)};Z().prototype.maxPool=function(e,t,n,a){return this.throwIfDisposed(),Yu(this,e,t,n,a)};Z().prototype.max=function(e,t){return this.throwIfDisposed(),Kn(this,e,t)};Z().prototype.maximum=function(e){return this.throwIfDisposed(),Pa(this,e)};Z().prototype.mean=function(e,t){return this.throwIfDisposed(),kt(this,e,t)};Z().prototype.min=function(e,t){return this.throwIfDisposed(),gl(this,e,t)};Z().prototype.minimum=function(e){return this.throwIfDisposed(),xl(this,e)};Z().prototype.mirrorPad=function(e,t){return this.throwIfDisposed(),IA(this,e,t)};Z().prototype.mod=function(e){return this.throwIfDisposed(),SA(this,e)};Z().prototype.mul=function(e){return this.throwIfDisposed(),_(this,e)};Z().prototype.neg=function(){return this.throwIfDisposed(),wt(this)};Z().prototype.norm=function(e,t,n){return this.throwIfDisposed(),Uc(this,e,t,n)};Z().prototype.notEqual=function(e){return this.throwIfDisposed(),Ai(this,e)};Z().prototype.oneHot=function(e,t=1,n=0){return this.throwIfDisposed(),ll(this,e,t,n)};Z().prototype.onesLike=function(){return this.throwIfDisposed(),On(this)};Z().prototype.pad=function(e,t){return this.throwIfDisposed(),rr(this,e,t)};Z().prototype.pool=function(e,t,n,a,r){return this.throwIfDisposed(),Kb(this,e,t,n,a,r)};Z().prototype.pow=function(e){return this.throwIfDisposed(),sr(this,e)};Z().prototype.prelu=function(e){return this.throwIfDisposed(),Qu(this,e)};Z().prototype.prod=function(e,t){return this.throwIfDisposed(),Mc(this,e,t)};Z().prototype.reciprocal=function(){return this.throwIfDisposed(),EA(this)};Z().prototype.relu=function(){return this.throwIfDisposed(),La(this)};Z().prototype.relu6=function(){return this.throwIfDisposed(),Fc(this)};Z().prototype.reshapeAs=function(e){return this.throwIfDisposed(),H(this,e.shape)};Z().prototype.reshape=function(e){return this.throwIfDisposed(),H(this,e)};Z().prototype.resizeBilinear=function(e,t,n){return this.throwIfDisposed(),h3(this,e,t,n)};Z().prototype.resizeNearestNeighbor=function(e,t,n){return this.throwIfDisposed(),f3(this,e,t,n)};Z().prototype.reverse=function(e){return this.throwIfDisposed(),zn(this,e)};Z().prototype.rfft=function(){return this.throwIfDisposed(),rd(this)};Z().prototype.round=function(){return this.throwIfDisposed(),$c(this)};Z().prototype.rsqrt=function(){return this.throwIfDisposed(),Dc(this)};Z().prototype.selu=function(){return this.throwIfDisposed(),Oc(this)};Z().prototype.separableConv2d=function(e,t,n,a,r,s){return this.throwIfDisposed(),CA(this,e,t,n,a,r,s)};Z().prototype.sigmoid=function(){return this.throwIfDisposed(),kn(this)};Z().prototype.sign=function(){return this.throwIfDisposed(),RA(this)};Z().prototype.sin=function(){return this.throwIfDisposed(),zc(this)};Z().prototype.sinh=function(){return this.throwIfDisposed(),_c(this)};Z().prototype.slice=function(e,t){return this.throwIfDisposed(),Re(this,e,t)};Z().prototype.softmax=function(e){return this.throwIfDisposed(),nd(this,e)};Z().prototype.softplus=function(){return this.throwIfDisposed(),fi(this)};Z().prototype.spaceToBatchND=function(e,t){return this.throwIfDisposed(),Ju(this,e,t)};Z().prototype.split=function(e,t){return this.throwIfDisposed(),rn(this,e,t)};Z().prototype.sqrt=function(){return this.throwIfDisposed(),Qt(this)};Z().prototype.square=function(){return this.throwIfDisposed(),st(this)};Z().prototype.squaredDifference=function(e){return this.throwIfDisposed(),Bc(this,e)};Z().prototype.squeeze=function(e){return this.throwIfDisposed(),zr(this,e)};Z().prototype.stack=function(e,t){this.throwIfDisposed();let n=e instanceof Le?[this,e]:[this,...e];return _n(n,t)};Z().prototype.step=function(e){return this.throwIfDisposed(),kl(this,e)};Z().prototype.stridedSlice=function(e,t,n,a,r,s,i,o){return this.throwIfDisposed(),FA(this,e,t,n,a,r,s,i,o)};Z().prototype.sub=function(e){return this.throwIfDisposed(),ge(this,e)};Z().prototype.sum=function(e,t){return this.throwIfDisposed(),ke(this,e,t)};Z().prototype.tan=function(){return this.throwIfDisposed(),$A(this)};Z().prototype.tanh=function(){return this.throwIfDisposed(),pi(this)};Z().prototype.tile=function(e){return this.throwIfDisposed(),$r(this,e)};Z().prototype.toBool=function(){return this.throwIfDisposed(),fe(this,"bool")};Z().prototype.toFloat=function(){return this.throwIfDisposed(),fe(this,"float32")};Z().prototype.toInt=function(){return this.throwIfDisposed(),fe(this,"int32")};Z().prototype.topk=function(e,t){return this.throwIfDisposed(),DA(this,e,t)};Z().prototype.transpose=function(e){return this.throwIfDisposed(),Ze(this,e)};Z().prototype.unique=function(e){return this.throwIfDisposed(),jc(this,e)};Z().prototype.unsortedSegmentSum=function(e,t){return this.throwIfDisposed(),OA(this,e,t)};Z().prototype.unstack=function(e){return this.throwIfDisposed(),ua(this,e)};Z().prototype.where=function(e,t){return this.throwIfDisposed(),an(e,this,t)};Z().prototype.zerosLike=function(){return this.throwIfDisposed(),Ue(this)};var h6={kernelName:eo,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(e,kl(fe(n,"float32"),-1))}}},JJ={kernelName:to,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>{let a=st(fe(n,"float32")),r=Qt(ge(Se(1),a));return wt(me(e,r))}}}},QJ={kernelName:no,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>{let a=Qt(ge(st(fe(n,"float32")),1));return me(e,a)}}}},eQ={kernelName:kr,inputsToSave:["a","b"],gradFunc:(e,t)=>{let[n,a]=t,r=ct(n.shape,a.shape);return{a:()=>{let s=e,i=_t(n.shape,r);return i.length>0&&(s=ke(s,i)),H(s,n.shape)},b:()=>{let s=e,i=_t(a.shape,r);return i.length>0&&(s=ke(s,i)),H(s,a.shape)}}}},tQ={kernelName:os,saveAllInputs:!0,gradFunc:(e,t)=>{let n={};return t.forEach((a,r)=>{n[r]=()=>e.clone()}),n}},nQ={kernelName:ls,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>Ue(n)}}},aQ={kernelName:Au,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>Ue(n)}}},rQ={kernelName:so,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>me(e,Qt(ge(Se(1),st(fe(n,"float32")))))}}},sQ={kernelName:io,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>{let a=Qt(se(Se(1),st(fe(n,"float32"))));return me(e,a)}}}},iQ={kernelName:uo,inputsToSave:["a","b"],gradFunc:(e,t)=>{let[n,a]=t,r=ct(n.shape,a.shape);return{a:()=>{let s=se(st(n),st(a)),i=_(e,me(a,s)),o=_t(n.shape,r);return o.length>0&&(i=ke(i,o)),H(i,n.shape)},b:()=>{let s=se(st(n),st(a)),i=wt(_(e,me(n,s))),o=_t(a.shape,r);return o.length>0&&(i=ke(i,o)),H(i,a.shape)}}}},oQ={kernelName:oo,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>me(e,se(st(fe(n,"float32")),1))}}},lQ={kernelName:lo,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>me(e,ge(Se(1),st(fe(n,"float32"))))}}};function uQ(e,t,n,a,r,s){let i=M(e,"dy","avgPool3dGrad"),o=M(t,"input","avgPool3dGrad"),l=i,d=o,u=!1;o.rank===4&&(u=!0,l=H(i,[1,i.shape[0],i.shape[1],i.shape[2],i.shape[3]]),d=H(o,[1,o.shape[0],o.shape[1],o.shape[2],o.shape[3]])),F(l.rank===5,()=>`Error in avgPool3dGrad: dy must be rank 5 but got rank ${l.rank}.`),F(d.rank===5,()=>`Error in avgPool3dGrad: input must be rank 5 but got rank ${d.rank}.`),s!=null&&F(jt(r),()=>`Error in avgPool3dGrad: pad must be an integer when using, dimRoundingMode ${s} but got pad ${r}.`);let p={dy:l,input:d},c={filterSize:n,strides:a,pad:r,dimRoundingMode:s},h=D.runKernel(Cp,p,c);return u?H(h,[h.shape[1],h.shape[2],h.shape[3],h.shape[4]]):h}var dQ=O({avgPool3dGrad_:uQ}),pQ={kernelName:yu,inputsToSave:["x"],gradFunc:(e,t,n)=>{let[a]=t,{filterSize:r,strides:s,pad:i,dimRoundingMode:o}=n;return{x:()=>dQ(e,a,r,s,i,o)}}};function cQ(e,t,n,a,r){let s=M(e,"dy","avgPoolGrad"),i=M(t,"input","avgPoolGrad");F(i.rank===s.rank,()=>`Rank of input (${i.rank}) does not match rank of dy (${s.rank})`);let o=i,l=s,d=!1;i.rank===3&&(d=!0,o=H(i,[1,i.shape[0],i.shape[1],i.shape[2]]),l=H(s,[1,s.shape[0],s.shape[1],s.shape[2]])),F(l.rank===4,()=>`Error in avgPoolGrad: dy must be rank 4 but got rank ${l.rank}.`),F(o.rank===4,()=>`Error in avgPoolGrad: input must be rank 4 but got rank ${o.rank}.`);let u={dy:l,input:o},p={filterSize:n,strides:a,pad:r},c=D.runKernel(Ep,u,p);return d?H(c,[c.shape[1],c.shape[2],c.shape[3]]):c}var hQ=O({avgPoolGrad_:cQ}),fQ={kernelName:us,inputsToSave:["x"],gradFunc:(e,t,n)=>{let[a]=t,{filterSize:r,strides:s,pad:i}=n;return{x:()=>hQ(e,a,r,s,i)}}},mQ={kernelName:ds,inputsToSave:["a","b"],gradFunc:(e,t,n)=>{let[a,r]=t,{transposeA:s,transposeB:i}=n;return!s&&!i?{a:()=>Be(e,r,!1,!0),b:()=>Be(a,e,!0,!1)}:!s&&i?{a:()=>Be(e,r,!1,!1),b:()=>Be(e,a,!0,!1)}:s&&!i?{a:()=>Be(r,e,!1,!0),b:()=>Be(a,e,!1,!1)}:{a:()=>Be(r,e,!0,!0),b:()=>Be(e,a,!0,!0)}}},AQ={kernelName:gu,gradFunc:(e,t,n)=>{let{blockShape:a,crops:r}=n;return{x:()=>Ju(e,a,r)}}},yQ={kernelName:Rx,gradFunc:(e,t,n)=>{let a=n,r=a.inputShape,s=a.shape,i=Array.from(s);for(let l=r.length-1;l>=0;l--)if(r[l]===s[l])i[l]=1;else if(r[l]!==1)throw new Error(`broadcastTo(): [${r}] cannot be broadcast to [${s}].`);let o=[];for(let l=0;l1&&o.push(l);return{x:()=>ke(e,o,!0)}}},gQ={kernelName:ps,gradFunc:e=>({x:()=>e.clone()})},xQ={kernelName:cs,gradFunc:e=>({x:()=>Ue(e)})},bQ={kernelName:Ir,inputsToSave:["x"],gradFunc:(e,t,n)=>{let[a]=t,{clipValueMin:r,clipValueMax:s}=n;return{x:()=>an(la(Dr(a,r),Or(a,s)),e,Ue(e))}}},vQ={kernelName:xu,inputsToSave:["x"],gradFunc:h6.gradFunc},wQ={kernelName:po,saveAllInputs:!0,gradFunc:(e,t,n)=>{let a=t.map(o=>o.shape),{axis:r}=n,s=sa(r,t[0].shape)[0],i=a.map(o=>o[s]);return rn(e,i,s).map(o=>()=>o)}},kQ={kernelName:hs,inputsToSave:["x","filter"],gradFunc:(e,t,n)=>{let[a,r]=t,{dilations:s,strides:i,pad:o,dataFormat:l}=n;return F(Mr(s),()=>`Error in gradient of conv2D: dilation rates greater than 1 are not yet supported in gradients. Got dilations '${s}'`),{x:()=>dA(a.shape,e,r,i,o,l),filter:()=>LA(a,e,r.shape,i,o,l)}}},IQ={kernelName:fs,inputsToSave:["dy","filter"],gradFunc:(e,t,n)=>{let[a,r]=t,{strides:s,pad:i,dataFormat:o,dimRoundingMode:l}=n;return{dy:()=>ar(e,r,s,i,o,1,l),filter:()=>LA(e,a,r.shape,s,i,o,l)}}};function SQ(e,t,n,a,r){let s=e;e.rank===4&&(s=H(e,[1,e.shape[0],e.shape[1],e.shape[2],e.shape[3]]));let i=t;i.rank===4&&(i=H(t,[1,t.shape[0],t.shape[1],t.shape[2],t.shape[3]])),F(s.rank===5,()=>`Error in conv3dDerFilter: input must be rank 5, but got shape ${s.shape}.`),F(i.rank===5,()=>`Error in conv3dDerFilter: dy must be rank 5, but got shape ${i.shape}.`),F(n.length===5,()=>`Error in conv3dDerFilter: filterShape must be length 5, but got ${n}.`),F(s.shape[4]===n[3],()=>`Error in conv3dDerFilter: depth of input ${s.shape[4]}) must match input depth in filter (${n[3]}.`),F(i.shape[4]===n[4],()=>`Error in conv3dDerFilter: depth of dy (${i.shape[4]}) must match output depth for filter (${n[4]}).`);let o={x:s,dy:i},l={strides:a,pad:r,filterShape:n};return D.runKernel($p,o,l)}var NQ=O({conv3DBackpropFilter_:SQ}),TQ={kernelName:bu,inputsToSave:["x","filter"],gradFunc:(e,t,n)=>{let{dilations:a,strides:r,pad:s}=n;F(Mr(a),()=>`Error in gradient of conv3D: dilation rates greater than 1 are not yet supported in gradients. Got dilations '${a}'`);let[i,o]=t;return{x:()=>$b(i.shape,e,o,r,s),filter:()=>NQ(i,e,o.shape,r,s)}}},EQ={kernelName:ms,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(wt(zc(fe(n,"float32"))),e)}}},CQ={kernelName:co,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(_c(fe(n,"float32")),e)}}},RQ={kernelName:As,inputsToSave:["x"],gradFunc:(e,t,n)=>{let[a]=t,{axis:r,exclusive:s,reverse:i}=n;return{x:()=>{let o=Hb([r],a.rank),l=kc(e,r,s,!i);return o!=null&&(l=Ze(l,o)),l}}}},MQ={kernelName:ys,inputsToSave:["x","filter"],gradFunc:(e,t,n)=>{let{dilations:a,strides:r,pad:s,dimRoundingMode:i}=n,o=a==null?[1,1]:a;F(Mr(o),()=>`Error in gradient of depthwiseConv2dNative: dilation rates greater than 1 are not yet supported. Got dilations '${o}'`);let[l,d]=t;return F(l.rank===4,()=>`Error in gradient of depthwiseConv2dNative: input must be rank 4, but got rank ${l.rank}.`),F(d.rank===4,()=>`Error in gradient of depthwiseConv2dNative: filter must be rank 4, but got rank ${d.rank}.`),F(l.shape[3]===d.shape[2],()=>`Error in gradient of depthwiseConv2d: number of input channels (${l.shape[3]}) must match the inChannels dimension in filter ${d.shape[2]}.`),F(za(r,o),()=>`Error in gradient of depthwiseConv2d: Either strides or dilations must be 1. Got strides ${r} and dilations '${o}'.`),i!=null&&F(jt(s),()=>`Error in depthwiseConv2d: pad must be an integer when using, dimRoundingMode ${i} but got pad ${s}.`),{x:()=>i3(l.shape,e,d,r,s,a,i),filter:()=>s3(l,e,d.shape,r,s,a,i)}}},FQ={kernelName:vu,inputsToSave:["x","filter"],gradFunc:(e,t,n)=>{let[a,r]=t,s={x:a,filter:r,dy:e},i={x:a,filter:r,dy:e};return{x:()=>D.runKernel(Lp,s,n),filter:()=>D.runKernel(Wp,i,n)}}},$Q={kernelName:mo,outputsToSave:[!0],gradFunc:(e,t)=>{let[n]=t,a={dy:e,y:n};return{x:()=>D.runKernel(Vp,a)}}},DQ={kernelName:Ao,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t,a=_(Xn(wt(st(n))),2/Math.sqrt(Math.PI));return{x:()=>_(e,a)}}},OQ={kernelName:xs,outputsToSave:[!0],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(e,n)}}},zQ={kernelName:go,inputsToSave:["input"],gradFunc:(e,t)=>{let[n]=t;return{input:()=>H(e,n.shape)}}},_Q={kernelName:xo,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(e,Xn(n))}}},PQ={kernelName:bs,gradFunc:e=>({x:()=>Ue(e)})},LQ={kernelName:vs,inputsToSave:["a","b"],gradFunc:(e,t)=>{let[n,a]=t,r=ct(n.shape,a.shape);return{a:()=>{let s=me(e,fe(a,"float32")),i=_t(n.shape,r);return i.length>0?H(ke(s,i),n.shape):s},b:()=>{let s=_(e,fe(n,"float32")),i=_t(a.shape,r);i.length>0&&(s=H(ke(s,i),a.shape));let o=st(a);return wt(me(s,fe(o,"float32")))}}}},WQ={kernelName:ws,inputsToSave:["x","mean","variance","scale"],gradFunc:(e,t,n)=>{let{varianceEpsilon:a}=n,[r,s,i,o]=t,l=o==null?Se(1):o,d=_t(s.shape,r.shape),u=[];if(s.rank===1){for(let f=0;fs.rank===1?H(_(_(e,$r(H(h,[1,1,1,s.shape[0]]),u)),l),r.shape):H(_(_(e,h),l),r.shape),mean:()=>{let f=_(_(h,Se(-1)),c);return s.rank===1&&(f=ke(f,d)),H(f,s.shape)},variance:()=>{let f=_(_(m,p),c);return s.rank===1&&(f=ke(f,d)),H(f,s.shape)},scale:()=>{let f=_(p,h),A=_(e,f);return s.rank===1&&(A=ke(A,d)),H(A,s.shape)},offset:()=>{let f=e;return s.rank===1&&(f=ke(f,d)),H(f,s.shape)}}}},BQ={kernelName:vo,inputsToSave:["x","indices"],gradFunc:(e,t,n)=>{let[a,r]=t,{axis:s}=n,i=sa(s,a.shape)[0];return{x:()=>{let o=a.shape,l=r.size,d=o.slice(0,i),u=d.length,p=o.slice(s,o.length).slice(1),c=p.length,h=f6(0,u),m=f6(u+1,u+1+c),f=m6([d,[l],p]),A=H(e,f),y=H(r,[l]),g=m6([[u],h,m]),x=Ze(A,g),w=OA(x,y,a.shape[i]),b=vA(g);return w=Ze(w,b),w},indices:()=>r}}};function f6(e,t){let n=[];for(let a=e;a{let[n,a]=t;return{a:()=>Ue(n),b:()=>Ue(a)}}},jQ={kernelName:Is,gradFunc:e=>({x:()=>fe(e,"float32")})},UQ={kernelName:Io,gradFunc:e=>({x:()=>Ue(e)})},HQ={kernelName:So,gradFunc:e=>({x:()=>Ue(e)})},GQ={kernelName:No,gradFunc:e=>({x:()=>Ue(e)})},qQ={kernelName:Ss,inputsToSave:["x"],gradFunc:(e,t,n)=>{let[a]=t,{alpha:r}=n,s=Fn(a,0);return{x:()=>an(s,e,_(e,r))}}},XQ={kernelName:Co,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>me(e,se(n,1))}}},KQ={kernelName:Ns,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>me(e,fe(n,"float32"))}}},ZQ={kernelName:Mx,inputsToSave:[],outputsToSave:[!0],gradFunc:(e,t,n)=>{let[a]=t,{axis:r}=n;return{logits:()=>{let s=!0,i=Xn(a);return ge(e,_(ke(e,r,s),i))}}}};function YQ(e,t,n,a=5,r=1,s=1,i=.5){let o={x:e,y:t,dy:n},l={depthRadius:a,bias:r,alpha:s,beta:i};return D.runKernel(qp,o,l)}var JQ=O({localResponseNormalizationBackprop_:YQ}),QQ={kernelName:Su,inputsToSave:["x"],outputsToSave:[!0],gradFunc:(e,t,n)=>{let[a,r]=t,{depthRadius:s,bias:i,alpha:o,beta:l}=n;return{x:()=>JQ(a,r,e,s,i,o,l)}}};function A6(e,t,n,a){return t.rank_(e,fe(Fr(n,t),e.dtype))}}var y6={kernelName:Ts,inputsToSave:["x"],outputsToSave:[!0],gradFunc:(e,t,n)=>{let a=n,{reductionIndices:r}=a,s=t[0],i=t[1],o=sa(r,s.shape),l=A6(e,i,s,o);return{x:()=>l.x()}}},eee={kernelName:Es,inputsToSave:["a","b"],gradFunc:(e,t)=>{let[n,a]=t;return{a:()=>_(e,fe(Dr(n,a),"float32")),b:()=>_(e,fe(Sc(n,a),"float32"))}}};function tee(e,t,n,a,r,s,i){let o=M(e,"dy","maxPool3dGrad"),l=M(t,"input","maxPool3dGrad"),d=M(n,"output","maxPool3dGrad"),u=o,p=l,c=d,h=!1;l.rank===4&&(h=!0,u=H(o,[1,o.shape[0],o.shape[1],o.shape[2],o.shape[3]]),p=H(l,[1,l.shape[0],l.shape[1],l.shape[2],l.shape[3]]),c=H(d,[1,d.shape[0],d.shape[1],d.shape[2],d.shape[3]])),F(u.rank===5,()=>`Error in maxPool3dGrad: dy must be rank 5 but got rank ${u.rank}.`),F(p.rank===5,()=>`Error in maxPool3dGrad: input must be rank 5 but got rank ${p.rank}.`),F(c.rank===5,()=>`Error in maxPool3dGrad: output must be rank 5 but got rank ${c.rank}.`),i!=null&&F(jt(s),()=>`Error in maxPool3dGrad: pad must be an integer when using, dimRoundingMode ${i} but got pad ${s}.`);let m={dy:u,input:p,output:c},f={filterSize:a,strides:r,pad:s,dimRoundingMode:i},A=D.runKernel(Kp,m,f);return h?H(A,[A.shape[1],A.shape[2],A.shape[3],A.shape[4]]):A}var nee=O({maxPool3dGrad_:tee}),aee={kernelName:Nu,inputsToSave:["x"],outputsToSave:[!0],gradFunc:(e,t,n)=>{let[a,r]=t,{filterSize:s,strides:i,pad:o,dimRoundingMode:l}=n;return{x:()=>nee(e,a,r,s,i,o,l)}}};function ree(e,t,n,a,r,s,i){let o=M(e,"dy","maxPoolGrad"),l=M(t,"input","maxPoolGrad"),d=M(n,"output","maxPoolGrad");F(l.rank===o.rank,()=>`Rank of input (${l.rank}) does not match rank of dy (${o.rank})`),F(o.rank===4,()=>`Error in maxPoolGrad: dy must be rank 4 but got rank ${o.rank}.`),F(l.rank===4,()=>`Error in maxPoolGrad: input must be rank 4 but got rank ${l.rank}.`),i!=null&&F(jt(s),()=>`Error in maxPoolGrad: pad must be an integer when using, dimRoundingMode ${i} but got pad ${s}.`);let u={dy:o,input:l,output:d},p={filterSize:a,strides:r,pad:s,dimRoundingMode:i};return D.runKernel(Xp,u,p)}var see=O({maxPoolGrad_:ree}),iee={kernelName:Cs,inputsToSave:["x"],outputsToSave:[!0],gradFunc:(e,t,n)=>{let[a,r]=t,{filterSize:s,strides:i,pad:o}=n;return{x:()=>see(e,a,r,s,i,o)}}},oee={kernelName:Rs,inputsToSave:["x"],gradFunc:(e,t,n)=>{let[a]=t,{axis:r}=n,s=sa(r,a.shape),i=Ub(a.shape,s)[1],o=Tt(i);return{x:()=>{let l=a.shape.slice();s.forEach(u=>{l[u]=1});let d=H(e,l);return me(_(d,Dn(a.shape,"float32")),o)}}}},lee={kernelName:Ms,inputsToSave:["x"],outputsToSave:[!0],gradFunc:(e,t,n)=>{let a=n,{axis:r}=a,[s,i]=t,o=sa(r,s.shape),l=A6(e,i,s,o);return{x:()=>l.x()}}},uee={kernelName:Fs,inputsToSave:["a","b"],gradFunc:(e,t)=>{let[n,a]=t;return{a:()=>_(e,fe(Or(n,a),"float32")),b:()=>_(e,fe(Fn(n,a),"float32"))}}},dee={kernelName:$s,inputsToSave:["x"],gradFunc:(e,t,n)=>{let a=t[0],{paddings:r}=n,s=r.map(i=>i[0]);return{x:()=>Re(e,s,a.shape)}}},pee={kernelName:Mo,inputsToSave:["a","b"],gradFunc:(e,t)=>{let[n,a]=t,r=ct(n.shape,a.shape);return{a:()=>{let s=_t(n.shape,r);return s.length>0?H(ke(e,s),n.shape):e},b:()=>{let s=_(e,wt(yl(me(n,a)))),i=_t(a.shape,r);return i.length>0?H(ke(s,i),a.shape):s}}}},cee={kernelName:Ds,inputsToSave:["a","b"],gradFunc:(e,t)=>{let[n,a]=t,r=ct(n.shape,a.shape);return{a:()=>{let s=_(e,fe(a,"float32")),i=_t(n.shape,r);return i.length>0?H(ke(s,i),n.shape):s},b:()=>{let s=_(e,fe(n,"float32")),i=_t(a.shape,r);return i.length>0?H(ke(s,i),a.shape):s}}}},hee={kernelName:Fo,gradFunc:e=>({x:()=>wt(e)})},fee={kernelName:Os,inputsToSave:["indices"],gradFunc:(e,t)=>{let n=t[0];return{indices:()=>Rt(n.shape,"float32")}}},mee={kernelName:_o,gradFunc:e=>({x:()=>Ue(e)})},Aee={kernelName:Po,saveAllInputs:!0,gradFunc:(e,t,n)=>{let{axis:a}=n;return ua(e,a).map(r=>()=>r)}},g6={kernelName:zs,inputsToSave:["x"],gradFunc:(e,t,n)=>{let a=t[0],{paddings:r}=n,s=r.map(i=>i[0]);return{x:()=>Re(e,s,a.shape)}}},yee={kernelName:_s,inputsToSave:["a","b"],outputsToSave:[!0],gradFunc:(e,t)=>{let[n,a,r]=t,s=n,i=a,o=ct(s.shape,i.shape);return{a:()=>{let l=fe(i,"float32"),d=_(e,_(l,sr(s,ge(l,Se(1))))),u=_t(s.shape,o);return u.length>0&&(d=ke(d,u)),H(d,s.shape)},b:()=>{let l=Fn(s,0),d=an(l,$n(s),Ue(s)),u=_(e,_(r,d)),p=_t(i.shape,o);return p.length>0&&(u=ke(u,p)),H(u,i.shape)}}}},gee={kernelName:Ps,inputsToSave:["x","alpha"],gradFunc:(e,t)=>{let[n,a]=t,r=Fn(n,0);return{x:()=>an(r,e,_(e,a)),alpha:()=>{let s=an(r,Ue(e),_(e,n)),i=_t(a.shape,e.shape);return i.length>0&&(s=ke(s,i)),H(s,a.shape)}}}},xee={kernelName:gs,inputsToSave:["a","b"],gradFunc:(e,t)=>{let[n,a]=t,r=ct(n.shape,a.shape);return{a:()=>{let s=me(e,fe(a,"float32")),i=_t(n.shape,r);return i.length>0?H(ke(s,i),n.shape):s},b:()=>{let s=_(e,fe(n,"float32")),i=_t(a.shape,r);i.length>0&&(s=H(ke(s,i),a.shape));let o=st(a);return wt(me(s,fe(o,"float32")))}}}},bee={kernelName:Wo,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>me(e,wt(st(n)))}}},vee={kernelName:Bs,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t,a=_(Or(n,6),kl(n));return{x:()=>_(e,fe(a,"float32"))}}},wee={kernelName:Ls,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(e,fe(kl(n),"float32"))}}},kee={kernelName:Bo,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>H(e,n.shape)}}},Iee={kernelName:Ws,inputsToSave:["images"],gradFunc:(e,t,n)=>{let[a]=t,r={dy:e,images:a};return{images:()=>D.runKernel(ec,r,n)}}},See={kernelName:Eu,inputsToSave:["images"],gradFunc:(e,t,n)=>{let[a]=t,r={dy:e,images:a};return{images:()=>D.runKernel(Qp,r,n)}}},Nee={kernelName:Vs,gradFunc:(e,t,n)=>{let{dims:a}=n,r=sa(a,e.shape);return{x:()=>zn(e,r)}}},Tee={kernelName:js,gradFunc:e=>({x:()=>Ue(e)})},Eee={kernelName:Us,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>wt(me(e,_(sr(n,1.5),2)))}}},Cee={kernelName:jo,inputsToSave:["condition"],gradFunc:(e,t)=>{let[n]=t;return{condition:()=>fe(Ue(n),"float32"),t:()=>_(e,fe(n,e.dtype)),e:()=>_(e,fe(Zu(n),e.dtype))}}},Ree={kernelName:Uo,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>{let a=Fn(n,Se(0)),r=Se(g3),s=Se(x3),i=_(e,s),o=_(_(e,r),Xn(fe(n,"float32")));return an(a,i,o)}}}},Mee={kernelName:Gs,outputsToSave:[!0],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(e,_(n,ge(Se(1),n)))}}},Fee={kernelName:qo,gradFunc:e=>({x:()=>Ue(e)})},$ee={kernelName:Hs,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(Xu(fe(n,"float32")),e)}}},Dee={kernelName:Go,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(wc(fe(n,"float32")),e)}}},Oee={kernelName:Ho,inputsToSave:["x"],gradFunc:(e,t,n)=>{let[a]=t,{begin:r,size:s}=n,i=a.shape,[o,l]=Ab(a,r,s),d=[];for(let u=0;urr(e,d)}}},zee={kernelName:Ks,outputsToSave:[!0],gradFunc:(e,t,n)=>{let[a]=t,{dim:r}=n,s=!0,i=_(e,a);return{logits:()=>ge(i,_(ke(i,[r],s),a))}}},_ee={kernelName:Xo,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(e,kn(n))}}},x6={kernelName:Cu,gradFunc:(e,t,n)=>{let{blockShape:a,paddings:r}=n;return{x:()=>qu(e,a,r)}}},b6={kernelName:Ko,gradFunc:(e,t,n)=>{let{axis:a}=n;return{x:()=>ot(e,a)}}},Pee={kernelName:qs,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>me(e,_(Qt(fe(n,"float32")),2))}}},Lee={kernelName:Ru,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(e,_(fe(n,"float32"),2))}}},Wee={kernelName:Zs,inputsToSave:["a","b"],gradFunc:(e,t)=>{let[n,a]=t,r=Se(2);return{a:()=>_(e,_(r,ge(n,a))),b:()=>_(e,_(r,ge(a,n)))}}},Bee={kernelName:Nr,gradFunc:e=>({x:()=>Ue(e)})},Vee={kernelName:Ys,inputsToSave:["a","b"],gradFunc:(e,t)=>{let[n,a]=t,r=ct(n.shape,a.shape);return{a:()=>{let s=e,i=_t(n.shape,r);return i.length>0&&(s=ke(s,i)),H(s,n.shape)},b:()=>{let s=e,i=_t(a.shape,r);return i.length>0&&(s=ke(s,i)),H(wt(s),a.shape)}}}},jee={kernelName:Xs,inputsToSave:["x"],gradFunc:(e,t,n)=>{let[a]=t,r=a.shape.slice(),{axis:s}=n;sa(s,a.shape).forEach(l=>{r[l]=1});let i=H(e,r),o=_(i,Dn(a.shape,"float32"));return{x:()=>o}}},Uee={kernelName:Js,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>me(e,st(Xu(n)))}}},Hee={kernelName:Qs,outputsToSave:[!0],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(ge(Se(1),st(n)),e)}}},Gee={kernelName:Sr,inputsToSave:["x"],gradFunc:(e,t,n)=>{let[a]=t,{reps:r}=n;return{x:()=>{let s=Ue(a);if(a.rank===1)for(let i=0;i{let a=n,{perm:r}=a,s=vA(r);return{x:()=>Ze(e,s)}}},Xee={kernelName:Qo,gradFunc:(e,t,n)=>{let a=n,{axis:r}=a;return{value:()=>_n(e,r)}}},Zee={kernelName:Mu,inputsToSave:["segmentIds"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>Kee(e,n)}}};function Kee(e,t){let n=Pa(t,Ue(t)),a=hi(e,n),r=Dr(t,Se(0,"int32")),s=a.rank-r.rank;for(let o=0;o({x:()=>Ue(e)})},Jee=[h6,JJ,QJ,eQ,tQ,nQ,aQ,rQ,sQ,iQ,oQ,lQ,pQ,fQ,mQ,AQ,yQ,gQ,xQ,bQ,vQ,wQ,IQ,kQ,TQ,EQ,CQ,RQ,MQ,FQ,xee,$Q,DQ,OQ,zQ,_Q,LQ,PQ,WQ,BQ,VQ,jQ,UQ,HQ,GQ,qQ,XQ,KQ,ZQ,QQ,y6,y6,eee,aee,iee,oee,lee,uee,dee,pee,cee,hee,fee,mee,Aee,g6,g6,yee,gee,bee,vee,wee,kee,Iee,See,Nee,Tee,Eee,Cee,Ree,Mee,Fee,$ee,Dee,Oee,zee,_ee,x6,x6,b6,b6,Pee,Wee,Lee,Bee,Vee,jee,Uee,Hee,Gee,qee,Xee,Zee,Yee];for(let e of Jee)Fx(e);var v6={};Fe(v6,{maxNorm:()=>Qee,minMaxNorm:()=>nte,nonNeg:()=>tte,unitNorm:()=>ete});var C1;function Pt(){return C1==null&&(C1=kb().epsilon()),C1}function va(){return"channelsLast"}var ur=class extends Error{constructor(e){super(e);Object.setPrototypeOf(this,ur.prototype)}},wa=class extends Error{constructor(e){super(e);Object.setPrototypeOf(this,wa.prototype)}},B=class extends Error{constructor(e){super(e);Object.setPrototypeOf(this,B.prototype)}},Oe=class extends Error{constructor(e){super(e);Object.setPrototypeOf(this,Oe.prototype)}},w6=class extends Error{constructor(e){super(e);Object.setPrototypeOf(this,w6.prototype)}};function Ti(e,t){if(Array.isArray(e)){let n=[];for(let a=0;an.toUpperCase())}var da={};function R1(e){if(e==null)return null;let t={};return t.className=e.getClassName(),t.config=e.getConfig(),t}function M1(e){if(!(e==null||typeof e!="object"))if(Array.isArray(e))e.forEach(t=>M1(t));else{let t=Object.keys(e);for(let n of t){let a=e[n];a!=null&&typeof a=="object"&&(!Array.isArray(a)&&a.type==="ndarray"&&typeof a.value=="number"?e[n]=a.value:M1(a))}}}function Id(e,t={},n={},a="object",r=!1){if(typeof e=="string"){let s=e,i;if(s in n)i=n[s];else if(s in da)i=da[s];else if(i=t[s],i==null)throw new B(`Unknown ${a}: ${e}. This may be due to one of the following reasons: + `}};function VX(e){let{inputs:t,backend:n,attrs:a}=e,{x:r,segmentIds:s}=t,{numSegments:i}=a,o=r.shape.length,l=[],d=0,u=C.getAxesPermutation([d],o),p=r;u!=null&&(p=cn({inputs:{x:r},backend:n,attrs:{perm:u}}),l.push(p),d=C.getInnerMostAxes(1,o)[0]);let c=C.segment_util.computeOutShape(p.shape,d,i),h=k.sizeFromShape([p.shape[d]]),m=Ae({inputs:{x:p},backend:n,attrs:{shape:[-1,h]}});l.push(m);let f=dc(r.dtype),A=(w,b,v,N,T)=>{let R=w.shape[0],$=w.shape[1],z=C.segment_util.segOpComputeOptimalWindowSize($,T),P={windowSize:z,inSize:$,batchSize:R,numSegments:T},V=new BX(P,b),j=n.compileAndRun(V,[w,v],N);if(l.push(j),j.shape[1]===T)return j;let U=pw({backend:n,attrs:{start:0,stop:T,step:1,dtype:"float32"}}),X=fw({inputs:{x:U},backend:n,attrs:{reps:[$/z]}});return l.push(U),l.push(X),A(j,b,X,N,T)},y=A(m,"unsortedSegmentSum",s,f,i),g=Ae({inputs:{x:y},backend:n,attrs:{shape:c}}),x=g;if(u!=null){l.push(g);let w=C.getUndoAxesPermutation(u);x=cn({inputs:{x},backend:n,attrs:{perm:w}})}return l.forEach(w=>n.disposeIntermediateTensorInfo(w)),x}var jX={kernelName:Mu,backendName:"webgl",kernelFunc:VX},UX=[EH,MH,hB,mB,gB,vB,kB,NB,EB,RB,DB,zB,LB,VB,KB,HB,JB,nV,eV,iV,lV,dV,fV,vV,kV,CV,MV,OV,PV,XW,jV,QV,tj,qV,sj,oj,aj,dj,hj,Aj,gj,bj,kj,Cj,Mj,Sj,Dj,_j,Lj,jj,qj,Yj,eU,tU,nU,rU,iU,lU,dU,cU,AU,bU,wU,IU,TU,MU,OU,LU,qW,BU,BV,UU,qU,ZU,ZW,eH,rH,iH,hH,dH,yH,bH,IH,$H,BH,LH,HH,qH,KH,_H,YH,QH,aG,oG,pG,xG,tB,vG,IG,TG,RG,SV,$G,OG,_G,WG,UG,JW,GG,qG,NV,mG,ZG,rq,eq,aB,lq,pq,mq,gq,wq,Iq,Tq,Rq,Fq,Oq,Pq,Bq,Uq,qq,Zq,xV,yG,Qq,tX,aX,sX,oX,uX,cX,mX,yX,xX,wX,AG,dB,SX,EX,MX,$X,zX,pB,PX,WX,jX,DG];for(let e of UX)ai(e);var In;(function(e){e[e.float32=0]="float32",e[e.int32=1]="int32",e[e.bool=2]="bool",e[e.string=3]="string",e[e.complex64=4]="complex64"})(In||(In={}));var bd;(function(e){e[e.linear=0]="linear",e[e.relu=1]="relu",e[e.relu6=2]="relu6",e[e.prelu=3]="prelu",e[e.leakyrelu=4]="leakyrelu",e[e.sigmoid=5]="sigmoid"})(bd||(bd={}));var mw;function HX(e){mw=e.wasm.cwrap(ei,null,["number","array","number","number","array","number","number","number","number","number","number","number","number"])}function GX(e){let{inputs:t,backend:n,attrs:a}=e,{a:r,b:s,bias:i,preluActivationWeights:o}=t;if(r.dtype!=="float32"||s.dtype!=="float32")throw new Error("_FusedMatMul for non non-float32 tensors not yet supported.");let{transposeA:l,transposeB:d,activation:u,leakyreluAlpha:p}=a,c=n.dataIdMap.get(r.dataId).id,h=n.dataIdMap.get(s.dataId).id,m=0;if(i!=null){let T=n.dataIdMap.get(i.dataId);if(T.shape.length!==1)throw new Error(`_FusedMatMul only supports rank-1 bias but got rank ${T.shape.length}.`);m=T.id}let f=o==null?0:n.dataIdMap.get(o.dataId).id,A=bd[u];if(A==null)throw new Error(`${u} activation not yet supported for FusedConv2D in the wasm backend.`);let y=l?r.shape[2]:r.shape[1],g=d?s.shape[1]:s.shape[2],x=r.shape[0],w=n.makeOutput([x,y,g],r.dtype),b=n.dataIdMap.get(w.dataId).id,v=new Uint8Array(new Int32Array(r.shape).buffer),N=new Uint8Array(new Int32Array(s.shape).buffer);return mw(c,v,r.shape.length,h,N,s.shape.length,l,d,A,m,f,p||0,b),w}var qX={kernelName:ei,backendName:"wasm",setupFunc:HX,kernelFunc:GX};function hn(e){let t;function n(r){t=r.wasm.cwrap(e,null,["number","number"])}function a(r){let{backend:s,inputs:{x:i}}=r,o=s.dataIdMap.get(i.dataId).id,l=s.makeOutput(i.shape,i.dtype),d=s.dataIdMap.get(l.dataId).id;return k.sizeFromShape(l.shape)===0||t(o,d),l}return{kernelName:e,backendName:"wasm",setupFunc:n,kernelFunc:a}}var XX=hn(Qi);function fn(e,t,n){let a;function r(i){a=i.wasm.cwrap(e,null,["number","array","number","number","array","number","number","number"])}function s(i){let{backend:o,inputs:l}=i,{a:d,b:u}=l,p=o.dataIdMap.get(d.dataId).id,c=o.dataIdMap.get(u.dataId).id,h=n!=null?n:d.dtype,m=C.assertAndGetBroadcastShape(d.shape,u.shape),f=o.makeOutput(m,h);if(k.sizeFromShape(m)===0)return f;let A=new Uint8Array(new Int32Array(d.shape).buffer),y=new Uint8Array(new Int32Array(u.shape).buffer),g=o.dataIdMap.get(f.dataId).id,x=()=>a(p,A,d.shape.length,c,y,u.shape.length,In[d.dtype],g);if(t&&d.dtype==="float32")return x(),f;let w=C.getBroadcastDims(d.shape,m),b=C.getBroadcastDims(u.shape,m),v=w.every((T,R)=>T===R),N=b.every((T,R)=>T===R);if(v&&N)return x(),f;throw new Error(`Broadcasting along outer dims is not yet supported for ${d.dtype} ${e}.`)}return{kernelName:e,backendName:"wasm",setupFunc:r,kernelFunc:s}}var KX=!0,ZX=fn(wr,KX),Aw;function YX(e){Aw=e.wasm.cwrap(is,null,["array","number","number","number"])}function JX(e){let{inputs:t,backend:n}=e,a=n.makeOutput(t[0].shape,t[0].dtype);if(k.sizeFromShape(a.shape)===0)return a;let r=t.map(o=>n.dataIdMap.get(o.dataId).id),s=new Uint8Array(new Int32Array(r).buffer),i=n.dataIdMap.get(a.dataId).id;return Aw(s,r.length,In[a.dtype],i),a}var QX={kernelName:is,backendName:"wasm",setupFunc:YX,kernelFunc:JX};function Nh(e){let{inputs:{x:t},backend:n}=e,a=n.makeOutput(t.shape,t.dtype),r=n.typedArrayFromHeap(t);return n.typedArrayFromHeap(a).set(r),a}var eK={kernelName:ks,backendName:"wasm",kernelFunc:Nh},yw;function tK(e){yw=e.wasm.cwrap(Qs,null,["number","array","number","number","number","array","number"])}function Th(e){let{inputs:t,backend:n,attrs:a}=e,[r,s]=aK(t.x.shape,a.perm),i=!0;for(let m=0;m=r&&(s===-1||a[s]>a[i])&&(s=i);a[s]=r}return[n,a]}var rK={kernelName:Qs,backendName:"wasm",kernelFunc:Th,setupFunc:tK};function Wr(e,t,n){let a=e.shape,r=e.shape.length,s=k.parseAxisParam(t,a),i=s,o=C.getAxesPermutation(i,r),l=null,d=!1;if(o!=null){let u=new Array(r);for(let c=0;c`new shape: ${i}, old shape: ${a.shape}. New shape and old shape must have the same number of elements.`),e.backend.incRef(a.dataId),{dataId:a.dataId,shape:i,dtype:a.dtype}}var yK={kernelName:Wo,backendName:"wasm",kernelFunc:xa},ww;function gK(e){ww=e.wasm.cwrap(us,null,["number","array","number","number","array","number","number","number","number"])}function xK(e){let{inputs:t,backend:n,attrs:a}=e,{a:r,b:s}=t,{transposeA:i,transposeB:o}=a;if(r.dtype!=="float32"||s.dtype!=="float32")throw new Error("BatchMatMul for non non-float32 tensors not yet supported.");let l=r.shape.length,d=s.shape.length,u=i?r.shape[l-2]:r.shape[l-1],p=o?s.shape[d-1]:s.shape[d-2],c=i?r.shape[l-1]:r.shape[l-2],h=o?s.shape[d-2]:s.shape[d-1],m=r.shape.slice(0,-2),f=s.shape.slice(0,-2),A=k.sizeFromShape(m),y=k.sizeFromShape(f),g=A===y||A===1||y===1;k.assert(l>=2&&d>=2&&g,()=>`Error in matMul: the input batch dimensions must either be the same or at least one input batch dimension must be 1. Got input batch dimensions of (${m}) and (${f}).`);let x=(A>y?r.shape.slice(0,-2):s.shape.slice(0,-2)).concat([c,h]);k.assert(u===p,()=>`Error in matMul: inner shapes (${u}) and (${p}) of Tensors with shapes ${r.shape} and ${s.shape} and transposeA=${i} and transposeB=${o} must match.`);let w=i?[A,u,c]:[A,c,u],b=o?[y,h,p]:[y,p,h],v=xa({inputs:{x:r},backend:n,attrs:{shape:w}}),N=xa({inputs:{x:s},backend:n,attrs:{shape:b}}),T=n.dataIdMap.get(v.dataId).id,R=n.dataIdMap.get(N.dataId).id,$=i?v.shape[2]:v.shape[1],z=o?N.shape[1]:N.shape[2],P=Math.max(A,y),V=n.makeOutput([P,$,z],v.dtype),j=n.dataIdMap.get(V.dataId).id,U=new Uint8Array(new Int32Array(v.shape).buffer),X=new Uint8Array(new Int32Array(N.shape).buffer);return ww(T,U,v.shape.length,R,X,N.shape.length,i,o,j),n.disposeData(v.dataId),n.disposeData(N.dataId),V.shape=x,V}var bK={kernelName:us,backendName:"wasm",setupFunc:gK,kernelFunc:xK};function Eh(e){let{inputs:{x:t},attrs:{dtype:n},backend:a}=e,r=a.makeOutput(t.shape,n),s=a.typedArrayFromHeap(t);return a.typedArrayFromHeap(r).set(s),r}var vK={kernelName:ds,backendName:"wasm",kernelFunc:Eh},wK=hn(ps),kw;function kK(e){kw=e.wasm.cwrap(kr,null,["number","number","number","number"])}function IK(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{clipValueMin:s,clipValueMax:i}=a,o=n.dataIdMap.get(r.dataId).id,l=n.makeOutput(r.shape,r.dtype),d=n.dataIdMap.get(l.dataId).id;return kw(o,s,i,d),l}var SK={kernelName:kr,backendName:"wasm",setupFunc:kK,kernelFunc:IK};function Iw(e){let{inputs:t,backend:n}=e,a=k.parseAxisParam(e.attrs.axis,t[0].shape)[0],r=C.computeOutShape(t.map(h=>h.shape),a),s=t.filter(h=>k.sizeFromShape(h.shape)>0);if(s.length===1)return Nh({inputs:{x:s[0]},backend:n});let i=n.makeOutput(r,t[0].dtype);if(k.sizeFromShape(r)===0)return i;let o=s.map(h=>h.shape);if(C.assertParamsConsistent(o,a),s[0].dtype==="string"){let h=s.map(x=>{let w=k.sizeFromShape(x.shape.slice(a));return xa({inputs:{x},backend:n,attrs:{shape:[-1,w]}})}),m=h.map(x=>({vals:n.readSync(x.dataId),shape:x.shape}));r=C.computeOutShape(h.map(x=>x.shape),1);let f=h[0].shape[0]===1,A=HA(m,r,t[0].dtype,f),y=C.computeOutShape(s.map(x=>x.shape),a);i.shape=y;let g=n.dataIdMap.get(i.dataId);return g.stringBytes=C.fromStringArrayToUint8(A),h.forEach(x=>n.disposeData(x.dataId)),i}let l=k.sizeFromShape(s[0].shape.slice(0,a)),d=0,u=s.map(h=>{let m=k.sizeFromShape(h.shape.slice(a));return d+=m,m}),p=s.map(h=>n.typedArrayFromHeap(h)),c=n.typedArrayFromHeap(i);for(let h=0;h`cumsum does not support ${r.dtype} tensors in the WASM backend`);let d=C.getAxesPermutation([s],l),u=r;d!==null&&(u=Th({inputs:{x:r},attrs:{perm:d},backend:n}));let p=C.getInnerMostAxes(1,l)[0];C.assertAxesAreInnerMostDims("cumsum",[p],l);let c=n.makeOutput(u.shape,u.dtype),h=u.shape[p],m=n.dataIdMap.get(u.dataId).id,f=n.dataIdMap.get(c.dataId).id;Ew(m,i?1:0,o?1:0,h,f,In[r.dtype]);let A=c;if(d!==null){let y=C.getUndoAxesPermutation(d);A=Th({inputs:{x:c},attrs:{perm:y},backend:n}),n.disposeData(u.dataId),n.disposeData(c.dataId)}return A}var LK={kernelName:ms,backendName:"wasm",setupFunc:_K,kernelFunc:PK},Cw;function WK(e){Cw=e.wasm.cwrap(ho,null,["number","number","number","array","number","array","array","number","number"])}function BK(e){let{backend:t,inputs:n,attrs:a}=e,{x:r}=n,{blockSize:s,dataFormat:i}=a;k.assert(s>1,()=>`blockSize should be > 1 for depthToSpace, but was: ${s}`);let o=r.shape[0],l=i==="NHWC"?r.shape[1]:r.shape[2],d=i==="NHWC"?r.shape[2]:r.shape[3],u=i==="NHWC"?r.shape[3]:r.shape[1],p=l*s,c=d*s,h=u/(s*s),m=i==="NHWC"?[o,p,c,h]:[o,h,p,c],f=t.makeOutput(m,"float32"),A=t.dataIdMap.get(r.dataId).id,y=new Uint8Array(new Int32Array(k.computeStrides(r.shape)).buffer),g=new Uint8Array(new Int32Array(m).buffer),x=new Uint8Array(new Int32Array(k.computeStrides(m)).buffer),w=t.dataIdMap.get(f.dataId).id;return Cw(A,s,i==="NHWC"?1:0,y,r.shape.length-1,g,x,m.length,w),f}var VK={kernelName:ho,backendName:"wasm",setupFunc:WK,kernelFunc:BK},Rw;function jK(e){Rw=e.wasm.cwrap(As,null,["number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number"])}function UK(e){let{inputs:t,attrs:n,backend:a}=e,{x:r,filter:s}=t,i=a.dataIdMap.get(r.dataId).id,o=a.dataIdMap.get(s.dataId).id,{strides:l,dilations:d,pad:u,dimRoundingMode:p}=n,c=d==null?[1,1]:d,h=C.computeConv2DInfo(r.shape,s.shape,l,c,u,p,!0),m=h.filterHeight,f=h.filterWidth,A=h.padInfo.top,y=h.padInfo.right,g=h.padInfo.bottom,x=h.padInfo.left,w=h.dilationHeight,b=h.dilationWidth,v=h.strideHeight,N=h.strideWidth,T=h.inChannels,R=h.outChannels,$=h.padInfo.type==="SAME"?1:0;if(h.dataFormat!=="channelsLast")throw new Error(`wasm backend DepthwiseConv2dNative does not support dataFormat:'${h.dataFormat}'. Please use 'channelsLast'.`);let z=a.makeOutput(h.outShape,"float32"),P=a.dataIdMap.get(z.dataId).id;return Rw(i,r.shape[0],r.shape[1],r.shape[2],o,m,f,A,y,g,x,$,w,b,v,N,T,R,P),z}var HK={kernelName:As,backendName:"wasm",setupFunc:jK,kernelFunc:UK},GK=!1,qK=fn(Ao,GK,"bool"),XK=hn(gs);function I1(e){let{inputs:t,attrs:n,backend:a}=e,{input:r}=t,{dim:s}=n,i=r.shape.length,o=r.shape.slice(),l=s;return s<0&&(k.assert(-(i+1)<=s,()=>`Axis must be in the interval [${-(i+1)}, ${i}]`),l=i+s+1),o.splice(l,0,1),xa({inputs:{x:r},backend:a,attrs:{shape:o}})}var KK={kernelName:yo,backendName:"wasm",kernelFunc:I1};function ZK(e){let{attrs:{shape:t,value:n,dtype:a},backend:r}=e,s=r.makeOutput(t,a);return r.typedArrayFromHeap(s).fill(n),s}var YK={kernelName:wu,backendName:"wasm",kernelFunc:ZK},Mw;function JK(e){Mw=e.wasm.cwrap(xo,null,["number","number","number","number","number","number"])}function QK(e){let{inputs:t,backend:n}=e,{image:a}=t,r=n.makeOutput(a.shape,a.dtype),s=n.dataIdMap.get(a.dataId).id,i=n.dataIdMap.get(r.dataId).id,[o,l,d,u]=a.shape;return Mw(s,o,l,d,u,i),r}var eZ={kernelName:xo,backendName:"wasm",kernelFunc:QK,setupFunc:JK},tZ=hn(xs),nZ=!1,aZ=fn(bs,nZ),Fw;function rZ(e){Fw=e.wasm.cwrap(vs,null,["number","number","number","number","number","number","number"])}function sZ(e){let{backend:t,inputs:n,attrs:a}=e,{varianceEpsilon:r}=a,{x:s,mean:i,variance:o,offset:l,scale:d}=n,u=t.dataIdMap.get(s.dataId).id,p=t.dataIdMap.get(i.dataId).id,c=t.dataIdMap.get(o.dataId).id,h=l!=null?t.dataIdMap.get(l.dataId).id:0,m=d!=null?t.dataIdMap.get(d.dataId).id:0,f=t.makeOutput(s.shape,s.dtype);if(k.sizeFromShape(s.shape)===0)return f;let A=t.dataIdMap.get(f.dataId).id;return Fw(u,p,c,h,m,r,A),f}var iZ={kernelName:vs,backendName:"wasm",setupFunc:rZ,kernelFunc:sZ},$w;function oZ(e){$w=e.wasm.cwrap(ti,null,["number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number"])}function lZ(e){let{inputs:t,attrs:n,backend:a}=e,{x:r,filter:s,bias:i,preluActivationWeights:o}=t,{strides:l,pad:d,dilations:u,dataFormat:p,dimRoundingMode:c,activation:h,leakyreluAlpha:m}=n,f=C.computeConv2DInfo(r.shape,s.shape,l,u,d,c),A=bd[h];if(A==null)throw new Error(`${h} activation not yet supported for FusedConv2D in the wasm backend.`);let y=a.dataIdMap.get(r.dataId).id,g=a.dataIdMap.get(s.dataId).id,x=f.outChannels,w=0;if(i!=null){let Q=a.dataIdMap.get(i.dataId);if(Q.shape.length!==1)throw new Error(`FusedConv2D only supports rank-1 bias but got rank ${Q.shape.length}.`);if(Q.shape[0]!==x)throw new Error(`FusedConv2D bias shape (${Q.shape}) does not match the number of output channels (${x})`);w=Q.id}let b=f.filterHeight,v=f.filterWidth,N=f.padInfo.top,T=f.padInfo.right,R=f.padInfo.bottom,$=f.padInfo.left,z=f.dilationHeight,P=f.dilationWidth,V=f.strideHeight,j=f.strideWidth,U=f.inChannels,X=f.padInfo.type==="SAME"?1:0,G=f.batchSize,ee=f.inHeight,Y=f.inWidth;if(p!=="NHWC")throw new Error(`wasm backend FusedConv2D does not support dataFormat:'${p}'. Please use 'NHWC'.`);let re=a.makeOutput(f.outShape,"float32"),ne=a.dataIdMap.get(re.dataId).id,ie=o==null?0:a.dataIdMap.get(o.dataId).id;return $w(y,G,ee,Y,g,b,v,w,N,T,R,$,X,z,P,V,j,U,x,A,ie,m||0,ne),re}var uZ={kernelName:ti,backendName:"wasm",setupFunc:oZ,kernelFunc:lZ},Dw;function dZ(e){Dw=e.wasm.cwrap(ni,null,["number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number"])}function pZ(e){let{inputs:t,attrs:n,backend:a}=e,{x:r,filter:s,bias:i,preluActivationWeights:o}=t,{strides:l,pad:d,dilations:u,dataFormat:p,dimRoundingMode:c,activation:h,leakyreluAlpha:m}=n,f=C.computeConv2DInfo(r.shape,s.shape,l,u,d,c,!0),A=bd[h];if(A==null)throw new Error(`${h} activation not yet supported for FusedDepthwiseConv2D in the wasm backend.`);let y=a.dataIdMap.get(r.dataId).id,g=a.dataIdMap.get(s.dataId).id,x=f.outChannels,w=0;if(i!=null){let Q=a.dataIdMap.get(i.dataId);if(Q.shape.length!==1)throw new Error(`FusedDepthwiseConv2D only supports rank-1 bias but got rank ${Q.shape.length}.`);if(Q.shape[0]!==x)throw new Error(`FusedDepthwiseConv2D bias shape (${Q.shape}) does not match the number of output channels (${x})`);w=Q.id}let b=f.filterHeight,v=f.filterWidth,N=f.padInfo.top,T=f.padInfo.right,R=f.padInfo.bottom,$=f.padInfo.left,z=f.dilationHeight,P=f.dilationWidth,V=f.strideHeight,j=f.strideWidth,U=f.inChannels,X=f.padInfo.type==="SAME"?1:0,G=f.batchSize,ee=f.inHeight,Y=f.inWidth;if(p!=="NHWC")throw new Error(`wasm backend FusedDepthwiseConv2D does not support dataFormat:'${p}'. Please use 'NHWC'.`);let re=a.makeOutput(f.outShape,"float32"),ne=a.dataIdMap.get(re.dataId).id,ie=o==null?0:a.dataIdMap.get(o.dataId).id;return Dw(y,G,ee,Y,g,b,v,w,N,T,R,$,X,z,P,V,j,U,x,A,ie,m||0,ne),re}var cZ={kernelName:ni,backendName:"wasm",setupFunc:dZ,kernelFunc:pZ},Ow;function hZ(e){Ow=e.wasm.cwrap(vo,null,["number","number","number","number","number","number","array","number"])}function fZ(e){let{backend:t,inputs:n}=e,{params:a,indices:r}=n,[s,i,o,l]=Vm.prepareAndValidate(a,r),d=t.makeOutput(s,a.dtype);if(i===0)return d;let u=r.shape,p=u[u.length-1],c=t.dataIdMap.get(a.dataId).id,h=t.dataIdMap.get(r.dataId).id,m=new Uint8Array(new Int32Array(l).buffer),f=t.dataIdMap.get(d.dataId).id;return Ow(c,In[a.dtype],h,i,p,o,m,f),d}var mZ={kernelName:vo,backendName:"wasm",setupFunc:hZ,kernelFunc:fZ},zw;function AZ(e){zw=e.wasm.cwrap("Gather",null,["number","number","array","number","number","number","array","number"])}function yZ(e){let{backend:t,inputs:n,attrs:a}=e,{x:r,indices:s}=n,{axis:i,batchDims:o}=a,l=k.parseAxisParam(i,r.shape)[0],d=C.segment_util.collectGatherOpShapeInfo(r,s,l,o),u=xa({inputs:{x:r},attrs:{shape:[d.batchSize,d.outerSize,d.dimSize,d.sliceSize]},backend:t}),p=k.sizeFromShape(s.shape),c=xa({inputs:{x:s},attrs:{shape:[d.batchSize,p/d.batchSize]},backend:t}),h=[d.batchSize,d.outerSize,p/d.batchSize,d.sliceSize],m=t.makeOutput(h,r.dtype);if(k.sizeFromShape(r.shape)===0)return m;let f=u.shape.length-1,A=t.dataIdMap.get(u.dataId).id,y=t.dataIdMap.get(c.dataId).id,g=t.dataIdMap.get(m.dataId).id,x=new Uint8Array(new Int32Array(k.computeStrides(u.shape)).buffer),w=new Uint8Array(new Int32Array(k.computeStrides(h)).buffer);return zw(A,In[r.dtype],x,f,y,d.batchSize,w,g),t.disposeData(u.dataId),t.disposeData(c.dataId),m.shape=d.outputShape,m}var gZ={kernelName:bo,backendName:"wasm",setupFunc:AZ,kernelFunc:yZ},xZ=!1,bZ=fn(wo,xZ,"bool"),vZ=!1,wZ=fn(ws,vZ,"bool"),_w;function kZ(e){_w=e.wasm.cwrap(Is,null,["number","number","number"])}function IZ(e){let{inputs:{x:t},attrs:{alpha:n},backend:a}=e,r=a.dataIdMap.get(t.dataId).id,s=a.makeOutput(t.shape,t.dtype);if(k.sizeFromShape(t.shape)!==0){let i=a.dataIdMap.get(s.dataId).id;_w(r,n,i)}return s}var SZ={kernelName:Is,backendName:"wasm",setupFunc:kZ,kernelFunc:IZ},NZ=!1,TZ=fn(No,NZ,"bool"),EZ=!1,CZ=fn(To,EZ,"bool"),RZ=hn(Ss),MZ=!1,FZ=fn(Co,MZ,"bool"),Pw;function $Z(e){Pw=e.wasm.cwrap(Ns,null,["number, number, number"])}function DZ(e){let{backend:t,inputs:n,attrs:a}=e,{reductionIndices:r,keepDims:s}=a,{x:i}=n,o=t.dataIdMap.get(i.dataId).id,l=i,{transposed:d,axes:u,originalAxes:p,inputWasTransposed:c}=Wr(i,r,t);if(c){let g=t.dataIdMap.get(d.dataId).id;l=d,o=g}let h=l.shape.length;C.assertAxesAreInnerMostDims("max",u,h);let[m,f]=C.computeOutAndReduceShapes(l.shape,u),A=k.sizeFromShape(f),y=t.makeOutput(m,i.dtype);if(k.sizeFromShape(l.shape)!==0){let g=t.dataIdMap.get(y.dataId).id;Pw(o,A,g)}if(c&&t.disposeData(d.dataId),s){let g=C.expandShapeToKeepDim(y.shape,p);y.shape=g}return y}var OZ={kernelName:Ns,backendName:"wasm",setupFunc:$Z,kernelFunc:DZ},zZ=!1,_Z=fn(Ts,zZ),Lw;function PZ(e){Lw=e.wasm.cwrap(Es,null,["number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number","number"])}function LZ(e){let{inputs:t,attrs:n,backend:a}=e,r=t.x,s=a.dataIdMap.get(r.dataId).id,{filterSize:i,strides:o,pad:l,dimRoundingMode:d}=n,u=C.computePool2DInfo(r.shape,i,o,1,l,d),p=u.filterHeight,c=u.filterWidth,h=u.padInfo.top,m=u.padInfo.right,f=u.padInfo.bottom,A=u.padInfo.left,y=u.dilationHeight,g=u.dilationWidth,x=u.strideHeight,w=u.strideWidth,b=u.inChannels,v=u.outChannels;if(u.dataFormat!=="channelsLast")throw new Error(`wasm backend does not support dataFormat:'${u.dataFormat}'. Please use 'channelsLast'.`);let N=a.makeOutput(u.outShape,"float32"),T=a.dataIdMap.get(N.dataId).id;return Lw(s,r.shape[0],r.shape[1],r.shape[2],p,c,h,m,f,A,y,g,x,w,b,v,T),N}var WZ={kernelName:Es,backendName:"wasm",setupFunc:PZ,kernelFunc:LZ},Ww;function BZ(e){Ww=e.wasm.cwrap(Cs,null,["number, number, number"])}function VZ(e){let{backend:t,inputs:n,attrs:a}=e,{axis:r,keepDims:s}=a,{x:i}=n,o=t.dataIdMap.get(i.dataId).id,l=o,d=i,{transposed:u,axes:p,originalAxes:c,inputWasTransposed:h}=Wr(i,r,t),m=p;if(h){let w=t.dataIdMap.get(u.dataId).id;w!==o&&(d=u,l=w,m=C.getInnerMostAxes(m.length,d.shape.length))}C.assertAxesAreInnerMostDims("mean",m,d.shape.length);let[f,A]=C.computeOutAndReduceShapes(d.shape,m),y=k.sizeFromShape(A),g=d;d.dtype!=="float32"&&(g=Eh({backend:t,inputs:{x:d},attrs:{dtype:"float32"}}),l=t.dataIdMap.get(g.dataId).id);let x=t.makeOutput(f,"float32");if(k.sizeFromShape(d.shape)!==0){let w=t.dataIdMap.get(x.dataId).id;Ww(l,y,w)}if(h&&t.disposeData(u.dataId),s){let w=C.expandShapeToKeepDim(x.shape,c);x.shape=w}return d.dtype!=="float32"&&t.disposeData(g.dataId),x}var jZ={kernelName:Cs,backendName:"wasm",setupFunc:BZ,kernelFunc:VZ},Bw;function UZ(e){Bw=e.wasm.cwrap(Rs,null,["number, number, number"])}function HZ(e){let{backend:t,inputs:n,attrs:a}=e,{axis:r,keepDims:s}=a,{x:i}=n,o=t.dataIdMap.get(i.dataId).id,l=o,d=i,{transposed:u,axes:p,originalAxes:c,inputWasTransposed:h}=Wr(i,r,t);if(h){let x=t.dataIdMap.get(u.dataId).id;x!==o&&(d=u,l=x)}let m=d.shape.length;C.assertAxesAreInnerMostDims("min",p,m);let[f,A]=C.computeOutAndReduceShapes(d.shape,p),y=k.sizeFromShape(A),g=t.makeOutput(f,d.dtype);if(k.sizeFromShape(d.shape)!==0){let x=t.dataIdMap.get(g.dataId).id;Bw(l,y,x)}if(h&&t.disposeData(u.dataId),s){let x=C.expandShapeToKeepDim(g.shape,c);g.shape=x}return g}var GZ={kernelName:Rs,backendName:"wasm",setupFunc:UZ,kernelFunc:HZ},qZ=!1,XZ=fn(Ms,qZ),S1;(function(e){e[e.reflect=0]="reflect",e[e.symmetric=1]="symmetric"})(S1||(S1={}));var Vw;function KZ(e){Vw=e.wasm.cwrap(Fs,null,["number","array","number","number","array","array","number","number"])}function ZZ(e){let{inputs:{x:t},backend:n,attrs:{paddings:a,mode:r}}=e,s=a.map((m,f)=>m[0]+t.shape[f]+m[1]),i=n.dataIdMap.get(t.dataId).id,o=n.makeOutput(s,t.dtype),l=n.dataIdMap.get(o.dataId).id,d=new Uint8Array(new Int32Array(t.shape).buffer),u=a.map(m=>m[0]),p=a.map(m=>m[1]),c=new Uint8Array(new Int32Array(u).buffer),h=new Uint8Array(new Int32Array(p).buffer);return Vw(i,d,t.shape.length,In[t.dtype],c,h,S1[r],l),o}var YZ={kernelName:Fs,backendName:"wasm",kernelFunc:ZZ,setupFunc:KZ},JZ=!0,QZ=fn($s,JZ),eY=hn(Mo);function N1(e,t){let n=new Int32Array(e.wasm.HEAPU8.buffer,t,4),a=n[0],r=n[1],s=n[2],i=n[3];return e.wasm._free(t),{pSelectedIndices:a,selectedSize:r,pSelectedScores:s,pValidOutputs:i}}var jw;function tY(e){jw=e.wasm.cwrap($o,"number",["number","number","number","number","number"])}function nY(e){let{backend:t,inputs:n,attrs:a}=e,{iouThreshold:r,maxOutputSize:s,scoreThreshold:i}=a,{boxes:o,scores:l}=n,d=t.dataIdMap.get(o.dataId).id,u=t.dataIdMap.get(l.dataId).id,p=jw(d,u,s,r,i),{pSelectedIndices:c,selectedSize:h,pSelectedScores:m,pValidOutputs:f}=N1(t,p);return t.wasm._free(m),t.wasm._free(f),t.makeOutput([h],"int32",c)}var aY={kernelName:$o,backendName:"wasm",setupFunc:tY,kernelFunc:nY},Uw;function rY(e){Uw=e.wasm.cwrap(Do,"number",["number","number","number","number","number","bool"])}function sY(e){let{backend:t,inputs:n,attrs:a}=e,{iouThreshold:r,maxOutputSize:s,scoreThreshold:i,padToMaxOutputSize:o}=a,{boxes:l,scores:d}=n,u=t.dataIdMap.get(l.dataId).id,p=t.dataIdMap.get(d.dataId).id,c=Uw(u,p,s,r,i,o),{pSelectedIndices:h,selectedSize:m,pSelectedScores:f,pValidOutputs:A}=N1(t,c);t.wasm._free(f);let y=t.makeOutput([m],"int32",h),g=t.makeOutput([],"int32",A);return[y,g]}var iY={kernelName:Do,backendName:"wasm",setupFunc:rY,kernelFunc:sY},Hw;function oY(e){Hw=e.wasm.cwrap(Oo,"number",["number","number","number","number","number","number"])}function lY(e){let{backend:t,inputs:n,attrs:a}=e,{iouThreshold:r,maxOutputSize:s,scoreThreshold:i,softNmsSigma:o}=a,{boxes:l,scores:d}=n,u=t.dataIdMap.get(l.dataId).id,p=t.dataIdMap.get(d.dataId).id,c=Hw(u,p,s,r,i,o),{pSelectedIndices:h,selectedSize:m,pSelectedScores:f,pValidOutputs:A}=N1(t,c);t.wasm._free(A);let y=t.makeOutput([m],"int32",h),g=t.makeOutput([m],"float32",f);return[y,g]}var uY={kernelName:Oo,backendName:"wasm",setupFunc:oY,kernelFunc:lY},dY=!1,pY=fn(Fo,dY,"bool"),Gw;function cY(e){Gw=e.wasm.cwrap(Ds,null,["number","number","number","number","number"])}function hY(e){let{inputs:t,backend:n,attrs:a}=e,{indices:r}=t,{depth:s,onValue:i,offValue:o}=a,l=n.makeOutput([...r.shape,s],"int32"),d=n.dataIdMap.get(l.dataId).id,u=n.dataIdMap.get(r.dataId).id;return Gw(u,s,i,o,d),l}var fY={kernelName:Ds,backendName:"wasm",setupFunc:cY,kernelFunc:hY};function mY(e){let{inputs:{x:t},backend:n}=e,a=n.makeOutput(t.shape,t.dtype);return n.typedArrayFromHeap(a).fill(1),a}var AY={kernelName:zo,backendName:"wasm",kernelFunc:mY};function yY(e){let{inputs:t,backend:n,attrs:a}=e,{axis:r}=a;if(t.length===1)return I1({inputs:{input:t[0]},backend:n,attrs:{dim:r}});let s=t[0].shape,i=t[0].dtype;t.forEach(u=>{k.assertShapesMatch(s,u.shape,"All tensors passed to stack must have matching shapes"),k.assert(i===u.dtype,()=>"All tensors passed to stack must have matching dtypes")});let o=[],l=t.map(u=>{let p=I1({inputs:{input:u},backend:n,attrs:{dim:r}});return o.push(p),p}),d=Iw({inputs:l,backend:n,attrs:{axis:r}});return o.forEach(u=>n.disposeData(u.dataId)),d}var gY={kernelName:_o,backendName:"wasm",kernelFunc:yY},qw;function xY(e){qw=e.wasm.cwrap(Os,null,["number","array","number","number","array","array","number","number"])}function bY(e){let{inputs:{x:t},backend:n,attrs:{paddings:a,constantValue:r}}=e,s=a.map((m,f)=>m[0]+t.shape[f]+m[1]),i=n.dataIdMap.get(t.dataId).id,o=n.makeOutput(s,t.dtype),l=n.dataIdMap.get(o.dataId).id,d=new Uint8Array(new Int32Array(t.shape).buffer),u=a.map(m=>m[0]),p=a.map(m=>m[1]),c=new Uint8Array(new Int32Array(u).buffer),h=new Uint8Array(new Int32Array(p).buffer);return qw(i,d,t.shape.length,In[t.dtype],c,h,r,l),o}var vY={kernelName:Os,backendName:"wasm",kernelFunc:bY,setupFunc:xY},wY=!1,kY=fn(zs,wY),Xw;function IY(e){Xw=e.wasm.cwrap(_s,null,["number","number","number"])}function SY(e){let{inputs:t,backend:n}=e,{x:a,alpha:r}=t,s=n.dataIdMap.get(a.dataId).id,i=n.dataIdMap.get(r.dataId).id,o=n.makeOutput(a.shape,"float32"),l=n.dataIdMap.get(o.dataId).id;return Xw(s,i,l),o}var NY={kernelName:_s,backendName:"wasm",setupFunc:IY,kernelFunc:SY},Kw;function TY(e){Kw=e.wasm.cwrap(Po,null,["number","number","number","number"])}function EY(e){let{backend:t,inputs:n,attrs:a}=e,{axis:r,keepDims:s}=a,{x:i}=n,o=t.dataIdMap.get(i.dataId).id,l=o,d=i,{transposed:u,axes:p,originalAxes:c,inputWasTransposed:h}=Wr(i,r,t),m=p;if(h){let x=t.dataIdMap.get(u.dataId).id;x!==o&&(d=u,l=x,m=C.getInnerMostAxes(m.length,d.shape.length))}C.assertAxesAreInnerMostDims("prod",m,d.shape.length);let[f,A]=C.computeOutAndReduceShapes(d.shape,m),y=k.sizeFromShape(A),g=t.makeOutput(f,d.dtype);if(k.sizeFromShape(d.shape)!==0){let x=t.dataIdMap.get(g.dataId).id;Kw(l,y,In[g.dtype],x)}if(h&&t.disposeData(u.dataId),s){let x=C.expandShapeToKeepDim(g.shape,c);g.shape=x}return g}var CY={kernelName:Po,backendName:"wasm",setupFunc:TY,kernelFunc:EY},RY=e=>{let{backend:t,attrs:n}=e,{start:a,stop:r,step:s,dtype:i}=n,o=XA(a,r,s,i),l=t.makeOutput([o.length],i);return t.typedArrayFromHeap(l).set(o),l},MY={kernelName:Tu,backendName:"wasm",kernelFunc:RY},FY=!0,$Y=fn(ys,FY),DY=hn(Ps),OY=hn(Ws),Zw;function zY(e){Zw=e.wasm.cwrap(Ls,null,["number","number","number","number","number","number","number","number","number","number"])}function _Y(e){let{backend:t,inputs:n,attrs:a}=e,{images:r}=n,{alignCorners:s,halfPixelCenters:i,size:o}=a,[l,d]=o,[u,p,c,h]=r.shape,m=[u,l,d,h],f=t.dataIdMap.get(r.dataId),A;f.dtype!=="float32"&&(A=Eh({backend:t,inputs:{x:r},attrs:{dtype:"float32"}}),f=t.dataIdMap.get(A.dataId));let y=f.id,g=t.makeOutput(m,"float32");if(k.sizeFromShape(r.shape)===0)return g;let x=t.dataIdMap.get(g.dataId).id;return Zw(y,u,p,c,h,l,d,s?1:0,i?1:0,x),A!=null&&t.disposeData(A.dataId),g}var PY={kernelName:Ls,backendName:"wasm",setupFunc:zY,kernelFunc:_Y},Yw;function LY(e){Yw=e.wasm.cwrap(Bs,null,["number","array","number","array","number","number"])}function WY(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,{dims:s}=a,i=k.parseAxisParam(s,r.shape);if(r.shape.length===0)return Nh({inputs:{x:r},backend:n});let o=n.makeOutput(r.shape,r.dtype),l=n.dataIdMap.get(r.dataId).id,d=n.dataIdMap.get(o.dataId).id,u=new Uint8Array(new Int32Array(i).buffer),p=new Uint8Array(new Int32Array(r.shape).buffer);Yw(l,u,i.length,p,r.shape.length,d);let c=xa({inputs:{x:o},attrs:{shape:r.shape},backend:n});return n.disposeData(o.dataId),c}var BY={kernelName:Bs,backendName:"wasm",kernelFunc:WY,setupFunc:LY},Jw;function VY(e){Jw=e.wasm.cwrap(el,null,["number","number","number","number","number","number","number","number","array","number","number"])}function jY(e){let{inputs:t,backend:n,attrs:a}=e,{image:r}=t,{radians:s,fillValue:i,center:o}=a,l=n.makeOutput(r.shape,r.dtype),d=n.dataIdMap.get(r.dataId).id,u=n.dataIdMap.get(l.dataId).id,[p,c,h,m]=r.shape,[f,A]=C.getImageCenter(o,c,h),y=i===0,g=255,x=typeof i=="number"?[i,i,i,y?0:g]:[...i,g],w=new Uint8Array(new Int32Array(x).buffer);return Jw(d,p,c,h,m,s,f,A,w,x.length,u),l}var UY={kernelName:el,backendName:"wasm",kernelFunc:jY,setupFunc:VY},HY=hn(Vs),GY=hn(js),Qw;function qY(e){Qw=e.wasm.cwrap(Bo,null,["number","number","number","number","number","number","array","number","number"])}function XY(e){let{backend:t,inputs:n,attrs:a}=e,{indices:r,updates:s}=n,{shape:i}=a,o=t.makeOutput(i,s.dtype);if(k.sizeFromShape(i)===0)return o;let{sliceRank:l,numUpdates:d,sliceSize:u,strides:p,outputSize:c}=jm.calculateShapes(s,r,i),h=t.dataIdMap.get(r.dataId).id,m=t.dataIdMap.get(s.dataId).id,f=new Uint8Array(new Int32Array(p).buffer),A=t.dataIdMap.get(o.dataId).id;return Qw(h,m,In[s.dtype],l,d,u,f,c,A),o}var KY={kernelName:Bo,backendName:"wasm",setupFunc:qY,kernelFunc:XY},e6;function ZY(e){e6=e.wasm.cwrap("SelectV2",null,["number","number","number","number","number"])}function YY(e){let{inputs:t,backend:n}=e,{condition:a,t:r,e:s}=t,i=n.dataIdMap.get(a.dataId).id,o=n.dataIdMap.get(r.dataId).id,l=n.dataIdMap.get(s.dataId).id,d=n.makeOutput(r.shape,r.dtype),u=n.dataIdMap.get(d.dataId).id,p=a.shape.length,c=r.shape.length,h=p===0||p>1||c===1?1:k.sizeFromShape(r.shape.slice(1));return e6(i,o,l,h,u),d}var JY={kernelName:Vo,backendName:"wasm",kernelFunc:YY,setupFunc:ZY},t6;function QY(e){t6=e.wasm.cwrap(Hs,null,["number","number"])}function eJ(e){let{backend:t,inputs:{x:n}}=e,a=t.dataIdMap.get(n.dataId).id,r=t.makeOutput(n.shape,n.dtype),s=t.dataIdMap.get(r.dataId).id;return k.sizeFromShape(r.shape)===0||t6(a,s),r}var tJ={kernelName:"Sigmoid",backendName:"wasm",setupFunc:QY,kernelFunc:eJ},nJ=hn(Us);function Ch(e){let{inputs:{x:t},attrs:{begin:n,size:a},backend:r}=e,[s,i]=on.parseSliceParams(t,n,a),o=on.isSliceContinous(t.shape,s,i),l=r.readSync(t.dataId),d=r.makeOutput(i,t.dtype),u=k.computeStrides(t.shape),p=r.dataIdMap.get(d.dataId);if(o){let m=on.computeFlatOffset(s,u);return t.dtype==="string"?p.stringBytes=l.slice(m,m+k.sizeFromShape(i)):r.typedArrayFromHeap(d).set(l.subarray(m,m+k.sizeFromShape(i))),d}if(t.dtype==="string"){let m=ah(l,s,i,t.shape,t.dtype);return p.stringBytes=m,d}let c=r.typedArrayFromHeap(d),h=t.shape.length;if(h===2)aJ(l,u[0],c,s,i);else if(h===3)rJ(l,u[0],u[1],c,s,i);else if(h===4)sJ(l,u[0],u[1],u[2],c,s,i);else{let m=ah(l,s,i,t.shape,t.dtype);c.set(m)}return d}function aJ(e,t,n,a,r){let s=0,i=a[0],o=a[1],l=i+r[0];for(let d=i;d{let c=[...u];c[o]=p;let h=Ch({inputs:{x:r},attrs:{begin:d,size:c},backend:a});return d[o]+=p,h})}var pJ={kernelName:Xo,backendName:"wasm",kernelFunc:dJ},cJ=hn(Gs),hJ=hn(Ru),fJ=!0,mJ=fn(Ks,fJ),a6;function AJ(e){a6=e.wasm.cwrap(Sr,null,["number","number","number"])}function yJ(e){let{backend:t,inputs:n,attrs:a}=e,{alpha:r}=a,{x:s}=n,i=t.dataIdMap.get(s.dataId).id,o=t.makeOutput(s.shape,s.dtype),l=t.dataIdMap.get(o.dataId).id;return a6(i,r,l),o}var gJ={kernelName:Sr,backendName:"wasm",setupFunc:AJ,kernelFunc:yJ},r6;function xJ(e){r6=e.wasm.cwrap(Ko,null,["number","array","number","array","array","array","array","array","number","number"])}function bJ(e){let{backend:t,inputs:n,attrs:a}=e,{x:r}=n,{begin:s,end:i,strides:o}=a;o==null&&(o=new Array(s.length));let{beginMask:l,endMask:d,ellipsisMask:u,newAxisMask:p,shrinkAxisMask:c}=a,h=C.slice_util.maskToAxes(u);if(h.length>1)throw new Error("Multiple ellipses in slice is not allowed.");if(u!==0&&p!==0)throw new Error("Using both ellipsisMask and newAxisMask is not yet supported.");if(u!==0&&c!==0)throw new Error("Using both ellipsisMask and shrinkAxisMask is not yet supported.");let m=r.shape.length-s.length,f=C.slice_util.maskToAxes(p),A=r.shape.slice();f.forEach($=>{s[$]=0,i[$]=1,A.splice($,0,1)});let y=xa({inputs:{x:r},attrs:{shape:A},backend:t}),{begin:g,end:x,strides:w}=C.slice_util.getNormalizedAxes(y.shape,h,m,s,i,o,l,d,u);s=g,i=x,o=w;let b=C.slice_util.maskToAxes(c);b.forEach($=>{i[$]=s[$]+1,o[$]=1});let v=C.slice_util.computeOutShape(s,i,o),N=v.filter(($,z)=>b.indexOf(z)===-1);if(o.every($=>$===1)){let $=Ch({inputs:{x:y},attrs:{begin:s,size:v},backend:t});t.disposeData(y.dataId);let z=xa({inputs:{x:$},attrs:{shape:N},backend:t});return t.disposeData($.dataId),z}let T=t.makeOutput(N,"float32");if(!N.some($=>$===0)){let $=t.dataIdMap.get(y.dataId).id,z=new Uint8Array(new Int32Array(k.computeStrides(y.shape)).buffer),P=new Uint8Array(new Int32Array(s).buffer),V=new Uint8Array(new Int32Array(i).buffer),j=new Uint8Array(new Int32Array(o).buffer),U=new Uint8Array(new Int32Array(N).buffer),X=new Uint8Array(new Int32Array(k.computeStrides(N)).buffer),G=t.dataIdMap.get(T.dataId).id;r6($,z,y.shape.length,P,V,j,U,X,N.length,G)}t.disposeData(y.dataId);let R=xa({inputs:{x:T},attrs:{shape:N},backend:t});return t.disposeData(T.dataId),R}var vJ={kernelName:Ko,backendName:"wasm",setupFunc:xJ,kernelFunc:bJ},wJ=!0,kJ=fn(Zs,wJ),s6;function IJ(e){s6=e.wasm.cwrap(qs,null,["number, number, number"])}function SJ(e){let{backend:t,inputs:n,attrs:a}=e,{axis:r,keepDims:s}=a,{x:i}=n,o=t.dataIdMap.get(i.dataId).id,l=o,d=i,{transposed:u,axes:p,originalAxes:c,inputWasTransposed:h}=Wr(i,r,t),m=p;if(h){let x=t.dataIdMap.get(u.dataId).id;x!==o&&(d=u,l=x,m=C.getInnerMostAxes(m.length,d.shape.length))}C.assertAxesAreInnerMostDims("sum",m,d.shape.length);let[f,A]=C.computeOutAndReduceShapes(d.shape,m),y=k.sizeFromShape(A),g=t.makeOutput(f,d.dtype);if(k.sizeFromShape(d.shape)!==0){let x=t.dataIdMap.get(g.dataId).id;s6(l,y,x)}if(h&&t.disposeData(u.dataId),s){let x=C.expandShapeToKeepDim(g.shape,c);g.shape=x}return g}var NJ={kernelName:qs,backendName:"wasm",setupFunc:IJ,kernelFunc:SJ},TJ=hn(Ys),EJ=hn(Js),i6;function CJ(e){i6=e.wasm.cwrap(Ir,null,["number","array","number","array","number","number"])}function RJ(e){let{inputs:t,backend:n,attrs:a}=e,{x:r}=t,s=n.dataIdMap.get(r.dataId).id,{reps:i}=a,o=new Array(r.shape.length);for(let c=0;c{let{x:a}=e,{k:r,sorted:s}=n,i=t.dataIdMap.get(a.dataId).id,o=new Uint8Array(new Int32Array(a.shape).buffer),l=a.shape.slice();l[l.length-1]=r;let d=t.makeOutput(l,a.dtype),u=t.dataIdMap.get(d.dataId).id,p=t.makeOutput(l,"int32"),c=t.dataIdMap.get(p.dataId).id;return o6(i,o,a.shape.length,In[a.dtype],r,s,u,c),[d,p]},DJ={kernelName:Zo,backendName:"wasm",setupFunc:FJ,kernelFunc:$J},l6;function OJ(e){l6=e.wasm.cwrap(Yo,null,["number","number","bool","number","number","number","number","number","number","array","number","number","number","number","number"])}function zJ(e){let{backend:t,inputs:n,attrs:a}=e,{image:r,transforms:s}=n,{interpolation:i,fillMode:o,fillValue:l,outputShape:d}=a,[u,p,c,h]=r.shape,[m,f]=d!=null?d:[p,c],A=[u,m,f,h],y=new Uint8Array(new Int32Array(k.computeStrides(r.shape)).buffer),g=t.makeOutput(A,r.dtype),x=t.dataIdMap.get(g.dataId).id,w=t.dataIdMap.get(r.dataId).id,b=t.dataIdMap.get(s.dataId).id,v=i==="nearest"?1:2,N;switch(o){case"constant":N=1;break;case"reflect":N=2;break;case"wrap":N=3;break;case"nearest":N=4;break;default:N=1;break}return l6(w,b,s.shape[0]>1,u,m,f,h,c,p,y,r.shape.length-1,v,N,l,x),g}var _J={kernelName:Yo,backendName:"wasm",setupFunc:OJ,kernelFunc:zJ};function PJ(e){let{inputs:t,backend:n,attrs:a}=e,{value:r}=t,{axis:s}=a;s<0&&(s+=r.shape.length);let i=r.shape[s],o=r.shape.length,l=new Array(o-1),d=0;for(let h=0;h({dataId:h,dtype:m,shape:l}))}var LJ={kernelName:Jo,backendName:"wasm",kernelFunc:PJ};function WJ(e){let{inputs:{x:t},backend:n}=e,a=n.makeOutput(t.shape,t.dtype);return n.typedArrayFromHeap(a).fill(0),a}var BJ={kernelName:Qo,backendName:"wasm",kernelFunc:WJ},VJ=[XX,ZX,QX,oK,dK,hK,AK,bK,vK,wK,SK,NK,CK,FK,$K,zK,LK,VK,HK,qK,XK,KK,YK,eZ,tZ,aZ,qX,iZ,uZ,cZ,mZ,gZ,bZ,wZ,eK,SZ,TZ,CZ,RZ,FZ,OZ,_Z,WZ,jZ,GZ,XZ,YZ,QZ,eY,aY,iY,uY,pY,fY,AY,gY,vY,kY,NY,CY,MY,$Y,DY,OY,yK,PY,BY,UY,GY,HY,KY,JY,tJ,nJ,iJ,uJ,pJ,cJ,hJ,mJ,gJ,vJ,kJ,NJ,TJ,EJ,MJ,DJ,_J,rK,LJ,BJ];for(let e of VJ)ai(e);var T1=J();T1.registerFlag("WASM_HAS_SIMD_SUPPORT",async()=>WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,2,1,0,10,9,1,7,0,65,0,253,15,26,11])));T1.registerFlag("WASM_HAS_MULTITHREAD_SUPPORT",async()=>{if(T1.get("IS_NODE"))return!1;try{return new MessageChannel().port1.postMessage(new SharedArrayBuffer(1)),WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,2,1,0,5,4,1,3,1,1,10,11,1,9,0,65,0,254,16,2,0,26,11]))}catch(e){return!1}});var u6=Zi(nI()),jJ='var Module={};function threadPrintErr(){var text=Array.prototype.slice.call(arguments).join(" ");console.error(text)}function threadAlert(){var text=Array.prototype.slice.call(arguments).join(" ");postMessage({cmd:"alert",text:text,threadId:Module["_pthread_self"]()})}var err=threadPrintErr;this.alert=threadAlert;Module["instantiateWasm"]=function(info,receiveInstance){var instance=new WebAssembly.Instance(Module["wasmModule"],info);Module["wasmModule"]=null;receiveInstance(instance);return instance.exports};function moduleLoaded(){}this.onmessage=function(e){try{if(e.data.cmd==="load"){Module["wasmModule"]=e.data.wasmModule;Module["wasmMemory"]=e.data.wasmMemory;Module["buffer"]=Module["wasmMemory"].buffer;Module["ENVIRONMENT_IS_PTHREAD"]=true;if(typeof e.data.urlOrBlob==="string"){importScripts(e.data.urlOrBlob)}else{var objectUrl=URL.createObjectURL(e.data.urlOrBlob);importScripts(objectUrl);URL.revokeObjectURL(objectUrl)}WasmBackendModuleThreadedSimd(Module).then(function(instance){Module=instance;moduleLoaded()})}else if(e.data.cmd==="objectTransfer"){Module["PThread"].receiveObjectTransfer(e.data)}else if(e.data.cmd==="run"){Module["__performance_now_clock_drift"]=performance.now()-e.data.time;Module["__emscripten_thread_init"](e.data.threadInfoStruct,0,0);var max=e.data.stackBase;var top=e.data.stackBase+e.data.stackSize;Module["establishStackSpace"](top,max);Module["_emscripten_tls_init"]();Module["PThread"].receiveObjectTransfer(e.data);Module["PThread"].setThreadStatus(Module["_pthread_self"](),1);try{var result=Module["invokeEntryPoint"](e.data.start_routine,e.data.arg);if(!Module["getNoExitRuntime"]())Module["PThread"].threadExit(result)}catch(ex){if(ex==="Canceled!"){Module["PThread"].threadCancel()}else if(ex!="unwind"){if(ex instanceof Module["ExitStatus"]){if(Module["getNoExitRuntime"]()){}else{Module["PThread"].threadExit(ex.status)}}else{Module["PThread"].threadExit(-2);throw ex}}}}else if(e.data.cmd==="cancel"){if(Module["_pthread_self"]()){Module["PThread"].threadCancel()}}else if(e.data.target==="setimmediate"){}else if(e.data.cmd==="processThreadQueue"){if(Module["_pthread_self"]()){Module["_emscripten_current_thread_process_queued_calls"]()}}else{err("worker.js received unknown command "+e.data.cmd);err(e.data)}}catch(ex){err("worker.js onmessage() captured an uncaught exception: "+ex);if(ex&&ex.stack)err(ex.stack);throw ex}};if(typeof process==="object"&&typeof process.versions==="object"&&typeof process.versions.node==="string"){self={location:{href:__filename}};var onmessage=this.onmessage;var nodeWorkerThreads=require("worker_threads");global.Worker=nodeWorkerThreads.Worker;var parentPort=nodeWorkerThreads.parentPort;parentPort.on("message",function(data){onmessage({data:data})});var nodeFS=require("fs");var nodeRead=function(filename){return nodeFS.readFileSync(filename,"utf8")};function globalEval(x){global.require=require;global.Module=Module;eval.call(null,x)}importScripts=function(f){globalEval(nodeRead(f))};postMessage=function(msg){parentPort.postMessage(msg)};if(typeof performance==="undefined"){performance={now:function(){return Date.now()}}}}',UJ=Zi(aI()),d6=class extends hu{constructor(e){super();this.wasm=e,this.dataIdNextNumber=1,this.wasm.tfjs.init(),this.dataIdMap=new Ip(this,tr())}write(e,t,n){let a={id:this.dataIdNextNumber++};return this.move(a,e,t,n,1),a}numDataIds(){return this.dataIdMap.numDataIds()}async time(e){let t=k.now();return e(),{kernelMs:k.now()-t}}move(e,t,n,a,r){let s=this.dataIdNextNumber++;if(a==="string"){let d=t;this.dataIdMap.set(e,{id:s,stringBytes:d,shape:n,dtype:a,memoryOffset:null,refCount:r});return}let i=k.sizeFromShape(n),o=i*k.bytesPerElement(a),l=this.wasm._malloc(o);this.dataIdMap.set(e,{id:s,memoryOffset:l,shape:n,dtype:a,refCount:r}),this.wasm.tfjs.registerTensor(s,i,l),t!=null&&this.wasm.HEAPU8.set(new Uint8Array(t.buffer,t.byteOffset,o),l)}async read(e){return this.readSync(e)}readSync(e){let{memoryOffset:t,dtype:n,shape:a,stringBytes:r}=this.dataIdMap.get(e);if(n==="string")return r;let s=this.wasm.HEAPU8.slice(t,t+k.sizeFromShape(a)*k.bytesPerElement(n));return HJ(s.buffer,n)}disposeData(e,t=!1){if(this.dataIdMap.has(e)){let n=this.dataIdMap.get(e);if(n.refCount--,!t&&n.refCount>0)return!1;this.wasm._free(n.memoryOffset),this.wasm.tfjs.disposeData(n.id),this.dataIdMap.delete(e)}return!0}refCount(e){return this.dataIdMap.has(e)?this.dataIdMap.get(e).refCount:0}incRef(e){let t=this.dataIdMap.get(e);t!=null&&t.refCount++}floatPrecision(){return 32}getMemoryOffset(e){return this.dataIdMap.get(e).memoryOffset}dispose(){this.wasm.tfjs.dispose(),"PThread"in this.wasm&&this.wasm.PThread.terminateAllThreads(),this.wasm=null}memory(){return{unreliable:!1}}makeOutput(e,t,n){let a;if(n==null)a=this.write(null,e,t);else{let r=this.dataIdNextNumber++;a={id:r},this.dataIdMap.set(a,{id:r,memoryOffset:n,shape:e,dtype:t,refCount:1});let s=k.sizeFromShape(e);this.wasm.tfjs.registerTensor(r,s,n)}return{dataId:a,shape:e,dtype:t}}typedArrayFromHeap({shape:e,dtype:t,dataId:n}){let a=this.wasm.HEAPU8.buffer,{memoryOffset:r}=this.dataIdMap.get(n),s=k.sizeFromShape(e);switch(t){case"float32":return new Float32Array(a,r,s);case"int32":return new Int32Array(a,r,s);case"bool":return new Uint8Array(a,r,s);default:throw new Error(`Unknown dtype ${t}`)}}};function GJ(e){return(t,n)=>(k.fetch(e,{credentials:"same-origin"}).then(a=>{a.ok||t.env.a(`failed to load wasm binary file at '${e}'`),a.arrayBuffer().then(r=>{WebAssembly.instantiate(r,t).then(s=>{n(s.instance,s.module)})})}),{})}function p6(e,t,n){if(Rh!=null)return Rh;let a="tfjs-backend-wasm.wasm";return e&&t?a="tfjs-backend-wasm-threaded-simd.wasm":e&&(a="tfjs-backend-wasm-simd.wasm"),vd!=null&&vd[a]!=null?vd[a]:n+a}async function qJ(){let[e,t]=await Promise.all([J().getAsync("WASM_HAS_SIMD_SUPPORT"),J().getAsync("WASM_HAS_MULTITHREAD_SUPPORT")]);return new Promise((n,a)=>{let r={};r.locateFile=(o,l)=>{if(o.endsWith(".worker.js")){let d=jJ,u=new Blob([d],{type:"application/javascript"});return URL.createObjectURL(u)}return o.endsWith(".wasm")?p6(e,t,wd!=null?wd:l):l+o},E1&&(r.instantiateWasm=GJ(p6(e,t,wd!=null?wd:"")));let s=!1;r.onAbort=()=>{s||kd||(kd=!0,a({message:"Make sure the server can serve the `.wasm` file relative to the bundled js file. For more details see https://github.com/tensorflow/tfjs/blob/master/tfjs-backend-wasm/README.md#using-bundlers"}))};let i;t&&e&&Rh==null?(r.mainScriptUrlOrBlob=new Blob(["var WasmBackendModuleThreadedSimd = "+u6.default.toString()],{type:"text/javascript"}),i=(0,u6.default)(r)):i=(0,UJ.default)(r),i.then(o=>{s=!0,kd=!1;let l=null;o.tfjs={init:o.cwrap("init",null,[]),registerTensor:o.cwrap("register_tensor",null,["number","number","number"]),disposeData:o.cwrap("dispose_data",l,["number"]),dispose:o.cwrap("dispose",l,[])},n({wasm:o})})})}function HJ(e,t){switch(t){case"float32":return new Float32Array(e);case"int32":return new Int32Array(e);case"bool":return new Uint8Array(e);default:throw new Error(`Unknown dtype ${t}`)}}var XJ=["tfjs-backend-wasm.wasm","tfjs-backend-wasm-simd.wasm","tfjs-backend-wasm-threaded-simd.wasm"],Rh=null,wd=null,vd={},kd=!1,E1=!1;function KJ(e,t=!1){if(Km("setWasmPath has been deprecated in favor of setWasmPaths and will be removed in a future release."),kd)throw new Error("The WASM backend was already initialized. Make sure you call `setWasmPath()` before you call `tf.setBackend()` or `tf.ready()`");Rh=e,E1=t}function ZJ(e,t=!1){if(kd)throw new Error("The WASM backend was already initialized. Make sure you call `setWasmPaths()` before you call `tf.setBackend()` or `tf.ready()`");if(typeof e=="string")wd=e;else{vd=e;let n=XJ.filter(a=>vd[a]==null);if(n.length>0)throw new Error(`There were no entries found for the following binaries: ${n.join(",")}. Please either call setWasmPaths with a map providing a path for each binary, or with a string indicating the directory where all the binaries can be found.`)}E1=t}var c6="3.6.0",YJ=2;ul("wasm",async()=>{let{wasm:e}=await qJ();return new d6(e)},YJ);Z().prototype.abs=function(){return this.throwIfDisposed(),Ot(this)};Z().prototype.acos=function(){return this.throwIfDisposed(),Ym(this)};Z().prototype.acosh=function(){return this.throwIfDisposed(),Jm(this)};Z().prototype.add=function(e){return this.throwIfDisposed(),se(this,e)};Z().prototype.all=function(e,t){return this.throwIfDisposed(),gc(this,e,t)};Z().prototype.any=function(e,t){return this.throwIfDisposed(),ju(this,e,t)};Z().prototype.argMax=function(e){return this.throwIfDisposed(),Uu(this,e)};Z().prototype.argMin=function(e){return this.throwIfDisposed(),Qm(this,e)};Z().prototype.asScalar=function(){return this.throwIfDisposed(),F(this.size===1,()=>"The array must have only 1 element."),H(this,[])};Z().prototype.asType=function(e){return this.throwIfDisposed(),fe(this,e)};Z().prototype.as1D=function(){return this.throwIfDisposed(),H(this,[this.size])};Z().prototype.as2D=function(e,t){return this.throwIfDisposed(),H(this,[e,t])};Z().prototype.as3D=function(e,t,n){return this.throwIfDisposed(),H(this,[e,t,n])};Z().prototype.as4D=function(e,t,n,a){return this.throwIfDisposed(),H(this,[e,t,n,a])};Z().prototype.as5D=function(e,t,n,a,r){return this.throwIfDisposed(),H(this,[e,t,n,a,r])};Z().prototype.asin=function(){return this.throwIfDisposed(),eA(this)};Z().prototype.asinh=function(){return this.throwIfDisposed(),tA(this)};Z().prototype.atan=function(){return this.throwIfDisposed(),nA(this)};Z().prototype.atan2=function(e){return this.throwIfDisposed(),aA(this,e)};Z().prototype.atanh=function(){return this.throwIfDisposed(),rA(this)};Z().prototype.avgPool=function(e,t,n,a){return this.throwIfDisposed(),Gu(this,e,t,n,a)};Z().prototype.batchToSpaceND=function(e,t){return this.throwIfDisposed(),qu(this,e,t)};Z().prototype.batchNorm=function(e,t,n,a,r){return this.throwIfDisposed(),pi(this,e,t,n,a,r)};Z().prototype.broadcastTo=function(e){return this.throwIfDisposed(),pl(this,e)};Z().prototype.cast=function(e){return this.throwIfDisposed(),fe(this,e)};Z().prototype.ceil=function(){return this.throwIfDisposed(),uA(this)};Z().prototype.clipByValue=function(e,t){return this.throwIfDisposed(),kn(this,e,t)};Z().prototype.concat=function(e,t){return this.throwIfDisposed(),e instanceof Le&&(e=[e]),ot([this,...e],t)};Z().prototype.conv1d=function(e,t,n,a,r,s){return this.throwIfDisposed(),bc(this,e,t,n,a,r,s)};Z().prototype.conv2dTranspose=function(e,t,n,a,r){return this.throwIfDisposed(),vc(this,e,t,n,a,r)};Z().prototype.conv2d=function(e,t,n,a,r,s){return this.throwIfDisposed(),nr(this,e,t,n,a,r,s)};Z().prototype.cos=function(){return this.throwIfDisposed(),Xu(this)};Z().prototype.cosh=function(){return this.throwIfDisposed(),wc(this)};Z().prototype.cumsum=function(e,t,n){return this.throwIfDisposed(),kc(this,e,t,n)};Z().prototype.depthToSpace=function(e,t){return this.throwIfDisposed(),cA(this,e,t)};Z().prototype.depthwiseConv2d=function(e,t,n,a,r,s){return this.throwIfDisposed(),hl(this,e,t,n,a,r,s)};Z().prototype.dilation2d=function(e,t,n,a,r){return this.throwIfDisposed(),hA(this,e,t,n,a,r)};Z().prototype.divNoNan=function(e){return this.throwIfDisposed(),fA(this,e)};Z().prototype.div=function(e){return this.throwIfDisposed(),me(this,e)};Z().prototype.dot=function(e){return this.throwIfDisposed(),zb(this,e)};Z().prototype.elu=function(){return this.throwIfDisposed(),fl(this)};Z().prototype.equal=function(e){return this.throwIfDisposed(),Mr(this,e)};Z().prototype.erf=function(){return this.throwIfDisposed(),mA(this)};Z().prototype.exp=function(){return this.throwIfDisposed(),qn(this)};Z().prototype.expandDims=function(e){return this.throwIfDisposed(),ln(this,e)};Z().prototype.expm1=function(){return this.throwIfDisposed(),AA(this)};Z().prototype.fft=function(){return this.throwIfDisposed(),ad(this)};Z().prototype.flatten=function(){return this.throwIfDisposed(),H(this,[this.size])};Z().prototype.floor=function(){return this.throwIfDisposed(),Al(this)};Z().prototype.floorDiv=function(e){return this.throwIfDisposed(),Ac(this,e)};Z().prototype.gather=function(e,t){return this.throwIfDisposed(),ci(this,e,t)};Z().prototype.greaterEqual=function(e){return this.throwIfDisposed(),$r(this,e)};Z().prototype.greater=function(e){return this.throwIfDisposed(),Mn(this,e)};Z().prototype.ifft=function(){return this.throwIfDisposed(),vl(this)};Z().prototype.irfft=function(){return this.throwIfDisposed(),Wc(this)};Z().prototype.isFinite=function(){return this.throwIfDisposed(),Pb(this)};Z().prototype.isInf=function(){return this.throwIfDisposed(),Lb(this)};Z().prototype.isNaN=function(){return this.throwIfDisposed(),gA(this)};Z().prototype.leakyRelu=function(e){return this.throwIfDisposed(),Ku(this,e)};Z().prototype.lessEqual=function(e){return this.throwIfDisposed(),Dr(this,e)};Z().prototype.less=function(e){return this.throwIfDisposed(),Sc(this,e)};Z().prototype.localResponseNormalization=function(e,t,n,a){return this.throwIfDisposed(),xA(this,e,t,n,a)};Z().prototype.logSigmoid=function(){return this.throwIfDisposed(),Vb(this)};Z().prototype.logSoftmax=function(e){return this.throwIfDisposed(),Ec(this,e)};Z().prototype.logSumExp=function(e,t){return this.throwIfDisposed(),wA(this,e,t)};Z().prototype.log=function(){return this.throwIfDisposed(),Fn(this)};Z().prototype.log1p=function(){return this.throwIfDisposed(),Nc(this)};Z().prototype.logicalAnd=function(e){return this.throwIfDisposed(),oa(this,e)};Z().prototype.logicalNot=function(){return this.throwIfDisposed(),Zu(this)};Z().prototype.logicalOr=function(e){return this.throwIfDisposed(),Cc(this,e)};Z().prototype.logicalXor=function(e){return this.throwIfDisposed(),Gb(this,e)};Z().prototype.matMul=function(e,t,n){return this.throwIfDisposed(),Be(this,e,t,n)};Z().prototype.maxPool=function(e,t,n,a){return this.throwIfDisposed(),Yu(this,e,t,n,a)};Z().prototype.max=function(e,t){return this.throwIfDisposed(),Xn(this,e,t)};Z().prototype.maximum=function(e){return this.throwIfDisposed(),_a(this,e)};Z().prototype.mean=function(e,t){return this.throwIfDisposed(),wt(this,e,t)};Z().prototype.min=function(e,t){return this.throwIfDisposed(),yl(this,e,t)};Z().prototype.minimum=function(e){return this.throwIfDisposed(),gl(this,e)};Z().prototype.mirrorPad=function(e,t){return this.throwIfDisposed(),IA(this,e,t)};Z().prototype.mod=function(e){return this.throwIfDisposed(),SA(this,e)};Z().prototype.mul=function(e){return this.throwIfDisposed(),_(this,e)};Z().prototype.neg=function(){return this.throwIfDisposed(),vt(this)};Z().prototype.norm=function(e,t,n){return this.throwIfDisposed(),Uc(this,e,t,n)};Z().prototype.notEqual=function(e){return this.throwIfDisposed(),mi(this,e)};Z().prototype.oneHot=function(e,t=1,n=0){return this.throwIfDisposed(),ol(this,e,t,n)};Z().prototype.onesLike=function(){return this.throwIfDisposed(),Dn(this)};Z().prototype.pad=function(e,t){return this.throwIfDisposed(),ar(this,e,t)};Z().prototype.pool=function(e,t,n,a,r){return this.throwIfDisposed(),Kb(this,e,t,n,a,r)};Z().prototype.pow=function(e){return this.throwIfDisposed(),rr(this,e)};Z().prototype.prelu=function(e){return this.throwIfDisposed(),Qu(this,e)};Z().prototype.prod=function(e,t){return this.throwIfDisposed(),Mc(this,e,t)};Z().prototype.reciprocal=function(){return this.throwIfDisposed(),EA(this)};Z().prototype.relu=function(){return this.throwIfDisposed(),Pa(this)};Z().prototype.relu6=function(){return this.throwIfDisposed(),Fc(this)};Z().prototype.reshapeAs=function(e){return this.throwIfDisposed(),H(this,e.shape)};Z().prototype.reshape=function(e){return this.throwIfDisposed(),H(this,e)};Z().prototype.resizeBilinear=function(e,t,n){return this.throwIfDisposed(),h3(this,e,t,n)};Z().prototype.resizeNearestNeighbor=function(e,t,n){return this.throwIfDisposed(),f3(this,e,t,n)};Z().prototype.reverse=function(e){return this.throwIfDisposed(),On(this,e)};Z().prototype.rfft=function(){return this.throwIfDisposed(),rd(this)};Z().prototype.round=function(){return this.throwIfDisposed(),$c(this)};Z().prototype.rsqrt=function(){return this.throwIfDisposed(),Dc(this)};Z().prototype.selu=function(){return this.throwIfDisposed(),Oc(this)};Z().prototype.separableConv2d=function(e,t,n,a,r,s){return this.throwIfDisposed(),CA(this,e,t,n,a,r,s)};Z().prototype.sigmoid=function(){return this.throwIfDisposed(),wn(this)};Z().prototype.sign=function(){return this.throwIfDisposed(),RA(this)};Z().prototype.sin=function(){return this.throwIfDisposed(),zc(this)};Z().prototype.sinh=function(){return this.throwIfDisposed(),_c(this)};Z().prototype.slice=function(e,t){return this.throwIfDisposed(),Re(this,e,t)};Z().prototype.softmax=function(e){return this.throwIfDisposed(),nd(this,e)};Z().prototype.softplus=function(){return this.throwIfDisposed(),hi(this)};Z().prototype.spaceToBatchND=function(e,t){return this.throwIfDisposed(),Ju(this,e,t)};Z().prototype.split=function(e,t){return this.throwIfDisposed(),an(this,e,t)};Z().prototype.sqrt=function(){return this.throwIfDisposed(),Jt(this)};Z().prototype.square=function(){return this.throwIfDisposed(),st(this)};Z().prototype.squaredDifference=function(e){return this.throwIfDisposed(),Bc(this,e)};Z().prototype.squeeze=function(e){return this.throwIfDisposed(),Or(this,e)};Z().prototype.stack=function(e,t){this.throwIfDisposed();let n=e instanceof Le?[this,e]:[this,...e];return zn(n,t)};Z().prototype.step=function(e){return this.throwIfDisposed(),wl(this,e)};Z().prototype.stridedSlice=function(e,t,n,a,r,s,i,o){return this.throwIfDisposed(),FA(this,e,t,n,a,r,s,i,o)};Z().prototype.sub=function(e){return this.throwIfDisposed(),ge(this,e)};Z().prototype.sum=function(e,t){return this.throwIfDisposed(),ke(this,e,t)};Z().prototype.tan=function(){return this.throwIfDisposed(),$A(this)};Z().prototype.tanh=function(){return this.throwIfDisposed(),di(this)};Z().prototype.tile=function(e){return this.throwIfDisposed(),Fr(this,e)};Z().prototype.toBool=function(){return this.throwIfDisposed(),fe(this,"bool")};Z().prototype.toFloat=function(){return this.throwIfDisposed(),fe(this,"float32")};Z().prototype.toInt=function(){return this.throwIfDisposed(),fe(this,"int32")};Z().prototype.topk=function(e,t){return this.throwIfDisposed(),DA(this,e,t)};Z().prototype.transpose=function(e){return this.throwIfDisposed(),Ze(this,e)};Z().prototype.unique=function(e){return this.throwIfDisposed(),jc(this,e)};Z().prototype.unsortedSegmentSum=function(e,t){return this.throwIfDisposed(),OA(this,e,t)};Z().prototype.unstack=function(e){return this.throwIfDisposed(),la(this,e)};Z().prototype.where=function(e,t){return this.throwIfDisposed(),nn(e,this,t)};Z().prototype.zerosLike=function(){return this.throwIfDisposed(),Ue(this)};var h6={kernelName:Qi,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(e,wl(fe(n,"float32"),-1))}}},JJ={kernelName:eo,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>{let a=st(fe(n,"float32")),r=Jt(ge(Se(1),a));return vt(me(e,r))}}}},QJ={kernelName:to,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>{let a=Jt(ge(st(fe(n,"float32")),1));return me(e,a)}}}},eQ={kernelName:wr,inputsToSave:["a","b"],gradFunc:(e,t)=>{let[n,a]=t,r=pt(n.shape,a.shape);return{a:()=>{let s=e,i=zt(n.shape,r);return i.length>0&&(s=ke(s,i)),H(s,n.shape)},b:()=>{let s=e,i=zt(a.shape,r);return i.length>0&&(s=ke(s,i)),H(s,a.shape)}}}},tQ={kernelName:is,saveAllInputs:!0,gradFunc:(e,t)=>{let n={};return t.forEach((a,r)=>{n[r]=()=>e.clone()}),n}},nQ={kernelName:os,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>Ue(n)}}},aQ={kernelName:Au,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>Ue(n)}}},rQ={kernelName:ro,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>me(e,Jt(ge(Se(1),st(fe(n,"float32")))))}}},sQ={kernelName:so,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>{let a=Jt(se(Se(1),st(fe(n,"float32"))));return me(e,a)}}}},iQ={kernelName:lo,inputsToSave:["a","b"],gradFunc:(e,t)=>{let[n,a]=t,r=pt(n.shape,a.shape);return{a:()=>{let s=se(st(n),st(a)),i=_(e,me(a,s)),o=zt(n.shape,r);return o.length>0&&(i=ke(i,o)),H(i,n.shape)},b:()=>{let s=se(st(n),st(a)),i=vt(_(e,me(n,s))),o=zt(a.shape,r);return o.length>0&&(i=ke(i,o)),H(i,a.shape)}}}},oQ={kernelName:io,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>me(e,se(st(fe(n,"float32")),1))}}},lQ={kernelName:oo,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>me(e,ge(Se(1),st(fe(n,"float32"))))}}};function uQ(e,t,n,a,r,s){let i=M(e,"dy","avgPool3dGrad"),o=M(t,"input","avgPool3dGrad"),l=i,d=o,u=!1;o.rank===4&&(u=!0,l=H(i,[1,i.shape[0],i.shape[1],i.shape[2],i.shape[3]]),d=H(o,[1,o.shape[0],o.shape[1],o.shape[2],o.shape[3]])),F(l.rank===5,()=>`Error in avgPool3dGrad: dy must be rank 5 but got rank ${l.rank}.`),F(d.rank===5,()=>`Error in avgPool3dGrad: input must be rank 5 but got rank ${d.rank}.`),s!=null&&F(Vt(r),()=>`Error in avgPool3dGrad: pad must be an integer when using, dimRoundingMode ${s} but got pad ${r}.`);let p={dy:l,input:d},c={filterSize:n,strides:a,pad:r,dimRoundingMode:s},h=D.runKernel(Cp,p,c);return u?H(h,[h.shape[1],h.shape[2],h.shape[3],h.shape[4]]):h}var dQ=O({avgPool3dGrad_:uQ}),pQ={kernelName:yu,inputsToSave:["x"],gradFunc:(e,t,n)=>{let[a]=t,{filterSize:r,strides:s,pad:i,dimRoundingMode:o}=n;return{x:()=>dQ(e,a,r,s,i,o)}}};function cQ(e,t,n,a,r){let s=M(e,"dy","avgPoolGrad"),i=M(t,"input","avgPoolGrad");F(i.rank===s.rank,()=>`Rank of input (${i.rank}) does not match rank of dy (${s.rank})`);let o=i,l=s,d=!1;i.rank===3&&(d=!0,o=H(i,[1,i.shape[0],i.shape[1],i.shape[2]]),l=H(s,[1,s.shape[0],s.shape[1],s.shape[2]])),F(l.rank===4,()=>`Error in avgPoolGrad: dy must be rank 4 but got rank ${l.rank}.`),F(o.rank===4,()=>`Error in avgPoolGrad: input must be rank 4 but got rank ${o.rank}.`);let u={dy:l,input:o},p={filterSize:n,strides:a,pad:r},c=D.runKernel(Ep,u,p);return d?H(c,[c.shape[1],c.shape[2],c.shape[3]]):c}var hQ=O({avgPoolGrad_:cQ}),fQ={kernelName:ls,inputsToSave:["x"],gradFunc:(e,t,n)=>{let[a]=t,{filterSize:r,strides:s,pad:i}=n;return{x:()=>hQ(e,a,r,s,i)}}},mQ={kernelName:us,inputsToSave:["a","b"],gradFunc:(e,t,n)=>{let[a,r]=t,{transposeA:s,transposeB:i}=n;return!s&&!i?{a:()=>Be(e,r,!1,!0),b:()=>Be(a,e,!0,!1)}:!s&&i?{a:()=>Be(e,r,!1,!1),b:()=>Be(e,a,!0,!1)}:s&&!i?{a:()=>Be(r,e,!1,!0),b:()=>Be(a,e,!1,!1)}:{a:()=>Be(r,e,!0,!0),b:()=>Be(e,a,!0,!0)}}},AQ={kernelName:gu,gradFunc:(e,t,n)=>{let{blockShape:a,crops:r}=n;return{x:()=>Ju(e,a,r)}}},yQ={kernelName:Rx,gradFunc:(e,t,n)=>{let a=n,r=a.inputShape,s=a.shape,i=Array.from(s);for(let l=r.length-1;l>=0;l--)if(r[l]===s[l])i[l]=1;else if(r[l]!==1)throw new Error(`broadcastTo(): [${r}] cannot be broadcast to [${s}].`);let o=[];for(let l=0;l1&&o.push(l);return{x:()=>ke(e,o,!0)}}},gQ={kernelName:ds,gradFunc:e=>({x:()=>e.clone()})},xQ={kernelName:ps,gradFunc:e=>({x:()=>Ue(e)})},bQ={kernelName:kr,inputsToSave:["x"],gradFunc:(e,t,n)=>{let[a]=t,{clipValueMin:r,clipValueMax:s}=n;return{x:()=>nn(oa($r(a,r),Dr(a,s)),e,Ue(e))}}},vQ={kernelName:xu,inputsToSave:["x"],gradFunc:h6.gradFunc},wQ={kernelName:uo,saveAllInputs:!0,gradFunc:(e,t,n)=>{let a=t.map(o=>o.shape),{axis:r}=n,s=ra(r,t[0].shape)[0],i=a.map(o=>o[s]);return an(e,i,s).map(o=>()=>o)}},kQ={kernelName:cs,inputsToSave:["x","filter"],gradFunc:(e,t,n)=>{let[a,r]=t,{dilations:s,strides:i,pad:o,dataFormat:l}=n;return F(Rr(s),()=>`Error in gradient of conv2D: dilation rates greater than 1 are not yet supported in gradients. Got dilations '${s}'`),{x:()=>dA(a.shape,e,r,i,o,l),filter:()=>LA(a,e,r.shape,i,o,l)}}},IQ={kernelName:hs,inputsToSave:["dy","filter"],gradFunc:(e,t,n)=>{let[a,r]=t,{strides:s,pad:i,dataFormat:o,dimRoundingMode:l}=n;return{dy:()=>nr(e,r,s,i,o,1,l),filter:()=>LA(e,a,r.shape,s,i,o,l)}}};function SQ(e,t,n,a,r){let s=e;e.rank===4&&(s=H(e,[1,e.shape[0],e.shape[1],e.shape[2],e.shape[3]]));let i=t;i.rank===4&&(i=H(t,[1,t.shape[0],t.shape[1],t.shape[2],t.shape[3]])),F(s.rank===5,()=>`Error in conv3dDerFilter: input must be rank 5, but got shape ${s.shape}.`),F(i.rank===5,()=>`Error in conv3dDerFilter: dy must be rank 5, but got shape ${i.shape}.`),F(n.length===5,()=>`Error in conv3dDerFilter: filterShape must be length 5, but got ${n}.`),F(s.shape[4]===n[3],()=>`Error in conv3dDerFilter: depth of input ${s.shape[4]}) must match input depth in filter (${n[3]}.`),F(i.shape[4]===n[4],()=>`Error in conv3dDerFilter: depth of dy (${i.shape[4]}) must match output depth for filter (${n[4]}).`);let o={x:s,dy:i},l={strides:a,pad:r,filterShape:n};return D.runKernel($p,o,l)}var NQ=O({conv3DBackpropFilter_:SQ}),TQ={kernelName:bu,inputsToSave:["x","filter"],gradFunc:(e,t,n)=>{let{dilations:a,strides:r,pad:s}=n;F(Rr(a),()=>`Error in gradient of conv3D: dilation rates greater than 1 are not yet supported in gradients. Got dilations '${a}'`);let[i,o]=t;return{x:()=>$b(i.shape,e,o,r,s),filter:()=>NQ(i,e,o.shape,r,s)}}},EQ={kernelName:fs,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(vt(zc(fe(n,"float32"))),e)}}},CQ={kernelName:po,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(_c(fe(n,"float32")),e)}}},RQ={kernelName:ms,inputsToSave:["x"],gradFunc:(e,t,n)=>{let[a]=t,{axis:r,exclusive:s,reverse:i}=n;return{x:()=>{let o=Hb([r],a.rank),l=kc(e,r,s,!i);return o!=null&&(l=Ze(l,o)),l}}}},MQ={kernelName:As,inputsToSave:["x","filter"],gradFunc:(e,t,n)=>{let{dilations:a,strides:r,pad:s,dimRoundingMode:i}=n,o=a==null?[1,1]:a;F(Rr(o),()=>`Error in gradient of depthwiseConv2dNative: dilation rates greater than 1 are not yet supported. Got dilations '${o}'`);let[l,d]=t;return F(l.rank===4,()=>`Error in gradient of depthwiseConv2dNative: input must be rank 4, but got rank ${l.rank}.`),F(d.rank===4,()=>`Error in gradient of depthwiseConv2dNative: filter must be rank 4, but got rank ${d.rank}.`),F(l.shape[3]===d.shape[2],()=>`Error in gradient of depthwiseConv2d: number of input channels (${l.shape[3]}) must match the inChannels dimension in filter ${d.shape[2]}.`),F(Oa(r,o),()=>`Error in gradient of depthwiseConv2d: Either strides or dilations must be 1. Got strides ${r} and dilations '${o}'.`),i!=null&&F(Vt(s),()=>`Error in depthwiseConv2d: pad must be an integer when using, dimRoundingMode ${i} but got pad ${s}.`),{x:()=>i3(l.shape,e,d,r,s,a,i),filter:()=>s3(l,e,d.shape,r,s,a,i)}}},FQ={kernelName:vu,inputsToSave:["x","filter"],gradFunc:(e,t,n)=>{let[a,r]=t,s={x:a,filter:r,dy:e},i={x:a,filter:r,dy:e};return{x:()=>D.runKernel(Lp,s,n),filter:()=>D.runKernel(Wp,i,n)}}},$Q={kernelName:fo,outputsToSave:[!0],gradFunc:(e,t)=>{let[n]=t,a={dy:e,y:n};return{x:()=>D.runKernel(Vp,a)}}},DQ={kernelName:mo,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t,a=_(qn(vt(st(n))),2/Math.sqrt(Math.PI));return{x:()=>_(e,a)}}},OQ={kernelName:gs,outputsToSave:[!0],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(e,n)}}},zQ={kernelName:yo,inputsToSave:["input"],gradFunc:(e,t)=>{let[n]=t;return{input:()=>H(e,n.shape)}}},_Q={kernelName:go,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(e,qn(n))}}},PQ={kernelName:xs,gradFunc:e=>({x:()=>Ue(e)})},LQ={kernelName:bs,inputsToSave:["a","b"],gradFunc:(e,t)=>{let[n,a]=t,r=pt(n.shape,a.shape);return{a:()=>{let s=me(e,fe(a,"float32")),i=zt(n.shape,r);return i.length>0?H(ke(s,i),n.shape):s},b:()=>{let s=_(e,fe(n,"float32")),i=zt(a.shape,r);i.length>0&&(s=H(ke(s,i),a.shape));let o=st(a);return vt(me(s,fe(o,"float32")))}}}},WQ={kernelName:vs,inputsToSave:["x","mean","variance","scale"],gradFunc:(e,t,n)=>{let{varianceEpsilon:a}=n,[r,s,i,o]=t,l=o==null?Se(1):o,d=zt(s.shape,r.shape),u=[];if(s.rank===1){for(let f=0;fs.rank===1?H(_(_(e,Fr(H(h,[1,1,1,s.shape[0]]),u)),l),r.shape):H(_(_(e,h),l),r.shape),mean:()=>{let f=_(_(h,Se(-1)),c);return s.rank===1&&(f=ke(f,d)),H(f,s.shape)},variance:()=>{let f=_(_(m,p),c);return s.rank===1&&(f=ke(f,d)),H(f,s.shape)},scale:()=>{let f=_(p,h),A=_(e,f);return s.rank===1&&(A=ke(A,d)),H(A,s.shape)},offset:()=>{let f=e;return s.rank===1&&(f=ke(f,d)),H(f,s.shape)}}}},BQ={kernelName:bo,inputsToSave:["x","indices"],gradFunc:(e,t,n)=>{let[a,r]=t,{axis:s}=n,i=ra(s,a.shape)[0];return{x:()=>{let o=a.shape,l=r.size,d=o.slice(0,i),u=d.length,p=o.slice(s,o.length).slice(1),c=p.length,h=f6(0,u),m=f6(u+1,u+1+c),f=m6([d,[l],p]),A=H(e,f),y=H(r,[l]),g=m6([[u],h,m]),x=Ze(A,g),w=OA(x,y,a.shape[i]),b=vA(g);return w=Ze(w,b),w},indices:()=>r}}};function f6(e,t){let n=[];for(let a=e;a{let[n,a]=t;return{a:()=>Ue(n),b:()=>Ue(a)}}},jQ={kernelName:ks,gradFunc:e=>({x:()=>fe(e,"float32")})},UQ={kernelName:ko,gradFunc:e=>({x:()=>Ue(e)})},HQ={kernelName:Io,gradFunc:e=>({x:()=>Ue(e)})},GQ={kernelName:So,gradFunc:e=>({x:()=>Ue(e)})},qQ={kernelName:Is,inputsToSave:["x"],gradFunc:(e,t,n)=>{let[a]=t,{alpha:r}=n,s=Mn(a,0);return{x:()=>nn(s,e,_(e,r))}}},XQ={kernelName:Eo,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>me(e,se(n,1))}}},KQ={kernelName:Ss,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>me(e,fe(n,"float32"))}}},ZQ={kernelName:Mx,inputsToSave:[],outputsToSave:[!0],gradFunc:(e,t,n)=>{let[a]=t,{axis:r}=n;return{logits:()=>{let s=!0,i=qn(a);return ge(e,_(ke(e,r,s),i))}}}};function YQ(e,t,n,a=5,r=1,s=1,i=.5){let o={x:e,y:t,dy:n},l={depthRadius:a,bias:r,alpha:s,beta:i};return D.runKernel(qp,o,l)}var JQ=O({localResponseNormalizationBackprop_:YQ}),QQ={kernelName:Su,inputsToSave:["x"],outputsToSave:[!0],gradFunc:(e,t,n)=>{let[a,r]=t,{depthRadius:s,bias:i,alpha:o,beta:l}=n;return{x:()=>JQ(a,r,e,s,i,o,l)}}};function A6(e,t,n,a){return t.rank_(e,fe(Mr(n,t),e.dtype))}}var y6={kernelName:Ns,inputsToSave:["x"],outputsToSave:[!0],gradFunc:(e,t,n)=>{let a=n,{reductionIndices:r}=a,s=t[0],i=t[1],o=ra(r,s.shape),l=A6(e,i,s,o);return{x:()=>l.x()}}},eee={kernelName:Ts,inputsToSave:["a","b"],gradFunc:(e,t)=>{let[n,a]=t;return{a:()=>_(e,fe($r(n,a),"float32")),b:()=>_(e,fe(Sc(n,a),"float32"))}}};function tee(e,t,n,a,r,s,i){let o=M(e,"dy","maxPool3dGrad"),l=M(t,"input","maxPool3dGrad"),d=M(n,"output","maxPool3dGrad"),u=o,p=l,c=d,h=!1;l.rank===4&&(h=!0,u=H(o,[1,o.shape[0],o.shape[1],o.shape[2],o.shape[3]]),p=H(l,[1,l.shape[0],l.shape[1],l.shape[2],l.shape[3]]),c=H(d,[1,d.shape[0],d.shape[1],d.shape[2],d.shape[3]])),F(u.rank===5,()=>`Error in maxPool3dGrad: dy must be rank 5 but got rank ${u.rank}.`),F(p.rank===5,()=>`Error in maxPool3dGrad: input must be rank 5 but got rank ${p.rank}.`),F(c.rank===5,()=>`Error in maxPool3dGrad: output must be rank 5 but got rank ${c.rank}.`),i!=null&&F(Vt(s),()=>`Error in maxPool3dGrad: pad must be an integer when using, dimRoundingMode ${i} but got pad ${s}.`);let m={dy:u,input:p,output:c},f={filterSize:a,strides:r,pad:s,dimRoundingMode:i},A=D.runKernel(Kp,m,f);return h?H(A,[A.shape[1],A.shape[2],A.shape[3],A.shape[4]]):A}var nee=O({maxPool3dGrad_:tee}),aee={kernelName:Nu,inputsToSave:["x"],outputsToSave:[!0],gradFunc:(e,t,n)=>{let[a,r]=t,{filterSize:s,strides:i,pad:o,dimRoundingMode:l}=n;return{x:()=>nee(e,a,r,s,i,o,l)}}};function ree(e,t,n,a,r,s,i){let o=M(e,"dy","maxPoolGrad"),l=M(t,"input","maxPoolGrad"),d=M(n,"output","maxPoolGrad");F(l.rank===o.rank,()=>`Rank of input (${l.rank}) does not match rank of dy (${o.rank})`),F(o.rank===4,()=>`Error in maxPoolGrad: dy must be rank 4 but got rank ${o.rank}.`),F(l.rank===4,()=>`Error in maxPoolGrad: input must be rank 4 but got rank ${l.rank}.`),i!=null&&F(Vt(s),()=>`Error in maxPoolGrad: pad must be an integer when using, dimRoundingMode ${i} but got pad ${s}.`);let u={dy:o,input:l,output:d},p={filterSize:a,strides:r,pad:s,dimRoundingMode:i};return D.runKernel(Xp,u,p)}var see=O({maxPoolGrad_:ree}),iee={kernelName:Es,inputsToSave:["x"],outputsToSave:[!0],gradFunc:(e,t,n)=>{let[a,r]=t,{filterSize:s,strides:i,pad:o}=n;return{x:()=>see(e,a,r,s,i,o)}}},oee={kernelName:Cs,inputsToSave:["x"],gradFunc:(e,t,n)=>{let[a]=t,{axis:r}=n,s=ra(r,a.shape),i=Ub(a.shape,s)[1],o=Nt(i);return{x:()=>{let l=a.shape.slice();s.forEach(u=>{l[u]=1});let d=H(e,l);return me(_(d,$n(a.shape,"float32")),o)}}}},lee={kernelName:Rs,inputsToSave:["x"],outputsToSave:[!0],gradFunc:(e,t,n)=>{let a=n,{axis:r}=a,[s,i]=t,o=ra(r,s.shape),l=A6(e,i,s,o);return{x:()=>l.x()}}},uee={kernelName:Ms,inputsToSave:["a","b"],gradFunc:(e,t)=>{let[n,a]=t;return{a:()=>_(e,fe(Dr(n,a),"float32")),b:()=>_(e,fe(Mn(n,a),"float32"))}}},dee={kernelName:Fs,inputsToSave:["x"],gradFunc:(e,t,n)=>{let a=t[0],{paddings:r}=n,s=r.map(i=>i[0]);return{x:()=>Re(e,s,a.shape)}}},pee={kernelName:Ro,inputsToSave:["a","b"],gradFunc:(e,t)=>{let[n,a]=t,r=pt(n.shape,a.shape);return{a:()=>{let s=zt(n.shape,r);return s.length>0?H(ke(e,s),n.shape):e},b:()=>{let s=_(e,vt(Al(me(n,a)))),i=zt(a.shape,r);return i.length>0?H(ke(s,i),a.shape):s}}}},cee={kernelName:$s,inputsToSave:["a","b"],gradFunc:(e,t)=>{let[n,a]=t,r=pt(n.shape,a.shape);return{a:()=>{let s=_(e,fe(a,"float32")),i=zt(n.shape,r);return i.length>0?H(ke(s,i),n.shape):s},b:()=>{let s=_(e,fe(n,"float32")),i=zt(a.shape,r);return i.length>0?H(ke(s,i),a.shape):s}}}},hee={kernelName:Mo,gradFunc:e=>({x:()=>vt(e)})},fee={kernelName:Ds,inputsToSave:["indices"],gradFunc:(e,t)=>{let n=t[0];return{indices:()=>Ct(n.shape,"float32")}}},mee={kernelName:zo,gradFunc:e=>({x:()=>Ue(e)})},Aee={kernelName:_o,saveAllInputs:!0,gradFunc:(e,t,n)=>{let{axis:a}=n;return la(e,a).map(r=>()=>r)}},g6={kernelName:Os,inputsToSave:["x"],gradFunc:(e,t,n)=>{let a=t[0],{paddings:r}=n,s=r.map(i=>i[0]);return{x:()=>Re(e,s,a.shape)}}},yee={kernelName:zs,inputsToSave:["a","b"],outputsToSave:[!0],gradFunc:(e,t)=>{let[n,a,r]=t,s=n,i=a,o=pt(s.shape,i.shape);return{a:()=>{let l=fe(i,"float32"),d=_(e,_(l,rr(s,ge(l,Se(1))))),u=zt(s.shape,o);return u.length>0&&(d=ke(d,u)),H(d,s.shape)},b:()=>{let l=Mn(s,0),d=nn(l,Fn(s),Ue(s)),u=_(e,_(r,d)),p=zt(i.shape,o);return p.length>0&&(u=ke(u,p)),H(u,i.shape)}}}},gee={kernelName:_s,inputsToSave:["x","alpha"],gradFunc:(e,t)=>{let[n,a]=t,r=Mn(n,0);return{x:()=>nn(r,e,_(e,a)),alpha:()=>{let s=nn(r,Ue(e),_(e,n)),i=zt(a.shape,e.shape);return i.length>0&&(s=ke(s,i)),H(s,a.shape)}}}},xee={kernelName:ys,inputsToSave:["a","b"],gradFunc:(e,t)=>{let[n,a]=t,r=pt(n.shape,a.shape);return{a:()=>{let s=me(e,fe(a,"float32")),i=zt(n.shape,r);return i.length>0?H(ke(s,i),n.shape):s},b:()=>{let s=_(e,fe(n,"float32")),i=zt(a.shape,r);i.length>0&&(s=H(ke(s,i),a.shape));let o=st(a);return vt(me(s,fe(o,"float32")))}}}},bee={kernelName:Lo,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>me(e,vt(st(n)))}}},vee={kernelName:Ws,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t,a=_(Dr(n,6),wl(n));return{x:()=>_(e,fe(a,"float32"))}}},wee={kernelName:Ps,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(e,fe(wl(n),"float32"))}}},kee={kernelName:Wo,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>H(e,n.shape)}}},Iee={kernelName:Ls,inputsToSave:["images"],gradFunc:(e,t,n)=>{let[a]=t,r={dy:e,images:a};return{images:()=>D.runKernel(ec,r,n)}}},See={kernelName:Eu,inputsToSave:["images"],gradFunc:(e,t,n)=>{let[a]=t,r={dy:e,images:a};return{images:()=>D.runKernel(Qp,r,n)}}},Nee={kernelName:Bs,gradFunc:(e,t,n)=>{let{dims:a}=n,r=ra(a,e.shape);return{x:()=>On(e,r)}}},Tee={kernelName:Vs,gradFunc:e=>({x:()=>Ue(e)})},Eee={kernelName:js,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>vt(me(e,_(rr(n,1.5),2)))}}},Cee={kernelName:Vo,inputsToSave:["condition"],gradFunc:(e,t)=>{let[n]=t;return{condition:()=>fe(Ue(n),"float32"),t:()=>_(e,fe(n,e.dtype)),e:()=>_(e,fe(Zu(n),e.dtype))}}},Ree={kernelName:jo,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>{let a=Mn(n,Se(0)),r=Se(g3),s=Se(x3),i=_(e,s),o=_(_(e,r),qn(fe(n,"float32")));return nn(a,i,o)}}}},Mee={kernelName:Hs,outputsToSave:[!0],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(e,_(n,ge(Se(1),n)))}}},Fee={kernelName:Go,gradFunc:e=>({x:()=>Ue(e)})},$ee={kernelName:Us,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(Xu(fe(n,"float32")),e)}}},Dee={kernelName:Ho,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(wc(fe(n,"float32")),e)}}},Oee={kernelName:Uo,inputsToSave:["x"],gradFunc:(e,t,n)=>{let[a]=t,{begin:r,size:s}=n,i=a.shape,[o,l]=Ab(a,r,s),d=[];for(let u=0;uar(e,d)}}},zee={kernelName:Xs,outputsToSave:[!0],gradFunc:(e,t,n)=>{let[a]=t,{dim:r}=n,s=!0,i=_(e,a);return{logits:()=>ge(i,_(ke(i,[r],s),a))}}},_ee={kernelName:qo,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(e,wn(n))}}},x6={kernelName:Cu,gradFunc:(e,t,n)=>{let{blockShape:a,paddings:r}=n;return{x:()=>qu(e,a,r)}}},b6={kernelName:Xo,gradFunc:(e,t,n)=>{let{axis:a}=n;return{x:()=>ot(e,a)}}},Pee={kernelName:Gs,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>me(e,_(Jt(fe(n,"float32")),2))}}},Lee={kernelName:Ru,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(e,_(fe(n,"float32"),2))}}},Wee={kernelName:Ks,inputsToSave:["a","b"],gradFunc:(e,t)=>{let[n,a]=t,r=Se(2);return{a:()=>_(e,_(r,ge(n,a))),b:()=>_(e,_(r,ge(a,n)))}}},Bee={kernelName:Sr,gradFunc:e=>({x:()=>Ue(e)})},Vee={kernelName:Zs,inputsToSave:["a","b"],gradFunc:(e,t)=>{let[n,a]=t,r=pt(n.shape,a.shape);return{a:()=>{let s=e,i=zt(n.shape,r);return i.length>0&&(s=ke(s,i)),H(s,n.shape)},b:()=>{let s=e,i=zt(a.shape,r);return i.length>0&&(s=ke(s,i)),H(vt(s),a.shape)}}}},jee={kernelName:qs,inputsToSave:["x"],gradFunc:(e,t,n)=>{let[a]=t,r=a.shape.slice(),{axis:s}=n;ra(s,a.shape).forEach(l=>{r[l]=1});let i=H(e,r),o=_(i,$n(a.shape,"float32"));return{x:()=>o}}},Uee={kernelName:Ys,inputsToSave:["x"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>me(e,st(Xu(n)))}}},Hee={kernelName:Js,outputsToSave:[!0],gradFunc:(e,t)=>{let[n]=t;return{x:()=>_(ge(Se(1),st(n)),e)}}},Gee={kernelName:Ir,inputsToSave:["x"],gradFunc:(e,t,n)=>{let[a]=t,{reps:r}=n;return{x:()=>{let s=Ue(a);if(a.rank===1)for(let i=0;i{let a=n,{perm:r}=a,s=vA(r);return{x:()=>Ze(e,s)}}},Xee={kernelName:Jo,gradFunc:(e,t,n)=>{let a=n,{axis:r}=a;return{value:()=>zn(e,r)}}},Zee={kernelName:Mu,inputsToSave:["segmentIds"],gradFunc:(e,t)=>{let[n]=t;return{x:()=>Kee(e,n)}}};function Kee(e,t){let n=_a(t,Ue(t)),a=ci(e,n),r=$r(t,Se(0,"int32")),s=a.rank-r.rank;for(let o=0;o({x:()=>Ue(e)})},Jee=[h6,JJ,QJ,eQ,tQ,nQ,aQ,rQ,sQ,iQ,oQ,lQ,pQ,fQ,mQ,AQ,yQ,gQ,xQ,bQ,vQ,wQ,IQ,kQ,TQ,EQ,CQ,RQ,MQ,FQ,xee,$Q,DQ,OQ,zQ,_Q,LQ,PQ,WQ,BQ,VQ,jQ,UQ,HQ,GQ,qQ,XQ,KQ,ZQ,QQ,y6,y6,eee,aee,iee,oee,lee,uee,dee,pee,cee,hee,fee,mee,Aee,g6,g6,yee,gee,bee,vee,wee,kee,Iee,See,Nee,Tee,Eee,Cee,Ree,Mee,Fee,$ee,Dee,Oee,zee,_ee,x6,x6,b6,b6,Pee,Wee,Lee,Bee,Vee,jee,Uee,Hee,Gee,qee,Xee,Zee,Yee];for(let e of Jee)Fx(e);var v6={};Fe(v6,{maxNorm:()=>Qee,minMaxNorm:()=>nte,nonNeg:()=>tte,unitNorm:()=>ete});var C1;function _t(){return C1==null&&(C1=kb().epsilon()),C1}function ba(){return"channelsLast"}var lr=class extends Error{constructor(e){super(e);Object.setPrototypeOf(this,lr.prototype)}},va=class extends Error{constructor(e){super(e);Object.setPrototypeOf(this,va.prototype)}},B=class extends Error{constructor(e){super(e);Object.setPrototypeOf(this,B.prototype)}},Oe=class extends Error{constructor(e){super(e);Object.setPrototypeOf(this,Oe.prototype)}},w6=class extends Error{constructor(e){super(e);Object.setPrototypeOf(this,w6.prototype)}};function Ni(e,t){if(Array.isArray(e)){let n=[];for(let a=0;an.toUpperCase())}var ua={};function R1(e){if(e==null)return null;let t={};return t.className=e.getClassName(),t.config=e.getConfig(),t}function M1(e){if(!(e==null||typeof e!="object"))if(Array.isArray(e))e.forEach(t=>M1(t));else{let t=Object.keys(e);for(let n of t){let a=e[n];a!=null&&typeof a=="object"&&(!Array.isArray(a)&&a.type==="ndarray"&&typeof a.value=="number"?e[n]=a.value:M1(a))}}}function Id(e,t={},n={},a="object",r=!1){if(typeof e=="string"){let s=e,i;if(s in n)i=n[s];else if(s in ua)i=ua[s];else if(i=t[s],i==null)throw new B(`Unknown ${a}: ${e}. This may be due to one of the following reasons: 1. The ${a} is defined in Python, in which case it needs to be ported to TensorFlow.js or your JavaScript code. 2. The custom ${a} is defined in JavaScript, but is not registered properly with tf.serialization.registerClass().`);return i}else{let s=e;if(s.className==null||s.config==null)throw new B(`${a}: Improper config format: ${JSON.stringify(s)}. -'className' and 'config' must set.`);let i=s.className,o,l;if(i in n?[o,l]=n[i]:i in da?[o,l]=da.className:i in t&&([o,l]=t[i]),o==null)throw new B(`Unknown ${a}: ${i}. This may be due to one of the following reasons: +'className' and 'config' must set.`);let i=s.className,o,l;if(i in n?[o,l]=n[i]:i in ua?[o,l]=ua.className:i in t&&([o,l]=t[i]),o==null)throw new B(`Unknown ${a}: ${i}. This may be due to one of the following reasons: 1. The ${a} is defined in Python, in which case it needs to be ported to TensorFlow.js or your JavaScript code. -2. The custom ${a} is defined in JavaScript, but is not registered properly with tf.serialization.registerClass().`);if(l!=null){let d={};for(let h of Object.keys(da))d[h]=da[h];for(let h of Object.keys(n))d[h]=n[h];let u=s.config;u.customObjects=d;let p=Object.assign({},da);for(let h of Object.keys(n))da[h]=n[h];M1(s.config);let c=l(o,s.config,n,r);return da=Object.assign({},p),c}else{let d=Object.assign({},da);for(let p of Object.keys(n))da[p]=n[p];let u=new o(s.config);return da=Object.assign({},d),u}}}function ate(e,t){return et?1:0}function Mh(e,t){return-1*ate(e,t)}function Vr(e){if(e==null)return e;let t=[];for(let n of e)t.indexOf(n)===-1&&t.push(n);return t}function rte(e){if(e==null)throw new B(`Invalid value in obj: ${JSON.stringify(e)}`);for(let t in e)if(e.hasOwnProperty(t))return!1;return!0}function Ci(e,t,n){if(n!=null&&e.indexOf(n)<0)throw new B(`${n} is not a valid ${t}. Valid values are ${e} or null/undefined.`)}function F1(e,t,n=0,a=Infinity){return ja(n>=0),ja(a>=n),Array.isArray(e)&&e.length>=n&&e.length<=a&&e.every(r=>typeof r===t)}function Gt(e,t){Array.isArray(e)?(k.assert(e.length>0,()=>`${t} is unexpectedly an empty array.`),e.forEach((n,a)=>Gt(n,`element ${a+1} of ${t}`))):k.assert(Number.isInteger(e)&&e>0,()=>`Expected ${t} to be a positive integer, but got ${I6(e)}.`)}function I6(e){return e===null?"null":Array.isArray(e)?"["+e.map(t=>I6(t)).join(",")+"]":typeof e=="string"?`"${e}"`:`${e}`}function ste(e,t){let n=k.now(),a;return(...r)=>{let s=k.now();return s-nQt(ke(_(e,e),t,!0)))}var Sd=class extends ae.Serializable{getConfig(){return{}}},D1=class extends Sd{constructor(e){super();this.defaultMaxValue=2,this.defaultAxis=0,this.maxValue=e.maxValue!=null?e.maxValue:this.defaultMaxValue,this.axis=e.axis!=null?e.axis:this.defaultAxis}apply(e){return W(()=>{let t=$1(e,this.axis),n=In(t,0,this.maxValue);return _(e,me(n,se(Pt(),t)))})}getConfig(){return{maxValue:this.maxValue,axis:this.axis}}};D1.className="MaxNorm";ae.registerClass(D1);var O1=class extends Sd{constructor(e){super();this.defaultAxis=0,this.axis=e.axis!=null?e.axis:this.defaultAxis}apply(e){return W(()=>me(e,se(Pt(),$1(e,this.axis))))}getConfig(){return{axis:this.axis}}};O1.className="UnitNorm";ae.registerClass(O1);var z1=class extends Sd{apply(e){return La(e)}};z1.className="NonNeg";ae.registerClass(z1);var _1=class extends Sd{constructor(e){super();this.defaultMinValue=0,this.defaultMaxValue=1,this.defaultRate=1,this.defaultAxis=0,this.minValue=e.minValue!=null?e.minValue:this.defaultMinValue,this.maxValue=e.maxValue!=null?e.maxValue:this.defaultMaxValue,this.rate=e.rate!=null?e.rate:this.defaultRate,this.axis=e.axis!=null?e.axis:this.defaultAxis}apply(e){return W(()=>{let t=$1(e,this.axis),n=se(_(this.rate,In(t,this.minValue,this.maxValue)),_(1-this.rate,t));return _(e,me(n,se(Pt(),t)))})}getConfig(){return{minValue:this.minValue,maxValue:this.maxValue,rate:this.rate,axis:this.axis}}};_1.className="MinMaxNorm";ae.registerClass(_1);var N6={maxNorm:"MaxNorm",minMaxNorm:"MinMaxNorm",nonNeg:"NonNeg",unitNorm:"UnitNorm"};function Lt(e){return R1(e)}function T6(e,t={}){return Id(e,ae.SerializationMap.getMap().classNameMap,t,"constraint")}function Wt(e){if(e==null)return null;if(typeof e=="string"){let t={className:e in N6?N6[e]:e,config:{}};return T6(t)}else return e instanceof Sd?e:T6(e)}function Qee(e){return new D1(e)}function ete(e){return new O1(e)}function tte(){return new z1}function nte(e){return new _1(e)}var E6={};Fe(E6,{constant:()=>lte,glorotNormal:()=>mte,glorotUniform:()=>fte,heNormal:()=>Ate,heUniform:()=>yte,identity:()=>cte,leCunNormal:()=>gte,leCunUniform:()=>xte,ones:()=>ote,orthogonal:()=>bte,randomNormal:()=>dte,randomUniform:()=>ute,truncatedNormal:()=>pte,varianceScaling:()=>hte,zeros:()=>ite});var vte=["channelsFirst","channelsLast"],wte=["nearest","bilinear"],kte=["valid","same","causal"],Ite=["max","avg"],Ste=["sum","mul","concat","ave"],Wl=new Map;function Ct(e){Ci(vte,"DataFormat",e)}function Nte(e){Ci(wte,"InterpolationFormat",e)}function Qn(e){Ci(kte,"PaddingMode",e)}function C6(e){Ci(Ite,"PoolMode",e)}var Nd=[],R6="/";function Ri(e,t){Nd.push(e);try{let n=t();return Nd.pop(),n}catch(n){throw Nd.pop(),n}}function Tte(){return Nd.length===0?"":Nd.join(R6)+R6}function F6(e){if(!M6(e))throw new Error("Not a valid tensor name: '"+e+"'");return Tte()+e}function $6(e){if(!M6(e))throw new Error("Not a valid tensor name: '"+e+"'");Wl.has(e)||Wl.set(e,0);let t=Wl.get(e);if(Wl.set(e,Wl.get(e)+1),t>0){let n=`${e}_${t}`;return Wl.set(n,1),n}else return e}var Ete=new RegExp(/^[A-Za-z0-9][-A-Za-z0-9\._\/]*$/);function M6(e){return!!e.match(Ete)}function Cte(e){return e===parseInt(e.toString(),10)}function jr(e,t,n){t==null&&(t=0),n==null&&(n=e.length);let a=1;for(let r=t;r{if(e.shape.length!==2)throw new B(`repeat() expects a rank-2 tensor, but received a rank-${e.shape.length} tensor.`);let n=Ed(e,1);return P1(n,[1,t,1])})}function Mte(e){let t=[jr(e.shape)];return e.reshape(t)}function Fte(e){if(e.rank<=1)throw new B(`batchFlatten requires a minimum rank of 2. Got rank: ${e.rank}.`);let t=[e.shape[0],jr(e.shape,1)];return e.reshape(t)}function Mi(e,t,n){return W(()=>{switch(e.rank){case 1:return Pc(e,t,n);case 2:return MA(e,[t,0],[n,e.shape[1]]);case 3:return Lc(e,[t,0,0],[n,e.shape[1],e.shape[2]]);case 4:return td(e,[t,0,0,0],[n,e.shape[1],e.shape[2],e.shape[3]]);case 5:return Re(e,[t,0,0,0,0],[n,e.shape[1],e.shape[2],e.shape[3],e.shape[4]]);case 6:return Re(e,[t,0,0,0,0,0],[n,e.shape[1],e.shape[2],e.shape[3],e.shape[4],e.shape[5]]);default:throw new B(`sliceAlongFirstAxis() received an unsupported tensor rank: ${e.rank}`)}})}function L1(e,t,n){return W(()=>{switch(e.rank){case 1:return Pc(e,t,n);case 2:return MA(e,[0,t],[e.shape[0],n]);case 3:return Lc(e,[0,0,t],[e.shape[0],e.shape[1],n]);case 4:return td(e,[0,0,0,t],[e.shape[0],e.shape[1],e.shape[2],n]);default:throw new B(`sliceAlongLastAxis() received an unsupported tensor rank: ${e.rank}`)}})}function Fh(e,t,n,a){return W(()=>{switch(e.rank){case 1:return Pc(e,t,n);case 2:switch(a){case 1:return Mi(e,t,n);case 2:return L1(e,t,n);default:throw new B(`The axis is not within the rank of the tensor ${a}`)}case 3:switch(a){case 1:return Mi(e,t,n);case 2:return Lc(e,[0,t,0],[e.shape[0],n,e.shape[2]]);case 3:return L1(e,t,n);default:throw new B(`The axis is not within the rank of the tensor ${a}`)}case 4:switch(a){case 1:return Mi(e,t,n);case 2:return td(e,[0,t,0,0],[e.shape[0],n,e.shape[2],e.shape[3]]);case 3:return td(e,[0,0,t,0],[e.shape[0],e.shape[1],n,e.shape[3]]);case 4:return L1(e,t,n);default:throw new B(`The axis is not within the rank of the tensor ${a}`)}default:throw new B(`sliceAlongLastAxis() received an unsupported tensor rank: ${e.rank}`)}})}function W1(e,t=-1){let n;return t<0&&(n=e[0].rank,n!==0?t=n:t=0),t===e[0].rank&&(t=-1),ot(e,t)}function O6(e,t){switch(e.rank){case 1:return Rb([e,t]);case 2:return hl([e,t],0);case 3:return Mb([e,t],0);case 4:return Fb([e,t],0);default:throw new B(`concatAlongFirstAxis() received an unsupported tensor rank: ${e.rank}`)}}function P1(e,t){if(Array.isArray(t)||(t=[t]),e.rank!==t.length)throw new B(`The length of input n (${t.length}) does not match the number of dimensions in input x (${e.rank})`);return $r(e,t)}function $h(e,t=0,n=1,a,r){return Zb(e,t,n,a,r)}function Ua(e,t,n,a){if(e.rank<2||t.rank<2)throw new Oe(`dot requires both inputs to be rank >= 2 but got x shape = ${e.shape} and y shape = ${t.shape}`);if(t.rank>=3){let r=e.shape.slice(-1)[0],s=t.shape.slice(-2)[0];if(r!==s)throw new Oe(`If rank y >= 3, then the second last dim of y must equal the last dim of x but got x shape = ${e.shape} and y shape = ${t.shape}`)}if(e.rank===2&&t.rank===2){let r=!1,s=!1;return _r.matMul({a:e,b:t,transposeA:r,transposeB:s,bias:a?B1(e.rank,a,va()):null,activation:n})}else{let r=e.shape.slice(),s=r.pop();e=e.reshape([-1,s]);let i=t.shape.slice(),o=i.pop(),l=i.pop(),d=[...i,o],u=Array.from({length:t.rank},(m,f)=>f===0?t.rank-2:f<=t.rank-2?f-1:f);t=t.transpose(u).reshape([l,-1]);let p=[...r,...d],c=!1,h=!1;return _r.matMul({a:e,b:t,transposeA:c,transposeB:h,bias:a?B1(e.rank,a,va()):null,activation:n}).reshape(p)}}function z6(e,t,n){return W(()=>(Array.isArray(t)?t=Et(t,"int32"):t=t.toInt(),hi(e,t,n)))}function Cd(e){return _(e,e)}function B1(e,t,n){let a=t.shape;if(t.rank!==1&&t.rank!==e)throw new B(`Unexpected bias dimensions: ${t.rank}; expected it to be 1 or ${e}`);if(e===5){if(n==="channelsFirst")return a.length===1?t.reshape([1,a[0],1,1,1]):t.reshape([1,a[3],a[0],a[1],a[2]]);if(n==="channelsLast")return a.length===1?t.reshape([1,1,1,1,a[0]]):t.reshape([1].concat(a))}else if(e===4){if(n==="channelsFirst")return a.length===1?t.reshape([1,a[0],1,1]):t.reshape([1,a[2],a[0],a[1]]);if(n==="channelsLast")return a.length===1?t.reshape([1,1,1,a[0]]):t.reshape([1].concat(a))}else if(e===3){if(n==="channelsFirst")return a.length===1?t.reshape([1,a[0],1]):t.reshape([1,a[1],a[0]]);if(n==="channelsLast")return a.length===1?t.reshape([1,1,a[0]]):t.reshape([1].concat(a))}else if(e<3)return t;throw new B(`Unsupported input rank by biasAdd: ${t.rank}`)}function Ia(e,t,n){return W(()=>(n==null&&(n=va()),Ct(n),e.add(B1(e.rank,t,n))))}function $te(e,t=1){if(t!==1)throw new Oe(`Support for alpha values other than 1 (${t}) is not implemented yet.`);return ml(e)}function Dte(e){return W(()=>me(e,zt(e).add(1)))}function _6(e,t,n,a){return W(()=>a3(e,t,n,a))}function Ote(e){return W(()=>{let t=se(.5,_(.2,e));return In(t,0,1)})}function Rd(e,t,n=!1){return n?e():t()}var zte=["fanIn","fanOut","fanAvg"],_te=["normal","uniform","truncatedNormal"];function Pte(e){Ci(zte,"FanMode",e)}function Lte(e){Ci(_te,"Distribution",e)}var pa=class extends ae.Serializable{fromConfigUsesCustomObjects(){return!1}getConfig(){return{}}},V1=class extends pa{apply(e,t){return Rt(e,t)}};V1.className="Zeros";ae.registerClass(V1);var Dh=class extends pa{apply(e,t){return Dn(e,t)}};Dh.className="Ones";ae.registerClass(Dh);var j1=class extends pa{constructor(e){super();if(typeof e!="object")throw new B(`Expected argument of type ConstantConfig but got ${e}`);if(e.value===void 0)throw new B(`config must have value set but got ${e}`);this.value=e.value}apply(e,t){return W(()=>_(Se(this.value),Dn(e,t)))}getConfig(){return{value:this.value}}};j1.className="Constant";ae.registerClass(j1);var U1=class extends pa{constructor(e){super();this.DEFAULT_MINVAL=-.05,this.DEFAULT_MAXVAL=.05,this.minval=e.minval||this.DEFAULT_MINVAL,this.maxval=e.maxval||this.DEFAULT_MAXVAL,this.seed=e.seed}apply(e,t){return bl(e,this.minval,this.maxval,t)}getConfig(){return{minval:this.minval,maxval:this.maxval,seed:this.seed}}};U1.className="RandomUniform";ae.registerClass(U1);var H1=class extends pa{constructor(e){super();this.DEFAULT_MEAN=0,this.DEFAULT_STDDEV=.05,this.mean=e.mean||this.DEFAULT_MEAN,this.stddev=e.stddev||this.DEFAULT_STDDEV,this.seed=e.seed}apply(e,t){if(t=t||"float32",t!=="float32"&&t!=="int32")throw new Oe(`randomNormal does not support dType ${t}.`);return $h(e,this.mean,this.stddev,t,this.seed)}getConfig(){return{mean:this.mean,stddev:this.stddev,seed:this.seed}}};H1.className="RandomNormal";ae.registerClass(H1);var G1=class extends pa{constructor(e){super();this.DEFAULT_MEAN=0,this.DEFAULT_STDDEV=.05,this.mean=e.mean||this.DEFAULT_MEAN,this.stddev=e.stddev||this.DEFAULT_STDDEV,this.seed=e.seed}apply(e,t){if(t=t||"float32",t!=="float32"&&t!=="int32")throw new Oe(`truncatedNormal does not support dType ${t}.`);return Vc(e,this.mean,this.stddev,t,this.seed)}getConfig(){return{mean:this.mean,stddev:this.stddev,seed:this.seed}}};G1.className="TruncatedNormal";ae.registerClass(G1);var q1=class extends pa{constructor(e){super();this.gain=e.gain!=null?e.gain:1}apply(e,t){return W(()=>{if(e.length!==2||e[0]!==e[1])throw new B("Identity matrix initializer can only be used for 2D square matrices.");return _(this.gain,yA(e[0]))})}getConfig(){return{gain:this.gain}}};q1.className="Identity";ae.registerClass(q1);function Wte(e,t="channelsLast"){let n,a;if(Ct(t),e.length===2)n=e[0],a=e[1];else if([3,4,5].indexOf(e.length)!==-1){if(t==="channelsFirst"){let r=jr(e,2);n=e[1]*r,a=e[0]*r}else if(t==="channelsLast"){let r=jr(e,0,e.length-2);n=e[e.length-2]*r,a=e[e.length-1]*r}}else{let r=jr(e);n=Math.sqrt(r),a=Math.sqrt(r)}return[n,a]}var Tn=class extends pa{constructor(e){super();if(e.scale<0)throw new B(`scale must be a positive float. Got: ${e.scale}`);this.scale=e.scale==null?1:e.scale,this.mode=e.mode==null?"fanIn":e.mode,Pte(this.mode),this.distribution=e.distribution==null?"normal":e.distribution,Lte(this.distribution),this.seed=e.seed}apply(e,t){let n=Wte(e),a=n[0],r=n[1],s=this.scale;if(this.mode==="fanIn"?s/=Math.max(1,a):this.mode==="fanOut"?s/=Math.max(1,r):s/=Math.max(1,(a+r)/2),this.distribution==="normal"){let i=Math.sqrt(s);if(t=t||"float32",t!=="float32"&&t!=="int32")throw new Oe(`${this.getClassName()} does not support dType ${t}.`);return Vc(e,0,i,t,this.seed)}else{let i=Math.sqrt(3*s);return bl(e,-i,i,t)}}getConfig(){return{scale:this.scale,mode:this.mode,distribution:this.distribution,seed:this.seed}}};Tn.className="VarianceScaling";ae.registerClass(Tn);var Oh=class extends Tn{constructor(e){super({scale:1,mode:"fanAvg",distribution:"uniform",seed:e==null?null:e.seed})}getClassName(){return Tn.className}};Oh.className="GlorotUniform";ae.registerClass(Oh);var zh=class extends Tn{constructor(e){super({scale:1,mode:"fanAvg",distribution:"normal",seed:e==null?null:e.seed})}getClassName(){return Tn.className}};zh.className="GlorotNormal";ae.registerClass(zh);var _h=class extends Tn{constructor(e){super({scale:2,mode:"fanIn",distribution:"normal",seed:e==null?null:e.seed})}getClassName(){return Tn.className}};_h.className="HeNormal";ae.registerClass(_h);var Ph=class extends Tn{constructor(e){super({scale:2,mode:"fanIn",distribution:"uniform",seed:e==null?null:e.seed})}getClassName(){return Tn.className}};Ph.className="HeUniform";ae.registerClass(Ph);var Lh=class extends Tn{constructor(e){super({scale:1,mode:"fanIn",distribution:"normal",seed:e==null?null:e.seed})}getClassName(){return Tn.className}};Lh.className="LeCunNormal";ae.registerClass(Lh);var Wh=class extends Tn{constructor(e){super({scale:1,mode:"fanIn",distribution:"uniform",seed:e==null?null:e.seed})}getClassName(){return Tn.className}};Wh.className="LeCunNormal";ae.registerClass(Wh);var X1=class extends pa{constructor(e){super();if(this.DEFAULT_GAIN=1,this.gain=e.gain==null?this.DEFAULT_GAIN:e.gain,this.seed=e.seed,this.seed!=null)throw new Oe("Random seed is not implemented for Orthogonal Initializer yet.")}apply(e,t){return W(()=>{if(e.length<2)throw new Oe("Shape must be at least 2D.");e[0]*e[1]>2e3&&console.warn(`Orthogonal initializer is being called on a matrix with more than 2000 (${e[0]*e[1]}) elements: Slowness may result.`);let n=e[0]>e[1]?[e[1],e[0]]:e,a=$h(n,0,1,"float32"),r=A3.gramSchmidt(a);return e[0]>e[1]&&(r=r.transpose()),_(this.gain,r)})}getConfig(){return{gain:this.gain,seed:this.seed}}};X1.className="Orthogonal";ae.registerClass(X1);var P6={constant:"Constant",glorotNormal:"GlorotNormal",glorotUniform:"GlorotUniform",heNormal:"HeNormal",heUniform:"HeUniform",identity:"Identity",leCunNormal:"LeCunNormal",leCunUniform:"LeCunUniform",ones:"Ones",orthogonal:"Orthogonal",randomNormal:"RandomNormal",randomUniform:"RandomUniform",truncatedNormal:"TruncatedNormal",varianceScaling:"VarianceScaling",zeros:"Zeros"};function L6(e,t={}){return Id(e,ae.SerializationMap.getMap().classNameMap,t,"initializer")}function It(e){return R1(e)}function At(e){if(typeof e=="string"){let t=e in P6?P6[e]:e;if(t==="GlorotNormal")return new zh;if(t==="GlorotUniform")return new Oh;if(t==="HeNormal")return new _h;if(t==="HeUniform")return new Ph;if(t==="LeCunNormal")return new Lh;if(t==="LeCunUniform")return new Wh;{let n={};return n.className=t,n.config={},L6(n)}}else return e instanceof pa?e:L6(e)}function ite(){return new V1}function ote(){return new Dh}function lte(e){return new j1(e)}function ute(e){return new U1(e)}function dte(e){return new H1(e)}function pte(e){return new G1(e)}function cte(e){return new q1(e)}function hte(e){return new Tn(e)}function fte(e){return new Oh(e)}function mte(e){return new zh(e)}function Ate(e){return new _h(e)}function yte(e){return new Ph(e)}function gte(e){return new Lh(e)}function xte(e){return new Wh(e)}function bte(e){return new X1(e)}var W6={};Fe(W6,{Layer:()=>Ge,RNN:()=>Ha,RNNCell:()=>Md,activation:()=>ane,add:()=>cne,alphaDropout:()=>Kne,average:()=>hne,averagePooling1d:()=>K1,averagePooling2d:()=>Z1,averagePooling3d:()=>Y1,avgPool1d:()=>wne,avgPool2d:()=>Ine,avgPool3d:()=>Nne,avgPooling1d:()=>kne,avgPooling2d:()=>Sne,avgPooling3d:()=>Tne,batchNormalization:()=>xne,bidirectional:()=>Bne,concatenate:()=>fne,conv1d:()=>Xte,conv2d:()=>Kte,conv2dTranspose:()=>Zte,conv3d:()=>Yte,conv3dTranspose:()=>Jte,convLstm2d:()=>_ne,convLstm2dCell:()=>Pne,cropping2D:()=>ene,dense:()=>rne,depthwiseConv2d:()=>nne,dot:()=>gne,dropout:()=>sne,elu:()=>Vte,embedding:()=>pne,flatten:()=>one,gaussianDropout:()=>Xne,gaussianNoise:()=>qne,globalAveragePooling1d:()=>Ene,globalAveragePooling2d:()=>Cne,globalMaxPool1d:()=>jne,globalMaxPool2d:()=>Une,globalMaxPooling1d:()=>V6,globalMaxPooling2d:()=>j6,gru:()=>Mne,gruCell:()=>Fne,input:()=>B6,inputLayer:()=>Bte,layerNormalization:()=>bne,leakyReLU:()=>Ute,lstm:()=>$ne,lstmCell:()=>Dne,masking:()=>Zne,maxPool1d:()=>Hne,maxPool2d:()=>Gne,maxPooling1d:()=>U6,maxPooling2d:()=>H6,maxPooling3d:()=>Rne,maximum:()=>mne,minimum:()=>Ane,multiply:()=>yne,permute:()=>dne,prelu:()=>Hte,reLU:()=>jte,repeatVector:()=>lne,reshape:()=>une,rnn:()=>Lne,separableConv2d:()=>Qte,simpleRNN:()=>One,simpleRNNCell:()=>zne,softmax:()=>Gte,spatialDropout1d:()=>ine,stackedRNNCells:()=>Wne,thresholdedReLU:()=>qte,timeDistributed:()=>Vne,upSampling2d:()=>tne,zeroPadding2d:()=>vne});var Yne=0;function G6(){return Yne++}var Bh={};function Vh(e=""){return e in Bh||(Bh[e]=0),Bh[e]+=1,e+Bh[e].toString()}function J1(e){return Array.isArray(e)&&Array.isArray(e[0])}function jh(e){return e.length===0?[]:Array.isArray(e[0])?e:[e]}function _e(e){let t;if(Array.isArray(e)){if(e.length!==1)throw new B(`Expected Tensor length to be 1; got ${e.length}`);t=e[0]}else t=e;return t}function at(e){if(Array.isArray(e)&&Array.isArray(e[0])){if(e.length===1)return e=e,e[0];throw new B(`Expected exactly 1 Shape; got ${e.length}`)}else return e}function Uh(e){let t=0;for(let n of e)n.shape.length===0?t+=1:t+=n.shape.reduce((a,r)=>a*r);return t}var q6="Variable",X6=class{constructor(e,t="float32",n=q6,a=!0,r=null){this.dtype=t==null?"float32":t,this.shape=e.shape,this.id=G6(),n=n==null?q6:n,this.originalName=F6(n),this.name=$6(this.originalName),this.trainable_=a,this.constraint=r,this.val=Jb(e,this.trainable_,this.name,this.dtype)}read(){return this.assertNotDisposed(),this.val}write(e){return this.assertNotDisposed(),Jne(this.val,e),this.val.id!==e.id&&(this.val.assign(e),this.constraint!=null&&this.val.assign(this.constraint.apply(this.val))),this}dispose(){this.assertNotDisposed(),this.val.dispose()}assertNotDisposed(){if(this.val.isDisposed)throw new Error(`LayersVariable ${this.name} is already disposed.`)}get trainable(){return this.trainable_}set trainable(e){this.trainable_=e,this.val.trainable=e}};function Jne(e,t){if(e.shape.toString()!==t.shape.toString())throw new Error("Shape mismatch: "+JSON.stringify(e.shape)+" vs. "+JSON.stringify(t.shape))}function Q1(e){return e.map(t=>t.read())}function ey(e){e.forEach(t=>{t[0].write(t[1])})}var Ft=class{constructor(e){this.dtype=e.dtype,this.shape=e.shape,e.shape!=null?this.ndim=e.shape.length:this.ndim=e.ndim,this.maxNDim=e.maxNDim,this.minNDim=e.minNDim,this.axes=e.axes||{}}},Sa=class{constructor(e,t,n,a,r,s,i){this.dtype=e,this.shape=t,this.sourceLayer=n,this.inputs=a,this.callArgs=r,this.outputTensorIndex=i,this.id=G6(),s!=null&&(this.originalName=F6(s),this.name=$6(this.originalName)),this.rank=t.length}},Qne=0,Hh=class{constructor(e,t){this.callArgs=t,this.id=Qne++,this.outboundLayer=e.outboundLayer,this.inboundLayers=e.inboundLayers,this.nodeIndices=e.nodeIndices,this.tensorIndices=e.tensorIndices,this.inputTensors=e.inputTensors,this.outputTensors=e.outputTensors,this.inputMasks=e.inputMasks,this.outputMasks=e.outputMasks,this.inputShapes=e.inputShapes,this.outputShapes=e.outputShapes;for(let n of e.inboundLayers)n!=null&&n.outboundNodes.push(this);e.outboundLayer.inboundNodes.push(this)}getConfig(){let e=[];for(let t of this.inboundLayers)t!=null?e.push(t.name):e.push(null);return{outboundLayer:this.outboundLayer?this.outboundLayer.name:null,inboundLayers:e,nodeIndices:this.nodeIndices,tensorIndices:this.tensorIndices}}},eae=0,Ge=class extends ae.Serializable{constructor(e={}){super();this._callHook=null,this._addedWeightNames=[],this._stateful=!1,this.id=eae++,this.activityRegularizer=null,this.inputSpec=null,this.supportsMasking=!1,this._trainableWeights=[],this._nonTrainableWeights=[],this._losses=[],this._updates=[],this._built=!1,this.inboundNodes=[],this.outboundNodes=[];let t=e.name;if(!t){let n=this.getClassName();t=dr(n)+"_"+Vh(n)}if(this.name=t,this.trainable_=e.trainable==null?!0:e.trainable,e.inputShape!=null||e.batchInputShape!=null){let n;if(e.batchInputShape!=null)n=e.batchInputShape;else if(e.inputShape!=null){let r=null;e.batchSize!=null&&(r=e.batchSize),n=[r].concat(e.inputShape)}this.batchInputShape=n;let a=e.dtype;a==null&&(a=e.inputDType),a==null&&(a="float32"),this.dtype=a}e.weights!=null?this.initialWeights=e.weights:this.initialWeights=null,this._refCount=null,this.fastWeightInitDuringBuild=!1}static nodeKey(e,t){return e.name+"_ib-"+t.toString()}getNodeAtIndex(e,t){if(this.inboundNodes.length===0)throw new wa(`The layer has never been called and thus has no defined ${t}.`);if(this.inboundNodes.length<=e)throw new B(`Asked to get ${t} at node ${e}, but the layer has only ${this.inboundNodes.length} inbound nodes.`);return this.inboundNodes[e]}getInputAt(e){return Nn(this.getNodeAtIndex(e,"input").inputTensors)}getOutputAt(e){return Nn(this.getNodeAtIndex(e,"output").outputTensors)}get input(){if(this.inboundNodes.length>1)throw new ur(`Layer ${this.name} has multiple inbound nodes, hence the notion of "layer input" is ill-defined. Use \`getInputAt(nodeIndex)\` instead.`);if(this.inboundNodes.length===0)throw new ur(`Layer ${this.name} is not connected, no input to return.`);return Nn(this.getNodeAtIndex(0,"input").inputTensors)}get output(){if(this.inboundNodes.length===0)throw new ur(`Layer ${this.name} has no inbound nodes.`);if(this.inboundNodes.length>1)throw new ur(`Layer ${this.name} has multiple inbound nodes, hence the notion of "layer output" is ill-defined. Use \`getOutputAt(nodeIndex)\` instead.`);return Nn(this.getNodeAtIndex(0,"output").outputTensors)}get losses(){return this._losses}calculateLosses(){return this.losses.map(e=>e())}get updates(){return this._updates}get built(){return this._built}set built(e){this._built=e}get trainable(){return this.trainable_}set trainable(e){this._trainableWeights.forEach(t=>t.trainable=e),this.trainable_=e}get trainableWeights(){return this.trainable_?this._trainableWeights.filter(e=>e.trainable):[]}set trainableWeights(e){this._trainableWeights=e}get nonTrainableWeights(){return this.trainable?this._trainableWeights.filter(e=>!e.trainable).concat(this._nonTrainableWeights):this._trainableWeights.concat(this._nonTrainableWeights)}set nonTrainableWeights(e){this._nonTrainableWeights=e}get weights(){return this.trainableWeights.concat(this.nonTrainableWeights)}get stateful(){return this._stateful}resetStates(){if(!this.stateful)throw new Error("Cannot call the resetStates() method of a non-stateful Layer object.")}assertInputCompatibility(e){if(e=ft(e),this.inputSpec==null||this.inputSpec.length===0)return;let t=ft(this.inputSpec);if(e.length!==t.length)throw new B(`Layer ${this.name} expects ${t.length} inputs, but it received ${e.length} input tensors. Input received: ${e}`);for(let n=0;nr.maxNDim)throw new B(`Input ${n} is incompatible with layer ${this.name}: expected max_ndim=${r.maxNDim}, found ndim=${s}`);if(r.minNDim!=null&&s=0?i[l]:i[i.length+l];if(d!=null&&[d,null].indexOf(u)===-1)throw new B(`Input ${n} is incompatible with layer ${this.name}: expected axis ${l} of input shape to have value ${d} but got shape ${i}.`)}}if(r.shape!=null)for(let i=0;i{if(!this.built){this.assertInputCompatibility(e);let s=[];for(let i of ft(e))s.push(i.shape);this.build(Nn(s)),this.built=!0,this.initialWeights&&this.setWeights(this.initialWeights),this._refCount===null&&r&&(this._refCount=1)}if(this.assertInputCompatibility(e),r){let s=this.call(e,t),i=ft(s),o=[];for(let l of i)n.indexOf(l)!==-1&&(l=l.clone()),o.push(l);if(s=Nn(o),this.activityRegularizer!=null)throw new Oe("Layer invocation in the presence of activity regularizer(s) is not supported yet.");return s}else{let s=tae(e),i=this.computeOutputShape(s),o,l=nae(e);if(this.warnOnIncompatibleInputShape(Array.isArray(e)?s[0]:s),i!=null&&i.length>0&&Array.isArray(i[0])?o=i.map((d,u)=>new Sa(l,d,this,ft(e),t,this.name,u)):o=new Sa(l,i,this,ft(e),t,this.name),this.addInboundNode(e,o,null,null,s,i,t),this._refCount++,this.activityRegularizer!=null)throw new Oe("Layer invocation in the presence of activity regularizer(s) is not supported yet.");return o}})}warnOnIncompatibleInputShape(e){if(this.batchInputShape!=null)if(e.length!==this.batchInputShape.length)console.warn(`The rank of the input tensor provided (shape: ${JSON.stringify(e)}) does not match that of the batchInputShape (${JSON.stringify(this.batchInputShape)}) of the layer ${this.name}`);else{let t=!1;this.batchInputShape.forEach((n,a)=>{n!=null&&e[a]!=null&&e[a]!==n&&(t=!0)}),t&&console.warn(`The shape of the input tensor (${JSON.stringify(e)}) does not match the expectation of layer ${this.name}: ${JSON.stringify(this.batchInputShape)}`)}}get outputShape(){if(this.inboundNodes==null||this.inboundNodes.length===0)throw new ur(`The layer ${this.name} has never been called and thus has no defined output shape.`);let e=[];for(let t of this.inboundNodes){let n=JSON.stringify(t.outputShapes);e.indexOf(n)===-1&&e.push(n)}if(e.length===1){let t=this.inboundNodes[0].outputShapes;return Array.isArray(t)&&Array.isArray(t[0])&&t.length===1?t[0]:t}else throw new ur(`The layer ${this.name} has multiple inbound nodes with different output shapes. Hence the notion of "output shape" is ill-defined for the layer.`)}countParams(){if(!this.built)throw new wa(`You tried to call countParams() on ${this.name}, but the layer is not built yet. Build it first by calling build(batchInputShape).`);return Uh(this.weights)}build(e){this.built=!0}getWeights(e=!1){return Q1(e?this.trainableWeights:this.weights)}setWeights(e){W(()=>{let t=this.weights;if(t.length!==e.length)throw new B(`You called setWeights(weights) on layer "${this.name}" with a weight list of length ${e.length}, but the layer was expecting ${t.length} weights. Provided weights: ${e}...`);if(t.length===0)return;let n=[],a=Q1(t);for(let r=0;rr.apply(l.read())),s==null&&(s=!0),s?this._trainableWeights.push(l):this._nonTrainableWeights.push(l),l}setFastWeightInitDuringBuild(e){this.fastWeightInitDuringBuild=e}addLoss(e){e==null||Array.isArray(e)&&e.length===0||(e=ft(e),this._losses!==void 0&&this._losses!==null&&this.losses.push(...e))}computeOutputShape(e){return e}computeMask(e,t){if(!this.supportsMasking){if(t!=null)if(Array.isArray(t))t.forEach(n=>{if(n!=null)throw new TypeError(`Layer ${this.name} does not support masking, but was passed an inputMask.`)});else throw new TypeError(`Layer ${this.name} does not support masking, but was passed an inputMask.`);return null}return t}addInboundNode(e,t,n,a,r,s,i=null){let o=ft(e);t=ft(t),n=ft(n),a=ft(a),r=jh(r),s=jh(s);let l=[],d=[],u=[];for(let p of o)l.push(p.sourceLayer),d.push(p.nodeIndex),u.push(p.tensorIndex);new Hh({outboundLayer:this,inboundLayers:l,nodeIndices:d,tensorIndices:u,inputTensors:o,outputTensors:t,inputMasks:n,outputMasks:a,inputShapes:r,outputShapes:s},i);for(let p=0;pe.dispose()),this.weights.length}assertNotDisposed(){if(this._refCount===0)throw new Error(`Layer '${this.name}' is already disposed.`)}dispose(){if(!this.built)throw new Error(`Cannot dispose Layer ${this.name} because it has not been built yet.`);if(this._refCount===null)throw new Error(`Cannot dispose Layer ${this.name} because it has not been used yet.`);this.assertNotDisposed();let e=0;return--this._refCount==0&&(e=this.disposeWeights()),{refCountAfterDispose:this._refCount,numDisposedVariables:e}}};function tae(e){e=ft(e);let t=[];for(let n of e)t.push(n.shape);return Nn(t)}function nae(e){return"float32"}function K6(e,t,n){if((t==null||n!=null&&n>0)&&(t=e.sourceLayer,n=e.nodeIndex),t.inboundNodes.length===0)return[e];{let a=t.inboundNodes[n];if(a.inboundLayers.length===0)return a.inputTensors;{let r=[];for(let s=0;s0){let r=await Promise.all(t);for(let s=0;sse(this.totals[a],_(r,n)));this.totals[a]=i,s!=null&&s.dispose()}}}async onEpochEnd(e,t){if(t!=null)for(let n of this.params.metrics)this.totals[n]!=null&&(typeof this.totals[n]=="number"?t[n]=this.totals[n]/this.seen:W(()=>{let a=_(me(1,this.seen),this.totals[n]);t[n]=a,this.totals[n].dispose(),Ut(t[n])}))}},e4=class extends jl{async onTrainBegin(e){this.epoch=[],this.history={}}async onEpochEnd(e,t){t==null&&(t={}),this.epoch.push(e);for(let n in t)this.history[n]==null&&(this.history[n]=[]),this.history[n].push(t[n])}async syncData(){let e=[],t=[],n=[];for(let r in this.history){let s=this.history[r];for(let i=0;inew t4(n,t))}var ca=class{constructor(){}static registerCallbackConstructor(e,t){k.assert(e>=0&&Number.isInteger(e),()=>`Verbosity level is expected to be an integer >= 0, but got ${e}`),ca.checkForDuplicate(t),ca.constructors[e]==null&&(ca.constructors[e]=[]),ca.constructors[e].push(t)}static checkForDuplicate(e){for(let t in ca.constructors)ca.constructors[+t].forEach(n=>{if(n===e)throw new B("Duplicate callback constructor.")})}static clear(){ca.constructors={}}static createCallbacks(e){let t=[];for(let n in ca.constructors){let a=+n;e>=a&&t.push(...ca.constructors[a])}return t.map(n=>new n)}};ca.constructors={};function a4(e,t,n,a,r,s,i,o,l){let d=new e4,u=[new rae,...ca.createCallbacks(t)];e!=null&&u.push(...e),u.push(d);let p=new Q6(u);return p.setParams({epochs:n,initialEpoch:a,samples:r,steps:s,batchSize:i,verbose:t,doValidation:o,metrics:l}),{callbackList:p,history:d}}function Na(e,t={},n=!1){return Id(e,ae.SerializationMap.getMap().classNameMap,t,"layer",n)}function Gh(e,t){return W(()=>{e.dtype!=="float32"&&(e=e.asType("float32"));let n=ke(Cd(e),t,!0),a=Al(n.shape,Pt()),r=Qt(Pa(n,a));return me(e,r)})}function Fi(e,t){return W(()=>kt(Cd(ge(t,e)),-1))}function qh(e,t){return W(()=>kt(zt(ge(t,e)),-1))}function Ul(e,t){return W(()=>{let n=ge(e,t),a=In(zt(e),Pt(),Number.MAX_VALUE),r=zt(me(n,a));return _(100,kt(r,-1))})}function sae(e,t){return W(()=>{let n=In(t,Pt(),Number.MAX_VALUE),a=$n(se(1,n)),r=In(e,Pt(),Number.MAX_VALUE),s=$n(se(1,r));return kt(Cd(ge(a,s)),-1)})}function iae(e,t){return W(()=>{let n=Pa(0,ge(1,_(e,t)));return kt(Cd(n),-1)})}function oae(e,t){return W(()=>{let n=Pa(0,ge(1,_(e,t)));return kt(n,-1)})}function lae(e,t){return W(()=>{let n=ke(_(e,t),-1),a=Kn(_(ge(1,e),t),-1);return Pa(0,se(1,ge(a,n)))})}function uae(e,t){return W(()=>{let n=Math.log(2),a=ge(t,e),r=ge(se(a,fi(_(-2,a))),n);return kt(r,-1)})}function Fd(e,t,n=!1){return W(()=>{if(n)t=nd(t);else{let a=ke(t,t.shape.length-1,!0);t=me(t,a)}return t=In(t,Pt(),1-Pt()),wt(ke(_(e.toFloat(),$n(t)),t.shape.length-1))})}function Xh(e,t,n=!1){return W(()=>{let a=yl(Mte(e)).toInt();t=In(t,Pt(),1-Pt());let r=t.shape,s=ll(a,r[r.length-1]).reshape(r);return Fd(s,t,n)})}function dae(e,t){if(!k.arraysEqual(e.shape,t.shape))throw new B(`logits and labels must have the same shape, but got shapes ${JSON.stringify(e.shape)} and ${JSON.stringify(t.shape)}`);return W(()=>{let n=t.relu(),a=t.abs().neg();return n.sub(t.mul(e)).add(a.exp().log1p())})}function Kh(e,t){return W(()=>{let n;return n=In(t,Pt(),1-Pt()),n=$n(me(n,ge(1,n))),kt(dae(e,n),-1)})}function pae(e,t){return W(()=>{let n=In(e,Pt(),1),a=In(t,Pt(),1);return ke(_(e,$n(me(n,a))),-1)})}function cae(e,t){return W(()=>{let n=$n(se(Pt(),t));return kt(ge(t,_(e,n)),-1)})}function ty(e,t){return W(()=>{let n=Gh(e,-1),a=Gh(t,-1),r=_(n,a);return wt(ke(r,-1))})}var Zh={meanSquaredError:Fi,meanAbsoluteError:qh,meanAbsolutePercentageError:Ul,meanSquaredLogarithmicError:sae,squaredHinge:iae,hinge:oae,categoricalHinge:lae,logcosh:uae,categoricalCrossentropy:Fd,sparseCategoricalCrossentropy:Xh,binaryCrossentropy:Kh,kullbackLeiblerDivergence:pae,poisson:cae,cosineProximity:ty};function ny(e){if(typeof e=="string"){if(e in Zh)return Zh[e];let t=`Unknown loss ${e}`;throw e.toLowerCase().includes("softmaxcrossentropy")&&(t=`Unknown loss ${e}. Use "categoricalCrossentropy" as the string name for tf.losses.softmaxCrossEntropy`),new B(t)}else return e}function ay(e,t){return W(()=>{let n=_(.5,On(t)),a=Td(Fn(t,n),e.dtype);return kt(Fr(e,a),-1)})}function ry(e,t){return W(()=>Td(Fr(Uu(e,-1),Uu(t,-1)),"float32"))}function r4(e,t){return W(()=>la(e.equal(1),t.equal(1)).sum().cast("float32"))}function hae(e,t){return W(()=>la(e.equal(1),t.equal(0)).sum().cast("float32"))}function fae(e,t){return W(()=>la(e.equal(0),t.equal(1)).sum().cast("float32"))}function s4(e,t){return W(()=>{let n=r4(e,t),a=fae(e,t),r=n.add(a);return an(Fn(r,0),n.div(r),0).cast("float32")})}function mae(e,t){return W(()=>{let n=r4(e,t),a=hae(e,t),r=n.add(a);return an(Fn(r,0),n.div(r),0).cast("float32")})}function i4(e,t){return Kh(e,t)}function o4(e,t){return e.rank===t.rank&&(e=e.squeeze([e.rank-1])),t=t.argMax(-1),t.dtype!==e.dtype&&(t=t.asType(e.dtype)),Fr(e,t).asType("float32")}var Aae=Fi,yae=Fi,gae=qh,xae=qh,bae=Ul,vae=Ul,sy=Fd,wae=ty,l4=Xh,Yh={binaryAccuracy:ay,categoricalAccuracy:ry,precision:s4,categoricalCrossentropy:sy,sparseCategoricalCrossentropy:l4,mse:Aae,MSE:yae,mae:gae,MAE:xae,mape:bae,MAPE:vae,cosine:wae};function kae(e){if(typeof e=="string"&&e in Yh)return Yh[e];if(typeof e!="string"&&e!=null)return e;throw new B(`Unknown metric ${e}`)}function Jh(e){if(ja(e!==null,`Unknown LossOrMetricFn ${e}`),typeof e=="string")return e;{let t;for(let n of Object.keys(Zh))if(Zh[n]===e){t=n;break}if(t!==void 0)return t;for(let n of Object.keys(Yh))if(Yh[n]===e){t=n;break}return t!==void 0?t:e.name}}function Iae(e){let t={Adagrad:()=>gi.adagrad(.01),Adadelta:()=>gi.adadelta(1,.95,Pt()),Adam:()=>gi.adam(.001,.9,.999,Pt()),Adamax:()=>gi.adamax(.002,.9,.999,Pt(),0),RMSProp:()=>gi.rmsprop(.001,.9,0,Pt()),SGD:()=>gi.sgd(.01)};if(t.adagrad=t.Adagrad,t.adadelta=t.Adadelta,t.adam=t.Adam,t.adamax=t.Adamax,t.rmsprop=t.RMSProp,t.sgd=t.SGD,e in t)return t[e]();throw new B(`Unknown Optimizer ${e}`)}var u4=1*1024*1024;function d4(e,t,n=!1){if(e==null||typeof e!="object"||Object.getPrototypeOf(e)!==Object.prototype||!iy(e))throw new Error("User-defined metadata is expected to be a JSON object, but is not.");if(n){let a=JSON.stringify(e);a.length>u4&&console.warn(`User-defined metadata of model "${t}" is too large in size (length=${a.length} when serialized). It is not recommended to store such large objects in user-defined metadata. Please make sure its serialized length is <= ${u4}.`)}}function iy(e){if(e===null)return!0;if(typeof e=="object")if(Object.getPrototypeOf(e)===Object.prototype){let t=Object.keys(e);for(let n of t)if(typeof n!="string"||!iy(e[n]))return!1;return!0}else if(Array.isArray(e)){for(let t of e)if(!iy(t))return!1;return!0}else return!1;else{let t=typeof e;return t==="string"||t==="number"||t==="boolean"}}function Cae(e,t,n,a=console.log){let r=Nae(e),s=["Layer (type)","Output shape","Param #"];r?(t=t||65,n=n||[.45,.85,1]):(t=t||98,n=n||[.33,.55,.67,1]),n[n.length-1]<=1&&(n=n.map(u=>Math.floor(t*u)));let i;if(!r){s.push("Receives inputs"),i=[];for(let u in e.nodesByDepth)i.push(...e.nodesByDepth[u])}a("_".repeat(t)),Qh(s,n,a),a("=".repeat(t));let o=e.layers;for(let u=0;u1||r.length===1&&r[0].inboundLayers.length>1){t=!1;break}a.push(...r)}if(t)for(let r of e.layers){let s=!1;for(let i of r.inboundNodes)if(a.indexOf(i)!==-1)if(s){t=!1;break}else s=!0;if(!t)break}return t}function Qh(e,t,n=console.log){let a="";for(let r=0;r0&&(a=a.slice(0,a.length-1)+" "),a+=e[r],a=a.slice(0,t[r]),a+=" ".repeat(t[r]-a.length);n(a)}function Tae(e,t,n){let a;try{a=JSON.stringify(e.outputShape)}catch(o){a="multiple"}let r=e.name,s=e.getClassName(),i=[`${r} (${s})`,a,e.countParams().toString()];Qh(i,t,n)}function Eae(e,t,n,a){let r;try{r=JSON.stringify(e.outputShape)}catch(u){r="multiple"}let s=[];for(let u of e.inboundNodes)if(!(n!=null&&n.length>0&&n.indexOf(u)===-1))for(let p=0;pm.name),l=[],d=t.names();for(let m of o)d.indexOf(m)!==-1?l.push(t.getValue(m)):l.push(null);a!=null&&(a.maxNumTensors=-Infinity,a.minNumTensors=Infinity);let u=o.join(",")+"|"+t.names().join(","),p,c;if(uy[u]==null){let m=Mae(i,t);p=m.sorted,c=m.recipientCounts,uy[u]=p,c4[u]=c}p=uy[u],c={},r||Object.assign(c,c4[u]);let h=new $i(t);for(let m=0;ma.maxNumTensors&&(a.maxNumTensors=R),R0,()=>"Expected at least one fetch, got none");let n=[],a={};if(e.length===1){let r=h4(e[0],t);n=r.sorted,a=r.recipientMap}else{let r=new Set;for(let s of e){let{sorted:i,recipientMap:o}=h4(s,t);for(let l of i)r.has(l.name)||(n.push(l),r.add(l.name));for(let l in o)a[l]==null&&(a[l]=new Set),o[l].forEach(d=>a[l].add(d))}}return{sorted:n,recipientCounts:$ae(a)}}function $ae(e){let t={};for(let n in e)t[n]=e[n].size;return t}function h4(e,t){let n=new Set,a=[],r={};for(let o of t.names())n.add(o);let s=[],i=[];for(s.push(e);s.length>0;){let o=s[s.length-1];if(n.has(o.name)){s.pop();continue}let l=i[i.length-1]===s.length-1;if(o.inputs.length===0||l)s.pop(),a.push(o),n.add(o.name),l&&i.pop();else{i.push(s.length-1);for(let d of o.inputs)r[d.name]==null&&(r[d.name]=new Set),r[d.name].add(o.name),!n.has(d.name)&&s.push(d)}}return{sorted:a,recipientMap:r}}function Fae(e){let t;if(e.sourceLayer.inboundNodes.length===1)t=e.sourceLayer.output;else{let n=null;for(let a=0;ay.name)}`);Vr(this.outputs).length!==this.outputs.length&&console.warn(`The list of outputs passed to the model is redundant. All outputs should only appear once. Found: ${this.outputs.map(y=>y.name)}`),this.inputLayers=[],this.inputLayersNodeIndices=[],this.inputLayersTensorIndices=[],this.outputLayers=[],this.outputLayersNodeIndices=[],this.outputLayersTensorIndices=[],this.layers=[],this.internalContainerRefs=[];for(let y of this.outputs){let g=y.sourceLayer,x=y.nodeIndex,w=y.tensorIndex;this.outputLayers.push(g),this.outputLayersNodeIndices.push(x),this.outputLayersTensorIndices.push(w)}for(let y of this.inputs){let g=y.sourceLayer,x=y.nodeIndex,w=y.tensorIndex;ja(x===0,"input layer has >1 nodes"),ja(w===0,"input layer has >1 tensors"),this.inputLayers.push(g),this.inputLayersNodeIndices.push(x),this.inputLayersTensorIndices.push(w)}this.inputNames=[],this.outputNames=[],this.feedInputShapes=[],this.feedInputNames=[],this.feedOutputNames=[];for(let y=0;yy.shape),this.internalOutputShapes=this.outputs.map(y=>y.shape);let t={},n={},a={},r={},s={},i=[],o=(y,g,x,w,b,v)=>{(w==null||b==null||v==null)&&(w=y.sourceLayer,b=y.nodeIndex,v=y.tensorIndex);let N=w.inboundNodes[b];if(x.indexOf(N)!==-1)throw new wa(`The tensor ${y.name} at layer "${w.name}" is part of a cycle.`);if(g.indexOf(N)!==-1)return;this.containerNodes.add(Ga.nodeKey(w,b)),w.id in s||(s[w.id]=Object.keys(s).length),x.indexOf(N)===-1&&x.push(N);let T=N.inboundLayers.length;for(let R=0;R=0;)x.splice(x.indexOf(N),1);i.push(N)},l=[],d=[];for(let y of this.outputs)o(y,l,d);let u=i.slice().reverse();for(let y of u){n[y.id]=y,y.id in t||(t[y.id]=0);let g=t[y.id],x=a[y.outboundLayer.id]==null?0:a[y.outboundLayer.id];g=Math.max(g,x),a[y.outboundLayer.id]=g,r[y.outboundLayer.id]=y.outboundLayer,t[y.id]=g;for(let w=0;wparseInt(y,10)).sort(Mh);this.layers=[];for(let y of h){let g=c[y];g.sort((x,w)=>{let b=s[x.id],v=s[w.id];return bv?1:0});for(let x of g)x instanceof Ga&&this.internalContainerRefs.push(x),this.layers.push(x)}this.layersByDepth=c,h=Object.keys(p).map(y=>parseInt(y,10)).sort(Mh);let m=this.inputs.slice(),f=[];for(let y of h)for(let g of p[y]){let x=g.outboundLayer;if(x!=null){for(let w of g.inputTensors)if(m.indexOf(w)===-1)throw new wa(`Graph disconnected: cannot obtain value for tensor ${w} at layer "${x.name}". The following previous layers were accessed without issue: ${f}`);for(let w of g.outputTensors)m.push(w);f.push(x.name)}}this.nodesByDepth=p;let A=this.layers.map(y=>y.name);for(let y of A){let g=A.filter(x=>x===y).length;if(g!==1)throw new wa(`The name "${y}" is used ${g} times in the model. All layer names should be unique. Layer names: `+JSON.stringify(A))}this.outboundNodes=[],this.inboundNodes=[],new Hh({outboundLayer:this,inboundLayers:[],nodeIndices:[],tensorIndices:[],inputTensors:this.inputs,outputTensors:this.outputs,inputMasks:this.inputs.map(y=>null),outputMasks:this.outputs.map(y=>null),inputShapes:this.inputs.map(y=>y.shape),outputShapes:this.outputs.map(y=>y.shape)}),this.built=!0,this._refCount=1}assertNotDisposed(){if(this._refCount===0)throw new Error(`Container '${this.name}' is already disposed.`)}dispose(){this.assertNotDisposed();let e={refCountAfterDispose:null,numDisposedVariables:0};if(--this._refCount==0){for(let t of this.layers)e.numDisposedVariables+=t.dispose().numDisposedVariables;for(let t of this.internalContainerRefs)e.numDisposedVariables+=t.dispose().numDisposedVariables}return e.refCountAfterDispose=this._refCount,e}get trainable(){return this.trainable_}set trainable(e){this.layers.forEach(t=>{t._trainableWeights.forEach(n=>n.trainable=e)}),this.trainable_=e}get trainableWeights(){if(this._trainableWeights.length>0)throw new B("Container instance unexpectedly contains _trainableWeights.The trainable weights of a Container are a union of the trainable weights of its consituent Layers. Its own _trainableWeights must remain an empty Array.");if(!this.trainable)return[];let e=[];for(let t of this.layers)e=e.concat(t.trainableWeights);return e}get nonTrainableWeights(){let e=[];for(let t of this.layers)e.push(...t.nonTrainableWeights);if(!this.trainable){let t=[];for(let n of this.layers)t.push(...n.trainableWeights);return t.concat(e)}return e}get weights(){return this.trainableWeights.concat(this.nonTrainableWeights)}loadWeights(e,t=!0){let n={},a=0;for(let s of this.layers)for(let i of s.weights){if(n[i.originalName]!=null)throw new B(`Duplicate weight name: ${i.originalName}`);n[i.originalName]=i,a++}let r=[];for(let s in e){let i=s;if(n[s]==null){let o=s.split("/");i=o.slice(0,-2).concat([o[o.length-1]]).join("/")}if(n[i]!=null)r.push([n[i],e[s]]);else if(t)throw new B(`Provided weight data has no target variable: ${s}`);delete n[i]}if(t){let s=[];for(let i in n)s.push(i);if(s.length>0)throw new B(`${s.length} of ${a} weights are not set: ${s}`)}ey(r)}updatedConfig(){let e=this.getConfig(),t={};return t.className=this.getClassName(),t.config=e,t.kerasVersion=`tfjs-layers ${ly}`,t.backend="TensorFlow.js",t}toJSON(e,t=!0){let n=oy(this.updatedConfig());return t?JSON.stringify(n):n}call(e,t){return W(()=>{e=ft(e);let n=new $i;for(let a=0;a{e=ft(e);let n;return t==null?n=Ti(null,e.length):n=ft(t),this.runInternalGraph(e,n)[1]})}computeOutputShape(e){let t=jh(e);if(t.length!==this.inputLayers.length)throw new B(`Invalid inputShape argument ${e}: model has ${this.inputLayers.length} tensor inputs.`);let n={};for(let i=0;iparseInt(i,10)).sort(Mh);if(a.length>1)for(let i of a){let o=this.nodesByDepth[i];for(let l of o){let d=l.outboundLayer;if(this.inputLayers.map(m=>m.id).indexOf(d.id)!==-1)continue;let u=[];for(let m=0;mparseInt(o,10)).sort(Mh);for(let o of a){let l=this.nodesByDepth[o];for(let d of l){let u=d.outboundLayer,p=d.inputTensors,c=d.outputTensors,h=new Array;for(let m of p)m.id in n&&h.push(n[m.id]);if(h.length===p.length){let m={},f,A,y,g;if(d.callArgs!=null&&(m=d.callArgs),h.length===1){let[x,w]=h[0];m.mask==null&&(m.mask=w),y=ft(u.call(x,m)),g=ft(u.computeMask(x,w)),f=[x],A=[w]}else f=h.map(x=>x[0]),A=h.map(x=>x[1]),m.mask==null&&(m.mask=A),y=ft(u.call(f,m)),g=ft(u.computeMask(f,A));if(u.activityRegularizer)throw new Oe("LayersModel invocation with concrete Tensor value(s) in the presence of activity regularizer(s) is not supported yet.");for(let x=0;x{let e=[];for(let t of this.layers)for(let n=0;n0){let m=[];for(let f=0;f0&&f.apply(Nn(y),g)}function l(f){let A=f.name,y=Na(f,t.customObjects!=null?t.customObjects:{});y.setFastWeightInitDuringBuild(a),r[A]=y,f.inboundNodes.forEach(g=>{if(!(g instanceof Array))throw new B(`Corrupted configuration, expected array for nodeData: ${g}`);i(y,g)})}let d=t.name,u=t.layers;for(let f of u)l(f);for(;!rte(s);)for(let f of u){let A=r[f.name];if(A.name in s){let y=s[A.name];delete s[A.name];for(let g of y)o(A,g)}}let p=[],c=[],h=t.inputLayers;for(let f of h){let A=f[0],y=f[1],g=f[2];ja(A in r);let x=r[A].inboundNodes[y].outputTensors;p.push(x[g])}let m=t.outputLayers;for(let f of m){let A=f[0],y=f[1],g=f[2];ja(A in r);let x=r[A].inboundNodes[y].outputTensors;c.push(x[g])}return new e({inputs:p,outputs:c,name:d})}get stateful(){if(this._stateful)throw new B("Container instance unexpectedly has _stateful = true. The statefulness of a Container is determined by the Layers it contains. Its _stateful property must remain the default false.");for(let e of this.layers)if(e.stateful)return!0;return!1}resetStates(){W(()=>{this.layers.forEach(e=>{e.stateful&&e.resetStates()})})}};function Dae(e,t,n){let a=t.length;if(e==null||Array.isArray(e)&&e.length===0)return t.map(r=>null);if(a===1)return Array.isArray(e)&&e.length===1?e:typeof e=="object"&&t[0]in e?[e[t[0]]]:[e];if(Array.isArray(e)){if(e.length!==a)throw new Error(`Provided ${n} is an array of ${e.length} element(s), but the model has ${a} outputs. Make sure a set of weights is provided for each model output.`);return e}else if(typeof e=="object"&&Object.keys(e).length>0&&typeof e[Object.keys(e)[0]]=="object"){let r=[];return t.forEach(s=>{s in e?r.push(e[s]):r.push(null)}),r}else throw new Error(`The model has multiple (${a}) outputs, so ${n} must be either an array with ${a} elements or an object with ${t} keys. Provided ${n} not understood: ${JSON.stringify(e)}`)}function f4(e,t){return Dae(e,t,"classWeight")}async function m4(e,t,n,a){if(t!=null||a!=null)throw new Error("Support sampleWeight is not implemented yet");if(n!=null){let r=W(()=>{if(e.shape.length===1)return e.clone();if(e.shape.length===2)if(e.shape[1]>1){let o=1;return e.argMax(o)}else{if(e.shape[1]===1)return e.reshape([e.shape[0]]);throw new Error(`Encountered unexpected last-dimension size (${e.shape[1]}) during handling of class weights. The size is expected to be >= 1.`)}else throw new Error(`Unexpected rank of target (y) tensor (${e.rank}) during handling of class weights. The rank is expected to be 1 or 2.`)}),s=Array.from(await r.data());Ee(r);let i=[];return s.forEach(o=>{if(n[o]==null)throw new Error(`classWeight must contain all classes in the training data. The class ${o} exists in the data but not in classWeight`);i.push(n[o])}),Et(i,"float32")}else return null}function Oae(e,t){return _(e,t)}var zae=32;function y4(e,t){let n,a,r=t;n=r.xs,a=r.ys,k.assert(n!=null&&a!=null,()=>`A Dataset iterator for fitDataset() is expected to generate objects of the form \`{xs: xVal, ys: yVal}\`, where the two values may be \`tf.Tensor\`, an array of Tensors, or a map of string to Tensor. The provided Dataset instead generates ${t}`);let s=A4("input",e.inputNames,n),i=A4("output",e.outputNames,a),o=s[0].shape[0];k.assert(s.length===e.inputs.length,()=>`LayersModel has ${e.inputs.length} inputs, but the dataset provides ${s.length} inputs. (Expected input keys: ${JSON.stringify(e.inputNames)})`),k.assert(i.length===e.outputs.length,()=>`LayersModel has ${e.outputs.length} outputs, but the dataset provides ${i.length} outputs. (Expected output keys: ${JSON.stringify(e.outputNames)})`);for(let l=0;l`Batch size mismatch: input ${e.inputNames[l]} has ${s[l].shape[0]}; expected ${o} based on input ${e.inputNames[0]}.`);for(let l=0;l`Batch size mismatch: output ${e.outputNames[l]} has ${i[l].shape[0]}; expected ${o} based on input ${e.inputNames[0]}.`);return{xs:s,ys:i}}function A4(e,t,n){if(n instanceof Le)return[n];if(Array.isArray(n))return k.assert(n.length===t.length,()=>`Received an array of ${n.length} Tensors, but expected ${t.length} to match the ${e} keys ${t}.`),n;{let a=[];for(let r of t){if(n[r]==null)throw new B(`The feature data generated by the dataset lacks the required ${e} key '${r}'.`);a.push(n[r])}return a}}function _ae(e){if(e.length===3)throw new Oe("Validation with sample weights is not implemented yet.");return{xs:e[0],ys:e[1]}}async function Lae(e,t,n){let a=n.batchesPerEpoch!=null;if(k.assert(e.optimizer!=null,()=>"You must compile a model before training/testing. Use LayersModel.compile(modelCompileConfig)."),k.assert(n!=null,()=>"For fitDataset(), the 2nd argument (config) is required, but it is not provided in this call."),k.assert(n.epochs!=null&&n.epochs>0&&Number.isInteger(n.epochs),()=>`For fitDataset(), config.epochs is expected to be a positive integer, but got ${n.epochs}`),k.assert(!a||n.batchesPerEpoch>0&&Number.isInteger(n.batchesPerEpoch),()=>`For fitDataset(), config.batchesPerEpoch is expected to be a positive integer if specified, but got ${n.batchesPerEpoch}`),k.assert(n.validationSplit==null,()=>"`validationSplit` is not supported by `fitDataset()`. Use validationData instead."),e.isTraining)throw new Error("Cannot start training because another fit() call is ongoing.");e.isTraining=!0;try{let r=n.validationData!=null,s,i;if(r)if(g4(n.validationData))k.assert(n.validationBatches==null||n.validationBatches>0&&Number.isInteger(n.validationBatches),()=>`For fitDataset() with dataset-based validation, config.validationBatches is expected not to be provided, or to be a positive integer, but got ${n.validationBatches}`);else{let A=_ae(n.validationData);s=A.xs,i=A.ys}let o=e.makeTrainFunction(),l=e.getDedupedMetricsNames(),d;r?d=l.slice().concat(l.map(A=>"val_"+A)):d=l.slice();let u=n4(n.callbacks,n.yieldEvery),p=n.verbose==null?1:n.verbose,{callbackList:c,history:h}=a4(u,p,n.epochs,null,null,Pae(t,n),null,r,d);c.setModel(e),e.history=h,await c.onTrainBegin(),e.stopTraining_=!1;let m=n.initialEpoch==null?0:n.initialEpoch,f=await t.iterator();for(;m=n.batchesPerEpoch:x.done){if(r){let w;g4(n.validationData)?w=ft(await e.evaluateDataset(n.validationData,{batches:n.validationBatches})):w=ft(e.evaluate(s,i,{batchSize:n.validationBatchSize==null?zae:n.validationBatchSize,verbose:0}));for(let b=0;b0)throw new Oe("Verbose mode is not implemented yet.");k.assert(!a||n.batches>0&&Number.isInteger(n.batches),()=>`Test loop expects \`batches\` to be a positive integer, but received ${JSON.stringify(n.batches)}`);let i=Wae(t)?t:await t.iterator(),o=0,l=0;for(;a?l{if(d.value){let{xs:u,ys:p}=y4(e,d.value),c=u.concat(p),h=W(()=>r(c));if(Ee(c),l===0)for(let f=0;fse(s[f],_(m,A))),l>0&&Ee(y)}Ee(h),o+=m,++l}return s}),d.done){a&&console.warn(`Your dataset iterator ran out of data during evaluateDataset(). Interrupting evalution. Make sure that your dataset can generate at least \`batches\` batches (in this case, ${n.batches} batches). You may need to use the repeat() function when building your dataset.`);break}}for(let d=0;d0&&Number.isInteger(e),()=>`batchSize is required to be a positive integer, but got ${e}`)}function Od(e,t,n){return e==null?[null]:Array.isArray(e)?e.map(a=>Mi(a,t,n-t)):Mi(e,t,n-t)}function py(e,t){return W(()=>e==null?null:Array.isArray(e)?e.map(n=>py(n,t)):z6(e,t.dtype==="int32"?t:t.toInt()))}function cy(e,t){let n=[],a=0,r=null;for(;a=e&&(r=e),n.push([a,r]),a=r;return n}async function Vae(e,t,n,a,r,s,i,o,l,d,u,p,c,h,m){r==null&&(r=32),s==null&&(s=1),u==null&&(u=!0),c==null&&(c=0);let f=!1;if(l!=null&&d!=null&&(f=!0),m!=null&&(f=!0,h==null))throw new B("Can only use `validationSteps` when doing step-wise training, i.e., `stepsPerEpoch` must be set.");let A=e.checkNumSamples(n,r,h,"steps_per_epoch"),y;A!=null&&(y=ka(0,A)),i==null&&(i=1);let{callbackList:g,history:x}=a4(o,i,s,c,A,h,r,f,p);g.setModel(e),e.history=x,await g.onTrainBegin(),e.stopTraining_=!1;for(let w=c;w{let $=N[T][0],z=N[T][1],P=Mi(v,$,z-$);R.batch=T,R.size=z-$;let V=py(n,P),j=t(V);for(let U=0;U0){if(m=!0,a.validationData.length===2)i=a.validationData[0],o=a.validationData[1];else throw a.validationData.length===3?new Oe("validationData including sample weights is not supported yet."):new B(`When passing validation data, it must contain 2 (valX, valY) or 3 (valX, valY, valSampleWeight) items; ${a.validationData} is invalid.`);let v=!0,N=await e.standardizeUserData(i,o,null,null,v,p);l=N[0],d=N[1],f=l.concat(d)}else if(a.validationSplit!=null&&a.validationSplit>0&&a.validationSplit<1){m=!0;let v=Math.floor(r[0].shape[0]*(1-a.validationSplit)),N=r[0].shape[0];l=Od(r,v,N),r=Od(r,0,v),d=Od(s,v,N),s=Od(s,0,v),f=l.concat(d)}else a.validationSteps!=null&&(m=!0);let A=r.concat(s).concat(u);e.checkTrainableWeightsConsistency();let y=e.makeTrainFunction(),g=e.getDedupedMetricsNames(),x,w;m?(e.makeTestFunction(),x=e.testFunction,w=g.slice().concat(g.map(v=>"val_"+v))):(x=null,f=[],w=g.slice());let b=n4(a.callbacks,a.yieldEvery);return await Vae(e,y,A,g,p,a.epochs,a.verbose,b,x,f,a.shuffle,w,a.initialEpoch,null,null)}finally{e.isTraining=!1,Di(r,t),Di(s,n),Di(l,i),Di(d,o),u!=null&&Ee(u)}}function x4(e){let t=[];e instanceof Le&&(e=[e]);for(let n=0;nn.push(r.id));else if(t!=null)for(let r in t){let s=t[r];n.push(s.id)}let a=[];if(e instanceof Le)n.indexOf(e.id)===-1&&a.push(e);else if(Array.isArray(e))e.forEach(r=>{n.indexOf(r.id)===-1&&a.push(r)});else if(e!=null)for(let r in e){let s=e[r];n.indexOf(s.id)===-1&&a.push(s)}a.forEach(r=>{r.isDisposed||r.dispose()})}function Uae(e){return e instanceof Le}function hy(e){return Array.isArray(e)}function b4(e){return!Uae(e)&&!hy(e)}function v4(e,t,n,a=!0,r=""){if(t==null||t.length===0){if(e!=null){let i=!1;if(hy(e)&&e.length>0)i=!0;else if(b4(e)){for(let o in e)if(e.hasOwnProperty(o)){i=!0;break}}else i=!0;if(i)throw new B(`Error when checking model ${r} expected no data, but got ${e}`)}return[]}if(e==null)return t.map(i=>null);let s;if(b4(e)){e=e,s=[];for(let i of t){if(e[i]==null)throw new B(`No data provided for "${i}". Need data for each key in: ${t}`);s.push(e[i])}}else if(hy(e)){if(e=e,e.length!==t.length)throw new B(`Error when checking model ${r}: the Array of Tensors that you are passing to your model is not the size the model expected. Expected to see ${t.length} Tensor(s), but instead got the following list of Tensor(s): ${e}`);s=e}else{if(e=e,t.length>1)throw new B(`The model ${r} expects ${t.length} Tensor(s), but only received one Tensor. Found: Tensor with shape ${e.shape}`);s=[e]}if(s=x4(s),n!=null)for(let i=0;i=0&&d!==u)throw new B(`Error when checking ${r}: expected ${t[i]} to have shape [${n[i]}], but got array with shape [${o.shape}].`)}}return s}function Hae(e,t,n){let a=Vr(e.map(s=>s.shape[0]));a.sort();let r=Vr(t.map(s=>s.shape[0]));if(r.sort(),a.length>1)throw new B(`All input Tensors (x) should have the same number of samples. Got array shapes: ${JSON.stringify(e.map(s=>s.shape))}`);if(r.length>1)throw new B(`All target Tensors (y) should have the same number of samples. Got array shapes: ${JSON.stringify(t.map(s=>s.shape))}`);if(a.length>0&&r.length>0&&!k.arraysEqual(a,r))throw new B(`Input Tensors should have the same number of samples as target Tensors. Found ${a[0]} input sample(s) and ${r[0]} target sample(s).`)}function Gae(e,t,n){let a=[Fi,Kh,Fd];for(let r=0;r1)throw new B(`The model expects ${t.length} ${r} Tensors, but only received one Tensor. Found: array with shape ${JSON.stringify(e.shape)}.`);s=[e]}if(n!=null)for(let i=0;i[]);let n;if(typeof e=="string"||typeof e=="function")n=[e];else if(Array.isArray(e)||typeof e=="object")n=e;else throw new TypeError(`Type of metrics argument not understood. Expected an string,function, Array, or Object, found: ${e}`);if(Array.isArray(n))return t.map(a=>n);{let a=[];for(let r of t){let s=n.hasOwnProperty(r)?n[r]:[];Array.isArray(s)||(s=[s]),a.push(s)}return a}}var Xae="layers-model",pr=class extends Ga{constructor(e){super(e);this.isTraining=!1}summary(e,t,n=console.log){if(!this.built)throw new B("This model has never been called, thus its weights have not been created yet. So no summary can be displayed. Build the model first (e.g., by calling it on some test data).");Cae(this,e,t,n)}compile(e){if(e.loss==null&&(e.loss=[]),this.loss=e.loss,typeof e.optimizer=="string")this.optimizer_=Iae(e.optimizer),this.isOptimizerOwned=!0;else{if(!(e.optimizer instanceof or))throw new B("User-defined optimizer must be an instance of tf.Optimizer.");this.optimizer_=e.optimizer,this.isOptimizerOwned=!1}let t=[];if(!Array.isArray(e.loss)&&typeof e.loss!="string"&&typeof e.loss!="function"){e.loss=e.loss;for(let s in e.loss)if(this.outputNames.indexOf(s)===-1)throw new B(`Unknown entry in loss dictionary: "${s}". Only expected the following keys: ${this.outputNames}`);for(let s of this.outputNames)e.loss[s]==null&&console.warn(`Output "${s}" is missing from loss dictionary. We assume this was done on purpose, and we will not be expecting data to be passed to ${s} during training`),t.push(ny(e.loss[s]))}else if(Array.isArray(e.loss)){if(e.loss.length!==this.outputs.length)throw new B(`When passing an Array as loss, it should have one entry per model output. The model has ${this.outputs.length} output(s), but you passed loss=${e.loss}.`);t=e.loss.map(s=>ny(s))}else{let s=ny(e.loss);this.outputs.forEach(i=>{t.push(s)})}this.lossFunctions=t,this.feedOutputNames=[],this.feedOutputShapes=[],this.feedLossFns=[];for(let s=0;s{for(let s=0;s1&&(this.metricsTensors.push([i,s]),this.metricsNames.push(this.outputNames[s]+"_loss"))}});let a=qae(e.metrics,this.outputNames),r=(s,i,o)=>{this.outputNames.length>1&&(i=this.outputNames[s]+"_"+i),this.metricsNames.push(i),this.metricsTensors.push([o,s])};Ri("metric",()=>{for(let s=0;s{let l="",d,u,p;for(let c of o){if(typeof c=="string"&&["accuracy","acc","crossentropy","ce"].indexOf(c)!==-1){let m=this.internalOutputShapes[s];m[m.length-1]===1||this.lossFunctions[s]===Kh?["accuracy","acc"].indexOf(c)!==-1?u=ay:["crossentropy","ce"].indexOf(c)!==-1&&(u=i4):this.lossFunctions[s]===Xh?["accuracy","acc"].indexOf(c)!==-1?u=o4:["crossentropy","ce"].indexOf(c)!==-1&&(u=l4):["accuracy","acc"].indexOf(c)!==-1?u=ry:["crossentropy","ce"].indexOf(c)!==-1&&(u=sy);let f;["accuracy","acc"].indexOf(c)!==-1?f="acc":["crossentropy","ce"].indexOf(c)!==-1&&(f="ce"),p=u,d=l+f}else p=kae(c),d=l+Jh(c);let h;Ri(d,()=>{h=p}),r(s,d,h)}})(i)}}),this.collectedTrainableWeights=this.trainableWeights}checkTrainableWeightsConsistency(){this.collectedTrainableWeights!=null&&this.trainableWeights.length!==this.collectedTrainableWeights.length&&console.warn("Discrepancy between trainableweights and collected trainable weights. Did you set `model.trainable` without calling `model.compile()` afterwards?")}evaluate(e,t,n={}){let a=n.batchSize==null?32:n.batchSize;dy(a);let r=!0,s=this.standardizeUserDataXY(e,t,r,a);try{let i=s[0].concat(s[1]);this.makeTestFunction();let o=this.testFunction,l=this.testLoop(o,i,a,n.verbose,n.steps);return Nn(l)}finally{Di(s[0],e),Di(s[1],t)}}async evaluateDataset(e,t){return this.makeTestFunction(),Bae(this,e,t)}checkNumSamples(e,t,n,a="steps"){let r;if(n!=null){if(r=null,t!=null)throw new B(`If ${a} is set, batchSize must be null or undefined.Got batchSize = ${t}`)}else if(e!=null)Array.isArray(e)?r=e[0].shape[0]:r=e.shape[0];else throw new B(`Either the input data should have a defined shape, or ${a} shoud be specified.`);return r}execute(e,t){if(Array.isArray(t)&&t.length===0)throw new B("`outputs` is an empty Array, which is not allowed.");let n=Array.isArray(t),a=n?t:[t],r=this.retrieveSymbolicTensors(a),s=new $i;if(e instanceof Le&&(e=[e]),Array.isArray(e)){if(e.length!==this.inputs.length)throw new B(`The number of inputs provided (${e.length}) does not match the number of inputs of this model (${this.inputs.length}).`);for(let o=0;oi.name);for(let i=0;i0){let a=[];throw t.forEach((r,s)=>{r==null&&a.push(e[s])}),new B(`Cannot find SymbolicTensors for output name(s): ${JSON.stringify(a)}`)}return t}predictLoop(e,t=32,n=!1){return W(()=>{let a=this.checkNumSamples(e);if(n)throw new Oe("Verbose predictLoop() is not implemented yet.");let r=cy(a,t),s=this.outputs.map(i=>[]);for(let i=0;i{let o=r[i][0],l=r[i][1],d=Od(e,o,l),u=[];if(Array.isArray(d))for(let c=0;cs[l].push(o));return Nn(s.map(i=>ot(i,0)))})}predict(e,t={}){let n=x4(e);w4(n,this.inputNames,this.feedInputShapes,!1);try{let a=t.batchSize==null?32:t.batchSize;return dy(a),this.predictLoop(n,a)}finally{Di(n,e)}}predictOnBatch(e){w4(e,this.inputNames,this.feedInputShapes,!0);let t=(Array.isArray(e)?e[0]:e).shape[0];return this.predictLoop(e,t)}standardizeUserDataXY(e,t,n=!0,a){if(this.optimizer_==null)throw new wa("You must compile a model before training/testing. Use LayersModel.compile(modelCompileArgs).");let r=[];for(let s=0;s0&&e[0].shape[0]%a!=0)throw new B(`In a stateful network, you should only pass inputs with a number of samples that is divisible by the batch size ${a}. Found: ${e[0].shape[0]} sample(s).`);return[e,t]}async standardizeUserData(e,t,n,a,r=!0,s){let[i,o]=this.standardizeUserDataXY(e,t,r,s);if(n!=null)throw new Error("sample weight is not supported yet.");let l=null;if(a!=null){let d=f4(a,this.outputNames);l=[];for(let u=0;u{let s=this.checkNumSamples(t,n,r,"steps"),i=[];if(a>0)throw new Oe("Verbose mode is not implemented yet.");if(r!=null)throw new Oe("steps mode in testLoop() is not implemented yet");{let o=cy(s,n),l=Et(ka(0,s));for(let d=0;d1&&(r+=`_${k6(e.slice(0,n),a)}`),t.push(r)}return t}makeTrainFunction(){return e=>{let t=[],n=e.slice(0,this.inputs.length),a=e.slice(this.inputs.length,this.inputs.length+this.outputs.length),r=e.slice(this.inputs.length+this.outputs.length,this.inputs.length+this.outputs.length*2),s=[],i=()=>{let d=[];for(let h=0;h1&&h{c=se(c,h)}),c},o=this.collectedTrainableWeights.map(d=>d.read()),l=!0;return[this.optimizer_.minimize(i,l,o)].concat(s)}}makeTestFunction(){this.testFunction=e=>W(()=>{let t=[],n,a=e.slice(0,this.inputs.length),r=e.slice(this.inputs.length,this.inputs.length+this.outputs.length),s=[];for(let l=0;ldr(t))}else{let t=Object.keys(this.loss);e={};let n=this.loss;for(let a of t)if(typeof n[a]=="string")e[a]=dr(n[a]);else throw new Error("Serialization of non-string loss is not supported.")}return e}getMetricIdentifiers(){if(typeof this.metrics=="string"||typeof this.metrics=="function")return[dr(Jh(this.metrics))];if(Array.isArray(this.metrics))return this.metrics.map(e=>dr(Jh(e)));{let e={};for(let t in this.metrics)e[t]=dr(Jh(this.metrics[t]));return e}}getTrainingConfig(){return{loss:this.getLossIdentifiers(),metrics:this.getMetricIdentifiers(),optimizer_config:{class_name:this.optimizer.getClassName(),config:this.optimizer.getConfig()}}}loadTrainingConfig(e){if(e.weighted_metrics!=null)throw new Error("Loading weight_metrics is not supported yet.");if(e.loss_weights!=null)throw new Error("Loading loss_weights is not supported yet.");if(e.sample_weight_mode!=null)throw new Error("Loading sample_weight_mode is not supported yet.");let t=$d(e.optimizer_config),n=Na(t),a;if(typeof e.loss=="string")a=Ei(e.loss);else if(Array.isArray(e.loss))a=e.loss.map(s=>Ei(s));else if(e.loss!=null){a={};for(let s in e.loss)a[s]=Ei(e.loss[s])}let r;if(Array.isArray(e.metrics))r=e.metrics.map(s=>Ei(s));else if(e.metrics!=null){r={};for(let s in e.metrics)r[s]=Ei(e.metrics[s])}this.compile({loss:a,metrics:r,optimizer:n})}async save(e,t){if(typeof e=="string"){let i=wn.getSaveHandlers(e);if(i.length===0)throw new B(`Cannot find any save handlers for URL '${e}'`);if(i.length>1)throw new B(`Found more than one (${i.length}) save handlers for URL '${e}'`);e=i[0]}if(e.save==null)throw new B("LayersModel.save() cannot proceed because the IOHandler provided does not have the `save` attribute defined.");let n=await wn.encodeWeights(this.getNamedWeights(t)),a=!1,r=null,s={modelTopology:this.toJSON(r,a),format:Xae,generatedBy:`TensorFlow.js tfjs-layers v${ly}`,convertedBy:null};if((t==null?!1:t.includeOptimizer)&&this.optimizer!=null){s.trainingConfig=this.getTrainingConfig();let i="optimizer",{data:o,specs:l}=await wn.encodeWeights(await this.optimizer.getWeights(),i);n.specs.push(...l),n.data=wn.concatenateArrayBuffers([n.data,o])}if(this.userDefinedMetadata!=null){let i=!0;d4(this.userDefinedMetadata,this.name,i),s.userDefinedMetadata=this.userDefinedMetadata}return s.weightData=n.data,s.weightSpecs=n.specs,e.save(s)}setUserDefinedMetadata(e){d4(e,this.name),this.userDefinedMetadata=e}getUserDefinedMetadata(){return this.userDefinedMetadata}};pr.className="Model";ae.registerClass(pr);var k4=class extends pr{};k4.className="Functional";ae.registerClass(k4);async function Kae(e,t){"modelTopology"in e||(e={modelTopology:e}),e=e;let n=e.modelTopology;n.model_config!=null&&(n=n.model_config);let a=$d(n),r=Na(a,t);if(e.weightsManifest!=null){let s=await wn.loadWeights(e.weightsManifest,e.pathPrefix,r.weights.map(o=>o.originalName)),i={};for(let o of r.weights)i[o.originalName]=s[o.originalName];r.loadWeights(i),Ee(s)}return r}async function Yae(e,t){if(t==null&&(t={}),typeof e=="string"){let n=wn.getLoadHandlers(e,t);if(n.length===0)n.push(wn.browserHTTPRequest(e,t));else if(n.length>1)throw new B(`Found more than one (${n.length}) load handlers for URL '${e}'`);e=n[0]}return Zae(e,void 0,t)}async function Zae(e,t,n){if(n==null&&(n={}),e.load==null)throw new B("Cannot proceed with model loading because the IOHandler provided does not have the `load` method implemented.");let a=await e.load(),r=a.modelTopology;r.model_config!=null&&(r=r.model_config);let s=n.strict==null?!0:n.strict,i=a.weightData!=null&&a.weightSpecs!=null&&s,o=Na($d(r),t,i),l=a.trainingConfig;if(l!=null&&o.loadTrainingConfig(l),a.userDefinedMetadata!=null&&o.setUserDefinedMetadata(a.userDefinedMetadata),a.weightData!=null){if(a.weightSpecs==null)throw new B("LayersModel artifacts contains weight data, but not weight specs. Therefore loading of weights cannot proceed.");let{modelWeights:d,optimizerWeights:u}=Jae(a.weightData,a.weightSpecs);o.loadWeights(d,s),o.optimizer!=null&&u.length>0&&await o.optimizer.setWeights(u),Ee(d),Ee(u.map(p=>p.tensor))}return o}function Jae(e,t){let n=wn.decodeWeights(e,t),a={},r=[];return t.forEach(s=>{s.group==="optimizer"?r.push({name:s.name,tensor:n[s.name]}):a[s.name]=n[s.name]}),{modelWeights:a,optimizerWeights:r}}var Hl=class extends pr{constructor(e){super({inputs:[],outputs:[]});if(e=e||{},this.trainable=!0,this.built=!1,this.name=e.name!=null?e.name:Vh("sequential_"),e.layers!=null)for(let t of e.layers)this.add(t)}checkShape(e){if(e.inboundNodes[0].outputTensors[0].shape.some(t=>t<0))throw new B(`Negative dimension size caused by adding layer ${e.name} with input shape [${e.inboundNodes[0].inputTensors[0].shape}]`)}add(e){let t=e instanceof Hl||e instanceof pr,n;if(t){if(n=e,n.outputs.length!==1)throw new B("All layers in a Sequential model should have a single output tensor. For multi-output layers, use the functional API.");if(n.inputs.length!==1)throw new B("All layers in a Sequential model should have a single input tensor. For multi-input layers, use the functional API.")}if(this.outputs.length===0){if(e.inboundNodes.length===0){if(e.batchInputShape==null)throw new B("The first layer in a Sequential model must get an `inputShape` or `batchInputShape` argument.");let a=Z6({batchShape:e.batchInputShape,dtype:e.dtype,name:e.name+"_input"});e.apply(a)}if(t)this.outputs=n.outputs,this.inputs=n.inputs;else{if(e.inboundNodes.length!==1)throw new B(`A layer added to a Sequential model must not already be connected somewhere else. LayersModel received layer ${e.name} which has ${e.inboundNodes.length} pre-existing inbound connections.`);if(e.inboundNodes[0].outputTensors.length!==1)throw new B("All layers in a Sequential model should have a single output tensor. For multi-output layers, use the functional API.");this.checkShape(e),this.outputs=[e.inboundNodes[0].outputTensors[0]],this.inputs=K6(this.outputs[0])}this.inboundNodes=[],new Hh({outboundLayer:this,inboundLayers:[],nodeIndices:[],tensorIndices:[],inputTensors:this.inputs,outputTensors:this.outputs,inputMasks:Ti(null,this.inputs.length),outputMasks:[null],inputShapes:this.inputs.map(a=>a.shape),outputShapes:this.outputs[0].shape})}else{let a=e.apply(this.outputs[0]);if(Array.isArray(a))throw new TypeError("All layers in a Sequential model should have a single output tensor. For multi-output layers, use the functional API.");this.checkShape(e),this.outputs=[a],this.inboundNodes[0].outputTensors=this.outputs,this.inboundNodes[0].outputShapes=[this.outputs[0].shape]}this.layers.push(e),this.built=!1}pop(){if(this.layers.length===0)throw new TypeError("There are no layers in the model.");if(this.layers.pop(),this.layers.length===0)this.outputs=[],this.inboundNodes=[],this.outboundNodes=[];else{let e=this.layers.length-1;this.layers[e].outboundNodes=[],this.outputs=[this.layers[e].output],this.inboundNodes[0].outputTensors=this.outputs,this.inboundNodes[0].outputShapes=[this.outputs[0].shape]}}call(e,t){return this.model==null&&this.build(),this.model.call(e,t)}build(e){if(at(e),this.inputs.length===0||this.outputs.length===0)throw new TypeError("Sequential model cannot be built: model is empty. Add some layers first.");this.model=new pr({inputs:this.inputs,outputs:this.outputs[0],name:this.name+"_model"}),this.model.trainable=this.trainable,this.supportsMasking=this.model.supportsMasking,this.inputLayers=this.model.inputLayers,this.inputLayersNodeIndices=this.model.inputLayersNodeIndices,this.inputLayersTensorIndices=this.model.inputLayersTensorIndices,this.outputLayers=this.model.outputLayers,this.outputLayersNodeIndices=this.model.outputLayersNodeIndices,this.outputLayersTensorIndices=this.model.outputLayersTensorIndices,this.nodesByDepth=this.model.nodesByDepth,this.containerNodes=this.model.containerNodes,this.outputNames=this.model.outputNames,this.inputNames=this.model.inputNames,this.built=!0}countParams(){return this.built||this.build(),super.countParams()}summary(e,t,n=console.log){this.built||this.build(),super.summary(e,t,n)}setWeights(e){this.model==null&&this.build(),this.model.setWeights(e)}evaluate(e,t,n={}){if(!this.built)throw new wa("The model needs to be compiled before being used.");return this.model.evaluate(e,t,n)}async evaluateDataset(e,t){if(!this.built)throw new wa("The model needs to be compiled before being used.");return this.model.evaluateDataset(e,t)}predict(e,t={}){return this.model==null&&this.build(),this.model.predict(e,t)}predictOnBatch(e){return this.model==null&&this.build(),this.model.predictOnBatch(e)}compile(e){this.build(),this.model.compile(e),this.optimizer_=this.model.optimizer,this.isOptimizerOwned=this.model.isOptimizerOwned,this.loss=this.model.loss,this.metrics=this.model.metrics,this.metricsTensors=this.model.metricsTensors,this.metricsNames=this.model.metricsNames}get optimizer(){return this.model==null?void 0:this.model.optimizer}set optimizer(e){this.model.optimizer=e}async fit(e,t,n={}){if(!this.built)throw new wa("The model needs to be compiled before being used.");return this.model.fit(e,t,n)}async fitDataset(e,t){if(!this.built)throw new wa("The model needs to be compiled before being used.");return this.model.fitDataset(e,t)}async trainOnBatch(e,t){return this.model.trainOnBatch(e,t)}static fromConfig(e,t,n={},a=!1){let r,s={};if(t instanceof Array){if(t[0].className==null||t[0].className==="Merge")throw new B("Legacy serialization format not supported yet.");r=t}else k.assert(t.layers!=null,()=>"When the config data for a Sequential model is not an Array, it must be an Object that contains the 'layers' field."),r=t.layers,delete t.layers,s=t;let i=new e(s);if(!(i instanceof Hl))throw new Oe(`Sequential.fromConfig called on non-Sequential input: ${i}`);for(let o of r){let l=Na(o,void 0,a);a&&l.setFastWeightInitDuringBuild(!0),i.add(l)}return i}set stopTraining(e){if(this.model==null)throw new B("Cannot set the stopTraining property of a sequential model before it is compiled.");this.model.stopTraining=e}get stopTraining(){if(this.model==null)throw new B("Cannot get the stopTraining property of a sequential model before it is compiled.");return this.model.stopTraining}getConfig(){let e=[];for(let t of this.layers){let n={};n.className=t.getClassName(),n.config=t.getConfig(),e.push(n)}return{name:this.name,layers:e}}};Hl.className="Sequential";ae.registerClass(Hl);function Qae(e){return new pr(e)}function ere(e){return new Hl(e)}function tre(e,t){return t==null&&(t={}),Yae(e,t)}function B6(e){return Z6(e)}function nre(e,t){ca.registerCallbackConstructor(e,t)}var En=class extends ae.Serializable{getConfig(){return{}}},I4=class extends En{apply(e,t=1){return $te(e,t)}};I4.className="elu";ae.registerClass(I4);var S4=class extends En{apply(e){return Oc(e)}};S4.className="selu";ae.registerClass(S4);var N4=class extends En{apply(e){return La(e)}};N4.className="relu";ae.registerClass(N4);var T4=class extends En{apply(e){return W(()=>xl(6,La(e)))}};T4.className="relu6";ae.registerClass(T4);var E4=class extends En{apply(e){return e}};E4.className="linear";ae.registerClass(E4);var C4=class extends En{apply(e){return kn(e)}};C4.className="sigmoid";ae.registerClass(C4);var R4=class extends En{apply(e){return Ote(e)}};R4.className="hardSigmoid";ae.registerClass(R4);var M4=class extends En{apply(e){return fi(e)}};M4.className="softplus";ae.registerClass(M4);var F4=class extends En{apply(e){return Dte(e)}};F4.className="softsign";ae.registerClass(F4);var $4=class extends En{apply(e){return pi(e)}};$4.className="tanh";ae.registerClass($4);var fy=class extends En{apply(e,t=-1){return nd(e,t)}};fy.className="softmax";ae.registerClass(fy);var D4=class extends En{apply(e,t=-1){return Ec(e,t)}};D4.className="logSoftmax";ae.registerClass(D4);var O4=class extends En{apply(e,t=1){return W(()=>kn(e.mul(t)).mul(e))}};O4.className="swish";ae.registerClass(O4);var z4=class extends En{apply(e){return W(()=>_(e,pi(fi(e))))}};z4.className="mish";ae.registerClass(z4);function Gr(e){return e.getClassName()}function my(e,t={}){return Id(e,ae.SerializationMap.getMap().classNameMap,t,"activation")}function qr(e){if(e==null){let t={};return t.className="linear",t.config={},my(t)}if(typeof e=="string"){let t={};return t.className=e,t.config={},my(t)}else return e instanceof En?e:my(e)}function Ay(e){if(e!=null&&typeof e!="object")throw new Error(`Argument to L1L2 regularizer's constructor is expected to be an object, but received: ${e}`)}var _4=class extends ae.Serializable{},zd=class extends _4{constructor(e){super();Ay(e),this.l1=e==null||e.l1==null?.01:e.l1,this.l2=e==null||e.l2==null?.01:e.l2,this.hasL1=this.l1!==0,this.hasL2=this.l2!==0}apply(e){return W(()=>{let t=Rt([1]);return this.hasL1&&(t=se(t,ke(_(this.l1,zt(e))))),this.hasL2&&(t=se(t,ke(_(this.l2,Cd(e))))),t.asScalar()})}getConfig(){return{l1:this.l1,l2:this.l2}}static fromConfig(e,t){return new e({l1:t.l1,l2:t.l2})}};zd.className="L1L2";ae.registerClass(zd);function are(e){return Ay(e),new zd({l1:e!=null?e.l1:null,l2:0})}function rre(e){return Ay(e),new zd({l2:e!=null?e.l2:null,l1:0})}var P4={l1l2:"L1L2"};function ut(e){return R1(e)}function L4(e,t={}){return Id(e,ae.SerializationMap.getMap().classNameMap,t,"regularizer")}function yt(e){if(e==null)return null;if(typeof e=="string"){let t={className:e in P4?P4[e]:e,config:{}};return L4(t)}else return e instanceof _4?e:L4(e)}var yy=class extends Ge{constructor(e){super(e==null?{}:e);this.supportsMasking=!0,e!=null&&(this.maxValue=e.maxValue)}call(e,t){e=_e(e);let n=La(e);return this.maxValue!=null&&(n=In(n,0,this.maxValue)),n}computeOutputShape(e){return e}getConfig(){let e={maxValue:this.maxValue},t=super.getConfig();return Object.assign(e,t),e}};yy.className="ReLU";ae.registerClass(yy);var gy=class extends Ge{constructor(e){super(e==null?{}:e);this.DEFAULT_ALPHA=.3,e==null&&(e={}),this.alpha=e.alpha==null?this.DEFAULT_ALPHA:e.alpha}call(e,t){let n=_e(e);return Ku(n,this.alpha)}computeOutputShape(e){return e}getConfig(){let e={alpha:this.alpha},t=super.getConfig();return Object.assign(e,t),e}};gy.className="LeakyReLU";ae.registerClass(gy);var xy=class extends Ge{constructor(e){super(e==null?{}:e);if(this.DEFAULT_ALPHA_INITIALIZER="zeros",e==null&&(e={}),this.supportsMasking=!0,this.alphaInitializer=At(e.alphaInitializer||this.DEFAULT_ALPHA_INITIALIZER),this.alphaRegularizer=yt(e.alphaRegularizer),this.alphaConstraint=Wt(e.alphaConstraint),e.sharedAxes==null)this.sharedAxes=null;else if(Array.isArray(e.sharedAxes))this.sharedAxes=e.sharedAxes;else if(typeof e.sharedAxes=="number")this.sharedAxes=[e.sharedAxes];else throw new B(`Expected sharedAxes to be a number or an array of numbers, but got ${e.sharedAxes}`)}build(e){e=at(e);let t=e.slice(1);if(this.sharedAxes!=null)for(let a of this.sharedAxes)t[a-1]=1;this.alpha=this.addWeight("alpha",t,"float32",this.alphaInitializer,this.alphaRegularizer,!0,this.alphaConstraint);let n={};if(this.sharedAxes!=null)for(let a=1;a(Ct(t),t==="channelsFirst"?Ze(e,[0,2,3,1]):e))}function W4(e,t){return W(()=>(Ct(t),t==="channelsFirst"?Ze(e,[0,2,3,4,1]):e))}function sre(e,t,n,a=1,r="valid",s,i=1){return W(()=>{if(s==null&&(s=va()),Ct(s),e.shape.length!==3)throw new B(`The input of a conv1dWithBias operation should be 3, but is ${e.shape.length} instead.`);if(t.shape.length!==3)throw new B(`The kernel for a conv1dWithBias operation should be 3, but is ${t.shape.length} instead`);if(n!=null&&n.shape.length!==1)throw new B(`The bias for a conv1dWithBias operation should be 1, but is ${t.shape.length} instead`);if(s==="channelsFirst"&&(e=Ze(e,[0,2,1])),r==="causal")throw new Oe("The support for CAUSAL padding mode in conv1dWithBias is not implemented yet.");let o=bc(e,t,a,r==="same"?"same":"valid","NWC",i);return n!=null&&(o=Ia(o,n)),o})}function B4(e,t,n,a=[1,1],r="valid",s,i,o=null){return W(()=>{if(s==null&&(s=va()),Ct(s),e.rank!==3&&e.rank!==4)throw new B(`conv2dWithBiasActivation expects input to be of rank 3 or 4, but received ${e.rank}.`);if(t.rank!==3&&t.rank!==4)throw new B(`conv2dWithBiasActivation expects kernel to be of rank 3 or 4, but received ${e.rank}.`);let l=ky(e,s);if(r==="causal")throw new Oe("The support for CAUSAL padding mode in conv1dWithBias is not implemented yet.");return l=_r.conv2d({x:l,filter:t,strides:a,pad:r==="same"?"same":"valid",dilations:i,dataFormat:"NHWC",bias:n,activation:o}),s==="channelsFirst"&&(l=Ze(l,[0,3,1,2])),l})}function ire(e,t,n,a=[1,1,1],r="valid",s,i){return W(()=>{if(s==null&&(s=va()),Ct(s),e.rank!==4&&e.rank!==5)throw new B(`conv3dWithBias expects input to be of rank 4 or 5, but received ${e.rank}.`);if(t.rank!==4&&t.rank!==5)throw new B(`conv3dWithBias expects kernel to be of rank 4 or 5, but received ${e.rank}.`);let o=W4(e,s);if(r==="causal")throw new Oe("The support for CAUSAL padding mode in conv3dWithBias is not implemented yet.");return o=pA(o,t,a,r==="same"?"same":"valid","NDHWC",i),n!=null&&(o=Ia(o,n)),s==="channelsFirst"&&(o=Ze(o,[0,4,1,2,3])),o})}var Iy=class extends Ge{constructor(e,t){super(t);if(this.bias=null,this.DEFAULT_KERNEL_INITIALIZER="glorotNormal",this.DEFAULT_BIAS_INITIALIZER="zeros",Iy.verifyArgs(t),this.rank=e,Gt(this.rank,"rank"),this.rank!==1&&this.rank!==2&&this.rank!==3)throw new Oe(`Convolution layer for rank other than 1, 2, or 3 (${this.rank}) is not implemented yet.`);if(this.kernelSize=Gl(t.kernelSize,e,"kernelSize"),this.strides=Gl(t.strides==null?1:t.strides,e,"strides"),this.padding=t.padding==null?"valid":t.padding,Qn(this.padding),this.dataFormat=t.dataFormat==null?"channelsLast":t.dataFormat,Ct(this.dataFormat),this.activation=qr(t.activation),this.useBias=t.useBias==null?!0:t.useBias,this.biasInitializer=At(t.biasInitializer||this.DEFAULT_BIAS_INITIALIZER),this.biasConstraint=Wt(t.biasConstraint),this.biasRegularizer=yt(t.biasRegularizer),this.activityRegularizer=yt(t.activityRegularizer),this.dilationRate=Gl(t.dilationRate==null?1:t.dilationRate,e,"dilationRate"),this.rank===1&&Array.isArray(this.dilationRate)&&this.dilationRate.length!==1)throw new B(`dilationRate must be a number or an array of a single number for 1D convolution, but received ${JSON.stringify(this.dilationRate)}`);if(this.rank===2){if(typeof this.dilationRate=="number")this.dilationRate=[this.dilationRate,this.dilationRate];else if(this.dilationRate.length!==2)throw new B(`dilationRate must be a number or array of two numbers for 2D convolution, but received ${JSON.stringify(this.dilationRate)}`)}else if(this.rank===3){if(typeof this.dilationRate=="number")this.dilationRate=[this.dilationRate,this.dilationRate,this.dilationRate];else if(this.dilationRate.length!==3)throw new B(`dilationRate must be a number or array of three numbers for 3D convolution, but received ${JSON.stringify(this.dilationRate)}`)}}static verifyArgs(e){if(ja("kernelSize"in e,"required key 'kernelSize' not in config"),typeof e.kernelSize!="number"&&!F1(e.kernelSize,"number",1,3))throw new B(`BaseConv expects config.kernelSize to be number or number[] with length 1, 2, or 3, but received ${JSON.stringify(e.kernelSize)}.`)}getConfig(){let e={kernelSize:this.kernelSize,strides:this.strides,padding:this.padding,dataFormat:this.dataFormat,dilationRate:this.dilationRate,activation:Gr(this.activation),useBias:this.useBias,biasInitializer:It(this.biasInitializer),biasRegularizer:ut(this.biasRegularizer),activityRegularizer:ut(this.activityRegularizer),biasConstraint:Lt(this.biasConstraint)},t=super.getConfig();return Object.assign(e,t),e}},_d=class extends Iy{constructor(e,t){super(e,t);this.kernel=null,_d.verifyArgs(t),this.filters=t.filters,Gt(this.filters,"filters"),this.kernelInitializer=At(t.kernelInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.kernelConstraint=Wt(t.kernelConstraint),this.kernelRegularizer=yt(t.kernelRegularizer)}build(e){e=at(e);let t=this.dataFormat==="channelsFirst"?1:e.length-1;if(e[t]==null)throw new B(`The channel dimension of the input should be defined. Found ${e[t]}`);let n=e[t],a=this.kernelSize.concat([n,this.filters]);this.kernel=this.addWeight("kernel",a,null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.useBias&&(this.bias=this.addWeight("bias",[this.filters],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint)),this.inputSpec=[{ndim:this.rank+2,axes:{[t]:n}}],this.built=!0}call(e,t){return W(()=>{e=_e(e);let n,a=this.bias==null?null:this.bias.read(),r=S6(this.activation.getClassName());if(r!=null&&this.rank===2)n=B4(e,this.kernel.read(),a,this.strides,this.padding,this.dataFormat,this.dilationRate,r);else{if(this.rank===1)n=sre(e,this.kernel.read(),a,this.strides[0],this.padding,this.dataFormat,this.dilationRate[0]);else if(this.rank===2)n=B4(e,this.kernel.read(),a,this.strides,this.padding,this.dataFormat,this.dilationRate);else if(this.rank===3)n=ire(e,this.kernel.read(),a,this.strides,this.padding,this.dataFormat,this.dilationRate);else throw new Oe("convolutions greater than 3D are not implemented yet.");this.activation!=null&&(n=this.activation.apply(n))}return n})}computeOutputShape(e){e=at(e);let t=[],n=this.dataFormat==="channelsLast"?e.slice(1,e.length-1):e.slice(2);for(let r=0;r 0 but got ${JSON.stringify(e.filters)}`)}},Pd=class extends _d{constructor(e){super(2,e);Pd.verifyArgs(e)}getConfig(){let e=super.getConfig();return delete e.rank,e}static verifyArgs(e){if(typeof e.kernelSize!="number"&&!F1(e.kernelSize,"number",1,2))throw new B(`Conv2D expects config.kernelSize to be number or number[] with length 1 or 2, but received ${JSON.stringify(e.kernelSize)}.`)}};Pd.className="Conv2D";ae.registerClass(Pd);var Ld=class extends _d{constructor(e){super(3,e);Ld.verifyArgs(e)}getConfig(){let e=super.getConfig();return delete e.rank,e}static verifyArgs(e){if(typeof e.kernelSize!="number"&&!(Array.isArray(e.kernelSize)&&(e.kernelSize.length===1||e.kernelSize.length===3)))throw new B(`Conv3D expects config.kernelSize to be number or [number, number, number], but received ${JSON.stringify(e.kernelSize)}.`)}};Ld.className="Conv3D";ae.registerClass(Ld);var Sy=class extends Pd{constructor(e){super(e);if(this.inputSpec=[new Ft({ndim:4})],this.padding!=="same"&&this.padding!=="valid")throw new B(`Conv2DTranspose currently supports only padding modes 'same' and 'valid', but received padding mode ${this.padding}`)}build(e){if(e=at(e),e.length!==4)throw new B("Input should have rank 4; Received input shape: "+JSON.stringify(e));let t=this.dataFormat==="channelsFirst"?1:e.length-1;if(e[t]==null)throw new B("The channel dimension of the inputs should be defined. Found `None`.");let n=e[t],a=this.kernelSize.concat([this.filters,n]);this.kernel=this.addWeight("kernel",a,"float32",this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.useBias&&(this.bias=this.addWeight("bias",[this.filters],"float32",this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint)),this.inputSpec=[new Ft({ndim:4,axes:{[t]:n}})],this.built=!0}call(e,t){return W(()=>{let n=_e(e);if(n.shape.length!==4)throw new B(`Conv2DTranspose.call() expects input tensor to be rank-4, but received a tensor of rank-${n.shape.length}`);let a=n.shape,r=a[0],s,i;this.dataFormat==="channelsFirst"?(s=2,i=3):(s=1,i=2);let o=a[s],l=a[i],d=this.kernelSize[0],u=this.kernelSize[1],p=this.strides[0],c=this.strides[1],h=qa(o,p,d,this.padding),m=qa(l,c,u,this.padding),f=[r,h,m,this.filters];this.dataFormat!=="channelsLast"&&(n=Ze(n,[0,2,3,1]));let A=vc(n,this.kernel.read(),f,this.strides,this.padding);return this.dataFormat!=="channelsLast"&&(A=Ze(A,[0,3,1,2])),this.bias!=null&&(A=Ia(A,this.bias.read(),this.dataFormat)),this.activation!=null&&(A=this.activation.apply(A)),A})}computeOutputShape(e){e=at(e);let t=e.slice(),n,a,r;this.dataFormat==="channelsFirst"?(n=1,a=2,r=3):(n=3,a=1,r=2);let s=this.kernelSize[0],i=this.kernelSize[1],o=this.strides[0],l=this.strides[1];return t[n]=this.filters,t[a]=qa(t[a],o,s,this.padding),t[r]=qa(t[r],l,i,this.padding),t}getConfig(){let e=super.getConfig();return delete e.dilationRate,e}};Sy.className="Conv2DTranspose";ae.registerClass(Sy);var Ny=class extends Ld{constructor(e){super(e);if(this.inputSpec=[new Ft({ndim:5})],this.padding!=="same"&&this.padding!=="valid")throw new B(`Conv3DTranspose currently supports only padding modes 'same' and 'valid', but received padding mode ${this.padding}`)}build(e){if(e=at(e),e.length!==5)throw new B("Input should have rank 5; Received input shape: "+JSON.stringify(e));let t=this.dataFormat==="channelsFirst"?1:e.length-1;if(e[t]==null)throw new B("The channel dimension of the inputs should be defined. Found `None`.");let n=e[t],a=this.kernelSize.concat([this.filters,n]);this.kernel=this.addWeight("kernel",a,"float32",this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.useBias&&(this.bias=this.addWeight("bias",[this.filters],"float32",this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint)),this.inputSpec=[new Ft({ndim:5,axes:{[t]:n}})],this.built=!0}call(e,t){return W(()=>{let n=_e(e);if(n.shape.length!==5)throw new B(`Conv3DTranspose.call() expects input tensor to be rank-4, but received a tensor of rank-${n.shape.length}`);let a=n.shape,r=a[0],s,i,o;this.dataFormat==="channelsFirst"?(o=2,s=3,i=4):(o=1,s=2,i=3);let l=a[o],d=a[s],u=a[i],p=this.kernelSize[0],c=this.kernelSize[1],h=this.kernelSize[2],m=this.strides[0],f=this.strides[1],A=this.strides[2],y=qa(l,m,p,this.padding),g=qa(d,f,c,this.padding),x=qa(u,A,h,this.padding),w=[r,y,g,x,this.filters];this.dataFormat!=="channelsLast"&&(n=Ze(n,[0,2,3,4,1]));let b=Db(n,this.kernel.read(),w,this.strides,this.padding);return this.dataFormat!=="channelsLast"&&(b=Ze(b,[0,4,1,2,3])),this.bias!==null&&(b=Ia(b,this.bias.read(),this.dataFormat)),this.activation!==null&&(b=this.activation.apply(b)),b})}computeOutputShape(e){e=at(e);let t=e.slice(),n,a,r,s;this.dataFormat==="channelsFirst"?(n=1,a=2,r=3,s=4):(n=4,a=1,r=2,s=3);let i=this.kernelSize[0],o=this.kernelSize[1],l=this.kernelSize[2],d=this.strides[0],u=this.strides[1],p=this.strides[2];return t[n]=this.filters,t[a]=qa(t[a],d,i,this.padding),t[r]=qa(t[r],u,o,this.padding),t[s]=qa(t[s],p,l,this.padding),t}getConfig(){let e=super.getConfig();return delete e.dilationRate,e}};Ny.className="Conv3DTranspose";ae.registerClass(Ny);var V4=class extends _d{constructor(e,t){super(e,t);if(this.DEFAULT_DEPTHWISE_INITIALIZER="glorotUniform",this.DEFAULT_POINTWISE_INITIALIZER="glorotUniform",this.depthwiseKernel=null,this.pointwiseKernel=null,t.filters==null)throw new B("The `filters` configuration field is required by SeparableConv, but is unspecified.");if(t.kernelInitializer!=null||t.kernelRegularizer!=null||t.kernelConstraint!=null)throw new B("Fields kernelInitializer, kernelRegularizer and kernelConstraint are invalid for SeparableConv2D. Use depthwiseInitializer, depthwiseRegularizer, depthwiseConstraint, pointwiseInitializer, pointwiseRegularizer and pointwiseConstraint instead.");if(t.padding!=null&&t.padding!=="same"&&t.padding!=="valid")throw new B(`SeparableConv${this.rank}D supports only padding modes: 'same' and 'valid', but received ${JSON.stringify(t.padding)}`);this.depthMultiplier=t.depthMultiplier==null?1:t.depthMultiplier,this.depthwiseInitializer=At(t.depthwiseInitializer||this.DEFAULT_DEPTHWISE_INITIALIZER),this.depthwiseRegularizer=yt(t.depthwiseRegularizer),this.depthwiseConstraint=Wt(t.depthwiseConstraint),this.pointwiseInitializer=At(t.depthwiseInitializer||this.DEFAULT_POINTWISE_INITIALIZER),this.pointwiseRegularizer=yt(t.pointwiseRegularizer),this.pointwiseConstraint=Wt(t.pointwiseConstraint)}build(e){if(e=at(e),e.length{e=_e(e);let n;if(this.rank===1)throw new Oe("1D separable convolution is not implemented yet.");return this.rank===2&&(this.dataFormat==="channelsFirst"&&(e=Ze(e,[0,2,3,1])),n=CA(e,this.depthwiseKernel.read(),this.pointwiseKernel.read(),this.strides,this.padding,this.dilationRate,"NHWC")),this.useBias&&(n=Ia(n,this.bias.read(),this.dataFormat)),this.activation!=null&&(n=this.activation.apply(n)),this.dataFormat==="channelsFirst"&&(n=Ze(n,[0,3,1,2])),n})}getConfig(){let e=super.getConfig();return delete e.rank,delete e.kernelInitializer,delete e.kernelRegularizer,delete e.kernelConstraint,e.depthwiseInitializer=It(this.depthwiseInitializer),e.pointwiseInitializer=It(this.pointwiseInitializer),e.depthwiseRegularizer=ut(this.depthwiseRegularizer),e.pointwiseRegularizer=ut(this.pointwiseRegularizer),e.depthwiseConstraint=Lt(this.depthwiseConstraint),e.pointwiseConstraint=Lt(this.pointwiseConstraint),e}};V4.className="SeparableConv";var Ty=class extends V4{constructor(e){super(2,e)}};Ty.className="SeparableConv2D";ae.registerClass(Ty);var e0=class extends _d{constructor(e){super(1,e);e0.verifyArgs(e),this.inputSpec=[{ndim:3}]}getConfig(){let e=super.getConfig();return delete e.rank,delete e.dataFormat,e}static verifyArgs(e){if(typeof e.kernelSize!="number"&&!F1(e.kernelSize,"number",1,1))throw new B(`Conv1D expects config.kernelSize to be number or number[] with length 1, but received ${JSON.stringify(e.kernelSize)}.`)}};e0.className="Conv1D";ae.registerClass(e0);var Ey=class extends Ge{constructor(e){super(e);typeof e.cropping=="number"?this.cropping=[[e.cropping,e.cropping],[e.cropping,e.cropping]]:typeof e.cropping[0]=="number"?this.cropping=[[e.cropping[0],e.cropping[0]],[e.cropping[1],e.cropping[1]]]:this.cropping=e.cropping,this.dataFormat=e.dataFormat===void 0?"channelsLast":e.dataFormat,this.inputSpec=[{ndim:4}]}computeOutputShape(e){return this.dataFormat==="channelsFirst"?[e[0],e[1],e[2]-this.cropping[0][0]-this.cropping[0][1],e[3]-this.cropping[1][0]-this.cropping[1][1]]:[e[0],e[1]-this.cropping[0][0]-this.cropping[0][1],e[2]-this.cropping[1][0]-this.cropping[1][1],e[3]]}call(e,t){return W(()=>{if(e=_e(e),this.dataFormat==="channelsLast"){let n=Fh(e,this.cropping[0][0],e.shape[1]-this.cropping[0][0]-this.cropping[0][1],2);return Fh(n,this.cropping[1][0],e.shape[2]-this.cropping[1][1]-this.cropping[1][0],3)}else{let n=Fh(e,this.cropping[0][0],e.shape[2]-this.cropping[0][0]-this.cropping[0][1],3);return Fh(n,this.cropping[1][0],e.shape[3]-this.cropping[1][1]-this.cropping[1][0],4)}})}getConfig(){let e={cropping:this.cropping,dataFormat:this.dataFormat},t=super.getConfig();return Object.assign(e,t),e}};Ey.className="Cropping2D";ae.registerClass(Ey);var Cy=class extends Ge{constructor(e){super(e);this.DEFAULT_SIZE=[2,2],this.inputSpec=[{ndim:4}],this.size=e.size==null?this.DEFAULT_SIZE:e.size,this.dataFormat=e.dataFormat==null?"channelsLast":e.dataFormat,Ct(this.dataFormat),this.interpolation=e.interpolation==null?"nearest":e.interpolation,Nte(this.interpolation)}computeOutputShape(e){if(this.dataFormat==="channelsFirst"){let t=e[2]==null?null:this.size[0]*e[2],n=e[3]==null?null:this.size[1]*e[3];return[e[0],e[1],t,n]}else{let t=e[1]==null?null:this.size[0]*e[1],n=e[2]==null?null:this.size[1]*e[2];return[e[0],t,n,e[3]]}}call(e,t){return W(()=>{let n=_e(e),a=n.shape;if(this.dataFormat==="channelsFirst"){n=Ze(n,[0,2,3,1]);let r=this.size[0]*a[2],s=this.size[1]*a[3],i=this.interpolation==="nearest"?n.resizeNearestNeighbor([r,s]):n.resizeBilinear([r,s]);return Ze(i,[0,3,1,2])}else{let r=this.size[0]*a[1],s=this.size[1]*a[2];return this.interpolation==="nearest"?n.resizeNearestNeighbor([r,s]):n.resizeBilinear([r,s])}})}getConfig(){let e={size:this.size,dataFormat:this.dataFormat},t=super.getConfig();return Object.assign(e,t),e}};Cy.className="UpSampling2D";ae.registerClass(Cy);function ore(e,t,n=[1,1],a="valid",r,s){return W(()=>{r==null&&(r=va()),Ct(r);let i=ky(e,r);if(e.rank!==4)throw new B(`Input for depthwiseConv2d is required to be 4-D, but is instead ${e.rank}-D`);if(t.rank!==4)throw new B(`depthwiseKernel is required to be 4-D, but is instead ${t.rank}-D`);return i=fl(i,t,n,a==="same"?"same":"valid","NHWC",s),r==="channelsFirst"&&(i=Ze(i,[0,3,1,2])),i})}var Ry=class extends Iy{constructor(e){super(2,e);this.depthwiseKernel=null,this.depthMultiplier=e.depthMultiplier==null?1:e.depthMultiplier,this.depthwiseInitializer=At(e.depthwiseInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.depthwiseConstraint=Wt(e.depthwiseConstraint),this.depthwiseRegularizer=yt(e.depthwiseRegularizer)}build(e){if(e=at(e),e.length<4)throw new B(`Inputs to DepthwiseConv2D should have rank 4. Received input shape: ${JSON.stringify(e)}.`);let t=this.dataFormat==="channelsFirst"?1:3;if(e[t]==null||e[t]<0)throw new B(`The channel dimension of the inputs to DepthwiseConv2D should be defined, but is not (${e[t]}).`);let n=e[t],a=[this.kernelSize[0],this.kernelSize[1],n,this.depthMultiplier];this.depthwiseKernel=this.addWeight("depthwise_kernel",a,null,this.depthwiseInitializer,this.depthwiseRegularizer,!0,this.depthwiseConstraint),this.useBias?this.bias=this.addWeight("bias",[n*this.depthMultiplier],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint):this.bias=null,this.built=!0}call(e,t){return W(()=>{e=_e(e);let n=ore(e,this.depthwiseKernel.read(),this.strides,this.padding,this.dataFormat,null);return this.useBias&&(n=Ia(n,this.bias.read(),this.dataFormat)),this.activation!=null&&(n=this.activation.apply(n)),n})}computeOutputShape(e){e=at(e);let t=this.dataFormat==="channelsFirst"?e[2]:e[1],n=this.dataFormat==="channelsFirst"?e[3]:e[2],a=this.dataFormat==="channelsFirst"?e[1]*this.depthMultiplier:e[3]*this.depthMultiplier,r=Ta(t,this.kernelSize[0],this.padding,this.strides[0]),s=Ta(n,this.kernelSize[1],this.padding,this.strides[1]);return this.dataFormat==="channelsFirst"?[e[0],a,r,s]:[e[0],r,s,a]}getConfig(){let e=super.getConfig();return e.depthMultiplier=this.depthMultiplier,e.depthwiseInitializer=It(this.depthwiseInitializer),e.depthwiseRegularizer=ut(this.depthwiseRegularizer),e.depthwiseConstraint=Lt(this.depthwiseRegularizer),e}};Ry.className="DepthwiseConv2D";ae.registerClass(Ry);function j4(e,t,n,a){if(Array.isArray(e)){if(t!=null||n!=null)throw new B("When inputs is an array, neither initialState or constants should be provided");a!=null&&(n=e.slice(e.length-a,e.length),e=e.slice(0,e.length-a)),e.length>1&&(t=e.slice(1,e.length)),e=e[0]}function r(s){return s==null||Array.isArray(s)?s:[s]}return t=r(t),n=r(n),{inputs:e,initialState:t,constants:n}}function U4(e,t,n,a=!1,r,s,i=!1,o=!1){return W(()=>{let l=t.shape.length;if(l<3)throw new B(`Input should be at least 3D, but is ${l}D.`);let d=[1,0].concat(ka(2,l));if(t=Ze(t,d),s!=null)throw new Oe("The rnn() functoin of the deeplearn.js backend does not support constants yet.");i&&console.warn("Backend rnn(): the unroll = true option is not applicable to the imperative deeplearn.js backend."),r!=null&&(r=r.asType("bool").asType("float32"),r.rank===l-1&&(r=un(r,-1)),r=Ze(r,d)),a&&(t=zn(t,0),r!=null&&(r=zn(r,0)));let u=[],p,c=n,h=t.shape[0],m=ua(t),f;r!=null&&(f=ua(r));for(let y=0;ye(g,c));if(r==null)p=x[0],c=x[1];else{let w=W(()=>{let b=f[y],v=On(b).sub(b),N=x[0].mul(b).add(c[0].mul(v)),T=c.map((R,$)=>x[1][$].mul(b).add(R.mul(v)));return{output:N,newStates:T}});p=w.output,c=w.newStates}o&&u.push(p)}let A;return o&&(A=_n(u,1)),[p,A,c]})}var Ha=class extends Ge{constructor(e){super(e);let t;if(e.cell==null)throw new B("cell property is missing for the constructor of RNN.");if(Array.isArray(e.cell)?t=new t0({cells:e.cell}):t=e.cell,t.stateSize==null)throw new B("The RNN cell should have an attribute `stateSize` (tuple of integers, one integer per RNN state).");this.cell=t,this.returnSequences=e.returnSequences==null?!1:e.returnSequences,this.returnState=e.returnState==null?!1:e.returnState,this.goBackwards=e.goBackwards==null?!1:e.goBackwards,this._stateful=e.stateful==null?!1:e.stateful,this.unroll=e.unroll==null?!1:e.unroll,this.supportsMasking=!0,this.inputSpec=[new Ft({ndim:3})],this.stateSpec=null,this.states_=null,this.numConstants=null,this.keptStates=[]}getStates(){if(this.states_==null){let e=Array.isArray(this.cell.stateSize)?this.cell.stateSize.length:1;return ka(0,e).map(t=>null)}else return this.states_}setStates(e){this.states_=e}computeOutputShape(e){J1(e)&&(e=e[0]),e=e;let t=this.cell.stateSize;Array.isArray(t)||(t=[t]);let n=t[0],a;if(this.returnSequences?a=[e[0],e[1],n]:a=[e[0],n],this.returnState){let r=[];for(let s of t)r.push([e[0],s]);return[a].concat(r)}else return a}computeMask(e,t){return W(()=>{Array.isArray(t)&&(t=t[0]);let n=this.returnSequences?t:null;if(this.returnState){let a=this.states.map(r=>null);return[n].concat(a)}else return n})}get states(){if(this.states_==null){let e=Array.isArray(this.cell.stateSize)?this.cell.stateSize.length:1,t=[];for(let n=0;ni.shape[i.shape.length-1]),s))throw new B(`An initialState was passed that is not compatible with cell.stateSize. Received stateSpec=${this.stateSpec}; However cell.stateSize is ${this.cell.stateSize}`)}else this.stateSpec=s.map(i=>new Ft({shape:[null,i]}));this.stateful&&this.resetStates()}resetStates(e,t=!1){W(()=>{if(!this.stateful)throw new ur("Cannot call resetStates() on an RNN Layer that is not stateful.");let n=this.inputSpec[0].shape[0];if(n==null)throw new B("If an RNN is stateful, it needs to know its batch size. Specify the batch size of your input tensors: \n- If using a Sequential model, specify the batch size by passing a `batchInputShape` option to your first layer.\n- If using the functional API, specify the batch size by passing a `batchShape` option to your Input layer.");if(this.states_==null)Array.isArray(this.cell.stateSize)?this.states_=this.cell.stateSize.map(a=>Rt([n,a])):this.states_=[Rt([n,this.cell.stateSize])];else if(e==null)Ee(this.states_),this.keptStates!=null&&(Ee(this.keptStates),this.keptStates=[]),Array.isArray(this.cell.stateSize)?this.states_=this.cell.stateSize.map(a=>Rt([n,a])):this.states_[0]=Rt([n,this.cell.stateSize]);else{if(Array.isArray(e)||(e=[e]),e.length!==this.states_.length)throw new B(`Layer ${this.name} expects ${this.states_.length} state(s), but it received ${e.length} state value(s). Input received: ${e}`);t===!0?this.keptStates.push(this.states_.slice()):Ee(this.states_);for(let a=0;aUt(a.clone()))})}apply(e,t){let n=t==null?null:t.initialState,a=t==null?null:t.constants;t==null&&(t={});let r=j4(e,n,a,this.numConstants);e=r.inputs,n=r.initialState,a=r.constants;let s=[],i=[];if(n!=null){t.initialState=n,s=s.concat(n),this.stateSpec=[];for(let o of n)this.stateSpec.push(new Ft({shape:o.shape}));i=i.concat(this.stateSpec)}if(a!=null&&(t.constants=a,s=s.concat(a),this.numConstants=a.length),s[0]instanceof Sa){let o=[e].concat(s),l=this.inputSpec.concat(i),d=this.inputSpec;this.inputSpec=l;let u=super.apply(o,t);return this.inputSpec=d,u}else return super.apply(e,t)}call(e,t){return W(()=>{let n=t==null?null:t.mask,a=t==null?null:t.training,r=t==null?null:t.initialState;e=_e(e),r==null&&(this.stateful?r=this.states_:r=this.getInitialState(e));let s=Array.isArray(this.cell.stateSize)?this.cell.stateSize.length:1;if(r.length!==s)throw new B(`RNN Layer has ${s} state(s) but was passed ${r.length} initial state(s).`);this.unroll&&console.warn("Ignoring unroll = true for RNN layer, due to imperative backend.");let i={training:a},o=U4((c,h)=>{let m=this.cell.call([c].concat(h),i);return[m[0],m.slice(1)]},e,r,this.goBackwards,n,null,this.unroll,this.returnSequences),l=o[0],d=o[1],u=o[2];this.stateful&&this.resetStates(u,a);let p=this.returnSequences?d:l;return this.returnState?[p].concat(u):p})}getInitialState(e){return W(()=>{let t=Rt(e.shape);return t=ke(t,[1,2]),t=Ed(t),Array.isArray(this.cell.stateSize)?this.cell.stateSize.map(n=>n>1?P1(t,[1,n]):t):this.cell.stateSize>1?[P1(t,[1,this.cell.stateSize])]:[t]})}get trainableWeights(){return this.trainable?this.cell.trainableWeights:[]}get nonTrainableWeights(){return this.trainable?this.cell.nonTrainableWeights:this.cell.weights}setFastWeightInitDuringBuild(e){super.setFastWeightInitDuringBuild(e),this.cell!=null&&this.cell.setFastWeightInitDuringBuild(e)}getConfig(){let e=super.getConfig(),t={returnSequences:this.returnSequences,returnState:this.returnState,goBackwards:this.goBackwards,stateful:this.stateful,unroll:this.unroll};this.numConstants!=null&&(t.numConstants=this.numConstants);let n=this.cell.getConfig();return this.getClassName()===Ha.className&&(t.cell={className:this.cell.getClassName(),config:n}),Object.assign({},n,e,t)}static fromConfig(e,t,n={}){let a=t.cell,r=Na(a,n);return new e(Object.assign(t,{cell:r}))}};Ha.className="RNN";ae.registerClass(Ha);var Md=class extends Ge{},n0=class extends Md{constructor(e){super(e);this.DEFAULT_ACTIVATION="tanh",this.DEFAULT_KERNEL_INITIALIZER="glorotNormal",this.DEFAULT_RECURRENT_INITIALIZER="orthogonal",this.DEFAULT_BIAS_INITIALIZER="zeros",this.units=e.units,Gt(this.units,"units"),this.activation=qr(e.activation==null?this.DEFAULT_ACTIVATION:e.activation),this.useBias=e.useBias==null?!0:e.useBias,this.kernelInitializer=At(e.kernelInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.recurrentInitializer=At(e.recurrentInitializer||this.DEFAULT_RECURRENT_INITIALIZER),this.biasInitializer=At(e.biasInitializer||this.DEFAULT_BIAS_INITIALIZER),this.kernelRegularizer=yt(e.kernelRegularizer),this.recurrentRegularizer=yt(e.recurrentRegularizer),this.biasRegularizer=yt(e.biasRegularizer),this.kernelConstraint=Wt(e.kernelConstraint),this.recurrentConstraint=Wt(e.recurrentConstraint),this.biasConstraint=Wt(e.biasConstraint),this.dropout=Bl([1,Ur([0,e.dropout==null?0:e.dropout])]),this.recurrentDropout=Bl([1,Ur([0,e.recurrentDropout==null?0:e.recurrentDropout])]),this.stateSize=this.units,this.dropoutMask=null,this.recurrentDropoutMask=null}build(e){e=at(e),this.kernel=this.addWeight("kernel",[e[e.length-1],this.units],null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.recurrentKernel=this.addWeight("recurrent_kernel",[this.units,this.units],null,this.recurrentInitializer,this.recurrentRegularizer,!0,this.recurrentConstraint),this.useBias?this.bias=this.addWeight("bias",[this.units],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint):this.bias=null,this.built=!0}call(e,t){return W(()=>{if(e=e,e.length!==2)throw new B(`SimpleRNNCell expects 2 input Tensors, got ${e.length}.`);let n=e[1];e=e[0];let a=t.training==null?!1:t.training;0On(e),rate:this.dropout,training:a})),0On(n),rate:this.recurrentDropout,training:a}));let r,s=this.dropoutMask,i=this.recurrentDropoutMask;s!=null?r=Ua(_(e,s),this.kernel.read()):r=Ua(e,this.kernel.read()),this.bias!=null&&(r=Ia(r,this.bias.read())),i!=null&&(n=_(n,i));let o=se(r,Ua(n,this.recurrentKernel.read()));return this.activation!=null&&(o=this.activation.apply(o)),[o,o]})}getConfig(){let e=super.getConfig(),t={units:this.units,activation:Gr(this.activation),useBias:this.useBias,kernelInitializer:It(this.kernelInitializer),recurrentInitializer:It(this.recurrentInitializer),biasInitializer:It(this.biasInitializer),kernelRegularizer:ut(this.kernelRegularizer),recurrentRegularizer:ut(this.recurrentRegularizer),biasRegularizer:ut(this.biasRegularizer),activityRegularizer:ut(this.activityRegularizer),kernelConstraint:Lt(this.kernelConstraint),recurrentConstraint:Lt(this.recurrentConstraint),biasConstraint:Lt(this.biasConstraint),dropout:this.dropout,recurrentDropout:this.recurrentDropout};return Object.assign({},e,t)}};n0.className="SimpleRNNCell";ae.registerClass(n0);var My=class extends Ha{constructor(e){e.cell=new n0(e),super(e)}call(e,t){return W(()=>{this.cell.dropoutMask!=null&&(Ee(this.cell.dropoutMask),this.cell.dropoutMask=null),this.cell.recurrentDropoutMask!=null&&(Ee(this.cell.recurrentDropoutMask),this.cell.recurrentDropoutMask=null);let n=t==null?null:t.mask,a=t==null?null:t.training,r=t==null?null:t.initialState;return super.call(e,{mask:n,training:a,initialState:r})})}static fromConfig(e,t){return new e(t)}};My.className="SimpleRNN";ae.registerClass(My);var a0=class extends Md{constructor(e){super(e);if(this.DEFAULT_ACTIVATION="tanh",this.DEFAULT_RECURRENT_ACTIVATION="hardSigmoid",this.DEFAULT_KERNEL_INITIALIZER="glorotNormal",this.DEFAULT_RECURRENT_INITIALIZER="orthogonal",this.DEFAULT_BIAS_INITIALIZER="zeros",e.resetAfter)throw new B("GRUCell does not support reset_after parameter set to true.");this.units=e.units,Gt(this.units,"units"),this.activation=qr(e.activation===void 0?this.DEFAULT_ACTIVATION:e.activation),this.recurrentActivation=qr(e.recurrentActivation===void 0?this.DEFAULT_RECURRENT_ACTIVATION:e.recurrentActivation),this.useBias=e.useBias==null?!0:e.useBias,this.kernelInitializer=At(e.kernelInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.recurrentInitializer=At(e.recurrentInitializer||this.DEFAULT_RECURRENT_INITIALIZER),this.biasInitializer=At(e.biasInitializer||this.DEFAULT_BIAS_INITIALIZER),this.kernelRegularizer=yt(e.kernelRegularizer),this.recurrentRegularizer=yt(e.recurrentRegularizer),this.biasRegularizer=yt(e.biasRegularizer),this.kernelConstraint=Wt(e.kernelConstraint),this.recurrentConstraint=Wt(e.recurrentConstraint),this.biasConstraint=Wt(e.biasConstraint),this.dropout=Bl([1,Ur([0,e.dropout==null?0:e.dropout])]),this.recurrentDropout=Bl([1,Ur([0,e.recurrentDropout==null?0:e.recurrentDropout])]),this.implementation=e.implementation,this.stateSize=this.units,this.dropoutMask=null,this.recurrentDropoutMask=null}build(e){e=at(e);let t=e[e.length-1];this.kernel=this.addWeight("kernel",[t,this.units*3],null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.recurrentKernel=this.addWeight("recurrent_kernel",[this.units,this.units*3],null,this.recurrentInitializer,this.recurrentRegularizer,!0,this.recurrentConstraint),this.useBias?this.bias=this.addWeight("bias",[this.units*3],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint):this.bias=null,this.built=!0}call(e,t){return W(()=>{if(e=e,e.length!==2)throw new B(`GRUCell expects 2 input Tensors (inputs, h, c), got ${e.length}.`);let n=t.training==null?!1:t.training,a=e[1];e=e[0],0On(e),rate:this.dropout,training:n,count:3})),0On(a),rate:this.recurrentDropout,training:n,count:3}));let r=this.dropoutMask,s=this.recurrentDropoutMask,i,o,l;0{this.cell.dropoutMask!=null&&(Ee(this.cell.dropoutMask),this.cell.dropoutMask=null),this.cell.recurrentDropoutMask!=null&&(Ee(this.cell.recurrentDropoutMask),this.cell.recurrentDropoutMask=null);let n=t==null?null:t.mask,a=t==null?null:t.training,r=t==null?null:t.initialState;return super.call(e,{mask:n,training:a,initialState:r})})}static fromConfig(e,t){return t.implmentation===0&&(t.implementation=1),new e(t)}};Fy.className="GRU";ae.registerClass(Fy);var Wd=class extends Md{constructor(e){super(e);this.DEFAULT_ACTIVATION="tanh",this.DEFAULT_RECURRENT_ACTIVATION="hardSigmoid",this.DEFAULT_KERNEL_INITIALIZER="glorotNormal",this.DEFAULT_RECURRENT_INITIALIZER="orthogonal",this.DEFAULT_BIAS_INITIALIZER="zeros",this.units=e.units,Gt(this.units,"units"),this.activation=qr(e.activation===void 0?this.DEFAULT_ACTIVATION:e.activation),this.recurrentActivation=qr(e.recurrentActivation===void 0?this.DEFAULT_RECURRENT_ACTIVATION:e.recurrentActivation),this.useBias=e.useBias==null?!0:e.useBias,this.kernelInitializer=At(e.kernelInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.recurrentInitializer=At(e.recurrentInitializer||this.DEFAULT_RECURRENT_INITIALIZER),this.biasInitializer=At(e.biasInitializer||this.DEFAULT_BIAS_INITIALIZER),this.unitForgetBias=e.unitForgetBias,this.kernelRegularizer=yt(e.kernelRegularizer),this.recurrentRegularizer=yt(e.recurrentRegularizer),this.biasRegularizer=yt(e.biasRegularizer),this.kernelConstraint=Wt(e.kernelConstraint),this.recurrentConstraint=Wt(e.recurrentConstraint),this.biasConstraint=Wt(e.biasConstraint),this.dropout=Bl([1,Ur([0,e.dropout==null?0:e.dropout])]),this.recurrentDropout=Bl([1,Ur([0,e.recurrentDropout==null?0:e.recurrentDropout])]),this.implementation=e.implementation,this.stateSize=[this.units,this.units],this.dropoutMask=null,this.recurrentDropoutMask=null}build(e){var t;e=at(e);let n=e[e.length-1];this.kernel=this.addWeight("kernel",[n,this.units*4],null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.recurrentKernel=this.addWeight("recurrent_kernel",[this.units,this.units*4],null,this.recurrentInitializer,this.recurrentRegularizer,!0,this.recurrentConstraint);let a;if(this.useBias){if(this.unitForgetBias){let r=this.biasInitializer,s=this.units;a=new(t=class extends pa{apply(i,o){let l=r.apply([s]),d=new Dh().apply([s]),u=r.apply([s*2]);return O6(O6(l,d),u)}},t.className="CustomInit",t)}else a=this.biasInitializer;this.bias=this.addWeight("bias",[this.units*4],null,a,this.biasRegularizer,!0,this.biasConstraint)}else this.bias=null;this.built=!0}call(e,t){return W(()=>{let n=t.training==null?!1:t.training;if(e=e,e.length!==3)throw new B(`LSTMCell expects 3 input Tensors (inputs, h, c), got ${e.length}.`);let a=e[1],r=e[2];e=e[0],0On(e),rate:this.dropout,training:n,count:4})),0On(a),rate:this.recurrentDropout,training:n,count:4}));let s=this.dropoutMask,i=this.recurrentDropoutMask,o,l,d,u;0{this.cell.dropoutMask!=null&&(Ee(this.cell.dropoutMask),this.cell.dropoutMask=null),this.cell.recurrentDropoutMask!=null&&(Ee(this.cell.recurrentDropoutMask),this.cell.recurrentDropoutMask=null);let n=t==null?null:t.mask,a=t==null?null:t.training,r=t==null?null:t.initialState;return super.call(e,{mask:n,training:a,initialState:r})})}static fromConfig(e,t){return t.implmentation===0&&(t.implementation=1),new e(t)}};$y.className="LSTM";ae.registerClass($y);var t0=class extends Md{constructor(e){super(e);this.cells=e.cells}get stateSize(){let e=[];for(let t of this.cells.slice().reverse())Array.isArray(t.stateSize)?e.push(...t.stateSize):e.push(t.stateSize);return e}call(e,t){return W(()=>{e=e;let n=e.slice(1),a=[];for(let i of this.cells.slice().reverse())Array.isArray(i.stateSize)?a.push(n.splice(0,i.stateSize.length)):a.push(n.splice(0,1));a.reverse();let r=[],s;for(let i=0;i{Ri(`RNNCell_${a}`,()=>{n.build(e),Array.isArray(n.stateSize)?t=n.stateSize[0]:t=n.stateSize,e=[e[0],t]})}),this.built=!0}getConfig(){let e=super.getConfig(),t=a=>({className:a.getClassName(),config:a.getConfig()}),n={cells:this.cells.map(t)};return Object.assign({},e,n)}static fromConfig(e,t,n={}){let a=[];for(let r of t.cells)a.push(Na(r,n));return new e({cells:a})}get trainableWeights(){if(!this.trainable)return[];let e=[];for(let t of this.cells)e.push(...t.trainableWeights);return e}get nonTrainableWeights(){let e=[];for(let t of this.cells)e.push(...t.nonTrainableWeights);if(!this.trainable){let t=[];for(let n of this.cells)t.push(...n.trainableWeights);return t.concat(e)}return e}getWeights(){let e=[];for(let t of this.cells)e.push(...t.weights);return Q1(e)}setWeights(e){let t=[];for(let n of this.cells){let a=n.weights.length,r=e.splice(a);for(let s=0;s_6(t(),n),i=()=>Rd(s,t,a);return!r||r<=1?Ut(i().clone()):Array(r).fill(void 0).map(i).map(o=>Ut(o.clone()))}var lre=function(e,t){var n={};for(var a in e)Object.prototype.hasOwnProperty.call(e,a)&&t.indexOf(a)<0&&(n[a]=e[a]);if(e!=null&&typeof Object.getOwnPropertySymbols=="function")for(var r=0,a=Object.getOwnPropertySymbols(e);r{if(this.cell.dropoutMask!=null&&(Ee(this.cell.dropoutMask),this.cell.dropoutMask=null),this.cell.recurrentDropoutMask!=null&&(Ee(this.cell.recurrentDropoutMask),this.cell.recurrentDropoutMask=null),t&&t.constants)throw new B("ConvRNN2D cell does not support constants");let n=t==null?null:t.mask,a=t==null?null:t.training,r=t==null?null:t.initialState;return super.call(e,{mask:n,training:a,initialState:r})})}computeOutputShape(e){let t=this.computeSingleOutputShape(e);return this.returnSequences||(t=[t[0],...t.slice(2)]),this.returnState&&(t=[t,...Array(2).fill([e[0],...t.slice(-3)])]),t}getInitialState(e){return W(()=>{let{stateSize:t}=this.cell,n=e.shape,a=this.computeSingleOutputShape(n),r=[a[0],...a.slice(2)],s=Rt(r);return Array.isArray(t)?Array(t.length).fill(s):[s]})}resetStates(e,t=!1){W(()=>{if(!this.stateful)throw new ur("Cannot call resetStates() on an RNN Layer that is not stateful.");let n=this.inputSpec[0].shape,a=this.computeSingleOutputShape(n),r=[a[0],...a.slice(2)];if(n[0]==null)throw new B("If an RNN is stateful, it needs to know its batch size. Specify the batch size of your input tensors: \n- If using a Sequential model, specify the batch size by passing a `batchInputShape` option to your first layer.\n- If using the functional API, specify the batch size by passing a `batchShape` option to your Input layer.");if(this.getStates()==null)Array.isArray(this.cell.stateSize)?this.states_=this.cell.stateSize.map(()=>Rt(r)):this.states_=[Rt(r)];else if(e==null)Ee(this.states_),this.keptStates!=null&&(Ee(this.keptStates),this.keptStates=[]),Array.isArray(this.cell.stateSize)?this.states_=this.cell.stateSize.map(()=>Rt(r)):this.states_[0]=Rt(r);else{if(Array.isArray(e)||(e=[e]),e.length!==this.states_.length)throw new B(`Layer ${this.name} expects ${this.states_.length} state(s), but it received ${e.length} state value(s). Input received: ${e}`);t?this.keptStates.push(this.states_.slice()):Ee(this.states_);for(let s=0;sUt(s.clone()))})}computeSingleOutputShape(e){let{dataFormat:t,filters:n,kernelSize:a,padding:r,strides:s,dilationRate:i}=this.cell,o=t==="channelsFirst",l=e[o?3:2],d=e[o?4:3],u=Ta(l,a[0],r,s[0],i[0]),p=Ta(d,a[1],r,s[1],i[1]);return[...e.slice(0,2),...o?[n,u,p]:[u,p,n]]}};H4.className="ConvRNN2D";var r0=class extends Wd{constructor(e){let{filters:t,kernelSize:n,strides:a,padding:r,dataFormat:s,dilationRate:i}=e;super(Object.assign({},e,{units:t}));this.filters=t,Gt(this.filters,"filters"),this.kernelSize=Gl(n,2,"kernelSize"),this.kernelSize.forEach(o=>Gt(o,"kernelSize")),this.strides=Gl(a||1,2,"strides"),this.strides.forEach(o=>Gt(o,"strides")),this.padding=r||"valid",Qn(this.padding),this.dataFormat=s||"channelsLast",Ct(this.dataFormat),this.dilationRate=Gl(i||1,2,"dilationRate"),this.dilationRate.forEach(o=>Gt(o,"dilationRate"))}build(e){var t;e=at(e);let n=this.dataFormat==="channelsFirst"?1:e.length-1;if(e[n]==null)throw new B(`The channel dimension of the input should be defined. Found ${e[n]}`);let a=e[n],r=4,s=this.kernelSize.concat([a,this.filters*r]);this.kernel=this.addWeight("kernel",s,null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint);let i=this.kernelSize.concat([this.filters,this.filters*r]);if(this.recurrentKernel=this.addWeight("recurrent_kernel",i,null,this.recurrentInitializer,this.recurrentRegularizer,!0,this.recurrentConstraint),this.useBias){let o;if(this.unitForgetBias){let l=this.biasInitializer,d=this.filters;o=new(t=class extends pa{apply(u,p){let c=l.apply([d]),h=Dn([d]),m=l.apply([d*2]);return W1([c,h,m])}},t.className="CustomInit",t)}else o=this.biasInitializer;this.bias=this.addWeight("bias",[this.filters*r],null,o,this.biasRegularizer,!0,this.biasConstraint)}this.built=!0}call(e,t){return W(()=>{if(e.length!==3)throw new B(`ConvLSTM2DCell expects 3 input Tensors (inputs, h, c), got ${e.length}.`);let n=t.training||!1,a=e[0],r=e[1],s=e[2],i=4;0On(a),rate:this.dropout,training:n,count:i}));let o=this.dropoutMask,l=(Y,re,ne)=>!re||!re[ne]?Y:_(re[ne],Y),d=l(a,o,0),u=l(a,o,1),p=l(a,o,2),c=l(a,o,3);0On(r),rate:this.recurrentDropout,training:n,count:i}));let h=this.recurrentDropoutMask,m=l(r,h,0),f=l(r,h,1),A=l(r,h,2),y=l(r,h,3),g=3,[x,w,b,v]=rn(this.kernel.read(),i,g),[N,T,R,$]=this.useBias?rn(this.bias.read(),i):[null,null,null,null];d=this.inputConv(d,x,N,this.padding),u=this.inputConv(u,w,T,this.padding),p=this.inputConv(p,b,R,this.padding),c=this.inputConv(c,v,$,this.padding);let[z,P,V,j]=rn(this.recurrentKernel.read(),i,g);m=this.recurrentConv(m,z),f=this.recurrentConv(f,P),A=this.recurrentConv(A,V),y=this.recurrentConv(y,j);let U=this.recurrentActivation.apply(se(d,m)),X=this.recurrentActivation.apply(se(u,f)),G=se(_(X,s),_(U,this.activation.apply(se(p,A)))),ee=_(this.recurrentActivation.apply(se(c,y)),this.activation.apply(G));return[ee,ee,G]})}getConfig(){let e=super.getConfig(),{units:t}=e,n=lre(e,["units"]),a={filters:this.filters,kernelSize:this.kernelSize,padding:this.padding,dataFormat:this.dataFormat,dilationRate:this.dilationRate,strides:this.strides};return Object.assign({},n,a)}inputConv(e,t,n,a){let r=ar(e,t,this.strides,a||"valid",this.dataFormat==="channelsFirst"?"NCHW":"NHWC",this.dilationRate);return n?Ia(r,n,this.dataFormat):r}recurrentConv(e,t){return ar(e,t,1,"same",this.dataFormat==="channelsFirst"?"NCHW":"NHWC")}};r0.className="ConvLSTM2DCell";ae.registerClass(r0);var Dy=class extends H4{constructor(e){let t=new r0(e);super(Object.assign({},e,{cell:t}))}static fromConfig(e,t){return new e(t)}};Dy.className="ConvLSTM2D";ae.registerClass(Dy);var s0=class extends Ge{constructor(e){super(e);this.rate=Math.max(Math.min(e.rate,1),0),this.noiseShape=e.noiseShape,this.seed=e.seed,this.supportsMasking=!0}getNoiseShape(e){if(this.noiseShape==null)return this.noiseShape;let t=e.shape,n=[];for(let a=0;a{this.invokeCallHook(e,t);let n=_e(e);if(0_6(n,this.rate,r,this.seed),()=>n,a)}return e})}getConfig(){let e={rate:this.rate,noiseShape:this.noiseShape,seed:this.seed},t=super.getConfig();return Object.assign(e,t),e}dispose(){return super.dispose()}};s0.className="Dropout";ae.registerClass(s0);var Oy=class extends s0{constructor(e){super(e);this.inputSpec=[{ndim:3}]}getNoiseShape(e){let t=e.shape;return[t[0],1,t[2]]}};Oy.className="SpatialDropout1D";ae.registerClass(Oy);var zy=class extends Ge{constructor(e){super(e);if(this.activation=null,this.useBias=!0,this.kernel=null,this.bias=null,this.DEFAULT_KERNEL_INITIALIZER="glorotNormal",this.DEFAULT_BIAS_INITIALIZER="zeros",e.batchInputShape==null&&e.inputShape==null&&e.inputDim!=null){let t=null;e.batchSize!=null&&(t=e.batchSize),this.batchInputShape=[t,e.inputDim]}this.units=e.units,Gt(this.units,"units"),this.activation=qr(e.activation),e.useBias!=null&&(this.useBias=e.useBias),this.kernelInitializer=At(e.kernelInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.biasInitializer=At(e.biasInitializer||this.DEFAULT_BIAS_INITIALIZER),this.kernelConstraint=Wt(e.kernelConstraint),this.biasConstraint=Wt(e.biasConstraint),this.kernelRegularizer=yt(e.kernelRegularizer),this.biasRegularizer=yt(e.biasRegularizer),this.activityRegularizer=yt(e.activityRegularizer),this.supportsMasking=!0,this.inputSpec=[{minNDim:2}]}build(e){e=at(e);let t=e[e.length-1];this.kernel==null&&(this.kernel=this.addWeight("kernel",[t,this.units],null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.useBias&&(this.bias=this.addWeight("bias",[this.units],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint))),this.inputSpec=[{minNDim:2,axes:{[-1]:t}}],this.built=!0}computeOutputShape(e){e=at(e);let t=e.slice();return t[t.length-1]=this.units,t}call(e,t){return W(()=>{this.invokeCallHook(e,t);let n=_e(e),a=S6(this.activation.getClassName()),r;return a!=null?r=Ua(n,this.kernel.read(),a,this.bias?this.bias.read():null):(r=Ua(n,this.kernel.read()),this.bias!=null&&(r=Ia(r,this.bias.read())),this.activation!=null&&(r=this.activation.apply(r))),r})}getConfig(){let e={units:this.units,activation:Gr(this.activation),useBias:this.useBias,kernelInitializer:It(this.kernelInitializer),biasInitializer:It(this.biasInitializer),kernelRegularizer:ut(this.kernelRegularizer),biasRegularizer:ut(this.biasRegularizer),activityRegularizer:ut(this.activityRegularizer),kernelConstraint:Lt(this.kernelConstraint),biasConstraint:Lt(this.biasConstraint)},t=super.getConfig();return Object.assign(e,t),e}};zy.className="Dense";ae.registerClass(zy);var _y=class extends Ge{constructor(e){e=e||{},super(e),this.inputSpec=[{minNDim:3}],this.dataFormat=e.dataFormat}computeOutputShape(e){e=at(e);for(let t of e.slice(1))if(t==null)throw new B(`The shape of the input to "Flatten" is not fully defined (got ${e.slice(1)}). Make sure to pass a complete "input_shape" or "batch_input_shape" argument to the first layer in your model.`);return[e[0],jr(e,1)]}call(e,t){return W(()=>{this.invokeCallHook(e,t);let n=_e(e);if(this.dataFormat==="channelsFirst"&&n.rank>1){let a=[0];for(let r=2;r{this.invokeCallHook(e,t);let n=_e(e);return this.activation.apply(n)})}getConfig(){let e={activation:Gr(this.activation)},t=super.getConfig();return Object.assign(e,t),e}};Py.className="Activation";ae.registerClass(Py);var Ly=class extends Ge{constructor(e){super(e);this.n=e.n,this.inputSpec=[{ndim:2}]}computeOutputShape(e){return[e[0],this.n,e[1]]}call(e,t){return W(()=>(e=_e(e),Rte(e,this.n)))}getConfig(){let e={n:this.n},t=super.getConfig();return Object.assign(e,t),e}};Ly.className="RepeatVector";ae.registerClass(Ly);var Wy=class extends Ge{constructor(e){super(e);this.targetShape=e.targetShape;for(let t=0;t{this.invokeCallHook(e,t);let n=_e(e),a=n.shape,r=a.slice(0,1).concat(this.fixUnknownDimension(a.slice(1),this.targetShape));return n.reshape(r)})}getConfig(){let e={targetShape:this.targetShape},t=super.getConfig();return Object.assign(e,t),e}};Wy.className="Reshape";ae.registerClass(Wy);var By=class extends Ge{constructor(e){super(e);if(e.dims==null)throw new Error("Required configuration field `dims` is missing during Permute constructor call.");if(!Array.isArray(e.dims))throw new Error(`Permute constructor requires \`dims\` to be an Array, but received ${e.dims} instead.`);let t=ka(1,e.dims.length+1);if(!k.arraysEqual(e.dims.slice().sort(),t))throw new Error("Invalid permutation `dims`: "+JSON.stringify(e.dims)+" `dims` must contain consecutive integers starting from 1.");this.dims=e.dims,this.dimsIncludingBatch=[0].concat(this.dims),this.inputSpec=[new Ft({ndim:this.dims.length+1})]}computeOutputShape(e){e=at(e);let t=e.slice();return this.dims.forEach((n,a)=>{t[a+1]=e[n]}),t}call(e,t){return Ze(_e(e),this.dimsIncludingBatch)}getConfig(){let e={dims:this.dims},t=super.getConfig();return Object.assign(e,t),e}};By.className="Permute";ae.registerClass(By);var Vy=class extends Ge{constructor(e){super(e==null?{}:e);this.supportsMasking=!0,e!=null?this.maskValue=e.maskValue==null?0:e.maskValue:this.maskValue=0}computeOutputShape(e){return e}getConfig(){let e=super.getConfig(),t={maskValue:this.maskValue};return Object.assign(t,e),t}computeMask(e,t){let n=_e(e),a=-1;return ju(Ai(n,this.maskValue),a)}call(e,t){return W(()=>{this.invokeCallHook(e,t);let n=_e(e),a=-1,r=!0,s=ju(Ai(n,this.maskValue),a,r);return n.mul(s.asType(n.dtype))})}};Vy.className="Masking";ae.registerClass(Vy);var jy=class extends Ge{constructor(e){super(e);if(this.embeddings=null,this.DEFAULT_EMBEDDINGS_INITIALIZER="randomUniform",e.batchInputShape==null&&e.inputShape==null){let t=null;e.batchSize!=null&&(t=e.batchSize),e.inputLength==null?this.batchInputShape=[t,null]:this.batchInputShape=[t].concat(ft(e.inputLength))}this.inputDim=e.inputDim,Gt(this.inputDim,"inputDim"),this.outputDim=e.outputDim,Gt(this.outputDim,"outputDim"),this.embeddingsInitializer=At(e.embeddingsInitializer||this.DEFAULT_EMBEDDINGS_INITIALIZER),this.embeddingsRegularizer=yt(e.embeddingsRegularizer),this.activityRegularizer=yt(e.activityRegularizer),this.embeddingsConstraint=Wt(e.embeddingsConstraint),this.maskZero=e.maskZero,this.supportsMasking=e.maskZero,this.inputLength=e.inputLength}build(e){this.embeddings=this.addWeight("embeddings",[this.inputDim,this.outputDim],this.dtype,this.embeddingsInitializer,this.embeddingsRegularizer,!0,this.embeddingsConstraint),this.built=!0}warnOnIncompatibleInputShape(e){}computeMask(e,t){return W(()=>this.maskZero?(e=_e(e),Ai(e,Ue(e))):null)}computeOutputShape(e){if(e=at(e),this.inputLength==null)return[...e,this.outputDim];let t=ft(this.inputLength);if(t.length!==e.length-1)throw new B(`"inputLength" is ${this.inputLength}, but received input shape has shape ${e}`);{let n=0;for(let a=0;a{this.invokeCallHook(e,t);let n=_e(e);return n.dtype!=="int32"&&(n=Td(n,"int32")),z6(this.embeddings.read(),n.as1D()).reshape(at(this.computeOutputShape(n.shape)))})}getConfig(){let e={inputDim:this.inputDim,outputDim:this.outputDim,embeddingsInitializer:It(this.embeddingsInitializer),embeddingsRegularizer:ut(this.embeddingsRegularizer),activityRegularizer:ut(this.activityRegularizer),embeddingsConstraint:Lt(this.embeddingsConstraint),maskZero:this.maskZero,inputLength:this.inputLength},t=super.getConfig();return Object.assign(e,t),e}};jy.className="Embedding";ae.registerClass(jy);var Oi=class extends Ge{constructor(e){super(e||{});this.supportsMasking=!0}mergeFunction(e){throw new Oe}computeElementwiseOpOutputShape(e,t){if(e==null||t==null)return null;if(e.length1)throw new B(`Can not merge tensors with different batch sizes. Got tensors with shapes: ${JSON.stringify(e)}.`);let n=e[0]==null?null:e[0].slice(1);for(let r=1;rr.length);e.indexOf(null)===-1&&Vr(a).length===1?this.reshapeRequired=!1:this.reshapeRequired=!0}call(e,t){return W(()=>{if(e=e,this.reshapeRequired){let n=[],a=e.map(r=>r.rank);if(a.indexOf(null)===-1){let r=Ur(a);for(let s of e){let i=s.rank;for(let o=0;o1){let d=ka(1,l).concat([0]);n.push(Ze(o,d)),r=!0}else n.push(o)}let s=this.mergeFunction(n),i=s.rank;if(r){if(i==null){let o=s.shape,l=o.length,d=o[l-1],u=[d].concat(o.slice(0,o.length-1));s=Ze(s.reshape([-1,d]),[1,0]).reshape(u)}else if(i>1){let o=[i-1].concat(ka(0,i-1));s=Ze(s,o)}}return s}}else return this.mergeFunction(e)})}computeOutputShape(e){e=e;let t;e[0]==null?t=null:t=e[0].slice(1);for(let a=1;a{if(t==null)return null;if(!Array.isArray(t))throw new B("`mask` should be an Array");if(!Array.isArray(e))throw new B("`inputs` should be an Array");if(t.length!==e.length)throw new B(`The Array 'inputs' and 'mask' are expected to have the same length, but have different lengths (${e.length} vs ${t.length})`);if(t.every(a=>a==null))return null;t=t.map(a=>a==null?a:un(a,0));let n=t[0];for(let a=1;a{let t=e[0].clone();for(let n=1;n{let t=e[0].clone();for(let n=1;n{let t=e[0].clone();for(let n=1;n{let t=e[0];for(let n=1;n{let t=e[0];for(let n=1;n1)throw new B("A `Concatenate` layer requires inputs with matching shapes except for the concat axis. Got input shapes: "+JSON.stringify(e))}mergeFunction(e){return W(()=>W1(e,this.axis))}computeOutputShape(e){if(!(Array.isArray(e)&&Array.isArray(e[0])))throw new B("A `Concatenate` layer should be called on a list of inputs.");let t=e,n=t[0].slice(),a=this.axis<0?n.length+this.axis:this.axis;for(let r of t.slice(1)){if(n[a]==null||r[a]==null){n[a]=null;break}n[a]+=r[a]}return n}computeMask(e,t){if(t==null)return null;if(!Array.isArray(t))throw new B("`mask` should be an array for Concatenate");if(!Array.isArray(e))throw new B("`inputs` should be an array for Concatenate");if(t.length!==e.length)throw new B(`Mismatch in the length of mask (${t.length}) and the legnth of inputs (${e.length})`);return W(()=>{let n=!0;if(t.forEach(s=>{if(s!=null){n=!1;return}}),n)return null;let a=[];for(let s=0;s3||t.shape.length>3)throw new Oe("batchDot is not implemented for tensors of 4D or higher rank yet");if(k.assert(e.shape.length>=2,()=>`batchDot requires the rank of x to be >= 2, but got ${e.shape.length}`),k.assert(e.shape.length>=2,()=>`batchDot requires the rank of y to be >= 2, but got ${t.shape.length}`),typeof n=="number"&&(n=[n,n]),e.dtype==="complex64"||t.dtype==="complex64")throw new Oe("batchDot is not implemented for complex64-type Tensors yet.");let a=e.shape.length,r=t.shape.length;n==null&&(n=[a-1,r-2]);let s=n;return W(()=>{let i;if(a>r){i=a-r;let l=[];for(let d=0;da){i=r-a;let l=[];for(let d=0;d0){let l;a>r?l=a+r-3:l=a-1;let d=[];for(let u=l;u"A `Dot` layer should be called on a list of exactly 2 inputs.");let t=e[0],n=e[1];if(t.length>3||n.length>3)throw new Oe("Dot layer does not support tensors of 4D or higher rank yet.");let a=this.interpretAxes(t,n);if(t[a[0]]!==n[a[1]])throw new B(`Dimension incompatibility: ${t[a[0]]} !== ${n[a[1]]}`)}mergeFunction(e){if(e.length!==2)throw new B(`A \`Dot\` layer must be called on exactly 2 inputs, but received ${e.length} input(s).`);let t=e[0],n=e[1],a;return Array.isArray(this.axes)?a=this.axes.map((r,s)=>Bd(r,e[s].shape.length)):a=[Bd(this.axes,t.shape.length),Bd(this.axes,n.shape.length)],this.normalize&&(t=Gh(t,a[0]),n=Gh(n,a[1])),ure(t,n,a)}interpretAxes(e,t){let n;return Array.isArray(this.axes)?n=this.axes:n=[Bd(this.axes,e.length),Bd(this.axes,t.length)],n}computeOutputShape(e){k.assert(Array.isArray(e)&&e.length===2&&Array.isArray(e[0])&&Array.isArray(e[1]),()=>"A `Dot` layer should be called on a list of exactly 2 inputs.");let t=e[0].slice(),n=e[1].slice();if(t.length>3||n.length>3)throw new Oe("Dot layer does not support tensors of 4D or higher rank yet.");let a=this.interpretAxes(t,n);t.splice(a[0],1),n.splice(a[1],1),n.splice(0,1);let r=t.concat(n);return r.length===1&&r.push(1),r}computeMask(e,t){return null}getConfig(){let e={axes:this.axes,normalize:this.normalize},t=super.getConfig();return Object.assign(e,t),e}};Zy.className="Dot";ae.registerClass(Zy);var Yy=class extends Ge{constructor(e){super(e);this.supportsMasking=!0,this.stddev=e.stddev}computeOutputShape(e){return e}getConfig(){let e=super.getConfig(),t={stddev:this.stddev};return Object.assign(t,e),t}call(e,t){return W(()=>{this.invokeCallHook(e,t);let n=_e(e);return Rd(()=>$h(n.shape,0,this.stddev).add(n),()=>n,t.training||!1)})}};Yy.className="GaussianNoise";ae.registerClass(Yy);var Jy=class extends Ge{constructor(e){super(e);this.supportsMasking=!0,this.rate=e.rate}computeOutputShape(e){return e}getConfig(){let e=super.getConfig(),t={rate:this.rate};return Object.assign(t,e),t}call(e,t){return W(()=>{this.invokeCallHook(e,t);let n=_e(e);return this.rate>0&&this.rate<1?Rd(()=>{let a=Math.sqrt(this.rate/(1-this.rate));return n.mul($h(n.shape,1,a))},()=>n,t.training||!1):n})}};Jy.className="GaussianDropout";ae.registerClass(Jy);var Qy=class extends Ge{constructor(e){super(e);this.supportsMasking=!0,this.rate=e.rate,this.noiseShape=e.noiseShape}_getNoiseShape(e){return this.noiseShape||_e(e).shape}computeOutputShape(e){return e}getConfig(){let e=super.getConfig(),t={rate:this.rate};return Object.assign(t,e),t}call(e,t){return W(()=>{if(this.rate<1&&this.rate>0){let n=this._getNoiseShape(e);return Rd(()=>{let a=_e(e),r=1.6732632423543772,s=1.0507009873554805,i=-r*s,o=Dr(bl(n),this.rate);o=Td(o,"float32");let l=((1-this.rate)*(1+this.rate*i**2))**-.5,d=-l*i*this.rate;return a.mul(o).add(o.add(-1).mul(i)).mul(l).add(d)},()=>_e(e),t.training||!1)}return e})}};Qy.className="AlphaDropout";ae.registerClass(Qy);function Vd(e,t,n,a,r,s=.001){let i;if(e.rank===2)i=Tb(e,t,n,a,r,s);else if(e.rank===3)i=Eb(e,t,n,a,r,s);else if(e.rank===4)i=Cb(e,t,n,a,r,s);else throw new Oe(`batchNormalization is not implemented for array of rank ${e.rank} yet`);return i}function dre(e,t,n,a,r=.001){return W(()=>{let s=Rc(e,a),i=s.mean,o=s.variance;return[Vd(e,i,o,n,t,r),i,o]})}function pre(e,t,n,a,r=.001){return W(()=>{let s=Rc(e,a),i=s.mean,o=s.variance,l=[];for(let h of ka(0,e.rank))a.indexOf(h)!==-1?l.push(1):l.push(e.shape[h]);let d=i.reshape(l),u=o.reshape(l),p=t==null?null:t.reshape(l),c=n==null?null:n.reshape(l);return[Vd(e,d,u,c,p,r),i,o]})}function cre(e,t,n,a,r=.001){return k.arraysEqual(a.slice().sort(),ka(0,e.rank-1))?dre(e,t,n,a,r):pre(e,t,n,a,r)}var e2=class extends Ge{constructor(e){e==null&&(e={}),super(e),this.supportsMasking=!0,this.axis=e.axis==null?-1:e.axis,this.momentum=e.momentum==null?.99:e.momentum,this.epsilon=e.epsilon==null?.001:e.epsilon,this.center=e.center==null?!0:e.center,this.scale=e.scale==null?!0:e.scale,this.betaInitializer=At(e.betaInitializer||"zeros"),this.gammaInitializer=At(e.gammaInitializer||"ones"),this.movingMeanInitializer=At(e.movingMeanInitializer||"zeros"),this.movingVarianceInitializer=At(e.movingVarianceInitializer||"ones"),this.betaConstraint=Wt(e.betaConstraint),this.gammaConstraint=Wt(e.gammaConstraint),this.betaRegularizer=yt(e.betaRegularizer),this.gammaRegularizer=yt(e.gammaRegularizer)}build(e){e=at(e);let t=this.axis>=0?this.axis:this.axis+e.length,n=e[t];if(n==null)throw new B(`Axis ${t} of input tensor should have a defined dimension but the layer received an input with shape ${JSON.stringify(e)}.`);this.inputSpec=[new Ft({ndim:e.length,axes:{[t]:n}})];let a=[n];this.scale&&(this.gamma=this.addWeight("gamma",a,null,this.gammaInitializer,this.gammaRegularizer,!0,this.gammaConstraint)),this.center&&(this.beta=this.addWeight("beta",a,null,this.betaInitializer,this.betaRegularizer,!0,this.betaConstraint)),this.movingMean=this.addWeight("moving_mean",a,null,this.movingMeanInitializer,null,!1),this.movingVariance=this.addWeight("moving_variance",a,null,this.movingVarianceInitializer,null,!1),this.built=!0}call(e,t){return W(()=>{let n=t.training==null?!1:t.training,a=_e(e),r=a.shape,s=r.length,i=ka(0,s),o=this.axis>=0?this.axis:this.axis+s;i.splice(o,1);let l=Ti(1,s);l[o]=r[o];let d=i.slice();d.sort();let u=!k.arraysEqual(d,ka(0,s).slice(0,s-1)),p=()=>{if(u){let A=this.movingMean.read().reshape(l),y=this.movingVariance.read().reshape(l),g=this.center?this.beta.read().reshape(l):null,x=this.scale?this.gamma.read().reshape(l):null;return Vd(a,A,y,g,x,this.epsilon)}else return Vd(a,this.movingMean.read(),this.movingVariance.read(),this.beta==null?null:this.beta.read(),this.gamma==null?null:this.gamma.read(),this.epsilon)};if(!n)return p();let[c,h,m]=cre(a,this.gamma.read(),this.beta.read(),i,this.epsilon),f=(A,y,g)=>{W(()=>{let x=1-g,w=A.read(),b=w.sub(y).mul(x);A.write(w.sub(b))})};return(()=>{f(this.movingMean,h,this.momentum),f(this.movingVariance,m,this.momentum)})(),c})}getConfig(){let e={axis:this.axis,momentum:this.momentum,epsilon:this.epsilon,center:this.center,scale:this.scale,betaInitializer:It(this.betaInitializer),gammaInitializer:It(this.gammaInitializer),movingMeanInitializer:It(this.movingMeanInitializer),movingVarianceInitializer:It(this.movingVarianceInitializer),betaRegularizer:ut(this.betaRegularizer),gammaRegularizer:ut(this.gammaRegularizer),betaConstraint:Lt(this.betaConstraint),gammaConstraint:Lt(this.gammaConstraint)},t=super.getConfig();return Object.assign(e,t),e}};e2.className="BatchNormalization";ae.registerClass(e2);var t2=class extends Ge{constructor(e){if(e==null&&(e={}),super(e),this.axis=e.axis==null?-1:e.axis,typeof this.axis=="number"){if(!Number.isInteger(this.axis))throw new Error(`Expected axis to be an integer, but received ${this.axis}`)}else if(Array.isArray(this.axis)){for(let t of this.axis)if(!Number.isInteger(t))throw new Error(`Expected axis to be an array of integers, but received ${JSON.stringify(this.axis)}`)}else throw new Error(`Expected axis to be an integer or an array of integers, but received ${JSON.stringify(this.axis)}`);this.epsilon=e.epsilon==null?.001:e.epsilon,this.center=e.center==null?!0:e.center,this.scale=e.scale==null?!0:e.scale,this.betaInitializer=At(e.betaInitializer||"zeros"),this.gammaInitializer=At(e.gammaInitializer||"ones"),this.betaRegularizer=yt(e.betaRegularizer),this.gammaRegularizer=yt(e.gammaRegularizer),this.supportsMasking=!0}build(e){e=at(e);let t=e.length;typeof this.axis=="number"&&(this.axis=[this.axis]);for(let r=0;r=t)throw new Error(`Invalid axis: ${r}`);if(this.axis.length!==Vr(this.axis).length)throw new Error(`Found duplicate axes in: ${this.axis}`);let n=this.axis.map(r=>e[r]),a=!0;this.scale?this.gamma=this.addWeight("gamma",n,"float32",this.gammaInitializer,this.gammaRegularizer,a):this.gamma=null,this.center?this.beta=this.addWeight("beta",n,"float32",this.betaInitializer,this.betaRegularizer,a):this.beta=null,this.built=!0}call(e,t){let n=_e(e),a=n.shape,r=a.length;return W(()=>{let s=!0,{mean:i,variance:o}=Rc(n,this.axis,s),l=Ti(1,r);for(let m of this.axis)l[m]=a[m];let d=m=>m!=null&&m.shape.length!==r&&this.axis!==[r-1]?m.reshape(l):m,u=d(this.gamma.read()),p=d(this.beta.read()),c=[],h=[];for(let m=0;m{if(e.rank!==4)throw new B(`temporalPadding expects input tensor to be 4-D, but received a ${e.rank}-D tensor.`);if(t==null&&(t=[[1,1],[1,1]]),t.length!==2||t[0].length!==2||t[1].length!==2)throw new B("spatial2dPadding expects `padding` to be an Array of two Arrays, each of which is an Array of two integers.");if(n==null&&(n=va()),n!=="channelsLast"&&n!=="channelsFirst")throw new B(`Unknown data format: ${n}. Supported data formats are 'channelsLast' and 'channelsFirst.`);let a;return n==="channelsFirst"?a=[[0,0],[0,0],t[0],t[1]]:a=[[0,0],t[0],t[1],[0,0]],rr(e,a)})}var n2=class extends Ge{constructor(e){if(e==null&&(e={}),super(e),this.dataFormat=e.dataFormat==null?va():e.dataFormat,e.padding==null)this.padding=[[1,1],[1,1]];else if(typeof e.padding=="number")this.padding=[[e.padding,e.padding],[e.padding,e.padding]];else{if(e.padding=e.padding,e.padding.length!==2)throw new B(`ZeroPadding2D expects padding to be a length-2 array, but received a length-${e.padding.length} array.`);let t,n;if(typeof e.padding[0]=="number")t=[e.padding[0],e.padding[0]],n=[e.padding[1],e.padding[1]];else{if(e.padding=e.padding,e.padding[0].length!==2)throw new B(`ZeroPadding2D expects height padding to be a length-2 array, but received a length-${e.padding[0].length} array.`);if(t=e.padding[0],e.padding[1].length!==2)throw new B(`ZeroPadding2D expects width padding to be a length-2 array, but received a length-${e.padding[1].length} array.`);n=e.padding[1]}this.padding=[t,n]}this.inputSpec=[new Ft({ndim:4})]}computeOutputShape(e){e=at(e);let t,n;return this.dataFormat==="channelsFirst"?(e[2]!=null&&e[2]>=0?t=e[2]+this.padding[0][0]+this.padding[0][1]:t=null,e[3]!=null&&e[3]>=0?n=e[3]+this.padding[1][0]+this.padding[1][1]:n=null,[e[0],e[1],t,n]):(e[1]!=null&&e[1]>=0?t=e[1]+this.padding[0][0]+this.padding[0][1]:t=null,e[2]!=null&&e[2]>=0?n=e[2]+this.padding[1][0]+this.padding[1][1]:n=null,[e[0],t,n,e[3]])}call(e,t){return W(()=>hre(_e(e),this.padding,this.dataFormat))}getConfig(){let e={padding:this.padding,dataFormat:this.dataFormat},t=super.getConfig();return Object.assign(e,t),e}};n2.className="ZeroPadding2D";ae.registerClass(n2);function i0(e,t,n,a,r,s){return W(()=>{Ct(r),C6(s),Qn(a),n==null&&(n=[1,1]),a==null&&(a="valid"),r==null&&(r=va()),s==null&&(s="max"),e=ky(e,r);let i,o=a==="same"?"same":"valid";return s==="max"?i=Yu(e,t,n,o):i=Gu(e,t,n,o),r==="channelsFirst"&&(i=Ze(i,[0,3,1,2])),i})}function G4(e,t,n,a,r,s){return W(()=>{Ct(r),C6(s),Qn(a),n==null&&(n=[1,1,1]),a==null&&(a="valid"),r==null&&(r=va()),s==null&&(s="max"),e=W4(e,r);let i,o=a==="same"?"same":"valid";return s==="max"?i=kA(e,t,n,o):i=oA(e,t,n,o),r==="channelsFirst"&&(i=Ze(i,[0,4,1,2,3])),i})}var q4=class extends Ge{constructor(e){if(e.poolSize==null&&(e.poolSize=2),super(e),typeof e.poolSize=="number")this.poolSize=[e.poolSize];else if(Array.isArray(e.poolSize)&&e.poolSize.length===1&&typeof e.poolSize[0]=="number")this.poolSize=e.poolSize;else throw new B(`poolSize for 1D convolutional layer must be a number or an Array of a single number, but received ${JSON.stringify(e.poolSize)}`);if(Gt(this.poolSize,"poolSize"),e.strides==null)this.strides=this.poolSize;else if(typeof e.strides=="number")this.strides=[e.strides];else if(Array.isArray(e.strides)&&e.strides.length===1&&typeof e.strides[0]=="number")this.strides=e.strides;else throw new B(`strides for 1D convolutional layer must be a number or an Array of a single number, but received ${JSON.stringify(e.strides)}`);Gt(this.strides,"strides"),this.padding=e.padding==null?"valid":e.padding,Qn(this.padding),this.inputSpec=[new Ft({ndim:3})]}computeOutputShape(e){e=at(e);let t=Ta(e[1],this.poolSize[0],this.padding,this.strides[0]);return[e[0],t,e[2]]}call(e,t){return W(()=>{this.invokeCallHook(e,t),e=Ed(_e(e),2);let n=this.poolingFunction(_e(e),[this.poolSize[0],1],[this.strides[0],1],this.padding,"channelsLast");return zr(n,[2])})}getConfig(){let e={poolSize:this.poolSize,padding:this.padding,strides:this.strides},t=super.getConfig();return Object.assign(e,t),e}},a2=class extends q4{constructor(e){super(e)}poolingFunction(e,t,n,a,r){return Ct(r),Qn(a),i0(e,t,n,a,r,"max")}};a2.className="MaxPooling1D";ae.registerClass(a2);var r2=class extends q4{constructor(e){super(e)}poolingFunction(e,t,n,a,r){return Ct(r),Qn(a),i0(e,t,n,a,r,"avg")}};r2.className="AveragePooling1D";ae.registerClass(r2);var X4=class extends Ge{constructor(e){if(e.poolSize==null&&(e.poolSize=[2,2]),super(e),this.poolSize=Array.isArray(e.poolSize)?e.poolSize:[e.poolSize,e.poolSize],e.strides==null)this.strides=this.poolSize;else if(Array.isArray(e.strides)){if(e.strides.length!==2)throw new B(`If the strides property of a 2D pooling layer is an Array, it is expected to have a length of 2, but received length ${e.strides.length}.`);this.strides=e.strides}else this.strides=[e.strides,e.strides];Gt(this.poolSize,"poolSize"),Gt(this.strides,"strides"),this.padding=e.padding==null?"valid":e.padding,this.dataFormat=e.dataFormat==null?"channelsLast":e.dataFormat,Ct(this.dataFormat),Qn(this.padding),this.inputSpec=[new Ft({ndim:4})]}computeOutputShape(e){e=at(e);let t=this.dataFormat==="channelsFirst"?e[2]:e[1],n=this.dataFormat==="channelsFirst"?e[3]:e[2];return t=Ta(t,this.poolSize[0],this.padding,this.strides[0]),n=Ta(n,this.poolSize[1],this.padding,this.strides[1]),this.dataFormat==="channelsFirst"?[e[0],e[1],t,n]:[e[0],t,n,e[3]]}call(e,t){return W(()=>(this.invokeCallHook(e,t),this.poolingFunction(_e(e),this.poolSize,this.strides,this.padding,this.dataFormat)))}getConfig(){let e={poolSize:this.poolSize,padding:this.padding,strides:this.strides,dataFormat:this.dataFormat},t=super.getConfig();return Object.assign(e,t),e}},s2=class extends X4{constructor(e){super(e)}poolingFunction(e,t,n,a,r){return Ct(r),Qn(a),i0(e,t,n,a,r,"max")}};s2.className="MaxPooling2D";ae.registerClass(s2);var i2=class extends X4{constructor(e){super(e)}poolingFunction(e,t,n,a,r){return Ct(r),Qn(a),i0(e,t,n,a,r,"avg")}};i2.className="AveragePooling2D";ae.registerClass(i2);var K4=class extends Ge{constructor(e){if(e.poolSize==null&&(e.poolSize=[2,2,2]),super(e),this.poolSize=Array.isArray(e.poolSize)?e.poolSize:[e.poolSize,e.poolSize,e.poolSize],e.strides==null)this.strides=this.poolSize;else if(Array.isArray(e.strides)){if(e.strides.length!==3)throw new B(`If the strides property of a 3D pooling layer is an Array, it is expected to have a length of 3, but received length ${e.strides.length}.`);this.strides=e.strides}else this.strides=[e.strides,e.strides,e.strides];Gt(this.poolSize,"poolSize"),Gt(this.strides,"strides"),this.padding=e.padding==null?"valid":e.padding,this.dataFormat=e.dataFormat==null?"channelsLast":e.dataFormat,Ct(this.dataFormat),Qn(this.padding),this.inputSpec=[new Ft({ndim:5})]}computeOutputShape(e){e=at(e);let t=this.dataFormat==="channelsFirst"?e[2]:e[1],n=this.dataFormat==="channelsFirst"?e[3]:e[2],a=this.dataFormat==="channelsFirst"?e[4]:e[3];return t=Ta(t,this.poolSize[0],this.padding,this.strides[0]),n=Ta(n,this.poolSize[1],this.padding,this.strides[1]),a=Ta(a,this.poolSize[2],this.padding,this.strides[2]),this.dataFormat==="channelsFirst"?[e[0],e[1],t,n,a]:[e[0],t,n,a,e[4]]}call(e,t){return W(()=>(this.invokeCallHook(e,t),this.poolingFunction(_e(e),this.poolSize,this.strides,this.padding,this.dataFormat)))}getConfig(){let e={poolSize:this.poolSize,padding:this.padding,strides:this.strides,dataFormat:this.dataFormat},t=super.getConfig();return Object.assign(e,t),e}},o2=class extends K4{constructor(e){super(e)}poolingFunction(e,t,n,a,r){return Ct(r),Qn(a),G4(e,t,n,a,r,"max")}};o2.className="MaxPooling3D";ae.registerClass(o2);var l2=class extends K4{constructor(e){super(e)}poolingFunction(e,t,n,a,r){return Ct(r),Qn(a),G4(e,t,n,a,r,"avg")}};l2.className="AveragePooling3D";ae.registerClass(l2);var Z4=class extends Ge{constructor(e){super(e);this.inputSpec=[new Ft({ndim:3})]}computeOutputShape(e){return[e[0],e[2]]}call(e,t){throw new Oe}},u2=class extends Z4{constructor(e){super(e||{})}call(e,t){return W(()=>{let n=_e(e);return kt(n,1)})}};u2.className="GlobalAveragePooling1D";ae.registerClass(u2);var d2=class extends Z4{constructor(e){super(e||{})}call(e,t){return W(()=>{let n=_e(e);return Kn(n,1)})}};d2.className="GlobalMaxPooling1D";ae.registerClass(d2);var Y4=class extends Ge{constructor(e){super(e);this.dataFormat=e.dataFormat==null?"channelsLast":e.dataFormat,Ct(this.dataFormat),this.inputSpec=[new Ft({ndim:4})]}computeOutputShape(e){return e=e,this.dataFormat==="channelsLast"?[e[0],e[3]]:[e[0],e[1]]}call(e,t){throw new Oe}getConfig(){let e={dataFormat:this.dataFormat},t=super.getConfig();return Object.assign(e,t),e}},p2=class extends Y4{call(e,t){return W(()=>{let n=_e(e);return this.dataFormat==="channelsLast"?kt(n,[1,2]):kt(n,[2,3])})}};p2.className="GlobalAveragePooling2D";ae.registerClass(p2);var c2=class extends Y4{call(e,t){return W(()=>{let n=_e(e);return this.dataFormat==="channelsLast"?Kn(n,[1,2]):Kn(n,[2,3])})}};c2.className="GlobalMaxPooling2D";ae.registerClass(c2);var J4=class extends Ge{constructor(e){super(e);this.layer=e.layer}build(e){this.built=!0}get trainable(){return this.layer!=null?this.layer.trainable:!1}set trainable(e){this.layer!=null&&(this.layer.trainable=e)}get trainableWeights(){return this.layer.trainableWeights}get nonTrainableWeights(){return this.layer.nonTrainableWeights}get updates(){return this.layer._updates}get losses(){return this.layer.losses}getWeights(){return this.layer.getWeights()}setWeights(e){this.layer.setWeights(e)}getConfig(){let e={layer:{className:this.layer.getClassName(),config:this.layer.getConfig()}},t=super.getConfig();return Object.assign(e,t),e}setFastWeightInitDuringBuild(e){super.setFastWeightInitDuringBuild(e),this.layer!=null&&this.layer.setFastWeightInitDuringBuild(e)}static fromConfig(e,t,n={}){let a=t.layer,r=Na(a,n);delete t.layer;let s={layer:r};return Object.assign(s,t),new e(s)}},h2=class extends J4{constructor(e){super(e);this.supportsMasking=!0}build(e){if(e=at(e),e.length<3)throw new B(`TimeDistributed layer expects an input shape >= 3D, but received input shape ${JSON.stringify(e)}`);this.inputSpec=[{shape:e}];let t=[e[0]].concat(e.slice(2));this.layer.built||(this.layer.build(t),this.layer.built=!0),super.build(e)}computeOutputShape(e){e=at(e);let t=[e[0]].concat(e.slice(2)),n=this.layer.computeOutputShape(t),a=e[1];return[n[0],a].concat(n.slice(1))}call(e,t){return W(()=>(e=_e(e),U4((n,a)=>[_e(this.layer.call(n,t)),[]],e,[],!1,null,null,!1,!0)[1]))}};h2.className="TimeDistributed";ae.registerClass(h2);function fre(e){Ci(Ste,"BidirectionalMergeMode",e)}var mre="concat",f2=class extends J4{constructor(e){super(e);let t=e.layer.getConfig(),n={};n.className=e.layer.getClassName(),n.config=t,this.forwardLayer=Na(n),t.goBackwards=t.goBackwards!==!0;let a={};if(a.className=e.layer.getClassName(),a.config=t,this.backwardLayer=Na(a),this.forwardLayer.name="forward_"+this.forwardLayer.name,this.backwardLayer.name="backward_"+this.backwardLayer.name,this.mergeMode=e.mergeMode===void 0?mre:e.mergeMode,fre(this.mergeMode),e.weights)throw new Oe("weights support is not implemented for Bidirectional layer yet.");this._stateful=e.layer.stateful,this.returnSequences=e.layer.returnSequences,this.returnState=e.layer.returnState,this.supportsMasking=!0,this._trainable=!0,this.inputSpec=e.layer.inputSpec,this.numConstants=null}get trainable(){return this._trainable}set trainable(e){this._trainable=e,this.forwardLayer!=null&&(this.forwardLayer.trainable=e),this.backwardLayer!=null&&(this.backwardLayer.trainable=e)}getWeights(){return this.forwardLayer.getWeights().concat(this.backwardLayer.getWeights())}setWeights(e){let t=e.length,n=Math.floor(t/2);this.forwardLayer.setWeights(e.slice(0,n)),this.backwardLayer.setWeights(e.slice(n))}computeOutputShape(e){let t=this.forwardLayer.computeOutputShape(e);Array.isArray(t)&&Array.isArray(t[0])||(t=[t]),t=t;let n,a,r;return this.returnState&&(r=t.slice(1)),n=t[0],n=n,this.mergeMode==="concat"?(n[n.length-1]*=2,a=[n]):this.mergeMode==null?a=[n,n.slice()]:a=[n],this.returnState?this.mergeMode==null?a.concat(r).concat(r.slice()):[n].concat(r).concat(r.slice()):Nn(a)}apply(e,t){let n=t==null?null:t.initialState,a=t==null?null:t.constants;t==null&&(t={});let r=j4(e,n,a,this.numConstants);if(e=r.inputs,n=r.initialState,a=r.constants,Array.isArray(e)&&(n=e.slice(1),e=e[0]),(n==null||n.length===0)&&a==null)return super.apply(e,t);let s=[],i=[];if(n!=null){let l=n.length;if(l%2>0)throw new B("When passing `initialState` to a Bidrectional RNN, the state should be an Array containing the states of the underlying RNNs.");t.initialState=n,s.push(...n);let d=n.map(u=>new Ft({shape:u.shape}));this.forwardLayer.stateSpec=d.slice(0,l/2),this.backwardLayer.stateSpec=d.slice(l/2),i.push(...d)}if(a!=null)throw new Oe("Support for constants in Bidirectional layers is not implemented yet.");let o=s[0]instanceof Sa;for(let l of s)if(l instanceof Sa!==o)throw new B("The initial state of a Bidirectional layer cannot be specified as a mix of symbolic and non-symbolic tensors");if(o){let l=[e].concat(s),d=this.inputSpec.concat(i),u=this.inputSpec;this.inputSpec=d;let p=super.apply(l,t);return this.inputSpec=u,p}else return super.apply(e,t)}call(e,t){return W(()=>{let n=t.initialState,a,r;if(n==null)a=this.forwardLayer.call(e,t),r=this.backwardLayer.call(e,t);else{let o=n.slice(0,n.length/2),l=n.slice(n.length/2);a=this.forwardLayer.call(e,Object.assign(t,{initialState:o})),r=this.backwardLayer.call(e,Object.assign(t,{initialState:l}))}let s;this.returnState&&(Array.isArray(a)&&(s=a.slice(1).concat(r.slice(1))),a=a[0],r=r[0]),this.returnSequences&&(r=zn(r,1));let i;return this.mergeMode==="concat"?i=W1([a,r]):this.mergeMode==="sum"?i=se(a,r):this.mergeMode==="ave"?i=_(.5,se(a,r)):this.mergeMode==="mul"?i=_(a,r):this.mergeMode==null&&(i=[a,r]),this.returnState?this.mergeMode==null?i.concat(s):[i].concat(s):i})}resetStates(e){this.forwardLayer.resetStates(),this.backwardLayer.resetStates()}build(e){Ri(this.forwardLayer.name,()=>{this.forwardLayer.build(e)}),Ri(this.backwardLayer.name,()=>{this.backwardLayer.build(e)}),this.built=!0}computeMask(e,t){Array.isArray(t)&&(t=t[0]);let n;if(this.returnSequences?this.mergeMode==null?n=[t,t]:n=t:this.mergeMode==null?n=[null,null]:n=null,this.returnState){let a=this.forwardLayer.states.map(r=>null);return Array.isArray(n)?n.concat(a).concat(a):[n].concat(a).concat(a)}else return n}get trainableWeights(){return this.forwardLayer.trainableWeights.concat(this.backwardLayer.trainableWeights)}get nonTrainableWeights(){return this.forwardLayer.nonTrainableWeights.concat(this.backwardLayer.nonTrainableWeights)}setFastWeightInitDuringBuild(e){super.setFastWeightInitDuringBuild(e),this.forwardLayer!=null&&this.forwardLayer.setFastWeightInitDuringBuild(e),this.backwardLayer!=null&&this.backwardLayer.setFastWeightInitDuringBuild(e)}getConfig(){let e={mergeMode:this.mergeMode},t=super.getConfig();return Object.assign(e,t),e}static fromConfig(e,t){let n=Na(t.layer);if(delete t.layer,t.numConstants!=null)throw new Oe("Deserialization of a Bidirectional layer with numConstants present is not supported yet.");let a=t;return a.layer=n,new e(a)}};f2.className="Bidirectional";ae.registerClass(f2);function Bte(e){return new Vl(e)}function Vte(e){return new by(e)}function jte(e){return new yy(e)}function Ute(e){return new gy(e)}function Hte(e){return new xy(e)}function Gte(e){return new wy(e)}function qte(e){return new vy(e)}function Xte(e){return new e0(e)}function Kte(e){return new Pd(e)}function Zte(e){return new Sy(e)}function Yte(e){return new Ld(e)}function Jte(e){return new Ny(e)}function Qte(e){return new Ty(e)}function ene(e){return new Ey(e)}function tne(e){return new Cy(e)}function nne(e){return new Ry(e)}function ane(e){return new Py(e)}function rne(e){return new zy(e)}function sne(e){return new s0(e)}function ine(e){return new Oy(e)}function one(e){return new _y(e)}function lne(e){return new Ly(e)}function une(e){return new Wy(e)}function dne(e){return new By(e)}function pne(e){return new jy(e)}function cne(e){return new Uy(e)}function hne(e){return new Gy(e)}function fne(e){return new Ky(e)}function mne(e){return new qy(e)}function Ane(e){return new Xy(e)}function yne(e){return new Hy(e)}function gne(e){return new Zy(e)}function xne(e){return new e2(e)}function bne(e){return new t2(e)}function vne(e){return new n2(e)}function K1(e){return new r2(e)}function wne(e){return K1(e)}function kne(e){return K1(e)}function Z1(e){return new i2(e)}function Ine(e){return Z1(e)}function Sne(e){return Z1(e)}function Y1(e){return new l2(e)}function Nne(e){return Y1(e)}function Tne(e){return Y1(e)}function Ene(e){return new u2(e)}function Cne(e){return new p2(e)}function V6(e){return new d2(e)}function j6(e){return new c2(e)}function U6(e){return new a2(e)}function H6(e){return new s2(e)}function Rne(e){return new o2(e)}function Mne(e){return new Fy(e)}function Fne(e){return new a0(e)}function $ne(e){return new $y(e)}function Dne(e){return new Wd(e)}function One(e){return new My(e)}function zne(e){return new n0(e)}function _ne(e){return new Dy(e)}function Pne(e){return new r0(e)}function Lne(e){return new Ha(e)}function Wne(e){return new t0(e)}function Bne(e){return new f2(e)}function Vne(e){return new h2(e)}var jne=V6,Une=j6,Hne=U6,Gne=H6;function qne(e){return new Yy(e)}function Xne(e){return new Jy(e)}function Kne(e){return new Qy(e)}function Zne(e){return new Vy(e)}var Q4={};Fe(Q4,{MAPE:()=>Nre,MSE:()=>Cre,binaryAccuracy:()=>Are,binaryCrossentropy:()=>yre,categoricalAccuracy:()=>xre,categoricalCrossentropy:()=>bre,cosineProximity:()=>kre,mape:()=>Tre,meanAbsoluteError:()=>Ire,meanAbsolutePercentageError:()=>Sre,meanSquaredError:()=>Ere,mse:()=>Rre,precision:()=>vre,recall:()=>wre,sparseCategoricalAccuracy:()=>gre});function Are(e,t){return ay(e,t)}function yre(e,t){return i4(e,t)}function gre(e,t){return o4(e,t)}function xre(e,t){return ry(e,t)}function bre(e,t){return sy(e,t)}function vre(e,t){return s4(e,t)}function wre(e,t){return mae(e,t)}function kre(e,t){return ty(e,t)}function Ire(e,t){return qh(e,t)}function Sre(e,t){return Ul(e,t)}function Nre(e,t){return Ul(e,t)}function Tre(e,t){return Ul(e,t)}function Ere(e,t){return Fi(e,t)}function Cre(e,t){return Fi(e,t)}function Rre(e,t){return Fi(e,t)}var e8={};Fe(e8,{modelFromJSON:()=>Kae});var t8={};Fe(t8,{l1:()=>Fre,l1l2:()=>Mre,l2:()=>$re});function Mre(e){return new zd(e)}function Fre(e){return are(e)}function $re(e){return rre(e)}var n8=class extends jl{constructor(){super(...arguments);this.model=null}setModel(e){if(!(e instanceof pr))throw new Error("model must be a LayersModel, not some other Container");this.model=e}};function o0(e,t){return et}var r8=class extends n8{constructor(e){super();if(e==null&&(e={}),e.restoreBestWeights)throw new Oe("restoreBestWeights = True is not implemented in EarlyStopping yet.");this.monitor=e.monitor||"val_loss",this.minDelta=Math.abs(e.minDelta||0),this.patience=e.patience||0,this.verbose=e.verbose||0,this.mode=e.mode||"auto",this.baseline=e.baseline,["auto","min","max"].indexOf(this.mode)===-1&&(console.warn(`EarlyStopping mode '${this.mode}' is invalid. Falling back to mode 'auto'.`),this.mode="auto"),this.mode==="min"?this.monitorFunc=o0:this.mode==="max"?this.monitorFunc=a8:this.monitor.indexOf("acc")!==-1?this.monitorFunc=a8:this.monitorFunc=o0,this.monitorFunc===o0&&(this.minDelta*=-1)}async onTrainBegin(e){this.wait=0,this.stoppedEpoch=0,this.baseline!=null?this.best=this.baseline:this.best=this.monitorFunc===o0?Infinity:-Infinity}async onEpochEnd(e,t){await Hr(t);let n=this.getMonitorValue(t);n!=null&&(this.monitorFunc(n-this.minDelta,this.best)?(this.best=n,this.wait=0):(this.wait++,this.wait>=this.patience&&(this.stoppedEpoch=e,this.model.stopTraining=!0)))}async onTrainEnd(e){this.stoppedEpoch>0&&this.verbose&&console.log(`Epoch ${this.stoppedEpoch}: early stopping.`)}getMonitorValue(e){e==null&&(e={});let t=e[this.monitor];return t==null&&console.warn(`Metric for EarlyStopping ${this.monitor} is not available. Available metrics are: ${Object.keys(e)}`),t}};function Dre(e){return new r8(e)}var Ore={earlyStopping:Dre},Ea;(function(e){e[e.DT_INVALID=0]="DT_INVALID",e[e.DT_FLOAT=1]="DT_FLOAT",e[e.DT_DOUBLE=2]="DT_DOUBLE",e[e.DT_INT32=3]="DT_INT32",e[e.DT_UINT8=4]="DT_UINT8",e[e.DT_INT16=5]="DT_INT16",e[e.DT_INT8=6]="DT_INT8",e[e.DT_STRING=7]="DT_STRING",e[e.DT_COMPLEX64=8]="DT_COMPLEX64",e[e.DT_INT64=9]="DT_INT64",e[e.DT_BOOL=10]="DT_BOOL",e[e.DT_QINT8=11]="DT_QINT8",e[e.DT_QUINT8=12]="DT_QUINT8",e[e.DT_QINT32=13]="DT_QINT32",e[e.DT_BFLOAT16=14]="DT_BFLOAT16",e[e.DT_FLOAT_REF=101]="DT_FLOAT_REF",e[e.DT_DOUBLE_REF=102]="DT_DOUBLE_REF",e[e.DT_INT32_REF=103]="DT_INT32_REF",e[e.DT_UINT8_REF=104]="DT_UINT8_REF",e[e.DT_INT16_REF=105]="DT_INT16_REF",e[e.DT_INT8_REF=106]="DT_INT8_REF",e[e.DT_STRING_REF=107]="DT_STRING_REF",e[e.DT_COMPLEX64_REF=108]="DT_COMPLEX64_REF",e[e.DT_INT64_REF=109]="DT_INT64_REF",e[e.DT_BOOL_REF=110]="DT_BOOL_REF",e[e.DT_QINT8_REF=111]="DT_QINT8_REF",e[e.DT_QUINT8_REF=112]="DT_QUINT8_REF",e[e.DT_QINT32_REF=113]="DT_QINT32_REF",e[e.DT_BFLOAT16_REF=114]="DT_BFLOAT16_REF"})(Ea||(Ea={}));var s8;(function(e){let t;(function(n){n[n.LEGACY=0]="LEGACY",n[n.V1=1]="V1",n[n.V2=2]="V2"})(t=e.CheckpointFormatVersion||(e.CheckpointFormatVersion={}))})(s8||(s8={}));var m2={};function zre(e,t){let n={tfOpName:e,category:"custom",inputs:[],attrs:[],customExecutor:t};m2[e]=n}function i8(e){return m2[e]}function _re(e){delete m2[e]}function I(e,t,n,a,r){let s=t.inputParams[e];if(s&&s.inputIndexStart!==void 0){let o=s.inputIndexStart,l=s.inputIndexEnd===0?void 0:s.inputIndexEnd===void 0?o+1:s.inputIndexEnd;if(s.type==="tensor")return An(t.inputNames[s.inputIndexStart],n,a,r);if(s.type==="tensors")return t.inputNames.slice(o,l).map(p=>An(p,n,a,r));let d=An(t.inputNames.slice(o)[0],n,a,r),u=d.dataSync();return s.type==="number"?u[0]:k.toNestedArray(d.shape,u)}let i=t.attrParams[e];return i&&i.value}function An(e,t,n,a){let[r,s]=Wn(e);if(a!=null){let o=a.getHashTableHandleByName(r);if(o!=null)return o}let i=n.currentContextIds.find(o=>!!t[l0(r,o)]);return i!==void 0?t[l0(r,i)][s]:void 0}function Pre(e,t,n){return t[l0(e,n.currentContextId)]}function cr(e,t){let[n,a]=Wn(e);return[l0(n,t&&t.currentContextId),a]}function l0(e,t){return t?`${e}-${t}`:e}function Wn(e){let t=e.split(":");return t.length===1?[e,0]:[t[0],Number(t[t.length-1])]}function u0(e,t,n){let a=I("pad",e,t,n);if(a==="explicit"){a=I("explicitPaddings",e,t,n);let r=[[0,0],[0,0],[0,0],[0,0]];for(let s=0;s<4;s++)r[s][0]=a[s*2],r[s][1]=a[s*2+1];return r}return a}function hr(e){return e.kept?e:Oa(e)}var o8={};Fe(o8,{json:()=>Lre});var Lre=[{tfOpName:"Add",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"AddV2",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"AddN",category:"arithmetic",inputs:[{start:0,end:0,name:"tensors",type:"tensors"}]},{tfOpName:"BiasAdd",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0},{tfName:"data_format",name:"dataFormat",type:"string",notSupported:!0}]},{tfOpName:"Sub",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"RealDiv",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Div",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"DivNoNan",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"FloorDiv",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Mul",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Maximum",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Minimum",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Pow",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"SquaredDifference",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Mod",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"FloorMod",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]}],l8={};Fe(l8,{json:()=>Wre});var Wre=[{tfOpName:"Abs",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Acos",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Asin",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Atan",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Atan2",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"y",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Ceil",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"ClipByValue",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"clipValueMin",type:"number"},{start:2,name:"clipValueMax",type:"number"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Complex",category:"basic_math",inputs:[{start:0,name:"real",type:"tensor"},{start:1,name:"imag",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"ComplexAbs",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Cos",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Cosh",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Elu",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Exp",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Floor",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Log",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Imag",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0},{tfName:"Tout",name:"outputType",type:"dtype",notSupported:!0}]},{tfOpName:"Neg",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Real",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0},{tfName:"Tout",name:"outputType",type:"dtype",notSupported:!0}]},{tfOpName:"Prelu",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"alpha",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Relu",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Relu6",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Selu",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Sigmoid",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Sin",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Sinh",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Sqrt",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Rsqrt",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Square",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Tan",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Tanh",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Sign",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Round",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Expm1",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Log1p",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Reciprocal",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Softplus",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Asinh",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Acosh",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Atanh",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Erf",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Prod",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axes",type:"number[]"}],attrs:[{tfName:"keep_dims",name:"keepDims",type:"bool",notSupported:!0},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"LeakyRelu",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"alpha",name:"alpha",type:"number",defaultValue:.2},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"IsNan",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]}],u8={};Fe(u8,{json:()=>Bre});var Bre=[{tfOpName:"EmptyTensorList",category:"control",inputs:[{start:0,name:"elementShape",type:"shape"},{start:1,name:"maxNumElements",type:"number"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"}]},{tfOpName:"LoopCond",category:"control",inputs:[{start:0,name:"pred",type:"tensor"}]},{tfOpName:"Switch",category:"control",inputs:[{start:0,name:"data",type:"tensor"},{start:1,name:"pred",type:"tensor"}]},{tfOpName:"Merge",category:"control",inputs:[{start:0,end:0,name:"tensors",type:"tensors"}]},{tfOpName:"Enter",category:"control",inputs:[{start:0,name:"tensor",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0},{tfName:"frame_name",name:"frameName",type:"string"},{tfName:"is_constant",name:"isConstant",type:"bool"}]},{tfOpName:"Exit",category:"control",inputs:[{start:0,name:"tensor",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"NextIteration",category:"control",inputs:[{start:0,name:"tensor",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"TensorArrayV3",category:"control",inputs:[{start:0,name:"size",type:"number"}],attrs:[{tfName:"dtype",name:"dtype",type:"dtype"},{tfName:"element_shape",name:"elementShape",type:"shape"},{tfName:"dynamic_size",name:"dynamicSize",type:"bool"},{tfName:"clear_after_read",name:"clearAfterRead",type:"bool"},{tfName:"identical_element_shapes",name:"identicalElementShapes",type:"bool"},{tfName:"tensor_array_name",name:"name",type:"string"}]},{tfOpName:"TensorArrayWriteV3",category:"control",inputs:[{start:0,name:"tensorArrayId",type:"tensor"},{start:1,name:"index",type:"number"},{start:2,name:"tensor",type:"tensor"},{start:3,name:"flowIn",type:"number"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"TensorArrayReadV3",category:"control",inputs:[{start:0,name:"tensorArrayId",type:"tensor"},{start:1,name:"index",type:"number"},{start:2,name:"flowIn",type:"number"}],attrs:[{tfName:"dtype",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"TensorArrayGatherV3",category:"control",inputs:[{start:0,name:"tensorArrayId",type:"tensor"},{start:1,name:"indices",type:"number[]"},{start:2,name:"flowIn",type:"number"}],attrs:[{tfName:"dtype",name:"dtype",type:"dtype"},{tfName:"element_shape",name:"elementShape",type:"shape"}]},{tfOpName:"TensorArrayScatterV3",category:"control",inputs:[{start:0,name:"tensorArrayId",type:"tensor"},{start:1,name:"indices",type:"number[]"},{start:2,name:"tensor",type:"tensor"},{start:3,name:"flowIn",type:"number"}],attrs:[{tfName:"T",name:"dtype",type:"dtype"}]},{tfOpName:"TensorArrayConcatV3",category:"control",inputs:[{start:0,name:"tensorArrayId",type:"tensor"},{start:1,name:"flowIn",type:"number"}],attrs:[{tfName:"dtype",name:"dtype",type:"dtype"},{tfName:"element_shape_except0",name:"elementShapeExcept0",type:"shape",notSupported:!0}]},{tfOpName:"TensorArraySplitV3",category:"control",inputs:[{start:0,name:"tensorArrayId",type:"tensor"},{start:1,name:"tensor",type:"tensor"},{start:2,name:"lengths",type:"number[]"},{start:3,name:"flowIn",type:"number"}],attrs:[{tfName:"T",name:"dtype",type:"dtype"}]},{tfOpName:"TensorArraySizeV3",category:"control",inputs:[{start:0,name:"tensorArrayId",type:"tensor"},{start:1,name:"flowIn",type:"number"}]},{tfOpName:"TensorArrayCloseV3",category:"control",inputs:[{start:0,name:"tensorArrayId",type:"tensor"}]},{tfOpName:"StatelessIf",category:"control",inputs:[{start:0,name:"cond",type:"tensor"},{start:1,end:0,name:"args",type:"tensors"}],attrs:[{tfName:"then_branch",name:"thenBranch",type:"func"},{tfName:"else_branch",name:"elseBranch",type:"func"}]},{tfOpName:"If",category:"control",inputs:[{start:0,name:"cond",type:"tensor"},{start:1,end:0,name:"args",type:"tensors"}],attrs:[{tfName:"then_branch",name:"thenBranch",type:"func"},{tfName:"else_branch",name:"elseBranch",type:"func"}]},{tfOpName:"StatelessWhile",category:"control",inputs:[{start:0,end:0,name:"args",type:"tensors"}],attrs:[{tfName:"cond",name:"cond",type:"func"},{tfName:"body",name:"body",type:"func"}]},{tfOpName:"While",category:"control",inputs:[{start:0,end:0,name:"args",type:"tensors"}],attrs:[{tfName:"cond",name:"cond",type:"func"},{tfName:"body",name:"body",type:"func"}]},{tfOpName:"TensorListScatter",category:"control",inputs:[{start:0,name:"tensor",type:"tensor"},{start:1,name:"indices",type:"number[]"},{start:2,name:"elementShape",type:"shape"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"}]},{tfOpName:"TensorListScatterV2",category:"control",inputs:[{start:0,name:"tensor",type:"tensor"},{start:1,name:"indices",type:"number[]"},{start:2,name:"elementShape",type:"shape"},{start:3,name:"numElements",type:"number"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"}]},{tfOpName:"TensorListGather",category:"control",inputs:[{start:0,name:"tensorListId",type:"tensor"},{start:1,name:"indices",type:"number[]"},{start:2,name:"elementShape",type:"shape"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"}]},{tfOpName:"TensorListGetItem",category:"control",inputs:[{start:0,name:"tensorListId",type:"tensor"},{start:1,name:"index",type:"number"},{start:2,name:"elementShape",type:"shape"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"}]},{tfOpName:"TensorListSetItem",category:"control",inputs:[{start:0,name:"tensorListId",type:"tensor"},{start:1,name:"index",type:"number"},{start:2,name:"tensor",type:"tensor"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"}]},{tfOpName:"TensorListReserve",category:"control",inputs:[{start:0,name:"elementShape",type:"shape"},{start:1,name:"numElements",type:"number"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"}]},{tfOpName:"TensorListFromTensor",category:"control",inputs:[{start:0,name:"tensor",type:"tensor"},{start:1,name:"elementShape",type:"shape"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"}]},{tfOpName:"TensorListStack",category:"control",inputs:[{start:0,name:"tensorListId",type:"tensor"},{start:1,name:"elementShape",type:"shape"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"},{tfName:"num_elements",name:"numElements",type:"dtype"}]},{tfOpName:"TensorListSplit",category:"control",inputs:[{start:0,name:"tensor",type:"tensor"},{start:1,name:"elementShape",type:"shape"},{start:2,name:"lengths",type:"number[]"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"}]},{tfOpName:"TensorListConcat",category:"control",inputs:[{start:0,name:"tensorListId",type:"tensor"}],attrs:[{tfName:"element_shape",name:"elementShape",type:"shape"},{tfName:"element_dtype",name:"elementDType",type:"dtype"}]},{tfOpName:"TensorListPopBack",category:"control",inputs:[{start:0,name:"tensorListId",type:"tensor"},{start:1,name:"elementShape",type:"shape"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"}]},{tfOpName:"TensorListPushBack",category:"control",inputs:[{start:0,name:"tensorListId",type:"tensor"},{start:1,name:"tensor",type:"tensor"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"}]}],d8={};Fe(d8,{json:()=>Vre});var Vre=[{tfOpName:"AvgPool",category:"convolution",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"data_format",name:"dataFormat",type:"string",notSupported:!0},{tfName:"ksize",name:"kernelSize",type:"number[]"},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"MaxPool",category:"convolution",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"data_format",name:"dataFormat",type:"string",notSupported:!0},{tfName:"ksize",name:"kernelSize",type:"number[]"},{tfName:"explicit_paddings",name:"explicitPaddings",type:"number[]",defaultValue:[],notSupported:!0},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"MaxPoolWithArgmax",category:"convolution",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"ksize",name:"kernelSize",type:"number[]"},{tfName:"include_batch_in_index",name:"includeBatchInIndex",type:"bool"},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"AvgPool3D",category:"convolution",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"data_format",name:"dataFormat",type:"string",notSupported:!0},{tfName:"ksize",name:"kernelSize",type:"number[]"},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"MaxPool3D",category:"convolution",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"data_format",name:"dataFormat",type:"string",notSupported:!0},{tfName:"ksize",name:"kernelSize",type:"number[]"},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Conv1D",category:"convolution",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"filter",type:"tensor"}],attrs:[{tfName:"stride",name:"stride",type:"number"},{tfName:"padding",name:"pad",type:"string"},{tfName:"data_format",name:"dataFormat",type:"string",defaultValue:"NWC"},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0},{tfName:"dilation",name:"dilation",type:"number",defaultValue:1}]},{tfOpName:"Conv2D",category:"convolution",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"filter",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0},{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"useCudnnOnGpu",name:"useCudnnOnGpu",type:"bool"},{tfName:"data_format",name:"dataFormat",type:"string",defaultValue:"NHWC"},{tfName:"explicit_paddings",name:"explicitPaddings",type:"number[]",defaultValue:[]},{tfName:"dilations",name:"dilations",type:"number[]"}]},{tfOpName:"_FusedConv2D",category:"convolution",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"filter",type:"tensor"},{start:2,end:0,name:"args",type:"tensors"}],attrs:[{tfName:"num_args",name:"numArgs",type:"number"},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0},{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"explicit_paddings",name:"explicitPaddings",type:"number[]",defaultValue:[]},{tfName:"use_cudnn_on_gpu",name:"useCudnnOnGpu",type:"bool",defaultValue:!0},{tfName:"data_format",name:"dataFormat",type:"string",defaultValue:"NHWC"},{tfName:"dilations",name:"dilations",type:"number[]",defaultValue:[1,1,1,1]},{tfName:"fused_ops",name:"fusedOps",type:"string[]",defaultValue:[]},{tfName:"epsilon",name:"epsilon",type:"number",defaultValue:1e-4},{tfName:"leakyrelu_alpha",name:"leakyreluAlpha",type:"number"}]},{tfOpName:"Conv2DBackpropInput",category:"convolution",inputs:[{start:2,name:"x",type:"tensor"},{start:1,name:"filter",type:"tensor"},{start:0,name:"outputShape",type:"number[]"}],attrs:[{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"data_format",name:"dataFormat",type:"string",notSupported:!0},{tfName:"explicit_paddings",name:"explicitPaddings",type:"number[]",defaultValue:[]},{tfName:"dilations",name:"dilations",type:"number[]",notSupported:!0}]},{tfOpName:"DepthwiseConv2d",category:"convolution",inputs:[{start:0,name:"input",type:"tensor"},{start:1,name:"filter",type:"tensor"}],attrs:[{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"data_format",name:"dataFormat",type:"string",defaultValue:"NHWC"},{tfName:"explicit_paddings",name:"explicitPaddings",type:"number[]",defaultValue:[]},{tfName:"dilations",name:"dilations",type:"number[]"}]},{tfOpName:"DepthwiseConv2dNative",category:"convolution",inputs:[{start:0,name:"input",type:"tensor"},{start:1,name:"filter",type:"tensor"}],attrs:[{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"data_format",name:"dataFormat",type:"string",defaultValue:"NHWC"},{tfName:"explicit_paddings",name:"explicitPaddings",type:"number[]",defaultValue:[]},{tfName:"dilations",name:"dilations",type:"number[]"}]},{tfOpName:"FusedDepthwiseConv2dNative",category:"convolution",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"filter",type:"tensor"},{start:2,end:0,name:"args",type:"tensors"}],attrs:[{tfName:"num_args",name:"numArgs",type:"number"},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0},{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"data_format",name:"dataFormat",type:"string",defaultValue:"NHWC"},{tfName:"dilations",name:"dilations",type:"number[]",defaultValue:[1,1,1,1]},{tfName:"fused_ops",name:"fusedOps",type:"string[]",defaultValue:[]},{tfName:"explicit_paddings",name:"explicitPaddings",type:"number[]",defaultValue:[]}]},{tfOpName:"Conv3D",category:"convolution",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"filter",type:"tensor"}],attrs:[{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"data_format",name:"dataFormat",type:"string",defaultValue:"NHWC"},{tfName:"dilations",name:"dilations",type:"number[]"}]},{tfOpName:"Dilation2D",category:"convolution",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"filter",type:"tensor"}],attrs:[{tfName:"strides",name:"strides",type:"number[]"},{tfName:"rates",name:"dilations",type:"number[]"},{tfName:"padding",name:"pad",type:"string"}]}],p8={};Fe(p8,{json:()=>jre});var jre=[{tfOpName:"Fill",category:"creation",inputs:[{start:0,name:"shape",type:"number[]"},{start:1,name:"value",type:"number"}],attrs:[{tfName:"T",name:"dtype",type:"dtype"}]},{tfOpName:"LinSpace",category:"creation",inputs:[{start:0,name:"start",type:"number"},{start:1,name:"stop",type:"number"},{start:2,name:"num",type:"number"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"OneHot",category:"creation",inputs:[{start:0,name:"indices",type:"tensor"},{start:1,name:"depth",type:"number"},{start:2,name:"onValue",type:"number",defaultValue:1},{start:3,name:"offValue",type:"number",defaultValue:0}],attrs:[{tfName:"axis",name:"axis",type:"number",notSupported:!0},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Ones",category:"creation",inputs:[{start:0,name:"shape",type:"number[]"}],attrs:[{tfName:"T",name:"dtype",type:"dtype"}]},{tfOpName:"OnesLike",category:"creation",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"dtype",name:"dtype",type:"dtype"}]},{tfOpName:"RandomUniform",category:"creation",inputs:[{start:0,name:"shape",type:"number[]"}],attrs:[{tfName:"minval",name:"minval",type:"number",defaultValue:0},{tfName:"maxval",name:"maxval",type:"number",defaultValue:1},{tfName:"dtype",name:"dtype",type:"dtype"},{tfName:"seed",name:"seed",type:"number",defaultValue:0},{tfName:"seed2",name:"seed2",type:"number",defaultValue:0,notSupported:!0},{tfName:"T",name:"T",type:"number",notSupported:!0}]},{tfOpName:"Range",category:"creation",inputs:[{start:0,name:"start",type:"number"},{start:1,name:"stop",type:"number"},{start:2,name:"step",type:"number",defaultValue:0}],attrs:[{tfName:"Tidx",name:"dtype",type:"dtype"}]},{tfOpName:"TruncatedNormal",category:"creation",inputs:[{start:0,name:"shape",type:"number[]"}],attrs:[{tfName:"means",name:"mean",type:"number",defaultValue:0},{tfName:"stddev",name:"stdDev",type:"number",defaultValue:1},{tfName:"seed",name:"seed",type:"number"},{tfName:"seed2",name:"seed2",type:"number",defaultValue:0,notSupported:!0},{tfName:"dtype",name:"dtype",type:"dtype"},{tfName:"T",name:"T",type:"number",notSupported:!0}]},{tfOpName:"Zeros",category:"creation",inputs:[{start:0,name:"shape",type:"number[]"}],attrs:[{tfName:"T",name:"dtype",type:"dtype"}]},{tfOpName:"ZerosLike",category:"creation",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype"}]},{tfOpName:"Multinomial",category:"creation",inputs:[{start:0,name:"logits",type:"tensor"},{start:1,name:"numSamples",type:"number"}],attrs:[{tfName:"seed",name:"seed",type:"number"},{tfName:"seed2",name:"seed2",type:"number"},{tfName:"T",name:"dtype",type:"dtype"},{tfName:"output_dtype",name:"output_dtype",type:"dtype"}]}],c8={};Fe(c8,{json:()=>Ure});var Ure=[{tfOpName:"NonMaxSuppressionV2",category:"dynamic",inputs:[{start:0,name:"boxes",type:"tensor"},{start:1,name:"scores",type:"tensor"},{start:2,name:"maxOutputSize",type:"number"},{start:3,name:"iouThreshold",type:"number"}]},{tfOpName:"NonMaxSuppressionV3",category:"dynamic",inputs:[{start:0,name:"boxes",type:"tensor"},{start:1,name:"scores",type:"tensor"},{start:2,name:"maxOutputSize",type:"number"},{start:3,name:"iouThreshold",type:"number"},{start:4,name:"scoreThreshold",type:"number"}]},{tfOpName:"NonMaxSuppressionV4",category:"dynamic",inputs:[{start:0,name:"boxes",type:"tensor"},{start:1,name:"scores",type:"tensor"},{start:2,name:"maxOutputSize",type:"number"},{start:3,name:"iouThreshold",type:"number"},{start:4,name:"scoreThreshold",type:"number"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0},{tfName:"T_threshold",name:"threshold",type:"dtype",notSupported:!0},{tfName:"pad_to_max_output_size",name:"padToMaxOutputSize",type:"bool"}]},{tfOpName:"NonMaxSuppressionV5",category:"dynamic",inputs:[{start:0,name:"boxes",type:"tensor"},{start:1,name:"scores",type:"tensor"},{start:2,name:"maxOutputSize",type:"number"},{start:3,name:"iouThreshold",type:"number"},{start:4,name:"scoreThreshold",type:"number"},{start:5,name:"softNmsSigma",type:"number"}]},{tfOpName:"Where",category:"dynamic",inputs:[{start:0,name:"condition",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"ListDiff",category:"dynamic",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"y",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]}],h8={};Fe(h8,{json:()=>Hre});var Hre=[{tfOpName:"TopKV2",category:"evaluation",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"k",type:"number"}],attrs:[{tfName:"sorted",name:"sorted",type:"bool"}]},{tfOpName:"Unique",category:"evaluation",inputs:[{start:0,name:"x",type:"tensor"}]},{tfOpName:"UniqueV2",category:"evaluation",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number"}]}],f8={};Fe(f8,{json:()=>Gre});var Gre=[{tfOpName:"PlaceholderWithDefault",category:"graph",inputs:[{start:0,name:"default",type:"tensor"}],attrs:[{tfName:"shape",name:"shape",type:"shape"},{tfName:"dtype",name:"dtype",type:"dtype"}]},{tfOpName:"Placeholder",category:"graph",attrs:[{tfName:"shape",name:"shape",type:"shape"},{tfName:"dtype",name:"dtype",type:"dtype"}]},{tfOpName:"Const",category:"graph"},{tfOpName:"Identity",category:"graph",inputs:[{start:0,name:"x",type:"tensor"}]},{tfOpName:"IdentityN",category:"graph",inputs:[{start:0,end:0,name:"x",type:"tensors"}]},{tfOpName:"Snapshot",category:"graph",inputs:[{start:0,name:"x",type:"tensor"}]},{tfOpName:"Rank",category:"graph",inputs:[{start:0,name:"x",type:"tensor"}]},{tfOpName:"Size",category:"graph",inputs:[{start:0,name:"x",type:"tensor"}]},{tfOpName:"Shape",category:"graph",inputs:[{start:0,name:"x",type:"tensor"}]},{tfOpName:"ShapeN",category:"graph",inputs:[{start:0,end:0,name:"x",type:"tensors"}]},{tfOpName:"Print",category:"graph",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"data",type:"tensors"}],attrs:[{tfName:"message",name:"message",type:"string"},{tfName:"first_n",name:"firstN",type:"number",notSupported:!0},{tfName:"summarize",name:"summarize",type:"number",defaultValue:3}]},{tfOpName:"NoOp",category:"graph",inputs:[]},{tfOpName:"StopGradient",category:"graph",inputs:[{start:0,name:"x",type:"tensor"}]},{tfOpName:"FakeQuantWithMinMaxVars",category:"graph",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"min",name:"min",type:"number"},{tfName:"max",name:"max",type:"number"}]}],m8={};Fe(m8,{json:()=>qre});var qre=[{tfOpName:"HashTable",category:"hash_table",inputs:[],attrs:[{tfName:"shared_name",name:"sharedName",type:"string"},{tfName:"use_node_name_sharing",name:"useNodeNameSharing",type:"bool"},{tfName:"key_dtype",name:"keyDType",type:"dtype"},{tfName:"value_dtype",name:"valueDType",type:"dtype"}]},{tfOpName:"HashTableV2",category:"hash_table",inputs:[],attrs:[{tfName:"shared_name",name:"sharedName",type:"string"},{tfName:"use_node_name_sharing",name:"useNodeNameSharing",type:"bool"},{tfName:"key_dtype",name:"keyDType",type:"dtype"},{tfName:"value_dtype",name:"valueDType",type:"dtype"}]},{tfOpName:"LookupTableImport",category:"hash_table",inputs:[{start:0,name:"tableHandle",type:"tensor"},{start:1,name:"keys",type:"tensor"},{start:2,name:"values",type:"tensor"}],attrs:[{tfName:"Tin",name:"tIn",type:"dtype",notSupported:!0},{tfName:"Tout",name:"tOut",type:"dtype",notSupported:!0}]},{tfOpName:"LookupTableImportV2",category:"hash_table",inputs:[{start:0,name:"tableHandle",type:"tensor"},{start:1,name:"keys",type:"tensor"},{start:2,name:"values",type:"tensor"}],attrs:[{tfName:"Tin",name:"tIn",type:"dtype",notSupported:!0},{tfName:"Tout",name:"tOut",type:"dtype",notSupported:!0}]},{tfOpName:"LookupTableFind",category:"hash_table",inputs:[{start:0,name:"tableHandle",type:"tensor"},{start:1,name:"keys",type:"tensor"},{start:2,name:"defaultValue",type:"tensor"}],attrs:[{tfName:"Tin",name:"tIn",type:"dtype",notSupported:!0},{tfName:"Tout",name:"tOut",type:"dtype",notSupported:!0}]},{tfOpName:"LookupTableFindV2",category:"hash_table",inputs:[{start:0,name:"tableHandle",type:"tensor"},{start:1,name:"keys",type:"tensor"},{start:2,name:"defaultValue",type:"tensor"}],attrs:[{tfName:"Tin",name:"tIn",type:"dtype",notSupported:!0},{tfName:"Tout",name:"tOut",type:"dtype",notSupported:!0}]},{tfOpName:"LookupTableSize",category:"hash_table",inputs:[{start:0,name:"tableHandle",type:"tensor"}]},{tfOpName:"LookupTableSizeV2",category:"hash_table",inputs:[{start:0,name:"tableHandle",type:"tensor"}]}],A8={};Fe(A8,{json:()=>Xre});var Xre=[{tfOpName:"ResizeBilinear",category:"image",inputs:[{start:0,name:"images",type:"tensor"},{start:1,name:"size",type:"number[]"}],attrs:[{tfName:"align_corners",name:"alignCorners",type:"bool"},{tfName:"half_pixel_centers",name:"halfPixelCenters",type:"bool"},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"ResizeNearestNeighbor",category:"image",inputs:[{start:0,name:"images",type:"tensor"},{start:1,name:"size",type:"number[]"}],attrs:[{tfName:"align_corners",name:"alignCorners",type:"bool"},{tfName:"half_pixel_centers",name:"halfPixelCenters",type:"bool"},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"CropAndResize",category:"image",inputs:[{start:0,name:"image",type:"tensor"},{start:1,name:"boxes",type:"tensor"},{start:2,name:"boxInd",type:"tensor"},{start:3,name:"cropSize",type:"number[]"}],attrs:[{tfName:"method",name:"method",type:"string"},{tfName:"extrapolation_value",name:"extrapolationValue",type:"number"}]}],y8={};Fe(y8,{json:()=>Kre});var Kre=[{tfOpName:"Equal",category:"logical",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"NotEqual",category:"logical",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Greater",category:"logical",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"GreaterEqual",category:"logical",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Less",category:"logical",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"LessEqual",category:"logical",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"LogicalAnd",category:"logical",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"LogicalNot",category:"logical",inputs:[{start:0,name:"a",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"LogicalOr",category:"logical",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Select",category:"logical",inputs:[{start:0,name:"condition",type:"tensor"},{start:1,name:"a",type:"tensor"},{start:2,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"SelectV2",category:"logical",inputs:[{start:0,name:"condition",type:"tensor"},{start:1,name:"a",type:"tensor"},{start:2,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]}],g8={};Fe(g8,{json:()=>Zre});var Zre=[{tfOpName:"_FusedMatMul",category:"matrices",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"},{start:2,end:0,name:"args",type:"tensors"}],attrs:[{tfName:"num_args",name:"numArgs",type:"number"},{tfName:"fused_ops",name:"fusedOps",type:"string[]",defaultValue:[]},{tfName:"epsilon",name:"epsilon",type:"number",defaultValue:1e-4},{tfName:"transpose_a",name:"transposeA",type:"bool",defaultValue:!1},{tfName:"transpose_b",name:"transposeB",type:"bool",defaultValue:!1},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"MatMul",category:"matrices",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"transpose_a",name:"transposeA",type:"bool",defaultValue:!1},{tfName:"transpose_b",name:"transposeB",type:"bool",defaultValue:!1},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"BatchMatMul",category:"matrices",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"adj_x",name:"transposeA",type:"bool",defaultValue:!1},{tfName:"adj_y",name:"transposeB",type:"bool",defaultValue:!1},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"BatchMatMulV2",category:"matrices",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"adj_x",name:"transposeA",type:"bool",defaultValue:!1},{tfName:"adj_y",name:"transposeB",type:"bool",defaultValue:!1},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Transpose",category:"matrices",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"perm",type:"number[]"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Einsum",category:"matrices",inputs:[{start:0,end:0,name:"tensors",type:"tensors"}],attrs:[{tfName:"equation",name:"equation",type:"string"},{tfName:"N",name:"n",type:"number",defaultValue:2},{tfName:"T",name:"dtype",type:"dtype"}]}],x8={};Fe(x8,{json:()=>Yre});var Yre=[{tfOpName:"FusedBatchNorm",category:"normalization",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"scale",type:"tensor"},{start:2,name:"offset",type:"tensor"},{start:3,name:"mean",type:"tensor"},{start:4,name:"variance",type:"tensor"}],attrs:[{tfName:"epsilon",name:"epsilon",type:"number",defaultValue:.001},{tfName:"data_format",name:"dataFormat",type:"string",notSupported:!0}]},{tfOpName:"FusedBatchNormV2",category:"normalization",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"scale",type:"tensor"},{start:2,name:"offset",type:"tensor"},{start:3,name:"mean",type:"tensor"},{start:4,name:"variance",type:"tensor"}],attrs:[{tfName:"epsilon",name:"epsilon",type:"number",defaultValue:.001},{tfName:"data_format",name:"dataFormat",type:"string",notSupported:!0}]},{tfOpName:"FusedBatchNormV3",category:"normalization",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"scale",type:"tensor"},{start:2,name:"offset",type:"tensor"},{start:3,name:"mean",type:"tensor"},{start:4,name:"variance",type:"tensor"}],attrs:[{tfName:"epsilon",name:"epsilon",type:"number",defaultValue:.001},{tfName:"data_format",name:"dataFormat",type:"string",notSupported:!0}]},{tfOpName:"LRN",category:"normalization",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"depth_radius",name:"radius",type:"number",defaultValue:5},{tfName:"bias",name:"bias",type:"number",defaultValue:1},{tfName:"alpha",name:"alpha",type:"number",defaultValue:1},{tfName:"beta",name:"beta",type:"number",defaultValue:.5}]},{tfOpName:"Softmax",category:"normalization",inputs:[{start:0,name:"x",type:"tensor"}]},{tfOpName:"LogSoftmax",category:"normalization",inputs:[{start:0,name:"x",type:"tensor"}]},{tfOpName:"SparseToDense",category:"normalization",inputs:[{start:0,name:"sparseIndices",type:"tensor"},{start:1,name:"outputShape",type:"number[]"},{start:2,name:"sparseValues",type:"tensor"},{start:3,name:"defaultValue",type:"tensor"}],attrs:[{tfName:"validate_indices",name:"validateIndices",type:"bool",defaultValue:!0,notSupported:!0}]}],b8={};Fe(b8,{json:()=>Jre});var Jre=[{tfOpName:"Bincount",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"size",type:"number"},{start:2,name:"weights",type:"tensor"}]},{tfOpName:"DenseBincount",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"size",type:"number"},{start:2,name:"weights",type:"tensor"}],attrs:[{tfName:"binary_output",name:"binaryOutput",type:"bool"}]},{tfOpName:"Max",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number[]"}],attrs:[{tfName:"keep_dims",name:"keepDims",type:"bool"}]},{tfOpName:"Mean",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number[]"}],attrs:[{tfName:"keep_dims",name:"keepDims",type:"bool"}]},{tfOpName:"Min",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number[]"}],attrs:[{tfName:"keep_dims",name:"keepDims",type:"bool"}]},{tfOpName:"Sum",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number[]"}],attrs:[{tfName:"keep_dims",name:"keepDims",type:"bool"}]},{tfOpName:"All",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number[]"}],attrs:[{tfName:"keep_dims",name:"keepDims",type:"bool"}]},{tfOpName:"Any",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number[]"}],attrs:[{tfName:"keep_dims",name:"keepDims",type:"bool"}]},{tfOpName:"ArgMax",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number"}]},{tfOpName:"ArgMin",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number"}]},{tfOpName:"Prod",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number[]"}],attrs:[{tfName:"keep_dims",name:"keepDims",type:"bool"}]},{tfOpName:"Cumsum",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number"}],attrs:[{tfName:"exclusive",name:"exclusive",type:"bool"},{tfName:"reverse",name:"reverse",type:"bool"}]}],v8={};Fe(v8,{json:()=>Qre});var Qre=[{tfOpName:"ConcatV2",category:"slice_join",inputs:[{start:0,end:-1,name:"tensors",type:"tensors"},{start:-1,name:"axis",type:"number"}],attrs:[{tfName:"N",name:"n",type:"number",defaultValue:2}]},{tfOpName:"Concat",category:"slice_join",inputs:[{start:1,end:0,name:"tensors",type:"tensors"},{start:0,name:"axis",type:"number"}],attrs:[{tfName:"N",name:"n",type:"number",defaultValue:2}]},{tfOpName:"GatherV2",category:"slice_join",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"indices",type:"tensor"},{start:2,name:"axis",type:"number",defaultValue:0}],attrs:[{tfName:"batch_dims",name:"batchDims",type:"number",defaultValue:0}]},{tfOpName:"Gather",category:"slice_join",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"indices",type:"tensor"}],attrs:[{tfName:"validate_indices",name:"validateIndices",type:"bool",notSupported:!0}]},{tfOpName:"Reverse",category:"slice_join",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"dims",type:"bool[]"}]},{tfOpName:"ReverseV2",category:"slice_join",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number[]"}]},{tfOpName:"Slice",category:"slice_join",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"begin",type:"number[]"},{start:2,name:"size",type:"number[]"}]},{tfOpName:"StridedSlice",category:"slice_join",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"begin",type:"number[]"},{start:2,name:"end",type:"number[]"},{start:3,name:"strides",type:"number[]"}],attrs:[{tfName:"begin_mask",name:"beginMask",type:"number",defaultValue:0},{tfName:"end_mask",name:"endMask",type:"number",defaultValue:0},{tfName:"new_axis_mask",name:"newAxisMask",type:"number",defaultValue:0},{tfName:"ellipsis_mask",name:"ellipsisMask",type:"number",defaultValue:0},{tfName:"shrink_axis_mask",name:"shrinkAxisMask",type:"number",defaultValue:0}]},{tfOpName:"Pack",category:"slice_join",inputs:[{start:0,end:0,name:"tensors",type:"tensors"}],attrs:[{tfName:"axis",name:"axis",type:"number",defaultValue:0}]},{tfOpName:"Unpack",category:"slice_join",inputs:[{start:0,name:"tensor",type:"tensor"}],attrs:[{tfName:"axis",name:"axis",type:"number",defaultValue:0},{tfName:"num",name:"num",type:"number",defaultValue:0,notSupported:!0}]},{tfOpName:"Tile",category:"slice_join",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"reps",type:"number[]"}]},{tfOpName:"Split",category:"slice_join",inputs:[{start:0,name:"axis",type:"number",defaultValue:0},{start:1,name:"x",type:"tensor"}],attrs:[{tfName:"num_split",name:"numOrSizeSplits",type:"number",defaultValue:1}]},{tfOpName:"SplitV",category:"slice_join",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"numOrSizeSplits",type:"number[]"},{start:2,name:"axis",type:"number",defaultValue:0}]},{tfOpName:"ScatterNd",category:"slice_join",inputs:[{start:0,name:"indices",type:"tensor"},{start:1,name:"values",type:"tensor"},{start:2,name:"shape",type:"number[]"}]},{tfOpName:"GatherNd",category:"slice_join",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"indices",type:"tensor"}]},{tfOpName:"SparseToDense",category:"slice_join",inputs:[{start:0,name:"sparseIndices",type:"tensor"},{start:1,name:"outputShape",type:"number[]"},{start:2,name:"sparseValues",type:"tensor"},{start:3,name:"defaultValue",type:"tensor"}],attrs:[{tfName:"validate_indices",name:"validateIndices",type:"bool",defaultValue:!1,notSupported:!0}]}],w8={};Fe(w8,{json:()=>ese});var ese=[{tfOpName:"FFT",category:"spectral",inputs:[{start:0,name:"x",type:"tensor"}]},{tfOpName:"IFFT",category:"spectral",inputs:[{start:0,name:"x",type:"tensor"}]},{tfOpName:"RFFT",category:"spectral",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"fft_length",type:"number",notSupported:!0}]},{tfOpName:"IRFFT",category:"spectral",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"fft_length",type:"number",notSupported:!0}]}],k8={};Fe(k8,{json:()=>tse});var tse=[{tfOpName:"Cast",category:"transformation",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"SrcT",name:"sdtype",type:"dtype",notSupported:!0},{tfName:"DstT",name:"dtype",type:"dtype"}]},{tfOpName:"ExpandDims",category:"transformation",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number"}]},{tfOpName:"MirrorPad",category:"transformation",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"padding",type:"number[]"}],attrs:[{tfName:"mode",name:"mode",type:"string"}]},{tfOpName:"Pad",category:"transformation",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"padding",type:"number[]"}],attrs:[{tfName:"constant_value",name:"constantValue",type:"number",defaultValue:0}]},{tfOpName:"PadV2",category:"transformation",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"padding",type:"number[]"},{start:2,name:"constantValue",type:"number",defaultValue:0}]},{tfOpName:"Reshape",category:"transformation",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"shape",type:"number[]"}]},{tfOpName:"Squeeze",category:"transformation",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"axis",tfDeprecatedName:"squeeze_dims",name:"axis",type:"number[]"}]},{tfOpName:"SpaceToBatchND",category:"transformation",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"blockShape",type:"number[]"},{start:2,name:"paddings",type:"number[]"}]},{tfOpName:"BatchToSpaceND",category:"transformation",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"blockShape",type:"number[]"},{start:2,name:"crops",type:"number[]"}]},{tfOpName:"DepthToSpace",category:"transformation",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"block_size",name:"blockSize",type:"number"},{tfName:"data_format",name:"dataFormat",type:"string"}]},{tfOpName:"BroadcastTo",category:"transformation",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"shape",type:"number[]"}],attrs:[]}],S8=class{static get Instance(){return this._instance||(this._instance=new this)}constructor(){let e=[o8,l8,u8,d8,p8,c8,h8,y8,A8,f8,g8,x8,b8,v8,w8,k8,m8],t=[].concat(...e.map(n=>n.json));this.opMappers=t.reduce((n,a)=>(n[a.tfOpName]=a,n),{})}transformGraph(e,t={}){let n=e.node,a=[],r=[],s=[],i=n.reduce((m,f)=>(m[f.name]=this.mapNode(f),f.op.startsWith("Placeholder")?a.push(m[f.name]):f.op==="Const"?r.push(m[f.name]):(f.input==null||f.input.length===0)&&s.push(m[f.name]),m),{}),o=[],l=[],d={},u={};t!=null&&(d=this.mapSignatureEntries(t.inputs),u=this.mapSignatureEntries(t.outputs));let p=Object.keys(i);p.forEach(m=>{let f=i[m];f.inputNames.forEach(A=>{let[y]=cr(A);f.inputs.push(i[y]),i[y].children.push(f)})}),Object.keys(u).length===0?p.forEach(m=>{let f=i[m];f.children.length===0&&l.push(f)}):Object.keys(u).forEach(m=>{let[f]=cr(m),A=i[f];A!=null&&(A.signatureKey=u[m],l.push(A))}),Object.keys(d).length>0?Object.keys(d).forEach(m=>{let[f]=cr(m),A=i[f];A&&(A.signatureKey=d[m],o.push(A))}):o=a;let c={};e.library!=null&&e.library.function!=null&&(c=e.library.function.reduce((m,f)=>(m[f.signature.name]=this.mapFunction(f),m),{}));let h={nodes:i,inputs:o,outputs:l,weights:r,placeholders:a,signature:t,functions:c};return s.length>0&&(h.initNodes=s),h}mapSignatureEntries(e){return Object.keys(e||{}).reduce((t,n)=>(t[e[n].name]=n,t),{})}mapNode(e){let t=i8(e.op)||this.opMappers[e.op]||{};e.attr==null&&(e.attr={});let n={name:e.name,op:e.op,category:t.category,inputNames:(e.input||[]).map(a=>a.startsWith("^")?a.substr(1):a),inputs:[],children:[],inputParams:{},attrParams:{},rawAttrs:e.attr};return t.inputs!=null&&(n.inputParams=t.inputs.reduce((a,r)=>(a[r.name]={type:r.type,inputIndexStart:r.start,inputIndexEnd:r.end},a),{})),t.attrs!=null&&(n.attrParams=t.attrs.reduce((a,r)=>{let s=r.type,i;switch(r.type){case"string":i=A2(e.attr,r.tfName,r.defaultValue),i===void 0&&!!r.tfDeprecatedName&&(i=A2(e.attr,r.tfDeprecatedName,r.defaultValue));break;case"string[]":i=I2(e.attr,r.tfName,r.defaultValue),i===void 0&&!!r.tfDeprecatedName&&(i=I2(e.attr,r.tfDeprecatedName,r.defaultValue));break;case"number":i=g2(e.attr,r.tfName,r.defaultValue||0),i===void 0&&!!r.tfDeprecatedName&&(i=g2(e.attr,r.tfDeprecatedName,r.defaultValue));break;case"number[]":i=k2(e.attr,r.tfName,r.defaultValue),i===void 0&&!!r.tfDeprecatedName&&(i=k2(e.attr,r.tfDeprecatedName,r.defaultValue));break;case"bool":i=y2(e.attr,r.tfName,r.defaultValue),i===void 0&&!!r.tfDeprecatedName&&(i=y2(e.attr,r.tfDeprecatedName,r.defaultValue));break;case"bool[]":i=N2(e.attr,r.tfName,r.defaultValue),i===void 0&&!!r.tfDeprecatedName&&(i=N2(e.attr,r.tfDeprecatedName,r.defaultValue));break;case"shape":i=w2(e.attr,r.tfName,r.defaultValue),i===void 0&&!!r.tfDeprecatedName&&(i=w2(e.attr,r.tfDeprecatedName,r.defaultValue));break;case"shape[]":i=S2(e.attr,r.tfName,r.defaultValue),i===void 0&&!!r.tfDeprecatedName&&(i=S2(e.attr,r.tfDeprecatedName,r.defaultValue));break;case"dtype":i=b2(e.attr,r.tfName,r.defaultValue),i===void 0&&!!r.tfDeprecatedName&&(i=b2(e.attr,r.tfDeprecatedName,r.defaultValue));break;case"dtype[]":i=v2(e.attr,r.tfName,r.defaultValue),i===void 0&&!!r.tfDeprecatedName&&(i=v2(e.attr,r.tfDeprecatedName,r.defaultValue));break;case"func":i=I8(e.attr,r.tfName,r.defaultValue),i===void 0&&!!r.tfDeprecatedName&&(i=I8(e.attr,r.tfDeprecatedName,r.defaultValue));break;case"tensor":case"tensors":break;default:throw new Error(`Unsupported param type: ${r.type} for op: ${e.op}`)}return a[r.name]={value:i,type:s},a},{})),n}mapFunction(e){let t=e.nodeDef,n=[],a=[],r={};t!=null&&(r=t.reduce((d,u)=>(d[u.name]=this.mapNode(u),u.op==="Const"&&a.push(d[u.name]),d),{}));let s=[],i=[];e.signature.inputArg.forEach(d=>{let[u]=cr(d.name),p={name:u,op:"Placeholder",inputs:[],inputNames:[],category:"graph",inputParams:{},attrParams:{dtype:{value:x2(d.type),type:"dtype"}},children:[]};p.signatureKey=d.name,s.push(p),r[u]=p}),Object.keys(r).forEach(d=>{let u=r[d];u.inputNames.forEach(p=>{let[c]=cr(p);u.inputs.push(r[c]),r[c].children.push(u)})});let o=e.ret;e.signature.outputArg.forEach(d=>{let[u,p]=cr(o[d.name]),c=r[u];c!=null&&(c.defaultOutput=p,i.push(c))});let l=this.mapArgsToSignature(e);return{nodes:r,inputs:s,outputs:i,weights:a,placeholders:n,signature:l}}mapArgsToSignature(e){return{methodName:e.signature.name,inputs:e.signature.inputArg.reduce((t,n)=>(t[n.name]=this.mapArgToTensorInfo(n),t),{}),outputs:e.signature.outputArg.reduce((t,n)=>(t[n.name]=this.mapArgToTensorInfo(n,e.ret),t),{})}}mapArgToTensorInfo(e,t){let n=e.name;return t!=null&&(n=t[n]),{name:n,dtype:e.type}}};function nse(e){let t=J().global;if(typeof t.atob!="undefined")return t.atob(e);if(typeof Buffer!="undefined")return new Buffer(e,"base64").toString();throw new Error("Unable to decode base64 in this environment. Missing built-in atob() or Buffer()")}function N8(e,t){let n=Array.isArray(e)?String.fromCharCode.apply(null,e):nse(e);return t?n:n.toLowerCase()}function A2(e,t,n,a=!1){let r=e[t];return r!=null?N8(r.s,a):n}function y2(e,t,n){let a=e[t];return a?a.b:n}function g2(e,t,n){let a=e[t]||{},r=a.i!=null?a.i:a.f!=null?a.f:n;return typeof r=="number"?r:parseInt(r,10)}function x2(e){switch(typeof e=="string"&&(e=Ea[e]),e){case Ea.DT_FLOAT:return"float32";case Ea.DT_INT32:case Ea.DT_INT64:case Ea.DT_INT8:case Ea.DT_UINT8:return"int32";case Ea.DT_BOOL:return"bool";case Ea.DT_DOUBLE:return"float32";case Ea.DT_STRING:return"string";default:return null}}function I8(e,t,n){let a=e[t];return a&&a.func?a.func.name:n}function b2(e,t,n){let a=e[t];return a&&a.type?x2(a.type):n}function v2(e,t,n){let a=e[t];return a&&a.list&&a.list.type?a.list.type.map(r=>x2(r)):n}function T8(e){if(!e.unknownRank)return e.dim!=null?e.dim.map(t=>typeof t.size=="number"?t.size:parseInt(t.size,10)):[]}function w2(e,t,n){let a=e[t];return a&&a.shape?T8(a.shape):n}function k2(e,t,n){let a=e[t];return a?((a.list.f&&a.list.f.length?a.list.f:a.list.i)||[]).map(r=>typeof r=="number"?r:parseInt(r,10)):n}function I2(e,t,n,a=!1){let r=e[t];return r&&r.list&&r.list.s?r.list.s.map(s=>N8(s,a)):n}function S2(e,t,n){let a=e[t];return a&&a.list&&a.list.shape?a.list.shape.map(r=>T8(r)):n}function N2(e,t,n){let a=e[t];return a&&a.list&&a.list.b?a.list.b:n}var ase=class{constructor(e,t,n){this.node=e,this.tensorMap=t,this.context=n,this.inputs=[],this.attrs={},this.inputs=e.inputNames.map(a=>this.getInput(a)),e.rawAttrs!=null&&(this.attrs=Object.keys(e.rawAttrs).reduce((a,r)=>(a[r]=this.getAttr(r),a),{}))}getInput(e){return An(e,this.tensorMap,this.context)}getAttr(e,t){let n=this.node.rawAttrs[e];if(n.tensor!=null)return An(e,this.tensorMap,this.context);if(n.i!=null||n.f!=null)return g2(this.node.rawAttrs,e,t);if(n.s!=null)return A2(this.node.rawAttrs,e,t);if(n.b!=null)return y2(this.node.rawAttrs,e,t);if(n.shape!=null)return w2(this.node.rawAttrs,e,t);if(n.type!=null)return b2(this.node.rawAttrs,e,t);if(n.list!=null){if(n.list.i!=null||n.list.f!=null)return k2(this.node.rawAttrs,e,t);if(n.list.s!=null)return I2(this.node.rawAttrs,e,t);if(n.list.shape!=null)return S2(this.node.rawAttrs,e,t);if(n.list.b!=null)return N2(this.node.rawAttrs,e,t);if(n.list.type!=null)return v2(this.node.rawAttrs,e,t)}return t}},rse=(e,t,n)=>{switch(e.op){case"BiasAdd":case"AddV2":case"Add":return[se(I("a",e,t,n),I("b",e,t,n))];case"AddN":return[yc(I("tensors",e,t,n))];case"FloorMod":case"Mod":return[SA(I("a",e,t,n),I("b",e,t,n))];case"Mul":return[_(I("a",e,t,n),I("b",e,t,n))];case"RealDiv":case"Div":return[me(I("a",e,t,n),I("b",e,t,n))];case"DivNoNan":return[fA(I("a",e,t,n),I("b",e,t,n))];case"FloorDiv":return[Ac(I("a",e,t,n),I("b",e,t,n))];case"Sub":return[ge(I("a",e,t,n),I("b",e,t,n))];case"Minimum":return[xl(I("a",e,t,n),I("b",e,t,n))];case"Maximum":return[Pa(I("a",e,t,n),I("b",e,t,n))];case"Pow":return[sr(I("a",e,t,n),I("b",e,t,n))];case"SquaredDifference":return[Bc(I("a",e,t,n),I("b",e,t,n))];default:throw TypeError(`Node type ${e.op} is not implemented`)}},sse=(e,t,n)=>{switch(e.op){case"Abs":case"ComplexAbs":return[zt(I("x",e,t,n))];case"Acos":return[Ym(I("x",e,t,n))];case"Acosh":return[Jm(I("x",e,t,n))];case"Asin":return[eA(I("x",e,t,n))];case"Asinh":return[tA(I("x",e,t,n))];case"Atan":return[nA(I("x",e,t,n))];case"Atan2":return[aA(I("x",e,t,n),I("y",e,t,n))];case"Atanh":return[rA(I("x",e,t,n))];case"Ceil":return[uA(I("x",e,t,n))];case"Complex":return[Tr(I("real",e,t,n),I("imag",e,t,n))];case"Cos":return[Xu(I("x",e,t,n))];case"Cosh":return[wc(I("x",e,t,n))];case"Elu":return[ml(I("x",e,t,n))];case"Erf":return[mA(I("x",e,t,n))];case"Exp":return[Xn(I("x",e,t,n))];case"Expm1":return[AA(I("x",e,t,n))];case"Floor":return[yl(I("x",e,t,n))];case"Log":return[$n(I("x",e,t,n))];case"Log1p":return[Nc(I("x",e,t,n))];case"Imag":return[Ic(I("x",e,t,n))];case"Neg":return[wt(I("x",e,t,n))];case"Reciprocal":return[EA(I("x",e,t,n))];case"Real":return[ed(I("x",e,t,n))];case"Relu":return[La(I("x",e,t,n))];case"Round":return[$c(I("x",e,t,n))];case"Selu":return[Oc(I("x",e,t,n))];case"Sigmoid":return[kn(I("x",e,t,n))];case"Sin":return[zc(I("x",e,t,n))];case"Sign":return[RA(I("x",e,t,n))];case"Sinh":return[_c(I("x",e,t,n))];case"Softplus":return[fi(I("x",e,t,n))];case"Sqrt":return[Qt(I("x",e,t,n))];case"Square":return[st(I("x",e,t,n))];case"Tanh":return[pi(I("x",e,t,n))];case"Tan":return[$A(I("x",e,t,n))];case"ClipByValue":return[In(I("x",e,t,n),I("clipValueMin",e,t,n),I("clipValueMax",e,t,n))];case"Relu6":return[Fc(I("x",e,t,n))];case"Rsqrt":return[Dc(An(e.inputNames[0],t,n))];case"Prod":return[Mc(I("x",e,t,n),I("axes",e,t,n))];case"LeakyRelu":return[Ku(I("x",e,t,n),I("alpha",e,t,n))];case"Prelu":return[Qu(I("x",e,t,n),I("alpha",e,t,n))];case"IsNan":return[gA(An(e.inputNames[0],t,n))];default:throw TypeError(`Node type ${e.op} is not implemented`)}};function ha(e,t,n=""){if(!(typeof e=="number"||typeof t=="number")){k.assert(e.length===t.length,()=>n+` Shapes ${e} and ${t} must match`);for(let a=0;an+` Shapes ${e} and ${t} must match`)}}}function E8(e){return!(typeof e=="number"||e.some(t=>t<0))}function jd(e,t,n){let a=T2(e,n),r=!E8(a);if(r&&t.length===0)throw new Error(`Tried to calculate elements of an empty list with non-fully-defined elementShape: ${a}`);if(r&&t.forEach(s=>{a=T2(s.shape,a)}),!E8(a))throw new Error(`Non-fully-defined elementShape: ${a}`);return a}function T2(e,t){if(typeof e=="number")return t;if(typeof t=="number")return e;if(e.length!==t.length)throw new Error(`Incompatible ranks during merge: ${e} vs. ${t}`);let n=[];for(let a=0;a=0&&s>=0&&r!==s)throw new Error(`Incompatible shape during merge: ${e} vs. ${t}`);n[a]=r>=0?r:s}return n}var ise=class{constructor(e,t,n,a,r,s,i){this.name=e,this.dtype=t,this.maxSize=n,this.elementShape=a,this.identicalElementShapes=r,this.dynamicSize=s,this.clearAfterRead=i,this.tensors=[],this.closed_=!1,this.idTensor=Se(0),Ut(this.idTensor)}get id(){return this.idTensor.id}get closed(){return this.closed_}clearAndClose(e){this.tensors.forEach(t=>{(e==null||!e.has(t.tensor.id))&&t.tensor.dispose()}),this.tensors=[],this.closed_=!0,this.idTensor.dispose()}size(){return this.tensors.length}read(e){if(this.closed_)throw new Error(`TensorArray ${this.name} has already been closed.`);if(e<0||e>=this.size())throw new Error(`Tried to read from index ${e}, but array size is: ${this.size()}`);let t=this.tensors[e];if(t.cleared)throw new Error(`TensorArray ${this.name}: Could not read index ${e} twice because it was cleared after a previous read (perhaps try setting clear_after_read = false?).`);return this.clearAfterRead&&(t.cleared=!0),t.read=!0,t.tensor}readMany(e){return e.map(t=>this.read(t))}write(e,t){if(this.closed_)throw new Error(`TensorArray ${this.name} has already been closed.`);if(e<0||!this.dynamicSize&&e>=this.maxSize)throw new Error(`Tried to write to index ${e}, but array is not resizeable and size is: ${this.maxSize}`);let n=this.tensors[e]||{};if(t.dtype!==this.dtype)throw new Error(`TensorArray ${this.name}: Could not write to TensorArray index ${e}, - because the value dtype is ${t.dtype}, but TensorArray dtype is ${this.dtype}.`);if(this.size()===0&&(this.elementShape==null||this.elementShape.length===0)&&(this.elementShape=t.shape),ha(this.elementShape,t.shape,`TensorArray ${this.name}: Could not write to TensorArray index ${e}.`),n.read)throw new Error(`TensorArray ${this.name}: Could not write to TensorArray index ${e}, because it has already been read.`);if(n.written)throw new Error(`TensorArray ${this.name}: Could not write to TensorArray index ${e}, because it has already been written.`);n.tensor=t,Ut(t),n.written=!0,this.tensors[e]=n}writeMany(e,t){if(e.length!==t.length)throw new Error(`TensorArray ${this.name}: could not write multiple tensors,because the index size: ${e.length} is not the same as tensors size: ${t.length}.`);e.forEach((n,a)=>this.write(n,t[a]))}gather(e,t){if(!!t&&t!==this.dtype)throw new Error(`TensorArray dtype is ${this.dtype} but gather requested dtype ${t}`);if(e)e=e.slice(0,this.size());else{e=[];for(let a=0;a=this.maxSize)throw new Error(`Max index must be < array size (${n} vs. ${this.maxSize})`);this.writeMany(e,ua(t,0))}split(e,t){if(t.dtype!==this.dtype)throw new Error(`TensorArray dtype is ${this.dtype} but tensor has dtype ${t.dtype}`);let n=0,a=e.map(o=>(n+=o,n));if(n!==t.shape[0])throw new Error(`Expected sum of lengths to be equal to +2. The custom ${a} is defined in JavaScript, but is not registered properly with tf.serialization.registerClass().`);if(l!=null){let d={};for(let h of Object.keys(ua))d[h]=ua[h];for(let h of Object.keys(n))d[h]=n[h];let u=s.config;u.customObjects=d;let p=Object.assign({},ua);for(let h of Object.keys(n))ua[h]=n[h];M1(s.config);let c=l(o,s.config,n,r);return ua=Object.assign({},p),c}else{let d=Object.assign({},ua);for(let p of Object.keys(n))ua[p]=n[p];let u=new o(s.config);return ua=Object.assign({},d),u}}}function ate(e,t){return et?1:0}function Mh(e,t){return-1*ate(e,t)}function Br(e){if(e==null)return e;let t=[];for(let n of e)t.indexOf(n)===-1&&t.push(n);return t}function rte(e){if(e==null)throw new B(`Invalid value in obj: ${JSON.stringify(e)}`);for(let t in e)if(e.hasOwnProperty(t))return!1;return!0}function Ei(e,t,n){if(n!=null&&e.indexOf(n)<0)throw new B(`${n} is not a valid ${t}. Valid values are ${e} or null/undefined.`)}function F1(e,t,n=0,a=Infinity){return Va(n>=0),Va(a>=n),Array.isArray(e)&&e.length>=n&&e.length<=a&&e.every(r=>typeof r===t)}function Ht(e,t){Array.isArray(e)?(k.assert(e.length>0,()=>`${t} is unexpectedly an empty array.`),e.forEach((n,a)=>Ht(n,`element ${a+1} of ${t}`))):k.assert(Number.isInteger(e)&&e>0,()=>`Expected ${t} to be a positive integer, but got ${I6(e)}.`)}function I6(e){return e===null?"null":Array.isArray(e)?"["+e.map(t=>I6(t)).join(",")+"]":typeof e=="string"?`"${e}"`:`${e}`}function ste(e,t){let n=k.now(),a;return(...r)=>{let s=k.now();return s-nJt(ke(_(e,e),t,!0)))}var Sd=class extends ae.Serializable{getConfig(){return{}}},D1=class extends Sd{constructor(e){super();this.defaultMaxValue=2,this.defaultAxis=0,this.maxValue=e.maxValue!=null?e.maxValue:this.defaultMaxValue,this.axis=e.axis!=null?e.axis:this.defaultAxis}apply(e){return W(()=>{let t=$1(e,this.axis),n=kn(t,0,this.maxValue);return _(e,me(n,se(_t(),t)))})}getConfig(){return{maxValue:this.maxValue,axis:this.axis}}};D1.className="MaxNorm";ae.registerClass(D1);var O1=class extends Sd{constructor(e){super();this.defaultAxis=0,this.axis=e.axis!=null?e.axis:this.defaultAxis}apply(e){return W(()=>me(e,se(_t(),$1(e,this.axis))))}getConfig(){return{axis:this.axis}}};O1.className="UnitNorm";ae.registerClass(O1);var z1=class extends Sd{apply(e){return Pa(e)}};z1.className="NonNeg";ae.registerClass(z1);var _1=class extends Sd{constructor(e){super();this.defaultMinValue=0,this.defaultMaxValue=1,this.defaultRate=1,this.defaultAxis=0,this.minValue=e.minValue!=null?e.minValue:this.defaultMinValue,this.maxValue=e.maxValue!=null?e.maxValue:this.defaultMaxValue,this.rate=e.rate!=null?e.rate:this.defaultRate,this.axis=e.axis!=null?e.axis:this.defaultAxis}apply(e){return W(()=>{let t=$1(e,this.axis),n=se(_(this.rate,kn(t,this.minValue,this.maxValue)),_(1-this.rate,t));return _(e,me(n,se(_t(),t)))})}getConfig(){return{minValue:this.minValue,maxValue:this.maxValue,rate:this.rate,axis:this.axis}}};_1.className="MinMaxNorm";ae.registerClass(_1);var N6={maxNorm:"MaxNorm",minMaxNorm:"MinMaxNorm",nonNeg:"NonNeg",unitNorm:"UnitNorm"};function Pt(e){return R1(e)}function T6(e,t={}){return Id(e,ae.SerializationMap.getMap().classNameMap,t,"constraint")}function Lt(e){if(e==null)return null;if(typeof e=="string"){let t={className:e in N6?N6[e]:e,config:{}};return T6(t)}else return e instanceof Sd?e:T6(e)}function Qee(e){return new D1(e)}function ete(e){return new O1(e)}function tte(){return new z1}function nte(e){return new _1(e)}var E6={};Fe(E6,{constant:()=>lte,glorotNormal:()=>mte,glorotUniform:()=>fte,heNormal:()=>Ate,heUniform:()=>yte,identity:()=>cte,leCunNormal:()=>gte,leCunUniform:()=>xte,ones:()=>ote,orthogonal:()=>bte,randomNormal:()=>dte,randomUniform:()=>ute,truncatedNormal:()=>pte,varianceScaling:()=>hte,zeros:()=>ite});var vte=["channelsFirst","channelsLast"],wte=["nearest","bilinear"],kte=["valid","same","causal"],Ite=["max","avg"],Ste=["sum","mul","concat","ave"],Ll=new Map;function Et(e){Ei(vte,"DataFormat",e)}function Nte(e){Ei(wte,"InterpolationFormat",e)}function Jn(e){Ei(kte,"PaddingMode",e)}function C6(e){Ei(Ite,"PoolMode",e)}var Nd=[],R6="/";function Ci(e,t){Nd.push(e);try{let n=t();return Nd.pop(),n}catch(n){throw Nd.pop(),n}}function Tte(){return Nd.length===0?"":Nd.join(R6)+R6}function F6(e){if(!M6(e))throw new Error("Not a valid tensor name: '"+e+"'");return Tte()+e}function $6(e){if(!M6(e))throw new Error("Not a valid tensor name: '"+e+"'");Ll.has(e)||Ll.set(e,0);let t=Ll.get(e);if(Ll.set(e,Ll.get(e)+1),t>0){let n=`${e}_${t}`;return Ll.set(n,1),n}else return e}var Ete=new RegExp(/^[A-Za-z0-9][-A-Za-z0-9\._\/]*$/);function M6(e){return!!e.match(Ete)}function Cte(e){return e===parseInt(e.toString(),10)}function Vr(e,t,n){t==null&&(t=0),n==null&&(n=e.length);let a=1;for(let r=t;r{if(e.shape.length!==2)throw new B(`repeat() expects a rank-2 tensor, but received a rank-${e.shape.length} tensor.`);let n=Ed(e,1);return P1(n,[1,t,1])})}function Mte(e){let t=[Vr(e.shape)];return e.reshape(t)}function Fte(e){if(e.rank<=1)throw new B(`batchFlatten requires a minimum rank of 2. Got rank: ${e.rank}.`);let t=[e.shape[0],Vr(e.shape,1)];return e.reshape(t)}function Ri(e,t,n){return W(()=>{switch(e.rank){case 1:return Pc(e,t,n);case 2:return MA(e,[t,0],[n,e.shape[1]]);case 3:return Lc(e,[t,0,0],[n,e.shape[1],e.shape[2]]);case 4:return td(e,[t,0,0,0],[n,e.shape[1],e.shape[2],e.shape[3]]);case 5:return Re(e,[t,0,0,0,0],[n,e.shape[1],e.shape[2],e.shape[3],e.shape[4]]);case 6:return Re(e,[t,0,0,0,0,0],[n,e.shape[1],e.shape[2],e.shape[3],e.shape[4],e.shape[5]]);default:throw new B(`sliceAlongFirstAxis() received an unsupported tensor rank: ${e.rank}`)}})}function L1(e,t,n){return W(()=>{switch(e.rank){case 1:return Pc(e,t,n);case 2:return MA(e,[0,t],[e.shape[0],n]);case 3:return Lc(e,[0,0,t],[e.shape[0],e.shape[1],n]);case 4:return td(e,[0,0,0,t],[e.shape[0],e.shape[1],e.shape[2],n]);default:throw new B(`sliceAlongLastAxis() received an unsupported tensor rank: ${e.rank}`)}})}function Fh(e,t,n,a){return W(()=>{switch(e.rank){case 1:return Pc(e,t,n);case 2:switch(a){case 1:return Ri(e,t,n);case 2:return L1(e,t,n);default:throw new B(`The axis is not within the rank of the tensor ${a}`)}case 3:switch(a){case 1:return Ri(e,t,n);case 2:return Lc(e,[0,t,0],[e.shape[0],n,e.shape[2]]);case 3:return L1(e,t,n);default:throw new B(`The axis is not within the rank of the tensor ${a}`)}case 4:switch(a){case 1:return Ri(e,t,n);case 2:return td(e,[0,t,0,0],[e.shape[0],n,e.shape[2],e.shape[3]]);case 3:return td(e,[0,0,t,0],[e.shape[0],e.shape[1],n,e.shape[3]]);case 4:return L1(e,t,n);default:throw new B(`The axis is not within the rank of the tensor ${a}`)}default:throw new B(`sliceAlongLastAxis() received an unsupported tensor rank: ${e.rank}`)}})}function W1(e,t=-1){let n;return t<0&&(n=e[0].rank,n!==0?t=n:t=0),t===e[0].rank&&(t=-1),ot(e,t)}function O6(e,t){switch(e.rank){case 1:return Rb([e,t]);case 2:return cl([e,t],0);case 3:return Mb([e,t],0);case 4:return Fb([e,t],0);default:throw new B(`concatAlongFirstAxis() received an unsupported tensor rank: ${e.rank}`)}}function P1(e,t){if(Array.isArray(t)||(t=[t]),e.rank!==t.length)throw new B(`The length of input n (${t.length}) does not match the number of dimensions in input x (${e.rank})`);return Fr(e,t)}function $h(e,t=0,n=1,a,r){return Zb(e,t,n,a,r)}function ja(e,t,n,a){if(e.rank<2||t.rank<2)throw new Oe(`dot requires both inputs to be rank >= 2 but got x shape = ${e.shape} and y shape = ${t.shape}`);if(t.rank>=3){let r=e.shape.slice(-1)[0],s=t.shape.slice(-2)[0];if(r!==s)throw new Oe(`If rank y >= 3, then the second last dim of y must equal the last dim of x but got x shape = ${e.shape} and y shape = ${t.shape}`)}if(e.rank===2&&t.rank===2){let r=!1,s=!1;return zr.matMul({a:e,b:t,transposeA:r,transposeB:s,bias:a?B1(e.rank,a,ba()):null,activation:n})}else{let r=e.shape.slice(),s=r.pop();e=e.reshape([-1,s]);let i=t.shape.slice(),o=i.pop(),l=i.pop(),d=[...i,o],u=Array.from({length:t.rank},(m,f)=>f===0?t.rank-2:f<=t.rank-2?f-1:f);t=t.transpose(u).reshape([l,-1]);let p=[...r,...d],c=!1,h=!1;return zr.matMul({a:e,b:t,transposeA:c,transposeB:h,bias:a?B1(e.rank,a,ba()):null,activation:n}).reshape(p)}}function z6(e,t,n){return W(()=>(Array.isArray(t)?t=Tt(t,"int32"):t=t.toInt(),ci(e,t,n)))}function Cd(e){return _(e,e)}function B1(e,t,n){let a=t.shape;if(t.rank!==1&&t.rank!==e)throw new B(`Unexpected bias dimensions: ${t.rank}; expected it to be 1 or ${e}`);if(e===5){if(n==="channelsFirst")return a.length===1?t.reshape([1,a[0],1,1,1]):t.reshape([1,a[3],a[0],a[1],a[2]]);if(n==="channelsLast")return a.length===1?t.reshape([1,1,1,1,a[0]]):t.reshape([1].concat(a))}else if(e===4){if(n==="channelsFirst")return a.length===1?t.reshape([1,a[0],1,1]):t.reshape([1,a[2],a[0],a[1]]);if(n==="channelsLast")return a.length===1?t.reshape([1,1,1,a[0]]):t.reshape([1].concat(a))}else if(e===3){if(n==="channelsFirst")return a.length===1?t.reshape([1,a[0],1]):t.reshape([1,a[1],a[0]]);if(n==="channelsLast")return a.length===1?t.reshape([1,1,a[0]]):t.reshape([1].concat(a))}else if(e<3)return t;throw new B(`Unsupported input rank by biasAdd: ${t.rank}`)}function ka(e,t,n){return W(()=>(n==null&&(n=ba()),Et(n),e.add(B1(e.rank,t,n))))}function $te(e,t=1){if(t!==1)throw new Oe(`Support for alpha values other than 1 (${t}) is not implemented yet.`);return fl(e)}function Dte(e){return W(()=>me(e,Ot(e).add(1)))}function _6(e,t,n,a){return W(()=>a3(e,t,n,a))}function Ote(e){return W(()=>{let t=se(.5,_(.2,e));return kn(t,0,1)})}function Rd(e,t,n=!1){return n?e():t()}var zte=["fanIn","fanOut","fanAvg"],_te=["normal","uniform","truncatedNormal"];function Pte(e){Ei(zte,"FanMode",e)}function Lte(e){Ei(_te,"Distribution",e)}var da=class extends ae.Serializable{fromConfigUsesCustomObjects(){return!1}getConfig(){return{}}},V1=class extends da{apply(e,t){return Ct(e,t)}};V1.className="Zeros";ae.registerClass(V1);var Dh=class extends da{apply(e,t){return $n(e,t)}};Dh.className="Ones";ae.registerClass(Dh);var j1=class extends da{constructor(e){super();if(typeof e!="object")throw new B(`Expected argument of type ConstantConfig but got ${e}`);if(e.value===void 0)throw new B(`config must have value set but got ${e}`);this.value=e.value}apply(e,t){return W(()=>_(Se(this.value),$n(e,t)))}getConfig(){return{value:this.value}}};j1.className="Constant";ae.registerClass(j1);var U1=class extends da{constructor(e){super();this.DEFAULT_MINVAL=-.05,this.DEFAULT_MAXVAL=.05,this.minval=e.minval||this.DEFAULT_MINVAL,this.maxval=e.maxval||this.DEFAULT_MAXVAL,this.seed=e.seed}apply(e,t){return xl(e,this.minval,this.maxval,t)}getConfig(){return{minval:this.minval,maxval:this.maxval,seed:this.seed}}};U1.className="RandomUniform";ae.registerClass(U1);var H1=class extends da{constructor(e){super();this.DEFAULT_MEAN=0,this.DEFAULT_STDDEV=.05,this.mean=e.mean||this.DEFAULT_MEAN,this.stddev=e.stddev||this.DEFAULT_STDDEV,this.seed=e.seed}apply(e,t){if(t=t||"float32",t!=="float32"&&t!=="int32")throw new Oe(`randomNormal does not support dType ${t}.`);return $h(e,this.mean,this.stddev,t,this.seed)}getConfig(){return{mean:this.mean,stddev:this.stddev,seed:this.seed}}};H1.className="RandomNormal";ae.registerClass(H1);var G1=class extends da{constructor(e){super();this.DEFAULT_MEAN=0,this.DEFAULT_STDDEV=.05,this.mean=e.mean||this.DEFAULT_MEAN,this.stddev=e.stddev||this.DEFAULT_STDDEV,this.seed=e.seed}apply(e,t){if(t=t||"float32",t!=="float32"&&t!=="int32")throw new Oe(`truncatedNormal does not support dType ${t}.`);return Vc(e,this.mean,this.stddev,t,this.seed)}getConfig(){return{mean:this.mean,stddev:this.stddev,seed:this.seed}}};G1.className="TruncatedNormal";ae.registerClass(G1);var q1=class extends da{constructor(e){super();this.gain=e.gain!=null?e.gain:1}apply(e,t){return W(()=>{if(e.length!==2||e[0]!==e[1])throw new B("Identity matrix initializer can only be used for 2D square matrices.");return _(this.gain,yA(e[0]))})}getConfig(){return{gain:this.gain}}};q1.className="Identity";ae.registerClass(q1);function Wte(e,t="channelsLast"){let n,a;if(Et(t),e.length===2)n=e[0],a=e[1];else if([3,4,5].indexOf(e.length)!==-1){if(t==="channelsFirst"){let r=Vr(e,2);n=e[1]*r,a=e[0]*r}else if(t==="channelsLast"){let r=Vr(e,0,e.length-2);n=e[e.length-2]*r,a=e[e.length-1]*r}}else{let r=Vr(e);n=Math.sqrt(r),a=Math.sqrt(r)}return[n,a]}var Nn=class extends da{constructor(e){super();if(e.scale<0)throw new B(`scale must be a positive float. Got: ${e.scale}`);this.scale=e.scale==null?1:e.scale,this.mode=e.mode==null?"fanIn":e.mode,Pte(this.mode),this.distribution=e.distribution==null?"normal":e.distribution,Lte(this.distribution),this.seed=e.seed}apply(e,t){let n=Wte(e),a=n[0],r=n[1],s=this.scale;if(this.mode==="fanIn"?s/=Math.max(1,a):this.mode==="fanOut"?s/=Math.max(1,r):s/=Math.max(1,(a+r)/2),this.distribution==="normal"){let i=Math.sqrt(s);if(t=t||"float32",t!=="float32"&&t!=="int32")throw new Oe(`${this.getClassName()} does not support dType ${t}.`);return Vc(e,0,i,t,this.seed)}else{let i=Math.sqrt(3*s);return xl(e,-i,i,t)}}getConfig(){return{scale:this.scale,mode:this.mode,distribution:this.distribution,seed:this.seed}}};Nn.className="VarianceScaling";ae.registerClass(Nn);var Oh=class extends Nn{constructor(e){super({scale:1,mode:"fanAvg",distribution:"uniform",seed:e==null?null:e.seed})}getClassName(){return Nn.className}};Oh.className="GlorotUniform";ae.registerClass(Oh);var zh=class extends Nn{constructor(e){super({scale:1,mode:"fanAvg",distribution:"normal",seed:e==null?null:e.seed})}getClassName(){return Nn.className}};zh.className="GlorotNormal";ae.registerClass(zh);var _h=class extends Nn{constructor(e){super({scale:2,mode:"fanIn",distribution:"normal",seed:e==null?null:e.seed})}getClassName(){return Nn.className}};_h.className="HeNormal";ae.registerClass(_h);var Ph=class extends Nn{constructor(e){super({scale:2,mode:"fanIn",distribution:"uniform",seed:e==null?null:e.seed})}getClassName(){return Nn.className}};Ph.className="HeUniform";ae.registerClass(Ph);var Lh=class extends Nn{constructor(e){super({scale:1,mode:"fanIn",distribution:"normal",seed:e==null?null:e.seed})}getClassName(){return Nn.className}};Lh.className="LeCunNormal";ae.registerClass(Lh);var Wh=class extends Nn{constructor(e){super({scale:1,mode:"fanIn",distribution:"uniform",seed:e==null?null:e.seed})}getClassName(){return Nn.className}};Wh.className="LeCunNormal";ae.registerClass(Wh);var X1=class extends da{constructor(e){super();if(this.DEFAULT_GAIN=1,this.gain=e.gain==null?this.DEFAULT_GAIN:e.gain,this.seed=e.seed,this.seed!=null)throw new Oe("Random seed is not implemented for Orthogonal Initializer yet.")}apply(e,t){return W(()=>{if(e.length<2)throw new Oe("Shape must be at least 2D.");e[0]*e[1]>2e3&&console.warn(`Orthogonal initializer is being called on a matrix with more than 2000 (${e[0]*e[1]}) elements: Slowness may result.`);let n=e[0]>e[1]?[e[1],e[0]]:e,a=$h(n,0,1,"float32"),r=A3.gramSchmidt(a);return e[0]>e[1]&&(r=r.transpose()),_(this.gain,r)})}getConfig(){return{gain:this.gain,seed:this.seed}}};X1.className="Orthogonal";ae.registerClass(X1);var P6={constant:"Constant",glorotNormal:"GlorotNormal",glorotUniform:"GlorotUniform",heNormal:"HeNormal",heUniform:"HeUniform",identity:"Identity",leCunNormal:"LeCunNormal",leCunUniform:"LeCunUniform",ones:"Ones",orthogonal:"Orthogonal",randomNormal:"RandomNormal",randomUniform:"RandomUniform",truncatedNormal:"TruncatedNormal",varianceScaling:"VarianceScaling",zeros:"Zeros"};function L6(e,t={}){return Id(e,ae.SerializationMap.getMap().classNameMap,t,"initializer")}function kt(e){return R1(e)}function mt(e){if(typeof e=="string"){let t=e in P6?P6[e]:e;if(t==="GlorotNormal")return new zh;if(t==="GlorotUniform")return new Oh;if(t==="HeNormal")return new _h;if(t==="HeUniform")return new Ph;if(t==="LeCunNormal")return new Lh;if(t==="LeCunUniform")return new Wh;{let n={};return n.className=t,n.config={},L6(n)}}else return e instanceof da?e:L6(e)}function ite(){return new V1}function ote(){return new Dh}function lte(e){return new j1(e)}function ute(e){return new U1(e)}function dte(e){return new H1(e)}function pte(e){return new G1(e)}function cte(e){return new q1(e)}function hte(e){return new Nn(e)}function fte(e){return new Oh(e)}function mte(e){return new zh(e)}function Ate(e){return new _h(e)}function yte(e){return new Ph(e)}function gte(e){return new Lh(e)}function xte(e){return new Wh(e)}function bte(e){return new X1(e)}var W6={};Fe(W6,{Layer:()=>Ge,RNN:()=>Ua,RNNCell:()=>Md,activation:()=>ane,add:()=>cne,alphaDropout:()=>Kne,average:()=>hne,averagePooling1d:()=>K1,averagePooling2d:()=>Z1,averagePooling3d:()=>Y1,avgPool1d:()=>wne,avgPool2d:()=>Ine,avgPool3d:()=>Nne,avgPooling1d:()=>kne,avgPooling2d:()=>Sne,avgPooling3d:()=>Tne,batchNormalization:()=>xne,bidirectional:()=>Bne,concatenate:()=>fne,conv1d:()=>Xte,conv2d:()=>Kte,conv2dTranspose:()=>Zte,conv3d:()=>Yte,conv3dTranspose:()=>Jte,convLstm2d:()=>_ne,convLstm2dCell:()=>Pne,cropping2D:()=>ene,dense:()=>rne,depthwiseConv2d:()=>nne,dot:()=>gne,dropout:()=>sne,elu:()=>Vte,embedding:()=>pne,flatten:()=>one,gaussianDropout:()=>Xne,gaussianNoise:()=>qne,globalAveragePooling1d:()=>Ene,globalAveragePooling2d:()=>Cne,globalMaxPool1d:()=>jne,globalMaxPool2d:()=>Une,globalMaxPooling1d:()=>V6,globalMaxPooling2d:()=>j6,gru:()=>Mne,gruCell:()=>Fne,input:()=>B6,inputLayer:()=>Bte,layerNormalization:()=>bne,leakyReLU:()=>Ute,lstm:()=>$ne,lstmCell:()=>Dne,masking:()=>Zne,maxPool1d:()=>Hne,maxPool2d:()=>Gne,maxPooling1d:()=>U6,maxPooling2d:()=>H6,maxPooling3d:()=>Rne,maximum:()=>mne,minimum:()=>Ane,multiply:()=>yne,permute:()=>dne,prelu:()=>Hte,reLU:()=>jte,repeatVector:()=>lne,reshape:()=>une,rnn:()=>Lne,separableConv2d:()=>Qte,simpleRNN:()=>One,simpleRNNCell:()=>zne,softmax:()=>Gte,spatialDropout1d:()=>ine,stackedRNNCells:()=>Wne,thresholdedReLU:()=>qte,timeDistributed:()=>Vne,upSampling2d:()=>tne,zeroPadding2d:()=>vne});var Yne=0;function G6(){return Yne++}var Bh={};function Vh(e=""){return e in Bh||(Bh[e]=0),Bh[e]+=1,e+Bh[e].toString()}function J1(e){return Array.isArray(e)&&Array.isArray(e[0])}function jh(e){return e.length===0?[]:Array.isArray(e[0])?e:[e]}function _e(e){let t;if(Array.isArray(e)){if(e.length!==1)throw new B(`Expected Tensor length to be 1; got ${e.length}`);t=e[0]}else t=e;return t}function at(e){if(Array.isArray(e)&&Array.isArray(e[0])){if(e.length===1)return e=e,e[0];throw new B(`Expected exactly 1 Shape; got ${e.length}`)}else return e}function Uh(e){let t=0;for(let n of e)n.shape.length===0?t+=1:t+=n.shape.reduce((a,r)=>a*r);return t}var q6="Variable",X6=class{constructor(e,t="float32",n=q6,a=!0,r=null){this.dtype=t==null?"float32":t,this.shape=e.shape,this.id=G6(),n=n==null?q6:n,this.originalName=F6(n),this.name=$6(this.originalName),this.trainable_=a,this.constraint=r,this.val=Jb(e,this.trainable_,this.name,this.dtype)}read(){return this.assertNotDisposed(),this.val}write(e){return this.assertNotDisposed(),Jne(this.val,e),this.val.id!==e.id&&(this.val.assign(e),this.constraint!=null&&this.val.assign(this.constraint.apply(this.val))),this}dispose(){this.assertNotDisposed(),this.val.dispose()}assertNotDisposed(){if(this.val.isDisposed)throw new Error(`LayersVariable ${this.name} is already disposed.`)}get trainable(){return this.trainable_}set trainable(e){this.trainable_=e,this.val.trainable=e}};function Jne(e,t){if(e.shape.toString()!==t.shape.toString())throw new Error("Shape mismatch: "+JSON.stringify(e.shape)+" vs. "+JSON.stringify(t.shape))}function Q1(e){return e.map(t=>t.read())}function ey(e){e.forEach(t=>{t[0].write(t[1])})}var Mt=class{constructor(e){this.dtype=e.dtype,this.shape=e.shape,e.shape!=null?this.ndim=e.shape.length:this.ndim=e.ndim,this.maxNDim=e.maxNDim,this.minNDim=e.minNDim,this.axes=e.axes||{}}},Ia=class{constructor(e,t,n,a,r,s,i){this.dtype=e,this.shape=t,this.sourceLayer=n,this.inputs=a,this.callArgs=r,this.outputTensorIndex=i,this.id=G6(),s!=null&&(this.originalName=F6(s),this.name=$6(this.originalName)),this.rank=t.length}},Qne=0,Hh=class{constructor(e,t){this.callArgs=t,this.id=Qne++,this.outboundLayer=e.outboundLayer,this.inboundLayers=e.inboundLayers,this.nodeIndices=e.nodeIndices,this.tensorIndices=e.tensorIndices,this.inputTensors=e.inputTensors,this.outputTensors=e.outputTensors,this.inputMasks=e.inputMasks,this.outputMasks=e.outputMasks,this.inputShapes=e.inputShapes,this.outputShapes=e.outputShapes;for(let n of e.inboundLayers)n!=null&&n.outboundNodes.push(this);e.outboundLayer.inboundNodes.push(this)}getConfig(){let e=[];for(let t of this.inboundLayers)t!=null?e.push(t.name):e.push(null);return{outboundLayer:this.outboundLayer?this.outboundLayer.name:null,inboundLayers:e,nodeIndices:this.nodeIndices,tensorIndices:this.tensorIndices}}},eae=0,Ge=class extends ae.Serializable{constructor(e={}){super();this._callHook=null,this._addedWeightNames=[],this._stateful=!1,this.id=eae++,this.activityRegularizer=null,this.inputSpec=null,this.supportsMasking=!1,this._trainableWeights=[],this._nonTrainableWeights=[],this._losses=[],this._updates=[],this._built=!1,this.inboundNodes=[],this.outboundNodes=[];let t=e.name;if(!t){let n=this.getClassName();t=ur(n)+"_"+Vh(n)}if(this.name=t,this.trainable_=e.trainable==null?!0:e.trainable,e.inputShape!=null||e.batchInputShape!=null){let n;if(e.batchInputShape!=null)n=e.batchInputShape;else if(e.inputShape!=null){let r=null;e.batchSize!=null&&(r=e.batchSize),n=[r].concat(e.inputShape)}this.batchInputShape=n;let a=e.dtype;a==null&&(a=e.inputDType),a==null&&(a="float32"),this.dtype=a}e.weights!=null?this.initialWeights=e.weights:this.initialWeights=null,this._refCount=null,this.fastWeightInitDuringBuild=!1}static nodeKey(e,t){return e.name+"_ib-"+t.toString()}getNodeAtIndex(e,t){if(this.inboundNodes.length===0)throw new va(`The layer has never been called and thus has no defined ${t}.`);if(this.inboundNodes.length<=e)throw new B(`Asked to get ${t} at node ${e}, but the layer has only ${this.inboundNodes.length} inbound nodes.`);return this.inboundNodes[e]}getInputAt(e){return Sn(this.getNodeAtIndex(e,"input").inputTensors)}getOutputAt(e){return Sn(this.getNodeAtIndex(e,"output").outputTensors)}get input(){if(this.inboundNodes.length>1)throw new lr(`Layer ${this.name} has multiple inbound nodes, hence the notion of "layer input" is ill-defined. Use \`getInputAt(nodeIndex)\` instead.`);if(this.inboundNodes.length===0)throw new lr(`Layer ${this.name} is not connected, no input to return.`);return Sn(this.getNodeAtIndex(0,"input").inputTensors)}get output(){if(this.inboundNodes.length===0)throw new lr(`Layer ${this.name} has no inbound nodes.`);if(this.inboundNodes.length>1)throw new lr(`Layer ${this.name} has multiple inbound nodes, hence the notion of "layer output" is ill-defined. Use \`getOutputAt(nodeIndex)\` instead.`);return Sn(this.getNodeAtIndex(0,"output").outputTensors)}get losses(){return this._losses}calculateLosses(){return this.losses.map(e=>e())}get updates(){return this._updates}get built(){return this._built}set built(e){this._built=e}get trainable(){return this.trainable_}set trainable(e){this._trainableWeights.forEach(t=>t.trainable=e),this.trainable_=e}get trainableWeights(){return this.trainable_?this._trainableWeights.filter(e=>e.trainable):[]}set trainableWeights(e){this._trainableWeights=e}get nonTrainableWeights(){return this.trainable?this._trainableWeights.filter(e=>!e.trainable).concat(this._nonTrainableWeights):this._trainableWeights.concat(this._nonTrainableWeights)}set nonTrainableWeights(e){this._nonTrainableWeights=e}get weights(){return this.trainableWeights.concat(this.nonTrainableWeights)}get stateful(){return this._stateful}resetStates(){if(!this.stateful)throw new Error("Cannot call the resetStates() method of a non-stateful Layer object.")}assertInputCompatibility(e){if(e=ht(e),this.inputSpec==null||this.inputSpec.length===0)return;let t=ht(this.inputSpec);if(e.length!==t.length)throw new B(`Layer ${this.name} expects ${t.length} inputs, but it received ${e.length} input tensors. Input received: ${e}`);for(let n=0;nr.maxNDim)throw new B(`Input ${n} is incompatible with layer ${this.name}: expected max_ndim=${r.maxNDim}, found ndim=${s}`);if(r.minNDim!=null&&s=0?i[l]:i[i.length+l];if(d!=null&&[d,null].indexOf(u)===-1)throw new B(`Input ${n} is incompatible with layer ${this.name}: expected axis ${l} of input shape to have value ${d} but got shape ${i}.`)}}if(r.shape!=null)for(let i=0;i{if(!this.built){this.assertInputCompatibility(e);let s=[];for(let i of ht(e))s.push(i.shape);this.build(Sn(s)),this.built=!0,this.initialWeights&&this.setWeights(this.initialWeights),this._refCount===null&&r&&(this._refCount=1)}if(this.assertInputCompatibility(e),r){let s=this.call(e,t),i=ht(s),o=[];for(let l of i)n.indexOf(l)!==-1&&(l=l.clone()),o.push(l);if(s=Sn(o),this.activityRegularizer!=null)throw new Oe("Layer invocation in the presence of activity regularizer(s) is not supported yet.");return s}else{let s=tae(e),i=this.computeOutputShape(s),o,l=nae(e);if(this.warnOnIncompatibleInputShape(Array.isArray(e)?s[0]:s),i!=null&&i.length>0&&Array.isArray(i[0])?o=i.map((d,u)=>new Ia(l,d,this,ht(e),t,this.name,u)):o=new Ia(l,i,this,ht(e),t,this.name),this.addInboundNode(e,o,null,null,s,i,t),this._refCount++,this.activityRegularizer!=null)throw new Oe("Layer invocation in the presence of activity regularizer(s) is not supported yet.");return o}})}warnOnIncompatibleInputShape(e){if(this.batchInputShape!=null)if(e.length!==this.batchInputShape.length)console.warn(`The rank of the input tensor provided (shape: ${JSON.stringify(e)}) does not match that of the batchInputShape (${JSON.stringify(this.batchInputShape)}) of the layer ${this.name}`);else{let t=!1;this.batchInputShape.forEach((n,a)=>{n!=null&&e[a]!=null&&e[a]!==n&&(t=!0)}),t&&console.warn(`The shape of the input tensor (${JSON.stringify(e)}) does not match the expectation of layer ${this.name}: ${JSON.stringify(this.batchInputShape)}`)}}get outputShape(){if(this.inboundNodes==null||this.inboundNodes.length===0)throw new lr(`The layer ${this.name} has never been called and thus has no defined output shape.`);let e=[];for(let t of this.inboundNodes){let n=JSON.stringify(t.outputShapes);e.indexOf(n)===-1&&e.push(n)}if(e.length===1){let t=this.inboundNodes[0].outputShapes;return Array.isArray(t)&&Array.isArray(t[0])&&t.length===1?t[0]:t}else throw new lr(`The layer ${this.name} has multiple inbound nodes with different output shapes. Hence the notion of "output shape" is ill-defined for the layer.`)}countParams(){if(!this.built)throw new va(`You tried to call countParams() on ${this.name}, but the layer is not built yet. Build it first by calling build(batchInputShape).`);return Uh(this.weights)}build(e){this.built=!0}getWeights(e=!1){return Q1(e?this.trainableWeights:this.weights)}setWeights(e){W(()=>{let t=this.weights;if(t.length!==e.length)throw new B(`You called setWeights(weights) on layer "${this.name}" with a weight list of length ${e.length}, but the layer was expecting ${t.length} weights. Provided weights: ${e}...`);if(t.length===0)return;let n=[],a=Q1(t);for(let r=0;rr.apply(l.read())),s==null&&(s=!0),s?this._trainableWeights.push(l):this._nonTrainableWeights.push(l),l}setFastWeightInitDuringBuild(e){this.fastWeightInitDuringBuild=e}addLoss(e){e==null||Array.isArray(e)&&e.length===0||(e=ht(e),this._losses!==void 0&&this._losses!==null&&this.losses.push(...e))}computeOutputShape(e){return e}computeMask(e,t){if(!this.supportsMasking){if(t!=null)if(Array.isArray(t))t.forEach(n=>{if(n!=null)throw new TypeError(`Layer ${this.name} does not support masking, but was passed an inputMask.`)});else throw new TypeError(`Layer ${this.name} does not support masking, but was passed an inputMask.`);return null}return t}addInboundNode(e,t,n,a,r,s,i=null){let o=ht(e);t=ht(t),n=ht(n),a=ht(a),r=jh(r),s=jh(s);let l=[],d=[],u=[];for(let p of o)l.push(p.sourceLayer),d.push(p.nodeIndex),u.push(p.tensorIndex);new Hh({outboundLayer:this,inboundLayers:l,nodeIndices:d,tensorIndices:u,inputTensors:o,outputTensors:t,inputMasks:n,outputMasks:a,inputShapes:r,outputShapes:s},i);for(let p=0;pe.dispose()),this.weights.length}assertNotDisposed(){if(this._refCount===0)throw new Error(`Layer '${this.name}' is already disposed.`)}dispose(){if(!this.built)throw new Error(`Cannot dispose Layer ${this.name} because it has not been built yet.`);if(this._refCount===null)throw new Error(`Cannot dispose Layer ${this.name} because it has not been used yet.`);this.assertNotDisposed();let e=0;return--this._refCount==0&&(e=this.disposeWeights()),{refCountAfterDispose:this._refCount,numDisposedVariables:e}}};function tae(e){e=ht(e);let t=[];for(let n of e)t.push(n.shape);return Sn(t)}function nae(e){return"float32"}function K6(e,t,n){if((t==null||n!=null&&n>0)&&(t=e.sourceLayer,n=e.nodeIndex),t.inboundNodes.length===0)return[e];{let a=t.inboundNodes[n];if(a.inboundLayers.length===0)return a.inputTensors;{let r=[];for(let s=0;s0){let r=await Promise.all(t);for(let s=0;sse(this.totals[a],_(r,n)));this.totals[a]=i,s!=null&&s.dispose()}}}async onEpochEnd(e,t){if(t!=null)for(let n of this.params.metrics)this.totals[n]!=null&&(typeof this.totals[n]=="number"?t[n]=this.totals[n]/this.seen:W(()=>{let a=_(me(1,this.seen),this.totals[n]);t[n]=a,this.totals[n].dispose(),jt(t[n])}))}},e4=class extends Vl{async onTrainBegin(e){this.epoch=[],this.history={}}async onEpochEnd(e,t){t==null&&(t={}),this.epoch.push(e);for(let n in t)this.history[n]==null&&(this.history[n]=[]),this.history[n].push(t[n])}async syncData(){let e=[],t=[],n=[];for(let r in this.history){let s=this.history[r];for(let i=0;inew t4(n,t))}var pa=class{constructor(){}static registerCallbackConstructor(e,t){k.assert(e>=0&&Number.isInteger(e),()=>`Verbosity level is expected to be an integer >= 0, but got ${e}`),pa.checkForDuplicate(t),pa.constructors[e]==null&&(pa.constructors[e]=[]),pa.constructors[e].push(t)}static checkForDuplicate(e){for(let t in pa.constructors)pa.constructors[+t].forEach(n=>{if(n===e)throw new B("Duplicate callback constructor.")})}static clear(){pa.constructors={}}static createCallbacks(e){let t=[];for(let n in pa.constructors){let a=+n;e>=a&&t.push(...pa.constructors[a])}return t.map(n=>new n)}};pa.constructors={};function a4(e,t,n,a,r,s,i,o,l){let d=new e4,u=[new rae,...pa.createCallbacks(t)];e!=null&&u.push(...e),u.push(d);let p=new Q6(u);return p.setParams({epochs:n,initialEpoch:a,samples:r,steps:s,batchSize:i,verbose:t,doValidation:o,metrics:l}),{callbackList:p,history:d}}function Sa(e,t={},n=!1){return Id(e,ae.SerializationMap.getMap().classNameMap,t,"layer",n)}function Gh(e,t){return W(()=>{e.dtype!=="float32"&&(e=e.asType("float32"));let n=ke(Cd(e),t,!0),a=ml(n.shape,_t()),r=Jt(_a(n,a));return me(e,r)})}function Mi(e,t){return W(()=>wt(Cd(ge(t,e)),-1))}function qh(e,t){return W(()=>wt(Ot(ge(t,e)),-1))}function jl(e,t){return W(()=>{let n=ge(e,t),a=kn(Ot(e),_t(),Number.MAX_VALUE),r=Ot(me(n,a));return _(100,wt(r,-1))})}function sae(e,t){return W(()=>{let n=kn(t,_t(),Number.MAX_VALUE),a=Fn(se(1,n)),r=kn(e,_t(),Number.MAX_VALUE),s=Fn(se(1,r));return wt(Cd(ge(a,s)),-1)})}function iae(e,t){return W(()=>{let n=_a(0,ge(1,_(e,t)));return wt(Cd(n),-1)})}function oae(e,t){return W(()=>{let n=_a(0,ge(1,_(e,t)));return wt(n,-1)})}function lae(e,t){return W(()=>{let n=ke(_(e,t),-1),a=Xn(_(ge(1,e),t),-1);return _a(0,se(1,ge(a,n)))})}function uae(e,t){return W(()=>{let n=Math.log(2),a=ge(t,e),r=ge(se(a,hi(_(-2,a))),n);return wt(r,-1)})}function Fd(e,t,n=!1){return W(()=>{if(n)t=nd(t);else{let a=ke(t,t.shape.length-1,!0);t=me(t,a)}return t=kn(t,_t(),1-_t()),vt(ke(_(e.toFloat(),Fn(t)),t.shape.length-1))})}function Xh(e,t,n=!1){return W(()=>{let a=Al(Mte(e)).toInt();t=kn(t,_t(),1-_t());let r=t.shape,s=ol(a,r[r.length-1]).reshape(r);return Fd(s,t,n)})}function dae(e,t){if(!k.arraysEqual(e.shape,t.shape))throw new B(`logits and labels must have the same shape, but got shapes ${JSON.stringify(e.shape)} and ${JSON.stringify(t.shape)}`);return W(()=>{let n=t.relu(),a=t.abs().neg();return n.sub(t.mul(e)).add(a.exp().log1p())})}function Kh(e,t){return W(()=>{let n;return n=kn(t,_t(),1-_t()),n=Fn(me(n,ge(1,n))),wt(dae(e,n),-1)})}function pae(e,t){return W(()=>{let n=kn(e,_t(),1),a=kn(t,_t(),1);return ke(_(e,Fn(me(n,a))),-1)})}function cae(e,t){return W(()=>{let n=Fn(se(_t(),t));return wt(ge(t,_(e,n)),-1)})}function ty(e,t){return W(()=>{let n=Gh(e,-1),a=Gh(t,-1),r=_(n,a);return vt(ke(r,-1))})}var Zh={meanSquaredError:Mi,meanAbsoluteError:qh,meanAbsolutePercentageError:jl,meanSquaredLogarithmicError:sae,squaredHinge:iae,hinge:oae,categoricalHinge:lae,logcosh:uae,categoricalCrossentropy:Fd,sparseCategoricalCrossentropy:Xh,binaryCrossentropy:Kh,kullbackLeiblerDivergence:pae,poisson:cae,cosineProximity:ty};function ny(e){if(typeof e=="string"){if(e in Zh)return Zh[e];let t=`Unknown loss ${e}`;throw e.toLowerCase().includes("softmaxcrossentropy")&&(t=`Unknown loss ${e}. Use "categoricalCrossentropy" as the string name for tf.losses.softmaxCrossEntropy`),new B(t)}else return e}function ay(e,t){return W(()=>{let n=_(.5,Dn(t)),a=Td(Mn(t,n),e.dtype);return wt(Mr(e,a),-1)})}function ry(e,t){return W(()=>Td(Mr(Uu(e,-1),Uu(t,-1)),"float32"))}function r4(e,t){return W(()=>oa(e.equal(1),t.equal(1)).sum().cast("float32"))}function hae(e,t){return W(()=>oa(e.equal(1),t.equal(0)).sum().cast("float32"))}function fae(e,t){return W(()=>oa(e.equal(0),t.equal(1)).sum().cast("float32"))}function s4(e,t){return W(()=>{let n=r4(e,t),a=fae(e,t),r=n.add(a);return nn(Mn(r,0),n.div(r),0).cast("float32")})}function mae(e,t){return W(()=>{let n=r4(e,t),a=hae(e,t),r=n.add(a);return nn(Mn(r,0),n.div(r),0).cast("float32")})}function i4(e,t){return Kh(e,t)}function o4(e,t){return e.rank===t.rank&&(e=e.squeeze([e.rank-1])),t=t.argMax(-1),t.dtype!==e.dtype&&(t=t.asType(e.dtype)),Mr(e,t).asType("float32")}var Aae=Mi,yae=Mi,gae=qh,xae=qh,bae=jl,vae=jl,sy=Fd,wae=ty,l4=Xh,Yh={binaryAccuracy:ay,categoricalAccuracy:ry,precision:s4,categoricalCrossentropy:sy,sparseCategoricalCrossentropy:l4,mse:Aae,MSE:yae,mae:gae,MAE:xae,mape:bae,MAPE:vae,cosine:wae};function kae(e){if(typeof e=="string"&&e in Yh)return Yh[e];if(typeof e!="string"&&e!=null)return e;throw new B(`Unknown metric ${e}`)}function Jh(e){if(Va(e!==null,`Unknown LossOrMetricFn ${e}`),typeof e=="string")return e;{let t;for(let n of Object.keys(Zh))if(Zh[n]===e){t=n;break}if(t!==void 0)return t;for(let n of Object.keys(Yh))if(Yh[n]===e){t=n;break}return t!==void 0?t:e.name}}function Iae(e){let t={Adagrad:()=>yi.adagrad(.01),Adadelta:()=>yi.adadelta(1,.95,_t()),Adam:()=>yi.adam(.001,.9,.999,_t()),Adamax:()=>yi.adamax(.002,.9,.999,_t(),0),RMSProp:()=>yi.rmsprop(.001,.9,0,_t()),SGD:()=>yi.sgd(.01)};if(t.adagrad=t.Adagrad,t.adadelta=t.Adadelta,t.adam=t.Adam,t.adamax=t.Adamax,t.rmsprop=t.RMSProp,t.sgd=t.SGD,e in t)return t[e]();throw new B(`Unknown Optimizer ${e}`)}var u4=1*1024*1024;function d4(e,t,n=!1){if(e==null||typeof e!="object"||Object.getPrototypeOf(e)!==Object.prototype||!iy(e))throw new Error("User-defined metadata is expected to be a JSON object, but is not.");if(n){let a=JSON.stringify(e);a.length>u4&&console.warn(`User-defined metadata of model "${t}" is too large in size (length=${a.length} when serialized). It is not recommended to store such large objects in user-defined metadata. Please make sure its serialized length is <= ${u4}.`)}}function iy(e){if(e===null)return!0;if(typeof e=="object")if(Object.getPrototypeOf(e)===Object.prototype){let t=Object.keys(e);for(let n of t)if(typeof n!="string"||!iy(e[n]))return!1;return!0}else if(Array.isArray(e)){for(let t of e)if(!iy(t))return!1;return!0}else return!1;else{let t=typeof e;return t==="string"||t==="number"||t==="boolean"}}function Cae(e,t,n,a=console.log){let r=Nae(e),s=["Layer (type)","Output shape","Param #"];r?(t=t||65,n=n||[.45,.85,1]):(t=t||98,n=n||[.33,.55,.67,1]),n[n.length-1]<=1&&(n=n.map(u=>Math.floor(t*u)));let i;if(!r){s.push("Receives inputs"),i=[];for(let u in e.nodesByDepth)i.push(...e.nodesByDepth[u])}a("_".repeat(t)),Qh(s,n,a),a("=".repeat(t));let o=e.layers;for(let u=0;u1||r.length===1&&r[0].inboundLayers.length>1){t=!1;break}a.push(...r)}if(t)for(let r of e.layers){let s=!1;for(let i of r.inboundNodes)if(a.indexOf(i)!==-1)if(s){t=!1;break}else s=!0;if(!t)break}return t}function Qh(e,t,n=console.log){let a="";for(let r=0;r0&&(a=a.slice(0,a.length-1)+" "),a+=e[r],a=a.slice(0,t[r]),a+=" ".repeat(t[r]-a.length);n(a)}function Tae(e,t,n){let a;try{a=JSON.stringify(e.outputShape)}catch(o){a="multiple"}let r=e.name,s=e.getClassName(),i=[`${r} (${s})`,a,e.countParams().toString()];Qh(i,t,n)}function Eae(e,t,n,a){let r;try{r=JSON.stringify(e.outputShape)}catch(u){r="multiple"}let s=[];for(let u of e.inboundNodes)if(!(n!=null&&n.length>0&&n.indexOf(u)===-1))for(let p=0;pm.name),l=[],d=t.names();for(let m of o)d.indexOf(m)!==-1?l.push(t.getValue(m)):l.push(null);a!=null&&(a.maxNumTensors=-Infinity,a.minNumTensors=Infinity);let u=o.join(",")+"|"+t.names().join(","),p,c;if(uy[u]==null){let m=Mae(i,t);p=m.sorted,c=m.recipientCounts,uy[u]=p,c4[u]=c}p=uy[u],c={},r||Object.assign(c,c4[u]);let h=new Fi(t);for(let m=0;ma.maxNumTensors&&(a.maxNumTensors=R),R0,()=>"Expected at least one fetch, got none");let n=[],a={};if(e.length===1){let r=h4(e[0],t);n=r.sorted,a=r.recipientMap}else{let r=new Set;for(let s of e){let{sorted:i,recipientMap:o}=h4(s,t);for(let l of i)r.has(l.name)||(n.push(l),r.add(l.name));for(let l in o)a[l]==null&&(a[l]=new Set),o[l].forEach(d=>a[l].add(d))}}return{sorted:n,recipientCounts:$ae(a)}}function $ae(e){let t={};for(let n in e)t[n]=e[n].size;return t}function h4(e,t){let n=new Set,a=[],r={};for(let o of t.names())n.add(o);let s=[],i=[];for(s.push(e);s.length>0;){let o=s[s.length-1];if(n.has(o.name)){s.pop();continue}let l=i[i.length-1]===s.length-1;if(o.inputs.length===0||l)s.pop(),a.push(o),n.add(o.name),l&&i.pop();else{i.push(s.length-1);for(let d of o.inputs)r[d.name]==null&&(r[d.name]=new Set),r[d.name].add(o.name),!n.has(d.name)&&s.push(d)}}return{sorted:a,recipientMap:r}}function Fae(e){let t;if(e.sourceLayer.inboundNodes.length===1)t=e.sourceLayer.output;else{let n=null;for(let a=0;ay.name)}`);Br(this.outputs).length!==this.outputs.length&&console.warn(`The list of outputs passed to the model is redundant. All outputs should only appear once. Found: ${this.outputs.map(y=>y.name)}`),this.inputLayers=[],this.inputLayersNodeIndices=[],this.inputLayersTensorIndices=[],this.outputLayers=[],this.outputLayersNodeIndices=[],this.outputLayersTensorIndices=[],this.layers=[],this.internalContainerRefs=[];for(let y of this.outputs){let g=y.sourceLayer,x=y.nodeIndex,w=y.tensorIndex;this.outputLayers.push(g),this.outputLayersNodeIndices.push(x),this.outputLayersTensorIndices.push(w)}for(let y of this.inputs){let g=y.sourceLayer,x=y.nodeIndex,w=y.tensorIndex;Va(x===0,"input layer has >1 nodes"),Va(w===0,"input layer has >1 tensors"),this.inputLayers.push(g),this.inputLayersNodeIndices.push(x),this.inputLayersTensorIndices.push(w)}this.inputNames=[],this.outputNames=[],this.feedInputShapes=[],this.feedInputNames=[],this.feedOutputNames=[];for(let y=0;yy.shape),this.internalOutputShapes=this.outputs.map(y=>y.shape);let t={},n={},a={},r={},s={},i=[],o=(y,g,x,w,b,v)=>{(w==null||b==null||v==null)&&(w=y.sourceLayer,b=y.nodeIndex,v=y.tensorIndex);let N=w.inboundNodes[b];if(x.indexOf(N)!==-1)throw new va(`The tensor ${y.name} at layer "${w.name}" is part of a cycle.`);if(g.indexOf(N)!==-1)return;this.containerNodes.add(Ha.nodeKey(w,b)),w.id in s||(s[w.id]=Object.keys(s).length),x.indexOf(N)===-1&&x.push(N);let T=N.inboundLayers.length;for(let R=0;R=0;)x.splice(x.indexOf(N),1);i.push(N)},l=[],d=[];for(let y of this.outputs)o(y,l,d);let u=i.slice().reverse();for(let y of u){n[y.id]=y,y.id in t||(t[y.id]=0);let g=t[y.id],x=a[y.outboundLayer.id]==null?0:a[y.outboundLayer.id];g=Math.max(g,x),a[y.outboundLayer.id]=g,r[y.outboundLayer.id]=y.outboundLayer,t[y.id]=g;for(let w=0;wparseInt(y,10)).sort(Mh);this.layers=[];for(let y of h){let g=c[y];g.sort((x,w)=>{let b=s[x.id],v=s[w.id];return bv?1:0});for(let x of g)x instanceof Ha&&this.internalContainerRefs.push(x),this.layers.push(x)}this.layersByDepth=c,h=Object.keys(p).map(y=>parseInt(y,10)).sort(Mh);let m=this.inputs.slice(),f=[];for(let y of h)for(let g of p[y]){let x=g.outboundLayer;if(x!=null){for(let w of g.inputTensors)if(m.indexOf(w)===-1)throw new va(`Graph disconnected: cannot obtain value for tensor ${w} at layer "${x.name}". The following previous layers were accessed without issue: ${f}`);for(let w of g.outputTensors)m.push(w);f.push(x.name)}}this.nodesByDepth=p;let A=this.layers.map(y=>y.name);for(let y of A){let g=A.filter(x=>x===y).length;if(g!==1)throw new va(`The name "${y}" is used ${g} times in the model. All layer names should be unique. Layer names: `+JSON.stringify(A))}this.outboundNodes=[],this.inboundNodes=[],new Hh({outboundLayer:this,inboundLayers:[],nodeIndices:[],tensorIndices:[],inputTensors:this.inputs,outputTensors:this.outputs,inputMasks:this.inputs.map(y=>null),outputMasks:this.outputs.map(y=>null),inputShapes:this.inputs.map(y=>y.shape),outputShapes:this.outputs.map(y=>y.shape)}),this.built=!0,this._refCount=1}assertNotDisposed(){if(this._refCount===0)throw new Error(`Container '${this.name}' is already disposed.`)}dispose(){this.assertNotDisposed();let e={refCountAfterDispose:null,numDisposedVariables:0};if(--this._refCount==0){for(let t of this.layers)e.numDisposedVariables+=t.dispose().numDisposedVariables;for(let t of this.internalContainerRefs)e.numDisposedVariables+=t.dispose().numDisposedVariables}return e.refCountAfterDispose=this._refCount,e}get trainable(){return this.trainable_}set trainable(e){this.layers.forEach(t=>{t._trainableWeights.forEach(n=>n.trainable=e)}),this.trainable_=e}get trainableWeights(){if(this._trainableWeights.length>0)throw new B("Container instance unexpectedly contains _trainableWeights.The trainable weights of a Container are a union of the trainable weights of its consituent Layers. Its own _trainableWeights must remain an empty Array.");if(!this.trainable)return[];let e=[];for(let t of this.layers)e=e.concat(t.trainableWeights);return e}get nonTrainableWeights(){let e=[];for(let t of this.layers)e.push(...t.nonTrainableWeights);if(!this.trainable){let t=[];for(let n of this.layers)t.push(...n.trainableWeights);return t.concat(e)}return e}get weights(){return this.trainableWeights.concat(this.nonTrainableWeights)}loadWeights(e,t=!0){let n={},a=0;for(let s of this.layers)for(let i of s.weights){if(n[i.originalName]!=null)throw new B(`Duplicate weight name: ${i.originalName}`);n[i.originalName]=i,a++}let r=[];for(let s in e){let i=s;if(n[s]==null){let o=s.split("/");i=o.slice(0,-2).concat([o[o.length-1]]).join("/")}if(n[i]!=null)r.push([n[i],e[s]]);else if(t)throw new B(`Provided weight data has no target variable: ${s}`);delete n[i]}if(t){let s=[];for(let i in n)s.push(i);if(s.length>0)throw new B(`${s.length} of ${a} weights are not set: ${s}`)}ey(r)}updatedConfig(){let e=this.getConfig(),t={};return t.className=this.getClassName(),t.config=e,t.kerasVersion=`tfjs-layers ${ly}`,t.backend="TensorFlow.js",t}toJSON(e,t=!0){let n=oy(this.updatedConfig());return t?JSON.stringify(n):n}call(e,t){return W(()=>{e=ht(e);let n=new Fi;for(let a=0;a{e=ht(e);let n;return t==null?n=Ni(null,e.length):n=ht(t),this.runInternalGraph(e,n)[1]})}computeOutputShape(e){let t=jh(e);if(t.length!==this.inputLayers.length)throw new B(`Invalid inputShape argument ${e}: model has ${this.inputLayers.length} tensor inputs.`);let n={};for(let i=0;iparseInt(i,10)).sort(Mh);if(a.length>1)for(let i of a){let o=this.nodesByDepth[i];for(let l of o){let d=l.outboundLayer;if(this.inputLayers.map(m=>m.id).indexOf(d.id)!==-1)continue;let u=[];for(let m=0;mparseInt(o,10)).sort(Mh);for(let o of a){let l=this.nodesByDepth[o];for(let d of l){let u=d.outboundLayer,p=d.inputTensors,c=d.outputTensors,h=new Array;for(let m of p)m.id in n&&h.push(n[m.id]);if(h.length===p.length){let m={},f,A,y,g;if(d.callArgs!=null&&(m=d.callArgs),h.length===1){let[x,w]=h[0];m.mask==null&&(m.mask=w),y=ht(u.call(x,m)),g=ht(u.computeMask(x,w)),f=[x],A=[w]}else f=h.map(x=>x[0]),A=h.map(x=>x[1]),m.mask==null&&(m.mask=A),y=ht(u.call(f,m)),g=ht(u.computeMask(f,A));if(u.activityRegularizer)throw new Oe("LayersModel invocation with concrete Tensor value(s) in the presence of activity regularizer(s) is not supported yet.");for(let x=0;x{let e=[];for(let t of this.layers)for(let n=0;n0){let m=[];for(let f=0;f0&&f.apply(Sn(y),g)}function l(f){let A=f.name,y=Sa(f,t.customObjects!=null?t.customObjects:{});y.setFastWeightInitDuringBuild(a),r[A]=y,f.inboundNodes.forEach(g=>{if(!(g instanceof Array))throw new B(`Corrupted configuration, expected array for nodeData: ${g}`);i(y,g)})}let d=t.name,u=t.layers;for(let f of u)l(f);for(;!rte(s);)for(let f of u){let A=r[f.name];if(A.name in s){let y=s[A.name];delete s[A.name];for(let g of y)o(A,g)}}let p=[],c=[],h=t.inputLayers;for(let f of h){let A=f[0],y=f[1],g=f[2];Va(A in r);let x=r[A].inboundNodes[y].outputTensors;p.push(x[g])}let m=t.outputLayers;for(let f of m){let A=f[0],y=f[1],g=f[2];Va(A in r);let x=r[A].inboundNodes[y].outputTensors;c.push(x[g])}return new e({inputs:p,outputs:c,name:d})}get stateful(){if(this._stateful)throw new B("Container instance unexpectedly has _stateful = true. The statefulness of a Container is determined by the Layers it contains. Its _stateful property must remain the default false.");for(let e of this.layers)if(e.stateful)return!0;return!1}resetStates(){W(()=>{this.layers.forEach(e=>{e.stateful&&e.resetStates()})})}};function Dae(e,t,n){let a=t.length;if(e==null||Array.isArray(e)&&e.length===0)return t.map(r=>null);if(a===1)return Array.isArray(e)&&e.length===1?e:typeof e=="object"&&t[0]in e?[e[t[0]]]:[e];if(Array.isArray(e)){if(e.length!==a)throw new Error(`Provided ${n} is an array of ${e.length} element(s), but the model has ${a} outputs. Make sure a set of weights is provided for each model output.`);return e}else if(typeof e=="object"&&Object.keys(e).length>0&&typeof e[Object.keys(e)[0]]=="object"){let r=[];return t.forEach(s=>{s in e?r.push(e[s]):r.push(null)}),r}else throw new Error(`The model has multiple (${a}) outputs, so ${n} must be either an array with ${a} elements or an object with ${t} keys. Provided ${n} not understood: ${JSON.stringify(e)}`)}function f4(e,t){return Dae(e,t,"classWeight")}async function m4(e,t,n,a){if(t!=null||a!=null)throw new Error("Support sampleWeight is not implemented yet");if(n!=null){let r=W(()=>{if(e.shape.length===1)return e.clone();if(e.shape.length===2)if(e.shape[1]>1){let o=1;return e.argMax(o)}else{if(e.shape[1]===1)return e.reshape([e.shape[0]]);throw new Error(`Encountered unexpected last-dimension size (${e.shape[1]}) during handling of class weights. The size is expected to be >= 1.`)}else throw new Error(`Unexpected rank of target (y) tensor (${e.rank}) during handling of class weights. The rank is expected to be 1 or 2.`)}),s=Array.from(await r.data());Ee(r);let i=[];return s.forEach(o=>{if(n[o]==null)throw new Error(`classWeight must contain all classes in the training data. The class ${o} exists in the data but not in classWeight`);i.push(n[o])}),Tt(i,"float32")}else return null}function Oae(e,t){return _(e,t)}var zae=32;function y4(e,t){let n,a,r=t;n=r.xs,a=r.ys,k.assert(n!=null&&a!=null,()=>`A Dataset iterator for fitDataset() is expected to generate objects of the form \`{xs: xVal, ys: yVal}\`, where the two values may be \`tf.Tensor\`, an array of Tensors, or a map of string to Tensor. The provided Dataset instead generates ${t}`);let s=A4("input",e.inputNames,n),i=A4("output",e.outputNames,a),o=s[0].shape[0];k.assert(s.length===e.inputs.length,()=>`LayersModel has ${e.inputs.length} inputs, but the dataset provides ${s.length} inputs. (Expected input keys: ${JSON.stringify(e.inputNames)})`),k.assert(i.length===e.outputs.length,()=>`LayersModel has ${e.outputs.length} outputs, but the dataset provides ${i.length} outputs. (Expected output keys: ${JSON.stringify(e.outputNames)})`);for(let l=0;l`Batch size mismatch: input ${e.inputNames[l]} has ${s[l].shape[0]}; expected ${o} based on input ${e.inputNames[0]}.`);for(let l=0;l`Batch size mismatch: output ${e.outputNames[l]} has ${i[l].shape[0]}; expected ${o} based on input ${e.inputNames[0]}.`);return{xs:s,ys:i}}function A4(e,t,n){if(n instanceof Le)return[n];if(Array.isArray(n))return k.assert(n.length===t.length,()=>`Received an array of ${n.length} Tensors, but expected ${t.length} to match the ${e} keys ${t}.`),n;{let a=[];for(let r of t){if(n[r]==null)throw new B(`The feature data generated by the dataset lacks the required ${e} key '${r}'.`);a.push(n[r])}return a}}function _ae(e){if(e.length===3)throw new Oe("Validation with sample weights is not implemented yet.");return{xs:e[0],ys:e[1]}}async function Lae(e,t,n){let a=n.batchesPerEpoch!=null;if(k.assert(e.optimizer!=null,()=>"You must compile a model before training/testing. Use LayersModel.compile(modelCompileConfig)."),k.assert(n!=null,()=>"For fitDataset(), the 2nd argument (config) is required, but it is not provided in this call."),k.assert(n.epochs!=null&&n.epochs>0&&Number.isInteger(n.epochs),()=>`For fitDataset(), config.epochs is expected to be a positive integer, but got ${n.epochs}`),k.assert(!a||n.batchesPerEpoch>0&&Number.isInteger(n.batchesPerEpoch),()=>`For fitDataset(), config.batchesPerEpoch is expected to be a positive integer if specified, but got ${n.batchesPerEpoch}`),k.assert(n.validationSplit==null,()=>"`validationSplit` is not supported by `fitDataset()`. Use validationData instead."),e.isTraining)throw new Error("Cannot start training because another fit() call is ongoing.");e.isTraining=!0;try{let r=n.validationData!=null,s,i;if(r)if(g4(n.validationData))k.assert(n.validationBatches==null||n.validationBatches>0&&Number.isInteger(n.validationBatches),()=>`For fitDataset() with dataset-based validation, config.validationBatches is expected not to be provided, or to be a positive integer, but got ${n.validationBatches}`);else{let A=_ae(n.validationData);s=A.xs,i=A.ys}let o=e.makeTrainFunction(),l=e.getDedupedMetricsNames(),d;r?d=l.slice().concat(l.map(A=>"val_"+A)):d=l.slice();let u=n4(n.callbacks,n.yieldEvery),p=n.verbose==null?1:n.verbose,{callbackList:c,history:h}=a4(u,p,n.epochs,null,null,Pae(t,n),null,r,d);c.setModel(e),e.history=h,await c.onTrainBegin(),e.stopTraining_=!1;let m=n.initialEpoch==null?0:n.initialEpoch,f=await t.iterator();for(;m=n.batchesPerEpoch:x.done){if(r){let w;g4(n.validationData)?w=ht(await e.evaluateDataset(n.validationData,{batches:n.validationBatches})):w=ht(e.evaluate(s,i,{batchSize:n.validationBatchSize==null?zae:n.validationBatchSize,verbose:0}));for(let b=0;b0)throw new Oe("Verbose mode is not implemented yet.");k.assert(!a||n.batches>0&&Number.isInteger(n.batches),()=>`Test loop expects \`batches\` to be a positive integer, but received ${JSON.stringify(n.batches)}`);let i=Wae(t)?t:await t.iterator(),o=0,l=0;for(;a?l{if(d.value){let{xs:u,ys:p}=y4(e,d.value),c=u.concat(p),h=W(()=>r(c));if(Ee(c),l===0)for(let f=0;fse(s[f],_(m,A))),l>0&&Ee(y)}Ee(h),o+=m,++l}return s}),d.done){a&&console.warn(`Your dataset iterator ran out of data during evaluateDataset(). Interrupting evalution. Make sure that your dataset can generate at least \`batches\` batches (in this case, ${n.batches} batches). You may need to use the repeat() function when building your dataset.`);break}}for(let d=0;d0&&Number.isInteger(e),()=>`batchSize is required to be a positive integer, but got ${e}`)}function Od(e,t,n){return e==null?[null]:Array.isArray(e)?e.map(a=>Ri(a,t,n-t)):Ri(e,t,n-t)}function py(e,t){return W(()=>e==null?null:Array.isArray(e)?e.map(n=>py(n,t)):z6(e,t.dtype==="int32"?t:t.toInt()))}function cy(e,t){let n=[],a=0,r=null;for(;a=e&&(r=e),n.push([a,r]),a=r;return n}async function Vae(e,t,n,a,r,s,i,o,l,d,u,p,c,h,m){r==null&&(r=32),s==null&&(s=1),u==null&&(u=!0),c==null&&(c=0);let f=!1;if(l!=null&&d!=null&&(f=!0),m!=null&&(f=!0,h==null))throw new B("Can only use `validationSteps` when doing step-wise training, i.e., `stepsPerEpoch` must be set.");let A=e.checkNumSamples(n,r,h,"steps_per_epoch"),y;A!=null&&(y=wa(0,A)),i==null&&(i=1);let{callbackList:g,history:x}=a4(o,i,s,c,A,h,r,f,p);g.setModel(e),e.history=x,await g.onTrainBegin(),e.stopTraining_=!1;for(let w=c;w{let $=N[T][0],z=N[T][1],P=Ri(v,$,z-$);R.batch=T,R.size=z-$;let V=py(n,P),j=t(V);for(let U=0;U0){if(m=!0,a.validationData.length===2)i=a.validationData[0],o=a.validationData[1];else throw a.validationData.length===3?new Oe("validationData including sample weights is not supported yet."):new B(`When passing validation data, it must contain 2 (valX, valY) or 3 (valX, valY, valSampleWeight) items; ${a.validationData} is invalid.`);let v=!0,N=await e.standardizeUserData(i,o,null,null,v,p);l=N[0],d=N[1],f=l.concat(d)}else if(a.validationSplit!=null&&a.validationSplit>0&&a.validationSplit<1){m=!0;let v=Math.floor(r[0].shape[0]*(1-a.validationSplit)),N=r[0].shape[0];l=Od(r,v,N),r=Od(r,0,v),d=Od(s,v,N),s=Od(s,0,v),f=l.concat(d)}else a.validationSteps!=null&&(m=!0);let A=r.concat(s).concat(u);e.checkTrainableWeightsConsistency();let y=e.makeTrainFunction(),g=e.getDedupedMetricsNames(),x,w;m?(e.makeTestFunction(),x=e.testFunction,w=g.slice().concat(g.map(v=>"val_"+v))):(x=null,f=[],w=g.slice());let b=n4(a.callbacks,a.yieldEvery);return await Vae(e,y,A,g,p,a.epochs,a.verbose,b,x,f,a.shuffle,w,a.initialEpoch,null,null)}finally{e.isTraining=!1,$i(r,t),$i(s,n),$i(l,i),$i(d,o),u!=null&&Ee(u)}}function x4(e){let t=[];e instanceof Le&&(e=[e]);for(let n=0;nn.push(r.id));else if(t!=null)for(let r in t){let s=t[r];n.push(s.id)}let a=[];if(e instanceof Le)n.indexOf(e.id)===-1&&a.push(e);else if(Array.isArray(e))e.forEach(r=>{n.indexOf(r.id)===-1&&a.push(r)});else if(e!=null)for(let r in e){let s=e[r];n.indexOf(s.id)===-1&&a.push(s)}a.forEach(r=>{r.isDisposed||r.dispose()})}function Uae(e){return e instanceof Le}function hy(e){return Array.isArray(e)}function b4(e){return!Uae(e)&&!hy(e)}function v4(e,t,n,a=!0,r=""){if(t==null||t.length===0){if(e!=null){let i=!1;if(hy(e)&&e.length>0)i=!0;else if(b4(e)){for(let o in e)if(e.hasOwnProperty(o)){i=!0;break}}else i=!0;if(i)throw new B(`Error when checking model ${r} expected no data, but got ${e}`)}return[]}if(e==null)return t.map(i=>null);let s;if(b4(e)){e=e,s=[];for(let i of t){if(e[i]==null)throw new B(`No data provided for "${i}". Need data for each key in: ${t}`);s.push(e[i])}}else if(hy(e)){if(e=e,e.length!==t.length)throw new B(`Error when checking model ${r}: the Array of Tensors that you are passing to your model is not the size the model expected. Expected to see ${t.length} Tensor(s), but instead got the following list of Tensor(s): ${e}`);s=e}else{if(e=e,t.length>1)throw new B(`The model ${r} expects ${t.length} Tensor(s), but only received one Tensor. Found: Tensor with shape ${e.shape}`);s=[e]}if(s=x4(s),n!=null)for(let i=0;i=0&&d!==u)throw new B(`Error when checking ${r}: expected ${t[i]} to have shape [${n[i]}], but got array with shape [${o.shape}].`)}}return s}function Hae(e,t,n){let a=Br(e.map(s=>s.shape[0]));a.sort();let r=Br(t.map(s=>s.shape[0]));if(r.sort(),a.length>1)throw new B(`All input Tensors (x) should have the same number of samples. Got array shapes: ${JSON.stringify(e.map(s=>s.shape))}`);if(r.length>1)throw new B(`All target Tensors (y) should have the same number of samples. Got array shapes: ${JSON.stringify(t.map(s=>s.shape))}`);if(a.length>0&&r.length>0&&!k.arraysEqual(a,r))throw new B(`Input Tensors should have the same number of samples as target Tensors. Found ${a[0]} input sample(s) and ${r[0]} target sample(s).`)}function Gae(e,t,n){let a=[Mi,Kh,Fd];for(let r=0;r1)throw new B(`The model expects ${t.length} ${r} Tensors, but only received one Tensor. Found: array with shape ${JSON.stringify(e.shape)}.`);s=[e]}if(n!=null)for(let i=0;i[]);let n;if(typeof e=="string"||typeof e=="function")n=[e];else if(Array.isArray(e)||typeof e=="object")n=e;else throw new TypeError(`Type of metrics argument not understood. Expected an string,function, Array, or Object, found: ${e}`);if(Array.isArray(n))return t.map(a=>n);{let a=[];for(let r of t){let s=n.hasOwnProperty(r)?n[r]:[];Array.isArray(s)||(s=[s]),a.push(s)}return a}}var Xae="layers-model",dr=class extends Ha{constructor(e){super(e);this.isTraining=!1}summary(e,t,n=console.log){if(!this.built)throw new B("This model has never been called, thus its weights have not been created yet. So no summary can be displayed. Build the model first (e.g., by calling it on some test data).");Cae(this,e,t,n)}compile(e){if(e.loss==null&&(e.loss=[]),this.loss=e.loss,typeof e.optimizer=="string")this.optimizer_=Iae(e.optimizer),this.isOptimizerOwned=!0;else{if(!(e.optimizer instanceof ir))throw new B("User-defined optimizer must be an instance of tf.Optimizer.");this.optimizer_=e.optimizer,this.isOptimizerOwned=!1}let t=[];if(!Array.isArray(e.loss)&&typeof e.loss!="string"&&typeof e.loss!="function"){e.loss=e.loss;for(let s in e.loss)if(this.outputNames.indexOf(s)===-1)throw new B(`Unknown entry in loss dictionary: "${s}". Only expected the following keys: ${this.outputNames}`);for(let s of this.outputNames)e.loss[s]==null&&console.warn(`Output "${s}" is missing from loss dictionary. We assume this was done on purpose, and we will not be expecting data to be passed to ${s} during training`),t.push(ny(e.loss[s]))}else if(Array.isArray(e.loss)){if(e.loss.length!==this.outputs.length)throw new B(`When passing an Array as loss, it should have one entry per model output. The model has ${this.outputs.length} output(s), but you passed loss=${e.loss}.`);t=e.loss.map(s=>ny(s))}else{let s=ny(e.loss);this.outputs.forEach(i=>{t.push(s)})}this.lossFunctions=t,this.feedOutputNames=[],this.feedOutputShapes=[],this.feedLossFns=[];for(let s=0;s{for(let s=0;s1&&(this.metricsTensors.push([i,s]),this.metricsNames.push(this.outputNames[s]+"_loss"))}});let a=qae(e.metrics,this.outputNames),r=(s,i,o)=>{this.outputNames.length>1&&(i=this.outputNames[s]+"_"+i),this.metricsNames.push(i),this.metricsTensors.push([o,s])};Ci("metric",()=>{for(let s=0;s{let l="",d,u,p;for(let c of o){if(typeof c=="string"&&["accuracy","acc","crossentropy","ce"].indexOf(c)!==-1){let m=this.internalOutputShapes[s];m[m.length-1]===1||this.lossFunctions[s]===Kh?["accuracy","acc"].indexOf(c)!==-1?u=ay:["crossentropy","ce"].indexOf(c)!==-1&&(u=i4):this.lossFunctions[s]===Xh?["accuracy","acc"].indexOf(c)!==-1?u=o4:["crossentropy","ce"].indexOf(c)!==-1&&(u=l4):["accuracy","acc"].indexOf(c)!==-1?u=ry:["crossentropy","ce"].indexOf(c)!==-1&&(u=sy);let f;["accuracy","acc"].indexOf(c)!==-1?f="acc":["crossentropy","ce"].indexOf(c)!==-1&&(f="ce"),p=u,d=l+f}else p=kae(c),d=l+Jh(c);let h;Ci(d,()=>{h=p}),r(s,d,h)}})(i)}}),this.collectedTrainableWeights=this.trainableWeights}checkTrainableWeightsConsistency(){this.collectedTrainableWeights!=null&&this.trainableWeights.length!==this.collectedTrainableWeights.length&&console.warn("Discrepancy between trainableweights and collected trainable weights. Did you set `model.trainable` without calling `model.compile()` afterwards?")}evaluate(e,t,n={}){let a=n.batchSize==null?32:n.batchSize;dy(a);let r=!0,s=this.standardizeUserDataXY(e,t,r,a);try{let i=s[0].concat(s[1]);this.makeTestFunction();let o=this.testFunction,l=this.testLoop(o,i,a,n.verbose,n.steps);return Sn(l)}finally{$i(s[0],e),$i(s[1],t)}}async evaluateDataset(e,t){return this.makeTestFunction(),Bae(this,e,t)}checkNumSamples(e,t,n,a="steps"){let r;if(n!=null){if(r=null,t!=null)throw new B(`If ${a} is set, batchSize must be null or undefined.Got batchSize = ${t}`)}else if(e!=null)Array.isArray(e)?r=e[0].shape[0]:r=e.shape[0];else throw new B(`Either the input data should have a defined shape, or ${a} shoud be specified.`);return r}execute(e,t){if(Array.isArray(t)&&t.length===0)throw new B("`outputs` is an empty Array, which is not allowed.");let n=Array.isArray(t),a=n?t:[t],r=this.retrieveSymbolicTensors(a),s=new Fi;if(e instanceof Le&&(e=[e]),Array.isArray(e)){if(e.length!==this.inputs.length)throw new B(`The number of inputs provided (${e.length}) does not match the number of inputs of this model (${this.inputs.length}).`);for(let o=0;oi.name);for(let i=0;i0){let a=[];throw t.forEach((r,s)=>{r==null&&a.push(e[s])}),new B(`Cannot find SymbolicTensors for output name(s): ${JSON.stringify(a)}`)}return t}predictLoop(e,t=32,n=!1){return W(()=>{let a=this.checkNumSamples(e);if(n)throw new Oe("Verbose predictLoop() is not implemented yet.");let r=cy(a,t),s=this.outputs.map(i=>[]);for(let i=0;i{let o=r[i][0],l=r[i][1],d=Od(e,o,l),u=[];if(Array.isArray(d))for(let c=0;cs[l].push(o));return Sn(s.map(i=>ot(i,0)))})}predict(e,t={}){let n=x4(e);w4(n,this.inputNames,this.feedInputShapes,!1);try{let a=t.batchSize==null?32:t.batchSize;return dy(a),this.predictLoop(n,a)}finally{$i(n,e)}}predictOnBatch(e){w4(e,this.inputNames,this.feedInputShapes,!0);let t=(Array.isArray(e)?e[0]:e).shape[0];return this.predictLoop(e,t)}standardizeUserDataXY(e,t,n=!0,a){if(this.optimizer_==null)throw new va("You must compile a model before training/testing. Use LayersModel.compile(modelCompileArgs).");let r=[];for(let s=0;s0&&e[0].shape[0]%a!=0)throw new B(`In a stateful network, you should only pass inputs with a number of samples that is divisible by the batch size ${a}. Found: ${e[0].shape[0]} sample(s).`);return[e,t]}async standardizeUserData(e,t,n,a,r=!0,s){let[i,o]=this.standardizeUserDataXY(e,t,r,s);if(n!=null)throw new Error("sample weight is not supported yet.");let l=null;if(a!=null){let d=f4(a,this.outputNames);l=[];for(let u=0;u{let s=this.checkNumSamples(t,n,r,"steps"),i=[];if(a>0)throw new Oe("Verbose mode is not implemented yet.");if(r!=null)throw new Oe("steps mode in testLoop() is not implemented yet");{let o=cy(s,n),l=Tt(wa(0,s));for(let d=0;d1&&(r+=`_${k6(e.slice(0,n),a)}`),t.push(r)}return t}makeTrainFunction(){return e=>{let t=[],n=e.slice(0,this.inputs.length),a=e.slice(this.inputs.length,this.inputs.length+this.outputs.length),r=e.slice(this.inputs.length+this.outputs.length,this.inputs.length+this.outputs.length*2),s=[],i=()=>{let d=[];for(let h=0;h1&&h{c=se(c,h)}),c},o=this.collectedTrainableWeights.map(d=>d.read()),l=!0;return[this.optimizer_.minimize(i,l,o)].concat(s)}}makeTestFunction(){this.testFunction=e=>W(()=>{let t=[],n,a=e.slice(0,this.inputs.length),r=e.slice(this.inputs.length,this.inputs.length+this.outputs.length),s=[];for(let l=0;lur(t))}else{let t=Object.keys(this.loss);e={};let n=this.loss;for(let a of t)if(typeof n[a]=="string")e[a]=ur(n[a]);else throw new Error("Serialization of non-string loss is not supported.")}return e}getMetricIdentifiers(){if(typeof this.metrics=="string"||typeof this.metrics=="function")return[ur(Jh(this.metrics))];if(Array.isArray(this.metrics))return this.metrics.map(e=>ur(Jh(e)));{let e={};for(let t in this.metrics)e[t]=ur(Jh(this.metrics[t]));return e}}getTrainingConfig(){return{loss:this.getLossIdentifiers(),metrics:this.getMetricIdentifiers(),optimizer_config:{class_name:this.optimizer.getClassName(),config:this.optimizer.getConfig()}}}loadTrainingConfig(e){if(e.weighted_metrics!=null)throw new Error("Loading weight_metrics is not supported yet.");if(e.loss_weights!=null)throw new Error("Loading loss_weights is not supported yet.");if(e.sample_weight_mode!=null)throw new Error("Loading sample_weight_mode is not supported yet.");let t=$d(e.optimizer_config),n=Sa(t),a;if(typeof e.loss=="string")a=Ti(e.loss);else if(Array.isArray(e.loss))a=e.loss.map(s=>Ti(s));else if(e.loss!=null){a={};for(let s in e.loss)a[s]=Ti(e.loss[s])}let r;if(Array.isArray(e.metrics))r=e.metrics.map(s=>Ti(s));else if(e.metrics!=null){r={};for(let s in e.metrics)r[s]=Ti(e.metrics[s])}this.compile({loss:a,metrics:r,optimizer:n})}async save(e,t){if(typeof e=="string"){let i=vn.getSaveHandlers(e);if(i.length===0)throw new B(`Cannot find any save handlers for URL '${e}'`);if(i.length>1)throw new B(`Found more than one (${i.length}) save handlers for URL '${e}'`);e=i[0]}if(e.save==null)throw new B("LayersModel.save() cannot proceed because the IOHandler provided does not have the `save` attribute defined.");let n=await vn.encodeWeights(this.getNamedWeights(t)),a=!1,r=null,s={modelTopology:this.toJSON(r,a),format:Xae,generatedBy:`TensorFlow.js tfjs-layers v${ly}`,convertedBy:null};if((t==null?!1:t.includeOptimizer)&&this.optimizer!=null){s.trainingConfig=this.getTrainingConfig();let i="optimizer",{data:o,specs:l}=await vn.encodeWeights(await this.optimizer.getWeights(),i);n.specs.push(...l),n.data=vn.concatenateArrayBuffers([n.data,o])}if(this.userDefinedMetadata!=null){let i=!0;d4(this.userDefinedMetadata,this.name,i),s.userDefinedMetadata=this.userDefinedMetadata}return s.weightData=n.data,s.weightSpecs=n.specs,e.save(s)}setUserDefinedMetadata(e){d4(e,this.name),this.userDefinedMetadata=e}getUserDefinedMetadata(){return this.userDefinedMetadata}};dr.className="Model";ae.registerClass(dr);var k4=class extends dr{};k4.className="Functional";ae.registerClass(k4);async function Kae(e,t){"modelTopology"in e||(e={modelTopology:e}),e=e;let n=e.modelTopology;n.model_config!=null&&(n=n.model_config);let a=$d(n),r=Sa(a,t);if(e.weightsManifest!=null){let s=await vn.loadWeights(e.weightsManifest,e.pathPrefix,r.weights.map(o=>o.originalName)),i={};for(let o of r.weights)i[o.originalName]=s[o.originalName];r.loadWeights(i),Ee(s)}return r}async function Yae(e,t){if(t==null&&(t={}),typeof e=="string"){let n=vn.getLoadHandlers(e,t);if(n.length===0)n.push(vn.browserHTTPRequest(e,t));else if(n.length>1)throw new B(`Found more than one (${n.length}) load handlers for URL '${e}'`);e=n[0]}return Zae(e,void 0,t)}async function Zae(e,t,n){if(n==null&&(n={}),e.load==null)throw new B("Cannot proceed with model loading because the IOHandler provided does not have the `load` method implemented.");let a=await e.load(),r=a.modelTopology;r.model_config!=null&&(r=r.model_config);let s=n.strict==null?!0:n.strict,i=a.weightData!=null&&a.weightSpecs!=null&&s,o=Sa($d(r),t,i),l=a.trainingConfig;if(l!=null&&o.loadTrainingConfig(l),a.userDefinedMetadata!=null&&o.setUserDefinedMetadata(a.userDefinedMetadata),a.weightData!=null){if(a.weightSpecs==null)throw new B("LayersModel artifacts contains weight data, but not weight specs. Therefore loading of weights cannot proceed.");let{modelWeights:d,optimizerWeights:u}=Jae(a.weightData,a.weightSpecs);o.loadWeights(d,s),o.optimizer!=null&&u.length>0&&await o.optimizer.setWeights(u),Ee(d),Ee(u.map(p=>p.tensor))}return o}function Jae(e,t){let n=vn.decodeWeights(e,t),a={},r=[];return t.forEach(s=>{s.group==="optimizer"?r.push({name:s.name,tensor:n[s.name]}):a[s.name]=n[s.name]}),{modelWeights:a,optimizerWeights:r}}var Ul=class extends dr{constructor(e){super({inputs:[],outputs:[]});if(e=e||{},this.trainable=!0,this.built=!1,this.name=e.name!=null?e.name:Vh("sequential_"),e.layers!=null)for(let t of e.layers)this.add(t)}checkShape(e){if(e.inboundNodes[0].outputTensors[0].shape.some(t=>t<0))throw new B(`Negative dimension size caused by adding layer ${e.name} with input shape [${e.inboundNodes[0].inputTensors[0].shape}]`)}add(e){let t=e instanceof Ul||e instanceof dr,n;if(t){if(n=e,n.outputs.length!==1)throw new B("All layers in a Sequential model should have a single output tensor. For multi-output layers, use the functional API.");if(n.inputs.length!==1)throw new B("All layers in a Sequential model should have a single input tensor. For multi-input layers, use the functional API.")}if(this.outputs.length===0){if(e.inboundNodes.length===0){if(e.batchInputShape==null)throw new B("The first layer in a Sequential model must get an `inputShape` or `batchInputShape` argument.");let a=Z6({batchShape:e.batchInputShape,dtype:e.dtype,name:e.name+"_input"});e.apply(a)}if(t)this.outputs=n.outputs,this.inputs=n.inputs;else{if(e.inboundNodes.length!==1)throw new B(`A layer added to a Sequential model must not already be connected somewhere else. LayersModel received layer ${e.name} which has ${e.inboundNodes.length} pre-existing inbound connections.`);if(e.inboundNodes[0].outputTensors.length!==1)throw new B("All layers in a Sequential model should have a single output tensor. For multi-output layers, use the functional API.");this.checkShape(e),this.outputs=[e.inboundNodes[0].outputTensors[0]],this.inputs=K6(this.outputs[0])}this.inboundNodes=[],new Hh({outboundLayer:this,inboundLayers:[],nodeIndices:[],tensorIndices:[],inputTensors:this.inputs,outputTensors:this.outputs,inputMasks:Ni(null,this.inputs.length),outputMasks:[null],inputShapes:this.inputs.map(a=>a.shape),outputShapes:this.outputs[0].shape})}else{let a=e.apply(this.outputs[0]);if(Array.isArray(a))throw new TypeError("All layers in a Sequential model should have a single output tensor. For multi-output layers, use the functional API.");this.checkShape(e),this.outputs=[a],this.inboundNodes[0].outputTensors=this.outputs,this.inboundNodes[0].outputShapes=[this.outputs[0].shape]}this.layers.push(e),this.built=!1}pop(){if(this.layers.length===0)throw new TypeError("There are no layers in the model.");if(this.layers.pop(),this.layers.length===0)this.outputs=[],this.inboundNodes=[],this.outboundNodes=[];else{let e=this.layers.length-1;this.layers[e].outboundNodes=[],this.outputs=[this.layers[e].output],this.inboundNodes[0].outputTensors=this.outputs,this.inboundNodes[0].outputShapes=[this.outputs[0].shape]}}call(e,t){return this.model==null&&this.build(),this.model.call(e,t)}build(e){if(at(e),this.inputs.length===0||this.outputs.length===0)throw new TypeError("Sequential model cannot be built: model is empty. Add some layers first.");this.model=new dr({inputs:this.inputs,outputs:this.outputs[0],name:this.name+"_model"}),this.model.trainable=this.trainable,this.supportsMasking=this.model.supportsMasking,this.inputLayers=this.model.inputLayers,this.inputLayersNodeIndices=this.model.inputLayersNodeIndices,this.inputLayersTensorIndices=this.model.inputLayersTensorIndices,this.outputLayers=this.model.outputLayers,this.outputLayersNodeIndices=this.model.outputLayersNodeIndices,this.outputLayersTensorIndices=this.model.outputLayersTensorIndices,this.nodesByDepth=this.model.nodesByDepth,this.containerNodes=this.model.containerNodes,this.outputNames=this.model.outputNames,this.inputNames=this.model.inputNames,this.built=!0}countParams(){return this.built||this.build(),super.countParams()}summary(e,t,n=console.log){this.built||this.build(),super.summary(e,t,n)}setWeights(e){this.model==null&&this.build(),this.model.setWeights(e)}evaluate(e,t,n={}){if(!this.built)throw new va("The model needs to be compiled before being used.");return this.model.evaluate(e,t,n)}async evaluateDataset(e,t){if(!this.built)throw new va("The model needs to be compiled before being used.");return this.model.evaluateDataset(e,t)}predict(e,t={}){return this.model==null&&this.build(),this.model.predict(e,t)}predictOnBatch(e){return this.model==null&&this.build(),this.model.predictOnBatch(e)}compile(e){this.build(),this.model.compile(e),this.optimizer_=this.model.optimizer,this.isOptimizerOwned=this.model.isOptimizerOwned,this.loss=this.model.loss,this.metrics=this.model.metrics,this.metricsTensors=this.model.metricsTensors,this.metricsNames=this.model.metricsNames}get optimizer(){return this.model==null?void 0:this.model.optimizer}set optimizer(e){this.model.optimizer=e}async fit(e,t,n={}){if(!this.built)throw new va("The model needs to be compiled before being used.");return this.model.fit(e,t,n)}async fitDataset(e,t){if(!this.built)throw new va("The model needs to be compiled before being used.");return this.model.fitDataset(e,t)}async trainOnBatch(e,t){return this.model.trainOnBatch(e,t)}static fromConfig(e,t,n={},a=!1){let r,s={};if(t instanceof Array){if(t[0].className==null||t[0].className==="Merge")throw new B("Legacy serialization format not supported yet.");r=t}else k.assert(t.layers!=null,()=>"When the config data for a Sequential model is not an Array, it must be an Object that contains the 'layers' field."),r=t.layers,delete t.layers,s=t;let i=new e(s);if(!(i instanceof Ul))throw new Oe(`Sequential.fromConfig called on non-Sequential input: ${i}`);for(let o of r){let l=Sa(o,void 0,a);a&&l.setFastWeightInitDuringBuild(!0),i.add(l)}return i}set stopTraining(e){if(this.model==null)throw new B("Cannot set the stopTraining property of a sequential model before it is compiled.");this.model.stopTraining=e}get stopTraining(){if(this.model==null)throw new B("Cannot get the stopTraining property of a sequential model before it is compiled.");return this.model.stopTraining}getConfig(){let e=[];for(let t of this.layers){let n={};n.className=t.getClassName(),n.config=t.getConfig(),e.push(n)}return{name:this.name,layers:e}}};Ul.className="Sequential";ae.registerClass(Ul);function Qae(e){return new dr(e)}function ere(e){return new Ul(e)}function tre(e,t){return t==null&&(t={}),Yae(e,t)}function B6(e){return Z6(e)}function nre(e,t){pa.registerCallbackConstructor(e,t)}var Tn=class extends ae.Serializable{getConfig(){return{}}},I4=class extends Tn{apply(e,t=1){return $te(e,t)}};I4.className="elu";ae.registerClass(I4);var S4=class extends Tn{apply(e){return Oc(e)}};S4.className="selu";ae.registerClass(S4);var N4=class extends Tn{apply(e){return Pa(e)}};N4.className="relu";ae.registerClass(N4);var T4=class extends Tn{apply(e){return W(()=>gl(6,Pa(e)))}};T4.className="relu6";ae.registerClass(T4);var E4=class extends Tn{apply(e){return e}};E4.className="linear";ae.registerClass(E4);var C4=class extends Tn{apply(e){return wn(e)}};C4.className="sigmoid";ae.registerClass(C4);var R4=class extends Tn{apply(e){return Ote(e)}};R4.className="hardSigmoid";ae.registerClass(R4);var M4=class extends Tn{apply(e){return hi(e)}};M4.className="softplus";ae.registerClass(M4);var F4=class extends Tn{apply(e){return Dte(e)}};F4.className="softsign";ae.registerClass(F4);var $4=class extends Tn{apply(e){return di(e)}};$4.className="tanh";ae.registerClass($4);var fy=class extends Tn{apply(e,t=-1){return nd(e,t)}};fy.className="softmax";ae.registerClass(fy);var D4=class extends Tn{apply(e,t=-1){return Ec(e,t)}};D4.className="logSoftmax";ae.registerClass(D4);var O4=class extends Tn{apply(e,t=1){return W(()=>wn(e.mul(t)).mul(e))}};O4.className="swish";ae.registerClass(O4);var z4=class extends Tn{apply(e){return W(()=>_(e,di(hi(e))))}};z4.className="mish";ae.registerClass(z4);function Hr(e){return e.getClassName()}function my(e,t={}){return Id(e,ae.SerializationMap.getMap().classNameMap,t,"activation")}function Gr(e){if(e==null){let t={};return t.className="linear",t.config={},my(t)}if(typeof e=="string"){let t={};return t.className=e,t.config={},my(t)}else return e instanceof Tn?e:my(e)}function Ay(e){if(e!=null&&typeof e!="object")throw new Error(`Argument to L1L2 regularizer's constructor is expected to be an object, but received: ${e}`)}var _4=class extends ae.Serializable{},zd=class extends _4{constructor(e){super();Ay(e),this.l1=e==null||e.l1==null?.01:e.l1,this.l2=e==null||e.l2==null?.01:e.l2,this.hasL1=this.l1!==0,this.hasL2=this.l2!==0}apply(e){return W(()=>{let t=Ct([1]);return this.hasL1&&(t=se(t,ke(_(this.l1,Ot(e))))),this.hasL2&&(t=se(t,ke(_(this.l2,Cd(e))))),t.asScalar()})}getConfig(){return{l1:this.l1,l2:this.l2}}static fromConfig(e,t){return new e({l1:t.l1,l2:t.l2})}};zd.className="L1L2";ae.registerClass(zd);function are(e){return Ay(e),new zd({l1:e!=null?e.l1:null,l2:0})}function rre(e){return Ay(e),new zd({l2:e!=null?e.l2:null,l1:0})}var P4={l1l2:"L1L2"};function ut(e){return R1(e)}function L4(e,t={}){return Id(e,ae.SerializationMap.getMap().classNameMap,t,"regularizer")}function At(e){if(e==null)return null;if(typeof e=="string"){let t={className:e in P4?P4[e]:e,config:{}};return L4(t)}else return e instanceof _4?e:L4(e)}var yy=class extends Ge{constructor(e){super(e==null?{}:e);this.supportsMasking=!0,e!=null&&(this.maxValue=e.maxValue)}call(e,t){e=_e(e);let n=Pa(e);return this.maxValue!=null&&(n=kn(n,0,this.maxValue)),n}computeOutputShape(e){return e}getConfig(){let e={maxValue:this.maxValue},t=super.getConfig();return Object.assign(e,t),e}};yy.className="ReLU";ae.registerClass(yy);var gy=class extends Ge{constructor(e){super(e==null?{}:e);this.DEFAULT_ALPHA=.3,e==null&&(e={}),this.alpha=e.alpha==null?this.DEFAULT_ALPHA:e.alpha}call(e,t){let n=_e(e);return Ku(n,this.alpha)}computeOutputShape(e){return e}getConfig(){let e={alpha:this.alpha},t=super.getConfig();return Object.assign(e,t),e}};gy.className="LeakyReLU";ae.registerClass(gy);var xy=class extends Ge{constructor(e){super(e==null?{}:e);if(this.DEFAULT_ALPHA_INITIALIZER="zeros",e==null&&(e={}),this.supportsMasking=!0,this.alphaInitializer=mt(e.alphaInitializer||this.DEFAULT_ALPHA_INITIALIZER),this.alphaRegularizer=At(e.alphaRegularizer),this.alphaConstraint=Lt(e.alphaConstraint),e.sharedAxes==null)this.sharedAxes=null;else if(Array.isArray(e.sharedAxes))this.sharedAxes=e.sharedAxes;else if(typeof e.sharedAxes=="number")this.sharedAxes=[e.sharedAxes];else throw new B(`Expected sharedAxes to be a number or an array of numbers, but got ${e.sharedAxes}`)}build(e){e=at(e);let t=e.slice(1);if(this.sharedAxes!=null)for(let a of this.sharedAxes)t[a-1]=1;this.alpha=this.addWeight("alpha",t,"float32",this.alphaInitializer,this.alphaRegularizer,!0,this.alphaConstraint);let n={};if(this.sharedAxes!=null)for(let a=1;a(Et(t),t==="channelsFirst"?Ze(e,[0,2,3,1]):e))}function W4(e,t){return W(()=>(Et(t),t==="channelsFirst"?Ze(e,[0,2,3,4,1]):e))}function sre(e,t,n,a=1,r="valid",s,i=1){return W(()=>{if(s==null&&(s=ba()),Et(s),e.shape.length!==3)throw new B(`The input of a conv1dWithBias operation should be 3, but is ${e.shape.length} instead.`);if(t.shape.length!==3)throw new B(`The kernel for a conv1dWithBias operation should be 3, but is ${t.shape.length} instead`);if(n!=null&&n.shape.length!==1)throw new B(`The bias for a conv1dWithBias operation should be 1, but is ${t.shape.length} instead`);if(s==="channelsFirst"&&(e=Ze(e,[0,2,1])),r==="causal")throw new Oe("The support for CAUSAL padding mode in conv1dWithBias is not implemented yet.");let o=bc(e,t,a,r==="same"?"same":"valid","NWC",i);return n!=null&&(o=ka(o,n)),o})}function B4(e,t,n,a=[1,1],r="valid",s,i,o=null){return W(()=>{if(s==null&&(s=ba()),Et(s),e.rank!==3&&e.rank!==4)throw new B(`conv2dWithBiasActivation expects input to be of rank 3 or 4, but received ${e.rank}.`);if(t.rank!==3&&t.rank!==4)throw new B(`conv2dWithBiasActivation expects kernel to be of rank 3 or 4, but received ${e.rank}.`);let l=ky(e,s);if(r==="causal")throw new Oe("The support for CAUSAL padding mode in conv1dWithBias is not implemented yet.");return l=zr.conv2d({x:l,filter:t,strides:a,pad:r==="same"?"same":"valid",dilations:i,dataFormat:"NHWC",bias:n,activation:o}),s==="channelsFirst"&&(l=Ze(l,[0,3,1,2])),l})}function ire(e,t,n,a=[1,1,1],r="valid",s,i){return W(()=>{if(s==null&&(s=ba()),Et(s),e.rank!==4&&e.rank!==5)throw new B(`conv3dWithBias expects input to be of rank 4 or 5, but received ${e.rank}.`);if(t.rank!==4&&t.rank!==5)throw new B(`conv3dWithBias expects kernel to be of rank 4 or 5, but received ${e.rank}.`);let o=W4(e,s);if(r==="causal")throw new Oe("The support for CAUSAL padding mode in conv3dWithBias is not implemented yet.");return o=pA(o,t,a,r==="same"?"same":"valid","NDHWC",i),n!=null&&(o=ka(o,n)),s==="channelsFirst"&&(o=Ze(o,[0,4,1,2,3])),o})}var Iy=class extends Ge{constructor(e,t){super(t);if(this.bias=null,this.DEFAULT_KERNEL_INITIALIZER="glorotNormal",this.DEFAULT_BIAS_INITIALIZER="zeros",Iy.verifyArgs(t),this.rank=e,Ht(this.rank,"rank"),this.rank!==1&&this.rank!==2&&this.rank!==3)throw new Oe(`Convolution layer for rank other than 1, 2, or 3 (${this.rank}) is not implemented yet.`);if(this.kernelSize=Hl(t.kernelSize,e,"kernelSize"),this.strides=Hl(t.strides==null?1:t.strides,e,"strides"),this.padding=t.padding==null?"valid":t.padding,Jn(this.padding),this.dataFormat=t.dataFormat==null?"channelsLast":t.dataFormat,Et(this.dataFormat),this.activation=Gr(t.activation),this.useBias=t.useBias==null?!0:t.useBias,this.biasInitializer=mt(t.biasInitializer||this.DEFAULT_BIAS_INITIALIZER),this.biasConstraint=Lt(t.biasConstraint),this.biasRegularizer=At(t.biasRegularizer),this.activityRegularizer=At(t.activityRegularizer),this.dilationRate=Hl(t.dilationRate==null?1:t.dilationRate,e,"dilationRate"),this.rank===1&&Array.isArray(this.dilationRate)&&this.dilationRate.length!==1)throw new B(`dilationRate must be a number or an array of a single number for 1D convolution, but received ${JSON.stringify(this.dilationRate)}`);if(this.rank===2){if(typeof this.dilationRate=="number")this.dilationRate=[this.dilationRate,this.dilationRate];else if(this.dilationRate.length!==2)throw new B(`dilationRate must be a number or array of two numbers for 2D convolution, but received ${JSON.stringify(this.dilationRate)}`)}else if(this.rank===3){if(typeof this.dilationRate=="number")this.dilationRate=[this.dilationRate,this.dilationRate,this.dilationRate];else if(this.dilationRate.length!==3)throw new B(`dilationRate must be a number or array of three numbers for 3D convolution, but received ${JSON.stringify(this.dilationRate)}`)}}static verifyArgs(e){if(Va("kernelSize"in e,"required key 'kernelSize' not in config"),typeof e.kernelSize!="number"&&!F1(e.kernelSize,"number",1,3))throw new B(`BaseConv expects config.kernelSize to be number or number[] with length 1, 2, or 3, but received ${JSON.stringify(e.kernelSize)}.`)}getConfig(){let e={kernelSize:this.kernelSize,strides:this.strides,padding:this.padding,dataFormat:this.dataFormat,dilationRate:this.dilationRate,activation:Hr(this.activation),useBias:this.useBias,biasInitializer:kt(this.biasInitializer),biasRegularizer:ut(this.biasRegularizer),activityRegularizer:ut(this.activityRegularizer),biasConstraint:Pt(this.biasConstraint)},t=super.getConfig();return Object.assign(e,t),e}},_d=class extends Iy{constructor(e,t){super(e,t);this.kernel=null,_d.verifyArgs(t),this.filters=t.filters,Ht(this.filters,"filters"),this.kernelInitializer=mt(t.kernelInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.kernelConstraint=Lt(t.kernelConstraint),this.kernelRegularizer=At(t.kernelRegularizer)}build(e){e=at(e);let t=this.dataFormat==="channelsFirst"?1:e.length-1;if(e[t]==null)throw new B(`The channel dimension of the input should be defined. Found ${e[t]}`);let n=e[t],a=this.kernelSize.concat([n,this.filters]);this.kernel=this.addWeight("kernel",a,null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.useBias&&(this.bias=this.addWeight("bias",[this.filters],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint)),this.inputSpec=[{ndim:this.rank+2,axes:{[t]:n}}],this.built=!0}call(e,t){return W(()=>{e=_e(e);let n,a=this.bias==null?null:this.bias.read(),r=S6(this.activation.getClassName());if(r!=null&&this.rank===2)n=B4(e,this.kernel.read(),a,this.strides,this.padding,this.dataFormat,this.dilationRate,r);else{if(this.rank===1)n=sre(e,this.kernel.read(),a,this.strides[0],this.padding,this.dataFormat,this.dilationRate[0]);else if(this.rank===2)n=B4(e,this.kernel.read(),a,this.strides,this.padding,this.dataFormat,this.dilationRate);else if(this.rank===3)n=ire(e,this.kernel.read(),a,this.strides,this.padding,this.dataFormat,this.dilationRate);else throw new Oe("convolutions greater than 3D are not implemented yet.");this.activation!=null&&(n=this.activation.apply(n))}return n})}computeOutputShape(e){e=at(e);let t=[],n=this.dataFormat==="channelsLast"?e.slice(1,e.length-1):e.slice(2);for(let r=0;r 0 but got ${JSON.stringify(e.filters)}`)}},Pd=class extends _d{constructor(e){super(2,e);Pd.verifyArgs(e)}getConfig(){let e=super.getConfig();return delete e.rank,e}static verifyArgs(e){if(typeof e.kernelSize!="number"&&!F1(e.kernelSize,"number",1,2))throw new B(`Conv2D expects config.kernelSize to be number or number[] with length 1 or 2, but received ${JSON.stringify(e.kernelSize)}.`)}};Pd.className="Conv2D";ae.registerClass(Pd);var Ld=class extends _d{constructor(e){super(3,e);Ld.verifyArgs(e)}getConfig(){let e=super.getConfig();return delete e.rank,e}static verifyArgs(e){if(typeof e.kernelSize!="number"&&!(Array.isArray(e.kernelSize)&&(e.kernelSize.length===1||e.kernelSize.length===3)))throw new B(`Conv3D expects config.kernelSize to be number or [number, number, number], but received ${JSON.stringify(e.kernelSize)}.`)}};Ld.className="Conv3D";ae.registerClass(Ld);var Sy=class extends Pd{constructor(e){super(e);if(this.inputSpec=[new Mt({ndim:4})],this.padding!=="same"&&this.padding!=="valid")throw new B(`Conv2DTranspose currently supports only padding modes 'same' and 'valid', but received padding mode ${this.padding}`)}build(e){if(e=at(e),e.length!==4)throw new B("Input should have rank 4; Received input shape: "+JSON.stringify(e));let t=this.dataFormat==="channelsFirst"?1:e.length-1;if(e[t]==null)throw new B("The channel dimension of the inputs should be defined. Found `None`.");let n=e[t],a=this.kernelSize.concat([this.filters,n]);this.kernel=this.addWeight("kernel",a,"float32",this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.useBias&&(this.bias=this.addWeight("bias",[this.filters],"float32",this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint)),this.inputSpec=[new Mt({ndim:4,axes:{[t]:n}})],this.built=!0}call(e,t){return W(()=>{let n=_e(e);if(n.shape.length!==4)throw new B(`Conv2DTranspose.call() expects input tensor to be rank-4, but received a tensor of rank-${n.shape.length}`);let a=n.shape,r=a[0],s,i;this.dataFormat==="channelsFirst"?(s=2,i=3):(s=1,i=2);let o=a[s],l=a[i],d=this.kernelSize[0],u=this.kernelSize[1],p=this.strides[0],c=this.strides[1],h=Ga(o,p,d,this.padding),m=Ga(l,c,u,this.padding),f=[r,h,m,this.filters];this.dataFormat!=="channelsLast"&&(n=Ze(n,[0,2,3,1]));let A=vc(n,this.kernel.read(),f,this.strides,this.padding);return this.dataFormat!=="channelsLast"&&(A=Ze(A,[0,3,1,2])),this.bias!=null&&(A=ka(A,this.bias.read(),this.dataFormat)),this.activation!=null&&(A=this.activation.apply(A)),A})}computeOutputShape(e){e=at(e);let t=e.slice(),n,a,r;this.dataFormat==="channelsFirst"?(n=1,a=2,r=3):(n=3,a=1,r=2);let s=this.kernelSize[0],i=this.kernelSize[1],o=this.strides[0],l=this.strides[1];return t[n]=this.filters,t[a]=Ga(t[a],o,s,this.padding),t[r]=Ga(t[r],l,i,this.padding),t}getConfig(){let e=super.getConfig();return delete e.dilationRate,e}};Sy.className="Conv2DTranspose";ae.registerClass(Sy);var Ny=class extends Ld{constructor(e){super(e);if(this.inputSpec=[new Mt({ndim:5})],this.padding!=="same"&&this.padding!=="valid")throw new B(`Conv3DTranspose currently supports only padding modes 'same' and 'valid', but received padding mode ${this.padding}`)}build(e){if(e=at(e),e.length!==5)throw new B("Input should have rank 5; Received input shape: "+JSON.stringify(e));let t=this.dataFormat==="channelsFirst"?1:e.length-1;if(e[t]==null)throw new B("The channel dimension of the inputs should be defined. Found `None`.");let n=e[t],a=this.kernelSize.concat([this.filters,n]);this.kernel=this.addWeight("kernel",a,"float32",this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.useBias&&(this.bias=this.addWeight("bias",[this.filters],"float32",this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint)),this.inputSpec=[new Mt({ndim:5,axes:{[t]:n}})],this.built=!0}call(e,t){return W(()=>{let n=_e(e);if(n.shape.length!==5)throw new B(`Conv3DTranspose.call() expects input tensor to be rank-4, but received a tensor of rank-${n.shape.length}`);let a=n.shape,r=a[0],s,i,o;this.dataFormat==="channelsFirst"?(o=2,s=3,i=4):(o=1,s=2,i=3);let l=a[o],d=a[s],u=a[i],p=this.kernelSize[0],c=this.kernelSize[1],h=this.kernelSize[2],m=this.strides[0],f=this.strides[1],A=this.strides[2],y=Ga(l,m,p,this.padding),g=Ga(d,f,c,this.padding),x=Ga(u,A,h,this.padding),w=[r,y,g,x,this.filters];this.dataFormat!=="channelsLast"&&(n=Ze(n,[0,2,3,4,1]));let b=Db(n,this.kernel.read(),w,this.strides,this.padding);return this.dataFormat!=="channelsLast"&&(b=Ze(b,[0,4,1,2,3])),this.bias!==null&&(b=ka(b,this.bias.read(),this.dataFormat)),this.activation!==null&&(b=this.activation.apply(b)),b})}computeOutputShape(e){e=at(e);let t=e.slice(),n,a,r,s;this.dataFormat==="channelsFirst"?(n=1,a=2,r=3,s=4):(n=4,a=1,r=2,s=3);let i=this.kernelSize[0],o=this.kernelSize[1],l=this.kernelSize[2],d=this.strides[0],u=this.strides[1],p=this.strides[2];return t[n]=this.filters,t[a]=Ga(t[a],d,i,this.padding),t[r]=Ga(t[r],u,o,this.padding),t[s]=Ga(t[s],p,l,this.padding),t}getConfig(){let e=super.getConfig();return delete e.dilationRate,e}};Ny.className="Conv3DTranspose";ae.registerClass(Ny);var V4=class extends _d{constructor(e,t){super(e,t);if(this.DEFAULT_DEPTHWISE_INITIALIZER="glorotUniform",this.DEFAULT_POINTWISE_INITIALIZER="glorotUniform",this.depthwiseKernel=null,this.pointwiseKernel=null,t.filters==null)throw new B("The `filters` configuration field is required by SeparableConv, but is unspecified.");if(t.kernelInitializer!=null||t.kernelRegularizer!=null||t.kernelConstraint!=null)throw new B("Fields kernelInitializer, kernelRegularizer and kernelConstraint are invalid for SeparableConv2D. Use depthwiseInitializer, depthwiseRegularizer, depthwiseConstraint, pointwiseInitializer, pointwiseRegularizer and pointwiseConstraint instead.");if(t.padding!=null&&t.padding!=="same"&&t.padding!=="valid")throw new B(`SeparableConv${this.rank}D supports only padding modes: 'same' and 'valid', but received ${JSON.stringify(t.padding)}`);this.depthMultiplier=t.depthMultiplier==null?1:t.depthMultiplier,this.depthwiseInitializer=mt(t.depthwiseInitializer||this.DEFAULT_DEPTHWISE_INITIALIZER),this.depthwiseRegularizer=At(t.depthwiseRegularizer),this.depthwiseConstraint=Lt(t.depthwiseConstraint),this.pointwiseInitializer=mt(t.depthwiseInitializer||this.DEFAULT_POINTWISE_INITIALIZER),this.pointwiseRegularizer=At(t.pointwiseRegularizer),this.pointwiseConstraint=Lt(t.pointwiseConstraint)}build(e){if(e=at(e),e.length{e=_e(e);let n;if(this.rank===1)throw new Oe("1D separable convolution is not implemented yet.");return this.rank===2&&(this.dataFormat==="channelsFirst"&&(e=Ze(e,[0,2,3,1])),n=CA(e,this.depthwiseKernel.read(),this.pointwiseKernel.read(),this.strides,this.padding,this.dilationRate,"NHWC")),this.useBias&&(n=ka(n,this.bias.read(),this.dataFormat)),this.activation!=null&&(n=this.activation.apply(n)),this.dataFormat==="channelsFirst"&&(n=Ze(n,[0,3,1,2])),n})}getConfig(){let e=super.getConfig();return delete e.rank,delete e.kernelInitializer,delete e.kernelRegularizer,delete e.kernelConstraint,e.depthwiseInitializer=kt(this.depthwiseInitializer),e.pointwiseInitializer=kt(this.pointwiseInitializer),e.depthwiseRegularizer=ut(this.depthwiseRegularizer),e.pointwiseRegularizer=ut(this.pointwiseRegularizer),e.depthwiseConstraint=Pt(this.depthwiseConstraint),e.pointwiseConstraint=Pt(this.pointwiseConstraint),e}};V4.className="SeparableConv";var Ty=class extends V4{constructor(e){super(2,e)}};Ty.className="SeparableConv2D";ae.registerClass(Ty);var e0=class extends _d{constructor(e){super(1,e);e0.verifyArgs(e),this.inputSpec=[{ndim:3}]}getConfig(){let e=super.getConfig();return delete e.rank,delete e.dataFormat,e}static verifyArgs(e){if(typeof e.kernelSize!="number"&&!F1(e.kernelSize,"number",1,1))throw new B(`Conv1D expects config.kernelSize to be number or number[] with length 1, but received ${JSON.stringify(e.kernelSize)}.`)}};e0.className="Conv1D";ae.registerClass(e0);var Ey=class extends Ge{constructor(e){super(e);typeof e.cropping=="number"?this.cropping=[[e.cropping,e.cropping],[e.cropping,e.cropping]]:typeof e.cropping[0]=="number"?this.cropping=[[e.cropping[0],e.cropping[0]],[e.cropping[1],e.cropping[1]]]:this.cropping=e.cropping,this.dataFormat=e.dataFormat===void 0?"channelsLast":e.dataFormat,this.inputSpec=[{ndim:4}]}computeOutputShape(e){return this.dataFormat==="channelsFirst"?[e[0],e[1],e[2]-this.cropping[0][0]-this.cropping[0][1],e[3]-this.cropping[1][0]-this.cropping[1][1]]:[e[0],e[1]-this.cropping[0][0]-this.cropping[0][1],e[2]-this.cropping[1][0]-this.cropping[1][1],e[3]]}call(e,t){return W(()=>{if(e=_e(e),this.dataFormat==="channelsLast"){let n=Fh(e,this.cropping[0][0],e.shape[1]-this.cropping[0][0]-this.cropping[0][1],2);return Fh(n,this.cropping[1][0],e.shape[2]-this.cropping[1][1]-this.cropping[1][0],3)}else{let n=Fh(e,this.cropping[0][0],e.shape[2]-this.cropping[0][0]-this.cropping[0][1],3);return Fh(n,this.cropping[1][0],e.shape[3]-this.cropping[1][1]-this.cropping[1][0],4)}})}getConfig(){let e={cropping:this.cropping,dataFormat:this.dataFormat},t=super.getConfig();return Object.assign(e,t),e}};Ey.className="Cropping2D";ae.registerClass(Ey);var Cy=class extends Ge{constructor(e){super(e);this.DEFAULT_SIZE=[2,2],this.inputSpec=[{ndim:4}],this.size=e.size==null?this.DEFAULT_SIZE:e.size,this.dataFormat=e.dataFormat==null?"channelsLast":e.dataFormat,Et(this.dataFormat),this.interpolation=e.interpolation==null?"nearest":e.interpolation,Nte(this.interpolation)}computeOutputShape(e){if(this.dataFormat==="channelsFirst"){let t=e[2]==null?null:this.size[0]*e[2],n=e[3]==null?null:this.size[1]*e[3];return[e[0],e[1],t,n]}else{let t=e[1]==null?null:this.size[0]*e[1],n=e[2]==null?null:this.size[1]*e[2];return[e[0],t,n,e[3]]}}call(e,t){return W(()=>{let n=_e(e),a=n.shape;if(this.dataFormat==="channelsFirst"){n=Ze(n,[0,2,3,1]);let r=this.size[0]*a[2],s=this.size[1]*a[3],i=this.interpolation==="nearest"?n.resizeNearestNeighbor([r,s]):n.resizeBilinear([r,s]);return Ze(i,[0,3,1,2])}else{let r=this.size[0]*a[1],s=this.size[1]*a[2];return this.interpolation==="nearest"?n.resizeNearestNeighbor([r,s]):n.resizeBilinear([r,s])}})}getConfig(){let e={size:this.size,dataFormat:this.dataFormat},t=super.getConfig();return Object.assign(e,t),e}};Cy.className="UpSampling2D";ae.registerClass(Cy);function ore(e,t,n=[1,1],a="valid",r,s){return W(()=>{r==null&&(r=ba()),Et(r);let i=ky(e,r);if(e.rank!==4)throw new B(`Input for depthwiseConv2d is required to be 4-D, but is instead ${e.rank}-D`);if(t.rank!==4)throw new B(`depthwiseKernel is required to be 4-D, but is instead ${t.rank}-D`);return i=hl(i,t,n,a==="same"?"same":"valid","NHWC",s),r==="channelsFirst"&&(i=Ze(i,[0,3,1,2])),i})}var Ry=class extends Iy{constructor(e){super(2,e);this.depthwiseKernel=null,this.depthMultiplier=e.depthMultiplier==null?1:e.depthMultiplier,this.depthwiseInitializer=mt(e.depthwiseInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.depthwiseConstraint=Lt(e.depthwiseConstraint),this.depthwiseRegularizer=At(e.depthwiseRegularizer)}build(e){if(e=at(e),e.length<4)throw new B(`Inputs to DepthwiseConv2D should have rank 4. Received input shape: ${JSON.stringify(e)}.`);let t=this.dataFormat==="channelsFirst"?1:3;if(e[t]==null||e[t]<0)throw new B(`The channel dimension of the inputs to DepthwiseConv2D should be defined, but is not (${e[t]}).`);let n=e[t],a=[this.kernelSize[0],this.kernelSize[1],n,this.depthMultiplier];this.depthwiseKernel=this.addWeight("depthwise_kernel",a,null,this.depthwiseInitializer,this.depthwiseRegularizer,!0,this.depthwiseConstraint),this.useBias?this.bias=this.addWeight("bias",[n*this.depthMultiplier],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint):this.bias=null,this.built=!0}call(e,t){return W(()=>{e=_e(e);let n=ore(e,this.depthwiseKernel.read(),this.strides,this.padding,this.dataFormat,null);return this.useBias&&(n=ka(n,this.bias.read(),this.dataFormat)),this.activation!=null&&(n=this.activation.apply(n)),n})}computeOutputShape(e){e=at(e);let t=this.dataFormat==="channelsFirst"?e[2]:e[1],n=this.dataFormat==="channelsFirst"?e[3]:e[2],a=this.dataFormat==="channelsFirst"?e[1]*this.depthMultiplier:e[3]*this.depthMultiplier,r=Na(t,this.kernelSize[0],this.padding,this.strides[0]),s=Na(n,this.kernelSize[1],this.padding,this.strides[1]);return this.dataFormat==="channelsFirst"?[e[0],a,r,s]:[e[0],r,s,a]}getConfig(){let e=super.getConfig();return e.depthMultiplier=this.depthMultiplier,e.depthwiseInitializer=kt(this.depthwiseInitializer),e.depthwiseRegularizer=ut(this.depthwiseRegularizer),e.depthwiseConstraint=Pt(this.depthwiseRegularizer),e}};Ry.className="DepthwiseConv2D";ae.registerClass(Ry);function j4(e,t,n,a){if(Array.isArray(e)){if(t!=null||n!=null)throw new B("When inputs is an array, neither initialState or constants should be provided");a!=null&&(n=e.slice(e.length-a,e.length),e=e.slice(0,e.length-a)),e.length>1&&(t=e.slice(1,e.length)),e=e[0]}function r(s){return s==null||Array.isArray(s)?s:[s]}return t=r(t),n=r(n),{inputs:e,initialState:t,constants:n}}function U4(e,t,n,a=!1,r,s,i=!1,o=!1){return W(()=>{let l=t.shape.length;if(l<3)throw new B(`Input should be at least 3D, but is ${l}D.`);let d=[1,0].concat(wa(2,l));if(t=Ze(t,d),s!=null)throw new Oe("The rnn() functoin of the deeplearn.js backend does not support constants yet.");i&&console.warn("Backend rnn(): the unroll = true option is not applicable to the imperative deeplearn.js backend."),r!=null&&(r=r.asType("bool").asType("float32"),r.rank===l-1&&(r=ln(r,-1)),r=Ze(r,d)),a&&(t=On(t,0),r!=null&&(r=On(r,0)));let u=[],p,c=n,h=t.shape[0],m=la(t),f;r!=null&&(f=la(r));for(let y=0;ye(g,c));if(r==null)p=x[0],c=x[1];else{let w=W(()=>{let b=f[y],v=Dn(b).sub(b),N=x[0].mul(b).add(c[0].mul(v)),T=c.map((R,$)=>x[1][$].mul(b).add(R.mul(v)));return{output:N,newStates:T}});p=w.output,c=w.newStates}o&&u.push(p)}let A;return o&&(A=zn(u,1)),[p,A,c]})}var Ua=class extends Ge{constructor(e){super(e);let t;if(e.cell==null)throw new B("cell property is missing for the constructor of RNN.");if(Array.isArray(e.cell)?t=new t0({cells:e.cell}):t=e.cell,t.stateSize==null)throw new B("The RNN cell should have an attribute `stateSize` (tuple of integers, one integer per RNN state).");this.cell=t,this.returnSequences=e.returnSequences==null?!1:e.returnSequences,this.returnState=e.returnState==null?!1:e.returnState,this.goBackwards=e.goBackwards==null?!1:e.goBackwards,this._stateful=e.stateful==null?!1:e.stateful,this.unroll=e.unroll==null?!1:e.unroll,this.supportsMasking=!0,this.inputSpec=[new Mt({ndim:3})],this.stateSpec=null,this.states_=null,this.numConstants=null,this.keptStates=[]}getStates(){if(this.states_==null){let e=Array.isArray(this.cell.stateSize)?this.cell.stateSize.length:1;return wa(0,e).map(t=>null)}else return this.states_}setStates(e){this.states_=e}computeOutputShape(e){J1(e)&&(e=e[0]),e=e;let t=this.cell.stateSize;Array.isArray(t)||(t=[t]);let n=t[0],a;if(this.returnSequences?a=[e[0],e[1],n]:a=[e[0],n],this.returnState){let r=[];for(let s of t)r.push([e[0],s]);return[a].concat(r)}else return a}computeMask(e,t){return W(()=>{Array.isArray(t)&&(t=t[0]);let n=this.returnSequences?t:null;if(this.returnState){let a=this.states.map(r=>null);return[n].concat(a)}else return n})}get states(){if(this.states_==null){let e=Array.isArray(this.cell.stateSize)?this.cell.stateSize.length:1,t=[];for(let n=0;ni.shape[i.shape.length-1]),s))throw new B(`An initialState was passed that is not compatible with cell.stateSize. Received stateSpec=${this.stateSpec}; However cell.stateSize is ${this.cell.stateSize}`)}else this.stateSpec=s.map(i=>new Mt({shape:[null,i]}));this.stateful&&this.resetStates()}resetStates(e,t=!1){W(()=>{if(!this.stateful)throw new lr("Cannot call resetStates() on an RNN Layer that is not stateful.");let n=this.inputSpec[0].shape[0];if(n==null)throw new B("If an RNN is stateful, it needs to know its batch size. Specify the batch size of your input tensors: \n- If using a Sequential model, specify the batch size by passing a `batchInputShape` option to your first layer.\n- If using the functional API, specify the batch size by passing a `batchShape` option to your Input layer.");if(this.states_==null)Array.isArray(this.cell.stateSize)?this.states_=this.cell.stateSize.map(a=>Ct([n,a])):this.states_=[Ct([n,this.cell.stateSize])];else if(e==null)Ee(this.states_),this.keptStates!=null&&(Ee(this.keptStates),this.keptStates=[]),Array.isArray(this.cell.stateSize)?this.states_=this.cell.stateSize.map(a=>Ct([n,a])):this.states_[0]=Ct([n,this.cell.stateSize]);else{if(Array.isArray(e)||(e=[e]),e.length!==this.states_.length)throw new B(`Layer ${this.name} expects ${this.states_.length} state(s), but it received ${e.length} state value(s). Input received: ${e}`);t===!0?this.keptStates.push(this.states_.slice()):Ee(this.states_);for(let a=0;ajt(a.clone()))})}apply(e,t){let n=t==null?null:t.initialState,a=t==null?null:t.constants;t==null&&(t={});let r=j4(e,n,a,this.numConstants);e=r.inputs,n=r.initialState,a=r.constants;let s=[],i=[];if(n!=null){t.initialState=n,s=s.concat(n),this.stateSpec=[];for(let o of n)this.stateSpec.push(new Mt({shape:o.shape}));i=i.concat(this.stateSpec)}if(a!=null&&(t.constants=a,s=s.concat(a),this.numConstants=a.length),s[0]instanceof Ia){let o=[e].concat(s),l=this.inputSpec.concat(i),d=this.inputSpec;this.inputSpec=l;let u=super.apply(o,t);return this.inputSpec=d,u}else return super.apply(e,t)}call(e,t){return W(()=>{let n=t==null?null:t.mask,a=t==null?null:t.training,r=t==null?null:t.initialState;e=_e(e),r==null&&(this.stateful?r=this.states_:r=this.getInitialState(e));let s=Array.isArray(this.cell.stateSize)?this.cell.stateSize.length:1;if(r.length!==s)throw new B(`RNN Layer has ${s} state(s) but was passed ${r.length} initial state(s).`);this.unroll&&console.warn("Ignoring unroll = true for RNN layer, due to imperative backend.");let i={training:a},o=U4((c,h)=>{let m=this.cell.call([c].concat(h),i);return[m[0],m.slice(1)]},e,r,this.goBackwards,n,null,this.unroll,this.returnSequences),l=o[0],d=o[1],u=o[2];this.stateful&&this.resetStates(u,a);let p=this.returnSequences?d:l;return this.returnState?[p].concat(u):p})}getInitialState(e){return W(()=>{let t=Ct(e.shape);return t=ke(t,[1,2]),t=Ed(t),Array.isArray(this.cell.stateSize)?this.cell.stateSize.map(n=>n>1?P1(t,[1,n]):t):this.cell.stateSize>1?[P1(t,[1,this.cell.stateSize])]:[t]})}get trainableWeights(){return this.trainable?this.cell.trainableWeights:[]}get nonTrainableWeights(){return this.trainable?this.cell.nonTrainableWeights:this.cell.weights}setFastWeightInitDuringBuild(e){super.setFastWeightInitDuringBuild(e),this.cell!=null&&this.cell.setFastWeightInitDuringBuild(e)}getConfig(){let e=super.getConfig(),t={returnSequences:this.returnSequences,returnState:this.returnState,goBackwards:this.goBackwards,stateful:this.stateful,unroll:this.unroll};this.numConstants!=null&&(t.numConstants=this.numConstants);let n=this.cell.getConfig();return this.getClassName()===Ua.className&&(t.cell={className:this.cell.getClassName(),config:n}),Object.assign({},n,e,t)}static fromConfig(e,t,n={}){let a=t.cell,r=Sa(a,n);return new e(Object.assign(t,{cell:r}))}};Ua.className="RNN";ae.registerClass(Ua);var Md=class extends Ge{},n0=class extends Md{constructor(e){super(e);this.DEFAULT_ACTIVATION="tanh",this.DEFAULT_KERNEL_INITIALIZER="glorotNormal",this.DEFAULT_RECURRENT_INITIALIZER="orthogonal",this.DEFAULT_BIAS_INITIALIZER="zeros",this.units=e.units,Ht(this.units,"units"),this.activation=Gr(e.activation==null?this.DEFAULT_ACTIVATION:e.activation),this.useBias=e.useBias==null?!0:e.useBias,this.kernelInitializer=mt(e.kernelInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.recurrentInitializer=mt(e.recurrentInitializer||this.DEFAULT_RECURRENT_INITIALIZER),this.biasInitializer=mt(e.biasInitializer||this.DEFAULT_BIAS_INITIALIZER),this.kernelRegularizer=At(e.kernelRegularizer),this.recurrentRegularizer=At(e.recurrentRegularizer),this.biasRegularizer=At(e.biasRegularizer),this.kernelConstraint=Lt(e.kernelConstraint),this.recurrentConstraint=Lt(e.recurrentConstraint),this.biasConstraint=Lt(e.biasConstraint),this.dropout=Wl([1,jr([0,e.dropout==null?0:e.dropout])]),this.recurrentDropout=Wl([1,jr([0,e.recurrentDropout==null?0:e.recurrentDropout])]),this.stateSize=this.units,this.dropoutMask=null,this.recurrentDropoutMask=null}build(e){e=at(e),this.kernel=this.addWeight("kernel",[e[e.length-1],this.units],null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.recurrentKernel=this.addWeight("recurrent_kernel",[this.units,this.units],null,this.recurrentInitializer,this.recurrentRegularizer,!0,this.recurrentConstraint),this.useBias?this.bias=this.addWeight("bias",[this.units],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint):this.bias=null,this.built=!0}call(e,t){return W(()=>{if(e=e,e.length!==2)throw new B(`SimpleRNNCell expects 2 input Tensors, got ${e.length}.`);let n=e[1];e=e[0];let a=t.training==null?!1:t.training;0Dn(e),rate:this.dropout,training:a})),0Dn(n),rate:this.recurrentDropout,training:a}));let r,s=this.dropoutMask,i=this.recurrentDropoutMask;s!=null?r=ja(_(e,s),this.kernel.read()):r=ja(e,this.kernel.read()),this.bias!=null&&(r=ka(r,this.bias.read())),i!=null&&(n=_(n,i));let o=se(r,ja(n,this.recurrentKernel.read()));return this.activation!=null&&(o=this.activation.apply(o)),[o,o]})}getConfig(){let e=super.getConfig(),t={units:this.units,activation:Hr(this.activation),useBias:this.useBias,kernelInitializer:kt(this.kernelInitializer),recurrentInitializer:kt(this.recurrentInitializer),biasInitializer:kt(this.biasInitializer),kernelRegularizer:ut(this.kernelRegularizer),recurrentRegularizer:ut(this.recurrentRegularizer),biasRegularizer:ut(this.biasRegularizer),activityRegularizer:ut(this.activityRegularizer),kernelConstraint:Pt(this.kernelConstraint),recurrentConstraint:Pt(this.recurrentConstraint),biasConstraint:Pt(this.biasConstraint),dropout:this.dropout,recurrentDropout:this.recurrentDropout};return Object.assign({},e,t)}};n0.className="SimpleRNNCell";ae.registerClass(n0);var My=class extends Ua{constructor(e){e.cell=new n0(e),super(e)}call(e,t){return W(()=>{this.cell.dropoutMask!=null&&(Ee(this.cell.dropoutMask),this.cell.dropoutMask=null),this.cell.recurrentDropoutMask!=null&&(Ee(this.cell.recurrentDropoutMask),this.cell.recurrentDropoutMask=null);let n=t==null?null:t.mask,a=t==null?null:t.training,r=t==null?null:t.initialState;return super.call(e,{mask:n,training:a,initialState:r})})}static fromConfig(e,t){return new e(t)}};My.className="SimpleRNN";ae.registerClass(My);var a0=class extends Md{constructor(e){super(e);if(this.DEFAULT_ACTIVATION="tanh",this.DEFAULT_RECURRENT_ACTIVATION="hardSigmoid",this.DEFAULT_KERNEL_INITIALIZER="glorotNormal",this.DEFAULT_RECURRENT_INITIALIZER="orthogonal",this.DEFAULT_BIAS_INITIALIZER="zeros",e.resetAfter)throw new B("GRUCell does not support reset_after parameter set to true.");this.units=e.units,Ht(this.units,"units"),this.activation=Gr(e.activation===void 0?this.DEFAULT_ACTIVATION:e.activation),this.recurrentActivation=Gr(e.recurrentActivation===void 0?this.DEFAULT_RECURRENT_ACTIVATION:e.recurrentActivation),this.useBias=e.useBias==null?!0:e.useBias,this.kernelInitializer=mt(e.kernelInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.recurrentInitializer=mt(e.recurrentInitializer||this.DEFAULT_RECURRENT_INITIALIZER),this.biasInitializer=mt(e.biasInitializer||this.DEFAULT_BIAS_INITIALIZER),this.kernelRegularizer=At(e.kernelRegularizer),this.recurrentRegularizer=At(e.recurrentRegularizer),this.biasRegularizer=At(e.biasRegularizer),this.kernelConstraint=Lt(e.kernelConstraint),this.recurrentConstraint=Lt(e.recurrentConstraint),this.biasConstraint=Lt(e.biasConstraint),this.dropout=Wl([1,jr([0,e.dropout==null?0:e.dropout])]),this.recurrentDropout=Wl([1,jr([0,e.recurrentDropout==null?0:e.recurrentDropout])]),this.implementation=e.implementation,this.stateSize=this.units,this.dropoutMask=null,this.recurrentDropoutMask=null}build(e){e=at(e);let t=e[e.length-1];this.kernel=this.addWeight("kernel",[t,this.units*3],null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.recurrentKernel=this.addWeight("recurrent_kernel",[this.units,this.units*3],null,this.recurrentInitializer,this.recurrentRegularizer,!0,this.recurrentConstraint),this.useBias?this.bias=this.addWeight("bias",[this.units*3],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint):this.bias=null,this.built=!0}call(e,t){return W(()=>{if(e=e,e.length!==2)throw new B(`GRUCell expects 2 input Tensors (inputs, h, c), got ${e.length}.`);let n=t.training==null?!1:t.training,a=e[1];e=e[0],0Dn(e),rate:this.dropout,training:n,count:3})),0Dn(a),rate:this.recurrentDropout,training:n,count:3}));let r=this.dropoutMask,s=this.recurrentDropoutMask,i,o,l;0{this.cell.dropoutMask!=null&&(Ee(this.cell.dropoutMask),this.cell.dropoutMask=null),this.cell.recurrentDropoutMask!=null&&(Ee(this.cell.recurrentDropoutMask),this.cell.recurrentDropoutMask=null);let n=t==null?null:t.mask,a=t==null?null:t.training,r=t==null?null:t.initialState;return super.call(e,{mask:n,training:a,initialState:r})})}static fromConfig(e,t){return t.implmentation===0&&(t.implementation=1),new e(t)}};Fy.className="GRU";ae.registerClass(Fy);var Wd=class extends Md{constructor(e){super(e);this.DEFAULT_ACTIVATION="tanh",this.DEFAULT_RECURRENT_ACTIVATION="hardSigmoid",this.DEFAULT_KERNEL_INITIALIZER="glorotNormal",this.DEFAULT_RECURRENT_INITIALIZER="orthogonal",this.DEFAULT_BIAS_INITIALIZER="zeros",this.units=e.units,Ht(this.units,"units"),this.activation=Gr(e.activation===void 0?this.DEFAULT_ACTIVATION:e.activation),this.recurrentActivation=Gr(e.recurrentActivation===void 0?this.DEFAULT_RECURRENT_ACTIVATION:e.recurrentActivation),this.useBias=e.useBias==null?!0:e.useBias,this.kernelInitializer=mt(e.kernelInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.recurrentInitializer=mt(e.recurrentInitializer||this.DEFAULT_RECURRENT_INITIALIZER),this.biasInitializer=mt(e.biasInitializer||this.DEFAULT_BIAS_INITIALIZER),this.unitForgetBias=e.unitForgetBias,this.kernelRegularizer=At(e.kernelRegularizer),this.recurrentRegularizer=At(e.recurrentRegularizer),this.biasRegularizer=At(e.biasRegularizer),this.kernelConstraint=Lt(e.kernelConstraint),this.recurrentConstraint=Lt(e.recurrentConstraint),this.biasConstraint=Lt(e.biasConstraint),this.dropout=Wl([1,jr([0,e.dropout==null?0:e.dropout])]),this.recurrentDropout=Wl([1,jr([0,e.recurrentDropout==null?0:e.recurrentDropout])]),this.implementation=e.implementation,this.stateSize=[this.units,this.units],this.dropoutMask=null,this.recurrentDropoutMask=null}build(e){var t;e=at(e);let n=e[e.length-1];this.kernel=this.addWeight("kernel",[n,this.units*4],null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.recurrentKernel=this.addWeight("recurrent_kernel",[this.units,this.units*4],null,this.recurrentInitializer,this.recurrentRegularizer,!0,this.recurrentConstraint);let a;if(this.useBias){if(this.unitForgetBias){let r=this.biasInitializer,s=this.units;a=new(t=class extends da{apply(i,o){let l=r.apply([s]),d=new Dh().apply([s]),u=r.apply([s*2]);return O6(O6(l,d),u)}},t.className="CustomInit",t)}else a=this.biasInitializer;this.bias=this.addWeight("bias",[this.units*4],null,a,this.biasRegularizer,!0,this.biasConstraint)}else this.bias=null;this.built=!0}call(e,t){return W(()=>{let n=t.training==null?!1:t.training;if(e=e,e.length!==3)throw new B(`LSTMCell expects 3 input Tensors (inputs, h, c), got ${e.length}.`);let a=e[1],r=e[2];e=e[0],0Dn(e),rate:this.dropout,training:n,count:4})),0Dn(a),rate:this.recurrentDropout,training:n,count:4}));let s=this.dropoutMask,i=this.recurrentDropoutMask,o,l,d,u;0{this.cell.dropoutMask!=null&&(Ee(this.cell.dropoutMask),this.cell.dropoutMask=null),this.cell.recurrentDropoutMask!=null&&(Ee(this.cell.recurrentDropoutMask),this.cell.recurrentDropoutMask=null);let n=t==null?null:t.mask,a=t==null?null:t.training,r=t==null?null:t.initialState;return super.call(e,{mask:n,training:a,initialState:r})})}static fromConfig(e,t){return t.implmentation===0&&(t.implementation=1),new e(t)}};$y.className="LSTM";ae.registerClass($y);var t0=class extends Md{constructor(e){super(e);this.cells=e.cells}get stateSize(){let e=[];for(let t of this.cells.slice().reverse())Array.isArray(t.stateSize)?e.push(...t.stateSize):e.push(t.stateSize);return e}call(e,t){return W(()=>{e=e;let n=e.slice(1),a=[];for(let i of this.cells.slice().reverse())Array.isArray(i.stateSize)?a.push(n.splice(0,i.stateSize.length)):a.push(n.splice(0,1));a.reverse();let r=[],s;for(let i=0;i{Ci(`RNNCell_${a}`,()=>{n.build(e),Array.isArray(n.stateSize)?t=n.stateSize[0]:t=n.stateSize,e=[e[0],t]})}),this.built=!0}getConfig(){let e=super.getConfig(),t=a=>({className:a.getClassName(),config:a.getConfig()}),n={cells:this.cells.map(t)};return Object.assign({},e,n)}static fromConfig(e,t,n={}){let a=[];for(let r of t.cells)a.push(Sa(r,n));return new e({cells:a})}get trainableWeights(){if(!this.trainable)return[];let e=[];for(let t of this.cells)e.push(...t.trainableWeights);return e}get nonTrainableWeights(){let e=[];for(let t of this.cells)e.push(...t.nonTrainableWeights);if(!this.trainable){let t=[];for(let n of this.cells)t.push(...n.trainableWeights);return t.concat(e)}return e}getWeights(){let e=[];for(let t of this.cells)e.push(...t.weights);return Q1(e)}setWeights(e){let t=[];for(let n of this.cells){let a=n.weights.length,r=e.splice(a);for(let s=0;s_6(t(),n),i=()=>Rd(s,t,a);return!r||r<=1?jt(i().clone()):Array(r).fill(void 0).map(i).map(o=>jt(o.clone()))}var lre=function(e,t){var n={};for(var a in e)Object.prototype.hasOwnProperty.call(e,a)&&t.indexOf(a)<0&&(n[a]=e[a]);if(e!=null&&typeof Object.getOwnPropertySymbols=="function")for(var r=0,a=Object.getOwnPropertySymbols(e);r{if(this.cell.dropoutMask!=null&&(Ee(this.cell.dropoutMask),this.cell.dropoutMask=null),this.cell.recurrentDropoutMask!=null&&(Ee(this.cell.recurrentDropoutMask),this.cell.recurrentDropoutMask=null),t&&t.constants)throw new B("ConvRNN2D cell does not support constants");let n=t==null?null:t.mask,a=t==null?null:t.training,r=t==null?null:t.initialState;return super.call(e,{mask:n,training:a,initialState:r})})}computeOutputShape(e){let t=this.computeSingleOutputShape(e);return this.returnSequences||(t=[t[0],...t.slice(2)]),this.returnState&&(t=[t,...Array(2).fill([e[0],...t.slice(-3)])]),t}getInitialState(e){return W(()=>{let{stateSize:t}=this.cell,n=e.shape,a=this.computeSingleOutputShape(n),r=[a[0],...a.slice(2)],s=Ct(r);return Array.isArray(t)?Array(t.length).fill(s):[s]})}resetStates(e,t=!1){W(()=>{if(!this.stateful)throw new lr("Cannot call resetStates() on an RNN Layer that is not stateful.");let n=this.inputSpec[0].shape,a=this.computeSingleOutputShape(n),r=[a[0],...a.slice(2)];if(n[0]==null)throw new B("If an RNN is stateful, it needs to know its batch size. Specify the batch size of your input tensors: \n- If using a Sequential model, specify the batch size by passing a `batchInputShape` option to your first layer.\n- If using the functional API, specify the batch size by passing a `batchShape` option to your Input layer.");if(this.getStates()==null)Array.isArray(this.cell.stateSize)?this.states_=this.cell.stateSize.map(()=>Ct(r)):this.states_=[Ct(r)];else if(e==null)Ee(this.states_),this.keptStates!=null&&(Ee(this.keptStates),this.keptStates=[]),Array.isArray(this.cell.stateSize)?this.states_=this.cell.stateSize.map(()=>Ct(r)):this.states_[0]=Ct(r);else{if(Array.isArray(e)||(e=[e]),e.length!==this.states_.length)throw new B(`Layer ${this.name} expects ${this.states_.length} state(s), but it received ${e.length} state value(s). Input received: ${e}`);t?this.keptStates.push(this.states_.slice()):Ee(this.states_);for(let s=0;sjt(s.clone()))})}computeSingleOutputShape(e){let{dataFormat:t,filters:n,kernelSize:a,padding:r,strides:s,dilationRate:i}=this.cell,o=t==="channelsFirst",l=e[o?3:2],d=e[o?4:3],u=Na(l,a[0],r,s[0],i[0]),p=Na(d,a[1],r,s[1],i[1]);return[...e.slice(0,2),...o?[n,u,p]:[u,p,n]]}};H4.className="ConvRNN2D";var r0=class extends Wd{constructor(e){let{filters:t,kernelSize:n,strides:a,padding:r,dataFormat:s,dilationRate:i}=e;super(Object.assign({},e,{units:t}));this.filters=t,Ht(this.filters,"filters"),this.kernelSize=Hl(n,2,"kernelSize"),this.kernelSize.forEach(o=>Ht(o,"kernelSize")),this.strides=Hl(a||1,2,"strides"),this.strides.forEach(o=>Ht(o,"strides")),this.padding=r||"valid",Jn(this.padding),this.dataFormat=s||"channelsLast",Et(this.dataFormat),this.dilationRate=Hl(i||1,2,"dilationRate"),this.dilationRate.forEach(o=>Ht(o,"dilationRate"))}build(e){var t;e=at(e);let n=this.dataFormat==="channelsFirst"?1:e.length-1;if(e[n]==null)throw new B(`The channel dimension of the input should be defined. Found ${e[n]}`);let a=e[n],r=4,s=this.kernelSize.concat([a,this.filters*r]);this.kernel=this.addWeight("kernel",s,null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint);let i=this.kernelSize.concat([this.filters,this.filters*r]);if(this.recurrentKernel=this.addWeight("recurrent_kernel",i,null,this.recurrentInitializer,this.recurrentRegularizer,!0,this.recurrentConstraint),this.useBias){let o;if(this.unitForgetBias){let l=this.biasInitializer,d=this.filters;o=new(t=class extends da{apply(u,p){let c=l.apply([d]),h=$n([d]),m=l.apply([d*2]);return W1([c,h,m])}},t.className="CustomInit",t)}else o=this.biasInitializer;this.bias=this.addWeight("bias",[this.filters*r],null,o,this.biasRegularizer,!0,this.biasConstraint)}this.built=!0}call(e,t){return W(()=>{if(e.length!==3)throw new B(`ConvLSTM2DCell expects 3 input Tensors (inputs, h, c), got ${e.length}.`);let n=t.training||!1,a=e[0],r=e[1],s=e[2],i=4;0Dn(a),rate:this.dropout,training:n,count:i}));let o=this.dropoutMask,l=(Y,re,ne)=>!re||!re[ne]?Y:_(re[ne],Y),d=l(a,o,0),u=l(a,o,1),p=l(a,o,2),c=l(a,o,3);0Dn(r),rate:this.recurrentDropout,training:n,count:i}));let h=this.recurrentDropoutMask,m=l(r,h,0),f=l(r,h,1),A=l(r,h,2),y=l(r,h,3),g=3,[x,w,b,v]=an(this.kernel.read(),i,g),[N,T,R,$]=this.useBias?an(this.bias.read(),i):[null,null,null,null];d=this.inputConv(d,x,N,this.padding),u=this.inputConv(u,w,T,this.padding),p=this.inputConv(p,b,R,this.padding),c=this.inputConv(c,v,$,this.padding);let[z,P,V,j]=an(this.recurrentKernel.read(),i,g);m=this.recurrentConv(m,z),f=this.recurrentConv(f,P),A=this.recurrentConv(A,V),y=this.recurrentConv(y,j);let U=this.recurrentActivation.apply(se(d,m)),X=this.recurrentActivation.apply(se(u,f)),G=se(_(X,s),_(U,this.activation.apply(se(p,A)))),ee=_(this.recurrentActivation.apply(se(c,y)),this.activation.apply(G));return[ee,ee,G]})}getConfig(){let e=super.getConfig(),{units:t}=e,n=lre(e,["units"]),a={filters:this.filters,kernelSize:this.kernelSize,padding:this.padding,dataFormat:this.dataFormat,dilationRate:this.dilationRate,strides:this.strides};return Object.assign({},n,a)}inputConv(e,t,n,a){let r=nr(e,t,this.strides,a||"valid",this.dataFormat==="channelsFirst"?"NCHW":"NHWC",this.dilationRate);return n?ka(r,n,this.dataFormat):r}recurrentConv(e,t){return nr(e,t,1,"same",this.dataFormat==="channelsFirst"?"NCHW":"NHWC")}};r0.className="ConvLSTM2DCell";ae.registerClass(r0);var Dy=class extends H4{constructor(e){let t=new r0(e);super(Object.assign({},e,{cell:t}))}static fromConfig(e,t){return new e(t)}};Dy.className="ConvLSTM2D";ae.registerClass(Dy);var s0=class extends Ge{constructor(e){super(e);this.rate=Math.max(Math.min(e.rate,1),0),this.noiseShape=e.noiseShape,this.seed=e.seed,this.supportsMasking=!0}getNoiseShape(e){if(this.noiseShape==null)return this.noiseShape;let t=e.shape,n=[];for(let a=0;a{this.invokeCallHook(e,t);let n=_e(e);if(0_6(n,this.rate,r,this.seed),()=>n,a)}return e})}getConfig(){let e={rate:this.rate,noiseShape:this.noiseShape,seed:this.seed},t=super.getConfig();return Object.assign(e,t),e}dispose(){return super.dispose()}};s0.className="Dropout";ae.registerClass(s0);var Oy=class extends s0{constructor(e){super(e);this.inputSpec=[{ndim:3}]}getNoiseShape(e){let t=e.shape;return[t[0],1,t[2]]}};Oy.className="SpatialDropout1D";ae.registerClass(Oy);var zy=class extends Ge{constructor(e){super(e);if(this.activation=null,this.useBias=!0,this.kernel=null,this.bias=null,this.DEFAULT_KERNEL_INITIALIZER="glorotNormal",this.DEFAULT_BIAS_INITIALIZER="zeros",e.batchInputShape==null&&e.inputShape==null&&e.inputDim!=null){let t=null;e.batchSize!=null&&(t=e.batchSize),this.batchInputShape=[t,e.inputDim]}this.units=e.units,Ht(this.units,"units"),this.activation=Gr(e.activation),e.useBias!=null&&(this.useBias=e.useBias),this.kernelInitializer=mt(e.kernelInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.biasInitializer=mt(e.biasInitializer||this.DEFAULT_BIAS_INITIALIZER),this.kernelConstraint=Lt(e.kernelConstraint),this.biasConstraint=Lt(e.biasConstraint),this.kernelRegularizer=At(e.kernelRegularizer),this.biasRegularizer=At(e.biasRegularizer),this.activityRegularizer=At(e.activityRegularizer),this.supportsMasking=!0,this.inputSpec=[{minNDim:2}]}build(e){e=at(e);let t=e[e.length-1];this.kernel==null&&(this.kernel=this.addWeight("kernel",[t,this.units],null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.useBias&&(this.bias=this.addWeight("bias",[this.units],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint))),this.inputSpec=[{minNDim:2,axes:{[-1]:t}}],this.built=!0}computeOutputShape(e){e=at(e);let t=e.slice();return t[t.length-1]=this.units,t}call(e,t){return W(()=>{this.invokeCallHook(e,t);let n=_e(e),a=S6(this.activation.getClassName()),r;return a!=null?r=ja(n,this.kernel.read(),a,this.bias?this.bias.read():null):(r=ja(n,this.kernel.read()),this.bias!=null&&(r=ka(r,this.bias.read())),this.activation!=null&&(r=this.activation.apply(r))),r})}getConfig(){let e={units:this.units,activation:Hr(this.activation),useBias:this.useBias,kernelInitializer:kt(this.kernelInitializer),biasInitializer:kt(this.biasInitializer),kernelRegularizer:ut(this.kernelRegularizer),biasRegularizer:ut(this.biasRegularizer),activityRegularizer:ut(this.activityRegularizer),kernelConstraint:Pt(this.kernelConstraint),biasConstraint:Pt(this.biasConstraint)},t=super.getConfig();return Object.assign(e,t),e}};zy.className="Dense";ae.registerClass(zy);var _y=class extends Ge{constructor(e){e=e||{},super(e),this.inputSpec=[{minNDim:3}],this.dataFormat=e.dataFormat}computeOutputShape(e){e=at(e);for(let t of e.slice(1))if(t==null)throw new B(`The shape of the input to "Flatten" is not fully defined (got ${e.slice(1)}). Make sure to pass a complete "input_shape" or "batch_input_shape" argument to the first layer in your model.`);return[e[0],Vr(e,1)]}call(e,t){return W(()=>{this.invokeCallHook(e,t);let n=_e(e);if(this.dataFormat==="channelsFirst"&&n.rank>1){let a=[0];for(let r=2;r{this.invokeCallHook(e,t);let n=_e(e);return this.activation.apply(n)})}getConfig(){let e={activation:Hr(this.activation)},t=super.getConfig();return Object.assign(e,t),e}};Py.className="Activation";ae.registerClass(Py);var Ly=class extends Ge{constructor(e){super(e);this.n=e.n,this.inputSpec=[{ndim:2}]}computeOutputShape(e){return[e[0],this.n,e[1]]}call(e,t){return W(()=>(e=_e(e),Rte(e,this.n)))}getConfig(){let e={n:this.n},t=super.getConfig();return Object.assign(e,t),e}};Ly.className="RepeatVector";ae.registerClass(Ly);var Wy=class extends Ge{constructor(e){super(e);this.targetShape=e.targetShape;for(let t=0;t{this.invokeCallHook(e,t);let n=_e(e),a=n.shape,r=a.slice(0,1).concat(this.fixUnknownDimension(a.slice(1),this.targetShape));return n.reshape(r)})}getConfig(){let e={targetShape:this.targetShape},t=super.getConfig();return Object.assign(e,t),e}};Wy.className="Reshape";ae.registerClass(Wy);var By=class extends Ge{constructor(e){super(e);if(e.dims==null)throw new Error("Required configuration field `dims` is missing during Permute constructor call.");if(!Array.isArray(e.dims))throw new Error(`Permute constructor requires \`dims\` to be an Array, but received ${e.dims} instead.`);let t=wa(1,e.dims.length+1);if(!k.arraysEqual(e.dims.slice().sort(),t))throw new Error("Invalid permutation `dims`: "+JSON.stringify(e.dims)+" `dims` must contain consecutive integers starting from 1.");this.dims=e.dims,this.dimsIncludingBatch=[0].concat(this.dims),this.inputSpec=[new Mt({ndim:this.dims.length+1})]}computeOutputShape(e){e=at(e);let t=e.slice();return this.dims.forEach((n,a)=>{t[a+1]=e[n]}),t}call(e,t){return Ze(_e(e),this.dimsIncludingBatch)}getConfig(){let e={dims:this.dims},t=super.getConfig();return Object.assign(e,t),e}};By.className="Permute";ae.registerClass(By);var Vy=class extends Ge{constructor(e){super(e==null?{}:e);this.supportsMasking=!0,e!=null?this.maskValue=e.maskValue==null?0:e.maskValue:this.maskValue=0}computeOutputShape(e){return e}getConfig(){let e=super.getConfig(),t={maskValue:this.maskValue};return Object.assign(t,e),t}computeMask(e,t){let n=_e(e),a=-1;return ju(mi(n,this.maskValue),a)}call(e,t){return W(()=>{this.invokeCallHook(e,t);let n=_e(e),a=-1,r=!0,s=ju(mi(n,this.maskValue),a,r);return n.mul(s.asType(n.dtype))})}};Vy.className="Masking";ae.registerClass(Vy);var jy=class extends Ge{constructor(e){super(e);if(this.embeddings=null,this.DEFAULT_EMBEDDINGS_INITIALIZER="randomUniform",e.batchInputShape==null&&e.inputShape==null){let t=null;e.batchSize!=null&&(t=e.batchSize),e.inputLength==null?this.batchInputShape=[t,null]:this.batchInputShape=[t].concat(ht(e.inputLength))}this.inputDim=e.inputDim,Ht(this.inputDim,"inputDim"),this.outputDim=e.outputDim,Ht(this.outputDim,"outputDim"),this.embeddingsInitializer=mt(e.embeddingsInitializer||this.DEFAULT_EMBEDDINGS_INITIALIZER),this.embeddingsRegularizer=At(e.embeddingsRegularizer),this.activityRegularizer=At(e.activityRegularizer),this.embeddingsConstraint=Lt(e.embeddingsConstraint),this.maskZero=e.maskZero,this.supportsMasking=e.maskZero,this.inputLength=e.inputLength}build(e){this.embeddings=this.addWeight("embeddings",[this.inputDim,this.outputDim],this.dtype,this.embeddingsInitializer,this.embeddingsRegularizer,!0,this.embeddingsConstraint),this.built=!0}warnOnIncompatibleInputShape(e){}computeMask(e,t){return W(()=>this.maskZero?(e=_e(e),mi(e,Ue(e))):null)}computeOutputShape(e){if(e=at(e),this.inputLength==null)return[...e,this.outputDim];let t=ht(this.inputLength);if(t.length!==e.length-1)throw new B(`"inputLength" is ${this.inputLength}, but received input shape has shape ${e}`);{let n=0;for(let a=0;a{this.invokeCallHook(e,t);let n=_e(e);return n.dtype!=="int32"&&(n=Td(n,"int32")),z6(this.embeddings.read(),n.as1D()).reshape(at(this.computeOutputShape(n.shape)))})}getConfig(){let e={inputDim:this.inputDim,outputDim:this.outputDim,embeddingsInitializer:kt(this.embeddingsInitializer),embeddingsRegularizer:ut(this.embeddingsRegularizer),activityRegularizer:ut(this.activityRegularizer),embeddingsConstraint:Pt(this.embeddingsConstraint),maskZero:this.maskZero,inputLength:this.inputLength},t=super.getConfig();return Object.assign(e,t),e}};jy.className="Embedding";ae.registerClass(jy);var Di=class extends Ge{constructor(e){super(e||{});this.supportsMasking=!0}mergeFunction(e){throw new Oe}computeElementwiseOpOutputShape(e,t){if(e==null||t==null)return null;if(e.length1)throw new B(`Can not merge tensors with different batch sizes. Got tensors with shapes: ${JSON.stringify(e)}.`);let n=e[0]==null?null:e[0].slice(1);for(let r=1;rr.length);e.indexOf(null)===-1&&Br(a).length===1?this.reshapeRequired=!1:this.reshapeRequired=!0}call(e,t){return W(()=>{if(e=e,this.reshapeRequired){let n=[],a=e.map(r=>r.rank);if(a.indexOf(null)===-1){let r=jr(a);for(let s of e){let i=s.rank;for(let o=0;o1){let d=wa(1,l).concat([0]);n.push(Ze(o,d)),r=!0}else n.push(o)}let s=this.mergeFunction(n),i=s.rank;if(r){if(i==null){let o=s.shape,l=o.length,d=o[l-1],u=[d].concat(o.slice(0,o.length-1));s=Ze(s.reshape([-1,d]),[1,0]).reshape(u)}else if(i>1){let o=[i-1].concat(wa(0,i-1));s=Ze(s,o)}}return s}}else return this.mergeFunction(e)})}computeOutputShape(e){e=e;let t;e[0]==null?t=null:t=e[0].slice(1);for(let a=1;a{if(t==null)return null;if(!Array.isArray(t))throw new B("`mask` should be an Array");if(!Array.isArray(e))throw new B("`inputs` should be an Array");if(t.length!==e.length)throw new B(`The Array 'inputs' and 'mask' are expected to have the same length, but have different lengths (${e.length} vs ${t.length})`);if(t.every(a=>a==null))return null;t=t.map(a=>a==null?a:ln(a,0));let n=t[0];for(let a=1;a{let t=e[0].clone();for(let n=1;n{let t=e[0].clone();for(let n=1;n{let t=e[0].clone();for(let n=1;n{let t=e[0];for(let n=1;n{let t=e[0];for(let n=1;n1)throw new B("A `Concatenate` layer requires inputs with matching shapes except for the concat axis. Got input shapes: "+JSON.stringify(e))}mergeFunction(e){return W(()=>W1(e,this.axis))}computeOutputShape(e){if(!(Array.isArray(e)&&Array.isArray(e[0])))throw new B("A `Concatenate` layer should be called on a list of inputs.");let t=e,n=t[0].slice(),a=this.axis<0?n.length+this.axis:this.axis;for(let r of t.slice(1)){if(n[a]==null||r[a]==null){n[a]=null;break}n[a]+=r[a]}return n}computeMask(e,t){if(t==null)return null;if(!Array.isArray(t))throw new B("`mask` should be an array for Concatenate");if(!Array.isArray(e))throw new B("`inputs` should be an array for Concatenate");if(t.length!==e.length)throw new B(`Mismatch in the length of mask (${t.length}) and the legnth of inputs (${e.length})`);return W(()=>{let n=!0;if(t.forEach(s=>{if(s!=null){n=!1;return}}),n)return null;let a=[];for(let s=0;s3||t.shape.length>3)throw new Oe("batchDot is not implemented for tensors of 4D or higher rank yet");if(k.assert(e.shape.length>=2,()=>`batchDot requires the rank of x to be >= 2, but got ${e.shape.length}`),k.assert(e.shape.length>=2,()=>`batchDot requires the rank of y to be >= 2, but got ${t.shape.length}`),typeof n=="number"&&(n=[n,n]),e.dtype==="complex64"||t.dtype==="complex64")throw new Oe("batchDot is not implemented for complex64-type Tensors yet.");let a=e.shape.length,r=t.shape.length;n==null&&(n=[a-1,r-2]);let s=n;return W(()=>{let i;if(a>r){i=a-r;let l=[];for(let d=0;da){i=r-a;let l=[];for(let d=0;d0){let l;a>r?l=a+r-3:l=a-1;let d=[];for(let u=l;u"A `Dot` layer should be called on a list of exactly 2 inputs.");let t=e[0],n=e[1];if(t.length>3||n.length>3)throw new Oe("Dot layer does not support tensors of 4D or higher rank yet.");let a=this.interpretAxes(t,n);if(t[a[0]]!==n[a[1]])throw new B(`Dimension incompatibility: ${t[a[0]]} !== ${n[a[1]]}`)}mergeFunction(e){if(e.length!==2)throw new B(`A \`Dot\` layer must be called on exactly 2 inputs, but received ${e.length} input(s).`);let t=e[0],n=e[1],a;return Array.isArray(this.axes)?a=this.axes.map((r,s)=>Bd(r,e[s].shape.length)):a=[Bd(this.axes,t.shape.length),Bd(this.axes,n.shape.length)],this.normalize&&(t=Gh(t,a[0]),n=Gh(n,a[1])),ure(t,n,a)}interpretAxes(e,t){let n;return Array.isArray(this.axes)?n=this.axes:n=[Bd(this.axes,e.length),Bd(this.axes,t.length)],n}computeOutputShape(e){k.assert(Array.isArray(e)&&e.length===2&&Array.isArray(e[0])&&Array.isArray(e[1]),()=>"A `Dot` layer should be called on a list of exactly 2 inputs.");let t=e[0].slice(),n=e[1].slice();if(t.length>3||n.length>3)throw new Oe("Dot layer does not support tensors of 4D or higher rank yet.");let a=this.interpretAxes(t,n);t.splice(a[0],1),n.splice(a[1],1),n.splice(0,1);let r=t.concat(n);return r.length===1&&r.push(1),r}computeMask(e,t){return null}getConfig(){let e={axes:this.axes,normalize:this.normalize},t=super.getConfig();return Object.assign(e,t),e}};Zy.className="Dot";ae.registerClass(Zy);var Yy=class extends Ge{constructor(e){super(e);this.supportsMasking=!0,this.stddev=e.stddev}computeOutputShape(e){return e}getConfig(){let e=super.getConfig(),t={stddev:this.stddev};return Object.assign(t,e),t}call(e,t){return W(()=>{this.invokeCallHook(e,t);let n=_e(e);return Rd(()=>$h(n.shape,0,this.stddev).add(n),()=>n,t.training||!1)})}};Yy.className="GaussianNoise";ae.registerClass(Yy);var Jy=class extends Ge{constructor(e){super(e);this.supportsMasking=!0,this.rate=e.rate}computeOutputShape(e){return e}getConfig(){let e=super.getConfig(),t={rate:this.rate};return Object.assign(t,e),t}call(e,t){return W(()=>{this.invokeCallHook(e,t);let n=_e(e);return this.rate>0&&this.rate<1?Rd(()=>{let a=Math.sqrt(this.rate/(1-this.rate));return n.mul($h(n.shape,1,a))},()=>n,t.training||!1):n})}};Jy.className="GaussianDropout";ae.registerClass(Jy);var Qy=class extends Ge{constructor(e){super(e);this.supportsMasking=!0,this.rate=e.rate,this.noiseShape=e.noiseShape}_getNoiseShape(e){return this.noiseShape||_e(e).shape}computeOutputShape(e){return e}getConfig(){let e=super.getConfig(),t={rate:this.rate};return Object.assign(t,e),t}call(e,t){return W(()=>{if(this.rate<1&&this.rate>0){let n=this._getNoiseShape(e);return Rd(()=>{let a=_e(e),r=1.6732632423543772,s=1.0507009873554805,i=-r*s,o=$r(xl(n),this.rate);o=Td(o,"float32");let l=((1-this.rate)*(1+this.rate*i**2))**-.5,d=-l*i*this.rate;return a.mul(o).add(o.add(-1).mul(i)).mul(l).add(d)},()=>_e(e),t.training||!1)}return e})}};Qy.className="AlphaDropout";ae.registerClass(Qy);function Vd(e,t,n,a,r,s=.001){let i;if(e.rank===2)i=Tb(e,t,n,a,r,s);else if(e.rank===3)i=Eb(e,t,n,a,r,s);else if(e.rank===4)i=Cb(e,t,n,a,r,s);else throw new Oe(`batchNormalization is not implemented for array of rank ${e.rank} yet`);return i}function dre(e,t,n,a,r=.001){return W(()=>{let s=Rc(e,a),i=s.mean,o=s.variance;return[Vd(e,i,o,n,t,r),i,o]})}function pre(e,t,n,a,r=.001){return W(()=>{let s=Rc(e,a),i=s.mean,o=s.variance,l=[];for(let h of wa(0,e.rank))a.indexOf(h)!==-1?l.push(1):l.push(e.shape[h]);let d=i.reshape(l),u=o.reshape(l),p=t==null?null:t.reshape(l),c=n==null?null:n.reshape(l);return[Vd(e,d,u,c,p,r),i,o]})}function cre(e,t,n,a,r=.001){return k.arraysEqual(a.slice().sort(),wa(0,e.rank-1))?dre(e,t,n,a,r):pre(e,t,n,a,r)}var e2=class extends Ge{constructor(e){e==null&&(e={}),super(e),this.supportsMasking=!0,this.axis=e.axis==null?-1:e.axis,this.momentum=e.momentum==null?.99:e.momentum,this.epsilon=e.epsilon==null?.001:e.epsilon,this.center=e.center==null?!0:e.center,this.scale=e.scale==null?!0:e.scale,this.betaInitializer=mt(e.betaInitializer||"zeros"),this.gammaInitializer=mt(e.gammaInitializer||"ones"),this.movingMeanInitializer=mt(e.movingMeanInitializer||"zeros"),this.movingVarianceInitializer=mt(e.movingVarianceInitializer||"ones"),this.betaConstraint=Lt(e.betaConstraint),this.gammaConstraint=Lt(e.gammaConstraint),this.betaRegularizer=At(e.betaRegularizer),this.gammaRegularizer=At(e.gammaRegularizer)}build(e){e=at(e);let t=this.axis>=0?this.axis:this.axis+e.length,n=e[t];if(n==null)throw new B(`Axis ${t} of input tensor should have a defined dimension but the layer received an input with shape ${JSON.stringify(e)}.`);this.inputSpec=[new Mt({ndim:e.length,axes:{[t]:n}})];let a=[n];this.scale&&(this.gamma=this.addWeight("gamma",a,null,this.gammaInitializer,this.gammaRegularizer,!0,this.gammaConstraint)),this.center&&(this.beta=this.addWeight("beta",a,null,this.betaInitializer,this.betaRegularizer,!0,this.betaConstraint)),this.movingMean=this.addWeight("moving_mean",a,null,this.movingMeanInitializer,null,!1),this.movingVariance=this.addWeight("moving_variance",a,null,this.movingVarianceInitializer,null,!1),this.built=!0}call(e,t){return W(()=>{let n=t.training==null?!1:t.training,a=_e(e),r=a.shape,s=r.length,i=wa(0,s),o=this.axis>=0?this.axis:this.axis+s;i.splice(o,1);let l=Ni(1,s);l[o]=r[o];let d=i.slice();d.sort();let u=!k.arraysEqual(d,wa(0,s).slice(0,s-1)),p=()=>{if(u){let A=this.movingMean.read().reshape(l),y=this.movingVariance.read().reshape(l),g=this.center?this.beta.read().reshape(l):null,x=this.scale?this.gamma.read().reshape(l):null;return Vd(a,A,y,g,x,this.epsilon)}else return Vd(a,this.movingMean.read(),this.movingVariance.read(),this.beta==null?null:this.beta.read(),this.gamma==null?null:this.gamma.read(),this.epsilon)};if(!n)return p();let[c,h,m]=cre(a,this.gamma.read(),this.beta.read(),i,this.epsilon),f=(A,y,g)=>{W(()=>{let x=1-g,w=A.read(),b=w.sub(y).mul(x);A.write(w.sub(b))})};return(()=>{f(this.movingMean,h,this.momentum),f(this.movingVariance,m,this.momentum)})(),c})}getConfig(){let e={axis:this.axis,momentum:this.momentum,epsilon:this.epsilon,center:this.center,scale:this.scale,betaInitializer:kt(this.betaInitializer),gammaInitializer:kt(this.gammaInitializer),movingMeanInitializer:kt(this.movingMeanInitializer),movingVarianceInitializer:kt(this.movingVarianceInitializer),betaRegularizer:ut(this.betaRegularizer),gammaRegularizer:ut(this.gammaRegularizer),betaConstraint:Pt(this.betaConstraint),gammaConstraint:Pt(this.gammaConstraint)},t=super.getConfig();return Object.assign(e,t),e}};e2.className="BatchNormalization";ae.registerClass(e2);var t2=class extends Ge{constructor(e){if(e==null&&(e={}),super(e),this.axis=e.axis==null?-1:e.axis,typeof this.axis=="number"){if(!Number.isInteger(this.axis))throw new Error(`Expected axis to be an integer, but received ${this.axis}`)}else if(Array.isArray(this.axis)){for(let t of this.axis)if(!Number.isInteger(t))throw new Error(`Expected axis to be an array of integers, but received ${JSON.stringify(this.axis)}`)}else throw new Error(`Expected axis to be an integer or an array of integers, but received ${JSON.stringify(this.axis)}`);this.epsilon=e.epsilon==null?.001:e.epsilon,this.center=e.center==null?!0:e.center,this.scale=e.scale==null?!0:e.scale,this.betaInitializer=mt(e.betaInitializer||"zeros"),this.gammaInitializer=mt(e.gammaInitializer||"ones"),this.betaRegularizer=At(e.betaRegularizer),this.gammaRegularizer=At(e.gammaRegularizer),this.supportsMasking=!0}build(e){e=at(e);let t=e.length;typeof this.axis=="number"&&(this.axis=[this.axis]);for(let r=0;r=t)throw new Error(`Invalid axis: ${r}`);if(this.axis.length!==Br(this.axis).length)throw new Error(`Found duplicate axes in: ${this.axis}`);let n=this.axis.map(r=>e[r]),a=!0;this.scale?this.gamma=this.addWeight("gamma",n,"float32",this.gammaInitializer,this.gammaRegularizer,a):this.gamma=null,this.center?this.beta=this.addWeight("beta",n,"float32",this.betaInitializer,this.betaRegularizer,a):this.beta=null,this.built=!0}call(e,t){let n=_e(e),a=n.shape,r=a.length;return W(()=>{let s=!0,{mean:i,variance:o}=Rc(n,this.axis,s),l=Ni(1,r);for(let m of this.axis)l[m]=a[m];let d=m=>m!=null&&m.shape.length!==r&&this.axis!==[r-1]?m.reshape(l):m,u=d(this.gamma.read()),p=d(this.beta.read()),c=[],h=[];for(let m=0;m{if(e.rank!==4)throw new B(`temporalPadding expects input tensor to be 4-D, but received a ${e.rank}-D tensor.`);if(t==null&&(t=[[1,1],[1,1]]),t.length!==2||t[0].length!==2||t[1].length!==2)throw new B("spatial2dPadding expects `padding` to be an Array of two Arrays, each of which is an Array of two integers.");if(n==null&&(n=ba()),n!=="channelsLast"&&n!=="channelsFirst")throw new B(`Unknown data format: ${n}. Supported data formats are 'channelsLast' and 'channelsFirst.`);let a;return n==="channelsFirst"?a=[[0,0],[0,0],t[0],t[1]]:a=[[0,0],t[0],t[1],[0,0]],ar(e,a)})}var n2=class extends Ge{constructor(e){if(e==null&&(e={}),super(e),this.dataFormat=e.dataFormat==null?ba():e.dataFormat,e.padding==null)this.padding=[[1,1],[1,1]];else if(typeof e.padding=="number")this.padding=[[e.padding,e.padding],[e.padding,e.padding]];else{if(e.padding=e.padding,e.padding.length!==2)throw new B(`ZeroPadding2D expects padding to be a length-2 array, but received a length-${e.padding.length} array.`);let t,n;if(typeof e.padding[0]=="number")t=[e.padding[0],e.padding[0]],n=[e.padding[1],e.padding[1]];else{if(e.padding=e.padding,e.padding[0].length!==2)throw new B(`ZeroPadding2D expects height padding to be a length-2 array, but received a length-${e.padding[0].length} array.`);if(t=e.padding[0],e.padding[1].length!==2)throw new B(`ZeroPadding2D expects width padding to be a length-2 array, but received a length-${e.padding[1].length} array.`);n=e.padding[1]}this.padding=[t,n]}this.inputSpec=[new Mt({ndim:4})]}computeOutputShape(e){e=at(e);let t,n;return this.dataFormat==="channelsFirst"?(e[2]!=null&&e[2]>=0?t=e[2]+this.padding[0][0]+this.padding[0][1]:t=null,e[3]!=null&&e[3]>=0?n=e[3]+this.padding[1][0]+this.padding[1][1]:n=null,[e[0],e[1],t,n]):(e[1]!=null&&e[1]>=0?t=e[1]+this.padding[0][0]+this.padding[0][1]:t=null,e[2]!=null&&e[2]>=0?n=e[2]+this.padding[1][0]+this.padding[1][1]:n=null,[e[0],t,n,e[3]])}call(e,t){return W(()=>hre(_e(e),this.padding,this.dataFormat))}getConfig(){let e={padding:this.padding,dataFormat:this.dataFormat},t=super.getConfig();return Object.assign(e,t),e}};n2.className="ZeroPadding2D";ae.registerClass(n2);function i0(e,t,n,a,r,s){return W(()=>{Et(r),C6(s),Jn(a),n==null&&(n=[1,1]),a==null&&(a="valid"),r==null&&(r=ba()),s==null&&(s="max"),e=ky(e,r);let i,o=a==="same"?"same":"valid";return s==="max"?i=Yu(e,t,n,o):i=Gu(e,t,n,o),r==="channelsFirst"&&(i=Ze(i,[0,3,1,2])),i})}function G4(e,t,n,a,r,s){return W(()=>{Et(r),C6(s),Jn(a),n==null&&(n=[1,1,1]),a==null&&(a="valid"),r==null&&(r=ba()),s==null&&(s="max"),e=W4(e,r);let i,o=a==="same"?"same":"valid";return s==="max"?i=kA(e,t,n,o):i=oA(e,t,n,o),r==="channelsFirst"&&(i=Ze(i,[0,4,1,2,3])),i})}var q4=class extends Ge{constructor(e){if(e.poolSize==null&&(e.poolSize=2),super(e),typeof e.poolSize=="number")this.poolSize=[e.poolSize];else if(Array.isArray(e.poolSize)&&e.poolSize.length===1&&typeof e.poolSize[0]=="number")this.poolSize=e.poolSize;else throw new B(`poolSize for 1D convolutional layer must be a number or an Array of a single number, but received ${JSON.stringify(e.poolSize)}`);if(Ht(this.poolSize,"poolSize"),e.strides==null)this.strides=this.poolSize;else if(typeof e.strides=="number")this.strides=[e.strides];else if(Array.isArray(e.strides)&&e.strides.length===1&&typeof e.strides[0]=="number")this.strides=e.strides;else throw new B(`strides for 1D convolutional layer must be a number or an Array of a single number, but received ${JSON.stringify(e.strides)}`);Ht(this.strides,"strides"),this.padding=e.padding==null?"valid":e.padding,Jn(this.padding),this.inputSpec=[new Mt({ndim:3})]}computeOutputShape(e){e=at(e);let t=Na(e[1],this.poolSize[0],this.padding,this.strides[0]);return[e[0],t,e[2]]}call(e,t){return W(()=>{this.invokeCallHook(e,t),e=Ed(_e(e),2);let n=this.poolingFunction(_e(e),[this.poolSize[0],1],[this.strides[0],1],this.padding,"channelsLast");return Or(n,[2])})}getConfig(){let e={poolSize:this.poolSize,padding:this.padding,strides:this.strides},t=super.getConfig();return Object.assign(e,t),e}},a2=class extends q4{constructor(e){super(e)}poolingFunction(e,t,n,a,r){return Et(r),Jn(a),i0(e,t,n,a,r,"max")}};a2.className="MaxPooling1D";ae.registerClass(a2);var r2=class extends q4{constructor(e){super(e)}poolingFunction(e,t,n,a,r){return Et(r),Jn(a),i0(e,t,n,a,r,"avg")}};r2.className="AveragePooling1D";ae.registerClass(r2);var X4=class extends Ge{constructor(e){if(e.poolSize==null&&(e.poolSize=[2,2]),super(e),this.poolSize=Array.isArray(e.poolSize)?e.poolSize:[e.poolSize,e.poolSize],e.strides==null)this.strides=this.poolSize;else if(Array.isArray(e.strides)){if(e.strides.length!==2)throw new B(`If the strides property of a 2D pooling layer is an Array, it is expected to have a length of 2, but received length ${e.strides.length}.`);this.strides=e.strides}else this.strides=[e.strides,e.strides];Ht(this.poolSize,"poolSize"),Ht(this.strides,"strides"),this.padding=e.padding==null?"valid":e.padding,this.dataFormat=e.dataFormat==null?"channelsLast":e.dataFormat,Et(this.dataFormat),Jn(this.padding),this.inputSpec=[new Mt({ndim:4})]}computeOutputShape(e){e=at(e);let t=this.dataFormat==="channelsFirst"?e[2]:e[1],n=this.dataFormat==="channelsFirst"?e[3]:e[2];return t=Na(t,this.poolSize[0],this.padding,this.strides[0]),n=Na(n,this.poolSize[1],this.padding,this.strides[1]),this.dataFormat==="channelsFirst"?[e[0],e[1],t,n]:[e[0],t,n,e[3]]}call(e,t){return W(()=>(this.invokeCallHook(e,t),this.poolingFunction(_e(e),this.poolSize,this.strides,this.padding,this.dataFormat)))}getConfig(){let e={poolSize:this.poolSize,padding:this.padding,strides:this.strides,dataFormat:this.dataFormat},t=super.getConfig();return Object.assign(e,t),e}},s2=class extends X4{constructor(e){super(e)}poolingFunction(e,t,n,a,r){return Et(r),Jn(a),i0(e,t,n,a,r,"max")}};s2.className="MaxPooling2D";ae.registerClass(s2);var i2=class extends X4{constructor(e){super(e)}poolingFunction(e,t,n,a,r){return Et(r),Jn(a),i0(e,t,n,a,r,"avg")}};i2.className="AveragePooling2D";ae.registerClass(i2);var K4=class extends Ge{constructor(e){if(e.poolSize==null&&(e.poolSize=[2,2,2]),super(e),this.poolSize=Array.isArray(e.poolSize)?e.poolSize:[e.poolSize,e.poolSize,e.poolSize],e.strides==null)this.strides=this.poolSize;else if(Array.isArray(e.strides)){if(e.strides.length!==3)throw new B(`If the strides property of a 3D pooling layer is an Array, it is expected to have a length of 3, but received length ${e.strides.length}.`);this.strides=e.strides}else this.strides=[e.strides,e.strides,e.strides];Ht(this.poolSize,"poolSize"),Ht(this.strides,"strides"),this.padding=e.padding==null?"valid":e.padding,this.dataFormat=e.dataFormat==null?"channelsLast":e.dataFormat,Et(this.dataFormat),Jn(this.padding),this.inputSpec=[new Mt({ndim:5})]}computeOutputShape(e){e=at(e);let t=this.dataFormat==="channelsFirst"?e[2]:e[1],n=this.dataFormat==="channelsFirst"?e[3]:e[2],a=this.dataFormat==="channelsFirst"?e[4]:e[3];return t=Na(t,this.poolSize[0],this.padding,this.strides[0]),n=Na(n,this.poolSize[1],this.padding,this.strides[1]),a=Na(a,this.poolSize[2],this.padding,this.strides[2]),this.dataFormat==="channelsFirst"?[e[0],e[1],t,n,a]:[e[0],t,n,a,e[4]]}call(e,t){return W(()=>(this.invokeCallHook(e,t),this.poolingFunction(_e(e),this.poolSize,this.strides,this.padding,this.dataFormat)))}getConfig(){let e={poolSize:this.poolSize,padding:this.padding,strides:this.strides,dataFormat:this.dataFormat},t=super.getConfig();return Object.assign(e,t),e}},o2=class extends K4{constructor(e){super(e)}poolingFunction(e,t,n,a,r){return Et(r),Jn(a),G4(e,t,n,a,r,"max")}};o2.className="MaxPooling3D";ae.registerClass(o2);var l2=class extends K4{constructor(e){super(e)}poolingFunction(e,t,n,a,r){return Et(r),Jn(a),G4(e,t,n,a,r,"avg")}};l2.className="AveragePooling3D";ae.registerClass(l2);var Z4=class extends Ge{constructor(e){super(e);this.inputSpec=[new Mt({ndim:3})]}computeOutputShape(e){return[e[0],e[2]]}call(e,t){throw new Oe}},u2=class extends Z4{constructor(e){super(e||{})}call(e,t){return W(()=>{let n=_e(e);return wt(n,1)})}};u2.className="GlobalAveragePooling1D";ae.registerClass(u2);var d2=class extends Z4{constructor(e){super(e||{})}call(e,t){return W(()=>{let n=_e(e);return Xn(n,1)})}};d2.className="GlobalMaxPooling1D";ae.registerClass(d2);var Y4=class extends Ge{constructor(e){super(e);this.dataFormat=e.dataFormat==null?"channelsLast":e.dataFormat,Et(this.dataFormat),this.inputSpec=[new Mt({ndim:4})]}computeOutputShape(e){return e=e,this.dataFormat==="channelsLast"?[e[0],e[3]]:[e[0],e[1]]}call(e,t){throw new Oe}getConfig(){let e={dataFormat:this.dataFormat},t=super.getConfig();return Object.assign(e,t),e}},p2=class extends Y4{call(e,t){return W(()=>{let n=_e(e);return this.dataFormat==="channelsLast"?wt(n,[1,2]):wt(n,[2,3])})}};p2.className="GlobalAveragePooling2D";ae.registerClass(p2);var c2=class extends Y4{call(e,t){return W(()=>{let n=_e(e);return this.dataFormat==="channelsLast"?Xn(n,[1,2]):Xn(n,[2,3])})}};c2.className="GlobalMaxPooling2D";ae.registerClass(c2);var J4=class extends Ge{constructor(e){super(e);this.layer=e.layer}build(e){this.built=!0}get trainable(){return this.layer!=null?this.layer.trainable:!1}set trainable(e){this.layer!=null&&(this.layer.trainable=e)}get trainableWeights(){return this.layer.trainableWeights}get nonTrainableWeights(){return this.layer.nonTrainableWeights}get updates(){return this.layer._updates}get losses(){return this.layer.losses}getWeights(){return this.layer.getWeights()}setWeights(e){this.layer.setWeights(e)}getConfig(){let e={layer:{className:this.layer.getClassName(),config:this.layer.getConfig()}},t=super.getConfig();return Object.assign(e,t),e}setFastWeightInitDuringBuild(e){super.setFastWeightInitDuringBuild(e),this.layer!=null&&this.layer.setFastWeightInitDuringBuild(e)}static fromConfig(e,t,n={}){let a=t.layer,r=Sa(a,n);delete t.layer;let s={layer:r};return Object.assign(s,t),new e(s)}},h2=class extends J4{constructor(e){super(e);this.supportsMasking=!0}build(e){if(e=at(e),e.length<3)throw new B(`TimeDistributed layer expects an input shape >= 3D, but received input shape ${JSON.stringify(e)}`);this.inputSpec=[{shape:e}];let t=[e[0]].concat(e.slice(2));this.layer.built||(this.layer.build(t),this.layer.built=!0),super.build(e)}computeOutputShape(e){e=at(e);let t=[e[0]].concat(e.slice(2)),n=this.layer.computeOutputShape(t),a=e[1];return[n[0],a].concat(n.slice(1))}call(e,t){return W(()=>(e=_e(e),U4((n,a)=>[_e(this.layer.call(n,t)),[]],e,[],!1,null,null,!1,!0)[1]))}};h2.className="TimeDistributed";ae.registerClass(h2);function fre(e){Ei(Ste,"BidirectionalMergeMode",e)}var mre="concat",f2=class extends J4{constructor(e){super(e);let t=e.layer.getConfig(),n={};n.className=e.layer.getClassName(),n.config=t,this.forwardLayer=Sa(n),t.goBackwards=t.goBackwards!==!0;let a={};if(a.className=e.layer.getClassName(),a.config=t,this.backwardLayer=Sa(a),this.forwardLayer.name="forward_"+this.forwardLayer.name,this.backwardLayer.name="backward_"+this.backwardLayer.name,this.mergeMode=e.mergeMode===void 0?mre:e.mergeMode,fre(this.mergeMode),e.weights)throw new Oe("weights support is not implemented for Bidirectional layer yet.");this._stateful=e.layer.stateful,this.returnSequences=e.layer.returnSequences,this.returnState=e.layer.returnState,this.supportsMasking=!0,this._trainable=!0,this.inputSpec=e.layer.inputSpec,this.numConstants=null}get trainable(){return this._trainable}set trainable(e){this._trainable=e,this.forwardLayer!=null&&(this.forwardLayer.trainable=e),this.backwardLayer!=null&&(this.backwardLayer.trainable=e)}getWeights(){return this.forwardLayer.getWeights().concat(this.backwardLayer.getWeights())}setWeights(e){let t=e.length,n=Math.floor(t/2);this.forwardLayer.setWeights(e.slice(0,n)),this.backwardLayer.setWeights(e.slice(n))}computeOutputShape(e){let t=this.forwardLayer.computeOutputShape(e);Array.isArray(t)&&Array.isArray(t[0])||(t=[t]),t=t;let n,a,r;return this.returnState&&(r=t.slice(1)),n=t[0],n=n,this.mergeMode==="concat"?(n[n.length-1]*=2,a=[n]):this.mergeMode==null?a=[n,n.slice()]:a=[n],this.returnState?this.mergeMode==null?a.concat(r).concat(r.slice()):[n].concat(r).concat(r.slice()):Sn(a)}apply(e,t){let n=t==null?null:t.initialState,a=t==null?null:t.constants;t==null&&(t={});let r=j4(e,n,a,this.numConstants);if(e=r.inputs,n=r.initialState,a=r.constants,Array.isArray(e)&&(n=e.slice(1),e=e[0]),(n==null||n.length===0)&&a==null)return super.apply(e,t);let s=[],i=[];if(n!=null){let l=n.length;if(l%2>0)throw new B("When passing `initialState` to a Bidrectional RNN, the state should be an Array containing the states of the underlying RNNs.");t.initialState=n,s.push(...n);let d=n.map(u=>new Mt({shape:u.shape}));this.forwardLayer.stateSpec=d.slice(0,l/2),this.backwardLayer.stateSpec=d.slice(l/2),i.push(...d)}if(a!=null)throw new Oe("Support for constants in Bidirectional layers is not implemented yet.");let o=s[0]instanceof Ia;for(let l of s)if(l instanceof Ia!==o)throw new B("The initial state of a Bidirectional layer cannot be specified as a mix of symbolic and non-symbolic tensors");if(o){let l=[e].concat(s),d=this.inputSpec.concat(i),u=this.inputSpec;this.inputSpec=d;let p=super.apply(l,t);return this.inputSpec=u,p}else return super.apply(e,t)}call(e,t){return W(()=>{let n=t.initialState,a,r;if(n==null)a=this.forwardLayer.call(e,t),r=this.backwardLayer.call(e,t);else{let o=n.slice(0,n.length/2),l=n.slice(n.length/2);a=this.forwardLayer.call(e,Object.assign(t,{initialState:o})),r=this.backwardLayer.call(e,Object.assign(t,{initialState:l}))}let s;this.returnState&&(Array.isArray(a)&&(s=a.slice(1).concat(r.slice(1))),a=a[0],r=r[0]),this.returnSequences&&(r=On(r,1));let i;return this.mergeMode==="concat"?i=W1([a,r]):this.mergeMode==="sum"?i=se(a,r):this.mergeMode==="ave"?i=_(.5,se(a,r)):this.mergeMode==="mul"?i=_(a,r):this.mergeMode==null&&(i=[a,r]),this.returnState?this.mergeMode==null?i.concat(s):[i].concat(s):i})}resetStates(e){this.forwardLayer.resetStates(),this.backwardLayer.resetStates()}build(e){Ci(this.forwardLayer.name,()=>{this.forwardLayer.build(e)}),Ci(this.backwardLayer.name,()=>{this.backwardLayer.build(e)}),this.built=!0}computeMask(e,t){Array.isArray(t)&&(t=t[0]);let n;if(this.returnSequences?this.mergeMode==null?n=[t,t]:n=t:this.mergeMode==null?n=[null,null]:n=null,this.returnState){let a=this.forwardLayer.states.map(r=>null);return Array.isArray(n)?n.concat(a).concat(a):[n].concat(a).concat(a)}else return n}get trainableWeights(){return this.forwardLayer.trainableWeights.concat(this.backwardLayer.trainableWeights)}get nonTrainableWeights(){return this.forwardLayer.nonTrainableWeights.concat(this.backwardLayer.nonTrainableWeights)}setFastWeightInitDuringBuild(e){super.setFastWeightInitDuringBuild(e),this.forwardLayer!=null&&this.forwardLayer.setFastWeightInitDuringBuild(e),this.backwardLayer!=null&&this.backwardLayer.setFastWeightInitDuringBuild(e)}getConfig(){let e={mergeMode:this.mergeMode},t=super.getConfig();return Object.assign(e,t),e}static fromConfig(e,t){let n=Sa(t.layer);if(delete t.layer,t.numConstants!=null)throw new Oe("Deserialization of a Bidirectional layer with numConstants present is not supported yet.");let a=t;return a.layer=n,new e(a)}};f2.className="Bidirectional";ae.registerClass(f2);function Bte(e){return new Bl(e)}function Vte(e){return new by(e)}function jte(e){return new yy(e)}function Ute(e){return new gy(e)}function Hte(e){return new xy(e)}function Gte(e){return new wy(e)}function qte(e){return new vy(e)}function Xte(e){return new e0(e)}function Kte(e){return new Pd(e)}function Zte(e){return new Sy(e)}function Yte(e){return new Ld(e)}function Jte(e){return new Ny(e)}function Qte(e){return new Ty(e)}function ene(e){return new Ey(e)}function tne(e){return new Cy(e)}function nne(e){return new Ry(e)}function ane(e){return new Py(e)}function rne(e){return new zy(e)}function sne(e){return new s0(e)}function ine(e){return new Oy(e)}function one(e){return new _y(e)}function lne(e){return new Ly(e)}function une(e){return new Wy(e)}function dne(e){return new By(e)}function pne(e){return new jy(e)}function cne(e){return new Uy(e)}function hne(e){return new Gy(e)}function fne(e){return new Ky(e)}function mne(e){return new qy(e)}function Ane(e){return new Xy(e)}function yne(e){return new Hy(e)}function gne(e){return new Zy(e)}function xne(e){return new e2(e)}function bne(e){return new t2(e)}function vne(e){return new n2(e)}function K1(e){return new r2(e)}function wne(e){return K1(e)}function kne(e){return K1(e)}function Z1(e){return new i2(e)}function Ine(e){return Z1(e)}function Sne(e){return Z1(e)}function Y1(e){return new l2(e)}function Nne(e){return Y1(e)}function Tne(e){return Y1(e)}function Ene(e){return new u2(e)}function Cne(e){return new p2(e)}function V6(e){return new d2(e)}function j6(e){return new c2(e)}function U6(e){return new a2(e)}function H6(e){return new s2(e)}function Rne(e){return new o2(e)}function Mne(e){return new Fy(e)}function Fne(e){return new a0(e)}function $ne(e){return new $y(e)}function Dne(e){return new Wd(e)}function One(e){return new My(e)}function zne(e){return new n0(e)}function _ne(e){return new Dy(e)}function Pne(e){return new r0(e)}function Lne(e){return new Ua(e)}function Wne(e){return new t0(e)}function Bne(e){return new f2(e)}function Vne(e){return new h2(e)}var jne=V6,Une=j6,Hne=U6,Gne=H6;function qne(e){return new Yy(e)}function Xne(e){return new Jy(e)}function Kne(e){return new Qy(e)}function Zne(e){return new Vy(e)}var Q4={};Fe(Q4,{MAPE:()=>Nre,MSE:()=>Cre,binaryAccuracy:()=>Are,binaryCrossentropy:()=>yre,categoricalAccuracy:()=>xre,categoricalCrossentropy:()=>bre,cosineProximity:()=>kre,mape:()=>Tre,meanAbsoluteError:()=>Ire,meanAbsolutePercentageError:()=>Sre,meanSquaredError:()=>Ere,mse:()=>Rre,precision:()=>vre,recall:()=>wre,sparseCategoricalAccuracy:()=>gre});function Are(e,t){return ay(e,t)}function yre(e,t){return i4(e,t)}function gre(e,t){return o4(e,t)}function xre(e,t){return ry(e,t)}function bre(e,t){return sy(e,t)}function vre(e,t){return s4(e,t)}function wre(e,t){return mae(e,t)}function kre(e,t){return ty(e,t)}function Ire(e,t){return qh(e,t)}function Sre(e,t){return jl(e,t)}function Nre(e,t){return jl(e,t)}function Tre(e,t){return jl(e,t)}function Ere(e,t){return Mi(e,t)}function Cre(e,t){return Mi(e,t)}function Rre(e,t){return Mi(e,t)}var e8={};Fe(e8,{modelFromJSON:()=>Kae});var t8={};Fe(t8,{l1:()=>Fre,l1l2:()=>Mre,l2:()=>$re});function Mre(e){return new zd(e)}function Fre(e){return are(e)}function $re(e){return rre(e)}var n8=class extends Vl{constructor(){super(...arguments);this.model=null}setModel(e){if(!(e instanceof dr))throw new Error("model must be a LayersModel, not some other Container");this.model=e}};function o0(e,t){return et}var r8=class extends n8{constructor(e){super();if(e==null&&(e={}),e.restoreBestWeights)throw new Oe("restoreBestWeights = True is not implemented in EarlyStopping yet.");this.monitor=e.monitor||"val_loss",this.minDelta=Math.abs(e.minDelta||0),this.patience=e.patience||0,this.verbose=e.verbose||0,this.mode=e.mode||"auto",this.baseline=e.baseline,["auto","min","max"].indexOf(this.mode)===-1&&(console.warn(`EarlyStopping mode '${this.mode}' is invalid. Falling back to mode 'auto'.`),this.mode="auto"),this.mode==="min"?this.monitorFunc=o0:this.mode==="max"?this.monitorFunc=a8:this.monitor.indexOf("acc")!==-1?this.monitorFunc=a8:this.monitorFunc=o0,this.monitorFunc===o0&&(this.minDelta*=-1)}async onTrainBegin(e){this.wait=0,this.stoppedEpoch=0,this.baseline!=null?this.best=this.baseline:this.best=this.monitorFunc===o0?Infinity:-Infinity}async onEpochEnd(e,t){await Ur(t);let n=this.getMonitorValue(t);n!=null&&(this.monitorFunc(n-this.minDelta,this.best)?(this.best=n,this.wait=0):(this.wait++,this.wait>=this.patience&&(this.stoppedEpoch=e,this.model.stopTraining=!0)))}async onTrainEnd(e){this.stoppedEpoch>0&&this.verbose&&console.log(`Epoch ${this.stoppedEpoch}: early stopping.`)}getMonitorValue(e){e==null&&(e={});let t=e[this.monitor];return t==null&&console.warn(`Metric for EarlyStopping ${this.monitor} is not available. Available metrics are: ${Object.keys(e)}`),t}};function Dre(e){return new r8(e)}var Ore={earlyStopping:Dre},Ta;(function(e){e[e.DT_INVALID=0]="DT_INVALID",e[e.DT_FLOAT=1]="DT_FLOAT",e[e.DT_DOUBLE=2]="DT_DOUBLE",e[e.DT_INT32=3]="DT_INT32",e[e.DT_UINT8=4]="DT_UINT8",e[e.DT_INT16=5]="DT_INT16",e[e.DT_INT8=6]="DT_INT8",e[e.DT_STRING=7]="DT_STRING",e[e.DT_COMPLEX64=8]="DT_COMPLEX64",e[e.DT_INT64=9]="DT_INT64",e[e.DT_BOOL=10]="DT_BOOL",e[e.DT_QINT8=11]="DT_QINT8",e[e.DT_QUINT8=12]="DT_QUINT8",e[e.DT_QINT32=13]="DT_QINT32",e[e.DT_BFLOAT16=14]="DT_BFLOAT16",e[e.DT_FLOAT_REF=101]="DT_FLOAT_REF",e[e.DT_DOUBLE_REF=102]="DT_DOUBLE_REF",e[e.DT_INT32_REF=103]="DT_INT32_REF",e[e.DT_UINT8_REF=104]="DT_UINT8_REF",e[e.DT_INT16_REF=105]="DT_INT16_REF",e[e.DT_INT8_REF=106]="DT_INT8_REF",e[e.DT_STRING_REF=107]="DT_STRING_REF",e[e.DT_COMPLEX64_REF=108]="DT_COMPLEX64_REF",e[e.DT_INT64_REF=109]="DT_INT64_REF",e[e.DT_BOOL_REF=110]="DT_BOOL_REF",e[e.DT_QINT8_REF=111]="DT_QINT8_REF",e[e.DT_QUINT8_REF=112]="DT_QUINT8_REF",e[e.DT_QINT32_REF=113]="DT_QINT32_REF",e[e.DT_BFLOAT16_REF=114]="DT_BFLOAT16_REF"})(Ta||(Ta={}));var s8;(function(e){let t;(function(n){n[n.LEGACY=0]="LEGACY",n[n.V1=1]="V1",n[n.V2=2]="V2"})(t=e.CheckpointFormatVersion||(e.CheckpointFormatVersion={}))})(s8||(s8={}));var m2={};function zre(e,t){let n={tfOpName:e,category:"custom",inputs:[],attrs:[],customExecutor:t};m2[e]=n}function i8(e){return m2[e]}function _re(e){delete m2[e]}function I(e,t,n,a,r){let s=t.inputParams[e];if(s&&s.inputIndexStart!==void 0){let o=s.inputIndexStart,l=s.inputIndexEnd===0?void 0:s.inputIndexEnd===void 0?o+1:s.inputIndexEnd;if(s.type==="tensor")return mn(t.inputNames[s.inputIndexStart],n,a,r);if(s.type==="tensors")return t.inputNames.slice(o,l).map(p=>mn(p,n,a,r));let d=mn(t.inputNames.slice(o)[0],n,a,r),u=d.dataSync();return s.type==="number"?u[0]:k.toNestedArray(d.shape,u)}let i=t.attrParams[e];return i&&i.value}function mn(e,t,n,a){let[r,s]=Ln(e);if(a!=null){let o=a.getHashTableHandleByName(r);if(o!=null)return o}let i=n.currentContextIds.find(o=>!!t[l0(r,o)]);return i!==void 0?t[l0(r,i)][s]:void 0}function Pre(e,t,n){return t[l0(e,n.currentContextId)]}function pr(e,t){let[n,a]=Ln(e);return[l0(n,t&&t.currentContextId),a]}function l0(e,t){return t?`${e}-${t}`:e}function Ln(e){let t=e.split(":");return t.length===1?[e,0]:[t[0],Number(t[t.length-1])]}function u0(e,t,n){let a=I("pad",e,t,n);if(a==="explicit"){a=I("explicitPaddings",e,t,n);let r=[[0,0],[0,0],[0,0],[0,0]];for(let s=0;s<4;s++)r[s][0]=a[s*2],r[s][1]=a[s*2+1];return r}return a}function cr(e){return e.kept?e:Da(e)}var o8={};Fe(o8,{json:()=>Lre});var Lre=[{tfOpName:"Add",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"AddV2",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"AddN",category:"arithmetic",inputs:[{start:0,end:0,name:"tensors",type:"tensors"}]},{tfOpName:"BiasAdd",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0},{tfName:"data_format",name:"dataFormat",type:"string",notSupported:!0}]},{tfOpName:"Sub",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"RealDiv",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Div",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"DivNoNan",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"FloorDiv",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Mul",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Maximum",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Minimum",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Pow",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"SquaredDifference",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Mod",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"FloorMod",category:"arithmetic",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]}],l8={};Fe(l8,{json:()=>Wre});var Wre=[{tfOpName:"Abs",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Acos",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Asin",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Atan",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Atan2",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"y",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Ceil",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"ClipByValue",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"clipValueMin",type:"number"},{start:2,name:"clipValueMax",type:"number"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Complex",category:"basic_math",inputs:[{start:0,name:"real",type:"tensor"},{start:1,name:"imag",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"ComplexAbs",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Cos",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Cosh",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Elu",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Exp",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Floor",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Log",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Imag",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0},{tfName:"Tout",name:"outputType",type:"dtype",notSupported:!0}]},{tfOpName:"Neg",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Real",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0},{tfName:"Tout",name:"outputType",type:"dtype",notSupported:!0}]},{tfOpName:"Prelu",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"alpha",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Relu",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Relu6",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Selu",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Sigmoid",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Sin",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Sinh",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Sqrt",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Rsqrt",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Square",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Tan",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Tanh",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Sign",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Round",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Expm1",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Log1p",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Reciprocal",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Softplus",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Asinh",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Acosh",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Atanh",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Erf",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Prod",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axes",type:"number[]"}],attrs:[{tfName:"keep_dims",name:"keepDims",type:"bool",notSupported:!0},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"LeakyRelu",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"alpha",name:"alpha",type:"number",defaultValue:.2},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"IsNan",category:"basic_math",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]}],u8={};Fe(u8,{json:()=>Bre});var Bre=[{tfOpName:"EmptyTensorList",category:"control",inputs:[{start:0,name:"elementShape",type:"shape"},{start:1,name:"maxNumElements",type:"number"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"}]},{tfOpName:"LoopCond",category:"control",inputs:[{start:0,name:"pred",type:"tensor"}]},{tfOpName:"Switch",category:"control",inputs:[{start:0,name:"data",type:"tensor"},{start:1,name:"pred",type:"tensor"}]},{tfOpName:"Merge",category:"control",inputs:[{start:0,end:0,name:"tensors",type:"tensors"}]},{tfOpName:"Enter",category:"control",inputs:[{start:0,name:"tensor",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0},{tfName:"frame_name",name:"frameName",type:"string"},{tfName:"is_constant",name:"isConstant",type:"bool"}]},{tfOpName:"Exit",category:"control",inputs:[{start:0,name:"tensor",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"NextIteration",category:"control",inputs:[{start:0,name:"tensor",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"TensorArrayV3",category:"control",inputs:[{start:0,name:"size",type:"number"}],attrs:[{tfName:"dtype",name:"dtype",type:"dtype"},{tfName:"element_shape",name:"elementShape",type:"shape"},{tfName:"dynamic_size",name:"dynamicSize",type:"bool"},{tfName:"clear_after_read",name:"clearAfterRead",type:"bool"},{tfName:"identical_element_shapes",name:"identicalElementShapes",type:"bool"},{tfName:"tensor_array_name",name:"name",type:"string"}]},{tfOpName:"TensorArrayWriteV3",category:"control",inputs:[{start:0,name:"tensorArrayId",type:"tensor"},{start:1,name:"index",type:"number"},{start:2,name:"tensor",type:"tensor"},{start:3,name:"flowIn",type:"number"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"TensorArrayReadV3",category:"control",inputs:[{start:0,name:"tensorArrayId",type:"tensor"},{start:1,name:"index",type:"number"},{start:2,name:"flowIn",type:"number"}],attrs:[{tfName:"dtype",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"TensorArrayGatherV3",category:"control",inputs:[{start:0,name:"tensorArrayId",type:"tensor"},{start:1,name:"indices",type:"number[]"},{start:2,name:"flowIn",type:"number"}],attrs:[{tfName:"dtype",name:"dtype",type:"dtype"},{tfName:"element_shape",name:"elementShape",type:"shape"}]},{tfOpName:"TensorArrayScatterV3",category:"control",inputs:[{start:0,name:"tensorArrayId",type:"tensor"},{start:1,name:"indices",type:"number[]"},{start:2,name:"tensor",type:"tensor"},{start:3,name:"flowIn",type:"number"}],attrs:[{tfName:"T",name:"dtype",type:"dtype"}]},{tfOpName:"TensorArrayConcatV3",category:"control",inputs:[{start:0,name:"tensorArrayId",type:"tensor"},{start:1,name:"flowIn",type:"number"}],attrs:[{tfName:"dtype",name:"dtype",type:"dtype"},{tfName:"element_shape_except0",name:"elementShapeExcept0",type:"shape",notSupported:!0}]},{tfOpName:"TensorArraySplitV3",category:"control",inputs:[{start:0,name:"tensorArrayId",type:"tensor"},{start:1,name:"tensor",type:"tensor"},{start:2,name:"lengths",type:"number[]"},{start:3,name:"flowIn",type:"number"}],attrs:[{tfName:"T",name:"dtype",type:"dtype"}]},{tfOpName:"TensorArraySizeV3",category:"control",inputs:[{start:0,name:"tensorArrayId",type:"tensor"},{start:1,name:"flowIn",type:"number"}]},{tfOpName:"TensorArrayCloseV3",category:"control",inputs:[{start:0,name:"tensorArrayId",type:"tensor"}]},{tfOpName:"StatelessIf",category:"control",inputs:[{start:0,name:"cond",type:"tensor"},{start:1,end:0,name:"args",type:"tensors"}],attrs:[{tfName:"then_branch",name:"thenBranch",type:"func"},{tfName:"else_branch",name:"elseBranch",type:"func"}]},{tfOpName:"If",category:"control",inputs:[{start:0,name:"cond",type:"tensor"},{start:1,end:0,name:"args",type:"tensors"}],attrs:[{tfName:"then_branch",name:"thenBranch",type:"func"},{tfName:"else_branch",name:"elseBranch",type:"func"}]},{tfOpName:"StatelessWhile",category:"control",inputs:[{start:0,end:0,name:"args",type:"tensors"}],attrs:[{tfName:"cond",name:"cond",type:"func"},{tfName:"body",name:"body",type:"func"}]},{tfOpName:"While",category:"control",inputs:[{start:0,end:0,name:"args",type:"tensors"}],attrs:[{tfName:"cond",name:"cond",type:"func"},{tfName:"body",name:"body",type:"func"}]},{tfOpName:"TensorListScatter",category:"control",inputs:[{start:0,name:"tensor",type:"tensor"},{start:1,name:"indices",type:"number[]"},{start:2,name:"elementShape",type:"shape"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"}]},{tfOpName:"TensorListScatterV2",category:"control",inputs:[{start:0,name:"tensor",type:"tensor"},{start:1,name:"indices",type:"number[]"},{start:2,name:"elementShape",type:"shape"},{start:3,name:"numElements",type:"number"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"}]},{tfOpName:"TensorListGather",category:"control",inputs:[{start:0,name:"tensorListId",type:"tensor"},{start:1,name:"indices",type:"number[]"},{start:2,name:"elementShape",type:"shape"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"}]},{tfOpName:"TensorListGetItem",category:"control",inputs:[{start:0,name:"tensorListId",type:"tensor"},{start:1,name:"index",type:"number"},{start:2,name:"elementShape",type:"shape"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"}]},{tfOpName:"TensorListSetItem",category:"control",inputs:[{start:0,name:"tensorListId",type:"tensor"},{start:1,name:"index",type:"number"},{start:2,name:"tensor",type:"tensor"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"}]},{tfOpName:"TensorListReserve",category:"control",inputs:[{start:0,name:"elementShape",type:"shape"},{start:1,name:"numElements",type:"number"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"}]},{tfOpName:"TensorListFromTensor",category:"control",inputs:[{start:0,name:"tensor",type:"tensor"},{start:1,name:"elementShape",type:"shape"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"}]},{tfOpName:"TensorListStack",category:"control",inputs:[{start:0,name:"tensorListId",type:"tensor"},{start:1,name:"elementShape",type:"shape"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"},{tfName:"num_elements",name:"numElements",type:"dtype"}]},{tfOpName:"TensorListSplit",category:"control",inputs:[{start:0,name:"tensor",type:"tensor"},{start:1,name:"elementShape",type:"shape"},{start:2,name:"lengths",type:"number[]"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"}]},{tfOpName:"TensorListConcat",category:"control",inputs:[{start:0,name:"tensorListId",type:"tensor"}],attrs:[{tfName:"element_shape",name:"elementShape",type:"shape"},{tfName:"element_dtype",name:"elementDType",type:"dtype"}]},{tfOpName:"TensorListPopBack",category:"control",inputs:[{start:0,name:"tensorListId",type:"tensor"},{start:1,name:"elementShape",type:"shape"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"}]},{tfOpName:"TensorListPushBack",category:"control",inputs:[{start:0,name:"tensorListId",type:"tensor"},{start:1,name:"tensor",type:"tensor"}],attrs:[{tfName:"element_dtype",name:"elementDType",type:"dtype"}]}],d8={};Fe(d8,{json:()=>Vre});var Vre=[{tfOpName:"AvgPool",category:"convolution",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"data_format",name:"dataFormat",type:"string",notSupported:!0},{tfName:"ksize",name:"kernelSize",type:"number[]"},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"MaxPool",category:"convolution",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"data_format",name:"dataFormat",type:"string",notSupported:!0},{tfName:"ksize",name:"kernelSize",type:"number[]"},{tfName:"explicit_paddings",name:"explicitPaddings",type:"number[]",defaultValue:[],notSupported:!0},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"MaxPoolWithArgmax",category:"convolution",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"ksize",name:"kernelSize",type:"number[]"},{tfName:"include_batch_in_index",name:"includeBatchInIndex",type:"bool"},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"AvgPool3D",category:"convolution",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"data_format",name:"dataFormat",type:"string",notSupported:!0},{tfName:"ksize",name:"kernelSize",type:"number[]"},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"MaxPool3D",category:"convolution",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"data_format",name:"dataFormat",type:"string",notSupported:!0},{tfName:"ksize",name:"kernelSize",type:"number[]"},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Conv1D",category:"convolution",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"filter",type:"tensor"}],attrs:[{tfName:"stride",name:"stride",type:"number"},{tfName:"padding",name:"pad",type:"string"},{tfName:"data_format",name:"dataFormat",type:"string",defaultValue:"NWC"},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0},{tfName:"dilation",name:"dilation",type:"number",defaultValue:1}]},{tfOpName:"Conv2D",category:"convolution",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"filter",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0},{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"useCudnnOnGpu",name:"useCudnnOnGpu",type:"bool"},{tfName:"data_format",name:"dataFormat",type:"string",defaultValue:"NHWC"},{tfName:"explicit_paddings",name:"explicitPaddings",type:"number[]",defaultValue:[]},{tfName:"dilations",name:"dilations",type:"number[]"}]},{tfOpName:"_FusedConv2D",category:"convolution",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"filter",type:"tensor"},{start:2,end:0,name:"args",type:"tensors"}],attrs:[{tfName:"num_args",name:"numArgs",type:"number"},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0},{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"explicit_paddings",name:"explicitPaddings",type:"number[]",defaultValue:[]},{tfName:"use_cudnn_on_gpu",name:"useCudnnOnGpu",type:"bool",defaultValue:!0},{tfName:"data_format",name:"dataFormat",type:"string",defaultValue:"NHWC"},{tfName:"dilations",name:"dilations",type:"number[]",defaultValue:[1,1,1,1]},{tfName:"fused_ops",name:"fusedOps",type:"string[]",defaultValue:[]},{tfName:"epsilon",name:"epsilon",type:"number",defaultValue:1e-4},{tfName:"leakyrelu_alpha",name:"leakyreluAlpha",type:"number"}]},{tfOpName:"Conv2DBackpropInput",category:"convolution",inputs:[{start:2,name:"x",type:"tensor"},{start:1,name:"filter",type:"tensor"},{start:0,name:"outputShape",type:"number[]"}],attrs:[{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"data_format",name:"dataFormat",type:"string",notSupported:!0},{tfName:"explicit_paddings",name:"explicitPaddings",type:"number[]",defaultValue:[]},{tfName:"dilations",name:"dilations",type:"number[]",notSupported:!0}]},{tfOpName:"DepthwiseConv2d",category:"convolution",inputs:[{start:0,name:"input",type:"tensor"},{start:1,name:"filter",type:"tensor"}],attrs:[{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"data_format",name:"dataFormat",type:"string",defaultValue:"NHWC"},{tfName:"explicit_paddings",name:"explicitPaddings",type:"number[]",defaultValue:[]},{tfName:"dilations",name:"dilations",type:"number[]"}]},{tfOpName:"DepthwiseConv2dNative",category:"convolution",inputs:[{start:0,name:"input",type:"tensor"},{start:1,name:"filter",type:"tensor"}],attrs:[{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"data_format",name:"dataFormat",type:"string",defaultValue:"NHWC"},{tfName:"explicit_paddings",name:"explicitPaddings",type:"number[]",defaultValue:[]},{tfName:"dilations",name:"dilations",type:"number[]"}]},{tfOpName:"FusedDepthwiseConv2dNative",category:"convolution",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"filter",type:"tensor"},{start:2,end:0,name:"args",type:"tensors"}],attrs:[{tfName:"num_args",name:"numArgs",type:"number"},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0},{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"data_format",name:"dataFormat",type:"string",defaultValue:"NHWC"},{tfName:"dilations",name:"dilations",type:"number[]",defaultValue:[1,1,1,1]},{tfName:"fused_ops",name:"fusedOps",type:"string[]",defaultValue:[]},{tfName:"explicit_paddings",name:"explicitPaddings",type:"number[]",defaultValue:[]}]},{tfOpName:"Conv3D",category:"convolution",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"filter",type:"tensor"}],attrs:[{tfName:"strides",name:"strides",type:"number[]"},{tfName:"padding",name:"pad",type:"string"},{tfName:"data_format",name:"dataFormat",type:"string",defaultValue:"NHWC"},{tfName:"dilations",name:"dilations",type:"number[]"}]},{tfOpName:"Dilation2D",category:"convolution",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"filter",type:"tensor"}],attrs:[{tfName:"strides",name:"strides",type:"number[]"},{tfName:"rates",name:"dilations",type:"number[]"},{tfName:"padding",name:"pad",type:"string"}]}],p8={};Fe(p8,{json:()=>jre});var jre=[{tfOpName:"Fill",category:"creation",inputs:[{start:0,name:"shape",type:"number[]"},{start:1,name:"value",type:"number"}],attrs:[{tfName:"T",name:"dtype",type:"dtype"}]},{tfOpName:"LinSpace",category:"creation",inputs:[{start:0,name:"start",type:"number"},{start:1,name:"stop",type:"number"},{start:2,name:"num",type:"number"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"OneHot",category:"creation",inputs:[{start:0,name:"indices",type:"tensor"},{start:1,name:"depth",type:"number"},{start:2,name:"onValue",type:"number",defaultValue:1},{start:3,name:"offValue",type:"number",defaultValue:0}],attrs:[{tfName:"axis",name:"axis",type:"number",notSupported:!0},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Ones",category:"creation",inputs:[{start:0,name:"shape",type:"number[]"}],attrs:[{tfName:"T",name:"dtype",type:"dtype"}]},{tfOpName:"OnesLike",category:"creation",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"dtype",name:"dtype",type:"dtype"}]},{tfOpName:"RandomUniform",category:"creation",inputs:[{start:0,name:"shape",type:"number[]"}],attrs:[{tfName:"minval",name:"minval",type:"number",defaultValue:0},{tfName:"maxval",name:"maxval",type:"number",defaultValue:1},{tfName:"dtype",name:"dtype",type:"dtype"},{tfName:"seed",name:"seed",type:"number",defaultValue:0},{tfName:"seed2",name:"seed2",type:"number",defaultValue:0,notSupported:!0},{tfName:"T",name:"T",type:"number",notSupported:!0}]},{tfOpName:"Range",category:"creation",inputs:[{start:0,name:"start",type:"number"},{start:1,name:"stop",type:"number"},{start:2,name:"step",type:"number",defaultValue:0}],attrs:[{tfName:"Tidx",name:"dtype",type:"dtype"}]},{tfOpName:"TruncatedNormal",category:"creation",inputs:[{start:0,name:"shape",type:"number[]"}],attrs:[{tfName:"means",name:"mean",type:"number",defaultValue:0},{tfName:"stddev",name:"stdDev",type:"number",defaultValue:1},{tfName:"seed",name:"seed",type:"number"},{tfName:"seed2",name:"seed2",type:"number",defaultValue:0,notSupported:!0},{tfName:"dtype",name:"dtype",type:"dtype"},{tfName:"T",name:"T",type:"number",notSupported:!0}]},{tfOpName:"Zeros",category:"creation",inputs:[{start:0,name:"shape",type:"number[]"}],attrs:[{tfName:"T",name:"dtype",type:"dtype"}]},{tfOpName:"ZerosLike",category:"creation",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype"}]},{tfOpName:"Multinomial",category:"creation",inputs:[{start:0,name:"logits",type:"tensor"},{start:1,name:"numSamples",type:"number"}],attrs:[{tfName:"seed",name:"seed",type:"number"},{tfName:"seed2",name:"seed2",type:"number"},{tfName:"T",name:"dtype",type:"dtype"},{tfName:"output_dtype",name:"output_dtype",type:"dtype"}]}],c8={};Fe(c8,{json:()=>Ure});var Ure=[{tfOpName:"NonMaxSuppressionV2",category:"dynamic",inputs:[{start:0,name:"boxes",type:"tensor"},{start:1,name:"scores",type:"tensor"},{start:2,name:"maxOutputSize",type:"number"},{start:3,name:"iouThreshold",type:"number"}]},{tfOpName:"NonMaxSuppressionV3",category:"dynamic",inputs:[{start:0,name:"boxes",type:"tensor"},{start:1,name:"scores",type:"tensor"},{start:2,name:"maxOutputSize",type:"number"},{start:3,name:"iouThreshold",type:"number"},{start:4,name:"scoreThreshold",type:"number"}]},{tfOpName:"NonMaxSuppressionV4",category:"dynamic",inputs:[{start:0,name:"boxes",type:"tensor"},{start:1,name:"scores",type:"tensor"},{start:2,name:"maxOutputSize",type:"number"},{start:3,name:"iouThreshold",type:"number"},{start:4,name:"scoreThreshold",type:"number"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0},{tfName:"T_threshold",name:"threshold",type:"dtype",notSupported:!0},{tfName:"pad_to_max_output_size",name:"padToMaxOutputSize",type:"bool"}]},{tfOpName:"NonMaxSuppressionV5",category:"dynamic",inputs:[{start:0,name:"boxes",type:"tensor"},{start:1,name:"scores",type:"tensor"},{start:2,name:"maxOutputSize",type:"number"},{start:3,name:"iouThreshold",type:"number"},{start:4,name:"scoreThreshold",type:"number"},{start:5,name:"softNmsSigma",type:"number"}]},{tfOpName:"Where",category:"dynamic",inputs:[{start:0,name:"condition",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"ListDiff",category:"dynamic",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"y",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]}],h8={};Fe(h8,{json:()=>Hre});var Hre=[{tfOpName:"TopKV2",category:"evaluation",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"k",type:"number"}],attrs:[{tfName:"sorted",name:"sorted",type:"bool"}]},{tfOpName:"Unique",category:"evaluation",inputs:[{start:0,name:"x",type:"tensor"}]},{tfOpName:"UniqueV2",category:"evaluation",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number"}]}],f8={};Fe(f8,{json:()=>Gre});var Gre=[{tfOpName:"PlaceholderWithDefault",category:"graph",inputs:[{start:0,name:"default",type:"tensor"}],attrs:[{tfName:"shape",name:"shape",type:"shape"},{tfName:"dtype",name:"dtype",type:"dtype"}]},{tfOpName:"Placeholder",category:"graph",attrs:[{tfName:"shape",name:"shape",type:"shape"},{tfName:"dtype",name:"dtype",type:"dtype"}]},{tfOpName:"Const",category:"graph"},{tfOpName:"Identity",category:"graph",inputs:[{start:0,name:"x",type:"tensor"}]},{tfOpName:"IdentityN",category:"graph",inputs:[{start:0,end:0,name:"x",type:"tensors"}]},{tfOpName:"Snapshot",category:"graph",inputs:[{start:0,name:"x",type:"tensor"}]},{tfOpName:"Rank",category:"graph",inputs:[{start:0,name:"x",type:"tensor"}]},{tfOpName:"Size",category:"graph",inputs:[{start:0,name:"x",type:"tensor"}]},{tfOpName:"Shape",category:"graph",inputs:[{start:0,name:"x",type:"tensor"}]},{tfOpName:"ShapeN",category:"graph",inputs:[{start:0,end:0,name:"x",type:"tensors"}]},{tfOpName:"Print",category:"graph",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"data",type:"tensors"}],attrs:[{tfName:"message",name:"message",type:"string"},{tfName:"first_n",name:"firstN",type:"number",notSupported:!0},{tfName:"summarize",name:"summarize",type:"number",defaultValue:3}]},{tfOpName:"NoOp",category:"graph",inputs:[]},{tfOpName:"StopGradient",category:"graph",inputs:[{start:0,name:"x",type:"tensor"}]},{tfOpName:"FakeQuantWithMinMaxVars",category:"graph",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"min",name:"min",type:"number"},{tfName:"max",name:"max",type:"number"}]}],m8={};Fe(m8,{json:()=>qre});var qre=[{tfOpName:"HashTable",category:"hash_table",inputs:[],attrs:[{tfName:"shared_name",name:"sharedName",type:"string"},{tfName:"use_node_name_sharing",name:"useNodeNameSharing",type:"bool"},{tfName:"key_dtype",name:"keyDType",type:"dtype"},{tfName:"value_dtype",name:"valueDType",type:"dtype"}]},{tfOpName:"HashTableV2",category:"hash_table",inputs:[],attrs:[{tfName:"shared_name",name:"sharedName",type:"string"},{tfName:"use_node_name_sharing",name:"useNodeNameSharing",type:"bool"},{tfName:"key_dtype",name:"keyDType",type:"dtype"},{tfName:"value_dtype",name:"valueDType",type:"dtype"}]},{tfOpName:"LookupTableImport",category:"hash_table",inputs:[{start:0,name:"tableHandle",type:"tensor"},{start:1,name:"keys",type:"tensor"},{start:2,name:"values",type:"tensor"}],attrs:[{tfName:"Tin",name:"tIn",type:"dtype",notSupported:!0},{tfName:"Tout",name:"tOut",type:"dtype",notSupported:!0}]},{tfOpName:"LookupTableImportV2",category:"hash_table",inputs:[{start:0,name:"tableHandle",type:"tensor"},{start:1,name:"keys",type:"tensor"},{start:2,name:"values",type:"tensor"}],attrs:[{tfName:"Tin",name:"tIn",type:"dtype",notSupported:!0},{tfName:"Tout",name:"tOut",type:"dtype",notSupported:!0}]},{tfOpName:"LookupTableFind",category:"hash_table",inputs:[{start:0,name:"tableHandle",type:"tensor"},{start:1,name:"keys",type:"tensor"},{start:2,name:"defaultValue",type:"tensor"}],attrs:[{tfName:"Tin",name:"tIn",type:"dtype",notSupported:!0},{tfName:"Tout",name:"tOut",type:"dtype",notSupported:!0}]},{tfOpName:"LookupTableFindV2",category:"hash_table",inputs:[{start:0,name:"tableHandle",type:"tensor"},{start:1,name:"keys",type:"tensor"},{start:2,name:"defaultValue",type:"tensor"}],attrs:[{tfName:"Tin",name:"tIn",type:"dtype",notSupported:!0},{tfName:"Tout",name:"tOut",type:"dtype",notSupported:!0}]},{tfOpName:"LookupTableSize",category:"hash_table",inputs:[{start:0,name:"tableHandle",type:"tensor"}]},{tfOpName:"LookupTableSizeV2",category:"hash_table",inputs:[{start:0,name:"tableHandle",type:"tensor"}]}],A8={};Fe(A8,{json:()=>Xre});var Xre=[{tfOpName:"ResizeBilinear",category:"image",inputs:[{start:0,name:"images",type:"tensor"},{start:1,name:"size",type:"number[]"}],attrs:[{tfName:"align_corners",name:"alignCorners",type:"bool"},{tfName:"half_pixel_centers",name:"halfPixelCenters",type:"bool"},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"ResizeNearestNeighbor",category:"image",inputs:[{start:0,name:"images",type:"tensor"},{start:1,name:"size",type:"number[]"}],attrs:[{tfName:"align_corners",name:"alignCorners",type:"bool"},{tfName:"half_pixel_centers",name:"halfPixelCenters",type:"bool"},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"CropAndResize",category:"image",inputs:[{start:0,name:"image",type:"tensor"},{start:1,name:"boxes",type:"tensor"},{start:2,name:"boxInd",type:"tensor"},{start:3,name:"cropSize",type:"number[]"}],attrs:[{tfName:"method",name:"method",type:"string"},{tfName:"extrapolation_value",name:"extrapolationValue",type:"number"}]}],y8={};Fe(y8,{json:()=>Kre});var Kre=[{tfOpName:"Equal",category:"logical",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"NotEqual",category:"logical",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Greater",category:"logical",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"GreaterEqual",category:"logical",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Less",category:"logical",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"LessEqual",category:"logical",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"LogicalAnd",category:"logical",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"LogicalNot",category:"logical",inputs:[{start:0,name:"a",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"LogicalOr",category:"logical",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Select",category:"logical",inputs:[{start:0,name:"condition",type:"tensor"},{start:1,name:"a",type:"tensor"},{start:2,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"SelectV2",category:"logical",inputs:[{start:0,name:"condition",type:"tensor"},{start:1,name:"a",type:"tensor"},{start:2,name:"b",type:"tensor"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]}],g8={};Fe(g8,{json:()=>Zre});var Zre=[{tfOpName:"_FusedMatMul",category:"matrices",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"},{start:2,end:0,name:"args",type:"tensors"}],attrs:[{tfName:"num_args",name:"numArgs",type:"number"},{tfName:"fused_ops",name:"fusedOps",type:"string[]",defaultValue:[]},{tfName:"epsilon",name:"epsilon",type:"number",defaultValue:1e-4},{tfName:"transpose_a",name:"transposeA",type:"bool",defaultValue:!1},{tfName:"transpose_b",name:"transposeB",type:"bool",defaultValue:!1},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"MatMul",category:"matrices",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"transpose_a",name:"transposeA",type:"bool",defaultValue:!1},{tfName:"transpose_b",name:"transposeB",type:"bool",defaultValue:!1},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"BatchMatMul",category:"matrices",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"adj_x",name:"transposeA",type:"bool",defaultValue:!1},{tfName:"adj_y",name:"transposeB",type:"bool",defaultValue:!1},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"BatchMatMulV2",category:"matrices",inputs:[{start:0,name:"a",type:"tensor"},{start:1,name:"b",type:"tensor"}],attrs:[{tfName:"adj_x",name:"transposeA",type:"bool",defaultValue:!1},{tfName:"adj_y",name:"transposeB",type:"bool",defaultValue:!1},{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Transpose",category:"matrices",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"perm",type:"number[]"}],attrs:[{tfName:"T",name:"dtype",type:"dtype",notSupported:!0}]},{tfOpName:"Einsum",category:"matrices",inputs:[{start:0,end:0,name:"tensors",type:"tensors"}],attrs:[{tfName:"equation",name:"equation",type:"string"},{tfName:"N",name:"n",type:"number",defaultValue:2},{tfName:"T",name:"dtype",type:"dtype"}]}],x8={};Fe(x8,{json:()=>Yre});var Yre=[{tfOpName:"FusedBatchNorm",category:"normalization",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"scale",type:"tensor"},{start:2,name:"offset",type:"tensor"},{start:3,name:"mean",type:"tensor"},{start:4,name:"variance",type:"tensor"}],attrs:[{tfName:"epsilon",name:"epsilon",type:"number",defaultValue:.001},{tfName:"data_format",name:"dataFormat",type:"string",notSupported:!0}]},{tfOpName:"FusedBatchNormV2",category:"normalization",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"scale",type:"tensor"},{start:2,name:"offset",type:"tensor"},{start:3,name:"mean",type:"tensor"},{start:4,name:"variance",type:"tensor"}],attrs:[{tfName:"epsilon",name:"epsilon",type:"number",defaultValue:.001},{tfName:"data_format",name:"dataFormat",type:"string",notSupported:!0}]},{tfOpName:"FusedBatchNormV3",category:"normalization",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"scale",type:"tensor"},{start:2,name:"offset",type:"tensor"},{start:3,name:"mean",type:"tensor"},{start:4,name:"variance",type:"tensor"}],attrs:[{tfName:"epsilon",name:"epsilon",type:"number",defaultValue:.001},{tfName:"data_format",name:"dataFormat",type:"string",notSupported:!0}]},{tfOpName:"LRN",category:"normalization",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"depth_radius",name:"radius",type:"number",defaultValue:5},{tfName:"bias",name:"bias",type:"number",defaultValue:1},{tfName:"alpha",name:"alpha",type:"number",defaultValue:1},{tfName:"beta",name:"beta",type:"number",defaultValue:.5}]},{tfOpName:"Softmax",category:"normalization",inputs:[{start:0,name:"x",type:"tensor"}]},{tfOpName:"LogSoftmax",category:"normalization",inputs:[{start:0,name:"x",type:"tensor"}]},{tfOpName:"SparseToDense",category:"normalization",inputs:[{start:0,name:"sparseIndices",type:"tensor"},{start:1,name:"outputShape",type:"number[]"},{start:2,name:"sparseValues",type:"tensor"},{start:3,name:"defaultValue",type:"tensor"}],attrs:[{tfName:"validate_indices",name:"validateIndices",type:"bool",defaultValue:!0,notSupported:!0}]}],b8={};Fe(b8,{json:()=>Jre});var Jre=[{tfOpName:"Bincount",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"size",type:"number"},{start:2,name:"weights",type:"tensor"}]},{tfOpName:"DenseBincount",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"size",type:"number"},{start:2,name:"weights",type:"tensor"}],attrs:[{tfName:"binary_output",name:"binaryOutput",type:"bool"}]},{tfOpName:"Max",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number[]"}],attrs:[{tfName:"keep_dims",name:"keepDims",type:"bool"}]},{tfOpName:"Mean",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number[]"}],attrs:[{tfName:"keep_dims",name:"keepDims",type:"bool"}]},{tfOpName:"Min",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number[]"}],attrs:[{tfName:"keep_dims",name:"keepDims",type:"bool"}]},{tfOpName:"Sum",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number[]"}],attrs:[{tfName:"keep_dims",name:"keepDims",type:"bool"}]},{tfOpName:"All",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number[]"}],attrs:[{tfName:"keep_dims",name:"keepDims",type:"bool"}]},{tfOpName:"Any",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number[]"}],attrs:[{tfName:"keep_dims",name:"keepDims",type:"bool"}]},{tfOpName:"ArgMax",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number"}]},{tfOpName:"ArgMin",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number"}]},{tfOpName:"Prod",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number[]"}],attrs:[{tfName:"keep_dims",name:"keepDims",type:"bool"}]},{tfOpName:"Cumsum",category:"reduction",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number"}],attrs:[{tfName:"exclusive",name:"exclusive",type:"bool"},{tfName:"reverse",name:"reverse",type:"bool"}]}],v8={};Fe(v8,{json:()=>Qre});var Qre=[{tfOpName:"ConcatV2",category:"slice_join",inputs:[{start:0,end:-1,name:"tensors",type:"tensors"},{start:-1,name:"axis",type:"number"}],attrs:[{tfName:"N",name:"n",type:"number",defaultValue:2}]},{tfOpName:"Concat",category:"slice_join",inputs:[{start:1,end:0,name:"tensors",type:"tensors"},{start:0,name:"axis",type:"number"}],attrs:[{tfName:"N",name:"n",type:"number",defaultValue:2}]},{tfOpName:"GatherV2",category:"slice_join",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"indices",type:"tensor"},{start:2,name:"axis",type:"number",defaultValue:0}],attrs:[{tfName:"batch_dims",name:"batchDims",type:"number",defaultValue:0}]},{tfOpName:"Gather",category:"slice_join",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"indices",type:"tensor"}],attrs:[{tfName:"validate_indices",name:"validateIndices",type:"bool",notSupported:!0}]},{tfOpName:"Reverse",category:"slice_join",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"dims",type:"bool[]"}]},{tfOpName:"ReverseV2",category:"slice_join",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number[]"}]},{tfOpName:"Slice",category:"slice_join",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"begin",type:"number[]"},{start:2,name:"size",type:"number[]"}]},{tfOpName:"StridedSlice",category:"slice_join",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"begin",type:"number[]"},{start:2,name:"end",type:"number[]"},{start:3,name:"strides",type:"number[]"}],attrs:[{tfName:"begin_mask",name:"beginMask",type:"number",defaultValue:0},{tfName:"end_mask",name:"endMask",type:"number",defaultValue:0},{tfName:"new_axis_mask",name:"newAxisMask",type:"number",defaultValue:0},{tfName:"ellipsis_mask",name:"ellipsisMask",type:"number",defaultValue:0},{tfName:"shrink_axis_mask",name:"shrinkAxisMask",type:"number",defaultValue:0}]},{tfOpName:"Pack",category:"slice_join",inputs:[{start:0,end:0,name:"tensors",type:"tensors"}],attrs:[{tfName:"axis",name:"axis",type:"number",defaultValue:0}]},{tfOpName:"Unpack",category:"slice_join",inputs:[{start:0,name:"tensor",type:"tensor"}],attrs:[{tfName:"axis",name:"axis",type:"number",defaultValue:0},{tfName:"num",name:"num",type:"number",defaultValue:0,notSupported:!0}]},{tfOpName:"Tile",category:"slice_join",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"reps",type:"number[]"}]},{tfOpName:"Split",category:"slice_join",inputs:[{start:0,name:"axis",type:"number",defaultValue:0},{start:1,name:"x",type:"tensor"}],attrs:[{tfName:"num_split",name:"numOrSizeSplits",type:"number",defaultValue:1}]},{tfOpName:"SplitV",category:"slice_join",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"numOrSizeSplits",type:"number[]"},{start:2,name:"axis",type:"number",defaultValue:0}]},{tfOpName:"ScatterNd",category:"slice_join",inputs:[{start:0,name:"indices",type:"tensor"},{start:1,name:"values",type:"tensor"},{start:2,name:"shape",type:"number[]"}]},{tfOpName:"GatherNd",category:"slice_join",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"indices",type:"tensor"}]},{tfOpName:"SparseToDense",category:"slice_join",inputs:[{start:0,name:"sparseIndices",type:"tensor"},{start:1,name:"outputShape",type:"number[]"},{start:2,name:"sparseValues",type:"tensor"},{start:3,name:"defaultValue",type:"tensor"}],attrs:[{tfName:"validate_indices",name:"validateIndices",type:"bool",defaultValue:!1,notSupported:!0}]}],w8={};Fe(w8,{json:()=>ese});var ese=[{tfOpName:"FFT",category:"spectral",inputs:[{start:0,name:"x",type:"tensor"}]},{tfOpName:"IFFT",category:"spectral",inputs:[{start:0,name:"x",type:"tensor"}]},{tfOpName:"RFFT",category:"spectral",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"fft_length",type:"number",notSupported:!0}]},{tfOpName:"IRFFT",category:"spectral",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"fft_length",type:"number",notSupported:!0}]}],k8={};Fe(k8,{json:()=>tse});var tse=[{tfOpName:"Cast",category:"transformation",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"SrcT",name:"sdtype",type:"dtype",notSupported:!0},{tfName:"DstT",name:"dtype",type:"dtype"}]},{tfOpName:"ExpandDims",category:"transformation",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"axis",type:"number"}]},{tfOpName:"MirrorPad",category:"transformation",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"padding",type:"number[]"}],attrs:[{tfName:"mode",name:"mode",type:"string"}]},{tfOpName:"Pad",category:"transformation",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"padding",type:"number[]"}],attrs:[{tfName:"constant_value",name:"constantValue",type:"number",defaultValue:0}]},{tfOpName:"PadV2",category:"transformation",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"padding",type:"number[]"},{start:2,name:"constantValue",type:"number",defaultValue:0}]},{tfOpName:"Reshape",category:"transformation",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"shape",type:"number[]"}]},{tfOpName:"Squeeze",category:"transformation",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"axis",tfDeprecatedName:"squeeze_dims",name:"axis",type:"number[]"}]},{tfOpName:"SpaceToBatchND",category:"transformation",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"blockShape",type:"number[]"},{start:2,name:"paddings",type:"number[]"}]},{tfOpName:"BatchToSpaceND",category:"transformation",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"blockShape",type:"number[]"},{start:2,name:"crops",type:"number[]"}]},{tfOpName:"DepthToSpace",category:"transformation",inputs:[{start:0,name:"x",type:"tensor"}],attrs:[{tfName:"block_size",name:"blockSize",type:"number"},{tfName:"data_format",name:"dataFormat",type:"string"}]},{tfOpName:"BroadcastTo",category:"transformation",inputs:[{start:0,name:"x",type:"tensor"},{start:1,name:"shape",type:"number[]"}],attrs:[]}],S8=class{static get Instance(){return this._instance||(this._instance=new this)}constructor(){let e=[o8,l8,u8,d8,p8,c8,h8,y8,A8,f8,g8,x8,b8,v8,w8,k8,m8],t=[].concat(...e.map(n=>n.json));this.opMappers=t.reduce((n,a)=>(n[a.tfOpName]=a,n),{})}transformGraph(e,t={}){let n=e.node,a=[],r=[],s=[],i=n.reduce((m,f)=>(m[f.name]=this.mapNode(f),f.op.startsWith("Placeholder")?a.push(m[f.name]):f.op==="Const"?r.push(m[f.name]):(f.input==null||f.input.length===0)&&s.push(m[f.name]),m),{}),o=[],l=[],d={},u={};t!=null&&(d=this.mapSignatureEntries(t.inputs),u=this.mapSignatureEntries(t.outputs));let p=Object.keys(i);p.forEach(m=>{let f=i[m];f.inputNames.forEach(A=>{let[y]=pr(A);f.inputs.push(i[y]),i[y].children.push(f)})}),Object.keys(u).length===0?p.forEach(m=>{let f=i[m];f.children.length===0&&l.push(f)}):Object.keys(u).forEach(m=>{let[f]=pr(m),A=i[f];A!=null&&(A.signatureKey=u[m],l.push(A))}),Object.keys(d).length>0?Object.keys(d).forEach(m=>{let[f]=pr(m),A=i[f];A&&(A.signatureKey=d[m],o.push(A))}):o=a;let c={};e.library!=null&&e.library.function!=null&&(c=e.library.function.reduce((m,f)=>(m[f.signature.name]=this.mapFunction(f),m),{}));let h={nodes:i,inputs:o,outputs:l,weights:r,placeholders:a,signature:t,functions:c};return s.length>0&&(h.initNodes=s),h}mapSignatureEntries(e){return Object.keys(e||{}).reduce((t,n)=>(t[e[n].name]=n,t),{})}mapNode(e){let t=i8(e.op)||this.opMappers[e.op]||{};e.attr==null&&(e.attr={});let n={name:e.name,op:e.op,category:t.category,inputNames:(e.input||[]).map(a=>a.startsWith("^")?a.substr(1):a),inputs:[],children:[],inputParams:{},attrParams:{},rawAttrs:e.attr};return t.inputs!=null&&(n.inputParams=t.inputs.reduce((a,r)=>(a[r.name]={type:r.type,inputIndexStart:r.start,inputIndexEnd:r.end},a),{})),t.attrs!=null&&(n.attrParams=t.attrs.reduce((a,r)=>{let s=r.type,i;switch(r.type){case"string":i=A2(e.attr,r.tfName,r.defaultValue),i===void 0&&!!r.tfDeprecatedName&&(i=A2(e.attr,r.tfDeprecatedName,r.defaultValue));break;case"string[]":i=I2(e.attr,r.tfName,r.defaultValue),i===void 0&&!!r.tfDeprecatedName&&(i=I2(e.attr,r.tfDeprecatedName,r.defaultValue));break;case"number":i=g2(e.attr,r.tfName,r.defaultValue||0),i===void 0&&!!r.tfDeprecatedName&&(i=g2(e.attr,r.tfDeprecatedName,r.defaultValue));break;case"number[]":i=k2(e.attr,r.tfName,r.defaultValue),i===void 0&&!!r.tfDeprecatedName&&(i=k2(e.attr,r.tfDeprecatedName,r.defaultValue));break;case"bool":i=y2(e.attr,r.tfName,r.defaultValue),i===void 0&&!!r.tfDeprecatedName&&(i=y2(e.attr,r.tfDeprecatedName,r.defaultValue));break;case"bool[]":i=N2(e.attr,r.tfName,r.defaultValue),i===void 0&&!!r.tfDeprecatedName&&(i=N2(e.attr,r.tfDeprecatedName,r.defaultValue));break;case"shape":i=w2(e.attr,r.tfName,r.defaultValue),i===void 0&&!!r.tfDeprecatedName&&(i=w2(e.attr,r.tfDeprecatedName,r.defaultValue));break;case"shape[]":i=S2(e.attr,r.tfName,r.defaultValue),i===void 0&&!!r.tfDeprecatedName&&(i=S2(e.attr,r.tfDeprecatedName,r.defaultValue));break;case"dtype":i=b2(e.attr,r.tfName,r.defaultValue),i===void 0&&!!r.tfDeprecatedName&&(i=b2(e.attr,r.tfDeprecatedName,r.defaultValue));break;case"dtype[]":i=v2(e.attr,r.tfName,r.defaultValue),i===void 0&&!!r.tfDeprecatedName&&(i=v2(e.attr,r.tfDeprecatedName,r.defaultValue));break;case"func":i=I8(e.attr,r.tfName,r.defaultValue),i===void 0&&!!r.tfDeprecatedName&&(i=I8(e.attr,r.tfDeprecatedName,r.defaultValue));break;case"tensor":case"tensors":break;default:throw new Error(`Unsupported param type: ${r.type} for op: ${e.op}`)}return a[r.name]={value:i,type:s},a},{})),n}mapFunction(e){let t=e.nodeDef,n=[],a=[],r={};t!=null&&(r=t.reduce((d,u)=>(d[u.name]=this.mapNode(u),u.op==="Const"&&a.push(d[u.name]),d),{}));let s=[],i=[];e.signature.inputArg.forEach(d=>{let[u]=pr(d.name),p={name:u,op:"Placeholder",inputs:[],inputNames:[],category:"graph",inputParams:{},attrParams:{dtype:{value:x2(d.type),type:"dtype"}},children:[]};p.signatureKey=d.name,s.push(p),r[u]=p}),Object.keys(r).forEach(d=>{let u=r[d];u.inputNames.forEach(p=>{let[c]=pr(p);u.inputs.push(r[c]),r[c].children.push(u)})});let o=e.ret;e.signature.outputArg.forEach(d=>{let[u,p]=pr(o[d.name]),c=r[u];c!=null&&(c.defaultOutput=p,i.push(c))});let l=this.mapArgsToSignature(e);return{nodes:r,inputs:s,outputs:i,weights:a,placeholders:n,signature:l}}mapArgsToSignature(e){return{methodName:e.signature.name,inputs:e.signature.inputArg.reduce((t,n)=>(t[n.name]=this.mapArgToTensorInfo(n),t),{}),outputs:e.signature.outputArg.reduce((t,n)=>(t[n.name]=this.mapArgToTensorInfo(n,e.ret),t),{})}}mapArgToTensorInfo(e,t){let n=e.name;return t!=null&&(n=t[n]),{name:n,dtype:e.type}}};function nse(e){let t=J().global;if(typeof t.atob!="undefined")return t.atob(e);if(typeof Buffer!="undefined")return new Buffer(e,"base64").toString();throw new Error("Unable to decode base64 in this environment. Missing built-in atob() or Buffer()")}function N8(e,t){let n=Array.isArray(e)?String.fromCharCode.apply(null,e):nse(e);return t?n:n.toLowerCase()}function A2(e,t,n,a=!1){let r=e[t];return r!=null?N8(r.s,a):n}function y2(e,t,n){let a=e[t];return a?a.b:n}function g2(e,t,n){let a=e[t]||{},r=a.i!=null?a.i:a.f!=null?a.f:n;return typeof r=="number"?r:parseInt(r,10)}function x2(e){switch(typeof e=="string"&&(e=Ta[e]),e){case Ta.DT_FLOAT:return"float32";case Ta.DT_INT32:case Ta.DT_INT64:case Ta.DT_INT8:case Ta.DT_UINT8:return"int32";case Ta.DT_BOOL:return"bool";case Ta.DT_DOUBLE:return"float32";case Ta.DT_STRING:return"string";default:return null}}function I8(e,t,n){let a=e[t];return a&&a.func?a.func.name:n}function b2(e,t,n){let a=e[t];return a&&a.type?x2(a.type):n}function v2(e,t,n){let a=e[t];return a&&a.list&&a.list.type?a.list.type.map(r=>x2(r)):n}function T8(e){if(!e.unknownRank)return e.dim!=null?e.dim.map(t=>typeof t.size=="number"?t.size:parseInt(t.size,10)):[]}function w2(e,t,n){let a=e[t];return a&&a.shape?T8(a.shape):n}function k2(e,t,n){let a=e[t];return a?((a.list.f&&a.list.f.length?a.list.f:a.list.i)||[]).map(r=>typeof r=="number"?r:parseInt(r,10)):n}function I2(e,t,n,a=!1){let r=e[t];return r&&r.list&&r.list.s?r.list.s.map(s=>N8(s,a)):n}function S2(e,t,n){let a=e[t];return a&&a.list&&a.list.shape?a.list.shape.map(r=>T8(r)):n}function N2(e,t,n){let a=e[t];return a&&a.list&&a.list.b?a.list.b:n}var ase=class{constructor(e,t,n){this.node=e,this.tensorMap=t,this.context=n,this.inputs=[],this.attrs={},this.inputs=e.inputNames.map(a=>this.getInput(a)),e.rawAttrs!=null&&(this.attrs=Object.keys(e.rawAttrs).reduce((a,r)=>(a[r]=this.getAttr(r),a),{}))}getInput(e){return mn(e,this.tensorMap,this.context)}getAttr(e,t){let n=this.node.rawAttrs[e];if(n.tensor!=null)return mn(e,this.tensorMap,this.context);if(n.i!=null||n.f!=null)return g2(this.node.rawAttrs,e,t);if(n.s!=null)return A2(this.node.rawAttrs,e,t);if(n.b!=null)return y2(this.node.rawAttrs,e,t);if(n.shape!=null)return w2(this.node.rawAttrs,e,t);if(n.type!=null)return b2(this.node.rawAttrs,e,t);if(n.list!=null){if(n.list.i!=null||n.list.f!=null)return k2(this.node.rawAttrs,e,t);if(n.list.s!=null)return I2(this.node.rawAttrs,e,t);if(n.list.shape!=null)return S2(this.node.rawAttrs,e,t);if(n.list.b!=null)return N2(this.node.rawAttrs,e,t);if(n.list.type!=null)return v2(this.node.rawAttrs,e,t)}return t}},rse=(e,t,n)=>{switch(e.op){case"BiasAdd":case"AddV2":case"Add":return[se(I("a",e,t,n),I("b",e,t,n))];case"AddN":return[yc(I("tensors",e,t,n))];case"FloorMod":case"Mod":return[SA(I("a",e,t,n),I("b",e,t,n))];case"Mul":return[_(I("a",e,t,n),I("b",e,t,n))];case"RealDiv":case"Div":return[me(I("a",e,t,n),I("b",e,t,n))];case"DivNoNan":return[fA(I("a",e,t,n),I("b",e,t,n))];case"FloorDiv":return[Ac(I("a",e,t,n),I("b",e,t,n))];case"Sub":return[ge(I("a",e,t,n),I("b",e,t,n))];case"Minimum":return[gl(I("a",e,t,n),I("b",e,t,n))];case"Maximum":return[_a(I("a",e,t,n),I("b",e,t,n))];case"Pow":return[rr(I("a",e,t,n),I("b",e,t,n))];case"SquaredDifference":return[Bc(I("a",e,t,n),I("b",e,t,n))];default:throw TypeError(`Node type ${e.op} is not implemented`)}},sse=(e,t,n)=>{switch(e.op){case"Abs":case"ComplexAbs":return[Ot(I("x",e,t,n))];case"Acos":return[Ym(I("x",e,t,n))];case"Acosh":return[Jm(I("x",e,t,n))];case"Asin":return[eA(I("x",e,t,n))];case"Asinh":return[tA(I("x",e,t,n))];case"Atan":return[nA(I("x",e,t,n))];case"Atan2":return[aA(I("x",e,t,n),I("y",e,t,n))];case"Atanh":return[rA(I("x",e,t,n))];case"Ceil":return[uA(I("x",e,t,n))];case"Complex":return[Nr(I("real",e,t,n),I("imag",e,t,n))];case"Cos":return[Xu(I("x",e,t,n))];case"Cosh":return[wc(I("x",e,t,n))];case"Elu":return[fl(I("x",e,t,n))];case"Erf":return[mA(I("x",e,t,n))];case"Exp":return[qn(I("x",e,t,n))];case"Expm1":return[AA(I("x",e,t,n))];case"Floor":return[Al(I("x",e,t,n))];case"Log":return[Fn(I("x",e,t,n))];case"Log1p":return[Nc(I("x",e,t,n))];case"Imag":return[Ic(I("x",e,t,n))];case"Neg":return[vt(I("x",e,t,n))];case"Reciprocal":return[EA(I("x",e,t,n))];case"Real":return[ed(I("x",e,t,n))];case"Relu":return[Pa(I("x",e,t,n))];case"Round":return[$c(I("x",e,t,n))];case"Selu":return[Oc(I("x",e,t,n))];case"Sigmoid":return[wn(I("x",e,t,n))];case"Sin":return[zc(I("x",e,t,n))];case"Sign":return[RA(I("x",e,t,n))];case"Sinh":return[_c(I("x",e,t,n))];case"Softplus":return[hi(I("x",e,t,n))];case"Sqrt":return[Jt(I("x",e,t,n))];case"Square":return[st(I("x",e,t,n))];case"Tanh":return[di(I("x",e,t,n))];case"Tan":return[$A(I("x",e,t,n))];case"ClipByValue":return[kn(I("x",e,t,n),I("clipValueMin",e,t,n),I("clipValueMax",e,t,n))];case"Relu6":return[Fc(I("x",e,t,n))];case"Rsqrt":return[Dc(mn(e.inputNames[0],t,n))];case"Prod":return[Mc(I("x",e,t,n),I("axes",e,t,n))];case"LeakyRelu":return[Ku(I("x",e,t,n),I("alpha",e,t,n))];case"Prelu":return[Qu(I("x",e,t,n),I("alpha",e,t,n))];case"IsNan":return[gA(mn(e.inputNames[0],t,n))];default:throw TypeError(`Node type ${e.op} is not implemented`)}};function ca(e,t,n=""){if(!(typeof e=="number"||typeof t=="number")){k.assert(e.length===t.length,()=>n+` Shapes ${e} and ${t} must match`);for(let a=0;an+` Shapes ${e} and ${t} must match`)}}}function E8(e){return!(typeof e=="number"||e.some(t=>t<0))}function jd(e,t,n){let a=T2(e,n),r=!E8(a);if(r&&t.length===0)throw new Error(`Tried to calculate elements of an empty list with non-fully-defined elementShape: ${a}`);if(r&&t.forEach(s=>{a=T2(s.shape,a)}),!E8(a))throw new Error(`Non-fully-defined elementShape: ${a}`);return a}function T2(e,t){if(typeof e=="number")return t;if(typeof t=="number")return e;if(e.length!==t.length)throw new Error(`Incompatible ranks during merge: ${e} vs. ${t}`);let n=[];for(let a=0;a=0&&s>=0&&r!==s)throw new Error(`Incompatible shape during merge: ${e} vs. ${t}`);n[a]=r>=0?r:s}return n}var ise=class{constructor(e,t,n,a,r,s,i){this.name=e,this.dtype=t,this.maxSize=n,this.elementShape=a,this.identicalElementShapes=r,this.dynamicSize=s,this.clearAfterRead=i,this.tensors=[],this.closed_=!1,this.idTensor=Se(0),jt(this.idTensor)}get id(){return this.idTensor.id}get closed(){return this.closed_}clearAndClose(e){this.tensors.forEach(t=>{(e==null||!e.has(t.tensor.id))&&t.tensor.dispose()}),this.tensors=[],this.closed_=!0,this.idTensor.dispose()}size(){return this.tensors.length}read(e){if(this.closed_)throw new Error(`TensorArray ${this.name} has already been closed.`);if(e<0||e>=this.size())throw new Error(`Tried to read from index ${e}, but array size is: ${this.size()}`);let t=this.tensors[e];if(t.cleared)throw new Error(`TensorArray ${this.name}: Could not read index ${e} twice because it was cleared after a previous read (perhaps try setting clear_after_read = false?).`);return this.clearAfterRead&&(t.cleared=!0),t.read=!0,t.tensor}readMany(e){return e.map(t=>this.read(t))}write(e,t){if(this.closed_)throw new Error(`TensorArray ${this.name} has already been closed.`);if(e<0||!this.dynamicSize&&e>=this.maxSize)throw new Error(`Tried to write to index ${e}, but array is not resizeable and size is: ${this.maxSize}`);let n=this.tensors[e]||{};if(t.dtype!==this.dtype)throw new Error(`TensorArray ${this.name}: Could not write to TensorArray index ${e}, + because the value dtype is ${t.dtype}, but TensorArray dtype is ${this.dtype}.`);if(this.size()===0&&(this.elementShape==null||this.elementShape.length===0)&&(this.elementShape=t.shape),ca(this.elementShape,t.shape,`TensorArray ${this.name}: Could not write to TensorArray index ${e}.`),n.read)throw new Error(`TensorArray ${this.name}: Could not write to TensorArray index ${e}, because it has already been read.`);if(n.written)throw new Error(`TensorArray ${this.name}: Could not write to TensorArray index ${e}, because it has already been written.`);n.tensor=t,jt(t),n.written=!0,this.tensors[e]=n}writeMany(e,t){if(e.length!==t.length)throw new Error(`TensorArray ${this.name}: could not write multiple tensors,because the index size: ${e.length} is not the same as tensors size: ${t.length}.`);e.forEach((n,a)=>this.write(n,t[a]))}gather(e,t){if(!!t&&t!==this.dtype)throw new Error(`TensorArray dtype is ${this.dtype} but gather requested dtype ${t}`);if(e)e=e.slice(0,this.size());else{e=[];for(let a=0;a=this.maxSize)throw new Error(`Max index must be < array size (${n} vs. ${this.maxSize})`);this.writeMany(e,la(t,0))}split(e,t){if(t.dtype!==this.dtype)throw new Error(`TensorArray dtype is ${this.dtype} but tensor has dtype ${t.dtype}`);let n=0,a=e.map(o=>(n+=o,n));if(n!==t.shape[0])throw new Error(`Expected sum of lengths to be equal to tensor.shape[0], but sum of lengths is - ${n}, and tensor's shape is: ${t.shape}`);if(!this.dynamicSize&&e.length!==this.maxSize)throw new Error(`TensorArray's size is not equal to the size of lengths (${this.maxSize} vs. ${e.length}), and the TensorArray is not marked as dynamically resizeable`);let r=n===0?0:t.size/n,s=[];W(()=>{t=H(t,[1,n,r]);for(let o=0;o{if(n!==r.dtype)throw new Error(`Invalid data types; op elements ${n}, but list elements ${r.dtype}`);ha(t,r.shape,"TensorList shape mismatch: "),Ut(r)}),this.idTensor=Se(0),this.maxNumElements=a,Ut(this.idTensor)}get id(){return this.idTensor.id}copy(){return new Ud([...this.tensors],this.elementShape,this.elementDtype)}clearAndClose(e){this.tensors.forEach(t=>{(e==null||!e.has(t.id))&&t.dispose()}),this.tensors.length=0,this.idTensor.dispose()}size(){return this.tensors.length}stack(e,t,n=-1){if(t!==this.elementDtype)throw new Error(`Invalid data types; op elements ${t}, but list elements ${this.elementDtype}`);if(n!==-1&&this.tensors.length!==n)throw new Error(`Operation expected a list with ${n} elements but got a list with ${this.tensors.length} elements.`);ha(e,this.elementShape,"TensorList shape mismatch: ");let a=jd(this.elementShape,this.tensors,e);return W(()=>{let r=this.tensors.map(s=>H(s,a));return _n(r,0)})}popBack(e,t){if(t!==this.elementDtype)throw new Error(`Invalid data types; op elements ${t}, but list elements ${this.elementDtype}`);if(this.size()===0)throw new Error("Trying to pop from an empty list.");let n=jd(this.elementShape,this.tensors,e),a=this.tensors.pop();return ha(a.shape,e,"TensorList shape mismatch: "),H(a,n)}pushBack(e){if(e.dtype!==this.elementDtype)throw new Error(`Invalid data types; op elements ${e.dtype}, but list elements ${this.elementDtype}`);if(ha(e.shape,this.elementShape,"TensorList shape mismatch: "),this.maxNumElements===this.size())throw new Error("Trying to push element into a full list.");Ut(e),this.tensors.push(e)}resize(e){if(e<0)throw new Error(`TensorListResize expects size to be non-negative. Got: ${e}`);if(this.maxNumElements!==-1&&e>this.maxNumElements)throw new Error(`TensorListResize input size ${e} is greater maxNumElement ${this.maxNumElements}.`);this.tensors.length=e}getItem(e,t,n){if(n!==this.elementDtype)throw new Error(`Invalid data types; op elements ${n}, but list elements ${this.elementDtype}`);if(e<0||e>this.tensors.length)throw new Error(`Trying to access element ${e} in a list with ${this.tensors.length} elements.`);if(this.tensors[e]==null)throw new Error(`element at index ${e} is null.`);ha(this.tensors[e].shape,t,"TensorList shape mismatch: ");let a=jd(this.elementShape,this.tensors,t);return H(this.tensors[e],a)}setItem(e,t){if(t.dtype!==this.elementDtype)throw new Error(`Invalid data types; op elements ${t.dtype}, but list elements ${this.elementDtype}`);if(e<0||this.maxNumElements!==-1&&e>=this.maxNumElements)throw new Error(`Trying to set element ${e} in a list with max ${this.maxNumElements} elements.`);ha(this.elementShape,t.shape,"TensorList shape mismatch: "),Ut(t),this.tensors[e]=t}gather(e,t,n){if(t!==this.elementDtype)throw new Error(`Invalid data types; op elements ${t}, but list elements ${this.elementDtype}`);ha(this.elementShape,n,"TensorList shape mismatch: "),e=e.slice(0,this.size());let a=jd(this.elementShape,this.tensors,n);return e.length===0?oa([],[0].concat(a)):W(()=>{let r=e.map(s=>H(this.tensors[s],a));return _n(r,0)})}concat(e,t){if(!!e&&e!==this.elementDtype)throw new Error(`TensorList dtype is ${this.elementDtype} but concat requested dtype ${e}`);ha(this.elementShape,t,"TensorList shape mismatch: ");let n=jd(this.elementShape,this.tensors,t);return this.size()===0?oa([],[0].concat(n)):W(()=>{let a=this.tensors.map(r=>H(r,n));return ot(a,0)})}};function ose(e,t,n){let a=e.dtype;if(e.shape.length<1)throw new Error(`Tensor must be at least a vector, but saw shape: ${e.shape}`);if(e.dtype!==n)throw new Error(`Invalid data types; op elements ${e.dtype}, but list elements ${n}`);let r=e.shape.slice(1);ha(r,t,"TensorList shape mismatch: ");let s=ua(e);return new Ud(s,t,a)}function lse(e,t,n){return new Ud([],e,t,n)}function use(e,t,n,a){if(t.length!==e.shape[0])throw new Error(`Expected len(indices) == tensor.shape[0], but saw: ${t.length} vs. ${e.shape[0]}`);let r=Math.max(...t);if(a!=null&&a!==-1&&r>=a)throw new Error(`Max index must be < array size (${r} vs. ${a})`);let s=new Ud([],n,e.dtype,a),i=ua(e,0);return t.forEach((o,l)=>{s.setItem(o,i[l])}),s}function dse(e,t,n){let a=0,r=t.map(u=>(a+=u,a));if(a!==e.shape[0])throw new Error(`Expected sum of lengths to be equal to + ${n}, and tensor's shape is: ${t.shape}`);if(!this.dynamicSize&&e.length!==this.maxSize)throw new Error(`TensorArray's size is not equal to the size of lengths (${this.maxSize} vs. ${e.length}), and the TensorArray is not marked as dynamically resizeable`);let r=n===0?0:t.size/n,s=[];W(()=>{t=H(t,[1,n,r]);for(let o=0;o{if(n!==r.dtype)throw new Error(`Invalid data types; op elements ${n}, but list elements ${r.dtype}`);ca(t,r.shape,"TensorList shape mismatch: "),jt(r)}),this.idTensor=Se(0),this.maxNumElements=a,jt(this.idTensor)}get id(){return this.idTensor.id}copy(){return new Ud([...this.tensors],this.elementShape,this.elementDtype)}clearAndClose(e){this.tensors.forEach(t=>{(e==null||!e.has(t.id))&&t.dispose()}),this.tensors.length=0,this.idTensor.dispose()}size(){return this.tensors.length}stack(e,t,n=-1){if(t!==this.elementDtype)throw new Error(`Invalid data types; op elements ${t}, but list elements ${this.elementDtype}`);if(n!==-1&&this.tensors.length!==n)throw new Error(`Operation expected a list with ${n} elements but got a list with ${this.tensors.length} elements.`);ca(e,this.elementShape,"TensorList shape mismatch: ");let a=jd(this.elementShape,this.tensors,e);return W(()=>{let r=this.tensors.map(s=>H(s,a));return zn(r,0)})}popBack(e,t){if(t!==this.elementDtype)throw new Error(`Invalid data types; op elements ${t}, but list elements ${this.elementDtype}`);if(this.size()===0)throw new Error("Trying to pop from an empty list.");let n=jd(this.elementShape,this.tensors,e),a=this.tensors.pop();return ca(a.shape,e,"TensorList shape mismatch: "),H(a,n)}pushBack(e){if(e.dtype!==this.elementDtype)throw new Error(`Invalid data types; op elements ${e.dtype}, but list elements ${this.elementDtype}`);if(ca(e.shape,this.elementShape,"TensorList shape mismatch: "),this.maxNumElements===this.size())throw new Error("Trying to push element into a full list.");jt(e),this.tensors.push(e)}resize(e){if(e<0)throw new Error(`TensorListResize expects size to be non-negative. Got: ${e}`);if(this.maxNumElements!==-1&&e>this.maxNumElements)throw new Error(`TensorListResize input size ${e} is greater maxNumElement ${this.maxNumElements}.`);this.tensors.length=e}getItem(e,t,n){if(n!==this.elementDtype)throw new Error(`Invalid data types; op elements ${n}, but list elements ${this.elementDtype}`);if(e<0||e>this.tensors.length)throw new Error(`Trying to access element ${e} in a list with ${this.tensors.length} elements.`);if(this.tensors[e]==null)throw new Error(`element at index ${e} is null.`);ca(this.tensors[e].shape,t,"TensorList shape mismatch: ");let a=jd(this.elementShape,this.tensors,t);return H(this.tensors[e],a)}setItem(e,t){if(t.dtype!==this.elementDtype)throw new Error(`Invalid data types; op elements ${t.dtype}, but list elements ${this.elementDtype}`);if(e<0||this.maxNumElements!==-1&&e>=this.maxNumElements)throw new Error(`Trying to set element ${e} in a list with max ${this.maxNumElements} elements.`);ca(this.elementShape,t.shape,"TensorList shape mismatch: "),jt(t),this.tensors[e]=t}gather(e,t,n){if(t!==this.elementDtype)throw new Error(`Invalid data types; op elements ${t}, but list elements ${this.elementDtype}`);ca(this.elementShape,n,"TensorList shape mismatch: "),e=e.slice(0,this.size());let a=jd(this.elementShape,this.tensors,n);return e.length===0?ia([],[0].concat(a)):W(()=>{let r=e.map(s=>H(this.tensors[s],a));return zn(r,0)})}concat(e,t){if(!!e&&e!==this.elementDtype)throw new Error(`TensorList dtype is ${this.elementDtype} but concat requested dtype ${e}`);ca(this.elementShape,t,"TensorList shape mismatch: ");let n=jd(this.elementShape,this.tensors,t);return this.size()===0?ia([],[0].concat(n)):W(()=>{let a=this.tensors.map(r=>H(r,n));return ot(a,0)})}};function ose(e,t,n){let a=e.dtype;if(e.shape.length<1)throw new Error(`Tensor must be at least a vector, but saw shape: ${e.shape}`);if(e.dtype!==n)throw new Error(`Invalid data types; op elements ${e.dtype}, but list elements ${n}`);let r=e.shape.slice(1);ca(r,t,"TensorList shape mismatch: ");let s=la(e);return new Ud(s,t,a)}function lse(e,t,n){return new Ud([],e,t,n)}function use(e,t,n,a){if(t.length!==e.shape[0])throw new Error(`Expected len(indices) == tensor.shape[0], but saw: ${t.length} vs. ${e.shape[0]}`);let r=Math.max(...t);if(a!=null&&a!==-1&&r>=a)throw new Error(`Max index must be < array size (${r} vs. ${a})`);let s=new Ud([],n,e.dtype,a),i=la(e,0);return t.forEach((o,l)=>{s.setItem(o,i[l])}),s}function dse(e,t,n){let a=0,r=t.map(u=>(a+=u,a));if(a!==e.shape[0])throw new Error(`Expected sum of lengths to be equal to tensor.shape[0], but sum of lengths is - ${a}, and tensor's shape is: ${e.shape}`);let s=e.shape.slice(1),i=T2(s,n),o=a===0?0:e.size/a,l=W(()=>{let u=[];e=H(e,[1,a,o]);for(let p=0;p{switch(e.op){case"If":case"StatelessIf":{let a=I("thenBranch",e,t,n),r=I("elseBranch",e,t,n),s=I("cond",e,t,n),i=I("args",e,t,n);return(await s.data())[0]?n.functionMap[a].executeFunctionAsync(i,n.tensorArrayMap,n.tensorListMap):n.functionMap[r].executeFunctionAsync(i,n.tensorArrayMap,n.tensorListMap)}case"While":case"StatelessWhile":{let a=I("body",e,t,n),r=I("cond",e,t,n),s=I("args",e,t,n),i=await n.functionMap[r].executeFunctionAsync(s,n.tensorArrayMap,n.tensorListMap),o=s.map(u=>u.id),l=await i[0].data();i.forEach(u=>{!u.kept&&o.indexOf(u.id)===-1&&u.dispose()});let d=s;for(;l[0];){let u=d;d=await n.functionMap[a].executeFunctionAsync(d,n.tensorArrayMap,n.tensorListMap);let p=d.map(h=>h.id);u.forEach(h=>{!h.kept&&o.indexOf(h.id)===-1&&p.indexOf(h.id)===-1&&h.dispose()});let c=await n.functionMap[r].executeFunctionAsync(d,n.tensorArrayMap,n.tensorListMap);l=await c[0].data(),c.forEach(h=>{!h.kept&&o.indexOf(h.id)===-1&&p.indexOf(h.id)===-1&&h.dispose()})}return d}case"LoopCond":{let a=I("pred",e,t,n);return[hr(a)]}case"Switch":{let a=I("pred",e,t,n),r=I("data",e,t,n);return r.kept||(r=hr(r)),(await a.data())[0]?[void 0,r]:[r,void 0]}case"Merge":{let a=e.inputNames.find(r=>An(r,t,n)!==void 0);if(a){let r=An(a,t,n);return[hr(r)]}return}case"Enter":{let a=I("frameName",e,t,n),r=I("tensor",e,t,n);return n.enterFrame(a),[hr(r)]}case"Exit":{let a=I("tensor",e,t,n);return n.exitFrame(),[hr(a)]}case"NextIteration":{let a=I("tensor",e,t,n);return n.nextIteration(),[hr(a)]}case"TensorArrayV3":{let a=I("size",e,t,n),r=I("dtype",e,t,n),s=I("elementShape",e,t,n),i=I("dynamicSize",e,t,n),o=I("clearAfterRead",e,t,n),l=I("identicalElementShapes",e,t,n),d=I("name",e,t,n),u=new ise(d,r,a,s,l,i,o);return n.addTensorArray(u),[u.idTensor,Se(1)]}case"TensorArrayWriteV3":{let a=I("tensorArrayId",e,t,n),r=I("index",e,t,n),s=I("tensor",e,t,n),i=n.getTensorArray(a.id);return i.write(r,s),[i.idTensor]}case"TensorArrayReadV3":{let a=I("tensorArrayId",e,t,n),r=I("index",e,t,n);return[n.getTensorArray(a.id).read(r)]}case"TensorArrayGatherV3":{let a=I("tensorArrayId",e,t,n),r=I("indices",e,t,n),s=I("dtype",e,t,n);return[n.getTensorArray(a.id).gather(r,s)]}case"TensorArrayScatterV3":{let a=I("tensorArrayId",e,t,n),r=I("indices",e,t,n),s=I("tensor",e,t,n),i=n.getTensorArray(a.id);return i.scatter(r,s),[i.idTensor]}case"TensorArrayConcatV3":{let a=I("tensorArrayId",e,t,n),r=n.getTensorArray(a.id),s=I("dtype",e,t,n);return[r.concat(s)]}case"TensorArraySplitV3":{let a=I("tensorArrayId",e,t,n),r=I("tensor",e,t,n),s=I("lengths",e,t,n),i=n.getTensorArray(a.id);return i.split(s,r),[i.idTensor]}case"TensorArraySizeV3":{let a=I("tensorArrayId",e,t,n),r=n.getTensorArray(a.id);return[Se(r.size(),"int32")]}case"TensorArrayCloseV3":{let a=I("tensorArrayId",e,t,n),r=n.getTensorArray(a.id);return r.clearAndClose(),[r.idTensor]}case"TensorListSetItem":{let a=I("tensorListId",e,t,n),r=I("index",e,t,n),s=I("tensor",e,t,n),i=n.getTensorList(a.id);return i.setItem(r,s),[i.idTensor]}case"TensorListGetItem":{let a=I("tensorListId",e,t,n),r=I("index",e,t,n),s=I("elementShape",e,t,n),i=I("elementDType",e,t,n);return[n.getTensorList(a.id).getItem(r,s,i)]}case"TensorListScatterV2":case"TensorListScatter":{let a=I("indices",e,t,n),r=I("tensor",e,t,n),s=I("elementShape",e,t,n),i=I("numElements",e,t,n),o=use(r,a,s,i);return n.addTensorList(o),[o.idTensor]}case"TensorListReserve":case"EmptyTensorList":{let a=I("elementShape",e,t,n),r=I("elementDType",e,t,n),s;e.op==="TensorListReserve"?s="numElements":s="maxNumElements";let i=I(s,e,t,n),o=lse(a,r,i);return n.addTensorList(o),[o.idTensor]}case"TensorListGather":{let a=I("tensorListId",e,t,n),r=I("indices",e,t,n),s=I("elementShape",e,t,n),i=I("elementDType",e,t,n);return[n.getTensorList(a.id).gather(r,i,s)]}case"TensorListStack":{let a=I("tensorListId",e,t,n),r=I("elementShape",e,t,n),s=I("elementDType",e,t,n),i=I("numElements",e,t,n);return[n.getTensorList(a.id).stack(r,s,i)]}case"TensorListFromTensor":{let a=I("tensor",e,t,n),r=I("elementShape",e,t,n),s=I("elementDType",e,t,n),i=ose(a,r,s);return n.addTensorList(i),[i.idTensor]}case"TensorListConcat":{let a=I("tensorListId",e,t,n),r=n.getTensorList(a.id),s=I("dtype",e,t,n),i=I("elementShape",e,t,n);return[r.concat(s,i)]}case"TensorListPushBack":{let a=I("tensorListId",e,t,n),r=I("tensor",e,t,n),s=n.getTensorList(a.id);return s.pushBack(r),[s.idTensor]}case"TensorListPopBack":{let a=I("tensorListId",e,t,n),r=I("elementShape",e,t,n),s=I("elementDType",e,t,n);return[n.getTensorList(a.id).popBack(r,s)]}case"TensorListSplit":{let a=I("tensor",e,t,n),r=I("elementShape",e,t,n),s=I("lengths",e,t,n),i=dse(a,s,r);return n.addTensorList(i),[i.idTensor]}default:throw TypeError(`Node type ${e.op} is not implemented`)}};function C8(e,t,n){let[a,r]=I("fusedOps",e,t,n),s=a==="biasadd",i=r==="prelu",o=a==="fusedbatchnorm",l=I("numArgs",e,t,n);if(s){if(i&&l!==2)throw new Error("FusedConv2d and DepthwiseConv2d with BiasAdd and Prelu must have two extra arguments: bias and alpha.");if(!i&&l!==1)throw new Error("FusedConv2d and DepthwiseConv2d with BiasAdd must have one extra argument: bias.")}if(o)throw new Error("FusedConv2d and DepthwiseConv2d with FusedBatchNorm is not supported");let d=I("strides",e,t,n),u=u0(e,t,n),p=I("dataFormat",e,t,n).toUpperCase(),c=I("dilations",e,t,n),[h,m]=I("args",e,t,n),f=I("leakyreluAlpha",e,t,n);return{stride:d,pad:u,dataFormat:p,dilations:c,biasArg:h,preluArg:m,activationFunc:r,leakyreluAlpha:f}}var cse=(e,t,n)=>{switch(e.op){case"Conv1D":{let a=I("stride",e,t,n),r=I("pad",e,t,n),s=I("dataFormat",e,t,n).toUpperCase(),i=I("dilation",e,t,n);return[bc(I("x",e,t,n),I("filter",e,t,n),a,r,s,i)]}case"Conv2D":{let a=I("strides",e,t,n),r=u0(e,t,n),s=I("dataFormat",e,t,n).toUpperCase(),i=I("dilations",e,t,n);return[ar(I("x",e,t,n),I("filter",e,t,n),[a[1],a[2]],r,s,[i[1],i[2]])]}case"_FusedConv2D":{let{stride:a,pad:r,dataFormat:s,dilations:i,biasArg:o,preluArg:l,activationFunc:d,leakyreluAlpha:u}=C8(e,t,n);return[_r.conv2d({x:I("x",e,t,n),filter:I("filter",e,t,n),strides:[a[1],a[2]],pad:r,dataFormat:s,dilations:[i[1],i[2]],bias:o,activation:d,preluActivationWeights:l,leakyreluAlpha:u})]}case"FusedDepthwiseConv2dNative":{let{stride:a,pad:r,dataFormat:s,dilations:i,biasArg:o,preluArg:l,activationFunc:d,leakyreluAlpha:u}=C8(e,t,n);return[_r.depthwiseConv2d({x:I("x",e,t,n),filter:I("filter",e,t,n),strides:[a[1],a[2]],pad:r,dataFormat:s,dilations:[i[1],i[2]],bias:o,activation:d,preluActivationWeights:l,leakyreluAlpha:u})]}case"Conv2DBackpropInput":case"Conv2dTranspose":{let a=I("outputShape",e,t,n),r=I("strides",e,t,n),s=u0(e,t,n);return[vc(I("x",e,t,n),I("filter",e,t,n),a,[r[1],r[2]],s)]}case"DepthwiseConv2dNative":case"DepthwiseConv2d":{let a=I("strides",e,t,n),r=u0(e,t,n),s=I("dilations",e,t,n),i=I("dataFormat",e,t,n).toUpperCase();return[fl(I("input",e,t,n),I("filter",e,t,n),[a[1],a[2]],r,i,[s[1],s[2]])]}case"Conv3D":{let a=I("strides",e,t,n),r=I("pad",e,t,n),s=I("dataFormat",e,t,n).toUpperCase(),i=I("dilations",e,t,n);return[pA(I("x",e,t,n),I("filter",e,t,n),[a[1],a[2],a[3]],r,s,[i[1],i[2],i[3]])]}case"AvgPool":{let a=I("strides",e,t,n),r=I("pad",e,t,n),s=I("kernelSize",e,t,n);return[Gu(I("x",e,t,n),[s[1],s[2]],[a[1],a[2]],r)]}case"MaxPool":{let a=I("strides",e,t,n),r=I("pad",e,t,n),s=I("kernelSize",e,t,n);return[Yu(I("x",e,t,n),[s[1],s[2]],[a[1],a[2]],r)]}case"MaxPoolWithArgmax":{let a=I("strides",e,t,n),r=I("pad",e,t,n),s=I("kernelSize",e,t,n),i=I("includeBatchInIndex",e,t,n),{result:o,indexes:l}=qb(I("x",e,t,n),[s[1],s[2]],[a[1],a[2]],r,i);return[o,l]}case"AvgPool3D":{let a=I("strides",e,t,n),r=I("pad",e,t,n),s=I("kernelSize",e,t,n);return[oA(I("x",e,t,n),[s[1],s[2],s[3]],[a[1],a[2],a[3]],r)]}case"MaxPool3D":{let a=I("strides",e,t,n),r=I("pad",e,t,n),s=I("kernelSize",e,t,n);return[kA(I("x",e,t,n),[s[1],s[2],s[3]],[a[1],a[2],a[3]],r)]}case"Dilation2D":{let a=I("strides",e,t,n),r=I("pad",e,t,n),s=I("dilations",e,t,n),i=a[1],o=a[2],l=s[1],d=s[2];return[hA(I("x",e,t,n),I("filter",e,t,n),[i,o],r,[l,d],"NHWC")]}default:throw TypeError(`Node type ${e.op} is not implemented`)}},hse=(e,t,n)=>{switch(e.op){case"Fill":{let a=I("shape",e,t,n),r=I("dtype",e,t,n),s=I("value",e,t,n);return[Al(a,s,r)]}case"LinSpace":{let a=I("start",e,t,n),r=I("stop",e,t,n),s=I("num",e,t,n);return[Wb(a,r,s)]}case"Multinomial":{let a=I("logits",e,t,n),r=I("numSamples",e,t,n),s=I("seed",e,t,n);return[Xb(a,r,s)]}case"OneHot":{let a=I("indices",e,t,n),r=I("depth",e,t,n),s=I("onValue",e,t,n),i=I("offValue",e,t,n);return[ll(a,r,s,i)]}case"Ones":return[Dn(I("shape",e,t,n),I("dtype",e,t,n))];case"OnesLike":return[On(I("x",e,t,n))];case"RandomUniform":return[bl(I("shape",e,t,n),I("minval",e,t,n),I("maxval",e,t,n),I("dtype",e,t,n))];case"Range":{let a=I("start",e,t,n),r=I("stop",e,t,n),s=I("step",e,t,n);return[vl(a,r,s,I("dtype",e,t,n))]}case"TruncatedNormal":{let a=I("shape",e,t,n),r=I("mean",e,t,n),s=I("stdDev",e,t,n),i=I("seed",e,t,n);return[Vc(a,r,s,I("dtype",e,t,n),i)]}case"Zeros":return[Rt(I("shape",e,t,n),I("dtype",e,t,n))];case"ZerosLike":return[Ue(I("x",e,t,n))];default:throw TypeError(`Node type ${e.op} is not implemented`)}};function E2(e,t,n){let a=I("boxes",e,t,n),r=I("scores",e,t,n),s=I("maxOutputSize",e,t,n),i=I("iouThreshold",e,t,n),o=I("scoreThreshold",e,t,n),l=I("softNmsSigma",e,t,n);return{boxes:a,scores:r,maxOutputSize:s,iouThreshold:i,scoreThreshold:o,softNmsSigma:l}}var fse=async(e,t,n)=>{switch(e.op){case"NonMaxSuppressionV5":{let{boxes:a,scores:r,maxOutputSize:s,iouThreshold:i,scoreThreshold:o,softNmsSigma:l}=E2(e,t,n),d=await Ye.nonMaxSuppressionWithScoreAsync(a,r,s,i,o,l);return[d.selectedIndices,d.selectedScores]}case"NonMaxSuppressionV4":{let{boxes:a,scores:r,maxOutputSize:s,iouThreshold:i,scoreThreshold:o}=E2(e,t,n),l=I("padToMaxOutputSize",e,t,n),d=await Ye.nonMaxSuppressionPaddedAsync(a,r,s,i,o,l);return[d.selectedIndices,d.validOutputs]}case"NonMaxSuppressionV3":case"NonMaxSuppressionV2":{let{boxes:a,scores:r,maxOutputSize:s,iouThreshold:i,scoreThreshold:o}=E2(e,t,n);return[await Ye.nonMaxSuppressionAsync(a,r,s,i,o)]}case"Where":{let a=fe(I("condition",e,t,n),"bool"),r=[await zA(a)];return a.dispose(),r}case"ListDiff":return Yb(I("x",e,t,n),I("y",e,t,n));default:throw TypeError(`Node type ${e.op} is not implemented`)}},mse=(e,t,n)=>{switch(e.op){case"TopKV2":{let a=I("x",e,t,n),r=I("k",e,t,n),s=I("sorted",e,t,n),i=DA(a,r,s);return[i.values,i.indices]}case"Unique":{let a=I("x",e,t,n),r=jc(a);return[r.values,r.indices]}case"UniqueV2":{let a=I("x",e,t,n),r=I("axis",e,t,n),s=jc(a,r);return[s.values,s.indices]}default:throw TypeError(`Node type ${e.op} is not implemented`)}},Ase=(e,t,n)=>{switch(e.op){case"Const":return t[e.name];case"PlaceholderWithDefault":let a=I("default",e,t,n);return[An(e.name,t,n)||a];case"Placeholder":return[An(e.name,t,n)];case"Identity":case"StopGradient":case"FakeQuantWithMinMaxVars":{let d=I("x",e,t,n);return[hr(d)]}case"IdentityN":return I("x",e,t,n).map(d=>hr(d));case"Snapshot":let r=I("x",e,t,n);return[hr(r)];case"Shape":return[Et(I("x",e,t,n).shape,"int32")];case"ShapeN":return I("x",e,t,n).map(d=>Et(d.shape));case"Size":return[Se(I("x",e,t,n).size,"int32")];case"Rank":return[Se(I("x",e,t,n).rank,"int32")];case"NoOp":return[Se(1)];case"Print":let s=I("x",e,t,n),i=I("data",e,t,n),o=I("message",e,t,n),l=I("summarize",e,t,n);console.warn("The graph has a tf.print() operation,usually used for debugging, which slows down performance."),console.log(o);for(let d=0;de.dispose()),this.tensorMap.clear(),this.handle.dispose()}size(){return this.tensorMap.size}tensorSize(){return Se(this.size(),"int32")}async import(e,t){this.checkKeyAndValueTensor(e,t);let n=await e.data();return this.tensorMap.forEach(a=>a.dispose()),this.tensorMap.clear(),W(()=>{let a=ua(t),r=n.length,s=a.length;k.assert(r===s,()=>`The number of elements doesn't match, keys has ${r} elements, the values has ${s} elements.`);for(let i=0;i{let a=[];for(let r=0;r{switch(e.op){case"HashTable":case"HashTableV2":{let r=I("keyDType",e,t,n),s=I("valueDType",e,t,n),i=new yse(r,s);return a.addHashTable(e.name,i),[i.handle]}case"LookupTableImport":case"LookupTableImportV2":{let r=I("tableHandle",e,t,n,a),s=I("keys",e,t,n),i=I("values",e,t,n);return[await a.getHashTableById(r.id).import(s,i)]}case"LookupTableFind":case"LookupTableFindV2":{let r=I("tableHandle",e,t,n,a),s=I("keys",e,t,n),i=I("defaultValue",e,t,n);return[await a.getHashTableById(r.id).find(s,i)]}case"LookupTableSize":case"LookupTableSizeV2":{let r=I("tableHandle",e,t,n,a);return[a.getHashTableById(r.id).tensorSize()]}default:throw TypeError(`Node type ${e.op} is not implemented`)}},xse=(e,t,n)=>{switch(e.op){case"ResizeBilinear":{let a=I("images",e,t,n),r=I("size",e,t,n),s=I("alignCorners",e,t,n),i=I("halfPixelCenters",e,t,n);return[Ye.resizeBilinear(a,[r[0],r[1]],s,i)]}case"ResizeNearestNeighbor":{let a=I("images",e,t,n),r=I("size",e,t,n),s=I("alignCorners",e,t,n),i=I("halfPixelCenters",e,t,n);return[Ye.resizeNearestNeighbor(a,[r[0],r[1]],s,i)]}case"CropAndResize":{let a=I("image",e,t,n),r=I("boxes",e,t,n),s=I("boxInd",e,t,n),i=I("cropSize",e,t,n),o=I("method",e,t,n),l=I("extrapolationValue",e,t,n);return[Ye.cropAndResize(a,r,s,i,o,l)]}default:throw TypeError(`Node type ${e.op} is not implemented`)}},bse=(e,t,n)=>{switch(e.op){case"Equal":return[Fr(I("a",e,t,n),I("b",e,t,n))];case"NotEqual":return[Ai(I("a",e,t,n),I("b",e,t,n))];case"Greater":return[Fn(I("a",e,t,n),I("b",e,t,n))];case"GreaterEqual":return[Dr(I("a",e,t,n),I("b",e,t,n))];case"Less":return[Sc(I("a",e,t,n),I("b",e,t,n))];case"LessEqual":return[Or(I("a",e,t,n),I("b",e,t,n))];case"LogicalAnd":return[la(I("a",e,t,n),I("b",e,t,n))];case"LogicalNot":return[Zu(I("a",e,t,n))];case"LogicalOr":return[Cc(I("a",e,t,n),I("b",e,t,n))];case"Select":case"SelectV2":return[an(I("condition",e,t,n),I("a",e,t,n),I("b",e,t,n))];default:throw TypeError(`Node type ${e.op} is not implemented`)}},vse=(e,t,n)=>{switch(e.op){case"BatchMatMul":case"BatchMatMulV2":case"MatMul":return[Be(I("a",e,t,n),I("b",e,t,n),I("transposeA",e,t,n),I("transposeB",e,t,n))];case"Einsum":return[_b(I("equation",e,t,n),...I("tensors",e,t,n))];case"Transpose":return[Ze(I("x",e,t,n),I("perm",e,t,n))];case"_FusedMatMul":let[a,r]=I("fusedOps",e,t,n),s=a==="biasadd",i=r==="prelu",o=I("numArgs",e,t,n),l=I("leakyreluAlpha",e,t,n);if(s){if(i&&o!==2)throw new Error("Fused MatMul with BiasAdd and Prelu must have two extra arguments: bias and alpha.");if(!i&&o!==1)throw new Error("Fused MatMul with BiasAdd must have one extra argument: bias.")}let[d,u]=I("args",e,t,n);return[_r.matMul({a:I("a",e,t,n),b:I("b",e,t,n),transposeA:I("transposeA",e,t,n),transposeB:I("transposeB",e,t,n),bias:d,activation:r,preluActivationWeights:u,leakyreluAlpha:l})];default:throw TypeError(`Node type ${e.op} is not implemented`)}},wse=(e,t,n)=>{switch(e.op){case"FusedBatchNorm":case"FusedBatchNormV2":return[ci(I("x",e,t,n),I("mean",e,t,n),I("variance",e,t,n),I("offset",e,t,n),I("scale",e,t,n),I("epsilon",e,t,n))];case"FusedBatchNormV3":return[ci(I("x",e,t,n),I("mean",e,t,n),I("variance",e,t,n),I("offset",e,t,n),I("scale",e,t,n),I("epsilon",e,t,n))];case"LRN":return[xA(I("x",e,t,n),I("radius",e,t,n),I("bias",e,t,n),I("alpha",e,t,n),I("beta",e,t,n))];case"Softmax":return[nd(I("x",e,t,n))];case"LogSoftmax":return[Ec(I("x",e,t,n))];case"SparseToDense":return[_A(I("sparseIndices",e,t,n),I("outputShape",e,t,n),I("sparseValues",e,t,n),I("defaultValue",e,t,n))];default:throw TypeError(`Node type ${e.op} is not implemented`)}},kse=(e,t,n)=>{switch(e.op){case"Max":{let i=I("axis",e,t,n),o=I("keepDims",e,t,n);return[Kn(I("x",e,t,n),i,o)]}case"Mean":{let i=I("axis",e,t,n),o=I("keepDims",e,t,n);return[kt(I("x",e,t,n),i,o)]}case"Min":{let i=I("axis",e,t,n),o=I("keepDims",e,t,n);return[gl(I("x",e,t,n),i,o)]}case"Sum":{let i=I("axis",e,t,n),o=I("keepDims",e,t,n);return[ke(I("x",e,t,n),i,o)]}case"All":{let i=I("axis",e,t,n),o=I("keepDims",e,t,n);return[gc(I("x",e,t,n),i,o)]}case"Any":{let i=I("axis",e,t,n),o=I("keepDims",e,t,n);return[ju(I("x",e,t,n),i,o)]}case"ArgMax":{let i=I("axis",e,t,n);return[Uu(I("x",e,t,n),i)]}case"ArgMin":{let i=I("axis",e,t,n);return[Qm(I("x",e,t,n),i)]}case"Prod":{let i=I("axis",e,t,n),o=I("keepDims",e,t,n);return[Mc(I("x",e,t,n),i,o)]}case"Cumsum":{let i=I("axis",e,t,n),o=I("exclusive",e,t,n),l=I("reverse",e,t,n);return[kc(I("x",e,t,n),i,o,l)]}case"Bincount":let a=I("x",e,t,n),r=I("weights",e,t,n),s=I("size",e,t,n);return[lA(a,r,s)];case"DenseBincount":{let i=I("x",e,t,n),o=I("weights",e,t,n),l=I("size",e,t,n),d=I("binaryOutput",e,t,n);return[Ob(i,o,l,d)]}default:throw TypeError(`Node type ${e.op} is not implemented`)}},Ise=(e,t,n)=>{switch(e.op){case"ConcatV2":case"Concat":{let a=I("n",e,t,n),r=I("axis",e,t,n),s=I("tensors",e,t,n);return s=s.slice(0,a),[ot(s,r)]}case"Gather":{let a=I("x",e,t,n),r=I("indices",e,t,n);return[hi(a,fe(r,"int32"),0)]}case"GatherV2":{let a=I("axis",e,t,n),r=I("batchDims",e,t,n),s=I("x",e,t,n),i=I("indices",e,t,n);return[hi(s,fe(i,"int32"),a,r)]}case"Reverse":{let a=I("dims",e,t,n),r=[];for(let i=0;i{let a=I("axis",e,t,n),r=I("tensors",e,t,n),s=r[0].shape,i=zr(r[0]).shape,o=r.map(l=>{let d=k.arraysEqual(l.shape,s);if(!d&&!k.arraysEqual(zr(l).shape,i))throw new Error("the input tensors shape does not match");return d?l:H(l,s)});return[_n(o,a)]});case"Unpack":{let a=I("axis",e,t,n),r=I("tensor",e,t,n);return ua(r,a)}case"Tile":{let a=I("reps",e,t,n);return[$r(I("x",e,t,n),a)]}case"Split":case"SplitV":{let a=I("axis",e,t,n),r=I("numOrSizeSplits",e,t,n),s=I("x",e,t,n);return rn(s,r,a)}case"ScatterNd":{let a=I("indices",e,t,n),r=I("values",e,t,n),s=I("shape",e,t,n);return[t3(a,r,s)]}case"GatherNd":{let a=I("x",e,t,n),r=I("indices",e,t,n);return[n3(a,r)]}case"SparseToDense":{let a=I("sparseIndices",e,t,n),r=I("outputShape",e,t,n),s=I("sparseValues",e,t,n),i=I("defaultValue",e,t,n);return[_A(a,s,r,s.dtype===i.dtype?i:fe(i,s.dtype))]}default:throw TypeError(`Node type ${e.op} is not implemented`)}},Sse=(e,t,n)=>{switch(e.op){case"SparseReshape":{let{outputIndices:a,outputShape:r}=y3.sparseReshape(I("inputIndices",e,t,n),I("inputShape",e,t,n),I("newShape",e,t,n));return[a,r]}default:throw TypeError(`Node type ${e.op} is not implemented`)}},Nse=(e,t,n)=>{switch(e.op){case"FFT":return[ad(I("x",e,t,n))];case"IFFT":return[wl(I("x",e,t,n))];case"RFFT":return[rd(I("x",e,t,n))];case"IRFFT":return[Wc(I("x",e,t,n))];default:throw TypeError(`Node type ${e.op} is not implemented`)}},Tse=(e,t,n)=>{switch(e.op){case"Cast":return[fe(I("x",e,t,n),I("dtype",e,t,n))];case"ExpandDims":{let a=I("axis",e,t,n);return[un(I("x",e,t,n),a)]}case"Squeeze":{let a=I("axis",e,t,n);return[zr(I("x",e,t,n),a)]}case"Reshape":return[H(I("x",e,t,n),I("shape",e,t,n))];case"MirrorPad":return[IA(I("x",e,t,n),I("padding",e,t,n),I("mode",e,t,n))];case"PadV2":case"Pad":return[rr(I("x",e,t,n),I("padding",e,t,n),I("constantValue",e,t,n))];case"SpaceToBatchND":{let a=I("blockShape",e,t,n),r=I("paddings",e,t,n);return[Ju(I("x",e,t,n),a,r)]}case"BatchToSpaceND":{let a=I("blockShape",e,t,n),r=I("crops",e,t,n);return[qu(I("x",e,t,n),a,r)]}case"DepthToSpace":{let a=I("blockSize",e,t,n),r=I("dataFormat",e,t,n).toUpperCase();return[cA(I("x",e,t,n),a,r)]}case"BroadcastTo":return[cl(I("x",e,t,n),I("shape",e,t,n))];default:throw TypeError(`Node type ${e.op} is not implemented`)}};function R8(e,t,n,a){let r=((s,i,o)=>{switch(s.category){case"arithmetic":return W(()=>rse(s,i,o));case"basic_math":return W(()=>sse(s,i,o));case"control":return pse(s,i,o);case"convolution":return W(()=>cse(s,i,o));case"creation":return W(()=>hse(s,i,o));case"dynamic":return fse(s,i,o);case"evaluation":return W(()=>mse(s,i,o));case"image":return W(()=>xse(s,i,o));case"graph":return W(()=>Ase(s,i,o));case"logical":return W(()=>bse(s,i,o));case"matrices":return W(()=>vse(s,i,o));case"normalization":return W(()=>wse(s,i,o));case"reduction":return W(()=>kse(s,i,o));case"slice_join":return W(()=>Ise(s,i,o));case"sparse":return W(()=>Sse(s,i,o));case"spectral":return W(()=>Nse(s,i,o));case"transformation":return W(()=>Tse(s,i,o));case"hash_table":return gse(s,i,o,a);case"custom":let l=i8(s.op);if(l&&l.customExecutor)return l.customExecutor(new ase(s,i,o));throw TypeError(`Custom op ${s.op} is not registered.`);default:throw TypeError(`Unknown op '${s.op}'. File an issue at https://github.com/tensorflow/tfjs/issues so we can add it, or register a custom execution with tf.registerOp()`)}})(e,t,n);return k.isPromise(r)?r.then(s=>[].concat(s)):[].concat(r)}var M8=class{constructor(e={},t={},n={},a={}){this.weightMap=e,this.tensorArrayMap=t,this.tensorListMap=n,this.functionMap=a,this.rootContext={id:0,frameName:"",iterationId:0},this.contexts=[this.rootContext],this.lastId=0,this.generateCurrentContextIds()}newFrame(e,t){return{id:e,frameName:t,iterationId:0}}set currentContext(e){this.contexts!==e&&(this.contexts=e,this.generateCurrentContextIds())}get currentContext(){return this.contexts}get currentContextId(){return this._currentContextIds[0]}get currentContextIds(){return this._currentContextIds}generateCurrentContextIds(){let e=[];for(let t=0;tt.id===0&&t.iterationId===0?"":`${t.frameName}-${t.iterationId}`).join("/"):""}enterFrame(e){this.contexts&&(this.lastId++,this.contexts=this.contexts.slice(),this.contexts.push(this.newFrame(this.lastId,e)),this._currentContextIds.unshift(this.contextIdforContexts(this.contexts)))}exitFrame(){if(this.contexts&&this.contexts.length>1)this.contexts=this.contexts.slice(),this.contexts.splice(-1),this.currentContextIds.shift();else throw new Error("Cannot exit frame, the context is empty")}nextIteration(){if(this.contexts&&this.contexts.length>0){this.contexts=this.contexts.slice(),this.lastId++;let e=Object.assign({},this.contexts[this.contexts.length-1]);e.iterationId+=1,e.id=this.lastId,this.contexts.splice(-1,1,e),this._currentContextIds.splice(0,1,this.contextIdforContexts(this.contexts))}else throw new Error("Cannot increase frame iteration, the context is empty")}getWeight(e){return this.weightMap[e]}addTensorArray(e){this.tensorArrayMap[e.id]=e}getTensorArray(e){return this.tensorArrayMap[e]}addTensorList(e){this.tensorListMap[e.id]=e}getTensorList(e){return this.tensorListMap[e]}dispose(e){for(let t in this.tensorArrayMap)this.tensorArrayMap[t].clearAndClose(e);for(let t in this.tensorListMap)this.tensorListMap[t].clearAndClose(e)}};function $8(e,t,n,a){let r=new Set,s=[],i=null,o=null,l=new Set,d=Object.keys(e).map(c=>Wn(c)[0]),u=[];a!=null&&(u=a.map(c=>Wn(c.name)[0]));let p=[...t];for(;p.length>0;){let c=p.pop();if((F8(c)||Ese(c)||Cse(c))&&i==null&&(i=c,o=i.children.map(h=>h.name).filter(h=>r.has(h))),r.add(c.name),n[c.name]==null&&d.indexOf(c.name)===-1&&u.indexOf(c.name)===-1){if(c.inputs.length===0){s.push(c.name);continue}c.inputs.forEach(h=>{l.has(h.name)||(l.add(h.name),p.push(h))})}}return{inputs:e,outputs:t,usedNodes:r,missingInputs:s,dynamicNode:i,syncInputs:o}}function Rse(e,t,n){let{usedNodes:a,inputs:r}=n,s=[],i=Object.keys(r).map(u=>Wn(u)[0]).map(u=>e.nodes[u]),o=e.initNodes;i.forEach(u=>{a.has(u.name)&&s.push(u)}),e.weights.forEach(u=>{a.has(u.name)&&s.push(u)}),o!=null&&o.forEach(u=>{a.has(u.name)&&s.push(u)});let l=new Set,d=[];for(;s.length>0;){let u=s.pop();l.add(u.name),t[u.name]||d.push(u),u.children.forEach(p=>{!l.has(p.name)&&a.has(p.name)&&p.inputs.every(c=>l.has(c.name))&&s.push(p)})}return d}var Mse=["Switch","Merge","Enter","Exit","NextIteration","StatelessIf","StatelessWhile","if","While"],Fse=["NonMaxSuppressionV2","NonMaxSuppressionV3","NonMaxSuppressionV5","Where"],$se=["HashTable","HashTableV2","LookupTableImport","LookupTableImportV2","LookupTableFind","LookupTableFindV2","LookupTableSize","LookupTableSizeV2"];function F8(e){return Mse.indexOf(e.op)>=0}function Ese(e){return Fse.indexOf(e.op)>=0}function Cse(e){return $se.indexOf(e.op)>=0}var C2=class{constructor(e,t){this.graph=e,this.parent=t,this.compiledMap=new Map,this._weightMap={},this.SEPERATOR=",",this._functions={},this._functionExecutorMap={},this._outputs=e.outputs,this._inputs=e.inputs,this._initNodes=e.initNodes,this._signature=e.signature,this._functions=e.functions,e.functions!=null&&Object.keys(e.functions).forEach(n=>{this._functionExecutorMap[n]=new C2(e.functions[n],this)})}get weightIds(){return this.parent?this.parent.weightIds:this._weightIds}get functionExecutorMap(){return this.parent?this.parent.functionExecutorMap:this._functionExecutorMap}get weightMap(){return this.parent?this.parent.weightMap:this._weightMap}set weightMap(e){let t=Object.keys(e).map(n=>e[n].map(a=>a.id));this._weightIds=[].concat(...t),this._weightMap=e}set resourceManager(e){this._resourceManager=e}get inputs(){return this._inputs.map(e=>({name:e.name,shape:e.attrParams.shape?e.attrParams.shape.value:void 0,dtype:e.attrParams.dtype?e.attrParams.dtype.value:void 0}))}get outputs(){return this._outputs.map(e=>({name:e.name,shape:e.attrParams.shape?e.attrParams.shape.value:void 0,dtype:e.attrParams.dtype?e.attrParams.dtype.value:void 0}))}get inputNodes(){return this._inputs.map(e=>e.signatureKey||e.name)}get outputNodes(){return this._outputs.map(e=>{let t=e.signatureKey||e.name;return e.defaultOutput?`${t}:${e.defaultOutput}`:t})}get functions(){return Object.keys(this._functions).reduce((e,t)=>(e[t]=this._functions[t].signature,e),{})}getCompilationKey(e,t){let n=e.map(r=>r.name).sort(),a=t.map(r=>r.name).sort();return n.join(this.SEPERATOR)+"--"+a.join(this.SEPERATOR)}compile(e,t){let n=$8(e,t,this.weightMap,this._initNodes),{missingInputs:a,dynamicNode:r,syncInputs:s}=n;if(r!=null)throw new Error(`This execution contains the node '${r.name}', which has the dynamic op '${r.op}'. Please use model.executeAsync() instead. Alternatively, to avoid the dynamic ops, specify the inputs [${s}]`);if(a.length>0){let i=t.map(l=>l.name),o=Object.keys(e);throw new Error(`Cannot compute the outputs [${i}] from the provided inputs [${o}]. Missing the following inputs: [${a}]`)}return Rse(this.graph,this.weightMap,n)}execute(e,t){e=this.mapInputs(e);let n=Object.keys(e).sort();this.checkInputs(e),this.checkInputShapeAndType(e),t=this.mapOutputs(t),this.checkOutputs(t);let a=n.map(u=>this.graph.nodes[Wn(u)[0]]),r=t.map(u=>Wn(u)[0]),s=r.map(u=>this.graph.nodes[u]);s.length===0&&(s=this._outputs);let i=this.getCompilationKey(a,s),o=this.compiledMap.get(i);o==null&&(o=this.compile(e,s),this.compiledMap.set(i,o));let l={},d={};return W(()=>{let u=new M8(this.weightMap,l,d,this.functionExecutorMap),p=Object.assign({},this.weightMap);Object.keys(e).forEach(m=>{let[f,A]=Wn(m),y=[];y[A]=e[m],p[f]=y});let c=this.getFrozenTensorIds(p),h={};for(let m=0;mAn(m,p,u))})}getFrozenTensorIds(e){let t=[].concat.apply([],Object.keys(e).map(n=>e[n]).map(n=>n.map(a=>a.id)));return new Set(t)}checkTensorForDisposal(e,t,n,a,r,s,i){t.category==="control"||s.indexOf(e)!==-1||(n[e].forEach(o=>{o!=null&&(i[o.id]=(i[o.id]||0)+t.children.length)}),t.inputs.forEach(o=>{if(o.category!=="control"){let l=Pre(o.name,n,a);l!=null&&l.forEach(d=>{if(d&&!d.kept&&!r.has(d.id)){let u=i[d.id];u===1?(d.dispose(),delete i[d.id]):u!=null&&i[d.id]--}})}}))}async executeAsync(e,t){return this._executeAsync(e,t)}async _executeAsync(e,t,n=!1,a={},r={}){n||(e=this.mapInputs(e),this.checkInputs(e),this.checkInputShapeAndType(e),t=this.mapOutputs(t),this.checkOutputs(t));let s=new M8(this.weightMap,a,r,this.functionExecutorMap),i=await this.executeWithControlFlow(e,s,t,n),o=t.map(p=>An(p,i,s)),l=o.map(p=>p.id),d=Object.keys(e).map(p=>e[p].id),u=new Set([...l,...d,...this.weightIds]);return Object.keys(i).forEach(p=>{i[p].forEach(c=>{c&&!c.kept&&!c.isDisposed&&!u.has(c.id)&&c.dispose()})}),this.parent==null&&s.dispose(u),o}async executeFunctionAsync(e,t,n){let a=e.reduce((r,s,i)=>(r[this.inputs[i].name]=s,r),{});return this._executeAsync(a,this.outputNodes,!0,t,n)}async executeWithControlFlow(e,t,n,a){let r=Object.keys(e),s=r.map(g=>this.graph.nodes[Wn(g)[0]]),i=n.map(g=>Wn(g)[0]),o=i.map(g=>this.graph.nodes[g]);o.length===0&&(o=this._outputs);let{usedNodes:l,missingInputs:d,dynamicNode:u,syncInputs:p}=$8(e,o,this.weightMap,this._initNodes),c=[...s,...this.graph.weights,...this._initNodes||[]].map(g=>({node:g,contexts:t.currentContext})),h=Object.assign({},this.weightMap);Object.keys(e).forEach(g=>{let[x,w]=Wn(g),b=[];b[w]=e[g],h[x]=b});let m={},f=this.getFrozenTensorIds(h),A={};for(;c.length>0;){let g=this.processStack(s,c,t,h,A,f,i,m,l);await Promise.all(g)}u==null&&!a&&console.warn("This model execution did not contain any nodes with control flow or dynamic output shapes. You can use model.execute() instead.");let y=o.filter(g=>!F8(g)&&!An(g.name,h,t)).map(g=>g.name);if(y.length>0){let g="";throw u!=null&&(g=`Alternatively, to avoid the dynamic ops, use model.execute() and specify the inputs [${p}]`),new Error(`Cannot compute the outputs [${y}] from the provided inputs [${r}]. Consider providing the following inputs: [${d}]. ${g}`)}return h}processStack(e,t,n,a,r,s,i,o,l){let d=[];for(;t.length>0;){let u=t.pop();n.currentContext=u.contexts;let p="";if(u.node.op==="Enter"&&I("isConstant",u.node,a,n)&&([p]=cr(u.node.name,n)),a[u.node.name]==null){let c=R8(u.node,a,n,this._resourceManager);p||([p]=cr(u.node.name,n));let h=n.currentContext;k.isPromise(c)?d.push(c.then(m=>(a[p]=m,n.currentContext=h,this.checkTensorForDisposal(p,u.node,a,n,s,i,o),this.processChildNodes(u.node,t,n,a,r,l),m))):(a[p]=c,this.checkTensorForDisposal(p,u.node,a,n,s,i,o),this.processChildNodes(u.node,t,n,a,r,l))}else this.processChildNodes(u.node,t,n,a,r,l)}return d}processChildNodes(e,t,n,a,r,s){e.children.forEach(i=>{let[o]=cr(i.name,n);r[o]||!s.has(i.name)||(i.op==="Merge"?i.inputNames.some(l=>!!An(l,a,n))&&(r[o]=!0,t.push({contexts:n.currentContext,node:i})):i.inputNames.every(l=>!!An(l,a,n))&&(r[o]=!0,t.push({contexts:n.currentContext,node:i})))})}dispose(){Object.keys(this.weightMap).forEach(e=>this.weightMap[e].forEach(t=>t.dispose()))}checkInputShapeAndType(e){Object.keys(e).forEach(t=>{let n=e[t],[a]=Wn(t),r=this.graph.nodes[a];if(r.attrParams.shape&&r.attrParams.shape.value){let s=r.attrParams.shape.value,i=s.length===n.shape.length&&n.shape.every((o,l)=>s[l]===-1||s[l]===o);k.assert(i,()=>`The shape of dict['${r.name}'] provided in model.execute(dict) must be [${s}], but was [${n.shape}]`)}r.attrParams.dtype&&r.attrParams.dtype.value&&k.assert(n.dtype===r.attrParams.dtype.value,()=>`The dtype of dict['${r.name}'] provided in model.execute(dict) must be ${r.attrParams.dtype.value}, but was ${n.dtype}`)})}mapInputs(e){let t={};for(let n in e)if(this._signature!=null&&this._signature.inputs!=null&&this._signature.inputs[n]!=null){let a=this._signature.inputs[n];t[a.name]=e[n]}else t[n]=e[n];return t}checkInputs(e){let t=Object.keys(e).filter(n=>{let[a]=Wn(n);return this.graph.nodes[a]==null});if(t.length>0)throw new Error(`The dict provided in model.execute(dict) has keys: [${t}] that are not part of graph`)}mapOutputs(e){return e.map(t=>this._signature!=null&&this._signature.outputs!=null&&this._signature.outputs[t]!=null?this._signature.outputs[t].name:t,{})}checkOutputs(e){e.forEach(t=>{let[n]=Wn(t);if(!this.graph.nodes[n])throw new Error(`The output '${t}' is not found in the graph`)})}},Dse=class{constructor(e={},t={}){this.hashTableNameToHandle=e,this.hashTableMap=t}addHashTable(e,t){this.hashTableNameToHandle[e]=t.handle,this.hashTableMap[t.id]=t}getHashTableHandleByName(e){return this.hashTableNameToHandle[e]}getHashTableById(e){return this.hashTableMap[e]}dispose(){for(let e in this.hashTableMap)this.hashTableMap[e].clearAndClose(),delete this.hashTableMap[e];for(let e in this.hashTableNameToHandle)this.hashTableNameToHandle[e].dispose(),delete this.hashTableNameToHandle[e]}},Ose="?tfjs-format=file",zse="model.json",D8=class{constructor(e,t={}){this.modelUrl=e,this.loadOptions=t,this.version="n/a",t==null&&(this.loadOptions={}),this.resourceManager=new Dse}get modelVersion(){return this.version}get inputNodes(){return this.executor.inputNodes}get outputNodes(){return this.executor.outputNodes}get inputs(){return this.executor.inputs}get outputs(){return this.executor.outputs}get weights(){return this.executor.weightMap}get metadata(){return this.artifacts.userDefinedMetadata}get modelSignature(){return this.signature}findIOHandler(){let e=this.modelUrl;if(e.load!=null)this.handler=e;else if(this.loadOptions.requestInit!=null)this.handler=wn.browserHTTPRequest(e,this.loadOptions);else{let t=wn.getLoadHandlers(e,this.loadOptions);if(t.length===0)t.push(wn.browserHTTPRequest(e,this.loadOptions));else if(t.length>1)throw new Error(`Found more than one (${t.length}) load handlers for URL '${[e]}'`);this.handler=t[0]}}async load(){if(this.findIOHandler(),this.handler.load==null)throw new Error("Cannot proceed with model loading because the IOHandler provided does not have the `load` method implemented.");let e=await this.handler.load();return this.loadSync(e)}loadSync(e){this.artifacts=e;let t=this.artifacts.modelTopology,n;this.artifacts.userDefinedMetadata!=null&&this.artifacts.userDefinedMetadata.signature!=null?n=this.artifacts.userDefinedMetadata.signature:n=this.artifacts.signature,this.signature=n,this.version=`${t.versions.producer}.${t.versions.minConsumer}`;let a=wn.decodeWeights(this.artifacts.weightData,this.artifacts.weightSpecs);if(this.executor=new C2(S8.Instance.transformGraph(t,this.signature)),this.executor.weightMap=this.convertTensorMapToTensorsMap(a),this.executor.resourceManager=this.resourceManager,e.modelInitializer!=null&&e.modelInitializer.node!=null){let r=S8.Instance.transformGraph(e.modelInitializer);this.initializer=new C2(r),this.initializer.weightMap=this.executor.weightMap,this.initializer.resourceManager=this.resourceManager,this.initializer.executeAsync({},[])}return!0}async save(e,t){if(typeof e=="string"){let n=wn.getSaveHandlers(e);if(n.length===0)throw new Error(`Cannot find any save handlers for URL '${e}'`);if(n.length>1)throw new Error(`Found more than one (${n.length}) save handlers for URL '${e}'`);e=n[0]}if(e.save==null)throw new Error("GraphModel.save() cannot proceed because the IOHandler provided does not have the `save` attribute defined.");return e.save(this.artifacts)}predict(e,t){return this.execute(e,this.outputNodes)}normalizeInputs(e){if(!(e instanceof Le)&&!Array.isArray(e))return e;if(e=Array.isArray(e)?e:[e],e.length!==this.inputNodes.length)throw new Error(`Input tensor count mismatch,the graph model has ${this.inputNodes.length} placeholders, while there are ${e.length} input tensors.`);return this.inputNodes.reduce((t,n,a)=>(t[n]=e[a],t),{})}normalizeOutputs(e){return e=e||this.outputNodes,Array.isArray(e)?e:[e]}execute(e,t){e=this.normalizeInputs(e),t=this.normalizeOutputs(t);let n=this.executor.execute(e,t);return n.length>1?n:n[0]}async executeAsync(e,t){e=this.normalizeInputs(e),t=this.normalizeOutputs(t);let n=await this.executor.executeAsync(e,t);return n.length>1?n:n[0]}convertTensorMapToTensorsMap(e){return Object.keys(e).reduce((t,n)=>(t[n]=[e[n]],t),{})}dispose(){this.executor.dispose(),this.initializer&&this.initializer.dispose(),this.resourceManager.dispose()}};async function qt(e,t={}){if(e==null)throw new Error("modelUrl in loadGraphModel() cannot be null. Please provide a url or an IOHandler that loads the model");t==null&&(t={}),t.fromTFHub&&e.load==null&&(e.endsWith("/")||(e=e+"/"),e=`${e}${zse}${Ose}`);let n=new D8(e,t);return await n.load(),n}var _se="3.6.0",O8={};Fe(O8,{CSVDataset:()=>_8,Dataset:()=>ql,FileDataSource:()=>P8,TextLineDataset:()=>z8,URLDataSource:()=>L8,array:()=>Pse,csv:()=>Wse,func:()=>Bse,generator:()=>Vse,microphone:()=>Use,version_data:()=>Hse,webcam:()=>jse,zip:()=>Lse});var Gse=Yi(Bg()),qse=Yi(Bg());function Xse(e,t){return d0(e,t)}function d0(e,t,n=new Map,a=new Set){if(e==null)return null;if(a.has(e))throw new Error("Circular references are not supported.");if(n.has(e))return n.get(e);let r=t(e);if(r.recurse&&r.value!==null)throw new Error("A deep map function may not return both a value and recurse=true.");if(r.recurse)if(Xl(e)){let s=Array.isArray(e)?[]:{};a.add(e);for(let i in e){let o=e[i],l=d0(o,t,n,a);s[i]=l}return a.delete(e),s}else throw new Error(`Can't recurse into non-iterable type: ${e}`);else return n.set(e,r.value),r.value}function Kse(e,t=B8){return W8(e,t)}function W8(e,t,n=new Set){let a=e[0];if(n.has(a))throw new Error("Circular references are not supported.");let r=t(e);if(r.recurse&&r.value!==null)throw new Error("A deep zip function may not return both a value and recurse=true.");if(r.recurse)if(Xl(a)){let s=Array.isArray(a)?[]:{};n.add(a);for(let i in a){let o=e.map(d=>d[i]),l=W8(o,t,n);s[i]=l}return n.delete(a),s}else throw new Error(`Can't recurse into non-iterable type: ${a}`);else return r.value}function B8(e){return e===null?null:Xl(e[0])?{value:null,recurse:!0}:{value:e,recurse:!1}}async function V8(e,t){let n=new Map;d0(e,t,n);for(let a of Array.from(n.keys())){let r=n.get(a);if(k.isPromise(r)){let s=await r;n.set(a,s)}}return d0(e,t,n)}function Xl(e){return e!=null&&!ArrayBuffer.isView(e)&&(Array.isArray(e)||typeof e=="object"&&!(e instanceof Le))}function Yse(e){return e==null||Zse(e)||Array.isArray(e)||typeof e=="object"&&e instanceof Le||k.isTypedArray(e)}function Zse(e){return e===null||typeof e!="object"&&typeof e!="function"}function Qse(e){return Xse(e,Jse)}function Jse(e){return e instanceof Le?{value:e.clone(),recurse:!1}:Xl(e)?{value:null,recurse:!0}:{value:e,recurse:!1}}var j8=class{constructor(e){if(this.capacity=e,this.begin=0,this.end=0,e==null)throw new RangeError("Can't create a ring buffer of unknown capacity.");if(e<1)throw new RangeError("Can't create ring buffer of capacity < 1.");this.data=new Array(e),this.doubledCapacity=2*e}wrap(e){for(;e<0;)e+=this.doubledCapacity;return e%this.doubledCapacity}get(e){if(e<0)throw new RangeError("Can't get item at a negative index.");return this.data[e%this.capacity]}set(e,t){if(e<0)throw new RangeError("Can't set item at a negative index.");this.data[e%this.capacity]=t}length(){let e=this.end-this.begin;return e<0&&(e=this.doubledCapacity+e),e}isFull(){return this.length()===this.capacity}isEmpty(){return this.length()===0}push(e){if(this.isFull())throw new RangeError("Ring buffer is full.");this.set(this.end,e),this.end=this.wrap(this.end+1)}pushAll(e){for(let t of e)this.push(t)}pop(){if(this.isEmpty())throw new RangeError("Ring buffer is empty.");this.end=this.wrap(this.end-1);let e=this.get(this.end);return this.set(this.end,void 0),e}unshift(e){if(this.isFull())throw new RangeError("Ring buffer is full.");this.begin=this.wrap(this.begin-1),this.set(this.begin,e)}shift(){if(this.isEmpty())throw new RangeError("Ring buffer is empty.");let e=this.get(this.begin);return this.set(this.begin,void 0),this.begin=this.wrap(this.begin+1),e}shuffleExcise(e){if(this.isEmpty())throw new RangeError("Ring buffer is empty.");let t=this.wrap(this.begin+e),n=this.get(t);return this.set(t,this.pop()),n}},R2=class extends j8{constructor(){super(R2.INITIAL_CAPACITY)}isFull(){return!1}push(e){super.isFull()&&this.expand(),super.push(e)}unshift(e){super.isFull()&&this.expand(),super.unshift(e)}expand(){let e=this.capacity*2,t=new Array(e),n=this.length();for(let a=0;at===!0)}rowMajorBatch(e,t=!0){return new lie(this,e,t)}columnMajorBatch(e,t=!0,n=B8){return this.rowMajorBatch(e,t).map(a=>Kse(a,n))}concatenate(e,t){return new H8(U8([this,e]),t)}take(e){return e<0||e==null?this:new oie(this,e)}skip(e){return e<0||e==null?this:new iie(this,e)}prefetch(e){return new q8(this,e)}shuffle(e,t){return new hie(this,e,t)}serial(){return new sie(this)}},eie=class extends Xt{constructor(e){super();this.items=e,this.trav=0}summary(){return`Array of ${this.items.length} items`}async next(){if(this.trav>=this.items.length)return{value:null,done:!0};let e=this.items[this.trav];return this.trav++,{value:Qse(e),done:!1}}},tie=class extends Xt{constructor(e){super();this.nextFn=e}summary(){return"Function call"}async next(){try{return this.nextFn()}catch(e){throw e.message=`Error thrown while iterating through a dataset: ${e.message}`,e}}},sie=class extends Xt{constructor(e){super();this.upstream=e,this.lastRead=Promise.resolve({value:null,done:!1})}summary(){return`${this.upstream.summary()} -> Serial`}async next(){return this.lastRead=this.lastRead.then(()=>this.serialNext()),this.lastRead}async serialNext(){return this.upstream.next()}},iie=class extends Xt{constructor(e,t){super();this.upstream=e,this.maxCount=t,this.count=0,this.lastRead=Promise.resolve({value:null,done:!1})}summary(){return`${this.upstream.summary()} -> Skip`}async next(){return this.lastRead=this.lastRead.then(()=>this.serialNext()),this.lastRead}async serialNext(){for(;this.count++ Take`}async next(){return this.count++>=this.maxCount?{value:null,done:!0}:this.upstream.next()}},lie=class extends Xt{constructor(e,t,n=!0){super();this.upstream=e,this.batchSize=t,this.enableSmallLastBatch=n,this.lastRead=Promise.resolve({value:null,done:!1})}summary(){return`${this.upstream.summary()} -> RowMajorBatch`}async next(){return this.lastRead=this.lastRead.then(()=>this.serialNext()),this.lastRead}async serialNext(){let e=[];for(;e.length0?{value:e,done:!1}:{value:null,done:!0};e.push(t.value)}return{value:e,done:!1}}},uie=class extends Xt{constructor(e,t){super();this.upstream=e,this.predicate=t,this.lastRead=Promise.resolve({value:null,done:!1})}summary(){return`${this.upstream.summary()} -> Filter`}async next(){return this.lastRead=this.lastRead.then(()=>this.serialNext()),this.lastRead}async serialNext(){for(;;){let e=await this.upstream.next();if(e.done||this.predicate(e.value))return e;Ee(e.value)}}},die=class extends Xt{constructor(e,t){super();this.upstream=e,this.transform=t}summary(){return`${this.upstream.summary()} -> Map`}async next(){let e=await this.upstream.next();if(e.done)return{value:null,done:!0};let t=Aa.getTensorsInContainer(e.value),n=this.transform(e.value),a=Aa.getTensorsInContainer(n);for(let r of t)Aa.isTensorInList(r,a)||r.dispose();return{value:n,done:!1}}},pie=class extends Xt{constructor(e,t){super();this.upstream=e,this.handler=t,this.count=0,this.lastRead=Promise.resolve({value:null,done:!1})}summary(){return`${this.upstream.summary()} -> handleErrors`}async next(){return this.lastRead=this.lastRead.then(()=>this.serialNext()),this.lastRead}async serialNext(){for(;;)try{return await this.upstream.next()}catch(e){if(!this.handler(e))return{value:null,done:!0}}}},G8=class extends Xt{constructor(e,t){super();this.upstream=e,this.transform=t}summary(){return`${this.upstream.summary()} -> AsyncMap`}async next(){let e=await this.upstream.next();if(e.done)return{value:null,done:!0};let t=Aa.getTensorsInContainer(e.value),n=await this.transform(e.value),a=Aa.getTensorsInContainer(n);for(let r of t)Aa.isTensorInList(r,a)||r.dispose();return{value:n,done:!1}}},F2=class extends Xt{constructor(){super();this.outputQueue=new R2,this.lastRead=Promise.resolve({value:null,done:!1})}async next(){return this.lastRead=this.lastRead.then(()=>this.serialNext()),this.lastRead}async serialNext(){for(;this.outputQueue.length()===0;)if(!await this.pump())return{value:null,done:!0};return{value:this.outputQueue.shift(),done:!1}}},cie=class extends F2{constructor(e,t){super();this.upstream=e,this.transform=t}summary(){return`${this.upstream.summary()} -> Flatmap`}async pump(){let e=await this.upstream.next();if(e.done)return!1;let t=Aa.getTensorsInContainer(e.value),n=this.transform(e.value),a=Aa.getTensorsInContainer(n);this.outputQueue.pushAll(n);for(let r of t)Aa.isTensorInList(r,a)||r.dispose();return!0}},H8=class extends Xt{constructor(e,t){super();this.baseErrorHandler=t,this.lastRead=null,this.iterator=null,this.moreIterators=e}summary(){return"TODO: fill in upstream of chained summaries -> Chained"}async next(){return this.lastRead=this.readFromChain(this.lastRead),this.lastRead}async readFromChain(e){if(await e,this.iterator==null){let n=await this.moreIterators.next();if(n.done)return{value:null,done:!0};this.iterator=n.value,this.baseErrorHandler!=null&&(this.iterator=this.iterator.handleErrors(this.baseErrorHandler))}let t=await this.iterator.next();return t.done?(this.iterator=null,this.readFromChain(e)):t}},Kr;(function(e){e[e.FAIL=0]="FAIL",e[e.SHORTEST=1]="SHORTEST",e[e.LONGEST=2]="LONGEST"})(Kr||(Kr={}));var aie=class extends Xt{constructor(e,t=Kr.FAIL){super();this.iterators=e,this.mismatchMode=t,this.count=0,this.currentPromise=null}summary(){return"{TODO: fill in upstream of zip summaries} -> Zip"}async nextState(e){await e;let t=0,n=0;function a(s){return s instanceof Xt?{value:s.next().then(i=>(t++,i.done&&n++,i.value)),recurse:!1}:{value:null,recurse:!0}}let r=await V8(this.iterators,a);if(t===n)return{value:null,done:!0};if(n>0)switch(this.mismatchMode){case Kr.FAIL:throw new Error(`Zipped streams should have the same length. Mismatched at element ${this.count}.`);case Kr.SHORTEST:return{value:null,done:!0};case Kr.LONGEST:default:}return this.count++,{value:r,done:!1}}async next(){return this.currentPromise=this.nextState(this.currentPromise),this.currentPromise}},q8=class extends Xt{constructor(e,t){super();this.upstream=e,this.bufferSize=t,this.buffer=new j8(t)}summary(){return`${this.upstream.summary()} -> Prefetch`}refill(){for(;!this.buffer.isFull();){let e=this.upstream.next();this.buffer.push(e)}}next(){return this.refill(),this.buffer.shift()}},hie=class extends q8{constructor(e,t,n){super(e,t);this.upstream=e,this.windowSize=t,this.upstreamExhausted=!1,this.random=qse.alea(n||k.now().toString()),this.lastRead=Promise.resolve({value:null,done:!1})}async next(){return this.lastRead=this.lastRead.then(()=>this.serialNext()),this.lastRead}randomInt(e){return Math.floor(this.random()*e)}chooseIndex(){return this.randomInt(this.buffer.length())}async serialNext(){for(this.upstreamExhausted||this.refill();!this.buffer.isEmpty();){let e=this.chooseIndex(),t=await this.buffer.shuffleExcise(e);if(t.done)this.upstreamExhausted=!0;else return this.refill(),t}return{value:null,done:!0}}},ql=class{constructor(){this.size=null}batch(e,t=!0){let n=this;k.assert(e>0,()=>`batchSize needs to be positive, but it is - ${e}`);let a;return this.size===Infinity||this.size==null?a=this.size:t?a=Math.ceil(this.size/e):a=Math.floor(this.size/e),Bn(async()=>(await n.iterator()).columnMajorBatch(e,t,fie),a)}concatenate(e){let t=this,n;return this.size===Infinity||e.size===Infinity?n=Infinity:this.size!=null&&e.size!=null?n=this.size+e.size:n=null,Bn(async()=>(await t.iterator()).concatenate(await e.iterator()),n)}filter(e){let t=this,n;return this.size===Infinity?n=Infinity:n=null,Bn(async()=>(await t.iterator()).filter(a=>W(()=>e(a))),n)}async forEachAsync(e){return(await this.iterator()).forEachAsync(e)}map(e){let t=this;return Bn(async()=>(await t.iterator()).map(n=>W(()=>e(n))),this.size)}mapAsync(e){let t=this;return Bn(async()=>(await t.iterator()).mapAsync(e),this.size)}prefetch(e){if(e==null)throw new RangeError("`Dataset.prefetch()` requires bufferSize to be specified.");let t=this;return Bn(async()=>(await t.iterator()).prefetch(e),this.size)}repeat(e){let t=this,n;return this.size!=null&&e>0?n=this.size*e:e===0?n=0:this.size!=null&&(e===void 0||e<0)?n=Infinity:n=null,Bn(async()=>{let a=M2(async()=>({value:await t.iterator(),done:!1}));return nie(a.take(e))},n)}skip(e){let t=this,n;return this.size!=null&&e>=0&&this.size>=e?n=this.size-e:this.size!=null&&(this.size(await t.iterator()).skip(e),n)}shuffle(e,t,n=!0){if(e==null||e<0)throw this.size==null?new RangeError("`Dataset.shuffle()` requires bufferSize to be specified."):new RangeError(`\`Dataset.shuffle()\` requires bufferSize to be specified. If your data fits in main memory (for regular JS objects), and/or GPU memory (for \`tf.Tensor\`s), consider setting bufferSize to the dataset size (${this.size} elements)`);let a=this,r=Gse.alea(t||k.now().toString());return Bn(async()=>{let s=r.int32();return n&&(s+=r.int32()),(await a.iterator()).shuffle(e,s.toString())},this.size)}take(e){let t=this,n;return this.size!=null&&this.size>e?n=e:this.size!=null&&this.size<=e?n=this.size:n=null,Bn(async()=>(await t.iterator()).take(e),n)}async toArray(){if(this.size===Infinity)throw new Error("Can not convert infinite data stream to array.");return(await this.iterator()).toArray()}async toArrayForTest(){if(this.size===Infinity)throw new Error("Can not convert infinite data stream to array.");return(await this.iterator()).toArrayForTest()}};ql.MAX_BUFFER_SIZE=1e4;function Bn(e,t=null){return new class extends ql{constructor(){super(...arguments);this.size=t}async iterator(){return e()}}}function Pse(e){return Bn(async()=>U8(e),e.length)}function Lse(e){if(!Xl(e))throw new Error("The argument to zip() must be an object or array.");let t;if(Array.isArray(e))for(let n=0;n{let n=await V8(e,a=>{if(a instanceof ql)return{value:a.iterator(),recurse:!1};if(Xl(a))return{value:null,recurse:!0};throw new Error("Leaves of the structure passed to zip() must be Datasets, not primitives.")});return rie(n,Kr.SHORTEST)},t)}function fie(e){if(e===null)return null;let t=e[0];return Yse(t)?{value:mie(e),recurse:!1}:{value:null,recurse:!0}}function mie(e){if(e.length===0)throw new Error("Can't make a batch of zero elements.");return e[0]instanceof Le?_n(e):oa(e)}var z8=class extends ql{constructor(e){super();this.input=e}async iterator(){return(await this.input.iterator()).decodeUTF8().split(` -`).map(e=>(e.endsWith("\r")&&(e=e.slice(0,-1)),e))}},p0='"',Hd=Symbol("out"),X8=Symbol("field"),c0=Symbol("quote"),$2=Symbol("quoteafterquote"),K8=Symbol("quoteinquote"),_8=class extends ql{constructor(e,t){super();this.input=e,this.hasHeader=!0,this.fullColumnNames=null,this.columnNamesValidated=!1,this.columnConfigs=null,this.configuredColumnsOnly=!1,this.delimiter=",",this.delimWhitespace=!1,this.base=new z8(e),t||(t={}),this.hasHeader=t.hasHeader!==!1,this.fullColumnNames=t.columnNames,this.columnConfigs=t.columnConfigs,this.configuredColumnsOnly=t.configuredColumnsOnly,t.delimWhitespace?(k.assert(t.delimiter==null,()=>"Delimiter should not be provided when delimWhitespace is true."),this.delimWhitespace=!0,this.delimiter=" "):this.delimiter=t.delimiter?t.delimiter:","}async columnNames(){return this.columnNamesValidated||await this.setColumnNames(),this.configuredColumnsOnly?Object.keys(this.columnConfigs):this.fullColumnNames}async setColumnNames(){let e=await this.maybeReadHeaderLine();if(!this.fullColumnNames&&!e)throw new Error("Column names must be provided if there is no header line.");this.fullColumnNames&&e&&k.assert(e.length===this.fullColumnNames.length,()=>"The length of provided columnNames ("+this.fullColumnNames.length.toString()+") does not match the length of the header line read from file ("+e.length.toString()+")."),this.fullColumnNames||(this.fullColumnNames=e);let t=this.fullColumnNames.reduce((a,r)=>(a[r]=a[r]+1||1,a),{}),n=Object.keys(t).filter(a=>t[a]>1);if(k.assert(n.length===0,()=>"Duplicate column names found: "+n.toString()),this.columnConfigs){for(let a of Object.keys(this.columnConfigs))if(this.fullColumnNames.indexOf(a)===-1)throw new Error('The key "'+a+'" provided in columnConfigs does not match any of the column names ('+this.fullColumnNames.toString()+").")}this.columnNamesValidated=!0}async maybeReadHeaderLine(){if(this.hasHeader){let e=await(await this.base.iterator()).next();if(e.done)throw new Error("No data was found for CSV parsing.");let t=e.value;return this.parseRow(t,!1)}else return null}async iterator(){this.columnNamesValidated||await this.setColumnNames();let e=await this.base.iterator();return this.hasHeader&&(e=e.skip(1)),e.map(t=>this.makeDataElement(t))}makeDataElement(e){let t=this.parseRow(e),n={},a={};for(let r=0;r14||!Number.isInteger(t))throw new Error(`Invalid fftSize: it must be a power of 2 between 2 to 4 and 2 to 14, but got ${this.fftSize}`);if(this.numFrames=e.numFramesPerSpectrogram||43,this.sampleRateHz=e.sampleRateHz,this.columnTruncateLength=e.columnTruncateLength||this.fftSize,this.audioTrackConstraints=e.audioTrackConstraints,this.smoothingTimeConstant=e.smoothingTimeConstant||0,this.includeSpectrogram=e.includeSpectrogram!==!1,this.includeWaveform=e.includeWaveform===!0,!this.includeSpectrogram&&!this.includeWaveform)throw new Error("Both includeSpectrogram and includeWaveform are false. At least one type of data should be returned.")}summary(){return"microphone"}static async create(e={}){if(J().get("IS_NODE"))throw new Error("microphone API is only supported in browser environment.");let t=new Z8(e);return await t.start(),t}async start(){try{this.stream=await navigator.mediaDevices.getUserMedia({audio:this.audioTrackConstraints==null?!0:this.audioTrackConstraints,video:!1})}catch(n){throw new Error(`Error thrown while initializing video stream: ${n.message}`)}if(!this.stream)throw new Error("Could not obtain audio from microphone.");let e=window.AudioContext||window.webkitAudioContext;if(this.audioContext=new e,!this.sampleRateHz)this.sampleRateHz=this.audioContext.sampleRate;else if(this.audioContext.sampleRate!==this.sampleRateHz)throw new Error(`Mismatch in sampling rate: Expected: ${this.sampleRateHz}; Actual: ${this.audioContext.sampleRate}`);let t=this.audioContext.createMediaStreamSource(this.stream);this.analyser=this.audioContext.createAnalyser(),this.analyser.fftSize=this.fftSize*2,this.analyser.smoothingTimeConstant=this.smoothingTimeConstant,t.connect(this.analyser),this.freqData=new Float32Array(this.fftSize),this.timeData=new Float32Array(this.fftSize)}async next(){if(this.isClosed)return{value:null,done:!0};let e,t,n=await this.getAudioData();if(this.includeSpectrogram){let a=this.flattenQueue(n.freqDataQueue);e=this.getTensorFromAudioDataArray(a,[this.numFrames,this.columnTruncateLength,1])}if(this.includeWaveform){let a=this.flattenQueue(n.timeDataQueue);t=this.getTensorFromAudioDataArray(a,[this.numFrames*this.fftSize,1])}return{value:{spectrogram:e,waveform:t},done:!1}}async capture(){return(await this.next()).value}async getAudioData(){let e=[],t=[],n=0;return new Promise(a=>{let r=setInterval(()=>{this.includeSpectrogram&&(this.analyser.getFloatFrequencyData(this.freqData),this.freqData[0]===-Infinity&&a({freqDataQueue:e,timeDataQueue:t}),e.push(this.freqData.slice(0,this.columnTruncateLength))),this.includeWaveform&&(this.analyser.getFloatTimeDomainData(this.timeData),t.push(this.timeData.slice())),++n===this.numFrames&&(clearInterval(r),a({freqDataQueue:e,timeDataQueue:t}))},this.fftSize/this.sampleRateHz*1e3)})}stop(){this.isClosed||(this.isClosed=!0,this.analyser.disconnect(),this.audioContext.close(),this.stream!=null&&this.stream.getTracks().length>0&&this.stream.getTracks()[0].stop())}toArray(){throw new Error("Can not convert infinite audio stream to array.")}getSampleRate(){return this.sampleRateHz}flattenQueue(e){let t=e[0].length,n=new Float32Array(e.length*t);return e.forEach((a,r)=>n.set(a,r*t)),n}getTensorFromAudioDataArray(e,t){let n=new Float32Array(k.sizeFromShape(t));return n.set(e,n.length-e.length),oa(n,t)}},Y8=class extends Xt{constructor(e,t){super();if(this.webcamVideoElement=e,this.webcamConfig=t,this.isClosed=!0,this.resize=!1,this.needToResize())if(this.resize=!0,this.cropSize=[this.webcamConfig.resizeHeight,this.webcamConfig.resizeWidth],this.cropBoxInd=Et([0],"int32"),this.webcamConfig.centerCrop){let n=this.webcamConfig.resizeWidth*1/this.webcamVideoElement.width,a=this.webcamConfig.resizeHeight*1/this.webcamVideoElement.height,r=(1-n)/2,s=(1-a)/2,i=r+n,o=a+s;this.cropBox=ga([s,r,o,i],[1,4])}else this.cropBox=ga([0,0,1,1],[1,4])}summary(){return"webcam"}static async create(e,t={}){if(J().get("IS_NODE"))throw new Error("tf.data.webcam is only supported in browser environment.");if(!e){if(e=document.createElement("video"),!t.resizeWidth||!t.resizeHeight)throw new Error("Please provide webcam video element, or resizeWidth and resizeHeight to create a hidden video element.");e.width=t.resizeWidth,e.height=t.resizeHeight}let n=new Y8(e,t);return await n.start(),n}async start(){this.webcamConfig.facingMode&&k.assert(this.webcamConfig.facingMode==="user"||this.webcamConfig.facingMode==="environment",()=>`Invalid webcam facing mode: ${this.webcamConfig.facingMode}. Please provide 'user' or 'environment'`);try{this.stream=await navigator.mediaDevices.getUserMedia({video:{deviceId:this.webcamConfig.deviceId,facingMode:this.webcamConfig.facingMode?this.webcamConfig.facingMode:"user",width:this.webcamVideoElement.width,height:this.webcamVideoElement.height}})}catch(e){throw e.message=`Error thrown while initializing video stream: ${e.message}`,e}if(!this.stream)throw new Error("Could not obtain video from webcam.");try{this.webcamVideoElement.srcObject=this.stream}catch(e){console.log(e),this.webcamVideoElement.src=window.URL.createObjectURL(this.stream)}return this.webcamVideoElement.play(),this.isClosed=!1,new Promise(e=>{this.webcamVideoElement.onloadedmetadata=()=>{e()}})}async next(){if(this.isClosed)return{value:null,done:!0};let e;try{e=li.fromPixels(this.webcamVideoElement)}catch(t){throw new Error(`Error thrown converting video to pixels: ${JSON.stringify(t)}`)}if(this.resize)try{return{value:this.cropAndResizeFrame(e),done:!1}}catch(t){throw new Error(`Error thrown cropping the video: ${t.message}`)}finally{e.dispose()}else return{value:e,done:!1}}needToResize(){return!!(this.webcamConfig.resizeWidth&&this.webcamConfig.resizeHeight&&(this.webcamVideoElement.width!==this.webcamConfig.resizeWidth||this.webcamVideoElement.height!==this.webcamConfig.resizeHeight))}cropAndResizeFrame(e){return W(()=>{let t=un(fe(e,"float32"),0),n;n=Ye.cropAndResize(t,this.cropBox,this.cropBoxInd,this.cropSize,"bilinear");let a=n.shape;return H(n,a.slice(1))})}async capture(){return(await this.next()).value}stop(){this.stream.getTracks().forEach(e=>e.stop());try{this.webcamVideoElement.srcObject=null}catch(e){console.log(e),this.webcamVideoElement.src=null}this.isClosed=!0}toArray(){throw new Error("Can not convert infinite video stream to array.")}},J8=class{},Q8=class extends Xt{split(e){return new Aie(this,e)}},Aie=class extends Q8{constructor(e,t){super();this.upstream=e,this.impl=new yie(e,t)}summary(){return this.impl.summary()}async next(){return this.impl.next()}},yie=class extends F2{constructor(e,t){super();this.upstream=e,this.separator=t,this.carryover=""}summary(){return`${this.upstream.summary()} -> Split('${this.separator}')`}async pump(){let e=await this.upstream.next();if(e.done)return this.carryover===""?!1:(this.outputQueue.push(this.carryover),this.carryover="",!0);let t=e.value.split(this.separator);t[0]=this.carryover+t[0];for(let n of t.slice(0,-1))this.outputQueue.push(n);return this.carryover=t[t.length-1],!0}},xie=class extends Xt{decodeUTF8(){return new gie(this)}},gie=class extends Q8{constructor(e){super();this.upstream=e,this.impl=new bie(e)}summary(){return this.impl.summary()}async next(){return this.impl.next()}},bie=class extends F2{constructor(e){super();if(this.upstream=e,J().get("IS_BROWSER"))this.decoder=new TextDecoder("utf-8");else{let{StringDecoder:t}=pI();this.decoder=new t("utf8")}}summary(){return`${this.upstream.summary()} -> Utf8`}async pump(){let e=await this.upstream.next(),t;if(e.done)return!1;t=e.value;let n;return J().get("IS_BROWSER")?n=this.decoder.decode(t,{stream:!0}):n=this.decoder.write(Buffer.from(t.buffer)),this.outputQueue.push(n),!0}},ek=class extends xie{constructor(e,t={}){super();this.file=e,this.options=t,k.assert(e instanceof Uint8Array||(J().get("IS_BROWSER")?e instanceof File||e instanceof Blob:!1),()=>"FileChunkIterator only supports File, Blob and Uint8Array right now."),this.offset=t.offset||0,this.chunkSize=t.chunkSize||1024*1024}summary(){return`FileChunks ${this.file}`}async next(){return this.offset>=(this.file instanceof Uint8Array?this.file.byteLength:this.file.size)?{value:null,done:!0}:{value:await new Promise((e,t)=>{let n=this.offset+this.chunkSize;if(this.file instanceof Uint8Array)e(new Uint8Array(this.file.slice(this.offset,n)));else{let a=new FileReader;a.onload=s=>{let i=a.result;if(i instanceof ArrayBuffer&&(i=new Uint8Array(i)),!(i instanceof Uint8Array))return t(new TypeError("FileReader returned unknown type."));e(i)},a.onabort=s=>t(new Error("Aborted")),a.onerror=s=>t(new Error(s.type));let r=this.file.slice(this.offset,n);a.readAsArrayBuffer(r)}this.offset=n}),done:!1}}};async function wie(e,t={}){let n,a;typeof e=="string"?n=e:(n=e.url,a=vie(e));let r=await k.fetch(n,a);if(r.ok){let s=new Uint8Array(await r.arrayBuffer());return new ek(s,t)}else throw new Error(r.statusText)}var vie=e=>({method:e.method,headers:e.headers,body:e.body,mode:e.mode,credentials:e.credentials,cache:e.cache,redirect:e.redirect,referrer:e.referrer,integrity:e.integrity});function tk(e){return typeof e=="string"&&e.substr(0,7)==="file://"}var P8=class extends J8{constructor(e,t={}){super();this.input=e,this.options=t}async iterator(){if(tk(this.input)&&J().get("IS_NODE")){let e=require("fs");this.input=e.readFileSync(this.input.substr(7))}return new ek(this.input,this.options)}},L8=class extends J8{constructor(e,t={}){super();this.url=e,this.fileOptions=t}async iterator(){return tk(this.url)?new P8(this.url,this.fileOptions).iterator():wie(this.url,this.fileOptions)}};function Wse(e,t={}){return new _8(new L8(e),t)}function Bse(e){let t=M2(e);return Bn(async()=>t)}function Vse(e){return Bn(async()=>{let t=await e();return M2(()=>t.next())})}async function jse(e,t){return Y8.create(e,t)}async function Use(e){return Z8.create(e)}var Hse="3.6.0",kie={tfjs:(dm==null?void 0:dm.version)||void 0,"tfjs-core":(pm==null?void 0:pm.version)||void 0,"tfjs-data":(cm==null?void 0:cm.version)||void 0,"tfjs-layers":(hm==null?void 0:hm.version)||void 0,"tfjs-converter":(fm==null?void 0:fm.version)||void 0,"tfjs-backend-cpu":Y3||void 0,"tfjs-backend-webgl":bv||void 0,"tfjs-backend-wasm":c6||void 0};var Vn={name:"humangl",priority:99,canvas:null,gl:null,width:1024,height:1024,webGLattr:{alpha:!1,antialias:!1,premultipliedAlpha:!1,preserveDrawingBuffer:!1,depth:!1,stencil:!1,failIfMajorPerformanceCaveat:!1,desynchronized:!0}};function nk(){if(!Zm(Vn.name)){he("backend registration:",Vn.name);try{Vn.canvas=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(Vn.width,Vn.height):document.createElement("canvas")}catch(e){he("error: cannot create canvas:",e);return}try{Vn.gl=Vn.canvas.getContext("webgl2",Vn.webGLattr)}catch(e){he("error: cannot get WebGL2 context:",e);return}try{ph(2,Vn.gl)}catch(e){he("error: cannot set WebGL2 context:",e);return}try{let e=new mh(Vn.gl);dl(Vn.name,()=>new zl(e),Vn.priority)}catch(e){he("error: cannot register WebGL backend:",e);return}try{al("webgl").forEach(t=>{let n={...t,backendName:Vn.name};ri(n)})}catch(e){he("error: cannot update WebGL backend registration:",e);return}try{ma.set("WEBGL_VERSION",2)}catch(e){he("error: cannot set WebGL backend flags:",e);return}he("backend registered:",Vn.name)}}var W2={};Fa(W2,{load:()=>j2,predict:()=>V2,triangulation:()=>fk,uvmap:()=>mk});function ak(e,t){let n=[e.startPoint[0]*t[0],e.startPoint[1]*t[1]],a=[e.endPoint[0]*t[0],e.endPoint[1]*t[1]];return{startPoint:n,endPoint:a}}function Gd(e){return[Math.abs(e.endPoint[0]-e.startPoint[0]),Math.abs(e.endPoint[1]-e.startPoint[1])]}function Kl(e){return[e.startPoint[0]+(e.endPoint[0]-e.startPoint[0])/2,e.startPoint[1]+(e.endPoint[1]-e.startPoint[1])/2]}function Zl(e,t,n){let a=t.shape[1],r=t.shape[2],s=[[e.startPoint[1]/a,e.startPoint[0]/r,e.endPoint[1]/a,e.endPoint[0]/r]];return Ye.cropAndResize(t,s,[0],n)}function h0(e,t=1.5){let n=Kl(e),a=Gd(e),r=[t*a[0]/2,t*a[1]/2],s=[n[0]-r[0],n[1]-r[1]],i=[n[0]+r[0],n[1]+r[1]];return{startPoint:s,endPoint:i,landmarks:e.landmarks}}function f0(e){let t=Kl(e),n=Gd(e),r=Math.max(...n)/2,s=[Math.round(t[0]-r),Math.round(t[1]-r)],i=[Math.round(t[0]+r),Math.round(t[1]+r)];return{startPoint:s,endPoint:i,landmarks:e.landmarks}}function D2(e){let t=e.map(s=>s[0]),n=e.map(s=>s[1]),a=[Math.min(...t),Math.min(...n)],r=[Math.max(...t),Math.max(...n)];return{startPoint:a,endPoint:r,landmarks:e}}var rk=e=>({startPoint:Re(e,[0,0],[-1,2]),endPoint:Re(e,[0,2],[-1,2])});var m0=[[1,0,0],[0,1,0],[0,0,1]];function Iie(e){return e-2*Math.PI*Math.floor((e+Math.PI)/(2*Math.PI))}function O2(e,t){let n=Math.PI/2-Math.atan2(-(t[1]-e[1]),t[0]-e[0]);return Iie(n)}function sk(e,t){return[[1,0,e],[0,1,t],[0,0,1]]}function Zr(e,t){let n=0;for(let a=0;a{let d=t.resizeBilinear([this.inputSize,this.inputSize]).div(127.5).sub(.5),u=this.model.execute(d),p;if(Array.isArray(u)){let f=u.sort((x,w)=>x.size-w.size),A=ot([f[0],f[2]],2),y=ot([f[1],f[3]],2);p=ot([y,A],1).squeeze(0)}else p=u.squeeze();let c=Nie(p,this.anchors,[this.inputSize,this.inputSize]),h=Re(p,[0,0],[-1,1]),m=kn(h).squeeze().dataSync();return[p,c,m]}),s=await Ye.nonMaxSuppressionAsync(a,r,this.config.face.detector.maxDetected,this.config.face.detector.iouThreshold,this.config.face.detector.minConfidence),i=s.arraySync();s.dispose();let o=[];for(let l=0;lthis.config.face.detector.minConfidence){let u=Re(a,[i[l],0],[1,-1]),p=rk(u);u.dispose();let c=this.anchorsData[i[l]],h=W(()=>Re(n,[i[l],dk-1],[1,-1]).squeeze().reshape([dk,-1]));o.push({box:p,landmarks:h,anchor:c,confidence:d})}}return n.dispose(),a.dispose(),{boxes:o,scaleFactor:[t.shape[2]/this.inputSize,t.shape[1]/this.inputSize]}}};async function ck(e){let t=await qt(Jt(e.modelBasePath,e.face.detector.modelPath),{fromTFHub:e.face.detector.modelPath.includes("tfhub.dev")}),n=new pk(t,e);return!t||!t.modelUrl?he("load model failed:",e.face.detector.modelPath):e.debug&&he("load model:",t.modelUrl),n}var Xa={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]},z2=[{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]}],qd=[[.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]],zi=[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 Tie=[127,234,132,58,172,150,149,148,152,377,378,379,397,288,361,454,356,70,63,105,66,107,336,296,334,293,300,168,6,195,4,98,97,2,326,327,33,160,158,133,153,144,362,385,387,263,373,380,57,40,37,0,267,270,287,321,314,17,84,91,78,81,13,311,308,402,14,178],Eie=[33,133,362,263,1,62,308,159,145,386,374,6,102,331,2,13,14,70,105,107,336,334,300,54,10,284,50,280,234,454,58,288,152],Cie=[33,133,362,263,1,78,308],coe=Tie.map(e=>qd[e]),hoe=Eie.map(e=>qd[e]),foe=Cie.map(e=>qd[e]);var _2=Xa.leftEyeLower0,P2=Xa.rightEyeLower0,Yl={leftBounds:[_2[0],_2[_2.length-1]],rightBounds:[P2[0],P2[P2.length-1]]},y0={count:468,mouth:13,symmetryLine:[13,Xa.midwayBetweenEyes[0]]},hk={leftEye:0,rightEye:1,nose:2,mouth:3,leftEar:4,rightEar:5,symmetryLine:[3,2]},Jl={upperCenter:3,lowerCenter:4,index:71,numCoordinates:76};function g0(e,t,n,a){for(let r=0;r[s[0]/this.meshSize*(p[0]-this.meshSize/2),s[1]/this.meshSize*(p[1]-this.meshSize/2),p[2]]),o=a!==0?A0(a,[0,0]):m0,l=a!==0?i.map(p=>[...lk(p,o),p[2]]):i,d=a!==0?ok(r):m0,u=[...Kl({startPoint:n.startPoint,endPoint:n.endPoint}),1];return l.map(p=>[Math.round(p[0]+Zr(u,d[0])),Math.round(p[1]+Zr(u,d[1])),Math.round(p[2])])}getLeftToRightEyeDepthDifference(t){let n=t[Yl.leftBounds[0]][2],a=t[Yl.rightBounds[0]][2];return n-a}getEyeBox(t,n,a,r,s=!1){let i=f0(h0(D2([t[a],t[r]]),this.irisEnlarge)),o=Gd(i),l=Ye.cropAndResize(n,[[i.startPoint[1]/this.meshSize,i.startPoint[0]/this.meshSize,i.endPoint[1]/this.meshSize,i.endPoint[0]/this.meshSize]],[0],[this.irisSize,this.irisSize]);return s&&ma.flags.IS_BROWSER&&(l=Ye.flipLeftRight(l)),{box:i,boxSize:o,crop:l}}getEyeCoords(t,n,a,r=!1){let s=[];for(let i=0;i{let d=i;return l===2?d=r:l===4&&(d=s),[o[0],o[1],d]})}async predict(t,n){let a=!1,r;if((this.skipped===0||this.skipped>n.face.detector.skipFrames||!n.face.mesh.enabled||!n.videoOptimized)&&(r=await this.boundingBoxDetector.getBoundingBoxes(t),this.skipped=0),n.videoOptimized&&this.skipped++,!n.videoOptimized||r&&r.boxes&&(!n.face.mesh.enabled||r.boxes.length!==this.detectedFaces&&this.detectedFaces!==n.face.detector.maxDetected)){this.storedBoxes=[],this.detectedFaces=0;for(let i of r.boxes)this.storedBoxes.push({startPoint:i.box.startPoint.dataSync(),endPoint:i.box.endPoint.dataSync(),landmarks:i.landmarks,confidence:i.confidence});this.storedBoxes.length>0&&(a=!0)}if(n.face.detector.skipInitial&&this.detectedFaces===0&&(this.skipped=0),a){if(!r||!r.boxes||r.boxes.length===0)return this.storedBoxes=[],this.detectedFaces=0,null;for(let i=0;i{i.box.startPoint.dispose(),i.box.endPoint.dispose(),i.landmarks.dispose()});let s=W(()=>this.storedBoxes.map((i,o)=>{let l,d=0,u;if(n.face.detector.rotation&&n.face.mesh.enabled&&ma.flags.IS_BROWSER){let[w,b]=i.landmarks.length>=y0.count?y0.symmetryLine:hk.symmetryLine;d=O2(i.landmarks[w],i.landmarks[b]);let v=Kl({startPoint:i.startPoint,endPoint:i.endPoint}),N=[v[0]/t.shape[2],v[1]/t.shape[1]],T=Ye.rotateWithOffset(t,d,0,N);u=A0(-d,v),n.face.mesh.enabled?l=Zl({startPoint:i.startPoint,endPoint:i.endPoint},T,[this.meshSize,this.meshSize]).div(255):l=Zl({startPoint:i.startPoint,endPoint:i.endPoint},T,[this.boxSize,this.boxSize]).div(255)}else{u=m0;let w=t.clone();n.face.mesh.enabled?l=Zl({startPoint:i.startPoint,endPoint:i.endPoint},w,[this.meshSize,this.meshSize]).div(255):l=Zl({startPoint:i.startPoint,endPoint:i.endPoint},w,[this.boxSize,this.boxSize]).div(255)}if(!n.face.mesh.enabled)return{mesh:[],box:i,faceConfidence:null,boxConfidence:i.confidence,confidence:i.confidence,image:l};let[,p,c]=this.meshDetector.execute(l),h=p.dataSync()[0];if(h=y0.count?y0.symmetryLine:hk.symmetryLine;d=O2(i.landmarks[w],i.landmarks[b]);let v=Kl({startPoint:i.startPoint,endPoint:i.endPoint}),N=[v[0]/t.shape[2],v[1]/t.shape[1]],T=Ye.rotateWithOffset(t.toFloat(),d,0,N);u=A0(-d,v),l=Zl({startPoint:i.startPoint,endPoint:i.endPoint},T,[this.meshSize,this.meshSize]).div(255)}let g={mesh:A,box:i,faceConfidence:h,boxConfidence:i.confidence,image:l},x=f0(i);return x.confidence=i.confidence,x.faceConfidence=h,this.storedBoxes[o]=x,g}));return n.face.mesh.enabled&&(this.storedBoxes=this.storedBoxes.filter(i=>i.confidence>n.face.detector.minConfidence)),this.detectedFaces=s.length,s}};var Bt=[null,null,null],B2;async function V2(e,t){let n=await B2.predict(e,t),a=[];for(let r of n||[]){if(!r||r.isDisposedInternal)continue;let s=r.mesh.map(d=>[d[0]/e.shape[2],d[1]/e.shape[1],d[2]/B2.meshSize]),i={};if(r.mesh&&r.mesh.length>0)for(let d of Object.keys(Xa))i[d]=Xa[d].map(u=>r.mesh[u]);let o=r.box?[Math.max(0,r.box.startPoint[0]),Math.max(0,r.box.startPoint[1]),Math.min(e.shape[2],r.box.endPoint[0])-Math.max(0,r.box.startPoint[0]),Math.min(e.shape[1],r.box.endPoint[1])-Math.max(0,r.box.startPoint[1])]:0,l=r.box?[r.box.startPoint[0]/e.shape[2],r.box.startPoint[1]/e.shape[1],(r.box.endPoint[0]-r.box.startPoint[0])/e.shape[2],(r.box.endPoint[1]-r.box.startPoint[1])/e.shape[1]]:[];a.push({confidence:Math.round(100*r.faceConfidence||100*r.boxConfidence||0)/100,boxConfidence:Math.round(100*r.boxConfidence)/100,faceConfidence:Math.round(100*r.faceConfidence)/100,box:o,boxRaw:l,mesh:r.mesh,meshRaw:s,annotations:i,image:r.image}),r.coords&&r.coords.dispose()}return a}async function j2(e){return!Bt[0]&&e.face.enabled||!Bt[1]&&e.face.mesh.enabled||!Bt[2]&&e.face.iris.enabled?(Bt=await Promise.all([!Bt[0]&&e.face.enabled?ck(e):null,!Bt[1]&&e.face.mesh.enabled?qt(Jt(e.modelBasePath,e.face.mesh.modelPath),{fromTFHub:e.face.mesh.modelPath.includes("tfhub.dev")}):null,!Bt[2]&&e.face.iris.enabled?qt(Jt(e.modelBasePath,e.face.iris.modelPath),{fromTFHub:e.face.iris.modelPath.includes("tfhub.dev")}):null]),e.face.mesh.enabled&&(!Bt[1]||!Bt[1].modelUrl?he("load model failed:",e.face.mesh.modelPath):e.debug&&he("load model:",Bt[1].modelUrl)),e.face.iris.enabled&&(!Bt[2]||!Bt[1].modelUrl?he("load model failed:",e.face.iris.modelPath):e.debug&&he("load model:",Bt[2].modelUrl))):e.debug&&(he("cached model:",Bt[0].model.modelUrl),he("cached model:",Bt[1].modelUrl),he("cached model:",Bt[2].modelUrl)),B2=new L2(Bt[0],Bt[1],Bt[2]),Bt}var fk=zi,mk=qd;var U2={};Fa(U2,{load:()=>q2,predict:()=>b0});var Rie=["angry","disgust","fear","happy","sad","surprise","neutral"],Ca,H2=[],x0=Number.MAX_SAFE_INTEGER,G2=[.2989,.587,.114];async function q2(e){return Ca?e.debug&&he("cached model:",Ca.modelUrl):(Ca=await qt(Jt(e.modelBasePath,e.face.emotion.modelPath)),!Ca||!Ca.modelUrl?he("load model failed:",e.face.emotion.modelPath):e.debug&&he("load model:",Ca.modelUrl)),Ca}async function b0(e,t){return Ca?x00?(x0++,H2):(t.videoOptimized?x0=0:x0=Number.MAX_SAFE_INTEGER,new Promise(async n=>{let a=Ye.resizeBilinear(e,[Ca.inputs[0].shape[2],Ca.inputs[0].shape[1]],!1),[r,s,i]=rn(a,3,3);a.dispose();let o=_(r,G2[0]),l=_(s,G2[1]),d=_(i,G2[2]);r.dispose(),s.dispose(),i.dispose();let u=yc([o,l,d]);o.dispose(),l.dispose(),d.dispose();let p=W(()=>u.sub(.5).mul(2));u.dispose();let c=[];if(t.face.emotion.enabled){let h=await Ca.predict(p),m=h.dataSync();Ee(h);for(let f=0;ft.face.emotion.minConfidence&&c.push({score:Math.min(.99,Math.trunc(100*m[f])/100),emotion:Rie[f]});c.sort((f,A)=>A.score-f.score)}p.dispose(),H2=c,n(c)})):null}var X2={};Fa(X2,{enhance:()=>Y2,load:()=>K2,match:()=>Ak,predict:()=>k0,similarity:()=>Z2});var ea,v0={age:0},w0=Number.MAX_SAFE_INTEGER;async function K2(e){return ea?e.debug&&he("cached model:",ea.modelUrl):(ea=await qt(Jt(e.modelBasePath,e.face.description.modelPath)),!ea||!ea.modelUrl?he("load model failed:",e.face.description.modelPath):e.debug&&he("load model:",ea.modelUrl)),ea}function Z2(e,t,n=2){if(!e||!t||(e==null?void 0:e.length)===0||(t==null?void 0:t.length)===0||(e==null?void 0:e.length)!==(t==null?void 0:t.length))return 0;let a=5*e.map((s,i)=>Math.abs(e[i]-t[i])**n).reduce((s,i)=>s+i,0)**(1/n);return Math.max(0,100-a)/100}function Ak(e,t,n=0){let a={similarity:0,name:"",source:"",embedding:[]};if(!e||!t||!Array.isArray(e)||!Array.isArray(t))return a;for(let r of t)if(r.embedding&&r.name){let s=Z2(e,r.embedding);s>n&&s>a.similarity&&(a={...r,similarity:s})}return a}function Y2(e){return W(()=>{let n=e.image||e.tensor||e;if(!(n instanceof Le))return null;let a=[[.05,.15,.85,.85]];return(n.shape.length===3?Ye.cropAndResize(un(n,0),a,[0],[ea.inputs[0].shape[2],ea.inputs[0].shape[1]]):Ye.cropAndResize(n,a,[0],[ea.inputs[0].shape[2],ea.inputs[0].shape[1]])).mul(255)})}async function k0(e,t){return ea?w00?(w0++,v0):(t.videoOptimized?w0=0:w0=Number.MAX_SAFE_INTEGER,new Promise(async n=>{let a=Y2(e),r,s={age:0,gender:"unknown",genderConfidence:0,descriptor:[]};t.face.description.enabled&&(r=await ea.predict(a)),Ee(a),r&&(W(()=>{let i=r.find(p=>p.shape[1]===1).dataSync(),o=Math.trunc(200*Math.abs(i[0]-.5))/100;o>t.face.description.minConfidence&&(s.gender=i[0]<=.5?"female":"male",s.genderConfidence=Math.min(.99,o));let l=r.find(p=>p.shape[1]===100).argMax(1).dataSync()[0],d=r.find(p=>p.shape[1]===100).dataSync();s.age=Math.round(d[l-1]>d[l+1]?10*l-100*d[l-1]:10*l+100*d[l+1])/10;let u=r.find(p=>p.shape[1]===1024);s.descriptor=[...u.dataSync()]}),r.forEach(i=>Ee(i))),v0=s,n(s)})):null}var Mie=(e,t)=>{let n=A=>A*180/Math.PI,a=A=>{let y=Math.sqrt(A[0]*A[0]+A[1]*A[1]+A[2]*A[2]);return A[0]/=y,A[1]/=y,A[2]/=y,A},r=(A,y)=>{let g=A[0]-y[0],x=A[1]-y[1],w=A[2]-y[2];return[g,x,w]},s=(A,y)=>{let g=A[1]*y[2]-A[2]*y[1],x=A[2]*y[0]-A[0]*y[2],w=A[0]*y[1]-A[1]*y[0];return[g,x,w]},i=A=>{let[y,g,x,w,b,v,N,T,R]=A,$,z,P;return w<1?w>-1?(P=Math.asin(w),z=Math.atan2(-N,y),$=Math.atan2(-v,b)):(P=-Math.PI/2,z=-Math.atan2(T,R),$=0):(P=Math.PI/2,z=Math.atan2(T,R),$=0),{pitch:2*-$,yaw:2*-z,roll:2*-P}},o=A=>{let y=(x,w,b,v)=>Math.atan2(v-w,b-x);return{pitch:y(A[10][1],A[10][2],A[152][1],A[152][2]),yaw:y(A[33][0],A[33][2],A[263][0],A[263][2]),roll:y(A[33][0],A[33][1],A[263][0],A[263][1])}},l=e.meshRaw;if(!l||l.length<300)return{angle:{pitch:0,yaw:0,roll:0},matrix:[1,0,0,0,1,0,0,0,1]};let d=Math.max(e.boxRaw[2]*t[0],e.boxRaw[3]*t[1])/1.5,u=[l[10],l[152],l[234],l[454]].map(A=>[A[0]*t[0]/d,A[1]*t[1]/d,A[2]]),p=a(r(u[1],u[0])),c=a(r(u[3],u[2])),h=a(s(c,p));c=s(p,h);let m=[c[0],c[1],c[2],p[0],p[1],p[2],h[0],h[1],h[2]];return{angle:i(m),matrix:m}},J2=async(e,t)=>{var u,p,c,h,m,f;let n,a,r,s,i,o,l=[];e.state="run:face",n=it();let d=await V2(t,e.config);if(e.perf.face=Math.trunc(it()-n),!d)return[];for(let A of d){if(e.analyze("Get Face"),!A.image||A.image.isDisposedInternal){he("Face object is disposed:",A.image);continue}let y=Mie(A,[t.shape[2],t.shape[1]]);e.analyze("Start Emotion:"),e.config.async?s=e.config.face.emotion.enabled?b0(A.image,e.config):{}:(e.state="run:emotion",n=it(),s=e.config.face.emotion.enabled?await b0(A.image,e.config):{},e.perf.emotion=Math.trunc(it()-n)),e.analyze("End Emotion:"),e.analyze("Start Description:"),e.config.async?o=e.config.face.description.enabled?k0(A,e.config):[]:(e.state="run:description",n=it(),o=e.config.face.description.enabled?await k0(A.image,e.config):[],e.perf.embedding=Math.trunc(it()-n)),e.analyze("End Description:"),e.config.async&&([a,r,s,i,o]=await Promise.all([a,r,s,i,o])),e.analyze("Finish Face:"),!e.config.face.iris.enabled&&((u=A==null?void 0:A.annotations)==null?void 0:u.leftEyeIris)&&((p=A==null?void 0:A.annotations)==null?void 0:p.rightEyeIris)&&(delete A.annotations.leftEyeIris,delete A.annotations.rightEyeIris);let g=((c=A.annotations)==null?void 0:c.leftEyeIris)&&((h=A.annotations)==null?void 0:h.rightEyeIris)?11.7*Math.max(Math.abs(A.annotations.leftEyeIris[3][0]-A.annotations.leftEyeIris[1][0]),Math.abs(A.annotations.rightEyeIris[4][1]-A.annotations.rightEyeIris[2][1])):0;l.push({...A,age:o.age,gender:o.gender,genderConfidence:o.genderConfidence,embedding:o.descriptor,emotion:s,iris:g!==0?Math.trunc(g)/100:0,rotation:y,tensor:e.config.face.detector.return?(m=A.image)==null?void 0:m.squeeze():null}),(f=A.image)==null||f.dispose(),e.analyze("End Face")}return e.analyze("End FaceMesh:"),e.config.async&&(e.perf.face&&delete e.perf.face,e.perf.age&&delete e.perf.age,e.perf.gender&&delete e.perf.gender,e.perf.emotion&&delete e.perf.emotion),l};var rg={};Fa(rg,{load:()=>ig,predict:()=>sg});var Xd=["nose","leftEye","rightEye","leftEar","rightEar","leftShoulder","rightShoulder","leftElbow","rightElbow","leftWrist","rightWrist","leftHip","rightHip","leftKnee","rightKnee","leftAnkle","rightAnkle"],yk=Xd.length,Kd=Xd.reduce((e,t,n)=>(e[t]=n,e),{}),Fie=[["leftHip","leftShoulder"],["leftElbow","leftShoulder"],["leftElbow","leftWrist"],["leftHip","leftKnee"],["leftKnee","leftAnkle"],["rightHip","rightShoulder"],["rightElbow","rightShoulder"],["rightElbow","rightWrist"],["rightHip","rightKnee"],["rightKnee","rightAnkle"],["leftShoulder","rightShoulder"],["leftHip","rightHip"]],$ie=Fie.map(([e,t])=>[Kd[e],Kd[t]]),gk=[["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"]];function xk(e){let t=e.reduce(({maxX:n,maxY:a,minX:r,minY:s},{position:{x:i,y:o}})=>({maxX:Math.max(n,i),maxY:Math.max(a,o),minX:Math.min(r,i),minY:Math.min(s,o)}),{maxX:Number.NEGATIVE_INFINITY,maxY:Number.NEGATIVE_INFINITY,minX:Number.POSITIVE_INFINITY,minY:Number.POSITIVE_INFINITY});return[t.minX,t.minY,t.maxX-t.minX,t.maxY-t.minY]}function bk(e,[t,n],[a,r]){let s=(o,l,d)=>({score:o.score,box:[Math.trunc(o.box[0]*d),Math.trunc(o.box[1]*l),Math.trunc(o.box[2]*d),Math.trunc(o.box[3]*l)],keypoints:o.keypoints.map(({score:u,part:p,position:c})=>({score:u,part:p,position:{x:Math.trunc(c.x*d),y:Math.trunc(c.y*l)}}))});return e.map(o=>s(o,t/a,n/r))}var Q2=class{constructor(t,n){this.priorityQueue=new Array(t),this.numberOfElements=-1,this.getElementValue=n}enqueue(t){this.priorityQueue[++this.numberOfElements]=t,this.swim(this.numberOfElements)}dequeue(){let t=this.priorityQueue[0];return this.exchange(0,this.numberOfElements--),this.sink(0),this.priorityQueue[this.numberOfElements+1]=null,t}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(t){for(;t>0&&this.less(Math.floor(t/2),t);)this.exchange(t,Math.floor(t/2)),t=Math.floor(t/2)}sink(t){for(;2*t<=this.numberOfElements;){let n=2*t;if(nn?n:e}function vk(e,t,n,a){let r=n-e,s=a-t;return r*r+s*s}function ag(e,t){return{x:e.x+t.x,y:e.y+t.y}}var I0=1,wk=16,Die=20**2;function kk(e,t,n,a,r,s,i,o=2){let l=g=>({y:i.get(g.y,g.x,e),x:i.get(g.y,g.x,i.shape[2]/2+e)}),d=(g,x,w)=>({y:ng(Math.round(g.y/s),0,x-1),x:ng(Math.round(g.x/s),0,w-1)}),[u,p]=a.shape,c=d(t.position,u,p),h=l(c),f=ag(t.position,h);for(let g=0;g[Kd[f],Kd[A]]),o=i.map(([,f])=>f),l=i.map(([f])=>f),d=t.shape[2],u=o.length,p=new Array(d),{part:c,score:h}=e,m=tg(c,a,n);p[c.id]={score:h,part:Xd[c.id],position:m};for(let f=u-1;f>=0;--f){let A=o[f],y=l[f];p[A]&&!p[y]&&(p[y]=kk(f,p[A],y,t,n,a,s))}for(let f=0;ft){o=!1;break}if(!o)break}return o}function _ie(e,t){let[n,a,r]=t.shape,s=new Q2(n*a*r,({score:i})=>i);for(let i=0;i{let s=r[a].position;return vk(n,t,s.y,s.x)<=Die})}function Pie(e,t){return t.reduce((a,{position:r,score:s},i)=>(Ik(e,r,i)||(a+=s),a),0)/t.length}function Sk(e,t,n,a,r,s){let i=[],o=_ie(s,t);for(;i.lengthm.score>s),c=Pie(i,p),h=xk(p);c>s&&i.push({keypoints:p,box:h,score:Math.round(100*c)/100})}return i}var fa,Lie=["MobilenetV1/offset_2/BiasAdd","MobilenetV1/heatmap_2/BiasAdd","MobilenetV1/displacement_fwd_2/BiasAdd","MobilenetV1/displacement_bwd_2/BiasAdd"];async function sg(e,t){let n=W(()=>{let o=e.resizeBilinear([fa.inputs[0].shape[2],fa.inputs[0].shape[1]]).toFloat().div(127.5).sub(1),d=fa.execute(o,Lie).map(u=>u.squeeze([0]));return d[1]=d[1].sigmoid(),d}),a=await Promise.all(n.map(i=>i.buffer()));for(let i of n)i.dispose();let r=await Sk(a[0],a[1],a[2],a[3],t.body.maxDetected,t.body.minConfidence);return bk(r,[e.shape[1],e.shape[2]],[fa.inputs[0].shape[2],fa.inputs[0].shape[1]])}async function ig(e){return fa?e.debug&&he("cached model:",fa.modelUrl):(fa=await qt(Jt(e.modelBasePath,e.body.modelPath)),!fa||!fa.modelUrl?he("load model failed:",e.body.modelPath):e.debug&&he("load model:",fa.modelUrl)),fa}var pg={};Fa(pg,{load:()=>hg,predict:()=>cg});function S0(e){return[Math.abs(e.endPoint[0]-e.startPoint[0]),Math.abs(e.endPoint[1]-e.startPoint[1])]}function Zd(e){return[e.startPoint[0]+(e.endPoint[0]-e.startPoint[0])/2,e.startPoint[1]+(e.endPoint[1]-e.startPoint[1])/2]}function Nk(e,t,n){let a=t.shape[1],r=t.shape[2],s=[[e.startPoint[1]/a,e.startPoint[0]/r,e.endPoint[1]/a,e.endPoint[0]/r]];return Ye.cropAndResize(t,s,[0],n)}function Tk(e,t){let n=[e.startPoint[0]*t[0],e.startPoint[1]*t[1]],a=[e.endPoint[0]*t[0],e.endPoint[1]*t[1]],r=e.palmLandmarks.map(s=>[s[0]*t[0],s[1]*t[1]]);return{startPoint:n,endPoint:a,palmLandmarks:r,confidence:e.confidence}}function N0(e,t=1.5){let n=Zd(e),a=S0(e),r=[t*a[0]/2,t*a[1]/2],s=[n[0]-r[0],n[1]-r[1]],i=[n[0]+r[0],n[1]+r[1]];return{startPoint:s,endPoint:i,palmLandmarks:e.palmLandmarks}}function T0(e){let t=Zd(e),n=S0(e),r=Math.max(...n)/2,s=[t[0]-r,t[1]-r],i=[t[0]+r,t[1]+r];return{startPoint:s,endPoint:i,palmLandmarks:e.palmLandmarks}}var Ek=[{x:.015625,y:.015625},{x:.015625,y:.015625},{x:.046875,y:.015625},{x:.046875,y:.015625},{x:.078125,y:.015625},{x:.078125,y:.015625},{x:.109375,y:.015625},{x:.109375,y:.015625},{x:.140625,y:.015625},{x:.140625,y:.015625},{x:.171875,y:.015625},{x:.171875,y:.015625},{x:.203125,y:.015625},{x:.203125,y:.015625},{x:.234375,y:.015625},{x:.234375,y:.015625},{x:.265625,y:.015625},{x:.265625,y:.015625},{x:.296875,y:.015625},{x:.296875,y:.015625},{x:.328125,y:.015625},{x:.328125,y:.015625},{x:.359375,y:.015625},{x:.359375,y:.015625},{x:.390625,y:.015625},{x:.390625,y:.015625},{x:.421875,y:.015625},{x:.421875,y:.015625},{x:.453125,y:.015625},{x:.453125,y:.015625},{x:.484375,y:.015625},{x:.484375,y:.015625},{x:.515625,y:.015625},{x:.515625,y:.015625},{x:.546875,y:.015625},{x:.546875,y:.015625},{x:.578125,y:.015625},{x:.578125,y:.015625},{x:.609375,y:.015625},{x:.609375,y:.015625},{x:.640625,y:.015625},{x:.640625,y:.015625},{x:.671875,y:.015625},{x:.671875,y:.015625},{x:.703125,y:.015625},{x:.703125,y:.015625},{x:.734375,y:.015625},{x:.734375,y:.015625},{x:.765625,y:.015625},{x:.765625,y:.015625},{x:.796875,y:.015625},{x:.796875,y:.015625},{x:.828125,y:.015625},{x:.828125,y:.015625},{x:.859375,y:.015625},{x:.859375,y:.015625},{x:.890625,y:.015625},{x:.890625,y:.015625},{x:.921875,y:.015625},{x:.921875,y:.015625},{x:.953125,y:.015625},{x:.953125,y:.015625},{x:.984375,y:.015625},{x:.984375,y:.015625},{x:.015625,y:.046875},{x:.015625,y:.046875},{x:.046875,y:.046875},{x:.046875,y:.046875},{x:.078125,y:.046875},{x:.078125,y:.046875},{x:.109375,y:.046875},{x:.109375,y:.046875},{x:.140625,y:.046875},{x:.140625,y:.046875},{x:.171875,y:.046875},{x:.171875,y:.046875},{x:.203125,y:.046875},{x:.203125,y:.046875},{x:.234375,y:.046875},{x:.234375,y:.046875},{x:.265625,y:.046875},{x:.265625,y:.046875},{x:.296875,y:.046875},{x:.296875,y:.046875},{x:.328125,y:.046875},{x:.328125,y:.046875},{x:.359375,y:.046875},{x:.359375,y:.046875},{x:.390625,y:.046875},{x:.390625,y:.046875},{x:.421875,y:.046875},{x:.421875,y:.046875},{x:.453125,y:.046875},{x:.453125,y:.046875},{x:.484375,y:.046875},{x:.484375,y:.046875},{x:.515625,y:.046875},{x:.515625,y:.046875},{x:.546875,y:.046875},{x:.546875,y:.046875},{x:.578125,y:.046875},{x:.578125,y:.046875},{x:.609375,y:.046875},{x:.609375,y:.046875},{x:.640625,y:.046875},{x:.640625,y:.046875},{x:.671875,y:.046875},{x:.671875,y:.046875},{x:.703125,y:.046875},{x:.703125,y:.046875},{x:.734375,y:.046875},{x:.734375,y:.046875},{x:.765625,y:.046875},{x:.765625,y:.046875},{x:.796875,y:.046875},{x:.796875,y:.046875},{x:.828125,y:.046875},{x:.828125,y:.046875},{x:.859375,y:.046875},{x:.859375,y:.046875},{x:.890625,y:.046875},{x:.890625,y:.046875},{x:.921875,y:.046875},{x:.921875,y:.046875},{x:.953125,y:.046875},{x:.953125,y:.046875},{x:.984375,y:.046875},{x:.984375,y:.046875},{x:.015625,y:.078125},{x:.015625,y:.078125},{x:.046875,y:.078125},{x:.046875,y:.078125},{x:.078125,y:.078125},{x:.078125,y:.078125},{x:.109375,y:.078125},{x:.109375,y:.078125},{x:.140625,y:.078125},{x:.140625,y:.078125},{x:.171875,y:.078125},{x:.171875,y:.078125},{x:.203125,y:.078125},{x:.203125,y:.078125},{x:.234375,y:.078125},{x:.234375,y:.078125},{x:.265625,y:.078125},{x:.265625,y:.078125},{x:.296875,y:.078125},{x:.296875,y:.078125},{x:.328125,y:.078125},{x:.328125,y:.078125},{x:.359375,y:.078125},{x:.359375,y:.078125},{x:.390625,y:.078125},{x:.390625,y:.078125},{x:.421875,y:.078125},{x:.421875,y:.078125},{x:.453125,y:.078125},{x:.453125,y:.078125},{x:.484375,y:.078125},{x:.484375,y:.078125},{x:.515625,y:.078125},{x:.515625,y:.078125},{x:.546875,y:.078125},{x:.546875,y:.078125},{x:.578125,y:.078125},{x:.578125,y:.078125},{x:.609375,y:.078125},{x:.609375,y:.078125},{x:.640625,y:.078125},{x:.640625,y:.078125},{x:.671875,y:.078125},{x:.671875,y:.078125},{x:.703125,y:.078125},{x:.703125,y:.078125},{x:.734375,y:.078125},{x:.734375,y:.078125},{x:.765625,y:.078125},{x:.765625,y:.078125},{x:.796875,y:.078125},{x:.796875,y:.078125},{x:.828125,y:.078125},{x:.828125,y:.078125},{x:.859375,y:.078125},{x:.859375,y:.078125},{x:.890625,y:.078125},{x:.890625,y:.078125},{x:.921875,y:.078125},{x:.921875,y:.078125},{x:.953125,y:.078125},{x:.953125,y:.078125},{x:.984375,y:.078125},{x:.984375,y:.078125},{x:.015625,y:.109375},{x:.015625,y:.109375},{x:.046875,y:.109375},{x:.046875,y:.109375},{x:.078125,y:.109375},{x:.078125,y:.109375},{x:.109375,y:.109375},{x:.109375,y:.109375},{x:.140625,y:.109375},{x:.140625,y:.109375},{x:.171875,y:.109375},{x:.171875,y:.109375},{x:.203125,y:.109375},{x:.203125,y:.109375},{x:.234375,y:.109375},{x:.234375,y:.109375},{x:.265625,y:.109375},{x:.265625,y:.109375},{x:.296875,y:.109375},{x:.296875,y:.109375},{x:.328125,y:.109375},{x:.328125,y:.109375},{x:.359375,y:.109375},{x:.359375,y:.109375},{x:.390625,y:.109375},{x:.390625,y:.109375},{x:.421875,y:.109375},{x:.421875,y:.109375},{x:.453125,y:.109375},{x:.453125,y:.109375},{x:.484375,y:.109375},{x:.484375,y:.109375},{x:.515625,y:.109375},{x:.515625,y:.109375},{x:.546875,y:.109375},{x:.546875,y:.109375},{x:.578125,y:.109375},{x:.578125,y:.109375},{x:.609375,y:.109375},{x:.609375,y:.109375},{x:.640625,y:.109375},{x:.640625,y:.109375},{x:.671875,y:.109375},{x:.671875,y:.109375},{x:.703125,y:.109375},{x:.703125,y:.109375},{x:.734375,y:.109375},{x:.734375,y:.109375},{x:.765625,y:.109375},{x:.765625,y:.109375},{x:.796875,y:.109375},{x:.796875,y:.109375},{x:.828125,y:.109375},{x:.828125,y:.109375},{x:.859375,y:.109375},{x:.859375,y:.109375},{x:.890625,y:.109375},{x:.890625,y:.109375},{x:.921875,y:.109375},{x:.921875,y:.109375},{x:.953125,y:.109375},{x:.953125,y:.109375},{x:.984375,y:.109375},{x:.984375,y:.109375},{x:.015625,y:.140625},{x:.015625,y:.140625},{x:.046875,y:.140625},{x:.046875,y:.140625},{x:.078125,y:.140625},{x:.078125,y:.140625},{x:.109375,y:.140625},{x:.109375,y:.140625},{x:.140625,y:.140625},{x:.140625,y:.140625},{x:.171875,y:.140625},{x:.171875,y:.140625},{x:.203125,y:.140625},{x:.203125,y:.140625},{x:.234375,y:.140625},{x:.234375,y:.140625},{x:.265625,y:.140625},{x:.265625,y:.140625},{x:.296875,y:.140625},{x:.296875,y:.140625},{x:.328125,y:.140625},{x:.328125,y:.140625},{x:.359375,y:.140625},{x:.359375,y:.140625},{x:.390625,y:.140625},{x:.390625,y:.140625},{x:.421875,y:.140625},{x:.421875,y:.140625},{x:.453125,y:.140625},{x:.453125,y:.140625},{x:.484375,y:.140625},{x:.484375,y:.140625},{x:.515625,y:.140625},{x:.515625,y:.140625},{x:.546875,y:.140625},{x:.546875,y:.140625},{x:.578125,y:.140625},{x:.578125,y:.140625},{x:.609375,y:.140625},{x:.609375,y:.140625},{x:.640625,y:.140625},{x:.640625,y:.140625},{x:.671875,y:.140625},{x:.671875,y:.140625},{x:.703125,y:.140625},{x:.703125,y:.140625},{x:.734375,y:.140625},{x:.734375,y:.140625},{x:.765625,y:.140625},{x:.765625,y:.140625},{x:.796875,y:.140625},{x:.796875,y:.140625},{x:.828125,y:.140625},{x:.828125,y:.140625},{x:.859375,y:.140625},{x:.859375,y:.140625},{x:.890625,y:.140625},{x:.890625,y:.140625},{x:.921875,y:.140625},{x:.921875,y:.140625},{x:.953125,y:.140625},{x:.953125,y:.140625},{x:.984375,y:.140625},{x:.984375,y:.140625},{x:.015625,y:.171875},{x:.015625,y:.171875},{x:.046875,y:.171875},{x:.046875,y:.171875},{x:.078125,y:.171875},{x:.078125,y:.171875},{x:.109375,y:.171875},{x:.109375,y:.171875},{x:.140625,y:.171875},{x:.140625,y:.171875},{x:.171875,y:.171875},{x:.171875,y:.171875},{x:.203125,y:.171875},{x:.203125,y:.171875},{x:.234375,y:.171875},{x:.234375,y:.171875},{x:.265625,y:.171875},{x:.265625,y:.171875},{x:.296875,y:.171875},{x:.296875,y:.171875},{x:.328125,y:.171875},{x:.328125,y:.171875},{x:.359375,y:.171875},{x:.359375,y:.171875},{x:.390625,y:.171875},{x:.390625,y:.171875},{x:.421875,y:.171875},{x:.421875,y:.171875},{x:.453125,y:.171875},{x:.453125,y:.171875},{x:.484375,y:.171875},{x:.484375,y:.171875},{x:.515625,y:.171875},{x:.515625,y:.171875},{x:.546875,y:.171875},{x:.546875,y:.171875},{x:.578125,y:.171875},{x:.578125,y:.171875},{x:.609375,y:.171875},{x:.609375,y:.171875},{x:.640625,y:.171875},{x:.640625,y:.171875},{x:.671875,y:.171875},{x:.671875,y:.171875},{x:.703125,y:.171875},{x:.703125,y:.171875},{x:.734375,y:.171875},{x:.734375,y:.171875},{x:.765625,y:.171875},{x:.765625,y:.171875},{x:.796875,y:.171875},{x:.796875,y:.171875},{x:.828125,y:.171875},{x:.828125,y:.171875},{x:.859375,y:.171875},{x:.859375,y:.171875},{x:.890625,y:.171875},{x:.890625,y:.171875},{x:.921875,y:.171875},{x:.921875,y:.171875},{x:.953125,y:.171875},{x:.953125,y:.171875},{x:.984375,y:.171875},{x:.984375,y:.171875},{x:.015625,y:.203125},{x:.015625,y:.203125},{x:.046875,y:.203125},{x:.046875,y:.203125},{x:.078125,y:.203125},{x:.078125,y:.203125},{x:.109375,y:.203125},{x:.109375,y:.203125},{x:.140625,y:.203125},{x:.140625,y:.203125},{x:.171875,y:.203125},{x:.171875,y:.203125},{x:.203125,y:.203125},{x:.203125,y:.203125},{x:.234375,y:.203125},{x:.234375,y:.203125},{x:.265625,y:.203125},{x:.265625,y:.203125},{x:.296875,y:.203125},{x:.296875,y:.203125},{x:.328125,y:.203125},{x:.328125,y:.203125},{x:.359375,y:.203125},{x:.359375,y:.203125},{x:.390625,y:.203125},{x:.390625,y:.203125},{x:.421875,y:.203125},{x:.421875,y:.203125},{x:.453125,y:.203125},{x:.453125,y:.203125},{x:.484375,y:.203125},{x:.484375,y:.203125},{x:.515625,y:.203125},{x:.515625,y:.203125},{x:.546875,y:.203125},{x:.546875,y:.203125},{x:.578125,y:.203125},{x:.578125,y:.203125},{x:.609375,y:.203125},{x:.609375,y:.203125},{x:.640625,y:.203125},{x:.640625,y:.203125},{x:.671875,y:.203125},{x:.671875,y:.203125},{x:.703125,y:.203125},{x:.703125,y:.203125},{x:.734375,y:.203125},{x:.734375,y:.203125},{x:.765625,y:.203125},{x:.765625,y:.203125},{x:.796875,y:.203125},{x:.796875,y:.203125},{x:.828125,y:.203125},{x:.828125,y:.203125},{x:.859375,y:.203125},{x:.859375,y:.203125},{x:.890625,y:.203125},{x:.890625,y:.203125},{x:.921875,y:.203125},{x:.921875,y:.203125},{x:.953125,y:.203125},{x:.953125,y:.203125},{x:.984375,y:.203125},{x:.984375,y:.203125},{x:.015625,y:.234375},{x:.015625,y:.234375},{x:.046875,y:.234375},{x:.046875,y:.234375},{x:.078125,y:.234375},{x:.078125,y:.234375},{x:.109375,y:.234375},{x:.109375,y:.234375},{x:.140625,y:.234375},{x:.140625,y:.234375},{x:.171875,y:.234375},{x:.171875,y:.234375},{x:.203125,y:.234375},{x:.203125,y:.234375},{x:.234375,y:.234375},{x:.234375,y:.234375},{x:.265625,y:.234375},{x:.265625,y:.234375},{x:.296875,y:.234375},{x:.296875,y:.234375},{x:.328125,y:.234375},{x:.328125,y:.234375},{x:.359375,y:.234375},{x:.359375,y:.234375},{x:.390625,y:.234375},{x:.390625,y:.234375},{x:.421875,y:.234375},{x:.421875,y:.234375},{x:.453125,y:.234375},{x:.453125,y:.234375},{x:.484375,y:.234375},{x:.484375,y:.234375},{x:.515625,y:.234375},{x:.515625,y:.234375},{x:.546875,y:.234375},{x:.546875,y:.234375},{x:.578125,y:.234375},{x:.578125,y:.234375},{x:.609375,y:.234375},{x:.609375,y:.234375},{x:.640625,y:.234375},{x:.640625,y:.234375},{x:.671875,y:.234375},{x:.671875,y:.234375},{x:.703125,y:.234375},{x:.703125,y:.234375},{x:.734375,y:.234375},{x:.734375,y:.234375},{x:.765625,y:.234375},{x:.765625,y:.234375},{x:.796875,y:.234375},{x:.796875,y:.234375},{x:.828125,y:.234375},{x:.828125,y:.234375},{x:.859375,y:.234375},{x:.859375,y:.234375},{x:.890625,y:.234375},{x:.890625,y:.234375},{x:.921875,y:.234375},{x:.921875,y:.234375},{x:.953125,y:.234375},{x:.953125,y:.234375},{x:.984375,y:.234375},{x:.984375,y:.234375},{x:.015625,y:.265625},{x:.015625,y:.265625},{x:.046875,y:.265625},{x:.046875,y:.265625},{x:.078125,y:.265625},{x:.078125,y:.265625},{x:.109375,y:.265625},{x:.109375,y:.265625},{x:.140625,y:.265625},{x:.140625,y:.265625},{x:.171875,y:.265625},{x:.171875,y:.265625},{x:.203125,y:.265625},{x:.203125,y:.265625},{x:.234375,y:.265625},{x:.234375,y:.265625},{x:.265625,y:.265625},{x:.265625,y:.265625},{x:.296875,y:.265625},{x:.296875,y:.265625},{x:.328125,y:.265625},{x:.328125,y:.265625},{x:.359375,y:.265625},{x:.359375,y:.265625},{x:.390625,y:.265625},{x:.390625,y:.265625},{x:.421875,y:.265625},{x:.421875,y:.265625},{x:.453125,y:.265625},{x:.453125,y:.265625},{x:.484375,y:.265625},{x:.484375,y:.265625},{x:.515625,y:.265625},{x:.515625,y:.265625},{x:.546875,y:.265625},{x:.546875,y:.265625},{x:.578125,y:.265625},{x:.578125,y:.265625},{x:.609375,y:.265625},{x:.609375,y:.265625},{x:.640625,y:.265625},{x:.640625,y:.265625},{x:.671875,y:.265625},{x:.671875,y:.265625},{x:.703125,y:.265625},{x:.703125,y:.265625},{x:.734375,y:.265625},{x:.734375,y:.265625},{x:.765625,y:.265625},{x:.765625,y:.265625},{x:.796875,y:.265625},{x:.796875,y:.265625},{x:.828125,y:.265625},{x:.828125,y:.265625},{x:.859375,y:.265625},{x:.859375,y:.265625},{x:.890625,y:.265625},{x:.890625,y:.265625},{x:.921875,y:.265625},{x:.921875,y:.265625},{x:.953125,y:.265625},{x:.953125,y:.265625},{x:.984375,y:.265625},{x:.984375,y:.265625},{x:.015625,y:.296875},{x:.015625,y:.296875},{x:.046875,y:.296875},{x:.046875,y:.296875},{x:.078125,y:.296875},{x:.078125,y:.296875},{x:.109375,y:.296875},{x:.109375,y:.296875},{x:.140625,y:.296875},{x:.140625,y:.296875},{x:.171875,y:.296875},{x:.171875,y:.296875},{x:.203125,y:.296875},{x:.203125,y:.296875},{x:.234375,y:.296875},{x:.234375,y:.296875},{x:.265625,y:.296875},{x:.265625,y:.296875},{x:.296875,y:.296875},{x:.296875,y:.296875},{x:.328125,y:.296875},{x:.328125,y:.296875},{x:.359375,y:.296875},{x:.359375,y:.296875},{x:.390625,y:.296875},{x:.390625,y:.296875},{x:.421875,y:.296875},{x:.421875,y:.296875},{x:.453125,y:.296875},{x:.453125,y:.296875},{x:.484375,y:.296875},{x:.484375,y:.296875},{x:.515625,y:.296875},{x:.515625,y:.296875},{x:.546875,y:.296875},{x:.546875,y:.296875},{x:.578125,y:.296875},{x:.578125,y:.296875},{x:.609375,y:.296875},{x:.609375,y:.296875},{x:.640625,y:.296875},{x:.640625,y:.296875},{x:.671875,y:.296875},{x:.671875,y:.296875},{x:.703125,y:.296875},{x:.703125,y:.296875},{x:.734375,y:.296875},{x:.734375,y:.296875},{x:.765625,y:.296875},{x:.765625,y:.296875},{x:.796875,y:.296875},{x:.796875,y:.296875},{x:.828125,y:.296875},{x:.828125,y:.296875},{x:.859375,y:.296875},{x:.859375,y:.296875},{x:.890625,y:.296875},{x:.890625,y:.296875},{x:.921875,y:.296875},{x:.921875,y:.296875},{x:.953125,y:.296875},{x:.953125,y:.296875},{x:.984375,y:.296875},{x:.984375,y:.296875},{x:.015625,y:.328125},{x:.015625,y:.328125},{x:.046875,y:.328125},{x:.046875,y:.328125},{x:.078125,y:.328125},{x:.078125,y:.328125},{x:.109375,y:.328125},{x:.109375,y:.328125},{x:.140625,y:.328125},{x:.140625,y:.328125},{x:.171875,y:.328125},{x:.171875,y:.328125},{x:.203125,y:.328125},{x:.203125,y:.328125},{x:.234375,y:.328125},{x:.234375,y:.328125},{x:.265625,y:.328125},{x:.265625,y:.328125},{x:.296875,y:.328125},{x:.296875,y:.328125},{x:.328125,y:.328125},{x:.328125,y:.328125},{x:.359375,y:.328125},{x:.359375,y:.328125},{x:.390625,y:.328125},{x:.390625,y:.328125},{x:.421875,y:.328125},{x:.421875,y:.328125},{x:.453125,y:.328125},{x:.453125,y:.328125},{x:.484375,y:.328125},{x:.484375,y:.328125},{x:.515625,y:.328125},{x:.515625,y:.328125},{x:.546875,y:.328125},{x:.546875,y:.328125},{x:.578125,y:.328125},{x:.578125,y:.328125},{x:.609375,y:.328125},{x:.609375,y:.328125},{x:.640625,y:.328125},{x:.640625,y:.328125},{x:.671875,y:.328125},{x:.671875,y:.328125},{x:.703125,y:.328125},{x:.703125,y:.328125},{x:.734375,y:.328125},{x:.734375,y:.328125},{x:.765625,y:.328125},{x:.765625,y:.328125},{x:.796875,y:.328125},{x:.796875,y:.328125},{x:.828125,y:.328125},{x:.828125,y:.328125},{x:.859375,y:.328125},{x:.859375,y:.328125},{x:.890625,y:.328125},{x:.890625,y:.328125},{x:.921875,y:.328125},{x:.921875,y:.328125},{x:.953125,y:.328125},{x:.953125,y:.328125},{x:.984375,y:.328125},{x:.984375,y:.328125},{x:.015625,y:.359375},{x:.015625,y:.359375},{x:.046875,y:.359375},{x:.046875,y:.359375},{x:.078125,y:.359375},{x:.078125,y:.359375},{x:.109375,y:.359375},{x:.109375,y:.359375},{x:.140625,y:.359375},{x:.140625,y:.359375},{x:.171875,y:.359375},{x:.171875,y:.359375},{x:.203125,y:.359375},{x:.203125,y:.359375},{x:.234375,y:.359375},{x:.234375,y:.359375},{x:.265625,y:.359375},{x:.265625,y:.359375},{x:.296875,y:.359375},{x:.296875,y:.359375},{x:.328125,y:.359375},{x:.328125,y:.359375},{x:.359375,y:.359375},{x:.359375,y:.359375},{x:.390625,y:.359375},{x:.390625,y:.359375},{x:.421875,y:.359375},{x:.421875,y:.359375},{x:.453125,y:.359375},{x:.453125,y:.359375},{x:.484375,y:.359375},{x:.484375,y:.359375},{x:.515625,y:.359375},{x:.515625,y:.359375},{x:.546875,y:.359375},{x:.546875,y:.359375},{x:.578125,y:.359375},{x:.578125,y:.359375},{x:.609375,y:.359375},{x:.609375,y:.359375},{x:.640625,y:.359375},{x:.640625,y:.359375},{x:.671875,y:.359375},{x:.671875,y:.359375},{x:.703125,y:.359375},{x:.703125,y:.359375},{x:.734375,y:.359375},{x:.734375,y:.359375},{x:.765625,y:.359375},{x:.765625,y:.359375},{x:.796875,y:.359375},{x:.796875,y:.359375},{x:.828125,y:.359375},{x:.828125,y:.359375},{x:.859375,y:.359375},{x:.859375,y:.359375},{x:.890625,y:.359375},{x:.890625,y:.359375},{x:.921875,y:.359375},{x:.921875,y:.359375},{x:.953125,y:.359375},{x:.953125,y:.359375},{x:.984375,y:.359375},{x:.984375,y:.359375},{x:.015625,y:.390625},{x:.015625,y:.390625},{x:.046875,y:.390625},{x:.046875,y:.390625},{x:.078125,y:.390625},{x:.078125,y:.390625},{x:.109375,y:.390625},{x:.109375,y:.390625},{x:.140625,y:.390625},{x:.140625,y:.390625},{x:.171875,y:.390625},{x:.171875,y:.390625},{x:.203125,y:.390625},{x:.203125,y:.390625},{x:.234375,y:.390625},{x:.234375,y:.390625},{x:.265625,y:.390625},{x:.265625,y:.390625},{x:.296875,y:.390625},{x:.296875,y:.390625},{x:.328125,y:.390625},{x:.328125,y:.390625},{x:.359375,y:.390625},{x:.359375,y:.390625},{x:.390625,y:.390625},{x:.390625,y:.390625},{x:.421875,y:.390625},{x:.421875,y:.390625},{x:.453125,y:.390625},{x:.453125,y:.390625},{x:.484375,y:.390625},{x:.484375,y:.390625},{x:.515625,y:.390625},{x:.515625,y:.390625},{x:.546875,y:.390625},{x:.546875,y:.390625},{x:.578125,y:.390625},{x:.578125,y:.390625},{x:.609375,y:.390625},{x:.609375,y:.390625},{x:.640625,y:.390625},{x:.640625,y:.390625},{x:.671875,y:.390625},{x:.671875,y:.390625},{x:.703125,y:.390625},{x:.703125,y:.390625},{x:.734375,y:.390625},{x:.734375,y:.390625},{x:.765625,y:.390625},{x:.765625,y:.390625},{x:.796875,y:.390625},{x:.796875,y:.390625},{x:.828125,y:.390625},{x:.828125,y:.390625},{x:.859375,y:.390625},{x:.859375,y:.390625},{x:.890625,y:.390625},{x:.890625,y:.390625},{x:.921875,y:.390625},{x:.921875,y:.390625},{x:.953125,y:.390625},{x:.953125,y:.390625},{x:.984375,y:.390625},{x:.984375,y:.390625},{x:.015625,y:.421875},{x:.015625,y:.421875},{x:.046875,y:.421875},{x:.046875,y:.421875},{x:.078125,y:.421875},{x:.078125,y:.421875},{x:.109375,y:.421875},{x:.109375,y:.421875},{x:.140625,y:.421875},{x:.140625,y:.421875},{x:.171875,y:.421875},{x:.171875,y:.421875},{x:.203125,y:.421875},{x:.203125,y:.421875},{x:.234375,y:.421875},{x:.234375,y:.421875},{x:.265625,y:.421875},{x:.265625,y:.421875},{x:.296875,y:.421875},{x:.296875,y:.421875},{x:.328125,y:.421875},{x:.328125,y:.421875},{x:.359375,y:.421875},{x:.359375,y:.421875},{x:.390625,y:.421875},{x:.390625,y:.421875},{x:.421875,y:.421875},{x:.421875,y:.421875},{x:.453125,y:.421875},{x:.453125,y:.421875},{x:.484375,y:.421875},{x:.484375,y:.421875},{x:.515625,y:.421875},{x:.515625,y:.421875},{x:.546875,y:.421875},{x:.546875,y:.421875},{x:.578125,y:.421875},{x:.578125,y:.421875},{x:.609375,y:.421875},{x:.609375,y:.421875},{x:.640625,y:.421875},{x:.640625,y:.421875},{x:.671875,y:.421875},{x:.671875,y:.421875},{x:.703125,y:.421875},{x:.703125,y:.421875},{x:.734375,y:.421875},{x:.734375,y:.421875},{x:.765625,y:.421875},{x:.765625,y:.421875},{x:.796875,y:.421875},{x:.796875,y:.421875},{x:.828125,y:.421875},{x:.828125,y:.421875},{x:.859375,y:.421875},{x:.859375,y:.421875},{x:.890625,y:.421875},{x:.890625,y:.421875},{x:.921875,y:.421875},{x:.921875,y:.421875},{x:.953125,y:.421875},{x:.953125,y:.421875},{x:.984375,y:.421875},{x:.984375,y:.421875},{x:.015625,y:.453125},{x:.015625,y:.453125},{x:.046875,y:.453125},{x:.046875,y:.453125},{x:.078125,y:.453125},{x:.078125,y:.453125},{x:.109375,y:.453125},{x:.109375,y:.453125},{x:.140625,y:.453125},{x:.140625,y:.453125},{x:.171875,y:.453125},{x:.171875,y:.453125},{x:.203125,y:.453125},{x:.203125,y:.453125},{x:.234375,y:.453125},{x:.234375,y:.453125},{x:.265625,y:.453125},{x:.265625,y:.453125},{x:.296875,y:.453125},{x:.296875,y:.453125},{x:.328125,y:.453125},{x:.328125,y:.453125},{x:.359375,y:.453125},{x:.359375,y:.453125},{x:.390625,y:.453125},{x:.390625,y:.453125},{x:.421875,y:.453125},{x:.421875,y:.453125},{x:.453125,y:.453125},{x:.453125,y:.453125},{x:.484375,y:.453125},{x:.484375,y:.453125},{x:.515625,y:.453125},{x:.515625,y:.453125},{x:.546875,y:.453125},{x:.546875,y:.453125},{x:.578125,y:.453125},{x:.578125,y:.453125},{x:.609375,y:.453125},{x:.609375,y:.453125},{x:.640625,y:.453125},{x:.640625,y:.453125},{x:.671875,y:.453125},{x:.671875,y:.453125},{x:.703125,y:.453125},{x:.703125,y:.453125},{x:.734375,y:.453125},{x:.734375,y:.453125},{x:.765625,y:.453125},{x:.765625,y:.453125},{x:.796875,y:.453125},{x:.796875,y:.453125},{x:.828125,y:.453125},{x:.828125,y:.453125},{x:.859375,y:.453125},{x:.859375,y:.453125},{x:.890625,y:.453125},{x:.890625,y:.453125},{x:.921875,y:.453125},{x:.921875,y:.453125},{x:.953125,y:.453125},{x:.953125,y:.453125},{x:.984375,y:.453125},{x:.984375,y:.453125},{x:.015625,y:.484375},{x:.015625,y:.484375},{x:.046875,y:.484375},{x:.046875,y:.484375},{x:.078125,y:.484375},{x:.078125,y:.484375},{x:.109375,y:.484375},{x:.109375,y:.484375},{x:.140625,y:.484375},{x:.140625,y:.484375},{x:.171875,y:.484375},{x:.171875,y:.484375},{x:.203125,y:.484375},{x:.203125,y:.484375},{x:.234375,y:.484375},{x:.234375,y:.484375},{x:.265625,y:.484375},{x:.265625,y:.484375},{x:.296875,y:.484375},{x:.296875,y:.484375},{x:.328125,y:.484375},{x:.328125,y:.484375},{x:.359375,y:.484375},{x:.359375,y:.484375},{x:.390625,y:.484375},{x:.390625,y:.484375},{x:.421875,y:.484375},{x:.421875,y:.484375},{x:.453125,y:.484375},{x:.453125,y:.484375},{x:.484375,y:.484375},{x:.484375,y:.484375},{x:.515625,y:.484375},{x:.515625,y:.484375},{x:.546875,y:.484375},{x:.546875,y:.484375},{x:.578125,y:.484375},{x:.578125,y:.484375},{x:.609375,y:.484375},{x:.609375,y:.484375},{x:.640625,y:.484375},{x:.640625,y:.484375},{x:.671875,y:.484375},{x:.671875,y:.484375},{x:.703125,y:.484375},{x:.703125,y:.484375},{x:.734375,y:.484375},{x:.734375,y:.484375},{x:.765625,y:.484375},{x:.765625,y:.484375},{x:.796875,y:.484375},{x:.796875,y:.484375},{x:.828125,y:.484375},{x:.828125,y:.484375},{x:.859375,y:.484375},{x:.859375,y:.484375},{x:.890625,y:.484375},{x:.890625,y:.484375},{x:.921875,y:.484375},{x:.921875,y:.484375},{x:.953125,y:.484375},{x:.953125,y:.484375},{x:.984375,y:.484375},{x:.984375,y:.484375},{x:.015625,y:.515625},{x:.015625,y:.515625},{x:.046875,y:.515625},{x:.046875,y:.515625},{x:.078125,y:.515625},{x:.078125,y:.515625},{x:.109375,y:.515625},{x:.109375,y:.515625},{x:.140625,y:.515625},{x:.140625,y:.515625},{x:.171875,y:.515625},{x:.171875,y:.515625},{x:.203125,y:.515625},{x:.203125,y:.515625},{x:.234375,y:.515625},{x:.234375,y:.515625},{x:.265625,y:.515625},{x:.265625,y:.515625},{x:.296875,y:.515625},{x:.296875,y:.515625},{x:.328125,y:.515625},{x:.328125,y:.515625},{x:.359375,y:.515625},{x:.359375,y:.515625},{x:.390625,y:.515625},{x:.390625,y:.515625},{x:.421875,y:.515625},{x:.421875,y:.515625},{x:.453125,y:.515625},{x:.453125,y:.515625},{x:.484375,y:.515625},{x:.484375,y:.515625},{x:.515625,y:.515625},{x:.515625,y:.515625},{x:.546875,y:.515625},{x:.546875,y:.515625},{x:.578125,y:.515625},{x:.578125,y:.515625},{x:.609375,y:.515625},{x:.609375,y:.515625},{x:.640625,y:.515625},{x:.640625,y:.515625},{x:.671875,y:.515625},{x:.671875,y:.515625},{x:.703125,y:.515625},{x:.703125,y:.515625},{x:.734375,y:.515625},{x:.734375,y:.515625},{x:.765625,y:.515625},{x:.765625,y:.515625},{x:.796875,y:.515625},{x:.796875,y:.515625},{x:.828125,y:.515625},{x:.828125,y:.515625},{x:.859375,y:.515625},{x:.859375,y:.515625},{x:.890625,y:.515625},{x:.890625,y:.515625},{x:.921875,y:.515625},{x:.921875,y:.515625},{x:.953125,y:.515625},{x:.953125,y:.515625},{x:.984375,y:.515625},{x:.984375,y:.515625},{x:.015625,y:.546875},{x:.015625,y:.546875},{x:.046875,y:.546875},{x:.046875,y:.546875},{x:.078125,y:.546875},{x:.078125,y:.546875},{x:.109375,y:.546875},{x:.109375,y:.546875},{x:.140625,y:.546875},{x:.140625,y:.546875},{x:.171875,y:.546875},{x:.171875,y:.546875},{x:.203125,y:.546875},{x:.203125,y:.546875},{x:.234375,y:.546875},{x:.234375,y:.546875},{x:.265625,y:.546875},{x:.265625,y:.546875},{x:.296875,y:.546875},{x:.296875,y:.546875},{x:.328125,y:.546875},{x:.328125,y:.546875},{x:.359375,y:.546875},{x:.359375,y:.546875},{x:.390625,y:.546875},{x:.390625,y:.546875},{x:.421875,y:.546875},{x:.421875,y:.546875},{x:.453125,y:.546875},{x:.453125,y:.546875},{x:.484375,y:.546875},{x:.484375,y:.546875},{x:.515625,y:.546875},{x:.515625,y:.546875},{x:.546875,y:.546875},{x:.546875,y:.546875},{x:.578125,y:.546875},{x:.578125,y:.546875},{x:.609375,y:.546875},{x:.609375,y:.546875},{x:.640625,y:.546875},{x:.640625,y:.546875},{x:.671875,y:.546875},{x:.671875,y:.546875},{x:.703125,y:.546875},{x:.703125,y:.546875},{x:.734375,y:.546875},{x:.734375,y:.546875},{x:.765625,y:.546875},{x:.765625,y:.546875},{x:.796875,y:.546875},{x:.796875,y:.546875},{x:.828125,y:.546875},{x:.828125,y:.546875},{x:.859375,y:.546875},{x:.859375,y:.546875},{x:.890625,y:.546875},{x:.890625,y:.546875},{x:.921875,y:.546875},{x:.921875,y:.546875},{x:.953125,y:.546875},{x:.953125,y:.546875},{x:.984375,y:.546875},{x:.984375,y:.546875},{x:.015625,y:.578125},{x:.015625,y:.578125},{x:.046875,y:.578125},{x:.046875,y:.578125},{x:.078125,y:.578125},{x:.078125,y:.578125},{x:.109375,y:.578125},{x:.109375,y:.578125},{x:.140625,y:.578125},{x:.140625,y:.578125},{x:.171875,y:.578125},{x:.171875,y:.578125},{x:.203125,y:.578125},{x:.203125,y:.578125},{x:.234375,y:.578125},{x:.234375,y:.578125},{x:.265625,y:.578125},{x:.265625,y:.578125},{x:.296875,y:.578125},{x:.296875,y:.578125},{x:.328125,y:.578125},{x:.328125,y:.578125},{x:.359375,y:.578125},{x:.359375,y:.578125},{x:.390625,y:.578125},{x:.390625,y:.578125},{x:.421875,y:.578125},{x:.421875,y:.578125},{x:.453125,y:.578125},{x:.453125,y:.578125},{x:.484375,y:.578125},{x:.484375,y:.578125},{x:.515625,y:.578125},{x:.515625,y:.578125},{x:.546875,y:.578125},{x:.546875,y:.578125},{x:.578125,y:.578125},{x:.578125,y:.578125},{x:.609375,y:.578125},{x:.609375,y:.578125},{x:.640625,y:.578125},{x:.640625,y:.578125},{x:.671875,y:.578125},{x:.671875,y:.578125},{x:.703125,y:.578125},{x:.703125,y:.578125},{x:.734375,y:.578125},{x:.734375,y:.578125},{x:.765625,y:.578125},{x:.765625,y:.578125},{x:.796875,y:.578125},{x:.796875,y:.578125},{x:.828125,y:.578125},{x:.828125,y:.578125},{x:.859375,y:.578125},{x:.859375,y:.578125},{x:.890625,y:.578125},{x:.890625,y:.578125},{x:.921875,y:.578125},{x:.921875,y:.578125},{x:.953125,y:.578125},{x:.953125,y:.578125},{x:.984375,y:.578125},{x:.984375,y:.578125},{x:.015625,y:.609375},{x:.015625,y:.609375},{x:.046875,y:.609375},{x:.046875,y:.609375},{x:.078125,y:.609375},{x:.078125,y:.609375},{x:.109375,y:.609375},{x:.109375,y:.609375},{x:.140625,y:.609375},{x:.140625,y:.609375},{x:.171875,y:.609375},{x:.171875,y:.609375},{x:.203125,y:.609375},{x:.203125,y:.609375},{x:.234375,y:.609375},{x:.234375,y:.609375},{x:.265625,y:.609375},{x:.265625,y:.609375},{x:.296875,y:.609375},{x:.296875,y:.609375},{x:.328125,y:.609375},{x:.328125,y:.609375},{x:.359375,y:.609375},{x:.359375,y:.609375},{x:.390625,y:.609375},{x:.390625,y:.609375},{x:.421875,y:.609375},{x:.421875,y:.609375},{x:.453125,y:.609375},{x:.453125,y:.609375},{x:.484375,y:.609375},{x:.484375,y:.609375},{x:.515625,y:.609375},{x:.515625,y:.609375},{x:.546875,y:.609375},{x:.546875,y:.609375},{x:.578125,y:.609375},{x:.578125,y:.609375},{x:.609375,y:.609375},{x:.609375,y:.609375},{x:.640625,y:.609375},{x:.640625,y:.609375},{x:.671875,y:.609375},{x:.671875,y:.609375},{x:.703125,y:.609375},{x:.703125,y:.609375},{x:.734375,y:.609375},{x:.734375,y:.609375},{x:.765625,y:.609375},{x:.765625,y:.609375},{x:.796875,y:.609375},{x:.796875,y:.609375},{x:.828125,y:.609375},{x:.828125,y:.609375},{x:.859375,y:.609375},{x:.859375,y:.609375},{x:.890625,y:.609375},{x:.890625,y:.609375},{x:.921875,y:.609375},{x:.921875,y:.609375},{x:.953125,y:.609375},{x:.953125,y:.609375},{x:.984375,y:.609375},{x:.984375,y:.609375},{x:.015625,y:.640625},{x:.015625,y:.640625},{x:.046875,y:.640625},{x:.046875,y:.640625},{x:.078125,y:.640625},{x:.078125,y:.640625},{x:.109375,y:.640625},{x:.109375,y:.640625},{x:.140625,y:.640625},{x:.140625,y:.640625},{x:.171875,y:.640625},{x:.171875,y:.640625},{x:.203125,y:.640625},{x:.203125,y:.640625},{x:.234375,y:.640625},{x:.234375,y:.640625},{x:.265625,y:.640625},{x:.265625,y:.640625},{x:.296875,y:.640625},{x:.296875,y:.640625},{x:.328125,y:.640625},{x:.328125,y:.640625},{x:.359375,y:.640625},{x:.359375,y:.640625},{x:.390625,y:.640625},{x:.390625,y:.640625},{x:.421875,y:.640625},{x:.421875,y:.640625},{x:.453125,y:.640625},{x:.453125,y:.640625},{x:.484375,y:.640625},{x:.484375,y:.640625},{x:.515625,y:.640625},{x:.515625,y:.640625},{x:.546875,y:.640625},{x:.546875,y:.640625},{x:.578125,y:.640625},{x:.578125,y:.640625},{x:.609375,y:.640625},{x:.609375,y:.640625},{x:.640625,y:.640625},{x:.640625,y:.640625},{x:.671875,y:.640625},{x:.671875,y:.640625},{x:.703125,y:.640625},{x:.703125,y:.640625},{x:.734375,y:.640625},{x:.734375,y:.640625},{x:.765625,y:.640625},{x:.765625,y:.640625},{x:.796875,y:.640625},{x:.796875,y:.640625},{x:.828125,y:.640625},{x:.828125,y:.640625},{x:.859375,y:.640625},{x:.859375,y:.640625},{x:.890625,y:.640625},{x:.890625,y:.640625},{x:.921875,y:.640625},{x:.921875,y:.640625},{x:.953125,y:.640625},{x:.953125,y:.640625},{x:.984375,y:.640625},{x:.984375,y:.640625},{x:.015625,y:.671875},{x:.015625,y:.671875},{x:.046875,y:.671875},{x:.046875,y:.671875},{x:.078125,y:.671875},{x:.078125,y:.671875},{x:.109375,y:.671875},{x:.109375,y:.671875},{x:.140625,y:.671875},{x:.140625,y:.671875},{x:.171875,y:.671875},{x:.171875,y:.671875},{x:.203125,y:.671875},{x:.203125,y:.671875},{x:.234375,y:.671875},{x:.234375,y:.671875},{x:.265625,y:.671875},{x:.265625,y:.671875},{x:.296875,y:.671875},{x:.296875,y:.671875},{x:.328125,y:.671875},{x:.328125,y:.671875},{x:.359375,y:.671875},{x:.359375,y:.671875},{x:.390625,y:.671875},{x:.390625,y:.671875},{x:.421875,y:.671875},{x:.421875,y:.671875},{x:.453125,y:.671875},{x:.453125,y:.671875},{x:.484375,y:.671875},{x:.484375,y:.671875},{x:.515625,y:.671875},{x:.515625,y:.671875},{x:.546875,y:.671875},{x:.546875,y:.671875},{x:.578125,y:.671875},{x:.578125,y:.671875},{x:.609375,y:.671875},{x:.609375,y:.671875},{x:.640625,y:.671875},{x:.640625,y:.671875},{x:.671875,y:.671875},{x:.671875,y:.671875},{x:.703125,y:.671875},{x:.703125,y:.671875},{x:.734375,y:.671875},{x:.734375,y:.671875},{x:.765625,y:.671875},{x:.765625,y:.671875},{x:.796875,y:.671875},{x:.796875,y:.671875},{x:.828125,y:.671875},{x:.828125,y:.671875},{x:.859375,y:.671875},{x:.859375,y:.671875},{x:.890625,y:.671875},{x:.890625,y:.671875},{x:.921875,y:.671875},{x:.921875,y:.671875},{x:.953125,y:.671875},{x:.953125,y:.671875},{x:.984375,y:.671875},{x:.984375,y:.671875},{x:.015625,y:.703125},{x:.015625,y:.703125},{x:.046875,y:.703125},{x:.046875,y:.703125},{x:.078125,y:.703125},{x:.078125,y:.703125},{x:.109375,y:.703125},{x:.109375,y:.703125},{x:.140625,y:.703125},{x:.140625,y:.703125},{x:.171875,y:.703125},{x:.171875,y:.703125},{x:.203125,y:.703125},{x:.203125,y:.703125},{x:.234375,y:.703125},{x:.234375,y:.703125},{x:.265625,y:.703125},{x:.265625,y:.703125},{x:.296875,y:.703125},{x:.296875,y:.703125},{x:.328125,y:.703125},{x:.328125,y:.703125},{x:.359375,y:.703125},{x:.359375,y:.703125},{x:.390625,y:.703125},{x:.390625,y:.703125},{x:.421875,y:.703125},{x:.421875,y:.703125},{x:.453125,y:.703125},{x:.453125,y:.703125},{x:.484375,y:.703125},{x:.484375,y:.703125},{x:.515625,y:.703125},{x:.515625,y:.703125},{x:.546875,y:.703125},{x:.546875,y:.703125},{x:.578125,y:.703125},{x:.578125,y:.703125},{x:.609375,y:.703125},{x:.609375,y:.703125},{x:.640625,y:.703125},{x:.640625,y:.703125},{x:.671875,y:.703125},{x:.671875,y:.703125},{x:.703125,y:.703125},{x:.703125,y:.703125},{x:.734375,y:.703125},{x:.734375,y:.703125},{x:.765625,y:.703125},{x:.765625,y:.703125},{x:.796875,y:.703125},{x:.796875,y:.703125},{x:.828125,y:.703125},{x:.828125,y:.703125},{x:.859375,y:.703125},{x:.859375,y:.703125},{x:.890625,y:.703125},{x:.890625,y:.703125},{x:.921875,y:.703125},{x:.921875,y:.703125},{x:.953125,y:.703125},{x:.953125,y:.703125},{x:.984375,y:.703125},{x:.984375,y:.703125},{x:.015625,y:.734375},{x:.015625,y:.734375},{x:.046875,y:.734375},{x:.046875,y:.734375},{x:.078125,y:.734375},{x:.078125,y:.734375},{x:.109375,y:.734375},{x:.109375,y:.734375},{x:.140625,y:.734375},{x:.140625,y:.734375},{x:.171875,y:.734375},{x:.171875,y:.734375},{x:.203125,y:.734375},{x:.203125,y:.734375},{x:.234375,y:.734375},{x:.234375,y:.734375},{x:.265625,y:.734375},{x:.265625,y:.734375},{x:.296875,y:.734375},{x:.296875,y:.734375},{x:.328125,y:.734375},{x:.328125,y:.734375},{x:.359375,y:.734375},{x:.359375,y:.734375},{x:.390625,y:.734375},{x:.390625,y:.734375},{x:.421875,y:.734375},{x:.421875,y:.734375},{x:.453125,y:.734375},{x:.453125,y:.734375},{x:.484375,y:.734375},{x:.484375,y:.734375},{x:.515625,y:.734375},{x:.515625,y:.734375},{x:.546875,y:.734375},{x:.546875,y:.734375},{x:.578125,y:.734375},{x:.578125,y:.734375},{x:.609375,y:.734375},{x:.609375,y:.734375},{x:.640625,y:.734375},{x:.640625,y:.734375},{x:.671875,y:.734375},{x:.671875,y:.734375},{x:.703125,y:.734375},{x:.703125,y:.734375},{x:.734375,y:.734375},{x:.734375,y:.734375},{x:.765625,y:.734375},{x:.765625,y:.734375},{x:.796875,y:.734375},{x:.796875,y:.734375},{x:.828125,y:.734375},{x:.828125,y:.734375},{x:.859375,y:.734375},{x:.859375,y:.734375},{x:.890625,y:.734375},{x:.890625,y:.734375},{x:.921875,y:.734375},{x:.921875,y:.734375},{x:.953125,y:.734375},{x:.953125,y:.734375},{x:.984375,y:.734375},{x:.984375,y:.734375},{x:.015625,y:.765625},{x:.015625,y:.765625},{x:.046875,y:.765625},{x:.046875,y:.765625},{x:.078125,y:.765625},{x:.078125,y:.765625},{x:.109375,y:.765625},{x:.109375,y:.765625},{x:.140625,y:.765625},{x:.140625,y:.765625},{x:.171875,y:.765625},{x:.171875,y:.765625},{x:.203125,y:.765625},{x:.203125,y:.765625},{x:.234375,y:.765625},{x:.234375,y:.765625},{x:.265625,y:.765625},{x:.265625,y:.765625},{x:.296875,y:.765625},{x:.296875,y:.765625},{x:.328125,y:.765625},{x:.328125,y:.765625},{x:.359375,y:.765625},{x:.359375,y:.765625},{x:.390625,y:.765625},{x:.390625,y:.765625},{x:.421875,y:.765625},{x:.421875,y:.765625},{x:.453125,y:.765625},{x:.453125,y:.765625},{x:.484375,y:.765625},{x:.484375,y:.765625},{x:.515625,y:.765625},{x:.515625,y:.765625},{x:.546875,y:.765625},{x:.546875,y:.765625},{x:.578125,y:.765625},{x:.578125,y:.765625},{x:.609375,y:.765625},{x:.609375,y:.765625},{x:.640625,y:.765625},{x:.640625,y:.765625},{x:.671875,y:.765625},{x:.671875,y:.765625},{x:.703125,y:.765625},{x:.703125,y:.765625},{x:.734375,y:.765625},{x:.734375,y:.765625},{x:.765625,y:.765625},{x:.765625,y:.765625},{x:.796875,y:.765625},{x:.796875,y:.765625},{x:.828125,y:.765625},{x:.828125,y:.765625},{x:.859375,y:.765625},{x:.859375,y:.765625},{x:.890625,y:.765625},{x:.890625,y:.765625},{x:.921875,y:.765625},{x:.921875,y:.765625},{x:.953125,y:.765625},{x:.953125,y:.765625},{x:.984375,y:.765625},{x:.984375,y:.765625},{x:.015625,y:.796875},{x:.015625,y:.796875},{x:.046875,y:.796875},{x:.046875,y:.796875},{x:.078125,y:.796875},{x:.078125,y:.796875},{x:.109375,y:.796875},{x:.109375,y:.796875},{x:.140625,y:.796875},{x:.140625,y:.796875},{x:.171875,y:.796875},{x:.171875,y:.796875},{x:.203125,y:.796875},{x:.203125,y:.796875},{x:.234375,y:.796875},{x:.234375,y:.796875},{x:.265625,y:.796875},{x:.265625,y:.796875},{x:.296875,y:.796875},{x:.296875,y:.796875},{x:.328125,y:.796875},{x:.328125,y:.796875},{x:.359375,y:.796875},{x:.359375,y:.796875},{x:.390625,y:.796875},{x:.390625,y:.796875},{x:.421875,y:.796875},{x:.421875,y:.796875},{x:.453125,y:.796875},{x:.453125,y:.796875},{x:.484375,y:.796875},{x:.484375,y:.796875},{x:.515625,y:.796875},{x:.515625,y:.796875},{x:.546875,y:.796875},{x:.546875,y:.796875},{x:.578125,y:.796875},{x:.578125,y:.796875},{x:.609375,y:.796875},{x:.609375,y:.796875},{x:.640625,y:.796875},{x:.640625,y:.796875},{x:.671875,y:.796875},{x:.671875,y:.796875},{x:.703125,y:.796875},{x:.703125,y:.796875},{x:.734375,y:.796875},{x:.734375,y:.796875},{x:.765625,y:.796875},{x:.765625,y:.796875},{x:.796875,y:.796875},{x:.796875,y:.796875},{x:.828125,y:.796875},{x:.828125,y:.796875},{x:.859375,y:.796875},{x:.859375,y:.796875},{x:.890625,y:.796875},{x:.890625,y:.796875},{x:.921875,y:.796875},{x:.921875,y:.796875},{x:.953125,y:.796875},{x:.953125,y:.796875},{x:.984375,y:.796875},{x:.984375,y:.796875},{x:.015625,y:.828125},{x:.015625,y:.828125},{x:.046875,y:.828125},{x:.046875,y:.828125},{x:.078125,y:.828125},{x:.078125,y:.828125},{x:.109375,y:.828125},{x:.109375,y:.828125},{x:.140625,y:.828125},{x:.140625,y:.828125},{x:.171875,y:.828125},{x:.171875,y:.828125},{x:.203125,y:.828125},{x:.203125,y:.828125},{x:.234375,y:.828125},{x:.234375,y:.828125},{x:.265625,y:.828125},{x:.265625,y:.828125},{x:.296875,y:.828125},{x:.296875,y:.828125},{x:.328125,y:.828125},{x:.328125,y:.828125},{x:.359375,y:.828125},{x:.359375,y:.828125},{x:.390625,y:.828125},{x:.390625,y:.828125},{x:.421875,y:.828125},{x:.421875,y:.828125},{x:.453125,y:.828125},{x:.453125,y:.828125},{x:.484375,y:.828125},{x:.484375,y:.828125},{x:.515625,y:.828125},{x:.515625,y:.828125},{x:.546875,y:.828125},{x:.546875,y:.828125},{x:.578125,y:.828125},{x:.578125,y:.828125},{x:.609375,y:.828125},{x:.609375,y:.828125},{x:.640625,y:.828125},{x:.640625,y:.828125},{x:.671875,y:.828125},{x:.671875,y:.828125},{x:.703125,y:.828125},{x:.703125,y:.828125},{x:.734375,y:.828125},{x:.734375,y:.828125},{x:.765625,y:.828125},{x:.765625,y:.828125},{x:.796875,y:.828125},{x:.796875,y:.828125},{x:.828125,y:.828125},{x:.828125,y:.828125},{x:.859375,y:.828125},{x:.859375,y:.828125},{x:.890625,y:.828125},{x:.890625,y:.828125},{x:.921875,y:.828125},{x:.921875,y:.828125},{x:.953125,y:.828125},{x:.953125,y:.828125},{x:.984375,y:.828125},{x:.984375,y:.828125},{x:.015625,y:.859375},{x:.015625,y:.859375},{x:.046875,y:.859375},{x:.046875,y:.859375},{x:.078125,y:.859375},{x:.078125,y:.859375},{x:.109375,y:.859375},{x:.109375,y:.859375},{x:.140625,y:.859375},{x:.140625,y:.859375},{x:.171875,y:.859375},{x:.171875,y:.859375},{x:.203125,y:.859375},{x:.203125,y:.859375},{x:.234375,y:.859375},{x:.234375,y:.859375},{x:.265625,y:.859375},{x:.265625,y:.859375},{x:.296875,y:.859375},{x:.296875,y:.859375},{x:.328125,y:.859375},{x:.328125,y:.859375},{x:.359375,y:.859375},{x:.359375,y:.859375},{x:.390625,y:.859375},{x:.390625,y:.859375},{x:.421875,y:.859375},{x:.421875,y:.859375},{x:.453125,y:.859375},{x:.453125,y:.859375},{x:.484375,y:.859375},{x:.484375,y:.859375},{x:.515625,y:.859375},{x:.515625,y:.859375},{x:.546875,y:.859375},{x:.546875,y:.859375},{x:.578125,y:.859375},{x:.578125,y:.859375},{x:.609375,y:.859375},{x:.609375,y:.859375},{x:.640625,y:.859375},{x:.640625,y:.859375},{x:.671875,y:.859375},{x:.671875,y:.859375},{x:.703125,y:.859375},{x:.703125,y:.859375},{x:.734375,y:.859375},{x:.734375,y:.859375},{x:.765625,y:.859375},{x:.765625,y:.859375},{x:.796875,y:.859375},{x:.796875,y:.859375},{x:.828125,y:.859375},{x:.828125,y:.859375},{x:.859375,y:.859375},{x:.859375,y:.859375},{x:.890625,y:.859375},{x:.890625,y:.859375},{x:.921875,y:.859375},{x:.921875,y:.859375},{x:.953125,y:.859375},{x:.953125,y:.859375},{x:.984375,y:.859375},{x:.984375,y:.859375},{x:.015625,y:.890625},{x:.015625,y:.890625},{x:.046875,y:.890625},{x:.046875,y:.890625},{x:.078125,y:.890625},{x:.078125,y:.890625},{x:.109375,y:.890625},{x:.109375,y:.890625},{x:.140625,y:.890625},{x:.140625,y:.890625},{x:.171875,y:.890625},{x:.171875,y:.890625},{x:.203125,y:.890625},{x:.203125,y:.890625},{x:.234375,y:.890625},{x:.234375,y:.890625},{x:.265625,y:.890625},{x:.265625,y:.890625},{x:.296875,y:.890625},{x:.296875,y:.890625},{x:.328125,y:.890625},{x:.328125,y:.890625},{x:.359375,y:.890625},{x:.359375,y:.890625},{x:.390625,y:.890625},{x:.390625,y:.890625},{x:.421875,y:.890625},{x:.421875,y:.890625},{x:.453125,y:.890625},{x:.453125,y:.890625},{x:.484375,y:.890625},{x:.484375,y:.890625},{x:.515625,y:.890625},{x:.515625,y:.890625},{x:.546875,y:.890625},{x:.546875,y:.890625},{x:.578125,y:.890625},{x:.578125,y:.890625},{x:.609375,y:.890625},{x:.609375,y:.890625},{x:.640625,y:.890625},{x:.640625,y:.890625},{x:.671875,y:.890625},{x:.671875,y:.890625},{x:.703125,y:.890625},{x:.703125,y:.890625},{x:.734375,y:.890625},{x:.734375,y:.890625},{x:.765625,y:.890625},{x:.765625,y:.890625},{x:.796875,y:.890625},{x:.796875,y:.890625},{x:.828125,y:.890625},{x:.828125,y:.890625},{x:.859375,y:.890625},{x:.859375,y:.890625},{x:.890625,y:.890625},{x:.890625,y:.890625},{x:.921875,y:.890625},{x:.921875,y:.890625},{x:.953125,y:.890625},{x:.953125,y:.890625},{x:.984375,y:.890625},{x:.984375,y:.890625},{x:.015625,y:.921875},{x:.015625,y:.921875},{x:.046875,y:.921875},{x:.046875,y:.921875},{x:.078125,y:.921875},{x:.078125,y:.921875},{x:.109375,y:.921875},{x:.109375,y:.921875},{x:.140625,y:.921875},{x:.140625,y:.921875},{x:.171875,y:.921875},{x:.171875,y:.921875},{x:.203125,y:.921875},{x:.203125,y:.921875},{x:.234375,y:.921875},{x:.234375,y:.921875},{x:.265625,y:.921875},{x:.265625,y:.921875},{x:.296875,y:.921875},{x:.296875,y:.921875},{x:.328125,y:.921875},{x:.328125,y:.921875},{x:.359375,y:.921875},{x:.359375,y:.921875},{x:.390625,y:.921875},{x:.390625,y:.921875},{x:.421875,y:.921875},{x:.421875,y:.921875},{x:.453125,y:.921875},{x:.453125,y:.921875},{x:.484375,y:.921875},{x:.484375,y:.921875},{x:.515625,y:.921875},{x:.515625,y:.921875},{x:.546875,y:.921875},{x:.546875,y:.921875},{x:.578125,y:.921875},{x:.578125,y:.921875},{x:.609375,y:.921875},{x:.609375,y:.921875},{x:.640625,y:.921875},{x:.640625,y:.921875},{x:.671875,y:.921875},{x:.671875,y:.921875},{x:.703125,y:.921875},{x:.703125,y:.921875},{x:.734375,y:.921875},{x:.734375,y:.921875},{x:.765625,y:.921875},{x:.765625,y:.921875},{x:.796875,y:.921875},{x:.796875,y:.921875},{x:.828125,y:.921875},{x:.828125,y:.921875},{x:.859375,y:.921875},{x:.859375,y:.921875},{x:.890625,y:.921875},{x:.890625,y:.921875},{x:.921875,y:.921875},{x:.921875,y:.921875},{x:.953125,y:.921875},{x:.953125,y:.921875},{x:.984375,y:.921875},{x:.984375,y:.921875},{x:.015625,y:.953125},{x:.015625,y:.953125},{x:.046875,y:.953125},{x:.046875,y:.953125},{x:.078125,y:.953125},{x:.078125,y:.953125},{x:.109375,y:.953125},{x:.109375,y:.953125},{x:.140625,y:.953125},{x:.140625,y:.953125},{x:.171875,y:.953125},{x:.171875,y:.953125},{x:.203125,y:.953125},{x:.203125,y:.953125},{x:.234375,y:.953125},{x:.234375,y:.953125},{x:.265625,y:.953125},{x:.265625,y:.953125},{x:.296875,y:.953125},{x:.296875,y:.953125},{x:.328125,y:.953125},{x:.328125,y:.953125},{x:.359375,y:.953125},{x:.359375,y:.953125},{x:.390625,y:.953125},{x:.390625,y:.953125},{x:.421875,y:.953125},{x:.421875,y:.953125},{x:.453125,y:.953125},{x:.453125,y:.953125},{x:.484375,y:.953125},{x:.484375,y:.953125},{x:.515625,y:.953125},{x:.515625,y:.953125},{x:.546875,y:.953125},{x:.546875,y:.953125},{x:.578125,y:.953125},{x:.578125,y:.953125},{x:.609375,y:.953125},{x:.609375,y:.953125},{x:.640625,y:.953125},{x:.640625,y:.953125},{x:.671875,y:.953125},{x:.671875,y:.953125},{x:.703125,y:.953125},{x:.703125,y:.953125},{x:.734375,y:.953125},{x:.734375,y:.953125},{x:.765625,y:.953125},{x:.765625,y:.953125},{x:.796875,y:.953125},{x:.796875,y:.953125},{x:.828125,y:.953125},{x:.828125,y:.953125},{x:.859375,y:.953125},{x:.859375,y:.953125},{x:.890625,y:.953125},{x:.890625,y:.953125},{x:.921875,y:.953125},{x:.921875,y:.953125},{x:.953125,y:.953125},{x:.953125,y:.953125},{x:.984375,y:.953125},{x:.984375,y:.953125},{x:.015625,y:.984375},{x:.015625,y:.984375},{x:.046875,y:.984375},{x:.046875,y:.984375},{x:.078125,y:.984375},{x:.078125,y:.984375},{x:.109375,y:.984375},{x:.109375,y:.984375},{x:.140625,y:.984375},{x:.140625,y:.984375},{x:.171875,y:.984375},{x:.171875,y:.984375},{x:.203125,y:.984375},{x:.203125,y:.984375},{x:.234375,y:.984375},{x:.234375,y:.984375},{x:.265625,y:.984375},{x:.265625,y:.984375},{x:.296875,y:.984375},{x:.296875,y:.984375},{x:.328125,y:.984375},{x:.328125,y:.984375},{x:.359375,y:.984375},{x:.359375,y:.984375},{x:.390625,y:.984375},{x:.390625,y:.984375},{x:.421875,y:.984375},{x:.421875,y:.984375},{x:.453125,y:.984375},{x:.453125,y:.984375},{x:.484375,y:.984375},{x:.484375,y:.984375},{x:.515625,y:.984375},{x:.515625,y:.984375},{x:.546875,y:.984375},{x:.546875,y:.984375},{x:.578125,y:.984375},{x:.578125,y:.984375},{x:.609375,y:.984375},{x:.609375,y:.984375},{x:.640625,y:.984375},{x:.640625,y:.984375},{x:.671875,y:.984375},{x:.671875,y:.984375},{x:.703125,y:.984375},{x:.703125,y:.984375},{x:.734375,y:.984375},{x:.734375,y:.984375},{x:.765625,y:.984375},{x:.765625,y:.984375},{x:.796875,y:.984375},{x:.796875,y:.984375},{x:.828125,y:.984375},{x:.828125,y:.984375},{x:.859375,y:.984375},{x:.859375,y:.984375},{x:.890625,y:.984375},{x:.890625,y:.984375},{x:.921875,y:.984375},{x:.921875,y:.984375},{x:.953125,y:.984375},{x:.953125,y:.984375},{x:.984375,y:.984375},{x:.984375,y:.984375},{x:.03125,y:.03125},{x:.03125,y:.03125},{x:.09375,y:.03125},{x:.09375,y:.03125},{x:.15625,y:.03125},{x:.15625,y:.03125},{x:.21875,y:.03125},{x:.21875,y:.03125},{x:.28125,y:.03125},{x:.28125,y:.03125},{x:.34375,y:.03125},{x:.34375,y:.03125},{x:.40625,y:.03125},{x:.40625,y:.03125},{x:.46875,y:.03125},{x:.46875,y:.03125},{x:.53125,y:.03125},{x:.53125,y:.03125},{x:.59375,y:.03125},{x:.59375,y:.03125},{x:.65625,y:.03125},{x:.65625,y:.03125},{x:.71875,y:.03125},{x:.71875,y:.03125},{x:.78125,y:.03125},{x:.78125,y:.03125},{x:.84375,y:.03125},{x:.84375,y:.03125},{x:.90625,y:.03125},{x:.90625,y:.03125},{x:.96875,y:.03125},{x:.96875,y:.03125},{x:.03125,y:.09375},{x:.03125,y:.09375},{x:.09375,y:.09375},{x:.09375,y:.09375},{x:.15625,y:.09375},{x:.15625,y:.09375},{x:.21875,y:.09375},{x:.21875,y:.09375},{x:.28125,y:.09375},{x:.28125,y:.09375},{x:.34375,y:.09375},{x:.34375,y:.09375},{x:.40625,y:.09375},{x:.40625,y:.09375},{x:.46875,y:.09375},{x:.46875,y:.09375},{x:.53125,y:.09375},{x:.53125,y:.09375},{x:.59375,y:.09375},{x:.59375,y:.09375},{x:.65625,y:.09375},{x:.65625,y:.09375},{x:.71875,y:.09375},{x:.71875,y:.09375},{x:.78125,y:.09375},{x:.78125,y:.09375},{x:.84375,y:.09375},{x:.84375,y:.09375},{x:.90625,y:.09375},{x:.90625,y:.09375},{x:.96875,y:.09375},{x:.96875,y:.09375},{x:.03125,y:.15625},{x:.03125,y:.15625},{x:.09375,y:.15625},{x:.09375,y:.15625},{x:.15625,y:.15625},{x:.15625,y:.15625},{x:.21875,y:.15625},{x:.21875,y:.15625},{x:.28125,y:.15625},{x:.28125,y:.15625},{x:.34375,y:.15625},{x:.34375,y:.15625},{x:.40625,y:.15625},{x:.40625,y:.15625},{x:.46875,y:.15625},{x:.46875,y:.15625},{x:.53125,y:.15625},{x:.53125,y:.15625},{x:.59375,y:.15625},{x:.59375,y:.15625},{x:.65625,y:.15625},{x:.65625,y:.15625},{x:.71875,y:.15625},{x:.71875,y:.15625},{x:.78125,y:.15625},{x:.78125,y:.15625},{x:.84375,y:.15625},{x:.84375,y:.15625},{x:.90625,y:.15625},{x:.90625,y:.15625},{x:.96875,y:.15625},{x:.96875,y:.15625},{x:.03125,y:.21875},{x:.03125,y:.21875},{x:.09375,y:.21875},{x:.09375,y:.21875},{x:.15625,y:.21875},{x:.15625,y:.21875},{x:.21875,y:.21875},{x:.21875,y:.21875},{x:.28125,y:.21875},{x:.28125,y:.21875},{x:.34375,y:.21875},{x:.34375,y:.21875},{x:.40625,y:.21875},{x:.40625,y:.21875},{x:.46875,y:.21875},{x:.46875,y:.21875},{x:.53125,y:.21875},{x:.53125,y:.21875},{x:.59375,y:.21875},{x:.59375,y:.21875},{x:.65625,y:.21875},{x:.65625,y:.21875},{x:.71875,y:.21875},{x:.71875,y:.21875},{x:.78125,y:.21875},{x:.78125,y:.21875},{x:.84375,y:.21875},{x:.84375,y:.21875},{x:.90625,y:.21875},{x:.90625,y:.21875},{x:.96875,y:.21875},{x:.96875,y:.21875},{x:.03125,y:.28125},{x:.03125,y:.28125},{x:.09375,y:.28125},{x:.09375,y:.28125},{x:.15625,y:.28125},{x:.15625,y:.28125},{x:.21875,y:.28125},{x:.21875,y:.28125},{x:.28125,y:.28125},{x:.28125,y:.28125},{x:.34375,y:.28125},{x:.34375,y:.28125},{x:.40625,y:.28125},{x:.40625,y:.28125},{x:.46875,y:.28125},{x:.46875,y:.28125},{x:.53125,y:.28125},{x:.53125,y:.28125},{x:.59375,y:.28125},{x:.59375,y:.28125},{x:.65625,y:.28125},{x:.65625,y:.28125},{x:.71875,y:.28125},{x:.71875,y:.28125},{x:.78125,y:.28125},{x:.78125,y:.28125},{x:.84375,y:.28125},{x:.84375,y:.28125},{x:.90625,y:.28125},{x:.90625,y:.28125},{x:.96875,y:.28125},{x:.96875,y:.28125},{x:.03125,y:.34375},{x:.03125,y:.34375},{x:.09375,y:.34375},{x:.09375,y:.34375},{x:.15625,y:.34375},{x:.15625,y:.34375},{x:.21875,y:.34375},{x:.21875,y:.34375},{x:.28125,y:.34375},{x:.28125,y:.34375},{x:.34375,y:.34375},{x:.34375,y:.34375},{x:.40625,y:.34375},{x:.40625,y:.34375},{x:.46875,y:.34375},{x:.46875,y:.34375},{x:.53125,y:.34375},{x:.53125,y:.34375},{x:.59375,y:.34375},{x:.59375,y:.34375},{x:.65625,y:.34375},{x:.65625,y:.34375},{x:.71875,y:.34375},{x:.71875,y:.34375},{x:.78125,y:.34375},{x:.78125,y:.34375},{x:.84375,y:.34375},{x:.84375,y:.34375},{x:.90625,y:.34375},{x:.90625,y:.34375},{x:.96875,y:.34375},{x:.96875,y:.34375},{x:.03125,y:.40625},{x:.03125,y:.40625},{x:.09375,y:.40625},{x:.09375,y:.40625},{x:.15625,y:.40625},{x:.15625,y:.40625},{x:.21875,y:.40625},{x:.21875,y:.40625},{x:.28125,y:.40625},{x:.28125,y:.40625},{x:.34375,y:.40625},{x:.34375,y:.40625},{x:.40625,y:.40625},{x:.40625,y:.40625},{x:.46875,y:.40625},{x:.46875,y:.40625},{x:.53125,y:.40625},{x:.53125,y:.40625},{x:.59375,y:.40625},{x:.59375,y:.40625},{x:.65625,y:.40625},{x:.65625,y:.40625},{x:.71875,y:.40625},{x:.71875,y:.40625},{x:.78125,y:.40625},{x:.78125,y:.40625},{x:.84375,y:.40625},{x:.84375,y:.40625},{x:.90625,y:.40625},{x:.90625,y:.40625},{x:.96875,y:.40625},{x:.96875,y:.40625},{x:.03125,y:.46875},{x:.03125,y:.46875},{x:.09375,y:.46875},{x:.09375,y:.46875},{x:.15625,y:.46875},{x:.15625,y:.46875},{x:.21875,y:.46875},{x:.21875,y:.46875},{x:.28125,y:.46875},{x:.28125,y:.46875},{x:.34375,y:.46875},{x:.34375,y:.46875},{x:.40625,y:.46875},{x:.40625,y:.46875},{x:.46875,y:.46875},{x:.46875,y:.46875},{x:.53125,y:.46875},{x:.53125,y:.46875},{x:.59375,y:.46875},{x:.59375,y:.46875},{x:.65625,y:.46875},{x:.65625,y:.46875},{x:.71875,y:.46875},{x:.71875,y:.46875},{x:.78125,y:.46875},{x:.78125,y:.46875},{x:.84375,y:.46875},{x:.84375,y:.46875},{x:.90625,y:.46875},{x:.90625,y:.46875},{x:.96875,y:.46875},{x:.96875,y:.46875},{x:.03125,y:.53125},{x:.03125,y:.53125},{x:.09375,y:.53125},{x:.09375,y:.53125},{x:.15625,y:.53125},{x:.15625,y:.53125},{x:.21875,y:.53125},{x:.21875,y:.53125},{x:.28125,y:.53125},{x:.28125,y:.53125},{x:.34375,y:.53125},{x:.34375,y:.53125},{x:.40625,y:.53125},{x:.40625,y:.53125},{x:.46875,y:.53125},{x:.46875,y:.53125},{x:.53125,y:.53125},{x:.53125,y:.53125},{x:.59375,y:.53125},{x:.59375,y:.53125},{x:.65625,y:.53125},{x:.65625,y:.53125},{x:.71875,y:.53125},{x:.71875,y:.53125},{x:.78125,y:.53125},{x:.78125,y:.53125},{x:.84375,y:.53125},{x:.84375,y:.53125},{x:.90625,y:.53125},{x:.90625,y:.53125},{x:.96875,y:.53125},{x:.96875,y:.53125},{x:.03125,y:.59375},{x:.03125,y:.59375},{x:.09375,y:.59375},{x:.09375,y:.59375},{x:.15625,y:.59375},{x:.15625,y:.59375},{x:.21875,y:.59375},{x:.21875,y:.59375},{x:.28125,y:.59375},{x:.28125,y:.59375},{x:.34375,y:.59375},{x:.34375,y:.59375},{x:.40625,y:.59375},{x:.40625,y:.59375},{x:.46875,y:.59375},{x:.46875,y:.59375},{x:.53125,y:.59375},{x:.53125,y:.59375},{x:.59375,y:.59375},{x:.59375,y:.59375},{x:.65625,y:.59375},{x:.65625,y:.59375},{x:.71875,y:.59375},{x:.71875,y:.59375},{x:.78125,y:.59375},{x:.78125,y:.59375},{x:.84375,y:.59375},{x:.84375,y:.59375},{x:.90625,y:.59375},{x:.90625,y:.59375},{x:.96875,y:.59375},{x:.96875,y:.59375},{x:.03125,y:.65625},{x:.03125,y:.65625},{x:.09375,y:.65625},{x:.09375,y:.65625},{x:.15625,y:.65625},{x:.15625,y:.65625},{x:.21875,y:.65625},{x:.21875,y:.65625},{x:.28125,y:.65625},{x:.28125,y:.65625},{x:.34375,y:.65625},{x:.34375,y:.65625},{x:.40625,y:.65625},{x:.40625,y:.65625},{x:.46875,y:.65625},{x:.46875,y:.65625},{x:.53125,y:.65625},{x:.53125,y:.65625},{x:.59375,y:.65625},{x:.59375,y:.65625},{x:.65625,y:.65625},{x:.65625,y:.65625},{x:.71875,y:.65625},{x:.71875,y:.65625},{x:.78125,y:.65625},{x:.78125,y:.65625},{x:.84375,y:.65625},{x:.84375,y:.65625},{x:.90625,y:.65625},{x:.90625,y:.65625},{x:.96875,y:.65625},{x:.96875,y:.65625},{x:.03125,y:.71875},{x:.03125,y:.71875},{x:.09375,y:.71875},{x:.09375,y:.71875},{x:.15625,y:.71875},{x:.15625,y:.71875},{x:.21875,y:.71875},{x:.21875,y:.71875},{x:.28125,y:.71875},{x:.28125,y:.71875},{x:.34375,y:.71875},{x:.34375,y:.71875},{x:.40625,y:.71875},{x:.40625,y:.71875},{x:.46875,y:.71875},{x:.46875,y:.71875},{x:.53125,y:.71875},{x:.53125,y:.71875},{x:.59375,y:.71875},{x:.59375,y:.71875},{x:.65625,y:.71875},{x:.65625,y:.71875},{x:.71875,y:.71875},{x:.71875,y:.71875},{x:.78125,y:.71875},{x:.78125,y:.71875},{x:.84375,y:.71875},{x:.84375,y:.71875},{x:.90625,y:.71875},{x:.90625,y:.71875},{x:.96875,y:.71875},{x:.96875,y:.71875},{x:.03125,y:.78125},{x:.03125,y:.78125},{x:.09375,y:.78125},{x:.09375,y:.78125},{x:.15625,y:.78125},{x:.15625,y:.78125},{x:.21875,y:.78125},{x:.21875,y:.78125},{x:.28125,y:.78125},{x:.28125,y:.78125},{x:.34375,y:.78125},{x:.34375,y:.78125},{x:.40625,y:.78125},{x:.40625,y:.78125},{x:.46875,y:.78125},{x:.46875,y:.78125},{x:.53125,y:.78125},{x:.53125,y:.78125},{x:.59375,y:.78125},{x:.59375,y:.78125},{x:.65625,y:.78125},{x:.65625,y:.78125},{x:.71875,y:.78125},{x:.71875,y:.78125},{x:.78125,y:.78125},{x:.78125,y:.78125},{x:.84375,y:.78125},{x:.84375,y:.78125},{x:.90625,y:.78125},{x:.90625,y:.78125},{x:.96875,y:.78125},{x:.96875,y:.78125},{x:.03125,y:.84375},{x:.03125,y:.84375},{x:.09375,y:.84375},{x:.09375,y:.84375},{x:.15625,y:.84375},{x:.15625,y:.84375},{x:.21875,y:.84375},{x:.21875,y:.84375},{x:.28125,y:.84375},{x:.28125,y:.84375},{x:.34375,y:.84375},{x:.34375,y:.84375},{x:.40625,y:.84375},{x:.40625,y:.84375},{x:.46875,y:.84375},{x:.46875,y:.84375},{x:.53125,y:.84375},{x:.53125,y:.84375},{x:.59375,y:.84375},{x:.59375,y:.84375},{x:.65625,y:.84375},{x:.65625,y:.84375},{x:.71875,y:.84375},{x:.71875,y:.84375},{x:.78125,y:.84375},{x:.78125,y:.84375},{x:.84375,y:.84375},{x:.84375,y:.84375},{x:.90625,y:.84375},{x:.90625,y:.84375},{x:.96875,y:.84375},{x:.96875,y:.84375},{x:.03125,y:.90625},{x:.03125,y:.90625},{x:.09375,y:.90625},{x:.09375,y:.90625},{x:.15625,y:.90625},{x:.15625,y:.90625},{x:.21875,y:.90625},{x:.21875,y:.90625},{x:.28125,y:.90625},{x:.28125,y:.90625},{x:.34375,y:.90625},{x:.34375,y:.90625},{x:.40625,y:.90625},{x:.40625,y:.90625},{x:.46875,y:.90625},{x:.46875,y:.90625},{x:.53125,y:.90625},{x:.53125,y:.90625},{x:.59375,y:.90625},{x:.59375,y:.90625},{x:.65625,y:.90625},{x:.65625,y:.90625},{x:.71875,y:.90625},{x:.71875,y:.90625},{x:.78125,y:.90625},{x:.78125,y:.90625},{x:.84375,y:.90625},{x:.84375,y:.90625},{x:.90625,y:.90625},{x:.90625,y:.90625},{x:.96875,y:.90625},{x:.96875,y:.90625},{x:.03125,y:.96875},{x:.03125,y:.96875},{x:.09375,y:.96875},{x:.09375,y:.96875},{x:.15625,y:.96875},{x:.15625,y:.96875},{x:.21875,y:.96875},{x:.21875,y:.96875},{x:.28125,y:.96875},{x:.28125,y:.96875},{x:.34375,y:.96875},{x:.34375,y:.96875},{x:.40625,y:.96875},{x:.40625,y:.96875},{x:.46875,y:.96875},{x:.46875,y:.96875},{x:.53125,y:.96875},{x:.53125,y:.96875},{x:.59375,y:.96875},{x:.59375,y:.96875},{x:.65625,y:.96875},{x:.65625,y:.96875},{x:.71875,y:.96875},{x:.71875,y:.96875},{x:.78125,y:.96875},{x:.78125,y:.96875},{x:.84375,y:.96875},{x:.84375,y:.96875},{x:.90625,y:.96875},{x:.90625,y:.96875},{x:.96875,y:.96875},{x:.96875,y:.96875},{x:.0625,y:.0625},{x:.0625,y:.0625},{x:.0625,y:.0625},{x:.0625,y:.0625},{x:.0625,y:.0625},{x:.0625,y:.0625},{x:.1875,y:.0625},{x:.1875,y:.0625},{x:.1875,y:.0625},{x:.1875,y:.0625},{x:.1875,y:.0625},{x:.1875,y:.0625},{x:.3125,y:.0625},{x:.3125,y:.0625},{x:.3125,y:.0625},{x:.3125,y:.0625},{x:.3125,y:.0625},{x:.3125,y:.0625},{x:.4375,y:.0625},{x:.4375,y:.0625},{x:.4375,y:.0625},{x:.4375,y:.0625},{x:.4375,y:.0625},{x:.4375,y:.0625},{x:.5625,y:.0625},{x:.5625,y:.0625},{x:.5625,y:.0625},{x:.5625,y:.0625},{x:.5625,y:.0625},{x:.5625,y:.0625},{x:.6875,y:.0625},{x:.6875,y:.0625},{x:.6875,y:.0625},{x:.6875,y:.0625},{x:.6875,y:.0625},{x:.6875,y:.0625},{x:.8125,y:.0625},{x:.8125,y:.0625},{x:.8125,y:.0625},{x:.8125,y:.0625},{x:.8125,y:.0625},{x:.8125,y:.0625},{x:.9375,y:.0625},{x:.9375,y:.0625},{x:.9375,y:.0625},{x:.9375,y:.0625},{x:.9375,y:.0625},{x:.9375,y:.0625},{x:.0625,y:.1875},{x:.0625,y:.1875},{x:.0625,y:.1875},{x:.0625,y:.1875},{x:.0625,y:.1875},{x:.0625,y:.1875},{x:.1875,y:.1875},{x:.1875,y:.1875},{x:.1875,y:.1875},{x:.1875,y:.1875},{x:.1875,y:.1875},{x:.1875,y:.1875},{x:.3125,y:.1875},{x:.3125,y:.1875},{x:.3125,y:.1875},{x:.3125,y:.1875},{x:.3125,y:.1875},{x:.3125,y:.1875},{x:.4375,y:.1875},{x:.4375,y:.1875},{x:.4375,y:.1875},{x:.4375,y:.1875},{x:.4375,y:.1875},{x:.4375,y:.1875},{x:.5625,y:.1875},{x:.5625,y:.1875},{x:.5625,y:.1875},{x:.5625,y:.1875},{x:.5625,y:.1875},{x:.5625,y:.1875},{x:.6875,y:.1875},{x:.6875,y:.1875},{x:.6875,y:.1875},{x:.6875,y:.1875},{x:.6875,y:.1875},{x:.6875,y:.1875},{x:.8125,y:.1875},{x:.8125,y:.1875},{x:.8125,y:.1875},{x:.8125,y:.1875},{x:.8125,y:.1875},{x:.8125,y:.1875},{x:.9375,y:.1875},{x:.9375,y:.1875},{x:.9375,y:.1875},{x:.9375,y:.1875},{x:.9375,y:.1875},{x:.9375,y:.1875},{x:.0625,y:.3125},{x:.0625,y:.3125},{x:.0625,y:.3125},{x:.0625,y:.3125},{x:.0625,y:.3125},{x:.0625,y:.3125},{x:.1875,y:.3125},{x:.1875,y:.3125},{x:.1875,y:.3125},{x:.1875,y:.3125},{x:.1875,y:.3125},{x:.1875,y:.3125},{x:.3125,y:.3125},{x:.3125,y:.3125},{x:.3125,y:.3125},{x:.3125,y:.3125},{x:.3125,y:.3125},{x:.3125,y:.3125},{x:.4375,y:.3125},{x:.4375,y:.3125},{x:.4375,y:.3125},{x:.4375,y:.3125},{x:.4375,y:.3125},{x:.4375,y:.3125},{x:.5625,y:.3125},{x:.5625,y:.3125},{x:.5625,y:.3125},{x:.5625,y:.3125},{x:.5625,y:.3125},{x:.5625,y:.3125},{x:.6875,y:.3125},{x:.6875,y:.3125},{x:.6875,y:.3125},{x:.6875,y:.3125},{x:.6875,y:.3125},{x:.6875,y:.3125},{x:.8125,y:.3125},{x:.8125,y:.3125},{x:.8125,y:.3125},{x:.8125,y:.3125},{x:.8125,y:.3125},{x:.8125,y:.3125},{x:.9375,y:.3125},{x:.9375,y:.3125},{x:.9375,y:.3125},{x:.9375,y:.3125},{x:.9375,y:.3125},{x:.9375,y:.3125},{x:.0625,y:.4375},{x:.0625,y:.4375},{x:.0625,y:.4375},{x:.0625,y:.4375},{x:.0625,y:.4375},{x:.0625,y:.4375},{x:.1875,y:.4375},{x:.1875,y:.4375},{x:.1875,y:.4375},{x:.1875,y:.4375},{x:.1875,y:.4375},{x:.1875,y:.4375},{x:.3125,y:.4375},{x:.3125,y:.4375},{x:.3125,y:.4375},{x:.3125,y:.4375},{x:.3125,y:.4375},{x:.3125,y:.4375},{x:.4375,y:.4375},{x:.4375,y:.4375},{x:.4375,y:.4375},{x:.4375,y:.4375},{x:.4375,y:.4375},{x:.4375,y:.4375},{x:.5625,y:.4375},{x:.5625,y:.4375},{x:.5625,y:.4375},{x:.5625,y:.4375},{x:.5625,y:.4375},{x:.5625,y:.4375},{x:.6875,y:.4375},{x:.6875,y:.4375},{x:.6875,y:.4375},{x:.6875,y:.4375},{x:.6875,y:.4375},{x:.6875,y:.4375},{x:.8125,y:.4375},{x:.8125,y:.4375},{x:.8125,y:.4375},{x:.8125,y:.4375},{x:.8125,y:.4375},{x:.8125,y:.4375},{x:.9375,y:.4375},{x:.9375,y:.4375},{x:.9375,y:.4375},{x:.9375,y:.4375},{x:.9375,y:.4375},{x:.9375,y:.4375},{x:.0625,y:.5625},{x:.0625,y:.5625},{x:.0625,y:.5625},{x:.0625,y:.5625},{x:.0625,y:.5625},{x:.0625,y:.5625},{x:.1875,y:.5625},{x:.1875,y:.5625},{x:.1875,y:.5625},{x:.1875,y:.5625},{x:.1875,y:.5625},{x:.1875,y:.5625},{x:.3125,y:.5625},{x:.3125,y:.5625},{x:.3125,y:.5625},{x:.3125,y:.5625},{x:.3125,y:.5625},{x:.3125,y:.5625},{x:.4375,y:.5625},{x:.4375,y:.5625},{x:.4375,y:.5625},{x:.4375,y:.5625},{x:.4375,y:.5625},{x:.4375,y:.5625},{x:.5625,y:.5625},{x:.5625,y:.5625},{x:.5625,y:.5625},{x:.5625,y:.5625},{x:.5625,y:.5625},{x:.5625,y:.5625},{x:.6875,y:.5625},{x:.6875,y:.5625},{x:.6875,y:.5625},{x:.6875,y:.5625},{x:.6875,y:.5625},{x:.6875,y:.5625},{x:.8125,y:.5625},{x:.8125,y:.5625},{x:.8125,y:.5625},{x:.8125,y:.5625},{x:.8125,y:.5625},{x:.8125,y:.5625},{x:.9375,y:.5625},{x:.9375,y:.5625},{x:.9375,y:.5625},{x:.9375,y:.5625},{x:.9375,y:.5625},{x:.9375,y:.5625},{x:.0625,y:.6875},{x:.0625,y:.6875},{x:.0625,y:.6875},{x:.0625,y:.6875},{x:.0625,y:.6875},{x:.0625,y:.6875},{x:.1875,y:.6875},{x:.1875,y:.6875},{x:.1875,y:.6875},{x:.1875,y:.6875},{x:.1875,y:.6875},{x:.1875,y:.6875},{x:.3125,y:.6875},{x:.3125,y:.6875},{x:.3125,y:.6875},{x:.3125,y:.6875},{x:.3125,y:.6875},{x:.3125,y:.6875},{x:.4375,y:.6875},{x:.4375,y:.6875},{x:.4375,y:.6875},{x:.4375,y:.6875},{x:.4375,y:.6875},{x:.4375,y:.6875},{x:.5625,y:.6875},{x:.5625,y:.6875},{x:.5625,y:.6875},{x:.5625,y:.6875},{x:.5625,y:.6875},{x:.5625,y:.6875},{x:.6875,y:.6875},{x:.6875,y:.6875},{x:.6875,y:.6875},{x:.6875,y:.6875},{x:.6875,y:.6875},{x:.6875,y:.6875},{x:.8125,y:.6875},{x:.8125,y:.6875},{x:.8125,y:.6875},{x:.8125,y:.6875},{x:.8125,y:.6875},{x:.8125,y:.6875},{x:.9375,y:.6875},{x:.9375,y:.6875},{x:.9375,y:.6875},{x:.9375,y:.6875},{x:.9375,y:.6875},{x:.9375,y:.6875},{x:.0625,y:.8125},{x:.0625,y:.8125},{x:.0625,y:.8125},{x:.0625,y:.8125},{x:.0625,y:.8125},{x:.0625,y:.8125},{x:.1875,y:.8125},{x:.1875,y:.8125},{x:.1875,y:.8125},{x:.1875,y:.8125},{x:.1875,y:.8125},{x:.1875,y:.8125},{x:.3125,y:.8125},{x:.3125,y:.8125},{x:.3125,y:.8125},{x:.3125,y:.8125},{x:.3125,y:.8125},{x:.3125,y:.8125},{x:.4375,y:.8125},{x:.4375,y:.8125},{x:.4375,y:.8125},{x:.4375,y:.8125},{x:.4375,y:.8125},{x:.4375,y:.8125},{x:.5625,y:.8125},{x:.5625,y:.8125},{x:.5625,y:.8125},{x:.5625,y:.8125},{x:.5625,y:.8125},{x:.5625,y:.8125},{x:.6875,y:.8125},{x:.6875,y:.8125},{x:.6875,y:.8125},{x:.6875,y:.8125},{x:.6875,y:.8125},{x:.6875,y:.8125},{x:.8125,y:.8125},{x:.8125,y:.8125},{x:.8125,y:.8125},{x:.8125,y:.8125},{x:.8125,y:.8125},{x:.8125,y:.8125},{x:.9375,y:.8125},{x:.9375,y:.8125},{x:.9375,y:.8125},{x:.9375,y:.8125},{x:.9375,y:.8125},{x:.9375,y:.8125},{x:.0625,y:.9375},{x:.0625,y:.9375},{x:.0625,y:.9375},{x:.0625,y:.9375},{x:.0625,y:.9375},{x:.0625,y:.9375},{x:.1875,y:.9375},{x:.1875,y:.9375},{x:.1875,y:.9375},{x:.1875,y:.9375},{x:.1875,y:.9375},{x:.1875,y:.9375},{x:.3125,y:.9375},{x:.3125,y:.9375},{x:.3125,y:.9375},{x:.3125,y:.9375},{x:.3125,y:.9375},{x:.3125,y:.9375},{x:.4375,y:.9375},{x:.4375,y:.9375},{x:.4375,y:.9375},{x:.4375,y:.9375},{x:.4375,y:.9375},{x:.4375,y:.9375},{x:.5625,y:.9375},{x:.5625,y:.9375},{x:.5625,y:.9375},{x:.5625,y:.9375},{x:.5625,y:.9375},{x:.5625,y:.9375},{x:.6875,y:.9375},{x:.6875,y:.9375},{x:.6875,y:.9375},{x:.6875,y:.9375},{x:.6875,y:.9375},{x:.6875,y:.9375},{x:.8125,y:.9375},{x:.8125,y:.9375},{x:.8125,y:.9375},{x:.8125,y:.9375},{x:.8125,y:.9375},{x:.8125,y:.9375},{x:.9375,y:.9375},{x:.9375,y:.9375},{x:.9375,y:.9375},{x:.9375,y:.9375},{x:.9375,y:.9375},{x:.9375,y:.9375}];var og=class{constructor(t){var n;this.model=t,this.anchors=Ek.map(a=>[a.x,a.y]),this.anchorsTensor=ga(this.anchors),this.inputSize=(n=this.model)==null?void 0:n.inputs[0].shape[2],this.inputSizeTensor=Et([this.inputSize,this.inputSize]),this.doubleInputSizeTensor=Et([this.inputSize*2,this.inputSize*2])}normalizeBoxes(t){return W(()=>{let n=Re(t,[0,0],[-1,2]),a=Re(t,[0,2],[-1,2]),r=se(me(n,this.inputSizeTensor),this.anchorsTensor),s=me(a,this.doubleInputSizeTensor),i=_(ge(r,s),this.inputSizeTensor),o=_(se(r,s),this.inputSizeTensor);return hl([i,o],1)})}normalizeLandmarks(t,n){return W(()=>{let a=se(me(t.reshape([-1,7,2]),this.inputSizeTensor),this.anchors[n]);return _(a,this.inputSizeTensor)})}async getBoxes(t,n){let a=this.model.predict(t),r=a.squeeze();a.dispose();let s=W(()=>kn(Re(r,[0,0],[-1,1])).squeeze()),i=s.dataSync(),o=Re(r,[0,1],[-1,4]),l=this.normalizeBoxes(o);o.dispose();let d=await Ye.nonMaxSuppressionAsync(l,i,n.hand.maxDetected,n.hand.iouThreshold,n.hand.minConfidence),u=d.arraySync();s.dispose(),d.dispose();let p=[];for(let c of u)if(i[c]>=n.hand.minConfidence){let h=Re(l,[c,0],[1,-1]),m=Re(r,[c,5],[1,14]),f=W(()=>this.normalizeLandmarks(m,c).reshape([-1,2]));m.dispose(),p.push({box:h,palmLandmarks:f,confidence:i[c]})}return r.dispose(),l.dispose(),p}async estimateHandBounds(t,n){let a=t.shape[1],r=t.shape[2],s=W(()=>t.resizeBilinear([this.inputSize,this.inputSize]).div(127.5).sub(1)),i=await this.getBoxes(s,n);s.dispose();let o=[];if(!i||i.length===0)return o;for(let l of i){let d=l.box.dataSync(),u=d.slice(0,2),p=d.slice(2,4),c=l.palmLandmarks.arraySync();l.box.dispose(),l.palmLandmarks.dispose(),o.push(Tk({startPoint:u,endPoint:p,palmLandmarks:c,confidence:l.confidence},[r/this.inputSize,a/this.inputSize]))}return o}};function Wie(e){return e-2*Math.PI*Math.floor((e+Math.PI)/(2*Math.PI))}function Ck(e,t){let n=Math.PI/2-Math.atan2(-(t[1]-e[1]),t[0]-e[0]);return Wie(n)}var Rk=(e,t)=>[[1,0,e],[0,1,t],[0,0,1]];function Yr(e,t){let n=0;for(let a=0;aug([...s,1],n)),r=this.calculateLandmarksBoundingBox(a);return N0(T0(r),Vie)}getBoxForHandLandmarks(t){let n=this.calculateLandmarksBoundingBox(t),a=N0(T0(n),$k);a.palmLandmarks=[];for(let r=0;r[i[0]*(h[0]-this.inputSize/2),i[1]*(h[1]-this.inputSize/2),i[2]*h[2]]),l=lg(a,[0,0]),d=o.map(h=>[...ug(h,l),h[2]]),u=Fk(r),p=[...Zd(n),1],c=[Yr(p,u[0]),Yr(p,u[1])];return d.map(h=>[h[0]+c[0],h[1]+c[1],h[2]])}async estimateHands(t,n){let a=!1,r;(this.skipped===0||this.skipped>n.hand.skipFrames||!n.hand.landmarks||!n.videoOptimized)&&(r=await this.handDetector.estimateHandBounds(t,n),this.skipped=0),n.videoOptimized&&this.skipped++,r&&r.length>0&&(r.length!==this.detectedHands&&this.detectedHands!==n.hand.maxDetected||!n.hand.landmarks)&&(this.detectedHands=0,this.storedBoxes=[...r],this.storedBoxes.length>0&&(a=!0));let s=[];n.hand.skipInitial&&this.detectedHands===0&&(this.skipped=0);for(let i=0;i=n.hand.minConfidence){let x=H(y,[-1,3]),w=x.arraySync();y.dispose(),x.dispose();let b=this.transformRawCoords(w,h,l,c),v=this.getBoxForHandLandmarks(b);this.storedBoxes[i]=v;let N={landmarks:b,confidence:g,box:{topLeft:v.startPoint,bottomRight:v.endPoint}};s.push(N)}else this.storedBoxes[i]=null;y.dispose()}else{let l=N0(T0(o),$k),d={confidence:o.confidence,box:{topLeft:l.startPoint,bottomRight:l.endPoint}};s.push(d)}}return this.storedBoxes=this.storedBoxes.filter(i=>i!==null),this.detectedHands=s.length,s}calculateLandmarksBoundingBox(t){let n=t.map(i=>i[0]),a=t.map(i=>i[1]),r=[Math.min(...n),Math.min(...a)],s=[Math.max(...n),Math.max(...a)];return{startPoint:r,endPoint:s}}};var Ok={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]},Jr,Qr,zk;async function cg(e,t){let n=await zk.estimateHands(e,t);if(!n)return[];let a=[];for(let r of n){let s={};if(r.landmarks)for(let l of Object.keys(Ok))s[l]=Ok[l].map(d=>r.landmarks[d]);let i=r.box?[Math.max(0,r.box.topLeft[0]),Math.max(0,r.box.topLeft[1]),Math.min(e.shape[2],r.box.bottomRight[0])-Math.max(0,r.box.topLeft[0]),Math.min(e.shape[1],r.box.bottomRight[1])-Math.max(0,r.box.topLeft[1])]:[],o=[r.box.topLeft[0]/e.shape[2],r.box.topLeft[1]/e.shape[1],(r.box.bottomRight[0]-r.box.topLeft[0])/e.shape[2],(r.box.bottomRight[1]-r.box.topLeft[1])/e.shape[1]];a.push({confidence:Math.round(100*r.confidence)/100,box:i,boxRaw:o,landmarks:r.landmarks,annotations:s})}return a}async function hg(e){!Jr||!Qr?([Jr,Qr]=await Promise.all([e.hand.enabled?qt(Jt(e.modelBasePath,e.hand.detector.modelPath),{fromTFHub:e.hand.detector.modelPath.includes("tfhub.dev")}):null,e.hand.landmarks?qt(Jt(e.modelBasePath,e.hand.skeleton.modelPath),{fromTFHub:e.hand.skeleton.modelPath.includes("tfhub.dev")}):null]),e.hand.enabled&&(!Jr||!Jr.modelUrl?he("load model failed:",e.hand.detector.modelPath):e.debug&&he("load model:",Jr.modelUrl),!Qr||!Qr.modelUrl?he("load model failed:",e.hand.skeleton.modelPath):e.debug&&he("load model:",Qr.modelUrl))):(e.debug&&he("cached model:",Jr.modelUrl),e.debug&&he("cached model:",Qr.modelUrl));let t=new og(Jr);return zk=new dg(t,Qr),[Jr,Qr]}var fg={};Fa(fg,{load:()=>mg,predict:()=>Ag});var _k=["nose","leftEyeInside","leftEye","leftEyeOutside","rightEyeInside","rightEye","rightEyeOutside","leftEar","rightEar","leftMouth","rightMouth","leftShoulder","rightShoulder","leftElbow","rightElbow","leftWrist","rightWrist","leftPalm","rightPalm","leftIndex","rightIndex","leftPinky","rightPinky","leftHip","rightHip","leftKnee","rightKnee","leftAnkle","rightAnkle","leftHeel","rightHeel","leftFoot","rightFoot","midHip","forehead","leftThumb","leftHand","rightThumb","rightHand"],Pk=["nose","leftEyeInside","leftEye","leftEyeOutside","rightEyeInside","rightEye","rightEyeOutside","leftEar","rightEar","leftMouth","rightMouth","leftShoulder","rightShoulder","leftElbow","rightElbow","left:15","right:16","left:17","right:18","left:19","right:20","left:21","right:22","leftChest","rightChest","neck","forehead","left:27","right:28","left:29","right:30"];var Cn;async function mg(e){return Cn?e.debug&&he("cached model:",Cn.modelUrl):(Cn=await qt(Jt(e.modelBasePath,e.body.modelPath)),Cn.width=parseInt(Cn.signature.inputs["input_1:0"].tensorShape.dim[2].size),Cn.height=parseInt(Cn.signature.inputs["input_1:0"].tensorShape.dim[1].size),!Cn||!Cn.modelUrl?he("load model failed:",e.body.modelPath):e.debug&&he("load model:",Cn.modelUrl)),Cn}async function Ag(e,t){if(!Cn||!t.body.enabled)return null;let n={width:e.shape[2],height:e.shape[1]},a=Ye.resizeBilinear(e,[Cn.width,Cn.height],!1),r=me(a,[255]);a.dispose();let s=await Cn.predict(r),i=s.find(p=>p.size===195||p.size===155).dataSync();s.forEach(p=>p.dispose()),r.dispose();let o=[],l=i.length===195?_k:Pk,d=5;for(let p=0;pc.score>p?c.score:p,0),keypoints:o}]}var yg={};Fa(yg,{load:()=>xg,predict:()=>bg});var E0=[{class:1,label:"person"},{class:2,label:"bicycle"},{class:3,label:"car"},{class:4,label:"motorcycle"},{class:5,label:"airplane"},{class:6,label:"bus"},{class:7,label:"train"},{class:8,label:"truck"},{class:9,label:"boat"},{class:10,label:"traffic light"},{class:11,label:"fire hydrant"},{class:12,label:"stop sign"},{class:13,label:"parking meter"},{class:14,label:"bench"},{class:15,label:"bird"},{class:16,label:"cat"},{class:17,label:"dog"},{class:18,label:"horse"},{class:19,label:"sheep"},{class:20,label:"cow"},{class:21,label:"elephant"},{class:22,label:"bear"},{class:23,label:"zebra"},{class:24,label:"giraffe"},{class:25,label:"backpack"},{class:26,label:"umbrella"},{class:27,label:"handbag"},{class:28,label:"tie"},{class:29,label:"suitcase"},{class:30,label:"frisbee"},{class:31,label:"skis"},{class:32,label:"snowboard"},{class:33,label:"sports ball"},{class:34,label:"kite"},{class:35,label:"baseball bat"},{class:36,label:"baseball glove"},{class:37,label:"skateboard"},{class:38,label:"surfboard"},{class:39,label:"tennis racket"},{class:40,label:"bottle"},{class:41,label:"wine glass"},{class:42,label:"cup"},{class:43,label:"fork"},{class:44,label:"knife"},{class:45,label:"spoon"},{class:46,label:"bowl"},{class:47,label:"banana"},{class:48,label:"apple"},{class:49,label:"sandwich"},{class:50,label:"orange"},{class:51,label:"broccoli"},{class:52,label:"carrot"},{class:53,label:"hot dog"},{class:54,label:"pizza"},{class:55,label:"donut"},{class:56,label:"cake"},{class:57,label:"chair"},{class:58,label:"couch"},{class:59,label:"potted plant"},{class:60,label:"bed"},{class:61,label:"dining table"},{class:62,label:"toilet"},{class:63,label:"tv"},{class:64,label:"laptop"},{class:65,label:"mouse"},{class:66,label:"remote"},{class:67,label:"keyboard"},{class:68,label:"cell phone"},{class:69,label:"microwave"},{class:70,label:"oven"},{class:71,label:"toaster"},{class:72,label:"sink"},{class:73,label:"refrigerator"},{class:74,label:"book"},{class:75,label:"clock"},{class:76,label:"vase"},{class:77,label:"scissors"},{class:78,label:"teddy bear"},{class:79,label:"hair drier"},{class:80,label:"toothbrush"}];var Rn,gg=[],C0=Number.MAX_SAFE_INTEGER,R0=2.5;async function xg(e){if(Rn)e.debug&&he("cached model:",Rn.modelUrl);else{Rn=await qt(Jt(e.modelBasePath,e.object.modelPath));let t=Object.values(Rn.modelSignature.inputs);if(Rn.inputSize=Array.isArray(t)?parseInt(t[0].tensorShape.dim[2].size):null,!Rn.inputSize)throw new Error(`Human: Cannot determine model inputSize: ${e.object.modelPath}`);!Rn||!Rn.modelUrl?he("load model failed:",e.object.modelPath):e.debug&&he("load model:",Rn.modelUrl)}return Rn}async function Hie(e,t,n,a){let r=0,s=[];for(let d of[1,2,4])W(()=>{var A,y;let u=d*13,p=(A=e.find(g=>g.shape[1]===u**2&&g.shape[2]===E0.length))==null?void 0:A.squeeze(),c=(y=e.find(g=>g.shape[1]===u**2&&g.shape[2]a.object.minConfidence&&x!==61){let b=(.5+Math.trunc(g%u))/u,v=(.5+Math.trunc(g/u))/u,N=m[g].map(U=>U*(u/d/t)),[T,R]=[b-R0/d*N[0],v-R0/d*N[1]],[$,z]=[b+R0/d*N[2]-T,v+R0/d*N[3]-R],P=[T,R,$,z];P=P.map(U=>Math.max(0,Math.min(U,1)));let V=[P[0]*n[0],P[1]*n[1],P[2]*n[0],P[3]*n[1]],j={id:r++,strideSize:d,score:Math.round(100*w)/100,class:x+1,label:E0[x].label,center:[Math.trunc(n[0]*b),Math.trunc(n[1]*v)],centerRaw:[b,v],box:V.map(U=>Math.trunc(U)),boxRaw:P};s.push(j)}}});e.forEach(d=>Ee(d));let i=s.map(d=>d.boxRaw),o=s.map(d=>d.score),l=[];if(i&&i.length>0){let d=await Ye.nonMaxSuppressionAsync(i,o,a.object.maxDetected,a.object.iouThreshold,a.object.minConfidence);l=d.dataSync(),Ee(d)}return s=s.filter((d,u)=>l.includes(u)).sort((d,u)=>u.score-d.score),s}async function bg(e,t){return Rn?C00?(C0++,gg):(t.videoOptimized?C0=0:C0=Number.MAX_SAFE_INTEGER,new Promise(async n=>{let a=[e.shape[2],e.shape[1]],r=Ye.resizeBilinear(e,[Rn.inputSize,Rn.inputSize],!1),s=r.div(255),i=s.transpose([0,3,1,2]);s.dispose(),r.dispose();let o;t.object.enabled&&(o=await Rn.predict(i)),i.dispose();let l=await Hie(o,Rn.inputSize,a,t);gg=l,n(l)})):null}var Lk=e=>{if(!e)return[];let t=[];for(let n=0;nl.part==="leftWrist"),r=e[n].keypoints.find(l=>l.part==="rightWrist"),s=e[n].keypoints.find(l=>l.part==="nose");s&&a&&r&&a.position.yl.part==="leftShoulder"),o=e[n].keypoints.find(l=>l.part==="rightShoulder");i&&o&&t.push({body:n,gesture:`leaning ${i.position.y>o.position.y?"left":"right"}`})}return t},Wk=e=>{if(!e)return[];let t=[];for(let n=0;n0){let a=e[n].mesh[33][2]-e[n].mesh[263][2];Math.abs(a)<10?t.push({face:n,gesture:"facing center"}):t.push({face:n,gesture:`facing ${a<0?"left":"right"}`}),Math.abs(e[n].mesh[374][1]-e[n].mesh[386][1])/Math.abs(e[n].mesh[443][1]-e[n].mesh[450][1])<.2&&t.push({face:n,gesture:"blink left eye"}),Math.abs(e[n].mesh[145][1]-e[n].mesh[159][1])/Math.abs(e[n].mesh[223][1]-e[n].mesh[230][1])<.2&&t.push({face:n,gesture:"blink right eye"});let i=Math.min(100,500*Math.abs(e[n].mesh[13][1]-e[n].mesh[14][1])/Math.abs(e[n].mesh[10][1]-e[n].mesh[152][1]));i>10&&t.push({face:n,gesture:`mouth ${Math.trunc(i)}% open`});let o=e[n].mesh[152][2];Math.abs(o)>10&&t.push({face:n,gesture:`head ${o<0?"up":"down"}`})}return t},Bk=e=>{if(!e)return[];let t=[];for(let n=0;n.033||p>.033)&&(d=!1),c>.033&&t.push({iris:n,gesture:"looking right"}),p>.033&&t.push({iris:n,gesture:"looking left"});let h=Math.abs(e[n].mesh[145][1]-e[n].annotations.rightEyeIris[0][1])/e[n].annotations.rightEyeIris[0][1],m=Math.abs(e[n].mesh[374][1]-e[n].annotations.leftEyeIris[0][1])/e[n].annotations.leftEyeIris[0][1];(m<.015||h<.015||m>.03||h>.03)&&(d=!1),(m<.015||h<.015)&&t.push({iris:n,gesture:"looking down"}),(m>.03||h>.03)&&t.push({iris:n,gesture:"looking up"}),d&&t.push({iris:n,gesture:"looking center"})}return t},Vk=e=>{if(!e)return[];let t=[];for(let n=0;n0){let r=a.reduce((i,o)=>i.position[2]i.position[1]wg});function Gie(e,t,n){let a=function(o,l,d){let u=new RegExp("\\b"+l+" \\w+ (\\w+)","ig");o.replace(u,(p,c)=>(d[c]=0,p))},r=function(o,l){let d=e.createShader(l);if(e.shaderSource(d,o),e.compileShader(d),!e.getShaderParameter(d,e.COMPILE_STATUS))throw new Error("Filter: GL compile failed",e.getShaderInfoLog(d));return d};this.uniform={},this.attribute={};let s=r(t,e.VERTEX_SHADER),i=r(n,e.FRAGMENT_SHADER);if(this.id=e.createProgram(),e.attachShader(this.id,s),e.attachShader(this.id,i),e.linkProgram(this.id),!e.getProgramParameter(this.id,e.LINK_STATUS))throw new Error("Filter: GL link failed",e.getProgramInfoLog(this.id));e.useProgram(this.id),a(t,"attribute",this.attribute);for(let o in this.attribute)this.attribute[o]=e.getAttribLocation(this.id,o);a(t,"uniform",this.uniform),a(n,"uniform",this.uniform);for(let o in this.uniform)this.uniform[o]=e.getUniformLocation(this.id,o)}function jk(e){e||(e={});let t=0,n=null,a=!1,r=-1,s=[null,null],i=[],o=-1,l=-1,d=null,u=null,p={},c=e.canvas||document.createElement("canvas"),h={},m={INTERMEDIATE:1},f=c.getContext("webgl");if(!f)throw new Error("Filter: getContext() failed");this.addFilter=function(b){let v=Array.prototype.slice.call(arguments,1),N=p[b];i.push({func:N,args:v})},this.reset=function(){i=[]};let A=function(b,v){if(!(b===o&&v===l)){if(c.width=b,o=b,c.height=v,l=v,!d){let N=new Float32Array([-1,-1,0,1,1,-1,1,1,-1,1,0,0,-1,1,0,0,1,-1,1,1,1,1,1,0]);d=f.createBuffer(),f.bindBuffer(f.ARRAY_BUFFER,d),f.bufferData(f.ARRAY_BUFFER,N,f.STATIC_DRAW),f.pixelStorei(f.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!0)}f.viewport(0,0,o,l),s=[null,null]}},y=function(b,v){let N=f.createFramebuffer();f.bindFramebuffer(f.FRAMEBUFFER,N);let T=f.createRenderbuffer();f.bindRenderbuffer(f.RENDERBUFFER,T);let R=f.createTexture();return f.bindTexture(f.TEXTURE_2D,R),f.texImage2D(f.TEXTURE_2D,0,f.RGBA,b,v,0,f.RGBA,f.UNSIGNED_BYTE,null),f.texParameteri(f.TEXTURE_2D,f.TEXTURE_MAG_FILTER,f.LINEAR),f.texParameteri(f.TEXTURE_2D,f.TEXTURE_MIN_FILTER,f.LINEAR),f.texParameteri(f.TEXTURE_2D,f.TEXTURE_WRAP_S,f.CLAMP_TO_EDGE),f.texParameteri(f.TEXTURE_2D,f.TEXTURE_WRAP_T,f.CLAMP_TO_EDGE),f.framebufferTexture2D(f.FRAMEBUFFER,f.COLOR_ATTACHMENT0,f.TEXTURE_2D,R,0),f.bindTexture(f.TEXTURE_2D,null),f.bindFramebuffer(f.FRAMEBUFFER,null),{fbo:N,texture:R}},g=function(b){return s[b]=s[b]||y(o,l),s[b]},x=function(b=null){var R,$;let v=null,N=null,T=!1;t===0?v=n:v=(R=g(r))==null?void 0:R.texture,t++,a&&!(b&m.INTERMEDIATE)?(N=null,T=t%2==0):(r=(r+1)%2,N=($=g(r))==null?void 0:$.fbo),f.bindTexture(f.TEXTURE_2D,v),f.bindFramebuffer(f.FRAMEBUFFER,N),f.uniform1f(u.uniform.flipY,T?-1:1),f.drawArrays(f.TRIANGLES,0,6)};this.apply=function(b){if(A(b.width,b.height),t=0,n||(n=f.createTexture()),f.bindTexture(f.TEXTURE_2D,n),f.texParameteri(f.TEXTURE_2D,f.TEXTURE_WRAP_S,f.CLAMP_TO_EDGE),f.texParameteri(f.TEXTURE_2D,f.TEXTURE_WRAP_T,f.CLAMP_TO_EDGE),f.texParameteri(f.TEXTURE_2D,f.TEXTURE_MIN_FILTER,f.NEAREST),f.texParameteri(f.TEXTURE_2D,f.TEXTURE_MAG_FILTER,f.NEAREST),f.texImage2D(f.TEXTURE_2D,0,f.RGBA,f.RGBA,f.UNSIGNED_BYTE,b),i.length===0)return x(),c;for(let v=0;v{let u=[];e=H(e,[1,a,o]);for(let p=0;p{switch(e.op){case"If":case"StatelessIf":{let a=I("thenBranch",e,t,n),r=I("elseBranch",e,t,n),s=I("cond",e,t,n),i=I("args",e,t,n);return(await s.data())[0]?n.functionMap[a].executeFunctionAsync(i,n.tensorArrayMap,n.tensorListMap):n.functionMap[r].executeFunctionAsync(i,n.tensorArrayMap,n.tensorListMap)}case"While":case"StatelessWhile":{let a=I("body",e,t,n),r=I("cond",e,t,n),s=I("args",e,t,n),i=await n.functionMap[r].executeFunctionAsync(s,n.tensorArrayMap,n.tensorListMap),o=s.map(u=>u.id),l=await i[0].data();i.forEach(u=>{!u.kept&&o.indexOf(u.id)===-1&&u.dispose()});let d=s;for(;l[0];){let u=d;d=await n.functionMap[a].executeFunctionAsync(d,n.tensorArrayMap,n.tensorListMap);let p=d.map(h=>h.id);u.forEach(h=>{!h.kept&&o.indexOf(h.id)===-1&&p.indexOf(h.id)===-1&&h.dispose()});let c=await n.functionMap[r].executeFunctionAsync(d,n.tensorArrayMap,n.tensorListMap);l=await c[0].data(),c.forEach(h=>{!h.kept&&o.indexOf(h.id)===-1&&p.indexOf(h.id)===-1&&h.dispose()})}return d}case"LoopCond":{let a=I("pred",e,t,n);return[cr(a)]}case"Switch":{let a=I("pred",e,t,n),r=I("data",e,t,n);return r.kept||(r=cr(r)),(await a.data())[0]?[void 0,r]:[r,void 0]}case"Merge":{let a=e.inputNames.find(r=>mn(r,t,n)!==void 0);if(a){let r=mn(a,t,n);return[cr(r)]}return}case"Enter":{let a=I("frameName",e,t,n),r=I("tensor",e,t,n);return n.enterFrame(a),[cr(r)]}case"Exit":{let a=I("tensor",e,t,n);return n.exitFrame(),[cr(a)]}case"NextIteration":{let a=I("tensor",e,t,n);return n.nextIteration(),[cr(a)]}case"TensorArrayV3":{let a=I("size",e,t,n),r=I("dtype",e,t,n),s=I("elementShape",e,t,n),i=I("dynamicSize",e,t,n),o=I("clearAfterRead",e,t,n),l=I("identicalElementShapes",e,t,n),d=I("name",e,t,n),u=new ise(d,r,a,s,l,i,o);return n.addTensorArray(u),[u.idTensor,Se(1)]}case"TensorArrayWriteV3":{let a=I("tensorArrayId",e,t,n),r=I("index",e,t,n),s=I("tensor",e,t,n),i=n.getTensorArray(a.id);return i.write(r,s),[i.idTensor]}case"TensorArrayReadV3":{let a=I("tensorArrayId",e,t,n),r=I("index",e,t,n);return[n.getTensorArray(a.id).read(r)]}case"TensorArrayGatherV3":{let a=I("tensorArrayId",e,t,n),r=I("indices",e,t,n),s=I("dtype",e,t,n);return[n.getTensorArray(a.id).gather(r,s)]}case"TensorArrayScatterV3":{let a=I("tensorArrayId",e,t,n),r=I("indices",e,t,n),s=I("tensor",e,t,n),i=n.getTensorArray(a.id);return i.scatter(r,s),[i.idTensor]}case"TensorArrayConcatV3":{let a=I("tensorArrayId",e,t,n),r=n.getTensorArray(a.id),s=I("dtype",e,t,n);return[r.concat(s)]}case"TensorArraySplitV3":{let a=I("tensorArrayId",e,t,n),r=I("tensor",e,t,n),s=I("lengths",e,t,n),i=n.getTensorArray(a.id);return i.split(s,r),[i.idTensor]}case"TensorArraySizeV3":{let a=I("tensorArrayId",e,t,n),r=n.getTensorArray(a.id);return[Se(r.size(),"int32")]}case"TensorArrayCloseV3":{let a=I("tensorArrayId",e,t,n),r=n.getTensorArray(a.id);return r.clearAndClose(),[r.idTensor]}case"TensorListSetItem":{let a=I("tensorListId",e,t,n),r=I("index",e,t,n),s=I("tensor",e,t,n),i=n.getTensorList(a.id);return i.setItem(r,s),[i.idTensor]}case"TensorListGetItem":{let a=I("tensorListId",e,t,n),r=I("index",e,t,n),s=I("elementShape",e,t,n),i=I("elementDType",e,t,n);return[n.getTensorList(a.id).getItem(r,s,i)]}case"TensorListScatterV2":case"TensorListScatter":{let a=I("indices",e,t,n),r=I("tensor",e,t,n),s=I("elementShape",e,t,n),i=I("numElements",e,t,n),o=use(r,a,s,i);return n.addTensorList(o),[o.idTensor]}case"TensorListReserve":case"EmptyTensorList":{let a=I("elementShape",e,t,n),r=I("elementDType",e,t,n),s;e.op==="TensorListReserve"?s="numElements":s="maxNumElements";let i=I(s,e,t,n),o=lse(a,r,i);return n.addTensorList(o),[o.idTensor]}case"TensorListGather":{let a=I("tensorListId",e,t,n),r=I("indices",e,t,n),s=I("elementShape",e,t,n),i=I("elementDType",e,t,n);return[n.getTensorList(a.id).gather(r,i,s)]}case"TensorListStack":{let a=I("tensorListId",e,t,n),r=I("elementShape",e,t,n),s=I("elementDType",e,t,n),i=I("numElements",e,t,n);return[n.getTensorList(a.id).stack(r,s,i)]}case"TensorListFromTensor":{let a=I("tensor",e,t,n),r=I("elementShape",e,t,n),s=I("elementDType",e,t,n),i=ose(a,r,s);return n.addTensorList(i),[i.idTensor]}case"TensorListConcat":{let a=I("tensorListId",e,t,n),r=n.getTensorList(a.id),s=I("dtype",e,t,n),i=I("elementShape",e,t,n);return[r.concat(s,i)]}case"TensorListPushBack":{let a=I("tensorListId",e,t,n),r=I("tensor",e,t,n),s=n.getTensorList(a.id);return s.pushBack(r),[s.idTensor]}case"TensorListPopBack":{let a=I("tensorListId",e,t,n),r=I("elementShape",e,t,n),s=I("elementDType",e,t,n);return[n.getTensorList(a.id).popBack(r,s)]}case"TensorListSplit":{let a=I("tensor",e,t,n),r=I("elementShape",e,t,n),s=I("lengths",e,t,n),i=dse(a,s,r);return n.addTensorList(i),[i.idTensor]}default:throw TypeError(`Node type ${e.op} is not implemented`)}};function C8(e,t,n){let[a,r]=I("fusedOps",e,t,n),s=a==="biasadd",i=r==="prelu",o=a==="fusedbatchnorm",l=I("numArgs",e,t,n);if(s){if(i&&l!==2)throw new Error("FusedConv2d and DepthwiseConv2d with BiasAdd and Prelu must have two extra arguments: bias and alpha.");if(!i&&l!==1)throw new Error("FusedConv2d and DepthwiseConv2d with BiasAdd must have one extra argument: bias.")}if(o)throw new Error("FusedConv2d and DepthwiseConv2d with FusedBatchNorm is not supported");let d=I("strides",e,t,n),u=u0(e,t,n),p=I("dataFormat",e,t,n).toUpperCase(),c=I("dilations",e,t,n),[h,m]=I("args",e,t,n),f=I("leakyreluAlpha",e,t,n);return{stride:d,pad:u,dataFormat:p,dilations:c,biasArg:h,preluArg:m,activationFunc:r,leakyreluAlpha:f}}var cse=(e,t,n)=>{switch(e.op){case"Conv1D":{let a=I("stride",e,t,n),r=I("pad",e,t,n),s=I("dataFormat",e,t,n).toUpperCase(),i=I("dilation",e,t,n);return[bc(I("x",e,t,n),I("filter",e,t,n),a,r,s,i)]}case"Conv2D":{let a=I("strides",e,t,n),r=u0(e,t,n),s=I("dataFormat",e,t,n).toUpperCase(),i=I("dilations",e,t,n);return[nr(I("x",e,t,n),I("filter",e,t,n),[a[1],a[2]],r,s,[i[1],i[2]])]}case"_FusedConv2D":{let{stride:a,pad:r,dataFormat:s,dilations:i,biasArg:o,preluArg:l,activationFunc:d,leakyreluAlpha:u}=C8(e,t,n);return[zr.conv2d({x:I("x",e,t,n),filter:I("filter",e,t,n),strides:[a[1],a[2]],pad:r,dataFormat:s,dilations:[i[1],i[2]],bias:o,activation:d,preluActivationWeights:l,leakyreluAlpha:u})]}case"FusedDepthwiseConv2dNative":{let{stride:a,pad:r,dataFormat:s,dilations:i,biasArg:o,preluArg:l,activationFunc:d,leakyreluAlpha:u}=C8(e,t,n);return[zr.depthwiseConv2d({x:I("x",e,t,n),filter:I("filter",e,t,n),strides:[a[1],a[2]],pad:r,dataFormat:s,dilations:[i[1],i[2]],bias:o,activation:d,preluActivationWeights:l,leakyreluAlpha:u})]}case"Conv2DBackpropInput":case"Conv2dTranspose":{let a=I("outputShape",e,t,n),r=I("strides",e,t,n),s=u0(e,t,n);return[vc(I("x",e,t,n),I("filter",e,t,n),a,[r[1],r[2]],s)]}case"DepthwiseConv2dNative":case"DepthwiseConv2d":{let a=I("strides",e,t,n),r=u0(e,t,n),s=I("dilations",e,t,n),i=I("dataFormat",e,t,n).toUpperCase();return[hl(I("input",e,t,n),I("filter",e,t,n),[a[1],a[2]],r,i,[s[1],s[2]])]}case"Conv3D":{let a=I("strides",e,t,n),r=I("pad",e,t,n),s=I("dataFormat",e,t,n).toUpperCase(),i=I("dilations",e,t,n);return[pA(I("x",e,t,n),I("filter",e,t,n),[a[1],a[2],a[3]],r,s,[i[1],i[2],i[3]])]}case"AvgPool":{let a=I("strides",e,t,n),r=I("pad",e,t,n),s=I("kernelSize",e,t,n);return[Gu(I("x",e,t,n),[s[1],s[2]],[a[1],a[2]],r)]}case"MaxPool":{let a=I("strides",e,t,n),r=I("pad",e,t,n),s=I("kernelSize",e,t,n);return[Yu(I("x",e,t,n),[s[1],s[2]],[a[1],a[2]],r)]}case"MaxPoolWithArgmax":{let a=I("strides",e,t,n),r=I("pad",e,t,n),s=I("kernelSize",e,t,n),i=I("includeBatchInIndex",e,t,n),{result:o,indexes:l}=qb(I("x",e,t,n),[s[1],s[2]],[a[1],a[2]],r,i);return[o,l]}case"AvgPool3D":{let a=I("strides",e,t,n),r=I("pad",e,t,n),s=I("kernelSize",e,t,n);return[oA(I("x",e,t,n),[s[1],s[2],s[3]],[a[1],a[2],a[3]],r)]}case"MaxPool3D":{let a=I("strides",e,t,n),r=I("pad",e,t,n),s=I("kernelSize",e,t,n);return[kA(I("x",e,t,n),[s[1],s[2],s[3]],[a[1],a[2],a[3]],r)]}case"Dilation2D":{let a=I("strides",e,t,n),r=I("pad",e,t,n),s=I("dilations",e,t,n),i=a[1],o=a[2],l=s[1],d=s[2];return[hA(I("x",e,t,n),I("filter",e,t,n),[i,o],r,[l,d],"NHWC")]}default:throw TypeError(`Node type ${e.op} is not implemented`)}},hse=(e,t,n)=>{switch(e.op){case"Fill":{let a=I("shape",e,t,n),r=I("dtype",e,t,n),s=I("value",e,t,n);return[ml(a,s,r)]}case"LinSpace":{let a=I("start",e,t,n),r=I("stop",e,t,n),s=I("num",e,t,n);return[Wb(a,r,s)]}case"Multinomial":{let a=I("logits",e,t,n),r=I("numSamples",e,t,n),s=I("seed",e,t,n);return[Xb(a,r,s)]}case"OneHot":{let a=I("indices",e,t,n),r=I("depth",e,t,n),s=I("onValue",e,t,n),i=I("offValue",e,t,n);return[ol(a,r,s,i)]}case"Ones":return[$n(I("shape",e,t,n),I("dtype",e,t,n))];case"OnesLike":return[Dn(I("x",e,t,n))];case"RandomUniform":return[xl(I("shape",e,t,n),I("minval",e,t,n),I("maxval",e,t,n),I("dtype",e,t,n))];case"Range":{let a=I("start",e,t,n),r=I("stop",e,t,n),s=I("step",e,t,n);return[bl(a,r,s,I("dtype",e,t,n))]}case"TruncatedNormal":{let a=I("shape",e,t,n),r=I("mean",e,t,n),s=I("stdDev",e,t,n),i=I("seed",e,t,n);return[Vc(a,r,s,I("dtype",e,t,n),i)]}case"Zeros":return[Ct(I("shape",e,t,n),I("dtype",e,t,n))];case"ZerosLike":return[Ue(I("x",e,t,n))];default:throw TypeError(`Node type ${e.op} is not implemented`)}};function E2(e,t,n){let a=I("boxes",e,t,n),r=I("scores",e,t,n),s=I("maxOutputSize",e,t,n),i=I("iouThreshold",e,t,n),o=I("scoreThreshold",e,t,n),l=I("softNmsSigma",e,t,n);return{boxes:a,scores:r,maxOutputSize:s,iouThreshold:i,scoreThreshold:o,softNmsSigma:l}}var fse=async(e,t,n)=>{switch(e.op){case"NonMaxSuppressionV5":{let{boxes:a,scores:r,maxOutputSize:s,iouThreshold:i,scoreThreshold:o,softNmsSigma:l}=E2(e,t,n),d=await Ye.nonMaxSuppressionWithScoreAsync(a,r,s,i,o,l);return[d.selectedIndices,d.selectedScores]}case"NonMaxSuppressionV4":{let{boxes:a,scores:r,maxOutputSize:s,iouThreshold:i,scoreThreshold:o}=E2(e,t,n),l=I("padToMaxOutputSize",e,t,n),d=await Ye.nonMaxSuppressionPaddedAsync(a,r,s,i,o,l);return[d.selectedIndices,d.validOutputs]}case"NonMaxSuppressionV3":case"NonMaxSuppressionV2":{let{boxes:a,scores:r,maxOutputSize:s,iouThreshold:i,scoreThreshold:o}=E2(e,t,n);return[await Ye.nonMaxSuppressionAsync(a,r,s,i,o)]}case"Where":{let a=fe(I("condition",e,t,n),"bool"),r=[await zA(a)];return a.dispose(),r}case"ListDiff":return Yb(I("x",e,t,n),I("y",e,t,n));default:throw TypeError(`Node type ${e.op} is not implemented`)}},mse=(e,t,n)=>{switch(e.op){case"TopKV2":{let a=I("x",e,t,n),r=I("k",e,t,n),s=I("sorted",e,t,n),i=DA(a,r,s);return[i.values,i.indices]}case"Unique":{let a=I("x",e,t,n),r=jc(a);return[r.values,r.indices]}case"UniqueV2":{let a=I("x",e,t,n),r=I("axis",e,t,n),s=jc(a,r);return[s.values,s.indices]}default:throw TypeError(`Node type ${e.op} is not implemented`)}},Ase=(e,t,n)=>{switch(e.op){case"Const":return t[e.name];case"PlaceholderWithDefault":let a=I("default",e,t,n);return[mn(e.name,t,n)||a];case"Placeholder":return[mn(e.name,t,n)];case"Identity":case"StopGradient":case"FakeQuantWithMinMaxVars":{let d=I("x",e,t,n);return[cr(d)]}case"IdentityN":return I("x",e,t,n).map(d=>cr(d));case"Snapshot":let r=I("x",e,t,n);return[cr(r)];case"Shape":return[Tt(I("x",e,t,n).shape,"int32")];case"ShapeN":return I("x",e,t,n).map(d=>Tt(d.shape));case"Size":return[Se(I("x",e,t,n).size,"int32")];case"Rank":return[Se(I("x",e,t,n).rank,"int32")];case"NoOp":return[Se(1)];case"Print":let s=I("x",e,t,n),i=I("data",e,t,n),o=I("message",e,t,n),l=I("summarize",e,t,n);console.warn("The graph has a tf.print() operation,usually used for debugging, which slows down performance."),console.log(o);for(let d=0;de.dispose()),this.tensorMap.clear(),this.handle.dispose()}size(){return this.tensorMap.size}tensorSize(){return Se(this.size(),"int32")}async import(e,t){this.checkKeyAndValueTensor(e,t);let n=await e.data();return this.tensorMap.forEach(a=>a.dispose()),this.tensorMap.clear(),W(()=>{let a=la(t),r=n.length,s=a.length;k.assert(r===s,()=>`The number of elements doesn't match, keys has ${r} elements, the values has ${s} elements.`);for(let i=0;i{let a=[];for(let r=0;r{switch(e.op){case"HashTable":case"HashTableV2":{let r=I("keyDType",e,t,n),s=I("valueDType",e,t,n),i=new yse(r,s);return a.addHashTable(e.name,i),[i.handle]}case"LookupTableImport":case"LookupTableImportV2":{let r=I("tableHandle",e,t,n,a),s=I("keys",e,t,n),i=I("values",e,t,n);return[await a.getHashTableById(r.id).import(s,i)]}case"LookupTableFind":case"LookupTableFindV2":{let r=I("tableHandle",e,t,n,a),s=I("keys",e,t,n),i=I("defaultValue",e,t,n);return[await a.getHashTableById(r.id).find(s,i)]}case"LookupTableSize":case"LookupTableSizeV2":{let r=I("tableHandle",e,t,n,a);return[a.getHashTableById(r.id).tensorSize()]}default:throw TypeError(`Node type ${e.op} is not implemented`)}},xse=(e,t,n)=>{switch(e.op){case"ResizeBilinear":{let a=I("images",e,t,n),r=I("size",e,t,n),s=I("alignCorners",e,t,n),i=I("halfPixelCenters",e,t,n);return[Ye.resizeBilinear(a,[r[0],r[1]],s,i)]}case"ResizeNearestNeighbor":{let a=I("images",e,t,n),r=I("size",e,t,n),s=I("alignCorners",e,t,n),i=I("halfPixelCenters",e,t,n);return[Ye.resizeNearestNeighbor(a,[r[0],r[1]],s,i)]}case"CropAndResize":{let a=I("image",e,t,n),r=I("boxes",e,t,n),s=I("boxInd",e,t,n),i=I("cropSize",e,t,n),o=I("method",e,t,n),l=I("extrapolationValue",e,t,n);return[Ye.cropAndResize(a,r,s,i,o,l)]}default:throw TypeError(`Node type ${e.op} is not implemented`)}},bse=(e,t,n)=>{switch(e.op){case"Equal":return[Mr(I("a",e,t,n),I("b",e,t,n))];case"NotEqual":return[mi(I("a",e,t,n),I("b",e,t,n))];case"Greater":return[Mn(I("a",e,t,n),I("b",e,t,n))];case"GreaterEqual":return[$r(I("a",e,t,n),I("b",e,t,n))];case"Less":return[Sc(I("a",e,t,n),I("b",e,t,n))];case"LessEqual":return[Dr(I("a",e,t,n),I("b",e,t,n))];case"LogicalAnd":return[oa(I("a",e,t,n),I("b",e,t,n))];case"LogicalNot":return[Zu(I("a",e,t,n))];case"LogicalOr":return[Cc(I("a",e,t,n),I("b",e,t,n))];case"Select":case"SelectV2":return[nn(I("condition",e,t,n),I("a",e,t,n),I("b",e,t,n))];default:throw TypeError(`Node type ${e.op} is not implemented`)}},vse=(e,t,n)=>{switch(e.op){case"BatchMatMul":case"BatchMatMulV2":case"MatMul":return[Be(I("a",e,t,n),I("b",e,t,n),I("transposeA",e,t,n),I("transposeB",e,t,n))];case"Einsum":return[_b(I("equation",e,t,n),...I("tensors",e,t,n))];case"Transpose":return[Ze(I("x",e,t,n),I("perm",e,t,n))];case"_FusedMatMul":let[a,r]=I("fusedOps",e,t,n),s=a==="biasadd",i=r==="prelu",o=I("numArgs",e,t,n),l=I("leakyreluAlpha",e,t,n);if(s){if(i&&o!==2)throw new Error("Fused MatMul with BiasAdd and Prelu must have two extra arguments: bias and alpha.");if(!i&&o!==1)throw new Error("Fused MatMul with BiasAdd must have one extra argument: bias.")}let[d,u]=I("args",e,t,n);return[zr.matMul({a:I("a",e,t,n),b:I("b",e,t,n),transposeA:I("transposeA",e,t,n),transposeB:I("transposeB",e,t,n),bias:d,activation:r,preluActivationWeights:u,leakyreluAlpha:l})];default:throw TypeError(`Node type ${e.op} is not implemented`)}},wse=(e,t,n)=>{switch(e.op){case"FusedBatchNorm":case"FusedBatchNormV2":return[pi(I("x",e,t,n),I("mean",e,t,n),I("variance",e,t,n),I("offset",e,t,n),I("scale",e,t,n),I("epsilon",e,t,n))];case"FusedBatchNormV3":return[pi(I("x",e,t,n),I("mean",e,t,n),I("variance",e,t,n),I("offset",e,t,n),I("scale",e,t,n),I("epsilon",e,t,n))];case"LRN":return[xA(I("x",e,t,n),I("radius",e,t,n),I("bias",e,t,n),I("alpha",e,t,n),I("beta",e,t,n))];case"Softmax":return[nd(I("x",e,t,n))];case"LogSoftmax":return[Ec(I("x",e,t,n))];case"SparseToDense":return[_A(I("sparseIndices",e,t,n),I("outputShape",e,t,n),I("sparseValues",e,t,n),I("defaultValue",e,t,n))];default:throw TypeError(`Node type ${e.op} is not implemented`)}},kse=(e,t,n)=>{switch(e.op){case"Max":{let i=I("axis",e,t,n),o=I("keepDims",e,t,n);return[Xn(I("x",e,t,n),i,o)]}case"Mean":{let i=I("axis",e,t,n),o=I("keepDims",e,t,n);return[wt(I("x",e,t,n),i,o)]}case"Min":{let i=I("axis",e,t,n),o=I("keepDims",e,t,n);return[yl(I("x",e,t,n),i,o)]}case"Sum":{let i=I("axis",e,t,n),o=I("keepDims",e,t,n);return[ke(I("x",e,t,n),i,o)]}case"All":{let i=I("axis",e,t,n),o=I("keepDims",e,t,n);return[gc(I("x",e,t,n),i,o)]}case"Any":{let i=I("axis",e,t,n),o=I("keepDims",e,t,n);return[ju(I("x",e,t,n),i,o)]}case"ArgMax":{let i=I("axis",e,t,n);return[Uu(I("x",e,t,n),i)]}case"ArgMin":{let i=I("axis",e,t,n);return[Qm(I("x",e,t,n),i)]}case"Prod":{let i=I("axis",e,t,n),o=I("keepDims",e,t,n);return[Mc(I("x",e,t,n),i,o)]}case"Cumsum":{let i=I("axis",e,t,n),o=I("exclusive",e,t,n),l=I("reverse",e,t,n);return[kc(I("x",e,t,n),i,o,l)]}case"Bincount":let a=I("x",e,t,n),r=I("weights",e,t,n),s=I("size",e,t,n);return[lA(a,r,s)];case"DenseBincount":{let i=I("x",e,t,n),o=I("weights",e,t,n),l=I("size",e,t,n),d=I("binaryOutput",e,t,n);return[Ob(i,o,l,d)]}default:throw TypeError(`Node type ${e.op} is not implemented`)}},Ise=(e,t,n)=>{switch(e.op){case"ConcatV2":case"Concat":{let a=I("n",e,t,n),r=I("axis",e,t,n),s=I("tensors",e,t,n);return s=s.slice(0,a),[ot(s,r)]}case"Gather":{let a=I("x",e,t,n),r=I("indices",e,t,n);return[ci(a,fe(r,"int32"),0)]}case"GatherV2":{let a=I("axis",e,t,n),r=I("batchDims",e,t,n),s=I("x",e,t,n),i=I("indices",e,t,n);return[ci(s,fe(i,"int32"),a,r)]}case"Reverse":{let a=I("dims",e,t,n),r=[];for(let i=0;i{let a=I("axis",e,t,n),r=I("tensors",e,t,n),s=r[0].shape,i=Or(r[0]).shape,o=r.map(l=>{let d=k.arraysEqual(l.shape,s);if(!d&&!k.arraysEqual(Or(l).shape,i))throw new Error("the input tensors shape does not match");return d?l:H(l,s)});return[zn(o,a)]});case"Unpack":{let a=I("axis",e,t,n),r=I("tensor",e,t,n);return la(r,a)}case"Tile":{let a=I("reps",e,t,n);return[Fr(I("x",e,t,n),a)]}case"Split":case"SplitV":{let a=I("axis",e,t,n),r=I("numOrSizeSplits",e,t,n),s=I("x",e,t,n);return an(s,r,a)}case"ScatterNd":{let a=I("indices",e,t,n),r=I("values",e,t,n),s=I("shape",e,t,n);return[t3(a,r,s)]}case"GatherNd":{let a=I("x",e,t,n),r=I("indices",e,t,n);return[n3(a,r)]}case"SparseToDense":{let a=I("sparseIndices",e,t,n),r=I("outputShape",e,t,n),s=I("sparseValues",e,t,n),i=I("defaultValue",e,t,n);return[_A(a,s,r,s.dtype===i.dtype?i:fe(i,s.dtype))]}default:throw TypeError(`Node type ${e.op} is not implemented`)}},Sse=(e,t,n)=>{switch(e.op){case"SparseReshape":{let{outputIndices:a,outputShape:r}=y3.sparseReshape(I("inputIndices",e,t,n),I("inputShape",e,t,n),I("newShape",e,t,n));return[a,r]}default:throw TypeError(`Node type ${e.op} is not implemented`)}},Nse=(e,t,n)=>{switch(e.op){case"FFT":return[ad(I("x",e,t,n))];case"IFFT":return[vl(I("x",e,t,n))];case"RFFT":return[rd(I("x",e,t,n))];case"IRFFT":return[Wc(I("x",e,t,n))];default:throw TypeError(`Node type ${e.op} is not implemented`)}},Tse=(e,t,n)=>{switch(e.op){case"Cast":return[fe(I("x",e,t,n),I("dtype",e,t,n))];case"ExpandDims":{let a=I("axis",e,t,n);return[ln(I("x",e,t,n),a)]}case"Squeeze":{let a=I("axis",e,t,n);return[Or(I("x",e,t,n),a)]}case"Reshape":return[H(I("x",e,t,n),I("shape",e,t,n))];case"MirrorPad":return[IA(I("x",e,t,n),I("padding",e,t,n),I("mode",e,t,n))];case"PadV2":case"Pad":return[ar(I("x",e,t,n),I("padding",e,t,n),I("constantValue",e,t,n))];case"SpaceToBatchND":{let a=I("blockShape",e,t,n),r=I("paddings",e,t,n);return[Ju(I("x",e,t,n),a,r)]}case"BatchToSpaceND":{let a=I("blockShape",e,t,n),r=I("crops",e,t,n);return[qu(I("x",e,t,n),a,r)]}case"DepthToSpace":{let a=I("blockSize",e,t,n),r=I("dataFormat",e,t,n).toUpperCase();return[cA(I("x",e,t,n),a,r)]}case"BroadcastTo":return[pl(I("x",e,t,n),I("shape",e,t,n))];default:throw TypeError(`Node type ${e.op} is not implemented`)}};function R8(e,t,n,a){let r=((s,i,o)=>{switch(s.category){case"arithmetic":return W(()=>rse(s,i,o));case"basic_math":return W(()=>sse(s,i,o));case"control":return pse(s,i,o);case"convolution":return W(()=>cse(s,i,o));case"creation":return W(()=>hse(s,i,o));case"dynamic":return fse(s,i,o);case"evaluation":return W(()=>mse(s,i,o));case"image":return W(()=>xse(s,i,o));case"graph":return W(()=>Ase(s,i,o));case"logical":return W(()=>bse(s,i,o));case"matrices":return W(()=>vse(s,i,o));case"normalization":return W(()=>wse(s,i,o));case"reduction":return W(()=>kse(s,i,o));case"slice_join":return W(()=>Ise(s,i,o));case"sparse":return W(()=>Sse(s,i,o));case"spectral":return W(()=>Nse(s,i,o));case"transformation":return W(()=>Tse(s,i,o));case"hash_table":return gse(s,i,o,a);case"custom":let l=i8(s.op);if(l&&l.customExecutor)return l.customExecutor(new ase(s,i,o));throw TypeError(`Custom op ${s.op} is not registered.`);default:throw TypeError(`Unknown op '${s.op}'. File an issue at https://github.com/tensorflow/tfjs/issues so we can add it, or register a custom execution with tf.registerOp()`)}})(e,t,n);return k.isPromise(r)?r.then(s=>[].concat(s)):[].concat(r)}var M8=class{constructor(e={},t={},n={},a={}){this.weightMap=e,this.tensorArrayMap=t,this.tensorListMap=n,this.functionMap=a,this.rootContext={id:0,frameName:"",iterationId:0},this.contexts=[this.rootContext],this.lastId=0,this.generateCurrentContextIds()}newFrame(e,t){return{id:e,frameName:t,iterationId:0}}set currentContext(e){this.contexts!==e&&(this.contexts=e,this.generateCurrentContextIds())}get currentContext(){return this.contexts}get currentContextId(){return this._currentContextIds[0]}get currentContextIds(){return this._currentContextIds}generateCurrentContextIds(){let e=[];for(let t=0;tt.id===0&&t.iterationId===0?"":`${t.frameName}-${t.iterationId}`).join("/"):""}enterFrame(e){this.contexts&&(this.lastId++,this.contexts=this.contexts.slice(),this.contexts.push(this.newFrame(this.lastId,e)),this._currentContextIds.unshift(this.contextIdforContexts(this.contexts)))}exitFrame(){if(this.contexts&&this.contexts.length>1)this.contexts=this.contexts.slice(),this.contexts.splice(-1),this.currentContextIds.shift();else throw new Error("Cannot exit frame, the context is empty")}nextIteration(){if(this.contexts&&this.contexts.length>0){this.contexts=this.contexts.slice(),this.lastId++;let e=Object.assign({},this.contexts[this.contexts.length-1]);e.iterationId+=1,e.id=this.lastId,this.contexts.splice(-1,1,e),this._currentContextIds.splice(0,1,this.contextIdforContexts(this.contexts))}else throw new Error("Cannot increase frame iteration, the context is empty")}getWeight(e){return this.weightMap[e]}addTensorArray(e){this.tensorArrayMap[e.id]=e}getTensorArray(e){return this.tensorArrayMap[e]}addTensorList(e){this.tensorListMap[e.id]=e}getTensorList(e){return this.tensorListMap[e]}dispose(e){for(let t in this.tensorArrayMap)this.tensorArrayMap[t].clearAndClose(e);for(let t in this.tensorListMap)this.tensorListMap[t].clearAndClose(e)}};function $8(e,t,n,a){let r=new Set,s=[],i=null,o=null,l=new Set,d=Object.keys(e).map(c=>Ln(c)[0]),u=[];a!=null&&(u=a.map(c=>Ln(c.name)[0]));let p=[...t];for(;p.length>0;){let c=p.pop();if((F8(c)||Ese(c)||Cse(c))&&i==null&&(i=c,o=i.children.map(h=>h.name).filter(h=>r.has(h))),r.add(c.name),n[c.name]==null&&d.indexOf(c.name)===-1&&u.indexOf(c.name)===-1){if(c.inputs.length===0){s.push(c.name);continue}c.inputs.forEach(h=>{l.has(h.name)||(l.add(h.name),p.push(h))})}}return{inputs:e,outputs:t,usedNodes:r,missingInputs:s,dynamicNode:i,syncInputs:o}}function Rse(e,t,n){let{usedNodes:a,inputs:r}=n,s=[],i=Object.keys(r).map(u=>Ln(u)[0]).map(u=>e.nodes[u]),o=e.initNodes;i.forEach(u=>{a.has(u.name)&&s.push(u)}),e.weights.forEach(u=>{a.has(u.name)&&s.push(u)}),o!=null&&o.forEach(u=>{a.has(u.name)&&s.push(u)});let l=new Set,d=[];for(;s.length>0;){let u=s.pop();l.add(u.name),t[u.name]||d.push(u),u.children.forEach(p=>{!l.has(p.name)&&a.has(p.name)&&p.inputs.every(c=>l.has(c.name))&&s.push(p)})}return d}var Mse=["Switch","Merge","Enter","Exit","NextIteration","StatelessIf","StatelessWhile","if","While"],Fse=["NonMaxSuppressionV2","NonMaxSuppressionV3","NonMaxSuppressionV5","Where"],$se=["HashTable","HashTableV2","LookupTableImport","LookupTableImportV2","LookupTableFind","LookupTableFindV2","LookupTableSize","LookupTableSizeV2"];function F8(e){return Mse.indexOf(e.op)>=0}function Ese(e){return Fse.indexOf(e.op)>=0}function Cse(e){return $se.indexOf(e.op)>=0}var C2=class{constructor(e,t){this.graph=e,this.parent=t,this.compiledMap=new Map,this._weightMap={},this.SEPERATOR=",",this._functions={},this._functionExecutorMap={},this._outputs=e.outputs,this._inputs=e.inputs,this._initNodes=e.initNodes,this._signature=e.signature,this._functions=e.functions,e.functions!=null&&Object.keys(e.functions).forEach(n=>{this._functionExecutorMap[n]=new C2(e.functions[n],this)})}get weightIds(){return this.parent?this.parent.weightIds:this._weightIds}get functionExecutorMap(){return this.parent?this.parent.functionExecutorMap:this._functionExecutorMap}get weightMap(){return this.parent?this.parent.weightMap:this._weightMap}set weightMap(e){let t=Object.keys(e).map(n=>e[n].map(a=>a.id));this._weightIds=[].concat(...t),this._weightMap=e}set resourceManager(e){this._resourceManager=e}get inputs(){return this._inputs.map(e=>({name:e.name,shape:e.attrParams.shape?e.attrParams.shape.value:void 0,dtype:e.attrParams.dtype?e.attrParams.dtype.value:void 0}))}get outputs(){return this._outputs.map(e=>({name:e.name,shape:e.attrParams.shape?e.attrParams.shape.value:void 0,dtype:e.attrParams.dtype?e.attrParams.dtype.value:void 0}))}get inputNodes(){return this._inputs.map(e=>e.signatureKey||e.name)}get outputNodes(){return this._outputs.map(e=>{let t=e.signatureKey||e.name;return e.defaultOutput?`${t}:${e.defaultOutput}`:t})}get functions(){return Object.keys(this._functions).reduce((e,t)=>(e[t]=this._functions[t].signature,e),{})}getCompilationKey(e,t){let n=e.map(r=>r.name).sort(),a=t.map(r=>r.name).sort();return n.join(this.SEPERATOR)+"--"+a.join(this.SEPERATOR)}compile(e,t){let n=$8(e,t,this.weightMap,this._initNodes),{missingInputs:a,dynamicNode:r,syncInputs:s}=n;if(r!=null)throw new Error(`This execution contains the node '${r.name}', which has the dynamic op '${r.op}'. Please use model.executeAsync() instead. Alternatively, to avoid the dynamic ops, specify the inputs [${s}]`);if(a.length>0){let i=t.map(l=>l.name),o=Object.keys(e);throw new Error(`Cannot compute the outputs [${i}] from the provided inputs [${o}]. Missing the following inputs: [${a}]`)}return Rse(this.graph,this.weightMap,n)}execute(e,t){e=this.mapInputs(e);let n=Object.keys(e).sort();this.checkInputs(e),this.checkInputShapeAndType(e),t=this.mapOutputs(t),this.checkOutputs(t);let a=n.map(u=>this.graph.nodes[Ln(u)[0]]),r=t.map(u=>Ln(u)[0]),s=r.map(u=>this.graph.nodes[u]);s.length===0&&(s=this._outputs);let i=this.getCompilationKey(a,s),o=this.compiledMap.get(i);o==null&&(o=this.compile(e,s),this.compiledMap.set(i,o));let l={},d={};return W(()=>{let u=new M8(this.weightMap,l,d,this.functionExecutorMap),p=Object.assign({},this.weightMap);Object.keys(e).forEach(m=>{let[f,A]=Ln(m),y=[];y[A]=e[m],p[f]=y});let c=this.getFrozenTensorIds(p),h={};for(let m=0;mmn(m,p,u))})}getFrozenTensorIds(e){let t=[].concat.apply([],Object.keys(e).map(n=>e[n]).map(n=>n.map(a=>a.id)));return new Set(t)}checkTensorForDisposal(e,t,n,a,r,s,i){t.category==="control"||s.indexOf(e)!==-1||(n[e].forEach(o=>{o!=null&&(i[o.id]=(i[o.id]||0)+t.children.length)}),t.inputs.forEach(o=>{if(o.category!=="control"){let l=Pre(o.name,n,a);l!=null&&l.forEach(d=>{if(d&&!d.kept&&!r.has(d.id)){let u=i[d.id];u===1?(d.dispose(),delete i[d.id]):u!=null&&i[d.id]--}})}}))}async executeAsync(e,t){return this._executeAsync(e,t)}async _executeAsync(e,t,n=!1,a={},r={}){n||(e=this.mapInputs(e),this.checkInputs(e),this.checkInputShapeAndType(e),t=this.mapOutputs(t),this.checkOutputs(t));let s=new M8(this.weightMap,a,r,this.functionExecutorMap),i=await this.executeWithControlFlow(e,s,t,n),o=t.map(p=>mn(p,i,s)),l=o.map(p=>p.id),d=Object.keys(e).map(p=>e[p].id),u=new Set([...l,...d,...this.weightIds]);return Object.keys(i).forEach(p=>{i[p].forEach(c=>{c&&!c.kept&&!c.isDisposed&&!u.has(c.id)&&c.dispose()})}),this.parent==null&&s.dispose(u),o}async executeFunctionAsync(e,t,n){let a=e.reduce((r,s,i)=>(r[this.inputs[i].name]=s,r),{});return this._executeAsync(a,this.outputNodes,!0,t,n)}async executeWithControlFlow(e,t,n,a){let r=Object.keys(e),s=r.map(g=>this.graph.nodes[Ln(g)[0]]),i=n.map(g=>Ln(g)[0]),o=i.map(g=>this.graph.nodes[g]);o.length===0&&(o=this._outputs);let{usedNodes:l,missingInputs:d,dynamicNode:u,syncInputs:p}=$8(e,o,this.weightMap,this._initNodes),c=[...s,...this.graph.weights,...this._initNodes||[]].map(g=>({node:g,contexts:t.currentContext})),h=Object.assign({},this.weightMap);Object.keys(e).forEach(g=>{let[x,w]=Ln(g),b=[];b[w]=e[g],h[x]=b});let m={},f=this.getFrozenTensorIds(h),A={};for(;c.length>0;){let g=this.processStack(s,c,t,h,A,f,i,m,l);await Promise.all(g)}u==null&&!a&&console.warn("This model execution did not contain any nodes with control flow or dynamic output shapes. You can use model.execute() instead.");let y=o.filter(g=>!F8(g)&&!mn(g.name,h,t)).map(g=>g.name);if(y.length>0){let g="";throw u!=null&&(g=`Alternatively, to avoid the dynamic ops, use model.execute() and specify the inputs [${p}]`),new Error(`Cannot compute the outputs [${y}] from the provided inputs [${r}]. Consider providing the following inputs: [${d}]. ${g}`)}return h}processStack(e,t,n,a,r,s,i,o,l){let d=[];for(;t.length>0;){let u=t.pop();n.currentContext=u.contexts;let p="";if(u.node.op==="Enter"&&I("isConstant",u.node,a,n)&&([p]=pr(u.node.name,n)),a[u.node.name]==null){let c=R8(u.node,a,n,this._resourceManager);p||([p]=pr(u.node.name,n));let h=n.currentContext;k.isPromise(c)?d.push(c.then(m=>(a[p]=m,n.currentContext=h,this.checkTensorForDisposal(p,u.node,a,n,s,i,o),this.processChildNodes(u.node,t,n,a,r,l),m))):(a[p]=c,this.checkTensorForDisposal(p,u.node,a,n,s,i,o),this.processChildNodes(u.node,t,n,a,r,l))}else this.processChildNodes(u.node,t,n,a,r,l)}return d}processChildNodes(e,t,n,a,r,s){e.children.forEach(i=>{let[o]=pr(i.name,n);r[o]||!s.has(i.name)||(i.op==="Merge"?i.inputNames.some(l=>!!mn(l,a,n))&&(r[o]=!0,t.push({contexts:n.currentContext,node:i})):i.inputNames.every(l=>!!mn(l,a,n))&&(r[o]=!0,t.push({contexts:n.currentContext,node:i})))})}dispose(){Object.keys(this.weightMap).forEach(e=>this.weightMap[e].forEach(t=>t.dispose()))}checkInputShapeAndType(e){Object.keys(e).forEach(t=>{let n=e[t],[a]=Ln(t),r=this.graph.nodes[a];if(r.attrParams.shape&&r.attrParams.shape.value){let s=r.attrParams.shape.value,i=s.length===n.shape.length&&n.shape.every((o,l)=>s[l]===-1||s[l]===o);k.assert(i,()=>`The shape of dict['${r.name}'] provided in model.execute(dict) must be [${s}], but was [${n.shape}]`)}r.attrParams.dtype&&r.attrParams.dtype.value&&k.assert(n.dtype===r.attrParams.dtype.value,()=>`The dtype of dict['${r.name}'] provided in model.execute(dict) must be ${r.attrParams.dtype.value}, but was ${n.dtype}`)})}mapInputs(e){let t={};for(let n in e)if(this._signature!=null&&this._signature.inputs!=null&&this._signature.inputs[n]!=null){let a=this._signature.inputs[n];t[a.name]=e[n]}else t[n]=e[n];return t}checkInputs(e){let t=Object.keys(e).filter(n=>{let[a]=Ln(n);return this.graph.nodes[a]==null});if(t.length>0)throw new Error(`The dict provided in model.execute(dict) has keys: [${t}] that are not part of graph`)}mapOutputs(e){return e.map(t=>this._signature!=null&&this._signature.outputs!=null&&this._signature.outputs[t]!=null?this._signature.outputs[t].name:t,{})}checkOutputs(e){e.forEach(t=>{let[n]=Ln(t);if(!this.graph.nodes[n])throw new Error(`The output '${t}' is not found in the graph`)})}},Dse=class{constructor(e={},t={}){this.hashTableNameToHandle=e,this.hashTableMap=t}addHashTable(e,t){this.hashTableNameToHandle[e]=t.handle,this.hashTableMap[t.id]=t}getHashTableHandleByName(e){return this.hashTableNameToHandle[e]}getHashTableById(e){return this.hashTableMap[e]}dispose(){for(let e in this.hashTableMap)this.hashTableMap[e].clearAndClose(),delete this.hashTableMap[e];for(let e in this.hashTableNameToHandle)this.hashTableNameToHandle[e].dispose(),delete this.hashTableNameToHandle[e]}},Ose="?tfjs-format=file",zse="model.json",D8=class{constructor(e,t={}){this.modelUrl=e,this.loadOptions=t,this.version="n/a",t==null&&(this.loadOptions={}),this.resourceManager=new Dse}get modelVersion(){return this.version}get inputNodes(){return this.executor.inputNodes}get outputNodes(){return this.executor.outputNodes}get inputs(){return this.executor.inputs}get outputs(){return this.executor.outputs}get weights(){return this.executor.weightMap}get metadata(){return this.artifacts.userDefinedMetadata}get modelSignature(){return this.signature}findIOHandler(){let e=this.modelUrl;if(e.load!=null)this.handler=e;else if(this.loadOptions.requestInit!=null)this.handler=vn.browserHTTPRequest(e,this.loadOptions);else{let t=vn.getLoadHandlers(e,this.loadOptions);if(t.length===0)t.push(vn.browserHTTPRequest(e,this.loadOptions));else if(t.length>1)throw new Error(`Found more than one (${t.length}) load handlers for URL '${[e]}'`);this.handler=t[0]}}async load(){if(this.findIOHandler(),this.handler.load==null)throw new Error("Cannot proceed with model loading because the IOHandler provided does not have the `load` method implemented.");let e=await this.handler.load();return this.loadSync(e)}loadSync(e){this.artifacts=e;let t=this.artifacts.modelTopology,n;this.artifacts.userDefinedMetadata!=null&&this.artifacts.userDefinedMetadata.signature!=null?n=this.artifacts.userDefinedMetadata.signature:n=this.artifacts.signature,this.signature=n,this.version=`${t.versions.producer}.${t.versions.minConsumer}`;let a=vn.decodeWeights(this.artifacts.weightData,this.artifacts.weightSpecs);if(this.executor=new C2(S8.Instance.transformGraph(t,this.signature)),this.executor.weightMap=this.convertTensorMapToTensorsMap(a),this.executor.resourceManager=this.resourceManager,e.modelInitializer!=null&&e.modelInitializer.node!=null){let r=S8.Instance.transformGraph(e.modelInitializer);this.initializer=new C2(r),this.initializer.weightMap=this.executor.weightMap,this.initializer.resourceManager=this.resourceManager,this.initializer.executeAsync({},[])}return!0}async save(e,t){if(typeof e=="string"){let n=vn.getSaveHandlers(e);if(n.length===0)throw new Error(`Cannot find any save handlers for URL '${e}'`);if(n.length>1)throw new Error(`Found more than one (${n.length}) save handlers for URL '${e}'`);e=n[0]}if(e.save==null)throw new Error("GraphModel.save() cannot proceed because the IOHandler provided does not have the `save` attribute defined.");return e.save(this.artifacts)}predict(e,t){return this.execute(e,this.outputNodes)}normalizeInputs(e){if(!(e instanceof Le)&&!Array.isArray(e))return e;if(e=Array.isArray(e)?e:[e],e.length!==this.inputNodes.length)throw new Error(`Input tensor count mismatch,the graph model has ${this.inputNodes.length} placeholders, while there are ${e.length} input tensors.`);return this.inputNodes.reduce((t,n,a)=>(t[n]=e[a],t),{})}normalizeOutputs(e){return e=e||this.outputNodes,Array.isArray(e)?e:[e]}execute(e,t){e=this.normalizeInputs(e),t=this.normalizeOutputs(t);let n=this.executor.execute(e,t);return n.length>1?n:n[0]}async executeAsync(e,t){e=this.normalizeInputs(e),t=this.normalizeOutputs(t);let n=await this.executor.executeAsync(e,t);return n.length>1?n:n[0]}convertTensorMapToTensorsMap(e){return Object.keys(e).reduce((t,n)=>(t[n]=[e[n]],t),{})}dispose(){this.executor.dispose(),this.initializer&&this.initializer.dispose(),this.resourceManager.dispose()}};async function Gt(e,t={}){if(e==null)throw new Error("modelUrl in loadGraphModel() cannot be null. Please provide a url or an IOHandler that loads the model");t==null&&(t={}),t.fromTFHub&&e.load==null&&(e.endsWith("/")||(e=e+"/"),e=`${e}${zse}${Ose}`);let n=new D8(e,t);return await n.load(),n}var _se="3.6.0",O8={};Fe(O8,{CSVDataset:()=>_8,Dataset:()=>Gl,FileDataSource:()=>P8,TextLineDataset:()=>z8,URLDataSource:()=>L8,array:()=>Pse,csv:()=>Wse,func:()=>Bse,generator:()=>Vse,microphone:()=>Use,version_data:()=>Hse,webcam:()=>jse,zip:()=>Lse});var Gse=Zi(Bg()),qse=Zi(Bg());function Xse(e,t){return d0(e,t)}function d0(e,t,n=new Map,a=new Set){if(e==null)return null;if(a.has(e))throw new Error("Circular references are not supported.");if(n.has(e))return n.get(e);let r=t(e);if(r.recurse&&r.value!==null)throw new Error("A deep map function may not return both a value and recurse=true.");if(r.recurse)if(ql(e)){let s=Array.isArray(e)?[]:{};a.add(e);for(let i in e){let o=e[i],l=d0(o,t,n,a);s[i]=l}return a.delete(e),s}else throw new Error(`Can't recurse into non-iterable type: ${e}`);else return n.set(e,r.value),r.value}function Kse(e,t=B8){return W8(e,t)}function W8(e,t,n=new Set){let a=e[0];if(n.has(a))throw new Error("Circular references are not supported.");let r=t(e);if(r.recurse&&r.value!==null)throw new Error("A deep zip function may not return both a value and recurse=true.");if(r.recurse)if(ql(a)){let s=Array.isArray(a)?[]:{};n.add(a);for(let i in a){let o=e.map(d=>d[i]),l=W8(o,t,n);s[i]=l}return n.delete(a),s}else throw new Error(`Can't recurse into non-iterable type: ${a}`);else return r.value}function B8(e){return e===null?null:ql(e[0])?{value:null,recurse:!0}:{value:e,recurse:!1}}async function V8(e,t){let n=new Map;d0(e,t,n);for(let a of Array.from(n.keys())){let r=n.get(a);if(k.isPromise(r)){let s=await r;n.set(a,s)}}return d0(e,t,n)}function ql(e){return e!=null&&!ArrayBuffer.isView(e)&&(Array.isArray(e)||typeof e=="object"&&!(e instanceof Le))}function Yse(e){return e==null||Zse(e)||Array.isArray(e)||typeof e=="object"&&e instanceof Le||k.isTypedArray(e)}function Zse(e){return e===null||typeof e!="object"&&typeof e!="function"}function Qse(e){return Xse(e,Jse)}function Jse(e){return e instanceof Le?{value:e.clone(),recurse:!1}:ql(e)?{value:null,recurse:!0}:{value:e,recurse:!1}}var j8=class{constructor(e){if(this.capacity=e,this.begin=0,this.end=0,e==null)throw new RangeError("Can't create a ring buffer of unknown capacity.");if(e<1)throw new RangeError("Can't create ring buffer of capacity < 1.");this.data=new Array(e),this.doubledCapacity=2*e}wrap(e){for(;e<0;)e+=this.doubledCapacity;return e%this.doubledCapacity}get(e){if(e<0)throw new RangeError("Can't get item at a negative index.");return this.data[e%this.capacity]}set(e,t){if(e<0)throw new RangeError("Can't set item at a negative index.");this.data[e%this.capacity]=t}length(){let e=this.end-this.begin;return e<0&&(e=this.doubledCapacity+e),e}isFull(){return this.length()===this.capacity}isEmpty(){return this.length()===0}push(e){if(this.isFull())throw new RangeError("Ring buffer is full.");this.set(this.end,e),this.end=this.wrap(this.end+1)}pushAll(e){for(let t of e)this.push(t)}pop(){if(this.isEmpty())throw new RangeError("Ring buffer is empty.");this.end=this.wrap(this.end-1);let e=this.get(this.end);return this.set(this.end,void 0),e}unshift(e){if(this.isFull())throw new RangeError("Ring buffer is full.");this.begin=this.wrap(this.begin-1),this.set(this.begin,e)}shift(){if(this.isEmpty())throw new RangeError("Ring buffer is empty.");let e=this.get(this.begin);return this.set(this.begin,void 0),this.begin=this.wrap(this.begin+1),e}shuffleExcise(e){if(this.isEmpty())throw new RangeError("Ring buffer is empty.");let t=this.wrap(this.begin+e),n=this.get(t);return this.set(t,this.pop()),n}},R2=class extends j8{constructor(){super(R2.INITIAL_CAPACITY)}isFull(){return!1}push(e){super.isFull()&&this.expand(),super.push(e)}unshift(e){super.isFull()&&this.expand(),super.unshift(e)}expand(){let e=this.capacity*2,t=new Array(e),n=this.length();for(let a=0;at===!0)}rowMajorBatch(e,t=!0){return new lie(this,e,t)}columnMajorBatch(e,t=!0,n=B8){return this.rowMajorBatch(e,t).map(a=>Kse(a,n))}concatenate(e,t){return new H8(U8([this,e]),t)}take(e){return e<0||e==null?this:new oie(this,e)}skip(e){return e<0||e==null?this:new iie(this,e)}prefetch(e){return new q8(this,e)}shuffle(e,t){return new hie(this,e,t)}serial(){return new sie(this)}},eie=class extends qt{constructor(e){super();this.items=e,this.trav=0}summary(){return`Array of ${this.items.length} items`}async next(){if(this.trav>=this.items.length)return{value:null,done:!0};let e=this.items[this.trav];return this.trav++,{value:Qse(e),done:!1}}},tie=class extends qt{constructor(e){super();this.nextFn=e}summary(){return"Function call"}async next(){try{return this.nextFn()}catch(e){throw e.message=`Error thrown while iterating through a dataset: ${e.message}`,e}}},sie=class extends qt{constructor(e){super();this.upstream=e,this.lastRead=Promise.resolve({value:null,done:!1})}summary(){return`${this.upstream.summary()} -> Serial`}async next(){return this.lastRead=this.lastRead.then(()=>this.serialNext()),this.lastRead}async serialNext(){return this.upstream.next()}},iie=class extends qt{constructor(e,t){super();this.upstream=e,this.maxCount=t,this.count=0,this.lastRead=Promise.resolve({value:null,done:!1})}summary(){return`${this.upstream.summary()} -> Skip`}async next(){return this.lastRead=this.lastRead.then(()=>this.serialNext()),this.lastRead}async serialNext(){for(;this.count++ Take`}async next(){return this.count++>=this.maxCount?{value:null,done:!0}:this.upstream.next()}},lie=class extends qt{constructor(e,t,n=!0){super();this.upstream=e,this.batchSize=t,this.enableSmallLastBatch=n,this.lastRead=Promise.resolve({value:null,done:!1})}summary(){return`${this.upstream.summary()} -> RowMajorBatch`}async next(){return this.lastRead=this.lastRead.then(()=>this.serialNext()),this.lastRead}async serialNext(){let e=[];for(;e.length0?{value:e,done:!1}:{value:null,done:!0};e.push(t.value)}return{value:e,done:!1}}},uie=class extends qt{constructor(e,t){super();this.upstream=e,this.predicate=t,this.lastRead=Promise.resolve({value:null,done:!1})}summary(){return`${this.upstream.summary()} -> Filter`}async next(){return this.lastRead=this.lastRead.then(()=>this.serialNext()),this.lastRead}async serialNext(){for(;;){let e=await this.upstream.next();if(e.done||this.predicate(e.value))return e;Ee(e.value)}}},die=class extends qt{constructor(e,t){super();this.upstream=e,this.transform=t}summary(){return`${this.upstream.summary()} -> Map`}async next(){let e=await this.upstream.next();if(e.done)return{value:null,done:!0};let t=ma.getTensorsInContainer(e.value),n=this.transform(e.value),a=ma.getTensorsInContainer(n);for(let r of t)ma.isTensorInList(r,a)||r.dispose();return{value:n,done:!1}}},pie=class extends qt{constructor(e,t){super();this.upstream=e,this.handler=t,this.count=0,this.lastRead=Promise.resolve({value:null,done:!1})}summary(){return`${this.upstream.summary()} -> handleErrors`}async next(){return this.lastRead=this.lastRead.then(()=>this.serialNext()),this.lastRead}async serialNext(){for(;;)try{return await this.upstream.next()}catch(e){if(!this.handler(e))return{value:null,done:!0}}}},G8=class extends qt{constructor(e,t){super();this.upstream=e,this.transform=t}summary(){return`${this.upstream.summary()} -> AsyncMap`}async next(){let e=await this.upstream.next();if(e.done)return{value:null,done:!0};let t=ma.getTensorsInContainer(e.value),n=await this.transform(e.value),a=ma.getTensorsInContainer(n);for(let r of t)ma.isTensorInList(r,a)||r.dispose();return{value:n,done:!1}}},F2=class extends qt{constructor(){super();this.outputQueue=new R2,this.lastRead=Promise.resolve({value:null,done:!1})}async next(){return this.lastRead=this.lastRead.then(()=>this.serialNext()),this.lastRead}async serialNext(){for(;this.outputQueue.length()===0;)if(!await this.pump())return{value:null,done:!0};return{value:this.outputQueue.shift(),done:!1}}},cie=class extends F2{constructor(e,t){super();this.upstream=e,this.transform=t}summary(){return`${this.upstream.summary()} -> Flatmap`}async pump(){let e=await this.upstream.next();if(e.done)return!1;let t=ma.getTensorsInContainer(e.value),n=this.transform(e.value),a=ma.getTensorsInContainer(n);this.outputQueue.pushAll(n);for(let r of t)ma.isTensorInList(r,a)||r.dispose();return!0}},H8=class extends qt{constructor(e,t){super();this.baseErrorHandler=t,this.lastRead=null,this.iterator=null,this.moreIterators=e}summary(){return"TODO: fill in upstream of chained summaries -> Chained"}async next(){return this.lastRead=this.readFromChain(this.lastRead),this.lastRead}async readFromChain(e){if(await e,this.iterator==null){let n=await this.moreIterators.next();if(n.done)return{value:null,done:!0};this.iterator=n.value,this.baseErrorHandler!=null&&(this.iterator=this.iterator.handleErrors(this.baseErrorHandler))}let t=await this.iterator.next();return t.done?(this.iterator=null,this.readFromChain(e)):t}},Xr;(function(e){e[e.FAIL=0]="FAIL",e[e.SHORTEST=1]="SHORTEST",e[e.LONGEST=2]="LONGEST"})(Xr||(Xr={}));var aie=class extends qt{constructor(e,t=Xr.FAIL){super();this.iterators=e,this.mismatchMode=t,this.count=0,this.currentPromise=null}summary(){return"{TODO: fill in upstream of zip summaries} -> Zip"}async nextState(e){await e;let t=0,n=0;function a(s){return s instanceof qt?{value:s.next().then(i=>(t++,i.done&&n++,i.value)),recurse:!1}:{value:null,recurse:!0}}let r=await V8(this.iterators,a);if(t===n)return{value:null,done:!0};if(n>0)switch(this.mismatchMode){case Xr.FAIL:throw new Error(`Zipped streams should have the same length. Mismatched at element ${this.count}.`);case Xr.SHORTEST:return{value:null,done:!0};case Xr.LONGEST:default:}return this.count++,{value:r,done:!1}}async next(){return this.currentPromise=this.nextState(this.currentPromise),this.currentPromise}},q8=class extends qt{constructor(e,t){super();this.upstream=e,this.bufferSize=t,this.buffer=new j8(t)}summary(){return`${this.upstream.summary()} -> Prefetch`}refill(){for(;!this.buffer.isFull();){let e=this.upstream.next();this.buffer.push(e)}}next(){return this.refill(),this.buffer.shift()}},hie=class extends q8{constructor(e,t,n){super(e,t);this.upstream=e,this.windowSize=t,this.upstreamExhausted=!1,this.random=qse.alea(n||k.now().toString()),this.lastRead=Promise.resolve({value:null,done:!1})}async next(){return this.lastRead=this.lastRead.then(()=>this.serialNext()),this.lastRead}randomInt(e){return Math.floor(this.random()*e)}chooseIndex(){return this.randomInt(this.buffer.length())}async serialNext(){for(this.upstreamExhausted||this.refill();!this.buffer.isEmpty();){let e=this.chooseIndex(),t=await this.buffer.shuffleExcise(e);if(t.done)this.upstreamExhausted=!0;else return this.refill(),t}return{value:null,done:!0}}},Gl=class{constructor(){this.size=null}batch(e,t=!0){let n=this;k.assert(e>0,()=>`batchSize needs to be positive, but it is + ${e}`);let a;return this.size===Infinity||this.size==null?a=this.size:t?a=Math.ceil(this.size/e):a=Math.floor(this.size/e),Wn(async()=>(await n.iterator()).columnMajorBatch(e,t,fie),a)}concatenate(e){let t=this,n;return this.size===Infinity||e.size===Infinity?n=Infinity:this.size!=null&&e.size!=null?n=this.size+e.size:n=null,Wn(async()=>(await t.iterator()).concatenate(await e.iterator()),n)}filter(e){let t=this,n;return this.size===Infinity?n=Infinity:n=null,Wn(async()=>(await t.iterator()).filter(a=>W(()=>e(a))),n)}async forEachAsync(e){return(await this.iterator()).forEachAsync(e)}map(e){let t=this;return Wn(async()=>(await t.iterator()).map(n=>W(()=>e(n))),this.size)}mapAsync(e){let t=this;return Wn(async()=>(await t.iterator()).mapAsync(e),this.size)}prefetch(e){if(e==null)throw new RangeError("`Dataset.prefetch()` requires bufferSize to be specified.");let t=this;return Wn(async()=>(await t.iterator()).prefetch(e),this.size)}repeat(e){let t=this,n;return this.size!=null&&e>0?n=this.size*e:e===0?n=0:this.size!=null&&(e===void 0||e<0)?n=Infinity:n=null,Wn(async()=>{let a=M2(async()=>({value:await t.iterator(),done:!1}));return nie(a.take(e))},n)}skip(e){let t=this,n;return this.size!=null&&e>=0&&this.size>=e?n=this.size-e:this.size!=null&&(this.size(await t.iterator()).skip(e),n)}shuffle(e,t,n=!0){if(e==null||e<0)throw this.size==null?new RangeError("`Dataset.shuffle()` requires bufferSize to be specified."):new RangeError(`\`Dataset.shuffle()\` requires bufferSize to be specified. If your data fits in main memory (for regular JS objects), and/or GPU memory (for \`tf.Tensor\`s), consider setting bufferSize to the dataset size (${this.size} elements)`);let a=this,r=Gse.alea(t||k.now().toString());return Wn(async()=>{let s=r.int32();return n&&(s+=r.int32()),(await a.iterator()).shuffle(e,s.toString())},this.size)}take(e){let t=this,n;return this.size!=null&&this.size>e?n=e:this.size!=null&&this.size<=e?n=this.size:n=null,Wn(async()=>(await t.iterator()).take(e),n)}async toArray(){if(this.size===Infinity)throw new Error("Can not convert infinite data stream to array.");return(await this.iterator()).toArray()}async toArrayForTest(){if(this.size===Infinity)throw new Error("Can not convert infinite data stream to array.");return(await this.iterator()).toArrayForTest()}};Gl.MAX_BUFFER_SIZE=1e4;function Wn(e,t=null){return new class extends Gl{constructor(){super(...arguments);this.size=t}async iterator(){return e()}}}function Pse(e){return Wn(async()=>U8(e),e.length)}function Lse(e){if(!ql(e))throw new Error("The argument to zip() must be an object or array.");let t;if(Array.isArray(e))for(let n=0;n{let n=await V8(e,a=>{if(a instanceof Gl)return{value:a.iterator(),recurse:!1};if(ql(a))return{value:null,recurse:!0};throw new Error("Leaves of the structure passed to zip() must be Datasets, not primitives.")});return rie(n,Xr.SHORTEST)},t)}function fie(e){if(e===null)return null;let t=e[0];return Yse(t)?{value:mie(e),recurse:!1}:{value:null,recurse:!0}}function mie(e){if(e.length===0)throw new Error("Can't make a batch of zero elements.");return e[0]instanceof Le?zn(e):ia(e)}var z8=class extends Gl{constructor(e){super();this.input=e}async iterator(){return(await this.input.iterator()).decodeUTF8().split(` +`).map(e=>(e.endsWith("\r")&&(e=e.slice(0,-1)),e))}},p0='"',Hd=Symbol("out"),X8=Symbol("field"),c0=Symbol("quote"),$2=Symbol("quoteafterquote"),K8=Symbol("quoteinquote"),_8=class extends Gl{constructor(e,t){super();this.input=e,this.hasHeader=!0,this.fullColumnNames=null,this.columnNamesValidated=!1,this.columnConfigs=null,this.configuredColumnsOnly=!1,this.delimiter=",",this.delimWhitespace=!1,this.base=new z8(e),t||(t={}),this.hasHeader=t.hasHeader!==!1,this.fullColumnNames=t.columnNames,this.columnConfigs=t.columnConfigs,this.configuredColumnsOnly=t.configuredColumnsOnly,t.delimWhitespace?(k.assert(t.delimiter==null,()=>"Delimiter should not be provided when delimWhitespace is true."),this.delimWhitespace=!0,this.delimiter=" "):this.delimiter=t.delimiter?t.delimiter:","}async columnNames(){return this.columnNamesValidated||await this.setColumnNames(),this.configuredColumnsOnly?Object.keys(this.columnConfigs):this.fullColumnNames}async setColumnNames(){let e=await this.maybeReadHeaderLine();if(!this.fullColumnNames&&!e)throw new Error("Column names must be provided if there is no header line.");this.fullColumnNames&&e&&k.assert(e.length===this.fullColumnNames.length,()=>"The length of provided columnNames ("+this.fullColumnNames.length.toString()+") does not match the length of the header line read from file ("+e.length.toString()+")."),this.fullColumnNames||(this.fullColumnNames=e);let t=this.fullColumnNames.reduce((a,r)=>(a[r]=a[r]+1||1,a),{}),n=Object.keys(t).filter(a=>t[a]>1);if(k.assert(n.length===0,()=>"Duplicate column names found: "+n.toString()),this.columnConfigs){for(let a of Object.keys(this.columnConfigs))if(this.fullColumnNames.indexOf(a)===-1)throw new Error('The key "'+a+'" provided in columnConfigs does not match any of the column names ('+this.fullColumnNames.toString()+").")}this.columnNamesValidated=!0}async maybeReadHeaderLine(){if(this.hasHeader){let e=await(await this.base.iterator()).next();if(e.done)throw new Error("No data was found for CSV parsing.");let t=e.value;return this.parseRow(t,!1)}else return null}async iterator(){this.columnNamesValidated||await this.setColumnNames();let e=await this.base.iterator();return this.hasHeader&&(e=e.skip(1)),e.map(t=>this.makeDataElement(t))}makeDataElement(e){let t=this.parseRow(e),n={},a={};for(let r=0;r14||!Number.isInteger(t))throw new Error(`Invalid fftSize: it must be a power of 2 between 2 to 4 and 2 to 14, but got ${this.fftSize}`);if(this.numFrames=e.numFramesPerSpectrogram||43,this.sampleRateHz=e.sampleRateHz,this.columnTruncateLength=e.columnTruncateLength||this.fftSize,this.audioTrackConstraints=e.audioTrackConstraints,this.smoothingTimeConstant=e.smoothingTimeConstant||0,this.includeSpectrogram=e.includeSpectrogram!==!1,this.includeWaveform=e.includeWaveform===!0,!this.includeSpectrogram&&!this.includeWaveform)throw new Error("Both includeSpectrogram and includeWaveform are false. At least one type of data should be returned.")}summary(){return"microphone"}static async create(e={}){if(J().get("IS_NODE"))throw new Error("microphone API is only supported in browser environment.");let t=new Z8(e);return await t.start(),t}async start(){try{this.stream=await navigator.mediaDevices.getUserMedia({audio:this.audioTrackConstraints==null?!0:this.audioTrackConstraints,video:!1})}catch(n){throw new Error(`Error thrown while initializing video stream: ${n.message}`)}if(!this.stream)throw new Error("Could not obtain audio from microphone.");let e=window.AudioContext||window.webkitAudioContext;if(this.audioContext=new e,!this.sampleRateHz)this.sampleRateHz=this.audioContext.sampleRate;else if(this.audioContext.sampleRate!==this.sampleRateHz)throw new Error(`Mismatch in sampling rate: Expected: ${this.sampleRateHz}; Actual: ${this.audioContext.sampleRate}`);let t=this.audioContext.createMediaStreamSource(this.stream);this.analyser=this.audioContext.createAnalyser(),this.analyser.fftSize=this.fftSize*2,this.analyser.smoothingTimeConstant=this.smoothingTimeConstant,t.connect(this.analyser),this.freqData=new Float32Array(this.fftSize),this.timeData=new Float32Array(this.fftSize)}async next(){if(this.isClosed)return{value:null,done:!0};let e,t,n=await this.getAudioData();if(this.includeSpectrogram){let a=this.flattenQueue(n.freqDataQueue);e=this.getTensorFromAudioDataArray(a,[this.numFrames,this.columnTruncateLength,1])}if(this.includeWaveform){let a=this.flattenQueue(n.timeDataQueue);t=this.getTensorFromAudioDataArray(a,[this.numFrames*this.fftSize,1])}return{value:{spectrogram:e,waveform:t},done:!1}}async capture(){return(await this.next()).value}async getAudioData(){let e=[],t=[],n=0;return new Promise(a=>{let r=setInterval(()=>{this.includeSpectrogram&&(this.analyser.getFloatFrequencyData(this.freqData),this.freqData[0]===-Infinity&&a({freqDataQueue:e,timeDataQueue:t}),e.push(this.freqData.slice(0,this.columnTruncateLength))),this.includeWaveform&&(this.analyser.getFloatTimeDomainData(this.timeData),t.push(this.timeData.slice())),++n===this.numFrames&&(clearInterval(r),a({freqDataQueue:e,timeDataQueue:t}))},this.fftSize/this.sampleRateHz*1e3)})}stop(){this.isClosed||(this.isClosed=!0,this.analyser.disconnect(),this.audioContext.close(),this.stream!=null&&this.stream.getTracks().length>0&&this.stream.getTracks()[0].stop())}toArray(){throw new Error("Can not convert infinite audio stream to array.")}getSampleRate(){return this.sampleRateHz}flattenQueue(e){let t=e[0].length,n=new Float32Array(e.length*t);return e.forEach((a,r)=>n.set(a,r*t)),n}getTensorFromAudioDataArray(e,t){let n=new Float32Array(k.sizeFromShape(t));return n.set(e,n.length-e.length),ia(n,t)}},Y8=class extends qt{constructor(e,t){super();if(this.webcamVideoElement=e,this.webcamConfig=t,this.isClosed=!0,this.resize=!1,this.needToResize())if(this.resize=!0,this.cropSize=[this.webcamConfig.resizeHeight,this.webcamConfig.resizeWidth],this.cropBoxInd=Tt([0],"int32"),this.webcamConfig.centerCrop){let n=this.webcamConfig.resizeWidth*1/this.webcamVideoElement.width,a=this.webcamConfig.resizeHeight*1/this.webcamVideoElement.height,r=(1-n)/2,s=(1-a)/2,i=r+n,o=a+s;this.cropBox=ya([s,r,o,i],[1,4])}else this.cropBox=ya([0,0,1,1],[1,4])}summary(){return"webcam"}static async create(e,t={}){if(J().get("IS_NODE"))throw new Error("tf.data.webcam is only supported in browser environment.");if(!e){if(e=document.createElement("video"),!t.resizeWidth||!t.resizeHeight)throw new Error("Please provide webcam video element, or resizeWidth and resizeHeight to create a hidden video element.");e.width=t.resizeWidth,e.height=t.resizeHeight}let n=new Y8(e,t);return await n.start(),n}async start(){this.webcamConfig.facingMode&&k.assert(this.webcamConfig.facingMode==="user"||this.webcamConfig.facingMode==="environment",()=>`Invalid webcam facing mode: ${this.webcamConfig.facingMode}. Please provide 'user' or 'environment'`);try{this.stream=await navigator.mediaDevices.getUserMedia({video:{deviceId:this.webcamConfig.deviceId,facingMode:this.webcamConfig.facingMode?this.webcamConfig.facingMode:"user",width:this.webcamVideoElement.width,height:this.webcamVideoElement.height}})}catch(e){throw e.message=`Error thrown while initializing video stream: ${e.message}`,e}if(!this.stream)throw new Error("Could not obtain video from webcam.");try{this.webcamVideoElement.srcObject=this.stream}catch(e){console.log(e),this.webcamVideoElement.src=window.URL.createObjectURL(this.stream)}return this.webcamVideoElement.play(),this.isClosed=!1,new Promise(e=>{this.webcamVideoElement.onloadedmetadata=()=>{e()}})}async next(){if(this.isClosed)return{value:null,done:!0};let e;try{e=oi.fromPixels(this.webcamVideoElement)}catch(t){throw new Error(`Error thrown converting video to pixels: ${JSON.stringify(t)}`)}if(this.resize)try{return{value:this.cropAndResizeFrame(e),done:!1}}catch(t){throw new Error(`Error thrown cropping the video: ${t.message}`)}finally{e.dispose()}else return{value:e,done:!1}}needToResize(){return!!(this.webcamConfig.resizeWidth&&this.webcamConfig.resizeHeight&&(this.webcamVideoElement.width!==this.webcamConfig.resizeWidth||this.webcamVideoElement.height!==this.webcamConfig.resizeHeight))}cropAndResizeFrame(e){return W(()=>{let t=ln(fe(e,"float32"),0),n;n=Ye.cropAndResize(t,this.cropBox,this.cropBoxInd,this.cropSize,"bilinear");let a=n.shape;return H(n,a.slice(1))})}async capture(){return(await this.next()).value}stop(){this.stream.getTracks().forEach(e=>e.stop());try{this.webcamVideoElement.srcObject=null}catch(e){console.log(e),this.webcamVideoElement.src=null}this.isClosed=!0}toArray(){throw new Error("Can not convert infinite video stream to array.")}},J8=class{},Q8=class extends qt{split(e){return new Aie(this,e)}},Aie=class extends Q8{constructor(e,t){super();this.upstream=e,this.impl=new yie(e,t)}summary(){return this.impl.summary()}async next(){return this.impl.next()}},yie=class extends F2{constructor(e,t){super();this.upstream=e,this.separator=t,this.carryover=""}summary(){return`${this.upstream.summary()} -> Split('${this.separator}')`}async pump(){let e=await this.upstream.next();if(e.done)return this.carryover===""?!1:(this.outputQueue.push(this.carryover),this.carryover="",!0);let t=e.value.split(this.separator);t[0]=this.carryover+t[0];for(let n of t.slice(0,-1))this.outputQueue.push(n);return this.carryover=t[t.length-1],!0}},xie=class extends qt{decodeUTF8(){return new gie(this)}},gie=class extends Q8{constructor(e){super();this.upstream=e,this.impl=new bie(e)}summary(){return this.impl.summary()}async next(){return this.impl.next()}},bie=class extends F2{constructor(e){super();if(this.upstream=e,J().get("IS_BROWSER"))this.decoder=new TextDecoder("utf-8");else{let{StringDecoder:t}=pI();this.decoder=new t("utf8")}}summary(){return`${this.upstream.summary()} -> Utf8`}async pump(){let e=await this.upstream.next(),t;if(e.done)return!1;t=e.value;let n;return J().get("IS_BROWSER")?n=this.decoder.decode(t,{stream:!0}):n=this.decoder.write(Buffer.from(t.buffer)),this.outputQueue.push(n),!0}},ek=class extends xie{constructor(e,t={}){super();this.file=e,this.options=t,k.assert(e instanceof Uint8Array||(J().get("IS_BROWSER")?e instanceof File||e instanceof Blob:!1),()=>"FileChunkIterator only supports File, Blob and Uint8Array right now."),this.offset=t.offset||0,this.chunkSize=t.chunkSize||1024*1024}summary(){return`FileChunks ${this.file}`}async next(){return this.offset>=(this.file instanceof Uint8Array?this.file.byteLength:this.file.size)?{value:null,done:!0}:{value:await new Promise((e,t)=>{let n=this.offset+this.chunkSize;if(this.file instanceof Uint8Array)e(new Uint8Array(this.file.slice(this.offset,n)));else{let a=new FileReader;a.onload=s=>{let i=a.result;if(i instanceof ArrayBuffer&&(i=new Uint8Array(i)),!(i instanceof Uint8Array))return t(new TypeError("FileReader returned unknown type."));e(i)},a.onabort=s=>t(new Error("Aborted")),a.onerror=s=>t(new Error(s.type));let r=this.file.slice(this.offset,n);a.readAsArrayBuffer(r)}this.offset=n}),done:!1}}};async function wie(e,t={}){let n,a;typeof e=="string"?n=e:(n=e.url,a=vie(e));let r=await k.fetch(n,a);if(r.ok){let s=new Uint8Array(await r.arrayBuffer());return new ek(s,t)}else throw new Error(r.statusText)}var vie=e=>({method:e.method,headers:e.headers,body:e.body,mode:e.mode,credentials:e.credentials,cache:e.cache,redirect:e.redirect,referrer:e.referrer,integrity:e.integrity});function tk(e){return typeof e=="string"&&e.substr(0,7)==="file://"}var P8=class extends J8{constructor(e,t={}){super();this.input=e,this.options=t}async iterator(){if(tk(this.input)&&J().get("IS_NODE")){let e=require("fs");this.input=e.readFileSync(this.input.substr(7))}return new ek(this.input,this.options)}},L8=class extends J8{constructor(e,t={}){super();this.url=e,this.fileOptions=t}async iterator(){return tk(this.url)?new P8(this.url,this.fileOptions).iterator():wie(this.url,this.fileOptions)}};function Wse(e,t={}){return new _8(new L8(e),t)}function Bse(e){let t=M2(e);return Wn(async()=>t)}function Vse(e){return Wn(async()=>{let t=await e();return M2(()=>t.next())})}async function jse(e,t){return Y8.create(e,t)}async function Use(e){return Z8.create(e)}var Hse="3.6.0",kie={tfjs:(dm==null?void 0:dm.version)||void 0,"tfjs-core":(pm==null?void 0:pm.version)||void 0,"tfjs-data":(cm==null?void 0:cm.version)||void 0,"tfjs-layers":(hm==null?void 0:hm.version)||void 0,"tfjs-converter":(fm==null?void 0:fm.version)||void 0,"tfjs-backend-cpu":Y3||void 0,"tfjs-backend-webgl":bv||void 0,"tfjs-backend-wasm":c6||void 0};var Bn={name:"humangl",priority:99,canvas:null,gl:null,width:1024,height:1024,webGLattr:{alpha:!1,antialias:!1,premultipliedAlpha:!1,preserveDrawingBuffer:!1,depth:!1,stencil:!1,failIfMajorPerformanceCaveat:!1,desynchronized:!0}};function nk(){if(!Zm(Bn.name)){he("backend registration:",Bn.name);try{Bn.canvas=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(Bn.width,Bn.height):document.createElement("canvas")}catch(e){he("error: cannot create canvas:",e);return}try{Bn.gl=Bn.canvas.getContext("webgl2",Bn.webGLattr)}catch(e){he("error: cannot get WebGL2 context:",e);return}try{ph(2,Bn.gl)}catch(e){he("error: cannot set WebGL2 context:",e);return}try{let e=new mh(Bn.gl);ul(Bn.name,()=>new Ol(e),Bn.priority)}catch(e){he("error: cannot register WebGL backend:",e);return}try{nl("webgl").forEach(t=>{let n={...t,backendName:Bn.name};ai(n)})}catch(e){he("error: cannot update WebGL backend registration:",e);return}try{fa.set("WEBGL_VERSION",2)}catch(e){he("error: cannot set WebGL backend flags:",e);return}he("backend registered:",Bn.name)}}var W2={};Ma(W2,{load:()=>j2,predict:()=>V2,triangulation:()=>fk,uvmap:()=>mk});function ak(e,t){let n=[e.startPoint[0]*t[0],e.startPoint[1]*t[1]],a=[e.endPoint[0]*t[0],e.endPoint[1]*t[1]];return{startPoint:n,endPoint:a}}function Gd(e){return[Math.abs(e.endPoint[0]-e.startPoint[0]),Math.abs(e.endPoint[1]-e.startPoint[1])]}function Xl(e){return[e.startPoint[0]+(e.endPoint[0]-e.startPoint[0])/2,e.startPoint[1]+(e.endPoint[1]-e.startPoint[1])/2]}function Kl(e,t,n){let a=t.shape[1],r=t.shape[2],s=[[e.startPoint[1]/a,e.startPoint[0]/r,e.endPoint[1]/a,e.endPoint[0]/r]];return Ye.cropAndResize(t,s,[0],n)}function h0(e,t=1.5){let n=Xl(e),a=Gd(e),r=[t*a[0]/2,t*a[1]/2],s=[n[0]-r[0],n[1]-r[1]],i=[n[0]+r[0],n[1]+r[1]];return{startPoint:s,endPoint:i,landmarks:e.landmarks}}function f0(e){let t=Xl(e),n=Gd(e),r=Math.max(...n)/2,s=[Math.round(t[0]-r),Math.round(t[1]-r)],i=[Math.round(t[0]+r),Math.round(t[1]+r)];return{startPoint:s,endPoint:i,landmarks:e.landmarks}}function D2(e){let t=e.map(s=>s[0]),n=e.map(s=>s[1]),a=[Math.min(...t),Math.min(...n)],r=[Math.max(...t),Math.max(...n)];return{startPoint:a,endPoint:r,landmarks:e}}var rk=e=>({startPoint:Re(e,[0,0],[-1,2]),endPoint:Re(e,[0,2],[-1,2])});var m0=[[1,0,0],[0,1,0],[0,0,1]];function Iie(e){return e-2*Math.PI*Math.floor((e+Math.PI)/(2*Math.PI))}function O2(e,t){let n=Math.PI/2-Math.atan2(-(t[1]-e[1]),t[0]-e[0]);return Iie(n)}function sk(e,t){return[[1,0,e],[0,1,t],[0,0,1]]}function Kr(e,t){let n=0;for(let a=0;a{let d=t.resizeBilinear([this.inputSize,this.inputSize]).div(127.5).sub(.5),u=this.model.execute(d),p;if(Array.isArray(u)){let f=u.sort((x,w)=>x.size-w.size),A=ot([f[0],f[2]],2),y=ot([f[1],f[3]],2);p=ot([y,A],1).squeeze(0)}else p=u.squeeze();let c=Nie(p,this.anchors,[this.inputSize,this.inputSize]),h=Re(p,[0,0],[-1,1]),m=wn(h).squeeze().dataSync();return[p,c,m]}),s=await Ye.nonMaxSuppressionAsync(a,r,this.config.face.detector.maxDetected,this.config.face.detector.iouThreshold,this.config.face.detector.minConfidence),i=s.arraySync();s.dispose();let o=[];for(let l=0;lthis.config.face.detector.minConfidence){let u=Re(a,[i[l],0],[1,-1]),p=rk(u);u.dispose();let c=this.anchorsData[i[l]],h=W(()=>Re(n,[i[l],dk-1],[1,-1]).squeeze().reshape([dk,-1]));o.push({box:p,landmarks:h,anchor:c,confidence:d})}}return n.dispose(),a.dispose(),{boxes:o,scaleFactor:[t.shape[2]/this.inputSize,t.shape[1]/this.inputSize]}}};async function ck(e){let t=await Gt(Yt(e.modelBasePath,e.face.detector.modelPath),{fromTFHub:e.face.detector.modelPath.includes("tfhub.dev")}),n=new pk(t,e);return!t||!t.modelUrl?he("load model failed:",e.face.detector.modelPath):e.debug&&he("load model:",t.modelUrl),n}var qa={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]},z2=[{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]}],qd=[[.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]],Oi=[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 Tie=[127,234,132,58,172,150,149,148,152,377,378,379,397,288,361,454,356,70,63,105,66,107,336,296,334,293,300,168,6,195,4,98,97,2,326,327,33,160,158,133,153,144,362,385,387,263,373,380,57,40,37,0,267,270,287,321,314,17,84,91,78,81,13,311,308,402,14,178],Eie=[33,133,362,263,1,62,308,159,145,386,374,6,102,331,2,13,14,70,105,107,336,334,300,54,10,284,50,280,234,454,58,288,152],Cie=[33,133,362,263,1,78,308],coe=Tie.map(e=>qd[e]),hoe=Eie.map(e=>qd[e]),foe=Cie.map(e=>qd[e]);var _2=qa.leftEyeLower0,P2=qa.rightEyeLower0,Zl={leftBounds:[_2[0],_2[_2.length-1]],rightBounds:[P2[0],P2[P2.length-1]]},y0={count:468,mouth:13,symmetryLine:[13,qa.midwayBetweenEyes[0]]},hk={leftEye:0,rightEye:1,nose:2,mouth:3,leftEar:4,rightEar:5,symmetryLine:[3,2]},Yl={upperCenter:3,lowerCenter:4,index:71,numCoordinates:76};function g0(e,t,n,a){for(let r=0;r[s[0]/this.meshSize*(p[0]-this.meshSize/2),s[1]/this.meshSize*(p[1]-this.meshSize/2),p[2]]),o=a!==0?A0(a,[0,0]):m0,l=a!==0?i.map(p=>[...lk(p,o),p[2]]):i,d=a!==0?ok(r):m0,u=[...Xl({startPoint:n.startPoint,endPoint:n.endPoint}),1];return l.map(p=>[Math.round(p[0]+Kr(u,d[0])),Math.round(p[1]+Kr(u,d[1])),Math.round(p[2])])}getLeftToRightEyeDepthDifference(t){let n=t[Zl.leftBounds[0]][2],a=t[Zl.rightBounds[0]][2];return n-a}getEyeBox(t,n,a,r,s=!1){let i=f0(h0(D2([t[a],t[r]]),this.irisEnlarge)),o=Gd(i),l=Ye.cropAndResize(n,[[i.startPoint[1]/this.meshSize,i.startPoint[0]/this.meshSize,i.endPoint[1]/this.meshSize,i.endPoint[0]/this.meshSize]],[0],[this.irisSize,this.irisSize]);return s&&fa.flags.IS_BROWSER&&(l=Ye.flipLeftRight(l)),{box:i,boxSize:o,crop:l}}getEyeCoords(t,n,a,r=!1){let s=[];for(let i=0;i{let d=i;return l===2?d=r:l===4&&(d=s),[o[0],o[1],d]})}async predict(t,n){let a=!1,r;if((this.skipped===0||this.skipped>n.face.detector.skipFrames||!n.face.mesh.enabled||!n.videoOptimized)&&(r=await this.boundingBoxDetector.getBoundingBoxes(t),this.skipped=0),n.videoOptimized&&this.skipped++,!n.videoOptimized||r&&r.boxes&&(!n.face.mesh.enabled||r.boxes.length!==this.detectedFaces&&this.detectedFaces!==n.face.detector.maxDetected)){this.storedBoxes=[],this.detectedFaces=0;for(let i of r.boxes)this.storedBoxes.push({startPoint:i.box.startPoint.dataSync(),endPoint:i.box.endPoint.dataSync(),landmarks:i.landmarks,confidence:i.confidence});this.storedBoxes.length>0&&(a=!0)}if(n.face.detector.skipInitial&&this.detectedFaces===0&&(this.skipped=0),a){if(!r||!r.boxes||r.boxes.length===0)return this.storedBoxes=[],this.detectedFaces=0,null;for(let i=0;i{i.box.startPoint.dispose(),i.box.endPoint.dispose(),i.landmarks.dispose()});let s=W(()=>this.storedBoxes.map((i,o)=>{let l,d=0,u;if(n.face.detector.rotation&&n.face.mesh.enabled&&fa.flags.IS_BROWSER){let[w,b]=i.landmarks.length>=y0.count?y0.symmetryLine:hk.symmetryLine;d=O2(i.landmarks[w],i.landmarks[b]);let v=Xl({startPoint:i.startPoint,endPoint:i.endPoint}),N=[v[0]/t.shape[2],v[1]/t.shape[1]],T=Ye.rotateWithOffset(t,d,0,N);u=A0(-d,v),n.face.mesh.enabled?l=Kl({startPoint:i.startPoint,endPoint:i.endPoint},T,[this.meshSize,this.meshSize]).div(255):l=Kl({startPoint:i.startPoint,endPoint:i.endPoint},T,[this.boxSize,this.boxSize]).div(255)}else{u=m0;let w=t.clone();n.face.mesh.enabled?l=Kl({startPoint:i.startPoint,endPoint:i.endPoint},w,[this.meshSize,this.meshSize]).div(255):l=Kl({startPoint:i.startPoint,endPoint:i.endPoint},w,[this.boxSize,this.boxSize]).div(255)}if(!n.face.mesh.enabled)return{mesh:[],box:i,faceConfidence:null,boxConfidence:i.confidence,confidence:i.confidence,image:l};let[,p,c]=this.meshDetector.execute(l),h=p.dataSync()[0];if(h=y0.count?y0.symmetryLine:hk.symmetryLine;d=O2(i.landmarks[w],i.landmarks[b]);let v=Xl({startPoint:i.startPoint,endPoint:i.endPoint}),N=[v[0]/t.shape[2],v[1]/t.shape[1]],T=Ye.rotateWithOffset(t.toFloat(),d,0,N);u=A0(-d,v),l=Kl({startPoint:i.startPoint,endPoint:i.endPoint},T,[this.meshSize,this.meshSize]).div(255)}let g={mesh:A,box:i,faceConfidence:h,boxConfidence:i.confidence,image:l},x=f0(i);return x.confidence=i.confidence,x.faceConfidence=h,this.storedBoxes[o]=x,g}));return n.face.mesh.enabled&&(this.storedBoxes=this.storedBoxes.filter(i=>i.confidence>n.face.detector.minConfidence)),this.detectedFaces=s.length,s}};var Wt=[null,null,null],B2;async function V2(e,t){let n=await B2.predict(e,t),a=[];for(let r of n||[]){if(!r||r.isDisposedInternal)continue;let s=r.mesh.map(d=>[d[0]/e.shape[2],d[1]/e.shape[1],d[2]/B2.meshSize]),i={};if(r.mesh&&r.mesh.length>0)for(let d of Object.keys(qa))i[d]=qa[d].map(u=>r.mesh[u]);let o=r.box?[Math.max(0,r.box.startPoint[0]),Math.max(0,r.box.startPoint[1]),Math.min(e.shape[2],r.box.endPoint[0])-Math.max(0,r.box.startPoint[0]),Math.min(e.shape[1],r.box.endPoint[1])-Math.max(0,r.box.startPoint[1])]:0,l=r.box?[r.box.startPoint[0]/e.shape[2],r.box.startPoint[1]/e.shape[1],(r.box.endPoint[0]-r.box.startPoint[0])/e.shape[2],(r.box.endPoint[1]-r.box.startPoint[1])/e.shape[1]]:[];a.push({confidence:Math.round(100*r.faceConfidence||100*r.boxConfidence||0)/100,boxConfidence:Math.round(100*r.boxConfidence)/100,faceConfidence:Math.round(100*r.faceConfidence)/100,box:o,boxRaw:l,mesh:r.mesh,meshRaw:s,annotations:i,image:r.image}),r.coords&&r.coords.dispose()}return a}async function j2(e){return!Wt[0]&&e.face.enabled||!Wt[1]&&e.face.mesh.enabled||!Wt[2]&&e.face.iris.enabled?(Wt=await Promise.all([!Wt[0]&&e.face.enabled?ck(e):null,!Wt[1]&&e.face.mesh.enabled?Gt(Yt(e.modelBasePath,e.face.mesh.modelPath),{fromTFHub:e.face.mesh.modelPath.includes("tfhub.dev")}):null,!Wt[2]&&e.face.iris.enabled?Gt(Yt(e.modelBasePath,e.face.iris.modelPath),{fromTFHub:e.face.iris.modelPath.includes("tfhub.dev")}):null]),e.face.mesh.enabled&&(!Wt[1]||!Wt[1].modelUrl?he("load model failed:",e.face.mesh.modelPath):e.debug&&he("load model:",Wt[1].modelUrl)),e.face.iris.enabled&&(!Wt[2]||!Wt[1].modelUrl?he("load model failed:",e.face.iris.modelPath):e.debug&&he("load model:",Wt[2].modelUrl))):e.debug&&(he("cached model:",Wt[0].model.modelUrl),he("cached model:",Wt[1].modelUrl),he("cached model:",Wt[2].modelUrl)),B2=new L2(Wt[0],Wt[1],Wt[2]),Wt}var fk=Oi,mk=qd;var U2={};Ma(U2,{load:()=>q2,predict:()=>b0});var Rie=["angry","disgust","fear","happy","sad","surprise","neutral"],Ea,H2=[],x0=Number.MAX_SAFE_INTEGER,G2=[.2989,.587,.114];async function q2(e){return Ea?e.debug&&he("cached model:",Ea.modelUrl):(Ea=await Gt(Yt(e.modelBasePath,e.face.emotion.modelPath)),!Ea||!Ea.modelUrl?he("load model failed:",e.face.emotion.modelPath):e.debug&&he("load model:",Ea.modelUrl)),Ea}async function b0(e,t){return Ea?x00?(x0++,H2):(t.videoOptimized?x0=0:x0=Number.MAX_SAFE_INTEGER,new Promise(async n=>{let a=Ye.resizeBilinear(e,[Ea.inputs[0].shape[2],Ea.inputs[0].shape[1]],!1),[r,s,i]=an(a,3,3);a.dispose();let o=_(r,G2[0]),l=_(s,G2[1]),d=_(i,G2[2]);r.dispose(),s.dispose(),i.dispose();let u=yc([o,l,d]);o.dispose(),l.dispose(),d.dispose();let p=W(()=>u.sub(.5).mul(2));u.dispose();let c=[];if(t.face.emotion.enabled){let h=await Ea.predict(p),m=h.dataSync();Ee(h);for(let f=0;ft.face.emotion.minConfidence&&c.push({score:Math.min(.99,Math.trunc(100*m[f])/100),emotion:Rie[f]});c.sort((f,A)=>A.score-f.score)}p.dispose(),H2=c,n(c)})):null}var X2={};Ma(X2,{enhance:()=>Y2,load:()=>K2,match:()=>Ak,predict:()=>k0,similarity:()=>Z2});var Qn,v0={age:0},w0=Number.MAX_SAFE_INTEGER;async function K2(e){return Qn?e.debug&&he("cached model:",Qn.modelUrl):(Qn=await Gt(Yt(e.modelBasePath,e.face.description.modelPath)),!Qn||!Qn.modelUrl?he("load model failed:",e.face.description.modelPath):e.debug&&he("load model:",Qn.modelUrl)),Qn}function Z2(e,t,n=2){if(!e||!t||(e==null?void 0:e.length)===0||(t==null?void 0:t.length)===0||(e==null?void 0:e.length)!==(t==null?void 0:t.length))return 0;let a=5*e.map((s,i)=>Math.abs(e[i]-t[i])**n).reduce((s,i)=>s+i,0)**(1/n);return Math.max(0,100-a)/100}function Ak(e,t,n=0){let a={similarity:0,name:"",source:"",embedding:[]};if(!e||!t||!Array.isArray(e)||!Array.isArray(t))return a;for(let r of t)if(r.embedding&&r.name){let s=Z2(e,r.embedding);s>n&&s>a.similarity&&(a={...r,similarity:s})}return a}function Y2(e){return W(()=>{let n=e.image||e.tensor||e;if(!(n instanceof Le))return null;let a=[[.05,.15,.85,.85]];return(n.shape.length===3?Ye.cropAndResize(ln(n,0),a,[0],[Qn.inputs[0].shape[2],Qn.inputs[0].shape[1]]):Ye.cropAndResize(n,a,[0],[Qn.inputs[0].shape[2],Qn.inputs[0].shape[1]])).mul(255)})}async function k0(e,t){return Qn?w00?(w0++,v0):(t.videoOptimized?w0=0:w0=Number.MAX_SAFE_INTEGER,new Promise(async n=>{let a=Y2(e),r,s={age:0,gender:"unknown",genderConfidence:0,descriptor:[]};t.face.description.enabled&&(r=await Qn.predict(a)),Ee(a),r&&(W(()=>{let i=r.find(p=>p.shape[1]===1).dataSync(),o=Math.trunc(200*Math.abs(i[0]-.5))/100;o>t.face.description.minConfidence&&(s.gender=i[0]<=.5?"female":"male",s.genderConfidence=Math.min(.99,o));let l=r.find(p=>p.shape[1]===100).argMax(1).dataSync()[0],d=r.find(p=>p.shape[1]===100).dataSync();s.age=Math.round(d[l-1]>d[l+1]?10*l-100*d[l-1]:10*l+100*d[l+1])/10;let u=r.find(p=>p.shape[1]===1024);s.descriptor=[...u.dataSync()]}),r.forEach(i=>Ee(i))),v0=s,n(s)})):null}var Mie=(e,t)=>{let n=A=>A*180/Math.PI,a=A=>{let y=Math.sqrt(A[0]*A[0]+A[1]*A[1]+A[2]*A[2]);return A[0]/=y,A[1]/=y,A[2]/=y,A},r=(A,y)=>{let g=A[0]-y[0],x=A[1]-y[1],w=A[2]-y[2];return[g,x,w]},s=(A,y)=>{let g=A[1]*y[2]-A[2]*y[1],x=A[2]*y[0]-A[0]*y[2],w=A[0]*y[1]-A[1]*y[0];return[g,x,w]},i=A=>{let[y,g,x,w,b,v,N,T,R]=A,$,z,P;return w<1?w>-1?(P=Math.asin(w),z=Math.atan2(-N,y),$=Math.atan2(-v,b)):(P=-Math.PI/2,z=-Math.atan2(T,R),$=0):(P=Math.PI/2,z=Math.atan2(T,R),$=0),{pitch:2*-$,yaw:2*-z,roll:2*-P}},o=A=>{let y=(x,w,b,v)=>Math.atan2(v-w,b-x);return{pitch:y(A[10][1],A[10][2],A[152][1],A[152][2]),yaw:y(A[33][0],A[33][2],A[263][0],A[263][2]),roll:y(A[33][0],A[33][1],A[263][0],A[263][1])}},l=e.meshRaw;if(!l||l.length<300)return{angle:{pitch:0,yaw:0,roll:0},matrix:[1,0,0,0,1,0,0,0,1]};let d=Math.max(e.boxRaw[2]*t[0],e.boxRaw[3]*t[1])/1.5,u=[l[10],l[152],l[234],l[454]].map(A=>[A[0]*t[0]/d,A[1]*t[1]/d,A[2]]),p=a(r(u[1],u[0])),c=a(r(u[3],u[2])),h=a(s(c,p));c=s(p,h);let m=[c[0],c[1],c[2],p[0],p[1],p[2],h[0],h[1],h[2]];return{angle:i(m),matrix:m}},J2=async(e,t)=>{var u,p,c,h,m,f;let n,a,r,s,i,o,l=[];e.state="run:face",n=it();let d=await V2(t,e.config);if(e.perf.face=Math.trunc(it()-n),!d)return[];for(let A of d){if(e.analyze("Get Face"),!A.image||A.image.isDisposedInternal){he("Face object is disposed:",A.image);continue}let y=Mie(A,[t.shape[2],t.shape[1]]);e.analyze("Start Emotion:"),e.config.async?s=e.config.face.emotion.enabled?b0(A.image,e.config):{}:(e.state="run:emotion",n=it(),s=e.config.face.emotion.enabled?await b0(A.image,e.config):{},e.perf.emotion=Math.trunc(it()-n)),e.analyze("End Emotion:"),e.analyze("Start Description:"),e.config.async?o=e.config.face.description.enabled?k0(A,e.config):[]:(e.state="run:description",n=it(),o=e.config.face.description.enabled?await k0(A.image,e.config):[],e.perf.embedding=Math.trunc(it()-n)),e.analyze("End Description:"),e.config.async&&([a,r,s,i,o]=await Promise.all([a,r,s,i,o])),e.analyze("Finish Face:"),!e.config.face.iris.enabled&&((u=A==null?void 0:A.annotations)==null?void 0:u.leftEyeIris)&&((p=A==null?void 0:A.annotations)==null?void 0:p.rightEyeIris)&&(delete A.annotations.leftEyeIris,delete A.annotations.rightEyeIris);let g=((c=A.annotations)==null?void 0:c.leftEyeIris)&&((h=A.annotations)==null?void 0:h.rightEyeIris)?11.7*Math.max(Math.abs(A.annotations.leftEyeIris[3][0]-A.annotations.leftEyeIris[1][0]),Math.abs(A.annotations.rightEyeIris[4][1]-A.annotations.rightEyeIris[2][1])):0;l.push({...A,age:o.age,gender:o.gender,genderConfidence:o.genderConfidence,embedding:o.descriptor,emotion:s,iris:g!==0?Math.trunc(g)/100:0,rotation:y,tensor:e.config.face.detector.return?(m=A.image)==null?void 0:m.squeeze():null}),(f=A.image)==null||f.dispose(),e.analyze("End Face")}return e.analyze("End FaceMesh:"),e.config.async&&(e.perf.face&&delete e.perf.face,e.perf.age&&delete e.perf.age,e.perf.gender&&delete e.perf.gender,e.perf.emotion&&delete e.perf.emotion),l};var rg={};Ma(rg,{load:()=>ig,predict:()=>sg});var Xd=["nose","leftEye","rightEye","leftEar","rightEar","leftShoulder","rightShoulder","leftElbow","rightElbow","leftWrist","rightWrist","leftHip","rightHip","leftKnee","rightKnee","leftAnkle","rightAnkle"],yk=Xd.length,Kd=Xd.reduce((e,t,n)=>(e[t]=n,e),{}),Fie=[["leftHip","leftShoulder"],["leftElbow","leftShoulder"],["leftElbow","leftWrist"],["leftHip","leftKnee"],["leftKnee","leftAnkle"],["rightHip","rightShoulder"],["rightElbow","rightShoulder"],["rightElbow","rightWrist"],["rightHip","rightKnee"],["rightKnee","rightAnkle"],["leftShoulder","rightShoulder"],["leftHip","rightHip"]],$ie=Fie.map(([e,t])=>[Kd[e],Kd[t]]),gk=[["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"]];function xk(e){let t=e.reduce(({maxX:n,maxY:a,minX:r,minY:s},{position:{x:i,y:o}})=>({maxX:Math.max(n,i),maxY:Math.max(a,o),minX:Math.min(r,i),minY:Math.min(s,o)}),{maxX:Number.NEGATIVE_INFINITY,maxY:Number.NEGATIVE_INFINITY,minX:Number.POSITIVE_INFINITY,minY:Number.POSITIVE_INFINITY});return[t.minX,t.minY,t.maxX-t.minX,t.maxY-t.minY]}function bk(e,[t,n],[a,r]){let s=(o,l,d)=>({score:o.score,box:[Math.trunc(o.box[0]*d),Math.trunc(o.box[1]*l),Math.trunc(o.box[2]*d),Math.trunc(o.box[3]*l)],keypoints:o.keypoints.map(({score:u,part:p,position:c})=>({score:u,part:p,position:{x:Math.trunc(c.x*d),y:Math.trunc(c.y*l)}}))});return e.map(o=>s(o,t/a,n/r))}var Q2=class{constructor(t,n){this.priorityQueue=new Array(t),this.numberOfElements=-1,this.getElementValue=n}enqueue(t){this.priorityQueue[++this.numberOfElements]=t,this.swim(this.numberOfElements)}dequeue(){let t=this.priorityQueue[0];return this.exchange(0,this.numberOfElements--),this.sink(0),this.priorityQueue[this.numberOfElements+1]=null,t}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(t){for(;t>0&&this.less(Math.floor(t/2),t);)this.exchange(t,Math.floor(t/2)),t=Math.floor(t/2)}sink(t){for(;2*t<=this.numberOfElements;){let n=2*t;if(nn?n:e}function vk(e,t,n,a){let r=n-e,s=a-t;return r*r+s*s}function ag(e,t){return{x:e.x+t.x,y:e.y+t.y}}var I0=1,Jl=16,Die=50**2;function wk(e,t,n,a,r,s,i=2){let o=y=>({y:s.get(y.y,y.x,e),x:s.get(y.y,y.x,s.shape[2]/2+e)}),l=(y,g,x)=>({y:ng(Math.round(y.y/Jl),0,g-1),x:ng(Math.round(y.x/Jl),0,x-1)}),[d,u]=a.shape,p=l(t.position,d,u),c=o(p),m=ag(t.position,c);for(let y=0;y[Kd[c],Kd[h]]),i=s.map(([,c])=>c),o=s.map(([c])=>c),l=t.shape[2],d=i.length,u=new Array(l),p=tg(e.part,Jl,n);u[e.part.id]={score:e.score,part:Xd[e.part.id],position:p};for(let c=d-1;c>=0;--c){let h=i[c],m=o[c];u[h]&&!u[m]&&(u[m]=wk(c,u[h],m,t,n,r))}for(let c=0;ct){o=!1;break}if(!o)break}return o}function _ie(e,t){let[n,a,r]=t.shape,s=new Q2(n*a*r,({score:i})=>i);for(let i=0;i{let s=r[a].position;return vk(n,t,s.y,s.x)<=Die})}function Pie(e,t){return t.reduce((a,{position:r,score:s},i)=>(kk(e,r,i)||(a+=s),a),0)/t.length}function Ik(e,t,n,a,r,s){let i=[],o=_ie(s,t);for(;i.lengthh.score>s);let p=Pie(i,u),c=xk(u);p>s&&i.push({keypoints:u,box:c,score:Math.round(100*p)/100})}return i}var ha,Lie=["MobilenetV1/offset_2/BiasAdd","MobilenetV1/heatmap_2/BiasAdd","MobilenetV1/displacement_fwd_2/BiasAdd","MobilenetV1/displacement_bwd_2/BiasAdd"];async function sg(e,t){let n=W(()=>{let o=e.resizeBilinear([ha.inputs[0].shape[2],ha.inputs[0].shape[1]]).toFloat().div(127.5).sub(1),d=ha.execute(o,Lie).map(u=>u.squeeze([0]));return d[1]=d[1].sigmoid(),d}),a=await Promise.all(n.map(i=>i.buffer()));for(let i of n)i.dispose();let r=await Ik(a[0],a[1],a[2],a[3],t.body.maxDetected,t.body.minConfidence);return bk(r,[e.shape[1],e.shape[2]],[ha.inputs[0].shape[2],ha.inputs[0].shape[1]])}async function ig(e){return ha?e.debug&&he("cached model:",ha.modelUrl):(ha=await Gt(Yt(e.modelBasePath,e.body.modelPath)),!ha||!ha.modelUrl?he("load model failed:",e.body.modelPath):e.debug&&he("load model:",ha.modelUrl)),ha}var pg={};Ma(pg,{load:()=>hg,predict:()=>cg});function S0(e){return[Math.abs(e.endPoint[0]-e.startPoint[0]),Math.abs(e.endPoint[1]-e.startPoint[1])]}function Zd(e){return[e.startPoint[0]+(e.endPoint[0]-e.startPoint[0])/2,e.startPoint[1]+(e.endPoint[1]-e.startPoint[1])/2]}function Sk(e,t,n){let a=t.shape[1],r=t.shape[2],s=[[e.startPoint[1]/a,e.startPoint[0]/r,e.endPoint[1]/a,e.endPoint[0]/r]];return Ye.cropAndResize(t,s,[0],n)}function Nk(e,t){let n=[e.startPoint[0]*t[0],e.startPoint[1]*t[1]],a=[e.endPoint[0]*t[0],e.endPoint[1]*t[1]],r=e.palmLandmarks.map(s=>[s[0]*t[0],s[1]*t[1]]);return{startPoint:n,endPoint:a,palmLandmarks:r,confidence:e.confidence}}function N0(e,t=1.5){let n=Zd(e),a=S0(e),r=[t*a[0]/2,t*a[1]/2],s=[n[0]-r[0],n[1]-r[1]],i=[n[0]+r[0],n[1]+r[1]];return{startPoint:s,endPoint:i,palmLandmarks:e.palmLandmarks}}function T0(e){let t=Zd(e),n=S0(e),r=Math.max(...n)/2,s=[t[0]-r,t[1]-r],i=[t[0]+r,t[1]+r];return{startPoint:s,endPoint:i,palmLandmarks:e.palmLandmarks}}var Tk=[{x:.015625,y:.015625},{x:.015625,y:.015625},{x:.046875,y:.015625},{x:.046875,y:.015625},{x:.078125,y:.015625},{x:.078125,y:.015625},{x:.109375,y:.015625},{x:.109375,y:.015625},{x:.140625,y:.015625},{x:.140625,y:.015625},{x:.171875,y:.015625},{x:.171875,y:.015625},{x:.203125,y:.015625},{x:.203125,y:.015625},{x:.234375,y:.015625},{x:.234375,y:.015625},{x:.265625,y:.015625},{x:.265625,y:.015625},{x:.296875,y:.015625},{x:.296875,y:.015625},{x:.328125,y:.015625},{x:.328125,y:.015625},{x:.359375,y:.015625},{x:.359375,y:.015625},{x:.390625,y:.015625},{x:.390625,y:.015625},{x:.421875,y:.015625},{x:.421875,y:.015625},{x:.453125,y:.015625},{x:.453125,y:.015625},{x:.484375,y:.015625},{x:.484375,y:.015625},{x:.515625,y:.015625},{x:.515625,y:.015625},{x:.546875,y:.015625},{x:.546875,y:.015625},{x:.578125,y:.015625},{x:.578125,y:.015625},{x:.609375,y:.015625},{x:.609375,y:.015625},{x:.640625,y:.015625},{x:.640625,y:.015625},{x:.671875,y:.015625},{x:.671875,y:.015625},{x:.703125,y:.015625},{x:.703125,y:.015625},{x:.734375,y:.015625},{x:.734375,y:.015625},{x:.765625,y:.015625},{x:.765625,y:.015625},{x:.796875,y:.015625},{x:.796875,y:.015625},{x:.828125,y:.015625},{x:.828125,y:.015625},{x:.859375,y:.015625},{x:.859375,y:.015625},{x:.890625,y:.015625},{x:.890625,y:.015625},{x:.921875,y:.015625},{x:.921875,y:.015625},{x:.953125,y:.015625},{x:.953125,y:.015625},{x:.984375,y:.015625},{x:.984375,y:.015625},{x:.015625,y:.046875},{x:.015625,y:.046875},{x:.046875,y:.046875},{x:.046875,y:.046875},{x:.078125,y:.046875},{x:.078125,y:.046875},{x:.109375,y:.046875},{x:.109375,y:.046875},{x:.140625,y:.046875},{x:.140625,y:.046875},{x:.171875,y:.046875},{x:.171875,y:.046875},{x:.203125,y:.046875},{x:.203125,y:.046875},{x:.234375,y:.046875},{x:.234375,y:.046875},{x:.265625,y:.046875},{x:.265625,y:.046875},{x:.296875,y:.046875},{x:.296875,y:.046875},{x:.328125,y:.046875},{x:.328125,y:.046875},{x:.359375,y:.046875},{x:.359375,y:.046875},{x:.390625,y:.046875},{x:.390625,y:.046875},{x:.421875,y:.046875},{x:.421875,y:.046875},{x:.453125,y:.046875},{x:.453125,y:.046875},{x:.484375,y:.046875},{x:.484375,y:.046875},{x:.515625,y:.046875},{x:.515625,y:.046875},{x:.546875,y:.046875},{x:.546875,y:.046875},{x:.578125,y:.046875},{x:.578125,y:.046875},{x:.609375,y:.046875},{x:.609375,y:.046875},{x:.640625,y:.046875},{x:.640625,y:.046875},{x:.671875,y:.046875},{x:.671875,y:.046875},{x:.703125,y:.046875},{x:.703125,y:.046875},{x:.734375,y:.046875},{x:.734375,y:.046875},{x:.765625,y:.046875},{x:.765625,y:.046875},{x:.796875,y:.046875},{x:.796875,y:.046875},{x:.828125,y:.046875},{x:.828125,y:.046875},{x:.859375,y:.046875},{x:.859375,y:.046875},{x:.890625,y:.046875},{x:.890625,y:.046875},{x:.921875,y:.046875},{x:.921875,y:.046875},{x:.953125,y:.046875},{x:.953125,y:.046875},{x:.984375,y:.046875},{x:.984375,y:.046875},{x:.015625,y:.078125},{x:.015625,y:.078125},{x:.046875,y:.078125},{x:.046875,y:.078125},{x:.078125,y:.078125},{x:.078125,y:.078125},{x:.109375,y:.078125},{x:.109375,y:.078125},{x:.140625,y:.078125},{x:.140625,y:.078125},{x:.171875,y:.078125},{x:.171875,y:.078125},{x:.203125,y:.078125},{x:.203125,y:.078125},{x:.234375,y:.078125},{x:.234375,y:.078125},{x:.265625,y:.078125},{x:.265625,y:.078125},{x:.296875,y:.078125},{x:.296875,y:.078125},{x:.328125,y:.078125},{x:.328125,y:.078125},{x:.359375,y:.078125},{x:.359375,y:.078125},{x:.390625,y:.078125},{x:.390625,y:.078125},{x:.421875,y:.078125},{x:.421875,y:.078125},{x:.453125,y:.078125},{x:.453125,y:.078125},{x:.484375,y:.078125},{x:.484375,y:.078125},{x:.515625,y:.078125},{x:.515625,y:.078125},{x:.546875,y:.078125},{x:.546875,y:.078125},{x:.578125,y:.078125},{x:.578125,y:.078125},{x:.609375,y:.078125},{x:.609375,y:.078125},{x:.640625,y:.078125},{x:.640625,y:.078125},{x:.671875,y:.078125},{x:.671875,y:.078125},{x:.703125,y:.078125},{x:.703125,y:.078125},{x:.734375,y:.078125},{x:.734375,y:.078125},{x:.765625,y:.078125},{x:.765625,y:.078125},{x:.796875,y:.078125},{x:.796875,y:.078125},{x:.828125,y:.078125},{x:.828125,y:.078125},{x:.859375,y:.078125},{x:.859375,y:.078125},{x:.890625,y:.078125},{x:.890625,y:.078125},{x:.921875,y:.078125},{x:.921875,y:.078125},{x:.953125,y:.078125},{x:.953125,y:.078125},{x:.984375,y:.078125},{x:.984375,y:.078125},{x:.015625,y:.109375},{x:.015625,y:.109375},{x:.046875,y:.109375},{x:.046875,y:.109375},{x:.078125,y:.109375},{x:.078125,y:.109375},{x:.109375,y:.109375},{x:.109375,y:.109375},{x:.140625,y:.109375},{x:.140625,y:.109375},{x:.171875,y:.109375},{x:.171875,y:.109375},{x:.203125,y:.109375},{x:.203125,y:.109375},{x:.234375,y:.109375},{x:.234375,y:.109375},{x:.265625,y:.109375},{x:.265625,y:.109375},{x:.296875,y:.109375},{x:.296875,y:.109375},{x:.328125,y:.109375},{x:.328125,y:.109375},{x:.359375,y:.109375},{x:.359375,y:.109375},{x:.390625,y:.109375},{x:.390625,y:.109375},{x:.421875,y:.109375},{x:.421875,y:.109375},{x:.453125,y:.109375},{x:.453125,y:.109375},{x:.484375,y:.109375},{x:.484375,y:.109375},{x:.515625,y:.109375},{x:.515625,y:.109375},{x:.546875,y:.109375},{x:.546875,y:.109375},{x:.578125,y:.109375},{x:.578125,y:.109375},{x:.609375,y:.109375},{x:.609375,y:.109375},{x:.640625,y:.109375},{x:.640625,y:.109375},{x:.671875,y:.109375},{x:.671875,y:.109375},{x:.703125,y:.109375},{x:.703125,y:.109375},{x:.734375,y:.109375},{x:.734375,y:.109375},{x:.765625,y:.109375},{x:.765625,y:.109375},{x:.796875,y:.109375},{x:.796875,y:.109375},{x:.828125,y:.109375},{x:.828125,y:.109375},{x:.859375,y:.109375},{x:.859375,y:.109375},{x:.890625,y:.109375},{x:.890625,y:.109375},{x:.921875,y:.109375},{x:.921875,y:.109375},{x:.953125,y:.109375},{x:.953125,y:.109375},{x:.984375,y:.109375},{x:.984375,y:.109375},{x:.015625,y:.140625},{x:.015625,y:.140625},{x:.046875,y:.140625},{x:.046875,y:.140625},{x:.078125,y:.140625},{x:.078125,y:.140625},{x:.109375,y:.140625},{x:.109375,y:.140625},{x:.140625,y:.140625},{x:.140625,y:.140625},{x:.171875,y:.140625},{x:.171875,y:.140625},{x:.203125,y:.140625},{x:.203125,y:.140625},{x:.234375,y:.140625},{x:.234375,y:.140625},{x:.265625,y:.140625},{x:.265625,y:.140625},{x:.296875,y:.140625},{x:.296875,y:.140625},{x:.328125,y:.140625},{x:.328125,y:.140625},{x:.359375,y:.140625},{x:.359375,y:.140625},{x:.390625,y:.140625},{x:.390625,y:.140625},{x:.421875,y:.140625},{x:.421875,y:.140625},{x:.453125,y:.140625},{x:.453125,y:.140625},{x:.484375,y:.140625},{x:.484375,y:.140625},{x:.515625,y:.140625},{x:.515625,y:.140625},{x:.546875,y:.140625},{x:.546875,y:.140625},{x:.578125,y:.140625},{x:.578125,y:.140625},{x:.609375,y:.140625},{x:.609375,y:.140625},{x:.640625,y:.140625},{x:.640625,y:.140625},{x:.671875,y:.140625},{x:.671875,y:.140625},{x:.703125,y:.140625},{x:.703125,y:.140625},{x:.734375,y:.140625},{x:.734375,y:.140625},{x:.765625,y:.140625},{x:.765625,y:.140625},{x:.796875,y:.140625},{x:.796875,y:.140625},{x:.828125,y:.140625},{x:.828125,y:.140625},{x:.859375,y:.140625},{x:.859375,y:.140625},{x:.890625,y:.140625},{x:.890625,y:.140625},{x:.921875,y:.140625},{x:.921875,y:.140625},{x:.953125,y:.140625},{x:.953125,y:.140625},{x:.984375,y:.140625},{x:.984375,y:.140625},{x:.015625,y:.171875},{x:.015625,y:.171875},{x:.046875,y:.171875},{x:.046875,y:.171875},{x:.078125,y:.171875},{x:.078125,y:.171875},{x:.109375,y:.171875},{x:.109375,y:.171875},{x:.140625,y:.171875},{x:.140625,y:.171875},{x:.171875,y:.171875},{x:.171875,y:.171875},{x:.203125,y:.171875},{x:.203125,y:.171875},{x:.234375,y:.171875},{x:.234375,y:.171875},{x:.265625,y:.171875},{x:.265625,y:.171875},{x:.296875,y:.171875},{x:.296875,y:.171875},{x:.328125,y:.171875},{x:.328125,y:.171875},{x:.359375,y:.171875},{x:.359375,y:.171875},{x:.390625,y:.171875},{x:.390625,y:.171875},{x:.421875,y:.171875},{x:.421875,y:.171875},{x:.453125,y:.171875},{x:.453125,y:.171875},{x:.484375,y:.171875},{x:.484375,y:.171875},{x:.515625,y:.171875},{x:.515625,y:.171875},{x:.546875,y:.171875},{x:.546875,y:.171875},{x:.578125,y:.171875},{x:.578125,y:.171875},{x:.609375,y:.171875},{x:.609375,y:.171875},{x:.640625,y:.171875},{x:.640625,y:.171875},{x:.671875,y:.171875},{x:.671875,y:.171875},{x:.703125,y:.171875},{x:.703125,y:.171875},{x:.734375,y:.171875},{x:.734375,y:.171875},{x:.765625,y:.171875},{x:.765625,y:.171875},{x:.796875,y:.171875},{x:.796875,y:.171875},{x:.828125,y:.171875},{x:.828125,y:.171875},{x:.859375,y:.171875},{x:.859375,y:.171875},{x:.890625,y:.171875},{x:.890625,y:.171875},{x:.921875,y:.171875},{x:.921875,y:.171875},{x:.953125,y:.171875},{x:.953125,y:.171875},{x:.984375,y:.171875},{x:.984375,y:.171875},{x:.015625,y:.203125},{x:.015625,y:.203125},{x:.046875,y:.203125},{x:.046875,y:.203125},{x:.078125,y:.203125},{x:.078125,y:.203125},{x:.109375,y:.203125},{x:.109375,y:.203125},{x:.140625,y:.203125},{x:.140625,y:.203125},{x:.171875,y:.203125},{x:.171875,y:.203125},{x:.203125,y:.203125},{x:.203125,y:.203125},{x:.234375,y:.203125},{x:.234375,y:.203125},{x:.265625,y:.203125},{x:.265625,y:.203125},{x:.296875,y:.203125},{x:.296875,y:.203125},{x:.328125,y:.203125},{x:.328125,y:.203125},{x:.359375,y:.203125},{x:.359375,y:.203125},{x:.390625,y:.203125},{x:.390625,y:.203125},{x:.421875,y:.203125},{x:.421875,y:.203125},{x:.453125,y:.203125},{x:.453125,y:.203125},{x:.484375,y:.203125},{x:.484375,y:.203125},{x:.515625,y:.203125},{x:.515625,y:.203125},{x:.546875,y:.203125},{x:.546875,y:.203125},{x:.578125,y:.203125},{x:.578125,y:.203125},{x:.609375,y:.203125},{x:.609375,y:.203125},{x:.640625,y:.203125},{x:.640625,y:.203125},{x:.671875,y:.203125},{x:.671875,y:.203125},{x:.703125,y:.203125},{x:.703125,y:.203125},{x:.734375,y:.203125},{x:.734375,y:.203125},{x:.765625,y:.203125},{x:.765625,y:.203125},{x:.796875,y:.203125},{x:.796875,y:.203125},{x:.828125,y:.203125},{x:.828125,y:.203125},{x:.859375,y:.203125},{x:.859375,y:.203125},{x:.890625,y:.203125},{x:.890625,y:.203125},{x:.921875,y:.203125},{x:.921875,y:.203125},{x:.953125,y:.203125},{x:.953125,y:.203125},{x:.984375,y:.203125},{x:.984375,y:.203125},{x:.015625,y:.234375},{x:.015625,y:.234375},{x:.046875,y:.234375},{x:.046875,y:.234375},{x:.078125,y:.234375},{x:.078125,y:.234375},{x:.109375,y:.234375},{x:.109375,y:.234375},{x:.140625,y:.234375},{x:.140625,y:.234375},{x:.171875,y:.234375},{x:.171875,y:.234375},{x:.203125,y:.234375},{x:.203125,y:.234375},{x:.234375,y:.234375},{x:.234375,y:.234375},{x:.265625,y:.234375},{x:.265625,y:.234375},{x:.296875,y:.234375},{x:.296875,y:.234375},{x:.328125,y:.234375},{x:.328125,y:.234375},{x:.359375,y:.234375},{x:.359375,y:.234375},{x:.390625,y:.234375},{x:.390625,y:.234375},{x:.421875,y:.234375},{x:.421875,y:.234375},{x:.453125,y:.234375},{x:.453125,y:.234375},{x:.484375,y:.234375},{x:.484375,y:.234375},{x:.515625,y:.234375},{x:.515625,y:.234375},{x:.546875,y:.234375},{x:.546875,y:.234375},{x:.578125,y:.234375},{x:.578125,y:.234375},{x:.609375,y:.234375},{x:.609375,y:.234375},{x:.640625,y:.234375},{x:.640625,y:.234375},{x:.671875,y:.234375},{x:.671875,y:.234375},{x:.703125,y:.234375},{x:.703125,y:.234375},{x:.734375,y:.234375},{x:.734375,y:.234375},{x:.765625,y:.234375},{x:.765625,y:.234375},{x:.796875,y:.234375},{x:.796875,y:.234375},{x:.828125,y:.234375},{x:.828125,y:.234375},{x:.859375,y:.234375},{x:.859375,y:.234375},{x:.890625,y:.234375},{x:.890625,y:.234375},{x:.921875,y:.234375},{x:.921875,y:.234375},{x:.953125,y:.234375},{x:.953125,y:.234375},{x:.984375,y:.234375},{x:.984375,y:.234375},{x:.015625,y:.265625},{x:.015625,y:.265625},{x:.046875,y:.265625},{x:.046875,y:.265625},{x:.078125,y:.265625},{x:.078125,y:.265625},{x:.109375,y:.265625},{x:.109375,y:.265625},{x:.140625,y:.265625},{x:.140625,y:.265625},{x:.171875,y:.265625},{x:.171875,y:.265625},{x:.203125,y:.265625},{x:.203125,y:.265625},{x:.234375,y:.265625},{x:.234375,y:.265625},{x:.265625,y:.265625},{x:.265625,y:.265625},{x:.296875,y:.265625},{x:.296875,y:.265625},{x:.328125,y:.265625},{x:.328125,y:.265625},{x:.359375,y:.265625},{x:.359375,y:.265625},{x:.390625,y:.265625},{x:.390625,y:.265625},{x:.421875,y:.265625},{x:.421875,y:.265625},{x:.453125,y:.265625},{x:.453125,y:.265625},{x:.484375,y:.265625},{x:.484375,y:.265625},{x:.515625,y:.265625},{x:.515625,y:.265625},{x:.546875,y:.265625},{x:.546875,y:.265625},{x:.578125,y:.265625},{x:.578125,y:.265625},{x:.609375,y:.265625},{x:.609375,y:.265625},{x:.640625,y:.265625},{x:.640625,y:.265625},{x:.671875,y:.265625},{x:.671875,y:.265625},{x:.703125,y:.265625},{x:.703125,y:.265625},{x:.734375,y:.265625},{x:.734375,y:.265625},{x:.765625,y:.265625},{x:.765625,y:.265625},{x:.796875,y:.265625},{x:.796875,y:.265625},{x:.828125,y:.265625},{x:.828125,y:.265625},{x:.859375,y:.265625},{x:.859375,y:.265625},{x:.890625,y:.265625},{x:.890625,y:.265625},{x:.921875,y:.265625},{x:.921875,y:.265625},{x:.953125,y:.265625},{x:.953125,y:.265625},{x:.984375,y:.265625},{x:.984375,y:.265625},{x:.015625,y:.296875},{x:.015625,y:.296875},{x:.046875,y:.296875},{x:.046875,y:.296875},{x:.078125,y:.296875},{x:.078125,y:.296875},{x:.109375,y:.296875},{x:.109375,y:.296875},{x:.140625,y:.296875},{x:.140625,y:.296875},{x:.171875,y:.296875},{x:.171875,y:.296875},{x:.203125,y:.296875},{x:.203125,y:.296875},{x:.234375,y:.296875},{x:.234375,y:.296875},{x:.265625,y:.296875},{x:.265625,y:.296875},{x:.296875,y:.296875},{x:.296875,y:.296875},{x:.328125,y:.296875},{x:.328125,y:.296875},{x:.359375,y:.296875},{x:.359375,y:.296875},{x:.390625,y:.296875},{x:.390625,y:.296875},{x:.421875,y:.296875},{x:.421875,y:.296875},{x:.453125,y:.296875},{x:.453125,y:.296875},{x:.484375,y:.296875},{x:.484375,y:.296875},{x:.515625,y:.296875},{x:.515625,y:.296875},{x:.546875,y:.296875},{x:.546875,y:.296875},{x:.578125,y:.296875},{x:.578125,y:.296875},{x:.609375,y:.296875},{x:.609375,y:.296875},{x:.640625,y:.296875},{x:.640625,y:.296875},{x:.671875,y:.296875},{x:.671875,y:.296875},{x:.703125,y:.296875},{x:.703125,y:.296875},{x:.734375,y:.296875},{x:.734375,y:.296875},{x:.765625,y:.296875},{x:.765625,y:.296875},{x:.796875,y:.296875},{x:.796875,y:.296875},{x:.828125,y:.296875},{x:.828125,y:.296875},{x:.859375,y:.296875},{x:.859375,y:.296875},{x:.890625,y:.296875},{x:.890625,y:.296875},{x:.921875,y:.296875},{x:.921875,y:.296875},{x:.953125,y:.296875},{x:.953125,y:.296875},{x:.984375,y:.296875},{x:.984375,y:.296875},{x:.015625,y:.328125},{x:.015625,y:.328125},{x:.046875,y:.328125},{x:.046875,y:.328125},{x:.078125,y:.328125},{x:.078125,y:.328125},{x:.109375,y:.328125},{x:.109375,y:.328125},{x:.140625,y:.328125},{x:.140625,y:.328125},{x:.171875,y:.328125},{x:.171875,y:.328125},{x:.203125,y:.328125},{x:.203125,y:.328125},{x:.234375,y:.328125},{x:.234375,y:.328125},{x:.265625,y:.328125},{x:.265625,y:.328125},{x:.296875,y:.328125},{x:.296875,y:.328125},{x:.328125,y:.328125},{x:.328125,y:.328125},{x:.359375,y:.328125},{x:.359375,y:.328125},{x:.390625,y:.328125},{x:.390625,y:.328125},{x:.421875,y:.328125},{x:.421875,y:.328125},{x:.453125,y:.328125},{x:.453125,y:.328125},{x:.484375,y:.328125},{x:.484375,y:.328125},{x:.515625,y:.328125},{x:.515625,y:.328125},{x:.546875,y:.328125},{x:.546875,y:.328125},{x:.578125,y:.328125},{x:.578125,y:.328125},{x:.609375,y:.328125},{x:.609375,y:.328125},{x:.640625,y:.328125},{x:.640625,y:.328125},{x:.671875,y:.328125},{x:.671875,y:.328125},{x:.703125,y:.328125},{x:.703125,y:.328125},{x:.734375,y:.328125},{x:.734375,y:.328125},{x:.765625,y:.328125},{x:.765625,y:.328125},{x:.796875,y:.328125},{x:.796875,y:.328125},{x:.828125,y:.328125},{x:.828125,y:.328125},{x:.859375,y:.328125},{x:.859375,y:.328125},{x:.890625,y:.328125},{x:.890625,y:.328125},{x:.921875,y:.328125},{x:.921875,y:.328125},{x:.953125,y:.328125},{x:.953125,y:.328125},{x:.984375,y:.328125},{x:.984375,y:.328125},{x:.015625,y:.359375},{x:.015625,y:.359375},{x:.046875,y:.359375},{x:.046875,y:.359375},{x:.078125,y:.359375},{x:.078125,y:.359375},{x:.109375,y:.359375},{x:.109375,y:.359375},{x:.140625,y:.359375},{x:.140625,y:.359375},{x:.171875,y:.359375},{x:.171875,y:.359375},{x:.203125,y:.359375},{x:.203125,y:.359375},{x:.234375,y:.359375},{x:.234375,y:.359375},{x:.265625,y:.359375},{x:.265625,y:.359375},{x:.296875,y:.359375},{x:.296875,y:.359375},{x:.328125,y:.359375},{x:.328125,y:.359375},{x:.359375,y:.359375},{x:.359375,y:.359375},{x:.390625,y:.359375},{x:.390625,y:.359375},{x:.421875,y:.359375},{x:.421875,y:.359375},{x:.453125,y:.359375},{x:.453125,y:.359375},{x:.484375,y:.359375},{x:.484375,y:.359375},{x:.515625,y:.359375},{x:.515625,y:.359375},{x:.546875,y:.359375},{x:.546875,y:.359375},{x:.578125,y:.359375},{x:.578125,y:.359375},{x:.609375,y:.359375},{x:.609375,y:.359375},{x:.640625,y:.359375},{x:.640625,y:.359375},{x:.671875,y:.359375},{x:.671875,y:.359375},{x:.703125,y:.359375},{x:.703125,y:.359375},{x:.734375,y:.359375},{x:.734375,y:.359375},{x:.765625,y:.359375},{x:.765625,y:.359375},{x:.796875,y:.359375},{x:.796875,y:.359375},{x:.828125,y:.359375},{x:.828125,y:.359375},{x:.859375,y:.359375},{x:.859375,y:.359375},{x:.890625,y:.359375},{x:.890625,y:.359375},{x:.921875,y:.359375},{x:.921875,y:.359375},{x:.953125,y:.359375},{x:.953125,y:.359375},{x:.984375,y:.359375},{x:.984375,y:.359375},{x:.015625,y:.390625},{x:.015625,y:.390625},{x:.046875,y:.390625},{x:.046875,y:.390625},{x:.078125,y:.390625},{x:.078125,y:.390625},{x:.109375,y:.390625},{x:.109375,y:.390625},{x:.140625,y:.390625},{x:.140625,y:.390625},{x:.171875,y:.390625},{x:.171875,y:.390625},{x:.203125,y:.390625},{x:.203125,y:.390625},{x:.234375,y:.390625},{x:.234375,y:.390625},{x:.265625,y:.390625},{x:.265625,y:.390625},{x:.296875,y:.390625},{x:.296875,y:.390625},{x:.328125,y:.390625},{x:.328125,y:.390625},{x:.359375,y:.390625},{x:.359375,y:.390625},{x:.390625,y:.390625},{x:.390625,y:.390625},{x:.421875,y:.390625},{x:.421875,y:.390625},{x:.453125,y:.390625},{x:.453125,y:.390625},{x:.484375,y:.390625},{x:.484375,y:.390625},{x:.515625,y:.390625},{x:.515625,y:.390625},{x:.546875,y:.390625},{x:.546875,y:.390625},{x:.578125,y:.390625},{x:.578125,y:.390625},{x:.609375,y:.390625},{x:.609375,y:.390625},{x:.640625,y:.390625},{x:.640625,y:.390625},{x:.671875,y:.390625},{x:.671875,y:.390625},{x:.703125,y:.390625},{x:.703125,y:.390625},{x:.734375,y:.390625},{x:.734375,y:.390625},{x:.765625,y:.390625},{x:.765625,y:.390625},{x:.796875,y:.390625},{x:.796875,y:.390625},{x:.828125,y:.390625},{x:.828125,y:.390625},{x:.859375,y:.390625},{x:.859375,y:.390625},{x:.890625,y:.390625},{x:.890625,y:.390625},{x:.921875,y:.390625},{x:.921875,y:.390625},{x:.953125,y:.390625},{x:.953125,y:.390625},{x:.984375,y:.390625},{x:.984375,y:.390625},{x:.015625,y:.421875},{x:.015625,y:.421875},{x:.046875,y:.421875},{x:.046875,y:.421875},{x:.078125,y:.421875},{x:.078125,y:.421875},{x:.109375,y:.421875},{x:.109375,y:.421875},{x:.140625,y:.421875},{x:.140625,y:.421875},{x:.171875,y:.421875},{x:.171875,y:.421875},{x:.203125,y:.421875},{x:.203125,y:.421875},{x:.234375,y:.421875},{x:.234375,y:.421875},{x:.265625,y:.421875},{x:.265625,y:.421875},{x:.296875,y:.421875},{x:.296875,y:.421875},{x:.328125,y:.421875},{x:.328125,y:.421875},{x:.359375,y:.421875},{x:.359375,y:.421875},{x:.390625,y:.421875},{x:.390625,y:.421875},{x:.421875,y:.421875},{x:.421875,y:.421875},{x:.453125,y:.421875},{x:.453125,y:.421875},{x:.484375,y:.421875},{x:.484375,y:.421875},{x:.515625,y:.421875},{x:.515625,y:.421875},{x:.546875,y:.421875},{x:.546875,y:.421875},{x:.578125,y:.421875},{x:.578125,y:.421875},{x:.609375,y:.421875},{x:.609375,y:.421875},{x:.640625,y:.421875},{x:.640625,y:.421875},{x:.671875,y:.421875},{x:.671875,y:.421875},{x:.703125,y:.421875},{x:.703125,y:.421875},{x:.734375,y:.421875},{x:.734375,y:.421875},{x:.765625,y:.421875},{x:.765625,y:.421875},{x:.796875,y:.421875},{x:.796875,y:.421875},{x:.828125,y:.421875},{x:.828125,y:.421875},{x:.859375,y:.421875},{x:.859375,y:.421875},{x:.890625,y:.421875},{x:.890625,y:.421875},{x:.921875,y:.421875},{x:.921875,y:.421875},{x:.953125,y:.421875},{x:.953125,y:.421875},{x:.984375,y:.421875},{x:.984375,y:.421875},{x:.015625,y:.453125},{x:.015625,y:.453125},{x:.046875,y:.453125},{x:.046875,y:.453125},{x:.078125,y:.453125},{x:.078125,y:.453125},{x:.109375,y:.453125},{x:.109375,y:.453125},{x:.140625,y:.453125},{x:.140625,y:.453125},{x:.171875,y:.453125},{x:.171875,y:.453125},{x:.203125,y:.453125},{x:.203125,y:.453125},{x:.234375,y:.453125},{x:.234375,y:.453125},{x:.265625,y:.453125},{x:.265625,y:.453125},{x:.296875,y:.453125},{x:.296875,y:.453125},{x:.328125,y:.453125},{x:.328125,y:.453125},{x:.359375,y:.453125},{x:.359375,y:.453125},{x:.390625,y:.453125},{x:.390625,y:.453125},{x:.421875,y:.453125},{x:.421875,y:.453125},{x:.453125,y:.453125},{x:.453125,y:.453125},{x:.484375,y:.453125},{x:.484375,y:.453125},{x:.515625,y:.453125},{x:.515625,y:.453125},{x:.546875,y:.453125},{x:.546875,y:.453125},{x:.578125,y:.453125},{x:.578125,y:.453125},{x:.609375,y:.453125},{x:.609375,y:.453125},{x:.640625,y:.453125},{x:.640625,y:.453125},{x:.671875,y:.453125},{x:.671875,y:.453125},{x:.703125,y:.453125},{x:.703125,y:.453125},{x:.734375,y:.453125},{x:.734375,y:.453125},{x:.765625,y:.453125},{x:.765625,y:.453125},{x:.796875,y:.453125},{x:.796875,y:.453125},{x:.828125,y:.453125},{x:.828125,y:.453125},{x:.859375,y:.453125},{x:.859375,y:.453125},{x:.890625,y:.453125},{x:.890625,y:.453125},{x:.921875,y:.453125},{x:.921875,y:.453125},{x:.953125,y:.453125},{x:.953125,y:.453125},{x:.984375,y:.453125},{x:.984375,y:.453125},{x:.015625,y:.484375},{x:.015625,y:.484375},{x:.046875,y:.484375},{x:.046875,y:.484375},{x:.078125,y:.484375},{x:.078125,y:.484375},{x:.109375,y:.484375},{x:.109375,y:.484375},{x:.140625,y:.484375},{x:.140625,y:.484375},{x:.171875,y:.484375},{x:.171875,y:.484375},{x:.203125,y:.484375},{x:.203125,y:.484375},{x:.234375,y:.484375},{x:.234375,y:.484375},{x:.265625,y:.484375},{x:.265625,y:.484375},{x:.296875,y:.484375},{x:.296875,y:.484375},{x:.328125,y:.484375},{x:.328125,y:.484375},{x:.359375,y:.484375},{x:.359375,y:.484375},{x:.390625,y:.484375},{x:.390625,y:.484375},{x:.421875,y:.484375},{x:.421875,y:.484375},{x:.453125,y:.484375},{x:.453125,y:.484375},{x:.484375,y:.484375},{x:.484375,y:.484375},{x:.515625,y:.484375},{x:.515625,y:.484375},{x:.546875,y:.484375},{x:.546875,y:.484375},{x:.578125,y:.484375},{x:.578125,y:.484375},{x:.609375,y:.484375},{x:.609375,y:.484375},{x:.640625,y:.484375},{x:.640625,y:.484375},{x:.671875,y:.484375},{x:.671875,y:.484375},{x:.703125,y:.484375},{x:.703125,y:.484375},{x:.734375,y:.484375},{x:.734375,y:.484375},{x:.765625,y:.484375},{x:.765625,y:.484375},{x:.796875,y:.484375},{x:.796875,y:.484375},{x:.828125,y:.484375},{x:.828125,y:.484375},{x:.859375,y:.484375},{x:.859375,y:.484375},{x:.890625,y:.484375},{x:.890625,y:.484375},{x:.921875,y:.484375},{x:.921875,y:.484375},{x:.953125,y:.484375},{x:.953125,y:.484375},{x:.984375,y:.484375},{x:.984375,y:.484375},{x:.015625,y:.515625},{x:.015625,y:.515625},{x:.046875,y:.515625},{x:.046875,y:.515625},{x:.078125,y:.515625},{x:.078125,y:.515625},{x:.109375,y:.515625},{x:.109375,y:.515625},{x:.140625,y:.515625},{x:.140625,y:.515625},{x:.171875,y:.515625},{x:.171875,y:.515625},{x:.203125,y:.515625},{x:.203125,y:.515625},{x:.234375,y:.515625},{x:.234375,y:.515625},{x:.265625,y:.515625},{x:.265625,y:.515625},{x:.296875,y:.515625},{x:.296875,y:.515625},{x:.328125,y:.515625},{x:.328125,y:.515625},{x:.359375,y:.515625},{x:.359375,y:.515625},{x:.390625,y:.515625},{x:.390625,y:.515625},{x:.421875,y:.515625},{x:.421875,y:.515625},{x:.453125,y:.515625},{x:.453125,y:.515625},{x:.484375,y:.515625},{x:.484375,y:.515625},{x:.515625,y:.515625},{x:.515625,y:.515625},{x:.546875,y:.515625},{x:.546875,y:.515625},{x:.578125,y:.515625},{x:.578125,y:.515625},{x:.609375,y:.515625},{x:.609375,y:.515625},{x:.640625,y:.515625},{x:.640625,y:.515625},{x:.671875,y:.515625},{x:.671875,y:.515625},{x:.703125,y:.515625},{x:.703125,y:.515625},{x:.734375,y:.515625},{x:.734375,y:.515625},{x:.765625,y:.515625},{x:.765625,y:.515625},{x:.796875,y:.515625},{x:.796875,y:.515625},{x:.828125,y:.515625},{x:.828125,y:.515625},{x:.859375,y:.515625},{x:.859375,y:.515625},{x:.890625,y:.515625},{x:.890625,y:.515625},{x:.921875,y:.515625},{x:.921875,y:.515625},{x:.953125,y:.515625},{x:.953125,y:.515625},{x:.984375,y:.515625},{x:.984375,y:.515625},{x:.015625,y:.546875},{x:.015625,y:.546875},{x:.046875,y:.546875},{x:.046875,y:.546875},{x:.078125,y:.546875},{x:.078125,y:.546875},{x:.109375,y:.546875},{x:.109375,y:.546875},{x:.140625,y:.546875},{x:.140625,y:.546875},{x:.171875,y:.546875},{x:.171875,y:.546875},{x:.203125,y:.546875},{x:.203125,y:.546875},{x:.234375,y:.546875},{x:.234375,y:.546875},{x:.265625,y:.546875},{x:.265625,y:.546875},{x:.296875,y:.546875},{x:.296875,y:.546875},{x:.328125,y:.546875},{x:.328125,y:.546875},{x:.359375,y:.546875},{x:.359375,y:.546875},{x:.390625,y:.546875},{x:.390625,y:.546875},{x:.421875,y:.546875},{x:.421875,y:.546875},{x:.453125,y:.546875},{x:.453125,y:.546875},{x:.484375,y:.546875},{x:.484375,y:.546875},{x:.515625,y:.546875},{x:.515625,y:.546875},{x:.546875,y:.546875},{x:.546875,y:.546875},{x:.578125,y:.546875},{x:.578125,y:.546875},{x:.609375,y:.546875},{x:.609375,y:.546875},{x:.640625,y:.546875},{x:.640625,y:.546875},{x:.671875,y:.546875},{x:.671875,y:.546875},{x:.703125,y:.546875},{x:.703125,y:.546875},{x:.734375,y:.546875},{x:.734375,y:.546875},{x:.765625,y:.546875},{x:.765625,y:.546875},{x:.796875,y:.546875},{x:.796875,y:.546875},{x:.828125,y:.546875},{x:.828125,y:.546875},{x:.859375,y:.546875},{x:.859375,y:.546875},{x:.890625,y:.546875},{x:.890625,y:.546875},{x:.921875,y:.546875},{x:.921875,y:.546875},{x:.953125,y:.546875},{x:.953125,y:.546875},{x:.984375,y:.546875},{x:.984375,y:.546875},{x:.015625,y:.578125},{x:.015625,y:.578125},{x:.046875,y:.578125},{x:.046875,y:.578125},{x:.078125,y:.578125},{x:.078125,y:.578125},{x:.109375,y:.578125},{x:.109375,y:.578125},{x:.140625,y:.578125},{x:.140625,y:.578125},{x:.171875,y:.578125},{x:.171875,y:.578125},{x:.203125,y:.578125},{x:.203125,y:.578125},{x:.234375,y:.578125},{x:.234375,y:.578125},{x:.265625,y:.578125},{x:.265625,y:.578125},{x:.296875,y:.578125},{x:.296875,y:.578125},{x:.328125,y:.578125},{x:.328125,y:.578125},{x:.359375,y:.578125},{x:.359375,y:.578125},{x:.390625,y:.578125},{x:.390625,y:.578125},{x:.421875,y:.578125},{x:.421875,y:.578125},{x:.453125,y:.578125},{x:.453125,y:.578125},{x:.484375,y:.578125},{x:.484375,y:.578125},{x:.515625,y:.578125},{x:.515625,y:.578125},{x:.546875,y:.578125},{x:.546875,y:.578125},{x:.578125,y:.578125},{x:.578125,y:.578125},{x:.609375,y:.578125},{x:.609375,y:.578125},{x:.640625,y:.578125},{x:.640625,y:.578125},{x:.671875,y:.578125},{x:.671875,y:.578125},{x:.703125,y:.578125},{x:.703125,y:.578125},{x:.734375,y:.578125},{x:.734375,y:.578125},{x:.765625,y:.578125},{x:.765625,y:.578125},{x:.796875,y:.578125},{x:.796875,y:.578125},{x:.828125,y:.578125},{x:.828125,y:.578125},{x:.859375,y:.578125},{x:.859375,y:.578125},{x:.890625,y:.578125},{x:.890625,y:.578125},{x:.921875,y:.578125},{x:.921875,y:.578125},{x:.953125,y:.578125},{x:.953125,y:.578125},{x:.984375,y:.578125},{x:.984375,y:.578125},{x:.015625,y:.609375},{x:.015625,y:.609375},{x:.046875,y:.609375},{x:.046875,y:.609375},{x:.078125,y:.609375},{x:.078125,y:.609375},{x:.109375,y:.609375},{x:.109375,y:.609375},{x:.140625,y:.609375},{x:.140625,y:.609375},{x:.171875,y:.609375},{x:.171875,y:.609375},{x:.203125,y:.609375},{x:.203125,y:.609375},{x:.234375,y:.609375},{x:.234375,y:.609375},{x:.265625,y:.609375},{x:.265625,y:.609375},{x:.296875,y:.609375},{x:.296875,y:.609375},{x:.328125,y:.609375},{x:.328125,y:.609375},{x:.359375,y:.609375},{x:.359375,y:.609375},{x:.390625,y:.609375},{x:.390625,y:.609375},{x:.421875,y:.609375},{x:.421875,y:.609375},{x:.453125,y:.609375},{x:.453125,y:.609375},{x:.484375,y:.609375},{x:.484375,y:.609375},{x:.515625,y:.609375},{x:.515625,y:.609375},{x:.546875,y:.609375},{x:.546875,y:.609375},{x:.578125,y:.609375},{x:.578125,y:.609375},{x:.609375,y:.609375},{x:.609375,y:.609375},{x:.640625,y:.609375},{x:.640625,y:.609375},{x:.671875,y:.609375},{x:.671875,y:.609375},{x:.703125,y:.609375},{x:.703125,y:.609375},{x:.734375,y:.609375},{x:.734375,y:.609375},{x:.765625,y:.609375},{x:.765625,y:.609375},{x:.796875,y:.609375},{x:.796875,y:.609375},{x:.828125,y:.609375},{x:.828125,y:.609375},{x:.859375,y:.609375},{x:.859375,y:.609375},{x:.890625,y:.609375},{x:.890625,y:.609375},{x:.921875,y:.609375},{x:.921875,y:.609375},{x:.953125,y:.609375},{x:.953125,y:.609375},{x:.984375,y:.609375},{x:.984375,y:.609375},{x:.015625,y:.640625},{x:.015625,y:.640625},{x:.046875,y:.640625},{x:.046875,y:.640625},{x:.078125,y:.640625},{x:.078125,y:.640625},{x:.109375,y:.640625},{x:.109375,y:.640625},{x:.140625,y:.640625},{x:.140625,y:.640625},{x:.171875,y:.640625},{x:.171875,y:.640625},{x:.203125,y:.640625},{x:.203125,y:.640625},{x:.234375,y:.640625},{x:.234375,y:.640625},{x:.265625,y:.640625},{x:.265625,y:.640625},{x:.296875,y:.640625},{x:.296875,y:.640625},{x:.328125,y:.640625},{x:.328125,y:.640625},{x:.359375,y:.640625},{x:.359375,y:.640625},{x:.390625,y:.640625},{x:.390625,y:.640625},{x:.421875,y:.640625},{x:.421875,y:.640625},{x:.453125,y:.640625},{x:.453125,y:.640625},{x:.484375,y:.640625},{x:.484375,y:.640625},{x:.515625,y:.640625},{x:.515625,y:.640625},{x:.546875,y:.640625},{x:.546875,y:.640625},{x:.578125,y:.640625},{x:.578125,y:.640625},{x:.609375,y:.640625},{x:.609375,y:.640625},{x:.640625,y:.640625},{x:.640625,y:.640625},{x:.671875,y:.640625},{x:.671875,y:.640625},{x:.703125,y:.640625},{x:.703125,y:.640625},{x:.734375,y:.640625},{x:.734375,y:.640625},{x:.765625,y:.640625},{x:.765625,y:.640625},{x:.796875,y:.640625},{x:.796875,y:.640625},{x:.828125,y:.640625},{x:.828125,y:.640625},{x:.859375,y:.640625},{x:.859375,y:.640625},{x:.890625,y:.640625},{x:.890625,y:.640625},{x:.921875,y:.640625},{x:.921875,y:.640625},{x:.953125,y:.640625},{x:.953125,y:.640625},{x:.984375,y:.640625},{x:.984375,y:.640625},{x:.015625,y:.671875},{x:.015625,y:.671875},{x:.046875,y:.671875},{x:.046875,y:.671875},{x:.078125,y:.671875},{x:.078125,y:.671875},{x:.109375,y:.671875},{x:.109375,y:.671875},{x:.140625,y:.671875},{x:.140625,y:.671875},{x:.171875,y:.671875},{x:.171875,y:.671875},{x:.203125,y:.671875},{x:.203125,y:.671875},{x:.234375,y:.671875},{x:.234375,y:.671875},{x:.265625,y:.671875},{x:.265625,y:.671875},{x:.296875,y:.671875},{x:.296875,y:.671875},{x:.328125,y:.671875},{x:.328125,y:.671875},{x:.359375,y:.671875},{x:.359375,y:.671875},{x:.390625,y:.671875},{x:.390625,y:.671875},{x:.421875,y:.671875},{x:.421875,y:.671875},{x:.453125,y:.671875},{x:.453125,y:.671875},{x:.484375,y:.671875},{x:.484375,y:.671875},{x:.515625,y:.671875},{x:.515625,y:.671875},{x:.546875,y:.671875},{x:.546875,y:.671875},{x:.578125,y:.671875},{x:.578125,y:.671875},{x:.609375,y:.671875},{x:.609375,y:.671875},{x:.640625,y:.671875},{x:.640625,y:.671875},{x:.671875,y:.671875},{x:.671875,y:.671875},{x:.703125,y:.671875},{x:.703125,y:.671875},{x:.734375,y:.671875},{x:.734375,y:.671875},{x:.765625,y:.671875},{x:.765625,y:.671875},{x:.796875,y:.671875},{x:.796875,y:.671875},{x:.828125,y:.671875},{x:.828125,y:.671875},{x:.859375,y:.671875},{x:.859375,y:.671875},{x:.890625,y:.671875},{x:.890625,y:.671875},{x:.921875,y:.671875},{x:.921875,y:.671875},{x:.953125,y:.671875},{x:.953125,y:.671875},{x:.984375,y:.671875},{x:.984375,y:.671875},{x:.015625,y:.703125},{x:.015625,y:.703125},{x:.046875,y:.703125},{x:.046875,y:.703125},{x:.078125,y:.703125},{x:.078125,y:.703125},{x:.109375,y:.703125},{x:.109375,y:.703125},{x:.140625,y:.703125},{x:.140625,y:.703125},{x:.171875,y:.703125},{x:.171875,y:.703125},{x:.203125,y:.703125},{x:.203125,y:.703125},{x:.234375,y:.703125},{x:.234375,y:.703125},{x:.265625,y:.703125},{x:.265625,y:.703125},{x:.296875,y:.703125},{x:.296875,y:.703125},{x:.328125,y:.703125},{x:.328125,y:.703125},{x:.359375,y:.703125},{x:.359375,y:.703125},{x:.390625,y:.703125},{x:.390625,y:.703125},{x:.421875,y:.703125},{x:.421875,y:.703125},{x:.453125,y:.703125},{x:.453125,y:.703125},{x:.484375,y:.703125},{x:.484375,y:.703125},{x:.515625,y:.703125},{x:.515625,y:.703125},{x:.546875,y:.703125},{x:.546875,y:.703125},{x:.578125,y:.703125},{x:.578125,y:.703125},{x:.609375,y:.703125},{x:.609375,y:.703125},{x:.640625,y:.703125},{x:.640625,y:.703125},{x:.671875,y:.703125},{x:.671875,y:.703125},{x:.703125,y:.703125},{x:.703125,y:.703125},{x:.734375,y:.703125},{x:.734375,y:.703125},{x:.765625,y:.703125},{x:.765625,y:.703125},{x:.796875,y:.703125},{x:.796875,y:.703125},{x:.828125,y:.703125},{x:.828125,y:.703125},{x:.859375,y:.703125},{x:.859375,y:.703125},{x:.890625,y:.703125},{x:.890625,y:.703125},{x:.921875,y:.703125},{x:.921875,y:.703125},{x:.953125,y:.703125},{x:.953125,y:.703125},{x:.984375,y:.703125},{x:.984375,y:.703125},{x:.015625,y:.734375},{x:.015625,y:.734375},{x:.046875,y:.734375},{x:.046875,y:.734375},{x:.078125,y:.734375},{x:.078125,y:.734375},{x:.109375,y:.734375},{x:.109375,y:.734375},{x:.140625,y:.734375},{x:.140625,y:.734375},{x:.171875,y:.734375},{x:.171875,y:.734375},{x:.203125,y:.734375},{x:.203125,y:.734375},{x:.234375,y:.734375},{x:.234375,y:.734375},{x:.265625,y:.734375},{x:.265625,y:.734375},{x:.296875,y:.734375},{x:.296875,y:.734375},{x:.328125,y:.734375},{x:.328125,y:.734375},{x:.359375,y:.734375},{x:.359375,y:.734375},{x:.390625,y:.734375},{x:.390625,y:.734375},{x:.421875,y:.734375},{x:.421875,y:.734375},{x:.453125,y:.734375},{x:.453125,y:.734375},{x:.484375,y:.734375},{x:.484375,y:.734375},{x:.515625,y:.734375},{x:.515625,y:.734375},{x:.546875,y:.734375},{x:.546875,y:.734375},{x:.578125,y:.734375},{x:.578125,y:.734375},{x:.609375,y:.734375},{x:.609375,y:.734375},{x:.640625,y:.734375},{x:.640625,y:.734375},{x:.671875,y:.734375},{x:.671875,y:.734375},{x:.703125,y:.734375},{x:.703125,y:.734375},{x:.734375,y:.734375},{x:.734375,y:.734375},{x:.765625,y:.734375},{x:.765625,y:.734375},{x:.796875,y:.734375},{x:.796875,y:.734375},{x:.828125,y:.734375},{x:.828125,y:.734375},{x:.859375,y:.734375},{x:.859375,y:.734375},{x:.890625,y:.734375},{x:.890625,y:.734375},{x:.921875,y:.734375},{x:.921875,y:.734375},{x:.953125,y:.734375},{x:.953125,y:.734375},{x:.984375,y:.734375},{x:.984375,y:.734375},{x:.015625,y:.765625},{x:.015625,y:.765625},{x:.046875,y:.765625},{x:.046875,y:.765625},{x:.078125,y:.765625},{x:.078125,y:.765625},{x:.109375,y:.765625},{x:.109375,y:.765625},{x:.140625,y:.765625},{x:.140625,y:.765625},{x:.171875,y:.765625},{x:.171875,y:.765625},{x:.203125,y:.765625},{x:.203125,y:.765625},{x:.234375,y:.765625},{x:.234375,y:.765625},{x:.265625,y:.765625},{x:.265625,y:.765625},{x:.296875,y:.765625},{x:.296875,y:.765625},{x:.328125,y:.765625},{x:.328125,y:.765625},{x:.359375,y:.765625},{x:.359375,y:.765625},{x:.390625,y:.765625},{x:.390625,y:.765625},{x:.421875,y:.765625},{x:.421875,y:.765625},{x:.453125,y:.765625},{x:.453125,y:.765625},{x:.484375,y:.765625},{x:.484375,y:.765625},{x:.515625,y:.765625},{x:.515625,y:.765625},{x:.546875,y:.765625},{x:.546875,y:.765625},{x:.578125,y:.765625},{x:.578125,y:.765625},{x:.609375,y:.765625},{x:.609375,y:.765625},{x:.640625,y:.765625},{x:.640625,y:.765625},{x:.671875,y:.765625},{x:.671875,y:.765625},{x:.703125,y:.765625},{x:.703125,y:.765625},{x:.734375,y:.765625},{x:.734375,y:.765625},{x:.765625,y:.765625},{x:.765625,y:.765625},{x:.796875,y:.765625},{x:.796875,y:.765625},{x:.828125,y:.765625},{x:.828125,y:.765625},{x:.859375,y:.765625},{x:.859375,y:.765625},{x:.890625,y:.765625},{x:.890625,y:.765625},{x:.921875,y:.765625},{x:.921875,y:.765625},{x:.953125,y:.765625},{x:.953125,y:.765625},{x:.984375,y:.765625},{x:.984375,y:.765625},{x:.015625,y:.796875},{x:.015625,y:.796875},{x:.046875,y:.796875},{x:.046875,y:.796875},{x:.078125,y:.796875},{x:.078125,y:.796875},{x:.109375,y:.796875},{x:.109375,y:.796875},{x:.140625,y:.796875},{x:.140625,y:.796875},{x:.171875,y:.796875},{x:.171875,y:.796875},{x:.203125,y:.796875},{x:.203125,y:.796875},{x:.234375,y:.796875},{x:.234375,y:.796875},{x:.265625,y:.796875},{x:.265625,y:.796875},{x:.296875,y:.796875},{x:.296875,y:.796875},{x:.328125,y:.796875},{x:.328125,y:.796875},{x:.359375,y:.796875},{x:.359375,y:.796875},{x:.390625,y:.796875},{x:.390625,y:.796875},{x:.421875,y:.796875},{x:.421875,y:.796875},{x:.453125,y:.796875},{x:.453125,y:.796875},{x:.484375,y:.796875},{x:.484375,y:.796875},{x:.515625,y:.796875},{x:.515625,y:.796875},{x:.546875,y:.796875},{x:.546875,y:.796875},{x:.578125,y:.796875},{x:.578125,y:.796875},{x:.609375,y:.796875},{x:.609375,y:.796875},{x:.640625,y:.796875},{x:.640625,y:.796875},{x:.671875,y:.796875},{x:.671875,y:.796875},{x:.703125,y:.796875},{x:.703125,y:.796875},{x:.734375,y:.796875},{x:.734375,y:.796875},{x:.765625,y:.796875},{x:.765625,y:.796875},{x:.796875,y:.796875},{x:.796875,y:.796875},{x:.828125,y:.796875},{x:.828125,y:.796875},{x:.859375,y:.796875},{x:.859375,y:.796875},{x:.890625,y:.796875},{x:.890625,y:.796875},{x:.921875,y:.796875},{x:.921875,y:.796875},{x:.953125,y:.796875},{x:.953125,y:.796875},{x:.984375,y:.796875},{x:.984375,y:.796875},{x:.015625,y:.828125},{x:.015625,y:.828125},{x:.046875,y:.828125},{x:.046875,y:.828125},{x:.078125,y:.828125},{x:.078125,y:.828125},{x:.109375,y:.828125},{x:.109375,y:.828125},{x:.140625,y:.828125},{x:.140625,y:.828125},{x:.171875,y:.828125},{x:.171875,y:.828125},{x:.203125,y:.828125},{x:.203125,y:.828125},{x:.234375,y:.828125},{x:.234375,y:.828125},{x:.265625,y:.828125},{x:.265625,y:.828125},{x:.296875,y:.828125},{x:.296875,y:.828125},{x:.328125,y:.828125},{x:.328125,y:.828125},{x:.359375,y:.828125},{x:.359375,y:.828125},{x:.390625,y:.828125},{x:.390625,y:.828125},{x:.421875,y:.828125},{x:.421875,y:.828125},{x:.453125,y:.828125},{x:.453125,y:.828125},{x:.484375,y:.828125},{x:.484375,y:.828125},{x:.515625,y:.828125},{x:.515625,y:.828125},{x:.546875,y:.828125},{x:.546875,y:.828125},{x:.578125,y:.828125},{x:.578125,y:.828125},{x:.609375,y:.828125},{x:.609375,y:.828125},{x:.640625,y:.828125},{x:.640625,y:.828125},{x:.671875,y:.828125},{x:.671875,y:.828125},{x:.703125,y:.828125},{x:.703125,y:.828125},{x:.734375,y:.828125},{x:.734375,y:.828125},{x:.765625,y:.828125},{x:.765625,y:.828125},{x:.796875,y:.828125},{x:.796875,y:.828125},{x:.828125,y:.828125},{x:.828125,y:.828125},{x:.859375,y:.828125},{x:.859375,y:.828125},{x:.890625,y:.828125},{x:.890625,y:.828125},{x:.921875,y:.828125},{x:.921875,y:.828125},{x:.953125,y:.828125},{x:.953125,y:.828125},{x:.984375,y:.828125},{x:.984375,y:.828125},{x:.015625,y:.859375},{x:.015625,y:.859375},{x:.046875,y:.859375},{x:.046875,y:.859375},{x:.078125,y:.859375},{x:.078125,y:.859375},{x:.109375,y:.859375},{x:.109375,y:.859375},{x:.140625,y:.859375},{x:.140625,y:.859375},{x:.171875,y:.859375},{x:.171875,y:.859375},{x:.203125,y:.859375},{x:.203125,y:.859375},{x:.234375,y:.859375},{x:.234375,y:.859375},{x:.265625,y:.859375},{x:.265625,y:.859375},{x:.296875,y:.859375},{x:.296875,y:.859375},{x:.328125,y:.859375},{x:.328125,y:.859375},{x:.359375,y:.859375},{x:.359375,y:.859375},{x:.390625,y:.859375},{x:.390625,y:.859375},{x:.421875,y:.859375},{x:.421875,y:.859375},{x:.453125,y:.859375},{x:.453125,y:.859375},{x:.484375,y:.859375},{x:.484375,y:.859375},{x:.515625,y:.859375},{x:.515625,y:.859375},{x:.546875,y:.859375},{x:.546875,y:.859375},{x:.578125,y:.859375},{x:.578125,y:.859375},{x:.609375,y:.859375},{x:.609375,y:.859375},{x:.640625,y:.859375},{x:.640625,y:.859375},{x:.671875,y:.859375},{x:.671875,y:.859375},{x:.703125,y:.859375},{x:.703125,y:.859375},{x:.734375,y:.859375},{x:.734375,y:.859375},{x:.765625,y:.859375},{x:.765625,y:.859375},{x:.796875,y:.859375},{x:.796875,y:.859375},{x:.828125,y:.859375},{x:.828125,y:.859375},{x:.859375,y:.859375},{x:.859375,y:.859375},{x:.890625,y:.859375},{x:.890625,y:.859375},{x:.921875,y:.859375},{x:.921875,y:.859375},{x:.953125,y:.859375},{x:.953125,y:.859375},{x:.984375,y:.859375},{x:.984375,y:.859375},{x:.015625,y:.890625},{x:.015625,y:.890625},{x:.046875,y:.890625},{x:.046875,y:.890625},{x:.078125,y:.890625},{x:.078125,y:.890625},{x:.109375,y:.890625},{x:.109375,y:.890625},{x:.140625,y:.890625},{x:.140625,y:.890625},{x:.171875,y:.890625},{x:.171875,y:.890625},{x:.203125,y:.890625},{x:.203125,y:.890625},{x:.234375,y:.890625},{x:.234375,y:.890625},{x:.265625,y:.890625},{x:.265625,y:.890625},{x:.296875,y:.890625},{x:.296875,y:.890625},{x:.328125,y:.890625},{x:.328125,y:.890625},{x:.359375,y:.890625},{x:.359375,y:.890625},{x:.390625,y:.890625},{x:.390625,y:.890625},{x:.421875,y:.890625},{x:.421875,y:.890625},{x:.453125,y:.890625},{x:.453125,y:.890625},{x:.484375,y:.890625},{x:.484375,y:.890625},{x:.515625,y:.890625},{x:.515625,y:.890625},{x:.546875,y:.890625},{x:.546875,y:.890625},{x:.578125,y:.890625},{x:.578125,y:.890625},{x:.609375,y:.890625},{x:.609375,y:.890625},{x:.640625,y:.890625},{x:.640625,y:.890625},{x:.671875,y:.890625},{x:.671875,y:.890625},{x:.703125,y:.890625},{x:.703125,y:.890625},{x:.734375,y:.890625},{x:.734375,y:.890625},{x:.765625,y:.890625},{x:.765625,y:.890625},{x:.796875,y:.890625},{x:.796875,y:.890625},{x:.828125,y:.890625},{x:.828125,y:.890625},{x:.859375,y:.890625},{x:.859375,y:.890625},{x:.890625,y:.890625},{x:.890625,y:.890625},{x:.921875,y:.890625},{x:.921875,y:.890625},{x:.953125,y:.890625},{x:.953125,y:.890625},{x:.984375,y:.890625},{x:.984375,y:.890625},{x:.015625,y:.921875},{x:.015625,y:.921875},{x:.046875,y:.921875},{x:.046875,y:.921875},{x:.078125,y:.921875},{x:.078125,y:.921875},{x:.109375,y:.921875},{x:.109375,y:.921875},{x:.140625,y:.921875},{x:.140625,y:.921875},{x:.171875,y:.921875},{x:.171875,y:.921875},{x:.203125,y:.921875},{x:.203125,y:.921875},{x:.234375,y:.921875},{x:.234375,y:.921875},{x:.265625,y:.921875},{x:.265625,y:.921875},{x:.296875,y:.921875},{x:.296875,y:.921875},{x:.328125,y:.921875},{x:.328125,y:.921875},{x:.359375,y:.921875},{x:.359375,y:.921875},{x:.390625,y:.921875},{x:.390625,y:.921875},{x:.421875,y:.921875},{x:.421875,y:.921875},{x:.453125,y:.921875},{x:.453125,y:.921875},{x:.484375,y:.921875},{x:.484375,y:.921875},{x:.515625,y:.921875},{x:.515625,y:.921875},{x:.546875,y:.921875},{x:.546875,y:.921875},{x:.578125,y:.921875},{x:.578125,y:.921875},{x:.609375,y:.921875},{x:.609375,y:.921875},{x:.640625,y:.921875},{x:.640625,y:.921875},{x:.671875,y:.921875},{x:.671875,y:.921875},{x:.703125,y:.921875},{x:.703125,y:.921875},{x:.734375,y:.921875},{x:.734375,y:.921875},{x:.765625,y:.921875},{x:.765625,y:.921875},{x:.796875,y:.921875},{x:.796875,y:.921875},{x:.828125,y:.921875},{x:.828125,y:.921875},{x:.859375,y:.921875},{x:.859375,y:.921875},{x:.890625,y:.921875},{x:.890625,y:.921875},{x:.921875,y:.921875},{x:.921875,y:.921875},{x:.953125,y:.921875},{x:.953125,y:.921875},{x:.984375,y:.921875},{x:.984375,y:.921875},{x:.015625,y:.953125},{x:.015625,y:.953125},{x:.046875,y:.953125},{x:.046875,y:.953125},{x:.078125,y:.953125},{x:.078125,y:.953125},{x:.109375,y:.953125},{x:.109375,y:.953125},{x:.140625,y:.953125},{x:.140625,y:.953125},{x:.171875,y:.953125},{x:.171875,y:.953125},{x:.203125,y:.953125},{x:.203125,y:.953125},{x:.234375,y:.953125},{x:.234375,y:.953125},{x:.265625,y:.953125},{x:.265625,y:.953125},{x:.296875,y:.953125},{x:.296875,y:.953125},{x:.328125,y:.953125},{x:.328125,y:.953125},{x:.359375,y:.953125},{x:.359375,y:.953125},{x:.390625,y:.953125},{x:.390625,y:.953125},{x:.421875,y:.953125},{x:.421875,y:.953125},{x:.453125,y:.953125},{x:.453125,y:.953125},{x:.484375,y:.953125},{x:.484375,y:.953125},{x:.515625,y:.953125},{x:.515625,y:.953125},{x:.546875,y:.953125},{x:.546875,y:.953125},{x:.578125,y:.953125},{x:.578125,y:.953125},{x:.609375,y:.953125},{x:.609375,y:.953125},{x:.640625,y:.953125},{x:.640625,y:.953125},{x:.671875,y:.953125},{x:.671875,y:.953125},{x:.703125,y:.953125},{x:.703125,y:.953125},{x:.734375,y:.953125},{x:.734375,y:.953125},{x:.765625,y:.953125},{x:.765625,y:.953125},{x:.796875,y:.953125},{x:.796875,y:.953125},{x:.828125,y:.953125},{x:.828125,y:.953125},{x:.859375,y:.953125},{x:.859375,y:.953125},{x:.890625,y:.953125},{x:.890625,y:.953125},{x:.921875,y:.953125},{x:.921875,y:.953125},{x:.953125,y:.953125},{x:.953125,y:.953125},{x:.984375,y:.953125},{x:.984375,y:.953125},{x:.015625,y:.984375},{x:.015625,y:.984375},{x:.046875,y:.984375},{x:.046875,y:.984375},{x:.078125,y:.984375},{x:.078125,y:.984375},{x:.109375,y:.984375},{x:.109375,y:.984375},{x:.140625,y:.984375},{x:.140625,y:.984375},{x:.171875,y:.984375},{x:.171875,y:.984375},{x:.203125,y:.984375},{x:.203125,y:.984375},{x:.234375,y:.984375},{x:.234375,y:.984375},{x:.265625,y:.984375},{x:.265625,y:.984375},{x:.296875,y:.984375},{x:.296875,y:.984375},{x:.328125,y:.984375},{x:.328125,y:.984375},{x:.359375,y:.984375},{x:.359375,y:.984375},{x:.390625,y:.984375},{x:.390625,y:.984375},{x:.421875,y:.984375},{x:.421875,y:.984375},{x:.453125,y:.984375},{x:.453125,y:.984375},{x:.484375,y:.984375},{x:.484375,y:.984375},{x:.515625,y:.984375},{x:.515625,y:.984375},{x:.546875,y:.984375},{x:.546875,y:.984375},{x:.578125,y:.984375},{x:.578125,y:.984375},{x:.609375,y:.984375},{x:.609375,y:.984375},{x:.640625,y:.984375},{x:.640625,y:.984375},{x:.671875,y:.984375},{x:.671875,y:.984375},{x:.703125,y:.984375},{x:.703125,y:.984375},{x:.734375,y:.984375},{x:.734375,y:.984375},{x:.765625,y:.984375},{x:.765625,y:.984375},{x:.796875,y:.984375},{x:.796875,y:.984375},{x:.828125,y:.984375},{x:.828125,y:.984375},{x:.859375,y:.984375},{x:.859375,y:.984375},{x:.890625,y:.984375},{x:.890625,y:.984375},{x:.921875,y:.984375},{x:.921875,y:.984375},{x:.953125,y:.984375},{x:.953125,y:.984375},{x:.984375,y:.984375},{x:.984375,y:.984375},{x:.03125,y:.03125},{x:.03125,y:.03125},{x:.09375,y:.03125},{x:.09375,y:.03125},{x:.15625,y:.03125},{x:.15625,y:.03125},{x:.21875,y:.03125},{x:.21875,y:.03125},{x:.28125,y:.03125},{x:.28125,y:.03125},{x:.34375,y:.03125},{x:.34375,y:.03125},{x:.40625,y:.03125},{x:.40625,y:.03125},{x:.46875,y:.03125},{x:.46875,y:.03125},{x:.53125,y:.03125},{x:.53125,y:.03125},{x:.59375,y:.03125},{x:.59375,y:.03125},{x:.65625,y:.03125},{x:.65625,y:.03125},{x:.71875,y:.03125},{x:.71875,y:.03125},{x:.78125,y:.03125},{x:.78125,y:.03125},{x:.84375,y:.03125},{x:.84375,y:.03125},{x:.90625,y:.03125},{x:.90625,y:.03125},{x:.96875,y:.03125},{x:.96875,y:.03125},{x:.03125,y:.09375},{x:.03125,y:.09375},{x:.09375,y:.09375},{x:.09375,y:.09375},{x:.15625,y:.09375},{x:.15625,y:.09375},{x:.21875,y:.09375},{x:.21875,y:.09375},{x:.28125,y:.09375},{x:.28125,y:.09375},{x:.34375,y:.09375},{x:.34375,y:.09375},{x:.40625,y:.09375},{x:.40625,y:.09375},{x:.46875,y:.09375},{x:.46875,y:.09375},{x:.53125,y:.09375},{x:.53125,y:.09375},{x:.59375,y:.09375},{x:.59375,y:.09375},{x:.65625,y:.09375},{x:.65625,y:.09375},{x:.71875,y:.09375},{x:.71875,y:.09375},{x:.78125,y:.09375},{x:.78125,y:.09375},{x:.84375,y:.09375},{x:.84375,y:.09375},{x:.90625,y:.09375},{x:.90625,y:.09375},{x:.96875,y:.09375},{x:.96875,y:.09375},{x:.03125,y:.15625},{x:.03125,y:.15625},{x:.09375,y:.15625},{x:.09375,y:.15625},{x:.15625,y:.15625},{x:.15625,y:.15625},{x:.21875,y:.15625},{x:.21875,y:.15625},{x:.28125,y:.15625},{x:.28125,y:.15625},{x:.34375,y:.15625},{x:.34375,y:.15625},{x:.40625,y:.15625},{x:.40625,y:.15625},{x:.46875,y:.15625},{x:.46875,y:.15625},{x:.53125,y:.15625},{x:.53125,y:.15625},{x:.59375,y:.15625},{x:.59375,y:.15625},{x:.65625,y:.15625},{x:.65625,y:.15625},{x:.71875,y:.15625},{x:.71875,y:.15625},{x:.78125,y:.15625},{x:.78125,y:.15625},{x:.84375,y:.15625},{x:.84375,y:.15625},{x:.90625,y:.15625},{x:.90625,y:.15625},{x:.96875,y:.15625},{x:.96875,y:.15625},{x:.03125,y:.21875},{x:.03125,y:.21875},{x:.09375,y:.21875},{x:.09375,y:.21875},{x:.15625,y:.21875},{x:.15625,y:.21875},{x:.21875,y:.21875},{x:.21875,y:.21875},{x:.28125,y:.21875},{x:.28125,y:.21875},{x:.34375,y:.21875},{x:.34375,y:.21875},{x:.40625,y:.21875},{x:.40625,y:.21875},{x:.46875,y:.21875},{x:.46875,y:.21875},{x:.53125,y:.21875},{x:.53125,y:.21875},{x:.59375,y:.21875},{x:.59375,y:.21875},{x:.65625,y:.21875},{x:.65625,y:.21875},{x:.71875,y:.21875},{x:.71875,y:.21875},{x:.78125,y:.21875},{x:.78125,y:.21875},{x:.84375,y:.21875},{x:.84375,y:.21875},{x:.90625,y:.21875},{x:.90625,y:.21875},{x:.96875,y:.21875},{x:.96875,y:.21875},{x:.03125,y:.28125},{x:.03125,y:.28125},{x:.09375,y:.28125},{x:.09375,y:.28125},{x:.15625,y:.28125},{x:.15625,y:.28125},{x:.21875,y:.28125},{x:.21875,y:.28125},{x:.28125,y:.28125},{x:.28125,y:.28125},{x:.34375,y:.28125},{x:.34375,y:.28125},{x:.40625,y:.28125},{x:.40625,y:.28125},{x:.46875,y:.28125},{x:.46875,y:.28125},{x:.53125,y:.28125},{x:.53125,y:.28125},{x:.59375,y:.28125},{x:.59375,y:.28125},{x:.65625,y:.28125},{x:.65625,y:.28125},{x:.71875,y:.28125},{x:.71875,y:.28125},{x:.78125,y:.28125},{x:.78125,y:.28125},{x:.84375,y:.28125},{x:.84375,y:.28125},{x:.90625,y:.28125},{x:.90625,y:.28125},{x:.96875,y:.28125},{x:.96875,y:.28125},{x:.03125,y:.34375},{x:.03125,y:.34375},{x:.09375,y:.34375},{x:.09375,y:.34375},{x:.15625,y:.34375},{x:.15625,y:.34375},{x:.21875,y:.34375},{x:.21875,y:.34375},{x:.28125,y:.34375},{x:.28125,y:.34375},{x:.34375,y:.34375},{x:.34375,y:.34375},{x:.40625,y:.34375},{x:.40625,y:.34375},{x:.46875,y:.34375},{x:.46875,y:.34375},{x:.53125,y:.34375},{x:.53125,y:.34375},{x:.59375,y:.34375},{x:.59375,y:.34375},{x:.65625,y:.34375},{x:.65625,y:.34375},{x:.71875,y:.34375},{x:.71875,y:.34375},{x:.78125,y:.34375},{x:.78125,y:.34375},{x:.84375,y:.34375},{x:.84375,y:.34375},{x:.90625,y:.34375},{x:.90625,y:.34375},{x:.96875,y:.34375},{x:.96875,y:.34375},{x:.03125,y:.40625},{x:.03125,y:.40625},{x:.09375,y:.40625},{x:.09375,y:.40625},{x:.15625,y:.40625},{x:.15625,y:.40625},{x:.21875,y:.40625},{x:.21875,y:.40625},{x:.28125,y:.40625},{x:.28125,y:.40625},{x:.34375,y:.40625},{x:.34375,y:.40625},{x:.40625,y:.40625},{x:.40625,y:.40625},{x:.46875,y:.40625},{x:.46875,y:.40625},{x:.53125,y:.40625},{x:.53125,y:.40625},{x:.59375,y:.40625},{x:.59375,y:.40625},{x:.65625,y:.40625},{x:.65625,y:.40625},{x:.71875,y:.40625},{x:.71875,y:.40625},{x:.78125,y:.40625},{x:.78125,y:.40625},{x:.84375,y:.40625},{x:.84375,y:.40625},{x:.90625,y:.40625},{x:.90625,y:.40625},{x:.96875,y:.40625},{x:.96875,y:.40625},{x:.03125,y:.46875},{x:.03125,y:.46875},{x:.09375,y:.46875},{x:.09375,y:.46875},{x:.15625,y:.46875},{x:.15625,y:.46875},{x:.21875,y:.46875},{x:.21875,y:.46875},{x:.28125,y:.46875},{x:.28125,y:.46875},{x:.34375,y:.46875},{x:.34375,y:.46875},{x:.40625,y:.46875},{x:.40625,y:.46875},{x:.46875,y:.46875},{x:.46875,y:.46875},{x:.53125,y:.46875},{x:.53125,y:.46875},{x:.59375,y:.46875},{x:.59375,y:.46875},{x:.65625,y:.46875},{x:.65625,y:.46875},{x:.71875,y:.46875},{x:.71875,y:.46875},{x:.78125,y:.46875},{x:.78125,y:.46875},{x:.84375,y:.46875},{x:.84375,y:.46875},{x:.90625,y:.46875},{x:.90625,y:.46875},{x:.96875,y:.46875},{x:.96875,y:.46875},{x:.03125,y:.53125},{x:.03125,y:.53125},{x:.09375,y:.53125},{x:.09375,y:.53125},{x:.15625,y:.53125},{x:.15625,y:.53125},{x:.21875,y:.53125},{x:.21875,y:.53125},{x:.28125,y:.53125},{x:.28125,y:.53125},{x:.34375,y:.53125},{x:.34375,y:.53125},{x:.40625,y:.53125},{x:.40625,y:.53125},{x:.46875,y:.53125},{x:.46875,y:.53125},{x:.53125,y:.53125},{x:.53125,y:.53125},{x:.59375,y:.53125},{x:.59375,y:.53125},{x:.65625,y:.53125},{x:.65625,y:.53125},{x:.71875,y:.53125},{x:.71875,y:.53125},{x:.78125,y:.53125},{x:.78125,y:.53125},{x:.84375,y:.53125},{x:.84375,y:.53125},{x:.90625,y:.53125},{x:.90625,y:.53125},{x:.96875,y:.53125},{x:.96875,y:.53125},{x:.03125,y:.59375},{x:.03125,y:.59375},{x:.09375,y:.59375},{x:.09375,y:.59375},{x:.15625,y:.59375},{x:.15625,y:.59375},{x:.21875,y:.59375},{x:.21875,y:.59375},{x:.28125,y:.59375},{x:.28125,y:.59375},{x:.34375,y:.59375},{x:.34375,y:.59375},{x:.40625,y:.59375},{x:.40625,y:.59375},{x:.46875,y:.59375},{x:.46875,y:.59375},{x:.53125,y:.59375},{x:.53125,y:.59375},{x:.59375,y:.59375},{x:.59375,y:.59375},{x:.65625,y:.59375},{x:.65625,y:.59375},{x:.71875,y:.59375},{x:.71875,y:.59375},{x:.78125,y:.59375},{x:.78125,y:.59375},{x:.84375,y:.59375},{x:.84375,y:.59375},{x:.90625,y:.59375},{x:.90625,y:.59375},{x:.96875,y:.59375},{x:.96875,y:.59375},{x:.03125,y:.65625},{x:.03125,y:.65625},{x:.09375,y:.65625},{x:.09375,y:.65625},{x:.15625,y:.65625},{x:.15625,y:.65625},{x:.21875,y:.65625},{x:.21875,y:.65625},{x:.28125,y:.65625},{x:.28125,y:.65625},{x:.34375,y:.65625},{x:.34375,y:.65625},{x:.40625,y:.65625},{x:.40625,y:.65625},{x:.46875,y:.65625},{x:.46875,y:.65625},{x:.53125,y:.65625},{x:.53125,y:.65625},{x:.59375,y:.65625},{x:.59375,y:.65625},{x:.65625,y:.65625},{x:.65625,y:.65625},{x:.71875,y:.65625},{x:.71875,y:.65625},{x:.78125,y:.65625},{x:.78125,y:.65625},{x:.84375,y:.65625},{x:.84375,y:.65625},{x:.90625,y:.65625},{x:.90625,y:.65625},{x:.96875,y:.65625},{x:.96875,y:.65625},{x:.03125,y:.71875},{x:.03125,y:.71875},{x:.09375,y:.71875},{x:.09375,y:.71875},{x:.15625,y:.71875},{x:.15625,y:.71875},{x:.21875,y:.71875},{x:.21875,y:.71875},{x:.28125,y:.71875},{x:.28125,y:.71875},{x:.34375,y:.71875},{x:.34375,y:.71875},{x:.40625,y:.71875},{x:.40625,y:.71875},{x:.46875,y:.71875},{x:.46875,y:.71875},{x:.53125,y:.71875},{x:.53125,y:.71875},{x:.59375,y:.71875},{x:.59375,y:.71875},{x:.65625,y:.71875},{x:.65625,y:.71875},{x:.71875,y:.71875},{x:.71875,y:.71875},{x:.78125,y:.71875},{x:.78125,y:.71875},{x:.84375,y:.71875},{x:.84375,y:.71875},{x:.90625,y:.71875},{x:.90625,y:.71875},{x:.96875,y:.71875},{x:.96875,y:.71875},{x:.03125,y:.78125},{x:.03125,y:.78125},{x:.09375,y:.78125},{x:.09375,y:.78125},{x:.15625,y:.78125},{x:.15625,y:.78125},{x:.21875,y:.78125},{x:.21875,y:.78125},{x:.28125,y:.78125},{x:.28125,y:.78125},{x:.34375,y:.78125},{x:.34375,y:.78125},{x:.40625,y:.78125},{x:.40625,y:.78125},{x:.46875,y:.78125},{x:.46875,y:.78125},{x:.53125,y:.78125},{x:.53125,y:.78125},{x:.59375,y:.78125},{x:.59375,y:.78125},{x:.65625,y:.78125},{x:.65625,y:.78125},{x:.71875,y:.78125},{x:.71875,y:.78125},{x:.78125,y:.78125},{x:.78125,y:.78125},{x:.84375,y:.78125},{x:.84375,y:.78125},{x:.90625,y:.78125},{x:.90625,y:.78125},{x:.96875,y:.78125},{x:.96875,y:.78125},{x:.03125,y:.84375},{x:.03125,y:.84375},{x:.09375,y:.84375},{x:.09375,y:.84375},{x:.15625,y:.84375},{x:.15625,y:.84375},{x:.21875,y:.84375},{x:.21875,y:.84375},{x:.28125,y:.84375},{x:.28125,y:.84375},{x:.34375,y:.84375},{x:.34375,y:.84375},{x:.40625,y:.84375},{x:.40625,y:.84375},{x:.46875,y:.84375},{x:.46875,y:.84375},{x:.53125,y:.84375},{x:.53125,y:.84375},{x:.59375,y:.84375},{x:.59375,y:.84375},{x:.65625,y:.84375},{x:.65625,y:.84375},{x:.71875,y:.84375},{x:.71875,y:.84375},{x:.78125,y:.84375},{x:.78125,y:.84375},{x:.84375,y:.84375},{x:.84375,y:.84375},{x:.90625,y:.84375},{x:.90625,y:.84375},{x:.96875,y:.84375},{x:.96875,y:.84375},{x:.03125,y:.90625},{x:.03125,y:.90625},{x:.09375,y:.90625},{x:.09375,y:.90625},{x:.15625,y:.90625},{x:.15625,y:.90625},{x:.21875,y:.90625},{x:.21875,y:.90625},{x:.28125,y:.90625},{x:.28125,y:.90625},{x:.34375,y:.90625},{x:.34375,y:.90625},{x:.40625,y:.90625},{x:.40625,y:.90625},{x:.46875,y:.90625},{x:.46875,y:.90625},{x:.53125,y:.90625},{x:.53125,y:.90625},{x:.59375,y:.90625},{x:.59375,y:.90625},{x:.65625,y:.90625},{x:.65625,y:.90625},{x:.71875,y:.90625},{x:.71875,y:.90625},{x:.78125,y:.90625},{x:.78125,y:.90625},{x:.84375,y:.90625},{x:.84375,y:.90625},{x:.90625,y:.90625},{x:.90625,y:.90625},{x:.96875,y:.90625},{x:.96875,y:.90625},{x:.03125,y:.96875},{x:.03125,y:.96875},{x:.09375,y:.96875},{x:.09375,y:.96875},{x:.15625,y:.96875},{x:.15625,y:.96875},{x:.21875,y:.96875},{x:.21875,y:.96875},{x:.28125,y:.96875},{x:.28125,y:.96875},{x:.34375,y:.96875},{x:.34375,y:.96875},{x:.40625,y:.96875},{x:.40625,y:.96875},{x:.46875,y:.96875},{x:.46875,y:.96875},{x:.53125,y:.96875},{x:.53125,y:.96875},{x:.59375,y:.96875},{x:.59375,y:.96875},{x:.65625,y:.96875},{x:.65625,y:.96875},{x:.71875,y:.96875},{x:.71875,y:.96875},{x:.78125,y:.96875},{x:.78125,y:.96875},{x:.84375,y:.96875},{x:.84375,y:.96875},{x:.90625,y:.96875},{x:.90625,y:.96875},{x:.96875,y:.96875},{x:.96875,y:.96875},{x:.0625,y:.0625},{x:.0625,y:.0625},{x:.0625,y:.0625},{x:.0625,y:.0625},{x:.0625,y:.0625},{x:.0625,y:.0625},{x:.1875,y:.0625},{x:.1875,y:.0625},{x:.1875,y:.0625},{x:.1875,y:.0625},{x:.1875,y:.0625},{x:.1875,y:.0625},{x:.3125,y:.0625},{x:.3125,y:.0625},{x:.3125,y:.0625},{x:.3125,y:.0625},{x:.3125,y:.0625},{x:.3125,y:.0625},{x:.4375,y:.0625},{x:.4375,y:.0625},{x:.4375,y:.0625},{x:.4375,y:.0625},{x:.4375,y:.0625},{x:.4375,y:.0625},{x:.5625,y:.0625},{x:.5625,y:.0625},{x:.5625,y:.0625},{x:.5625,y:.0625},{x:.5625,y:.0625},{x:.5625,y:.0625},{x:.6875,y:.0625},{x:.6875,y:.0625},{x:.6875,y:.0625},{x:.6875,y:.0625},{x:.6875,y:.0625},{x:.6875,y:.0625},{x:.8125,y:.0625},{x:.8125,y:.0625},{x:.8125,y:.0625},{x:.8125,y:.0625},{x:.8125,y:.0625},{x:.8125,y:.0625},{x:.9375,y:.0625},{x:.9375,y:.0625},{x:.9375,y:.0625},{x:.9375,y:.0625},{x:.9375,y:.0625},{x:.9375,y:.0625},{x:.0625,y:.1875},{x:.0625,y:.1875},{x:.0625,y:.1875},{x:.0625,y:.1875},{x:.0625,y:.1875},{x:.0625,y:.1875},{x:.1875,y:.1875},{x:.1875,y:.1875},{x:.1875,y:.1875},{x:.1875,y:.1875},{x:.1875,y:.1875},{x:.1875,y:.1875},{x:.3125,y:.1875},{x:.3125,y:.1875},{x:.3125,y:.1875},{x:.3125,y:.1875},{x:.3125,y:.1875},{x:.3125,y:.1875},{x:.4375,y:.1875},{x:.4375,y:.1875},{x:.4375,y:.1875},{x:.4375,y:.1875},{x:.4375,y:.1875},{x:.4375,y:.1875},{x:.5625,y:.1875},{x:.5625,y:.1875},{x:.5625,y:.1875},{x:.5625,y:.1875},{x:.5625,y:.1875},{x:.5625,y:.1875},{x:.6875,y:.1875},{x:.6875,y:.1875},{x:.6875,y:.1875},{x:.6875,y:.1875},{x:.6875,y:.1875},{x:.6875,y:.1875},{x:.8125,y:.1875},{x:.8125,y:.1875},{x:.8125,y:.1875},{x:.8125,y:.1875},{x:.8125,y:.1875},{x:.8125,y:.1875},{x:.9375,y:.1875},{x:.9375,y:.1875},{x:.9375,y:.1875},{x:.9375,y:.1875},{x:.9375,y:.1875},{x:.9375,y:.1875},{x:.0625,y:.3125},{x:.0625,y:.3125},{x:.0625,y:.3125},{x:.0625,y:.3125},{x:.0625,y:.3125},{x:.0625,y:.3125},{x:.1875,y:.3125},{x:.1875,y:.3125},{x:.1875,y:.3125},{x:.1875,y:.3125},{x:.1875,y:.3125},{x:.1875,y:.3125},{x:.3125,y:.3125},{x:.3125,y:.3125},{x:.3125,y:.3125},{x:.3125,y:.3125},{x:.3125,y:.3125},{x:.3125,y:.3125},{x:.4375,y:.3125},{x:.4375,y:.3125},{x:.4375,y:.3125},{x:.4375,y:.3125},{x:.4375,y:.3125},{x:.4375,y:.3125},{x:.5625,y:.3125},{x:.5625,y:.3125},{x:.5625,y:.3125},{x:.5625,y:.3125},{x:.5625,y:.3125},{x:.5625,y:.3125},{x:.6875,y:.3125},{x:.6875,y:.3125},{x:.6875,y:.3125},{x:.6875,y:.3125},{x:.6875,y:.3125},{x:.6875,y:.3125},{x:.8125,y:.3125},{x:.8125,y:.3125},{x:.8125,y:.3125},{x:.8125,y:.3125},{x:.8125,y:.3125},{x:.8125,y:.3125},{x:.9375,y:.3125},{x:.9375,y:.3125},{x:.9375,y:.3125},{x:.9375,y:.3125},{x:.9375,y:.3125},{x:.9375,y:.3125},{x:.0625,y:.4375},{x:.0625,y:.4375},{x:.0625,y:.4375},{x:.0625,y:.4375},{x:.0625,y:.4375},{x:.0625,y:.4375},{x:.1875,y:.4375},{x:.1875,y:.4375},{x:.1875,y:.4375},{x:.1875,y:.4375},{x:.1875,y:.4375},{x:.1875,y:.4375},{x:.3125,y:.4375},{x:.3125,y:.4375},{x:.3125,y:.4375},{x:.3125,y:.4375},{x:.3125,y:.4375},{x:.3125,y:.4375},{x:.4375,y:.4375},{x:.4375,y:.4375},{x:.4375,y:.4375},{x:.4375,y:.4375},{x:.4375,y:.4375},{x:.4375,y:.4375},{x:.5625,y:.4375},{x:.5625,y:.4375},{x:.5625,y:.4375},{x:.5625,y:.4375},{x:.5625,y:.4375},{x:.5625,y:.4375},{x:.6875,y:.4375},{x:.6875,y:.4375},{x:.6875,y:.4375},{x:.6875,y:.4375},{x:.6875,y:.4375},{x:.6875,y:.4375},{x:.8125,y:.4375},{x:.8125,y:.4375},{x:.8125,y:.4375},{x:.8125,y:.4375},{x:.8125,y:.4375},{x:.8125,y:.4375},{x:.9375,y:.4375},{x:.9375,y:.4375},{x:.9375,y:.4375},{x:.9375,y:.4375},{x:.9375,y:.4375},{x:.9375,y:.4375},{x:.0625,y:.5625},{x:.0625,y:.5625},{x:.0625,y:.5625},{x:.0625,y:.5625},{x:.0625,y:.5625},{x:.0625,y:.5625},{x:.1875,y:.5625},{x:.1875,y:.5625},{x:.1875,y:.5625},{x:.1875,y:.5625},{x:.1875,y:.5625},{x:.1875,y:.5625},{x:.3125,y:.5625},{x:.3125,y:.5625},{x:.3125,y:.5625},{x:.3125,y:.5625},{x:.3125,y:.5625},{x:.3125,y:.5625},{x:.4375,y:.5625},{x:.4375,y:.5625},{x:.4375,y:.5625},{x:.4375,y:.5625},{x:.4375,y:.5625},{x:.4375,y:.5625},{x:.5625,y:.5625},{x:.5625,y:.5625},{x:.5625,y:.5625},{x:.5625,y:.5625},{x:.5625,y:.5625},{x:.5625,y:.5625},{x:.6875,y:.5625},{x:.6875,y:.5625},{x:.6875,y:.5625},{x:.6875,y:.5625},{x:.6875,y:.5625},{x:.6875,y:.5625},{x:.8125,y:.5625},{x:.8125,y:.5625},{x:.8125,y:.5625},{x:.8125,y:.5625},{x:.8125,y:.5625},{x:.8125,y:.5625},{x:.9375,y:.5625},{x:.9375,y:.5625},{x:.9375,y:.5625},{x:.9375,y:.5625},{x:.9375,y:.5625},{x:.9375,y:.5625},{x:.0625,y:.6875},{x:.0625,y:.6875},{x:.0625,y:.6875},{x:.0625,y:.6875},{x:.0625,y:.6875},{x:.0625,y:.6875},{x:.1875,y:.6875},{x:.1875,y:.6875},{x:.1875,y:.6875},{x:.1875,y:.6875},{x:.1875,y:.6875},{x:.1875,y:.6875},{x:.3125,y:.6875},{x:.3125,y:.6875},{x:.3125,y:.6875},{x:.3125,y:.6875},{x:.3125,y:.6875},{x:.3125,y:.6875},{x:.4375,y:.6875},{x:.4375,y:.6875},{x:.4375,y:.6875},{x:.4375,y:.6875},{x:.4375,y:.6875},{x:.4375,y:.6875},{x:.5625,y:.6875},{x:.5625,y:.6875},{x:.5625,y:.6875},{x:.5625,y:.6875},{x:.5625,y:.6875},{x:.5625,y:.6875},{x:.6875,y:.6875},{x:.6875,y:.6875},{x:.6875,y:.6875},{x:.6875,y:.6875},{x:.6875,y:.6875},{x:.6875,y:.6875},{x:.8125,y:.6875},{x:.8125,y:.6875},{x:.8125,y:.6875},{x:.8125,y:.6875},{x:.8125,y:.6875},{x:.8125,y:.6875},{x:.9375,y:.6875},{x:.9375,y:.6875},{x:.9375,y:.6875},{x:.9375,y:.6875},{x:.9375,y:.6875},{x:.9375,y:.6875},{x:.0625,y:.8125},{x:.0625,y:.8125},{x:.0625,y:.8125},{x:.0625,y:.8125},{x:.0625,y:.8125},{x:.0625,y:.8125},{x:.1875,y:.8125},{x:.1875,y:.8125},{x:.1875,y:.8125},{x:.1875,y:.8125},{x:.1875,y:.8125},{x:.1875,y:.8125},{x:.3125,y:.8125},{x:.3125,y:.8125},{x:.3125,y:.8125},{x:.3125,y:.8125},{x:.3125,y:.8125},{x:.3125,y:.8125},{x:.4375,y:.8125},{x:.4375,y:.8125},{x:.4375,y:.8125},{x:.4375,y:.8125},{x:.4375,y:.8125},{x:.4375,y:.8125},{x:.5625,y:.8125},{x:.5625,y:.8125},{x:.5625,y:.8125},{x:.5625,y:.8125},{x:.5625,y:.8125},{x:.5625,y:.8125},{x:.6875,y:.8125},{x:.6875,y:.8125},{x:.6875,y:.8125},{x:.6875,y:.8125},{x:.6875,y:.8125},{x:.6875,y:.8125},{x:.8125,y:.8125},{x:.8125,y:.8125},{x:.8125,y:.8125},{x:.8125,y:.8125},{x:.8125,y:.8125},{x:.8125,y:.8125},{x:.9375,y:.8125},{x:.9375,y:.8125},{x:.9375,y:.8125},{x:.9375,y:.8125},{x:.9375,y:.8125},{x:.9375,y:.8125},{x:.0625,y:.9375},{x:.0625,y:.9375},{x:.0625,y:.9375},{x:.0625,y:.9375},{x:.0625,y:.9375},{x:.0625,y:.9375},{x:.1875,y:.9375},{x:.1875,y:.9375},{x:.1875,y:.9375},{x:.1875,y:.9375},{x:.1875,y:.9375},{x:.1875,y:.9375},{x:.3125,y:.9375},{x:.3125,y:.9375},{x:.3125,y:.9375},{x:.3125,y:.9375},{x:.3125,y:.9375},{x:.3125,y:.9375},{x:.4375,y:.9375},{x:.4375,y:.9375},{x:.4375,y:.9375},{x:.4375,y:.9375},{x:.4375,y:.9375},{x:.4375,y:.9375},{x:.5625,y:.9375},{x:.5625,y:.9375},{x:.5625,y:.9375},{x:.5625,y:.9375},{x:.5625,y:.9375},{x:.5625,y:.9375},{x:.6875,y:.9375},{x:.6875,y:.9375},{x:.6875,y:.9375},{x:.6875,y:.9375},{x:.6875,y:.9375},{x:.6875,y:.9375},{x:.8125,y:.9375},{x:.8125,y:.9375},{x:.8125,y:.9375},{x:.8125,y:.9375},{x:.8125,y:.9375},{x:.8125,y:.9375},{x:.9375,y:.9375},{x:.9375,y:.9375},{x:.9375,y:.9375},{x:.9375,y:.9375},{x:.9375,y:.9375},{x:.9375,y:.9375}];var og=class{constructor(t){var n;this.model=t,this.anchors=Tk.map(a=>[a.x,a.y]),this.anchorsTensor=ya(this.anchors),this.inputSize=(n=this.model)==null?void 0:n.inputs[0].shape[2],this.inputSizeTensor=Tt([this.inputSize,this.inputSize]),this.doubleInputSizeTensor=Tt([this.inputSize*2,this.inputSize*2])}normalizeBoxes(t){return W(()=>{let n=Re(t,[0,0],[-1,2]),a=Re(t,[0,2],[-1,2]),r=se(me(n,this.inputSizeTensor),this.anchorsTensor),s=me(a,this.doubleInputSizeTensor),i=_(ge(r,s),this.inputSizeTensor),o=_(se(r,s),this.inputSizeTensor);return cl([i,o],1)})}normalizeLandmarks(t,n){return W(()=>{let a=se(me(t.reshape([-1,7,2]),this.inputSizeTensor),this.anchors[n]);return _(a,this.inputSizeTensor)})}async getBoxes(t,n){let a=this.model.predict(t),r=a.squeeze();a.dispose();let s=W(()=>wn(Re(r,[0,0],[-1,1])).squeeze()),i=s.dataSync(),o=Re(r,[0,1],[-1,4]),l=this.normalizeBoxes(o);o.dispose();let d=await Ye.nonMaxSuppressionAsync(l,i,n.hand.maxDetected,n.hand.iouThreshold,n.hand.minConfidence),u=d.arraySync();s.dispose(),d.dispose();let p=[];for(let c of u)if(i[c]>=n.hand.minConfidence){let h=Re(l,[c,0],[1,-1]),m=Re(r,[c,5],[1,14]),f=W(()=>this.normalizeLandmarks(m,c).reshape([-1,2]));m.dispose(),p.push({box:h,palmLandmarks:f,confidence:i[c]})}return r.dispose(),l.dispose(),p}async estimateHandBounds(t,n){let a=t.shape[1],r=t.shape[2],s=W(()=>t.resizeBilinear([this.inputSize,this.inputSize]).div(127.5).sub(1)),i=await this.getBoxes(s,n);s.dispose();let o=[];if(!i||i.length===0)return o;for(let l of i){let d=l.box.dataSync(),u=d.slice(0,2),p=d.slice(2,4),c=l.palmLandmarks.arraySync();l.box.dispose(),l.palmLandmarks.dispose(),o.push(Nk({startPoint:u,endPoint:p,palmLandmarks:c,confidence:l.confidence},[r/this.inputSize,a/this.inputSize]))}return o}};function Wie(e){return e-2*Math.PI*Math.floor((e+Math.PI)/(2*Math.PI))}function Ek(e,t){let n=Math.PI/2-Math.atan2(-(t[1]-e[1]),t[0]-e[0]);return Wie(n)}var Ck=(e,t)=>[[1,0,e],[0,1,t],[0,0,1]];function Zr(e,t){let n=0;for(let a=0;aug([...s,1],n)),r=this.calculateLandmarksBoundingBox(a);return N0(T0(r),Vie)}getBoxForHandLandmarks(t){let n=this.calculateLandmarksBoundingBox(t),a=N0(T0(n),Fk);a.palmLandmarks=[];for(let r=0;r<$k.length;r++)a.palmLandmarks.push(t[$k[r]].slice(0,2));return a}transformRawCoords(t,n,a,r){let s=S0(n),i=[s[0]/this.inputSize,s[1]/this.inputSize,(s[0]+s[1])/this.inputSize/2],o=t.map(h=>[i[0]*(h[0]-this.inputSize/2),i[1]*(h[1]-this.inputSize/2),i[2]*h[2]]),l=lg(a,[0,0]),d=o.map(h=>[...ug(h,l),h[2]]),u=Mk(r),p=[...Zd(n),1],c=[Zr(p,u[0]),Zr(p,u[1])];return d.map(h=>[h[0]+c[0],h[1]+c[1],h[2]])}async estimateHands(t,n){let a=!1,r;(this.skipped===0||this.skipped>n.hand.skipFrames||!n.hand.landmarks||!n.videoOptimized)&&(r=await this.handDetector.estimateHandBounds(t,n),this.skipped=0),n.videoOptimized&&this.skipped++,r&&r.length>0&&(r.length!==this.detectedHands&&this.detectedHands!==n.hand.maxDetected||!n.hand.landmarks)&&(this.detectedHands=0,this.storedBoxes=[...r],this.storedBoxes.length>0&&(a=!0));let s=[];n.hand.skipInitial&&this.detectedHands===0&&(this.skipped=0);for(let i=0;i=n.hand.minConfidence){let x=H(y,[-1,3]),w=x.arraySync();y.dispose(),x.dispose();let b=this.transformRawCoords(w,h,l,c),v=this.getBoxForHandLandmarks(b);this.storedBoxes[i]=v;let N={landmarks:b,confidence:g,box:{topLeft:v.startPoint,bottomRight:v.endPoint}};s.push(N)}else this.storedBoxes[i]=null;y.dispose()}else{let l=N0(T0(o),Fk),d={confidence:o.confidence,box:{topLeft:l.startPoint,bottomRight:l.endPoint}};s.push(d)}}return this.storedBoxes=this.storedBoxes.filter(i=>i!==null),this.detectedHands=s.length,s}calculateLandmarksBoundingBox(t){let n=t.map(i=>i[0]),a=t.map(i=>i[1]),r=[Math.min(...n),Math.min(...a)],s=[Math.max(...n),Math.max(...a)];return{startPoint:r,endPoint:s}}};var Dk={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]},Yr,Jr,Ok;async function cg(e,t){let n=await Ok.estimateHands(e,t);if(!n)return[];let a=[];for(let r of n){let s={};if(r.landmarks)for(let l of Object.keys(Dk))s[l]=Dk[l].map(d=>r.landmarks[d]);let i=r.box?[Math.max(0,r.box.topLeft[0]),Math.max(0,r.box.topLeft[1]),Math.min(e.shape[2],r.box.bottomRight[0])-Math.max(0,r.box.topLeft[0]),Math.min(e.shape[1],r.box.bottomRight[1])-Math.max(0,r.box.topLeft[1])]:[],o=[r.box.topLeft[0]/e.shape[2],r.box.topLeft[1]/e.shape[1],(r.box.bottomRight[0]-r.box.topLeft[0])/e.shape[2],(r.box.bottomRight[1]-r.box.topLeft[1])/e.shape[1]];a.push({confidence:Math.round(100*r.confidence)/100,box:i,boxRaw:o,landmarks:r.landmarks,annotations:s})}return a}async function hg(e){!Yr||!Jr?([Yr,Jr]=await Promise.all([e.hand.enabled?Gt(Yt(e.modelBasePath,e.hand.detector.modelPath),{fromTFHub:e.hand.detector.modelPath.includes("tfhub.dev")}):null,e.hand.landmarks?Gt(Yt(e.modelBasePath,e.hand.skeleton.modelPath),{fromTFHub:e.hand.skeleton.modelPath.includes("tfhub.dev")}):null]),e.hand.enabled&&(!Yr||!Yr.modelUrl?he("load model failed:",e.hand.detector.modelPath):e.debug&&he("load model:",Yr.modelUrl),!Jr||!Jr.modelUrl?he("load model failed:",e.hand.skeleton.modelPath):e.debug&&he("load model:",Jr.modelUrl))):(e.debug&&he("cached model:",Yr.modelUrl),e.debug&&he("cached model:",Jr.modelUrl));let t=new og(Yr);return Ok=new dg(t,Jr),[Yr,Jr]}var fg={};Ma(fg,{load:()=>mg,predict:()=>Ag});var zk=["nose","leftEyeInside","leftEye","leftEyeOutside","rightEyeInside","rightEye","rightEyeOutside","leftEar","rightEar","leftMouth","rightMouth","leftShoulder","rightShoulder","leftElbow","rightElbow","leftWrist","rightWrist","leftPalm","rightPalm","leftIndex","rightIndex","leftPinky","rightPinky","leftHip","rightHip","leftKnee","rightKnee","leftAnkle","rightAnkle","leftHeel","rightHeel","leftFoot","rightFoot","midHip","forehead","leftThumb","leftHand","rightThumb","rightHand"],_k=["nose","leftEyeInside","leftEye","leftEyeOutside","rightEyeInside","rightEye","rightEyeOutside","leftEar","rightEar","leftMouth","rightMouth","leftShoulder","rightShoulder","leftElbow","rightElbow","left:15","right:16","left:17","right:18","left:19","right:20","left:21","right:22","leftChest","rightChest","neck","forehead","left:27","right:28","left:29","right:30"];var En;async function mg(e){return En?e.debug&&he("cached model:",En.modelUrl):(En=await Gt(Yt(e.modelBasePath,e.body.modelPath)),En.width=parseInt(En.signature.inputs["input_1:0"].tensorShape.dim[2].size),En.height=parseInt(En.signature.inputs["input_1:0"].tensorShape.dim[1].size),!En||!En.modelUrl?he("load model failed:",e.body.modelPath):e.debug&&he("load model:",En.modelUrl)),En}async function Ag(e,t){if(!En||!t.body.enabled)return null;let n={width:e.shape[2],height:e.shape[1]},a=Ye.resizeBilinear(e,[En.width,En.height],!1),r=me(a,[255]);a.dispose();let s=await En.predict(r),i=s.find(p=>p.size===195||p.size===155).dataSync();s.forEach(p=>p.dispose()),r.dispose();let o=[],l=i.length===195?zk:_k,d=5;for(let p=0;pc.score>p?c.score:p,0),keypoints:o}]}var yg={};Ma(yg,{load:()=>xg,predict:()=>bg});var E0=[{class:1,label:"person"},{class:2,label:"bicycle"},{class:3,label:"car"},{class:4,label:"motorcycle"},{class:5,label:"airplane"},{class:6,label:"bus"},{class:7,label:"train"},{class:8,label:"truck"},{class:9,label:"boat"},{class:10,label:"traffic light"},{class:11,label:"fire hydrant"},{class:12,label:"stop sign"},{class:13,label:"parking meter"},{class:14,label:"bench"},{class:15,label:"bird"},{class:16,label:"cat"},{class:17,label:"dog"},{class:18,label:"horse"},{class:19,label:"sheep"},{class:20,label:"cow"},{class:21,label:"elephant"},{class:22,label:"bear"},{class:23,label:"zebra"},{class:24,label:"giraffe"},{class:25,label:"backpack"},{class:26,label:"umbrella"},{class:27,label:"handbag"},{class:28,label:"tie"},{class:29,label:"suitcase"},{class:30,label:"frisbee"},{class:31,label:"skis"},{class:32,label:"snowboard"},{class:33,label:"sports ball"},{class:34,label:"kite"},{class:35,label:"baseball bat"},{class:36,label:"baseball glove"},{class:37,label:"skateboard"},{class:38,label:"surfboard"},{class:39,label:"tennis racket"},{class:40,label:"bottle"},{class:41,label:"wine glass"},{class:42,label:"cup"},{class:43,label:"fork"},{class:44,label:"knife"},{class:45,label:"spoon"},{class:46,label:"bowl"},{class:47,label:"banana"},{class:48,label:"apple"},{class:49,label:"sandwich"},{class:50,label:"orange"},{class:51,label:"broccoli"},{class:52,label:"carrot"},{class:53,label:"hot dog"},{class:54,label:"pizza"},{class:55,label:"donut"},{class:56,label:"cake"},{class:57,label:"chair"},{class:58,label:"couch"},{class:59,label:"potted plant"},{class:60,label:"bed"},{class:61,label:"dining table"},{class:62,label:"toilet"},{class:63,label:"tv"},{class:64,label:"laptop"},{class:65,label:"mouse"},{class:66,label:"remote"},{class:67,label:"keyboard"},{class:68,label:"cell phone"},{class:69,label:"microwave"},{class:70,label:"oven"},{class:71,label:"toaster"},{class:72,label:"sink"},{class:73,label:"refrigerator"},{class:74,label:"book"},{class:75,label:"clock"},{class:76,label:"vase"},{class:77,label:"scissors"},{class:78,label:"teddy bear"},{class:79,label:"hair drier"},{class:80,label:"toothbrush"}];var Cn,gg=[],C0=Number.MAX_SAFE_INTEGER,R0=2.5;async function xg(e){if(Cn)e.debug&&he("cached model:",Cn.modelUrl);else{Cn=await Gt(Yt(e.modelBasePath,e.object.modelPath));let t=Object.values(Cn.modelSignature.inputs);if(Cn.inputSize=Array.isArray(t)?parseInt(t[0].tensorShape.dim[2].size):null,!Cn.inputSize)throw new Error(`Human: Cannot determine model inputSize: ${e.object.modelPath}`);!Cn||!Cn.modelUrl?he("load model failed:",e.object.modelPath):e.debug&&he("load model:",Cn.modelUrl)}return Cn}async function Hie(e,t,n,a){let r=0,s=[];for(let d of[1,2,4])W(()=>{var A,y;let u=d*13,p=(A=e.find(g=>g.shape[1]===u**2&&g.shape[2]===E0.length))==null?void 0:A.squeeze(),c=(y=e.find(g=>g.shape[1]===u**2&&g.shape[2]a.object.minConfidence&&x!==61){let b=(.5+Math.trunc(g%u))/u,v=(.5+Math.trunc(g/u))/u,N=m[g].map(U=>U*(u/d/t)),[T,R]=[b-R0/d*N[0],v-R0/d*N[1]],[$,z]=[b+R0/d*N[2]-T,v+R0/d*N[3]-R],P=[T,R,$,z];P=P.map(U=>Math.max(0,Math.min(U,1)));let V=[P[0]*n[0],P[1]*n[1],P[2]*n[0],P[3]*n[1]],j={id:r++,strideSize:d,score:Math.round(100*w)/100,class:x+1,label:E0[x].label,center:[Math.trunc(n[0]*b),Math.trunc(n[1]*v)],centerRaw:[b,v],box:V.map(U=>Math.trunc(U)),boxRaw:P};s.push(j)}}});e.forEach(d=>Ee(d));let i=s.map(d=>d.boxRaw),o=s.map(d=>d.score),l=[];if(i&&i.length>0){let d=await Ye.nonMaxSuppressionAsync(i,o,a.object.maxDetected,a.object.iouThreshold,a.object.minConfidence);l=d.dataSync(),Ee(d)}return s=s.filter((d,u)=>l.includes(u)).sort((d,u)=>u.score-d.score),s}async function bg(e,t){return Cn?C00?(C0++,gg):(t.videoOptimized?C0=0:C0=Number.MAX_SAFE_INTEGER,new Promise(async n=>{let a=[e.shape[2],e.shape[1]],r=Ye.resizeBilinear(e,[Cn.inputSize,Cn.inputSize],!1),s=r.div(255),i=s.transpose([0,3,1,2]);s.dispose(),r.dispose();let o;t.object.enabled&&(o=await Cn.predict(i)),i.dispose();let l=await Hie(o,Cn.inputSize,a,t);gg=l,n(l)})):null}var Pk=e=>{if(!e)return[];let t=[];for(let n=0;nl.part==="leftWrist"),r=e[n].keypoints.find(l=>l.part==="rightWrist"),s=e[n].keypoints.find(l=>l.part==="nose");s&&a&&r&&a.position.yl.part==="leftShoulder"),o=e[n].keypoints.find(l=>l.part==="rightShoulder");i&&o&&t.push({body:n,gesture:`leaning ${i.position.y>o.position.y?"left":"right"}`})}return t},Lk=e=>{if(!e)return[];let t=[];for(let n=0;n0){let a=e[n].mesh[33][2]-e[n].mesh[263][2];Math.abs(a)<10?t.push({face:n,gesture:"facing center"}):t.push({face:n,gesture:`facing ${a<0?"left":"right"}`}),Math.abs(e[n].mesh[374][1]-e[n].mesh[386][1])/Math.abs(e[n].mesh[443][1]-e[n].mesh[450][1])<.2&&t.push({face:n,gesture:"blink left eye"}),Math.abs(e[n].mesh[145][1]-e[n].mesh[159][1])/Math.abs(e[n].mesh[223][1]-e[n].mesh[230][1])<.2&&t.push({face:n,gesture:"blink right eye"});let i=Math.min(100,500*Math.abs(e[n].mesh[13][1]-e[n].mesh[14][1])/Math.abs(e[n].mesh[10][1]-e[n].mesh[152][1]));i>10&&t.push({face:n,gesture:`mouth ${Math.trunc(i)}% open`});let o=e[n].mesh[152][2];Math.abs(o)>10&&t.push({face:n,gesture:`head ${o<0?"up":"down"}`})}return t},Wk=e=>{if(!e)return[];let t=[];for(let n=0;n.033||p>.033)&&(d=!1),c>.033&&t.push({iris:n,gesture:"looking right"}),p>.033&&t.push({iris:n,gesture:"looking left"});let h=Math.abs(e[n].mesh[145][1]-e[n].annotations.rightEyeIris[0][1])/e[n].annotations.rightEyeIris[0][1],m=Math.abs(e[n].mesh[374][1]-e[n].annotations.leftEyeIris[0][1])/e[n].annotations.leftEyeIris[0][1];(m<.015||h<.015||m>.03||h>.03)&&(d=!1),(m<.015||h<.015)&&t.push({iris:n,gesture:"looking down"}),(m>.03||h>.03)&&t.push({iris:n,gesture:"looking up"}),d&&t.push({iris:n,gesture:"looking center"})}return t},Bk=e=>{if(!e)return[];let t=[];for(let n=0;n0){let r=a.reduce((i,o)=>i.position[2]i.position[1]wg});function Gie(e,t,n){let a=function(o,l,d){let u=new RegExp("\\b"+l+" \\w+ (\\w+)","ig");o.replace(u,(p,c)=>(d[c]=0,p))},r=function(o,l){let d=e.createShader(l);if(e.shaderSource(d,o),e.compileShader(d),!e.getShaderParameter(d,e.COMPILE_STATUS))throw new Error("Filter: GL compile failed",e.getShaderInfoLog(d));return d};this.uniform={},this.attribute={};let s=r(t,e.VERTEX_SHADER),i=r(n,e.FRAGMENT_SHADER);if(this.id=e.createProgram(),e.attachShader(this.id,s),e.attachShader(this.id,i),e.linkProgram(this.id),!e.getProgramParameter(this.id,e.LINK_STATUS))throw new Error("Filter: GL link failed",e.getProgramInfoLog(this.id));e.useProgram(this.id),a(t,"attribute",this.attribute);for(let o in this.attribute)this.attribute[o]=e.getAttribLocation(this.id,o);a(t,"uniform",this.uniform),a(n,"uniform",this.uniform);for(let o in this.uniform)this.uniform[o]=e.getUniformLocation(this.id,o)}function Vk(e){e||(e={});let t=0,n=null,a=!1,r=-1,s=[null,null],i=[],o=-1,l=-1,d=null,u=null,p={},c=e.canvas||document.createElement("canvas"),h={},m={INTERMEDIATE:1},f=c.getContext("webgl");if(!f)throw new Error("Filter: getContext() failed");this.addFilter=function(b){let v=Array.prototype.slice.call(arguments,1),N=p[b];i.push({func:N,args:v})},this.reset=function(){i=[]};let A=function(b,v){if(!(b===o&&v===l)){if(c.width=b,o=b,c.height=v,l=v,!d){let N=new Float32Array([-1,-1,0,1,1,-1,1,1,-1,1,0,0,-1,1,0,0,1,-1,1,1,1,1,1,0]);d=f.createBuffer(),f.bindBuffer(f.ARRAY_BUFFER,d),f.bufferData(f.ARRAY_BUFFER,N,f.STATIC_DRAW),f.pixelStorei(f.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!0)}f.viewport(0,0,o,l),s=[null,null]}},y=function(b,v){let N=f.createFramebuffer();f.bindFramebuffer(f.FRAMEBUFFER,N);let T=f.createRenderbuffer();f.bindRenderbuffer(f.RENDERBUFFER,T);let R=f.createTexture();return f.bindTexture(f.TEXTURE_2D,R),f.texImage2D(f.TEXTURE_2D,0,f.RGBA,b,v,0,f.RGBA,f.UNSIGNED_BYTE,null),f.texParameteri(f.TEXTURE_2D,f.TEXTURE_MAG_FILTER,f.LINEAR),f.texParameteri(f.TEXTURE_2D,f.TEXTURE_MIN_FILTER,f.LINEAR),f.texParameteri(f.TEXTURE_2D,f.TEXTURE_WRAP_S,f.CLAMP_TO_EDGE),f.texParameteri(f.TEXTURE_2D,f.TEXTURE_WRAP_T,f.CLAMP_TO_EDGE),f.framebufferTexture2D(f.FRAMEBUFFER,f.COLOR_ATTACHMENT0,f.TEXTURE_2D,R,0),f.bindTexture(f.TEXTURE_2D,null),f.bindFramebuffer(f.FRAMEBUFFER,null),{fbo:N,texture:R}},g=function(b){return s[b]=s[b]||y(o,l),s[b]},x=function(b=null){var R,$;let v=null,N=null,T=!1;t===0?v=n:v=(R=g(r))==null?void 0:R.texture,t++,a&&!(b&m.INTERMEDIATE)?(N=null,T=t%2==0):(r=(r+1)%2,N=($=g(r))==null?void 0:$.fbo),f.bindTexture(f.TEXTURE_2D,v),f.bindFramebuffer(f.FRAMEBUFFER,N),f.uniform1f(u.uniform.flipY,T?-1:1),f.drawArrays(f.TRIANGLES,0,6)};this.apply=function(b){if(A(b.width,b.height),t=0,n||(n=f.createTexture()),f.bindTexture(f.TEXTURE_2D,n),f.texParameteri(f.TEXTURE_2D,f.TEXTURE_WRAP_S,f.CLAMP_TO_EDGE),f.texParameteri(f.TEXTURE_2D,f.TEXTURE_WRAP_T,f.CLAMP_TO_EDGE),f.texParameteri(f.TEXTURE_2D,f.TEXTURE_MIN_FILTER,f.NEAREST),f.texParameteri(f.TEXTURE_2D,f.TEXTURE_MAG_FILTER,f.NEAREST),f.texImage2D(f.TEXTURE_2D,0,f.RGBA,f.RGBA,f.UNSIGNED_BYTE,b),i.length===0)return x(),c;for(let v=0;v0,s=e.naturalHeight||e.videoHeight||e.height||e.shape&&e.shape[2]>0,i=r,o=s;if(i>M0&&(i=M0,o=i*s/r),o>M0&&(o=M0,i=o*r/s),t.filter.width>0?i=t.filter.width:t.filter.height>0&&(i=r*(t.filter.height/s)),t.filter.height>0?o=t.filter.height:t.filter.width>0&&(o=s*(t.filter.width/r)),!i||!o)throw new Error("Human: Input cannot determine dimension");(!Ce||(Ce==null?void 0:Ce.width)!==i||(Ce==null?void 0:Ce.height)!==o)&&(Ce=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(i,o):document.createElement("canvas"),(Ce==null?void 0:Ce.width)!==i&&(Ce.width=i),(Ce==null?void 0:Ce.height)!==o&&(Ce.height=o));let l=Ce.getContext("2d");if(e instanceof ImageData?l.putImageData(e,0,0):t.filter.flip&&typeof l.translate!="undefined"?(l.translate(r,0),l.scale(-1,1),l.drawImage(e,0,0,r,s,0,0,Ce==null?void 0:Ce.width,Ce==null?void 0:Ce.height),l.setTransform(1,0,0,1,0,0)):l.drawImage(e,0,0,r,s,0,0,Ce==null?void 0:Ce.width,Ce==null?void 0:Ce.height),t.filter.enabled){if((!$t||!gt||Ce.width!==gt.width||(Ce==null?void 0:Ce.height)!==(gt==null?void 0:gt.height))&&(gt=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(Ce==null?void 0:Ce.width,Ce==null?void 0:Ce.height):document.createElement("canvas"),(gt==null?void 0:gt.width)!==(Ce==null?void 0:Ce.width)&&(gt.width=Ce==null?void 0:Ce.width),(gt==null?void 0:gt.height)!==(Ce==null?void 0:Ce.height)&&(gt.height=Ce==null?void 0:Ce.height),$t=ma.flags.IS_BROWSER?new jk({canvas:gt}):null),!$t)return{tensor:null,canvas:Ce};$t.reset(),$t.addFilter("brightness",t.filter.brightness),t.filter.contrast!==0&&$t.addFilter("contrast",t.filter.contrast),t.filter.sharpness!==0&&$t.addFilter("sharpen",t.filter.sharpness),t.filter.blur!==0&&$t.addFilter("blur",t.filter.blur),t.filter.saturation!==0&&$t.addFilter("saturation",t.filter.saturation),t.filter.hue!==0&&$t.addFilter("hue",t.filter.hue),t.filter.negative&&$t.addFilter("negative"),t.filter.sepia&&$t.addFilter("sepia"),t.filter.vintage&&$t.addFilter("brownie"),t.filter.sepia&&$t.addFilter("sepia"),t.filter.kodachrome&&$t.addFilter("kodachrome"),t.filter.technicolor&&$t.addFilter("technicolor"),t.filter.polaroid&&$t.addFilter("polaroid"),t.filter.pixelate!==0&&$t.addFilter("pixelate",t.filter.pixelate),$t.apply(Ce)}else gt=Ce,$t&&($t=null);let d;if(gt.data){let p=[gt.height,gt.width,3];d=hc(gt.data,p,"int32")}else if(gt instanceof ImageData)d=li.fromPixels(gt);else if(t.backend==="webgl"||t.backend==="humangl"){let p=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(i,o):document.createElement("canvas");p.width=i,p.height=o;let c=p.getContext("2d");c==null||c.drawImage(gt,0,0),d=li.fromPixels(p)}else{let p=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(i,o):document.createElement("canvas");p.width=i,p.height=o;let c=p.getContext("2d");c==null||c.drawImage(gt,0,0);let h=c==null?void 0:c.getImageData(0,0,i,o);d=li.fromPixels(h)}let u=d.toFloat();n=u.expandDims(0),d.dispose(),u.dispose()}let a=t.filter.return?gt:null;return{tensor:n,canvas:a}}var kg={};Fa(kg,{all:()=>Xie,body:()=>Gk,canvas:()=>qie,face:()=>Hk,gesture:()=>Uk,hand:()=>qk,object:()=>Xk,options:()=>_i});var dt={backend:"webgl",modelBasePath:"../models/",wasmPath:"../assets/",debug:!0,async:!0,videoOptimized:!0,warmup:"full",filter:{enabled:!0,width:0,height:0,flip:!1,return:!0,brightness:0,contrast:0,sharpness:0,blur:0,saturation:0,hue:0,negative:!1,sepia:!1,vintage:!1,kodachrome:!1,technicolor:!1,polaroid:!1,pixelate:0},gesture:{enabled:!0},face:{enabled:!0,detector:{modelPath:"blazeface.json",rotation:!1,maxDetected:10,skipFrames:21,skipInitial:!1,minConfidence:.2,iouThreshold:.1,return:!1},mesh:{enabled:!0,modelPath:"facemesh.json"},iris:{enabled:!0,modelPath:"iris.json"},description:{enabled:!0,modelPath:"faceres.json",skipFrames:31,minConfidence:.1},emotion:{enabled:!0,minConfidence:.1,skipFrames:32,modelPath:"emotion.json"}},body:{enabled:!0,modelPath:"posenet.json",maxDetected:1,minConfidence:.2},hand:{enabled:!0,rotation:!1,skipFrames:12,skipInitial:!1,minConfidence:.1,iouThreshold:.1,maxDetected:1,landmarks:!0,detector:{modelPath:"handdetect.json"},skeleton:{modelPath:"handskeleton.json"}},object:{enabled:!1,modelPath:"nanodet.json",minConfidence:.2,iouThreshold:.4,maxDetected:10,skipFrames:41}};var _i={color:"rgba(173, 216, 230, 0.3)",labelColor:"rgba(173, 216, 230, 1)",shadowColor:"black",font:'small-caps 16px "Segoe UI"',lineHeight:24,lineWidth:6,pointSize:2,roundRect:28,drawPoints:!1,drawLabels:!0,drawBoxes:!1,drawPolygons:!0,fillPolygons:!1,useDepth:!0,useCurves:!1,bufferedOutput:!1,useRawBoxes:!1,calculateHandBox:!0};function F0(e,t,n,a=0,r){e.fillStyle=r.useDepth&&a?`rgba(${127.5+2*a}, ${127.5-2*a}, 255, 0.3)`:r.color,e.beginPath(),e.arc(t,n,r.pointSize,0,2*Math.PI),e.fill()}function Pi(e,t,n,a,r,s){if(e.beginPath(),s.useCurves){let i=(t+t+a)/2,o=(n+n+r)/2;e.ellipse(i,o,a/2,r/2,0,0,2*Math.PI)}else e.lineWidth=s.lineWidth,e.moveTo(t+s.roundRect,n),e.lineTo(t+a-s.roundRect,n),e.quadraticCurveTo(t+a,n,t+a,n+s.roundRect),e.lineTo(t+a,n+r-s.roundRect),e.quadraticCurveTo(t+a,n+r,t+a-s.roundRect,n+r),e.lineTo(t+s.roundRect,n+r),e.quadraticCurveTo(t,n+r,t,n+r-s.roundRect),e.lineTo(t,n+s.roundRect),e.quadraticCurveTo(t,n,t+s.roundRect,n),e.closePath();e.stroke()}function Ig(e,t=[],n){if(!(t===void 0||t.length===0)){e.beginPath(),e.moveTo(t[0][0],t[0][1]);for(let a of t)e.strokeStyle=n.useDepth&&a[2]?`rgba(${127.5+2*a[2]}, ${127.5-2*a[2]}, 255, 0.3)`:n.color,e.fillStyle=n.useDepth&&a[2]?`rgba(${127.5+2*a[2]}, ${127.5-2*a[2]}, 255, 0.3)`:n.color,e.lineTo(a[0],parseInt(a[1]));e.stroke(),n.fillPolygons&&(e.closePath(),e.fill())}}function Yd(e,t=[],n){if(!(t===void 0||t.length===0)){if(!n.useCurves||t.length<=2){Ig(e,t,n);return}e.moveTo(t[0][0],t[0][1]);for(let a=0;a1&&l[1].length>0){let d=o[1]>0?`#${o[1]}`:"",u=`${o[0]} ${d}: ${l[1]}`;a.shadowColor&&a.shadowColor!==""&&(r.fillStyle=a.shadowColor,r.fillText(u,8,2+s*a.lineHeight)),r.fillStyle=a.labelColor,r.fillText(u,6,0+s*a.lineHeight),s+=1}}}async function Hk(e,t,n){let a=Gn(_i,n);if(!t||!e||!(e instanceof HTMLCanvasElement))return;let r=e.getContext("2d");if(!!r)for(let s of t){r.font=a.font,r.strokeStyle=a.color,r.fillStyle=a.color,a.drawBoxes&&(a.useRawBoxes?Pi(r,e.width*s.boxRaw[0],e.height*s.boxRaw[1],e.width*s.boxRaw[2],e.height*s.boxRaw[3],a):Pi(r,s.box[0],s.box[1],s.box[2],s.box[3],a));let i=[];if(i.push(`face confidence: ${Math.trunc(100*s.confidence)}%`),s.genderConfidence&&i.push(`${s.gender||""} ${Math.trunc(100*s.genderConfidence)}% confident`),s.age&&i.push(`age: ${s.age||""}`),s.iris&&i.push(`iris distance: ${s.iris}`),s.emotion&&s.emotion.length>0){let o=s.emotion.map(l=>`${Math.trunc(100*l.score)}% ${l.emotion}`);i.push(o.join(" "))}s.rotation&&s.rotation.angle&&s.rotation.angle.roll&&i.push(`roll: ${Math.trunc(100*s.rotation.angle.roll)/100} yaw:${Math.trunc(100*s.rotation.angle.yaw)/100} pitch:${Math.trunc(100*s.rotation.angle.pitch)/100}`),i.length===0&&i.push("face"),r.fillStyle=a.color;for(let o=i.length-1;o>=0;o--){let l=Math.max(s.box[0],0),d=o*a.lineHeight+s.box[1];a.shadowColor&&a.shadowColor!==""&&(r.fillStyle=a.shadowColor,r.fillText(i[o],l+5,d+16)),r.fillStyle=a.labelColor,r.fillText(i[o],l+4,d+15)}if(r.lineWidth=1,s.mesh&&s.mesh.length>0){if(a.drawPoints)for(let o of s.mesh)F0(r,o[0],o[1],o[2],a);if(a.drawPolygons){r.lineWidth=1;for(let o=0;os.mesh[d]);Ig(r,l,a)}if(s.annotations&&s.annotations.leftEyeIris){r.strokeStyle=a.useDepth?"rgba(255, 200, 255, 0.3)":a.color,r.beginPath();let o=Math.abs(s.annotations.leftEyeIris[3][0]-s.annotations.leftEyeIris[1][0])/2,l=Math.abs(s.annotations.leftEyeIris[4][1]-s.annotations.leftEyeIris[2][1])/2;r.ellipse(s.annotations.leftEyeIris[0][0],s.annotations.leftEyeIris[0][1],o,l,0,0,2*Math.PI),r.stroke(),a.fillPolygons&&(r.fillStyle=a.useDepth?"rgba(255, 255, 200, 0.3)":a.color,r.fill())}if(s.annotations&&s.annotations.rightEyeIris){r.strokeStyle=a.useDepth?"rgba(255, 200, 255, 0.3)":a.color,r.beginPath();let o=Math.abs(s.annotations.rightEyeIris[3][0]-s.annotations.rightEyeIris[1][0])/2,l=Math.abs(s.annotations.rightEyeIris[4][1]-s.annotations.rightEyeIris[2][1])/2;r.ellipse(s.annotations.rightEyeIris[0][0],s.annotations.rightEyeIris[0][1],o,l,0,0,2*Math.PI),r.stroke(),a.fillPolygons&&(r.fillStyle=a.useDepth?"rgba(255, 255, 200, 0.3)":a.color,r.fill())}}}}}var es=[];async function Gk(e,t,n){let a=Gn(_i,n);if(!t||!e||!(e instanceof HTMLCanvasElement))return;let r=e.getContext("2d");if(!!r){r.lineJoin="round";for(let s=0;sl.part==="leftShoulder"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="rightShoulder"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),Yd(r,o,a),o.length=0,i=t[s].keypoints.find(l=>l.part==="rightShoulder"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="rightHip"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="leftHip"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="leftShoulder"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),o.length===4&&Ig(r,o,a),o.length=0,i=t[s].keypoints.find(l=>l.part==="leftHip"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="leftKnee"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="leftAnkle"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="leftHeel"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="leftFoot"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),Yd(r,o,a),o.length=0,i=t[s].keypoints.find(l=>l.part==="rightHip"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="rightKnee"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="rightAnkle"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="rightHeel"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="rightFoot"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),Yd(r,o,a),o.length=0,i=t[s].keypoints.find(l=>l.part==="leftShoulder"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="leftElbow"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="leftWrist"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="leftPalm"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),Yd(r,o,a),o.length=0,i=t[s].keypoints.find(l=>l.part==="rightShoulder"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="rightElbow"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="rightWrist"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="rightPalm"),i&&i.score>dt.body.minConfidence&&o.push([i.position.x,i.position.y]),Yd(r,o,a)}}}}async function qk(e,t,n){let a=Gn(_i,n);if(!t||!e||!(e instanceof HTMLCanvasElement))return;let r=e.getContext("2d");if(!!r){r.lineJoin="round",r.font=a.font;for(let s of t){if(a.drawBoxes){r.strokeStyle=a.color,r.fillStyle=a.color;let i;if(!a.calculateHandBox)i=a.useRawBoxes?s.boxRaw:s.box;else if(i=[Number.MAX_SAFE_INTEGER,Number.MAX_SAFE_INTEGER,0,0],s.landmarks&&s.landmarks.length>0){for(let o of s.landmarks)o[0]i[2]&&(i[2]=o[0]),o[1]>i[3]&&(i[3]=o[1]);i[2]-=i[0],i[3]-=i[1]}a.useRawBoxes?Pi(r,e.width*i[0],e.height*i[1],e.width*i[2],e.height*i[3],a):Pi(r,i[0],i[1],i[2],i[3],a),a.drawLabels&&(a.shadowColor&&a.shadowColor!==""&&(r.fillStyle=a.shadowColor,r.fillText("hand",i[0]+3,1+i[1]+a.lineHeight,i[2])),r.fillStyle=a.labelColor,r.fillText("hand",i[0]+2,0+i[1]+a.lineHeight,i[2])),r.stroke()}if(a.drawPoints&&s.landmarks&&s.landmarks.length>0)for(let i of s.landmarks)r.fillStyle=a.useDepth?`rgba(${127.5+2*i[2]}, ${127.5-2*i[2]}, 255, 0.5)`:a.color,F0(r,i[0],i[1],0,a);if(a.drawLabels){let i=(o,l)=>{r.fillStyle=a.useDepth?`rgba(${127.5+2*o[o.length-1][2]}, ${127.5-2*o[o.length-1][2]}, 255, 0.5)`:a.color,r.fillText(l,o[o.length-1][0]+4,o[o.length-1][1]+4)};r.font=a.font,i(s.annotations.indexFinger,"index"),i(s.annotations.middleFinger,"middle"),i(s.annotations.ringFinger,"ring"),i(s.annotations.pinky,"pinky"),i(s.annotations.thumb,"thumb"),i(s.annotations.palmBase,"palm")}if(a.drawPolygons){let i=o=>{if(!!o)for(let l=0;l0?l-1:0][0],o[l>0?l-1:0][1]),r.lineTo(o[l][0],o[l][1]),r.stroke()};r.lineWidth=a.lineWidth,i(s.annotations.indexFinger),i(s.annotations.middleFinger),i(s.annotations.ringFinger),i(s.annotations.pinky),i(s.annotations.thumb)}}}}async function Xk(e,t,n){let a=Gn(_i,n);if(!t||!e||!(e instanceof HTMLCanvasElement))return;let r=e.getContext("2d");if(!!r){r.lineJoin="round",r.font=a.font;for(let s of t)if(a.drawBoxes){if(r.strokeStyle=a.color,r.fillStyle=a.color,a.useRawBoxes?Pi(r,e.width*s.boxRaw[0],e.height*s.boxRaw[1],e.width*s.boxRaw[2],e.height*s.boxRaw[3],a):Pi(r,s.box[0],s.box[1],s.box[2],s.box[3],a),a.drawLabels){let i=`${Math.round(100*s.score)}% ${s.label}`;a.shadowColor&&a.shadowColor!==""&&(r.fillStyle=a.shadowColor,r.fillText(i,s.box[0]+3,1+s.box[1]+a.lineHeight,s.box[2])),r.fillStyle=a.labelColor,r.fillText(i,s.box[0]+2,0+s.box[1]+a.lineHeight,s.box[2])}r.stroke()}}}async function qie(e,t){if(!e||!t||!(e instanceof HTMLCanvasElement)||!(t instanceof HTMLCanvasElement))return;let n=e.getContext("2d");n==null||n.drawImage(e,0,0)}async function Xie(e,t,n){let a=Gn(_i,n);!t||!e||e instanceof HTMLCanvasElement&&(Hk(e,t.face,a),Gk(e,t.body,a),qk(e,t.hand,a),Uk(e,t.gesture,a),Xk(e,t.object,a))}var $0=` +`)}var M0=2048,Ce,yt,Ft;function wg(e,t){let n;if(!e)throw new Error("Human: Input is missing");if(!(e instanceof Le)&&!(typeof Image!="undefined"&&e instanceof Image)&&!(typeof ImageData!="undefined"&&e instanceof ImageData)&&!(typeof ImageBitmap!="undefined"&&e instanceof ImageBitmap)&&!(typeof HTMLImageElement!="undefined"&&e instanceof HTMLImageElement)&&!(typeof HTMLMediaElement!="undefined"&&e instanceof HTMLMediaElement)&&!(typeof HTMLVideoElement!="undefined"&&e instanceof HTMLVideoElement)&&!(typeof HTMLCanvasElement!="undefined"&&e instanceof HTMLCanvasElement)&&!(typeof OffscreenCanvas!="undefined"&&e instanceof OffscreenCanvas))throw new Error("Human: Input type is not recognized");if(e instanceof Le)if(e.shape&&e.shape.length===4&&e.shape[0]===1&&e.shape[3]===3)n=Da(e);else throw new Error(`Human: Input tensor shape must be [1, height, width, 3] and instead was ${e.shape}`);else{let r=e.naturalWidth||e.videoWidth||e.width||e.shape&&e.shape[1]>0,s=e.naturalHeight||e.videoHeight||e.height||e.shape&&e.shape[2]>0,i=r,o=s;if(i>M0&&(i=M0,o=i*s/r),o>M0&&(o=M0,i=o*r/s),t.filter.width>0?i=t.filter.width:t.filter.height>0&&(i=r*(t.filter.height/s)),t.filter.height>0?o=t.filter.height:t.filter.width>0&&(o=s*(t.filter.width/r)),!i||!o)throw new Error("Human: Input cannot determine dimension");(!Ce||(Ce==null?void 0:Ce.width)!==i||(Ce==null?void 0:Ce.height)!==o)&&(Ce=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(i,o):document.createElement("canvas"),(Ce==null?void 0:Ce.width)!==i&&(Ce.width=i),(Ce==null?void 0:Ce.height)!==o&&(Ce.height=o));let l=Ce.getContext("2d");if(e instanceof ImageData?l.putImageData(e,0,0):t.filter.flip&&typeof l.translate!="undefined"?(l.translate(r,0),l.scale(-1,1),l.drawImage(e,0,0,r,s,0,0,Ce==null?void 0:Ce.width,Ce==null?void 0:Ce.height),l.setTransform(1,0,0,1,0,0)):l.drawImage(e,0,0,r,s,0,0,Ce==null?void 0:Ce.width,Ce==null?void 0:Ce.height),t.filter.enabled){if((!Ft||!yt||Ce.width!==yt.width||(Ce==null?void 0:Ce.height)!==(yt==null?void 0:yt.height))&&(yt=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(Ce==null?void 0:Ce.width,Ce==null?void 0:Ce.height):document.createElement("canvas"),(yt==null?void 0:yt.width)!==(Ce==null?void 0:Ce.width)&&(yt.width=Ce==null?void 0:Ce.width),(yt==null?void 0:yt.height)!==(Ce==null?void 0:Ce.height)&&(yt.height=Ce==null?void 0:Ce.height),Ft=fa.flags.IS_BROWSER?new Vk({canvas:yt}):null),!Ft)return{tensor:null,canvas:Ce};Ft.reset(),Ft.addFilter("brightness",t.filter.brightness),t.filter.contrast!==0&&Ft.addFilter("contrast",t.filter.contrast),t.filter.sharpness!==0&&Ft.addFilter("sharpen",t.filter.sharpness),t.filter.blur!==0&&Ft.addFilter("blur",t.filter.blur),t.filter.saturation!==0&&Ft.addFilter("saturation",t.filter.saturation),t.filter.hue!==0&&Ft.addFilter("hue",t.filter.hue),t.filter.negative&&Ft.addFilter("negative"),t.filter.sepia&&Ft.addFilter("sepia"),t.filter.vintage&&Ft.addFilter("brownie"),t.filter.sepia&&Ft.addFilter("sepia"),t.filter.kodachrome&&Ft.addFilter("kodachrome"),t.filter.technicolor&&Ft.addFilter("technicolor"),t.filter.polaroid&&Ft.addFilter("polaroid"),t.filter.pixelate!==0&&Ft.addFilter("pixelate",t.filter.pixelate),Ft.apply(Ce)}else yt=Ce,Ft&&(Ft=null);let d;if(yt.data){let p=[yt.height,yt.width,3];d=hc(yt.data,p,"int32")}else if(yt instanceof ImageData)d=oi.fromPixels(yt);else if(t.backend==="webgl"||t.backend==="humangl"){let p=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(i,o):document.createElement("canvas");p.width=i,p.height=o;let c=p.getContext("2d");c==null||c.drawImage(yt,0,0),d=oi.fromPixels(p)}else{let p=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(i,o):document.createElement("canvas");p.width=i,p.height=o;let c=p.getContext("2d");c==null||c.drawImage(yt,0,0);let h=c==null?void 0:c.getImageData(0,0,i,o);d=oi.fromPixels(h)}let u=d.toFloat();n=u.expandDims(0),d.dispose(),u.dispose()}let a=t.filter.return?yt:null;return{tensor:n,canvas:a}}var kg={};Ma(kg,{all:()=>Xie,body:()=>Hk,canvas:()=>qie,face:()=>Uk,gesture:()=>jk,hand:()=>Gk,object:()=>qk,options:()=>zi});var zi={color:"rgba(173, 216, 230, 0.3)",labelColor:"rgba(173, 216, 230, 1)",shadowColor:"black",font:'small-caps 16px "Segoe UI"',lineHeight:24,lineWidth:6,pointSize:2,roundRect:28,drawPoints:!1,drawLabels:!0,drawBoxes:!1,drawPolygons:!0,fillPolygons:!1,useDepth:!0,useCurves:!1,bufferedOutput:!1,useRawBoxes:!1,calculateHandBox:!0};function F0(e,t,n,a=0,r){e.fillStyle=r.useDepth&&a?`rgba(${127.5+2*a}, ${127.5-2*a}, 255, 0.3)`:r.color,e.beginPath(),e.arc(t,n,r.pointSize,0,2*Math.PI),e.fill()}function _i(e,t,n,a,r,s){if(e.beginPath(),s.useCurves){let i=(t+t+a)/2,o=(n+n+r)/2;e.ellipse(i,o,a/2,r/2,0,0,2*Math.PI)}else e.lineWidth=s.lineWidth,e.moveTo(t+s.roundRect,n),e.lineTo(t+a-s.roundRect,n),e.quadraticCurveTo(t+a,n,t+a,n+s.roundRect),e.lineTo(t+a,n+r-s.roundRect),e.quadraticCurveTo(t+a,n+r,t+a-s.roundRect,n+r),e.lineTo(t+s.roundRect,n+r),e.quadraticCurveTo(t,n+r,t,n+r-s.roundRect),e.lineTo(t,n+s.roundRect),e.quadraticCurveTo(t,n,t+s.roundRect,n),e.closePath();e.stroke()}function Ig(e,t=[],n){if(!(t===void 0||t.length===0)){e.beginPath(),e.moveTo(t[0][0],t[0][1]);for(let a of t)e.strokeStyle=n.useDepth&&a[2]?`rgba(${127.5+2*a[2]}, ${127.5-2*a[2]}, 255, 0.3)`:n.color,e.fillStyle=n.useDepth&&a[2]?`rgba(${127.5+2*a[2]}, ${127.5-2*a[2]}, 255, 0.3)`:n.color,e.lineTo(a[0],parseInt(a[1]));e.stroke(),n.fillPolygons&&(e.closePath(),e.fill())}}function Yd(e,t=[],n){if(!(t===void 0||t.length===0)){if(!n.useCurves||t.length<=2){Ig(e,t,n);return}e.moveTo(t[0][0],t[0][1]);for(let a=0;a1&&l[1].length>0){let d=o[1]>0?`#${o[1]}`:"",u=`${o[0]} ${d}: ${l[1]}`;a.shadowColor&&a.shadowColor!==""&&(r.fillStyle=a.shadowColor,r.fillText(u,8,2+s*a.lineHeight)),r.fillStyle=a.labelColor,r.fillText(u,6,0+s*a.lineHeight),s+=1}}}async function Uk(e,t,n){let a=Hn(zi,n);if(!t||!e||!(e instanceof HTMLCanvasElement))return;let r=e.getContext("2d");if(!!r)for(let s of t){r.font=a.font,r.strokeStyle=a.color,r.fillStyle=a.color,a.drawBoxes&&(a.useRawBoxes?_i(r,e.width*s.boxRaw[0],e.height*s.boxRaw[1],e.width*s.boxRaw[2],e.height*s.boxRaw[3],a):_i(r,s.box[0],s.box[1],s.box[2],s.box[3],a));let i=[];if(i.push(`face confidence: ${Math.trunc(100*s.confidence)}%`),s.genderConfidence&&i.push(`${s.gender||""} ${Math.trunc(100*s.genderConfidence)}% confident`),s.age&&i.push(`age: ${s.age||""}`),s.iris&&i.push(`iris distance: ${s.iris}`),s.emotion&&s.emotion.length>0){let o=s.emotion.map(l=>`${Math.trunc(100*l.score)}% ${l.emotion}`);i.push(o.join(" "))}s.rotation&&s.rotation.angle&&s.rotation.angle.roll&&i.push(`roll: ${Math.trunc(100*s.rotation.angle.roll)/100} yaw:${Math.trunc(100*s.rotation.angle.yaw)/100} pitch:${Math.trunc(100*s.rotation.angle.pitch)/100}`),i.length===0&&i.push("face"),r.fillStyle=a.color;for(let o=i.length-1;o>=0;o--){let l=Math.max(s.box[0],0),d=o*a.lineHeight+s.box[1];a.shadowColor&&a.shadowColor!==""&&(r.fillStyle=a.shadowColor,r.fillText(i[o],l+5,d+16)),r.fillStyle=a.labelColor,r.fillText(i[o],l+4,d+15)}if(r.lineWidth=1,s.mesh&&s.mesh.length>0){if(a.drawPoints)for(let o of s.mesh)F0(r,o[0],o[1],o[2],a);if(a.drawPolygons){r.lineWidth=1;for(let o=0;os.mesh[d]);Ig(r,l,a)}if(s.annotations&&s.annotations.leftEyeIris){r.strokeStyle=a.useDepth?"rgba(255, 200, 255, 0.3)":a.color,r.beginPath();let o=Math.abs(s.annotations.leftEyeIris[3][0]-s.annotations.leftEyeIris[1][0])/2,l=Math.abs(s.annotations.leftEyeIris[4][1]-s.annotations.leftEyeIris[2][1])/2;r.ellipse(s.annotations.leftEyeIris[0][0],s.annotations.leftEyeIris[0][1],o,l,0,0,2*Math.PI),r.stroke(),a.fillPolygons&&(r.fillStyle=a.useDepth?"rgba(255, 255, 200, 0.3)":a.color,r.fill())}if(s.annotations&&s.annotations.rightEyeIris){r.strokeStyle=a.useDepth?"rgba(255, 200, 255, 0.3)":a.color,r.beginPath();let o=Math.abs(s.annotations.rightEyeIris[3][0]-s.annotations.rightEyeIris[1][0])/2,l=Math.abs(s.annotations.rightEyeIris[4][1]-s.annotations.rightEyeIris[2][1])/2;r.ellipse(s.annotations.rightEyeIris[0][0],s.annotations.rightEyeIris[0][1],o,l,0,0,2*Math.PI),r.stroke(),a.fillPolygons&&(r.fillStyle=a.useDepth?"rgba(255, 255, 200, 0.3)":a.color,r.fill())}}}}}var Qr=[];async function Hk(e,t,n){let a=Hn(zi,n);if(!t||!e||!(e instanceof HTMLCanvasElement))return;let r=e.getContext("2d");if(!!r){r.lineJoin="round";for(let s=0;sl.part==="leftShoulder"),i&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="rightShoulder"),i&&o.push([i.position.x,i.position.y]),Yd(r,o,a),o.length=0,i=t[s].keypoints.find(l=>l.part==="rightShoulder"),i&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="rightHip"),i&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="leftHip"),i&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="leftShoulder"),i&&o.push([i.position.x,i.position.y]),o.length===4&&Ig(r,o,a),o.length=0,i=t[s].keypoints.find(l=>l.part==="leftHip"),i&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="leftKnee"),i&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="leftAnkle"),i&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="leftHeel"),i&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="leftFoot"),i&&o.push([i.position.x,i.position.y]),Yd(r,o,a),o.length=0,i=t[s].keypoints.find(l=>l.part==="rightHip"),i&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="rightKnee"),i&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="rightAnkle"),i&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="rightHeel"),i&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="rightFoot"),i&&o.push([i.position.x,i.position.y]),Yd(r,o,a),o.length=0,i=t[s].keypoints.find(l=>l.part==="leftShoulder"),i&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="leftElbow"),i&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="leftWrist"),i&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="leftPalm"),i&&o.push([i.position.x,i.position.y]),Yd(r,o,a),o.length=0,i=t[s].keypoints.find(l=>l.part==="rightShoulder"),i&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="rightElbow"),i&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="rightWrist"),i&&o.push([i.position.x,i.position.y]),i=t[s].keypoints.find(l=>l.part==="rightPalm"),i&&o.push([i.position.x,i.position.y]),Yd(r,o,a)}}}}async function Gk(e,t,n){let a=Hn(zi,n);if(!t||!e||!(e instanceof HTMLCanvasElement))return;let r=e.getContext("2d");if(!!r){r.lineJoin="round",r.font=a.font;for(let s of t){if(a.drawBoxes){r.strokeStyle=a.color,r.fillStyle=a.color;let i;if(!a.calculateHandBox)i=a.useRawBoxes?s.boxRaw:s.box;else if(i=[Number.MAX_SAFE_INTEGER,Number.MAX_SAFE_INTEGER,0,0],s.landmarks&&s.landmarks.length>0){for(let o of s.landmarks)o[0]i[2]&&(i[2]=o[0]),o[1]>i[3]&&(i[3]=o[1]);i[2]-=i[0],i[3]-=i[1]}a.useRawBoxes?_i(r,e.width*i[0],e.height*i[1],e.width*i[2],e.height*i[3],a):_i(r,i[0],i[1],i[2],i[3],a),a.drawLabels&&(a.shadowColor&&a.shadowColor!==""&&(r.fillStyle=a.shadowColor,r.fillText("hand",i[0]+3,1+i[1]+a.lineHeight,i[2])),r.fillStyle=a.labelColor,r.fillText("hand",i[0]+2,0+i[1]+a.lineHeight,i[2])),r.stroke()}if(a.drawPoints&&s.landmarks&&s.landmarks.length>0)for(let i of s.landmarks)r.fillStyle=a.useDepth?`rgba(${127.5+2*i[2]}, ${127.5-2*i[2]}, 255, 0.5)`:a.color,F0(r,i[0],i[1],0,a);if(a.drawLabels){let i=(o,l)=>{r.fillStyle=a.useDepth?`rgba(${127.5+2*o[o.length-1][2]}, ${127.5-2*o[o.length-1][2]}, 255, 0.5)`:a.color,r.fillText(l,o[o.length-1][0]+4,o[o.length-1][1]+4)};r.font=a.font,i(s.annotations.indexFinger,"index"),i(s.annotations.middleFinger,"middle"),i(s.annotations.ringFinger,"ring"),i(s.annotations.pinky,"pinky"),i(s.annotations.thumb,"thumb"),i(s.annotations.palmBase,"palm")}if(a.drawPolygons){let i=o=>{if(!!o)for(let l=0;l0?l-1:0][0],o[l>0?l-1:0][1]),r.lineTo(o[l][0],o[l][1]),r.stroke()};r.lineWidth=a.lineWidth,i(s.annotations.indexFinger),i(s.annotations.middleFinger),i(s.annotations.ringFinger),i(s.annotations.pinky),i(s.annotations.thumb)}}}}async function qk(e,t,n){let a=Hn(zi,n);if(!t||!e||!(e instanceof HTMLCanvasElement))return;let r=e.getContext("2d");if(!!r){r.lineJoin="round",r.font=a.font;for(let s of t)if(a.drawBoxes){if(r.strokeStyle=a.color,r.fillStyle=a.color,a.useRawBoxes?_i(r,e.width*s.boxRaw[0],e.height*s.boxRaw[1],e.width*s.boxRaw[2],e.height*s.boxRaw[3],a):_i(r,s.box[0],s.box[1],s.box[2],s.box[3],a),a.drawLabels){let i=`${Math.round(100*s.score)}% ${s.label}`;a.shadowColor&&a.shadowColor!==""&&(r.fillStyle=a.shadowColor,r.fillText(i,s.box[0]+3,1+s.box[1]+a.lineHeight,s.box[2])),r.fillStyle=a.labelColor,r.fillText(i,s.box[0]+2,0+s.box[1]+a.lineHeight,s.box[2])}r.stroke()}}}async function qie(e,t){if(!e||!t||!(e instanceof HTMLCanvasElement)||!(t instanceof HTMLCanvasElement))return;let n=e.getContext("2d");n==null||n.drawImage(e,0,0)}async function Xie(e,t,n){let a=Hn(zi,n);!t||!e||e instanceof HTMLCanvasElement&&(Uk(e,t.face,a),Hk(e,t.body,a),Gk(e,t.hand,a),jk(e,t.gesture,a),qk(e,t.object,a))}var Xk={backend:"webgl",modelBasePath:"../models/",wasmPath:"../assets/",debug:!0,async:!0,videoOptimized:!0,warmup:"full",filter:{enabled:!0,width:0,height:0,flip:!1,return:!0,brightness:0,contrast:0,sharpness:0,blur:0,saturation:0,hue:0,negative:!1,sepia:!1,vintage:!1,kodachrome:!1,technicolor:!1,polaroid:!1,pixelate:0},gesture:{enabled:!0},face:{enabled:!0,detector:{modelPath:"blazeface.json",rotation:!1,maxDetected:10,skipFrames:21,skipInitial:!1,minConfidence:.2,iouThreshold:.1,return:!1},mesh:{enabled:!0,modelPath:"facemesh.json"},iris:{enabled:!0,modelPath:"iris.json"},description:{enabled:!0,modelPath:"faceres.json",skipFrames:31,minConfidence:.1},emotion:{enabled:!0,minConfidence:.1,skipFrames:32,modelPath:"emotion.json"}},body:{enabled:!0,modelPath:"posenet.json",maxDetected:1,minConfidence:.1},hand:{enabled:!0,rotation:!1,skipFrames:12,skipInitial:!1,minConfidence:.1,iouThreshold:.1,maxDetected:1,landmarks:!0,detector:{modelPath:"handdetect.json"},skeleton:{modelPath:"handskeleton.json"}},object:{enabled:!1,modelPath:"nanodet.json",minConfidence:.2,iouThreshold:.4,maxDetected:10,skipFrames:41}};var $0=` /9j/4AAQSkZJRgABAQEAYABgAAD/4QBoRXhpZgAATU0AKgAAAAgABAEaAAUAAAABAAAAPgEbAAUA AAABAAAARgEoAAMAAAABAAIAAAExAAIAAAARAAAATgAAAAAAAABgAAAAAQAAAGAAAAABcGFpbnQu bmV0IDQuMi4xMwAA/9sAQwAGBAUGBQQGBgUGBwcGCAoQCgoJCQoUDg8MEBcUGBgXFBYWGh0lHxob @@ -4974,7 +4974,7 @@ AAAAAAJAAAAAAAAAAAAAABAJEAAAAAAAAAAAAAAAIEoBKAAAAAAAAAAAAAAABAlAAAAAAAIAAAAA BAkBAkBAkBAlACEgMZjdjbFW8bWrEx8YWANb6Fp+bfwab+vLDKMFK9qxH5L0bAr8OPRPKz2AY7J2 SbAjYZAI2E7AIEgIEgIEgMdkSy2NgY7MdlmyNoBXsxmFuyNgVTVjNV3KjlBRNTlXTVHKCrlIqt5T lBhEMohlFerLlBjEMohMVTEARDKCITsAk2AEgAAAkAAAAAAAAAAAAAAAAAAAAAAAASAAAAAAAAD/ -2Q==`;var Kk="1.8.2";var Ql,Jd,Qd,Li,O0,ep,z0,_0,P0,Zie=class{constructor(t={}){Ql.set(this,void 0);Jd.set(this,void 0);Qd.set(this,void 0);Li.set(this,void 0);this.analyze=(...t)=>{if(!aa(this,Jd))return;let n=this.tf.engine().state.numTensors,a=aa(this,Ql);rs(this,Ql,n);let r=n-a;r!==0&&he(...t,r)};O0.set(this,t=>{if(!aa(this,Qd))return null;if(!t)return"input is not defined";if(this.tf.ENV.flags.IS_NODE&&!(t instanceof Le))return"input must be a tensor";try{this.tf.getBackend()}catch(n){return"backend not loaded"}return null});ep.set(this,async(t=!1)=>{var n;if(this.config.backend&&this.config.backend.length>0&&t||this.tf.getBackend()!==this.config.backend){let a=it();if(this.state="backend",this.config.backend&&this.config.backend.length>0){if(typeof window=="undefined"&&typeof WorkerGlobalScope!="undefined"&&this.config.debug&&he("running inside web worker"),this.tf.ENV.flags.IS_BROWSER&&this.config.backend==="tensorflow"&&(this.config.backend="webgl"),this.tf.ENV.flags.IS_NODE&&(this.config.backend==="webgl"||this.config.backend==="humangl")&&(this.config.backend="tensorflow"),this.config.debug&&he("setting backend:",this.config.backend),this.config.backend==="wasm"){if(this.config.debug&&he("wasm path:",this.config.wasmPath),typeof((n=this.tf)==null?void 0:n.setWasmPaths)!="undefined")this.tf.setWasmPaths(this.config.wasmPath);else throw new Error("Human: WASM backend is not loaded");let r=await this.tf.env().getAsync("WASM_HAS_SIMD_SUPPORT"),s=await this.tf.env().getAsync("WASM_HAS_MULTITHREAD_SUPPORT");this.config.debug&&he(`wasm execution: ${r?"SIMD":"no SIMD"} ${s?"multithreaded":"singlethreaded"}`),this.config.debug&&!r&&he("warning: wasm simd support is not enabled")}this.config.backend==="humangl"&&nk();try{await this.tf.setBackend(this.config.backend)}catch(r){he("error: cannot set backend:",this.config.backend,r)}}if(this.tf.enableProdMode(),this.tf.getBackend()==="webgl"||this.tf.getBackend()==="humangl"){this.tf.ENV.set("CHECK_COMPUTATION_FOR_ERRORS",!1),this.tf.ENV.set("WEBGL_PACK_DEPTHWISECONV",!0),typeof this.config.deallocate!="undefined"&&(he("changing webgl: WEBGL_DELETE_TEXTURE_THRESHOLD:",!0),this.tf.ENV.set("WEBGL_DELETE_TEXTURE_THRESHOLD",0));let r=await this.tf.backend().getGPGPUContext().gl;this.config.debug&&he(`gl version:${r.getParameter(r.VERSION)} renderer:${r.getParameter(r.RENDERER)}`)}await this.tf.ready(),this.perf.backend=Math.trunc(it()-a)}});z0.set(this,async()=>{let t=(r,s="application/octet-stream")=>fetch(`data:${s};base64,${r}`).then(i=>i.blob()),n,a;switch(this.config.warmup){case"face":n=await t($0);break;case"full":n=await t(D0);break;default:n=null}if(n){let r=await createImageBitmap(n);a=await this.detect(r,this.config),r.close()}return a});_0.set(this,async()=>new Promise(t=>{let n,a=0;switch(this.config.warmup){case"face":a=256,n="data:image/jpeg;base64,"+$0;break;case"full":case"body":a=1200,n="data:image/jpeg;base64,"+D0;break;default:n=null}let r=new Image;r.onload=async()=>{let s=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(a,a):document.createElement("canvas");s.width=r.naturalWidth,s.height=r.naturalHeight;let i=s.getContext("2d");i==null||i.drawImage(r,0,0);let o=await this.detect(s,this.config);t(o)},n?r.src=n:t(null)}));P0.set(this,async()=>{let t=r=>Buffer.from(r,"base64"),n;if(this.config.warmup==="face"&&(n=t($0)),(this.config.warmup==="body"||this.config.warmup==="full")&&(n=t(D0)),!n)return null;let a;if(typeof void 0!="undefined"){let r=(void 0).decodeJpeg(n),s=r.expandDims(0);this.tf.dispose(r),a=await this.detect(s,this.config),this.tf.dispose(s)}else this.config.debug&&he("Warmup tfjs-node not loaded");return a});this.tf=pu,this.draw=kg,this.version=Kk,this.config=Gn(dt,t),this.state="idle",rs(this,Ql,0),rs(this,Jd,!1),rs(this,Qd,!1),rs(this,Li,!0),this.perf={},this.models={face:null,posenet:null,blazepose:null,efficientpose:null,handpose:null,iris:null,age:null,gender:null,emotion:null,embedding:null,nanodet:null,faceres:null},this.image=n=>wg(n,this.config),this.classes={facemesh:W2,emotion:U2,faceres:X2,body:this.config.body.modelPath.includes("posenet")?rg:fg,hand:pg,nanodet:yg},this.faceTriangulation=fk,this.faceUVMap=mk,this.sysinfo=Pg()}similarity(t,n){return Z2(t,n)}enhance(t){return Y2(t)}match(t,n,a=0){return Ak(t,n,a)}async load(t={}){this.state="load";let n=it();t&&(this.config=Gn(this.config,t)),aa(this,Li)&&(this.config.debug&&he(`version: ${this.version}`),this.config.debug&&he(`tfjs version: ${this.tf.version_core}`),this.config.debug&&he("platform:",this.sysinfo.platform),this.config.debug&&he("agent:",this.sysinfo.agent),await aa(this,ep).call(this,!0),this.tf.ENV.flags.IS_BROWSER&&(this.config.debug&&he("configuration:",this.config),this.config.debug&&he("tf flags:",this.tf.ENV.flags))),this.config.async?[this.models.face,this.models.emotion,this.models.handpose,this.models.posenet,this.models.blazepose,this.models.nanodet,this.models.faceres]=await Promise.all([this.models.face||(this.config.face.enabled?j2(this.config):null),this.models.emotion||(this.config.face.enabled&&this.config.face.emotion.enabled?q2(this.config):null),this.models.handpose||(this.config.hand.enabled?hg(this.config):null),this.models.posenet||(this.config.body.enabled&&this.config.body.modelPath.includes("posenet")?ig(this.config):null),this.models.blazepose||(this.config.body.enabled&&this.config.body.modelPath.includes("blazepose")?mg(this.config):null),this.models.nanodet||(this.config.object.enabled?xg(this.config):null),this.models.faceres||(this.config.face.enabled&&this.config.face.description.enabled?K2(this.config):null)]):(this.config.face.enabled&&!this.models.face&&(this.models.face=await j2(this.config)),this.config.face.enabled&&this.config.face.emotion.enabled&&!this.models.emotion&&(this.models.emotion=await q2(this.config)),this.config.hand.enabled&&!this.models.handpose&&(this.models.handpose=await hg(this.config)),this.config.body.enabled&&!this.models.posenet&&this.config.body.modelPath.includes("posenet")&&(this.models.posenet=await ig(this.config)),this.config.body.enabled&&!this.models.blazepose&&this.config.body.modelPath.includes("blazepose")&&(this.models.blazepose=await mg(this.config)),this.config.object.enabled&&!this.models.nanodet&&(this.models.nanodet=await xg(this.config)),this.config.face.enabled&&this.config.face.description.enabled&&!this.models.faceres&&(this.models.faceres=await K2(this.config))),aa(this,Li)&&(this.config.debug&&he("tf engine state:",this.tf.engine().state.numBytes,"bytes",this.tf.engine().state.numTensors,"tensors"),rs(this,Li,!1));let a=Math.trunc(it()-n);a>(this.perf.load||0)&&(this.perf.load=a)}async detect(t,n={}){return new Promise(async a=>{this.state="config";let r;this.config=Gn(this.config,n),this.state="check";let s=aa(this,O0).call(this,t);s&&(he(s,t),a({error:s}));let i=it();await aa(this,ep).call(this),await this.load();let o;t&&this.config.videoOptimized&&typeof window!="undefined"&&typeof WorkerGlobalScope!="undefined"&&(typeof HTMLImageElement!="undefined"&&t instanceof HTMLImageElement||typeof Image!="undefined"&&t instanceof Image||typeof ImageData!="undefined"&&t instanceof ImageData||typeof ImageBitmap!="undefined"&&vg instanceof ImageBitmap)&&(he("disabling video optimization"),o=this.config.videoOptimized,this.config.videoOptimized=!1),r=it();let l=wg(t,this.config);if(!l||!l.tensor){he("could not convert input to tensor"),a({error:"could not convert input to tensor"});return}this.perf.image=Math.trunc(it()-r),this.analyze("Get Image:");let d,u,p,c,h;this.config.async?(p=this.config.face.enabled?J2(this,l.tensor):[],this.perf.face&&delete this.perf.face):(this.state="run:face",r=it(),p=this.config.face.enabled?await J2(this,l.tensor):[],h=Math.trunc(it()-r),h>0&&(this.perf.face=h)),this.analyze("Start Body:"),this.config.async?(this.config.body.modelPath.includes("posenet")?d=this.config.body.enabled?sg(l.tensor,this.config):[]:this.config.body.modelPath.includes("blazepose")&&(d=this.config.body.enabled?Ag(l.tensor,this.config):[]),this.perf.body&&delete this.perf.body):(this.state="run:body",r=it(),this.config.body.modelPath.includes("posenet")?d=this.config.body.enabled?await sg(l.tensor,this.config):[]:this.config.body.modelPath.includes("blazepose")&&(d=this.config.body.enabled?await Ag(l.tensor,this.config):[]),h=Math.trunc(it()-r),h>0&&(this.perf.body=h)),this.analyze("End Body:"),this.analyze("Start Hand:"),this.config.async?(u=this.config.hand.enabled?cg(l.tensor,this.config):[],this.perf.hand&&delete this.perf.hand):(this.state="run:hand",r=it(),u=this.config.hand.enabled?await cg(l.tensor,this.config):[],h=Math.trunc(it()-r),h>0&&(this.perf.hand=h)),this.analyze("End Hand:"),this.analyze("Start Object:"),this.config.async?(c=this.config.object.enabled?bg(l.tensor,this.config):[],this.perf.object&&delete this.perf.object):(this.state="run:object",r=it(),c=this.config.object.enabled?await bg(l.tensor,this.config):[],h=Math.trunc(it()-r),h>0&&(this.perf.object=h)),this.analyze("End Object:"),this.config.async&&([p,d,u,c]=await Promise.all([p,d,u,c])),Ee(l.tensor);let m=[];this.config.gesture.enabled&&(r=it(),m=[...Wk(p),...Lk(d),...Vk(u),...Bk(p)],this.config.async?this.perf.gesture&&delete this.perf.gesture:this.perf.gesture=Math.trunc(it()-r)),o&&(this.config.videoOptimized=o),this.perf.total=Math.trunc(it()-i),this.state="idle";let f={face:p,body:d,hand:u,gesture:m,object:c,performance:this.perf,canvas:l.canvas};a(f)})}async warmup(t={}){let n=it();if(t&&(this.config=Gn(this.config,t)),!this.config.warmup||this.config.warmup==="none")return{error:"null"};let a=this.config.videoOptimized;this.config.videoOptimized=!1;let r;typeof createImageBitmap=="function"?r=await aa(this,z0).call(this):typeof Image!="undefined"?r=await aa(this,_0).call(this):r=await aa(this,P0).call(this),this.config.videoOptimized=a;let s=it();return this.config.debug&&he("Warmup",this.config.warmup,Math.round(s-n),"ms",r),r}};Ql=new WeakMap,Jd=new WeakMap,Qd=new WeakMap,Li=new WeakMap,O0=new WeakMap,ep=new WeakMap,z0=new WeakMap,_0=new WeakMap,P0=new WeakMap;export{Zie as Human,Zie as default}; +2Q==`;var Kk="1.8.2";var Ql,Jd,Qd,Pi,O0,ep,z0,_0,P0,Zie=class{constructor(t={}){Ql.set(this,void 0);Jd.set(this,void 0);Qd.set(this,void 0);Pi.set(this,void 0);this.analyze=(...t)=>{if(!na(this,Jd))return;let n=this.tf.engine().state.numTensors,a=na(this,Ql);as(this,Ql,n);let r=n-a;r!==0&&he(...t,r)};O0.set(this,t=>{if(!na(this,Qd))return null;if(!t)return"input is not defined";if(this.tf.ENV.flags.IS_NODE&&!(t instanceof Le))return"input must be a tensor";try{this.tf.getBackend()}catch(n){return"backend not loaded"}return null});ep.set(this,async(t=!1)=>{var n;if(this.config.backend&&this.config.backend.length>0&&t||this.tf.getBackend()!==this.config.backend){let a=it();if(this.state="backend",this.config.backend&&this.config.backend.length>0){if(typeof window=="undefined"&&typeof WorkerGlobalScope!="undefined"&&this.config.debug&&he("running inside web worker"),this.tf.ENV.flags.IS_BROWSER&&this.config.backend==="tensorflow"&&(this.config.backend="webgl"),this.tf.ENV.flags.IS_NODE&&(this.config.backend==="webgl"||this.config.backend==="humangl")&&(this.config.backend="tensorflow"),this.config.debug&&he("setting backend:",this.config.backend),this.config.backend==="wasm"){if(this.config.debug&&he("wasm path:",this.config.wasmPath),typeof((n=this.tf)==null?void 0:n.setWasmPaths)!="undefined")this.tf.setWasmPaths(this.config.wasmPath);else throw new Error("Human: WASM backend is not loaded");let r=await this.tf.env().getAsync("WASM_HAS_SIMD_SUPPORT"),s=await this.tf.env().getAsync("WASM_HAS_MULTITHREAD_SUPPORT");this.config.debug&&he(`wasm execution: ${r?"SIMD":"no SIMD"} ${s?"multithreaded":"singlethreaded"}`),this.config.debug&&!r&&he("warning: wasm simd support is not enabled")}this.config.backend==="humangl"&&nk();try{await this.tf.setBackend(this.config.backend)}catch(r){he("error: cannot set backend:",this.config.backend,r)}}if(this.tf.enableProdMode(),this.tf.getBackend()==="webgl"||this.tf.getBackend()==="humangl"){this.tf.ENV.set("CHECK_COMPUTATION_FOR_ERRORS",!1),this.tf.ENV.set("WEBGL_PACK_DEPTHWISECONV",!0),typeof this.config.deallocate!="undefined"&&(he("changing webgl: WEBGL_DELETE_TEXTURE_THRESHOLD:",!0),this.tf.ENV.set("WEBGL_DELETE_TEXTURE_THRESHOLD",0));let r=await this.tf.backend().getGPGPUContext().gl;this.config.debug&&he(`gl version:${r.getParameter(r.VERSION)} renderer:${r.getParameter(r.RENDERER)}`)}await this.tf.ready(),this.perf.backend=Math.trunc(it()-a)}});z0.set(this,async()=>{let t=(r,s="application/octet-stream")=>fetch(`data:${s};base64,${r}`).then(i=>i.blob()),n,a;switch(this.config.warmup){case"face":n=await t($0);break;case"full":n=await t(D0);break;default:n=null}if(n){let r=await createImageBitmap(n);a=await this.detect(r,this.config),r.close()}return a});_0.set(this,async()=>new Promise(t=>{let n,a=0;switch(this.config.warmup){case"face":a=256,n="data:image/jpeg;base64,"+$0;break;case"full":case"body":a=1200,n="data:image/jpeg;base64,"+D0;break;default:n=null}let r=new Image;r.onload=async()=>{let s=typeof OffscreenCanvas!="undefined"?new OffscreenCanvas(a,a):document.createElement("canvas");s.width=r.naturalWidth,s.height=r.naturalHeight;let i=s.getContext("2d");i==null||i.drawImage(r,0,0);let o=await this.detect(s,this.config);t(o)},n?r.src=n:t(null)}));P0.set(this,async()=>{let t=r=>Buffer.from(r,"base64"),n;if(this.config.warmup==="face"&&(n=t($0)),(this.config.warmup==="body"||this.config.warmup==="full")&&(n=t(D0)),!n)return null;let a;if(typeof void 0!="undefined"){let r=(void 0).decodeJpeg(n),s=r.expandDims(0);this.tf.dispose(r),a=await this.detect(s,this.config),this.tf.dispose(s)}else this.config.debug&&he("Warmup tfjs-node not loaded");return a});this.tf=pu,this.draw=kg,this.version=Kk,this.config=Hn(Xk,t),this.state="idle",as(this,Ql,0),as(this,Jd,!1),as(this,Qd,!1),as(this,Pi,!0),this.perf={},this.models={face:null,posenet:null,blazepose:null,efficientpose:null,handpose:null,iris:null,age:null,gender:null,emotion:null,embedding:null,nanodet:null,faceres:null},this.image=n=>wg(n,this.config),this.classes={facemesh:W2,emotion:U2,faceres:X2,body:this.config.body.modelPath.includes("posenet")?rg:fg,hand:pg,nanodet:yg},this.faceTriangulation=fk,this.faceUVMap=mk,this.sysinfo=Pg()}similarity(t,n){return Z2(t,n)}enhance(t){return Y2(t)}match(t,n,a=0){return Ak(t,n,a)}async load(t={}){this.state="load";let n=it();t&&(this.config=Hn(this.config,t)),na(this,Pi)&&(this.config.debug&&he(`version: ${this.version}`),this.config.debug&&he(`tfjs version: ${this.tf.version_core}`),this.config.debug&&he("platform:",this.sysinfo.platform),this.config.debug&&he("agent:",this.sysinfo.agent),await na(this,ep).call(this,!0),this.tf.ENV.flags.IS_BROWSER&&(this.config.debug&&he("configuration:",this.config),this.config.debug&&he("tf flags:",this.tf.ENV.flags))),this.config.async?[this.models.face,this.models.emotion,this.models.handpose,this.models.posenet,this.models.blazepose,this.models.nanodet,this.models.faceres]=await Promise.all([this.models.face||(this.config.face.enabled?j2(this.config):null),this.models.emotion||(this.config.face.enabled&&this.config.face.emotion.enabled?q2(this.config):null),this.models.handpose||(this.config.hand.enabled?hg(this.config):null),this.models.posenet||(this.config.body.enabled&&this.config.body.modelPath.includes("posenet")?ig(this.config):null),this.models.blazepose||(this.config.body.enabled&&this.config.body.modelPath.includes("blazepose")?mg(this.config):null),this.models.nanodet||(this.config.object.enabled?xg(this.config):null),this.models.faceres||(this.config.face.enabled&&this.config.face.description.enabled?K2(this.config):null)]):(this.config.face.enabled&&!this.models.face&&(this.models.face=await j2(this.config)),this.config.face.enabled&&this.config.face.emotion.enabled&&!this.models.emotion&&(this.models.emotion=await q2(this.config)),this.config.hand.enabled&&!this.models.handpose&&(this.models.handpose=await hg(this.config)),this.config.body.enabled&&!this.models.posenet&&this.config.body.modelPath.includes("posenet")&&(this.models.posenet=await ig(this.config)),this.config.body.enabled&&!this.models.blazepose&&this.config.body.modelPath.includes("blazepose")&&(this.models.blazepose=await mg(this.config)),this.config.object.enabled&&!this.models.nanodet&&(this.models.nanodet=await xg(this.config)),this.config.face.enabled&&this.config.face.description.enabled&&!this.models.faceres&&(this.models.faceres=await K2(this.config))),na(this,Pi)&&(this.config.debug&&he("tf engine state:",this.tf.engine().state.numBytes,"bytes",this.tf.engine().state.numTensors,"tensors"),as(this,Pi,!1));let a=Math.trunc(it()-n);a>(this.perf.load||0)&&(this.perf.load=a)}async detect(t,n={}){return new Promise(async a=>{this.state="config";let r;this.config=Hn(this.config,n),this.state="check";let s=na(this,O0).call(this,t);s&&(he(s,t),a({error:s}));let i=it();await na(this,ep).call(this),await this.load();let o;t&&this.config.videoOptimized&&typeof window!="undefined"&&typeof WorkerGlobalScope!="undefined"&&(typeof HTMLImageElement!="undefined"&&t instanceof HTMLImageElement||typeof Image!="undefined"&&t instanceof Image||typeof ImageData!="undefined"&&t instanceof ImageData||typeof ImageBitmap!="undefined"&&vg instanceof ImageBitmap)&&(he("disabling video optimization"),o=this.config.videoOptimized,this.config.videoOptimized=!1),r=it();let l=wg(t,this.config);if(!l||!l.tensor){he("could not convert input to tensor"),a({error:"could not convert input to tensor"});return}this.perf.image=Math.trunc(it()-r),this.analyze("Get Image:");let d,u,p,c,h;this.config.async?(p=this.config.face.enabled?J2(this,l.tensor):[],this.perf.face&&delete this.perf.face):(this.state="run:face",r=it(),p=this.config.face.enabled?await J2(this,l.tensor):[],h=Math.trunc(it()-r),h>0&&(this.perf.face=h)),this.analyze("Start Body:"),this.config.async?(this.config.body.modelPath.includes("posenet")?d=this.config.body.enabled?sg(l.tensor,this.config):[]:this.config.body.modelPath.includes("blazepose")&&(d=this.config.body.enabled?Ag(l.tensor,this.config):[]),this.perf.body&&delete this.perf.body):(this.state="run:body",r=it(),this.config.body.modelPath.includes("posenet")?d=this.config.body.enabled?await sg(l.tensor,this.config):[]:this.config.body.modelPath.includes("blazepose")&&(d=this.config.body.enabled?await Ag(l.tensor,this.config):[]),h=Math.trunc(it()-r),h>0&&(this.perf.body=h)),this.analyze("End Body:"),this.analyze("Start Hand:"),this.config.async?(u=this.config.hand.enabled?cg(l.tensor,this.config):[],this.perf.hand&&delete this.perf.hand):(this.state="run:hand",r=it(),u=this.config.hand.enabled?await cg(l.tensor,this.config):[],h=Math.trunc(it()-r),h>0&&(this.perf.hand=h)),this.analyze("End Hand:"),this.analyze("Start Object:"),this.config.async?(c=this.config.object.enabled?bg(l.tensor,this.config):[],this.perf.object&&delete this.perf.object):(this.state="run:object",r=it(),c=this.config.object.enabled?await bg(l.tensor,this.config):[],h=Math.trunc(it()-r),h>0&&(this.perf.object=h)),this.analyze("End Object:"),this.config.async&&([p,d,u,c]=await Promise.all([p,d,u,c])),Ee(l.tensor);let m=[];this.config.gesture.enabled&&(r=it(),m=[...Lk(p),...Pk(d),...Bk(u),...Wk(p)],this.config.async?this.perf.gesture&&delete this.perf.gesture:this.perf.gesture=Math.trunc(it()-r)),o&&(this.config.videoOptimized=o),this.perf.total=Math.trunc(it()-i),this.state="idle";let f={face:p,body:d,hand:u,gesture:m,object:c,performance:this.perf,canvas:l.canvas};a(f)})}async warmup(t={}){let n=it();if(t&&(this.config=Hn(this.config,t)),!this.config.warmup||this.config.warmup==="none")return{error:"null"};let a=this.config.videoOptimized;this.config.videoOptimized=!1;let r;typeof createImageBitmap=="function"?r=await na(this,z0).call(this):typeof Image!="undefined"?r=await na(this,_0).call(this):r=await na(this,P0).call(this),this.config.videoOptimized=a;let s=it();return this.config.debug&&he("Warmup",this.config.warmup,Math.round(s-n),"ms",r),r}};Ql=new WeakMap,Jd=new WeakMap,Qd=new WeakMap,Pi=new WeakMap,O0=new WeakMap,ep=new WeakMap,z0=new WeakMap,_0=new WeakMap,P0=new WeakMap;export{Zie as Human,Zie as default}; /** * @license * Copyright 2017 Google LLC. All Rights Reserved. diff --git a/dist/human.esm.js.map b/dist/human.esm.js.map index d20ed570..d7a14781 100644 --- a/dist/human.esm.js.map +++ b/dist/human.esm.js.map @@ -1,7 +1,7 @@ { "version": 3, "sources": ["../src/helpers.ts", "../src/sysinfo.ts", "../node_modules/.pnpm/node-fetch@2.6.1/node_modules/node-fetch/browser.js", "../node_modules/.pnpm/seedrandom@2.4.3/node_modules/seedrandom/lib/alea.js", "../node_modules/.pnpm/seedrandom@2.4.3/node_modules/seedrandom/lib/xor128.js", "../node_modules/.pnpm/seedrandom@2.4.3/node_modules/seedrandom/lib/xorwow.js", "../node_modules/.pnpm/seedrandom@2.4.3/node_modules/seedrandom/lib/xorshift7.js", "../node_modules/.pnpm/seedrandom@2.4.3/node_modules/seedrandom/lib/xor4096.js", "../node_modules/.pnpm/seedrandom@2.4.3/node_modules/seedrandom/lib/tychei.js", "(disabled):crypto", "../node_modules/.pnpm/seedrandom@2.4.3/node_modules/seedrandom/seedrandom.js", "../node_modules/.pnpm/seedrandom@2.4.3/node_modules/seedrandom/index.js", "(disabled):path", "(disabled):worker_threads", "(disabled):perf_hooks", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm.js", "../node_modules/.pnpm/seedrandom@3.0.5/node_modules/seedrandom/lib/alea.js", "../node_modules/.pnpm/seedrandom@3.0.5/node_modules/seedrandom/lib/xor128.js", "../node_modules/.pnpm/seedrandom@3.0.5/node_modules/seedrandom/lib/xorwow.js", "../node_modules/.pnpm/seedrandom@3.0.5/node_modules/seedrandom/lib/xorshift7.js", "../node_modules/.pnpm/seedrandom@3.0.5/node_modules/seedrandom/lib/xor4096.js", "../node_modules/.pnpm/seedrandom@3.0.5/node_modules/seedrandom/lib/tychei.js", "../node_modules/.pnpm/seedrandom@3.0.5/node_modules/seedrandom/seedrandom.js", "../node_modules/.pnpm/seedrandom@3.0.5/node_modules/seedrandom/index.js", "../node_modules/.pnpm/string_decoder@1.1.1/node_modules/string_decoder/lib/string_decoder.js", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/backends/backend.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/util_base.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/environment.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/global_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/kernel_names.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/kernel_registry.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/profiler.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/tape.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/tensor_format.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/tensor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/tensor_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/types.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/engine.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/device_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/flags.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/tensor_util_env.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/operation.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/complex.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/tensor_ops_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/tensor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/io/types.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/io/io_utils.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/io/router_registry.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/io/indexed_db.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/io/local_storage.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/io/model_management.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/platforms/platform_browser.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/platforms/platform_node.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/buffer.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/cast.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/clone.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/print.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/base_side_effects.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/io/io.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/io/browser_files.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/io/progress.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/io/weights_loader.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/io/http.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/io/passthrough.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/math.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/mat_mul.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/one_hot.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/transpose.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/confusion_matrix.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/browser.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/tensor3d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/gather_nd_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/scatter_nd_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/slice_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/serialization.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/test_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/version.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/globals.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/add.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/floorDiv.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/div.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/mul.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/abs.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/acos.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/acosh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/add_n.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/all.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/any.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/arg_max.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/arg_min.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/asin.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/asinh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/atan.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/atan2.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/atanh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/conv_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/reshape.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/avg_pool.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/avg_pool_3d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/concat.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/sigmoid.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/slice.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/tanh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/basic_lstm_cell.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/batch_to_space_nd.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/batchnorm_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/batchnorm.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/batchnorm2d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/batchnorm3d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/batchnorm4d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/bincount.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/broadcast_to.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/ceil.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/clip_by_value.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/concat_1d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/concat_2d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/concat_3d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/concat_4d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/conv2d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/conv1d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/conv2d_backprop_input.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/conv2d_transpose.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/conv3d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/conv3d_backprop_input.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/conv3d_transpose.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/cos.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/cosh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/cumsum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/dense_bincount.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/depth_to_space.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/depthwise_conv2d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/diag.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/dilation2d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/broadcast_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/equal.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/where.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/zeros_like.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/div_no_nan.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/dot.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/einsum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/elu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/erf.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/exp.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/expand_dims.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/expm1.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/tile.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/eye.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/fill.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/floor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/gather.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/greater.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/greater_equal.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/imag.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/is_finite.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/is_inf.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/is_nan.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/leaky_relu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/less.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/less_equal.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/linspace.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/local_response_normalization.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/log.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/log1p.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/neg.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/softplus.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/log_sigmoid.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/max.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/sub.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/sum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/log_softmax.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/axis_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/log_sum_exp.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/logical_and.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/logical_not.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/logical_or.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/logical_xor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/max_pool.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/max_pool_3d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/max_pool_with_argmax.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/maximum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/mean.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/zeros.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/ones.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/meshgrid.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/min.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/minimum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/mirror_pad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/mod.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/square.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/moments.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/multi_rnn_cell.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/multinomial.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/not_equal.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/ones_like.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/outer_product.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/pad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/pad1d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/pad2d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/pad3d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/pad4d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/space_to_batch_nd.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/pool.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/pow.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/prelu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/prod.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/rand.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/rand_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/random_gamma.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/random_normal.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/random_uniform.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/range.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/real.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/reciprocal.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/relu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/relu6.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/reverse.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/reverse_1d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/reverse_2d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/reverse_3d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/reverse_4d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/round.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/rsqrt.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/scalar.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/selu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/separable_conv2d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/setdiff1d_async.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/sign.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/sin.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/sinh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/slice1d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/slice2d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/slice3d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/slice4d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/softmax.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/spectral/fft.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/spectral/ifft.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/spectral/irfft.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/split.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/spectral/rfft.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/sqrt.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/squared_difference.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/squeeze.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/stack.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/step.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/strided_slice.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/tan.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/tensor1d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/tensor2d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/tensor4d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/tensor5d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/tensor6d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/topk.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/truncated_normal.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/unique.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/unsorted_segment_sum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/unstack.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/variable.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/backends/where_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/where_async.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/boolean_mask.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/norm.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/moving_average.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/scatter_nd.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/sparse_to_dense_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/sparse_to_dense.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/gather_nd.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/dropout_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/dropout.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/signal_ops_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/in_top_k.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/fused_ops.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/conv2d_backprop_filter.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/fused_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/fused/conv2d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/depthwise_conv2d_native_backprop_filter.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/depthwise_conv2d_native_backprop_input.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/fused/depthwise_conv2d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/fused/mat_mul.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/signal/hamming_window.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/signal/hann_window.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/signal/frame.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/signal/stft.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/image/crop_and_resize.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/image/flip_left_right.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/image/rotate_with_offset.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/nonmax_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/image/non_max_suppression.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/backends/non_max_suppression_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/backends/non_max_suppression_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/image/non_max_suppression_async.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/image/non_max_suppression_with_score.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/image/non_max_suppression_with_score_async.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/image/non_max_suppression_padded.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/image/non_max_suppression_padded_async.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/image/resize_bilinear.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/image/resize_nearest_neighbor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/image/threshold.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/image/transform.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/linalg/band_part.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/linalg/gram_schmidt.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/linalg/qr.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/loss_ops_utils.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/losses/compute_weighted_loss.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/losses/absolute_difference.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/losses/cosine_distance.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/losses/hinge_loss.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/losses/huber_loss.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/losses/log_loss.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/losses/mean_squared_error.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/losses/sigmoid_cross_entropy.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/losses/softmax_cross_entropy.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/sparse/sparse_fill_empty_rows.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/sparse/sparse_reshape.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/ops.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/optimizers/optimizer.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/optimizers/adadelta_optimizer.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/optimizers/adagrad_optimizer.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/optimizers/adam_optimizer.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/optimizers/adamax_optimizer.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/optimizers/sgd_optimizer.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/optimizers/momentum_optimizer.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/optimizers/rmsprop_optimizer.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/optimizers/optimizer_constructors.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/train.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/browser_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/backends/backend_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/concat_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/reduce_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/rotate_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/array_ops_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/selu_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/erf_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/log.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/backends/complex_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/backends/einsum_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/split_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/segment_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/backends/kernel_impls.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/base.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/index.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/cpu_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/backend_cpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/shared.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Abs.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/utils/binary_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Complex.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/utils/zeros_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Identity.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Real.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Cast.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/utils/binary_utils.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Add.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Bincount_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/utils/unary_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/utils/unary_utils.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Ceil.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Concat_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Exp.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Expm1.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Floor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/GatherV2_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Greater.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Less.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/LinSpace_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Log.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Max_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Maximum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Minimum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Multiply.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Neg.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/NotEqual.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Transpose_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Transpose.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Prod.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Range_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Rsqrt.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Slice.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/SparseFillEmptyRows_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/SparseReshape_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/SquaredDifference.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/StridedSlice_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Sub.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Tile_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/TopK_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Unique_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/version.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/base.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Elu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/LeakyRelu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Prelu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Relu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Relu6.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Sigmoid.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/utils/fused_utils.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Reshape.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/BatchMatMul.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/_FusedMatMul.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Acos.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Acosh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/AddN.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/All.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Any.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/ArgMax.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/ArgMin.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Asin.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Asinh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Atan.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Atan2.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Atanh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/utils/pool_utils.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/AvgPool.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/AvgPool3D.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/AvgPool3DGrad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/AvgPoolGrad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/BatchNorm.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/BatchToSpaceND.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Bincount.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Clip.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/ComplexAbs.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Imag.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Concat.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Conv2D.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Conv2DBackpropFilter.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Conv2DBackpropInput.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Conv3D.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Conv3DBackpropFilterV2.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Conv3DBackpropInputV2.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Cos.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Cosh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/CropAndResize.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Cumsum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/DenseBincount.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/DepthToSpace.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/DepthwiseConv2dNative.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/DepthwiseConv2dNativeBackpropFilter.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/DepthwiseConv2dNativeBackpropInput.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Diag.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Dilation2D.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Dilation2DBackpropFilter.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Dilation2DBackpropInput.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Sum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Einsum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/EluGrad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Equal.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Erf.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/ExpandDims.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/RealDiv.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/utils/fft_utils.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/FFT.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Fill.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/FlipLeftRight.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/FloorDiv.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/FusedConv2D.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/FusedDepthwiseConv2D.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/GatherNd.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/GatherV2.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/GreaterEqual.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/IFFT.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/IsFinite.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/IsInf.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/IsNaN.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/LessEqual.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/LinSpace.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Log1p.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/LogicalAnd.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/LogicalNot.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/LogicalOr.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/LRN.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/LRNGrad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Max.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/MaxPool.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/MaxPool3D.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/MaxPool3DGrad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/MaxPoolGrad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/MaxPoolWithArgmax_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/MaxPoolWithArgmax.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Mean.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Min.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/MirrorPad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Mod.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Multinomial.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Softmax.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/NonMaxSuppressionV3.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/NonMaxSuppressionV4.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/NonMaxSuppressionV5.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/OneHot.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/ZerosLike.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/OnesLike.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Pack.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/PadV2.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Pow.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Range.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Reciprocal.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/ResizeBilinear.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/ResizeBilinearGrad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/ResizeNearestNeighbor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/ResizeNearestNeighborGrad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Reverse.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/RotateWithOffset.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Round.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Scatter_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/ScatterNd.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Select.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Selu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Sign.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Sin.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Sinh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Softplus.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/SpaceToBatchND.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/SparseFillEmptyRows.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/SparseReshape.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/SparseToDense.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/SplitV.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Sqrt.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Square.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Step.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/StridedSlice.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Tan.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Tanh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Tile.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/TopK.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Transform.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Unique.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/Unpack.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/kernels/UnsortedSegmentSum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/register_all_kernels.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-cpu@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-cpu/src/index.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/webgl_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/canvas_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/tex_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/flags_webgl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/glsl_version.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/shader_compiler_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/decode_matrix_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/decode_matrix_packed_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/encode_float_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/encode_float_packed_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/encode_matrix_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/encode_matrix_packed_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/gpgpu_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/gpgpu_context.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/shader_compiler.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/gpgpu_math.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernel_utils/shared.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/packing_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/pack_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/reshape_packed_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/texture_manager.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/unaryop_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/unaryop_packed_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/unpack_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/backend_webgl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/version.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/webgl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/base.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/binaryop_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/binaryop_packed_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Identity.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Complex.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/LeakyRelu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Prelu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernel_utils/kernel_funcs_utils.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/mulmat_packed_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/binaryop_complex_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Multiply.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernel_utils/reshape.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Reshape.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/mean_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/reduce_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernel_utils/reduce.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/transpose_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/transpose_packed_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Transpose_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Sum_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Sum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Transpose.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/BatchMatMul_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/_FusedMatMul.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Abs.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Acos.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Acosh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Add.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/addn_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/addn_packed_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/AddN.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/All.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Any.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/argminmax_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/argminmax_packed_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernel_utils/arg_min_max.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/ArgMax.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/ArgMin.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Asin.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Asinh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Atan.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Atan2.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Atanh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/pool_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/AvgPool.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/AvgPool3D.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/avg_pool_backprop_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/AvgPool3DGrad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/AvgPoolGrad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/BatchMatMul.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/batchnorm_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/batchnorm_packed_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/BatchNorm.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/slice_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/slice_packed_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Slice.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/BatchToSpaceND.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Bincount.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/NotEqual.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Real.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernel_utils/int.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Cast.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Ceil.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/clip_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/clip_packed_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/ClipByValue.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/complex_abs_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/ComplexAbs.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/concat_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/concat_packed_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Imag.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Concat_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Concat.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/conv_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/im2col_packed_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Conv2D_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Conv2D.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/conv_backprop_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Conv2DBackpropFilter.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Conv2DBackpropInput.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Conv3D.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Conv3DBackpropFilterV2.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Conv3DBackpropInputV2.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Cos.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Cosh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/crop_and_resize_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/CropAndResize.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/cumsum_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Cumsum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/DenseBincount.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/depth_to_space_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/DepthToSpace.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/conv_gpu_depthwise.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/conv_packed_gpu_depthwise.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/DepthwiseConv2dNative.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/conv_backprop_gpu_depthwise.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/DepthwiseConv2dNativeBackpropFilter.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/DepthwiseConv2dNativeBackpropInput.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/diag_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Diag.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/dilation_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Dilation2D.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Einsum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Elu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/EluGrad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Equal.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Erf.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Exp.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/ExpandDims.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Expm1.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/fft_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/FFT_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/FFT.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/fill_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Fill.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/flip_left_right_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/FlipLeftRight.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Floor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/FloorDiv.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/FromPixels_utils/from_pixels_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/FromPixels_utils/from_pixels_packed_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/FromPixels.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/FusedConv2D.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/FusedDepthwiseConv2D.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/gather_nd_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/GatherNd.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/gather_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/GatherV2.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Greater.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/GreaterEqual.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/IFFT.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/IsFinite.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/IsInf.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/IsNaN.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Less.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/LessEqual.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/LinSpace.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Log.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Log1p.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/LogicalAnd.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/LogicalNot.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/LogicalOr.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/lrn_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/lrn_packed_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/LRN.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/lrn_grad_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/LRNGrad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Max_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Max.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Maximum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/MaxPool.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/MaxPool3D.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/max_pool_backprop_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/MaxPool3DGrad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/MaxPoolGrad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/MaxPoolWithArgmax_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/MaxPoolWithArgmax.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Mean_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Mean.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Min.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Minimum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/mirror_pad_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/mirror_pad_packed_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/MirrorPad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Mod.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/multinomial_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/RealDiv.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Sub.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Softmax.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Multinomial.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Neg.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/NonMaxSuppressionV3.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/NonMaxSuppressionV4.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/NonMaxSuppressionV5.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/onehot_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/OneHot.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/ZerosLike.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/OnesLike.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Pack.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/pad_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/pad_packed_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/PadV2.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Pow.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Prod.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Range.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Reciprocal.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Relu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Relu6.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/resize_bilinear_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/resize_bilinear_packed_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/ResizeBilinear.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/resize_bilinear_backprop_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/ResizeBilinearGrad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/resize_nearest_neighbor_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/resize_nearest_neighbor_packed_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/ResizeNearestNeighbor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/resize_nearest_neighbor_backprop_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/ResizeNearestNeighborGrad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/reverse_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/reverse_packed_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Reverse.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/rotate_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/RotateWithOffset.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Round.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Rsqrt.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/scatter_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/ScatterNd.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/select_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Select.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Selu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Sigmoid.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Sign.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Sin.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Sinh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Softplus.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/SpaceToBatchND.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/SparseFillEmptyRows.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/SparseReshape.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/SparseToDense.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/SplitV.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Sqrt.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Square.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/SquaredDifference.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Step.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/strided_slice_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/StridedSlice.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Tan.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Tanh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/tile_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Tile.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/TopK.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/transform_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Transform.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Unique.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/Unpack.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/segment_gpu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/kernels/UnsortedSegmentSum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/register_all_kernels.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-webgl@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-webgl/src/index.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/types.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/_FusedMatMul.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/unary_kernel.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Abs.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/binary_kernel.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Add.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/AddN.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Identity.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Transpose.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/kernel_utils.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/All.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Any.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/ArgMax.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/AvgPool.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Reshape.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/BatchMatMul.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Cast.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Ceil.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/ClipByValue.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernel_utils/shared.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Concat.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Conv2D.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Conv2DBackpropInput.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Cos.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/CropAndResize.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Cumsum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/DepthToSpace.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/DepthwiseConv2dNative.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Equal.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Exp.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/ExpandDims.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Fill.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/FlipLeftRight.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Floor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/FloorDiv.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/FusedBatchNorm.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/FusedConv2D.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/FusedDepthwiseConv2D.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/GatherNd.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/GatherV2.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Greater.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/GreaterEqual.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/LeakyRelu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Less.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/LessEqual.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Log.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/LogicalAnd.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Max.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Maximum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/MaxPool.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Mean.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Min.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Minimum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/MirrorPad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Multiply.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Neg.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/NonMaxSuppression_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/NonMaxSuppressionV3.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/NonMaxSuppressionV4.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/NonMaxSuppressionV5.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/NotEqual.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/OneHot.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/OnesLike.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Pack.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/PadV2.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Pow.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Prelu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Prod.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Range.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/RealDiv.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Relu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Relu6.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/ResizeBilinear.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Reverse.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/RotateWithOffset.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Round.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Rsqrt.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/ScatterNd.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Select.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Sigmoid.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Sin.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Slice.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Softmax.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/SplitV.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Sqrt.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Square.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/SquaredDifference.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Step.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/StridedSlice.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Sub.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Sum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Tan.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Tanh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Tile.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/TopK.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Transform.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/Unpack.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/kernels/ZerosLike.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/register_all_kernels.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/flags_wasm.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/backend_wasm.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.worker.js", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/version.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/base.ts", "../node_modules/.pnpm/@tensorflow+tfjs-backend-wasm@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-backend-wasm/src/index.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/abs.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/acos.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/acosh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/add.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/all.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/any.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/arg_max.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/arg_min.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/as_scalar.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/as_type.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/as1d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/as2d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/as3d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/as4d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/as5d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/asin.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/asinh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/atan.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/atan2.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/atanh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/avg_pool.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/batch_to_space_nd.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/batchnorm.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/broadcast_to.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/cast.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/ceil.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/clip_by_value.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/concat.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/conv1d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/conv2d_transpose.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/conv2d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/cos.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/cosh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/cumsum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/depth_to_space.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/depthwise_conv2d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/dilation2d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/div_no_nan.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/div.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/dot.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/elu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/equal.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/erf.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/exp.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/expand_dims.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/expm1.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/fft.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/flatten.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/floor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/floorDiv.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/gather.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/greater_equal.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/greater.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/ifft.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/irfft.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/is_finite.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/is_inf.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/is_nan.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/leaky_relu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/less_equal.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/less.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/local_response_normalization.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/log_sigmoid.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/log_softmax.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/log_sum_exp.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/log.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/log1p.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/logical_and.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/logical_not.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/logical_or.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/logical_xor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/mat_mul.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/max_pool.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/max.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/maximum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/mean.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/min.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/minimum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/mirror_pad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/mod.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/mul.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/neg.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/norm.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/not_equal.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/one_hot.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/ones_like.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/pad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/pool.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/pow.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/prelu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/prod.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/reciprocal.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/relu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/relu6.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/reshape_as.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/reshape.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/resize_bilinear.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/resize_nearest_neighbor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/reverse.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/rfft.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/round.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/rsqrt.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/selu.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/separable_conv2d.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/sigmoid.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/sign.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/sin.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/sinh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/slice.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/softmax.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/softplus.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/space_to_batch_nd.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/split.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/sqrt.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/square.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/squared_difference.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/squeeze.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/stack.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/step.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/strided_slice.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/sub.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/sum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/tan.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/tanh.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/tile.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/to_bool.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/to_float.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/to_int.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/topk.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/transpose.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/unique.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/unsorted_segment_sum.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/unstack.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/where.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/zeros_like.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/public/chained_ops/register_all_chained_ops.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Abs_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Acos_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Acosh_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Add_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/AddN_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/ArgMax_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/ArgMin_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Asin_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Asinh_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Atan2_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Atan_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Atanh_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/avg_pool_3d_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/AvgPool3D_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/avg_pool_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/AvgPool_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/BatchMatMul_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/BatchToSpaceND_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/BroadcastTo_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Cast_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Ceil_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/ClipByValue_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/ComplexAbs_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Concat_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Conv2D_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Conv2DBackpropInput_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/conv3d_backprop_filter.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Conv3D_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Cos_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Cosh_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Cumsum_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/DepthwiseConv2dNative_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Dilation2D_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Elu_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Erf_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Exp_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/ExpandDims_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Expm1_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Floor_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/FloorDiv_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/FusedBatchNorm_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/GatherV2_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/GreaterEqual_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Identity_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/IsFinite_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/IsInf_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/IsNan_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/LeakyRelu_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Log1p_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Log_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/LogSoftmax_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/local_response_normalization_backprop.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/LRN_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/min_max_grad_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Max_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Maximum_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/max_pool_3d_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/MaxPool3D_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/ops/max_pool_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/MaxPool_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Mean_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Min_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Minimum_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/MirrorPad_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Mod_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Multiply_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Neg_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/OneHot_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/OnesLike_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Pack_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/PadV2_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Pow_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Prelu_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/RealDiv_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Reciprocal_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Relu6_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Relu_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Reshape_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/ResizeBilinear_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/ResizeNearestNeighbor_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Reverse_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Round_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Rsqrt_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Select_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Selu_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Sigmoid_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Sign_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Sin_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Sinh_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Slice_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Softmax_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Softplus_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/SpaceToBatchND_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/SplitV_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Sqrt_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Square_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/SquaredDifference_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Step_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Sub_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Sum_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Tan_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Tanh_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Tile_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Transpose_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/Unpack_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/UnsortedSegmentSum_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/gradients/ZerosLike_grad.ts", "../node_modules/.pnpm/@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-core/src/register_all_gradients.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/exports_constraints.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/backend/common.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/errors.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/utils/generic_utils.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/constraints.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/exports_initializers.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/keras_format/common.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/common.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/utils/math_utils.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/backend/tfjs_backend.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/keras_format/initializer_config.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/initializers.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/exports_layers.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/backend/state.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/utils/types_utils.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/utils/variable_utils.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/variables.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/engine/topology.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/engine/input_layer.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/logs.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/base_callbacks.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/layers/serialization.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/losses.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/metrics.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/optimizers.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/user_defined_metadata.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/utils/layer_utils.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/utils/serialization_utils.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/version.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/engine/executor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/engine/container.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/engine/training_utils.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/engine/training_dataset.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/engine/training_tensors.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/engine/training.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/models.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/exports.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/activations.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/regularizers.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/layers/advanced_activations.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/utils/conv_utils.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/layers/convolutional.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/layers/convolutional_depthwise.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/layers/recurrent.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/layers/convolutional_recurrent.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/layers/core.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/layers/embeddings.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/layers/merge.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/layers/noise.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/layers/normalization.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/layers/padding.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/layers/pooling.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/layers/wrappers.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/exports_metrics.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/exports_models.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/exports_regularizers.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/callbacks.ts", "../node_modules/.pnpm/@tensorflow+tfjs-layers@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-layers/src/index.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/data/compiled_api.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/custom_op/register.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/executors/utils.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/op_list/arithmetic.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/op_list/basic_math.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/op_list/control.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/op_list/convolution.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/op_list/creation.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/op_list/dynamic.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/op_list/evaluation.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/op_list/graph.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/op_list/hash_table.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/op_list/image.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/op_list/logical.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/op_list/matrices.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/op_list/normalization.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/op_list/reduction.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/op_list/slice_join.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/op_list/spectral.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/op_list/transformation.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/operation_mapper.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/custom_op/node_value_impl.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/executors/arithmetic_executor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/executors/basic_math_executor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/executor/tensor_utils.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/executor/tensor_array.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/executor/tensor_list.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/executors/control_executor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/executors/convolution_executor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/executors/creation_executor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/executors/dynamic_executor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/executors/evaluation_executor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/executors/graph_executor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/executor/hash_table.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/executors/hash_table_executor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/executors/image_executor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/executors/logical_executor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/executors/matrices_executor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/executors/normalization_executor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/executors/reduction_executor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/executors/slice_join_executor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/executors/sparse_executor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/executors/spectral_executor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/executors/transformation_executor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/operations/operation_executor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/executor/execution_context.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/executor/model_analysis.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/executor/graph_executor.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/executor/resource_manager.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/executor/graph_model.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/version.ts", "../node_modules/.pnpm/@tensorflow+tfjs-converter@3.6.0_@tensorflow+tfjs-core@3.6.0/node_modules/@tensorflow/tfjs-converter/src/index.ts", "../node_modules/.pnpm/@tensorflow+tfjs-data@3.6.0_5706159424f1774d88b030214a8dd243/node_modules/@tensorflow/tfjs-data/src/index.ts", "../node_modules/.pnpm/@tensorflow+tfjs-data@3.6.0_5706159424f1774d88b030214a8dd243/node_modules/@tensorflow/tfjs-data/src/dataset.ts", "../node_modules/.pnpm/@tensorflow+tfjs-data@3.6.0_5706159424f1774d88b030214a8dd243/node_modules/@tensorflow/tfjs-data/src/iterators/lazy_iterator.ts", "../node_modules/.pnpm/@tensorflow+tfjs-data@3.6.0_5706159424f1774d88b030214a8dd243/node_modules/@tensorflow/tfjs-data/src/util/deep_map.ts", "../node_modules/.pnpm/@tensorflow+tfjs-data@3.6.0_5706159424f1774d88b030214a8dd243/node_modules/@tensorflow/tfjs-data/src/util/deep_clone.ts", "../node_modules/.pnpm/@tensorflow+tfjs-data@3.6.0_5706159424f1774d88b030214a8dd243/node_modules/@tensorflow/tfjs-data/src/util/ring_buffer.ts", "../node_modules/.pnpm/@tensorflow+tfjs-data@3.6.0_5706159424f1774d88b030214a8dd243/node_modules/@tensorflow/tfjs-data/src/util/growing_ring_buffer.ts", "../node_modules/.pnpm/@tensorflow+tfjs-data@3.6.0_5706159424f1774d88b030214a8dd243/node_modules/@tensorflow/tfjs-data/src/datasets/text_line_dataset.ts", "../node_modules/.pnpm/@tensorflow+tfjs-data@3.6.0_5706159424f1774d88b030214a8dd243/node_modules/@tensorflow/tfjs-data/src/datasets/csv_dataset.ts", "../node_modules/.pnpm/@tensorflow+tfjs-data@3.6.0_5706159424f1774d88b030214a8dd243/node_modules/@tensorflow/tfjs-data/src/iterators/microphone_iterator.ts", "../node_modules/.pnpm/@tensorflow+tfjs-data@3.6.0_5706159424f1774d88b030214a8dd243/node_modules/@tensorflow/tfjs-data/src/iterators/webcam_iterator.ts", "../node_modules/.pnpm/@tensorflow+tfjs-data@3.6.0_5706159424f1774d88b030214a8dd243/node_modules/@tensorflow/tfjs-data/src/datasource.ts", "../node_modules/.pnpm/@tensorflow+tfjs-data@3.6.0_5706159424f1774d88b030214a8dd243/node_modules/@tensorflow/tfjs-data/src/iterators/string_iterator.ts", "../node_modules/.pnpm/@tensorflow+tfjs-data@3.6.0_5706159424f1774d88b030214a8dd243/node_modules/@tensorflow/tfjs-data/src/iterators/byte_chunk_iterator.ts", "../node_modules/.pnpm/@tensorflow+tfjs-data@3.6.0_5706159424f1774d88b030214a8dd243/node_modules/@tensorflow/tfjs-data/src/iterators/file_chunk_iterator.ts", "../node_modules/.pnpm/@tensorflow+tfjs-data@3.6.0_5706159424f1774d88b030214a8dd243/node_modules/@tensorflow/tfjs-data/src/iterators/url_chunk_iterator.ts", "../node_modules/.pnpm/@tensorflow+tfjs-data@3.6.0_5706159424f1774d88b030214a8dd243/node_modules/@tensorflow/tfjs-data/src/util/source_util.ts", "../node_modules/.pnpm/@tensorflow+tfjs-data@3.6.0_5706159424f1774d88b030214a8dd243/node_modules/@tensorflow/tfjs-data/src/sources/file_data_source.ts", "../node_modules/.pnpm/@tensorflow+tfjs-data@3.6.0_5706159424f1774d88b030214a8dd243/node_modules/@tensorflow/tfjs-data/src/sources/url_data_source.ts", "../node_modules/.pnpm/@tensorflow+tfjs-data@3.6.0_5706159424f1774d88b030214a8dd243/node_modules/@tensorflow/tfjs-data/src/readers.ts", "../node_modules/.pnpm/@tensorflow+tfjs-data@3.6.0_5706159424f1774d88b030214a8dd243/node_modules/@tensorflow/tfjs-data/src/version.ts", "../src/tfjs/tf-browser.ts", "../src/tfjs/backend.ts", "../src/blazeface/facemesh.ts", "../src/blazeface/box.ts", "../src/blazeface/util.ts", "../src/blazeface/blazeface.ts", "../src/blazeface/coords.ts", "../src/blazeface/facepipeline.ts", "../src/emotion/emotion.ts", "../src/faceres/faceres.ts", "../src/faceall.ts", "../src/posenet/posenet.ts", "../src/posenet/keypoints.ts", "../src/posenet/utils.ts", "../src/posenet/poses.ts", "../src/handpose/handpose.ts", "../src/handpose/box.ts", "../src/handpose/anchors.ts", "../src/handpose/handdetector.ts", "../src/handpose/util.ts", "../src/handpose/handpipeline.ts", "../src/blazepose/blazepose.ts", "../src/blazepose/annotations.ts", "../src/nanodet/nanodet.ts", "../src/nanodet/labels.ts", "../src/gesture/gesture.ts", "../src/image/image.ts", "../src/image/imagefx.js", "../src/draw/draw.ts", "../src/config.ts", "../src/sample.ts", "../src/human.ts"], - "sourcesContent": ["// helper function: join two paths\nexport function join(folder: string, file: string): string {\n const separator = folder.endsWith('/') ? '' : '/';\n const skipJoin = file.startsWith('.') || file.startsWith('/') || file.startsWith('http:') || file.startsWith('https:') || file.startsWith('file:');\n const path = skipJoin ? `${file}` : `${folder}${separator}${file}`;\n if (!path.toLocaleLowerCase().includes('.json')) throw new Error(`Human: ModelPath Error: ${path} Expecting JSON file`);\n return path;\n}\n\n// helper function: wrapper around console output\nexport function log(...msg) {\n const dt = new Date();\n const ts = `${dt.getHours().toString().padStart(2, '0')}:${dt.getMinutes().toString().padStart(2, '0')}:${dt.getSeconds().toString().padStart(2, '0')}.${dt.getMilliseconds().toString().padStart(3, '0')}`;\n // eslint-disable-next-line no-console\n if (msg) console.log(ts, 'Human:', ...msg);\n}\n\n// helper function: gets elapsed time on both browser and nodejs\nexport const now = () => {\n if (typeof performance !== 'undefined') return performance.now();\n return parseInt((Number(process.hrtime.bigint()) / 1000 / 1000).toString());\n};\n\n// helper function: perform deep merge of multiple objects so it allows full inheriance with overrides\nexport function mergeDeep(...objects) {\n const isObject = (obj) => obj && typeof obj === 'object';\n return objects.reduce((prev, obj) => {\n Object.keys(obj || {}).forEach((key) => {\n const pVal = prev[key];\n const oVal = obj[key];\n if (Array.isArray(pVal) && Array.isArray(oVal)) prev[key] = pVal.concat(...oVal);\n else if (isObject(pVal) && isObject(oVal)) prev[key] = mergeDeep(pVal, oVal);\n else prev[key] = oVal;\n });\n return prev;\n }, {});\n}\n", "export function info(): { platform: string, agent: string } {\n let platform;\n let agent;\n if (typeof navigator !== 'undefined') {\n const raw = navigator.userAgent.match(/\\(([^()]+)\\)/g);\n if (raw && raw[0]) {\n const platformMatch = raw[0].match(/\\(([^()]+)\\)/g);\n platform = platformMatch ? platformMatch[0].replace(/\\(|\\)/g, '') : '';\n agent = navigator.userAgent.replace(raw[0], '');\n if (platform[1]) agent = agent.replace(raw[1], '');\n agent = agent.replace(/ /g, ' ');\n }\n } else if (typeof process !== 'undefined') {\n platform = `${process.platform} ${process.arch}`;\n agent = `NodeJS ${process.version}`;\n }\n return { platform, agent };\n}\n", "", "// A port of an algorithm by Johannes Baag\u00F8e , 2010\n// http://baagoe.com/en/RandomMusings/javascript/\n// https://github.com/nquinlan/better-random-numbers-for-javascript-mirror\n// Original work is under MIT license -\n\n// Copyright (C) 2010 by Johannes Baag\u00F8e \n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n// \n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n// \n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n\n\n(function(global, module, define) {\n\nfunction Alea(seed) {\n var me = this, mash = Mash();\n\n me.next = function() {\n var t = 2091639 * me.s0 + me.c * 2.3283064365386963e-10; // 2^-32\n me.s0 = me.s1;\n me.s1 = me.s2;\n return me.s2 = t - (me.c = t | 0);\n };\n\n // Apply the seeding algorithm from Baagoe.\n me.c = 1;\n me.s0 = mash(' ');\n me.s1 = mash(' ');\n me.s2 = mash(' ');\n me.s0 -= mash(seed);\n if (me.s0 < 0) { me.s0 += 1; }\n me.s1 -= mash(seed);\n if (me.s1 < 0) { me.s1 += 1; }\n me.s2 -= mash(seed);\n if (me.s2 < 0) { me.s2 += 1; }\n mash = null;\n}\n\nfunction copy(f, t) {\n t.c = f.c;\n t.s0 = f.s0;\n t.s1 = f.s1;\n t.s2 = f.s2;\n return t;\n}\n\nfunction impl(seed, opts) {\n var xg = new Alea(seed),\n state = opts && opts.state,\n prng = xg.next;\n prng.int32 = function() { return (xg.next() * 0x100000000) | 0; }\n prng.double = function() {\n return prng() + (prng() * 0x200000 | 0) * 1.1102230246251565e-16; // 2^-53\n };\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nfunction Mash() {\n var n = 0xefc8249d;\n\n var mash = function(data) {\n data = data.toString();\n for (var i = 0; i < data.length; i++) {\n n += data.charCodeAt(i);\n var h = 0.02519603282416938 * n;\n n = h >>> 0;\n h -= n;\n h *= n;\n n = h >>> 0;\n h -= n;\n n += h * 0x100000000; // 2^32\n }\n return (n >>> 0) * 2.3283064365386963e-10; // 2^-32\n };\n\n return mash;\n}\n\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.alea = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n", "// A Javascript implementaion of the \"xor128\" prng algorithm by\n// George Marsaglia. See http://www.jstatsoft.org/v08/i14/paper\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this, strseed = '';\n\n me.x = 0;\n me.y = 0;\n me.z = 0;\n me.w = 0;\n\n // Set up generator function.\n me.next = function() {\n var t = me.x ^ (me.x << 11);\n me.x = me.y;\n me.y = me.z;\n me.z = me.w;\n return me.w ^= (me.w >>> 19) ^ t ^ (t >>> 8);\n };\n\n if (seed === (seed | 0)) {\n // Integer seed.\n me.x = seed;\n } else {\n // String seed.\n strseed += seed;\n }\n\n // Mix in string seed, then discard an initial batch of 64 values.\n for (var k = 0; k < strseed.length + 64; k++) {\n me.x ^= strseed.charCodeAt(k) | 0;\n me.next();\n }\n}\n\nfunction copy(f, t) {\n t.x = f.x;\n t.y = f.y;\n t.z = f.z;\n t.w = f.w;\n return t;\n}\n\nfunction impl(seed, opts) {\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xor128 = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n", "// A Javascript implementaion of the \"xorwow\" prng algorithm by\n// George Marsaglia. See http://www.jstatsoft.org/v08/i14/paper\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this, strseed = '';\n\n // Set up generator function.\n me.next = function() {\n var t = (me.x ^ (me.x >>> 2));\n me.x = me.y; me.y = me.z; me.z = me.w; me.w = me.v;\n return (me.d = (me.d + 362437 | 0)) +\n (me.v = (me.v ^ (me.v << 4)) ^ (t ^ (t << 1))) | 0;\n };\n\n me.x = 0;\n me.y = 0;\n me.z = 0;\n me.w = 0;\n me.v = 0;\n\n if (seed === (seed | 0)) {\n // Integer seed.\n me.x = seed;\n } else {\n // String seed.\n strseed += seed;\n }\n\n // Mix in string seed, then discard an initial batch of 64 values.\n for (var k = 0; k < strseed.length + 64; k++) {\n me.x ^= strseed.charCodeAt(k) | 0;\n if (k == strseed.length) {\n me.d = me.x << 10 ^ me.x >>> 4;\n }\n me.next();\n }\n}\n\nfunction copy(f, t) {\n t.x = f.x;\n t.y = f.y;\n t.z = f.z;\n t.w = f.w;\n t.v = f.v;\n t.d = f.d;\n return t;\n}\n\nfunction impl(seed, opts) {\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xorwow = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n", "// A Javascript implementaion of the \"xorshift7\" algorithm by\n// Fran\u00E7ois Panneton and Pierre L'ecuyer:\n// \"On the Xorgshift Random Number Generators\"\n// http://saluc.engr.uconn.edu/refs/crypto/rng/panneton05onthexorshift.pdf\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this;\n\n // Set up generator function.\n me.next = function() {\n // Update xor generator.\n var X = me.x, i = me.i, t, v, w;\n t = X[i]; t ^= (t >>> 7); v = t ^ (t << 24);\n t = X[(i + 1) & 7]; v ^= t ^ (t >>> 10);\n t = X[(i + 3) & 7]; v ^= t ^ (t >>> 3);\n t = X[(i + 4) & 7]; v ^= t ^ (t << 7);\n t = X[(i + 7) & 7]; t = t ^ (t << 13); v ^= t ^ (t << 9);\n X[i] = v;\n me.i = (i + 1) & 7;\n return v;\n };\n\n function init(me, seed) {\n var j, w, X = [];\n\n if (seed === (seed | 0)) {\n // Seed state array using a 32-bit integer.\n w = X[0] = seed;\n } else {\n // Seed state using a string.\n seed = '' + seed;\n for (j = 0; j < seed.length; ++j) {\n X[j & 7] = (X[j & 7] << 15) ^\n (seed.charCodeAt(j) + X[(j + 1) & 7] << 13);\n }\n }\n // Enforce an array length of 8, not all zeroes.\n while (X.length < 8) X.push(0);\n for (j = 0; j < 8 && X[j] === 0; ++j);\n if (j == 8) w = X[7] = -1; else w = X[j];\n\n me.x = X;\n me.i = 0;\n\n // Discard an initial 256 values.\n for (j = 256; j > 0; --j) {\n me.next();\n }\n }\n\n init(me, seed);\n}\n\nfunction copy(f, t) {\n t.x = f.x.slice();\n t.i = f.i;\n return t;\n}\n\nfunction impl(seed, opts) {\n if (seed == null) seed = +(new Date);\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (state.x) copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xorshift7 = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n", "// A Javascript implementaion of Richard Brent's Xorgens xor4096 algorithm.\n//\n// This fast non-cryptographic random number generator is designed for\n// use in Monte-Carlo algorithms. It combines a long-period xorshift\n// generator with a Weyl generator, and it passes all common batteries\n// of stasticial tests for randomness while consuming only a few nanoseconds\n// for each prng generated. For background on the generator, see Brent's\n// paper: \"Some long-period random number generators using shifts and xors.\"\n// http://arxiv.org/pdf/1004.3115v1.pdf\n//\n// Usage:\n//\n// var xor4096 = require('xor4096');\n// random = xor4096(1); // Seed with int32 or string.\n// assert.equal(random(), 0.1520436450538547); // (0, 1) range, 53 bits.\n// assert.equal(random.int32(), 1806534897); // signed int32, 32 bits.\n//\n// For nonzero numeric keys, this impelementation provides a sequence\n// identical to that by Brent's xorgens 3 implementaion in C. This\n// implementation also provides for initalizing the generator with\n// string seeds, or for saving and restoring the state of the generator.\n//\n// On Chrome, this prng benchmarks about 2.1 times slower than\n// Javascript's built-in Math.random().\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this;\n\n // Set up generator function.\n me.next = function() {\n var w = me.w,\n X = me.X, i = me.i, t, v;\n // Update Weyl generator.\n me.w = w = (w + 0x61c88647) | 0;\n // Update xor generator.\n v = X[(i + 34) & 127];\n t = X[i = ((i + 1) & 127)];\n v ^= v << 13;\n t ^= t << 17;\n v ^= v >>> 15;\n t ^= t >>> 12;\n // Update Xor generator array state.\n v = X[i] = v ^ t;\n me.i = i;\n // Result is the combination.\n return (v + (w ^ (w >>> 16))) | 0;\n };\n\n function init(me, seed) {\n var t, v, i, j, w, X = [], limit = 128;\n if (seed === (seed | 0)) {\n // Numeric seeds initialize v, which is used to generates X.\n v = seed;\n seed = null;\n } else {\n // String seeds are mixed into v and X one character at a time.\n seed = seed + '\\0';\n v = 0;\n limit = Math.max(limit, seed.length);\n }\n // Initialize circular array and weyl value.\n for (i = 0, j = -32; j < limit; ++j) {\n // Put the unicode characters into the array, and shuffle them.\n if (seed) v ^= seed.charCodeAt((j + 32) % seed.length);\n // After 32 shuffles, take v as the starting w value.\n if (j === 0) w = v;\n v ^= v << 10;\n v ^= v >>> 15;\n v ^= v << 4;\n v ^= v >>> 13;\n if (j >= 0) {\n w = (w + 0x61c88647) | 0; // Weyl.\n t = (X[j & 127] ^= (v + w)); // Combine xor and weyl to init array.\n i = (0 == t) ? i + 1 : 0; // Count zeroes.\n }\n }\n // We have detected all zeroes; make the key nonzero.\n if (i >= 128) {\n X[(seed && seed.length || 0) & 127] = -1;\n }\n // Run the generator 512 times to further mix the state before using it.\n // Factoring this as a function slows the main generator, so it is just\n // unrolled here. The weyl generator is not advanced while warming up.\n i = 127;\n for (j = 4 * 128; j > 0; --j) {\n v = X[(i + 34) & 127];\n t = X[i = ((i + 1) & 127)];\n v ^= v << 13;\n t ^= t << 17;\n v ^= v >>> 15;\n t ^= t >>> 12;\n X[i] = v ^ t;\n }\n // Storing state as object members is faster than using closure variables.\n me.w = w;\n me.X = X;\n me.i = i;\n }\n\n init(me, seed);\n}\n\nfunction copy(f, t) {\n t.i = f.i;\n t.w = f.w;\n t.X = f.X.slice();\n return t;\n};\n\nfunction impl(seed, opts) {\n if (seed == null) seed = +(new Date);\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (state.X) copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xor4096 = impl;\n}\n\n})(\n this, // window object or global\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n", "// A Javascript implementaion of the \"Tyche-i\" prng algorithm by\n// Samuel Neves and Filipe Araujo.\n// See https://eden.dei.uc.pt/~sneves/pubs/2011-snfa2.pdf\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this, strseed = '';\n\n // Set up generator function.\n me.next = function() {\n var b = me.b, c = me.c, d = me.d, a = me.a;\n b = (b << 25) ^ (b >>> 7) ^ c;\n c = (c - d) | 0;\n d = (d << 24) ^ (d >>> 8) ^ a;\n a = (a - b) | 0;\n me.b = b = (b << 20) ^ (b >>> 12) ^ c;\n me.c = c = (c - d) | 0;\n me.d = (d << 16) ^ (c >>> 16) ^ a;\n return me.a = (a - b) | 0;\n };\n\n /* The following is non-inverted tyche, which has better internal\n * bit diffusion, but which is about 25% slower than tyche-i in JS.\n me.next = function() {\n var a = me.a, b = me.b, c = me.c, d = me.d;\n a = (me.a + me.b | 0) >>> 0;\n d = me.d ^ a; d = d << 16 ^ d >>> 16;\n c = me.c + d | 0;\n b = me.b ^ c; b = b << 12 ^ d >>> 20;\n me.a = a = a + b | 0;\n d = d ^ a; me.d = d = d << 8 ^ d >>> 24;\n me.c = c = c + d | 0;\n b = b ^ c;\n return me.b = (b << 7 ^ b >>> 25);\n }\n */\n\n me.a = 0;\n me.b = 0;\n me.c = 2654435769 | 0;\n me.d = 1367130551;\n\n if (seed === Math.floor(seed)) {\n // Integer seed.\n me.a = (seed / 0x100000000) | 0;\n me.b = seed | 0;\n } else {\n // String seed.\n strseed += seed;\n }\n\n // Mix in string seed, then discard an initial batch of 64 values.\n for (var k = 0; k < strseed.length + 20; k++) {\n me.b ^= strseed.charCodeAt(k) | 0;\n me.next();\n }\n}\n\nfunction copy(f, t) {\n t.a = f.a;\n t.b = f.b;\n t.c = f.c;\n t.d = f.d;\n return t;\n};\n\nfunction impl(seed, opts) {\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.tychei = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n", "", "/*\nCopyright 2014 David Bau.\n\nPermission is hereby granted, free of charge, to any person obtaining\na copy of this software and associated documentation files (the\n\"Software\"), to deal in the Software without restriction, including\nwithout limitation the rights to use, copy, modify, merge, publish,\ndistribute, sublicense, and/or sell copies of the Software, and to\npermit persons to whom the Software is furnished to do so, subject to\nthe following conditions:\n\nThe above copyright notice and this permission notice shall be\nincluded in all copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND,\nEXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\nMERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.\nIN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY\nCLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,\nTORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE\nSOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n*/\n\n(function (pool, math) {\n//\n// The following constants are related to IEEE 754 limits.\n//\nvar global = this,\n width = 256, // each RC4 output is 0 <= x < 256\n chunks = 6, // at least six RC4 outputs for each double\n digits = 52, // there are 52 significant digits in a double\n rngname = 'random', // rngname: name for Math.random and Math.seedrandom\n startdenom = math.pow(width, chunks),\n significance = math.pow(2, digits),\n overflow = significance * 2,\n mask = width - 1,\n nodecrypto; // node.js crypto module, initialized at the bottom.\n\n//\n// seedrandom()\n// This is the seedrandom function described above.\n//\nfunction seedrandom(seed, options, callback) {\n var key = [];\n options = (options == true) ? { entropy: true } : (options || {});\n\n // Flatten the seed string or build one from local entropy if needed.\n var shortseed = mixkey(flatten(\n options.entropy ? [seed, tostring(pool)] :\n (seed == null) ? autoseed() : seed, 3), key);\n\n // Use the seed to initialize an ARC4 generator.\n var arc4 = new ARC4(key);\n\n // This function returns a random double in [0, 1) that contains\n // randomness in every bit of the mantissa of the IEEE 754 value.\n var prng = function() {\n var n = arc4.g(chunks), // Start with a numerator n < 2 ^ 48\n d = startdenom, // and denominator d = 2 ^ 48.\n x = 0; // and no 'extra last byte'.\n while (n < significance) { // Fill up all significant digits by\n n = (n + x) * width; // shifting numerator and\n d *= width; // denominator and generating a\n x = arc4.g(1); // new least-significant-byte.\n }\n while (n >= overflow) { // To avoid rounding up, before adding\n n /= 2; // last byte, shift everything\n d /= 2; // right using integer math until\n x >>>= 1; // we have exactly the desired bits.\n }\n return (n + x) / d; // Form the number within [0, 1).\n };\n\n prng.int32 = function() { return arc4.g(4) | 0; }\n prng.quick = function() { return arc4.g(4) / 0x100000000; }\n prng.double = prng;\n\n // Mix the randomness into accumulated entropy.\n mixkey(tostring(arc4.S), pool);\n\n // Calling convention: what to return as a function of prng, seed, is_math.\n return (options.pass || callback ||\n function(prng, seed, is_math_call, state) {\n if (state) {\n // Load the arc4 state from the given state if it has an S array.\n if (state.S) { copy(state, arc4); }\n // Only provide the .state method if requested via options.state.\n prng.state = function() { return copy(arc4, {}); }\n }\n\n // If called as a method of Math (Math.seedrandom()), mutate\n // Math.random because that is how seedrandom.js has worked since v1.0.\n if (is_math_call) { math[rngname] = prng; return seed; }\n\n // Otherwise, it is a newer calling convention, so return the\n // prng directly.\n else return prng;\n })(\n prng,\n shortseed,\n 'global' in options ? options.global : (this == math),\n options.state);\n}\nmath['seed' + rngname] = seedrandom;\n\n//\n// ARC4\n//\n// An ARC4 implementation. The constructor takes a key in the form of\n// an array of at most (width) integers that should be 0 <= x < (width).\n//\n// The g(count) method returns a pseudorandom integer that concatenates\n// the next (count) outputs from ARC4. Its return value is a number x\n// that is in the range 0 <= x < (width ^ count).\n//\nfunction ARC4(key) {\n var t, keylen = key.length,\n me = this, i = 0, j = me.i = me.j = 0, s = me.S = [];\n\n // The empty key [] is treated as [0].\n if (!keylen) { key = [keylen++]; }\n\n // Set up S using the standard key scheduling algorithm.\n while (i < width) {\n s[i] = i++;\n }\n for (i = 0; i < width; i++) {\n s[i] = s[j = mask & (j + key[i % keylen] + (t = s[i]))];\n s[j] = t;\n }\n\n // The \"g\" method returns the next (count) outputs as one number.\n (me.g = function(count) {\n // Using instance members instead of closure state nearly doubles speed.\n var t, r = 0,\n i = me.i, j = me.j, s = me.S;\n while (count--) {\n t = s[i = mask & (i + 1)];\n r = r * width + s[mask & ((s[i] = s[j = mask & (j + t)]) + (s[j] = t))];\n }\n me.i = i; me.j = j;\n return r;\n // For robust unpredictability, the function call below automatically\n // discards an initial batch of values. This is called RC4-drop[256].\n // See http://google.com/search?q=rsa+fluhrer+response&btnI\n })(width);\n}\n\n//\n// copy()\n// Copies internal state of ARC4 to or from a plain object.\n//\nfunction copy(f, t) {\n t.i = f.i;\n t.j = f.j;\n t.S = f.S.slice();\n return t;\n};\n\n//\n// flatten()\n// Converts an object tree to nested arrays of strings.\n//\nfunction flatten(obj, depth) {\n var result = [], typ = (typeof obj), prop;\n if (depth && typ == 'object') {\n for (prop in obj) {\n try { result.push(flatten(obj[prop], depth - 1)); } catch (e) {}\n }\n }\n return (result.length ? result : typ == 'string' ? obj : obj + '\\0');\n}\n\n//\n// mixkey()\n// Mixes a string seed into a key that is an array of integers, and\n// returns a shortened string seed that is equivalent to the result key.\n//\nfunction mixkey(seed, key) {\n var stringseed = seed + '', smear, j = 0;\n while (j < stringseed.length) {\n key[mask & j] =\n mask & ((smear ^= key[mask & j] * 19) + stringseed.charCodeAt(j++));\n }\n return tostring(key);\n}\n\n//\n// autoseed()\n// Returns an object for autoseeding, using window.crypto and Node crypto\n// module if available.\n//\nfunction autoseed() {\n try {\n var out;\n if (nodecrypto && (out = nodecrypto.randomBytes)) {\n // The use of 'out' to remember randomBytes makes tight minified code.\n out = out(width);\n } else {\n out = new Uint8Array(width);\n (global.crypto || global.msCrypto).getRandomValues(out);\n }\n return tostring(out);\n } catch (e) {\n var browser = global.navigator,\n plugins = browser && browser.plugins;\n return [+new Date, global, plugins, global.screen, tostring(pool)];\n }\n}\n\n//\n// tostring()\n// Converts an array of charcodes to a string\n//\nfunction tostring(a) {\n return String.fromCharCode.apply(0, a);\n}\n\n//\n// When seedrandom.js is loaded, we immediately mix a few bits\n// from the built-in RNG into the entropy pool. Because we do\n// not want to interfere with deterministic PRNG state later,\n// seedrandom will not call math.random on its own again after\n// initialization.\n//\nmixkey(math.random(), pool);\n\n//\n// Nodejs and AMD support: export the implementation as a module using\n// either convention.\n//\nif ((typeof module) == 'object' && module.exports) {\n module.exports = seedrandom;\n // When in node.js, try using crypto package for autoseeding.\n try {\n nodecrypto = require('crypto');\n } catch (ex) {}\n} else if ((typeof define) == 'function' && define.amd) {\n define(function() { return seedrandom; });\n}\n\n// End anonymous scope, and pass initial values.\n})(\n [], // pool: entropy pool starts empty\n Math // math: package containing random, pow, and seedrandom\n);\n", "// A library of seedable RNGs implemented in Javascript.\n//\n// Usage:\n//\n// var seedrandom = require('seedrandom');\n// var random = seedrandom(1); // or any seed.\n// var x = random(); // 0 <= x < 1. Every bit is random.\n// var x = random.quick(); // 0 <= x < 1. 32 bits of randomness.\n\n// alea, a 53-bit multiply-with-carry generator by Johannes Baag\u00F8e.\n// Period: ~2^116\n// Reported to pass all BigCrush tests.\nvar alea = require('./lib/alea');\n\n// xor128, a pure xor-shift generator by George Marsaglia.\n// Period: 2^128-1.\n// Reported to fail: MatrixRank and LinearComp.\nvar xor128 = require('./lib/xor128');\n\n// xorwow, George Marsaglia's 160-bit xor-shift combined plus weyl.\n// Period: 2^192-2^32\n// Reported to fail: CollisionOver, SimpPoker, and LinearComp.\nvar xorwow = require('./lib/xorwow');\n\n// xorshift7, by Fran\u00E7ois Panneton and Pierre L'ecuyer, takes\n// a different approach: it adds robustness by allowing more shifts\n// than Marsaglia's original three. It is a 7-shift generator\n// with 256 bits, that passes BigCrush with no systmatic failures.\n// Period 2^256-1.\n// No systematic BigCrush failures reported.\nvar xorshift7 = require('./lib/xorshift7');\n\n// xor4096, by Richard Brent, is a 4096-bit xor-shift with a\n// very long period that also adds a Weyl generator. It also passes\n// BigCrush with no systematic failures. Its long period may\n// be useful if you have many generators and need to avoid\n// collisions.\n// Period: 2^4128-2^32.\n// No systematic BigCrush failures reported.\nvar xor4096 = require('./lib/xor4096');\n\n// Tyche-i, by Samuel Neves and Filipe Araujo, is a bit-shifting random\n// number generator derived from ChaCha, a modern stream cipher.\n// https://eden.dei.uc.pt/~sneves/pubs/2011-snfa2.pdf\n// Period: ~2^127\n// No systematic BigCrush failures reported.\nvar tychei = require('./lib/tychei');\n\n// The original ARC4-based prng included in this library.\n// Period: ~2^1600\nvar sr = require('./seedrandom');\n\nsr.alea = alea;\nsr.xor128 = xor128;\nsr.xorwow = xorwow;\nsr.xorshift7 = xorshift7;\nsr.xor4096 = xor4096;\nsr.tychei = tychei;\n\nmodule.exports = sr;\n", "", "", "", "\nvar WasmBackendModuleThreadedSimd = (function() {\n var _scriptDir = typeof document !== 'undefined' && document.currentScript ? document.currentScript.src : undefined;\n if (typeof __filename !== 'undefined') _scriptDir = _scriptDir || __filename;\n return (\nfunction(WasmBackendModuleThreadedSimd) {\n WasmBackendModuleThreadedSimd = WasmBackendModuleThreadedSimd || {};\n\nfunction GROWABLE_HEAP_I8(){if(wasmMemory.buffer!=buffer){updateGlobalBufferAndViews(wasmMemory.buffer)}return HEAP8}function GROWABLE_HEAP_U8(){if(wasmMemory.buffer!=buffer){updateGlobalBufferAndViews(wasmMemory.buffer)}return HEAPU8}function GROWABLE_HEAP_I32(){if(wasmMemory.buffer!=buffer){updateGlobalBufferAndViews(wasmMemory.buffer)}return HEAP32}function GROWABLE_HEAP_U32(){if(wasmMemory.buffer!=buffer){updateGlobalBufferAndViews(wasmMemory.buffer)}return HEAPU32}function GROWABLE_HEAP_F64(){if(wasmMemory.buffer!=buffer){updateGlobalBufferAndViews(wasmMemory.buffer)}return HEAPF64}var Module=typeof WasmBackendModuleThreadedSimd!==\"undefined\"?WasmBackendModuleThreadedSimd:{};var readyPromiseResolve,readyPromiseReject;Module[\"ready\"]=new Promise(function(resolve,reject){readyPromiseResolve=resolve;readyPromiseReject=reject});var moduleOverrides={};var key;for(key in Module){if(Module.hasOwnProperty(key)){moduleOverrides[key]=Module[key]}}var arguments_=[];var thisProgram=\"./this.program\";var quit_=function(status,toThrow){throw toThrow};var ENVIRONMENT_IS_WEB=false;var ENVIRONMENT_IS_WORKER=false;var ENVIRONMENT_IS_NODE=false;var ENVIRONMENT_IS_SHELL=false;ENVIRONMENT_IS_WEB=typeof window===\"object\";ENVIRONMENT_IS_WORKER=typeof importScripts===\"function\";ENVIRONMENT_IS_NODE=typeof process===\"object\"&&typeof process.versions===\"object\"&&typeof process.versions.node===\"string\";ENVIRONMENT_IS_SHELL=!ENVIRONMENT_IS_WEB&&!ENVIRONMENT_IS_NODE&&!ENVIRONMENT_IS_WORKER;var ENVIRONMENT_IS_PTHREAD=Module[\"ENVIRONMENT_IS_PTHREAD\"]||false;if(ENVIRONMENT_IS_PTHREAD){buffer=Module[\"buffer\"]}var scriptDirectory=\"\";function locateFile(path){if(Module[\"locateFile\"]){return Module[\"locateFile\"](path,scriptDirectory)}return scriptDirectory+path}var read_,readAsync,readBinary,setWindowTitle;var nodeFS;var nodePath;if(ENVIRONMENT_IS_NODE){if(ENVIRONMENT_IS_WORKER){scriptDirectory=require(\"path\").dirname(scriptDirectory)+\"/\"}else{scriptDirectory=__dirname+\"/\"}read_=function shell_read(filename,binary){if(!nodeFS)nodeFS=require(\"fs\");if(!nodePath)nodePath=require(\"path\");filename=nodePath[\"normalize\"](filename);return nodeFS[\"readFileSync\"](filename,binary?null:\"utf8\")};readBinary=function readBinary(filename){var ret=read_(filename,true);if(!ret.buffer){ret=new Uint8Array(ret)}assert(ret.buffer);return ret};if(process[\"argv\"].length>1){thisProgram=process[\"argv\"][1].replace(/\\\\/g,\"/\")}arguments_=process[\"argv\"].slice(2);process[\"on\"](\"uncaughtException\",function(ex){if(!(ex instanceof ExitStatus)){throw ex}});process[\"on\"](\"unhandledRejection\",abort);quit_=function(status){process[\"exit\"](status)};Module[\"inspect\"]=function(){return\"[Emscripten Module object]\"};var nodeWorkerThreads;try{nodeWorkerThreads=require(\"worker_threads\")}catch(e){console.error('The \"worker_threads\" module is not supported in this node.js build - perhaps a newer version is needed?');throw e}global.Worker=nodeWorkerThreads.Worker}else if(ENVIRONMENT_IS_SHELL){if(typeof read!=\"undefined\"){read_=function shell_read(f){return read(f)}}readBinary=function readBinary(f){var data;if(typeof readbuffer===\"function\"){return new Uint8Array(readbuffer(f))}data=read(f,\"binary\");assert(typeof data===\"object\");return data};if(typeof scriptArgs!=\"undefined\"){arguments_=scriptArgs}else if(typeof arguments!=\"undefined\"){arguments_=arguments}if(typeof quit===\"function\"){quit_=function(status){quit(status)}}if(typeof print!==\"undefined\"){if(typeof console===\"undefined\")console={};console.log=print;console.warn=console.error=typeof printErr!==\"undefined\"?printErr:print}}else if(ENVIRONMENT_IS_WEB||ENVIRONMENT_IS_WORKER){if(ENVIRONMENT_IS_WORKER){scriptDirectory=self.location.href}else if(typeof document!==\"undefined\"&&document.currentScript){scriptDirectory=document.currentScript.src}if(typeof _scriptDir !== \"undefined\" && _scriptDir){scriptDirectory=_scriptDir}if(scriptDirectory.indexOf(\"blob:\")!==0){scriptDirectory=scriptDirectory.substr(0,scriptDirectory.lastIndexOf(\"/\")+1)}else{scriptDirectory=\"\"}if(ENVIRONMENT_IS_NODE){read_=function shell_read(filename,binary){if(!nodeFS)nodeFS=require(\"fs\");if(!nodePath)nodePath=require(\"path\");filename=nodePath[\"normalize\"](filename);return nodeFS[\"readFileSync\"](filename,binary?null:\"utf8\")};readBinary=function readBinary(filename){var ret=read_(filename,true);if(!ret.buffer){ret=new Uint8Array(ret)}assert(ret.buffer);return ret}}else{read_=function(url){var xhr=new XMLHttpRequest;xhr.open(\"GET\",url,false);xhr.send(null);return xhr.responseText};if(ENVIRONMENT_IS_WORKER){readBinary=function(url){var xhr=new XMLHttpRequest;xhr.open(\"GET\",url,false);xhr.responseType=\"arraybuffer\";xhr.send(null);return new Uint8Array(xhr.response)}}readAsync=function(url,onload,onerror){var xhr=new XMLHttpRequest;xhr.open(\"GET\",url,true);xhr.responseType=\"arraybuffer\";xhr.onload=function(){if(xhr.status==200||xhr.status==0&&xhr.response){onload(xhr.response);return}onerror()};xhr.onerror=onerror;xhr.send(null)}}setWindowTitle=function(title){document.title=title}}else{}if(ENVIRONMENT_IS_NODE){if(typeof performance===\"undefined\"){global.performance=require(\"perf_hooks\").performance}}var out=Module[\"print\"]||console.log.bind(console);var err=Module[\"printErr\"]||console.warn.bind(console);for(key in moduleOverrides){if(moduleOverrides.hasOwnProperty(key)){Module[key]=moduleOverrides[key]}}moduleOverrides=null;if(Module[\"arguments\"])arguments_=Module[\"arguments\"];if(Module[\"thisProgram\"])thisProgram=Module[\"thisProgram\"];if(Module[\"quit\"])quit_=Module[\"quit\"];var Atomics_load=Atomics.load;var Atomics_store=Atomics.store;var Atomics_compareExchange=Atomics.compareExchange;var wasmBinary;if(Module[\"wasmBinary\"])wasmBinary=Module[\"wasmBinary\"];var noExitRuntime=Module[\"noExitRuntime\"]||true;if(typeof WebAssembly!==\"object\"){abort(\"no native wasm support detected\")}var wasmMemory;var wasmModule;var ABORT=false;var EXITSTATUS;function assert(condition,text){if(!condition){abort(\"Assertion failed: \"+text)}}function getCFunc(ident){var func=Module[\"_\"+ident];assert(func,\"Cannot call unknown function \"+ident+\", make sure it is exported\");return func}function ccall(ident,returnType,argTypes,args,opts){var toC={\"string\":function(str){var ret=0;if(str!==null&&str!==undefined&&str!==0){var len=(str.length<<2)+1;ret=stackAlloc(len);stringToUTF8(str,ret,len)}return ret},\"array\":function(arr){var ret=stackAlloc(arr.length);writeArrayToMemory(arr,ret);return ret}};function convertReturnValue(ret){if(returnType===\"string\")return UTF8ToString(ret);if(returnType===\"boolean\")return Boolean(ret);return ret}var func=getCFunc(ident);var cArgs=[];var stack=0;if(args){for(var i=0;i=endIdx)){var u0=heap[idx++];if(!u0)return str;if(!(u0&128)){str+=String.fromCharCode(u0);continue}var u1=heap[idx++]&63;if((u0&224)==192){str+=String.fromCharCode((u0&31)<<6|u1);continue}var u2=heap[idx++]&63;if((u0&240)==224){u0=(u0&15)<<12|u1<<6|u2}else{u0=(u0&7)<<18|u1<<12|u2<<6|heap[idx++]&63}if(u0<65536){str+=String.fromCharCode(u0)}else{var ch=u0-65536;str+=String.fromCharCode(55296|ch>>10,56320|ch&1023)}}return str}function UTF8ToString(ptr,maxBytesToRead){return ptr?UTF8ArrayToString(GROWABLE_HEAP_U8(),ptr,maxBytesToRead):\"\"}function stringToUTF8Array(str,heap,outIdx,maxBytesToWrite){if(!(maxBytesToWrite>0))return 0;var startIdx=outIdx;var endIdx=outIdx+maxBytesToWrite-1;for(var i=0;i=55296&&u<=57343){var u1=str.charCodeAt(++i);u=65536+((u&1023)<<10)|u1&1023}if(u<=127){if(outIdx>=endIdx)break;heap[outIdx++]=u}else if(u<=2047){if(outIdx+1>=endIdx)break;heap[outIdx++]=192|u>>6;heap[outIdx++]=128|u&63}else if(u<=65535){if(outIdx+2>=endIdx)break;heap[outIdx++]=224|u>>12;heap[outIdx++]=128|u>>6&63;heap[outIdx++]=128|u&63}else{if(outIdx+3>=endIdx)break;heap[outIdx++]=240|u>>18;heap[outIdx++]=128|u>>12&63;heap[outIdx++]=128|u>>6&63;heap[outIdx++]=128|u&63}}heap[outIdx]=0;return outIdx-startIdx}function stringToUTF8(str,outPtr,maxBytesToWrite){return stringToUTF8Array(str,GROWABLE_HEAP_U8(),outPtr,maxBytesToWrite)}function lengthBytesUTF8(str){var len=0;for(var i=0;i=55296&&u<=57343)u=65536+((u&1023)<<10)|str.charCodeAt(++i)&1023;if(u<=127)++len;else if(u<=2047)len+=2;else if(u<=65535)len+=3;else len+=4}return len}function writeArrayToMemory(array,buffer){GROWABLE_HEAP_I8().set(array,buffer)}function alignUp(x,multiple){if(x%multiple>0){x+=multiple-x%multiple}return x}var buffer,HEAP8,HEAPU8,HEAP16,HEAPU16,HEAP32,HEAPU32,HEAPF32,HEAPF64;function updateGlobalBufferAndViews(buf){buffer=buf;Module[\"HEAP8\"]=HEAP8=new Int8Array(buf);Module[\"HEAP16\"]=HEAP16=new Int16Array(buf);Module[\"HEAP32\"]=HEAP32=new Int32Array(buf);Module[\"HEAPU8\"]=HEAPU8=new Uint8Array(buf);Module[\"HEAPU16\"]=HEAPU16=new Uint16Array(buf);Module[\"HEAPU32\"]=HEAPU32=new Uint32Array(buf);Module[\"HEAPF32\"]=HEAPF32=new Float32Array(buf);Module[\"HEAPF64\"]=HEAPF64=new Float64Array(buf)}var INITIAL_MEMORY=Module[\"INITIAL_MEMORY\"]||16777216;if(ENVIRONMENT_IS_PTHREAD){wasmMemory=Module[\"wasmMemory\"];buffer=Module[\"buffer\"]}else{if(Module[\"wasmMemory\"]){wasmMemory=Module[\"wasmMemory\"]}else{wasmMemory=new WebAssembly.Memory({\"initial\":INITIAL_MEMORY/65536,\"maximum\":2147483648/65536,\"shared\":true});if(!(wasmMemory.buffer instanceof SharedArrayBuffer)){err(\"requested a shared WebAssembly.Memory but the returned buffer is not a SharedArrayBuffer, indicating that while the browser has SharedArrayBuffer it does not have WebAssembly threads support - you may need to set a flag\");if(ENVIRONMENT_IS_NODE){console.log(\"(on node you may need: --experimental-wasm-threads --experimental-wasm-bulk-memory and also use a recent version)\")}throw Error(\"bad memory\")}}}if(wasmMemory){buffer=wasmMemory.buffer}INITIAL_MEMORY=buffer.byteLength;updateGlobalBufferAndViews(buffer);var wasmTable;var __ATPRERUN__=[];var __ATINIT__=[];var __ATMAIN__=[];var __ATEXIT__=[];var __ATPOSTRUN__=[];var runtimeInitialized=false;var runtimeExited=false;if(!ENVIRONMENT_IS_PTHREAD)__ATINIT__.push({func:function(){___wasm_call_ctors()}});function preRun(){if(ENVIRONMENT_IS_PTHREAD)return;if(Module[\"preRun\"]){if(typeof Module[\"preRun\"]==\"function\")Module[\"preRun\"]=[Module[\"preRun\"]];while(Module[\"preRun\"].length){addOnPreRun(Module[\"preRun\"].shift())}}callRuntimeCallbacks(__ATPRERUN__)}function initRuntime(){runtimeInitialized=true;if(ENVIRONMENT_IS_PTHREAD)return;callRuntimeCallbacks(__ATINIT__)}function preMain(){if(ENVIRONMENT_IS_PTHREAD)return;callRuntimeCallbacks(__ATMAIN__)}function exitRuntime(){if(ENVIRONMENT_IS_PTHREAD)return;runtimeExited=true}function postRun(){if(ENVIRONMENT_IS_PTHREAD)return;if(Module[\"postRun\"]){if(typeof Module[\"postRun\"]==\"function\")Module[\"postRun\"]=[Module[\"postRun\"]];while(Module[\"postRun\"].length){addOnPostRun(Module[\"postRun\"].shift())}}callRuntimeCallbacks(__ATPOSTRUN__)}function addOnPreRun(cb){__ATPRERUN__.unshift(cb)}function addOnPostRun(cb){__ATPOSTRUN__.unshift(cb)}var runDependencies=0;var runDependencyWatcher=null;var dependenciesFulfilled=null;function addRunDependency(id){assert(!ENVIRONMENT_IS_PTHREAD,\"addRunDependency cannot be used in a pthread worker\");runDependencies++;if(Module[\"monitorRunDependencies\"]){Module[\"monitorRunDependencies\"](runDependencies)}}function removeRunDependency(id){runDependencies--;if(Module[\"monitorRunDependencies\"]){Module[\"monitorRunDependencies\"](runDependencies)}if(runDependencies==0){if(runDependencyWatcher!==null){clearInterval(runDependencyWatcher);runDependencyWatcher=null}if(dependenciesFulfilled){var callback=dependenciesFulfilled;dependenciesFulfilled=null;callback()}}}Module[\"preloadedImages\"]={};Module[\"preloadedAudios\"]={};function abort(what){if(Module[\"onAbort\"]){Module[\"onAbort\"](what)}if(ENVIRONMENT_IS_PTHREAD)console.error(\"Pthread aborting at \"+(new Error).stack);what+=\"\";err(what);ABORT=true;EXITSTATUS=1;what=\"abort(\"+what+\"). Build with -s ASSERTIONS=1 for more info.\";var e=new WebAssembly.RuntimeError(what);readyPromiseReject(e);throw e}function hasPrefix(str,prefix){return String.prototype.startsWith?str.startsWith(prefix):str.indexOf(prefix)===0}var dataURIPrefix=\"data:application/octet-stream;base64,\";function isDataURI(filename){return hasPrefix(filename,dataURIPrefix)}var fileURIPrefix=\"file://\";function isFileURI(filename){return hasPrefix(filename,fileURIPrefix)}var wasmBinaryFile=\"tfjs-backend-wasm-threaded-simd.wasm\";if(!isDataURI(wasmBinaryFile)){wasmBinaryFile=locateFile(wasmBinaryFile)}function getBinary(file){try{if(file==wasmBinaryFile&&wasmBinary){return new Uint8Array(wasmBinary)}if(readBinary){return readBinary(file)}else{throw\"both async and sync fetching of the wasm failed\"}}catch(err){abort(err)}}function getBinaryPromise(){if(!wasmBinary&&(ENVIRONMENT_IS_WEB||ENVIRONMENT_IS_WORKER)){if(typeof fetch===\"function\"&&!isFileURI(wasmBinaryFile)){return fetch(wasmBinaryFile,{credentials:\"same-origin\"}).then(function(response){if(!response[\"ok\"]){throw\"failed to load wasm binary file at '\"+wasmBinaryFile+\"'\"}return response[\"arrayBuffer\"]()}).catch(function(){return getBinary(wasmBinaryFile)})}else{if(readAsync){return new Promise(function(resolve,reject){readAsync(wasmBinaryFile,function(response){resolve(new Uint8Array(response))},reject)})}}}return Promise.resolve().then(function(){return getBinary(wasmBinaryFile)})}function createWasm(){var info={\"a\":asmLibraryArg};function receiveInstance(instance,module){var exports=instance.exports;Module[\"asm\"]=exports;wasmTable=Module[\"asm\"][\"F\"];wasmModule=module;if(!ENVIRONMENT_IS_PTHREAD){var numWorkersToLoad=PThread.unusedWorkers.length;PThread.unusedWorkers.forEach(function(w){PThread.loadWasmModuleToWorker(w,function(){if(!--numWorkersToLoad)removeRunDependency(\"wasm-instantiate\")})})}}if(!ENVIRONMENT_IS_PTHREAD){addRunDependency(\"wasm-instantiate\")}function receiveInstantiatedSource(output){receiveInstance(output[\"instance\"],output[\"module\"])}function instantiateArrayBuffer(receiver){return getBinaryPromise().then(function(binary){return WebAssembly.instantiate(binary,info)}).then(receiver,function(reason){err(\"failed to asynchronously prepare wasm: \"+reason);abort(reason)})}function instantiateAsync(){if(!wasmBinary&&typeof WebAssembly.instantiateStreaming===\"function\"&&!isDataURI(wasmBinaryFile)&&!isFileURI(wasmBinaryFile)&&typeof fetch===\"function\"){return fetch(wasmBinaryFile,{credentials:\"same-origin\"}).then(function(response){var result=WebAssembly.instantiateStreaming(response,info);return result.then(receiveInstantiatedSource,function(reason){err(\"wasm streaming compile failed: \"+reason);err(\"falling back to ArrayBuffer instantiation\");return instantiateArrayBuffer(receiveInstantiatedSource)})})}else{return instantiateArrayBuffer(receiveInstantiatedSource)}}if(Module[\"instantiateWasm\"]){try{var exports=Module[\"instantiateWasm\"](info,receiveInstance);return exports}catch(e){err(\"Module.instantiateWasm callback failed with error: \"+e);return false}}instantiateAsync().catch(readyPromiseReject);return{}}var ASM_CONSTS={9816:function(){throw\"Canceled!\"},9834:function($0,$1){setTimeout(function(){__emscripten_do_dispatch_to_thread($0,$1)},0)}};function initPthreadsJS(){PThread.initRuntime()}function callRuntimeCallbacks(callbacks){while(callbacks.length>0){var callback=callbacks.shift();if(typeof callback==\"function\"){callback(Module);continue}var func=callback.func;if(typeof func===\"number\"){if(callback.arg===undefined){wasmTable.get(func)()}else{wasmTable.get(func)(callback.arg)}}else{func(callback.arg===undefined?null:callback.arg)}}}function _emscripten_futex_wake(addr,count){if(addr<=0||addr>GROWABLE_HEAP_I8().length||addr&3!=0||count<0)return-28;if(count==0)return 0;if(count>=2147483647)count=Infinity;var mainThreadWaitAddress=Atomics.load(GROWABLE_HEAP_I32(),__emscripten_main_thread_futex>>2);var mainThreadWoken=0;if(mainThreadWaitAddress==addr){var loadedAddr=Atomics.compareExchange(GROWABLE_HEAP_I32(),__emscripten_main_thread_futex>>2,mainThreadWaitAddress,0);if(loadedAddr==mainThreadWaitAddress){--count;mainThreadWoken=1;if(count<=0)return 1}}var ret=Atomics.notify(GROWABLE_HEAP_I32(),addr>>2,count);if(ret>=0)return ret+mainThreadWoken;throw\"Atomics.notify returned an unexpected value \"+ret}Module[\"_emscripten_futex_wake\"]=_emscripten_futex_wake;function killThread(pthread_ptr){if(ENVIRONMENT_IS_PTHREAD)throw\"Internal Error! killThread() can only ever be called from main application thread!\";if(!pthread_ptr)throw\"Internal Error! Null pthread_ptr in killThread!\";GROWABLE_HEAP_I32()[pthread_ptr+12>>2]=0;var pthread=PThread.pthreads[pthread_ptr];pthread.worker.terminate();PThread.freeThreadData(pthread);PThread.runningWorkers.splice(PThread.runningWorkers.indexOf(pthread.worker),1);pthread.worker.pthread=undefined}function cancelThread(pthread_ptr){if(ENVIRONMENT_IS_PTHREAD)throw\"Internal Error! cancelThread() can only ever be called from main application thread!\";if(!pthread_ptr)throw\"Internal Error! Null pthread_ptr in cancelThread!\";var pthread=PThread.pthreads[pthread_ptr];pthread.worker.postMessage({\"cmd\":\"cancel\"})}function cleanupThread(pthread_ptr){if(ENVIRONMENT_IS_PTHREAD)throw\"Internal Error! cleanupThread() can only ever be called from main application thread!\";if(!pthread_ptr)throw\"Internal Error! Null pthread_ptr in cleanupThread!\";var pthread=PThread.pthreads[pthread_ptr];if(pthread){GROWABLE_HEAP_I32()[pthread_ptr+12>>2]=0;var worker=pthread.worker;PThread.returnWorkerToPool(worker)}}var PThread={unusedWorkers:[],runningWorkers:[],initMainThreadBlock:function(){var pthreadPoolSize=Math.min(4,Math.max(1,(navigator.hardwareConcurrency||1)/2));for(var i=0;i>2]=tb;var headPtr=tb+152;GROWABLE_HEAP_I32()[headPtr>>2]=headPtr;var tlsMemory=_malloc(512);for(var i=0;i<128;++i)GROWABLE_HEAP_U32()[tlsMemory/4+i]=0;Atomics.store(GROWABLE_HEAP_U32(),tb+100>>2,tlsMemory);Atomics.store(GROWABLE_HEAP_U32(),tb+40>>2,tb);__emscripten_thread_init(tb,!ENVIRONMENT_IS_WORKER,1);_emscripten_register_main_browser_thread_id(tb)},initWorker:function(){},pthreads:{},threadExitHandlers:[],setThreadStatus:function(){},runExitHandlers:function(){while(PThread.threadExitHandlers.length>0){PThread.threadExitHandlers.pop()()}if(ENVIRONMENT_IS_PTHREAD&&_pthread_self())___pthread_tsd_run_dtors()},runExitHandlersAndDeinitThread:function(tb,exitCode){Atomics.store(GROWABLE_HEAP_U32(),tb+56>>2,1);Atomics.store(GROWABLE_HEAP_U32(),tb+60>>2,0);PThread.runExitHandlers();Atomics.store(GROWABLE_HEAP_U32(),tb+4>>2,exitCode);Atomics.store(GROWABLE_HEAP_U32(),tb+0>>2,1);_emscripten_futex_wake(tb+0,2147483647);__emscripten_thread_init(0,0,0)},threadExit:function(exitCode){var tb=_pthread_self();if(tb){PThread.runExitHandlersAndDeinitThread(tb,exitCode);if(ENVIRONMENT_IS_PTHREAD){postMessage({\"cmd\":\"exit\"})}}},threadCancel:function(){PThread.runExitHandlersAndDeinitThread(_pthread_self(),-1);postMessage({\"cmd\":\"cancelDone\"})},terminateAllThreads:function(){for(var t in PThread.pthreads){var pthread=PThread.pthreads[t];if(pthread&&pthread.worker){PThread.returnWorkerToPool(pthread.worker)}}PThread.pthreads={};for(var i=0;i>2];GROWABLE_HEAP_I32()[pthread.threadInfoStruct+100>>2]=0;_free(tlsMemory);_free(pthread.threadInfoStruct)}pthread.threadInfoStruct=0;if(pthread.allocatedOwnStack&&pthread.stackBase)_free(pthread.stackBase);pthread.stackBase=0;if(pthread.worker)pthread.worker.pthread=null},returnWorkerToPool:function(worker){PThread.runWithoutMainThreadQueuedCalls(function(){delete PThread.pthreads[worker.pthread.threadInfoStruct];PThread.unusedWorkers.push(worker);PThread.runningWorkers.splice(PThread.runningWorkers.indexOf(worker),1);PThread.freeThreadData(worker.pthread);worker.pthread=undefined})},runWithoutMainThreadQueuedCalls:function(func){GROWABLE_HEAP_I32()[__emscripten_allow_main_runtime_queued_calls>>2]=0;try{func()}finally{GROWABLE_HEAP_I32()[__emscripten_allow_main_runtime_queued_calls>>2]=1}},receiveObjectTransfer:function(data){},loadWasmModuleToWorker:function(worker,onFinishedLoading){worker.onmessage=function(e){var d=e[\"data\"];var cmd=d[\"cmd\"];if(worker.pthread)PThread.currentProxiedOperationCallerThread=worker.pthread.threadInfoStruct;if(d[\"targetThread\"]&&d[\"targetThread\"]!=_pthread_self()){var thread=PThread.pthreads[d.targetThread];if(thread){thread.worker.postMessage(e.data,d[\"transferList\"])}else{console.error('Internal error! Worker sent a message \"'+cmd+'\" to target pthread '+d[\"targetThread\"]+\", but that thread no longer exists!\")}PThread.currentProxiedOperationCallerThread=undefined;return}if(cmd===\"processQueuedMainThreadWork\"){_emscripten_main_thread_process_queued_calls()}else if(cmd===\"spawnThread\"){spawnThread(e.data)}else if(cmd===\"cleanupThread\"){cleanupThread(d[\"thread\"])}else if(cmd===\"killThread\"){killThread(d[\"thread\"])}else if(cmd===\"cancelThread\"){cancelThread(d[\"thread\"])}else if(cmd===\"loaded\"){worker.loaded=true;if(onFinishedLoading)onFinishedLoading(worker);if(worker.runPthread){worker.runPthread();delete worker.runPthread}}else if(cmd===\"print\"){out(\"Thread \"+d[\"threadId\"]+\": \"+d[\"text\"])}else if(cmd===\"printErr\"){err(\"Thread \"+d[\"threadId\"]+\": \"+d[\"text\"])}else if(cmd===\"alert\"){alert(\"Thread \"+d[\"threadId\"]+\": \"+d[\"text\"])}else if(cmd===\"exit\"){var detached=worker.pthread&&Atomics.load(GROWABLE_HEAP_U32(),worker.pthread.threadInfoStruct+64>>2);if(detached){PThread.returnWorkerToPool(worker)}}else if(cmd===\"exitProcess\"){try{exit(d[\"returnCode\"])}catch(e){if(e instanceof ExitStatus)return;throw e}}else if(cmd===\"cancelDone\"){PThread.returnWorkerToPool(worker)}else if(cmd===\"objectTransfer\"){PThread.receiveObjectTransfer(e.data)}else if(e.data.target===\"setimmediate\"){worker.postMessage(e.data)}else{err(\"worker sent an unknown command \"+cmd)}PThread.currentProxiedOperationCallerThread=undefined};worker.onerror=function(e){err(\"pthread sent an error! \"+e.filename+\":\"+e.lineno+\": \"+e.message)};if(ENVIRONMENT_IS_NODE){worker.on(\"message\",function(data){worker.onmessage({data:data})});worker.on(\"error\",function(data){worker.onerror(data)});worker.on(\"exit\",function(data){})}worker.postMessage({\"cmd\":\"load\",\"urlOrBlob\":Module[\"mainScriptUrlOrBlob\"]||_scriptDir,\"wasmMemory\":wasmMemory,\"wasmModule\":wasmModule})},allocateUnusedWorker:function(){var pthreadMainJs=locateFile(\"tfjs-backend-wasm-threaded-simd.worker.js\");PThread.unusedWorkers.push(new Worker(pthreadMainJs))},getNewWorker:function(){if(PThread.unusedWorkers.length==0){PThread.allocateUnusedWorker();PThread.loadWasmModuleToWorker(PThread.unusedWorkers[0])}if(PThread.unusedWorkers.length>0)return PThread.unusedWorkers.pop();else return null},busySpinWait:function(msecs){var t=performance.now()+msecs;while(performance.now()>2]=value;return value}function _atexit(func,arg){if(ENVIRONMENT_IS_PTHREAD)return _emscripten_proxy_to_main_thread_js(1,1,func,arg)}function __emscripten_notify_thread_queue(targetThreadId,mainThreadId){if(targetThreadId==mainThreadId){postMessage({\"cmd\":\"processQueuedMainThreadWork\"})}else if(ENVIRONMENT_IS_PTHREAD){postMessage({\"targetThread\":targetThreadId,\"cmd\":\"processThreadQueue\"})}else{var pthread=PThread.pthreads[targetThreadId];var worker=pthread&&pthread.worker;if(!worker){return}worker.postMessage({\"cmd\":\"processThreadQueue\"})}return 1}function _abort(){abort()}function _emscripten_asm_const_int(code,sigPtr,argbuf){var args=readAsmConstArgs(sigPtr,argbuf);return ASM_CONSTS[code].apply(null,args)}function _emscripten_conditional_set_current_thread_status(expectedStatus,newStatus){}function _emscripten_futex_wait(addr,val,timeout){if(addr<=0||addr>GROWABLE_HEAP_I8().length||addr&3!=0)return-28;if(!ENVIRONMENT_IS_WEB){var ret=Atomics.wait(GROWABLE_HEAP_I32(),addr>>2,val,timeout);if(ret===\"timed-out\")return-73;if(ret===\"not-equal\")return-6;if(ret===\"ok\")return 0;throw\"Atomics.wait returned an unexpected value \"+ret}else{if(Atomics.load(GROWABLE_HEAP_I32(),addr>>2)!=val){return-6}var tNow=performance.now();var tEnd=tNow+timeout;var lastAddr=Atomics.exchange(GROWABLE_HEAP_I32(),__emscripten_main_thread_futex>>2,addr);while(1){tNow=performance.now();if(tNow>tEnd){lastAddr=Atomics.exchange(GROWABLE_HEAP_I32(),__emscripten_main_thread_futex>>2,0);return-73}lastAddr=Atomics.exchange(GROWABLE_HEAP_I32(),__emscripten_main_thread_futex>>2,0);if(lastAddr==0){break}_emscripten_main_thread_process_queued_calls();if(Atomics.load(GROWABLE_HEAP_I32(),addr>>2)!=val){return-6}lastAddr=Atomics.exchange(GROWABLE_HEAP_I32(),__emscripten_main_thread_futex>>2,addr)}return 0}}function _emscripten_memcpy_big(dest,src,num){GROWABLE_HEAP_U8().copyWithin(dest,src,src+num)}function _emscripten_num_logical_cores(){if(ENVIRONMENT_IS_NODE)return require(\"os\").cpus().length;return navigator[\"hardwareConcurrency\"]}function _emscripten_proxy_to_main_thread_js(index,sync){var numCallArgs=arguments.length-2;var stack=stackSave();var serializedNumCallArgs=numCallArgs;var args=stackAlloc(serializedNumCallArgs*8);var b=args>>3;for(var i=0;i>=2;while(ch=GROWABLE_HEAP_U8()[sigPtr++]){var double=ch<105;if(double&&buf&1)buf++;readAsmConstArgsArray.push(double?GROWABLE_HEAP_F64()[buf++>>1]:GROWABLE_HEAP_I32()[buf]);++buf}return readAsmConstArgsArray}function _emscripten_receive_on_main_thread_js(index,numCallArgs,args){_emscripten_receive_on_main_thread_js_callArgs.length=numCallArgs;var b=args>>3;for(var i=0;i>>16);updateGlobalBufferAndViews(wasmMemory.buffer);return 1}catch(e){}}function _emscripten_resize_heap(requestedSize){var oldSize=_emscripten_get_heap_size();if(requestedSize<=oldSize){return false}var maxHeapSize=2147483648;if(requestedSize>maxHeapSize){return false}for(var cutDown=1;cutDown<=4;cutDown*=2){var overGrownHeapSize=oldSize*(1+.2/cutDown);overGrownHeapSize=Math.min(overGrownHeapSize,requestedSize+100663296);var newSize=Math.min(maxHeapSize,alignUp(Math.max(requestedSize,overGrownHeapSize),65536));var replacement=emscripten_realloc_buffer(newSize);if(replacement){return true}}return false}var JSEvents={inEventHandler:0,removeAllEventListeners:function(){for(var i=JSEvents.eventHandlers.length-1;i>=0;--i){JSEvents._removeHandler(i)}JSEvents.eventHandlers=[];JSEvents.deferredCalls=[]},registerRemoveEventListeners:function(){if(!JSEvents.removeEventListenersRegistered){__ATEXIT__.push(JSEvents.removeAllEventListeners);JSEvents.removeEventListenersRegistered=true}},deferredCalls:[],deferCall:function(targetFunction,precedence,argsList){function arraysHaveEqualContent(arrA,arrB){if(arrA.length!=arrB.length)return false;for(var i in arrA){if(arrA[i]!=arrB[i])return false}return true}for(var i in JSEvents.deferredCalls){var call=JSEvents.deferredCalls[i];if(call.targetFunction==targetFunction&&arraysHaveEqualContent(call.argsList,argsList)){return}}JSEvents.deferredCalls.push({targetFunction:targetFunction,precedence:precedence,argsList:argsList});JSEvents.deferredCalls.sort(function(x,y){return x.precedence>2]=eventTypeId;GROWABLE_HEAP_I32()[varargs+4>>2]=eventData;GROWABLE_HEAP_I32()[varargs+8>>2]=userData;__emscripten_call_on_thread(0,targetThread,637534208,eventHandlerFunc,eventData,varargs);stackRestore(stackTop)},getTargetThreadForEventCallback:function(targetThread){switch(targetThread){case 1:return 0;case 2:return PThread.currentProxiedOperationCallerThread;default:return targetThread}},getNodeNameForTarget:function(target){if(!target)return\"\";if(target==window)return\"#window\";if(target==screen)return\"#screen\";return target&&target.nodeName?target.nodeName:\"\"},fullscreenEnabled:function(){return document.fullscreenEnabled||document.webkitFullscreenEnabled}};function stringToNewUTF8(jsString){var length=lengthBytesUTF8(jsString)+1;var cString=_malloc(length);stringToUTF8(jsString,cString,length);return cString}function _emscripten_set_offscreencanvas_size_on_target_thread_js(targetThread,targetCanvas,width,height){var stackTop=stackSave();var varargs=stackAlloc(12);var targetCanvasPtr=0;if(targetCanvas){targetCanvasPtr=stringToNewUTF8(targetCanvas)}GROWABLE_HEAP_I32()[varargs>>2]=targetCanvasPtr;GROWABLE_HEAP_I32()[varargs+4>>2]=width;GROWABLE_HEAP_I32()[varargs+8>>2]=height;__emscripten_call_on_thread(0,targetThread,657457152,0,targetCanvasPtr,varargs);stackRestore(stackTop)}function _emscripten_set_offscreencanvas_size_on_target_thread(targetThread,targetCanvas,width,height){targetCanvas=targetCanvas?UTF8ToString(targetCanvas):\"\";_emscripten_set_offscreencanvas_size_on_target_thread_js(targetThread,targetCanvas,width,height)}function maybeCStringToJsString(cString){return cString>2?UTF8ToString(cString):cString}var specialHTMLTargets=[0,typeof document!==\"undefined\"?document:0,typeof window!==\"undefined\"?window:0];function findEventTarget(target){target=maybeCStringToJsString(target);var domElement=specialHTMLTargets[target]||(typeof document!==\"undefined\"?document.querySelector(target):undefined);return domElement}function findCanvasEventTarget(target){return findEventTarget(target)}function _emscripten_set_canvas_element_size_calling_thread(target,width,height){var canvas=findCanvasEventTarget(target);if(!canvas)return-4;if(canvas.canvasSharedPtr){GROWABLE_HEAP_I32()[canvas.canvasSharedPtr>>2]=width;GROWABLE_HEAP_I32()[canvas.canvasSharedPtr+4>>2]=height}if(canvas.offscreenCanvas||!canvas.controlTransferredOffscreen){if(canvas.offscreenCanvas)canvas=canvas.offscreenCanvas;var autoResizeViewport=false;if(canvas.GLctxObject&&canvas.GLctxObject.GLctx){var prevViewport=canvas.GLctxObject.GLctx.getParameter(2978);autoResizeViewport=prevViewport[0]===0&&prevViewport[1]===0&&prevViewport[2]===canvas.width&&prevViewport[3]===canvas.height}canvas.width=width;canvas.height=height;if(autoResizeViewport){canvas.GLctxObject.GLctx.viewport(0,0,width,height)}}else if(canvas.canvasSharedPtr){var targetThread=GROWABLE_HEAP_I32()[canvas.canvasSharedPtr+8>>2];_emscripten_set_offscreencanvas_size_on_target_thread(targetThread,target,width,height);return 1}else{return-4}return 0}function _emscripten_set_canvas_element_size_main_thread(target,width,height){if(ENVIRONMENT_IS_PTHREAD)return _emscripten_proxy_to_main_thread_js(2,1,target,width,height);return _emscripten_set_canvas_element_size_calling_thread(target,width,height)}function _emscripten_set_canvas_element_size(target,width,height){var canvas=findCanvasEventTarget(target);if(canvas){return _emscripten_set_canvas_element_size_calling_thread(target,width,height)}else{return _emscripten_set_canvas_element_size_main_thread(target,width,height)}}function _emscripten_set_current_thread_status(newStatus){}function _emscripten_set_thread_name(threadId,name){}function __webgl_enable_ANGLE_instanced_arrays(ctx){var ext=ctx.getExtension(\"ANGLE_instanced_arrays\");if(ext){ctx[\"vertexAttribDivisor\"]=function(index,divisor){ext[\"vertexAttribDivisorANGLE\"](index,divisor)};ctx[\"drawArraysInstanced\"]=function(mode,first,count,primcount){ext[\"drawArraysInstancedANGLE\"](mode,first,count,primcount)};ctx[\"drawElementsInstanced\"]=function(mode,count,type,indices,primcount){ext[\"drawElementsInstancedANGLE\"](mode,count,type,indices,primcount)};return 1}}function __webgl_enable_OES_vertex_array_object(ctx){var ext=ctx.getExtension(\"OES_vertex_array_object\");if(ext){ctx[\"createVertexArray\"]=function(){return ext[\"createVertexArrayOES\"]()};ctx[\"deleteVertexArray\"]=function(vao){ext[\"deleteVertexArrayOES\"](vao)};ctx[\"bindVertexArray\"]=function(vao){ext[\"bindVertexArrayOES\"](vao)};ctx[\"isVertexArray\"]=function(vao){return ext[\"isVertexArrayOES\"](vao)};return 1}}function __webgl_enable_WEBGL_draw_buffers(ctx){var ext=ctx.getExtension(\"WEBGL_draw_buffers\");if(ext){ctx[\"drawBuffers\"]=function(n,bufs){ext[\"drawBuffersWEBGL\"](n,bufs)};return 1}}function __webgl_enable_WEBGL_multi_draw(ctx){return!!(ctx.multiDrawWebgl=ctx.getExtension(\"WEBGL_multi_draw\"))}var GL={counter:1,buffers:[],programs:[],framebuffers:[],renderbuffers:[],textures:[],uniforms:[],shaders:[],vaos:[],contexts:{},offscreenCanvases:{},timerQueriesEXT:[],programInfos:{},stringCache:{},unpackAlignment:4,recordError:function recordError(errorCode){if(!GL.lastError){GL.lastError=errorCode}},getNewId:function(table){var ret=GL.counter++;for(var i=table.length;i>2]:-1;source+=UTF8ToString(GROWABLE_HEAP_I32()[string+i*4>>2],len<0?undefined:len)}return source},createContext:function(canvas,webGLContextAttributes){var ctx=canvas.getContext(\"webgl\",webGLContextAttributes);if(!ctx)return 0;var handle=GL.registerContext(ctx,webGLContextAttributes);return handle},registerContext:function(ctx,webGLContextAttributes){var handle=_malloc(8);GROWABLE_HEAP_I32()[handle+4>>2]=_pthread_self();var context={handle:handle,attributes:webGLContextAttributes,version:webGLContextAttributes.majorVersion,GLctx:ctx};if(ctx.canvas)ctx.canvas.GLctxObject=context;GL.contexts[handle]=context;if(typeof webGLContextAttributes.enableExtensionsByDefault===\"undefined\"||webGLContextAttributes.enableExtensionsByDefault){GL.initExtensions(context)}return handle},makeContextCurrent:function(contextHandle){GL.currentContext=GL.contexts[contextHandle];Module.ctx=GLctx=GL.currentContext&&GL.currentContext.GLctx;return!(contextHandle&&!GLctx)},getContext:function(contextHandle){return GL.contexts[contextHandle]},deleteContext:function(contextHandle){if(GL.currentContext===GL.contexts[contextHandle])GL.currentContext=null;if(typeof JSEvents===\"object\")JSEvents.removeAllHandlersOnTarget(GL.contexts[contextHandle].GLctx.canvas);if(GL.contexts[contextHandle]&&GL.contexts[contextHandle].GLctx.canvas)GL.contexts[contextHandle].GLctx.canvas.GLctxObject=undefined;_free(GL.contexts[contextHandle].handle);GL.contexts[contextHandle]=null},initExtensions:function(context){if(!context)context=GL.currentContext;if(context.initExtensionsDone)return;context.initExtensionsDone=true;var GLctx=context.GLctx;__webgl_enable_ANGLE_instanced_arrays(GLctx);__webgl_enable_OES_vertex_array_object(GLctx);__webgl_enable_WEBGL_draw_buffers(GLctx);GLctx.disjointTimerQueryExt=GLctx.getExtension(\"EXT_disjoint_timer_query\");__webgl_enable_WEBGL_multi_draw(GLctx);var exts=GLctx.getSupportedExtensions()||[];exts.forEach(function(ext){if(ext.indexOf(\"lose_context\")<0&&ext.indexOf(\"debug\")<0){GLctx.getExtension(ext)}})},populateUniformTable:function(program){var p=GL.programs[program];var ptable=GL.programInfos[program]={uniforms:{},maxUniformLength:0,maxAttributeLength:-1,maxUniformBlockNameLength:-1};var utable=ptable.uniforms;var numUniforms=GLctx.getProgramParameter(p,35718);for(var i=0;i>2;var powerPreference=GROWABLE_HEAP_I32()[a+(24>>2)];var contextAttributes={\"alpha\":!!GROWABLE_HEAP_I32()[a+(0>>2)],\"depth\":!!GROWABLE_HEAP_I32()[a+(4>>2)],\"stencil\":!!GROWABLE_HEAP_I32()[a+(8>>2)],\"antialias\":!!GROWABLE_HEAP_I32()[a+(12>>2)],\"premultipliedAlpha\":!!GROWABLE_HEAP_I32()[a+(16>>2)],\"preserveDrawingBuffer\":!!GROWABLE_HEAP_I32()[a+(20>>2)],\"powerPreference\":__emscripten_webgl_power_preferences[powerPreference],\"failIfMajorPerformanceCaveat\":!!GROWABLE_HEAP_I32()[a+(28>>2)],majorVersion:GROWABLE_HEAP_I32()[a+(32>>2)],minorVersion:GROWABLE_HEAP_I32()[a+(36>>2)],enableExtensionsByDefault:GROWABLE_HEAP_I32()[a+(40>>2)],explicitSwapControl:GROWABLE_HEAP_I32()[a+(44>>2)],proxyContextToMainThread:GROWABLE_HEAP_I32()[a+(48>>2)],renderViaOffscreenBackBuffer:GROWABLE_HEAP_I32()[a+(52>>2)]};var canvas=findCanvasEventTarget(target);if(!canvas){return 0}if(contextAttributes.explicitSwapControl){return 0}var contextHandle=GL.createContext(canvas,contextAttributes);return contextHandle}function _emscripten_webgl_create_context(a0,a1){return _emscripten_webgl_do_create_context(a0,a1)}var SYSCALLS={mappings:{},buffers:[null,[],[]],printChar:function(stream,curr){var buffer=SYSCALLS.buffers[stream];if(curr===0||curr===10){(stream===1?out:err)(UTF8ArrayToString(buffer,0));buffer.length=0}else{buffer.push(curr)}},varargs:undefined,get:function(){SYSCALLS.varargs+=4;var ret=GROWABLE_HEAP_I32()[SYSCALLS.varargs-4>>2];return ret},getStr:function(ptr){var ret=UTF8ToString(ptr);return ret},get64:function(low,high){return low}};function _fd_close(fd){if(ENVIRONMENT_IS_PTHREAD)return _emscripten_proxy_to_main_thread_js(3,1,fd);return 0}function _fd_seek(fd,offset_low,offset_high,whence,newOffset){if(ENVIRONMENT_IS_PTHREAD)return _emscripten_proxy_to_main_thread_js(4,1,fd,offset_low,offset_high,whence,newOffset)}function _fd_write(fd,iov,iovcnt,pnum){if(ENVIRONMENT_IS_PTHREAD)return _emscripten_proxy_to_main_thread_js(5,1,fd,iov,iovcnt,pnum);var num=0;for(var i=0;i>2];var len=GROWABLE_HEAP_I32()[iov+(i*8+4)>>2];for(var j=0;j>2]=num;return 0}function _pthread_cleanup_pop(execute){var routine=PThread.threadExitHandlers.pop();if(execute)routine()}function _pthread_cleanup_push(routine,arg){PThread.threadExitHandlers.push(function(){wasmTable.get(routine)(arg)})}function spawnThread(threadParams){if(ENVIRONMENT_IS_PTHREAD)throw\"Internal Error! spawnThread() can only ever be called from main application thread!\";var worker=PThread.getNewWorker();if(worker.pthread!==undefined)throw\"Internal error!\";if(!threadParams.pthread_ptr)throw\"Internal error, no pthread ptr!\";PThread.runningWorkers.push(worker);var tlsMemory=_malloc(128*4);for(var i=0;i<128;++i){GROWABLE_HEAP_I32()[tlsMemory+i*4>>2]=0}var stackHigh=threadParams.stackBase+threadParams.stackSize;var pthread=PThread.pthreads[threadParams.pthread_ptr]={worker:worker,stackBase:threadParams.stackBase,stackSize:threadParams.stackSize,allocatedOwnStack:threadParams.allocatedOwnStack,threadInfoStruct:threadParams.pthread_ptr};var tis=pthread.threadInfoStruct>>2;Atomics.store(GROWABLE_HEAP_U32(),tis+(64>>2),threadParams.detached);Atomics.store(GROWABLE_HEAP_U32(),tis+(100>>2),tlsMemory);Atomics.store(GROWABLE_HEAP_U32(),tis+(40>>2),pthread.threadInfoStruct);Atomics.store(GROWABLE_HEAP_U32(),tis+(80>>2),threadParams.stackSize);Atomics.store(GROWABLE_HEAP_U32(),tis+(76>>2),stackHigh);Atomics.store(GROWABLE_HEAP_U32(),tis+(104>>2),threadParams.stackSize);Atomics.store(GROWABLE_HEAP_U32(),tis+(104+8>>2),stackHigh);Atomics.store(GROWABLE_HEAP_U32(),tis+(104+12>>2),threadParams.detached);var global_libc=_emscripten_get_global_libc();var global_locale=global_libc+40;Atomics.store(GROWABLE_HEAP_U32(),tis+(172>>2),global_locale);worker.pthread=pthread;var msg={\"cmd\":\"run\",\"start_routine\":threadParams.startRoutine,\"arg\":threadParams.arg,\"threadInfoStruct\":threadParams.pthread_ptr,\"stackBase\":threadParams.stackBase,\"stackSize\":threadParams.stackSize};worker.runPthread=function(){msg.time=performance.now();worker.postMessage(msg,threadParams.transferList)};if(worker.loaded){worker.runPthread();delete worker.runPthread}}function _pthread_create(pthread_ptr,attr,start_routine,arg){if(typeof SharedArrayBuffer===\"undefined\"){err(\"Current environment does not support SharedArrayBuffer, pthreads are not available!\");return 6}if(!pthread_ptr){err(\"pthread_create called with a null thread pointer!\");return 28}var transferList=[];var error=0;if(ENVIRONMENT_IS_PTHREAD&&(transferList.length===0||error)){return _emscripten_sync_run_in_main_thread_4(687865856,pthread_ptr,attr,start_routine,arg)}if(error)return error;var stackSize=0;var stackBase=0;var detached=0;if(attr&&attr!=-1){stackSize=GROWABLE_HEAP_I32()[attr>>2];stackSize+=81920;stackBase=GROWABLE_HEAP_I32()[attr+8>>2];detached=GROWABLE_HEAP_I32()[attr+12>>2]!==0}else{stackSize=2097152}var allocatedOwnStack=stackBase==0;if(allocatedOwnStack){stackBase=_memalign(16,stackSize)}else{stackBase-=stackSize;assert(stackBase>0)}var threadInfoStruct=_malloc(228);for(var i=0;i<228>>2;++i)GROWABLE_HEAP_U32()[(threadInfoStruct>>2)+i]=0;GROWABLE_HEAP_I32()[pthread_ptr>>2]=threadInfoStruct;GROWABLE_HEAP_I32()[threadInfoStruct+12>>2]=threadInfoStruct;var headPtr=threadInfoStruct+152;GROWABLE_HEAP_I32()[headPtr>>2]=headPtr;var threadParams={stackBase:stackBase,stackSize:stackSize,allocatedOwnStack:allocatedOwnStack,detached:detached,startRoutine:start_routine,pthread_ptr:threadInfoStruct,arg:arg,transferList:transferList};if(ENVIRONMENT_IS_PTHREAD){threadParams.cmd=\"spawnThread\";postMessage(threadParams,transferList)}else{spawnThread(threadParams)}return 0}function _sysconf(name){if(ENVIRONMENT_IS_PTHREAD)return _emscripten_proxy_to_main_thread_js(6,1,name);switch(name){case 30:return 16384;case 85:var maxHeapSize=2147483648;return maxHeapSize/16384;case 132:case 133:case 12:case 137:case 138:case 15:case 235:case 16:case 17:case 18:case 19:case 20:case 149:case 13:case 10:case 236:case 153:case 9:case 21:case 22:case 159:case 154:case 14:case 77:case 78:case 139:case 82:case 68:case 67:case 164:case 11:case 29:case 47:case 48:case 95:case 52:case 51:case 46:return 200809;case 27:case 246:case 127:case 128:case 23:case 24:case 160:case 161:case 181:case 182:case 242:case 183:case 184:case 243:case 244:case 245:case 165:case 178:case 179:case 49:case 50:case 168:case 169:case 175:case 170:case 171:case 172:case 97:case 76:case 32:case 173:case 35:case 80:case 81:case 79:return-1;case 176:case 177:case 7:case 155:case 8:case 157:case 125:case 126:case 92:case 93:case 129:case 130:case 131:case 94:case 91:return 1;case 74:case 60:case 69:case 70:case 4:return 1024;case 31:case 42:case 72:return 32;case 87:case 26:case 33:return 2147483647;case 34:case 1:return 47839;case 38:case 36:return 99;case 43:case 37:return 2048;case 0:return 2097152;case 3:return 65536;case 28:return 32768;case 44:return 32767;case 75:return 16384;case 39:return 1e3;case 89:return 700;case 71:return 256;case 40:return 255;case 2:return 100;case 180:return 64;case 25:return 20;case 5:return 16;case 6:return 6;case 73:return 4;case 84:{if(typeof navigator===\"object\")return navigator[\"hardwareConcurrency\"]||1;return 1}}setErrNo(28);return-1}if(!ENVIRONMENT_IS_PTHREAD)PThread.initMainThreadBlock();var GLctx;var proxiedFunctionTable=[null,_atexit,_emscripten_set_canvas_element_size_main_thread,_fd_close,_fd_seek,_fd_write,_sysconf];var asmLibraryArg={\"e\":___assert_fail,\"r\":___call_main,\"x\":__emscripten_notify_thread_queue,\"b\":_abort,\"y\":_emscripten_asm_const_int,\"j\":_emscripten_conditional_set_current_thread_status,\"c\":_emscripten_futex_wait,\"d\":_emscripten_futex_wake,\"f\":_emscripten_get_now,\"p\":_emscripten_memcpy_big,\"z\":_emscripten_num_logical_cores,\"u\":_emscripten_receive_on_main_thread_js,\"q\":_emscripten_resize_heap,\"v\":_emscripten_set_canvas_element_size,\"i\":_emscripten_set_current_thread_status,\"t\":_emscripten_set_thread_name,\"w\":_emscripten_webgl_create_context,\"m\":_fd_close,\"n\":_fd_seek,\"g\":_fd_write,\"o\":initPthreadsJS,\"a\":wasmMemory||Module[\"wasmMemory\"],\"k\":_pthread_cleanup_pop,\"l\":_pthread_cleanup_push,\"h\":_pthread_create,\"s\":_sysconf};var asm=createWasm();var ___wasm_call_ctors=Module[\"___wasm_call_ctors\"]=function(){return(___wasm_call_ctors=Module[\"___wasm_call_ctors\"]=Module[\"asm\"][\"A\"]).apply(null,arguments)};var _init=Module[\"_init\"]=function(){return(_init=Module[\"_init\"]=Module[\"asm\"][\"B\"]).apply(null,arguments)};var _register_tensor=Module[\"_register_tensor\"]=function(){return(_register_tensor=Module[\"_register_tensor\"]=Module[\"asm\"][\"C\"]).apply(null,arguments)};var _dispose_data=Module[\"_dispose_data\"]=function(){return(_dispose_data=Module[\"_dispose_data\"]=Module[\"asm\"][\"D\"]).apply(null,arguments)};var _dispose=Module[\"_dispose\"]=function(){return(_dispose=Module[\"_dispose\"]=Module[\"asm\"][\"E\"]).apply(null,arguments)};var _Abs=Module[\"_Abs\"]=function(){return(_Abs=Module[\"_Abs\"]=Module[\"asm\"][\"G\"]).apply(null,arguments)};var _Add=Module[\"_Add\"]=function(){return(_Add=Module[\"_Add\"]=Module[\"asm\"][\"H\"]).apply(null,arguments)};var _AddN=Module[\"_AddN\"]=function(){return(_AddN=Module[\"_AddN\"]=Module[\"asm\"][\"I\"]).apply(null,arguments)};var _All=Module[\"_All\"]=function(){return(_All=Module[\"_All\"]=Module[\"asm\"][\"J\"]).apply(null,arguments)};var _Any=Module[\"_Any\"]=function(){return(_Any=Module[\"_Any\"]=Module[\"asm\"][\"K\"]).apply(null,arguments)};var _ArgMax=Module[\"_ArgMax\"]=function(){return(_ArgMax=Module[\"_ArgMax\"]=Module[\"asm\"][\"L\"]).apply(null,arguments)};var _AvgPool=Module[\"_AvgPool\"]=function(){return(_AvgPool=Module[\"_AvgPool\"]=Module[\"asm\"][\"M\"]).apply(null,arguments)};var _BatchMatMul=Module[\"_BatchMatMul\"]=function(){return(_BatchMatMul=Module[\"_BatchMatMul\"]=Module[\"asm\"][\"N\"]).apply(null,arguments)};var _Ceil=Module[\"_Ceil\"]=function(){return(_Ceil=Module[\"_Ceil\"]=Module[\"asm\"][\"O\"]).apply(null,arguments)};var _ClipByValue=Module[\"_ClipByValue\"]=function(){return(_ClipByValue=Module[\"_ClipByValue\"]=Module[\"asm\"][\"P\"]).apply(null,arguments)};var _Conv2D=Module[\"_Conv2D\"]=function(){return(_Conv2D=Module[\"_Conv2D\"]=Module[\"asm\"][\"Q\"]).apply(null,arguments)};var _Conv2DBackpropInput=Module[\"_Conv2DBackpropInput\"]=function(){return(_Conv2DBackpropInput=Module[\"_Conv2DBackpropInput\"]=Module[\"asm\"][\"R\"]).apply(null,arguments)};var _Cos=Module[\"_Cos\"]=function(){return(_Cos=Module[\"_Cos\"]=Module[\"asm\"][\"S\"]).apply(null,arguments)};var _CropAndResize=Module[\"_CropAndResize\"]=function(){return(_CropAndResize=Module[\"_CropAndResize\"]=Module[\"asm\"][\"T\"]).apply(null,arguments)};var _Cumsum=Module[\"_Cumsum\"]=function(){return(_Cumsum=Module[\"_Cumsum\"]=Module[\"asm\"][\"U\"]).apply(null,arguments)};var _DepthToSpace=Module[\"_DepthToSpace\"]=function(){return(_DepthToSpace=Module[\"_DepthToSpace\"]=Module[\"asm\"][\"V\"]).apply(null,arguments)};var _DepthwiseConv2dNative=Module[\"_DepthwiseConv2dNative\"]=function(){return(_DepthwiseConv2dNative=Module[\"_DepthwiseConv2dNative\"]=Module[\"asm\"][\"W\"]).apply(null,arguments)};var _Equal=Module[\"_Equal\"]=function(){return(_Equal=Module[\"_Equal\"]=Module[\"asm\"][\"X\"]).apply(null,arguments)};var _Exp=Module[\"_Exp\"]=function(){return(_Exp=Module[\"_Exp\"]=Module[\"asm\"][\"Y\"]).apply(null,arguments)};var _FlipLeftRight=Module[\"_FlipLeftRight\"]=function(){return(_FlipLeftRight=Module[\"_FlipLeftRight\"]=Module[\"asm\"][\"Z\"]).apply(null,arguments)};var _Floor=Module[\"_Floor\"]=function(){return(_Floor=Module[\"_Floor\"]=Module[\"asm\"][\"_\"]).apply(null,arguments)};var _FloorDiv=Module[\"_FloorDiv\"]=function(){return(_FloorDiv=Module[\"_FloorDiv\"]=Module[\"asm\"][\"$\"]).apply(null,arguments)};var _FusedBatchNorm=Module[\"_FusedBatchNorm\"]=function(){return(_FusedBatchNorm=Module[\"_FusedBatchNorm\"]=Module[\"asm\"][\"aa\"]).apply(null,arguments)};var _FusedConv2D=Module[\"_FusedConv2D\"]=function(){return(_FusedConv2D=Module[\"_FusedConv2D\"]=Module[\"asm\"][\"ba\"]).apply(null,arguments)};var _FusedDepthwiseConv2D=Module[\"_FusedDepthwiseConv2D\"]=function(){return(_FusedDepthwiseConv2D=Module[\"_FusedDepthwiseConv2D\"]=Module[\"asm\"][\"ca\"]).apply(null,arguments)};var _Gather=Module[\"_Gather\"]=function(){return(_Gather=Module[\"_Gather\"]=Module[\"asm\"][\"da\"]).apply(null,arguments)};var _GatherNd=Module[\"_GatherNd\"]=function(){return(_GatherNd=Module[\"_GatherNd\"]=Module[\"asm\"][\"ea\"]).apply(null,arguments)};var _Greater=Module[\"_Greater\"]=function(){return(_Greater=Module[\"_Greater\"]=Module[\"asm\"][\"fa\"]).apply(null,arguments)};var _GreaterEqual=Module[\"_GreaterEqual\"]=function(){return(_GreaterEqual=Module[\"_GreaterEqual\"]=Module[\"asm\"][\"ga\"]).apply(null,arguments)};var _LeakyRelu=Module[\"_LeakyRelu\"]=function(){return(_LeakyRelu=Module[\"_LeakyRelu\"]=Module[\"asm\"][\"ha\"]).apply(null,arguments)};var _Less=Module[\"_Less\"]=function(){return(_Less=Module[\"_Less\"]=Module[\"asm\"][\"ia\"]).apply(null,arguments)};var _LessEqual=Module[\"_LessEqual\"]=function(){return(_LessEqual=Module[\"_LessEqual\"]=Module[\"asm\"][\"ja\"]).apply(null,arguments)};var _Log=Module[\"_Log\"]=function(){return(_Log=Module[\"_Log\"]=Module[\"asm\"][\"ka\"]).apply(null,arguments)};var _LogicalAnd=Module[\"_LogicalAnd\"]=function(){return(_LogicalAnd=Module[\"_LogicalAnd\"]=Module[\"asm\"][\"la\"]).apply(null,arguments)};var _Max=Module[\"_Max\"]=function(){return(_Max=Module[\"_Max\"]=Module[\"asm\"][\"ma\"]).apply(null,arguments)};var _MaxPool=Module[\"_MaxPool\"]=function(){return(_MaxPool=Module[\"_MaxPool\"]=Module[\"asm\"][\"na\"]).apply(null,arguments)};var _Maximum=Module[\"_Maximum\"]=function(){return(_Maximum=Module[\"_Maximum\"]=Module[\"asm\"][\"oa\"]).apply(null,arguments)};var _Mean=Module[\"_Mean\"]=function(){return(_Mean=Module[\"_Mean\"]=Module[\"asm\"][\"pa\"]).apply(null,arguments)};var _Min=Module[\"_Min\"]=function(){return(_Min=Module[\"_Min\"]=Module[\"asm\"][\"qa\"]).apply(null,arguments)};var _Minimum=Module[\"_Minimum\"]=function(){return(_Minimum=Module[\"_Minimum\"]=Module[\"asm\"][\"ra\"]).apply(null,arguments)};var _MirrorPad=Module[\"_MirrorPad\"]=function(){return(_MirrorPad=Module[\"_MirrorPad\"]=Module[\"asm\"][\"sa\"]).apply(null,arguments)};var _Multiply=Module[\"_Multiply\"]=function(){return(_Multiply=Module[\"_Multiply\"]=Module[\"asm\"][\"ta\"]).apply(null,arguments)};var _Neg=Module[\"_Neg\"]=function(){return(_Neg=Module[\"_Neg\"]=Module[\"asm\"][\"ua\"]).apply(null,arguments)};var _NonMaxSuppressionV3=Module[\"_NonMaxSuppressionV3\"]=function(){return(_NonMaxSuppressionV3=Module[\"_NonMaxSuppressionV3\"]=Module[\"asm\"][\"va\"]).apply(null,arguments)};var _NonMaxSuppressionV4=Module[\"_NonMaxSuppressionV4\"]=function(){return(_NonMaxSuppressionV4=Module[\"_NonMaxSuppressionV4\"]=Module[\"asm\"][\"wa\"]).apply(null,arguments)};var _NonMaxSuppressionV5=Module[\"_NonMaxSuppressionV5\"]=function(){return(_NonMaxSuppressionV5=Module[\"_NonMaxSuppressionV5\"]=Module[\"asm\"][\"xa\"]).apply(null,arguments)};var _NotEqual=Module[\"_NotEqual\"]=function(){return(_NotEqual=Module[\"_NotEqual\"]=Module[\"asm\"][\"ya\"]).apply(null,arguments)};var _OneHot=Module[\"_OneHot\"]=function(){return(_OneHot=Module[\"_OneHot\"]=Module[\"asm\"][\"za\"]).apply(null,arguments)};var _PadV2=Module[\"_PadV2\"]=function(){return(_PadV2=Module[\"_PadV2\"]=Module[\"asm\"][\"Aa\"]).apply(null,arguments)};var _Pow=Module[\"_Pow\"]=function(){return(_Pow=Module[\"_Pow\"]=Module[\"asm\"][\"Ba\"]).apply(null,arguments)};var _Prelu=Module[\"_Prelu\"]=function(){return(_Prelu=Module[\"_Prelu\"]=Module[\"asm\"][\"Ca\"]).apply(null,arguments)};var _Prod=Module[\"_Prod\"]=function(){return(_Prod=Module[\"_Prod\"]=Module[\"asm\"][\"Da\"]).apply(null,arguments)};var _RealDiv=Module[\"_RealDiv\"]=function(){return(_RealDiv=Module[\"_RealDiv\"]=Module[\"asm\"][\"Ea\"]).apply(null,arguments)};var _Relu=Module[\"_Relu\"]=function(){return(_Relu=Module[\"_Relu\"]=Module[\"asm\"][\"Fa\"]).apply(null,arguments)};var _Relu6=Module[\"_Relu6\"]=function(){return(_Relu6=Module[\"_Relu6\"]=Module[\"asm\"][\"Ga\"]).apply(null,arguments)};var _ResizeBilinear=Module[\"_ResizeBilinear\"]=function(){return(_ResizeBilinear=Module[\"_ResizeBilinear\"]=Module[\"asm\"][\"Ha\"]).apply(null,arguments)};var _Reverse=Module[\"_Reverse\"]=function(){return(_Reverse=Module[\"_Reverse\"]=Module[\"asm\"][\"Ia\"]).apply(null,arguments)};var _RotateWithOffset=Module[\"_RotateWithOffset\"]=function(){return(_RotateWithOffset=Module[\"_RotateWithOffset\"]=Module[\"asm\"][\"Ja\"]).apply(null,arguments)};var _Round=Module[\"_Round\"]=function(){return(_Round=Module[\"_Round\"]=Module[\"asm\"][\"Ka\"]).apply(null,arguments)};var _Rsqrt=Module[\"_Rsqrt\"]=function(){return(_Rsqrt=Module[\"_Rsqrt\"]=Module[\"asm\"][\"La\"]).apply(null,arguments)};var _ScatterNd=Module[\"_ScatterNd\"]=function(){return(_ScatterNd=Module[\"_ScatterNd\"]=Module[\"asm\"][\"Ma\"]).apply(null,arguments)};var _SelectV2=Module[\"_SelectV2\"]=function(){return(_SelectV2=Module[\"_SelectV2\"]=Module[\"asm\"][\"Na\"]).apply(null,arguments)};var _Sigmoid=Module[\"_Sigmoid\"]=function(){return(_Sigmoid=Module[\"_Sigmoid\"]=Module[\"asm\"][\"Oa\"]).apply(null,arguments)};var _Sin=Module[\"_Sin\"]=function(){return(_Sin=Module[\"_Sin\"]=Module[\"asm\"][\"Pa\"]).apply(null,arguments)};var _Softmax=Module[\"_Softmax\"]=function(){return(_Softmax=Module[\"_Softmax\"]=Module[\"asm\"][\"Qa\"]).apply(null,arguments)};var _Sqrt=Module[\"_Sqrt\"]=function(){return(_Sqrt=Module[\"_Sqrt\"]=Module[\"asm\"][\"Ra\"]).apply(null,arguments)};var _Square=Module[\"_Square\"]=function(){return(_Square=Module[\"_Square\"]=Module[\"asm\"][\"Sa\"]).apply(null,arguments)};var _SquaredDifference=Module[\"_SquaredDifference\"]=function(){return(_SquaredDifference=Module[\"_SquaredDifference\"]=Module[\"asm\"][\"Ta\"]).apply(null,arguments)};var _Step=Module[\"_Step\"]=function(){return(_Step=Module[\"_Step\"]=Module[\"asm\"][\"Ua\"]).apply(null,arguments)};var _StridedSlice=Module[\"_StridedSlice\"]=function(){return(_StridedSlice=Module[\"_StridedSlice\"]=Module[\"asm\"][\"Va\"]).apply(null,arguments)};var _Sub=Module[\"_Sub\"]=function(){return(_Sub=Module[\"_Sub\"]=Module[\"asm\"][\"Wa\"]).apply(null,arguments)};var _Sum=Module[\"_Sum\"]=function(){return(_Sum=Module[\"_Sum\"]=Module[\"asm\"][\"Xa\"]).apply(null,arguments)};var _Tan=Module[\"_Tan\"]=function(){return(_Tan=Module[\"_Tan\"]=Module[\"asm\"][\"Ya\"]).apply(null,arguments)};var _Tanh=Module[\"_Tanh\"]=function(){return(_Tanh=Module[\"_Tanh\"]=Module[\"asm\"][\"Za\"]).apply(null,arguments)};var _Tile=Module[\"_Tile\"]=function(){return(_Tile=Module[\"_Tile\"]=Module[\"asm\"][\"_a\"]).apply(null,arguments)};var _TopK=Module[\"_TopK\"]=function(){return(_TopK=Module[\"_TopK\"]=Module[\"asm\"][\"$a\"]).apply(null,arguments)};var _Transform=Module[\"_Transform\"]=function(){return(_Transform=Module[\"_Transform\"]=Module[\"asm\"][\"ab\"]).apply(null,arguments)};var _Transpose=Module[\"_Transpose\"]=function(){return(_Transpose=Module[\"_Transpose\"]=Module[\"asm\"][\"bb\"]).apply(null,arguments)};var __FusedMatMul=Module[\"__FusedMatMul\"]=function(){return(__FusedMatMul=Module[\"__FusedMatMul\"]=Module[\"asm\"][\"cb\"]).apply(null,arguments)};var _malloc=Module[\"_malloc\"]=function(){return(_malloc=Module[\"_malloc\"]=Module[\"asm\"][\"db\"]).apply(null,arguments)};var _free=Module[\"_free\"]=function(){return(_free=Module[\"_free\"]=Module[\"asm\"][\"eb\"]).apply(null,arguments)};var ___errno_location=Module[\"___errno_location\"]=function(){return(___errno_location=Module[\"___errno_location\"]=Module[\"asm\"][\"fb\"]).apply(null,arguments)};var _emscripten_get_global_libc=Module[\"_emscripten_get_global_libc\"]=function(){return(_emscripten_get_global_libc=Module[\"_emscripten_get_global_libc\"]=Module[\"asm\"][\"gb\"]).apply(null,arguments)};var _pthread_self=Module[\"_pthread_self\"]=function(){return(_pthread_self=Module[\"_pthread_self\"]=Module[\"asm\"][\"hb\"]).apply(null,arguments)};var ___pthread_tsd_run_dtors=Module[\"___pthread_tsd_run_dtors\"]=function(){return(___pthread_tsd_run_dtors=Module[\"___pthread_tsd_run_dtors\"]=Module[\"asm\"][\"ib\"]).apply(null,arguments)};var _emscripten_main_thread_process_queued_calls=Module[\"_emscripten_main_thread_process_queued_calls\"]=function(){return(_emscripten_main_thread_process_queued_calls=Module[\"_emscripten_main_thread_process_queued_calls\"]=Module[\"asm\"][\"jb\"]).apply(null,arguments)};var _emscripten_current_thread_process_queued_calls=Module[\"_emscripten_current_thread_process_queued_calls\"]=function(){return(_emscripten_current_thread_process_queued_calls=Module[\"_emscripten_current_thread_process_queued_calls\"]=Module[\"asm\"][\"kb\"]).apply(null,arguments)};var _emscripten_register_main_browser_thread_id=Module[\"_emscripten_register_main_browser_thread_id\"]=function(){return(_emscripten_register_main_browser_thread_id=Module[\"_emscripten_register_main_browser_thread_id\"]=Module[\"asm\"][\"lb\"]).apply(null,arguments)};var __emscripten_do_dispatch_to_thread=Module[\"__emscripten_do_dispatch_to_thread\"]=function(){return(__emscripten_do_dispatch_to_thread=Module[\"__emscripten_do_dispatch_to_thread\"]=Module[\"asm\"][\"mb\"]).apply(null,arguments)};var _emscripten_sync_run_in_main_thread_4=Module[\"_emscripten_sync_run_in_main_thread_4\"]=function(){return(_emscripten_sync_run_in_main_thread_4=Module[\"_emscripten_sync_run_in_main_thread_4\"]=Module[\"asm\"][\"nb\"]).apply(null,arguments)};var _emscripten_run_in_main_runtime_thread_js=Module[\"_emscripten_run_in_main_runtime_thread_js\"]=function(){return(_emscripten_run_in_main_runtime_thread_js=Module[\"_emscripten_run_in_main_runtime_thread_js\"]=Module[\"asm\"][\"ob\"]).apply(null,arguments)};var __emscripten_call_on_thread=Module[\"__emscripten_call_on_thread\"]=function(){return(__emscripten_call_on_thread=Module[\"__emscripten_call_on_thread\"]=Module[\"asm\"][\"pb\"]).apply(null,arguments)};var _emscripten_tls_init=Module[\"_emscripten_tls_init\"]=function(){return(_emscripten_tls_init=Module[\"_emscripten_tls_init\"]=Module[\"asm\"][\"qb\"]).apply(null,arguments)};var __emscripten_thread_init=Module[\"__emscripten_thread_init\"]=function(){return(__emscripten_thread_init=Module[\"__emscripten_thread_init\"]=Module[\"asm\"][\"rb\"]).apply(null,arguments)};var stackSave=Module[\"stackSave\"]=function(){return(stackSave=Module[\"stackSave\"]=Module[\"asm\"][\"sb\"]).apply(null,arguments)};var stackRestore=Module[\"stackRestore\"]=function(){return(stackRestore=Module[\"stackRestore\"]=Module[\"asm\"][\"tb\"]).apply(null,arguments)};var stackAlloc=Module[\"stackAlloc\"]=function(){return(stackAlloc=Module[\"stackAlloc\"]=Module[\"asm\"][\"ub\"]).apply(null,arguments)};var _emscripten_stack_set_limits=Module[\"_emscripten_stack_set_limits\"]=function(){return(_emscripten_stack_set_limits=Module[\"_emscripten_stack_set_limits\"]=Module[\"asm\"][\"vb\"]).apply(null,arguments)};var _memalign=Module[\"_memalign\"]=function(){return(_memalign=Module[\"_memalign\"]=Module[\"asm\"][\"wb\"]).apply(null,arguments)};var __emscripten_allow_main_runtime_queued_calls=Module[\"__emscripten_allow_main_runtime_queued_calls\"]=9808;var __emscripten_main_thread_futex=Module[\"__emscripten_main_thread_futex\"]=11432;Module[\"cwrap\"]=cwrap;Module[\"PThread\"]=PThread;Module[\"PThread\"]=PThread;Module[\"wasmMemory\"]=wasmMemory;Module[\"ExitStatus\"]=ExitStatus;var calledRun;function ExitStatus(status){this.name=\"ExitStatus\";this.message=\"Program terminated with exit(\"+status+\")\";this.status=status}dependenciesFulfilled=function runCaller(){if(!calledRun)run();if(!calledRun)dependenciesFulfilled=runCaller};function run(args){args=args||arguments_;if(runDependencies>0){return}if(ENVIRONMENT_IS_PTHREAD){readyPromiseResolve(Module);initRuntime();postMessage({\"cmd\":\"loaded\"});return}preRun();if(runDependencies>0){return}function doRun(){if(calledRun)return;calledRun=true;Module[\"calledRun\"]=true;if(ABORT)return;initRuntime();preMain();readyPromiseResolve(Module);if(Module[\"onRuntimeInitialized\"])Module[\"onRuntimeInitialized\"]();postRun()}if(Module[\"setStatus\"]){Module[\"setStatus\"](\"Running...\");setTimeout(function(){setTimeout(function(){Module[\"setStatus\"](\"\")},1);doRun()},1)}else{doRun()}}Module[\"run\"]=run;function exit(status,implicit){if(implicit&&noExitRuntime&&status===0){return}if(!implicit){if(ENVIRONMENT_IS_PTHREAD){postMessage({\"cmd\":\"exitProcess\",\"returnCode\":status});throw new ExitStatus(status)}else{}}if(noExitRuntime){}else{PThread.terminateAllThreads();EXITSTATUS=status;exitRuntime();if(Module[\"onExit\"])Module[\"onExit\"](status);ABORT=true}quit_(status,new ExitStatus(status))}if(Module[\"preInit\"]){if(typeof Module[\"preInit\"]==\"function\")Module[\"preInit\"]=[Module[\"preInit\"]];while(Module[\"preInit\"].length>0){Module[\"preInit\"].pop()()}}if(ENVIRONMENT_IS_PTHREAD){noExitRuntime=false;PThread.initWorker()}run();\n\n\n return WasmBackendModuleThreadedSimd.ready\n}\n);\n})();\nif (typeof exports === 'object' && typeof module === 'object')\n module.exports = WasmBackendModuleThreadedSimd;\nelse if (typeof define === 'function' && define['amd'])\n define([], function() { return WasmBackendModuleThreadedSimd; });\nelse if (typeof exports === 'object')\n exports[\"WasmBackendModuleThreadedSimd\"] = WasmBackendModuleThreadedSimd;\n", "\nvar WasmBackendModule = (function() {\n var _scriptDir = typeof document !== 'undefined' && document.currentScript ? document.currentScript.src : undefined;\n if (typeof __filename !== 'undefined') _scriptDir = _scriptDir || __filename;\n return (\nfunction(WasmBackendModule) {\n WasmBackendModule = WasmBackendModule || {};\n\nvar Module=typeof WasmBackendModule!==\"undefined\"?WasmBackendModule:{};var readyPromiseResolve,readyPromiseReject;Module[\"ready\"]=new Promise(function(resolve,reject){readyPromiseResolve=resolve;readyPromiseReject=reject});var moduleOverrides={};var key;for(key in Module){if(Module.hasOwnProperty(key)){moduleOverrides[key]=Module[key]}}var arguments_=[];var thisProgram=\"./this.program\";var quit_=function(status,toThrow){throw toThrow};var ENVIRONMENT_IS_WEB=false;var ENVIRONMENT_IS_WORKER=false;var ENVIRONMENT_IS_NODE=false;var ENVIRONMENT_IS_SHELL=false;ENVIRONMENT_IS_WEB=typeof window===\"object\";ENVIRONMENT_IS_WORKER=typeof importScripts===\"function\";ENVIRONMENT_IS_NODE=typeof process===\"object\"&&typeof process.versions===\"object\"&&typeof process.versions.node===\"string\";ENVIRONMENT_IS_SHELL=!ENVIRONMENT_IS_WEB&&!ENVIRONMENT_IS_NODE&&!ENVIRONMENT_IS_WORKER;var scriptDirectory=\"\";function locateFile(path){if(Module[\"locateFile\"]){return Module[\"locateFile\"](path,scriptDirectory)}return scriptDirectory+path}var read_,readAsync,readBinary,setWindowTitle;var nodeFS;var nodePath;if(ENVIRONMENT_IS_NODE){if(ENVIRONMENT_IS_WORKER){scriptDirectory=require(\"path\").dirname(scriptDirectory)+\"/\"}else{scriptDirectory=__dirname+\"/\"}read_=function shell_read(filename,binary){if(!nodeFS)nodeFS=require(\"fs\");if(!nodePath)nodePath=require(\"path\");filename=nodePath[\"normalize\"](filename);return nodeFS[\"readFileSync\"](filename,binary?null:\"utf8\")};readBinary=function readBinary(filename){var ret=read_(filename,true);if(!ret.buffer){ret=new Uint8Array(ret)}assert(ret.buffer);return ret};if(process[\"argv\"].length>1){thisProgram=process[\"argv\"][1].replace(/\\\\/g,\"/\")}arguments_=process[\"argv\"].slice(2);process[\"on\"](\"uncaughtException\",function(ex){if(!(ex instanceof ExitStatus)){throw ex}});process[\"on\"](\"unhandledRejection\",abort);quit_=function(status){process[\"exit\"](status)};Module[\"inspect\"]=function(){return\"[Emscripten Module object]\"}}else if(ENVIRONMENT_IS_SHELL){if(typeof read!=\"undefined\"){read_=function shell_read(f){return read(f)}}readBinary=function readBinary(f){var data;if(typeof readbuffer===\"function\"){return new Uint8Array(readbuffer(f))}data=read(f,\"binary\");assert(typeof data===\"object\");return data};if(typeof scriptArgs!=\"undefined\"){arguments_=scriptArgs}else if(typeof arguments!=\"undefined\"){arguments_=arguments}if(typeof quit===\"function\"){quit_=function(status){quit(status)}}if(typeof print!==\"undefined\"){if(typeof console===\"undefined\")console={};console.log=print;console.warn=console.error=typeof printErr!==\"undefined\"?printErr:print}}else if(ENVIRONMENT_IS_WEB||ENVIRONMENT_IS_WORKER){if(ENVIRONMENT_IS_WORKER){scriptDirectory=self.location.href}else if(typeof document!==\"undefined\"&&document.currentScript){scriptDirectory=document.currentScript.src}if(_scriptDir){scriptDirectory=_scriptDir}if(scriptDirectory.indexOf(\"blob:\")!==0){scriptDirectory=scriptDirectory.substr(0,scriptDirectory.lastIndexOf(\"/\")+1)}else{scriptDirectory=\"\"}{read_=function(url){var xhr=new XMLHttpRequest;xhr.open(\"GET\",url,false);xhr.send(null);return xhr.responseText};if(ENVIRONMENT_IS_WORKER){readBinary=function(url){var xhr=new XMLHttpRequest;xhr.open(\"GET\",url,false);xhr.responseType=\"arraybuffer\";xhr.send(null);return new Uint8Array(xhr.response)}}readAsync=function(url,onload,onerror){var xhr=new XMLHttpRequest;xhr.open(\"GET\",url,true);xhr.responseType=\"arraybuffer\";xhr.onload=function(){if(xhr.status==200||xhr.status==0&&xhr.response){onload(xhr.response);return}onerror()};xhr.onerror=onerror;xhr.send(null)}}setWindowTitle=function(title){document.title=title}}else{}var out=Module[\"print\"]||console.log.bind(console);var err=Module[\"printErr\"]||console.warn.bind(console);for(key in moduleOverrides){if(moduleOverrides.hasOwnProperty(key)){Module[key]=moduleOverrides[key]}}moduleOverrides=null;if(Module[\"arguments\"])arguments_=Module[\"arguments\"];if(Module[\"thisProgram\"])thisProgram=Module[\"thisProgram\"];if(Module[\"quit\"])quit_=Module[\"quit\"];var wasmBinary;if(Module[\"wasmBinary\"])wasmBinary=Module[\"wasmBinary\"];var noExitRuntime=Module[\"noExitRuntime\"]||true;if(typeof WebAssembly!==\"object\"){abort(\"no native wasm support detected\")}var wasmMemory;var ABORT=false;var EXITSTATUS;function assert(condition,text){if(!condition){abort(\"Assertion failed: \"+text)}}function getCFunc(ident){var func=Module[\"_\"+ident];assert(func,\"Cannot call unknown function \"+ident+\", make sure it is exported\");return func}function ccall(ident,returnType,argTypes,args,opts){var toC={\"string\":function(str){var ret=0;if(str!==null&&str!==undefined&&str!==0){var len=(str.length<<2)+1;ret=stackAlloc(len);stringToUTF8(str,ret,len)}return ret},\"array\":function(arr){var ret=stackAlloc(arr.length);writeArrayToMemory(arr,ret);return ret}};function convertReturnValue(ret){if(returnType===\"string\")return UTF8ToString(ret);if(returnType===\"boolean\")return Boolean(ret);return ret}var func=getCFunc(ident);var cArgs=[];var stack=0;if(args){for(var i=0;i=endIdx))++endPtr;if(endPtr-idx>16&&heap.subarray&&UTF8Decoder){return UTF8Decoder.decode(heap.subarray(idx,endPtr))}else{var str=\"\";while(idx>10,56320|ch&1023)}}}return str}function UTF8ToString(ptr,maxBytesToRead){return ptr?UTF8ArrayToString(HEAPU8,ptr,maxBytesToRead):\"\"}function stringToUTF8Array(str,heap,outIdx,maxBytesToWrite){if(!(maxBytesToWrite>0))return 0;var startIdx=outIdx;var endIdx=outIdx+maxBytesToWrite-1;for(var i=0;i=55296&&u<=57343){var u1=str.charCodeAt(++i);u=65536+((u&1023)<<10)|u1&1023}if(u<=127){if(outIdx>=endIdx)break;heap[outIdx++]=u}else if(u<=2047){if(outIdx+1>=endIdx)break;heap[outIdx++]=192|u>>6;heap[outIdx++]=128|u&63}else if(u<=65535){if(outIdx+2>=endIdx)break;heap[outIdx++]=224|u>>12;heap[outIdx++]=128|u>>6&63;heap[outIdx++]=128|u&63}else{if(outIdx+3>=endIdx)break;heap[outIdx++]=240|u>>18;heap[outIdx++]=128|u>>12&63;heap[outIdx++]=128|u>>6&63;heap[outIdx++]=128|u&63}}heap[outIdx]=0;return outIdx-startIdx}function stringToUTF8(str,outPtr,maxBytesToWrite){return stringToUTF8Array(str,HEAPU8,outPtr,maxBytesToWrite)}function writeArrayToMemory(array,buffer){HEAP8.set(array,buffer)}function alignUp(x,multiple){if(x%multiple>0){x+=multiple-x%multiple}return x}var buffer,HEAP8,HEAPU8,HEAP16,HEAPU16,HEAP32,HEAPU32,HEAPF32,HEAPF64;function updateGlobalBufferAndViews(buf){buffer=buf;Module[\"HEAP8\"]=HEAP8=new Int8Array(buf);Module[\"HEAP16\"]=HEAP16=new Int16Array(buf);Module[\"HEAP32\"]=HEAP32=new Int32Array(buf);Module[\"HEAPU8\"]=HEAPU8=new Uint8Array(buf);Module[\"HEAPU16\"]=HEAPU16=new Uint16Array(buf);Module[\"HEAPU32\"]=HEAPU32=new Uint32Array(buf);Module[\"HEAPF32\"]=HEAPF32=new Float32Array(buf);Module[\"HEAPF64\"]=HEAPF64=new Float64Array(buf)}var INITIAL_MEMORY=Module[\"INITIAL_MEMORY\"]||16777216;var wasmTable;var __ATPRERUN__=[];var __ATINIT__=[];var __ATMAIN__=[];var __ATPOSTRUN__=[];var runtimeInitialized=false;__ATINIT__.push({func:function(){___wasm_call_ctors()}});function preRun(){if(Module[\"preRun\"]){if(typeof Module[\"preRun\"]==\"function\")Module[\"preRun\"]=[Module[\"preRun\"]];while(Module[\"preRun\"].length){addOnPreRun(Module[\"preRun\"].shift())}}callRuntimeCallbacks(__ATPRERUN__)}function initRuntime(){runtimeInitialized=true;callRuntimeCallbacks(__ATINIT__)}function preMain(){callRuntimeCallbacks(__ATMAIN__)}function postRun(){if(Module[\"postRun\"]){if(typeof Module[\"postRun\"]==\"function\")Module[\"postRun\"]=[Module[\"postRun\"]];while(Module[\"postRun\"].length){addOnPostRun(Module[\"postRun\"].shift())}}callRuntimeCallbacks(__ATPOSTRUN__)}function addOnPreRun(cb){__ATPRERUN__.unshift(cb)}function addOnPostRun(cb){__ATPOSTRUN__.unshift(cb)}var runDependencies=0;var runDependencyWatcher=null;var dependenciesFulfilled=null;function addRunDependency(id){runDependencies++;if(Module[\"monitorRunDependencies\"]){Module[\"monitorRunDependencies\"](runDependencies)}}function removeRunDependency(id){runDependencies--;if(Module[\"monitorRunDependencies\"]){Module[\"monitorRunDependencies\"](runDependencies)}if(runDependencies==0){if(runDependencyWatcher!==null){clearInterval(runDependencyWatcher);runDependencyWatcher=null}if(dependenciesFulfilled){var callback=dependenciesFulfilled;dependenciesFulfilled=null;callback()}}}Module[\"preloadedImages\"]={};Module[\"preloadedAudios\"]={};function abort(what){if(Module[\"onAbort\"]){Module[\"onAbort\"](what)}what+=\"\";err(what);ABORT=true;EXITSTATUS=1;what=\"abort(\"+what+\"). Build with -s ASSERTIONS=1 for more info.\";var e=new WebAssembly.RuntimeError(what);readyPromiseReject(e);throw e}function hasPrefix(str,prefix){return String.prototype.startsWith?str.startsWith(prefix):str.indexOf(prefix)===0}var dataURIPrefix=\"data:application/octet-stream;base64,\";function isDataURI(filename){return hasPrefix(filename,dataURIPrefix)}var fileURIPrefix=\"file://\";function isFileURI(filename){return hasPrefix(filename,fileURIPrefix)}var wasmBinaryFile=\"tfjs-backend-wasm.wasm\";if(!isDataURI(wasmBinaryFile)){wasmBinaryFile=locateFile(wasmBinaryFile)}function getBinary(file){try{if(file==wasmBinaryFile&&wasmBinary){return new Uint8Array(wasmBinary)}if(readBinary){return readBinary(file)}else{throw\"both async and sync fetching of the wasm failed\"}}catch(err){abort(err)}}function getBinaryPromise(){if(!wasmBinary&&(ENVIRONMENT_IS_WEB||ENVIRONMENT_IS_WORKER)){if(typeof fetch===\"function\"&&!isFileURI(wasmBinaryFile)){return fetch(wasmBinaryFile,{credentials:\"same-origin\"}).then(function(response){if(!response[\"ok\"]){throw\"failed to load wasm binary file at '\"+wasmBinaryFile+\"'\"}return response[\"arrayBuffer\"]()}).catch(function(){return getBinary(wasmBinaryFile)})}else{if(readAsync){return new Promise(function(resolve,reject){readAsync(wasmBinaryFile,function(response){resolve(new Uint8Array(response))},reject)})}}}return Promise.resolve().then(function(){return getBinary(wasmBinaryFile)})}function createWasm(){var info={\"a\":asmLibraryArg};function receiveInstance(instance,module){var exports=instance.exports;Module[\"asm\"]=exports;wasmMemory=Module[\"asm\"][\"i\"];updateGlobalBufferAndViews(wasmMemory.buffer);wasmTable=Module[\"asm\"][\"o\"];removeRunDependency(\"wasm-instantiate\")}addRunDependency(\"wasm-instantiate\");function receiveInstantiatedSource(output){receiveInstance(output[\"instance\"])}function instantiateArrayBuffer(receiver){return getBinaryPromise().then(function(binary){return WebAssembly.instantiate(binary,info)}).then(receiver,function(reason){err(\"failed to asynchronously prepare wasm: \"+reason);abort(reason)})}function instantiateAsync(){if(!wasmBinary&&typeof WebAssembly.instantiateStreaming===\"function\"&&!isDataURI(wasmBinaryFile)&&!isFileURI(wasmBinaryFile)&&typeof fetch===\"function\"){return fetch(wasmBinaryFile,{credentials:\"same-origin\"}).then(function(response){var result=WebAssembly.instantiateStreaming(response,info);return result.then(receiveInstantiatedSource,function(reason){err(\"wasm streaming compile failed: \"+reason);err(\"falling back to ArrayBuffer instantiation\");return instantiateArrayBuffer(receiveInstantiatedSource)})})}else{return instantiateArrayBuffer(receiveInstantiatedSource)}}if(Module[\"instantiateWasm\"]){try{var exports=Module[\"instantiateWasm\"](info,receiveInstance);return exports}catch(e){err(\"Module.instantiateWasm callback failed with error: \"+e);return false}}instantiateAsync().catch(readyPromiseReject);return{}}function callRuntimeCallbacks(callbacks){while(callbacks.length>0){var callback=callbacks.shift();if(typeof callback==\"function\"){callback(Module);continue}var func=callback.func;if(typeof func===\"number\"){if(callback.arg===undefined){wasmTable.get(func)()}else{wasmTable.get(func)(callback.arg)}}else{func(callback.arg===undefined?null:callback.arg)}}}function _abort(){abort()}function _emscripten_memcpy_big(dest,src,num){HEAPU8.copyWithin(dest,src,src+num)}function _emscripten_get_heap_size(){return HEAPU8.length}function emscripten_realloc_buffer(size){try{wasmMemory.grow(size-buffer.byteLength+65535>>>16);updateGlobalBufferAndViews(wasmMemory.buffer);return 1}catch(e){}}function _emscripten_resize_heap(requestedSize){var oldSize=_emscripten_get_heap_size();var maxHeapSize=2147483648;if(requestedSize>maxHeapSize){return false}for(var cutDown=1;cutDown<=4;cutDown*=2){var overGrownHeapSize=oldSize*(1+.2/cutDown);overGrownHeapSize=Math.min(overGrownHeapSize,requestedSize+100663296);var newSize=Math.min(maxHeapSize,alignUp(Math.max(requestedSize,overGrownHeapSize),65536));var replacement=emscripten_realloc_buffer(newSize);if(replacement){return true}}return false}var SYSCALLS={mappings:{},buffers:[null,[],[]],printChar:function(stream,curr){var buffer=SYSCALLS.buffers[stream];if(curr===0||curr===10){(stream===1?out:err)(UTF8ArrayToString(buffer,0));buffer.length=0}else{buffer.push(curr)}},varargs:undefined,get:function(){SYSCALLS.varargs+=4;var ret=HEAP32[SYSCALLS.varargs-4>>2];return ret},getStr:function(ptr){var ret=UTF8ToString(ptr);return ret},get64:function(low,high){return low}};function _fd_close(fd){return 0}function _fd_seek(fd,offset_low,offset_high,whence,newOffset){}function _fd_write(fd,iov,iovcnt,pnum){var num=0;for(var i=0;i>2];var len=HEAP32[iov+(i*8+4)>>2];for(var j=0;j>2]=num;return 0}function _pthread_create(){return 6}function setErrNo(value){HEAP32[___errno_location()>>2]=value;return value}function _sysconf(name){switch(name){case 30:return 16384;case 85:var maxHeapSize=2147483648;return maxHeapSize/16384;case 132:case 133:case 12:case 137:case 138:case 15:case 235:case 16:case 17:case 18:case 19:case 20:case 149:case 13:case 10:case 236:case 153:case 9:case 21:case 22:case 159:case 154:case 14:case 77:case 78:case 139:case 82:case 68:case 67:case 164:case 11:case 29:case 47:case 48:case 95:case 52:case 51:case 46:return 200809;case 27:case 246:case 127:case 128:case 23:case 24:case 160:case 161:case 181:case 182:case 242:case 183:case 184:case 243:case 244:case 245:case 165:case 178:case 179:case 49:case 50:case 168:case 169:case 175:case 170:case 171:case 172:case 97:case 76:case 32:case 173:case 35:case 80:case 81:case 79:return-1;case 176:case 177:case 7:case 155:case 8:case 157:case 125:case 126:case 92:case 93:case 129:case 130:case 131:case 94:case 91:return 1;case 74:case 60:case 69:case 70:case 4:return 1024;case 31:case 42:case 72:return 32;case 87:case 26:case 33:return 2147483647;case 34:case 1:return 47839;case 38:case 36:return 99;case 43:case 37:return 2048;case 0:return 2097152;case 3:return 65536;case 28:return 32768;case 44:return 32767;case 75:return 16384;case 39:return 1e3;case 89:return 700;case 71:return 256;case 40:return 255;case 2:return 100;case 180:return 64;case 25:return 20;case 5:return 16;case 6:return 6;case 73:return 4;case 84:{if(typeof navigator===\"object\")return navigator[\"hardwareConcurrency\"]||1;return 1}}setErrNo(28);return-1}var asmLibraryArg={\"a\":_abort,\"d\":_emscripten_memcpy_big,\"e\":_emscripten_resize_heap,\"f\":_fd_close,\"c\":_fd_seek,\"b\":_fd_write,\"g\":_pthread_create,\"h\":_sysconf};var asm=createWasm();var ___wasm_call_ctors=Module[\"___wasm_call_ctors\"]=function(){return(___wasm_call_ctors=Module[\"___wasm_call_ctors\"]=Module[\"asm\"][\"j\"]).apply(null,arguments)};var _init=Module[\"_init\"]=function(){return(_init=Module[\"_init\"]=Module[\"asm\"][\"k\"]).apply(null,arguments)};var _register_tensor=Module[\"_register_tensor\"]=function(){return(_register_tensor=Module[\"_register_tensor\"]=Module[\"asm\"][\"l\"]).apply(null,arguments)};var _dispose_data=Module[\"_dispose_data\"]=function(){return(_dispose_data=Module[\"_dispose_data\"]=Module[\"asm\"][\"m\"]).apply(null,arguments)};var _dispose=Module[\"_dispose\"]=function(){return(_dispose=Module[\"_dispose\"]=Module[\"asm\"][\"n\"]).apply(null,arguments)};var _Abs=Module[\"_Abs\"]=function(){return(_Abs=Module[\"_Abs\"]=Module[\"asm\"][\"p\"]).apply(null,arguments)};var _Add=Module[\"_Add\"]=function(){return(_Add=Module[\"_Add\"]=Module[\"asm\"][\"q\"]).apply(null,arguments)};var _AddN=Module[\"_AddN\"]=function(){return(_AddN=Module[\"_AddN\"]=Module[\"asm\"][\"r\"]).apply(null,arguments)};var _All=Module[\"_All\"]=function(){return(_All=Module[\"_All\"]=Module[\"asm\"][\"s\"]).apply(null,arguments)};var _Any=Module[\"_Any\"]=function(){return(_Any=Module[\"_Any\"]=Module[\"asm\"][\"t\"]).apply(null,arguments)};var _ArgMax=Module[\"_ArgMax\"]=function(){return(_ArgMax=Module[\"_ArgMax\"]=Module[\"asm\"][\"u\"]).apply(null,arguments)};var _AvgPool=Module[\"_AvgPool\"]=function(){return(_AvgPool=Module[\"_AvgPool\"]=Module[\"asm\"][\"v\"]).apply(null,arguments)};var _BatchMatMul=Module[\"_BatchMatMul\"]=function(){return(_BatchMatMul=Module[\"_BatchMatMul\"]=Module[\"asm\"][\"w\"]).apply(null,arguments)};var _Ceil=Module[\"_Ceil\"]=function(){return(_Ceil=Module[\"_Ceil\"]=Module[\"asm\"][\"x\"]).apply(null,arguments)};var _ClipByValue=Module[\"_ClipByValue\"]=function(){return(_ClipByValue=Module[\"_ClipByValue\"]=Module[\"asm\"][\"y\"]).apply(null,arguments)};var _Conv2D=Module[\"_Conv2D\"]=function(){return(_Conv2D=Module[\"_Conv2D\"]=Module[\"asm\"][\"z\"]).apply(null,arguments)};var _Conv2DBackpropInput=Module[\"_Conv2DBackpropInput\"]=function(){return(_Conv2DBackpropInput=Module[\"_Conv2DBackpropInput\"]=Module[\"asm\"][\"A\"]).apply(null,arguments)};var _Cos=Module[\"_Cos\"]=function(){return(_Cos=Module[\"_Cos\"]=Module[\"asm\"][\"B\"]).apply(null,arguments)};var _CropAndResize=Module[\"_CropAndResize\"]=function(){return(_CropAndResize=Module[\"_CropAndResize\"]=Module[\"asm\"][\"C\"]).apply(null,arguments)};var _Cumsum=Module[\"_Cumsum\"]=function(){return(_Cumsum=Module[\"_Cumsum\"]=Module[\"asm\"][\"D\"]).apply(null,arguments)};var _DepthToSpace=Module[\"_DepthToSpace\"]=function(){return(_DepthToSpace=Module[\"_DepthToSpace\"]=Module[\"asm\"][\"E\"]).apply(null,arguments)};var _DepthwiseConv2dNative=Module[\"_DepthwiseConv2dNative\"]=function(){return(_DepthwiseConv2dNative=Module[\"_DepthwiseConv2dNative\"]=Module[\"asm\"][\"F\"]).apply(null,arguments)};var _Equal=Module[\"_Equal\"]=function(){return(_Equal=Module[\"_Equal\"]=Module[\"asm\"][\"G\"]).apply(null,arguments)};var _Exp=Module[\"_Exp\"]=function(){return(_Exp=Module[\"_Exp\"]=Module[\"asm\"][\"H\"]).apply(null,arguments)};var _FlipLeftRight=Module[\"_FlipLeftRight\"]=function(){return(_FlipLeftRight=Module[\"_FlipLeftRight\"]=Module[\"asm\"][\"I\"]).apply(null,arguments)};var _Floor=Module[\"_Floor\"]=function(){return(_Floor=Module[\"_Floor\"]=Module[\"asm\"][\"J\"]).apply(null,arguments)};var _FloorDiv=Module[\"_FloorDiv\"]=function(){return(_FloorDiv=Module[\"_FloorDiv\"]=Module[\"asm\"][\"K\"]).apply(null,arguments)};var _FusedBatchNorm=Module[\"_FusedBatchNorm\"]=function(){return(_FusedBatchNorm=Module[\"_FusedBatchNorm\"]=Module[\"asm\"][\"L\"]).apply(null,arguments)};var _FusedConv2D=Module[\"_FusedConv2D\"]=function(){return(_FusedConv2D=Module[\"_FusedConv2D\"]=Module[\"asm\"][\"M\"]).apply(null,arguments)};var _FusedDepthwiseConv2D=Module[\"_FusedDepthwiseConv2D\"]=function(){return(_FusedDepthwiseConv2D=Module[\"_FusedDepthwiseConv2D\"]=Module[\"asm\"][\"N\"]).apply(null,arguments)};var _Gather=Module[\"_Gather\"]=function(){return(_Gather=Module[\"_Gather\"]=Module[\"asm\"][\"O\"]).apply(null,arguments)};var _GatherNd=Module[\"_GatherNd\"]=function(){return(_GatherNd=Module[\"_GatherNd\"]=Module[\"asm\"][\"P\"]).apply(null,arguments)};var _Greater=Module[\"_Greater\"]=function(){return(_Greater=Module[\"_Greater\"]=Module[\"asm\"][\"Q\"]).apply(null,arguments)};var _GreaterEqual=Module[\"_GreaterEqual\"]=function(){return(_GreaterEqual=Module[\"_GreaterEqual\"]=Module[\"asm\"][\"R\"]).apply(null,arguments)};var _LeakyRelu=Module[\"_LeakyRelu\"]=function(){return(_LeakyRelu=Module[\"_LeakyRelu\"]=Module[\"asm\"][\"S\"]).apply(null,arguments)};var _Less=Module[\"_Less\"]=function(){return(_Less=Module[\"_Less\"]=Module[\"asm\"][\"T\"]).apply(null,arguments)};var _LessEqual=Module[\"_LessEqual\"]=function(){return(_LessEqual=Module[\"_LessEqual\"]=Module[\"asm\"][\"U\"]).apply(null,arguments)};var _Log=Module[\"_Log\"]=function(){return(_Log=Module[\"_Log\"]=Module[\"asm\"][\"V\"]).apply(null,arguments)};var _LogicalAnd=Module[\"_LogicalAnd\"]=function(){return(_LogicalAnd=Module[\"_LogicalAnd\"]=Module[\"asm\"][\"W\"]).apply(null,arguments)};var _Max=Module[\"_Max\"]=function(){return(_Max=Module[\"_Max\"]=Module[\"asm\"][\"X\"]).apply(null,arguments)};var _MaxPool=Module[\"_MaxPool\"]=function(){return(_MaxPool=Module[\"_MaxPool\"]=Module[\"asm\"][\"Y\"]).apply(null,arguments)};var _Maximum=Module[\"_Maximum\"]=function(){return(_Maximum=Module[\"_Maximum\"]=Module[\"asm\"][\"Z\"]).apply(null,arguments)};var _Mean=Module[\"_Mean\"]=function(){return(_Mean=Module[\"_Mean\"]=Module[\"asm\"][\"_\"]).apply(null,arguments)};var _Min=Module[\"_Min\"]=function(){return(_Min=Module[\"_Min\"]=Module[\"asm\"][\"$\"]).apply(null,arguments)};var _Minimum=Module[\"_Minimum\"]=function(){return(_Minimum=Module[\"_Minimum\"]=Module[\"asm\"][\"aa\"]).apply(null,arguments)};var _MirrorPad=Module[\"_MirrorPad\"]=function(){return(_MirrorPad=Module[\"_MirrorPad\"]=Module[\"asm\"][\"ba\"]).apply(null,arguments)};var _Multiply=Module[\"_Multiply\"]=function(){return(_Multiply=Module[\"_Multiply\"]=Module[\"asm\"][\"ca\"]).apply(null,arguments)};var _Neg=Module[\"_Neg\"]=function(){return(_Neg=Module[\"_Neg\"]=Module[\"asm\"][\"da\"]).apply(null,arguments)};var _NonMaxSuppressionV3=Module[\"_NonMaxSuppressionV3\"]=function(){return(_NonMaxSuppressionV3=Module[\"_NonMaxSuppressionV3\"]=Module[\"asm\"][\"ea\"]).apply(null,arguments)};var _NonMaxSuppressionV4=Module[\"_NonMaxSuppressionV4\"]=function(){return(_NonMaxSuppressionV4=Module[\"_NonMaxSuppressionV4\"]=Module[\"asm\"][\"fa\"]).apply(null,arguments)};var _NonMaxSuppressionV5=Module[\"_NonMaxSuppressionV5\"]=function(){return(_NonMaxSuppressionV5=Module[\"_NonMaxSuppressionV5\"]=Module[\"asm\"][\"ga\"]).apply(null,arguments)};var _NotEqual=Module[\"_NotEqual\"]=function(){return(_NotEqual=Module[\"_NotEqual\"]=Module[\"asm\"][\"ha\"]).apply(null,arguments)};var _OneHot=Module[\"_OneHot\"]=function(){return(_OneHot=Module[\"_OneHot\"]=Module[\"asm\"][\"ia\"]).apply(null,arguments)};var _PadV2=Module[\"_PadV2\"]=function(){return(_PadV2=Module[\"_PadV2\"]=Module[\"asm\"][\"ja\"]).apply(null,arguments)};var _Pow=Module[\"_Pow\"]=function(){return(_Pow=Module[\"_Pow\"]=Module[\"asm\"][\"ka\"]).apply(null,arguments)};var _Prelu=Module[\"_Prelu\"]=function(){return(_Prelu=Module[\"_Prelu\"]=Module[\"asm\"][\"la\"]).apply(null,arguments)};var _Prod=Module[\"_Prod\"]=function(){return(_Prod=Module[\"_Prod\"]=Module[\"asm\"][\"ma\"]).apply(null,arguments)};var _RealDiv=Module[\"_RealDiv\"]=function(){return(_RealDiv=Module[\"_RealDiv\"]=Module[\"asm\"][\"na\"]).apply(null,arguments)};var _Relu=Module[\"_Relu\"]=function(){return(_Relu=Module[\"_Relu\"]=Module[\"asm\"][\"oa\"]).apply(null,arguments)};var _Relu6=Module[\"_Relu6\"]=function(){return(_Relu6=Module[\"_Relu6\"]=Module[\"asm\"][\"pa\"]).apply(null,arguments)};var _ResizeBilinear=Module[\"_ResizeBilinear\"]=function(){return(_ResizeBilinear=Module[\"_ResizeBilinear\"]=Module[\"asm\"][\"qa\"]).apply(null,arguments)};var _Reverse=Module[\"_Reverse\"]=function(){return(_Reverse=Module[\"_Reverse\"]=Module[\"asm\"][\"ra\"]).apply(null,arguments)};var _RotateWithOffset=Module[\"_RotateWithOffset\"]=function(){return(_RotateWithOffset=Module[\"_RotateWithOffset\"]=Module[\"asm\"][\"sa\"]).apply(null,arguments)};var _Round=Module[\"_Round\"]=function(){return(_Round=Module[\"_Round\"]=Module[\"asm\"][\"ta\"]).apply(null,arguments)};var _Rsqrt=Module[\"_Rsqrt\"]=function(){return(_Rsqrt=Module[\"_Rsqrt\"]=Module[\"asm\"][\"ua\"]).apply(null,arguments)};var _ScatterNd=Module[\"_ScatterNd\"]=function(){return(_ScatterNd=Module[\"_ScatterNd\"]=Module[\"asm\"][\"va\"]).apply(null,arguments)};var _SelectV2=Module[\"_SelectV2\"]=function(){return(_SelectV2=Module[\"_SelectV2\"]=Module[\"asm\"][\"wa\"]).apply(null,arguments)};var _Sigmoid=Module[\"_Sigmoid\"]=function(){return(_Sigmoid=Module[\"_Sigmoid\"]=Module[\"asm\"][\"xa\"]).apply(null,arguments)};var _Sin=Module[\"_Sin\"]=function(){return(_Sin=Module[\"_Sin\"]=Module[\"asm\"][\"ya\"]).apply(null,arguments)};var _Softmax=Module[\"_Softmax\"]=function(){return(_Softmax=Module[\"_Softmax\"]=Module[\"asm\"][\"za\"]).apply(null,arguments)};var _Sqrt=Module[\"_Sqrt\"]=function(){return(_Sqrt=Module[\"_Sqrt\"]=Module[\"asm\"][\"Aa\"]).apply(null,arguments)};var _Square=Module[\"_Square\"]=function(){return(_Square=Module[\"_Square\"]=Module[\"asm\"][\"Ba\"]).apply(null,arguments)};var _SquaredDifference=Module[\"_SquaredDifference\"]=function(){return(_SquaredDifference=Module[\"_SquaredDifference\"]=Module[\"asm\"][\"Ca\"]).apply(null,arguments)};var _Step=Module[\"_Step\"]=function(){return(_Step=Module[\"_Step\"]=Module[\"asm\"][\"Da\"]).apply(null,arguments)};var _StridedSlice=Module[\"_StridedSlice\"]=function(){return(_StridedSlice=Module[\"_StridedSlice\"]=Module[\"asm\"][\"Ea\"]).apply(null,arguments)};var _Sub=Module[\"_Sub\"]=function(){return(_Sub=Module[\"_Sub\"]=Module[\"asm\"][\"Fa\"]).apply(null,arguments)};var _Sum=Module[\"_Sum\"]=function(){return(_Sum=Module[\"_Sum\"]=Module[\"asm\"][\"Ga\"]).apply(null,arguments)};var _Tan=Module[\"_Tan\"]=function(){return(_Tan=Module[\"_Tan\"]=Module[\"asm\"][\"Ha\"]).apply(null,arguments)};var _Tanh=Module[\"_Tanh\"]=function(){return(_Tanh=Module[\"_Tanh\"]=Module[\"asm\"][\"Ia\"]).apply(null,arguments)};var _Tile=Module[\"_Tile\"]=function(){return(_Tile=Module[\"_Tile\"]=Module[\"asm\"][\"Ja\"]).apply(null,arguments)};var _TopK=Module[\"_TopK\"]=function(){return(_TopK=Module[\"_TopK\"]=Module[\"asm\"][\"Ka\"]).apply(null,arguments)};var _Transform=Module[\"_Transform\"]=function(){return(_Transform=Module[\"_Transform\"]=Module[\"asm\"][\"La\"]).apply(null,arguments)};var _Transpose=Module[\"_Transpose\"]=function(){return(_Transpose=Module[\"_Transpose\"]=Module[\"asm\"][\"Ma\"]).apply(null,arguments)};var __FusedMatMul=Module[\"__FusedMatMul\"]=function(){return(__FusedMatMul=Module[\"__FusedMatMul\"]=Module[\"asm\"][\"Na\"]).apply(null,arguments)};var _malloc=Module[\"_malloc\"]=function(){return(_malloc=Module[\"_malloc\"]=Module[\"asm\"][\"Oa\"]).apply(null,arguments)};var _free=Module[\"_free\"]=function(){return(_free=Module[\"_free\"]=Module[\"asm\"][\"Pa\"]).apply(null,arguments)};var ___errno_location=Module[\"___errno_location\"]=function(){return(___errno_location=Module[\"___errno_location\"]=Module[\"asm\"][\"Qa\"]).apply(null,arguments)};var stackSave=Module[\"stackSave\"]=function(){return(stackSave=Module[\"stackSave\"]=Module[\"asm\"][\"Ra\"]).apply(null,arguments)};var stackRestore=Module[\"stackRestore\"]=function(){return(stackRestore=Module[\"stackRestore\"]=Module[\"asm\"][\"Sa\"]).apply(null,arguments)};var stackAlloc=Module[\"stackAlloc\"]=function(){return(stackAlloc=Module[\"stackAlloc\"]=Module[\"asm\"][\"Ta\"]).apply(null,arguments)};Module[\"cwrap\"]=cwrap;var calledRun;function ExitStatus(status){this.name=\"ExitStatus\";this.message=\"Program terminated with exit(\"+status+\")\";this.status=status}dependenciesFulfilled=function runCaller(){if(!calledRun)run();if(!calledRun)dependenciesFulfilled=runCaller};function run(args){args=args||arguments_;if(runDependencies>0){return}preRun();if(runDependencies>0){return}function doRun(){if(calledRun)return;calledRun=true;Module[\"calledRun\"]=true;if(ABORT)return;initRuntime();preMain();readyPromiseResolve(Module);if(Module[\"onRuntimeInitialized\"])Module[\"onRuntimeInitialized\"]();postRun()}if(Module[\"setStatus\"]){Module[\"setStatus\"](\"Running...\");setTimeout(function(){setTimeout(function(){Module[\"setStatus\"](\"\")},1);doRun()},1)}else{doRun()}}Module[\"run\"]=run;if(Module[\"preInit\"]){if(typeof Module[\"preInit\"]==\"function\")Module[\"preInit\"]=[Module[\"preInit\"]];while(Module[\"preInit\"].length>0){Module[\"preInit\"].pop()()}}run();\n\n\n return WasmBackendModule.ready\n}\n);\n})();\nif (typeof exports === 'object' && typeof module === 'object')\n module.exports = WasmBackendModule;\nelse if (typeof define === 'function' && define['amd'])\n define([], function() { return WasmBackendModule; });\nelse if (typeof exports === 'object')\n exports[\"WasmBackendModule\"] = WasmBackendModule;\n", "// A port of an algorithm by Johannes Baag\u00F8e , 2010\n// http://baagoe.com/en/RandomMusings/javascript/\n// https://github.com/nquinlan/better-random-numbers-for-javascript-mirror\n// Original work is under MIT license -\n\n// Copyright (C) 2010 by Johannes Baag\u00F8e \n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n\n\n(function(global, module, define) {\n\nfunction Alea(seed) {\n var me = this, mash = Mash();\n\n me.next = function() {\n var t = 2091639 * me.s0 + me.c * 2.3283064365386963e-10; // 2^-32\n me.s0 = me.s1;\n me.s1 = me.s2;\n return me.s2 = t - (me.c = t | 0);\n };\n\n // Apply the seeding algorithm from Baagoe.\n me.c = 1;\n me.s0 = mash(' ');\n me.s1 = mash(' ');\n me.s2 = mash(' ');\n me.s0 -= mash(seed);\n if (me.s0 < 0) { me.s0 += 1; }\n me.s1 -= mash(seed);\n if (me.s1 < 0) { me.s1 += 1; }\n me.s2 -= mash(seed);\n if (me.s2 < 0) { me.s2 += 1; }\n mash = null;\n}\n\nfunction copy(f, t) {\n t.c = f.c;\n t.s0 = f.s0;\n t.s1 = f.s1;\n t.s2 = f.s2;\n return t;\n}\n\nfunction impl(seed, opts) {\n var xg = new Alea(seed),\n state = opts && opts.state,\n prng = xg.next;\n prng.int32 = function() { return (xg.next() * 0x100000000) | 0; }\n prng.double = function() {\n return prng() + (prng() * 0x200000 | 0) * 1.1102230246251565e-16; // 2^-53\n };\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nfunction Mash() {\n var n = 0xefc8249d;\n\n var mash = function(data) {\n data = String(data);\n for (var i = 0; i < data.length; i++) {\n n += data.charCodeAt(i);\n var h = 0.02519603282416938 * n;\n n = h >>> 0;\n h -= n;\n h *= n;\n n = h >>> 0;\n h -= n;\n n += h * 0x100000000; // 2^32\n }\n return (n >>> 0) * 2.3283064365386963e-10; // 2^-32\n };\n\n return mash;\n}\n\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.alea = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n", "// A Javascript implementaion of the \"xor128\" prng algorithm by\n// George Marsaglia. See http://www.jstatsoft.org/v08/i14/paper\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this, strseed = '';\n\n me.x = 0;\n me.y = 0;\n me.z = 0;\n me.w = 0;\n\n // Set up generator function.\n me.next = function() {\n var t = me.x ^ (me.x << 11);\n me.x = me.y;\n me.y = me.z;\n me.z = me.w;\n return me.w ^= (me.w >>> 19) ^ t ^ (t >>> 8);\n };\n\n if (seed === (seed | 0)) {\n // Integer seed.\n me.x = seed;\n } else {\n // String seed.\n strseed += seed;\n }\n\n // Mix in string seed, then discard an initial batch of 64 values.\n for (var k = 0; k < strseed.length + 64; k++) {\n me.x ^= strseed.charCodeAt(k) | 0;\n me.next();\n }\n}\n\nfunction copy(f, t) {\n t.x = f.x;\n t.y = f.y;\n t.z = f.z;\n t.w = f.w;\n return t;\n}\n\nfunction impl(seed, opts) {\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xor128 = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n", "// A Javascript implementaion of the \"xorwow\" prng algorithm by\n// George Marsaglia. See http://www.jstatsoft.org/v08/i14/paper\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this, strseed = '';\n\n // Set up generator function.\n me.next = function() {\n var t = (me.x ^ (me.x >>> 2));\n me.x = me.y; me.y = me.z; me.z = me.w; me.w = me.v;\n return (me.d = (me.d + 362437 | 0)) +\n (me.v = (me.v ^ (me.v << 4)) ^ (t ^ (t << 1))) | 0;\n };\n\n me.x = 0;\n me.y = 0;\n me.z = 0;\n me.w = 0;\n me.v = 0;\n\n if (seed === (seed | 0)) {\n // Integer seed.\n me.x = seed;\n } else {\n // String seed.\n strseed += seed;\n }\n\n // Mix in string seed, then discard an initial batch of 64 values.\n for (var k = 0; k < strseed.length + 64; k++) {\n me.x ^= strseed.charCodeAt(k) | 0;\n if (k == strseed.length) {\n me.d = me.x << 10 ^ me.x >>> 4;\n }\n me.next();\n }\n}\n\nfunction copy(f, t) {\n t.x = f.x;\n t.y = f.y;\n t.z = f.z;\n t.w = f.w;\n t.v = f.v;\n t.d = f.d;\n return t;\n}\n\nfunction impl(seed, opts) {\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xorwow = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n", "// A Javascript implementaion of the \"xorshift7\" algorithm by\n// Fran\u00E7ois Panneton and Pierre L'ecuyer:\n// \"On the Xorgshift Random Number Generators\"\n// http://saluc.engr.uconn.edu/refs/crypto/rng/panneton05onthexorshift.pdf\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this;\n\n // Set up generator function.\n me.next = function() {\n // Update xor generator.\n var X = me.x, i = me.i, t, v, w;\n t = X[i]; t ^= (t >>> 7); v = t ^ (t << 24);\n t = X[(i + 1) & 7]; v ^= t ^ (t >>> 10);\n t = X[(i + 3) & 7]; v ^= t ^ (t >>> 3);\n t = X[(i + 4) & 7]; v ^= t ^ (t << 7);\n t = X[(i + 7) & 7]; t = t ^ (t << 13); v ^= t ^ (t << 9);\n X[i] = v;\n me.i = (i + 1) & 7;\n return v;\n };\n\n function init(me, seed) {\n var j, w, X = [];\n\n if (seed === (seed | 0)) {\n // Seed state array using a 32-bit integer.\n w = X[0] = seed;\n } else {\n // Seed state using a string.\n seed = '' + seed;\n for (j = 0; j < seed.length; ++j) {\n X[j & 7] = (X[j & 7] << 15) ^\n (seed.charCodeAt(j) + X[(j + 1) & 7] << 13);\n }\n }\n // Enforce an array length of 8, not all zeroes.\n while (X.length < 8) X.push(0);\n for (j = 0; j < 8 && X[j] === 0; ++j);\n if (j == 8) w = X[7] = -1; else w = X[j];\n\n me.x = X;\n me.i = 0;\n\n // Discard an initial 256 values.\n for (j = 256; j > 0; --j) {\n me.next();\n }\n }\n\n init(me, seed);\n}\n\nfunction copy(f, t) {\n t.x = f.x.slice();\n t.i = f.i;\n return t;\n}\n\nfunction impl(seed, opts) {\n if (seed == null) seed = +(new Date);\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (state.x) copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xorshift7 = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n", "// A Javascript implementaion of Richard Brent's Xorgens xor4096 algorithm.\n//\n// This fast non-cryptographic random number generator is designed for\n// use in Monte-Carlo algorithms. It combines a long-period xorshift\n// generator with a Weyl generator, and it passes all common batteries\n// of stasticial tests for randomness while consuming only a few nanoseconds\n// for each prng generated. For background on the generator, see Brent's\n// paper: \"Some long-period random number generators using shifts and xors.\"\n// http://arxiv.org/pdf/1004.3115v1.pdf\n//\n// Usage:\n//\n// var xor4096 = require('xor4096');\n// random = xor4096(1); // Seed with int32 or string.\n// assert.equal(random(), 0.1520436450538547); // (0, 1) range, 53 bits.\n// assert.equal(random.int32(), 1806534897); // signed int32, 32 bits.\n//\n// For nonzero numeric keys, this impelementation provides a sequence\n// identical to that by Brent's xorgens 3 implementaion in C. This\n// implementation also provides for initalizing the generator with\n// string seeds, or for saving and restoring the state of the generator.\n//\n// On Chrome, this prng benchmarks about 2.1 times slower than\n// Javascript's built-in Math.random().\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this;\n\n // Set up generator function.\n me.next = function() {\n var w = me.w,\n X = me.X, i = me.i, t, v;\n // Update Weyl generator.\n me.w = w = (w + 0x61c88647) | 0;\n // Update xor generator.\n v = X[(i + 34) & 127];\n t = X[i = ((i + 1) & 127)];\n v ^= v << 13;\n t ^= t << 17;\n v ^= v >>> 15;\n t ^= t >>> 12;\n // Update Xor generator array state.\n v = X[i] = v ^ t;\n me.i = i;\n // Result is the combination.\n return (v + (w ^ (w >>> 16))) | 0;\n };\n\n function init(me, seed) {\n var t, v, i, j, w, X = [], limit = 128;\n if (seed === (seed | 0)) {\n // Numeric seeds initialize v, which is used to generates X.\n v = seed;\n seed = null;\n } else {\n // String seeds are mixed into v and X one character at a time.\n seed = seed + '\\0';\n v = 0;\n limit = Math.max(limit, seed.length);\n }\n // Initialize circular array and weyl value.\n for (i = 0, j = -32; j < limit; ++j) {\n // Put the unicode characters into the array, and shuffle them.\n if (seed) v ^= seed.charCodeAt((j + 32) % seed.length);\n // After 32 shuffles, take v as the starting w value.\n if (j === 0) w = v;\n v ^= v << 10;\n v ^= v >>> 15;\n v ^= v << 4;\n v ^= v >>> 13;\n if (j >= 0) {\n w = (w + 0x61c88647) | 0; // Weyl.\n t = (X[j & 127] ^= (v + w)); // Combine xor and weyl to init array.\n i = (0 == t) ? i + 1 : 0; // Count zeroes.\n }\n }\n // We have detected all zeroes; make the key nonzero.\n if (i >= 128) {\n X[(seed && seed.length || 0) & 127] = -1;\n }\n // Run the generator 512 times to further mix the state before using it.\n // Factoring this as a function slows the main generator, so it is just\n // unrolled here. The weyl generator is not advanced while warming up.\n i = 127;\n for (j = 4 * 128; j > 0; --j) {\n v = X[(i + 34) & 127];\n t = X[i = ((i + 1) & 127)];\n v ^= v << 13;\n t ^= t << 17;\n v ^= v >>> 15;\n t ^= t >>> 12;\n X[i] = v ^ t;\n }\n // Storing state as object members is faster than using closure variables.\n me.w = w;\n me.X = X;\n me.i = i;\n }\n\n init(me, seed);\n}\n\nfunction copy(f, t) {\n t.i = f.i;\n t.w = f.w;\n t.X = f.X.slice();\n return t;\n};\n\nfunction impl(seed, opts) {\n if (seed == null) seed = +(new Date);\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (state.X) copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xor4096 = impl;\n}\n\n})(\n this, // window object or global\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n", "// A Javascript implementaion of the \"Tyche-i\" prng algorithm by\n// Samuel Neves and Filipe Araujo.\n// See https://eden.dei.uc.pt/~sneves/pubs/2011-snfa2.pdf\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this, strseed = '';\n\n // Set up generator function.\n me.next = function() {\n var b = me.b, c = me.c, d = me.d, a = me.a;\n b = (b << 25) ^ (b >>> 7) ^ c;\n c = (c - d) | 0;\n d = (d << 24) ^ (d >>> 8) ^ a;\n a = (a - b) | 0;\n me.b = b = (b << 20) ^ (b >>> 12) ^ c;\n me.c = c = (c - d) | 0;\n me.d = (d << 16) ^ (c >>> 16) ^ a;\n return me.a = (a - b) | 0;\n };\n\n /* The following is non-inverted tyche, which has better internal\n * bit diffusion, but which is about 25% slower than tyche-i in JS.\n me.next = function() {\n var a = me.a, b = me.b, c = me.c, d = me.d;\n a = (me.a + me.b | 0) >>> 0;\n d = me.d ^ a; d = d << 16 ^ d >>> 16;\n c = me.c + d | 0;\n b = me.b ^ c; b = b << 12 ^ d >>> 20;\n me.a = a = a + b | 0;\n d = d ^ a; me.d = d = d << 8 ^ d >>> 24;\n me.c = c = c + d | 0;\n b = b ^ c;\n return me.b = (b << 7 ^ b >>> 25);\n }\n */\n\n me.a = 0;\n me.b = 0;\n me.c = 2654435769 | 0;\n me.d = 1367130551;\n\n if (seed === Math.floor(seed)) {\n // Integer seed.\n me.a = (seed / 0x100000000) | 0;\n me.b = seed | 0;\n } else {\n // String seed.\n strseed += seed;\n }\n\n // Mix in string seed, then discard an initial batch of 64 values.\n for (var k = 0; k < strseed.length + 20; k++) {\n me.b ^= strseed.charCodeAt(k) | 0;\n me.next();\n }\n}\n\nfunction copy(f, t) {\n t.a = f.a;\n t.b = f.b;\n t.c = f.c;\n t.d = f.d;\n return t;\n};\n\nfunction impl(seed, opts) {\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.tychei = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n", "/*\nCopyright 2019 David Bau.\n\nPermission is hereby granted, free of charge, to any person obtaining\na copy of this software and associated documentation files (the\n\"Software\"), to deal in the Software without restriction, including\nwithout limitation the rights to use, copy, modify, merge, publish,\ndistribute, sublicense, and/or sell copies of the Software, and to\npermit persons to whom the Software is furnished to do so, subject to\nthe following conditions:\n\nThe above copyright notice and this permission notice shall be\nincluded in all copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND,\nEXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\nMERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.\nIN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY\nCLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,\nTORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE\nSOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n*/\n\n(function (global, pool, math) {\n//\n// The following constants are related to IEEE 754 limits.\n//\n\nvar width = 256, // each RC4 output is 0 <= x < 256\n chunks = 6, // at least six RC4 outputs for each double\n digits = 52, // there are 52 significant digits in a double\n rngname = 'random', // rngname: name for Math.random and Math.seedrandom\n startdenom = math.pow(width, chunks),\n significance = math.pow(2, digits),\n overflow = significance * 2,\n mask = width - 1,\n nodecrypto; // node.js crypto module, initialized at the bottom.\n\n//\n// seedrandom()\n// This is the seedrandom function described above.\n//\nfunction seedrandom(seed, options, callback) {\n var key = [];\n options = (options == true) ? { entropy: true } : (options || {});\n\n // Flatten the seed string or build one from local entropy if needed.\n var shortseed = mixkey(flatten(\n options.entropy ? [seed, tostring(pool)] :\n (seed == null) ? autoseed() : seed, 3), key);\n\n // Use the seed to initialize an ARC4 generator.\n var arc4 = new ARC4(key);\n\n // This function returns a random double in [0, 1) that contains\n // randomness in every bit of the mantissa of the IEEE 754 value.\n var prng = function() {\n var n = arc4.g(chunks), // Start with a numerator n < 2 ^ 48\n d = startdenom, // and denominator d = 2 ^ 48.\n x = 0; // and no 'extra last byte'.\n while (n < significance) { // Fill up all significant digits by\n n = (n + x) * width; // shifting numerator and\n d *= width; // denominator and generating a\n x = arc4.g(1); // new least-significant-byte.\n }\n while (n >= overflow) { // To avoid rounding up, before adding\n n /= 2; // last byte, shift everything\n d /= 2; // right using integer math until\n x >>>= 1; // we have exactly the desired bits.\n }\n return (n + x) / d; // Form the number within [0, 1).\n };\n\n prng.int32 = function() { return arc4.g(4) | 0; }\n prng.quick = function() { return arc4.g(4) / 0x100000000; }\n prng.double = prng;\n\n // Mix the randomness into accumulated entropy.\n mixkey(tostring(arc4.S), pool);\n\n // Calling convention: what to return as a function of prng, seed, is_math.\n return (options.pass || callback ||\n function(prng, seed, is_math_call, state) {\n if (state) {\n // Load the arc4 state from the given state if it has an S array.\n if (state.S) { copy(state, arc4); }\n // Only provide the .state method if requested via options.state.\n prng.state = function() { return copy(arc4, {}); }\n }\n\n // If called as a method of Math (Math.seedrandom()), mutate\n // Math.random because that is how seedrandom.js has worked since v1.0.\n if (is_math_call) { math[rngname] = prng; return seed; }\n\n // Otherwise, it is a newer calling convention, so return the\n // prng directly.\n else return prng;\n })(\n prng,\n shortseed,\n 'global' in options ? options.global : (this == math),\n options.state);\n}\n\n//\n// ARC4\n//\n// An ARC4 implementation. The constructor takes a key in the form of\n// an array of at most (width) integers that should be 0 <= x < (width).\n//\n// The g(count) method returns a pseudorandom integer that concatenates\n// the next (count) outputs from ARC4. Its return value is a number x\n// that is in the range 0 <= x < (width ^ count).\n//\nfunction ARC4(key) {\n var t, keylen = key.length,\n me = this, i = 0, j = me.i = me.j = 0, s = me.S = [];\n\n // The empty key [] is treated as [0].\n if (!keylen) { key = [keylen++]; }\n\n // Set up S using the standard key scheduling algorithm.\n while (i < width) {\n s[i] = i++;\n }\n for (i = 0; i < width; i++) {\n s[i] = s[j = mask & (j + key[i % keylen] + (t = s[i]))];\n s[j] = t;\n }\n\n // The \"g\" method returns the next (count) outputs as one number.\n (me.g = function(count) {\n // Using instance members instead of closure state nearly doubles speed.\n var t, r = 0,\n i = me.i, j = me.j, s = me.S;\n while (count--) {\n t = s[i = mask & (i + 1)];\n r = r * width + s[mask & ((s[i] = s[j = mask & (j + t)]) + (s[j] = t))];\n }\n me.i = i; me.j = j;\n return r;\n // For robust unpredictability, the function call below automatically\n // discards an initial batch of values. This is called RC4-drop[256].\n // See http://google.com/search?q=rsa+fluhrer+response&btnI\n })(width);\n}\n\n//\n// copy()\n// Copies internal state of ARC4 to or from a plain object.\n//\nfunction copy(f, t) {\n t.i = f.i;\n t.j = f.j;\n t.S = f.S.slice();\n return t;\n};\n\n//\n// flatten()\n// Converts an object tree to nested arrays of strings.\n//\nfunction flatten(obj, depth) {\n var result = [], typ = (typeof obj), prop;\n if (depth && typ == 'object') {\n for (prop in obj) {\n try { result.push(flatten(obj[prop], depth - 1)); } catch (e) {}\n }\n }\n return (result.length ? result : typ == 'string' ? obj : obj + '\\0');\n}\n\n//\n// mixkey()\n// Mixes a string seed into a key that is an array of integers, and\n// returns a shortened string seed that is equivalent to the result key.\n//\nfunction mixkey(seed, key) {\n var stringseed = seed + '', smear, j = 0;\n while (j < stringseed.length) {\n key[mask & j] =\n mask & ((smear ^= key[mask & j] * 19) + stringseed.charCodeAt(j++));\n }\n return tostring(key);\n}\n\n//\n// autoseed()\n// Returns an object for autoseeding, using window.crypto and Node crypto\n// module if available.\n//\nfunction autoseed() {\n try {\n var out;\n if (nodecrypto && (out = nodecrypto.randomBytes)) {\n // The use of 'out' to remember randomBytes makes tight minified code.\n out = out(width);\n } else {\n out = new Uint8Array(width);\n (global.crypto || global.msCrypto).getRandomValues(out);\n }\n return tostring(out);\n } catch (e) {\n var browser = global.navigator,\n plugins = browser && browser.plugins;\n return [+new Date, global, plugins, global.screen, tostring(pool)];\n }\n}\n\n//\n// tostring()\n// Converts an array of charcodes to a string\n//\nfunction tostring(a) {\n return String.fromCharCode.apply(0, a);\n}\n\n//\n// When seedrandom.js is loaded, we immediately mix a few bits\n// from the built-in RNG into the entropy pool. Because we do\n// not want to interfere with deterministic PRNG state later,\n// seedrandom will not call math.random on its own again after\n// initialization.\n//\nmixkey(math.random(), pool);\n\n//\n// Nodejs and AMD support: export the implementation as a module using\n// either convention.\n//\nif ((typeof module) == 'object' && module.exports) {\n module.exports = seedrandom;\n // When in node.js, try using crypto package for autoseeding.\n try {\n nodecrypto = require('crypto');\n } catch (ex) {}\n} else if ((typeof define) == 'function' && define.amd) {\n define(function() { return seedrandom; });\n} else {\n // When included as a plain script, set up Math.seedrandom global.\n math['seed' + rngname] = seedrandom;\n}\n\n\n// End anonymous scope, and pass initial values.\n})(\n // global: `self` in browsers (including strict mode and web workers),\n // otherwise `this` in Node and other environments\n (typeof self !== 'undefined') ? self : this,\n [], // pool: entropy pool starts empty\n Math // math: package containing random, pow, and seedrandom\n);\n", "// A library of seedable RNGs implemented in Javascript.\n//\n// Usage:\n//\n// var seedrandom = require('seedrandom');\n// var random = seedrandom(1); // or any seed.\n// var x = random(); // 0 <= x < 1. Every bit is random.\n// var x = random.quick(); // 0 <= x < 1. 32 bits of randomness.\n\n// alea, a 53-bit multiply-with-carry generator by Johannes Baag\u00F8e.\n// Period: ~2^116\n// Reported to pass all BigCrush tests.\nvar alea = require('./lib/alea');\n\n// xor128, a pure xor-shift generator by George Marsaglia.\n// Period: 2^128-1.\n// Reported to fail: MatrixRank and LinearComp.\nvar xor128 = require('./lib/xor128');\n\n// xorwow, George Marsaglia's 160-bit xor-shift combined plus weyl.\n// Period: 2^192-2^32\n// Reported to fail: CollisionOver, SimpPoker, and LinearComp.\nvar xorwow = require('./lib/xorwow');\n\n// xorshift7, by Fran\u00E7ois Panneton and Pierre L'ecuyer, takes\n// a different approach: it adds robustness by allowing more shifts\n// than Marsaglia's original three. It is a 7-shift generator\n// with 256 bits, that passes BigCrush with no systmatic failures.\n// Period 2^256-1.\n// No systematic BigCrush failures reported.\nvar xorshift7 = require('./lib/xorshift7');\n\n// xor4096, by Richard Brent, is a 4096-bit xor-shift with a\n// very long period that also adds a Weyl generator. It also passes\n// BigCrush with no systematic failures. Its long period may\n// be useful if you have many generators and need to avoid\n// collisions.\n// Period: 2^4128-2^32.\n// No systematic BigCrush failures reported.\nvar xor4096 = require('./lib/xor4096');\n\n// Tyche-i, by Samuel Neves and Filipe Araujo, is a bit-shifting random\n// number generator derived from ChaCha, a modern stream cipher.\n// https://eden.dei.uc.pt/~sneves/pubs/2011-snfa2.pdf\n// Period: ~2^127\n// No systematic BigCrush failures reported.\nvar tychei = require('./lib/tychei');\n\n// The original ARC4-based prng included in this library.\n// Period: ~2^1600\nvar sr = require('./seedrandom');\n\nsr.alea = alea;\nsr.xor128 = xor128;\nsr.xorwow = xorwow;\nsr.xorshift7 = xorshift7;\nsr.xor4096 = xor4096;\nsr.tychei = tychei;\n\nmodule.exports = sr;\n", "", "/**\n * @license\n * Copyright 2020 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Backend, DataId} from '../tensor';\nimport {BackendValues, DataType} from '../types';\n\nexport const EPSILON_FLOAT32 = 1e-7;\nexport const EPSILON_FLOAT16 = 1e-4;\n\n// Required information for all backends.\nexport interface BackendTimingInfo {\n kernelMs: number|{error: string};\n getExtraProfileInfo?(): string; // a field for additional timing information\n // e.g. packing / unpacking for WebGL backend\n}\n\nexport interface TensorStorage {\n read(dataId: DataId): Promise;\n readSync(dataId: DataId): BackendValues;\n disposeData(dataId: DataId, force?: boolean): boolean;\n write(values: BackendValues, shape: number[], dtype: DataType): DataId;\n move(\n dataId: DataId, values: BackendValues, shape: number[], dtype: DataType,\n refCount: number): void;\n memory(): {unreliable: boolean;}; // Backend-specific information.\n /** Returns number of data ids currently in the storage. */\n numDataIds(): number;\n refCount(dataId: DataId): number;\n}\n\n/** Convenient class for storing tensor-related data. */\nexport class DataStorage {\n private data = new WeakMap();\n private dataIdsCount = 0;\n\n constructor(private backend: KernelBackend, private dataMover: DataMover) {}\n\n get(dataId: DataId) {\n if (!this.data.has(dataId)) {\n this.dataMover.moveData(this.backend, dataId);\n }\n return this.data.get(dataId);\n }\n\n set(dataId: DataId, value: T): void {\n this.dataIdsCount++;\n this.data.set(dataId, value);\n }\n\n has(dataId: DataId): boolean {\n return this.data.has(dataId);\n }\n\n delete(dataId: DataId): boolean {\n this.dataIdsCount--;\n return this.data.delete(dataId);\n }\n\n numDataIds(): number {\n return this.dataIdsCount;\n }\n}\n\nexport interface DataMover {\n /**\n * To be called by backends whenever they see a dataId that they don't own.\n * Upon calling this method, the mover will fetch the tensor from another\n * backend and register it with the current active backend.\n */\n moveData(backend: KernelBackend, dataId: DataId): void;\n}\n\nexport interface BackendTimer {\n // check if backend timer is available\n timerAvailable(): boolean;\n time(f: () => void): Promise;\n}\n\n/**\n * The interface that defines the kernels that should be implemented when\n * adding a new backend. New backends don't need to implement every one of the\n * methods, this can be done gradually (throw an error for unimplemented\n * methods).\n */\nexport class KernelBackend implements TensorStorage, Backend, BackendTimer {\n refCount(dataId: DataId): number {\n return notYetImplemented('refCount');\n }\n incRef(dataId: DataId): void {\n return notYetImplemented('incRef');\n }\n timerAvailable(): boolean {\n return true;\n }\n time(f: () => void): Promise {\n return notYetImplemented('time');\n }\n read(dataId: object): Promise {\n return notYetImplemented('read');\n }\n readSync(dataId: object): BackendValues {\n return notYetImplemented('readSync');\n }\n numDataIds(): number {\n return notYetImplemented('numDataIds');\n }\n disposeData(dataId: object, force?: boolean): boolean {\n return notYetImplemented('disposeData');\n }\n write(values: BackendValues, shape: number[], dtype: DataType): DataId {\n return notYetImplemented('write');\n }\n move(\n dataId: DataId, values: BackendValues, shape: number[], dtype: DataType,\n refCount: number): void {\n return notYetImplemented('move');\n }\n memory(): {unreliable: boolean; reasons?: string[]} {\n return notYetImplemented('memory');\n }\n /** Returns the highest precision for floats in bits (e.g. 16 or 32) */\n floatPrecision(): 16|32 {\n return notYetImplemented('floatPrecision');\n }\n /** Returns the smallest representable number. */\n epsilon(): number {\n return this.floatPrecision() === 32 ? EPSILON_FLOAT32 : EPSILON_FLOAT16;\n }\n dispose(): void {\n return notYetImplemented('dispose');\n }\n}\n\nfunction notYetImplemented(kernelName: string): never {\n throw new Error(\n `'${kernelName}' not yet implemented or not found in the registry. ` +\n `This kernel may not be supported by the tfjs backend you have chosen`);\n}\n", "/**\n * @license\n * Copyright 2020 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {DataType, DataTypeMap, FlatVector, NumericDataType, RecursiveArray, TensorLike, TypedArray} from './types';\n\n/**\n * Shuffles the array in-place using Fisher-Yates algorithm.\n *\n * ```js\n * const a = [1, 2, 3, 4, 5];\n * tf.util.shuffle(a);\n * console.log(a);\n * ```\n *\n * @param array The array to shuffle in-place.\n *\n * @doc {heading: 'Util', namespace: 'util'}\n */\n// tslint:disable-next-line:no-any\nexport function shuffle(array: any[]|Uint32Array|Int32Array|\n Float32Array): void {\n let counter = array.length;\n let temp = 0;\n let index = 0;\n // While there are elements in the array\n while (counter > 0) {\n // Pick a random index\n index = (Math.random() * counter) | 0;\n // Decrease counter by 1\n counter--;\n // And swap the last element with it\n temp = array[counter];\n array[counter] = array[index];\n array[index] = temp;\n }\n}\n\n/**\n * Shuffles two arrays in-place the same way using Fisher-Yates algorithm.\n *\n * ```js\n * const a = [1,2,3,4,5];\n * const b = [11,22,33,44,55];\n * tf.util.shuffleCombo(a, b);\n * console.log(a, b);\n * ```\n *\n * @param array The first array to shuffle in-place.\n * @param array2 The second array to shuffle in-place with the same permutation\n * as the first array.\n *\n * @doc {heading: 'Util', namespace: 'util'}\n */\nexport function shuffleCombo(\n // tslint:disable-next-line:no-any\n array: any[]|Uint32Array|Int32Array|Float32Array,\n // tslint:disable-next-line:no-any\n array2: any[]|Uint32Array|Int32Array|Float32Array): void {\n if (array.length !== array2.length) {\n throw new Error(\n `Array sizes must match to be shuffled together ` +\n `First array length was ${array.length}` +\n `Second array length was ${array2.length}`);\n }\n let counter = array.length;\n let temp, temp2;\n let index = 0;\n // While there are elements in the array\n while (counter > 0) {\n // Pick a random index\n index = (Math.random() * counter) | 0;\n // Decrease counter by 1\n counter--;\n // And swap the last element of each array with it\n temp = array[counter];\n temp2 = array2[counter];\n array[counter] = array[index];\n array2[counter] = array2[index];\n array[index] = temp;\n array2[index] = temp2;\n }\n}\n\n/** Clamps a value to a specified range. */\nexport function clamp(min: number, x: number, max: number): number {\n return Math.max(min, Math.min(x, max));\n}\n\nexport function nearestLargerEven(val: number): number {\n return val % 2 === 0 ? val : val + 1;\n}\n\nexport function sum(arr: number[]): number {\n let sum = 0;\n for (let i = 0; i < arr.length; i++) {\n sum += arr[i];\n }\n return sum;\n}\n\n/**\n * Returns a sample from a uniform [a, b) distribution.\n *\n * @param a The minimum support (inclusive).\n * @param b The maximum support (exclusive).\n * @return A pseudorandom number on the half-open interval [a,b).\n */\nexport function randUniform(a: number, b: number) {\n const r = Math.random();\n return (b * r) + (1 - r) * a;\n}\n\n/** Returns the squared Euclidean distance between two vectors. */\nexport function distSquared(a: FlatVector, b: FlatVector): number {\n let result = 0;\n for (let i = 0; i < a.length; i++) {\n const diff = Number(a[i]) - Number(b[i]);\n result += diff * diff;\n }\n return result;\n}\n\n/**\n * Asserts that the expression is true. Otherwise throws an error with the\n * provided message.\n *\n * ```js\n * const x = 2;\n * tf.util.assert(x === 2, 'x is not 2');\n * ```\n *\n * @param expr The expression to assert (as a boolean).\n * @param msg A function that returns the message to report when throwing an\n * error. We use a function for performance reasons.\n *\n * @doc {heading: 'Util', namespace: 'util'}\n */\nexport function assert(expr: boolean, msg: () => string) {\n if (!expr) {\n throw new Error(typeof msg === 'string' ? msg : msg());\n }\n}\n\nexport function assertShapesMatch(\n shapeA: number[], shapeB: number[], errorMessagePrefix = ''): void {\n assert(\n arraysEqual(shapeA, shapeB),\n () => errorMessagePrefix + ` Shapes ${shapeA} and ${shapeB} must match`);\n}\n\nexport function assertNonNull(a: TensorLike): void {\n assert(\n a != null,\n () => `The input to the tensor constructor must be a non-null value.`);\n}\n\n// NOTE: We explicitly type out what T extends instead of any so that\n// util.flatten on a nested array of number doesn't try to infer T as a\n// number[][], causing us to explicitly type util.flatten().\n/**\n * Flattens an arbitrarily nested array.\n *\n * ```js\n * const a = [[1, 2], [3, 4], [5, [6, [7]]]];\n * const flat = tf.util.flatten(a);\n * console.log(flat);\n * ```\n *\n * @param arr The nested array to flatten.\n * @param result The destination array which holds the elements.\n * @param skipTypedArray If true, avoids flattening the typed arrays. Defaults\n * to false.\n *\n * @doc {heading: 'Util', namespace: 'util'}\n */\nexport function\nflatten|TypedArray>(\n arr: T|RecursiveArray, result: T[] = [], skipTypedArray = false): T[] {\n if (result == null) {\n result = [];\n }\n if (Array.isArray(arr) || isTypedArray(arr) && !skipTypedArray) {\n for (let i = 0; i < arr.length; ++i) {\n flatten(arr[i], result, skipTypedArray);\n }\n } else {\n result.push(arr as T);\n }\n return result;\n}\n\n/**\n * Returns the size (number of elements) of the tensor given its shape.\n *\n * ```js\n * const shape = [3, 4, 2];\n * const size = tf.util.sizeFromShape(shape);\n * console.log(size);\n * ```\n *\n * @doc {heading: 'Util', namespace: 'util'}\n */\nexport function sizeFromShape(shape: number[]): number {\n if (shape.length === 0) {\n // Scalar.\n return 1;\n }\n let size = shape[0];\n for (let i = 1; i < shape.length; i++) {\n size *= shape[i];\n }\n return size;\n}\n\nexport function isScalarShape(shape: number[]): boolean {\n return shape.length === 0;\n}\n\nexport function arraysEqual(n1: FlatVector, n2: FlatVector) {\n if (n1 === n2) {\n return true;\n }\n if (n1 == null || n2 == null) {\n return false;\n }\n\n if (n1.length !== n2.length) {\n return false;\n }\n for (let i = 0; i < n1.length; i++) {\n if (n1[i] !== n2[i]) {\n return false;\n }\n }\n return true;\n}\n\nexport function isInt(a: number): boolean {\n return a % 1 === 0;\n}\n\nexport function tanh(x: number): number {\n // tslint:disable-next-line:no-any\n if ((Math as any).tanh != null) {\n // tslint:disable-next-line:no-any\n return (Math as any).tanh(x);\n }\n if (x === Infinity) {\n return 1;\n } else if (x === -Infinity) {\n return -1;\n } else {\n const e2x = Math.exp(2 * x);\n return (e2x - 1) / (e2x + 1);\n }\n}\n\nexport function sizeToSquarishShape(size: number): [number, number] {\n const width = Math.ceil(Math.sqrt(size));\n return [width, Math.ceil(size / width)];\n}\n\n/**\n * Creates a new array with randomized indicies to a given quantity.\n *\n * ```js\n * const randomTen = tf.util.createShuffledIndices(10);\n * console.log(randomTen);\n * ```\n *\n * @param number Quantity of how many shuffled indicies to create.\n *\n * @doc {heading: 'Util', namespace: 'util'}\n */\nexport function createShuffledIndices(n: number): Uint32Array {\n const shuffledIndices = new Uint32Array(n);\n for (let i = 0; i < n; ++i) {\n shuffledIndices[i] = i;\n }\n shuffle(shuffledIndices);\n return shuffledIndices;\n}\n\nexport function rightPad(a: string, size: number): string {\n if (size <= a.length) {\n return a;\n }\n return a + ' '.repeat(size - a.length);\n}\n\nexport function repeatedTry(\n checkFn: () => boolean, delayFn = (counter: number) => 0,\n maxCounter?: number): Promise {\n return new Promise((resolve, reject) => {\n let tryCount = 0;\n\n const tryFn = () => {\n if (checkFn()) {\n resolve();\n return;\n }\n\n tryCount++;\n\n const nextBackoff = delayFn(tryCount);\n\n if (maxCounter != null && tryCount >= maxCounter) {\n reject();\n return;\n }\n setTimeout(tryFn, nextBackoff);\n };\n\n tryFn();\n });\n}\n\n/**\n * Given the full size of the array and a shape that may contain -1 as the\n * implicit dimension, returns the inferred shape where -1 is replaced.\n * E.g. For shape=[2, -1, 3] and size=24, it will return [2, 4, 3].\n *\n * @param shape The shape, which may contain -1 in some dimension.\n * @param size The full size (number of elements) of the array.\n * @return The inferred shape where -1 is replaced with the inferred size.\n */\nexport function inferFromImplicitShape(\n shape: number[], size: number): number[] {\n let shapeProd = 1;\n let implicitIdx = -1;\n\n for (let i = 0; i < shape.length; ++i) {\n if (shape[i] >= 0) {\n shapeProd *= shape[i];\n } else if (shape[i] === -1) {\n if (implicitIdx !== -1) {\n throw Error(\n `Shapes can only have 1 implicit size. ` +\n `Found -1 at dim ${implicitIdx} and dim ${i}`);\n }\n implicitIdx = i;\n } else if (shape[i] < 0) {\n throw Error(`Shapes can not be < 0. Found ${shape[i]} at dim ${i}`);\n }\n }\n\n if (implicitIdx === -1) {\n if (size > 0 && size !== shapeProd) {\n throw Error(`Size(${size}) must match the product of shape ${shape}`);\n }\n return shape;\n }\n\n if (shapeProd === 0) {\n throw Error(\n `Cannot infer the missing size in [${shape}] when ` +\n `there are 0 elements`);\n }\n if (size % shapeProd !== 0) {\n throw Error(\n `The implicit shape can't be a fractional number. ` +\n `Got ${size} / ${shapeProd}`);\n }\n\n const newShape = shape.slice();\n newShape[implicitIdx] = size / shapeProd;\n return newShape;\n}\n\nexport function parseAxisParam(\n axis: number|number[], shape: number[]): number[] {\n const rank = shape.length;\n\n // Normalize input\n axis = axis == null ? shape.map((s, i) => i) : [].concat(axis);\n\n // Check for valid range\n assert(\n axis.every(ax => ax >= -rank && ax < rank),\n () =>\n `All values in axis param must be in range [-${rank}, ${rank}) but ` +\n `got axis ${axis}`);\n\n // Check for only integers\n assert(\n axis.every(ax => isInt(ax)),\n () => `All values in axis param must be integers but ` +\n `got axis ${axis}`);\n\n // Handle negative axis.\n return axis.map(a => a < 0 ? rank + a : a);\n}\n\n/** Reduces the shape by removing all dimensions of shape 1. */\nexport function squeezeShape(shape: number[], axis?: number[]):\n {newShape: number[], keptDims: number[]} {\n const newShape: number[] = [];\n const keptDims: number[] = [];\n const isEmptyArray = axis != null && Array.isArray(axis) && axis.length === 0;\n const axes = (axis == null || isEmptyArray) ?\n null :\n parseAxisParam(axis, shape).sort();\n let j = 0;\n for (let i = 0; i < shape.length; ++i) {\n if (axes != null) {\n if (axes[j] === i && shape[i] !== 1) {\n throw new Error(\n `Can't squeeze axis ${i} since its dim '${shape[i]}' is not 1`);\n }\n if ((axes[j] == null || axes[j] > i) && shape[i] === 1) {\n newShape.push(shape[i]);\n keptDims.push(i);\n }\n if (axes[j] <= i) {\n j++;\n }\n }\n if (shape[i] !== 1) {\n newShape.push(shape[i]);\n keptDims.push(i);\n }\n }\n return {newShape, keptDims};\n}\n\nexport function getTypedArrayFromDType(\n dtype: D, size: number): DataTypeMap[D] {\n let values = null;\n if (dtype == null || dtype === 'float32') {\n values = new Float32Array(size);\n } else if (dtype === 'int32') {\n values = new Int32Array(size);\n } else if (dtype === 'bool') {\n values = new Uint8Array(size);\n } else {\n throw new Error(`Unknown data type ${dtype}`);\n }\n return values as DataTypeMap[D];\n}\n\nexport function getArrayFromDType(\n dtype: D, size: number): DataTypeMap[D] {\n let values = null;\n if (dtype == null || dtype === 'float32') {\n values = new Float32Array(size);\n } else if (dtype === 'int32') {\n values = new Int32Array(size);\n } else if (dtype === 'bool') {\n values = new Uint8Array(size);\n } else if (dtype === 'string') {\n values = new Array<'string'>(size);\n } else {\n throw new Error(`Unknown data type ${dtype}`);\n }\n return values as DataTypeMap[D];\n}\n\nexport function checkConversionForErrors(\n vals: DataTypeMap[D]|number[], dtype: D): void {\n for (let i = 0; i < vals.length; i++) {\n const num = vals[i] as number;\n if (isNaN(num) || !isFinite(num)) {\n throw Error(`A tensor of type ${dtype} being uploaded contains ${num}.`);\n }\n }\n}\n\n/** Returns true if the dtype is valid. */\nexport function isValidDtype(dtype: DataType): boolean {\n return dtype === 'bool' || dtype === 'complex64' || dtype === 'float32' ||\n dtype === 'int32' || dtype === 'string';\n}\n\n/**\n * Returns true if the new type can't encode the old type without loss of\n * precision.\n */\nexport function hasEncodingLoss(oldType: DataType, newType: DataType): boolean {\n if (newType === 'complex64') {\n return false;\n }\n if (newType === 'float32' && oldType !== 'complex64') {\n return false;\n }\n if (newType === 'int32' && oldType !== 'float32' && oldType !== 'complex64') {\n return false;\n }\n if (newType === 'bool' && oldType === 'bool') {\n return false;\n }\n return true;\n}\n\nexport function isTypedArray(a: {}): a is Float32Array|Int32Array|Uint8Array {\n return a instanceof Float32Array || a instanceof Int32Array ||\n a instanceof Uint8Array;\n}\n\nexport function bytesPerElement(dtype: DataType): number {\n if (dtype === 'float32' || dtype === 'int32') {\n return 4;\n } else if (dtype === 'complex64') {\n return 8;\n } else if (dtype === 'bool') {\n return 1;\n } else {\n throw new Error(`Unknown dtype ${dtype}`);\n }\n}\n\n/**\n * Returns the approximate number of bytes allocated in the string array - 2\n * bytes per character. Computing the exact bytes for a native string in JS is\n * not possible since it depends on the encoding of the html page that serves\n * the website.\n */\nexport function bytesFromStringArray(arr: Uint8Array[]): number {\n if (arr == null) {\n return 0;\n }\n let bytes = 0;\n arr.forEach(x => bytes += x.length);\n return bytes;\n}\n\n/** Returns true if the value is a string. */\nexport function isString(value: {}): value is string {\n return typeof value === 'string' || value instanceof String;\n}\n\nexport function isBoolean(value: {}): boolean {\n return typeof value === 'boolean';\n}\n\nexport function isNumber(value: {}): boolean {\n return typeof value === 'number';\n}\n\nexport function inferDtype(values: TensorLike): DataType {\n if (Array.isArray(values)) {\n return inferDtype(values[0]);\n }\n if (values instanceof Float32Array) {\n return 'float32';\n } else if (values instanceof Int32Array || values instanceof Uint8Array) {\n return 'int32';\n } else if (isNumber(values)) {\n return 'float32';\n } else if (isString(values)) {\n return 'string';\n } else if (isBoolean(values)) {\n return 'bool';\n }\n return 'float32';\n}\n\nexport function isFunction(f: Function) {\n return !!(f && f.constructor && f.call && f.apply);\n}\n\nexport function nearestDivisor(size: number, start: number): number {\n for (let i = start; i < size; ++i) {\n if (size % i === 0) {\n return i;\n }\n }\n return size;\n}\n\nexport function computeStrides(shape: number[]): number[] {\n const rank = shape.length;\n if (rank < 2) {\n return [];\n }\n\n // Last dimension has implicit stride of 1, thus having D-1 (instead of D)\n // strides.\n const strides = new Array(rank - 1);\n strides[rank - 2] = shape[rank - 1];\n for (let i = rank - 3; i >= 0; --i) {\n strides[i] = strides[i + 1] * shape[i + 1];\n }\n return strides;\n}\n\nfunction createNestedArray(\n offset: number, shape: number[], a: TypedArray, isComplex = false) {\n const ret = new Array();\n if (shape.length === 1) {\n const d = shape[0] * (isComplex ? 2 : 1);\n for (let i = 0; i < d; i++) {\n ret[i] = a[offset + i];\n }\n } else {\n const d = shape[0];\n const rest = shape.slice(1);\n const len = rest.reduce((acc, c) => acc * c) * (isComplex ? 2 : 1);\n for (let i = 0; i < d; i++) {\n ret[i] = createNestedArray(offset + i * len, rest, a, isComplex);\n }\n }\n return ret;\n}\n\n// Provide a nested array of TypedArray in given shape.\nexport function toNestedArray(\n shape: number[], a: TypedArray, isComplex = false) {\n if (shape.length === 0) {\n // Scalar type should return a single number.\n return a[0];\n }\n const size = shape.reduce((acc, c) => acc * c) * (isComplex ? 2 : 1);\n if (size === 0) {\n // A tensor with shape zero should be turned into empty list.\n return [];\n }\n if (size !== a.length) {\n throw new Error(`[${shape}] does not match the input size ${a.length}${\n isComplex ? ' for a complex tensor' : ''}.`);\n }\n\n return createNestedArray(0, shape, a, isComplex);\n}\n\nexport function makeOnesTypedArray(\n size: number, dtype: D): DataTypeMap[D] {\n const array = makeZerosTypedArray(size, dtype);\n for (let i = 0; i < array.length; i++) {\n array[i] = 1;\n }\n return array;\n}\n\nexport function makeZerosTypedArray(\n size: number, dtype: D): DataTypeMap[D] {\n if (dtype == null || dtype === 'float32' || dtype === 'complex64') {\n return new Float32Array(size) as DataTypeMap[D];\n } else if (dtype === 'int32') {\n return new Int32Array(size) as DataTypeMap[D];\n } else if (dtype === 'bool') {\n return new Uint8Array(size) as DataTypeMap[D];\n } else {\n throw new Error(`Unknown data type ${dtype}`);\n }\n}\n\n/**\n * Make nested `TypedArray` filled with zeros.\n * @param shape The shape information for the nested array.\n * @param dtype dtype of the array element.\n */\nexport function makeZerosNestedTypedArray(\n shape: number[], dtype: D) {\n const size = shape.reduce((prev, curr) => prev * curr, 1);\n if (dtype == null || dtype === 'float32') {\n return toNestedArray(shape, new Float32Array(size));\n } else if (dtype === 'int32') {\n return toNestedArray(shape, new Int32Array(size));\n } else if (dtype === 'bool') {\n return toNestedArray(shape, new Uint8Array(size));\n } else {\n throw new Error(`Unknown data type ${dtype}`);\n }\n}\n\nexport function assertNonNegativeIntegerDimensions(shape: number[]) {\n shape.forEach(dimSize => {\n assert(\n Number.isInteger(dimSize) && dimSize >= 0,\n () =>\n `Tensor must have a shape comprised of positive integers but got ` +\n `shape [${shape}].`);\n });\n}\n\n/**\n * Computes flat index for a given location (multidimentionsal index) in a\n * Tensor/multidimensional array.\n *\n * @param locs Location in the tensor.\n * @param rank Rank of the tensor.\n * @param strides Tensor strides.\n */\nexport function locToIndex(\n locs: number[], rank: number, strides: number[]): number {\n if (rank === 0) {\n return 0;\n } else if (rank === 1) {\n return locs[0];\n }\n let index = locs[locs.length - 1];\n for (let i = 0; i < locs.length - 1; ++i) {\n index += strides[i] * locs[i];\n }\n return index;\n}\n\n/**\n * Computes the location (multidimensional index) in a tensor/multidimentional\n * array for a given flat index.\n *\n * @param index Index in flat array.\n * @param rank Rank of tensor.\n * @param strides Strides of tensor.\n */\nexport function indexToLoc(\n index: number, rank: number, strides: number[]): number[] {\n if (rank === 0) {\n return [];\n } else if (rank === 1) {\n return [index];\n }\n const locs: number[] = new Array(rank);\n for (let i = 0; i < locs.length - 1; ++i) {\n locs[i] = Math.floor(index / strides[i]);\n index -= locs[i] * strides[i];\n }\n locs[locs.length - 1] = index;\n return locs;\n}\n\n/**\n * This method asserts whether an object is a Promise instance.\n * @param object\n */\n// tslint:disable-next-line: no-any\nexport function isPromise(object: any) {\n // We chose to not use 'obj instanceOf Promise' for two reasons:\n // 1. It only reliably works for es6 Promise, not other Promise\n // implementations.\n // 2. It doesn't work with framework that uses zone.js. zone.js monkey patch\n // the async calls, so it is possible the obj (patched) is comparing to a\n // pre-patched Promise.\n return object && object.then && typeof object.then === 'function';\n}\n", "/**\n * @license\n * Copyright 2017 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Platform} from './platforms/platform';\nimport {isPromise} from './util_base';\n\n// Expects flags from URL in the format ?tfjsflags=FLAG1:1,FLAG2:true.\nconst TENSORFLOWJS_FLAGS_PREFIX = 'tfjsflags';\n\ntype FlagValue = number|boolean;\ntype FlagEvaluationFn = (() => FlagValue)|(() => Promise);\nexport type Flags = {\n [featureName: string]: FlagValue\n};\nexport type FlagRegistryEntry = {\n evaluationFn: FlagEvaluationFn;\n setHook?: (value: FlagValue) => void;\n};\n\n/**\n * The environment contains evaluated flags as well as the registered platform.\n * This is always used as a global singleton and can be retrieved with\n * `tf.env()`.\n *\n * @doc {heading: 'Environment'}\n */\nexport class Environment {\n private flags: Flags = {};\n private flagRegistry: {[flagName: string]: FlagRegistryEntry} = {};\n\n private urlFlags: Flags = {};\n\n platformName: string;\n platform: Platform;\n\n // Jasmine spies on this in 'environment_test.ts'\n getQueryParams = getQueryParams;\n\n // tslint:disable-next-line: no-any\n constructor(public global: any) {\n this.populateURLFlags();\n }\n\n setPlatform(platformName: string, platform: Platform) {\n if (this.platform != null) {\n console.warn(\n `Platform ${this.platformName} has already been set. ` +\n `Overwriting the platform with ${platform}.`);\n }\n this.platformName = platformName;\n this.platform = platform;\n }\n\n registerFlag(\n flagName: string, evaluationFn: FlagEvaluationFn,\n setHook?: (value: FlagValue) => void) {\n this.flagRegistry[flagName] = {evaluationFn, setHook};\n\n // Override the flag value from the URL. This has to happen here because the\n // environment is initialized before flags get registered.\n if (this.urlFlags[flagName] != null) {\n const flagValue = this.urlFlags[flagName];\n console.warn(\n `Setting feature override from URL ${flagName}: ${flagValue}.`);\n this.set(flagName, flagValue);\n }\n }\n\n async getAsync(flagName: string): Promise {\n if (flagName in this.flags) {\n return this.flags[flagName];\n }\n\n this.flags[flagName] = await this.evaluateFlag(flagName);\n return this.flags[flagName];\n }\n\n get(flagName: string): FlagValue {\n if (flagName in this.flags) {\n return this.flags[flagName];\n }\n\n const flagValue = this.evaluateFlag(flagName);\n if (isPromise(flagValue)) {\n throw new Error(\n `Flag ${flagName} cannot be synchronously evaluated. ` +\n `Please use getAsync() instead.`);\n }\n\n this.flags[flagName] = flagValue as number | boolean;\n\n return this.flags[flagName];\n }\n\n getNumber(flagName: string): number {\n return this.get(flagName) as number;\n }\n\n getBool(flagName: string): boolean {\n return this.get(flagName) as boolean;\n }\n\n getFlags(): Flags {\n return this.flags;\n }\n // For backwards compatibility.\n get features(): Flags {\n return this.flags;\n }\n\n set(flagName: string, value: FlagValue): void {\n if (this.flagRegistry[flagName] == null) {\n throw new Error(\n `Cannot set flag ${flagName} as it has not been registered.`);\n }\n this.flags[flagName] = value;\n if (this.flagRegistry[flagName].setHook != null) {\n this.flagRegistry[flagName].setHook(value);\n }\n }\n\n private evaluateFlag(flagName: string): FlagValue|Promise {\n if (this.flagRegistry[flagName] == null) {\n throw new Error(\n `Cannot evaluate flag '${flagName}': no evaluation function found.`);\n }\n return this.flagRegistry[flagName].evaluationFn();\n }\n\n setFlags(flags: Flags) {\n this.flags = Object.assign({}, flags);\n }\n\n reset() {\n this.flags = {};\n this.urlFlags = {};\n this.populateURLFlags();\n }\n\n private populateURLFlags(): void {\n if (typeof this.global === 'undefined' ||\n typeof this.global.location === 'undefined' ||\n typeof this.global.location.search === 'undefined') {\n return;\n }\n\n const urlParams = this.getQueryParams(this.global.location.search);\n if (TENSORFLOWJS_FLAGS_PREFIX in urlParams) {\n const keyValues = urlParams[TENSORFLOWJS_FLAGS_PREFIX].split(',');\n keyValues.forEach(keyValue => {\n const [key, value] = keyValue.split(':') as [string, string];\n this.urlFlags[key] = parseValue(key, value);\n });\n }\n }\n}\n\nexport function getQueryParams(queryString: string): {[key: string]: string} {\n const params = {};\n queryString.replace(/[?&]([^=?&]+)(?:=([^&]*))?/g, (s, ...t) => {\n decodeParam(params, t[0], t[1]);\n return t.join('=');\n });\n return params;\n}\n\nfunction decodeParam(\n params: {[key: string]: string}, name: string, value?: string) {\n params[decodeURIComponent(name)] = decodeURIComponent(value || '');\n}\n\nfunction parseValue(flagName: string, value: string): FlagValue {\n value = value.toLowerCase();\n if (value === 'true' || value === 'false') {\n return value === 'true';\n } else if (`${+ value}` === value) {\n return +value;\n }\n throw new Error(\n `Could not parse value flag value ${value} for flag ${flagName}.`);\n}\n\n/**\n * Returns the current environment (a global singleton).\n *\n * The environment object contains the evaluated feature values as well as the\n * active platform.\n *\n * @doc {heading: 'Environment'}\n */\nexport function env() {\n return ENV;\n}\n\nexport let ENV: Environment = null;\nexport function setEnvironmentGlobal(environment: Environment) {\n ENV = environment;\n}\n", "/**\n * @license\n * Copyright 2020 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n// Note that the identifier globalNameSpace is scoped to this module, but will\n// always resolve to the same global object regardless of how the module is\n// resolved.\n// tslint:disable-next-line:no-any\nlet globalNameSpace: {_tfGlobals: Map};\n// tslint:disable-next-line:no-any\nexport function getGlobalNamespace(): {_tfGlobals: Map} {\n if (globalNameSpace == null) {\n // tslint:disable-next-line:no-any\n let ns: any;\n if (typeof (window) !== 'undefined') {\n ns = window;\n } else if (typeof (global) !== 'undefined') {\n ns = global;\n } else if (typeof (process) !== 'undefined') {\n ns = process;\n } else if (typeof (self) !== 'undefined') {\n ns = self;\n } else {\n throw new Error('Could not find a global object');\n }\n globalNameSpace = ns;\n }\n return globalNameSpace;\n}\n\n// tslint:disable-next-line:no-any\nfunction getGlobalMap(): Map {\n const ns = getGlobalNamespace();\n if (ns._tfGlobals == null) {\n ns._tfGlobals = new Map();\n }\n return ns._tfGlobals;\n}\n\n/**\n * Returns a globally accessible 'singleton' object.\n *\n * @param key the name of the object\n * @param init a function to initialize to initialize this object\n * the first time it is fetched.\n */\nexport function getGlobal(key: string, init: () => T): T {\n const globalMap = getGlobalMap();\n if (globalMap.has(key)) {\n return globalMap.get(key);\n } else {\n const singleton = init();\n globalMap.set(key, singleton);\n return globalMap.get(key);\n }\n}\n", "/**\n * @license\n * Copyright 2020 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n// Allow UpperCamelCase variable names\n// tslint:disable: variable-name\n// Unfortunately just enabling PascalCase per file (tslint:enable:\n// allow-pascal-case) doesn't work.\nimport {NamedTensorInfoMap, TensorInfo} from './kernel_registry';\nimport {ExplicitPadding} from './ops/conv_util';\nimport {Activation} from './ops/fused_types';\nimport {DataType, PixelData} from './types';\n\nexport const Abs = 'Abs';\nexport type AbsInputs = UnaryInputs;\n\nexport const Acos = 'Acos';\nexport type AcosInputs = UnaryInputs;\n\nexport const Acosh = 'Acosh';\nexport type AcoshInputs = UnaryInputs;\n\nexport const Add = 'Add';\nexport type AddInputs = BinaryInputs;\n\nexport const AddN = 'AddN';\nexport type AddNInputs = TensorInfo[];\n\nexport const All = 'All';\nexport type AllInputs = Pick;\nexport interface AllAttrs {\n axis: number|number[];\n keepDims: boolean;\n}\n\nexport const Any = 'Any';\nexport type AnyInputs = Pick;\nexport interface AnyAttrs {\n axis: number|number[];\n keepDims: boolean;\n}\n\nexport const ArgMax = 'ArgMax';\nexport type ArgMaxInputs = Pick;\nexport interface ArgMaxAttrs {\n axis: number;\n}\n\nexport const ArgMin = 'ArgMin';\nexport type ArgMinInputs = Pick;\nexport interface ArgMinAttrs {\n axis: number;\n}\n\nexport const Asin = 'Asin';\nexport type AsinInputs = UnaryInputs;\n\nexport const Asinh = 'Asinh';\nexport type AsinhInputs = UnaryInputs;\n\nexport const Atan = 'Atan';\nexport type AtanInputs = UnaryInputs;\n\nexport const Atanh = 'Atanh';\nexport type AtanhInputs = UnaryInputs;\n\nexport const Atan2 = 'Atan2';\nexport type Atan2Inputs = BinaryInputs;\n\nexport const AvgPool = 'AvgPool';\nexport type AvgPoolInputs = Pick;\nexport interface AvgPoolAttrs {\n filterSize: [number, number]|number;\n strides: [number, number]|number;\n pad: 'valid'|'same'|number;\n dimRoundingMode?: 'floor'|'round'|'ceil';\n}\n\nexport const AvgPoolGrad = 'AvgPoolGrad';\nexport type AvgPoolGradInputs = Pick;\nexport interface AvgPoolGradAttrs {\n filterSize: [number, number]|number;\n strides: [number, number]|number;\n pad: 'valid'|'same'|number;\n}\n\nexport const AvgPool3D = 'AvgPool3D';\nexport type AvgPool3DInputs = Pick;\nexport interface AvgPool3DAttrs {\n filterSize: [number, number, number]|number;\n strides: [number, number, number]|number;\n pad: 'valid'|'same'|number;\n dimRoundingMode?: 'floor'|'round'|'ceil';\n dataFormat: 'NDHWC'|'NCDHW';\n}\n\nexport const AvgPool3DGrad = 'AvgPool3DGrad';\nexport type AvgPool3DGradInputs = Pick;\nexport interface AvgPool3DGradAttrs {\n filterSize: [number, number, number]|number;\n strides: [number, number, number]|number;\n pad: 'valid'|'same'|number;\n dimRoundingMode?: 'floor'|'round'|'ceil';\n}\n\nexport const BatchMatMul = 'BatchMatMul';\nexport type BatchMatMulInputs = Pick;\nexport interface BatchMatMulAttrs {\n transposeA: boolean;\n transposeB: boolean;\n}\n\nexport const BatchToSpaceND = 'BatchToSpaceND';\nexport type BatchToSpaceNDInputs = Pick;\nexport interface BatchToSpaceNDAttrs {\n blockShape: number[];\n crops: number[][];\n}\n\nexport type BinaryInputs = Pick;\n\nexport const Bincount = 'Bincount';\nexport type BincountInputs = Pick;\nexport interface BincountAttrs {\n size: number;\n}\n\nexport const BroadcastTo = 'BroadcastTo';\nexport type BroadcastToInputs = Pick;\nexport interface BroadCastToAttrs {\n shape: number[];\n inputShape: number[]; // for gradient\n}\n\nexport const Cast = 'Cast';\nexport type CastInputs = UnaryInputs;\nexport interface CastAttrs {\n dtype: DataType;\n}\n\nexport const Ceil = 'Ceil';\nexport type CeilInputs = UnaryInputs;\n\nexport const ClipByValue = 'ClipByValue';\nexport type ClipByValueInputs = UnaryInputs;\nexport interface ClipByValueAttrs {\n clipValueMin: number;\n clipValueMax: number;\n}\n\nexport const Complex = 'Complex';\nexport type ComplexInputs = Pick;\n\nexport const ComplexAbs = 'ComplexAbs';\nexport type ComplexAbsInputs = UnaryInputs;\n\nexport const Concat = 'Concat';\nexport type ConcatInputs = TensorInfo[];\nexport interface ConcatAttrs {\n axis: number;\n}\n\nexport const Conv2D = 'Conv2D';\nexport type Conv2DInputs = Pick;\nexport interface Conv2DAttrs {\n strides: [number, number]|number;\n pad: 'valid'|'same'|number|ExplicitPadding;\n dataFormat: 'NHWC'|'NCHW';\n dilations: [number, number]|number;\n dimRoundingMode?: 'floor'|'round'|'ceil';\n}\n\nexport const Conv2DBackpropFilter = 'Conv2DBackpropFilter';\nexport type Conv2DBackpropFilterInputs = Pick;\nexport interface Conv2DBackpropFilterAttrs {\n strides: [number, number]|number;\n pad: 'valid'|'same'|number|ExplicitPadding;\n dataFormat: 'NHWC'|'NCHW';\n dimRoundingMode?: 'floor'|'round'|'ceil';\n filterShape: [number, number, number, number];\n}\n\nexport const Conv2DBackpropInput = 'Conv2DBackpropInput';\nexport type Conv2DBackpropInputInputs = Pick;\nexport interface Conv2DBackpropInputAttrs {\n strides: [number, number]|number;\n pad: 'valid'|'same'|number|ExplicitPadding;\n dataFormat: 'NHWC'|'NCHW';\n dimRoundingMode?: 'floor'|'round'|'ceil';\n inputShape: [number, number, number, number];\n}\n\nexport const Conv3D = 'Conv3D';\nexport type Conv3DInputs = Pick;\nexport interface Conv3DAttrs {\n strides: [number, number, number]|number;\n pad: 'valid'|'same';\n dataFormat: 'NDHWC'|'NCDHW';\n dilations: [number, number, number]|number;\n}\n\nexport const Conv3DBackpropFilterV2 = 'Conv3DBackpropFilterV2';\nexport type Conv3DBackpropFilterV2Inputs = Pick;\n\nexport interface Conv3DBackpropFilterV2Attrs {\n strides: [number, number, number]|number;\n pad: 'valid'|'same';\n filterShape: [number, number, number, number, number];\n}\n\nexport const Conv3DBackpropInputV2 = 'Conv3DBackpropInputV2';\nexport type Conv3DBackpropInputV2Inputs =\n Pick;\nexport interface Conv3DBackpropInputV2Attrs {\n strides: [number, number, number]|number;\n pad: 'valid'|'same';\n inputShape: [number, number, number, number, number];\n}\n\nexport const Cos = 'Cos';\nexport type CosInputs = UnaryInputs;\n\nexport const Cosh = 'Cosh';\nexport type CoshInputs = UnaryInputs;\n\nexport const Cumsum = 'Cumsum';\nexport type CumsumInputs = Pick;\nexport interface CumsumAttrs {\n axis: number;\n exclusive: boolean;\n reverse: boolean;\n}\n\nexport const CropAndResize = 'CropAndResize';\nexport type CropAndResizeInputs =\n Pick;\nexport interface CropAndResizeAttrs {\n cropSize: [number, number];\n method: 'bilinear'|'nearest';\n extrapolationValue: number;\n}\n\nexport const DenseBincount = 'DenseBincount';\nexport type DenseBincountInputs = Pick;\nexport interface DenseBincountAttrs {\n size: number;\n binaryOutput?: boolean;\n}\n\nexport const DepthToSpace = 'DepthToSpace';\nexport type DepthToSpaceInputs = Pick;\nexport interface DepthToSpaceAttrs {\n blockSize: number;\n dataFormat: 'NHWC'|'NCHW';\n}\n\nexport const DepthwiseConv2dNative = 'DepthwiseConv2dNative';\nexport type DepthwiseConv2dNativeInputs =\n Pick;\nexport interface DepthwiseConv2dNativeAttrs {\n strides: [number, number]|number;\n pad: 'valid'|'same'|number|ExplicitPadding;\n dataFormat: 'NHWC'|'NCHW';\n dilations: [number, number]|number;\n dimRoundingMode?: 'floor'|'round'|'ceil';\n}\n\nexport const DepthwiseConv2dNativeBackpropFilter =\n 'DepthwiseConv2dNativeBackpropFilter';\nexport type DepthwiseConv2dNativeBackpropFilterInputs =\n Pick;\nexport interface DepthwiseConv2dNativeBackpropFilterAttrs {\n strides: [number, number]|number;\n dilations: [number, number]|number;\n pad: 'valid'|'same'|number|ExplicitPadding;\n dimRoundingMode?: 'floor'|'round'|'ceil';\n filterShape: [number, number, number, number];\n}\n\nexport const DepthwiseConv2dNativeBackpropInput =\n 'DepthwiseConv2dNativeBackpropInput';\nexport type DepthwiseConv2dNativeBackpropInputInputs =\n Pick;\nexport interface DepthwiseConv2dNativeBackpropInputAttrs {\n strides: [number, number]|number;\n dilations: [number, number]|number;\n pad: 'valid'|'same'|number|ExplicitPadding;\n dimRoundingMode?: 'floor'|'round'|'ceil';\n inputShape: [number, number, number, number];\n}\n\nexport const Diag = 'Diag';\nexport type DiagInputs = Pick;\n\nexport const Dilation2D = 'Dilation2D';\nexport type Dilation2DInputs = Pick;\nexport interface Dilation2DAttrs {\n strides: [number, number]|number;\n pad: 'valid'|'same'|number;\n dilations: [number, number]|number;\n}\n\nexport const Dilation2DBackpropInput = 'Dilation2DBackpropInput';\nexport type Dilation2DBackpropInputInputs =\n Pick;\n\nexport const Dilation2DBackpropFilter = 'Dilation2DBackpropFilter';\nexport type Dilation2DBackpropFilterInputs =\n Pick;\n\nexport const RealDiv = 'RealDiv';\nexport type RealDivInputs = BinaryInputs;\n\nexport const Einsum = 'Einsum';\nexport type EinsumInputs = TensorInfo[];\nexport interface EinsumAttrs {\n equation: string;\n}\n\nexport const Elu = 'Elu';\nexport type EluInputs = Pick;\n\nexport const EluGrad = 'EluGrad';\nexport type EluGradInputs = Pick;\n\nexport const Erf = 'Erf';\nexport type ErfInputs = UnaryInputs;\n\nexport const Equal = 'Equal';\nexport type EqualInputs = BinaryInputs;\n\nexport const Exp = 'Exp';\nexport type ExpInputs = UnaryInputs;\n\nexport const ExpandDims = 'ExpandDims';\nexport type ExpandDimsInputs = Pick;\nexport interface ExpandDimsAttrs {\n dim: number;\n}\n\nexport const Expm1 = 'Expm1';\nexport type Expm1Inputs = UnaryInputs;\n\nexport const FFT = 'FFT';\nexport type FFTInputs = Pick;\n\nexport const Fill = 'Fill';\nexport interface FillAttrs {\n shape: number[];\n value: number|string;\n dtype: DataType;\n}\n\nexport const FlipLeftRight = 'FlipLeftRight';\nexport type FlipLeftRightInputs = Pick;\n\nexport const Floor = 'Floor';\nexport type FloorInputs = UnaryInputs;\n\nexport const FloorDiv = 'FloorDiv';\nexport type FloorDivInputs = BinaryInputs;\n\nexport const FusedBatchNorm = 'FusedBatchNorm';\nexport type FusedBatchNormInputs =\n Pick;\nexport interface FusedBatchNormAttrs {\n varianceEpsilon: number;\n}\n\nexport const GatherV2 = 'GatherV2';\nexport type GatherV2Inputs = Pick;\nexport interface GatherV2Attrs {\n axis: number;\n batchDims: number;\n}\n\nexport const GatherNd = 'GatherNd';\nexport type GatherNdInputs = Pick;\n\nexport const Greater = 'Greater';\nexport type GreaterInputs = BinaryInputs;\n\nexport const GreaterEqual = 'GreaterEqual';\nexport type GreaterEqualInputs = BinaryInputs;\n\nexport const Identity = 'Identity';\nexport type IdentityInputs = Pick;\n\nexport const IFFT = 'IFFT';\nexport type IFFTInputs = Pick;\n\nexport const Imag = 'Imag';\nexport type ImagInputs = Pick;\n\nexport const IsFinite = 'IsFinite';\nexport type IsFiniteInputs = UnaryInputs;\n\nexport const IsInf = 'IsInf';\nexport type IsInfInputs = UnaryInputs;\n\nexport const IsNan = 'IsNan';\nexport type IsNanInputs = UnaryInputs;\n\nexport const LeakyRelu = 'LeakyRelu';\nexport type LeakyReluInputs = Pick;\nexport interface LeakyReluAttrs {\n alpha: number;\n}\n\nexport const Less = 'Less';\nexport type LessInputs = BinaryInputs;\n\nexport const LessEqual = 'LessEqual';\nexport type LessEqualInputs = BinaryInputs;\n\nexport const LinSpace = 'LinSpace';\nexport interface LinSpaceAttrs {\n start: number;\n stop: number;\n num: number;\n}\nexport const Log = 'Log';\nexport type LogInputs = UnaryInputs;\n\nexport const Log1p = 'Log1p';\nexport type Log1pInputs = UnaryInputs;\n\nexport const LogicalAnd = 'LogicalAnd';\nexport type LogicalAndInputs = BinaryInputs;\n\nexport const LogicalNot = 'LogicalNot';\nexport type LogicalNotInputs = Pick;\n\nexport const LogicalOr = 'LogicalOr';\nexport type LogicalOrInputs = BinaryInputs;\n\nexport const LogSoftmax = 'LogSoftmax';\nexport type LogSoftmaxInputs = Pick;\nexport interface LogSoftmaxAttrs {\n axis: number;\n}\n\nexport const LRN = 'LRN';\nexport type LRNInputs = Pick;\nexport interface LRNAttrs {\n depthRadius: number;\n bias: number;\n alpha: number;\n beta: number;\n}\n\nexport const LRNGrad = 'LRNGrad';\nexport type LRNGradInputs = Pick;\nexport interface LRNGradAttrs {\n depthRadius: number;\n bias: number;\n alpha: number;\n beta: number;\n}\n\nexport const Max = 'Max';\nexport type MaxInputs = Pick;\nexport interface MaxAttrs {\n reductionIndices: number|number[];\n keepDims: boolean;\n}\n\nexport const Maximum = 'Maximum';\nexport type MaximumInputs = BinaryInputs;\n\nexport const MaxPool = 'MaxPool';\nexport type MaxPoolInputs = Pick;\nexport interface MaxPoolAttrs {\n filterSize: [number, number]|number;\n strides: [number, number]|number;\n pad: 'valid'|'same'|number;\n dimRoundingMode?: 'floor'|'round'|'ceil';\n}\n\nexport const MaxPoolGrad = 'MaxPoolGrad';\nexport type MaxPoolGradInputs = Pick;\nexport interface MaxPoolGradAttrs {\n filterSize: [number, number]|number;\n strides: [number, number]|number;\n pad: 'valid'|'same'|number;\n dimRoundingMode?: 'floor'|'round'|'ceil';\n}\n\nexport const MaxPool3D = 'MaxPool3D';\nexport type MaxPool3DInputs = Pick;\nexport interface MaxPool3DAttrs {\n filterSize: [number, number, number]|number;\n strides: [number, number, number]|number;\n pad: 'valid'|'same'|number;\n dataFormat: 'NDHWC'|'NCDHW';\n dimRoundingMode?: 'floor'|'round'|'ceil';\n}\n\nexport const MaxPool3DGrad = 'MaxPool3DGrad';\nexport type MaxPool3DGradInputs =\n Pick;\nexport interface MaxPool3DGradAttrs {\n filterSize: [number, number, number]|number;\n strides: [number, number, number]|number;\n pad: 'valid'|'same'|number;\n dimRoundingMode?: 'floor'|'round'|'ceil';\n}\n\nexport const MaxPoolWithArgmax = 'MaxPoolWithArgmax';\nexport type MaxPoolWithArgmaxInputs = Pick;\nexport interface MaxPoolWithArgmaxAttrs {\n filterSize: [number, number]|number;\n strides: [number, number]|number;\n pad: 'valid'|'same'|number;\n includeBatchInIndex: boolean;\n}\n\nexport const Mean = 'Mean';\nexport type MeanInputs = Pick;\nexport interface MeanAttrs {\n axis: number|number[];\n keepDims: boolean;\n}\n\nexport const Min = 'Min';\nexport type MinInputs = Pick;\nexport interface MinAttrs {\n axis: number|number[];\n keepDims: boolean;\n}\n\nexport const Minimum = 'Minimum';\nexport type MinimumInputs = BinaryInputs;\n\nexport const MirrorPad = 'MirrorPad';\nexport type MirrorPadInputs = Pick;\nexport interface MirrorPadAttrs {\n paddings: Array<[number, number]>;\n mode: 'reflect'|'symmetric';\n}\n\nexport const Mod = 'Mod';\nexport type ModInputs = BinaryInputs;\n\nexport const Multinomial = 'Multinomial';\nexport type MultinomialInputs = Pick;\nexport interface MultinomialAttrs {\n numSamples: number;\n seed: number;\n normalized: boolean;\n}\n\nexport const Multiply = 'Multiply';\nexport type MultiplyInputs = BinaryInputs;\n\nexport const Neg = 'Neg';\nexport type NegInputs = UnaryInputs;\n\nexport const NotEqual = 'NotEqual';\nexport type NotEqualInputs = BinaryInputs;\n\nexport const NonMaxSuppressionV3 = 'NonMaxSuppressionV3';\nexport type NonMaxSuppressionV3Inputs =\n Pick;\nexport interface NonMaxSuppressionV3Attrs {\n maxOutputSize: number;\n iouThreshold: number;\n scoreThreshold: number;\n}\n\nexport const NonMaxSuppressionV4 = 'NonMaxSuppressionV4';\nexport type NonMaxSuppressionV4Inputs =\n Pick;\nexport interface NonMaxSuppressionV4Attrs {\n maxOutputSize: number;\n iouThreshold: number;\n scoreThreshold: number;\n padToMaxOutputSize: boolean;\n}\n\nexport const NonMaxSuppressionV5 = 'NonMaxSuppressionV5';\nexport type NonMaxSuppressionV5Inputs =\n Pick;\nexport interface NonMaxSuppressionV5Attrs {\n maxOutputSize: number;\n iouThreshold: number;\n scoreThreshold: number;\n softNmsSigma: number;\n}\n\nexport const OnesLike = 'OnesLike';\nexport type OnesLikeInputs = UnaryInputs;\n\nexport const OneHot = 'OneHot';\nexport type OneHotInputs = Pick;\nexport interface OneHotAttrs {\n depth: number;\n onValue: number;\n offValue: number;\n}\n\nexport const Pack = 'Pack';\nexport type PackInputs = TensorInfo[];\nexport interface PackAttrs {\n axis: number;\n}\n\nexport const PadV2 = 'PadV2';\nexport type PadV2Inputs = Pick;\nexport interface PadV2Attrs {\n paddings: Array<[number, number]>;\n constantValue: number;\n}\n\nexport const Pool = 'Pool';\nexport type PoolInputs = Pick;\n\nexport const Pow = 'Pow';\nexport type PowInputs = BinaryInputs;\n\nexport const Prelu = 'Prelu';\nexport type PreluInputs = Pick;\n\nexport const Prod = 'Prod';\nexport type ProdInputs = Pick;\nexport interface ProdAttrs {\n axis: number|number[];\n keepDims: boolean;\n}\n\nexport const Range = 'Range';\nexport interface RangeAttrs {\n start: number;\n stop: number;\n step: number;\n dtype: 'float32'|'int32';\n}\n\nexport const Real = 'Real';\nexport type RealInputs = Pick;\n\nexport const Reciprocal = 'Reciprocal';\nexport type ReciprocalInputs = UnaryInputs;\n\nexport const Relu = 'Relu';\nexport type ReluInputs = Pick;\n\nexport const Reshape = 'Reshape';\nexport type ReshapeInputs = Pick;\nexport interface ReshapeAttrs {\n shape: number[];\n}\n\nexport const ResizeNearestNeighbor = 'ResizeNearestNeighbor';\nexport type ResizeNearestNeighborInputs = Pick;\nexport interface ResizeNearestNeighborAttrs {\n alignCorners: boolean;\n halfPixelCenters: boolean;\n size: [number, number];\n}\n\nexport const ResizeNearestNeighborGrad = 'ResizeNearestNeighborGrad';\nexport type ResizeNearestNeighborGradInputs =\n Pick;\nexport type ResizeNearestNeighborGradAttrs = ResizeNearestNeighborAttrs;\n\nexport const ResizeBilinear = 'ResizeBilinear';\nexport type ResizeBilinearInputs = Pick;\nexport interface ResizeBilinearAttrs {\n alignCorners: boolean;\n halfPixelCenters: boolean;\n size: [number, number];\n}\n\nexport const ResizeBilinearGrad = 'ResizeBilinearGrad';\nexport type ResizeBilinearGradInputs = Pick;\nexport type ResizeBilinearGradAttrs = ResizeBilinearAttrs;\n\nexport const Relu6 = 'Relu6';\nexport type Relu6Inputs = Pick;\n\nexport const Reverse = 'Reverse';\nexport type ReverseInputs = Pick;\nexport interface ReverseAttrs {\n dims: number|number[];\n}\n\nexport const Round = 'Round';\nexport type RoundInputs = UnaryInputs;\n\nexport const Rsqrt = 'Rsqrt';\nexport type RsqrtInputs = UnaryInputs;\n\nexport const ScatterNd = 'ScatterNd';\nexport type ScatterNdInputs = Pick;\nexport interface ScatterNdAttrs {\n shape: number[];\n}\n\nexport const Select = 'Select';\nexport type SelectInputs = Pick;\n\nexport const Selu = 'Selu';\nexport type SeluInputs = Pick;\n\nexport const Slice = 'Slice';\nexport type SliceInputs = Pick;\nexport interface SliceAttrs {\n begin: number|number[];\n size: number|number[];\n}\nexport const Sin = 'Sin';\nexport type SinInputs = UnaryInputs;\n\nexport const Sinh = 'Sinh';\nexport type SinhInputs = UnaryInputs;\n\nexport const Sign = 'Sign';\nexport type SignInputs = UnaryInputs;\n\nexport const Sigmoid = 'Sigmoid';\nexport type SigmoidInputs = UnaryInputs;\n\nexport const Softplus = 'Softplus';\nexport type SoftplusInputs = UnaryInputs;\n\nexport const Sqrt = 'Sqrt';\nexport type SqrtInputs = UnaryInputs;\n\nexport const Sum = 'Sum';\nexport type SumInputs = Pick;\nexport interface SumAttrs {\n axis: number|number[];\n keepDims: boolean;\n}\n\nexport const SpaceToBatchND = 'SpaceToBatchND';\nexport type SpaceToBatchNDInputs = Pick;\nexport interface SpaceToBatchNDAttrs {\n blockShape: number[];\n paddings: number[][];\n}\n\nexport const SplitV = 'SplitV';\nexport type SplitVInputs = Pick;\nexport interface SplitVAttrs {\n numOrSizeSplits: number[]|number;\n axis: number;\n}\n\nexport const Softmax = 'Softmax';\nexport type SoftmaxInputs = Pick;\nexport interface SoftmaxAttrs {\n dim: number;\n}\n\nexport const SparseFillEmptyRows = 'SparseFillEmptyRows';\nexport type SparseFillEmptyRowsInputs =\n Pick;\n\nexport const SparseReshape = 'SparseReshape';\nexport type SparseReshapeInputs =\n Pick;\n\nexport const SparseToDense = 'SparseToDense';\nexport type SparseToDenseInputs =\n Pick;\nexport interface SparseToDenseAttrs {\n outputShape: number[];\n}\n\nexport const SquaredDifference = 'SquaredDifference';\nexport type SquaredDifferenceInputs = BinaryInputs;\n\nexport const Square = 'Square';\nexport type SquareInputs = Pick;\n\nexport const StridedSlice = 'StridedSlice';\nexport type StridedSliceInputs = Pick;\nexport interface StridedSliceAttrs {\n begin: number[];\n end: number[];\n strides: number[];\n beginMask: number;\n endMask: number;\n ellipsisMask: number;\n newAxisMask: number;\n shrinkAxisMask: number;\n}\n\nexport const Sub = 'Sub';\nexport type SubInputs = BinaryInputs;\n\nexport const Tan = 'Tan';\nexport type TanInputs = UnaryInputs;\n\nexport const Tanh = 'Tanh';\nexport type TanhInputs = UnaryInputs;\n\nexport const Tile = 'Tile';\nexport type TileInputs = Pick;\nexport interface TileAttrs {\n reps: number[];\n}\n\nexport const TopK = 'TopK';\nexport type TopKInputs = Pick;\nexport interface TopKAttrs {\n k: number;\n sorted: boolean;\n}\n\nexport const Transform = 'Transform';\nexport type TransformInputs = Pick;\nexport interface TransformAttrs {\n interpolation: 'nearest'|'bilinear';\n fillMode: 'constant'|'reflect'|'wrap'|'nearest';\n fillValue: number;\n outputShape?: [number, number];\n}\n\nexport const Transpose = 'Transpose';\nexport type TransposeInputs = Pick;\nexport interface TransposeAttrs {\n perm: number[];\n}\n\nexport const Unique = 'Unique';\nexport type UniqueInputs = Pick;\nexport interface UniqueAttrs {\n axis: number;\n}\n\nexport type UnaryInputs = Pick;\n\nexport const Unpack = 'Unpack';\nexport type UnpackInputs = Pick;\nexport interface UnpackAttrs {\n axis: number;\n}\n\nexport const UnsortedSegmentSum = 'UnsortedSegmentSum';\nexport type UnsortedSegmentSumInputs =\n Pick;\nexport interface UnsortedSegmentSumAttrs {\n numSegments: number;\n}\n\nexport const ZerosLike = 'ZerosLike';\nexport type ZerosLikeInputs = UnaryInputs;\n\n/**\n * TensorFlow.js-only kernels\n */\nexport const Step = 'Step';\nexport type StepInputs = UnaryInputs;\nexport interface StepAttrs {\n alpha: number;\n}\n\nexport const FromPixels = 'FromPixels';\nexport interface FromPixelsInputs {\n pixels: PixelData|ImageData|HTMLImageElement|HTMLCanvasElement|\n HTMLVideoElement|ImageBitmap;\n}\nexport interface FromPixelsAttrs {\n numChannels: number;\n}\n\nexport const RotateWithOffset = 'RotateWithOffset';\nexport type RotateWithOffsetInputs = Pick;\nexport interface RotateWithOffsetAttrs {\n radians: number;\n fillValue: number|[number, number, number];\n center: number|[number, number];\n}\n\nexport const _FusedMatMul = '_FusedMatMul';\n// tslint:disable-next-line: class-name\nexport interface _FusedMatMulInputs extends NamedTensorInfoMap {\n a: TensorInfo;\n b: TensorInfo;\n bias?: TensorInfo;\n preluActivationWeights?: TensorInfo;\n}\n// tslint:disable-next-line: class-name\nexport interface _FusedMatMulAttrs {\n transposeA: boolean;\n transposeB: boolean;\n activation: Activation;\n leakyreluAlpha?: number;\n}\n\nexport const FusedConv2D = 'FusedConv2D';\nexport interface FusedConv2DInputs extends NamedTensorInfoMap {\n x: TensorInfo;\n filter: TensorInfo;\n bias?: TensorInfo;\n preluActivationWeights?: TensorInfo;\n}\nexport interface FusedConv2DAttrs {\n strides: [number, number]|number;\n pad: 'valid'|'same'|number|ExplicitPadding;\n dataFormat: 'NHWC'|'NCHW';\n dilations: [number, number]|number;\n dimRoundingMode: 'floor'|'round'|'ceil';\n activation: Activation;\n leakyreluAlpha?: number;\n}\n\nexport const FusedDepthwiseConv2D = 'FusedDepthwiseConv2D';\nexport interface FusedDepthwiseConv2DInputs extends NamedTensorInfoMap {\n x: TensorInfo;\n filter: TensorInfo;\n bias?: TensorInfo;\n preluActivationWeights?: TensorInfo;\n}\nexport interface FusedDepthwiseConv2DAttrs {\n strides: [number, number]|number;\n pad: 'valid'|'same'|number|ExplicitPadding;\n dataFormat: 'NHWC'|'NCHW';\n dilations: [number, number]|number;\n dimRoundingMode: 'floor'|'round'|'ceil';\n activation: Activation;\n leakyreluAlpha?: number;\n}\n", "/**\n * @license\n * Copyright 2019 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\nimport {env} from './environment';\n\nimport {getGlobal} from './global_util';\nimport {NamedGradientMap} from './tape';\nimport {Tensor} from './tensor';\nimport {DataType, RecursiveArray} from './types';\n\nconst kernelRegistry =\n getGlobal('kernelRegistry', () => new Map());\nconst gradRegistry =\n getGlobal('gradRegistry', () => new Map());\n\nexport type DataId = object;\n\ntype AttributeValue =\n number|number[]|boolean|boolean[]|string|string[]|NamedAttrMap;\n\n/** These are extra non-tensor/primitive params passed to kernel functions. */\nexport type Attribute = AttributeValue|RecursiveArray;\n\n/** Specifies the code to run when executing a kernel. */\nexport type KernelFunc = (params: {\n inputs: NamedTensorInfoMap,\n backend: {},\n attrs?: NamedAttrMap,\n}) => TensorInfo|TensorInfo[];\n\n/** The function to run when computing a gradient during backprop. */\nexport type GradFunc =\n (dy: Tensor|Tensor[], saved: Tensor[], attrs: NamedAttrMap) =>\n NamedGradientMap;\n\n/** Function that gets called after the backend initializes. */\nexport type KernelSetupFunc = (backend: {}) => void;\n/** Function that gets called right before the backend is disposed. */\nexport type KernelDisposeFunc = KernelSetupFunc;\n\n/** Config object for registering a kernel in the global registry. */\nexport interface KernelConfig {\n kernelName: string;\n backendName: string;\n kernelFunc: KernelFunc;\n setupFunc?: KernelSetupFunc;\n disposeFunc?: KernelDisposeFunc;\n}\n\n/** Config object for registering a gradient in the global registry. */\nexport interface GradConfig {\n kernelName: string;\n inputsToSave?: string[];\n // When saveAllInputs is true, all inputs will be saved. Only use this flag\n // if inputs is an array of Tensors.\n saveAllInputs?: boolean;\n outputsToSave?: boolean[];\n gradFunc: GradFunc;\n}\n\n/** Holds metadata for a given tensor. */\nexport interface TensorInfo {\n dataId: DataId;\n shape: number[];\n dtype: DataType;\n}\n\nexport interface NamedTensorInfoMap {\n [name: string]: TensorInfo;\n}\n\nexport interface NamedAttrMap {\n [name: string]: Attribute;\n}\n\n/**\n * Returns the kernel function (code) associated with the provided names.\n *\n * @param kernelName The official name of the kernel.\n * @param backendName The official name of the backend.\n */\nexport function getKernel(\n kernelName: string, backendName: string): KernelConfig {\n const key = makeKey(kernelName, backendName);\n return kernelRegistry.get(key);\n}\n\n/**\n * Returns the registered gradient info associated with the provided kernel.\n * @param kernelName The official TF kernel name.\n */\nexport function getGradient(kernelName: string): GradConfig {\n return gradRegistry.get(kernelName);\n}\n\nexport function getKernelsForBackend(backendName: string): KernelConfig[] {\n const it = kernelRegistry.entries();\n const result: KernelConfig[] = [];\n\n while (true) {\n const {done, value} = it.next();\n if (done) {\n break;\n }\n const [key, config] = value;\n const [backend, ] = key.split('_');\n if (backend === backendName) {\n result.push(config);\n }\n }\n return result;\n}\n\n/**\n * Registers the function (forward pass) for the kernel in a global registry.\n *\n * @param config A config object with the following properties:\n * - `kernelName` The official name of the kernel.\n * - `backendName` The official name of the backend.\n * - `kernelFunc` The function to run during the forward pass of the kernel.\n * - `setupFunc` Optional. Gets called once, after the backend initializes.\n * - `disposeFunc` Optional. Gets called once, right before the backend is\n * disposed.\n */\nexport function registerKernel(config: KernelConfig) {\n const {kernelName, backendName} = config;\n const key = makeKey(kernelName, backendName);\n if (kernelRegistry.has(key)) {\n console.warn(\n `The kernel '${kernelName}' for backend ` +\n `'${backendName}' is already registered`);\n }\n kernelRegistry.set(key, config);\n}\n\n/**\n * Registers a gradient function for a given kernel in the global registry,\n * to be used during the back-propagation of that kernel.\n *\n * @param config An object with the following properties:\n * - `kernelName` The name of the kernel that the gradient function is for.\n * - `gradFunc` The function to run during back-propagation.\n */\nexport function registerGradient(config: GradConfig) {\n const {kernelName} = config;\n\n if (gradRegistry.has(kernelName)) {\n // TODO (yassogba) after 3.0 assess whether we need to keep this gated\n // to debug mode.\n if (env().getBool('DEBUG')) {\n console.warn(`Overriding the gradient for '${kernelName}'`);\n }\n }\n gradRegistry.set(kernelName, config);\n}\n\n/**\n * Removes the kernel function from the registry.\n *\n * @param kernelName The official name of the kernel.\n * @param backendName The official name of the backend.\n *\n */\nexport function unregisterKernel(\n kernelName: string, backendName: string): void {\n const key = makeKey(kernelName, backendName);\n if (!kernelRegistry.has(key)) {\n throw new Error(\n `The kernel '${kernelName}' for backend ` +\n `'${backendName}' is not registered`);\n }\n kernelRegistry.delete(key);\n}\n\n/** Removes the registered gradient from the global registry. */\nexport function unregisterGradient(kernelName: string): void {\n if (!gradRegistry.has(kernelName)) {\n throw new Error(\n `The gradient '${kernelName}' for backend is not registered`);\n }\n gradRegistry.delete(kernelName);\n}\n\n/**\n * Finds kernels that have already been registered to a backend and re-registers\n * them for a new backend. Useful for registering custom backends.\n * @param registeredBackendName Already registered backend.\n * @param newBackendName New backend.\n */\nexport function copyRegisteredKernels(\n registeredBackendName: string, newBackendName: string): void {\n const kernels = getKernelsForBackend(registeredBackendName);\n kernels.forEach(kernelConfig => {\n const newKernelConfig =\n Object.assign({}, kernelConfig, {backendName: newBackendName});\n registerKernel(newKernelConfig);\n });\n}\n\nfunction makeKey(kernelName: string, backendName: string) {\n return `${backendName}_${kernelName}`;\n}\n", "/**\n * @license\n * Copyright 2017 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {env} from './environment';\nimport {BackendValues, DataType, TensorLike, TypedArray} from './types';\nimport * as base from './util_base';\nexport * from './util_base';\n\n/**\n * Create typed array for scalar value. Used for storing in `DataStorage`.\n */\nexport function createScalarValue(\n value: DataType, dtype: DataType): BackendValues {\n if (dtype === 'string') {\n return encodeString(value);\n }\n\n return toTypedArray([value], dtype);\n}\n\nfunction noConversionNeeded(a: TensorLike, dtype: DataType): boolean {\n return (a instanceof Float32Array && dtype === 'float32') ||\n (a instanceof Int32Array && dtype === 'int32') ||\n (a instanceof Uint8Array && dtype === 'bool');\n}\n\nexport function toTypedArray(a: TensorLike, dtype: DataType): TypedArray {\n if (dtype === 'string') {\n throw new Error('Cannot convert a string[] to a TypedArray');\n }\n if (Array.isArray(a)) {\n a = base.flatten(a);\n }\n\n if (env().getBool('DEBUG')) {\n base.checkConversionForErrors(a as number[], dtype);\n }\n if (noConversionNeeded(a, dtype)) {\n return a as TypedArray;\n }\n if (dtype == null || dtype === 'float32' || dtype === 'complex64') {\n return new Float32Array(a as number[]);\n } else if (dtype === 'int32') {\n return new Int32Array(a as number[]);\n } else if (dtype === 'bool') {\n const bool = new Uint8Array((a as number[]).length);\n for (let i = 0; i < bool.length; ++i) {\n if (Math.round((a as number[])[i]) !== 0) {\n bool[i] = 1;\n }\n }\n return bool;\n } else {\n throw new Error(`Unknown data type ${dtype}`);\n }\n}\n\n/**\n * Returns the current high-resolution time in milliseconds relative to an\n * arbitrary time in the past. It works across different platforms (node.js,\n * browsers).\n *\n * ```js\n * console.log(tf.util.now());\n * ```\n *\n * @doc {heading: 'Util', namespace: 'util'}\n */\nexport function now(): number {\n return env().platform.now();\n}\n\n/**\n * Returns a platform-specific implementation of\n * [`fetch`](https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API).\n *\n * If `fetch` is defined on the global object (`window`, `process`, etc.),\n * `tf.util.fetch` returns that function.\n *\n * If not, `tf.util.fetch` returns a platform-specific solution.\n *\n * ```js\n * const resource = await tf.util.fetch('https://unpkg.com/@tensorflow/tfjs');\n * // handle response\n * ```\n *\n * @doc {heading: 'Util'}\n */\nexport function fetch(\n path: string, requestInits?: RequestInit): Promise {\n return env().platform.fetch(path, requestInits);\n}\n\n/**\n * Encodes the provided string into bytes using the provided encoding scheme.\n *\n * @param s The string to encode.\n * @param encoding The encoding scheme. Defaults to utf-8.\n *\n * @doc {heading: 'Util'}\n */\nexport function encodeString(s: string, encoding = 'utf-8'): Uint8Array {\n encoding = encoding || 'utf-8';\n return env().platform.encode(s, encoding);\n}\n\n/**\n * Decodes the provided bytes into a string using the provided encoding scheme.\n * @param bytes The bytes to decode.\n *\n * @param encoding The encoding scheme. Defaults to utf-8.\n *\n * @doc {heading: 'Util'}\n */\nexport function decodeString(bytes: Uint8Array, encoding = 'utf-8'): string {\n encoding = encoding || 'utf-8';\n return env().platform.decode(bytes, encoding);\n}\n", "/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {BackendTimer, BackendTimingInfo} from './backends/backend';\nimport {env} from './environment';\nimport {Tensor} from './tensor';\nimport {NamedTensorMap} from './tensor_types';\nimport {DataType, DataTypeMap, TypedArray} from './types';\nimport * as util from './util';\n\nexport type KernelProfile = {\n kernelName: string,\n outputs: Tensor[],\n inputs: NamedTensorMap,\n timeMs: Promise,\n extraInfo: Promise\n};\n\nexport class Profiler {\n constructor(private backendTimer: BackendTimer, private logger?: Logger) {\n if (logger == null) {\n this.logger = new Logger();\n }\n }\n\n profileKernel(kernelName: string, inputs: NamedTensorMap, f: () => Tensor[]):\n KernelProfile {\n let outputs: Tensor[];\n const holdResultWrapperFn = () => {\n outputs = f();\n };\n let timer: Promise;\n const start = util.now();\n if (this.backendTimer.timerAvailable()) {\n timer = this.backendTimer.time(holdResultWrapperFn);\n } else {\n holdResultWrapperFn();\n for (const output of outputs) {\n output.dataSync();\n }\n timer = Promise.resolve({kernelMs: util.now() - start});\n }\n if (env().getBool('CHECK_COMPUTATION_FOR_ERRORS')) {\n for (let i = 0; i < outputs.length; i++) {\n const output = outputs[i];\n // Dangling promise here because we don't want to propagate up\n // asynchronicity.\n output.data().then(tensorVals => {\n checkComputationForErrors(tensorVals, output.dtype, kernelName);\n });\n }\n }\n\n const kernelProfile = {\n kernelName,\n outputs,\n inputs,\n timeMs: timer.then(timing => timing.kernelMs),\n extraInfo: timer.then(\n timing => timing.getExtraProfileInfo != null ?\n timing.getExtraProfileInfo() :\n '')\n };\n return kernelProfile;\n }\n\n logKernelProfile(kernelProfile: KernelProfile): void {\n const {kernelName, outputs, timeMs, inputs, extraInfo} = kernelProfile;\n\n outputs.forEach(result => {\n Promise.all([result.data(), timeMs, extraInfo]).then(valueContainer => {\n this.logger.logKernelProfile(\n kernelName, result, valueContainer[0], valueContainer[1], inputs,\n valueContainer[2]);\n });\n });\n }\n}\n\nexport function checkComputationForErrors(\n vals: DataTypeMap[D], dtype: D, kernelName: string): boolean {\n if (dtype !== 'float32') {\n // Only floating point computations will generate NaN values\n return false;\n }\n for (let i = 0; i < vals.length; i++) {\n const num = vals[i] as number;\n if (isNaN(num) || !isFinite(num)) {\n // Throwing custom exception so behavior is testable.\n console.warn(`Found ${num} in the result of '${kernelName}'`);\n return true;\n }\n }\n return false;\n}\n\nexport class Logger {\n logKernelProfile(\n name: string, result: Tensor, vals: TypedArray,\n timeMs: number|{error: string}, inputs: NamedTensorMap,\n extraInfo?: string) {\n const time = typeof timeMs === 'number' ? util.rightPad(`${timeMs}ms`, 9) :\n timeMs['error'];\n const paddedName = util.rightPad(name, 25);\n const rank = result.rank;\n const size = result.size;\n const shape = util.rightPad(result.shape.toString(), 14);\n let inputShapesDescription = '';\n\n for (const name in inputs) {\n const input = inputs[name];\n if (input != null) {\n // The input might be a non-tensor (e.g HTMLImageElement), in which case\n // we claim the output shape as input shape.\n const inputShape = input.shape || result.shape;\n const inputRank = inputShape.length;\n inputShapesDescription +=\n `${name}: ${inputRank}D ${inputRank > 0 ? inputShape : ''} `;\n }\n }\n\n console.log(\n `%c${paddedName}\\t%c${time}\\t%c${rank}D ${shape}\\t%c${size}\\t%c${\n inputShapesDescription}\\t%c${extraInfo}`,\n 'font-weight:bold', 'color:red', 'color:blue', 'color: orange',\n 'color: green', 'color: steelblue');\n }\n}\n", "/**\n * @license\n * Copyright 2017 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor} from './tensor';\nimport {NamedTensorMap} from './tensor_types';\nimport * as util from './util';\n\nexport interface TapeNode {\n id: number;\n kernelName: string;\n outputs: Tensor[];\n inputs: NamedTensorMap;\n // Optional params, defined only for ops with gradient impl.\n gradient?: (dys: Tensor[]) => NamedGradientMap;\n saved?: Tensor[];\n}\n\nexport type NamedGradientMap = {\n [inputName: string]: () => Tensor;\n};\n\n/**\n * Computes a list of TapeNodes that connect x to y, filtering everything else\n * out and preserving the order of the original tape elements.\n *\n * @param tape The tape elements to filter.\n * @param xs The input Tensors.\n * @param y The output Tensor.\n */\nexport function getFilteredNodesXToY(\n tape: TapeNode[], xs: Tensor[], y: Tensor): TapeNode[] {\n // Forward pass to compute all the nodes and Tensors that are transitively a\n // function of x.\n const tensorsFromX: {[tensorId: number]: boolean} = {};\n const nodesFromX: {[nodeId: number]: boolean} = {};\n for (let i = 0; i < xs.length; i++) {\n tensorsFromX[xs[i].id] = true;\n }\n\n for (let i = 0; i < tape.length; i++) {\n const node = tape[i];\n const nodeInputs = node.inputs;\n for (const inputName in nodeInputs) {\n const input = nodeInputs[inputName];\n\n let anyInputFromX = false;\n for (let j = 0; j < xs.length; j++) {\n if (tensorsFromX[input.id]) {\n node.outputs.forEach(output => tensorsFromX[output.id] = true);\n anyInputFromX = true;\n nodesFromX[node.id] = true;\n break;\n }\n }\n\n if (anyInputFromX) {\n break;\n }\n }\n }\n\n // Backward pass to find all of the nodes and Tensors that lead to y.\n const tensorsLeadToY: {[tensorId: number]: boolean} = {};\n tensorsLeadToY[y.id] = true;\n const nodesToY: {[nodeId: number]: boolean} = {};\n\n for (let i = tape.length - 1; i >= 0; i--) {\n const node = tape[i];\n const nodeInputs = node.inputs;\n\n // If any of the outputs lead to y, mark all of the inputs as leading to y.\n for (let j = 0; j < node.outputs.length; j++) {\n if (tensorsLeadToY[node.outputs[j].id]) {\n for (const inputName in nodeInputs) {\n tensorsLeadToY[nodeInputs[inputName].id] = true;\n nodesToY[node.id] = true;\n }\n break;\n }\n }\n }\n\n // Return the paths that come from x and lead to y.\n const filteredTape: TapeNode[] = [];\n for (let i = 0; i < tape.length; i++) {\n const node = tape[i];\n\n if (nodesFromX[node.id] && nodesToY[node.id]) {\n // Prune the inputs from the node that aren't a function of x.\n const prunedInputs: {[inputName: string]: Tensor} = {};\n for (const inputName in node.inputs) {\n const nodeInput = node.inputs[inputName];\n if (tensorsFromX[nodeInput.id]) {\n prunedInputs[inputName] = nodeInput;\n }\n }\n\n // Copy the node and overwrite inputsAndArgs to the pruned version.\n const prunedNode = Object.assign({}, node);\n prunedNode.inputs = prunedInputs;\n prunedNode.outputs = node.outputs;\n\n filteredTape.push(prunedNode);\n }\n }\n\n return filteredTape;\n}\n\n/**\n * Backpropagate gradients through the filtered TapeNodes.\n *\n * @param tensorAccumulatedGradientMap A map of Tensor to its gradient. This map\n * is mutated by this method.\n * @param filteredTape The filtered TapeNodes to backprop through.\n */\nexport function backpropagateGradients(\n tensorAccumulatedGradientMap: {[tensorId: number]: Tensor},\n filteredTape: TapeNode[], tidy: (f: Function) => Tensor,\n add: (a: Tensor, b: Tensor) => Tensor) {\n // Walk the tape backward and keep a map of Tensor to its gradient.\n for (let i = filteredTape.length - 1; i >= 0; i--) {\n const node = filteredTape[i];\n\n const dys: Tensor[] = [];\n node.outputs.forEach(o => {\n const gradTensor = tensorAccumulatedGradientMap[o.id];\n if (gradTensor != null) {\n dys.push(gradTensor);\n } else {\n // This particular output is not in the back-propagation subgraph, so it\n // does not affect the final output, thus we put null for its dy.\n dys.push(null);\n }\n });\n\n if (node.gradient == null) {\n throw new Error(\n `Cannot compute gradient: gradient function not found ` +\n `for ${node.kernelName}.`);\n }\n\n // Backprop dy through this node and accumulate gradients over the inputs.\n const inputGradients = node.gradient(dys);\n\n for (const inputName in node.inputs) {\n if (!(inputName in inputGradients)) {\n throw new Error(\n `Cannot backprop through input ${inputName}. ` +\n `Available gradients found: ${Object.keys(inputGradients)}.`);\n }\n\n // Call the gradient function.\n const dx = tidy(() => inputGradients[inputName]());\n if (dx.dtype !== 'float32') {\n throw new Error(\n `Error in gradient for op ${\n node.kernelName}. The gradient of input ` +\n `${inputName} must have 'float32' dtype, but has '${dx.dtype}'`);\n }\n const x = node.inputs[inputName];\n if (!util.arraysEqual(dx.shape, x.shape)) {\n throw new Error(\n `Error in gradient for op ${\n node.kernelName}. The gradient of input ` +\n `'${inputName}' has shape '${dx.shape}', which does not match ` +\n `the shape of the input '${x.shape}'`);\n }\n\n if (tensorAccumulatedGradientMap[x.id] == null) {\n tensorAccumulatedGradientMap[x.id] = dx;\n } else {\n const curGradient = tensorAccumulatedGradientMap[x.id];\n tensorAccumulatedGradientMap[x.id] = add(curGradient, dx);\n curGradient.dispose();\n }\n }\n }\n}\n", "/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {DataType, TypedArray} from './types';\nimport {computeStrides, isString, rightPad, sizeFromShape} from './util';\n\n// Maximum number of values before we decide to show ellipsis.\nconst FORMAT_LIMIT_NUM_VALS = 20;\n// Number of first and last values to show when displaying a, b,...,y, z.\nconst FORMAT_NUM_FIRST_LAST_VALS = 3;\n// Number of significant digits to show.\nconst FORMAT_NUM_SIG_DIGITS = 7;\n\nexport function tensorToString(\n vals: TypedArray|string[], shape: number[], dtype: DataType,\n verbose: boolean) {\n const strides = computeStrides(shape);\n const padPerCol = computeMaxSizePerColumn(vals, shape, dtype, strides);\n const rank = shape.length;\n const valsLines = subTensorToString(vals, shape, dtype, strides, padPerCol);\n const lines = ['Tensor'];\n if (verbose) {\n lines.push(` dtype: ${dtype}`);\n lines.push(` rank: ${rank}`);\n lines.push(` shape: [${shape}]`);\n lines.push(` values:`);\n }\n lines.push(valsLines.map(l => ' ' + l).join('\\n'));\n return lines.join('\\n');\n}\n\nfunction computeMaxSizePerColumn(\n vals: TypedArray|string[], shape: number[], dtype: DataType,\n strides: number[]): number[] {\n const n = sizeFromShape(shape);\n const numCols = strides[strides.length - 1];\n const padPerCol = new Array(numCols).fill(0);\n const rank = shape.length;\n const valuesOrTuples =\n dtype === 'complex64' ? createComplexTuples(vals) : vals;\n\n if (rank > 1) {\n for (let row = 0; row < n / numCols; row++) {\n const offset = row * numCols;\n for (let j = 0; j < numCols; j++) {\n padPerCol[j] = Math.max(\n padPerCol[j],\n valToString(valuesOrTuples[offset + j], 0, dtype).length);\n }\n }\n }\n return padPerCol;\n}\n\nfunction valToString(\n val: number|string|[number, number], pad: number, dtype: DataType) {\n let valStr: string;\n if (Array.isArray(val)) {\n valStr = `${parseFloat(val[0].toFixed(FORMAT_NUM_SIG_DIGITS))} + ` +\n `${parseFloat(val[1].toFixed(FORMAT_NUM_SIG_DIGITS))}j`;\n } else if (isString(val)) {\n valStr = `'${val}'`;\n } else if (dtype === 'bool') {\n valStr = boolNumToString(val);\n } else {\n valStr = parseFloat(val.toFixed(FORMAT_NUM_SIG_DIGITS)).toString();\n }\n\n return rightPad(valStr, pad);\n}\n\nfunction boolNumToString(v: number): string {\n return v === 0 ? 'false' : 'true';\n}\n\nfunction subTensorToString(\n vals: TypedArray|string[], shape: number[], dtype: DataType,\n strides: number[], padPerCol: number[], isLast = true): string[] {\n const storagePerElement = dtype === 'complex64' ? 2 : 1;\n\n const size = shape[0];\n const rank = shape.length;\n if (rank === 0) {\n if (dtype === 'complex64') {\n const complexTuple = createComplexTuples(vals);\n return [valToString(complexTuple[0], 0, dtype)];\n }\n if (dtype === 'bool') {\n return [boolNumToString(vals[0] as number)];\n }\n return [vals[0].toString()];\n }\n\n if (rank === 1) {\n if (size > FORMAT_LIMIT_NUM_VALS) {\n const firstValsSize = FORMAT_NUM_FIRST_LAST_VALS * storagePerElement;\n\n let firstVals = Array.from(\n vals.slice(0, firstValsSize));\n let lastVals = Array.from(vals.slice(\n (size - FORMAT_NUM_FIRST_LAST_VALS) * storagePerElement,\n size * storagePerElement));\n if (dtype === 'complex64') {\n firstVals = createComplexTuples(firstVals);\n lastVals = createComplexTuples(lastVals);\n }\n return [\n '[' +\n firstVals.map((x, i) => valToString(x, padPerCol[i], dtype))\n .join(', ') +\n ', ..., ' +\n lastVals\n .map(\n (x, i) => valToString(\n x, padPerCol[size - FORMAT_NUM_FIRST_LAST_VALS + i], dtype))\n .join(', ') +\n ']'\n ];\n }\n const displayVals: Array =\n dtype === 'complex64' ? createComplexTuples(vals) :\n Array.from(vals);\n\n return [\n '[' +\n displayVals.map((x, i) => valToString(x, padPerCol[i], dtype))\n .join(', ') +\n ']'\n ];\n }\n\n // The array is rank 2 or more.\n const subshape = shape.slice(1);\n const substrides = strides.slice(1);\n const stride = strides[0] * storagePerElement;\n const lines: string[] = [];\n if (size > FORMAT_LIMIT_NUM_VALS) {\n for (let i = 0; i < FORMAT_NUM_FIRST_LAST_VALS; i++) {\n const start = i * stride;\n const end = start + stride;\n lines.push(...subTensorToString(\n vals.slice(start, end), subshape, dtype, substrides, padPerCol,\n false /* isLast */));\n }\n lines.push('...');\n for (let i = size - FORMAT_NUM_FIRST_LAST_VALS; i < size; i++) {\n const start = i * stride;\n const end = start + stride;\n lines.push(...subTensorToString(\n vals.slice(start, end), subshape, dtype, substrides, padPerCol,\n i === size - 1 /* isLast */));\n }\n } else {\n for (let i = 0; i < size; i++) {\n const start = i * stride;\n const end = start + stride;\n lines.push(...subTensorToString(\n vals.slice(start, end), subshape, dtype, substrides, padPerCol,\n i === size - 1 /* isLast */));\n }\n }\n const sep = rank === 2 ? ',' : '';\n lines[0] = '[' + lines[0] + sep;\n for (let i = 1; i < lines.length - 1; i++) {\n lines[i] = ' ' + lines[i] + sep;\n }\n let newLineSep = ',\\n';\n for (let i = 2; i < rank; i++) {\n newLineSep += '\\n';\n }\n lines[lines.length - 1] =\n ' ' + lines[lines.length - 1] + ']' + (isLast ? '' : newLineSep);\n return lines;\n}\n\nfunction createComplexTuples(vals: Array<{}>|\n TypedArray): Array<[number, number]> {\n const complexTuples: Array<[number, number]> = [];\n for (let i = 0; i < vals.length; i += 2) {\n complexTuples.push([vals[i], vals[i + 1]] as [number, number]);\n }\n return complexTuples;\n}\n", "/**\n * @license\n * Copyright 2017 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {getGlobal} from './global_util';\nimport {tensorToString} from './tensor_format';\nimport {ArrayMap, BackendValues, DataType, DataTypeMap, DataValues, NumericDataType, Rank, ShapeMap, SingleValueMap, TypedArray} from './types';\nimport * as util from './util';\nimport {computeStrides, toNestedArray} from './util';\n\nexport interface TensorData {\n dataId?: DataId;\n values?: DataTypeMap[D];\n}\n\n// This interface mimics KernelBackend (in backend.ts), which would create a\n// circular dependency if imported.\nexport interface Backend {}\n\n/**\n * A mutable object, similar to `tf.Tensor`, that allows users to set values\n * at locations before converting to an immutable `tf.Tensor`.\n *\n * See `tf.buffer` for creating a tensor buffer.\n *\n * @doc {heading: 'Tensors', subheading: 'Classes'}\n */\nexport class TensorBuffer {\n size: number;\n shape: ShapeMap[R];\n strides: number[];\n values: DataTypeMap[D];\n\n constructor(shape: ShapeMap[R], public dtype: D, values?: DataTypeMap[D]) {\n this.shape = shape.slice() as ShapeMap[R];\n this.size = util.sizeFromShape(shape);\n\n if (values != null) {\n const n = values.length;\n util.assert(\n n === this.size,\n () => `Length of values '${n}' does not match the size ` +\n `inferred by the shape '${this.size}'.`);\n }\n if (dtype === 'complex64') {\n throw new Error(\n `complex64 dtype TensorBuffers are not supported. Please create ` +\n `a TensorBuffer for the real and imaginary parts separately and ` +\n `call tf.complex(real, imag).`);\n }\n this.values = values || util.getArrayFromDType(dtype, this.size);\n this.strides = computeStrides(shape);\n }\n\n /**\n * Sets a value in the buffer at a given location.\n *\n * @param value The value to set.\n * @param locs The location indices.\n *\n * @doc {heading: 'Tensors', subheading: 'Creation'}\n */\n set(value: SingleValueMap[D], ...locs: number[]): void {\n if (locs.length === 0) {\n locs = [0];\n }\n util.assert(\n locs.length === this.rank,\n () => `The number of provided coordinates (${locs.length}) must ` +\n `match the rank (${this.rank})`);\n\n const index = this.locToIndex(locs);\n this.values[index] = value as number;\n }\n\n /**\n * Returns the value in the buffer at the provided location.\n *\n * @param locs The location indices.\n *\n * @doc {heading: 'Tensors', subheading: 'Creation'}\n */\n get(...locs: number[]): SingleValueMap[D] {\n if (locs.length === 0) {\n locs = [0];\n }\n let i = 0;\n for (const loc of locs) {\n if (loc < 0 || loc >= this.shape[i]) {\n const msg = `Requested out of range element at ${locs}. ` +\n ` Buffer shape=${this.shape}`;\n throw new Error(msg);\n }\n i++;\n }\n let index = locs[locs.length - 1];\n for (let i = 0; i < locs.length - 1; ++i) {\n index += this.strides[i] * locs[i];\n }\n return this.values[index] as SingleValueMap[D];\n }\n\n locToIndex(locs: number[]): number {\n if (this.rank === 0) {\n return 0;\n } else if (this.rank === 1) {\n return locs[0];\n }\n let index = locs[locs.length - 1];\n for (let i = 0; i < locs.length - 1; ++i) {\n index += this.strides[i] * locs[i];\n }\n return index;\n }\n\n indexToLoc(index: number): number[] {\n if (this.rank === 0) {\n return [];\n } else if (this.rank === 1) {\n return [index];\n }\n const locs: number[] = new Array(this.shape.length);\n for (let i = 0; i < locs.length - 1; ++i) {\n locs[i] = Math.floor(index / this.strides[i]);\n index -= locs[i] * this.strides[i];\n }\n locs[locs.length - 1] = index;\n return locs;\n }\n\n get rank() {\n return this.shape.length;\n }\n\n /**\n * Creates an immutable `tf.Tensor` object from the buffer.\n *\n * @doc {heading: 'Tensors', subheading: 'Creation'}\n */\n toTensor(): Tensor {\n return trackerFn().makeTensor(this.values, this.shape, this.dtype) as\n Tensor;\n }\n}\n\nexport interface TensorTracker {\n makeTensor(\n values: DataValues, shape: number[], dtype: DataType,\n backend?: Backend): Tensor;\n makeVariable(\n initialValue: Tensor, trainable?: boolean, name?: string,\n dtype?: DataType): Variable;\n incRef(a: Tensor, backend: Backend): void;\n disposeTensor(t: Tensor): void;\n disposeVariable(v: Variable): void;\n read(dataId: DataId): Promise;\n readSync(dataId: DataId): BackendValues;\n}\n\n/**\n * The Tensor class calls into this handler to delegate chaining operations.\n */\nexport interface OpHandler {\n cast(x: T, dtype: DataType): T;\n buffer(\n shape: ShapeMap[R], dtype: D,\n values?: DataTypeMap[D]): TensorBuffer;\n print(x: T, verbose: boolean): void;\n clone(x: T): T;\n // TODO(yassogba) bring reshape back?\n}\n\n// For tracking tensor creation and disposal.\nlet trackerFn: () => TensorTracker = null;\n// Used by chaining methods to call into ops.\nlet opHandler: OpHandler = null;\n// Used to warn about deprecated methods.\nlet deprecationWarningFn: (msg: string) => void = null;\n// This here so that we can use this method on dev branches and keep the\n// functionality at master.\n// tslint:disable-next-line:no-unused-expression\n[deprecationWarningFn];\n\n/**\n * An external consumer can register itself as the tensor tracker. This way\n * the Tensor class can notify the tracker for every tensor created and\n * disposed.\n */\nexport function setTensorTracker(fn: () => TensorTracker) {\n trackerFn = fn;\n}\n\n/**\n * An external consumer can register itself as the op handler. This way the\n * Tensor class can have chaining methods that call into ops via the op\n * handler.\n */\nexport function setOpHandler(handler: OpHandler) {\n opHandler = handler;\n}\n\n/**\n * Sets the deprecation warning function to be used by this file. This way the\n * Tensor class can be a leaf but still use the environment.\n */\nexport function setDeprecationWarningFn(fn: (msg: string) => void) {\n deprecationWarningFn = fn;\n}\n\n/**\n * We wrap data id since we use weak map to avoid memory leaks.\n * Since we have our own memory management, we have a reference counter\n * mapping a tensor to its data, so there is always a pointer (even if that\n * data is otherwise garbage collectable).\n * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/\n * Global_Objects/WeakMap\n */\nexport type DataId = object; // object instead of {} to force non-primitive.\n\n// Declare this namespace to make Tensor class augmentation work in google3.\nexport declare namespace Tensor {}\n/**\n * A `tf.Tensor` object represents an immutable, multidimensional array of\n * numbers that has a shape and a data type.\n *\n * For performance reasons, functions that create tensors do not necessarily\n * perform a copy of the data passed to them (e.g. if the data is passed as a\n * `Float32Array`), and changes to the data will change the tensor. This is not\n * a feature and is not supported. To avoid this behavior, use the tensor before\n * changing the input data or create a copy with `copy = tf.add(yourTensor, 0)`.\n *\n * See `tf.tensor` for details on how to create a `tf.Tensor`.\n *\n * @doc {heading: 'Tensors', subheading: 'Classes'}\n */\nexport class Tensor {\n /** Unique id of this tensor. */\n readonly id: number;\n /**\n * Id of the bucket holding the data for this tensor. Multiple arrays can\n * point to the same bucket (e.g. when calling array.reshape()).\n */\n dataId: DataId;\n /** The shape of the tensor. */\n readonly shape: ShapeMap[R];\n /** Number of elements in the tensor. */\n readonly size: number;\n /** The data type for the array. */\n readonly dtype: DataType;\n /** The rank type for the array (see `Rank` enum). */\n readonly rankType: R;\n\n /** Whether this tensor has been globally kept. */\n kept = false;\n /** The id of the scope this tensor is being tracked in. */\n scopeId: number;\n\n /**\n * Number of elements to skip in each dimension when indexing. See\n * https://docs.scipy.org/doc/numpy/reference/generated/\\\n * numpy.ndarray.strides.html\n */\n readonly strides: number[];\n\n constructor(shape: ShapeMap[R], dtype: DataType, dataId: DataId, id: number) {\n this.shape = shape.slice() as ShapeMap[R];\n this.dtype = dtype || 'float32';\n this.size = util.sizeFromShape(shape);\n this.strides = computeStrides(shape);\n this.dataId = dataId;\n this.id = id;\n this.rankType = (this.rank < 5 ? this.rank.toString() : 'higher') as R;\n }\n\n get rank(): number {\n return this.shape.length;\n }\n\n /**\n * Returns a promise of `tf.TensorBuffer` that holds the underlying data.\n *\n * @doc {heading: 'Tensors', subheading: 'Classes'}\n */\n async buffer(): Promise> {\n const vals = await this.data();\n return opHandler.buffer(this.shape, this.dtype as D, vals);\n }\n\n /**\n * Returns a `tf.TensorBuffer` that holds the underlying data.\n * @doc {heading: 'Tensors', subheading: 'Classes'}\n */\n bufferSync(): TensorBuffer {\n return opHandler.buffer(this.shape, this.dtype as D, this.dataSync());\n }\n\n /**\n * Returns the tensor data as a nested array. The transfer of data is done\n * asynchronously.\n *\n * @doc {heading: 'Tensors', subheading: 'Classes'}\n */\n async array(): Promise {\n const vals = await this.data();\n return toNestedArray(this.shape, vals, this.dtype === 'complex64') as\n ArrayMap[R];\n }\n\n /**\n * Returns the tensor data as a nested array. The transfer of data is done\n * synchronously.\n *\n * @doc {heading: 'Tensors', subheading: 'Classes'}\n */\n arraySync(): ArrayMap[R] {\n return toNestedArray(\n this.shape, this.dataSync(), this.dtype === 'complex64') as\n ArrayMap[R];\n }\n\n /**\n * Asynchronously downloads the values from the `tf.Tensor`. Returns a\n * promise of `TypedArray` that resolves when the computation has finished.\n *\n * @doc {heading: 'Tensors', subheading: 'Classes'}\n */\n async data(): Promise {\n this.throwIfDisposed();\n const data = trackerFn().read(this.dataId);\n if (this.dtype === 'string') {\n const bytes = await data as Uint8Array[];\n try {\n return bytes.map(b => util.decodeString(b)) as DataTypeMap[D];\n } catch {\n throw new Error(\n 'Failed to decode the string bytes into utf-8. ' +\n 'To get the original bytes, call tensor.bytes().');\n }\n }\n return data as Promise;\n }\n\n /**\n * Synchronously downloads the values from the `tf.Tensor`. This blocks the\n * UI thread until the values are ready, which can cause performance issues.\n *\n * @doc {heading: 'Tensors', subheading: 'Classes'}\n */\n dataSync(): DataTypeMap[D] {\n this.throwIfDisposed();\n const data = trackerFn().readSync(this.dataId);\n if (this.dtype === 'string') {\n try {\n return (data as Uint8Array[]).map(b => util.decodeString(b)) as\n DataTypeMap[D];\n } catch {\n throw new Error(\n 'Failed to decode the string bytes into utf-8. ' +\n 'To get the original bytes, call tensor.bytes().');\n }\n }\n return data as DataTypeMap[D];\n }\n\n /** Returns the underlying bytes of the tensor's data. */\n async bytes(): Promise {\n this.throwIfDisposed();\n const data = await trackerFn().read(this.dataId);\n if (this.dtype === 'string') {\n return data as Uint8Array[];\n } else {\n return new Uint8Array((data as TypedArray).buffer);\n }\n }\n\n /**\n * Disposes `tf.Tensor` from memory.\n *\n * @doc {heading: 'Tensors', subheading: 'Classes'}\n */\n dispose(): void {\n if (this.isDisposed) {\n return;\n }\n trackerFn().disposeTensor(this);\n this.isDisposedInternal = true;\n }\n\n protected isDisposedInternal = false;\n get isDisposed(): boolean {\n return this.isDisposedInternal;\n }\n\n throwIfDisposed() {\n if (this.isDisposed) {\n throw new Error(`Tensor is disposed.`);\n }\n }\n\n /**\n * Prints the `tf.Tensor`. See `tf.print` for details.\n *\n * @param verbose Whether to print verbose information about the tensor,\n * including dtype and size.\n *\n * @doc {heading: 'Tensors', subheading: 'Classes'}\n */\n print(verbose = false): void {\n return opHandler.print(this, verbose);\n }\n\n /**\n * Returns a copy of the tensor. See `tf.clone` for details.\n * @doc {heading: 'Tensors', subheading: 'Classes'}\n */\n clone(this: T): T {\n this.throwIfDisposed();\n return opHandler.clone(this);\n }\n\n /**\n * Returns a human-readable description of the tensor. Useful for logging.\n *\n * @doc {heading: 'Tensors', subheading: 'Classes'}\n */\n toString(verbose = false): string {\n const vals = this.dataSync();\n return tensorToString(vals, this.shape, this.dtype, verbose);\n }\n\n cast(dtype: DataType): T {\n this.throwIfDisposed();\n return opHandler.cast(this as T, dtype);\n }\n variable(trainable = true, name?: string, dtype?: DataType): Variable {\n this.throwIfDisposed();\n return trackerFn().makeVariable(this, trainable, name, dtype) as\n Variable;\n }\n}\nObject.defineProperty(Tensor, Symbol.hasInstance, {\n value: (instance: Tensor) => {\n // Implementation note: we should use properties of the object that will be\n // defined before the constructor body has finished executing (methods).\n // This is because when this code is transpiled by babel, babel will call\n // classCallCheck before the constructor body is run.\n // See https://github.com/tensorflow/tfjs/issues/3384 for backstory.\n return !!instance && instance.data != null && instance.dataSync != null &&\n instance.throwIfDisposed != null;\n }\n});\n\nexport function getGlobalTensorClass() {\n // Use getGlobal so that we can augment the Tensor class across package\n // boundaries becase the node resolution alg may result in different modules\n // being returned for this file depending on the path they are loaded from.\n return getGlobal('Tensor', () => {\n return Tensor;\n });\n}\n\n// Global side effect. Cache global reference to Tensor class\ngetGlobalTensorClass();\n\nexport interface NumericTensor extends Tensor {\n dtype: NumericDataType;\n dataSync(): DataTypeMap[D];\n data(): Promise;\n}\n\nexport interface StringTensor extends Tensor {\n dtype: 'string';\n dataSync(): DataTypeMap[D];\n data(): Promise;\n}\n\n/** @doclink Tensor */\nexport type Scalar = Tensor;\n/** @doclink Tensor */\nexport type Tensor1D = Tensor;\n/** @doclink Tensor */\nexport type Tensor2D = Tensor;\n/** @doclink Tensor */\nexport type Tensor3D = Tensor;\n/** @doclink Tensor */\nexport type Tensor4D = Tensor;\n/** @doclink Tensor */\nexport type Tensor5D = Tensor;\n/** @doclink Tensor */\nexport type Tensor6D = Tensor;\n\n/**\n * A mutable `tf.Tensor`, useful for persisting state, e.g. for training.\n *\n * @doc {heading: 'Tensors', subheading: 'Classes'}\n */\nexport class Variable extends Tensor {\n name: string;\n\n constructor(\n initialValue: Tensor, public trainable: boolean, name: string,\n tensorId: number) {\n super(\n initialValue.shape, initialValue.dtype, initialValue.dataId, tensorId);\n this.name = name;\n }\n\n /**\n * Assign a new `tf.Tensor` to this variable. The new `tf.Tensor` must have\n * the same shape and dtype as the old `tf.Tensor`.\n *\n * @param newValue New tensor to be assigned to this variable.\n *\n * @doc {heading: 'Tensors', subheading: 'Classes'}\n */\n assign(newValue: Tensor): void {\n if (newValue.dtype !== this.dtype) {\n throw new Error(\n `dtype of the new value (${newValue.dtype}) and ` +\n `previous value (${this.dtype}) must match`);\n }\n if (!util.arraysEqual(newValue.shape, this.shape)) {\n throw new Error(\n `shape of the new value (${newValue.shape}) and ` +\n `previous value (${this.shape}) must match`);\n }\n trackerFn().disposeTensor(this);\n this.dataId = newValue.dataId;\n trackerFn().incRef(this, null /* backend */);\n }\n\n dispose(): void {\n trackerFn().disposeVariable(this);\n this.isDisposedInternal = true;\n }\n}\n\nObject.defineProperty(Variable, Symbol.hasInstance, {\n value: (instance: Variable) => {\n return instance instanceof Tensor && instance.assign != null &&\n instance.assign instanceof Function;\n }\n});\n", "/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor} from './tensor';\nimport {TensorContainer, TensorContainerArray} from './tensor_types';\nimport {upcastType} from './types';\nimport {assert} from './util';\n\nexport function makeTypesMatch(a: T, b: T): [T, T] {\n if (a.dtype === b.dtype) {\n return [a, b];\n }\n const dtype = upcastType(a.dtype, b.dtype);\n return [a.cast(dtype), b.cast(dtype)];\n}\n\nexport function assertTypesMatch(a: Tensor, b: Tensor): void {\n assert(\n a.dtype === b.dtype,\n () => `The dtypes of the first(${a.dtype}) and` +\n ` second(${b.dtype}) input must match`);\n}\n\nexport function isTensorInList(tensor: Tensor, tensorList: Tensor[]): boolean {\n return tensorList.some(x => x.id === tensor.id);\n}\n\n/**\n * Extracts any `Tensor`s found within the provided object.\n *\n * @param container an object that may be a `Tensor` or may directly contain\n * `Tensor`s, such as a `Tensor[]` or `{key: Tensor, ...}`. In general it\n * is safe to pass any object here, except that `Promise`s are not\n * supported.\n * @returns An array of `Tensors` found within the passed object. If the\n * argument is simply a `Tensor', a list containing that `Tensor` is\n * returned. If the object is not a `Tensor` or does not\n * contain `Tensors`, an empty list is returned.\n */\nexport function getTensorsInContainer(result: TensorContainer): Tensor[] {\n const list: Tensor[] = [];\n const seen = new Set<{}|void>();\n walkTensorContainer(result, list, seen);\n return list;\n}\n\nfunction walkTensorContainer(\n container: TensorContainer, list: Tensor[], seen: Set<{}|void>): void {\n if (container == null) {\n return;\n }\n if (container instanceof Tensor) {\n list.push(container);\n return;\n }\n if (!isIterable(container)) {\n return;\n }\n // Iteration over keys works also for arrays.\n const iterable = container as TensorContainerArray;\n for (const k in iterable) {\n const val = iterable[k];\n if (!seen.has(val)) {\n seen.add(val);\n walkTensorContainer(val, list, seen);\n }\n }\n}\n\n// tslint:disable-next-line:no-any\nfunction isIterable(obj: any): boolean {\n return Array.isArray(obj) || typeof obj === 'object';\n}\n", "/**\n * @license\n * Copyright 2017 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/** @docalias number[] */\nexport interface ShapeMap {\n R0: number[];\n R1: [number];\n R2: [number, number];\n R3: [number, number, number];\n R4: [number, number, number, number];\n R5: [number, number, number, number, number];\n R6: [number, number, number, number, number, number];\n}\n\n/** @docalias number[] */\nexport interface ArrayMap {\n R0: number;\n R1: number[];\n R2: number[][];\n R3: number[][][];\n R4: number[][][][];\n R5: number[][][][][];\n R6: number[][][][][][];\n}\n\nexport interface DataTypeMap {\n float32: Float32Array;\n int32: Int32Array;\n bool: Uint8Array;\n complex64: Float32Array;\n string: string[];\n}\n\nexport interface SingleValueMap {\n bool: boolean;\n int32: number;\n float32: number;\n complex64: number;\n string: string;\n}\n\n/** @docalias 'float32'|'int32'|'bool'|'complex64'|'string' */\nexport type DataType = keyof DataTypeMap;\nexport type NumericDataType = 'float32'|'int32'|'bool'|'complex64';\nexport type TypedArray = Float32Array|Int32Array|Uint8Array;\n/** Tensor data used in tensor creation and user-facing API. */\nexport type DataValues = DataTypeMap[DataType];\n/** The underlying tensor data that gets stored in a backend. */\nexport type BackendValues = Float32Array|Int32Array|Uint8Array|Uint8Array[];\n\nexport enum Rank {\n R0 = 'R0',\n R1 = 'R1',\n R2 = 'R2',\n R3 = 'R3',\n R4 = 'R4',\n R5 = 'R5',\n R6 = 'R6'\n}\n\nexport type FlatVector = boolean[]|number[]|TypedArray;\nexport type RegularArray =\n T[]|T[][]|T[][][]|T[][][][]|T[][][][][]|T[][][][][][];\n\n// tslint:disable-next-line:no-any\nexport interface RecursiveArray {\n [index: number]: T|RecursiveArray;\n}\n\n// Looks for upcasting types. Used, for example, in operations with mixed dtype\n// inputs.\nenum UpcastInt32AndMap {\n 'float32' = 'float32',\n 'int32' = 'int32',\n 'bool' = 'int32',\n 'complex64' = 'complex64'\n}\n\nenum UpcastBoolAndMap {\n 'float32' = 'float32',\n 'int32' = 'int32',\n 'bool' = 'bool',\n 'complex64' = 'complex64'\n}\n\nenum UpcastFloat32AndMap {\n 'float32' = 'float32',\n 'int32' = 'float32',\n 'bool' = 'float32',\n 'complex64' = 'complex64'\n}\n\nenum UpcastComplex64AndMap {\n 'float32' = 'complex64',\n 'int32' = 'complex64',\n 'bool' = 'complex64',\n 'complex64' = 'complex64'\n}\n\nconst upcastTypeMap = {\n 'float32': UpcastFloat32AndMap,\n 'int32': UpcastInt32AndMap,\n 'bool': UpcastBoolAndMap,\n 'complex64': UpcastComplex64AndMap\n};\n\nexport function upcastType(typeA: DataType, typeB: DataType): DataType {\n if (typeA === 'string' || typeB === 'string') {\n if (typeA === 'string' && typeB === 'string') {\n return 'string';\n }\n throw new Error(`Can not upcast ${typeA} with ${typeB}`);\n }\n return upcastTypeMap[typeA][typeB];\n}\n\n/** Returns the output type after summation. */\nexport function sumOutType(type: DataType): DataType {\n return upcastType(type, 'int32');\n}\n\n/** @docalias TypedArray|Array */\nexport type TensorLike =\n TypedArray|number|boolean|string|RecursiveArray|\n RecursiveArray|RecursiveArray|Uint8Array[];\nexport type ScalarLike = number|boolean|string|Uint8Array;\n/** @docalias TypedArray|Array */\nexport type TensorLike1D = TypedArray|number[]|boolean[]|string[]|Uint8Array[];\n/** @docalias TypedArray|Array */\nexport type TensorLike2D = TypedArray|number[]|number[][]|boolean[]|boolean[][]|\n string[]|string[][]|Uint8Array[]|Uint8Array[][];\n/** @docalias TypedArray|Array */\nexport type TensorLike3D = TypedArray|number[]|number[][][]|boolean[]|\n boolean[][][]|string[]|string[][][]|Uint8Array[]|Uint8Array[][][];\n/** @docalias TypedArray|Array */\nexport type TensorLike4D = TypedArray|number[]|number[][][][]|boolean[]|\n boolean[][][][]|string[]|string[][][][]|Uint8Array[]|Uint8Array[][][][];\n/** @docalias TypedArray|Array */\nexport type TensorLike5D =\n TypedArray|number[]|number[][][][][]|boolean[]|boolean[][][][][]|string[]|\n string[][][][][]|Uint8Array[]|Uint8Array[][][][][];\n/** @docalias TypedArray|Array */\nexport type TensorLike6D =\n TypedArray|number[]|number[][][][][][]|boolean[]|boolean[][][][][][]|\n string[]|string[][][][][][]|Uint8Array[]|Uint8Array[][][][][];\n\n/** Type for representing image data in Uint8Array type. */\nexport interface PixelData {\n width: number;\n height: number;\n data: Uint8Array;\n}\n", "/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {BackendTimingInfo, DataMover, KernelBackend} from './backends/backend';\nimport {Environment, setEnvironmentGlobal} from './environment';\nimport {getGlobalNamespace} from './global_util';\nimport {Add, Cast, Identity} from './kernel_names';\nimport {getGradient, getKernel, getKernelsForBackend, GradFunc, NamedAttrMap, TensorInfo} from './kernel_registry';\nimport {KernelProfile, Profiler} from './profiler';\nimport {backpropagateGradients, getFilteredNodesXToY, TapeNode} from './tape';\nimport {DataId, setTensorTracker, Tensor, TensorTracker, Variable} from './tensor';\nimport {GradSaveFunc, NamedTensorMap, NamedVariableMap, TensorContainer} from './tensor_types';\nimport {getTensorsInContainer} from './tensor_util';\nimport {BackendValues, DataType, DataValues} from './types';\nimport * as util from './util';\nimport {bytesFromStringArray, makeOnesTypedArray, now, sizeFromShape} from './util';\n\n/**\n * A function that computes an output. The save function is for saving tensors\n * computed in the forward pass, that we need in the backward pass.\n */\nexport type ForwardFunc = (backend: KernelBackend, save?: GradSaveFunc) => T;\n\n/**\n * @docalias (a: Tensor, b: Tensor,..., save?: Function) => {\n * value: Tensor,\n * gradFunc: (dy: Tensor, saved?: NamedTensorMap) => Tensor | Tensor[]\n * }\n */\nexport type CustomGradientFunc =\n (...inputs: Array) => {\n value: T;\n gradFunc: (dy: T, saved: Tensor[]) => Tensor | Tensor[];\n };\n\nexport type MemoryInfo = {\n numTensors: number; numDataBuffers: number; numBytes: number;\n unreliable?: boolean; reasons: string[];\n};\n\ntype KernelInfo = {\n name: string; bytesAdded: number; totalBytesSnapshot: number;\n tensorsAdded: number;\n totalTensorsSnapshot: number;\n inputShapes: number[][];\n outputShapes: number[][];\n kernelTimeMs: number | {error: string} | Promise;\n extraInfo: string | Promise;\n};\n\nexport type ProfileInfo = {\n newBytes: number; newTensors: number; peakBytes: number;\n kernels: KernelInfo[];\n result: TensorContainer;\n kernelNames: string[];\n};\n\nexport interface TimingInfo extends BackendTimingInfo {\n wallMs: number;\n}\n\n/** @docalias Function */\nexport type ScopeFn = () => T;\n\ninterface ScopeState {\n track: Tensor[];\n name: string;\n id: number;\n}\n\ninterface RegisteredKernelInvocation {\n kernelName: string;\n inputs: I;\n attrs?: NamedAttrMap;\n}\n\ninterface CustomGradKernelInvocation {\n forwardFunc: ForwardFunc;\n backwardsFunc: (dy: T, saved: Tensor[]) => {\n [P in keyof I]: () => I[P]\n };\n inputs: I;\n attrs?: NamedAttrMap;\n}\n\nfunction isRegisteredKernelInvocation(\n kernelInvocation: RegisteredKernelInvocation|\n CustomGradKernelInvocation):\n kernelInvocation is RegisteredKernelInvocation {\n return (kernelInvocation as RegisteredKernelInvocation).kernelName != null;\n}\n\nclass EngineState {\n // Public since optimizers will use it.\n registeredVariables: NamedVariableMap = {};\n\n nextTapeNodeId = 0;\n numBytes = 0;\n numTensors = 0;\n numStringTensors = 0;\n numDataBuffers = 0;\n\n activeTape: TapeNode[];\n // Number of nested tf.grad() statements when computing higher-order\n // gradients. E.g. `1` for first-order gradients and `2` for second-order\n // gradients. Used to track if the tape should be removed after a backprop.\n gradientDepth = 0;\n // Number of nested kernel calls. When kernel depth is greater than 1, we turn\n // off the tape.\n kernelDepth = 0;\n\n // Keep Tensors that parallel the tapes.\n activeScope: ScopeState;\n scopeStack: ScopeState[] = [];\n /**\n * Keeps track of the number of data moves during a kernel execution. We\n * maintain a stack since kernels can call other kernels, recursively.\n */\n numDataMovesStack: number[] = [];\n nextScopeId = 0;\n\n tensorInfo = new WeakMap();\n\n profiling = false;\n activeProfile: ProfileInfo = {\n newBytes: 0,\n newTensors: 0,\n peakBytes: 0,\n kernels: [],\n result: null,\n get kernelNames():\n string[] {\n return Array.from(new Set(this.kernels.map(k => k.name)));\n }\n };\n\n dispose() {\n for (const variableName in this.registeredVariables) {\n this.registeredVariables[variableName].dispose();\n }\n }\n}\n\nexport class Engine implements TensorTracker, DataMover {\n state: EngineState;\n backendName: string;\n registry: {[id: string]: KernelBackend} = {};\n registryFactory: {\n [id: string]: {\n factory: () => KernelBackend | Promise,\n priority: number\n }\n } = {};\n\n private profiler: Profiler;\n private backendInstance: KernelBackend;\n private pendingBackendInit: Promise;\n private pendingBackendInitId = 0;\n\n constructor(public ENV: Environment) {\n this.state = new EngineState();\n }\n\n async ready(): Promise {\n if (this.pendingBackendInit != null) {\n return this.pendingBackendInit.then(() => {});\n }\n if (this.backendInstance != null) {\n return;\n }\n const sortedBackends = this.getSortedBackends();\n\n for (let i = 0; i < sortedBackends.length; i++) {\n const backendName = sortedBackends[i];\n const success = await this.initializeBackend(backendName).success;\n if (success) {\n await this.setBackend(backendName);\n return;\n }\n }\n\n throw new Error(\n `Could not initialize any backends, all backend initializations ` +\n `failed.`);\n }\n\n get backend(): KernelBackend {\n if (this.pendingBackendInit != null) {\n throw new Error(\n `Backend '${this.backendName}' has not yet been initialized. Make ` +\n `sure to await tf.ready() or await tf.setBackend() before calling ` +\n `other methods`);\n }\n if (this.backendInstance == null) {\n const {name, asyncInit} = this.initializeBackendsAndReturnBest();\n if (asyncInit) {\n throw new Error(\n `The highest priority backend '${name}' has not yet been ` +\n `initialized. Make sure to await tf.ready() or ` +\n `await tf.setBackend() before calling other methods`);\n }\n this.setBackend(name);\n }\n return this.backendInstance;\n }\n\n backendNames(): string[] {\n return Object.keys(this.registryFactory);\n }\n\n findBackend(backendName: string): KernelBackend {\n if (!(backendName in this.registry)) {\n // If the backend hasn't been initialized but we have a registry entry for\n // it, initialize it and return it.\n if (backendName in this.registryFactory) {\n const {asyncInit} = this.initializeBackend(backendName);\n if (asyncInit) {\n // Backend is not ready yet.\n return null;\n }\n } else {\n return null;\n }\n }\n return this.registry[backendName];\n }\n\n findBackendFactory(backendName: string):\n () => KernelBackend | Promise {\n if (!(backendName in this.registryFactory)) {\n return null;\n }\n return this.registryFactory[backendName].factory;\n }\n\n registerBackend(\n backendName: string,\n factory: () => KernelBackend | Promise,\n priority = 1): boolean {\n if (backendName in this.registryFactory) {\n console.warn(\n `${backendName} backend was already registered. ` +\n `Reusing existing backend factory.`);\n return false;\n }\n this.registryFactory[backendName] = {factory, priority};\n return true;\n }\n\n async setBackend(backendName: string): Promise {\n if (this.registryFactory[backendName] == null) {\n throw new Error(`Backend name '${backendName}' not found in registry`);\n }\n this.backendName = backendName;\n if (this.registry[backendName] == null) {\n this.backendInstance = null;\n const {success, asyncInit} = this.initializeBackend(backendName);\n const result = asyncInit ? await success : success;\n if (!result) {\n return false;\n }\n }\n this.backendInstance = this.registry[backendName];\n this.setupRegisteredKernels();\n // Reset the profiler.\n this.profiler = new Profiler(this.backendInstance);\n\n return true;\n }\n\n private setupRegisteredKernels(): void {\n const kernels = getKernelsForBackend(this.backendName);\n kernels.forEach(kernel => {\n if (kernel.setupFunc != null) {\n kernel.setupFunc(this.backendInstance);\n }\n });\n }\n\n private disposeRegisteredKernels(backendName: string): void {\n const kernels = getKernelsForBackend(backendName);\n kernels.forEach(kernel => {\n if (kernel.disposeFunc != null) {\n kernel.disposeFunc(this.registry[backendName]);\n }\n });\n }\n\n /**\n * Initializes a backend by looking up the backend name in the factory\n * registry and calling the factory method. Returns a boolean representing\n * whether the initialization of the backend suceeded. Throws an error if\n * there is no backend in the factory registry.\n */\n private initializeBackend(backendName: string):\n {success: boolean|Promise, asyncInit: boolean} {\n const registryFactoryEntry = this.registryFactory[backendName];\n if (registryFactoryEntry == null) {\n throw new Error(\n `Cannot initialize backend ${backendName}, no registration found.`);\n }\n\n try {\n const backend = registryFactoryEntry.factory();\n /* Test if the factory returns a promise.\n Done in a more liberal way than\n previous 'Promise.resolve(backend)===backend'\n as we needed to account for custom Promise\n implementations (e.g. Angular) */\n if (backend && !(backend instanceof KernelBackend) &&\n typeof backend.then === 'function') {\n const promiseId = ++this.pendingBackendInitId;\n const success =\n backend\n .then(backendInstance => {\n // Outdated promise. Another backend was set in the meantime.\n if (promiseId < this.pendingBackendInitId) {\n return false;\n }\n this.registry[backendName] = backendInstance;\n this.pendingBackendInit = null;\n return true;\n })\n .catch(err => {\n // Outdated promise. Another backend was set in the meantime.\n if (promiseId < this.pendingBackendInitId) {\n return false;\n }\n this.pendingBackendInit = null;\n console.warn(\n `Initialization of backend ${backendName} failed`);\n console.warn(err.stack || err.message);\n return false;\n });\n this.pendingBackendInit = success;\n return {success, asyncInit: true};\n } else {\n this.registry[backendName] = backend as KernelBackend;\n return {success: true, asyncInit: false};\n }\n } catch (err) {\n console.warn(`Initialization of backend ${backendName} failed`);\n console.warn(err.stack || err.message);\n return {success: false, asyncInit: false};\n }\n }\n\n removeBackend(backendName: string): void {\n if (!(backendName in this.registryFactory)) {\n throw new Error(`${backendName} backend not found in registry`);\n }\n if (this.backendName === backendName && this.pendingBackendInit != null) {\n // There is a pending promise of the backend we want to remove. Make it\n // obsolete.\n this.pendingBackendInitId++;\n }\n\n if (backendName in this.registry) {\n this.disposeRegisteredKernels(backendName);\n this.registry[backendName].dispose();\n delete this.registry[backendName];\n }\n\n delete this.registryFactory[backendName];\n\n // Unset the backend if it is active.\n if (this.backendName === backendName) {\n this.pendingBackendInit = null;\n this.backendName = null;\n this.backendInstance = null;\n }\n }\n\n private getSortedBackends(): string[] {\n if (Object.keys(this.registryFactory).length === 0) {\n throw new Error('No backend found in registry.');\n }\n return Object.keys(this.registryFactory).sort((a: string, b: string) => {\n // Highest priority comes first.\n return this.registryFactory[b].priority -\n this.registryFactory[a].priority;\n });\n }\n\n private initializeBackendsAndReturnBest():\n {name: string, asyncInit: boolean} {\n const sortedBackends = this.getSortedBackends();\n\n for (let i = 0; i < sortedBackends.length; i++) {\n const backendName = sortedBackends[i];\n const {success, asyncInit} = this.initializeBackend(backendName);\n if (asyncInit || success) {\n return {name: backendName, asyncInit};\n }\n }\n throw new Error(\n `Could not initialize any backends, all backend initializations ` +\n `failed.`);\n }\n\n moveData(backend: KernelBackend, dataId: DataId) {\n const info = this.state.tensorInfo.get(dataId);\n const srcBackend = info.backend;\n const values = this.readSync(dataId);\n const refCount = srcBackend.refCount(dataId);\n // Delete the tensor from the old backend and move it to the new\n // backend.\n srcBackend.disposeData(dataId, true);\n info.backend = backend;\n backend.move(dataId, values, info.shape, info.dtype, refCount);\n if (this.shouldCheckForMemLeaks()) {\n // Track the number of moves during a kernel execution to correctly\n // detect memory leaks.\n this.state.numDataMovesStack[this.state.numDataMovesStack.length - 1]++;\n }\n }\n\n tidy(nameOrFn: string|ScopeFn, fn?: ScopeFn):\n T {\n let name: string = null;\n if (fn == null) {\n // Called with only 1 argument.\n if (typeof nameOrFn !== 'function') {\n throw new Error('Please provide a function to tidy()');\n }\n fn = nameOrFn;\n } else {\n // Called with 2 arguments.\n if (typeof nameOrFn !== 'string' && !(nameOrFn instanceof String)) {\n throw new Error(\n 'When calling with two arguments, the first argument ' +\n 'to tidy() must be a string');\n }\n if (typeof fn !== 'function') {\n throw new Error(\n 'When calling with two arguments, the 2nd argument ' +\n 'to tidy() must be a function');\n }\n name = nameOrFn as string;\n // TODO(nsthorat,smilkov): Do operation logging and performance\n // profiling.\n }\n let result: T;\n return this.scopedRun(\n () => this.startScope(name), () => this.endScope(result), () => {\n result = fn();\n if (result instanceof Promise) {\n console.error('Cannot return a Promise inside of tidy.');\n }\n return result;\n });\n }\n\n private scopedRun(start: () => void, end: () => void, f: () => T): T {\n start();\n try {\n const res = f();\n end();\n return res;\n } catch (ex) {\n end();\n throw ex;\n }\n }\n\n private static nextTensorId = 0;\n private nextTensorId(): number {\n return Engine.nextTensorId++;\n }\n\n private static nextVariableId = 0;\n private nextVariableId(): number {\n return Engine.nextVariableId++;\n }\n\n /**\n * This method is called instead of the public-facing tensor.clone() when\n * saving a tensor for backwards pass. It makes sure to add the clone\n * operation to the tape regardless of being called inside a kernel\n * execution.\n */\n private clone(x: Tensor): Tensor {\n const y: Tensor = ENGINE.runKernel(Identity, {x} as {} as NamedTensorMap);\n const inputs = {x};\n const grad = (dy: Tensor) => ({\n x: () => {\n const dtype = 'float32';\n const gradInputs = {x: dy};\n const attrs = {dtype};\n\n return ENGINE.runKernel(\n Cast, gradInputs as {} as NamedTensorMap,\n // tslint:disable-next-line: no-unnecessary-type-assertion\n attrs as {} as NamedAttrMap) as Tensor;\n }\n });\n const saved: Tensor[] = [];\n this.addTapeNode(this.state.activeScope.name, inputs, [y], grad, saved, {});\n return y;\n }\n\n /**\n * Execute a kernel with the given name and return the output tensor.\n *\n * @param kernelName The name of the kernel to execute.\n * @param inputs A map of input names to tensors.\n * @param attrs A map of attribute names to their values. An attribute is a\n * primitive (non-tensor) input to the kernel.\n * @param inputsToSave A list of tensors, inputs to save for the backprop\n * computation.\n * @param outputsToSave A list of booleans, specifying which output to save\n * for the backprop computation. These are booleans since the output\n * tensors are not visible to the user.\n */\n runKernel(\n kernelName: string, inputs: NamedTensorMap, attrs?: NamedAttrMap): T {\n const hasKernel = getKernel(kernelName, this.backendName) != null;\n if (!hasKernel) {\n throw new Error(`Kernel '${kernelName}' not registered for backend '${\n this.backendName}'`);\n }\n return this.runKernelFunc({kernelName, inputs, attrs});\n }\n\n private shouldCheckForMemLeaks(): boolean {\n return this.ENV.getBool('IS_TEST');\n }\n\n private checkKernelForMemLeak(\n kernelName: string, numDataIdsBefore: number,\n outInfos: TensorInfo[]): void {\n const numDataIdsAfter = this.backend.numDataIds();\n\n // Count the number of data ids associated with the result of the kernel.\n let numOutputDataIds = 0;\n outInfos.forEach(info => {\n // Complex numbers allocate 3 data ids, one for 'real', one for\n // 'imaginary', and one for the container that holds the former two.\n numOutputDataIds += (info.dtype === 'complex64' ? 3 : 1);\n });\n\n // Account for the number of moves during kernel execution. A \"data move\"\n // can happen in the middle of a kernel execution, placing a new (key,value)\n // pair in the data storage. Since data moves have net zero effect (we\n // always remove the data from the old backend), we have to cancel them out\n // when detecting memory leaks.\n const numMoves =\n this.state.numDataMovesStack[this.state.numDataMovesStack.length - 1];\n const dataIdsLeaked =\n numDataIdsAfter - numDataIdsBefore - numOutputDataIds - numMoves;\n if (dataIdsLeaked > 0) {\n throw new Error(\n `Backend '${this.backendName}' has an internal memory leak ` +\n `(${dataIdsLeaked} data ids) after running '${kernelName}'`);\n }\n }\n\n /**\n * Internal helper method to execute a kernel Func\n *\n * Use `runKernel` to execute kernels from outside of engine.\n */\n private runKernelFunc(\n kernelParams: RegisteredKernelInvocation|\n CustomGradKernelInvocation): T {\n let outputs: Tensor[];\n let saved: Tensor[] = [];\n const isTapeOn = this.isTapeOn();\n\n const startingBytecount = this.state.numBytes;\n const startingNumTensors = this.state.numTensors;\n\n if (this.shouldCheckForMemLeaks()) {\n this.state.numDataMovesStack.push(0);\n }\n\n let kernelFunc: () => Tensor[];\n if (this.backendName == null) {\n // backend has not been initialized yet (backend initialization is lazy\n // can be deferred until an op/ kernel is run).\n // The below getter has side effects that will try to initialize the\n // backend and set properties like this.backendName\n // tslint:disable-next-line: no-unused-expression\n this.backend;\n }\n\n let out: TensorInfo|TensorInfo[];\n\n const kernelOrScopeName = isRegisteredKernelInvocation(kernelParams) ?\n kernelParams.kernelName :\n this.state.activeScope != null ? this.state.activeScope.name : '';\n\n // Create the kernelFunc from either a registered kernel OR passed in\n // forward/backward functions (used by custom grad). In this context a\n // kernelFunc wraps a kernel implementation with some bookkeeping.\n\n if (isRegisteredKernelInvocation(kernelParams)) {\n const {kernelName, inputs, attrs} = kernelParams;\n if (this.backendName == null) {\n // backend has not been initialized yet (backend initialization is lazy\n // can be deferred until an op/ kernel is run).\n // The below getter has side effects that will try to initialize the\n // backend and set properties like this.backendName\n // tslint:disable-next-line: no-unused-expression\n this.backend;\n }\n const kernel = getKernel(kernelName, this.backendName);\n util.assert(\n kernel != null,\n () => `Cannot find registered kernel '${kernelName}' for backend '${\n this.backendName}'`);\n\n kernelFunc = () => {\n const numDataIdsBefore = this.backend.numDataIds();\n out = kernel.kernelFunc({inputs, attrs, backend: this.backend});\n const outInfos = Array.isArray(out) ? out : [out];\n if (this.shouldCheckForMemLeaks()) {\n this.checkKernelForMemLeak(kernelName, numDataIdsBefore, outInfos);\n }\n\n const outTensors = outInfos.map((outInfo: TensorInfo|Tensor) => {\n // todo (yassogba) remove this option (Tensor) when node backend\n // methods have been modularized and they all return tensorInfo.\n // TensorInfos do not have a rank attribute.\n if ((outInfo as Tensor).rank != null) {\n return outInfo as Tensor;\n }\n const {dataId, shape, dtype} = outInfo as TensorInfo;\n return this.makeTensorFromDataId(dataId, shape, dtype);\n });\n\n // Save any required inputs and outputs.\n\n // Do not save unless we are recording to the tape. Otherwise it would\n // cause a mem leak since there would be no backprop for these tensors\n // (which would otherwise dispose them).\n if (isTapeOn) {\n const tensorsToSave =\n this.getTensorsForGradient(kernelName, inputs, outTensors);\n saved = this.saveTensorsForBackwardMode(tensorsToSave);\n }\n return outTensors;\n };\n } else {\n const {forwardFunc} = kernelParams;\n // Running a customGrad op.\n const saveFunc: GradSaveFunc = (tensors) => {\n // Do not save unless we are recording to the tape. Otherwise it would\n // cause a mem leak since we would never run backprop, which disposes\n // the kept tensors.\n if (!isTapeOn) {\n return;\n }\n saved = tensors.map(tensor => this.keep(this.clone(tensor)));\n };\n\n kernelFunc = () => {\n const numDataIdsBefore = this.backend.numDataIds();\n out = this.tidy(() => forwardFunc(this.backend, saveFunc));\n const outs = (Array.isArray(out) ? out : [out]) as Tensor[];\n if (this.shouldCheckForMemLeaks()) {\n // Scope name is used to print a more helpful error message if needed.\n this.checkKernelForMemLeak(kernelOrScopeName, numDataIdsBefore, outs);\n }\n return outs;\n };\n }\n\n //\n // Run the kernelFunc. Optionally profiling it.\n //\n const {inputs, attrs} = kernelParams;\n const backwardsFunc = isRegisteredKernelInvocation(kernelParams) ?\n null :\n kernelParams.backwardsFunc;\n\n let kernelProfile: KernelProfile;\n this.scopedRun(\n // Stop recording to a tape when running a kernel.\n () => this.state.kernelDepth++, () => this.state.kernelDepth--, () => {\n if (!this.ENV.getBool('DEBUG') && !this.state.profiling) {\n outputs = kernelFunc();\n } else {\n kernelProfile = this.profiler.profileKernel(\n kernelOrScopeName, inputs, () => kernelFunc());\n if (this.ENV.getBool('DEBUG')) {\n this.profiler.logKernelProfile(kernelProfile);\n }\n outputs = kernelProfile.outputs;\n }\n });\n\n if (isTapeOn) {\n this.addTapeNode(\n kernelOrScopeName, inputs, outputs, backwardsFunc, saved, attrs);\n }\n\n if (this.state.profiling) {\n this.state.activeProfile.kernels.push({\n name: kernelOrScopeName,\n bytesAdded: this.state.numBytes - startingBytecount,\n totalBytesSnapshot: this.state.numBytes,\n tensorsAdded: this.state.numTensors - startingNumTensors,\n totalTensorsSnapshot: this.state.numTensors,\n inputShapes: Object.keys(inputs).map(\n key => inputs[key] != null ? inputs[key].shape : null),\n outputShapes: outputs.map(item => item.shape),\n kernelTimeMs: kernelProfile.timeMs,\n extraInfo: kernelProfile.extraInfo\n });\n }\n return (Array.isArray(out) ? outputs : outputs[0]) as T;\n }\n\n /**\n * Saves tensors used in forward mode for use in backward mode.\n *\n * @param tensors the list of tensors to save.\n */\n private saveTensorsForBackwardMode(tensors: Tensor[]): Tensor[] {\n const saved = tensors.map(tensor => this.keep(this.clone(tensor)));\n return saved;\n }\n\n /**\n * Returns a list of tensors to save for a given gradient calculation.\n *\n * @param kernelName name of kernel to look up gradient for.\n * @param inputs a map of input tensors.\n * @param outputs an array of output tensors from forward mode of kernel.\n */\n private getTensorsForGradient(\n kernelName: string, inputs: NamedTensorMap,\n outputs: Tensor[]): Tensor[]|null {\n const gradConfig = getGradient(kernelName);\n if (gradConfig != null) {\n const inputsToSave: string[] = gradConfig.inputsToSave || [];\n const outputsToSave: boolean[] = gradConfig.outputsToSave || [];\n\n // If saveAllInputs is true, all inputs will be saved. Otherwise, inputs\n // specified in inputsToSave will be saved.\n let inputTensorsToSave: Tensor[];\n if (gradConfig.saveAllInputs) {\n util.assert(\n Array.isArray(inputs),\n () => 'saveAllInputs is true, expected inputs to be an array.');\n\n inputTensorsToSave = Object.keys(inputs).map((key) => inputs[key]);\n } else {\n inputTensorsToSave = inputsToSave.map((inputName) => inputs[inputName]);\n }\n\n const outputTensorsToSave: Tensor[] =\n outputs.filter((_, i) => outputsToSave[i]);\n\n return inputTensorsToSave.concat(outputTensorsToSave);\n }\n // We return an empty list rather than throw an error because the kernel we\n // are looking up may not actually be relevant to backproping through the\n // overall function\n //\n // See 'does not error if irrelevant (pruned) ops are missing grads' test\n // in gradients_test.ts for an example.\n return [];\n }\n\n /**\n * Internal method used by public APIs for tensor creation. Makes a new\n * tensor with the provided shape, dtype and values. It always\n * creates a new data id and writes the values to the underlying backend.\n */\n makeTensor(\n values: DataValues, shape: number[], dtype: DataType,\n backend?: KernelBackend): Tensor {\n if (values == null) {\n throw new Error('Values passed to engine.makeTensor() are null');\n }\n dtype = dtype || 'float32';\n backend = backend || this.backend;\n let backendVals = values as BackendValues;\n if (dtype === 'string' && util.isString(values[0])) {\n backendVals = (values as string[]).map(d => util.encodeString(d));\n }\n const dataId = backend.write(backendVals, shape, dtype);\n const t = new Tensor(shape, dtype, dataId, this.nextTensorId());\n this.trackTensor(t, backend);\n\n // Count bytes for string tensors.\n if (dtype === 'string') {\n const info = this.state.tensorInfo.get(dataId);\n const newBytes = bytesFromStringArray(backendVals as Uint8Array[]);\n this.state.numBytes += newBytes - info.bytes;\n info.bytes = newBytes;\n }\n return t;\n }\n\n /**\n * Internal method used by backends. Makes a new tensor\n * that is a wrapper around an existing data id. It doesn't create\n * a new data id, only increments the ref count used in memory tracking.\n */\n makeTensorFromDataId(\n dataId: DataId, shape: number[], dtype: DataType,\n backend?: KernelBackend): Tensor {\n dtype = dtype || 'float32';\n const t = new Tensor(shape, dtype, dataId, this.nextTensorId());\n this.trackTensor(t, backend);\n return t;\n }\n\n makeVariable(\n initialValue: Tensor, trainable = true, name?: string,\n dtype?: DataType): Variable {\n name = name || this.nextVariableId().toString();\n if (dtype != null && dtype !== initialValue.dtype) {\n initialValue = initialValue.cast(dtype);\n }\n const v = new Variable(initialValue, trainable, name, this.nextTensorId());\n if (this.state.registeredVariables[v.name] != null) {\n throw new Error(`Variable with name ${v.name} was already registered`);\n }\n this.state.registeredVariables[v.name] = v;\n this.incRef(v, this.backend);\n return v;\n }\n\n trackTensor(a: Tensor, backend: KernelBackend): void {\n this.state.numTensors++;\n if (a.dtype === 'string') {\n this.state.numStringTensors++;\n }\n // Bytes for complex numbers are counted by their components. Bytes for\n // string tensors are counted when writing values.\n let bytes = 0;\n if (a.dtype !== 'complex64' && a.dtype !== 'string') {\n bytes = a.size * util.bytesPerElement(a.dtype);\n }\n this.state.numBytes += bytes;\n\n if (!this.state.tensorInfo.has(a.dataId)) {\n this.state.numDataBuffers++;\n this.state.tensorInfo.set(a.dataId, {\n backend: backend || this.backend,\n dtype: a.dtype,\n shape: a.shape,\n bytes\n });\n }\n\n if (!(a instanceof Variable)) {\n this.track(a);\n }\n }\n\n // Track the tensor by dataId and increase the refCount for the dataId in the\n // backend.\n // TODO(pyu10055): This is currently used by makeVariable method, to increase\n // refCount on the backend for the dataId. It can potentially be replaced with\n // Identity op indead of calling backend directly.\n incRef(a: Tensor, backend: KernelBackend): void {\n this.trackTensor(a, backend);\n this.backend.incRef(a.dataId);\n }\n\n removeDataId(dataId: DataId, backend: KernelBackend) {\n if (this.state.tensorInfo.has(dataId) &&\n this.state.tensorInfo.get(dataId).backend === backend) {\n this.state.tensorInfo.delete(dataId);\n this.state.numDataBuffers--;\n }\n }\n disposeTensor(a: Tensor): void {\n if (!this.state.tensorInfo.has(a.dataId)) {\n return;\n }\n const info = this.state.tensorInfo.get(a.dataId);\n\n this.state.numTensors--;\n if (a.dtype === 'string') {\n this.state.numStringTensors--;\n this.state.numBytes -= info.bytes;\n }\n // Don't count bytes for complex numbers as they are counted by their\n // components.\n if (a.dtype !== 'complex64' && a.dtype !== 'string') {\n const bytes = a.size * util.bytesPerElement(a.dtype);\n this.state.numBytes -= bytes;\n }\n\n // Remove the reference to dataId if backend dispose the data successfully\n if (info.backend.disposeData(a.dataId)) {\n this.removeDataId(a.dataId, info.backend);\n }\n\n // TODO(nsthorat): Construct an error and save the stack trace for\n // debugging when in debug mode. Creating a stack trace is too expensive\n // to do unconditionally.\n }\n\n disposeVariables(): void {\n for (const varName in this.state.registeredVariables) {\n const v = this.state.registeredVariables[varName];\n this.disposeVariable(v);\n }\n }\n\n disposeVariable(v: Variable): void {\n this.disposeTensor(v);\n if (this.state.registeredVariables[v.name] != null) {\n delete this.state.registeredVariables[v.name];\n }\n }\n\n memory(): MemoryInfo {\n const info = this.backend.memory() as MemoryInfo;\n info.numTensors = this.state.numTensors;\n info.numDataBuffers = this.state.numDataBuffers;\n info.numBytes = this.state.numBytes;\n if (this.state.numStringTensors > 0) {\n info.unreliable = true;\n if (info.reasons == null) {\n info.reasons = [];\n }\n info.reasons.push(\n 'Memory usage by string tensors is approximate ' +\n '(2 bytes per character)');\n }\n return info;\n }\n\n async profile(query: () => (TensorContainer | Promise)):\n Promise {\n this.state.profiling = true;\n\n const startBytes = this.state.numBytes;\n const startNumTensors = this.state.numTensors;\n\n this.state.activeProfile.kernels = [];\n this.state.activeProfile.result = await query();\n\n this.state.profiling = false;\n\n this.state.activeProfile.peakBytes = Math.max(\n ...this.state.activeProfile.kernels.map(d => d.totalBytesSnapshot));\n this.state.activeProfile.newBytes = this.state.numBytes - startBytes;\n this.state.activeProfile.newTensors =\n this.state.numTensors - startNumTensors;\n for (const kernel of this.state.activeProfile.kernels) {\n kernel.kernelTimeMs = await kernel.kernelTimeMs;\n kernel.extraInfo = await kernel.extraInfo;\n }\n return this.state.activeProfile;\n }\n\n isTapeOn(): boolean {\n return this.state.gradientDepth > 0 && this.state.kernelDepth === 0;\n }\n\n private addTapeNode(\n kernelName: string, inputs: NamedTensorMap, outputs: Tensor[],\n gradientsFunc: GradFunc, saved: Tensor[], attrs: NamedAttrMap): void {\n const tapeNode: TapeNode =\n {id: this.state.nextTapeNodeId++, kernelName, inputs, outputs, saved};\n\n const gradConfig = getGradient(kernelName);\n if (gradConfig != null) {\n gradientsFunc = gradConfig.gradFunc;\n }\n if (gradientsFunc != null) {\n tapeNode.gradient = (dys: Tensor[]) => {\n // TODO(smilkov): To optimize back-prop, pass dys that are not used in\n // the backprop graph to the user as null instead of zeros\n dys = dys.map((dy, i) => {\n if (dy == null) {\n const output = outputs[i];\n const vals = util.makeZerosTypedArray(output.size, output.dtype);\n return this.makeTensor(vals, output.shape, output.dtype);\n }\n return dy;\n });\n // Grad functions of ops with single outputs expect a dy, while ops\n // with multiple outputs expect dys (array of dy).\n return gradientsFunc(dys.length > 1 ? dys : dys[0], saved, attrs);\n };\n }\n this.state.activeTape.push(tapeNode);\n }\n\n keep(result: T): T {\n result.kept = true;\n return result;\n }\n\n private startTape() {\n if (this.state.gradientDepth === 0) {\n this.state.activeTape = [];\n }\n this.state.gradientDepth++;\n }\n\n private endTape() {\n this.state.gradientDepth--;\n }\n\n /**\n * Start a scope. Use this with endScope() to achieve the same functionality\n * as scope() without the need for a function closure.\n */\n startScope(name?: string) {\n const scopeInfo: ScopeState = {\n track: [],\n name: 'unnamed scope',\n id: this.state.nextScopeId++\n };\n if (name) {\n scopeInfo.name = name;\n }\n this.state.scopeStack.push(scopeInfo);\n this.state.activeScope = scopeInfo;\n }\n\n /**\n * End a scope. Use this with startScope() to achieve the same functionality\n * as scope() without the need for a function closure.\n */\n endScope(result?: TensorContainer) {\n const tensorsToTrackInParent = getTensorsInContainer(result);\n const tensorsToTrackInParentSet =\n new Set(tensorsToTrackInParent.map(t => t.id));\n\n // Dispose the arrays tracked in this scope.\n for (let i = 0; i < this.state.activeScope.track.length; i++) {\n const tensor = this.state.activeScope.track[i];\n if (!tensor.kept && !tensorsToTrackInParentSet.has(tensor.id)) {\n tensor.dispose();\n }\n }\n\n const oldScope = this.state.scopeStack.pop();\n this.state.activeScope = this.state.scopeStack.length === 0 ?\n null :\n this.state.scopeStack[this.state.scopeStack.length - 1];\n\n // Track the current result in the parent scope.\n tensorsToTrackInParent.forEach(tensor => {\n // Only track the tensor if was allocated in the inner scope and is not\n // globally kept.\n if (!tensor.kept && tensor.scopeId === oldScope.id) {\n this.track(tensor);\n }\n });\n }\n\n /**\n * Returns gradients of `f` with respect to each of the `xs`. The gradients\n * returned are of the same length as `xs`, but some might be null if `f`\n * was not a function of that `x`. It also takes optional dy to multiply the\n * gradient, which defaults to `1`.\n */\n gradients(\n f: () => T, xs: Tensor[], dy?: T,\n allowNoGradients = false): {value: T, grads: Tensor[]} {\n util.assert(\n xs.length > 0, () => 'gradients() received an empty list of xs.');\n if (dy != null && dy.dtype !== 'float32') {\n throw new Error(`dy must have 'float32' dtype, but has '${dy.dtype}'`);\n }\n\n const y = this.scopedRun(\n () => this.startTape(), () => this.endTape(),\n () => this.tidy('forward', f));\n\n util.assert(\n y instanceof Tensor,\n () => 'The result y returned by f() must be a tensor.');\n // Filter out the nodes that don't connect x => y.\n const filteredTape = getFilteredNodesXToY(this.state.activeTape, xs, y);\n if (!allowNoGradients && filteredTape.length === 0 && xs.length > 0) {\n throw new Error(\n 'Cannot compute gradient of y=f(x) with respect to x. Make sure ' +\n 'that the f you passed encloses all operations that lead from x ' +\n 'to y.');\n }\n\n return this.tidy('backward', () => {\n const accumulatedGradientMap: {[tensorId: number]: Tensor} = {};\n accumulatedGradientMap[y.id] = (dy == null) ? ones(y.shape) : dy;\n\n // Backprop gradients through the filtered nodes.\n backpropagateGradients(\n accumulatedGradientMap, filteredTape,\n // Pass the tidy function to avoid circular dep with `tape.ts`.\n f => this.tidy(f as ScopeFn),\n // Pass an add function to avoide a circular dep with `tape.ts`.\n add);\n const grads = xs.map(x => accumulatedGradientMap[x.id]);\n\n if (this.state.gradientDepth === 0) {\n // This means that we are not computing higher-order gradients\n // and can clean up the tape.\n this.state.activeTape.forEach(node => {\n for (const tensor of node.saved) {\n tensor.dispose();\n }\n });\n this.state.activeTape = null;\n }\n return {value: y, grads};\n });\n }\n\n customGrad(f: CustomGradientFunc):\n (...args: Array) => T {\n util.assert(\n util.isFunction(f),\n () => 'The f passed in customGrad(f) must be a function.');\n return (...inputs: Tensor[]): T => {\n util.assert(\n inputs.every(t => t instanceof Tensor),\n () => 'The args passed in customGrad(f)(x1, x2,...) must all be ' +\n 'tensors');\n\n let res: {\n value: T,\n gradFunc: (dy: T, saved: Tensor[]) => Tensor | Tensor[],\n };\n const inputMap: NamedTensorMap = {};\n inputs.forEach((input, i) => {\n inputMap[i] = input;\n });\n\n const forwardFunc: ForwardFunc = (_, save) => {\n res = f(...[...inputs, save]);\n util.assert(\n res.value instanceof Tensor,\n () => 'The function f passed in customGrad(f) must return an ' +\n 'object where `obj.value` is a tensor');\n util.assert(\n util.isFunction(res.gradFunc),\n () => 'The function f passed in customGrad(f) must return an ' +\n 'object where `obj.gradFunc` is a function.');\n return res.value;\n };\n\n const backwardsFunc = (dy: T, saved: Tensor[]) => {\n const gradRes = res.gradFunc(dy, saved);\n const grads: Tensor[] = Array.isArray(gradRes) ? gradRes : [gradRes];\n util.assert(\n grads.length === inputs.length,\n () => 'The function f passed in customGrad(f) must return an ' +\n 'object where `obj.gradFunc` is a function that returns ' +\n 'the same number of tensors as inputs passed to f(...).');\n util.assert(\n grads.every(t => t instanceof Tensor),\n () => 'The function f passed in customGrad(f) must return an ' +\n 'object where `obj.gradFunc` is a function that returns ' +\n 'a list of only tensors.');\n const gradMap: {[key: string]: () => Tensor} = {};\n grads.forEach((grad, i) => {\n gradMap[i] = () => grad;\n });\n return gradMap;\n };\n\n return this.runKernelFunc({\n forwardFunc,\n backwardsFunc,\n inputs: inputMap,\n });\n };\n }\n\n readSync(dataId: DataId): BackendValues {\n // Route the read to the correct backend.\n const info = this.state.tensorInfo.get(dataId);\n return info.backend.readSync(dataId);\n }\n read(dataId: DataId): Promise {\n // Route the read to the correct backend.\n const info = this.state.tensorInfo.get(dataId);\n return info.backend.read(dataId);\n }\n\n async time(query: () => void): Promise {\n const start = now();\n const timingInfo = await this.backend.time(query) as TimingInfo;\n timingInfo.wallMs = now() - start;\n return timingInfo;\n }\n\n /**\n * Tracks a Tensor in the current scope to be automatically cleaned up\n * when the current scope ends, and returns the value.\n *\n * @param result The Tensor to track in the current scope.\n */\n private track(result: T): T {\n if (this.state.activeScope != null) {\n result.scopeId = this.state.activeScope.id;\n this.state.activeScope.track.push(result);\n }\n\n return result;\n }\n\n get registeredVariables(): NamedVariableMap {\n return this.state.registeredVariables;\n }\n\n /**\n * Resets the engine state. Removes all backends but does not remove\n * registered backend factories.\n */\n reset(): void {\n // Make any pending promise obsolete.\n this.pendingBackendInitId++;\n\n this.state.dispose();\n this.ENV.reset();\n this.state = new EngineState();\n\n for (const backendName in this.registry) {\n this.disposeRegisteredKernels(backendName);\n this.registry[backendName].dispose();\n delete this.registry[backendName];\n }\n this.backendName = null;\n this.backendInstance = null;\n this.pendingBackendInit = null;\n }\n}\n\nfunction ones(shape: number[]): Tensor {\n const values = makeOnesTypedArray(sizeFromShape(shape), 'float32');\n return ENGINE.makeTensor(values, shape, 'float32');\n}\n\nexport function getOrMakeEngine(): Engine {\n const ns = getGlobalNamespace() as {} as {_tfengine: Engine};\n if (ns._tfengine == null) {\n const environment = new Environment(ns);\n ns._tfengine = new Engine(environment);\n }\n setEnvironmentGlobal(ns._tfengine.ENV);\n\n // Tell the current tensor interface that the global engine is responsible\n // for tracking.\n setTensorTracker(() => ns._tfengine);\n return ns._tfengine;\n}\n\nexport const ENGINE = getOrMakeEngine();\n\n/**\n * A implementation of the add op for use within engine and tape.\n *\n * This allows us to avoid a circular dependency between add.ts and engine.\n * It is exported to be available in tape tests.\n */\nexport function add(a: Tensor, b: Tensor): Tensor {\n // We duplicate Add here to avoid a circular dependency with add.ts.\n const inputs = {a, b};\n return ENGINE.runKernel(Add, inputs as {} as NamedTensorMap);\n}\n", "/**\n * @license\n * Copyright 2017 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n// tslint:disable-next-line:no-any\nfunction _isNavigatorDefined(): boolean {\n return typeof navigator !== 'undefined' && navigator != null;\n}\n\nexport function isMobile(nav?: Navigator): boolean {\n if (nav || _isNavigatorDefined()) {\n if (!nav) {\n nav = navigator;\n }\n if (nav.product === 'ReactNative') {\n return true;\n }\n\n // tslint:disable-next-line:no-any\n const a = nav.userAgent || nav.vendor || (window as any).opera;\n // tslint:disable-next-line:max-line-length\n return /(android|bb\\d+|meego).+mobile|avantgo|bada\\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\\.(browser|link)|vodafone|wap|windows ce|xda|xiino/i\n .test(a) ||\n // tslint:disable-next-line:max-line-length\n /1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\\-(n|u)|c55\\/|capi|ccwa|cdm\\-|cell|chtm|cldc|cmd\\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\\-s|devi|dica|dmob|do(c|p)o|ds(12|\\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\\-|_)|g1 u|g560|gene|gf\\-5|g\\-mo|go(\\.w|od)|gr(ad|un)|haie|hcit|hd\\-(m|p|t)|hei\\-|hi(pt|ta)|hp( i|ip)|hs\\-c|ht(c(\\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\\-(20|go|ma)|i230|iac( |\\-|\\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\\/)|klon|kpt |kwc\\-|kyo(c|k)|le(no|xi)|lg( g|\\/(k|l|u)|50|54|\\-[a-w])|libw|lynx|m1\\-w|m3ga|m50\\/|ma(te|ui|xo)|mc(01|21|ca)|m\\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\\-2|po(ck|rt|se)|prox|psio|pt\\-g|qa\\-a|qc(07|12|21|32|60|\\-[2-7]|i\\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\\-|oo|p\\-)|sdk\\/|se(c(\\-|0|1)|47|mc|nd|ri)|sgh\\-|shar|sie(\\-|m)|sk\\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\\-|v\\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\\-|tdg\\-|tel(i|m)|tim\\-|t\\-mo|to(pl|sh)|ts(70|m\\-|m3|m5)|tx\\-9|up(\\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\\-|your|zeto|zte\\-/i\n .test(a.substr(0, 4));\n }\n return false;\n}\n\nexport function isBrowser(): boolean {\n return (typeof window !== 'undefined' && window.document != null) ||\n //@ts-ignore\n (typeof WorkerGlobalScope !== 'undefined');\n}\n", "/**\n * @license\n * Copyright 2019 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\nimport './engine';\n\nimport * as device_util from './device_util';\nimport {env} from './environment';\n\nconst ENV = env();\n\n/**\n * This file contains environment-related flag registrations.\n */\n\n/** Whether to enable debug mode. */\nENV.registerFlag('DEBUG', () => false, debugValue => {\n if (debugValue) {\n console.warn(\n 'Debugging mode is ON. The output of every math call will ' +\n 'be downloaded to CPU and checked for NaNs. ' +\n 'This significantly impacts performance.');\n }\n});\n\n/** Whether we are in a browser (as versus, say, node.js) environment. */\nENV.registerFlag('IS_BROWSER', () => device_util.isBrowser());\n\n/** Whether we are in a browser (as versus, say, node.js) environment. */\nENV.registerFlag(\n 'IS_NODE',\n () => (typeof process !== 'undefined') &&\n (typeof process.versions !== 'undefined') &&\n (typeof process.versions.node !== 'undefined'));\n\n/** Whether this browser is Chrome. */\nENV.registerFlag(\n 'IS_CHROME',\n () => typeof navigator !== 'undefined' && navigator != null &&\n navigator.userAgent != null && /Chrome/.test(navigator.userAgent) &&\n /Google Inc/.test(navigator.vendor));\n\n/**\n * True when the environment is \"production\" where we disable safety checks\n * to gain performance.\n */\nENV.registerFlag('PROD', () => false);\n\n/**\n * Whether to do sanity checks when inferring a shape from user-provided\n * values, used when creating a new tensor.\n */\nENV.registerFlag(\n 'TENSORLIKE_CHECK_SHAPE_CONSISTENCY', () => ENV.getBool('DEBUG'));\n\n/** Whether deprecation warnings are enabled. */\nENV.registerFlag('DEPRECATION_WARNINGS_ENABLED', () => true);\n\n/** True if running unit tests. */\nENV.registerFlag('IS_TEST', () => false);\n\n/** Whether to check computation result for errors. */\nENV.registerFlag('CHECK_COMPUTATION_FOR_ERRORS', () => true);\n\n/** Whether the backend needs to wrap input to imageBitmap. */\nENV.registerFlag('WRAP_TO_IMAGEBITMAP', () => false);\n", "/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENGINE} from './engine';\nimport {env} from './environment';\nimport {Tensor} from './tensor';\nimport {DataType, TensorLike} from './types';\nimport {assert, flatten, inferDtype, isTypedArray, toTypedArray} from './util';\n\nexport function inferShape(val: TensorLike, dtype?: DataType): number[] {\n let firstElem: typeof val = val;\n\n if (isTypedArray(val)) {\n return dtype === 'string' ? [] : [val.length];\n }\n if (!Array.isArray(val)) {\n return []; // Scalar.\n }\n const shape: number[] = [];\n\n while (Array.isArray(firstElem) ||\n isTypedArray(firstElem) && dtype !== 'string') {\n shape.push(firstElem.length);\n firstElem = firstElem[0];\n }\n if (Array.isArray(val) &&\n env().getBool('TENSORLIKE_CHECK_SHAPE_CONSISTENCY')) {\n deepAssertShapeConsistency(val, shape, []);\n }\n\n return shape;\n}\n\nfunction deepAssertShapeConsistency(\n val: TensorLike, shape: number[], indices: number[]) {\n indices = indices || [];\n if (!(Array.isArray(val)) && !isTypedArray(val)) {\n assert(\n shape.length === 0,\n () => `Element arr[${indices.join('][')}] is a primitive, ` +\n `but should be an array/TypedArray of ${shape[0]} elements`);\n return;\n }\n assert(\n shape.length > 0,\n () => `Element arr[${indices.join('][')}] should be a primitive, ` +\n `but is an array of ${val.length} elements`);\n assert(\n val.length === shape[0],\n () => `Element arr[${indices.join('][')}] should have ${shape[0]} ` +\n `elements, but has ${val.length} elements`);\n const subShape = shape.slice(1);\n for (let i = 0; i < val.length; ++i) {\n deepAssertShapeConsistency(val[i], subShape, indices.concat(i));\n }\n}\n\nfunction assertDtype(\n expectedDtype: DataType|'numeric'|'string_or_numeric',\n actualDType: DataType, argName: string, functionName: string) {\n if (expectedDtype === 'string_or_numeric') {\n return;\n }\n if (expectedDtype == null) {\n throw new Error(`Expected dtype cannot be null.`);\n }\n if (expectedDtype !== 'numeric' && expectedDtype !== actualDType ||\n expectedDtype === 'numeric' && actualDType === 'string') {\n throw new Error(\n `Argument '${argName}' passed to '${functionName}' must ` +\n `be ${expectedDtype} tensor, but got ${actualDType} tensor`);\n }\n}\n\nexport function convertToTensor(\n x: T|TensorLike, argName: string, functionName: string,\n parseAsDtype: DataType|'numeric'|'string_or_numeric' = 'numeric'): T {\n if (x instanceof Tensor) {\n assertDtype(parseAsDtype, x.dtype, argName, functionName);\n return x;\n }\n let inferredDtype = inferDtype(x);\n // If the user expects a bool/int/float, use that info to update the\n // inferredDtype when it is not a string.\n if (inferredDtype !== 'string' &&\n ['bool', 'int32', 'float32'].indexOf(parseAsDtype) >= 0) {\n inferredDtype = parseAsDtype as DataType;\n }\n assertDtype(parseAsDtype, inferredDtype, argName, functionName);\n\n if ((x == null) ||\n (!isTypedArray(x) && !Array.isArray(x) && typeof x !== 'number' &&\n typeof x !== 'boolean' && typeof x !== 'string')) {\n const type = x == null ? 'null' : (x as {}).constructor.name;\n throw new Error(\n `Argument '${argName}' passed to '${functionName}' must be a ` +\n `Tensor or TensorLike, but got '${type}'`);\n }\n const inferredShape = inferShape(x, inferredDtype);\n if (!isTypedArray(x) && !Array.isArray(x)) {\n x = [x] as number[];\n }\n const skipTypedArray = true;\n const values = inferredDtype !== 'string' ?\n toTypedArray(x, inferredDtype as DataType) :\n flatten(x as string[], [], skipTypedArray) as string[];\n return ENGINE.makeTensor(values, inferredShape, inferredDtype) as T;\n}\n\nexport function convertToTensorArray(\n arg: Array, argName: string, functionName: string,\n parseAsDtype: DataType|'numeric'|'string_or_numeric' = 'numeric'): T[] {\n if (!Array.isArray(arg)) {\n throw new Error(\n `Argument ${argName} passed to ${functionName} must be a ` +\n '`Tensor[]` or `TensorLike[]`');\n }\n const tensors = arg as T[];\n return tensors.map(\n (t, i) =>\n convertToTensor(t, `${argName}[${i}]`, functionName, parseAsDtype));\n}\n", "/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\nimport {ENGINE} from '../engine';\nimport {isPromise} from '../util';\n\nexport const OP_SCOPE_SUFFIX = '__op';\n\n/**\n * Used for wrapping functions that perform math operations on\n * Tensors. The function will be wrapped in a named scope that cleans all\n * memory usage after the function is done.\n */\nexport function op(f: {[name: string]: T}): T {\n const keys = Object.keys(f);\n if (keys.length !== 1) {\n throw new Error(\n `Please provide an object with a single key ` +\n `(operation name) mapping to a function. Got an object with ` +\n `${keys.length} keys.`);\n }\n\n let opName = keys[0];\n const fn = f[opName];\n\n // Strip the underscore from the end of the function name.\n if (opName.endsWith('_')) {\n opName = opName.substring(0, opName.length - 1);\n }\n\n // add an __op suffix to distinguish ops from kernels in tf.profile\n opName = opName + OP_SCOPE_SUFFIX;\n\n // tslint:disable-next-line:no-any\n const f2 = (...args: any[]) => {\n ENGINE.startScope(opName);\n try {\n const result = fn(...args);\n if (isPromise(result)) {\n console.error('Cannot return a Promise inside of tidy.');\n }\n ENGINE.endScope(result);\n return result;\n } catch (ex) {\n ENGINE.endScope(null);\n throw ex;\n }\n };\n Object.defineProperty(f2, 'name', {value: opName, configurable: true});\n\n // tslint:disable-next-line:no-any\n return f2 as any as T;\n}\n", "/**\n * @license\n * Copyright 2020 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\nimport {ENGINE} from '../engine';\nimport {Complex, ComplexInputs} from '../kernel_names';\nimport {Tensor} from '../tensor';\nimport {NamedTensorMap} from '../tensor_types';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\n\nimport {op} from './operation';\n\n/**\n * Converts two real numbers to a complex number.\n *\n * Given a tensor `real` representing the real part of a complex number, and a\n * tensor `imag` representing the imaginary part of a complex number, this\n * operation returns complex numbers elementwise of the form [r0, i0, r1, i1],\n * where r represents the real part and i represents the imag part.\n *\n * The input tensors real and imag must have the same shape.\n *\n * ```js\n * const real = tf.tensor1d([2.25, 3.25]);\n * const imag = tf.tensor1d([4.75, 5.75]);\n * const complex = tf.complex(real, imag);\n *\n * complex.print();\n * ```\n *\n * @doc {heading: 'Tensors', subheading: 'Creation'}\n */\nfunction complex_(real: T|TensorLike, imag: T|TensorLike): T {\n const $real = convertToTensor(real, 'real', 'complex');\n const $imag = convertToTensor(imag, 'imag', 'complex');\n util.assertShapesMatch(\n $real.shape, $imag.shape,\n `real and imag shapes, ${$real.shape} and ${$imag.shape}, ` +\n `must match in call to tf.complex().`);\n\n const inputs: ComplexInputs = {real: $real, imag: $imag};\n return ENGINE.runKernel(Complex, inputs as {} as NamedTensorMap);\n}\n\nexport const complex = op({complex_});\n", "/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENGINE} from '../engine';\nimport {Tensor} from '../tensor';\nimport {TensorLike, TypedArray} from '../types';\nimport {DataType} from '../types';\nimport {assert, assertNonNegativeIntegerDimensions, flatten, inferDtype, isTypedArray, sizeFromShape, toTypedArray} from '../util';\n\n/** This is shared code across all tensor creation methods. */\nexport function makeTensor(\n values: TensorLike, shape: number[], inferredShape: number[],\n dtype?: DataType): Tensor {\n if (dtype == null) {\n dtype = inferDtype(values);\n }\n if (dtype === 'complex64') {\n throw new Error(\n `Cannot construct a complex64 tensor directly. ` +\n `Please use tf.complex(real, imag).`);\n }\n if (!isTypedArray(values) && !Array.isArray(values) &&\n typeof values !== 'number' && typeof values !== 'boolean' &&\n typeof values !== 'string') {\n throw new Error(\n 'values passed to tensor(values) must be a number/boolean/string or ' +\n 'an array of numbers/booleans/strings, or a TypedArray');\n }\n if (shape != null) {\n assertNonNegativeIntegerDimensions(shape);\n\n const providedSize = sizeFromShape(shape);\n const inferredSize = sizeFromShape(inferredShape);\n assert(\n providedSize === inferredSize,\n () =>\n `Based on the provided shape, [${shape}], the tensor should have ` +\n `${providedSize} values but has ${inferredSize}`);\n\n for (let i = 0; i < inferredShape.length; ++i) {\n const inferred = inferredShape[i];\n const flatDimsDontMatch = i === inferredShape.length - 1 ?\n inferred !== sizeFromShape(shape.slice(i)) :\n true;\n assert(\n inferredShape[i] === shape[i] || !flatDimsDontMatch,\n () => `Error creating a new Tensor. Inferred shape ` +\n `(${inferredShape}) does not match the provided ` +\n `shape (${shape}). `);\n }\n }\n\n if (!isTypedArray(values) && !Array.isArray(values)) {\n values = [values] as number[];\n }\n\n shape = shape || inferredShape;\n values = dtype !== 'string' ?\n toTypedArray(values, dtype) :\n flatten(values as string[], [], true) as string[];\n return ENGINE.makeTensor(values as TypedArray, shape, dtype);\n}\n", "/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor} from '../tensor';\nimport {inferShape} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport {DataType, Rank, ShapeMap} from '../types';\n\nimport {makeTensor} from './tensor_ops_util';\n\n/**\n * Creates a `tf.Tensor` with the provided values, shape and dtype.\n *\n * ```js\n * // Pass an array of values to create a vector.\n * tf.tensor([1, 2, 3, 4]).print();\n * ```\n *\n * ```js\n * // Pass a nested array of values to make a matrix or a higher\n * // dimensional tensor.\n * tf.tensor([[1, 2], [3, 4]]).print();\n * ```\n *\n * ```js\n * // Pass a flat array and specify a shape yourself.\n * tf.tensor([1, 2, 3, 4], [2, 2]).print();\n * ```\n *\n * @param values The values of the tensor. Can be nested array of numbers,\n * or a flat array, or a `TypedArray`. If the values are strings,\n * they will be encoded as utf-8 and kept as `Uint8Array[]`.\n * @param shape The shape of the tensor. Optional. If not provided,\n * it is inferred from `values`.\n * @param dtype The data type.\n *\n * @doc {heading: 'Tensors', subheading: 'Creation'}\n */\nexport function tensor(\n values: TensorLike, shape?: ShapeMap[R], dtype?: DataType): Tensor {\n const inferredShape = inferShape(values, dtype);\n return makeTensor(values, shape, inferredShape, dtype) as Tensor;\n}\n", "/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/* Type definitions for exporting and importing of models. */\n\n/**\n * A map from Tensor dtype to number of bytes per element of the Tensor.\n */\nexport const DTYPE_VALUE_SIZE_MAP: {[dtype: string]: number} = {\n 'float32': 4,\n 'float16': 2,\n 'int32': 4,\n 'uint16': 2,\n 'uint8': 1,\n 'bool': 1,\n 'complex64': 8\n};\n\n/**\n * A weight manifest.\n *\n * The weight manifest consists of an ordered list of weight-manifest groups.\n * Each weight-manifest group (\"group\" for short hereafter) consists of a\n * number of weight values stored in a number of paths.\n * See the documentation of `WeightManifestGroupConfig` below for more details.\n */\nexport declare type WeightsManifestConfig = WeightsManifestGroupConfig[];\n\n/**\n * A weight-manifest group.\n *\n * Consists of an ordered list of weight values encoded in binary format,\n * stored in an ordered list of paths.\n */\nexport declare interface WeightsManifestGroupConfig {\n /**\n * An ordered list of paths.\n *\n * Paths are intentionally abstract in order to be general. For example, they\n * can be relative URL paths or relative paths on the file system.\n */\n paths: string[];\n\n /**\n * Specifications of the weights stored in the paths.\n */\n weights: WeightsManifestEntry[];\n}\n\n/**\n * Group to which the weight belongs.\n *\n * - 'optimizer': Weight from a stateful optimizer.\n */\nexport type WeightGroup = 'model'|'optimizer';\n\n/**\n * An entry in the weight manifest.\n *\n * The entry contains specification of a weight.\n */\nexport declare interface WeightsManifestEntry {\n /**\n * Name of the weight, e.g., 'Dense_1/bias'\n */\n name: string;\n\n /**\n * Shape of the weight.\n */\n shape: number[];\n\n /**\n * Data type of the weight.\n */\n dtype: 'float32'|'int32'|'bool'|'string'|'complex64';\n\n /**\n * Type of the weight.\n *\n * Optional.\n *\n * The value 'optimizer' indicates the weight belongs to an optimizer\n * (i.e., used only during model training and not during inference).\n */\n group?: WeightGroup;\n\n /**\n * Information for dequantization of the weight.\n */\n quantization?: {\n scale?: number, // The scaling constant to multiply by.\n min?: number, // The (possibly nudged) minimum weight to add.\n dtype: 'uint16'|'uint8'|'float16' // The dtype of the quantized weights.\n };\n}\n\n/**\n * Options for saving a model.\n * @innamespace io\n */\nexport interface SaveConfig {\n /**\n * Whether to save only the trainable weights of the model, ignoring the\n * non-trainable ones.\n */\n trainableOnly?: boolean;\n\n /**\n * Whether the optimizer will be saved (if exists).\n *\n * Default: `false`.\n */\n includeOptimizer?: boolean;\n}\n\n/**\n * Result of a saving operation.\n */\nexport interface SaveResult {\n /**\n * Information about the model artifacts saved.\n */\n modelArtifactsInfo: ModelArtifactsInfo;\n\n /**\n * HTTP responses from the server that handled the model-saving request (if\n * any). This is applicable only to server-based saving routes.\n */\n responses?: Response[];\n\n /**\n * Error messages and related data (if any).\n */\n errors?: Array<{}|string>;\n}\n\nexport declare interface ModelArtifactsInfo {\n /**\n * Timestamp for when the model is saved.\n */\n dateSaved: Date;\n\n /**\n * TODO (cais,yassogba) consider removing GraphDef as GraphDefs now\n * come in a JSON format and none of our IOHandlers support a non json\n * format. We could conder replacing this with 'Binary' if we want to\n * allow future handlers to save to non json formats (though they will\n * probably want more information than 'Binary').\n * Type of the model topology\n *\n * Type of the model topology\n *\n * Possible values:\n * - JSON: JSON config (human-readable, e.g., Keras JSON).\n * - GraphDef: TensorFlow\n * [GraphDef](https://www.tensorflow.org/extend/tool_developers/#graphdef)\n * protocol buffer (binary).\n */\n modelTopologyType: 'JSON'|'GraphDef';\n\n /**\n * Size of model topology (Keras JSON or GraphDef), in bytes.\n */\n modelTopologyBytes?: number;\n\n /**\n * Size of weight specification or manifest, in bytes.\n */\n weightSpecsBytes?: number;\n\n /**\n * Size of weight value data, in bytes.\n */\n weightDataBytes?: number;\n}\n\n/** Model training configuration. */\nexport declare interface TrainingConfig {\n // TODO(cais): Tighten the typing once keras spec is available to tfjs-core.\n // See\n // tslint:disable-next-line:max-line-length\n // https://github.com/tensorflow/tfjs-layers/blob/master/src/keras_format/training_config.ts\n /** Optimizer used for the model training. */\n optimizer_config: {};\n\n // TODO(cais): Tighten the typing once keras spec is available to tfjs-core.\n /** Loss function(s) for the model's output(s). */\n loss: string|string[]|{[key: string]: string};\n\n // TODO(cais): Tighten the typing once keras spec is available to tfjs-core.\n /** Metric function(s) for the model's output(s). */\n metrics?: string[]|{[key: string]: string};\n\n // TODO(cais): Tighten the typing once keras spec is available to tfjs-core.\n weighted_metrics?: string[];\n\n // TODO(cais): Tighten the typing once keras spec is available to tfjs-core.\n sample_weight_mode?: string;\n\n loss_weights?: number[]|{[key: string]: number};\n}\n\n/**\n * The serialized artifacts of a model, including topology and weights.\n *\n * The `modelTopology`, `trainingConfig`, `weightSpecs` and `weightData` fields\n * of this interface are optional, in order to support topology- or weights-only\n * saving and loading.\n *\n * Note this interface is used internally in IOHandlers. For the file format\n * written to disk as `model.json`, see `ModelJSON`.\n */\nexport declare interface ModelArtifacts {\n /**\n * Model topology.\n *\n * For Keras-style `tf.Model`s, this is a JSON object.\n * For TensorFlow-style models (e.g., `SavedModel`), this is the JSON\n * encoding of the `GraphDef` protocol buffer.\n */\n modelTopology?: {}|ArrayBuffer;\n\n /**\n * Serialized configuration for the model's training.\n */\n trainingConfig?: TrainingConfig;\n\n /**\n * Weight specifications.\n *\n * This corresponds to the weightsData below.\n */\n weightSpecs?: WeightsManifestEntry[];\n\n /**\n * Binary buffer for all weight values concatenated in the order specified\n * by `weightSpecs`.\n */\n weightData?: ArrayBuffer;\n\n /**\n * Hard-coded format name for models saved from TensorFlow.js or converted\n * by TensorFlow.js Converter.\n */\n format?: string;\n\n /**\n * What library is responsible for originally generating this artifact.\n *\n * Used for debugging purposes. E.g., 'TensorFlow.js v1.0.0'.\n */\n generatedBy?: string;\n\n /**\n * What library or tool is responsible for converting the original model\n * to this format, applicable only if the model is output by a converter.\n *\n * Used for debugging purposes. E.g., 'TensorFlow.js Converter v1.0.0'.\n *\n * A value of `null` means the model artifacts are generated without any\n * conversion process (e.g., saved directly from a TensorFlow.js\n * `tf.LayersModel` instance.)\n */\n convertedBy?: string|null;\n\n /**\n * Inputs and outputs signature for saved model.\n */\n signature?: {};\n\n /**\n * User-defined metadata about the model.\n */\n userDefinedMetadata?: {[key: string]: {}};\n\n /**\n * Initializer for the model.\n */\n modelInitializer?: {};\n}\n\n/**\n * The on-disk format of the `model.json` file.\n *\n * TF.js 1.0 always populates the optional fields when writing model.json.\n * Prior versions did not provide those fields.\n */\nexport declare interface ModelJSON {\n /**\n * Model topology.\n *\n * For Keras-style `tf.Model`s, this is a JSON object.\n * For TensorFlow-style models (e.g., `SavedModel`), this is the JSON\n * encoding of the `GraphDef` protocol buffer.\n */\n modelTopology: {};\n\n /** Model training configuration. */\n trainingConfig?: TrainingConfig;\n\n /**\n * Weights manifest.\n *\n * The weights manifest consists of an ordered list of weight-manifest\n * groups. Each weight-manifest group consists of a number of weight values\n * stored in a number of paths. See the documentation of\n * `WeightsManifestConfig` for more details.\n */\n weightsManifest: WeightsManifestConfig;\n\n /**\n * Hard-coded format name for models saved from TensorFlow.js or converted\n * by TensorFlow.js Converter.\n */\n format?: string;\n\n /**\n * What library is responsible for originally generating this artifact.\n *\n * Used for debugging purposes. E.g., 'TensorFlow.js v1.0.0'.\n */\n generatedBy?: string;\n\n /**\n * What library or tool is responsible for converting the original model\n * to this format, applicable only if the model is output by a converter.\n *\n * Used for debugging purposes. E.g., 'TensorFlow.js Converter v1.0.0'.\n *\n * A value of `null` means the model artifacts are generated without any\n * conversion process (e.g., saved directly from a TensorFlow.js\n * `tf.LayersModel` instance.)\n */\n convertedBy?: string|null;\n\n /**\n * Inputs and outputs signature for saved model.\n */\n signature?: {};\n\n /**\n * User-defined metadata about the model.\n */\n userDefinedMetadata?: {[key: string]: {}};\n\n /**\n * Initializer for the model.\n */\n modelInitializer?: {};\n}\n\n/**\n * Type definition for handlers of loading operations.\n */\nexport type LoadHandler = () => Promise;\n\n/**\n * Type definition for handlers of saving operations.\n */\nexport type SaveHandler = (modelArtifact: ModelArtifacts) =>\n Promise;\n\n/**\n * Interface for a model import/export handler.\n *\n * The `save` and `load` handlers are both optional, in order to allow handlers\n * that support only saving or loading.\n */\n// tslint:disable-next-line:interface-name\nexport interface IOHandler {\n save?: SaveHandler;\n load?: LoadHandler;\n}\n\n/**\n * An interface for the manager of a model store.\n *\n * A model store is defined as a storage medium on which multiple models can\n * be stored. Each stored model has a unique `path` as its identifier.\n * A `ModelStoreManager` for the store allows actions including\n *\n * - Listing the models stored in the store.\n * - Deleting a model from the store.\n */\nexport interface ModelStoreManager {\n /**\n * List all models in the model store.\n *\n * @returns A dictionary mapping paths of existing models to their\n * model artifacts info. Model artifacts info include type of the model's\n * topology, byte sizes of the topology, weights, etc.\n */\n listModels(): Promise<{[path: string]: ModelArtifactsInfo}>;\n\n /**\n * Remove a model specified by `path`.\n *\n * @param path\n * @returns ModelArtifactsInfo of the deleted model (if and only if deletion\n * is successful).\n * @throws Error if deletion fails, e.g., if no model exists at `path`.\n */\n removeModel(path: string): Promise;\n}\n\n/**\n * Callback for the progress of a long-running action such as an HTTP\n * request for a large binary object.\n *\n * `fraction` should be a number in the [0, 1] interval, indicating how\n * much of the action has completed.\n */\nexport type OnProgressCallback = (fraction: number) => void;\n\n/** @innamespace io */\nexport interface LoadOptions {\n /**\n * RequestInit (options) for HTTP requests.\n *\n * For detailed information on the supported fields, see\n * [https://developer.mozilla.org/en-US/docs/Web/API/Request/Request](\n * https://developer.mozilla.org/en-US/docs/Web/API/Request/Request)\n */\n requestInit?: RequestInit;\n\n /**\n * Progress callback.\n */\n onProgress?: OnProgressCallback;\n\n /**\n * A function used to override the `window.fetch` function.\n */\n fetchFunc?: Function;\n\n /**\n * Strict loading model: whether extraneous weights or missing\n * weights should trigger an `Error`.\n *\n * If `true`, require that the provided weights exactly match those\n * required by the layers. `false` means that both extra weights\n * and missing weights will be silently ignored.\n *\n * Default: `true`.\n */\n strict?: boolean;\n\n /**\n * Path prefix for weight files, by default this is calculated from the\n * path of the model JSON file.\n *\n * For instance, if the path to the model JSON file is\n * `http://localhost/foo/model.json`, then the default path prefix will be\n * `http://localhost/foo/`. If a weight file has the path value\n * `group1-shard1of2` in the weight manifest, then the weight file will be\n * loaded from `http://localhost/foo/group1-shard1of2` by default. However,\n * if you provide a `weightPathPrefix` value of\n * `http://localhost/foo/alt-weights`, then the weight file will be loaded\n * from the path `http://localhost/foo/alt-weights/group1-shard1of2` instead.\n */\n weightPathPrefix?: string;\n\n /**\n * Whether the module or model is to be loaded from TF Hub.\n *\n * Setting this to `true` allows passing a TF-Hub module URL, omitting the\n * standard model file name and the query parameters.\n *\n * Default: `false`.\n */\n fromTFHub?: boolean;\n\n /**\n * An async function to convert weight file name to URL. The weight file\n * names are stored in model.json's weightsManifest.paths field. By default we\n * consider weight files are colocated with the model.json file. For example:\n * model.json URL: https://www.google.com/models/1/model.json\n * group1-shard1of1.bin url:\n * https://www.google.com/models/1/group1-shard1of1.bin\n *\n * With this func you can convert the weight file name to any URL.\n */\n weightUrlConverter?: (weightFileName: string) => Promise;\n}\n\n/**\n * Additional options for Platform.fetch\n */\nexport interface RequestDetails {\n /**\n * Is this request for a binary file (as opposed to a json file)\n */\n isBinary?: boolean;\n}\n", "/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {complex} from '../ops/complex';\n\nimport {tensor} from '../ops/tensor';\nimport {NamedTensor, NamedTensorMap} from '../tensor_types';\nimport {TypedArray} from '../types';\nimport {sizeFromShape} from '../util';\n\nimport {DTYPE_VALUE_SIZE_MAP, ModelArtifacts, ModelArtifactsInfo, WeightGroup, WeightsManifestEntry} from './types';\n\n/** Number of bytes reserved for the length of the string. (32bit integer). */\nconst NUM_BYTES_STRING_LENGTH = 4;\n\n/**\n * Encode a map from names to weight values as an ArrayBuffer, along with an\n * `Array` of `WeightsManifestEntry` as specification of the encoded weights.\n *\n * This function does not perform sharding.\n *\n * This function is the reverse of `decodeWeights`.\n *\n * @param tensors A map (\"dict\") from names to tensors.\n * @param group Group to which the weights belong (optional).\n * @returns A `Promise` of\n * - A flat `ArrayBuffer` with all the binary values of the `Tensor`s\n * concatenated.\n * - An `Array` of `WeightManifestEntry`s, carrying information including\n * tensor names, `dtype`s and shapes.\n * @throws Error: on unsupported tensor `dtype`.\n */\nexport async function encodeWeights(\n tensors: NamedTensorMap|NamedTensor[], group?: WeightGroup):\n Promise<{data: ArrayBuffer, specs: WeightsManifestEntry[]}> {\n // TODO(adarob, cais): Support quantization.\n const specs: WeightsManifestEntry[] = [];\n const dataPromises: Array> = [];\n\n const names: string[] = Array.isArray(tensors) ?\n tensors.map(tensor => tensor.name) :\n Object.keys(tensors);\n\n for (let i = 0; i < names.length; ++i) {\n const name = names[i];\n const t = Array.isArray(tensors) ? tensors[i].tensor : tensors[name];\n if (t.dtype !== 'float32' && t.dtype !== 'int32' && t.dtype !== 'bool' &&\n t.dtype !== 'string' && t.dtype !== 'complex64') {\n throw new Error(`Unsupported dtype in weight '${name}': ${t.dtype}`);\n }\n const spec: WeightsManifestEntry = {name, shape: t.shape, dtype: t.dtype};\n if (t.dtype === 'string') {\n const utf8bytes = new Promise(async resolve => {\n const vals = await t.bytes() as Uint8Array[];\n const totalNumBytes = vals.reduce((p, c) => p + c.length, 0) +\n NUM_BYTES_STRING_LENGTH * vals.length;\n const bytes = new Uint8Array(totalNumBytes);\n let offset = 0;\n for (let i = 0; i < vals.length; i++) {\n const val = vals[i];\n const bytesOfLength =\n new Uint8Array(new Uint32Array([val.length]).buffer);\n bytes.set(bytesOfLength, offset);\n offset += NUM_BYTES_STRING_LENGTH;\n bytes.set(val, offset);\n offset += val.length;\n }\n resolve(bytes);\n });\n dataPromises.push(utf8bytes);\n } else {\n dataPromises.push(t.data());\n }\n if (group != null) {\n spec.group = group;\n }\n specs.push(spec);\n }\n\n const tensorValues = await Promise.all(dataPromises);\n return {data: concatenateTypedArrays(tensorValues), specs};\n}\n\n/**\n * Decode flat ArrayBuffer as weights.\n *\n * This function does not handle sharding.\n *\n * This function is the reverse of `encodeWeights`.\n *\n * @param buffer A flat ArrayBuffer carrying the binary values of the tensors\n * concatenated in the order specified in `specs`.\n * @param specs Specifications of the names, dtypes and shapes of the tensors\n * whose value are encoded by `buffer`.\n * @return A map from tensor name to tensor value, with the names corresponding\n * to names in `specs`.\n * @throws Error, if any of the tensors has unsupported dtype.\n */\nexport function decodeWeights(\n buffer: ArrayBuffer, specs: WeightsManifestEntry[]): NamedTensorMap {\n // TODO(adarob, cais): Support quantization.\n const out: NamedTensorMap = {};\n let float16Decode: (buffer: Uint16Array) => Float32Array | undefined;\n let offset = 0;\n for (const spec of specs) {\n const name = spec.name;\n const dtype = spec.dtype;\n const shape = spec.shape;\n const size = sizeFromShape(shape);\n let values: TypedArray|string[]|Uint8Array[];\n\n if ('quantization' in spec) {\n const quantization = spec.quantization;\n if (quantization.dtype === 'uint8' || quantization.dtype === 'uint16') {\n if (!('min' in quantization && 'scale' in quantization)) {\n throw new Error(\n `Weight ${spec.name} with quantization ${quantization.dtype} ` +\n `doesn't have corresponding metadata min and scale.`);\n }\n } else if (quantization.dtype === 'float16') {\n if (dtype !== 'float32') {\n throw new Error(\n `Weight ${spec.name} is quantized with ${quantization.dtype} ` +\n `which only supports weights of type float32 not ${dtype}.`);\n }\n } else {\n throw new Error(\n `Weight ${spec.name} has unknown ` +\n `quantization dtype ${quantization.dtype}. ` +\n `Supported quantization dtypes are: ` +\n `'uint8', 'uint16', and 'float16'.`);\n }\n const quantizationSizeFactor = DTYPE_VALUE_SIZE_MAP[quantization.dtype];\n const byteBuffer =\n buffer.slice(offset, offset + size * quantizationSizeFactor);\n const quantizedArray = (quantization.dtype === 'uint8') ?\n new Uint8Array(byteBuffer) :\n new Uint16Array(byteBuffer);\n if (dtype === 'float32') {\n if (quantization.dtype === 'uint8' || quantization.dtype === 'uint16') {\n values = new Float32Array(quantizedArray.length);\n for (let i = 0; i < quantizedArray.length; i++) {\n const v = quantizedArray[i];\n values[i] = v * quantization.scale + quantization.min;\n }\n } else if (quantization.dtype === 'float16') {\n if (float16Decode === undefined) {\n float16Decode = getFloat16Decoder();\n }\n values = float16Decode(quantizedArray as Uint16Array);\n } else {\n throw new Error(\n `Unsupported quantization type ${quantization.dtype} ` +\n `for weight type float32.`);\n }\n } else if (dtype === 'int32') {\n if (quantization.dtype !== 'uint8' && quantization.dtype !== 'uint16') {\n throw new Error(\n `Unsupported quantization type ${quantization.dtype} ` +\n `for weight type int32.`);\n }\n values = new Int32Array(quantizedArray.length);\n for (let i = 0; i < quantizedArray.length; i++) {\n const v = quantizedArray[i];\n values[i] = Math.round(v * quantization.scale + quantization.min);\n }\n } else {\n throw new Error(`Unsupported dtype in weight '${name}': ${dtype}`);\n }\n offset += size * quantizationSizeFactor;\n } else if (dtype === 'string') {\n const size = sizeFromShape(spec.shape);\n values = [];\n for (let i = 0; i < size; i++) {\n const byteLength = new Uint32Array(\n buffer.slice(offset, offset + NUM_BYTES_STRING_LENGTH))[0];\n offset += NUM_BYTES_STRING_LENGTH;\n const bytes = new Uint8Array(buffer.slice(offset, offset + byteLength));\n (values as Uint8Array[]).push(bytes);\n offset += byteLength;\n }\n } else {\n const dtypeFactor = DTYPE_VALUE_SIZE_MAP[dtype];\n const byteBuffer = buffer.slice(offset, offset + size * dtypeFactor);\n\n if (dtype === 'float32') {\n values = new Float32Array(byteBuffer);\n } else if (dtype === 'int32') {\n values = new Int32Array(byteBuffer);\n } else if (dtype === 'bool') {\n values = new Uint8Array(byteBuffer);\n } else if (dtype === 'complex64') {\n values = new Float32Array(byteBuffer);\n const real = new Float32Array(values.length / 2);\n const image = new Float32Array(values.length / 2);\n for (let i = 0; i < real.length; i++) {\n real[i] = values[i * 2];\n image[i] = values[i * 2 + 1];\n }\n const realTensor = tensor(real, shape, 'float32');\n const imageTensor = tensor(image, shape, 'float32');\n out[name] = complex(realTensor, imageTensor);\n realTensor.dispose();\n imageTensor.dispose();\n } else {\n throw new Error(`Unsupported dtype in weight '${name}': ${dtype}`);\n }\n offset += size * dtypeFactor;\n }\n if (dtype !== 'complex64') {\n out[name] = tensor(values, shape, dtype);\n }\n }\n return out;\n}\n\n/**\n * Concatenate TypedArrays into an ArrayBuffer.\n */\nexport function concatenateTypedArrays(xs: TypedArray[]): ArrayBuffer {\n // TODO(adarob, cais): Support quantization.\n if (xs === null) {\n throw new Error(`Invalid input value: ${JSON.stringify(xs)}`);\n }\n\n let totalByteLength = 0;\n\n // `normalizedXs` is here for this reason: a `TypedArray`'s `buffer'\n // can have a different byte length from that of the `TypedArray` itself,\n // for example, when the `TypedArray` is created from an offset in an\n // `ArrayBuffer`. `normliazedXs` holds `TypedArray`s whose `buffer`s match\n // the `TypedArray` in byte length. If an element of `xs` does not show\n // this property, a new `TypedArray` that satisfy this property will be\n // constructed and pushed into `normalizedXs`.\n const normalizedXs: TypedArray[] = [];\n xs.forEach((x: TypedArray) => {\n totalByteLength += x.byteLength;\n // tslint:disable:no-any\n normalizedXs.push(\n x.byteLength === x.buffer.byteLength ? x :\n new (x.constructor as any)(x));\n if (!(x as any instanceof Float32Array || x as any instanceof Int32Array ||\n x as any instanceof Uint8Array)) {\n throw new Error(`Unsupported TypedArray subtype: ${x.constructor.name}`);\n }\n // tslint:enable:no-any\n });\n\n const y = new Uint8Array(totalByteLength);\n let offset = 0;\n normalizedXs.forEach((x: TypedArray) => {\n y.set(new Uint8Array(x.buffer), offset);\n offset += x.byteLength;\n });\n\n return y.buffer;\n}\n\n// Use Buffer on Node.js instead of Blob/atob/btoa\nconst useNodeBuffer = typeof Buffer !== 'undefined' &&\n (typeof Blob === 'undefined' || typeof atob === 'undefined' ||\n typeof btoa === 'undefined');\n\n/**\n * Calculate the byte length of a JavaScript string.\n *\n * Note that a JavaScript string can contain wide characters, therefore the\n * length of the string is not necessarily equal to the byte length.\n *\n * @param str Input string.\n * @returns Byte length.\n */\nexport function stringByteLength(str: string): number {\n if (useNodeBuffer) {\n return Buffer.byteLength(str);\n }\n return new Blob([str]).size;\n}\n\n/**\n * Encode an ArrayBuffer as a base64 encoded string.\n *\n * @param buffer `ArrayBuffer` to be converted.\n * @returns A string that base64-encodes `buffer`.\n */\nexport function arrayBufferToBase64String(buffer: ArrayBuffer): string {\n if (useNodeBuffer) {\n return Buffer.from(buffer).toString('base64');\n }\n const buf = new Uint8Array(buffer);\n let s = '';\n for (let i = 0, l = buf.length; i < l; i++) {\n s += String.fromCharCode(buf[i]);\n }\n return btoa(s);\n}\n\n/**\n * Decode a base64 string as an ArrayBuffer.\n *\n * @param str Base64 string.\n * @returns Decoded `ArrayBuffer`.\n */\nexport function base64StringToArrayBuffer(str: string): ArrayBuffer {\n if (useNodeBuffer) {\n const buf = Buffer.from(str, 'base64');\n return buf.buffer.slice(buf.byteOffset, buf.byteOffset + buf.byteLength);\n }\n const s = atob(str);\n const buffer = new Uint8Array(s.length);\n for (let i = 0; i < s.length; ++i) {\n buffer.set([s.charCodeAt(i)], i);\n }\n return buffer.buffer;\n}\n\n/**\n * Concatenate a number of ArrayBuffers into one.\n *\n * @param buffers A number of array buffers to concatenate.\n * @returns Result of concatenating `buffers` in order.\n */\nexport function concatenateArrayBuffers(buffers: ArrayBuffer[]): ArrayBuffer {\n if (buffers.length === 1) {\n return buffers[0];\n }\n\n let totalByteLength = 0;\n buffers.forEach((buffer: ArrayBuffer) => {\n totalByteLength += buffer.byteLength;\n });\n\n const temp = new Uint8Array(totalByteLength);\n let offset = 0;\n buffers.forEach((buffer: ArrayBuffer) => {\n temp.set(new Uint8Array(buffer), offset);\n offset += buffer.byteLength;\n });\n return temp.buffer;\n}\n\n/**\n * Get the basename of a path.\n *\n * Behaves in a way analogous to Linux's basename command.\n *\n * @param path\n */\nexport function basename(path: string): string {\n const SEPARATOR = '/';\n path = path.trim();\n while (path.endsWith(SEPARATOR)) {\n path = path.slice(0, path.length - 1);\n }\n const items = path.split(SEPARATOR);\n return items[items.length - 1];\n}\n\n/**\n * Populate ModelArtifactsInfo fields for a model with JSON topology.\n * @param modelArtifacts\n * @returns A ModelArtifactsInfo object.\n */\nexport function getModelArtifactsInfoForJSON(modelArtifacts: ModelArtifacts):\n ModelArtifactsInfo {\n if (modelArtifacts.modelTopology instanceof ArrayBuffer) {\n throw new Error('Expected JSON model topology, received ArrayBuffer.');\n }\n\n return {\n dateSaved: new Date(),\n modelTopologyType: 'JSON',\n modelTopologyBytes: modelArtifacts.modelTopology == null ?\n 0 :\n stringByteLength(JSON.stringify(modelArtifacts.modelTopology)),\n weightSpecsBytes: modelArtifacts.weightSpecs == null ?\n 0 :\n stringByteLength(JSON.stringify(modelArtifacts.weightSpecs)),\n weightDataBytes: modelArtifacts.weightData == null ?\n 0 :\n modelArtifacts.weightData.byteLength,\n };\n}\n\n/**\n * Computes mantisa table for casting Float16 to Float32\n * See http://www.fox-toolkit.org/ftp/fasthalffloatconversion.pdf\n *\n * @returns Uint32Array, 2048 mantissa lookup values.\n */\nfunction computeFloat16MantisaTable(): Uint32Array {\n const convertMantissa = (i: number): number => {\n let m = i << 13;\n let e = 0;\n\n while ((m & 0x00800000) === 0) {\n e -= 0x00800000;\n m <<= 1;\n }\n m &= ~0x00800000;\n e += 0x38800000;\n\n return m | e;\n };\n\n const mantisaTable = new Uint32Array(2048);\n\n mantisaTable[0] = 0;\n for (let i = 1; i < 1024; i++) {\n mantisaTable[i] = convertMantissa(i);\n }\n for (let i = 1024; i < 2048; i++) {\n mantisaTable[i] = 0x38000000 + ((i - 1024) << 13);\n }\n\n return mantisaTable;\n}\n\n/**\n * Computes exponent table for casting Float16 to Float32\n * See http://www.fox-toolkit.org/ftp/fasthalffloatconversion.pdf\n *\n * @returns Uint32Array, 64 exponent lookup values.\n */\nfunction computeFloat16ExponentTable(): Uint32Array {\n const exponentTable = new Uint32Array(64);\n\n exponentTable[0] = 0;\n exponentTable[31] = 0x47800000;\n exponentTable[32] = 0x80000000;\n exponentTable[63] = 0xc7800000;\n for (let i = 1; i < 31; i++) {\n exponentTable[i] = i << 23;\n }\n for (let i = 33; i < 63; i++) {\n exponentTable[i] = 0x80000000 + ((i - 32) << 23);\n }\n\n return exponentTable;\n}\n\n/**\n * Computes offset table for casting Float16 to Float32\n * See http://www.fox-toolkit.org/ftp/fasthalffloatconversion.pdf\n *\n * @returns Uint32Array, 6d offset values.\n */\nfunction computeFloat16OffsetTable(): Uint32Array {\n const offsetTable = new Uint32Array(64);\n\n for (let i = 0; i < 64; i++) {\n offsetTable[i] = 1024;\n }\n offsetTable[0] = offsetTable[32] = 0;\n\n return offsetTable;\n}\n\n/**\n * Retrieve a Float16 decoder which will decode a ByteArray of Float16 values\n * to a Float32Array.\n *\n * @returns Function (buffer: Uint16Array) => Float32Array which decodes\n * the Uint16Array of Float16 bytes to a Float32Array.\n */\nexport function getFloat16Decoder(): (buffer: Uint16Array) => Float32Array {\n // Algorithm is based off of\n // http://www.fox-toolkit.org/ftp/fasthalffloatconversion.pdf\n\n // Cache lookup tables\n const mantisaTable = computeFloat16MantisaTable();\n const exponentTable = computeFloat16ExponentTable();\n const offsetTable = computeFloat16OffsetTable();\n\n return (quantizedArray: Uint16Array) => {\n const buffer = new ArrayBuffer(4 * quantizedArray.length);\n const bufferUint32View = new Uint32Array(buffer);\n for (let index = 0; index < quantizedArray.length; index++) {\n const float16Bits = quantizedArray[index];\n const float32Bits =\n mantisaTable[offsetTable[float16Bits >> 10] + (float16Bits & 0x3ff)] +\n exponentTable[float16Bits >> 10];\n bufferUint32View[index] = float32Bits;\n }\n return new Float32Array(buffer);\n };\n}\n", "/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {IOHandler, LoadOptions} from './types';\n\nexport type IORouter = (url: string|string[], loadOptions?: LoadOptions) =>\n IOHandler;\n\nexport class IORouterRegistry {\n // Singleton instance.\n private static instance: IORouterRegistry;\n\n private saveRouters: IORouter[];\n private loadRouters: IORouter[];\n\n private constructor() {\n this.saveRouters = [];\n this.loadRouters = [];\n }\n\n private static getInstance(): IORouterRegistry {\n if (IORouterRegistry.instance == null) {\n IORouterRegistry.instance = new IORouterRegistry();\n }\n return IORouterRegistry.instance;\n }\n\n /**\n * Register a save-handler router.\n *\n * @param saveRouter A function that maps a URL-like string onto an instance\n * of `IOHandler` with the `save` method defined or `null`.\n */\n static registerSaveRouter(saveRouter: IORouter) {\n IORouterRegistry.getInstance().saveRouters.push(saveRouter);\n }\n\n /**\n * Register a load-handler router.\n *\n * @param loadRouter A function that maps a URL-like string onto an instance\n * of `IOHandler` with the `load` method defined or `null`.\n */\n static registerLoadRouter(loadRouter: IORouter) {\n IORouterRegistry.getInstance().loadRouters.push(loadRouter);\n }\n\n /**\n * Look up IOHandler for saving, given a URL-like string.\n *\n * @param url\n * @returns If only one match is found, an instance of IOHandler with the\n * `save` method defined. If no match is found, `null`.\n * @throws Error, if more than one match is found.\n */\n static getSaveHandlers(url: string|string[]): IOHandler[] {\n return IORouterRegistry.getHandlers(url, 'save');\n }\n\n /**\n * Look up IOHandler for loading, given a URL-like string.\n *\n * @param url\n * @param loadOptions Optional, custom load options.\n * @returns All valid handlers for `url`, given the currently registered\n * handler routers.\n */\n static getLoadHandlers(url: string|string[], loadOptions?: LoadOptions):\n IOHandler[] {\n return IORouterRegistry.getHandlers(url, 'load', loadOptions);\n }\n\n private static getHandlers(\n url: string|string[], handlerType: 'save'|'load',\n loadOptions?: LoadOptions): IOHandler[] {\n const validHandlers: IOHandler[] = [];\n const routers = handlerType === 'load' ?\n IORouterRegistry.getInstance().loadRouters :\n IORouterRegistry.getInstance().saveRouters;\n routers.forEach(router => {\n const handler = router(url, loadOptions);\n if (handler !== null) {\n validHandlers.push(handler);\n }\n });\n return validHandlers;\n }\n}\n\nexport const registerSaveRouter = (loudRouter: IORouter) =>\n IORouterRegistry.registerSaveRouter(loudRouter);\nexport const registerLoadRouter = (loudRouter: IORouter) =>\n IORouterRegistry.registerLoadRouter(loudRouter);\nexport const getSaveHandlers = (url: string|string[]) =>\n IORouterRegistry.getSaveHandlers(url);\nexport const getLoadHandlers =\n (url: string|string[], loadOptions?: LoadOptions) =>\n IORouterRegistry.getLoadHandlers(url, loadOptions);\n", "/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport '../flags';\n\nimport {env} from '../environment';\n\nimport {getModelArtifactsInfoForJSON} from './io_utils';\nimport {IORouter, IORouterRegistry} from './router_registry';\nimport {IOHandler, ModelArtifacts, ModelArtifactsInfo, ModelStoreManager, SaveResult} from './types';\n\nconst DATABASE_NAME = 'tensorflowjs';\nconst DATABASE_VERSION = 1;\n\n// Model data and ModelArtifactsInfo (metadata) are stored in two separate\n// stores for efficient access of the list of stored models and their metadata.\n// 1. The object store for model data: topology, weights and weight manifests.\nconst MODEL_STORE_NAME = 'models_store';\n// 2. The object store for ModelArtifactsInfo, including meta-information such\n// as the type of topology (JSON vs binary), byte size of the topology, byte\n// size of the weights, etc.\nconst INFO_STORE_NAME = 'model_info_store';\n\n/**\n * Delete the entire database for tensorflow.js, including the models store.\n */\nexport async function deleteDatabase(): Promise {\n const idbFactory = getIndexedDBFactory();\n\n return new Promise((resolve, reject) => {\n const deleteRequest = idbFactory.deleteDatabase(DATABASE_NAME);\n deleteRequest.onsuccess = () => resolve();\n deleteRequest.onerror = error => reject(error);\n });\n}\n\nfunction getIndexedDBFactory(): IDBFactory {\n if (!env().getBool('IS_BROWSER')) {\n // TODO(cais): Add more info about what IOHandler subtypes are available.\n // Maybe point to a doc page on the web and/or automatically determine\n // the available IOHandlers and print them in the error message.\n throw new Error(\n 'Failed to obtain IndexedDB factory because the current environment' +\n 'is not a web browser.');\n }\n // tslint:disable-next-line:no-any\n const theWindow: any = typeof window === 'undefined' ? self : window;\n const factory = theWindow.indexedDB || theWindow.mozIndexedDB ||\n theWindow.webkitIndexedDB || theWindow.msIndexedDB ||\n theWindow.shimIndexedDB;\n if (factory == null) {\n throw new Error(\n 'The current browser does not appear to support IndexedDB.');\n }\n return factory;\n}\n\nfunction setUpDatabase(openRequest: IDBRequest) {\n const db = openRequest.result as IDBDatabase;\n db.createObjectStore(MODEL_STORE_NAME, {keyPath: 'modelPath'});\n db.createObjectStore(INFO_STORE_NAME, {keyPath: 'modelPath'});\n}\n\n/**\n * IOHandler subclass: Browser IndexedDB.\n *\n * See the doc string of `browserIndexedDB` for more details.\n */\nexport class BrowserIndexedDB implements IOHandler {\n protected readonly indexedDB: IDBFactory;\n protected readonly modelPath: string;\n\n static readonly URL_SCHEME = 'indexeddb://';\n\n constructor(modelPath: string) {\n this.indexedDB = getIndexedDBFactory();\n\n if (modelPath == null || !modelPath) {\n throw new Error(\n 'For IndexedDB, modelPath must not be null, undefined or empty.');\n }\n this.modelPath = modelPath;\n }\n\n async save(modelArtifacts: ModelArtifacts): Promise {\n // TODO(cais): Support saving GraphDef models.\n if (modelArtifacts.modelTopology instanceof ArrayBuffer) {\n throw new Error(\n 'BrowserLocalStorage.save() does not support saving model topology ' +\n 'in binary formats yet.');\n }\n\n return this.databaseAction(this.modelPath, modelArtifacts) as\n Promise;\n }\n\n async load(): Promise {\n return this.databaseAction(this.modelPath) as Promise;\n }\n\n /**\n * Perform database action to put model artifacts into or read model artifacts\n * from IndexedDB object store.\n *\n * Whether the action is put or get depends on whether `modelArtifacts` is\n * specified. If it is specified, the action will be put; otherwise the action\n * will be get.\n *\n * @param modelPath A unique string path for the model.\n * @param modelArtifacts If specified, it will be the model artifacts to be\n * stored in IndexedDB.\n * @returns A `Promise` of `SaveResult`, if the action is put, or a `Promise`\n * of `ModelArtifacts`, if the action is get.\n */\n private databaseAction(modelPath: string, modelArtifacts?: ModelArtifacts):\n Promise {\n return new Promise((resolve, reject) => {\n const openRequest = this.indexedDB.open(DATABASE_NAME, DATABASE_VERSION);\n openRequest.onupgradeneeded = () => setUpDatabase(openRequest);\n\n openRequest.onsuccess = () => {\n const db = openRequest.result;\n\n if (modelArtifacts == null) {\n // Read model out from object store.\n const modelTx = db.transaction(MODEL_STORE_NAME, 'readonly');\n const modelStore = modelTx.objectStore(MODEL_STORE_NAME);\n const getRequest = modelStore.get(this.modelPath);\n getRequest.onsuccess = () => {\n if (getRequest.result == null) {\n db.close();\n return reject(new Error(\n `Cannot find model with path '${this.modelPath}' ` +\n `in IndexedDB.`));\n } else {\n resolve(getRequest.result.modelArtifacts);\n }\n };\n getRequest.onerror = error => {\n db.close();\n return reject(getRequest.error);\n };\n modelTx.oncomplete = () => db.close();\n } else {\n // Put model into object store.\n const modelArtifactsInfo: ModelArtifactsInfo =\n getModelArtifactsInfoForJSON(modelArtifacts);\n // First, put ModelArtifactsInfo into info store.\n const infoTx = db.transaction(INFO_STORE_NAME, 'readwrite');\n let infoStore = infoTx.objectStore(INFO_STORE_NAME);\n const putInfoRequest =\n infoStore.put({modelPath: this.modelPath, modelArtifactsInfo});\n let modelTx: IDBTransaction;\n putInfoRequest.onsuccess = () => {\n // Second, put model data into model store.\n modelTx = db.transaction(MODEL_STORE_NAME, 'readwrite');\n const modelStore = modelTx.objectStore(MODEL_STORE_NAME);\n const putModelRequest = modelStore.put({\n modelPath: this.modelPath,\n modelArtifacts,\n modelArtifactsInfo\n });\n putModelRequest.onsuccess = () => resolve({modelArtifactsInfo});\n putModelRequest.onerror = error => {\n // If the put-model request fails, roll back the info entry as\n // well.\n infoStore = infoTx.objectStore(INFO_STORE_NAME);\n const deleteInfoRequest = infoStore.delete(this.modelPath);\n deleteInfoRequest.onsuccess = () => {\n db.close();\n return reject(putModelRequest.error);\n };\n deleteInfoRequest.onerror = error => {\n db.close();\n return reject(putModelRequest.error);\n };\n };\n };\n putInfoRequest.onerror = error => {\n db.close();\n return reject(putInfoRequest.error);\n };\n infoTx.oncomplete = () => {\n if (modelTx == null) {\n db.close();\n } else {\n modelTx.oncomplete = () => db.close();\n }\n };\n }\n };\n openRequest.onerror = error => reject(openRequest.error);\n });\n }\n}\n\nexport const indexedDBRouter: IORouter = (url: string|string[]) => {\n if (!env().getBool('IS_BROWSER')) {\n return null;\n } else {\n if (!Array.isArray(url) && url.startsWith(BrowserIndexedDB.URL_SCHEME)) {\n return browserIndexedDB(url.slice(BrowserIndexedDB.URL_SCHEME.length));\n } else {\n return null;\n }\n }\n};\nIORouterRegistry.registerSaveRouter(indexedDBRouter);\nIORouterRegistry.registerLoadRouter(indexedDBRouter);\n\n/**\n * Creates a browser IndexedDB IOHandler for saving and loading models.\n *\n * ```js\n * const model = tf.sequential();\n * model.add(\n * tf.layers.dense({units: 1, inputShape: [100], activation: 'sigmoid'}));\n *\n * const saveResult = await model.save('indexeddb://MyModel'));\n * console.log(saveResult);\n * ```\n *\n * @param modelPath A unique identifier for the model to be saved. Must be a\n * non-empty string.\n * @returns An instance of `BrowserIndexedDB` (sublcass of `IOHandler`),\n * which can be used with, e.g., `tf.Model.save`.\n */\nexport function browserIndexedDB(modelPath: string): IOHandler {\n return new BrowserIndexedDB(modelPath);\n}\n\nfunction maybeStripScheme(key: string) {\n return key.startsWith(BrowserIndexedDB.URL_SCHEME) ?\n key.slice(BrowserIndexedDB.URL_SCHEME.length) :\n key;\n}\n\nexport class BrowserIndexedDBManager implements ModelStoreManager {\n private indexedDB: IDBFactory;\n\n constructor() {\n this.indexedDB = getIndexedDBFactory();\n }\n\n async listModels(): Promise<{[path: string]: ModelArtifactsInfo}> {\n return new Promise<{[path: string]: ModelArtifactsInfo}>(\n (resolve, reject) => {\n const openRequest =\n this.indexedDB.open(DATABASE_NAME, DATABASE_VERSION);\n openRequest.onupgradeneeded = () => setUpDatabase(openRequest);\n\n openRequest.onsuccess = () => {\n const db = openRequest.result;\n const tx = db.transaction(INFO_STORE_NAME, 'readonly');\n const store = tx.objectStore(INFO_STORE_NAME);\n // tslint:disable:max-line-length\n // Need to cast `store` as `any` here because TypeScript's DOM\n // library does not have the `getAll()` method even though the\n // method is supported in the latest version of most mainstream\n // browsers:\n // https://developer.mozilla.org/en-US/docs/Web/API/IDBObjectStore/getAll\n // tslint:enable:max-line-length\n // tslint:disable-next-line:no-any\n const getAllInfoRequest = (store as any).getAll() as IDBRequest;\n getAllInfoRequest.onsuccess = () => {\n const out: {[path: string]: ModelArtifactsInfo} = {};\n for (const item of getAllInfoRequest.result) {\n out[item.modelPath] = item.modelArtifactsInfo;\n }\n resolve(out);\n };\n getAllInfoRequest.onerror = error => {\n db.close();\n return reject(getAllInfoRequest.error);\n };\n tx.oncomplete = () => db.close();\n };\n openRequest.onerror = error => reject(openRequest.error);\n });\n }\n\n async removeModel(path: string): Promise {\n path = maybeStripScheme(path);\n return new Promise((resolve, reject) => {\n const openRequest = this.indexedDB.open(DATABASE_NAME, DATABASE_VERSION);\n openRequest.onupgradeneeded = () => setUpDatabase(openRequest);\n\n openRequest.onsuccess = () => {\n const db = openRequest.result;\n const infoTx = db.transaction(INFO_STORE_NAME, 'readwrite');\n const infoStore = infoTx.objectStore(INFO_STORE_NAME);\n\n const getInfoRequest = infoStore.get(path);\n let modelTx: IDBTransaction;\n getInfoRequest.onsuccess = () => {\n if (getInfoRequest.result == null) {\n db.close();\n return reject(new Error(\n `Cannot find model with path '${path}' ` +\n `in IndexedDB.`));\n } else {\n // First, delete the entry in the info store.\n const deleteInfoRequest = infoStore.delete(path);\n const deleteModelData = () => {\n // Second, delete the entry in the model store.\n modelTx = db.transaction(MODEL_STORE_NAME, 'readwrite');\n const modelStore = modelTx.objectStore(MODEL_STORE_NAME);\n const deleteModelRequest = modelStore.delete(path);\n deleteModelRequest.onsuccess = () =>\n resolve(getInfoRequest.result.modelArtifactsInfo);\n deleteModelRequest.onerror = error =>\n reject(getInfoRequest.error);\n };\n // Proceed with deleting model data regardless of whether deletion\n // of info data succeeds or not.\n deleteInfoRequest.onsuccess = deleteModelData;\n deleteInfoRequest.onerror = error => {\n deleteModelData();\n db.close();\n return reject(getInfoRequest.error);\n };\n }\n };\n getInfoRequest.onerror = error => {\n db.close();\n return reject(getInfoRequest.error);\n };\n\n infoTx.oncomplete = () => {\n if (modelTx == null) {\n db.close();\n } else {\n modelTx.oncomplete = () => db.close();\n }\n };\n };\n openRequest.onerror = error => reject(openRequest.error);\n });\n }\n}\n", "/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport '../flags';\nimport {env} from '../environment';\n\nimport {assert} from '../util';\nimport {arrayBufferToBase64String, base64StringToArrayBuffer, getModelArtifactsInfoForJSON} from './io_utils';\nimport {IORouter, IORouterRegistry} from './router_registry';\nimport {IOHandler, ModelArtifacts, ModelArtifactsInfo, ModelStoreManager, SaveResult} from './types';\n\nconst PATH_SEPARATOR = '/';\nconst PATH_PREFIX = 'tensorflowjs_models';\nconst INFO_SUFFIX = 'info';\nconst MODEL_TOPOLOGY_SUFFIX = 'model_topology';\nconst WEIGHT_SPECS_SUFFIX = 'weight_specs';\nconst WEIGHT_DATA_SUFFIX = 'weight_data';\nconst MODEL_METADATA_SUFFIX = 'model_metadata';\n\n/**\n * Purge all tensorflow.js-saved model artifacts from local storage.\n *\n * @returns Paths of the models purged.\n */\nexport function purgeLocalStorageArtifacts(): string[] {\n if (!env().getBool('IS_BROWSER') || typeof window === 'undefined' ||\n typeof window.localStorage === 'undefined') {\n throw new Error(\n 'purgeLocalStorageModels() cannot proceed because local storage is ' +\n 'unavailable in the current environment.');\n }\n const LS = window.localStorage;\n const purgedModelPaths: string[] = [];\n for (let i = 0; i < LS.length; ++i) {\n const key = LS.key(i);\n const prefix = PATH_PREFIX + PATH_SEPARATOR;\n if (key.startsWith(prefix) && key.length > prefix.length) {\n LS.removeItem(key);\n const modelName = getModelPathFromKey(key);\n if (purgedModelPaths.indexOf(modelName) === -1) {\n purgedModelPaths.push(modelName);\n }\n }\n }\n return purgedModelPaths;\n}\n\nfunction getModelKeys(path: string): {\n info: string,\n topology: string,\n weightSpecs: string,\n weightData: string,\n modelMetadata: string\n} {\n return {\n info: [PATH_PREFIX, path, INFO_SUFFIX].join(PATH_SEPARATOR),\n topology: [PATH_PREFIX, path, MODEL_TOPOLOGY_SUFFIX].join(PATH_SEPARATOR),\n weightSpecs: [PATH_PREFIX, path, WEIGHT_SPECS_SUFFIX].join(PATH_SEPARATOR),\n weightData: [PATH_PREFIX, path, WEIGHT_DATA_SUFFIX].join(PATH_SEPARATOR),\n modelMetadata:\n [PATH_PREFIX, path, MODEL_METADATA_SUFFIX].join(PATH_SEPARATOR)\n };\n}\n\n/**\n * Get model path from a local-storage key.\n *\n * E.g., 'tensorflowjs_models/my/model/1/info' --> 'my/model/1'\n *\n * @param key\n */\nfunction getModelPathFromKey(key: string) {\n const items = key.split(PATH_SEPARATOR);\n if (items.length < 3) {\n throw new Error(`Invalid key format: ${key}`);\n }\n return items.slice(1, items.length - 1).join(PATH_SEPARATOR);\n}\n\nfunction maybeStripScheme(key: string) {\n return key.startsWith(BrowserLocalStorage.URL_SCHEME) ?\n key.slice(BrowserLocalStorage.URL_SCHEME.length) :\n key;\n}\n\ndeclare type LocalStorageKeys = {\n info: string,\n topology: string,\n weightSpecs: string,\n weightData: string,\n modelMetadata: string\n};\n\n/**\n * IOHandler subclass: Browser Local Storage.\n *\n * See the doc string to `browserLocalStorage` for more details.\n */\nexport class BrowserLocalStorage implements IOHandler {\n protected readonly LS: Storage;\n protected readonly modelPath: string;\n protected readonly keys: LocalStorageKeys;\n\n static readonly URL_SCHEME = 'localstorage://';\n\n constructor(modelPath: string) {\n if (!env().getBool('IS_BROWSER') || typeof window === 'undefined' ||\n typeof window.localStorage === 'undefined') {\n // TODO(cais): Add more info about what IOHandler subtypes are\n // available.\n // Maybe point to a doc page on the web and/or automatically determine\n // the available IOHandlers and print them in the error message.\n throw new Error(\n 'The current environment does not support local storage.');\n }\n this.LS = window.localStorage;\n\n if (modelPath == null || !modelPath) {\n throw new Error(\n 'For local storage, modelPath must not be null, undefined or empty.');\n }\n this.modelPath = modelPath;\n this.keys = getModelKeys(this.modelPath);\n }\n\n /**\n * Save model artifacts to browser local storage.\n *\n * See the documentation to `browserLocalStorage` for details on the saved\n * artifacts.\n *\n * @param modelArtifacts The model artifacts to be stored.\n * @returns An instance of SaveResult.\n */\n async save(modelArtifacts: ModelArtifacts): Promise {\n if (modelArtifacts.modelTopology instanceof ArrayBuffer) {\n throw new Error(\n 'BrowserLocalStorage.save() does not support saving model topology ' +\n 'in binary formats yet.');\n } else {\n const topology = JSON.stringify(modelArtifacts.modelTopology);\n const weightSpecs = JSON.stringify(modelArtifacts.weightSpecs);\n\n const modelArtifactsInfo: ModelArtifactsInfo =\n getModelArtifactsInfoForJSON(modelArtifacts);\n\n try {\n this.LS.setItem(this.keys.info, JSON.stringify(modelArtifactsInfo));\n this.LS.setItem(this.keys.topology, topology);\n this.LS.setItem(this.keys.weightSpecs, weightSpecs);\n this.LS.setItem(\n this.keys.weightData,\n arrayBufferToBase64String(modelArtifacts.weightData));\n const result: ModelArtifacts = {\n format: modelArtifacts.format,\n generatedBy: modelArtifacts.generatedBy,\n convertedBy: modelArtifacts.convertedBy\n };\n if (modelArtifacts.signature != null) {\n result.signature = modelArtifacts.signature;\n }\n if (modelArtifacts.userDefinedMetadata != null) {\n result.userDefinedMetadata = modelArtifacts.userDefinedMetadata;\n }\n if (modelArtifacts.modelInitializer != null) {\n result.modelInitializer = modelArtifacts.modelInitializer;\n }\n this.LS.setItem(this.keys.modelMetadata, JSON.stringify(result));\n\n return {modelArtifactsInfo};\n } catch (err) {\n // If saving failed, clean up all items saved so far.\n this.LS.removeItem(this.keys.info);\n this.LS.removeItem(this.keys.topology);\n this.LS.removeItem(this.keys.weightSpecs);\n this.LS.removeItem(this.keys.weightData);\n this.LS.removeItem(this.keys.modelMetadata);\n\n throw new Error(\n `Failed to save model '${this.modelPath}' to local storage: ` +\n `size quota being exceeded is a possible cause of this failure: ` +\n `modelTopologyBytes=${modelArtifactsInfo.modelTopologyBytes}, ` +\n `weightSpecsBytes=${modelArtifactsInfo.weightSpecsBytes}, ` +\n `weightDataBytes=${modelArtifactsInfo.weightDataBytes}.`);\n }\n }\n }\n\n /**\n * Load a model from local storage.\n *\n * See the documentation to `browserLocalStorage` for details on the saved\n * artifacts.\n *\n * @returns The loaded model (if loading succeeds).\n */\n async load(): Promise {\n const info =\n JSON.parse(this.LS.getItem(this.keys.info)) as ModelArtifactsInfo;\n if (info == null) {\n throw new Error(\n `In local storage, there is no model with name '${this.modelPath}'`);\n }\n\n if (info.modelTopologyType !== 'JSON') {\n throw new Error(\n 'BrowserLocalStorage does not support loading non-JSON model ' +\n 'topology yet.');\n }\n\n const out: ModelArtifacts = {};\n\n // Load topology.\n const topology = JSON.parse(this.LS.getItem(this.keys.topology));\n if (topology == null) {\n throw new Error(\n `In local storage, the topology of model '${this.modelPath}' ` +\n `is missing.`);\n }\n out.modelTopology = topology;\n\n // Load weight specs.\n const weightSpecs = JSON.parse(this.LS.getItem(this.keys.weightSpecs));\n if (weightSpecs == null) {\n throw new Error(\n `In local storage, the weight specs of model '${this.modelPath}' ` +\n `are missing.`);\n }\n out.weightSpecs = weightSpecs;\n\n // Load meta-data fields.\n const metadataString = this.LS.getItem(this.keys.modelMetadata);\n if (metadataString != null) {\n const metadata = JSON.parse(metadataString) as ModelArtifacts;\n out.format = metadata['format'];\n out.generatedBy = metadata['generatedBy'];\n out.convertedBy = metadata['convertedBy'];\n if (metadata['signature'] != null) {\n out.signature = metadata['signature'];\n }\n if (metadata['userDefinedMetadata'] != null) {\n out.userDefinedMetadata = metadata['userDefinedMetadata'];\n }\n if (metadata['modelInitializer'] != null) {\n out.modelInitializer = metadata['modelInitializer'];\n }\n }\n\n // Load weight data.\n const weightDataBase64 = this.LS.getItem(this.keys.weightData);\n if (weightDataBase64 == null) {\n throw new Error(\n `In local storage, the binary weight values of model ` +\n `'${this.modelPath}' are missing.`);\n }\n out.weightData = base64StringToArrayBuffer(weightDataBase64);\n\n return out;\n }\n}\n\nexport const localStorageRouter: IORouter = (url: string|string[]) => {\n if (!env().getBool('IS_BROWSER')) {\n return null;\n } else {\n if (!Array.isArray(url) && url.startsWith(BrowserLocalStorage.URL_SCHEME)) {\n return browserLocalStorage(\n url.slice(BrowserLocalStorage.URL_SCHEME.length));\n } else {\n return null;\n }\n }\n};\nIORouterRegistry.registerSaveRouter(localStorageRouter);\nIORouterRegistry.registerLoadRouter(localStorageRouter);\n\n/**\n * Factory function for local storage IOHandler.\n *\n * This `IOHandler` supports both `save` and `load`.\n *\n * For each model's saved artifacts, four items are saved to local storage.\n * - `${PATH_SEPARATOR}/${modelPath}/info`: Contains meta-info about the\n * model, such as date saved, type of the topology, size in bytes, etc.\n * - `${PATH_SEPARATOR}/${modelPath}/topology`: Model topology. For Keras-\n * style models, this is a stringized JSON.\n * - `${PATH_SEPARATOR}/${modelPath}/weight_specs`: Weight specs of the\n * model, can be used to decode the saved binary weight values (see\n * item below).\n * - `${PATH_SEPARATOR}/${modelPath}/weight_data`: Concatenated binary\n * weight values, stored as a base64-encoded string.\n *\n * Saving may throw an `Error` if the total size of the artifacts exceed the\n * browser-specific quota.\n *\n * @param modelPath A unique identifier for the model to be saved. Must be a\n * non-empty string.\n * @returns An instance of `IOHandler`, which can be used with, e.g.,\n * `tf.Model.save`.\n */\nexport function browserLocalStorage(modelPath: string): IOHandler {\n return new BrowserLocalStorage(modelPath);\n}\n\nexport class BrowserLocalStorageManager implements ModelStoreManager {\n private readonly LS: Storage;\n\n constructor() {\n assert(\n env().getBool('IS_BROWSER'),\n () => 'Current environment is not a web browser');\n assert(\n typeof window === 'undefined' ||\n typeof window.localStorage !== 'undefined',\n () => 'Current browser does not appear to support localStorage');\n this.LS = window.localStorage;\n }\n\n async listModels(): Promise<{[path: string]: ModelArtifactsInfo}> {\n const out: {[path: string]: ModelArtifactsInfo} = {};\n const prefix = PATH_PREFIX + PATH_SEPARATOR;\n const suffix = PATH_SEPARATOR + INFO_SUFFIX;\n for (let i = 0; i < this.LS.length; ++i) {\n const key = this.LS.key(i);\n if (key.startsWith(prefix) && key.endsWith(suffix)) {\n const modelPath = getModelPathFromKey(key);\n out[modelPath] = JSON.parse(this.LS.getItem(key)) as ModelArtifactsInfo;\n }\n }\n return out;\n }\n\n async removeModel(path: string): Promise {\n path = maybeStripScheme(path);\n const keys = getModelKeys(path);\n if (this.LS.getItem(keys.info) == null) {\n throw new Error(`Cannot find model at path '${path}'`);\n }\n const info = JSON.parse(this.LS.getItem(keys.info)) as ModelArtifactsInfo;\n\n this.LS.removeItem(keys.info);\n this.LS.removeItem(keys.topology);\n this.LS.removeItem(keys.weightSpecs);\n this.LS.removeItem(keys.weightData);\n return info;\n }\n}\n", "/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * Classes and functions for model management across multiple storage mediums.\n *\n * Supported client actions:\n * - Listing models on all registered storage mediums.\n * - Remove model by URL from any registered storage mediums, by using URL\n * string.\n * - Moving or copying model from one path to another in the same medium or from\n * one medium to another, by using URL strings.\n */\n\nimport {assert} from '../util';\n\nimport {IORouterRegistry} from './router_registry';\nimport {ModelArtifactsInfo, ModelStoreManager} from './types';\n\nconst URL_SCHEME_SUFFIX = '://';\n\nexport class ModelStoreManagerRegistry {\n // Singleton instance.\n private static instance: ModelStoreManagerRegistry;\n\n private managers: {[scheme: string]: ModelStoreManager};\n\n private constructor() {\n this.managers = {};\n }\n\n private static getInstance(): ModelStoreManagerRegistry {\n if (ModelStoreManagerRegistry.instance == null) {\n ModelStoreManagerRegistry.instance = new ModelStoreManagerRegistry();\n }\n return ModelStoreManagerRegistry.instance;\n }\n\n /**\n * Register a save-handler router.\n *\n * @param saveRouter A function that maps a URL-like string onto an instance\n * of `IOHandler` with the `save` method defined or `null`.\n */\n static registerManager(scheme: string, manager: ModelStoreManager) {\n assert(scheme != null, () => 'scheme must not be undefined or null.');\n if (scheme.endsWith(URL_SCHEME_SUFFIX)) {\n scheme = scheme.slice(0, scheme.indexOf(URL_SCHEME_SUFFIX));\n }\n assert(scheme.length > 0, () => 'scheme must not be an empty string.');\n const registry = ModelStoreManagerRegistry.getInstance();\n assert(\n registry.managers[scheme] == null,\n () => `A model store manager is already registered for scheme '${\n scheme}'.`);\n registry.managers[scheme] = manager;\n }\n\n static getManager(scheme: string): ModelStoreManager {\n const manager = this.getInstance().managers[scheme];\n if (manager == null) {\n throw new Error(`Cannot find model manager for scheme '${scheme}'`);\n }\n return manager;\n }\n\n static getSchemes(): string[] {\n return Object.keys(this.getInstance().managers);\n }\n}\n\n/**\n * Helper method for parsing a URL string into a scheme and a path.\n *\n * @param url E.g., 'localstorage://my-model'\n * @returns A dictionary with two fields: scheme and path.\n * Scheme: e.g., 'localstorage' in the example above.\n * Path: e.g., 'my-model' in the example above.\n */\nfunction parseURL(url: string): {scheme: string, path: string} {\n if (url.indexOf(URL_SCHEME_SUFFIX) === -1) {\n throw new Error(\n `The url string provided does not contain a scheme. ` +\n `Supported schemes are: ` +\n `${ModelStoreManagerRegistry.getSchemes().join(',')}`);\n }\n return {\n scheme: url.split(URL_SCHEME_SUFFIX)[0],\n path: url.split(URL_SCHEME_SUFFIX)[1],\n };\n}\n\nasync function cloneModelInternal(\n sourceURL: string, destURL: string,\n deleteSource = false): Promise {\n assert(\n sourceURL !== destURL,\n () => `Old path and new path are the same: '${sourceURL}'`);\n\n const loadHandlers = IORouterRegistry.getLoadHandlers(sourceURL);\n assert(\n loadHandlers.length > 0,\n () => `Copying failed because no load handler is found for source URL ${\n sourceURL}.`);\n assert(\n loadHandlers.length < 2,\n () => `Copying failed because more than one (${loadHandlers.length}) ` +\n `load handlers for source URL ${sourceURL}.`);\n const loadHandler = loadHandlers[0];\n\n const saveHandlers = IORouterRegistry.getSaveHandlers(destURL);\n assert(\n saveHandlers.length > 0,\n () => `Copying failed because no save handler is found for destination ` +\n `URL ${destURL}.`);\n assert(\n saveHandlers.length < 2,\n () => `Copying failed because more than one (${loadHandlers.length}) ` +\n `save handlers for destination URL ${destURL}.`);\n const saveHandler = saveHandlers[0];\n\n const sourceScheme = parseURL(sourceURL).scheme;\n const sourcePath = parseURL(sourceURL).path;\n const sameMedium = sourceScheme === parseURL(sourceURL).scheme;\n\n const modelArtifacts = await loadHandler.load();\n\n // If moving within the same storage medium, remove the old model as soon as\n // the loading is done. Without doing this, it is possible that the combined\n // size of the two models will cause the cloning to fail.\n if (deleteSource && sameMedium) {\n await ModelStoreManagerRegistry.getManager(sourceScheme)\n .removeModel(sourcePath);\n }\n\n const saveResult = await saveHandler.save(modelArtifacts);\n\n // If moving between mediums, the deletion is done after the save succeeds.\n // This guards against the case in which saving to the destination medium\n // fails.\n if (deleteSource && !sameMedium) {\n await ModelStoreManagerRegistry.getManager(sourceScheme)\n .removeModel(sourcePath);\n }\n\n return saveResult.modelArtifactsInfo;\n}\n\n/**\n * List all models stored in registered storage mediums.\n *\n * For a web browser environment, the registered mediums are Local Storage and\n * IndexedDB.\n *\n * ```js\n * // First create and save a model.\n * const model = tf.sequential();\n * model.add(tf.layers.dense(\n * {units: 1, inputShape: [10], activation: 'sigmoid'}));\n * await model.save('localstorage://demo/management/model1');\n *\n * // Then list existing models.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Delete the model.\n * await tf.io.removeModel('localstorage://demo/management/model1');\n *\n * // List models again.\n * console.log(JSON.stringify(await tf.io.listModels()));\n * ```\n *\n * @returns A `Promise` of a dictionary mapping URLs of existing models to\n * their model artifacts info. URLs include medium-specific schemes, e.g.,\n * 'indexeddb://my/model/1'. Model artifacts info include type of the\n * model's topology, byte sizes of the topology, weights, etc.\n *\n * @doc {\n * heading: 'Models',\n * subheading: 'Management',\n * namespace: 'io',\n * ignoreCI: true\n * }\n */\nasync function listModels(): Promise<{[url: string]: ModelArtifactsInfo}> {\n const schemes = ModelStoreManagerRegistry.getSchemes();\n const out: {[url: string]: ModelArtifactsInfo} = {};\n for (const scheme of schemes) {\n const schemeOut =\n await ModelStoreManagerRegistry.getManager(scheme).listModels();\n for (const path in schemeOut) {\n const url = scheme + URL_SCHEME_SUFFIX + path;\n out[url] = schemeOut[path];\n }\n }\n return out;\n}\n\n/**\n * Remove a model specified by URL from a reigstered storage medium.\n *\n * ```js\n * // First create and save a model.\n * const model = tf.sequential();\n * model.add(tf.layers.dense(\n * {units: 1, inputShape: [10], activation: 'sigmoid'}));\n * await model.save('localstorage://demo/management/model1');\n *\n * // Then list existing models.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Delete the model.\n * await tf.io.removeModel('localstorage://demo/management/model1');\n *\n * // List models again.\n * console.log(JSON.stringify(await tf.io.listModels()));\n * ```\n *\n * @param url A URL to a stored model, with a scheme prefix, e.g.,\n * 'localstorage://my-model-1', 'indexeddb://my/model/2'.\n * @returns ModelArtifactsInfo of the deleted model (if and only if deletion\n * is successful).\n * @throws Error if deletion fails, e.g., if no model exists at `path`.\n *\n * @doc {\n * heading: 'Models',\n * subheading: 'Management',\n * namespace: 'io',\n * ignoreCI: true\n * }\n */\nasync function removeModel(url: string): Promise {\n const schemeAndPath = parseURL(url);\n const manager = ModelStoreManagerRegistry.getManager(schemeAndPath.scheme);\n return manager.removeModel(schemeAndPath.path);\n}\n\n/**\n * Copy a model from one URL to another.\n *\n * This function supports:\n *\n * 1. Copying within a storage medium, e.g.,\n * `tf.io.copyModel('localstorage://model-1', 'localstorage://model-2')`\n * 2. Copying between two storage mediums, e.g.,\n * `tf.io.copyModel('localstorage://model-1', 'indexeddb://model-1')`\n *\n * ```js\n * // First create and save a model.\n * const model = tf.sequential();\n * model.add(tf.layers.dense(\n * {units: 1, inputShape: [10], activation: 'sigmoid'}));\n * await model.save('localstorage://demo/management/model1');\n *\n * // Then list existing models.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Copy the model, from Local Storage to IndexedDB.\n * await tf.io.copyModel(\n * 'localstorage://demo/management/model1',\n * 'indexeddb://demo/management/model1');\n *\n * // List models again.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Remove both models.\n * await tf.io.removeModel('localstorage://demo/management/model1');\n * await tf.io.removeModel('indexeddb://demo/management/model1');\n * ```\n *\n * @param sourceURL Source URL of copying.\n * @param destURL Destination URL of copying.\n * @returns ModelArtifactsInfo of the copied model (if and only if copying\n * is successful).\n * @throws Error if copying fails, e.g., if no model exists at `sourceURL`, or\n * if `oldPath` and `newPath` are identical.\n *\n * @doc {\n * heading: 'Models',\n * subheading: 'Management',\n * namespace: 'io',\n * ignoreCI: true\n * }\n */\nasync function copyModel(\n sourceURL: string, destURL: string): Promise {\n const deleteSource = false;\n return cloneModelInternal(sourceURL, destURL, deleteSource);\n}\n\n/**\n * Move a model from one URL to another.\n *\n * This function supports:\n *\n * 1. Moving within a storage medium, e.g.,\n * `tf.io.moveModel('localstorage://model-1', 'localstorage://model-2')`\n * 2. Moving between two storage mediums, e.g.,\n * `tf.io.moveModel('localstorage://model-1', 'indexeddb://model-1')`\n *\n * ```js\n * // First create and save a model.\n * const model = tf.sequential();\n * model.add(tf.layers.dense(\n * {units: 1, inputShape: [10], activation: 'sigmoid'}));\n * await model.save('localstorage://demo/management/model1');\n *\n * // Then list existing models.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Move the model, from Local Storage to IndexedDB.\n * await tf.io.moveModel(\n * 'localstorage://demo/management/model1',\n * 'indexeddb://demo/management/model1');\n *\n * // List models again.\n * console.log(JSON.stringify(await tf.io.listModels()));\n *\n * // Remove the moved model.\n * await tf.io.removeModel('indexeddb://demo/management/model1');\n * ```\n *\n * @param sourceURL Source URL of moving.\n * @param destURL Destination URL of moving.\n * @returns ModelArtifactsInfo of the copied model (if and only if copying\n * is successful).\n * @throws Error if moving fails, e.g., if no model exists at `sourceURL`, or\n * if `oldPath` and `newPath` are identical.\n *\n * @doc {\n * heading: 'Models',\n * subheading: 'Management',\n * namespace: 'io',\n * ignoreCI: true\n * }\n */\nasync function moveModel(\n sourceURL: string, destURL: string): Promise {\n const deleteSource = true;\n return cloneModelInternal(sourceURL, destURL, deleteSource);\n}\n\nexport {moveModel, copyModel, removeModel, listModels};\n", "/**\n * @license\n * Copyright 2019 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport '../flags';\n\nimport {env} from '../environment';\nimport {BrowserIndexedDB, BrowserIndexedDBManager} from '../io/indexed_db';\nimport {BrowserLocalStorage, BrowserLocalStorageManager} from '../io/local_storage';\nimport {ModelStoreManagerRegistry} from '../io/model_management';\n\nimport {Platform} from './platform';\n\nexport class PlatformBrowser implements Platform {\n // According to the spec, the built-in encoder can do only UTF-8 encoding.\n // https://developer.mozilla.org/en-US/docs/Web/API/TextEncoder/TextEncoder\n private textEncoder: TextEncoder;\n\n fetch(path: string, init?: RequestInit): Promise {\n return fetch(path, init);\n }\n\n now(): number {\n return performance.now();\n }\n\n encode(text: string, encoding: string): Uint8Array {\n if (encoding !== 'utf-8' && encoding !== 'utf8') {\n throw new Error(\n `Browser's encoder only supports utf-8, but got ${encoding}`);\n }\n if (this.textEncoder == null) {\n this.textEncoder = new TextEncoder();\n }\n return this.textEncoder.encode(text);\n }\n decode(bytes: Uint8Array, encoding: string): string {\n return new TextDecoder(encoding).decode(bytes);\n }\n}\n\nif (env().get('IS_BROWSER')) {\n env().setPlatform('browser', new PlatformBrowser());\n\n // Register LocalStorage IOHandler\n try {\n ModelStoreManagerRegistry.registerManager(\n BrowserLocalStorage.URL_SCHEME, new BrowserLocalStorageManager());\n } catch (err) {\n }\n\n // Register IndexedDB IOHandler\n try {\n ModelStoreManagerRegistry.registerManager(\n BrowserIndexedDB.URL_SCHEME, new BrowserIndexedDBManager());\n } catch (err) {\n }\n}\n", "/**\n * @license\n * Copyright 2019 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\nimport {env} from '../environment';\n\nimport {Platform} from './platform';\n\n// We are wrapping this within an object so it can be stubbed by Jasmine.\nexport const getNodeFetch = {\n // tslint:disable-next-line:no-require-imports\n importFetch: () => require('node-fetch')\n};\n\ntype FetchFn = (url: string, init?: RequestInit) => Promise;\nlet systemFetch: FetchFn;\n// These getters and setters are for testing so we don't export a mutable\n// variable.\nexport function resetSystemFetch() {\n systemFetch = null;\n}\nexport function setSystemFetch(fetchFn: FetchFn) {\n systemFetch = fetchFn;\n}\nexport function getSystemFetch(): FetchFn {\n return systemFetch;\n}\n\nexport class PlatformNode implements Platform {\n private textEncoder: TextEncoder;\n // tslint:disable-next-line:no-any\n util: any;\n\n constructor() {\n // tslint:disable-next-line:no-require-imports\n this.util = require('util');\n // According to the spec, the built-in encoder can do only UTF-8 encoding.\n // https://developer.mozilla.org/en-US/docs/Web/API/TextEncoder/TextEncoder\n this.textEncoder = new this.util.TextEncoder();\n }\n\n fetch(path: string, requestInits?: RequestInit): Promise {\n if (env().global.fetch != null) {\n return env().global.fetch(path, requestInits);\n }\n\n if (systemFetch == null) {\n systemFetch = getNodeFetch.importFetch();\n }\n return systemFetch(path, requestInits);\n }\n\n now(): number {\n const time = process.hrtime();\n return time[0] * 1000 + time[1] / 1000000;\n }\n\n encode(text: string, encoding: string): Uint8Array {\n if (encoding !== 'utf-8' && encoding !== 'utf8') {\n throw new Error(\n `Node built-in encoder only supports utf-8, but got ${encoding}`);\n }\n return this.textEncoder.encode(text);\n }\n decode(bytes: Uint8Array, encoding: string): string {\n if (bytes.length === 0) {\n return '';\n }\n return new this.util.TextDecoder(encoding).decode(bytes);\n }\n}\n\nif (env().get('IS_NODE')) {\n env().setPlatform('node', new PlatformNode());\n}\n", "/**\n * @license\n * Copyright 2020 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {TensorBuffer} from '../tensor';\nimport {DataType, DataTypeMap, Rank, ShapeMap} from '../types';\nimport * as util from '../util';\n\n/**\n * Creates an empty `tf.TensorBuffer` with the specified `shape` and `dtype`.\n *\n * The values are stored in CPU as `TypedArray`. Fill the buffer using\n * `buffer.set()`, or by modifying directly `buffer.values`.\n *\n * When done, call `buffer.toTensor()` to get an immutable `tf.Tensor` with\n * those values.\n *\n * ```js\n * // Create a buffer and set values at particular indices.\n * const buffer = tf.buffer([2, 2]);\n * buffer.set(3, 0, 0);\n * buffer.set(5, 1, 0);\n *\n * // Convert the buffer back to a tensor.\n * buffer.toTensor().print();\n * ```\n *\n * @param shape An array of integers defining the output tensor shape.\n * @param dtype The dtype of the buffer. Defaults to 'float32'.\n * @param values The values of the buffer as `TypedArray`. Defaults to\n * zeros.\n *\n * @doc {heading: 'Tensors', subheading: 'Creation'}\n */\nexport function buffer(\n shape: ShapeMap[R], dtype: D = 'float32' as D,\n values?: DataTypeMap[D]): TensorBuffer {\n dtype = dtype || 'float32' as D;\n util.assertNonNegativeIntegerDimensions(shape);\n return new TensorBuffer(shape, dtype, values);\n}\n", "/**\n * @license\n * Copyright 2020 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\nimport {ENGINE} from '../engine';\nimport {Cast, CastAttrs, CastInputs} from '../kernel_names';\nimport {NamedAttrMap} from '../kernel_registry';\nimport {Tensor} from '../tensor';\nimport {NamedTensorMap} from '../tensor_types';\nimport {convertToTensor} from '../tensor_util_env';\nimport {DataType, TensorLike} from '../types';\nimport * as util from '../util';\n\nimport {op} from './operation';\n\n/**\n * Casts a `tf.Tensor` to a new dtype.\n *\n * ```js\n * const x = tf.tensor1d([1.5, 2.5, 3]);\n * tf.cast(x, 'int32').print();\n * ```\n * @param x The input tensor to be casted.\n * @param dtype The dtype to cast the input tensor to.\n *\n * @doc {heading: 'Tensors', subheading: 'Transformations'}\n */\nfunction cast_(x: T|TensorLike, dtype: DataType): T {\n const $x = convertToTensor(x, 'x', 'cast');\n\n // Sanity checks.\n if (!util.isValidDtype(dtype)) {\n throw new Error(`Failed to cast to unknown dtype ${dtype}`);\n }\n if (dtype === 'string' && $x.dtype !== 'string' ||\n dtype !== 'string' && $x.dtype === 'string') {\n throw new Error('Only strings can be casted to strings');\n }\n\n const inputs: CastInputs = {x: $x};\n const attrs: CastAttrs = {dtype};\n\n return ENGINE.runKernel(\n Cast, inputs as {} as NamedTensorMap, attrs as {} as NamedAttrMap);\n}\n\nexport const cast = op({cast_});\n", "/**\n * @license\n * Copyright 2020 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENGINE} from '../engine';\nimport {Identity, IdentityInputs} from '../kernel_names';\nimport {Tensor} from '../tensor';\nimport {NamedTensorMap} from '../tensor_types';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\n\nimport {op} from './operation';\n\n/**\n * Creates a new tensor with the same values and shape as the specified\n * tensor.\n *\n * ```js\n * const x = tf.tensor([1, 2]);\n *\n * x.clone().print();\n * ```\n *\n * @param x The tensor to clone.\n *\n * @doc {heading: 'Tensors', subheading: 'Creation'}\n */\nfunction clone_(x: T|TensorLike): T {\n const $x = convertToTensor(x, 'x', 'clone', 'string_or_numeric');\n const inputs: IdentityInputs = {x: $x};\n\n // Note this op is called tf.identity in python. Hence the kernel name used\n // here.\n return ENGINE.runKernel(Identity, inputs as {} as NamedTensorMap);\n}\n\nexport const clone = op({clone_});\n", "/**\n * @license\n * Copyright 2020 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor} from '../tensor';\n\n/**\n * Prints information about the `tf.Tensor` including its data.\n *\n * ```js\n * const verbose = true;\n * tf.tensor2d([1, 2, 3, 4], [2, 2]).print(verbose);\n * ```\n * @param x The tensor to be printed.\n * @param verbose Whether to print verbose information about the ` Tensor`,\n * including dtype and size.\n *\n * @doc {heading: 'Tensors', subheading: 'Creation'}\n */\nexport function print(x: T, verbose = false): void {\n console.log(x.toString(verbose));\n}\n", "/**\n * @license\n * Copyright 2020 Google Inc. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n// Required side effectful code for tfjs-core\n\n// Set up Engine and ENV\nimport {getOrMakeEngine} from './engine';\ngetOrMakeEngine();\n\n// Register backend-agnostic flags.\nimport './flags';\n// Register platforms\nimport './platforms/platform_browser';\nimport './platforms/platform_node';\n\n// Set up OpHandler\nimport {buffer} from './ops/buffer';\nimport {cast} from './ops/cast';\nimport {clone} from './ops/clone';\nimport {print} from './ops/print';\nimport {OpHandler, setOpHandler} from './tensor';\nconst opHandler: OpHandler = {\n buffer,\n cast,\n clone,\n print\n};\nsetOpHandler(opHandler);\n", "/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n// Importing local_storage and indexed_db is necessary for the routers to be\n// registered.\nimport './indexed_db';\nimport './local_storage';\n\nimport {browserFiles} from './browser_files';\nimport {browserHTTPRequest, http, isHTTPScheme} from './http';\nimport {concatenateArrayBuffers, decodeWeights, encodeWeights, getModelArtifactsInfoForJSON} from './io_utils';\nimport {fromMemory, withSaveHandler} from './passthrough';\nimport {getLoadHandlers, getSaveHandlers, registerLoadRouter, registerSaveRouter} from './router_registry';\nimport {IOHandler, LoadHandler, LoadOptions, ModelArtifacts, ModelArtifactsInfo, ModelJSON, ModelStoreManager, OnProgressCallback, RequestDetails, SaveConfig, SaveHandler, SaveResult, WeightGroup, WeightsManifestConfig, WeightsManifestEntry} from './types';\nimport {loadWeights, weightsLoaderFactory} from './weights_loader';\n\nexport {copyModel, listModels, moveModel, removeModel} from './model_management';\nexport {\n browserFiles,\n browserHTTPRequest,\n concatenateArrayBuffers,\n decodeWeights,\n encodeWeights,\n fromMemory,\n getLoadHandlers,\n getModelArtifactsInfoForJSON,\n getSaveHandlers,\n http,\n IOHandler,\n isHTTPScheme,\n LoadHandler,\n LoadOptions,\n loadWeights,\n ModelArtifacts,\n ModelArtifactsInfo,\n ModelJSON,\n ModelStoreManager,\n OnProgressCallback,\n registerLoadRouter,\n registerSaveRouter,\n RequestDetails,\n SaveConfig,\n SaveHandler,\n SaveResult,\n WeightGroup,\n weightsLoaderFactory,\n WeightsManifestConfig,\n WeightsManifestEntry,\n withSaveHandler\n};\n", "/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * IOHandlers related to files, such as browser-triggered file downloads,\n * user-selected files in browser.\n */\n\nimport '../flags';\nimport {env} from '../environment';\n\nimport {basename, concatenateArrayBuffers, getModelArtifactsInfoForJSON} from './io_utils';\nimport {IORouter, IORouterRegistry} from './router_registry';\nimport {IOHandler, ModelArtifacts, ModelJSON, SaveResult, WeightsManifestConfig, WeightsManifestEntry} from './types';\n\nconst DEFAULT_FILE_NAME_PREFIX = 'model';\nconst DEFAULT_JSON_EXTENSION_NAME = '.json';\nconst DEFAULT_WEIGHT_DATA_EXTENSION_NAME = '.weights.bin';\n\nfunction defer(f: () => T): Promise {\n return new Promise(resolve => setTimeout(resolve)).then(f);\n}\n\nexport class BrowserDownloads implements IOHandler {\n private readonly modelTopologyFileName: string;\n private readonly weightDataFileName: string;\n private readonly jsonAnchor: HTMLAnchorElement;\n private readonly weightDataAnchor: HTMLAnchorElement;\n\n static readonly URL_SCHEME = 'downloads://';\n\n constructor(fileNamePrefix?: string) {\n if (!env().getBool('IS_BROWSER')) {\n // TODO(cais): Provide info on what IOHandlers are available under the\n // current environment.\n throw new Error(\n 'browserDownloads() cannot proceed because the current environment ' +\n 'is not a browser.');\n }\n\n if (fileNamePrefix.startsWith(BrowserDownloads.URL_SCHEME)) {\n fileNamePrefix = fileNamePrefix.slice(BrowserDownloads.URL_SCHEME.length);\n }\n if (fileNamePrefix == null || fileNamePrefix.length === 0) {\n fileNamePrefix = DEFAULT_FILE_NAME_PREFIX;\n }\n\n this.modelTopologyFileName = fileNamePrefix + DEFAULT_JSON_EXTENSION_NAME;\n this.weightDataFileName =\n fileNamePrefix + DEFAULT_WEIGHT_DATA_EXTENSION_NAME;\n }\n\n async save(modelArtifacts: ModelArtifacts): Promise {\n if (typeof (document) === 'undefined') {\n throw new Error(\n 'Browser downloads are not supported in ' +\n 'this environment since `document` is not present');\n }\n const weightsURL = window.URL.createObjectURL(new Blob(\n [modelArtifacts.weightData], {type: 'application/octet-stream'}));\n\n if (modelArtifacts.modelTopology instanceof ArrayBuffer) {\n throw new Error(\n 'BrowserDownloads.save() does not support saving model topology ' +\n 'in binary formats yet.');\n } else {\n const weightsManifest: WeightsManifestConfig = [{\n paths: ['./' + this.weightDataFileName],\n weights: modelArtifacts.weightSpecs\n }];\n const modelTopologyAndWeightManifest: ModelJSON = {\n modelTopology: modelArtifacts.modelTopology,\n format: modelArtifacts.format,\n generatedBy: modelArtifacts.generatedBy,\n convertedBy: modelArtifacts.convertedBy,\n weightsManifest\n };\n if (modelArtifacts.signature != null) {\n modelTopologyAndWeightManifest.signature = modelArtifacts.signature;\n }\n if (modelArtifacts.userDefinedMetadata != null) {\n modelTopologyAndWeightManifest.userDefinedMetadata =\n modelArtifacts.userDefinedMetadata;\n }\n if (modelArtifacts.modelInitializer != null) {\n modelTopologyAndWeightManifest.modelInitializer =\n modelArtifacts.modelInitializer;\n }\n const modelTopologyAndWeightManifestURL =\n window.URL.createObjectURL(new Blob(\n [JSON.stringify(modelTopologyAndWeightManifest)],\n {type: 'application/json'}));\n\n // If anchor elements are not provided, create them without attaching them\n // to parents, so that the downloaded file names can be controlled.\n const jsonAnchor = this.jsonAnchor == null ? document.createElement('a') :\n this.jsonAnchor;\n jsonAnchor.download = this.modelTopologyFileName;\n jsonAnchor.href = modelTopologyAndWeightManifestURL;\n // Trigger downloads by evoking a click event on the download anchors.\n // When multiple downloads are started synchronously, Firefox will only\n // save the last one.\n await defer(() => jsonAnchor.dispatchEvent(new MouseEvent('click')));\n\n if (modelArtifacts.weightData != null) {\n const weightDataAnchor = this.weightDataAnchor == null ?\n document.createElement('a') :\n this.weightDataAnchor;\n weightDataAnchor.download = this.weightDataFileName;\n weightDataAnchor.href = weightsURL;\n await defer(\n () => weightDataAnchor.dispatchEvent(new MouseEvent('click')));\n }\n\n return {modelArtifactsInfo: getModelArtifactsInfoForJSON(modelArtifacts)};\n }\n }\n}\n\nclass BrowserFiles implements IOHandler {\n private readonly files: File[];\n\n constructor(files: File[]) {\n if (files == null || files.length < 1) {\n throw new Error(\n `When calling browserFiles, at least 1 file is required, ` +\n `but received ${files}`);\n }\n this.files = files;\n }\n\n async load(): Promise {\n const jsonFile = this.files[0];\n const weightFiles = this.files.slice(1);\n\n return new Promise((resolve, reject) => {\n const jsonReader = new FileReader();\n jsonReader.onload = (event: Event) => {\n // tslint:disable-next-line:no-any\n const modelJSON = JSON.parse((event.target as any).result) as ModelJSON;\n const modelTopology = modelJSON.modelTopology;\n if (modelTopology == null) {\n reject(new Error(\n `modelTopology field is missing from file ${jsonFile.name}`));\n return;\n }\n\n if (weightFiles.length === 0) {\n resolve({modelTopology});\n }\n\n const weightsManifest = modelJSON.weightsManifest;\n if (weightsManifest == null) {\n reject(new Error(\n `weightManifest field is missing from file ${jsonFile.name}`));\n return;\n }\n\n let pathToFile: {[path: string]: File};\n try {\n pathToFile =\n this.checkManifestAndWeightFiles(weightsManifest, weightFiles);\n } catch (err) {\n reject(err);\n return;\n }\n\n const weightSpecs: WeightsManifestEntry[] = [];\n const paths: string[] = [];\n const perFileBuffers: ArrayBuffer[] = [];\n weightsManifest.forEach(weightsGroup => {\n weightsGroup.paths.forEach(path => {\n paths.push(path);\n perFileBuffers.push(null);\n });\n weightSpecs.push(...weightsGroup.weights);\n });\n\n weightsManifest.forEach(weightsGroup => {\n weightsGroup.paths.forEach(path => {\n const weightFileReader = new FileReader();\n weightFileReader.onload = (event: Event) => {\n // tslint:disable-next-line:no-any\n const weightData = (event.target as any).result as ArrayBuffer;\n const index = paths.indexOf(path);\n perFileBuffers[index] = weightData;\n if (perFileBuffers.indexOf(null) === -1) {\n const result: ModelArtifacts = {\n modelTopology,\n weightSpecs,\n weightData: concatenateArrayBuffers(perFileBuffers),\n format: modelJSON.format,\n generatedBy: modelJSON.generatedBy,\n convertedBy: modelJSON.convertedBy\n };\n if (modelJSON.signature != null) {\n result.signature = modelJSON.signature;\n }\n if (modelJSON.userDefinedMetadata != null) {\n result.userDefinedMetadata = modelJSON.userDefinedMetadata;\n }\n if (modelJSON.modelInitializer != null) {\n result.modelInitializer = modelJSON.modelInitializer;\n }\n resolve(result);\n }\n };\n weightFileReader.onerror = error =>\n reject(`Failed to weights data from file of path '${path}'.`);\n weightFileReader.readAsArrayBuffer(pathToFile[path]);\n });\n });\n };\n jsonReader.onerror = error => reject(\n `Failed to read model topology and weights manifest JSON ` +\n `from file '${jsonFile.name}'. BrowserFiles supports loading ` +\n `Keras-style tf.Model artifacts only.`);\n jsonReader.readAsText(jsonFile);\n });\n }\n\n /**\n * Check the compatibility between weights manifest and weight files.\n */\n private checkManifestAndWeightFiles(\n manifest: WeightsManifestConfig, files: File[]): {[path: string]: File} {\n const basenames: string[] = [];\n const fileNames = files.map(file => basename(file.name));\n const pathToFile: {[path: string]: File} = {};\n for (const group of manifest) {\n group.paths.forEach(path => {\n const pathBasename = basename(path);\n if (basenames.indexOf(pathBasename) !== -1) {\n throw new Error(\n `Duplicate file basename found in weights manifest: ` +\n `'${pathBasename}'`);\n }\n basenames.push(pathBasename);\n if (fileNames.indexOf(pathBasename) === -1) {\n throw new Error(\n `Weight file with basename '${pathBasename}' is not provided.`);\n } else {\n pathToFile[path] = files[fileNames.indexOf(pathBasename)];\n }\n });\n }\n\n if (basenames.length !== files.length) {\n throw new Error(\n `Mismatch in the number of files in weights manifest ` +\n `(${basenames.length}) and the number of weight files provided ` +\n `(${files.length}).`);\n }\n return pathToFile;\n }\n}\n\nexport const browserDownloadsRouter: IORouter = (url: string|string[]) => {\n if (!env().getBool('IS_BROWSER')) {\n return null;\n } else {\n if (!Array.isArray(url) && url.startsWith(BrowserDownloads.URL_SCHEME)) {\n return browserDownloads(url.slice(BrowserDownloads.URL_SCHEME.length));\n } else {\n return null;\n }\n }\n};\nIORouterRegistry.registerSaveRouter(browserDownloadsRouter);\n\n/**\n * Creates an IOHandler that triggers file downloads from the browser.\n *\n * The returned `IOHandler` instance can be used as model exporting methods such\n * as `tf.Model.save` and supports only saving.\n *\n * ```js\n * const model = tf.sequential();\n * model.add(tf.layers.dense(\n * {units: 1, inputShape: [10], activation: 'sigmoid'}));\n * const saveResult = await model.save('downloads://mymodel');\n * // This will trigger downloading of two files:\n * // 'mymodel.json' and 'mymodel.weights.bin'.\n * console.log(saveResult);\n * ```\n *\n * @param fileNamePrefix Prefix name of the files to be downloaded. For use with\n * `tf.Model`, `fileNamePrefix` should follow either of the following two\n * formats:\n * 1. `null` or `undefined`, in which case the default file\n * names will be used:\n * - 'model.json' for the JSON file containing the model topology and\n * weights manifest.\n * - 'model.weights.bin' for the binary file containing the binary weight\n * values.\n * 2. A single string or an Array of a single string, as the file name prefix.\n * For example, if `'foo'` is provided, the downloaded JSON\n * file and binary weights file will be named 'foo.json' and\n * 'foo.weights.bin', respectively.\n * @param config Additional configuration for triggering downloads.\n * @returns An instance of `BrowserDownloads` `IOHandler`.\n *\n * @doc {\n * heading: 'Models',\n * subheading: 'Loading',\n * namespace: 'io',\n * ignoreCI: true\n * }\n */\nexport function browserDownloads(fileNamePrefix = 'model'): IOHandler {\n return new BrowserDownloads(fileNamePrefix);\n}\n\n/**\n * Creates an IOHandler that loads model artifacts from user-selected files.\n *\n * This method can be used for loading from files such as user-selected files\n * in the browser.\n * When used in conjunction with `tf.loadLayersModel`, an instance of\n * `tf.LayersModel` (Keras-style) can be constructed from the loaded artifacts.\n *\n * ```js\n * // Note: This code snippet won't run properly without the actual file input\n * // elements in the HTML DOM.\n *\n * // Suppose there are two HTML file input (``)\n * // elements.\n * const uploadJSONInput = document.getElementById('upload-json');\n * const uploadWeightsInput = document.getElementById('upload-weights');\n * const model = await tf.loadLayersModel(tf.io.browserFiles(\n * [uploadJSONInput.files[0], uploadWeightsInput.files[0]]));\n * ```\n *\n * @param files `File`s to load from. Currently, this function supports only\n * loading from files that contain Keras-style models (i.e., `tf.Model`s), for\n * which an `Array` of `File`s is expected (in that order):\n * - A JSON file containing the model topology and weight manifest.\n * - Optionally, One or more binary files containing the binary weights.\n * These files must have names that match the paths in the `weightsManifest`\n * contained by the aforementioned JSON file, or errors will be thrown\n * during loading. These weights files have the same format as the ones\n * generated by `tensorflowjs_converter` that comes with the `tensorflowjs`\n * Python PIP package. If no weights files are provided, only the model\n * topology will be loaded from the JSON file above.\n * @returns An instance of `Files` `IOHandler`.\n *\n * @doc {\n * heading: 'Models',\n * subheading: 'Loading',\n * namespace: 'io',\n * ignoreCI: true\n * }\n */\nexport function browserFiles(files: File[]): IOHandler {\n return new BrowserFiles(files);\n}\n", "/**\n * @license\n * Copyright 2019 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {assert} from '../util';\n\nimport {OnProgressCallback} from './types';\n\n/**\n * Monitor Promise.all progress, fire onProgress callback function.\n *\n * @param promises Promise list going to be monitored\n * @param onProgress Callback function. Fired when a promise resolved.\n * @param startFraction Optional fraction start. Default to 0.\n * @param endFraction Optional fraction end. Default to 1.\n */\nexport function monitorPromisesProgress(\n promises: Array>, onProgress: OnProgressCallback,\n startFraction?: number, endFraction?: number) {\n checkPromises(promises);\n startFraction = startFraction == null ? 0 : startFraction;\n endFraction = endFraction == null ? 1 : endFraction;\n checkFraction(startFraction, endFraction);\n let resolvedPromise = 0;\n\n const registerMonitor = (promise: Promise<{}>) => {\n promise.then(value => {\n const fraction = startFraction +\n ++resolvedPromise / promises.length * (endFraction - startFraction);\n // pass fraction as parameter to callback function.\n onProgress(fraction);\n return value;\n });\n return promise;\n };\n\n function checkPromises(promises: Array>): void {\n assert(\n promises != null && Array.isArray(promises) && promises.length > 0,\n () => 'promises must be a none empty array');\n }\n\n function checkFraction(startFraction: number, endFraction: number): void {\n assert(\n startFraction >= 0 && startFraction <= 1,\n () => `Progress fraction must be in range [0, 1], but ` +\n `got startFraction ${startFraction}`);\n assert(\n endFraction >= 0 && endFraction <= 1,\n () => `Progress fraction must be in range [0, 1], but ` +\n `got endFraction ${endFraction}`);\n assert(\n endFraction >= startFraction,\n () => `startFraction must be no more than endFraction, but ` +\n `got startFraction ${startFraction} and endFraction ` +\n `${endFraction}`);\n }\n\n return Promise.all(promises.map(registerMonitor));\n}\n", "/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {env} from '../environment';\n\nimport {NamedTensorMap} from '../tensor_types';\nimport * as util from '../util';\nimport {decodeWeights} from './io_utils';\nimport {monitorPromisesProgress} from './progress';\nimport {DTYPE_VALUE_SIZE_MAP, LoadOptions, WeightsManifestConfig, WeightsManifestEntry} from './types';\n\n/**\n * Reads binary weights data from a number of URLs.\n *\n * @param fetchURLs URLs to send the HTTP requests at, using `fetch` calls.\n * @param requestOptions RequestInit (options) for the HTTP requests.\n * @param fetchFunc Optional overriding value for the `window.fetch` function.\n * @param onProgress Optional, progress callback function, fired periodically\n * before the load is completed.\n * @returns A `Promise` of an Array of `ArrayBuffer`. The Array has the same\n * length as `fetchURLs`.\n */\nexport async function loadWeightsAsArrayBuffer(\n fetchURLs: string[], loadOptions?: LoadOptions): Promise {\n if (loadOptions == null) {\n loadOptions = {};\n }\n\n const fetchFunc = loadOptions.fetchFunc == null ? env().platform.fetch :\n loadOptions.fetchFunc;\n\n // Create the requests for all of the weights in parallel.\n const requests = fetchURLs.map(\n fetchURL =>\n fetchFunc(fetchURL, loadOptions.requestInit, {isBinary: true}));\n\n const fetchStartFraction = 0;\n const fetchEndFraction = 0.5;\n\n const responses = loadOptions.onProgress == null ?\n await Promise.all(requests) :\n await monitorPromisesProgress(\n requests, loadOptions.onProgress, fetchStartFraction,\n fetchEndFraction);\n\n const bufferPromises = responses.map(response => response.arrayBuffer());\n\n const bufferStartFraction = 0.5;\n const bufferEndFraction = 1;\n\n const buffers = loadOptions.onProgress == null ?\n await Promise.all(bufferPromises) :\n await monitorPromisesProgress(\n bufferPromises, loadOptions.onProgress, bufferStartFraction,\n bufferEndFraction);\n return buffers;\n}\n\n/**\n * Reads a weights manifest JSON configuration, fetches the weights and\n * returns them as `Tensor`s.\n *\n * @param manifest The weights manifest JSON.\n * @param filePathPrefix The path prefix for filenames given in the manifest.\n * Defaults to the empty string.\n * @param weightNames The names of the weights to be fetched.\n */\nexport async function loadWeights(\n manifest: WeightsManifestConfig, filePathPrefix = '',\n weightNames?: string[],\n requestInit?: RequestInit): Promise {\n // TODO(nsthorat): Groups are currently fetched atomically. If you need a\n // single weight from a group, the whole group will be fetched. At a future\n // date, we should support fetching only the individual shards within a\n // group that are needed to reconstruct the requested weight.\n // TODO(cais): Use `decodeWeights` for implementation.\n\n const fetchWeights = (fetchUrls: string[]) =>\n loadWeightsAsArrayBuffer(fetchUrls, {requestInit});\n const loadWeights = weightsLoaderFactory(fetchWeights);\n\n return loadWeights(manifest, filePathPrefix, weightNames);\n}\n\n/**\n * Creates a function, which reads a weights manifest JSON configuration,\n * fetches the weight files using the specified function and returns them as\n * `Tensor`s.\n *\n * ```js\n * // example for creating a nodejs weight loader, which reads the weight files\n * // from disk using fs.readFileSync\n *\n * import * as fs from 'fs'\n *\n * const fetchWeightsFromDisk = (filePaths: string[]) =>\n * filePaths.map(filePath => fs.readFileSync(filePath).buffer)\n *\n * const loadWeights = tf.io.weightsLoaderFactory(fetchWeightsFromDisk)\n *\n * const manifest = JSON.parse(\n * fs.readFileSync('./my_model-weights_manifest').toString()\n * )\n * const weightMap = await loadWeights(manifest, './')\n * ```\n * @param fetchWeightsFunction The function used for fetching the weight files.\n * @returns Weight loading function.\n */\nexport function weightsLoaderFactory(\n fetchWeightsFunction: (fetchUrls: string[]) => Promise):\n (manifest: WeightsManifestConfig, filePathPrefix?: string,\n weightNames?: string[]) => Promise {\n return async(\n manifest: WeightsManifestConfig, filePathPrefix = '',\n weightNames?: string[]): Promise => {\n // Collect all the groups, weights, and their relative offsets to be\n // fetched.\n const groupIndicesToFetchMap = manifest.map(() => false);\n const groupWeightsToFetch: {\n [group: number]: Array<{\n manifestEntry: WeightsManifestEntry; groupOffset: number;\n sizeBytes: number;\n }>\n } = {};\n const weightsFound =\n weightNames != null ? weightNames.map(() => false) : [];\n const allManifestWeightNames: string[] = [];\n manifest.forEach((manifestGroupConfig, groupIndex) => {\n let groupOffset = 0;\n manifestGroupConfig.weights.forEach(weightsEntry => {\n const rawDtype = ('quantization' in weightsEntry) ?\n weightsEntry.quantization.dtype :\n weightsEntry.dtype;\n\n const weightsBytes = DTYPE_VALUE_SIZE_MAP[rawDtype] *\n util.sizeFromShape(weightsEntry.shape);\n\n const enqueueWeightsForFetchingFn = () => {\n groupIndicesToFetchMap[groupIndex] = true;\n if (groupWeightsToFetch[groupIndex] == null) {\n groupWeightsToFetch[groupIndex] = [];\n }\n\n groupWeightsToFetch[groupIndex].push({\n manifestEntry: weightsEntry,\n groupOffset,\n sizeBytes: weightsBytes\n });\n };\n\n if (weightNames != null) {\n weightNames.forEach((weightName, weightIndex) => {\n if (weightName === weightsEntry.name) {\n enqueueWeightsForFetchingFn();\n weightsFound[weightIndex] = true;\n }\n });\n } else {\n enqueueWeightsForFetchingFn();\n }\n\n allManifestWeightNames.push(weightsEntry.name);\n groupOffset += weightsBytes;\n });\n });\n\n if (!weightsFound.every(found => found)) {\n const weightsNotFound = weightNames.filter((_, i) => !weightsFound[i]);\n throw new Error(\n `Could not find weights in manifest with names: ` +\n `${weightsNotFound.join(', ')}. \\n` +\n `Manifest JSON has weights with names: ` +\n `${allManifestWeightNames.join(', ')}.`);\n }\n\n // Convert the one-hot boolean groupId => shouldFetch map to a list of group\n // IDs.\n const groupIndicesToFetch =\n groupIndicesToFetchMap.reduce((accumulator, shouldFetch, i) => {\n if (shouldFetch) {\n accumulator.push(i);\n }\n return accumulator;\n }, []);\n\n const fetchUrls: string[] = [];\n groupIndicesToFetch.forEach(i => {\n manifest[i].paths.forEach(filepath => {\n const fetchUrl = filePathPrefix +\n (!filePathPrefix.endsWith('/') ? '/' : '') + filepath;\n fetchUrls.push(fetchUrl);\n });\n });\n const buffers = await fetchWeightsFunction(fetchUrls);\n\n const weightsTensorMap: NamedTensorMap = {};\n let bufferIndexOffset = 0;\n groupIndicesToFetch.forEach(i => {\n const numBuffers = manifest[i].paths.length;\n\n let groupBytes = 0;\n for (let i = 0; i < numBuffers; i++) {\n groupBytes += buffers[bufferIndexOffset + i].byteLength;\n }\n\n // Create a buffer for the whole group.\n const groupBuffer = new ArrayBuffer(groupBytes);\n const groupByteBuffer = new Uint8Array(groupBuffer);\n let groupBufferOffset = 0;\n for (let i = 0; i < numBuffers; i++) {\n const buffer = new Uint8Array(buffers[bufferIndexOffset + i]);\n groupByteBuffer.set(buffer, groupBufferOffset);\n groupBufferOffset += buffer.byteLength;\n }\n\n const weightsEntries = groupWeightsToFetch[i];\n weightsEntries.forEach(weightsEntry => {\n const byteBuffer = groupBuffer.slice(\n weightsEntry.groupOffset,\n weightsEntry.groupOffset + weightsEntry.sizeBytes);\n const nameToTensorMap =\n decodeWeights(byteBuffer, [weightsEntry.manifestEntry]);\n for (const name in nameToTensorMap) {\n weightsTensorMap[name] = nameToTensorMap[name];\n }\n });\n\n bufferIndexOffset += numBuffers;\n });\n\n return weightsTensorMap;\n };\n}\n", "/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * IOHandler implementations based on HTTP requests in the web browser.\n *\n * Uses [`fetch`](https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API).\n */\n\nimport {env} from '../environment';\n\nimport {assert} from '../util';\nimport {concatenateArrayBuffers, getModelArtifactsInfoForJSON} from './io_utils';\nimport {IORouter, IORouterRegistry} from './router_registry';\nimport {IOHandler, LoadOptions, ModelArtifacts, ModelJSON, OnProgressCallback, SaveResult, WeightsManifestConfig, WeightsManifestEntry} from './types';\nimport {loadWeightsAsArrayBuffer} from './weights_loader';\n\nconst OCTET_STREAM_MIME_TYPE = 'application/octet-stream';\nconst JSON_TYPE = 'application/json';\nexport class HTTPRequest implements IOHandler {\n protected readonly path: string;\n protected readonly requestInit: RequestInit;\n\n private readonly fetch: Function;\n private readonly weightUrlConverter: (weightName: string) => Promise;\n\n readonly DEFAULT_METHOD = 'POST';\n\n static readonly URL_SCHEME_REGEX = /^https?:\\/\\//;\n\n private readonly weightPathPrefix: string;\n private readonly onProgress: OnProgressCallback;\n\n constructor(path: string, loadOptions?: LoadOptions) {\n if (loadOptions == null) {\n loadOptions = {};\n }\n this.weightPathPrefix = loadOptions.weightPathPrefix;\n this.onProgress = loadOptions.onProgress;\n this.weightUrlConverter = loadOptions.weightUrlConverter;\n\n if (loadOptions.fetchFunc != null) {\n assert(\n typeof loadOptions.fetchFunc === 'function',\n () => 'Must pass a function that matches the signature of ' +\n '`fetch` (see ' +\n 'https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API)');\n this.fetch = loadOptions.fetchFunc;\n } else {\n this.fetch = env().platform.fetch;\n }\n\n assert(\n path != null && path.length > 0,\n () => 'URL path for http must not be null, undefined or ' +\n 'empty.');\n\n if (Array.isArray(path)) {\n assert(\n path.length === 2,\n () => 'URL paths for http must have a length of 2, ' +\n `(actual length is ${path.length}).`);\n }\n this.path = path;\n\n if (loadOptions.requestInit != null &&\n loadOptions.requestInit.body != null) {\n throw new Error(\n 'requestInit is expected to have no pre-existing body, but has one.');\n }\n this.requestInit = loadOptions.requestInit || {};\n }\n\n async save(modelArtifacts: ModelArtifacts): Promise {\n if (modelArtifacts.modelTopology instanceof ArrayBuffer) {\n throw new Error(\n 'BrowserHTTPRequest.save() does not support saving model topology ' +\n 'in binary formats yet.');\n }\n\n const init = Object.assign({method: this.DEFAULT_METHOD}, this.requestInit);\n init.body = new FormData();\n\n const weightsManifest: WeightsManifestConfig = [{\n paths: ['./model.weights.bin'],\n weights: modelArtifacts.weightSpecs,\n }];\n const modelTopologyAndWeightManifest: ModelJSON = {\n modelTopology: modelArtifacts.modelTopology,\n format: modelArtifacts.format,\n generatedBy: modelArtifacts.generatedBy,\n convertedBy: modelArtifacts.convertedBy,\n weightsManifest\n };\n if (modelArtifacts.signature != null) {\n modelTopologyAndWeightManifest.signature = modelArtifacts.signature;\n }\n if (modelArtifacts.userDefinedMetadata != null) {\n modelTopologyAndWeightManifest.userDefinedMetadata =\n modelArtifacts.userDefinedMetadata;\n }\n if (modelArtifacts.modelInitializer != null) {\n modelTopologyAndWeightManifest.modelInitializer =\n modelArtifacts.modelInitializer;\n }\n\n init.body.append(\n 'model.json',\n new Blob(\n [JSON.stringify(modelTopologyAndWeightManifest)],\n {type: JSON_TYPE}),\n 'model.json');\n\n if (modelArtifacts.weightData != null) {\n init.body.append(\n 'model.weights.bin',\n new Blob([modelArtifacts.weightData], {type: OCTET_STREAM_MIME_TYPE}),\n 'model.weights.bin');\n }\n\n const response = await this.fetch(this.path, init);\n\n if (response.ok) {\n return {\n modelArtifactsInfo: getModelArtifactsInfoForJSON(modelArtifacts),\n responses: [response],\n };\n } else {\n throw new Error(\n `BrowserHTTPRequest.save() failed due to HTTP response status ` +\n `${response.status}.`);\n }\n }\n\n /**\n * Load model artifacts via HTTP request(s).\n *\n * See the documentation to `tf.io.http` for details on the saved\n * artifacts.\n *\n * @returns The loaded model artifacts (if loading succeeds).\n */\n async load(): Promise {\n const modelConfigRequest = await this.fetch(this.path, this.requestInit);\n\n if (!modelConfigRequest.ok) {\n throw new Error(\n `Request to ${this.path} failed with status code ` +\n `${modelConfigRequest.status}. Please verify this URL points to ` +\n `the model JSON of the model to load.`);\n }\n let modelConfig: ModelJSON;\n try {\n modelConfig = await modelConfigRequest.json();\n } catch (e) {\n let message = `Failed to parse model JSON of response from ${this.path}.`;\n // TODO(nsthorat): Remove this after some time when we're comfortable that\n // .pb files are mostly gone.\n if (this.path.endsWith('.pb')) {\n message += ' Your path contains a .pb file extension. ' +\n 'Support for .pb models have been removed in TensorFlow.js 1.0 ' +\n 'in favor of .json models. You can re-convert your Python ' +\n 'TensorFlow model using the TensorFlow.js 1.0 conversion scripts ' +\n 'or you can convert your.pb models with the \\'pb2json\\'' +\n 'NPM script in the tensorflow/tfjs-converter repository.';\n } else {\n message += ' Please make sure the server is serving valid ' +\n 'JSON for this request.';\n }\n throw new Error(message);\n }\n const modelTopology = modelConfig.modelTopology;\n const weightsManifest = modelConfig.weightsManifest;\n const generatedBy = modelConfig.generatedBy;\n const convertedBy = modelConfig.convertedBy;\n const format = modelConfig.format;\n const signature = modelConfig.signature;\n const userDefinedMetadata = modelConfig.userDefinedMetadata;\n\n // We do not allow both modelTopology and weightsManifest to be missing.\n if (modelTopology == null && weightsManifest == null) {\n throw new Error(\n `The JSON from HTTP path ${this.path} contains neither model ` +\n `topology or manifest for weights.`);\n }\n\n let weightSpecs: WeightsManifestEntry[];\n let weightData: ArrayBuffer;\n if (weightsManifest != null) {\n const results = await this.loadWeights(weightsManifest);\n [weightSpecs, weightData] = results;\n }\n\n const artifacts: ModelArtifacts = {\n modelTopology,\n weightSpecs,\n weightData,\n generatedBy,\n convertedBy,\n format\n };\n\n if (signature != null) {\n artifacts.signature = signature;\n }\n if (userDefinedMetadata != null) {\n artifacts.userDefinedMetadata = userDefinedMetadata;\n }\n\n const initializer = modelConfig.modelInitializer;\n if (initializer) {\n artifacts.modelInitializer = initializer;\n }\n\n return artifacts;\n }\n\n private async loadWeights(weightsManifest: WeightsManifestConfig):\n Promise<[WeightsManifestEntry[], ArrayBuffer]> {\n const weightPath = Array.isArray(this.path) ? this.path[1] : this.path;\n const [prefix, suffix] = parseUrl(weightPath);\n const pathPrefix = this.weightPathPrefix || prefix;\n\n const weightSpecs = [];\n for (const entry of weightsManifest) {\n weightSpecs.push(...entry.weights);\n }\n\n const fetchURLs: string[] = [];\n const urlPromises: Array> = [];\n for (const weightsGroup of weightsManifest) {\n for (const path of weightsGroup.paths) {\n if (this.weightUrlConverter != null) {\n urlPromises.push(this.weightUrlConverter(path));\n } else {\n fetchURLs.push(pathPrefix + path + suffix);\n }\n }\n }\n\n if (this.weightUrlConverter) {\n fetchURLs.push(...await Promise.all(urlPromises));\n }\n\n const buffers = await loadWeightsAsArrayBuffer(fetchURLs, {\n requestInit: this.requestInit,\n fetchFunc: this.fetch,\n onProgress: this.onProgress\n });\n return [weightSpecs, concatenateArrayBuffers(buffers)];\n }\n}\n\n/**\n * Extract the prefix and suffix of the url, where the prefix is the path before\n * the last file, and suffix is the search params after the last file.\n * ```\n * const url = 'http://tfhub.dev/model/1/tensorflowjs_model.pb?tfjs-format=file'\n * [prefix, suffix] = parseUrl(url)\n * // prefix = 'http://tfhub.dev/model/1/'\n * // suffix = '?tfjs-format=file'\n * ```\n * @param url the model url to be parsed.\n */\nexport function parseUrl(url: string): [string, string] {\n const lastSlash = url.lastIndexOf('/');\n const lastSearchParam = url.lastIndexOf('?');\n const prefix = url.substring(0, lastSlash);\n const suffix =\n lastSearchParam > lastSlash ? url.substring(lastSearchParam) : '';\n return [prefix + '/', suffix];\n}\n\nexport function isHTTPScheme(url: string): boolean {\n return url.match(HTTPRequest.URL_SCHEME_REGEX) != null;\n}\n\nexport const httpRouter: IORouter =\n (url: string, loadOptions?: LoadOptions) => {\n if (typeof fetch === 'undefined' &&\n (loadOptions == null || loadOptions.fetchFunc == null)) {\n // `http` uses `fetch` or `node-fetch`, if one wants to use it in\n // an environment that is not the browser or node they have to setup a\n // global fetch polyfill.\n return null;\n } else {\n let isHTTP = true;\n if (Array.isArray(url)) {\n isHTTP = url.every(urlItem => isHTTPScheme(urlItem));\n } else {\n isHTTP = isHTTPScheme(url);\n }\n if (isHTTP) {\n return http(url, loadOptions);\n }\n }\n return null;\n };\nIORouterRegistry.registerSaveRouter(httpRouter);\nIORouterRegistry.registerLoadRouter(httpRouter);\n\n/**\n * Creates an IOHandler subtype that sends model artifacts to HTTP server.\n *\n * An HTTP request of the `multipart/form-data` mime type will be sent to the\n * `path` URL. The form data includes artifacts that represent the topology\n * and/or weights of the model. In the case of Keras-style `tf.Model`, two\n * blobs (files) exist in form-data:\n * - A JSON file consisting of `modelTopology` and `weightsManifest`.\n * - A binary weights file consisting of the concatenated weight values.\n * These files are in the same format as the one generated by\n * [tfjs_converter](https://js.tensorflow.org/tutorials/import-keras.html).\n *\n * The following code snippet exemplifies the client-side code that uses this\n * function:\n *\n * ```js\n * const model = tf.sequential();\n * model.add(\n * tf.layers.dense({units: 1, inputShape: [100], activation: 'sigmoid'}));\n *\n * const saveResult = await model.save(tf.io.http(\n * 'http://model-server:5000/upload', {requestInit: {method: 'PUT'}}));\n * console.log(saveResult);\n * ```\n *\n * If the default `POST` method is to be used, without any custom parameters\n * such as headers, you can simply pass an HTTP or HTTPS URL to `model.save`:\n *\n * ```js\n * const saveResult = await model.save('http://model-server:5000/upload');\n * ```\n *\n * The following GitHub Gist\n * https://gist.github.com/dsmilkov/1b6046fd6132d7408d5257b0976f7864\n * implements a server based on [flask](https://github.com/pallets/flask) that\n * can receive the request. Upon receiving the model artifacts via the requst,\n * this particular server reconsistutes instances of [Keras\n * Models](https://keras.io/models/model/) in memory.\n *\n *\n * @param path A URL path to the model.\n * Can be an absolute HTTP path (e.g.,\n * 'http://localhost:8000/model-upload)') or a relative path (e.g.,\n * './model-upload').\n * @param requestInit Request configurations to be used when sending\n * HTTP request to server using `fetch`. It can contain fields such as\n * `method`, `credentials`, `headers`, `mode`, etc. See\n * https://developer.mozilla.org/en-US/docs/Web/API/Request/Request\n * for more information. `requestInit` must not have a body, because the\n * body will be set by TensorFlow.js. File blobs representing the model\n * topology (filename: 'model.json') and the weights of the model (filename:\n * 'model.weights.bin') will be appended to the body. If `requestInit` has a\n * `body`, an Error will be thrown.\n * @param loadOptions Optional configuration for the loading. It includes the\n * following fields:\n * - weightPathPrefix Optional, this specifies the path prefix for weight\n * files, by default this is calculated from the path param.\n * - fetchFunc Optional, custom `fetch` function. E.g., in Node.js,\n * the `fetch` from node-fetch can be used here.\n * - onProgress Optional, progress callback function, fired periodically\n * before the load is completed.\n * @returns An instance of `IOHandler`.\n *\n * @doc {\n * heading: 'Models',\n * subheading: 'Loading',\n * namespace: 'io',\n * ignoreCI: true\n * }\n */\nexport function http(path: string, loadOptions?: LoadOptions): IOHandler {\n return new HTTPRequest(path, loadOptions);\n}\n\n/**\n * Deprecated. Use `tf.io.http`.\n * @param path\n * @param loadOptions\n */\nexport function browserHTTPRequest(\n path: string, loadOptions?: LoadOptions): IOHandler {\n return http(path, loadOptions);\n}\n", "/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * IOHandlers that pass through the in-memory ModelArtifacts format.\n */\n\nimport {IOHandler, ModelArtifacts, SaveResult, TrainingConfig, WeightsManifestEntry} from './types';\n\nclass PassthroughLoader implements IOHandler {\n constructor(private readonly modelArtifacts?: ModelArtifacts) {}\n\n async load(): Promise {\n return this.modelArtifacts;\n }\n}\n\nclass PassthroughSaver implements IOHandler {\n constructor(\n private readonly saveHandler:\n (artifacts: ModelArtifacts) => Promise) {}\n\n async save(modelArtifacts: ModelArtifacts) {\n return this.saveHandler(modelArtifacts);\n }\n}\n\n/**\n * Creates an IOHandler that loads model artifacts from memory.\n *\n * When used in conjunction with `tf.loadLayersModel`, an instance of\n * `tf.LayersModel` (Keras-style) can be constructed from the loaded artifacts.\n *\n * ```js\n * const model = await tf.loadLayersModel(tf.io.fromMemory(\n * modelTopology, weightSpecs, weightData));\n * ```\n *\n * @param modelArtifacts a object containing model topology (i.e., parsed from\n * the JSON format).\n * @param weightSpecs An array of `WeightsManifestEntry` objects describing the\n * names, shapes, types, and quantization of the weight data.\n * @param weightData A single `ArrayBuffer` containing the weight data,\n * concatenated in the order described by the weightSpecs.\n * @param trainingConfig Model training configuration. Optional.\n *\n * @returns A passthrough `IOHandler` that simply loads the provided data.\n */\nexport function fromMemory(\n modelArtifacts: {}|ModelArtifacts, weightSpecs?: WeightsManifestEntry[],\n weightData?: ArrayBuffer, trainingConfig?: TrainingConfig): IOHandler {\n if (arguments.length === 1) {\n const isModelArtifacts =\n (modelArtifacts as ModelArtifacts).modelTopology != null ||\n (modelArtifacts as ModelArtifacts).weightSpecs != null;\n if (isModelArtifacts) {\n return new PassthroughLoader(modelArtifacts as ModelArtifacts);\n } else {\n // Legacy support: with only modelTopology.\n // TODO(cais): Remove this deprecated API.\n console.warn(\n 'Please call tf.io.fromMemory() with only one argument. ' +\n 'The argument should be of type ModelArtifacts. ' +\n 'The multi-argument signature of tf.io.fromMemory() has been ' +\n 'deprecated and will be removed in a future release.');\n return new PassthroughLoader({modelTopology: modelArtifacts as {}});\n }\n } else {\n // Legacy support.\n // TODO(cais): Remove this deprecated API.\n console.warn(\n 'Please call tf.io.fromMemory() with only one argument. ' +\n 'The argument should be of type ModelArtifacts. ' +\n 'The multi-argument signature of tf.io.fromMemory() has been ' +\n 'deprecated and will be removed in a future release.');\n return new PassthroughLoader({\n modelTopology: modelArtifacts as {},\n weightSpecs,\n weightData,\n trainingConfig\n });\n }\n}\n\n/**\n * Creates an IOHandler that passes saved model artifacts to a callback.\n *\n * ```js\n * function handleSave(artifacts) {\n * // ... do something with the artifacts ...\n * return {modelArtifactsInfo: {...}, ...};\n * }\n *\n * const saveResult = model.save(tf.io.withSaveHandler(handleSave));\n * ```\n *\n * @param saveHandler A function that accepts a `ModelArtifacts` and returns a\n * `SaveResult`.\n */\nexport function withSaveHandler(\n saveHandler: (artifacts: ModelArtifacts) =>\n Promise): IOHandler {\n return new PassthroughSaver(saveHandler);\n}\n", "/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\n/**\n * Exports under the tf.math.* namespace.\n */\n\nimport {confusionMatrix} from './ops/confusion_matrix';\n\nexport {confusionMatrix};\n", "/**\n * @license\n * Copyright 2020 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\nimport {ENGINE} from '../engine';\nimport {BatchMatMul, BatchMatMulAttrs, BatchMatMulInputs} from '../kernel_names';\nimport {NamedAttrMap} from '../kernel_registry';\nimport {Tensor} from '../tensor';\nimport {NamedTensorMap} from '../tensor_types';\nimport {makeTypesMatch} from '../tensor_util';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\n\nimport {op} from './operation';\n\n/**\n * Computes the dot product of two matrices, A * B. These must be matrices.\n *\n * ```js\n * const a = tf.tensor2d([1, 2], [1, 2]);\n * const b = tf.tensor2d([1, 2, 3, 4], [2, 2]);\n *\n * a.matMul(b).print(); // or tf.matMul(a, b)\n * ```\n * @param a First matrix in dot product operation.\n * @param b Second matrix in dot product operation.\n * @param transposeA If true, `a` is transposed before multiplication.\n * @param transposeB If true, `b` is transposed before multiplication.\n *\n * @doc {heading: 'Operations', subheading: 'Matrices'}\n */\nfunction matMul_(\n a: Tensor|TensorLike, b: Tensor|TensorLike, transposeA = false,\n transposeB = false): T {\n let $a = convertToTensor(a, 'a', 'matMul');\n let $b = convertToTensor(b, 'b', 'matMul');\n [$a, $b] = makeTypesMatch($a, $b);\n\n const inputs: BatchMatMulInputs = {a: $a, b: $b};\n const attrs: BatchMatMulAttrs = {transposeA, transposeB};\n\n return ENGINE.runKernel(\n BatchMatMul, inputs as {} as NamedTensorMap, attrs as {} as NamedAttrMap);\n}\n\nexport const matMul = op({matMul_});\n", "/**\n * @license\n * Copyright 2020 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENGINE} from '../engine';\nimport {OneHot, OneHotAttrs, OneHotInputs} from '../kernel_names';\nimport {NamedAttrMap} from '../kernel_registry';\nimport {Tensor} from '../tensor';\nimport {NamedTensorMap} from '../tensor_types';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\n\nimport {op} from './operation';\n\n/**\n * Creates a one-hot `tf.Tensor`. The locations represented by `indices` take\n * value `onValue` (defaults to 1), while all other locations take value\n * `offValue` (defaults to 0). If `indices` is rank `R`, the output has rank\n * `R+1` with the last axis of size `depth`.\n *\n * ```js\n * tf.oneHot(tf.tensor1d([0, 1], 'int32'), 3).print();\n * ```\n *\n * @param indices `tf.Tensor` of indices with dtype `int32`.\n * @param depth The depth of the one hot dimension.\n * @param onValue A number used to fill in the output when the index matches\n * the location.\n * @param offValue A number used to fill in the output when the index does\n * not match the location.\n *\n * @doc {heading: 'Tensors', subheading: 'Creation'}\n */\nfunction oneHot_(\n indices: Tensor|TensorLike, depth: number, onValue = 1,\n offValue = 0): Tensor {\n if (depth < 2) {\n throw new Error(`Error in oneHot: depth must be >=2, but it is ${depth}`);\n }\n const $indices = convertToTensor(indices, 'indices', 'oneHot', 'int32');\n\n const inputs: OneHotInputs = {indices: $indices};\n const attrs: OneHotAttrs = {depth, onValue, offValue};\n\n return ENGINE.runKernel(\n OneHot, inputs as unknown as NamedTensorMap,\n attrs as unknown as NamedAttrMap);\n}\n\nexport const oneHot = op({oneHot_});\n", "/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENGINE} from '../engine';\nimport {Transpose, TransposeAttrs, TransposeInputs} from '../kernel_names';\nimport {NamedAttrMap} from '../kernel_registry';\nimport {Tensor} from '../tensor';\nimport {NamedTensorMap} from '../tensor_types';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\n\nimport {op} from './operation';\n\n/**\n * Transposes the `tf.Tensor`. Permutes the dimensions according to `perm`.\n *\n * The returned `tf.Tensor`'s dimension `i` will correspond to the input\n * dimension `perm[i]`. If `perm` is not given, it is set to `[n-1...0]`,\n * where `n` is the rank of the input `tf.Tensor`. Hence by default, this\n * operation performs a regular matrix transpose on 2-D input `tf.Tensor`s.\n *\n * ```js\n * const a = tf.tensor2d([1, 2, 3, 4, 5, 6], [2, 3]);\n *\n * a.transpose().print(); // or tf.transpose(a)\n * ```\n *\n * @param x The tensor to transpose.\n * @param perm The permutation of the dimensions of a.\n *\n * @doc {heading: 'Operations', subheading: 'Matrices'}\n */\nfunction transpose_(x: T|TensorLike, perm?: number[]): T {\n const $x = convertToTensor(x, 'x', 'transpose');\n\n if (perm == null) {\n perm = $x.shape.map((s, i) => i).reverse();\n }\n util.assert(\n $x.rank === perm.length,\n () => `Error in transpose: rank of input ${$x.rank} ` +\n `must match length of perm ${perm}.`);\n perm.forEach(axis => {\n util.assert(\n axis >= 0 && axis < $x.rank,\n () => `All entries in 'perm' must be between 0 and ${$x.rank - 1}` +\n ` but got ${perm}`);\n });\n\n if ($x.rank <= 1) {\n return $x.clone();\n }\n\n const inputs: TransposeInputs = {x: $x};\n const attrs: TransposeAttrs = {perm};\n\n return ENGINE.runKernel(\n Transpose, inputs as {} as NamedTensorMap, attrs as {} as NamedAttrMap);\n}\n\nexport const transpose = op({transpose_});\n", "/**\n * @license\n * Copyright 2018 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {Tensor1D, Tensor2D} from '../tensor';\nimport {convertToTensor} from '../tensor_util_env';\nimport {TensorLike} from '../types';\nimport * as util from '../util';\n\nimport {cast} from './cast';\nimport {matMul} from './mat_mul';\nimport {oneHot} from './one_hot';\nimport {op} from './operation';\nimport {transpose} from './transpose';\n\n/**\n * Computes the confusion matrix from true labels and predicted labels.\n *\n * ```js\n * const labels = tf.tensor1d([0, 1, 2, 1, 0], 'int32');\n * const predictions = tf.tensor1d([0, 2, 2, 1, 0], 'int32');\n * const numClasses = 3;\n * const out = tf.math.confusionMatrix(labels, predictions, numClasses);\n * out.print();\n * // Expected output matrix:\n * // [[2, 0, 0],\n * // [0, 1, 1],\n * // [0, 0, 1]]\n * ```\n *\n * @param labels The target labels, assumed to be 0-based integers\n * for the classes. The shape is `[numExamples]`, where\n * `numExamples` is the number of examples included.\n * @param predictions The predicted classes, assumed to be\n * 0-based integers for the classes. Must have the same shape as `labels`.\n * @param numClasses Number of all classes, as an integer.\n * Its value must be larger than the largest element in `labels` and\n * `predictions`.\n * @returns The confusion matrix as a int32-type 2D tensor. The value at\n * row `r` and column `c` is the number of times examples of actual class\n * `r` were predicted as class `c`.\n *\n * @doc {heading: 'Operations', subheading: 'Evaluation'}\n */\nexport function confusionMatrix_(\n labels: Tensor1D|TensorLike, predictions: Tensor1D|TensorLike,\n numClasses: number): Tensor2D {\n const $labels = convertToTensor(labels, 'labels', 'confusionMatrix');\n const $predictions =\n convertToTensor(predictions, 'predictions', 'confusionMatrix');\n\n util.assert(\n numClasses == null || numClasses > 0 && Number.isInteger(numClasses),\n () => `If provided, numClasses must be a positive integer, ` +\n `but got ${numClasses}`);\n util.assert(\n $labels.rank === 1,\n () => `Expected the rank of labels to be 1, but got ${$labels.rank}`);\n util.assert(\n $predictions.rank === 1,\n () => `Expected the rank of predictions to be 1, ` +\n `but got ${$predictions.rank}`);\n util.assert(\n $labels.shape[0] === $predictions.shape[0],\n () => `Mismatch in the number of examples: ` +\n `${$labels.shape[0]} vs. ${$predictions.shape[0]}. ` +\n `Labels and predictions should have the same number of elements.`);\n util.assert(\n numClasses > 0 && Number.isInteger(numClasses),\n () => `numClasses is required to be a positive integer, but got ` +\n `${numClasses}`);\n // TODO(cais): In the future, if oneHot supports tensors inputs for\n // `numClasses`, `confusionMatrix` can make `numClasses` optional.\n\n const oneHotLabels = oneHot(cast($labels, 'int32'), numClasses) as Tensor2D;\n const oneHotPredictions =\n oneHot(cast($predictions, 'int32'), numClasses) as Tensor2D;\n const oneHotLabelsT: Tensor2D = transpose(oneHotLabels);\n const product: Tensor2D = matMul(oneHotLabelsT, oneHotPredictions);\n return cast(product, 'int32');\n}\n\nexport const confusionMatrix = op({confusionMatrix_});\n", "/**\n * @license\n * Copyright 2019 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\n\nimport {ENGINE} from '../engine';\nimport {env} from '../environment';\nimport {FromPixels, FromPixelsAttrs, FromPixelsInputs} from '../kernel_names';\nimport {getKernel, NamedAttrMap} from '../kernel_registry';\nimport {Tensor, Tensor2D, Tensor3D} from '../tensor';\nimport {NamedTensorMap} from '../tensor_types';\nimport {convertToTensor} from '../tensor_util_env';\nimport {PixelData, TensorLike} from '../types';\n\nimport {cast} from './cast';\nimport {op} from './operation';\nimport {tensor3d} from './tensor3d';\n\nlet fromPixels2DContext: CanvasRenderingContext2D;\n\n/**\n * Creates a `tf.Tensor` from an image.\n *\n * ```js\n * const image = new ImageData(1, 1);\n * image.data[0] = 100;\n * image.data[1] = 150;\n * image.data[2] = 200;\n * image.data[3] = 255;\n *\n * tf.browser.fromPixels(image).print();\n * ```\n *\n * @param pixels The input image to construct the tensor from. The\n * supported image types are all 4-channel. You can also pass in an image\n * object with following attributes:\n * `{data: Uint8Array; width: number; height: number}`\n * @param numChannels The number of channels of the output tensor. A\n * numChannels value less than 4 allows you to ignore channels. Defaults to\n * 3 (ignores alpha channel of input image).\n *\n * @returns A Tensor3D with the shape `[height, width, numChannels]`.\n *\n * @doc {heading: 'Browser', namespace: 'browser', ignoreCI: true}\n */\nfunction fromPixels_(\n pixels: PixelData|ImageData|HTMLImageElement|HTMLCanvasElement|\n HTMLVideoElement|ImageBitmap,\n numChannels = 3): Tensor3D {\n // Sanity checks.\n if (numChannels > 4) {\n throw new Error(\n 'Cannot construct Tensor with more than 4 channels from pixels.');\n }\n if (pixels == null) {\n throw new Error('pixels passed to tf.browser.fromPixels() can not be null');\n }\n let isPixelData = false;\n let isImageData = false;\n let isVideo = false;\n let isImage = false;\n let isCanvasLike = false;\n let isImageBitmap = false;\n if ((pixels as PixelData).data instanceof Uint8Array) {\n isPixelData = true;\n } else if (\n typeof (ImageData) !== 'undefined' && pixels instanceof ImageData) {\n isImageData = true;\n } else if (\n typeof (HTMLVideoElement) !== 'undefined' &&\n pixels instanceof HTMLVideoElement) {\n isVideo = true;\n } else if (\n typeof (HTMLImageElement) !== 'undefined' &&\n pixels instanceof HTMLImageElement) {\n isImage = true;\n // tslint:disable-next-line: no-any\n } else if ((pixels as any).getContext != null) {\n isCanvasLike = true;\n } else if (\n typeof (ImageBitmap) !== 'undefined' && pixels instanceof ImageBitmap) {\n isImageBitmap = true;\n } else {\n throw new Error(\n 'pixels passed to tf.browser.fromPixels() must be either an ' +\n `HTMLVideoElement, HTMLImageElement, HTMLCanvasElement, ImageData ` +\n `in browser, or OffscreenCanvas, ImageData in webworker` +\n ` or {data: Uint32Array, width: number, height: number}, ` +\n `but was ${(pixels as {}).constructor.name}`);\n }\n if (isVideo) {\n const HAVE_CURRENT_DATA_READY_STATE = 2;\n if (isVideo &&\n (pixels as HTMLVideoElement).readyState <\n HAVE_CURRENT_DATA_READY_STATE) {\n throw new Error(\n 'The video element has not loaded data yet. Please wait for ' +\n '`loadeddata` event on the