leadal-auth 0.0.29 → 0.0.30

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -67,4 +67,4 @@ LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
67
67
  OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
68
68
  PERFORMANCE OF THIS SOFTWARE.
69
69
  ***************************************************************************** */
70
- var wm=function(n,x){return wm=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(n,x){n.__proto__=x}||function(n,x){for(var t in x)x.hasOwnProperty(t)&&(n[t]=x[t])},wm(n,x)};function km(n,x){function t(){this.constructor=n}wm(n,x),n.prototype=null===x?Object.create(x):(t.prototype=x.prototype,new t)}var qm=function(){return qm=Object.assign||function(n){for(var x,t=1,e=arguments.length;t<e;t++)for(var i in x=arguments[t],x)Object.prototype.hasOwnProperty.call(x,i)&&(n[i]=x[i]);return n},qm.apply(this,arguments)};function Cm(n,x,t,e){function i(n){return n instanceof t?n:new t(function(x){x(n)})}return new(t||(t=Promise))(function(t,r){function o(n){try{h(e.next(n))}catch(Di){r(Di)}}function s(n){try{h(e["throw"](n))}catch(Di){r(Di)}}function h(n){n.done?t(n.value):i(n.value).then(o,s)}h((e=e.apply(n,x||[])).next())})}function Am(n,x){var t,e,i,r,o={label:0,sent:function(){if(1&i[0])throw i[1];return i[1]},trys:[],ops:[]};return r={next:s(0),throw:s(1),return:s(2)},"function"===typeof Symbol&&(r[Symbol.iterator]=function(){return this}),r;function s(n){return function(x){return h([n,x])}}function h(r){if(t)throw new TypeError("Generator is already executing.");while(o)try{if(t=1,e&&(i=2&r[0]?e["return"]:r[0]?e["throw"]||((i=e["return"])&&i.call(e),0):e.next)&&!(i=i.call(e,r[1])).done)return i;switch(e=0,i&&(r=[2&r[0],i.value]),r[0]){case 0:case 1:i=r;break;case 4:return o.label++,{value:r[1],done:!1};case 5:o.label++,e=r[1],r=[0];continue;case 7:r=o.ops.pop(),o.trys.pop();continue;default:if(i=o.trys,!(i=i.length>0&&i[i.length-1])&&(6===r[0]||2===r[0])){o=0;continue}if(3===r[0]&&(!i||r[1]>i[0]&&r[1]<i[3])){o.label=r[1];break}if(6===r[0]&&o.label<i[1]){o.label=i[1],i=r;break}if(i&&o.label<i[2]){o.label=i[2],o.ops.push(r);break}i[2]&&o.ops.pop(),o.trys.pop();continue}r=x.call(n,o)}catch(Di){r=[6,Di],e=0}finally{t=i=0}if(5&r[0])throw r[1];return{value:r[0]?r[1]:void 0,done:!0}}}function Em(){for(var n=0,x=0,t=arguments.length;x<t;x++)n+=arguments[x].length;var e=Array(n),i=0;for(x=0;x<t;x++)for(var r=arguments[x],o=0,s=r.length;o<s;o++,i++)e[i]=r[o];return e}var Sm=function(){function n(n,x){if(!Lm(n)||!Lm(x))throw new Error("Dimensions.constructor - expected width and height to be valid numbers, instead have "+JSON.stringify({width:n,height:x}));this._width=n,this._height=x}return Object.defineProperty(n.prototype,"width",{get:function(){return this._width},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"height",{get:function(){return this._height},enumerable:!0,configurable:!0}),n.prototype.reverse=function(){return new n(1/this.width,1/this.height)},n}();function Im(n,x){return n instanceof Kr&&n.shape.length===x}function Dm(n){return Im(n,2)}function Om(n){return Im(n,3)}function _m(n){return Im(n,4)}function Tm(n){return n%1!==0}function Rm(n){return n%2===0}function Bm(n,x){void 0===x&&(x=2);var t=Math.pow(10,x);return Math.floor(n*t)/t}function Mm(n){return n&&n.width&&n.height}function Nm(n,x){var t=n.width,e=n.height,i=x/Math.max(e,t);return new Sm(Math.round(t*i),Math.round(e*i))}function Fm(n){return n.reduce(function(n,x){return n.add(x)},new Um(0,0)).div(new Um(n.length,n.length))}function Pm(n,x,t){return Array(n).fill(0).map(function(n,e){return x+e*t})}function Lm(n){return!!n&&n!==1/0&&n!==-1/0&&!isNaN(n)||0===n}function Hm(n){return Lm(n)&&0<=n&&n<=1}var Um=function(){function n(n,x){this._x=n,this._y=x}return Object.defineProperty(n.prototype,"x",{get:function(){return this._x},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"y",{get:function(){return this._y},enumerable:!0,configurable:!0}),n.prototype.add=function(x){return new n(this.x+x.x,this.y+x.y)},n.prototype.sub=function(x){return new n(this.x-x.x,this.y-x.y)},n.prototype.mul=function(x){return new n(this.x*x.x,this.y*x.y)},n.prototype.div=function(x){return new n(this.x/x.x,this.y/x.y)},n.prototype.abs=function(){return new n(Math.abs(this.x),Math.abs(this.y))},n.prototype.magnitude=function(){return Math.sqrt(Math.pow(this.x,2)+Math.pow(this.y,2))},n.prototype.floor=function(){return new n(Math.floor(this.x),Math.floor(this.y))},n}(),Vm=function(){function n(x,t){void 0===t&&(t=!0);var e=x||{},i=[e.left,e.top,e.right,e.bottom].every(Lm),r=[e.x,e.y,e.width,e.height].every(Lm);if(!r&&!i)throw new Error("Box.constructor - expected box to be IBoundingBox | IRect, instead have "+JSON.stringify(e));var o=r?[e.x,e.y,e.width,e.height]:[e.left,e.top,e.right-e.left,e.bottom-e.top],s=o[0],h=o[1],u=o[2],a=o[3];n.assertIsValidBox({x:s,y:h,width:u,height:a},"Box.constructor",t),this._x=s,this._y=h,this._width=u,this._height=a}return n.isRect=function(n){return!!n&&[n.x,n.y,n.width,n.height].every(Lm)},n.assertIsValidBox=function(x,t,e){if(void 0===e&&(e=!1),!n.isRect(x))throw new Error(t+" - invalid box: "+JSON.stringify(x)+", expected object with properties x, y, width, height");if(!e&&(x.width<0||x.height<0))throw new Error(t+" - width ("+x.width+") and height ("+x.height+") must be positive numbers")},Object.defineProperty(n.prototype,"x",{get:function(){return this._x},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"y",{get:function(){return this._y},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"width",{get:function(){return this._width},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"height",{get:function(){return this._height},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"left",{get:function(){return this.x},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"top",{get:function(){return this.y},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"right",{get:function(){return this.x+this.width},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"bottom",{get:function(){return this.y+this.height},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"area",{get:function(){return this.width*this.height},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"topLeft",{get:function(){return new Um(this.left,this.top)},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"topRight",{get:function(){return new Um(this.right,this.top)},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"bottomLeft",{get:function(){return new Um(this.left,this.bottom)},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"bottomRight",{get:function(){return new Um(this.right,this.bottom)},enumerable:!0,configurable:!0}),n.prototype.round=function(){var x=[this.x,this.y,this.width,this.height].map(function(n){return Math.round(n)}),t=x[0],e=x[1],i=x[2],r=x[3];return new n({x:t,y:e,width:i,height:r})},n.prototype.floor=function(){var x=[this.x,this.y,this.width,this.height].map(function(n){return Math.floor(n)}),t=x[0],e=x[1],i=x[2],r=x[3];return new n({x:t,y:e,width:i,height:r})},n.prototype.toSquare=function(){var x=this,t=x.x,e=x.y,i=x.width,r=x.height,o=Math.abs(i-r);return i<r&&(t-=o/2,i+=o),r<i&&(e-=o/2,r+=o),new n({x:t,y:e,width:i,height:r})},n.prototype.rescale=function(x){var t=Mm(x)?x.width:x,e=Mm(x)?x.height:x;return new n({x:this.x*t,y:this.y*e,width:this.width*t,height:this.height*e})},n.prototype.pad=function(x,t){var e=[this.x-x/2,this.y-t/2,this.width+x,this.height+t],i=e[0],r=e[1],o=e[2],s=e[3];return new n({x:i,y:r,width:o,height:s})},n.prototype.clipAtImageBorders=function(x,t){var e=this,i=e.x,r=e.y,o=e.right,s=e.bottom,h=Math.max(i,0),u=Math.max(r,0),a=o-h,g=s-u,l=Math.min(a,x-h),c=Math.min(g,t-u);return new n({x:h,y:u,width:l,height:c}).floor()},n.prototype.shift=function(x,t){var e=this,i=e.width,r=e.height,o=this.x+x,s=this.y+t;return new n({x:o,y:s,width:i,height:r})},n.prototype.padAtBorders=function(n,x){var t=this.width+1,e=this.height+1,i=1,r=1,o=t,s=e,h=this.left,u=this.top,a=this.right,g=this.bottom;return a>x&&(o=-a+x+t,a=x),g>n&&(s=-g+n+e,g=n),h<1&&(s=2-h,h=1),u<1&&(s=2-u,u=1),{dy:r,edy:s,dx:i,edx:o,y:u,ey:g,x:h,ex:a,w:t,h:e}},n.prototype.calibrate=function(x){return new n({left:this.left+x.left*this.width,top:this.top+x.top*this.height,right:this.right+x.right*this.width,bottom:this.bottom+x.bottom*this.height}).toSquare().round()},n}(),Wm=function(n){function x(x,t,e,i,r){return void 0===r&&(r=!1),n.call(this,{left:x,top:t,right:e,bottom:i},r)||this}return km(x,n),x}(Vm),Qm=function(){function n(n,x,t,e,i){this._imageDims=new Sm(i.width,i.height),this._score=n,this._classScore=x,this._className=t,this._box=new Vm(e).rescale(this._imageDims)}return Object.defineProperty(n.prototype,"score",{get:function(){return this._score},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"classScore",{get:function(){return this._classScore},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"className",{get:function(){return this._className},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"box",{get:function(){return this._box},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"imageDims",{get:function(){return this._imageDims},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"imageWidth",{get:function(){return this.imageDims.width},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"imageHeight",{get:function(){return this.imageDims.height},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"relativeBox",{get:function(){return new Vm(this._box).rescale(this.imageDims.reverse())},enumerable:!0,configurable:!0}),n.prototype.forSize=function(x,t){return new n(this.score,this.classScore,this.className,this.relativeBox,{width:x,height:t})},n}(),Gm=function(n){function x(x,t,e){return n.call(this,x,x,"",t,e)||this}return km(x,n),x.prototype.forSize=function(t,e){var i=n.prototype.forSize.call(this,t,e),r=i.score,o=i.relativeBox,s=i.imageDims;return new x(r,o,s)},x}(Qm);function Km(n){var x=n.map(function(n){return n.x}),t=n.map(function(n){return n.y}),e=x.reduce(function(n,x){return x<n?x:n},1/0),i=t.reduce(function(n,x){return x<n?x:n},1/0),r=x.reduce(function(n,x){return n<x?x:n},0),o=t.reduce(function(n,x){return n<x?x:n},0);return new Wm(e,i,r,o)}function Ym(n,x,t){void 0===t&&(t=!0);var e=Math.max(0,Math.min(n.right,x.right)-Math.max(n.left,x.left)),i=Math.max(0,Math.min(n.bottom,x.bottom)-Math.max(n.top,x.top)),r=e*i;return t?r/(n.area+x.area-r):r/Math.min(n.area,x.area)}function Jm(n,x,t,e){void 0===e&&(e=!0);var i=x.map(function(n,x){return{score:n,boxIndex:x}}).sort(function(n,x){return n.score-x.score}).map(function(n){return n.boxIndex}),r=[],o=function(){var x=i.pop();r.push(x);for(var o=i,s=[],h=0;h<o.length;h++){var u=o[h],a=n[x],g=n[u];s.push(Ym(a,g,e))}i=i.filter(function(n,x){return s[x]<=t})};while(i.length>0)o();return r}function Xm(n,x){return bs(function(){var t=x[0],e=x[1],i=x[2],r=$s(Em(n.shape.slice(0,3),[1]),t),o=$s(Em(n.shape.slice(0,3),[1]),e),s=$s(Em(n.shape.slice(0,3),[1]),i),h=ih([r,o,s],3);return vd(n,h)})}function Zm(n,x){return void 0===x&&(x=!1),bs(function(){var t=n.shape.slice(1),e=t[0],i=t[1];if(e===i)return n;var r=Math.abs(e-i),o=Math.round(r*(x?.5:1)),s=e>i?2:1,h=function(x){var t=n.shape.slice();return t[s]=x,$s(t,0)},u=h(o),a=r-u.shape[s],g=x&&a?h(a):null,l=[g,n,u].filter(function(n){return!!n}).map(function(n){return n.toFloat()});return ih(l,s)})}function $m(n){return 1/(1+Math.exp(-n))}var nb,xb=function(n){function x(x,t,e,i,r){return void 0===r&&(r=!1),n.call(this,{x:x,y:t,width:e,height:i},r)||this}return km(x,n),x}(Vm),tb=.5,eb=.43,ib=.45,rb=function(){function n(n,x,t){void 0===t&&(t=new Um(0,0));var e=x.width,i=x.height;this._imgDims=new Sm(e,i),this._shift=t,this._positions=n.map(function(n){return n.mul(new Um(e,i)).add(t)})}return Object.defineProperty(n.prototype,"shift",{get:function(){return new Um(this._shift.x,this._shift.y)},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"imageWidth",{get:function(){return this._imgDims.width},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"imageHeight",{get:function(){return this._imgDims.height},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"positions",{get:function(){return this._positions},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"relativePositions",{get:function(){var n=this;return this._positions.map(function(x){return x.sub(n._shift).div(new Um(n.imageWidth,n.imageHeight))})},enumerable:!0,configurable:!0}),n.prototype.forSize=function(n,x){return new this.constructor(this.relativePositions,{width:n,height:x})},n.prototype.shiftBy=function(n,x){return new this.constructor(this.relativePositions,this._imgDims,new Um(n,x))},n.prototype.shiftByPoint=function(n){return this.shiftBy(n.x,n.y)},n.prototype.align=function(n,x){if(void 0===x&&(x={}),n){var t=n instanceof Gm?n.box.floor():new Vm(n);return this.shiftBy(t.x,t.y).align(null,x)}var e=Object.assign({},{useDlibAlignment:!1,minBoxPadding:.2},x),i=e.useDlibAlignment,r=e.minBoxPadding;return i?this.alignDlib():this.alignMinBbox(r)},n.prototype.alignDlib=function(){var n=this.getRefPointsForAlignment(),x=n[0],t=n[1],e=n[2],i=function(n){return e.sub(n).magnitude()},r=(i(x)+i(t))/2,o=Math.floor(r/ib),s=Fm(n),h=Math.floor(Math.max(0,s.x-tb*o)),u=Math.floor(Math.max(0,s.y-eb*o));return new xb(h,u,Math.min(o,this.imageWidth+h),Math.min(o,this.imageHeight+u))},n.prototype.alignMinBbox=function(n){var x=Km(this.positions);return x.pad(x.width*n,x.height*n)},n.prototype.getRefPointsForAlignment=function(){throw new Error("getRefPointsForAlignment not implemented by base class")},n}(),ob=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.getRefPointsForAlignment=function(){var n=this.positions;return[n[0],n[1],Fm([n[3],n[4]])]},x}(rb),sb=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.getJawOutline=function(){return this.positions.slice(0,17)},x.prototype.getLeftEyeBrow=function(){return this.positions.slice(17,22)},x.prototype.getRightEyeBrow=function(){return this.positions.slice(22,27)},x.prototype.getNose=function(){return this.positions.slice(27,36)},x.prototype.getLeftEye=function(){return this.positions.slice(36,42)},x.prototype.getRightEye=function(){return this.positions.slice(42,48)},x.prototype.getMouth=function(){return this.positions.slice(48,68)},x.prototype.getRefPointsForAlignment=function(){return[this.getLeftEye(),this.getRightEye(),this.getMouth()].map(Fm)},x}(rb),hb=function(){function n(n,x){this._label=n,this._distance=x}return Object.defineProperty(n.prototype,"label",{get:function(){return this._label},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"distance",{get:function(){return this._distance},enumerable:!0,configurable:!0}),n.prototype.toString=function(n){return void 0===n&&(n=!0),this.label+(n?" ("+Bm(this.distance)+")":"")},n}(),ub=function(n){function x(x,t){var e=n.call(this,x)||this;return e._label=t,e}return km(x,n),x.assertIsValidLabeledBox=function(n,x){if(Vm.assertIsValidBox(n,x),!Lm(n.label))throw new Error(x+" - expected property label ("+n.label+") to be a number")},Object.defineProperty(x.prototype,"label",{get:function(){return this._label},enumerable:!0,configurable:!0}),x}(Vm),ab=function(){function n(n,x){if("string"!==typeof n)throw new Error("LabeledFaceDescriptors - constructor expected label to be a string");if(!Array.isArray(x)||x.some(function(n){return!(n instanceof Float32Array)}))throw new Error("LabeledFaceDescriptors - constructor expected descriptors to be an array of Float32Array");this._label=n,this._descriptors=x}return Object.defineProperty(n.prototype,"label",{get:function(){return this._label},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"descriptors",{get:function(){return this._descriptors},enumerable:!0,configurable:!0}),n.prototype.toJSON=function(){return{label:this.label,descriptors:this.descriptors.map(function(n){return Array.from(n)})}},n.fromJSON=function(x){var t=x.descriptors.map(function(n){return new Float32Array(n)});return new n(x.label,t)},n}();(function(n){function x(x,t,e,i){var r=n.call(this,x,t)||this;return r._score=e,r._classScore=i,r}km(x,n),x.assertIsValidPredictedBox=function(n,x){if(ub.assertIsValidLabeledBox(n,x),!Hm(n.score)||!Hm(n.classScore))throw new Error(x+" - expected properties score ("+n.score+") and ("+n.classScore+") to be a number between [0, 1]")},Object.defineProperty(x.prototype,"score",{get:function(){return this._score},enumerable:!0,configurable:!0}),Object.defineProperty(x.prototype,"classScore",{get:function(){return this._classScore},enumerable:!0,configurable:!0})})(ub);function gb(n){return n["detection"]instanceof Gm}function lb(n,x){var t={detection:x};return Object.assign({},n,t)}function cb(){var n=window["fetch"]||function(){throw new Error("fetch - missing fetch implementation for browser environment")},x=function(){throw new Error("readFile - filesystem not available for browser environment")};return{Canvas:HTMLCanvasElement,CanvasRenderingContext2D:CanvasRenderingContext2D,Image:HTMLImageElement,ImageData:ImageData,Video:HTMLVideoElement,createCanvasElement:function(){return document.createElement("canvas")},createImageElement:function(){return document.createElement("img")},fetch:n,readFile:x}}function db(n){var x="";if(!n)try{n=e(Object(function(){var n=new Error("Cannot find module 'fs'");throw n.code="MODULE_NOT_FOUND",n}()))}catch(i){x=i.toString()}var t=n?function(x){return new Promise(function(t,e){n.readFile(x,function(n,x){return n?e(n):t(x)})})}:function(){throw new Error("readFile - failed to require fs in nodejs environment with error: "+x)};return{readFile:t}}function fb(){var n=e.g["Canvas"]||e.g["HTMLCanvasElement"],x=e.g["Image"]||e.g["HTMLImageElement"],t=function(){if(n)return new n;throw new Error("createCanvasElement - missing Canvas implementation for nodejs environment")},i=function(){if(x)return new x;throw new Error("createImageElement - missing Image implementation for nodejs environment")},r=e.g["fetch"]||function(){throw new Error("fetch - missing fetch implementation for nodejs environment")},o=db();return qm({Canvas:n||function(){function n(){}return n}(),CanvasRenderingContext2D:e.g["CanvasRenderingContext2D"]||function(){function n(){}return n}(),Image:x||function(){function n(){}return n}(),ImageData:e.g["ImageData"]||function(){function n(){}return n}(),Video:e.g["HTMLVideoElement"]||function(){function n(){}return n}(),createCanvasElement:t,createImageElement:i,fetch:r},o)}function pb(){return"object"===typeof window&&"undefined"!==typeof document&&"undefined"!==typeof HTMLImageElement&&"undefined"!==typeof HTMLCanvasElement&&"undefined"!==typeof HTMLVideoElement&&"undefined"!==typeof ImageData&&"undefined"!==typeof CanvasRenderingContext2D}function yb(){return"object"===typeof e.g&&"undefined"!==typeof process&&!!process.version}function mb(){if(!nb)throw new Error("getEnv - environment is not defined, check isNodejs() and isBrowser()");return nb}function bb(n){nb=n}function zb(){pb()&&bb(cb()),yb()&&bb(fb())}function vb(n){if(nb||zb(),!nb)throw new Error("monkeyPatch - environment is not defined, check isNodejs() and isBrowser()");var x=n.Canvas,t=void 0===x?nb.Canvas:x,e=n.Image,i=void 0===e?nb.Image:e;nb.Canvas=t,nb.Image=i,nb.createCanvasElement=n.createCanvasElement||function(){return new t},nb.createImageElement=n.createImageElement||function(){return new i},nb.ImageData=n.ImageData||nb.ImageData,nb.Video=n.Video||nb.Video,nb.fetch=n.fetch||nb.fetch,nb.readFile=n.readFile||nb.readFile}var jb,wb={getEnv:mb,setEnv:bb,initialize:zb,createBrowserEnv:cb,createFileSystem:db,createNodejsEnv:fb,monkeyPatch:vb,isBrowser:pb,isNodejs:yb};function kb(n){return wb.isNodejs()||"string"!==typeof n?n:document.getElementById(n)}function qb(n){var x=wb.getEnv(),t=x.Canvas,e=x.CanvasRenderingContext2D;if(n instanceof e)return n;var i=kb(n);if(!(i instanceof t))throw new Error("resolveContext2d - expected canvas to be of instance of Canvas");var r=i.getContext("2d");if(!r)throw new Error("resolveContext2d - canvas 2d context is null");return r}zb(),function(n){n["TOP_LEFT"]="TOP_LEFT",n["TOP_RIGHT"]="TOP_RIGHT",n["BOTTOM_LEFT"]="BOTTOM_LEFT",n["BOTTOM_RIGHT"]="BOTTOM_RIGHT"}(jb||(jb={}));var Cb=function(){function n(n){void 0===n&&(n={});var x=n.anchorPosition,t=n.backgroundColor,e=n.fontColor,i=n.fontSize,r=n.fontStyle,o=n.padding;this.anchorPosition=x||jb.TOP_LEFT,this.backgroundColor=t||"rgba(0, 0, 0, 0.5)",this.fontColor=e||"rgba(255, 255, 255, 1)",this.fontSize=i||14,this.fontStyle=r||"Georgia",this.padding=o||4}return n}(),Ab=function(){function n(x,t,e){void 0===e&&(e={}),this.text="string"===typeof x?[x]:x instanceof n?x.text:x,this.anchor=t,this.options=new Cb(e)}return n.prototype.measureWidth=function(n){var x=this.options.padding;return this.text.map(function(x){return n.measureText(x).width}).reduce(function(n,x){return n<x?x:n},0)+2*x},n.prototype.measureHeight=function(){var n=this.options,x=n.fontSize,t=n.padding;return this.text.length*x+2*t},n.prototype.getUpperLeft=function(n,x){var t=this.options.anchorPosition,e=t===jb.BOTTOM_RIGHT||t===jb.TOP_RIGHT,i=t===jb.BOTTOM_LEFT||t===jb.BOTTOM_RIGHT,r=this.measureWidth(n),o=this.measureHeight(),s=e?this.anchor.x-r:this.anchor.x,h=i?this.anchor.y-o:this.anchor.y;if(x){var u=x.width,a=x.height,g=Math.max(Math.min(s,u-r),0),l=Math.max(Math.min(h,a-o),0);return{x:g,y:l}}return{x:s,y:h}},n.prototype.draw=function(n){var x=kb(n),t=qb(x),e=this.options,i=e.backgroundColor,r=e.fontColor,o=e.fontSize,s=e.fontStyle,h=e.padding;t.font=o+"px "+s;var u=this.measureWidth(t),a=this.measureHeight();t.fillStyle=i;var g=this.getUpperLeft(t,x);t.fillRect(g.x,g.y,u,a),t.fillStyle=r,this.text.forEach(function(n,x){var e=h+g.x,i=h+g.y+(x+1)*o;t.fillText(n,e,i)})},n}(),Eb=function(){function n(n){void 0===n&&(n={});var x=n.boxColor,t=n.lineWidth,e=n.label,i=n.drawLabelOptions;this.boxColor=x||"rgba(0, 0, 255, 1)",this.lineWidth=t||2,this.label=e;var r={anchorPosition:jb.BOTTOM_LEFT,backgroundColor:this.boxColor};this.drawLabelOptions=new Cb(Object.assign({},r,i))}return n}();(function(){function n(n,x){void 0===x&&(x={}),this.box=new Vm(n),this.options=new Eb(x)}n.prototype.draw=function(n){var x=qb(n),t=this.options,e=t.boxColor,i=t.lineWidth,r=this.box,o=r.x,s=r.y,h=r.width,u=r.height;x.strokeStyle=e,x.lineWidth=i,x.strokeRect(o,s,h,u);var a=this.options.label;a&&new Ab([a],{x:o-i/2,y:s},this.options.drawLabelOptions).draw(n)}})();function Sb(n){var x=wb.getEnv(),t=x.Image,e=x.Video;return n instanceof t&&n.complete||n instanceof e&&n.readyState>=3}function Ib(n){return new Promise(function(x,t){if(n instanceof wb.getEnv().Canvas||Sb(n))return x();function e(n){n.currentTarget&&(n.currentTarget.removeEventListener("load",e),n.currentTarget.removeEventListener("error",i),x(n))}function i(n){n.currentTarget&&(n.currentTarget.removeEventListener("load",e),n.currentTarget.removeEventListener("error",i),t(n))}n.addEventListener("load",e),n.addEventListener("error",i)})}function Db(n){var x=wb.getEnv(),t=x.Image,e=x.Video;return n instanceof t?new Sm(n.naturalWidth,n.naturalHeight):n instanceof e?new Sm(n.videoWidth,n.videoHeight):new Sm(n.width,n.height)}function Ob(n){var x=n.width,t=n.height,e=wb.getEnv().createCanvasElement,i=e();return i.width=x,i.height=t,i}function _b(n,x){var t=wb.getEnv().ImageData;if(!(n instanceof t)&&!Sb(n))throw new Error("createCanvasFromMedia - media has not finished loading yet");var e=x||Db(n),i=e.width,r=e.height,o=Ob({width:i,height:r});return n instanceof t?qb(o).putImageData(n,0,0):qb(o).drawImage(n,0,0,i,r),o}function Tb(n,x){return Cm(this,void 0,void 0,function(){var t,e,i,r,o,s;return Am(this,function(h){switch(h.label){case 0:return t=x||wb.getEnv().createCanvasElement(),e=n.shape.slice(_m(n)?1:0),i=e[0],r=e[1],o=e[2],s=bs(function(){return n.as3D(i,r,o).toInt()}),[4,im.toPixels(s,t)];case 1:return h.sent(),s.dispose(),[2,t]}})})}function Rb(n){var x=wb.getEnv(),t=x.Image,e=x.Canvas,i=x.Video;return n instanceof t||n instanceof e||n instanceof i}function Bb(n,x,t){void 0===t&&(t=!1);var e=wb.getEnv(),i=e.Image,r=e.Canvas;if(!(n instanceof i||n instanceof r))throw new Error("imageToSquare - expected arg0 to be HTMLImageElement | HTMLCanvasElement");var o=Db(n),s=x/Math.max(o.height,o.width),h=s*o.width,u=s*o.height,a=Ob({width:x,height:x}),g=n instanceof r?n:_b(n),l=Math.abs(h-u)/2,c=t&&h<u?l:0,d=t&&u<h?l:0;return qb(a).drawImage(g,c,d,h,u),a}var Mb=function(){function n(n,x){var t=this;if(void 0===x&&(x=!1),this._imageTensors=[],this._canvases=[],this._treatAsBatchInput=!1,this._inputDimensions=[],!Array.isArray(n))throw new Error("NetInput.constructor - expected inputs to be an Array of TResolvedNetInput or to be instanceof tf.Tensor4D, instead have "+n);this._treatAsBatchInput=x,this._batchSize=n.length,n.forEach(function(n,x){if(Om(n))return t._imageTensors[x]=n,void(t._inputDimensions[x]=n.shape);if(_m(n)){var e=n.shape[0];if(1!==e)throw new Error("NetInput - tf.Tensor4D with batchSize "+e+" passed, but not supported in input array");return t._imageTensors[x]=n,void(t._inputDimensions[x]=n.shape.slice(1))}var i=n instanceof wb.getEnv().Canvas?n:_b(n);t._canvases[x]=i,t._inputDimensions[x]=[i.height,i.width,3]})}return Object.defineProperty(n.prototype,"imageTensors",{get:function(){return this._imageTensors},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"canvases",{get:function(){return this._canvases},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"isBatchInput",{get:function(){return this.batchSize>1||this._treatAsBatchInput},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"batchSize",{get:function(){return this._batchSize},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"inputDimensions",{get:function(){return this._inputDimensions},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"inputSize",{get:function(){return this._inputSize},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"reshapedInputDimensions",{get:function(){var n=this;return Pm(this.batchSize,0,1).map(function(x,t){return n.getReshapedInputDimensions(t)})},enumerable:!0,configurable:!0}),n.prototype.getInput=function(n){return this.canvases[n]||this.imageTensors[n]},n.prototype.getInputDimensions=function(n){return this._inputDimensions[n]},n.prototype.getInputHeight=function(n){return this._inputDimensions[n][0]},n.prototype.getInputWidth=function(n){return this._inputDimensions[n][1]},n.prototype.getReshapedInputDimensions=function(n){if("number"!==typeof this.inputSize)throw new Error("getReshapedInputDimensions - inputSize not set, toBatchTensor has not been called yet");var x=this.getInputWidth(n),t=this.getInputHeight(n);return Nm({width:x,height:t},this.inputSize)},n.prototype.toBatchTensor=function(n,x){var t=this;return void 0===x&&(x=!0),this._inputSize=n,bs(function(){var e=Pm(t.batchSize,0,1).map(function(e){var i=t.getInput(e);if(i instanceof Kr){var r=_m(i)?i:i.expandDims();return r=Zm(r,x),r.shape[1]===n&&r.shape[2]===n||(r=Tp.resizeBilinear(r,[n,n])),r.as3D(n,n,3)}if(i instanceof wb.getEnv().Canvas)return im.fromPixels(Bb(i,n,x));throw new Error("toBatchTensor - at batchIdx "+e+", expected input to be instanceof tf.Tensor or instanceof HTMLCanvasElement, instead have "+i)}),i=Qh(e.map(function(n){return n.toFloat()})).as4D(t.batchSize,n,n,3);return i})},n}();function Nb(n){return Cm(this,void 0,void 0,function(){var x,t,e;return Am(this,function(i){switch(i.label){case 0:if(n instanceof Mb)return[2,n];if(x=Array.isArray(n)?n:[n],!x.length)throw new Error("toNetInput - empty array passed as input");return t=function(x){return Array.isArray(n)?" at input index "+x+":":""},e=x.map(kb),e.forEach(function(n,e){if(!Rb(n)&&!Om(n)&&!_m(n)){if("string"===typeof x[e])throw new Error("toNetInput -"+t(e)+" string passed, but could not resolve HTMLElement for element id "+x[e]);throw new Error("toNetInput -"+t(e)+" expected media to be of type HTMLImageElement | HTMLVideoElement | HTMLCanvasElement | tf.Tensor3D, or to be an element id")}if(_m(n)){var i=n.shape[0];if(1!==i)throw new Error("toNetInput -"+t(e)+" tf.Tensor4D with batchSize "+i+" passed, but not supported in input array")}}),[4,Promise.all(e.map(function(n){return Rb(n)&&Ib(n)}))];case 1:return i.sent(),[2,new Mb(e,Array.isArray(n))]}})})}function Fb(n,x){return Cm(this,void 0,void 0,function(){var t,e,i,r,o,s,h;return Am(this,function(u){switch(u.label){case 0:return t=wb.getEnv().Canvas,e=n,n instanceof t?[3,5]:[4,Nb(n)];case 1:if(i=u.sent(),i.batchSize>1)throw new Error("extractFaces - batchSize > 1 not supported");return r=i.getInput(0),r instanceof t?(o=r,[3,4]):[3,2];case 2:return[4,Tb(r)];case 3:o=u.sent(),u.label=4;case 4:e=o,u.label=5;case 5:return s=qb(e),h=x.map(function(n){return n instanceof Gm?n.forSize(e.width,e.height).box.floor():n}).map(function(n){return n.clipAtImageBorders(e.width,e.height)}),[2,h.map(function(n){var x=n.x,t=n.y,e=n.width,i=n.height,r=Ob({width:e,height:i});return qb(r).putImageData(s.getImageData(x,t,e,i),0,0),r})]}})})}function Pb(n,x){return Cm(this,void 0,void 0,function(){return Am(this,function(t){if(!Om(n)&&!_m(n))throw new Error("extractFaceTensors - expected image tensor to be 3D or 4D");if(_m(n)&&n.shape[0]>1)throw new Error("extractFaceTensors - batchSize > 1 not supported");return[2,bs(function(){var t=n.shape.slice(_m(n)?1:0),e=t[0],i=t[1],r=t[2],o=x.map(function(n){return n instanceof Gm?n.forSize(i,e).box:n}).map(function(n){return n.clipAtImageBorders(i,e)}),s=o.map(function(x){var t=x.x,o=x.y,s=x.width,h=x.height;return bf(n.as3D(e,i,r),[o,t,0],[h,s,r])});return s})]})})}function Lb(n,x){return Cm(this,void 0,void 0,function(){var t,e;return Am(this,function(i){switch(i.label){case 0:return t=wb.getEnv().fetch,[4,t(n,x)];case 1:if(e=i.sent(),!(e.status<400))throw new Error("failed to fetch: ("+e.status+") "+e.statusText+", from url: "+e.url);return[2,e]}})})}function Hb(n){return Cm(this,void 0,void 0,function(){return Am(this,function(x){switch(x.label){case 0:return[4,Lb(n)];case 1:return[2,x.sent().json()]}})})}function Ub(n,x){var t=x+"-weights_manifest.json";if(!n)return{modelBaseUri:"",manifestUri:t};if("/"===n)return{modelBaseUri:"/",manifestUri:"/"+t};var e=n.startsWith("http://")?"http://":n.startsWith("https://")?"https://":"";n=n.replace(e,"");var i=n.split("/").filter(function(n){return n}),r=n.endsWith(".json")?i[i.length-1]:t,o=e+(n.endsWith(".json")?i.slice(0,i.length-1):i).join("/");return o=n.startsWith("/")?"/"+o:o,{modelBaseUri:o,manifestUri:"/"===o?"/"+r:o+"/"+r}}function Vb(n,x){return Cm(this,void 0,void 0,function(){var t,e,i,r;return Am(this,function(o){switch(o.label){case 0:return t=Ub(n,x),e=t.manifestUri,i=t.modelBaseUri,[4,Hb(e)];case 1:return r=o.sent(),[2,xm.loadWeights(r,i)]}})})}var Wb=function(){function n(n){this._name=n,this._params=void 0,this._paramMappings=[]}return Object.defineProperty(n.prototype,"params",{get:function(){return this._params},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"paramMappings",{get:function(){return this._paramMappings},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"isLoaded",{get:function(){return!!this.params},enumerable:!0,configurable:!0}),n.prototype.getParamFromPath=function(n){var x=this.traversePropertyPath(n),t=x.obj,e=x.objProp;return t[e]},n.prototype.reassignParamFromPath=function(n,x){var t=this.traversePropertyPath(n),e=t.obj,i=t.objProp;e[i].dispose(),e[i]=x},n.prototype.getParamList=function(){var n=this;return this._paramMappings.map(function(x){var t=x.paramPath;return{path:t,tensor:n.getParamFromPath(t)}})},n.prototype.getTrainableParams=function(){return this.getParamList().filter(function(n){return n.tensor instanceof no})},n.prototype.getFrozenParams=function(){return this.getParamList().filter(function(n){return!(n.tensor instanceof no)})},n.prototype.variable=function(){var n=this;this.getFrozenParams().forEach(function(x){var t=x.path,e=x.tensor;n.reassignParamFromPath(t,e.variable())})},n.prototype.freeze=function(){var n=this;this.getTrainableParams().forEach(function(x){var t=x.path,e=x.tensor,i=Ls(e.dataSync());e.dispose(),n.reassignParamFromPath(t,i)})},n.prototype.dispose=function(n){void 0===n&&(n=!0),this.getParamList().forEach(function(x){if(n&&x.tensor.isDisposed)throw new Error("param tensor has already been disposed for path "+x.path);x.tensor.dispose()}),this._params=void 0},n.prototype.serializeParams=function(){return new Float32Array(this.getParamList().map(function(n){var x=n.tensor;return Array.from(x.dataSync())}).reduce(function(n,x){return n.concat(x)}))},n.prototype.load=function(n){return Cm(this,void 0,void 0,function(){return Am(this,function(x){switch(x.label){case 0:return n instanceof Float32Array?(this.extractWeights(n),[2]):[4,this.loadFromUri(n)];case 1:return x.sent(),[2]}})})},n.prototype.loadFromUri=function(n){return Cm(this,void 0,void 0,function(){var x;return Am(this,function(t){switch(t.label){case 0:if(n&&"string"!==typeof n)throw new Error(this._name+".loadFromUri - expected model uri");return[4,Vb(n,this.getDefaultModelName())];case 1:return x=t.sent(),this.loadFromWeightMap(x),[2]}})})},n.prototype.loadFromDisk=function(n){return Cm(this,void 0,void 0,function(){var x,t,e,i,r,o,s,h,u,a;return Am(this,function(g){switch(g.label){case 0:if(n&&"string"!==typeof n)throw new Error(this._name+".loadFromDisk - expected model file path");return x=wb.getEnv().readFile,t=Ub(n,this.getDefaultModelName()),e=t.manifestUri,i=t.modelBaseUri,r=function(n){return Promise.all(n.map(function(n){return x(n).then(function(n){return n.buffer})}))},o=xm.weightsLoaderFactory(r),u=(h=JSON).parse,[4,x(e)];case 1:return s=u.apply(h,[g.sent().toString()]),[4,o(s,i)];case 2:return a=g.sent(),this.loadFromWeightMap(a),[2]}})})},n.prototype.loadFromWeightMap=function(n){var x=this.extractParamsFromWeigthMap(n),t=x.paramMappings,e=x.params;this._paramMappings=t,this._params=e},n.prototype.extractWeights=function(n){var x=this.extractParams(n),t=x.paramMappings,e=x.params;this._paramMappings=t,this._params=e},n.prototype.traversePropertyPath=function(n){if(!this.params)throw new Error("traversePropertyPath - model has no loaded params");var x=n.split("/").reduce(function(x,t){if(!x.nextObj.hasOwnProperty(t))throw new Error("traversePropertyPath - object does not have property "+t+", for path "+n);return{obj:x.nextObj,objProp:t,nextObj:x.nextObj[t]}},{nextObj:this.params}),t=x.obj,e=x.objProp;if(!t||!e||!(t[e]instanceof Kr))throw new Error("traversePropertyPath - parameter is not a tensor, for path "+n);return{obj:t,objProp:e}},n}();function Qb(n,x,t){return bs(function(){var e=Xd(n,x.depthwise_filter,x.pointwise_filter,t,"same");return e=td(e,x.bias),e})}function Gb(n,x,t){return void 0===t&&(t=!1),bs(function(){var e=Bf(t?td(Vd(n,x.conv0.filters,[2,2],"same"),x.conv0.bias):Qb(n,x.conv0,[2,2])),i=Qb(e,x.conv1,[1,1]),r=Bf(td(e,i)),o=Qb(r,x.conv2,[1,1]);return Bf(td(e,td(i,o)))})}function Kb(n,x,t,e){return void 0===t&&(t=!1),void 0===e&&(e=!0),bs(function(){var i=Bf(t?td(Vd(n,x.conv0.filters,e?[2,2]:[1,1],"same"),x.conv0.bias):Qb(n,x.conv0,e?[2,2]:[1,1])),r=Qb(i,x.conv1,[1,1]),o=Bf(td(i,r)),s=Qb(o,x.conv2,[1,1]),h=Bf(td(i,td(r,s))),u=Qb(h,x.conv3,[1,1]);return Bf(td(i,td(r,td(s,u))))})}function Yb(n,x,t,e){return void 0===t&&(t="same"),void 0===e&&(e=!1),bs(function(){var i=td(Vd(n,x.filters,[1,1],t),x.bias);return e?Bf(i):i})}function Jb(n,x){Object.keys(n).forEach(function(t){x.some(function(n){return n.originalPath===t})||n[t].dispose()})}function Xb(n,x){return function(t,e,i,r){var o=Gs(n(t*e*i*i),[i,i,t,e]),s=Vs(n(e));return x.push({paramPath:r+"/filters"},{paramPath:r+"/bias"}),{filters:o,bias:s}}}function Zb(n,x){return function(t,e,i){var r=Ws(n(t*e),[t,e]),o=Vs(n(e));return x.push({paramPath:i+"/weights"},{paramPath:i+"/bias"}),{weights:r,bias:o}}}var $b=function(){function n(n,x,t){this.depthwise_filter=n,this.pointwise_filter=x,this.bias=t}return n}();function nz(n,x){return function(t,e,i){var r=Gs(n(9*t),[3,3,t,1]),o=Gs(n(t*e),[1,1,t,e]),s=Vs(n(e));return x.push({paramPath:i+"/depthwise_filter"},{paramPath:i+"/pointwise_filter"},{paramPath:i+"/bias"}),new $b(r,o,s)}}function xz(n){return function(x){var t=n(x+"/depthwise_filter",4),e=n(x+"/pointwise_filter",4),i=n(x+"/bias",1);return new $b(t,e,i)}}function tz(n,x){return function(t,e,i){var r=n[t];if(!Im(r,e))throw new Error("expected weightMap["+t+"] to be a Tensor"+e+"D, instead have "+r);return x.push({originalPath:t,paramPath:i||t}),r}}function ez(n){var x=n;function t(n){var t=x.slice(0,n);return x=x.slice(n),t}function e(){return x}return{extractWeights:t,getRemainingWeights:e}}function iz(n,x){var t=Xb(n,x),e=nz(n,x);function i(n,x,i,r){void 0===r&&(r=!1);var o=r?t(n,x,3,i+"/conv0"):e(n,x,i+"/conv0"),s=e(x,x,i+"/conv1"),h=e(x,x,i+"/conv2");return{conv0:o,conv1:s,conv2:h}}function r(n,x,t,r){void 0===r&&(r=!1);var o=i(n,x,t,r),s=o.conv0,h=o.conv1,u=o.conv2,a=e(x,x,t+"/conv3");return{conv0:s,conv1:h,conv2:u,conv3:a}}return{extractDenseBlock3Params:i,extractDenseBlock4Params:r}}function rz(n){var x=[],t=ez(n),e=t.extractWeights,i=t.getRemainingWeights,r=iz(e,x).extractDenseBlock4Params,o=r(3,32,"dense0",!0),s=r(32,64,"dense1"),h=r(64,128,"dense2"),u=r(128,256,"dense3");if(0!==i().length)throw new Error("weights remaing after extract: "+i().length);return{paramMappings:x,params:{dense0:o,dense1:s,dense2:h,dense3:u}}}function oz(n){return function(x){var t=n(x+"/filters",4),e=n(x+"/bias",1);return{filters:t,bias:e}}}function sz(n,x){var t=tz(n,x),e=oz(t),i=xz(t);function r(n,x){void 0===x&&(x=!1);var t=x?e(n+"/conv0"):i(n+"/conv0"),r=i(n+"/conv1"),o=i(n+"/conv2");return{conv0:t,conv1:r,conv2:o}}function o(n,x){void 0===x&&(x=!1);var t=x?e(n+"/conv0"):i(n+"/conv0"),r=i(n+"/conv1"),o=i(n+"/conv2"),s=i(n+"/conv3");return{conv0:t,conv1:r,conv2:o,conv3:s}}return{extractDenseBlock3Params:r,extractDenseBlock4Params:o}}function hz(n){var x=[],t=sz(n,x).extractDenseBlock4Params,e={dense0:t("dense0",!0),dense1:t("dense1"),dense2:t("dense2"),dense3:t("dense3")};return Jb(n,x),{params:e,paramMappings:x}}var uz=function(n){function x(){return n.call(this,"FaceFeatureExtractor")||this}return km(x,n),x.prototype.forwardInput=function(n){var x=this.params;if(!x)throw new Error("FaceFeatureExtractor - load model before inference");return bs(function(){var t=n.toBatchTensor(112,!0),e=[122.782,117.001,104.298],i=Xm(t,e).div(Us(255)),r=Kb(i,x.dense0,!0);return r=Kb(r,x.dense1),r=Kb(r,x.dense2),r=Kb(r,x.dense3),r=lf(r,[7,7],[2,2],"valid"),r})},x.prototype.forward=function(n){return Cm(this,void 0,void 0,function(){var x;return Am(this,function(t){switch(t.label){case 0:return x=this.forwardInput,[4,Nb(n)];case 1:return[2,x.apply(this,[t.sent()])]}})})},x.prototype.getDefaultModelName=function(){return"face_feature_extractor_model"},x.prototype.extractParamsFromWeigthMap=function(n){return hz(n)},x.prototype.extractParams=function(n){return rz(n)},x}(Wb);function az(n,x){return bs(function(){return td(nf(n,x.weights),x.bias)})}function gz(n,x,t){var e=[],i=ez(n),r=i.extractWeights,o=i.getRemainingWeights,s=Zb(r,e),h=s(x,t,"fc");if(0!==o().length)throw new Error("weights remaing after extract: "+o().length);return{paramMappings:e,params:{fc:h}}}function lz(n){var x=[],t=tz(n,x);function e(n){var x=t(n+"/weights",2),e=t(n+"/bias",1);return{weights:x,bias:e}}var i={fc:e("fc")};return Jb(n,x),{params:i,paramMappings:x}}function cz(n){var x={},t={};return Object.keys(n).forEach(function(e){var i=e.startsWith("fc")?t:x;i[e]=n[e]}),{featureExtractorMap:x,classifierMap:t}}var dz=function(n){function x(x,t){var e=n.call(this,x)||this;return e._faceFeatureExtractor=t,e}return km(x,n),Object.defineProperty(x.prototype,"faceFeatureExtractor",{get:function(){return this._faceFeatureExtractor},enumerable:!0,configurable:!0}),x.prototype.runNet=function(n){var x=this,t=this.params;if(!t)throw new Error(this._name+" - load model before inference");return bs(function(){var e=n instanceof Mb?x.faceFeatureExtractor.forwardInput(n):n;return az(e.as2D(e.shape[0],-1),t.fc)})},x.prototype.dispose=function(x){void 0===x&&(x=!0),this.faceFeatureExtractor.dispose(x),n.prototype.dispose.call(this,x)},x.prototype.loadClassifierParams=function(n){var x=this.extractClassifierParams(n),t=x.params,e=x.paramMappings;this._params=t,this._paramMappings=e},x.prototype.extractClassifierParams=function(n){return gz(n,this.getClassifierChannelsIn(),this.getClassifierChannelsOut())},x.prototype.extractParamsFromWeigthMap=function(n){var x=cz(n),t=x.featureExtractorMap,e=x.classifierMap;return this.faceFeatureExtractor.loadFromWeightMap(t),lz(e)},x.prototype.extractParams=function(n){var x=this.getClassifierChannelsIn(),t=this.getClassifierChannelsOut(),e=t*x+t,i=n.slice(0,n.length-e),r=n.slice(n.length-e);return this.faceFeatureExtractor.extractWeights(i),this.extractClassifierParams(r)},x}(Wb),fz=["neutral","happy","sad","angry","fearful","disgusted","surprised"],pz=function(){function n(n){var x=this;if(7!==n.length)throw new Error("FaceExpressions.constructor - expected probabilities.length to be 7, have: "+n.length);fz.forEach(function(t,e){x[t]=n[e]})}return n.prototype.asSortedArray=function(){var n=this;return fz.map(function(x){return{expression:x,probability:n[x]}}).sort(function(n,x){return x.probability-n.probability})},n}(),yz=function(n){function x(x){return void 0===x&&(x=new uz),n.call(this,"FaceExpressionNet",x)||this}return km(x,n),x.prototype.forwardInput=function(n){var x=this;return bs(function(){return yu(x.runNet(n))})},x.prototype.forward=function(n){return Cm(this,void 0,void 0,function(){var x;return Am(this,function(t){switch(t.label){case 0:return x=this.forwardInput,[4,Nb(n)];case 1:return[2,x.apply(this,[t.sent()])]}})})},x.prototype.predictExpressions=function(n){return Cm(this,void 0,void 0,function(){var x,t,e,i,r=this;return Am(this,function(o){switch(o.label){case 0:return[4,Nb(n)];case 1:return x=o.sent(),[4,this.forwardInput(x)];case 2:return t=o.sent(),[4,Promise.all(Yh(t).map(function(n){return Cm(r,void 0,void 0,function(){var x;return Am(this,function(t){switch(t.label){case 0:return[4,n.data()];case 1:return x=t.sent(),n.dispose(),[2,x]}})})}))];case 3:return e=o.sent(),t.dispose(),i=e.map(function(n){return new pz(n)}),[2,x.isBatchInput?i:i[0]]}})})},x.prototype.getDefaultModelName=function(){return"face_expression_model"},x.prototype.getClassifierChannelsIn=function(){return 256},x.prototype.getClassifierChannelsOut=function(){return 7},x}(dz);function mz(n,x){var t={expressions:x};return Object.assign({},n,t)}function bz(n){return gb(n)&&n["landmarks"]instanceof rb&&n["unshiftedLandmarks"]instanceof rb&&n["alignedRect"]instanceof Gm}function zz(n,x){var t=n.detection.box,e=x.shiftBy(t.x,t.y),i=e.align(),r=n.detection.imageDims,o=new Gm(n.detection.score,i.rescale(r.reverse()),r),s={landmarks:e,unshiftedLandmarks:x,alignedRect:o};return Object.assign({},n,s)}var vz=function(){function n(n){void 0===n&&(n={});var x=n.drawLines,t=void 0===x||x,e=n.drawPoints,i=void 0===e||e,r=n.lineWidth,o=n.lineColor,s=n.pointSize,h=n.pointColor;this.drawLines=t,this.drawPoints=i,this.lineWidth=r||1,this.pointSize=s||2,this.lineColor=o||"rgba(0, 255, 255, 1)",this.pointColor=h||"rgba(255, 0, 255, 1)"}return n}();(function(){function n(n,x){void 0===x&&(x={}),this.faceLandmarks=n,this.options=new vz(x)}n.prototype.draw=function(n){var x=qb(n),t=this.options,e=t.drawLines,i=t.drawPoints,r=t.lineWidth,o=t.lineColor,s=t.pointSize,h=t.pointColor;if(e&&this.faceLandmarks instanceof sb&&(x.strokeStyle=o,x.lineWidth=r,jm(x,this.faceLandmarks.getJawOutline()),jm(x,this.faceLandmarks.getLeftEyeBrow()),jm(x,this.faceLandmarks.getRightEyeBrow()),jm(x,this.faceLandmarks.getNose()),jm(x,this.faceLandmarks.getLeftEye(),!0),jm(x,this.faceLandmarks.getRightEye(),!0),jm(x,this.faceLandmarks.getMouth(),!0)),i){x.strokeStyle=h,x.fillStyle=h;var u=function(n){x.beginPath(),x.arc(n.x,n.y,s,0,2*Math.PI),x.fill()};this.faceLandmarks.positions.forEach(u)}}})();function jz(n,x){var t=Xb(n,x),e=nz(n,x);function i(n,x,i){var r=e(n,x,i+"/separable_conv0"),o=e(x,x,i+"/separable_conv1"),s=t(n,x,1,i+"/expansion_conv");return{separable_conv0:r,separable_conv1:o,expansion_conv:s}}function r(n,x){var t=e(n,n,x+"/separable_conv0"),i=e(n,n,x+"/separable_conv1"),r=e(n,n,x+"/separable_conv2");return{separable_conv0:t,separable_conv1:i,separable_conv2:r}}return{extractConvParams:t,extractSeparableConvParams:e,extractReductionBlockParams:i,extractMainBlockParams:r}}function wz(n,x){var t=[],e=ez(n),i=e.extractWeights,r=e.getRemainingWeights,o=jz(i,t),s=o.extractConvParams,h=o.extractSeparableConvParams,u=o.extractReductionBlockParams,a=o.extractMainBlockParams,g=s(3,32,3,"entry_flow/conv_in"),l=u(32,64,"entry_flow/reduction_block_0"),c=u(64,128,"entry_flow/reduction_block_1"),d={conv_in:g,reduction_block_0:l,reduction_block_1:c},f={};Pm(x,0,1).forEach(function(n){f["main_block_"+n]=a(128,"middle_flow/main_block_"+n)});var p=u(128,256,"exit_flow/reduction_block"),y=h(256,512,"exit_flow/separable_conv"),m={reduction_block:p,separable_conv:y};if(0!==r().length)throw new Error("weights remaing after extract: "+r().length);return{paramMappings:t,params:{entry_flow:d,middle_flow:f,exit_flow:m}}}function kz(n,x){var t=tz(n,x),e=oz(t),i=xz(t);function r(n){var x=i(n+"/separable_conv0"),t=i(n+"/separable_conv1"),r=e(n+"/expansion_conv");return{separable_conv0:x,separable_conv1:t,expansion_conv:r}}function o(n){var x=i(n+"/separable_conv0"),t=i(n+"/separable_conv1"),e=i(n+"/separable_conv2");return{separable_conv0:x,separable_conv1:t,separable_conv2:e}}return{extractConvParams:e,extractSeparableConvParams:i,extractReductionBlockParams:r,extractMainBlockParams:o}}function qz(n,x){var t=[],e=kz(n,t),i=e.extractConvParams,r=e.extractSeparableConvParams,o=e.extractReductionBlockParams,s=e.extractMainBlockParams,h=i("entry_flow/conv_in"),u=o("entry_flow/reduction_block_0"),a=o("entry_flow/reduction_block_1"),g={conv_in:h,reduction_block_0:u,reduction_block_1:a},l={};Pm(x,0,1).forEach(function(n){l["main_block_"+n]=s("middle_flow/main_block_"+n)});var c=o("exit_flow/reduction_block"),d=r("exit_flow/separable_conv"),f={reduction_block:c,separable_conv:d};return Jb(n,t),{params:{entry_flow:g,middle_flow:l,exit_flow:f},paramMappings:t}}function Cz(n,x,t){return td(Vd(n,x.filters,t,"same"),x.bias)}function Az(n,x,t){void 0===t&&(t=!0);var e=t?Bf(n):n;return e=Qb(e,x.separable_conv0,[1,1]),e=Qb(Bf(e),x.separable_conv1,[1,1]),e=gf(e,[3,3],[2,2],"same"),e=td(e,Cz(n,x.expansion_conv,[2,2])),e}function Ez(n,x){var t=Qb(Bf(n),x.separable_conv0,[1,1]);return t=Qb(Bf(t),x.separable_conv1,[1,1]),t=Qb(Bf(t),x.separable_conv2,[1,1]),t=td(t,n),t}var Sz,Iz=function(n){function x(x){var t=n.call(this,"TinyXception")||this;return t._numMainBlocks=x,t}return km(x,n),x.prototype.forwardInput=function(n){var x=this,t=this.params;if(!t)throw new Error("TinyXception - load model before inference");return bs(function(){var e=n.toBatchTensor(112,!0),i=[122.782,117.001,104.298],r=Xm(e,i).div(Us(256)),o=Bf(Cz(r,t.entry_flow.conv_in,[2,2]));return o=Az(o,t.entry_flow.reduction_block_0,!1),o=Az(o,t.entry_flow.reduction_block_1),Pm(x._numMainBlocks,0,1).forEach(function(n){o=Ez(o,t.middle_flow["main_block_"+n])}),o=Az(o,t.exit_flow.reduction_block),o=Bf(Qb(o,t.exit_flow.separable_conv,[1,1])),o})},x.prototype.forward=function(n){return Cm(this,void 0,void 0,function(){var x;return Am(this,function(t){switch(t.label){case 0:return x=this.forwardInput,[4,Nb(n)];case 1:return[2,x.apply(this,[t.sent()])]}})})},x.prototype.getDefaultModelName=function(){return"tiny_xception_model"},x.prototype.extractParamsFromWeigthMap=function(n){return qz(n,this._numMainBlocks)},x.prototype.extractParams=function(n){return wz(n,this._numMainBlocks)},x}(Wb);function Dz(n){var x=[],t=ez(n),e=t.extractWeights,i=t.getRemainingWeights,r=Zb(e,x),o=r(512,1,"fc/age"),s=r(512,2,"fc/gender");if(0!==i().length)throw new Error("weights remaing after extract: "+i().length);return{paramMappings:x,params:{fc:{age:o,gender:s}}}}function Oz(n){var x=[],t=tz(n,x);function e(n){var x=t(n+"/weights",2),e=t(n+"/bias",1);return{weights:x,bias:e}}var i={fc:{age:e("fc/age"),gender:e("fc/gender")}};return Jb(n,x),{params:i,paramMappings:x}}(function(n){n["FEMALE"]="female",n["MALE"]="male"})(Sz||(Sz={}));var _z=function(n){function x(x){void 0===x&&(x=new Iz(2));var t=n.call(this,"AgeGenderNet")||this;return t._faceFeatureExtractor=x,t}return km(x,n),Object.defineProperty(x.prototype,"faceFeatureExtractor",{get:function(){return this._faceFeatureExtractor},enumerable:!0,configurable:!0}),x.prototype.runNet=function(n){var x=this,t=this.params;if(!t)throw new Error(this._name+" - load model before inference");return bs(function(){var e=n instanceof Mb?x.faceFeatureExtractor.forwardInput(n):n,i=lf(e,[7,7],[2,2],"valid").as2D(e.shape[0],-1),r=az(i,t.fc.age).as1D(),o=az(i,t.fc.gender);return{age:r,gender:o}})},x.prototype.forwardInput=function(n){var x=this;return bs(function(){var t=x.runNet(n),e=t.age,i=t.gender;return{age:e,gender:yu(i)}})},x.prototype.forward=function(n){return Cm(this,void 0,void 0,function(){var x;return Am(this,function(t){switch(t.label){case 0:return x=this.forwardInput,[4,Nb(n)];case 1:return[2,x.apply(this,[t.sent()])]}})})},x.prototype.predictAgeAndGender=function(n){return Cm(this,void 0,void 0,function(){var x,t,e,i,r,o,s=this;return Am(this,function(h){switch(h.label){case 0:return[4,Nb(n)];case 1:return x=h.sent(),[4,this.forwardInput(x)];case 2:return t=h.sent(),e=Yh(t.age),i=Yh(t.gender),r=e.map(function(n,x){return{ageTensor:n,genderTensor:i[x]}}),[4,Promise.all(r.map(function(n){var x=n.ageTensor,t=n.genderTensor;return Cm(s,void 0,void 0,function(){var n,e,i,r,o;return Am(this,function(s){switch(s.label){case 0:return[4,x.data()];case 1:return n=s.sent()[0],[4,t.data()];case 2:return e=s.sent()[0],i=e>.5,r=i?Sz.MALE:Sz.FEMALE,o=i?e:1-e,x.dispose(),t.dispose(),[2,{age:n,gender:r,genderProbability:o}]}})})}))];case 3:return o=h.sent(),t.age.dispose(),t.gender.dispose(),[2,x.isBatchInput?o:o[0]]}})})},x.prototype.getDefaultModelName=function(){return"age_gender_model"},x.prototype.dispose=function(x){void 0===x&&(x=!0),this.faceFeatureExtractor.dispose(x),n.prototype.dispose.call(this,x)},x.prototype.loadClassifierParams=function(n){var x=this.extractClassifierParams(n),t=x.params,e=x.paramMappings;this._params=t,this._paramMappings=e},x.prototype.extractClassifierParams=function(n){return Dz(n)},x.prototype.extractParamsFromWeigthMap=function(n){var x=cz(n),t=x.featureExtractorMap,e=x.classifierMap;return this.faceFeatureExtractor.loadFromWeightMap(t),Oz(e)},x.prototype.extractParams=function(n){var x=1539,t=n.slice(0,n.length-x),e=n.slice(n.length-x);return this.faceFeatureExtractor.extractWeights(t),this.extractClassifierParams(e)},x}(Wb),Tz=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.postProcess=function(n,x,t){var e=t.map(function(n){var t=n.width,e=n.height,i=x/Math.max(e,t);return{width:t*i,height:e*i}}),i=e.length;return bs(function(){var t=function(n,x){return Qh([$s([68],n),$s([68],x)],1).as2D(1,136).as1D()},r=function(n,x){var t=e[n],i=t.width,r=t.height;return x(i,r)?Math.abs(i-r)/2:0},o=function(n){return r(n,function(n,x){return n<x})},s=function(n){return r(n,function(n,x){return x<n})},h=n.mul($s([i,136],x)).sub(Qh(Array.from(Array(i),function(n,x){return t(o(x),s(x))}))).div(Qh(Array.from(Array(i),function(n,x){return t(e[x].width,e[x].height)})));return h})},x.prototype.forwardInput=function(n){var x=this;return bs(function(){var t=x.runNet(n);return x.postProcess(t,n.inputSize,n.inputDimensions.map(function(n){var x=n[0],t=n[1];return{height:x,width:t}}))})},x.prototype.forward=function(n){return Cm(this,void 0,void 0,function(){var x;return Am(this,function(t){switch(t.label){case 0:return x=this.forwardInput,[4,Nb(n)];case 1:return[2,x.apply(this,[t.sent()])]}})})},x.prototype.detectLandmarks=function(n){return Cm(this,void 0,void 0,function(){var x,t,e,i=this;return Am(this,function(r){switch(r.label){case 0:return[4,Nb(n)];case 1:return x=r.sent(),t=bs(function(){return Yh(i.forwardInput(x))}),[4,Promise.all(t.map(function(n,t){return Cm(i,void 0,void 0,function(){var e,i,r,o,s;return Am(this,function(h){switch(h.label){case 0:return r=(i=Array).from,[4,n.data()];case 1:return e=r.apply(i,[h.sent()]),o=e.filter(function(n,x){return Rm(x)}),s=e.filter(function(n,x){return!Rm(x)}),[2,new sb(Array(68).fill(0).map(function(n,x){return new Um(o[x],s[x])}),{height:x.getInputHeight(t),width:x.getInputWidth(t)})]}})})}))];case 2:return e=r.sent(),t.forEach(function(n){return n.dispose()}),[2,x.isBatchInput?e:e[0]]}})})},x.prototype.getClassifierChannelsOut=function(){return 136},x}(dz),Rz=function(n){function x(x){return void 0===x&&(x=new uz),n.call(this,"FaceLandmark68Net",x)||this}return km(x,n),x.prototype.getDefaultModelName=function(){return"face_landmark_68_model"},x.prototype.getClassifierChannelsIn=function(){return 256},x}(Tz);function Bz(n){var x=[],t=sz(n,x).extractDenseBlock3Params,e={dense0:t("dense0",!0),dense1:t("dense1"),dense2:t("dense2")};return Jb(n,x),{params:e,paramMappings:x}}function Mz(n){var x=[],t=ez(n),e=t.extractWeights,i=t.getRemainingWeights,r=iz(e,x).extractDenseBlock3Params,o=r(3,32,"dense0",!0),s=r(32,64,"dense1"),h=r(64,128,"dense2");if(0!==i().length)throw new Error("weights remaing after extract: "+i().length);return{paramMappings:x,params:{dense0:o,dense1:s,dense2:h}}}var Nz=function(n){function x(){return n.call(this,"TinyFaceFeatureExtractor")||this}return km(x,n),x.prototype.forwardInput=function(n){var x=this.params;if(!x)throw new Error("TinyFaceFeatureExtractor - load model before inference");return bs(function(){var t=n.toBatchTensor(112,!0),e=[122.782,117.001,104.298],i=Xm(t,e).div(Us(255)),r=Gb(i,x.dense0,!0);return r=Gb(r,x.dense1),r=Gb(r,x.dense2),r=lf(r,[14,14],[2,2],"valid"),r})},x.prototype.forward=function(n){return Cm(this,void 0,void 0,function(){var x;return Am(this,function(t){switch(t.label){case 0:return x=this.forwardInput,[4,Nb(n)];case 1:return[2,x.apply(this,[t.sent()])]}})})},x.prototype.getDefaultModelName=function(){return"face_feature_extractor_tiny_model"},x.prototype.extractParamsFromWeigthMap=function(n){return Bz(n)},x.prototype.extractParams=function(n){return Mz(n)},x}(Wb),Fz=function(n){function x(x){return void 0===x&&(x=new Nz),n.call(this,"FaceLandmark68TinyNet",x)||this}return km(x,n),x.prototype.getDefaultModelName=function(){return"face_landmark_68_tiny_model"},x.prototype.getClassifierChannelsIn=function(){return 128},x}(Tz);(function(n){function x(){return null!==n&&n.apply(this,arguments)||this}km(x,n)})(Rz);function Pz(n,x){return td(pd(n,x.weights),x.biases)}function Lz(n,x,t,e,i){void 0===i&&(i="same");var r=x.conv,o=r.filters,s=r.bias,h=Vd(n,o,t,i);return h=td(h,s),h=Pz(h,x.scale),e?Bf(h):h}function Hz(n,x){return Lz(n,x,[1,1],!0)}function Uz(n,x){return Lz(n,x,[1,1],!1)}function Vz(n,x){return Lz(n,x,[2,2],!0,"valid")}function Wz(n,x){function t(x,t,e){var i=n(x),r=i.length/(t*e*e);if(Tm(r))throw new Error("depth has to be an integer: "+r+", weights.length: "+i.length+", numFilters: "+t+", filterSize: "+e);return bs(function(){return Ff(Gs(i,[t,r,e,e]),[2,3,1,0])})}function e(e,i,r,o){var s=t(e,i,r),h=Vs(n(i));return x.push({paramPath:o+"/filters"},{paramPath:o+"/bias"}),{filters:s,bias:h}}function i(t,e){var i=Vs(n(t)),r=Vs(n(t));return x.push({paramPath:e+"/weights"},{paramPath:e+"/biases"}),{weights:i,biases:r}}function r(n,x,t,r){var o=e(n,x,t,r+"/conv"),s=i(x,r+"/scale");return{conv:o,scale:s}}function o(n,x,t,e,i){void 0===i&&(i=!1);var o=r((i?.5:1)*n,x,t,e+"/conv1"),s=r(n,x,t,e+"/conv2");return{conv1:o,conv2:s}}return{extractConvLayerParams:r,extractResidualLayerParams:o}}function Qz(n){var x=ez(n),t=x.extractWeights,e=x.getRemainingWeights,i=[],r=Wz(t,i),o=r.extractConvLayerParams,s=r.extractResidualLayerParams,h=o(4704,32,7,"conv32_down"),u=s(9216,32,3,"conv32_1"),a=s(9216,32,3,"conv32_2"),g=s(9216,32,3,"conv32_3"),l=s(36864,64,3,"conv64_down",!0),c=s(36864,64,3,"conv64_1"),d=s(36864,64,3,"conv64_2"),f=s(36864,64,3,"conv64_3"),p=s(147456,128,3,"conv128_down",!0),y=s(147456,128,3,"conv128_1"),m=s(147456,128,3,"conv128_2"),b=s(589824,256,3,"conv256_down",!0),z=s(589824,256,3,"conv256_1"),v=s(589824,256,3,"conv256_2"),j=s(589824,256,3,"conv256_down_out"),w=bs(function(){return Ff(Ws(t(32768),[128,256]),[1,0])});if(i.push({paramPath:"fc"}),0!==e().length)throw new Error("weights remaing after extract: "+e().length);var k={conv32_down:h,conv32_1:u,conv32_2:a,conv32_3:g,conv64_down:l,conv64_1:c,conv64_2:d,conv64_3:f,conv128_down:p,conv128_1:y,conv128_2:m,conv256_down:b,conv256_1:z,conv256_2:v,conv256_down_out:j,fc:w};return{params:k,paramMappings:i}}function Gz(n,x){var t=tz(n,x);function e(n){var x=t(n+"/scale/weights",1),e=t(n+"/scale/biases",1);return{weights:x,biases:e}}function i(n){var x=t(n+"/conv/filters",4),i=t(n+"/conv/bias",1),r=e(n);return{conv:{filters:x,bias:i},scale:r}}function r(n){return{conv1:i(n+"/conv1"),conv2:i(n+"/conv2")}}return{extractConvLayerParams:i,extractResidualLayerParams:r}}function Kz(n){var x=[],t=Gz(n,x),e=t.extractConvLayerParams,i=t.extractResidualLayerParams,r=e("conv32_down"),o=i("conv32_1"),s=i("conv32_2"),h=i("conv32_3"),u=i("conv64_down"),a=i("conv64_1"),g=i("conv64_2"),l=i("conv64_3"),c=i("conv128_down"),d=i("conv128_1"),f=i("conv128_2"),p=i("conv256_down"),y=i("conv256_1"),m=i("conv256_2"),b=i("conv256_down_out"),z=n["fc"];if(x.push({originalPath:"fc",paramPath:"fc"}),!Dm(z))throw new Error("expected weightMap[fc] to be a Tensor2D, instead have "+z);var v={conv32_down:r,conv32_1:o,conv32_2:s,conv32_3:h,conv64_down:u,conv64_1:a,conv64_2:g,conv64_3:l,conv128_down:c,conv128_1:d,conv128_2:f,conv256_down:p,conv256_1:y,conv256_2:m,conv256_down_out:b,fc:z};return Jb(n,x),{params:v,paramMappings:x}}function Yz(n,x){var t=Hz(n,x.conv1);return t=Uz(t,x.conv2),t=td(t,n),t=Bf(t),t}function Jz(n,x){var t=Vz(n,x.conv1);t=Uz(t,x.conv2);var e=lf(n,2,2,"valid"),i=Zs(e.shape),r=e.shape[3]!==t.shape[3],o=e.shape[1]!==t.shape[1]||e.shape[2]!==t.shape[2];if(o){var s=Em(t.shape);s[1]=1;var h=Zs(s);t=ih([t,h],1);var u=Em(t.shape);u[2]=1;var a=Zs(u);t=ih([t,a],2)}return e=r?ih([e,i],3):e,t=td(e,t),t=Bf(t),t}var Xz=function(n){function x(){return n.call(this,"FaceRecognitionNet")||this}return km(x,n),x.prototype.forwardInput=function(n){var x=this.params;if(!x)throw new Error("FaceRecognitionNet - load model before inference");return bs(function(){var t=n.toBatchTensor(150,!0).toFloat(),e=[122.782,117.001,104.298],i=Xm(t,e).div(Us(256)),r=Vz(i,x.conv32_down);r=gf(r,3,2,"valid"),r=Yz(r,x.conv32_1),r=Yz(r,x.conv32_2),r=Yz(r,x.conv32_3),r=Jz(r,x.conv64_down),r=Yz(r,x.conv64_1),r=Yz(r,x.conv64_2),r=Yz(r,x.conv64_3),r=Jz(r,x.conv128_down),r=Yz(r,x.conv128_1),r=Yz(r,x.conv128_2),r=Jz(r,x.conv256_down),r=Yz(r,x.conv256_1),r=Yz(r,x.conv256_2),r=Jz(r,x.conv256_down_out);var o=r.mean([1,2]),s=nf(o,x.fc);return s})},x.prototype.forward=function(n){return Cm(this,void 0,void 0,function(){var x;return Am(this,function(t){switch(t.label){case 0:return x=this.forwardInput,[4,Nb(n)];case 1:return[2,x.apply(this,[t.sent()])]}})})},x.prototype.computeFaceDescriptor=function(n){return Cm(this,void 0,void 0,function(){var x,t,e,i=this;return Am(this,function(r){switch(r.label){case 0:return[4,Nb(n)];case 1:return x=r.sent(),t=bs(function(){return Yh(i.forwardInput(x))}),[4,Promise.all(t.map(function(n){return n.data()}))];case 2:return e=r.sent(),t.forEach(function(n){return n.dispose()}),[2,x.isBatchInput?e:e[0]]}})})},x.prototype.getDefaultModelName=function(){return"face_recognition_model"},x.prototype.extractParamsFromWeigthMap=function(n){return Kz(n)},x.prototype.extractParams=function(n){return Qz(n)},x}(Wb);function Zz(n,x,t){var e={gender:x,genderProbability:t};return Object.assign({},n,e)}var $z=function(){function n(n){var x=void 0===n?{}:n,t=x.minFaceSize,e=x.scaleFactor,i=x.maxNumScales,r=x.scoreThresholds,o=x.scaleSteps;if(this._name="MtcnnOptions",this._minFaceSize=t||20,this._scaleFactor=e||.709,this._maxNumScales=i||10,this._scoreThresholds=r||[.6,.7,.7],this._scaleSteps=o,"number"!==typeof this._minFaceSize||this._minFaceSize<0)throw new Error(this._name+" - expected minFaceSize to be a number > 0");if("number"!==typeof this._scaleFactor||this._scaleFactor<=0||this._scaleFactor>=1)throw new Error(this._name+" - expected scaleFactor to be a number between 0 and 1");if("number"!==typeof this._maxNumScales||this._maxNumScales<0)throw new Error(this._name+" - expected maxNumScales to be a number > 0");if(!Array.isArray(this._scoreThresholds)||3!==this._scoreThresholds.length||this._scoreThresholds.some(function(n){return"number"!==typeof n}))throw new Error(this._name+" - expected scoreThresholds to be an array of numbers of length 3");if(this._scaleSteps&&(!Array.isArray(this._scaleSteps)||this._scaleSteps.some(function(n){return"number"!==typeof n})))throw new Error(this._name+" - expected scaleSteps to be an array of numbers")}return Object.defineProperty(n.prototype,"minFaceSize",{get:function(){return this._minFaceSize},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"scaleFactor",{get:function(){return this._scaleFactor},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"maxNumScales",{get:function(){return this._maxNumScales},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"scoreThresholds",{get:function(){return this._scoreThresholds},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"scaleSteps",{get:function(){return this._scaleSteps},enumerable:!0,configurable:!0}),n}();function nv(n,x){function t(t,e){var i=Gs(n(9*t),[3,3,t,1]),r=Vs(n(t)),o=Vs(n(t)),s=Vs(n(t)),h=Vs(n(t));return x.push({paramPath:e+"/filters"},{paramPath:e+"/batch_norm_scale"},{paramPath:e+"/batch_norm_offset"},{paramPath:e+"/batch_norm_mean"},{paramPath:e+"/batch_norm_variance"}),{filters:i,batch_norm_scale:r,batch_norm_offset:o,batch_norm_mean:s,batch_norm_variance:h}}function e(t,e,i,r,o){var s=Gs(n(t*e*i*i),[i,i,t,e]),h=Vs(n(e));return x.push({paramPath:r+"/filters"},{paramPath:r+"/"+(o?"batch_norm_offset":"bias")}),{filters:s,bias:h}}function i(n,x,t,i){var r=e(n,x,t,i,!0),o=r.filters,s=r.bias;return{filters:o,batch_norm_offset:s}}function r(n,x,e){var r=t(n,e+"/depthwise_conv"),o=i(n,x,1,e+"/pointwise_conv");return{depthwise_conv:r,pointwise_conv:o}}function o(){var n=i(3,32,3,"mobilenetv1/conv_0"),x=r(32,64,"mobilenetv1/conv_1"),t=r(64,128,"mobilenetv1/conv_2"),e=r(128,128,"mobilenetv1/conv_3"),o=r(128,256,"mobilenetv1/conv_4"),s=r(256,256,"mobilenetv1/conv_5"),h=r(256,512,"mobilenetv1/conv_6"),u=r(512,512,"mobilenetv1/conv_7"),a=r(512,512,"mobilenetv1/conv_8"),g=r(512,512,"mobilenetv1/conv_9"),l=r(512,512,"mobilenetv1/conv_10"),c=r(512,512,"mobilenetv1/conv_11"),d=r(512,1024,"mobilenetv1/conv_12"),f=r(1024,1024,"mobilenetv1/conv_13");return{conv_0:n,conv_1:x,conv_2:t,conv_3:e,conv_4:o,conv_5:s,conv_6:h,conv_7:u,conv_8:a,conv_9:g,conv_10:l,conv_11:c,conv_12:d,conv_13:f}}function s(){var n=i(1024,256,1,"prediction_layer/conv_0"),x=i(256,512,3,"prediction_layer/conv_1"),t=i(512,128,1,"prediction_layer/conv_2"),r=i(128,256,3,"prediction_layer/conv_3"),o=i(256,128,1,"prediction_layer/conv_4"),s=i(128,256,3,"prediction_layer/conv_5"),h=i(256,64,1,"prediction_layer/conv_6"),u=i(64,128,3,"prediction_layer/conv_7"),a=e(512,12,1,"prediction_layer/box_predictor_0/box_encoding_predictor"),g=e(512,9,1,"prediction_layer/box_predictor_0/class_predictor"),l=e(1024,24,1,"prediction_layer/box_predictor_1/box_encoding_predictor"),c=e(1024,18,1,"prediction_layer/box_predictor_1/class_predictor"),d=e(512,24,1,"prediction_layer/box_predictor_2/box_encoding_predictor"),f=e(512,18,1,"prediction_layer/box_predictor_2/class_predictor"),p=e(256,24,1,"prediction_layer/box_predictor_3/box_encoding_predictor"),y=e(256,18,1,"prediction_layer/box_predictor_3/class_predictor"),m=e(256,24,1,"prediction_layer/box_predictor_4/box_encoding_predictor"),b=e(256,18,1,"prediction_layer/box_predictor_4/class_predictor"),z=e(128,24,1,"prediction_layer/box_predictor_5/box_encoding_predictor"),v=e(128,18,1,"prediction_layer/box_predictor_5/class_predictor"),j={box_encoding_predictor:a,class_predictor:g},w={box_encoding_predictor:l,class_predictor:c},k={box_encoding_predictor:d,class_predictor:f},q={box_encoding_predictor:p,class_predictor:y},C={box_encoding_predictor:m,class_predictor:b},A={box_encoding_predictor:z,class_predictor:v};return{conv_0:n,conv_1:x,conv_2:t,conv_3:r,conv_4:o,conv_5:s,conv_6:h,conv_7:u,box_predictor_0:j,box_predictor_1:w,box_predictor_2:k,box_predictor_3:q,box_predictor_4:C,box_predictor_5:A}}return{extractMobilenetV1Params:o,extractPredictionLayerParams:s}}function xv(n){var x=[],t=ez(n),e=t.extractWeights,i=t.getRemainingWeights,r=nv(e,x),o=r.extractMobilenetV1Params,s=r.extractPredictionLayerParams,h=o(),u=s(),a=Qs(e(20472),[1,5118,4]),g={extra_dim:a};if(x.push({paramPath:"output_layer/extra_dim"}),0!==i().length)throw new Error("weights remaing after extract: "+i().length);return{params:{mobilenetv1:h,prediction_layer:u,output_layer:g},paramMappings:x}}function tv(n,x){var t=tz(n,x);function e(n,x,e){var i=t(n+"/Conv2d_"+x+"_pointwise/weights",4,e+"/filters"),r=t(n+"/Conv2d_"+x+"_pointwise/convolution_bn_offset",1,e+"/batch_norm_offset");return{filters:i,batch_norm_offset:r}}function i(n){var x="mobilenetv1/conv_"+n,i="MobilenetV1/Conv2d_"+n+"_depthwise",r=x+"/depthwise_conv",o=x+"/pointwise_conv",s=t(i+"/depthwise_weights",4,r+"/filters"),h=t(i+"/BatchNorm/gamma",1,r+"/batch_norm_scale"),u=t(i+"/BatchNorm/beta",1,r+"/batch_norm_offset"),a=t(i+"/BatchNorm/moving_mean",1,r+"/batch_norm_mean"),g=t(i+"/BatchNorm/moving_variance",1,r+"/batch_norm_variance");return{depthwise_conv:{filters:s,batch_norm_scale:h,batch_norm_offset:u,batch_norm_mean:a,batch_norm_variance:g},pointwise_conv:e("MobilenetV1",n,o)}}function r(){return{conv_0:e("MobilenetV1",0,"mobilenetv1/conv_0"),conv_1:i(1),conv_2:i(2),conv_3:i(3),conv_4:i(4),conv_5:i(5),conv_6:i(6),conv_7:i(7),conv_8:i(8),conv_9:i(9),conv_10:i(10),conv_11:i(11),conv_12:i(12),conv_13:i(13)}}function o(n,x){var e=t(n+"/weights",4,x+"/filters"),i=t(n+"/biases",1,x+"/bias");return{filters:e,bias:i}}function s(n){var x=o("Prediction/BoxPredictor_"+n+"/BoxEncodingPredictor","prediction_layer/box_predictor_"+n+"/box_encoding_predictor"),t=o("Prediction/BoxPredictor_"+n+"/ClassPredictor","prediction_layer/box_predictor_"+n+"/class_predictor");return{box_encoding_predictor:x,class_predictor:t}}function h(){return{conv_0:e("Prediction",0,"prediction_layer/conv_0"),conv_1:e("Prediction",1,"prediction_layer/conv_1"),conv_2:e("Prediction",2,"prediction_layer/conv_2"),conv_3:e("Prediction",3,"prediction_layer/conv_3"),conv_4:e("Prediction",4,"prediction_layer/conv_4"),conv_5:e("Prediction",5,"prediction_layer/conv_5"),conv_6:e("Prediction",6,"prediction_layer/conv_6"),conv_7:e("Prediction",7,"prediction_layer/conv_7"),box_predictor_0:s(0),box_predictor_1:s(1),box_predictor_2:s(2),box_predictor_3:s(3),box_predictor_4:s(4),box_predictor_5:s(5)}}return{extractMobilenetV1Params:r,extractPredictionLayerParams:h}}function ev(n){var x=[],t=tv(n,x),e=t.extractMobilenetV1Params,i=t.extractPredictionLayerParams,r=n["Output/extra_dim"];if(x.push({originalPath:"Output/extra_dim",paramPath:"output_layer/extra_dim"}),!Om(r))throw new Error("expected weightMap['Output/extra_dim'] to be a Tensor3D, instead have "+r);var o={mobilenetv1:e(),prediction_layer:i(),output_layer:{extra_dim:r}};return Jb(n,x),{params:o,paramMappings:x}}function iv(n,x,t){return bs(function(){var e=Vd(n,x.filters,t,"same");return e=td(e,x.batch_norm_offset),ac(e,0,6)})}var rv=.0010000000474974513;function ov(n,x,t){return bs(function(){var e=Kd(n,x.filters,t,"same");return e=Qc(e,x.batch_norm_mean,x.batch_norm_variance,x.batch_norm_offset,x.batch_norm_scale,rv),ac(e,0,6)})}function sv(n){return[2,4,6,12].some(function(x){return x===n})?[2,2]:[1,1]}function hv(n,x){return bs(function(){var t=null,e=iv(n,x.conv_0,[2,2]),i=[x.conv_1,x.conv_2,x.conv_3,x.conv_4,x.conv_5,x.conv_6,x.conv_7,x.conv_8,x.conv_9,x.conv_10,x.conv_11,x.conv_12,x.conv_13];if(i.forEach(function(n,x){var i=x+1,r=sv(i);e=ov(e,n.depthwise_conv,r),e=iv(e,n.pointwise_conv,[1,1]),11===i&&(t=e)}),null===t)throw new Error("mobileNetV1 - output of conv layer 11 is null");return{out:e,conv11:t}})}function uv(n,x,t,e,i){var r=n.shape[0],o=Math.min(t,r),s=x.map(function(n,x){return{score:n,boxIndex:x}}).filter(function(n){return n.score>i}).sort(function(n,x){return x.score-n.score}),h=function(n){return n<=e?1:0},u=[];return s.forEach(function(x){if(!(u.length>=o)){for(var t=x.score,e=u.length-1;e>=0;--e){var r=av(n,x.boxIndex,u[e]);if(0!==r&&(x.score*=h(r),x.score<=i))break}t===x.score&&u.push(x.boxIndex)}}),u}function av(n,x,t){var e=n.arraySync(),i=Math.min(e[x][0],e[x][2]),r=Math.min(e[x][1],e[x][3]),o=Math.max(e[x][0],e[x][2]),s=Math.max(e[x][1],e[x][3]),h=Math.min(e[t][0],e[t][2]),u=Math.min(e[t][1],e[t][3]),a=Math.max(e[t][0],e[t][2]),g=Math.max(e[t][1],e[t][3]),l=(o-i)*(s-r),c=(a-h)*(g-u);if(l<=0||c<=0)return 0;var d=Math.max(i,h),f=Math.max(r,u),p=Math.min(o,a),y=Math.min(s,g),m=Math.max(p-d,0)*Math.max(y-f,0);return m/(l+c-m)}function gv(n){var x=Yh(Ff(n,[1,0])),t=[vd(x[2],x[0]),vd(x[3],x[1])],e=[td(x[0],od(t[0],Us(2))),td(x[1],od(t[1],Us(2)))];return{sizes:t,centers:e}}function lv(n,x){var t=gv(n),e=t.sizes,i=t.centers,r=Yh(Ff(x,[1,0])),o=od(pd(dc(od(r[2],Us(5))),e[0]),Us(2)),s=td(pd(od(r[0],Us(10)),e[0]),i[0]),h=od(pd(dc(od(r[3],Us(5))),e[1]),Us(2)),u=td(pd(od(r[1],Us(10)),e[1]),i[1]);return Ff(Qh([vd(s,o),vd(u,h),td(s,o),td(u,h)]),[1,0])}function cv(n,x,t){return bs(function(){var e=n.shape[0],i=lv(Uh(Gh(t.extra_dim,[e,1,1]),[-1,4]),Uh(n,[-1,4]));i=Uh(i,[e,i.shape[0]/e,4]);var r=kc(pf(x,[0,0,1],[-1,-1,-1])),o=pf(r,[0,0,0],[-1,-1,1]);o=Uh(o,[e,o.shape[1]]);var s=Yh(i),h=Yh(o);return{boxes:s,scores:h}})}function dv(n,x){return bs(function(){var t=n.shape[0],e=Uh(Yb(n,x.box_encoding_predictor),[t,-1,1,4]),i=Uh(Yb(n,x.class_predictor),[t,-1,3]);return{boxPredictionEncoding:e,classPrediction:i}})}function fv(n,x,t){return bs(function(){var e=iv(n,t.conv_0,[1,1]),i=iv(e,t.conv_1,[2,2]),r=iv(i,t.conv_2,[1,1]),o=iv(r,t.conv_3,[2,2]),s=iv(o,t.conv_4,[1,1]),h=iv(s,t.conv_5,[2,2]),u=iv(h,t.conv_6,[1,1]),a=iv(u,t.conv_7,[2,2]),g=dv(x,t.box_predictor_0),l=dv(n,t.box_predictor_1),c=dv(i,t.box_predictor_2),d=dv(o,t.box_predictor_3),f=dv(h,t.box_predictor_4),p=dv(a,t.box_predictor_5),y=ih([g.boxPredictionEncoding,l.boxPredictionEncoding,c.boxPredictionEncoding,d.boxPredictionEncoding,f.boxPredictionEncoding,p.boxPredictionEncoding],1),m=ih([g.classPrediction,l.classPrediction,c.classPrediction,d.classPrediction,f.classPrediction,p.classPrediction],1);return{boxPredictions:y,classPredictions:m}})}var pv=function(){function n(n){var x=void 0===n?{}:n,t=x.minConfidence,e=x.maxResults;if(this._name="SsdMobilenetv1Options",this._minConfidence=t||.5,this._maxResults=e||100,"number"!==typeof this._minConfidence||this._minConfidence<=0||this._minConfidence>=1)throw new Error(this._name+" - expected minConfidence to be a number between 0 and 1");if("number"!==typeof this._maxResults)throw new Error(this._name+" - expected maxResults to be a number")}return Object.defineProperty(n.prototype,"minConfidence",{get:function(){return this._minConfidence},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"maxResults",{get:function(){return this._maxResults},enumerable:!0,configurable:!0}),n}(),yv=function(n){function x(){return n.call(this,"SsdMobilenetv1")||this}return km(x,n),x.prototype.forwardInput=function(n){var x=this.params;if(!x)throw new Error("SsdMobilenetv1 - load model before inference");return bs(function(){var t=n.toBatchTensor(512,!1).toFloat(),e=vd(pd(t,Us(.007843137718737125)),Us(1)),i=hv(e,x.mobilenetv1),r=fv(i.out,i.conv11,x.prediction_layer),o=r.boxPredictions,s=r.classPredictions;return cv(o,s,x.output_layer)})},x.prototype.forward=function(n){return Cm(this,void 0,void 0,function(){var x;return Am(this,function(t){switch(t.label){case 0:return x=this.forwardInput,[4,Nb(n)];case 1:return[2,x.apply(this,[t.sent()])]}})})},x.prototype.locateFaces=function(n,x){return void 0===x&&(x={}),Cm(this,void 0,void 0,function(){var t,e,i,r,o,s,h,u,a,g,l,c,d,f,p,y,m,b,z,v,j;return Am(this,function(w){switch(w.label){case 0:return t=new pv(x),e=t.maxResults,i=t.minConfidence,[4,Nb(n)];case 1:for(r=w.sent(),o=this.forwardInput(r),s=o.boxes,h=o.scores,u=s[0],a=h[0],g=1;g<s.length;g++)s[g].dispose(),h[g].dispose();return d=(c=Array).from,[4,a.data()];case 2:return l=d.apply(c,[w.sent()]),f=.5,p=uv(u,l,e,f,i),y=r.getReshapedInputDimensions(0),m=r.inputSize,b=m/y.width,z=m/y.height,v=u.arraySync(),j=p.map(function(n){var x=[Math.max(0,v[n][0]),Math.min(1,v[n][2])].map(function(n){return n*z}),t=x[0],e=x[1],i=[Math.max(0,v[n][1]),Math.min(1,v[n][3])].map(function(n){return n*b}),o=i[0],s=i[1];return new Gm(l[n],new xb(o,t,s-o,e-t),{height:r.getInputHeight(0),width:r.getInputWidth(0)})}),u.dispose(),a.dispose(),[2,j]}})})},x.prototype.getDefaultModelName=function(){return"ssd_mobilenetv1_model"},x.prototype.extractParamsFromWeigthMap=function(n){return ev(n)},x.prototype.extractParams=function(n){return xv(n)},x}(Wb);(function(n){function x(){return null!==n&&n.apply(this,arguments)||this}km(x,n)})(yv);var mv,bv=.4,zv=[new Um(.738768,.874946),new Um(2.42204,2.65704),new Um(4.30971,7.04493),new Um(10.246,4.59428),new Um(12.6868,11.8741)],vv=[new Um(1.603231,2.094468),new Um(6.041143,7.080126),new Um(2.882459,3.518061),new Um(4.266906,5.178857),new Um(9.041765,10.66308)],jv=[117.001,114.697,97.404],wv="tiny_yolov2_model",kv="tiny_yolov2_separable_conv_model",qv=function(n){return"number"===typeof n};function Cv(n){if(!n)throw new Error("invalid config: "+n);if("boolean"!==typeof n.withSeparableConvs)throw new Error("config.withSeparableConvs has to be a boolean, have: "+n.withSeparableConvs);if(!qv(n.iouThreshold)||n.iouThreshold<0||n.iouThreshold>1)throw new Error("config.iouThreshold has to be a number between [0, 1], have: "+n.iouThreshold);if(!Array.isArray(n.classes)||!n.classes.length||!n.classes.every(function(n){return"string"===typeof n}))throw new Error("config.classes has to be an array class names: string[], have: "+JSON.stringify(n.classes));if(!Array.isArray(n.anchors)||!n.anchors.length||!n.anchors.map(function(n){return n||{}}).every(function(n){return qv(n.x)&&qv(n.y)}))throw new Error("config.anchors has to be an array of { x: number, y: number }, have: "+JSON.stringify(n.anchors));if(n.meanRgb&&(!Array.isArray(n.meanRgb)||3!==n.meanRgb.length||!n.meanRgb.every(qv)))throw new Error("config.meanRgb has to be an array of shape [number, number, number], have: "+JSON.stringify(n.meanRgb))}function Av(n){return bs(function(){var x=pd(n,Us(.10000000149011612));return td(Bf(vd(n,x)),x)})}function Ev(n,x){return bs(function(){var t=Th(n,[[0,0],[1,1],[1,1],[0,0]]);return t=Vd(t,x.conv.filters,[1,1],"valid"),t=vd(t,x.bn.sub),t=pd(t,x.bn.truediv),t=td(t,x.conv.bias),Av(t)})}function Sv(n,x){return bs(function(){var t=Th(n,[[0,0],[1,1],[1,1],[0,0]]);return t=Xd(t,x.depthwise_filter,x.pointwise_filter,[1,1],"valid"),t=td(t,x.bias),Av(t)})}function Iv(n,x){var t=Xb(n,x);function e(t,e){var i=Vs(n(t)),r=Vs(n(t));return x.push({paramPath:e+"/sub"},{paramPath:e+"/truediv"}),{sub:i,truediv:r}}function i(n,x,i){var r=t(n,x,3,i+"/conv"),o=e(x,i+"/bn");return{conv:r,bn:o}}var r=nz(n,x);return{extractConvParams:t,extractConvWithBatchNormParams:i,extractSeparableConvParams:r}}function Dv(n,x,t,e){var i,r=ez(n),o=r.extractWeights,s=r.getRemainingWeights,h=[],u=Iv(o,h),a=u.extractConvParams,g=u.extractConvWithBatchNormParams,l=u.extractSeparableConvParams;if(x.withSeparableConvs){var c=e[0],d=e[1],f=e[2],p=e[3],y=e[4],m=e[5],b=e[6],z=e[7],v=e[8],j=x.isFirstLayerConv2d?a(c,d,3,"conv0"):l(c,d,"conv0"),w=l(d,f,"conv1"),k=l(f,p,"conv2"),q=l(p,y,"conv3"),C=l(y,m,"conv4"),A=l(m,b,"conv5"),E=z?l(b,z,"conv6"):void 0,S=v?l(z,v,"conv7"):void 0,I=a(v||z||b,5*t,1,"conv8");i={conv0:j,conv1:w,conv2:k,conv3:q,conv4:C,conv5:A,conv6:E,conv7:S,conv8:I}}else{c=e[0],d=e[1],f=e[2],p=e[3],y=e[4],m=e[5],b=e[6],z=e[7],v=e[8],j=g(c,d,"conv0"),w=g(d,f,"conv1"),k=g(f,p,"conv2"),q=g(p,y,"conv3"),C=g(y,m,"conv4"),A=g(m,b,"conv5"),E=g(b,z,"conv6"),S=g(z,v,"conv7"),I=a(v,5*t,1,"conv8");i={conv0:j,conv1:w,conv2:k,conv3:q,conv4:C,conv5:A,conv6:E,conv7:S,conv8:I}}if(0!==s().length)throw new Error("weights remaing after extract: "+s().length);return{params:i,paramMappings:h}}function Ov(n,x){var t=tz(n,x);function e(n){var x=t(n+"/sub",1),e=t(n+"/truediv",1);return{sub:x,truediv:e}}function i(n){var x=t(n+"/filters",4),e=t(n+"/bias",1);return{filters:x,bias:e}}function r(n){var x=i(n+"/conv"),t=e(n+"/bn");return{conv:x,bn:t}}var o=xz(t);return{extractConvParams:i,extractConvWithBatchNormParams:r,extractSeparableConvParams:o}}function _v(n,x){var t,e=[],i=Ov(n,e),r=i.extractConvParams,o=i.extractConvWithBatchNormParams,s=i.extractSeparableConvParams;if(x.withSeparableConvs){var h=x.filterSizes&&x.filterSizes.length||9;t={conv0:x.isFirstLayerConv2d?r("conv0"):s("conv0"),conv1:s("conv1"),conv2:s("conv2"),conv3:s("conv3"),conv4:s("conv4"),conv5:s("conv5"),conv6:h>7?s("conv6"):void 0,conv7:h>8?s("conv7"):void 0,conv8:r("conv8")}}else t={conv0:o("conv0"),conv1:o("conv1"),conv2:o("conv2"),conv3:o("conv3"),conv4:o("conv4"),conv5:o("conv5"),conv6:o("conv6"),conv7:o("conv7"),conv8:r("conv8")};return Jb(n,e),{params:t,paramMappings:e}}(function(n){n[n["XS"]=224]="XS",n[n["SM"]=320]="SM",n[n["MD"]=416]="MD",n[n["LG"]=608]="LG"})(mv||(mv={}));var Tv=function(){function n(n){var x=void 0===n?{}:n,t=x.inputSize,e=x.scoreThreshold;if(this._name="TinyYolov2Options",this._inputSize=t||416,this._scoreThreshold=e||.5,"number"!==typeof this._inputSize||this._inputSize%32!==0)throw new Error(this._name+" - expected inputSize to be a number divisible by 32");if("number"!==typeof this._scoreThreshold||this._scoreThreshold<=0||this._scoreThreshold>=1)throw new Error(this._name+" - expected scoreThreshold to be a number between 0 and 1")}return Object.defineProperty(n.prototype,"inputSize",{get:function(){return this._inputSize},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"scoreThreshold",{get:function(){return this._scoreThreshold},enumerable:!0,configurable:!0}),n}(),Rv=function(n){function x(x){var t=n.call(this,"TinyYolov2")||this;return Cv(x),t._config=x,t}return km(x,n),Object.defineProperty(x.prototype,"config",{get:function(){return this._config},enumerable:!0,configurable:!0}),Object.defineProperty(x.prototype,"withClassScores",{get:function(){return this.config.withClassScores||this.config.classes.length>1},enumerable:!0,configurable:!0}),Object.defineProperty(x.prototype,"boxEncodingSize",{get:function(){return 5+(this.withClassScores?this.config.classes.length:0)},enumerable:!0,configurable:!0}),x.prototype.runTinyYolov2=function(n,x){var t=Ev(n,x.conv0);return t=gf(t,[2,2],[2,2],"same"),t=Ev(t,x.conv1),t=gf(t,[2,2],[2,2],"same"),t=Ev(t,x.conv2),t=gf(t,[2,2],[2,2],"same"),t=Ev(t,x.conv3),t=gf(t,[2,2],[2,2],"same"),t=Ev(t,x.conv4),t=gf(t,[2,2],[2,2],"same"),t=Ev(t,x.conv5),t=gf(t,[2,2],[1,1],"same"),t=Ev(t,x.conv6),t=Ev(t,x.conv7),Yb(t,x.conv8,"valid",!1)},x.prototype.runMobilenet=function(n,x){var t=this.config.isFirstLayerConv2d?Av(Yb(n,x.conv0,"valid",!1)):Sv(n,x.conv0);return t=gf(t,[2,2],[2,2],"same"),t=Sv(t,x.conv1),t=gf(t,[2,2],[2,2],"same"),t=Sv(t,x.conv2),t=gf(t,[2,2],[2,2],"same"),t=Sv(t,x.conv3),t=gf(t,[2,2],[2,2],"same"),t=Sv(t,x.conv4),t=gf(t,[2,2],[2,2],"same"),t=Sv(t,x.conv5),t=gf(t,[2,2],[1,1],"same"),t=x.conv6?Sv(t,x.conv6):t,t=x.conv7?Sv(t,x.conv7):t,Yb(t,x.conv8,"valid",!1)},x.prototype.forwardInput=function(n,x){var t=this,e=this.params;if(!e)throw new Error("TinyYolov2 - load model before inference");return bs(function(){var i=n.toBatchTensor(x,!1).toFloat();return i=t.config.meanRgb?Xm(i,t.config.meanRgb):i,i=i.div(Us(256)),t.config.withSeparableConvs?t.runMobilenet(i,e):t.runTinyYolov2(i,e)})},x.prototype.forward=function(n,x){return Cm(this,void 0,void 0,function(){var t;return Am(this,function(e){switch(e.label){case 0:return t=this.forwardInput,[4,Nb(n)];case 1:return[4,t.apply(this,[e.sent(),x])];case 2:return[2,e.sent()]}})})},x.prototype.detect=function(n,x){return void 0===x&&(x={}),Cm(this,void 0,void 0,function(){var t,e,i,r,o,s,h,u,a,g,l,c,d,f,p=this;return Am(this,function(y){switch(y.label){case 0:return t=new Tv(x),e=t.inputSize,i=t.scoreThreshold,[4,Nb(n)];case 1:return r=y.sent(),[4,this.forwardInput(r,e)];case 2:return o=y.sent(),s=bs(function(){return Yh(o)[0].expandDims()}),h={width:r.getInputWidth(0),height:r.getInputHeight(0)},[4,this.extractBoxes(s,r.getReshapedInputDimensions(0),i)];case 3:return u=y.sent(),o.dispose(),s.dispose(),a=u.map(function(n){return n.box}),g=u.map(function(n){return n.score}),l=u.map(function(n){return n.classScore}),c=u.map(function(n){return p.config.classes[n.label]}),d=Jm(a.map(function(n){return n.rescale(e)}),g,this.config.iouThreshold,!0),f=d.map(function(n){return new Qm(g[n],l[n],c[n],a[n],h)}),[2,f]}})})},x.prototype.getDefaultModelName=function(){return""},x.prototype.extractParamsFromWeigthMap=function(n){return _v(n,this.config)},x.prototype.extractParams=function(n){var t=this.config.filterSizes||x.DEFAULT_FILTER_SIZES,e=t?t.length:void 0;if(7!==e&&8!==e&&9!==e)throw new Error("TinyYolov2 - expected 7 | 8 | 9 convolutional filters, but found "+e+" filterSizes in config");return Dv(n,this.config,this.boxEncodingSize,t)},x.prototype.extractBoxes=function(n,x,t){return Cm(this,void 0,void 0,function(){var e,i,r,o,s,h,u,a,g,l,c,d,f,p,y,m,b,z,v,j,w,k,q,C,A,E,S,I,D,O=this;return Am(this,function(_){switch(_.label){case 0:return e=x.width,i=x.height,r=Math.max(e,i),o=r/e,s=r/i,h=n.shape[1],u=this.config.anchors.length,a=bs(function(){var x=n.reshape([h,h,u,O.boxEncodingSize]),t=x.slice([0,0,0,0],[h,h,u,4]),e=x.slice([0,0,0,4],[h,h,u,1]),i=O.withClassScores?yu(x.slice([0,0,0,5],[h,h,u,O.config.classes.length]),3):Us(0);return[t,e,i]}),g=a[0],l=a[1],c=a[2],d=[],[4,l.array()];case 1:return f=_.sent(),[4,g.array()];case 2:p=_.sent(),y=0,_.label=3;case 3:if(!(y<h))return[3,12];m=0,_.label=4;case 4:if(!(m<h))return[3,11];b=0,_.label=5;case 5:return b<u?(z=$m(f[y][m][b][0]),!t||z>t?(v=(m+$m(p[y][m][b][0]))/h*o,j=(y+$m(p[y][m][b][1]))/h*s,w=Math.exp(p[y][m][b][2])*this.config.anchors[b].x/h*o,k=Math.exp(p[y][m][b][3])*this.config.anchors[b].y/h*s,q=v-w/2,C=j-k/2,A={row:y,col:m,anchor:b},this.withClassScores?[4,this.extractPredictedClass(c,A)]:[3,7]):[3,9]):[3,10];case 6:return D=_.sent(),[3,8];case 7:D={classScore:1,label:0},_.label=8;case 8:E=D,S=E.classScore,I=E.label,d.push(qm({box:new Wm(q,C,q+w,C+k),score:z,classScore:z*S,label:I},A)),_.label=9;case 9:return b++,[3,5];case 10:return m++,[3,4];case 11:return y++,[3,3];case 12:return g.dispose(),l.dispose(),c.dispose(),[2,d]}})})},x.prototype.extractPredictedClass=function(n,x){return Cm(this,void 0,void 0,function(){var t,e,i,r;return Am(this,function(o){switch(o.label){case 0:return t=x.row,e=x.col,i=x.anchor,[4,n.array()];case 1:return r=o.sent(),[2,Array(this.config.classes.length).fill(0).map(function(n,x){return r[t][e][i][x]}).map(function(n,x){return{classScore:n,label:x}}).reduce(function(n,x){return n.classScore>x.classScore?n:x})]}})})},x.DEFAULT_FILTER_SIZES=[3,16,32,64,128,256,512,1024,1024],x}(Wb),Bv=function(n){function x(x){void 0===x&&(x=!0);var t=this,e=Object.assign({},{withSeparableConvs:x,iouThreshold:bv,classes:["face"]},x?{anchors:vv,meanRgb:jv}:{anchors:zv,withClassScores:!0});return t=n.call(this,e)||this,t}return km(x,n),Object.defineProperty(x.prototype,"withSeparableConvs",{get:function(){return this.config.withSeparableConvs},enumerable:!0,configurable:!0}),Object.defineProperty(x.prototype,"anchors",{get:function(){return this.config.anchors},enumerable:!0,configurable:!0}),x.prototype.locateFaces=function(n,x){return Cm(this,void 0,void 0,function(){var t;return Am(this,function(e){switch(e.label){case 0:return[4,this.detect(n,x)];case 1:return t=e.sent(),[2,t.map(function(n){return new Gm(n.score,n.relativeBox,{width:n.imageWidth,height:n.imageHeight})})]}})})},x.prototype.getDefaultModelName=function(){return this.withSeparableConvs?kv:wv},x.prototype.extractParamsFromWeigthMap=function(x){return n.prototype.extractParamsFromWeigthMap.call(this,x)},x}(Rv);var Mv=function(n){function x(){var x=null!==n&&n.apply(this,arguments)||this;return x._name="TinyFaceDetectorOptions",x}return km(x,n),x}(Tv),Nv=function(){function n(){}return n.prototype.then=function(n){return Cm(this,void 0,void 0,function(){var x;return Am(this,function(t){switch(t.label){case 0:return x=n,[4,this.run()];case 1:return[2,x.apply(void 0,[t.sent()])]}})})},n.prototype.run=function(){return Cm(this,void 0,void 0,function(){return Am(this,function(n){throw new Error("ComposableTask - run is not implemented")})})},n}();function Fv(n,x){var t={descriptor:x};return Object.assign({},n,t)}function Pv(n,x,t,e,i){return void 0===i&&(i=function(n){var x=n.alignedRect;return x}),Cm(this,void 0,void 0,function(){var r,o,s,h,u;return Am(this,function(a){switch(a.label){case 0:return r=n.map(function(n){return bz(n)?i(n):n.detection}),s=e,s?[3,5]:x instanceof Kr?[4,Pb(x,r)]:[3,2];case 1:return h=a.sent(),[3,4];case 2:return[4,Fb(x,r)];case 3:h=a.sent(),a.label=4;case 4:s=h,a.label=5;case 5:return o=s,[4,t(o)];case 6:return u=a.sent(),o.forEach(function(n){return n instanceof Kr&&n.dispose()}),[2,u]}})})}function Lv(n,x,t,e,i){return Cm(this,void 0,void 0,function(){var r=this;return Am(this,function(o){return[2,Pv([n],x,function(n){return Cm(r,void 0,void 0,function(){return Am(this,function(x){return[2,t(n[0])]})})},e,i)]})})}function Hv(n){return bs(function(){return Qh(Yh(n,3).reverse(),3)})}var Uv=2,Vv=12;function Wv(n,x){var t=Xb(n,x),e=Zb(n,x);function i(t,e){var i=Vs(n(t));return x.push({paramPath:e}),i}function r(n,x,e){void 0===e&&(e=!1);var r=t(n[0],n[1],3,x+"/conv1"),o=i(n[1],x+"/prelu1_alpha"),s=t(n[1],n[2],3,x+"/conv2"),h=i(n[2],x+"/prelu2_alpha"),u=t(n[2],n[3],e?2:3,x+"/conv3"),a=i(n[3],x+"/prelu3_alpha");return{conv1:r,prelu1_alpha:o,conv2:s,prelu2_alpha:h,conv3:u,prelu3_alpha:a}}function o(){var n=r([3,10,16,32],"pnet"),x=t(32,2,1,"pnet/conv4_1"),e=t(32,4,1,"pnet/conv4_2");return qm(qm({},n),{conv4_1:x,conv4_2:e})}function s(){var n=r([3,28,48,64],"rnet",!0),x=e(576,128,"rnet/fc1"),t=i(128,"rnet/prelu4_alpha"),o=e(128,2,"rnet/fc2_1"),s=e(128,4,"rnet/fc2_2");return qm(qm({},n),{fc1:x,prelu4_alpha:t,fc2_1:o,fc2_2:s})}function h(){var n=r([3,32,64,64],"onet"),x=t(64,128,2,"onet/conv4"),o=i(128,"onet/prelu4_alpha"),s=e(1152,256,"onet/fc1"),h=i(256,"onet/prelu5_alpha"),u=e(256,2,"onet/fc2_1"),a=e(256,4,"onet/fc2_2"),g=e(256,10,"onet/fc2_3");return qm(qm({},n),{conv4:x,prelu4_alpha:o,fc1:s,prelu5_alpha:h,fc2_1:u,fc2_2:a,fc2_3:g})}return{extractPNetParams:o,extractRNetParams:s,extractONetParams:h}}function Qv(n){var x=ez(n),t=x.extractWeights,e=x.getRemainingWeights,i=[],r=Wv(t,i),o=r.extractPNetParams,s=r.extractRNetParams,h=r.extractONetParams,u=o(),a=s(),g=h();if(0!==e().length)throw new Error("weights remaing after extract: "+e().length);return{params:{pnet:u,rnet:a,onet:g},paramMappings:i}}function Gv(n,x){var t=tz(n,x);function e(n){var x=t(n+"/weights",4,n+"/filters"),e=t(n+"/bias",1);return{filters:x,bias:e}}function i(n){var x=t(n+"/weights",2),e=t(n+"/bias",1);return{weights:x,bias:e}}function r(n){return t(n,1)}function o(n){var x=e(n+"/conv1"),t=r(n+"/prelu1_alpha"),i=e(n+"/conv2"),o=r(n+"/prelu2_alpha"),s=e(n+"/conv3"),h=r(n+"/prelu3_alpha");return{conv1:x,prelu1_alpha:t,conv2:i,prelu2_alpha:o,conv3:s,prelu3_alpha:h}}function s(){var n=o("pnet"),x=e("pnet/conv4_1"),t=e("pnet/conv4_2");return qm(qm({},n),{conv4_1:x,conv4_2:t})}function h(){var n=o("rnet"),x=i("rnet/fc1"),t=r("rnet/prelu4_alpha"),e=i("rnet/fc2_1"),s=i("rnet/fc2_2");return qm(qm({},n),{fc1:x,prelu4_alpha:t,fc2_1:e,fc2_2:s})}function u(){var n=o("onet"),x=e("onet/conv4"),t=r("onet/prelu4_alpha"),s=i("onet/fc1"),h=r("onet/prelu5_alpha"),u=i("onet/fc2_1"),a=i("onet/fc2_2"),g=i("onet/fc2_3");return qm(qm({},n),{conv4:x,prelu4_alpha:t,fc1:s,prelu5_alpha:h,fc2_1:u,fc2_2:a,fc2_3:g})}return{extractPNetParams:s,extractRNetParams:h,extractONetParams:u}}function Kv(n){var x=[],t=Gv(n,x),e=t.extractPNetParams,i=t.extractRNetParams,r=t.extractONetParams,o=e(),s=i(),h=r();return Jb(n,x),{params:{pnet:o,rnet:s,onet:h},paramMappings:x}}function Yv(n,x){var t=x[0],e=x[1];return{height:Math.floor(t*n),width:Math.floor(e*n)}}function Jv(n,x,t){var e=t[0],i=t[1],r=Vv/n,o=[],s=Math.min(e,i)*r,h=0;while(s>=12)o.push(r*Math.pow(x,h)),s*=x,h+=1;return o}var Xv=function(n){function x(x,t,e,i){return n.call(this,{left:x,top:t,right:e,bottom:i},!0)||this}return km(x,n),x}(Vm);function Zv(n){return bs(function(){return pd(vd(n,Us(127.5)),Us(.0078125))})}function $v(n,x){return bs(function(){return td(Bf(n),pd(x,zc(Bf(zc(n)))))})}function nj(n,x,t){return void 0===t&&(t=!1),bs(function(){var e=Yb(n,x.conv1,"valid");return e=$v(e,x.prelu1_alpha),e=gf(e,t?[2,2]:[3,3],[2,2],"same"),e=Yb(e,x.conv2,"valid"),e=$v(e,x.prelu2_alpha),e=t?e:gf(e,[3,3],[2,2],"valid"),e=Yb(e,x.conv3,"valid"),e=$v(e,x.prelu3_alpha),e})}function xj(n,x){return bs(function(){var t=nj(n,x,!0),e=Yb(t,x.conv4_1,"valid"),i=Ih(Af(e,3),3),r=yu(vd(e,i),3),o=Yb(t,x.conv4_2,"valid");return{prob:r,regions:o}})}function tj(n,x){return bs(function(){var t=Yv(x,n.shape.slice(1)),e=t.height,i=t.width,r=Tp.resizeBilinear(n,[e,i]),o=Zv(r);return Ff(o,[0,2,1,3])})}function ej(n,x,t,e){for(var i=[],r=n.arraySync(),o=0;o<n.shape[0];o++)for(var s=0;s<n.shape[1];s++)r[o][s]>=e&&i.push(new Um(s,o));var h=i.map(function(n){var e=new Wm(Math.round((n.y*Uv+1)/t),Math.round((n.x*Uv+1)/t),Math.round((n.y*Uv+Vv)/t),Math.round((n.x*Uv+Vv)/t)),i=r[n.y][n.x],o=x.arraySync(),s=new Xv(o[n.y][n.x][0],o[n.y][n.x][1],o[n.y][n.x][2],o[n.y][n.x][3]);return{cell:e,score:i,region:s}});return h}function ij(n,x,t,e,i){i.stage1=[];var r=x.map(function(x){return bs(function(){var t={scale:x},i=tj(n,x),r=Date.now(),o=xj(i,e),s=o.prob,h=o.regions;t.pnet=Date.now()-r;var u=Yh(Yh(s,3)[1])[0],a=Yh(h)[0];return{scoresTensor:u,regionsTensor:a,scale:x,statsForScale:t}})}),o=r.map(function(n){var x=n.scoresTensor,e=n.regionsTensor,r=n.scale,o=n.statsForScale,s=ej(x,e,r,t);if(x.dispose(),e.dispose(),!s.length)return i.stage1.push(o),[];var h=Date.now(),u=Jm(s.map(function(n){return n.cell}),s.map(function(n){return n.score}),.5);return o.nms=Date.now()-h,o.numBoxes=u.length,i.stage1.push(o),u.map(function(n){return s[n]})}),s=o.reduce(function(n,x){return n.concat(x)},[]),h=[],u=[];if(s.length>0){var a=Date.now(),g=Jm(s.map(function(n){return n.cell}),s.map(function(n){return n.score}),.7);i.stage1_nms=Date.now()-a,u=g.map(function(n){return s[n].score}),h=g.map(function(n){return s[n]}).map(function(n){var x=n.cell,t=n.region;return new Wm(x.left+t.left*x.width,x.top+t.top*x.height,x.right+t.right*x.width,x.bottom+t.bottom*x.height).toSquare().round()})}return{boxes:h,scores:u}}function rj(n,x,t){var e=t.width,i=t.height;return Cm(this,void 0,void 0,function(){var t,r,o,s=this;return Am(this,function(h){switch(h.label){case 0:return t=qb(n),[4,Promise.all(x.map(function(x){return Cm(s,void 0,void 0,function(){var e,i,r,o,s,h,u,a;return Am(this,function(g){return e=x.padAtBorders(n.height,n.width),i=e.y,r=e.ey,o=e.x,s=e.ex,h=o-1,u=i-1,a=t.getImageData(h,u,s-h,r-u),[2,wb.isNodejs()?_b(a):createImageBitmap(a)]})})}))];case 1:return r=h.sent(),o=[],r.forEach(function(n){var x=Ob({width:e,height:i}),t=qb(x);t.drawImage(n,0,0,e,i);for(var r=t.getImageData(0,0,e,i).data,s=[],h=0;h<r.length;h+=4)s.push(r[h+2]),s.push(r[h+1]),s.push(r[h]);o.push(s)}),[2,o.map(function(n){var x=bs(function(){var x=Ff(Gs(n,[1,e,i,3]),[0,2,1,3]).toFloat();return Zv(x)});return x})]}})})}function oj(n,x){return bs(function(){var t=nj(n,x),e=Uh(t,[t.shape[0],x.fc1.weights.shape[0]]),i=az(e,x.fc1),r=$v(i,x.prelu4_alpha),o=az(r,x.fc2_1),s=Ih(Af(o,1),1),h=yu(vd(o,s),1),u=az(r,x.fc2_2),a=Yh(h,1)[1];return{scores:a,regions:u}})}function sj(n,x,t,e,i){return Cm(this,void 0,void 0,function(){var r,o,s,h,u,a,g,l,c,d,f,p,y,m;return Am(this,function(b){switch(b.label){case 0:return r=Date.now(),[4,rj(n,x,{width:24,height:24})];case 1:return o=b.sent(),i.stage2_extractImagePatches=Date.now()-r,r=Date.now(),s=o.map(function(n){var x=oj(n,e);return n.dispose(),x}),i.stage2_rnet=Date.now()-r,h=s.length>1?ih(s.map(function(n){return n.scores})):s[0].scores,g=(a=Array).from,[4,h.data()];case 2:return u=g.apply(a,[b.sent()]),h.dispose(),l=u.map(function(n,x){return{score:n,idx:x}}).filter(function(n){return n.score>t}).map(function(n){var x=n.idx;return x}),c=l.map(function(n){return x[n]}),d=l.map(function(n){return u[n]}),f=[],p=[],c.length>0&&(r=Date.now(),y=Jm(c,d,.7),i.stage2_nms=Date.now()-r,m=y.map(function(n){var x=s[l[n]].regions.arraySync();return new Xv(x[0][0],x[0][1],x[0][2],x[0][3])}),p=y.map(function(n){return d[n]}),f=y.map(function(n,x){return c[n].calibrate(m[x])})),s.forEach(function(n){n.regions.dispose(),n.scores.dispose()}),[2,{boxes:f,scores:p}]}})})}function hj(n,x){return bs(function(){var t=nj(n,x);t=gf(t,[2,2],[2,2],"same"),t=Yb(t,x.conv4,"valid"),t=$v(t,x.prelu4_alpha);var e=Uh(t,[t.shape[0],x.fc1.weights.shape[0]]),i=az(e,x.fc1),r=$v(i,x.prelu5_alpha),o=az(r,x.fc2_1),s=Ih(Af(o,1),1),h=yu(vd(o,s),1),u=az(r,x.fc2_2),a=az(r,x.fc2_3),g=Yh(h,1)[1];return{scores:g,regions:u,points:a}})}function uj(n,x,t,e,i){return Cm(this,void 0,void 0,function(){var r,o,s,h,u,a,g,l,c,d,f,p,y,m,b;return Am(this,function(z){switch(z.label){case 0:return r=Date.now(),[4,rj(n,x,{width:48,height:48})];case 1:return o=z.sent(),i.stage3_extractImagePatches=Date.now()-r,r=Date.now(),s=o.map(function(n){var x=hj(n,e);return n.dispose(),x}),i.stage3_onet=Date.now()-r,h=s.length>1?ih(s.map(function(n){return n.scores})):s[0].scores,g=(a=Array).from,[4,h.data()];case 2:return u=g.apply(a,[z.sent()]),h.dispose(),l=u.map(function(n,x){return{score:n,idx:x}}).filter(function(n){return n.score>t}).map(function(n){var x=n.idx;return x}),c=l.map(function(n){var x=s[n].regions.arraySync();return new Xv(x[0][0],x[0][1],x[0][2],x[0][3])}),d=l.map(function(n,t){return x[n].calibrate(c[t])}),f=l.map(function(n){return u[n]}),p=[],y=[],m=[],d.length>0&&(r=Date.now(),b=Jm(d,f,.7,!1),i.stage3_nms=Date.now()-r,p=b.map(function(n){return d[n]}),y=b.map(function(n){return f[n]}),m=b.map(function(n,x){return Array(5).fill(0).map(function(t,e){var i=s[n].points.arraySync();return new Um(i[0][e]*(p[x].width+1)+p[x].left,i[0][e+5]*(p[x].height+1)+p[x].top)})})),s.forEach(function(n){n.regions.dispose(),n.scores.dispose(),n.points.dispose()}),[2,{boxes:p,scores:y,points:m}]}})})}var aj=function(n){function x(){return n.call(this,"Mtcnn")||this}return km(x,n),x.prototype.load=function(x){return Cm(this,void 0,void 0,function(){return Am(this,function(t){return console.warn("mtcnn is deprecated and will be removed soon"),[2,n.prototype.load.call(this,x)]})})},x.prototype.loadFromDisk=function(x){return Cm(this,void 0,void 0,function(){return Am(this,function(t){return console.warn("mtcnn is deprecated and will be removed soon"),[2,n.prototype.loadFromDisk.call(this,x)]})})},x.prototype.forwardInput=function(n,x){return void 0===x&&(x={}),Cm(this,void 0,void 0,function(){var t,e,i,r,o,s,h,u,a,g,l,c,d,f,p,y,m,b,z,v,j;return Am(this,function(w){switch(w.label){case 0:if(t=this.params,!t)throw new Error("Mtcnn - load model before inference");if(e=n.canvases[0],!e)throw new Error("Mtcnn - inputCanvas is not defined, note that passing tensors into Mtcnn.forwardInput is not supported yet.");return i={},r=Date.now(),o=bs(function(){return Hv(Ih(im.fromPixels(e)).toFloat())}),s=function(n){return o.dispose(),i.total=Date.now()-r,n},h=o.shape.slice(1),u=h[0],a=h[1],g=new $z(x),l=g.minFaceSize,c=g.scaleFactor,d=g.maxNumScales,f=g.scoreThresholds,p=g.scaleSteps,y=(p||Jv(l,c,[u,a])).filter(function(n){var x=Yv(n,[u,a]);return Math.min(x.width,x.height)>Vv}).slice(0,d),i.scales=y,i.pyramid=y.map(function(n){return Yv(n,[u,a])}),m=Date.now(),[4,ij(o,y,f[0],t.pnet,i)];case 1:return b=w.sent(),i.total_stage1=Date.now()-m,b.boxes.length?(i.stage2_numInputBoxes=b.boxes.length,m=Date.now(),[4,sj(e,b.boxes,f[1],t.rnet,i)]):[2,s({results:[],stats:i})];case 2:return z=w.sent(),i.total_stage2=Date.now()-m,z.boxes.length?(i.stage3_numInputBoxes=z.boxes.length,m=Date.now(),[4,uj(e,z.boxes,f[2],t.onet,i)]):[2,s({results:[],stats:i})];case 3:return v=w.sent(),i.total_stage3=Date.now()-m,j=v.boxes.map(function(n,x){return zz(lb({},new Gm(v.scores[x],new xb(n.left/a,n.top/u,n.width/a,n.height/u),{height:u,width:a})),new ob(v.points[x].map(function(x){return x.sub(new Um(n.left,n.top)).div(new Um(n.width,n.height))}),{width:n.width,height:n.height}))}),[2,s({results:j,stats:i})]}})})},x.prototype.forward=function(n,x){return void 0===x&&(x={}),Cm(this,void 0,void 0,function(){var t;return Am(this,function(e){switch(e.label){case 0:return t=this.forwardInput,[4,Nb(n)];case 1:return[4,t.apply(this,[e.sent(),x])];case 2:return[2,e.sent().results]}})})},x.prototype.forwardWithStats=function(n,x){return void 0===x&&(x={}),Cm(this,void 0,void 0,function(){var t;return Am(this,function(e){switch(e.label){case 0:return t=this.forwardInput,[4,Nb(n)];case 1:return[2,t.apply(this,[e.sent(),x])]}})})},x.prototype.getDefaultModelName=function(){return"mtcnn_model"},x.prototype.extractParamsFromWeigthMap=function(n){return Kv(n)},x.prototype.extractParams=function(n){return Qv(n)},x}(Wb),gj=.4,lj=[new Um(1.603231,2.094468),new Um(6.041143,7.080126),new Um(2.882459,3.518061),new Um(4.266906,5.178857),new Um(9.041765,10.66308)],cj=[117.001,114.697,97.404],dj=function(n){function x(){var x=this,t={withSeparableConvs:!0,iouThreshold:gj,classes:["face"],anchors:lj,meanRgb:cj,isFirstLayerConv2d:!0,filterSizes:[3,16,32,64,128,256,512]};return x=n.call(this,t)||this,x}return km(x,n),Object.defineProperty(x.prototype,"anchors",{get:function(){return this.config.anchors},enumerable:!0,configurable:!0}),x.prototype.locateFaces=function(n,x){return Cm(this,void 0,void 0,function(){var t;return Am(this,function(e){switch(e.label){case 0:return[4,this.detect(n,x)];case 1:return t=e.sent(),[2,t.map(function(n){return new Gm(n.score,n.relativeBox,{width:n.imageWidth,height:n.imageHeight})})]}})})},x.prototype.getDefaultModelName=function(){return"tiny_face_detector_model"},x.prototype.extractParamsFromWeigthMap=function(x){return n.prototype.extractParamsFromWeigthMap.call(this,x)},x}(Rv),fj={ssdMobilenetv1:new yv,tinyFaceDetector:new dj,tinyYolov2:new Bv,mtcnn:new aj,faceLandmark68Net:new Rz,faceLandmark68TinyNet:new Fz,faceRecognitionNet:new Xz,faceExpressionNet:new yz,ageGenderNet:new _z};function pj(n,x){var t={age:x};return Object.assign({},n,t)}var yj=function(n){function x(x,t,e){var i=n.call(this)||this;return i.parentTask=x,i.input=t,i.extractedFaces=e,i}return km(x,n),x}(Nv),mj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.run=function(){return Cm(this,void 0,void 0,function(){var n,x,t=this;return Am(this,function(e){switch(e.label){case 0:return[4,this.parentTask];case 1:return n=e.sent(),[4,Pv(n,this.input,function(n){return Cm(t,void 0,void 0,function(){return Am(this,function(x){switch(x.label){case 0:return[4,Promise.all(n.map(function(n){return fj.faceExpressionNet.predictExpressions(n)}))];case 1:return[2,x.sent()]}})})},this.extractedFaces)];case 2:return x=e.sent(),[2,n.map(function(n,t){return mz(n,x[t])})]}})})},x.prototype.withAgeAndGender=function(){return new wj(this,this.input)},x}(yj),bj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.run=function(){return Cm(this,void 0,void 0,function(){var n,x;return Am(this,function(t){switch(t.label){case 0:return[4,this.parentTask];case 1:return n=t.sent(),n?[4,Lv(n,this.input,function(n){return fj.faceExpressionNet.predictExpressions(n)},this.extractedFaces)]:[2];case 2:return x=t.sent(),[2,mz(n,x)]}})})},x.prototype.withAgeAndGender=function(){return new kj(this,this.input)},x}(yj),zj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.withAgeAndGender=function(){return new qj(this,this.input)},x.prototype.withFaceDescriptors=function(){return new Ej(this,this.input)},x}(mj),vj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.withAgeAndGender=function(){return new Cj(this,this.input)},x.prototype.withFaceDescriptor=function(){return new Sj(this,this.input)},x}(bj),jj=function(n){function x(x,t,e){var i=n.call(this)||this;return i.parentTask=x,i.input=t,i.extractedFaces=e,i}return km(x,n),x}(Nv),wj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.run=function(){return Cm(this,void 0,void 0,function(){var n,x,t=this;return Am(this,function(e){switch(e.label){case 0:return[4,this.parentTask];case 1:return n=e.sent(),[4,Pv(n,this.input,function(n){return Cm(t,void 0,void 0,function(){return Am(this,function(x){switch(x.label){case 0:return[4,Promise.all(n.map(function(n){return fj.ageGenderNet.predictAgeAndGender(n)}))];case 1:return[2,x.sent()]}})})},this.extractedFaces)];case 2:return x=e.sent(),[2,n.map(function(n,t){var e=x[t],i=e.age,r=e.gender,o=e.genderProbability;return pj(Zz(n,r,o),i)})]}})})},x.prototype.withFaceExpressions=function(){return new mj(this,this.input)},x}(jj),kj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.run=function(){return Cm(this,void 0,void 0,function(){var n,x,t,e,i;return Am(this,function(r){switch(r.label){case 0:return[4,this.parentTask];case 1:return n=r.sent(),n?[4,Lv(n,this.input,function(n){return fj.ageGenderNet.predictAgeAndGender(n)},this.extractedFaces)]:[2];case 2:return x=r.sent(),t=x.age,e=x.gender,i=x.genderProbability,[2,pj(Zz(n,e,i),t)]}})})},x.prototype.withFaceExpressions=function(){return new bj(this,this.input)},x}(jj),qj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.withFaceExpressions=function(){return new zj(this,this.input)},x.prototype.withFaceDescriptors=function(){return new Ej(this,this.input)},x}(wj),Cj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.withFaceExpressions=function(){return new vj(this,this.input)},x.prototype.withFaceDescriptor=function(){return new Sj(this,this.input)},x}(kj),Aj=function(n){function x(x,t){var e=n.call(this)||this;return e.parentTask=x,e.input=t,e}return km(x,n),x}(Nv),Ej=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.run=function(){return Cm(this,void 0,void 0,function(){var n,x;return Am(this,function(t){switch(t.label){case 0:return[4,this.parentTask];case 1:return n=t.sent(),[4,Pv(n,this.input,function(n){return Promise.all(n.map(function(n){return fj.faceRecognitionNet.computeFaceDescriptor(n)}))},null,function(n){return n.landmarks.align(null,{useDlibAlignment:!0})})];case 2:return x=t.sent(),[2,x.map(function(x,t){return Fv(n[t],x)})]}})})},x.prototype.withFaceExpressions=function(){return new zj(this,this.input)},x.prototype.withAgeAndGender=function(){return new qj(this,this.input)},x}(Aj),Sj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.run=function(){return Cm(this,void 0,void 0,function(){var n,x;return Am(this,function(t){switch(t.label){case 0:return[4,this.parentTask];case 1:return n=t.sent(),n?[4,Lv(n,this.input,function(n){return fj.faceRecognitionNet.computeFaceDescriptor(n)},null,function(n){return n.landmarks.align(null,{useDlibAlignment:!0})})]:[2];case 2:return x=t.sent(),[2,Fv(n,x)]}})})},x.prototype.withFaceExpressions=function(){return new vj(this,this.input)},x.prototype.withAgeAndGender=function(){return new Cj(this,this.input)},x}(Aj),Ij=function(n){function x(x,t,e){var i=n.call(this)||this;return i.parentTask=x,i.input=t,i.useTinyLandmarkNet=e,i}return km(x,n),Object.defineProperty(x.prototype,"landmarkNet",{get:function(){return this.useTinyLandmarkNet?fj.faceLandmark68TinyNet:fj.faceLandmark68Net},enumerable:!0,configurable:!0}),x}(Nv),Dj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.run=function(){return Cm(this,void 0,void 0,function(){var n,x,t,e,i,r=this;return Am(this,function(o){switch(o.label){case 0:return[4,this.parentTask];case 1:return n=o.sent(),x=n.map(function(n){return n.detection}),this.input instanceof Kr?[4,Pb(this.input,x)]:[3,3];case 2:return e=o.sent(),[3,5];case 3:return[4,Fb(this.input,x)];case 4:e=o.sent(),o.label=5;case 5:return t=e,[4,Promise.all(t.map(function(n){return r.landmarkNet.detectLandmarks(n)}))];case 6:return i=o.sent(),t.forEach(function(n){return n instanceof Kr&&n.dispose()}),[2,n.map(function(n,x){return zz(n,i[x])})]}})})},x.prototype.withFaceExpressions=function(){return new zj(this,this.input)},x.prototype.withAgeAndGender=function(){return new qj(this,this.input)},x.prototype.withFaceDescriptors=function(){return new Ej(this,this.input)},x}(Ij),Oj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.run=function(){return Cm(this,void 0,void 0,function(){var n,x,t,e,i;return Am(this,function(r){switch(r.label){case 0:return[4,this.parentTask];case 1:return n=r.sent(),n?(x=n.detection,this.input instanceof Kr?[4,Pb(this.input,[x])]:[3,3]):[2];case 2:return e=r.sent(),[3,5];case 3:return[4,Fb(this.input,[x])];case 4:e=r.sent(),r.label=5;case 5:return t=e,[4,this.landmarkNet.detectLandmarks(t[0])];case 6:return i=r.sent(),t.forEach(function(n){return n instanceof Kr&&n.dispose()}),[2,zz(n,i)]}})})},x.prototype.withFaceExpressions=function(){return new vj(this,this.input)},x.prototype.withAgeAndGender=function(){return new Cj(this,this.input)},x.prototype.withFaceDescriptor=function(){return new Sj(this,this.input)},x}(Ij),_j=function(n){function x(x,t){void 0===t&&(t=new pv);var e=n.call(this)||this;return e.input=x,e.options=t,e}return km(x,n),x}(Nv),Tj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.run=function(){return Cm(this,void 0,void 0,function(){var n,x,t,e;return Am(this,function(i){switch(i.label){case 0:return n=this,x=n.input,t=n.options,t instanceof $z?[4,fj.mtcnn.forward(x,t)]:[3,2];case 1:return[2,i.sent().map(function(n){return n.detection})];case 2:if(e=t instanceof Mv?function(n){return fj.tinyFaceDetector.locateFaces(n,t)}:t instanceof pv?function(n){return fj.ssdMobilenetv1.locateFaces(n,t)}:t instanceof Tv?function(n){return fj.tinyYolov2.locateFaces(n,t)}:null,!e)throw new Error("detectFaces - expected options to be instance of TinyFaceDetectorOptions | SsdMobilenetv1Options | MtcnnOptions | TinyYolov2Options");return[2,e(x)]}})})},x.prototype.runAndExtendWithFaceDetections=function(){var n=this;return new Promise(function(x){return Cm(n,void 0,void 0,function(){var n;return Am(this,function(t){switch(t.label){case 0:return[4,this.run()];case 1:return n=t.sent(),[2,x(n.map(function(n){return lb({},n)}))]}})})})},x.prototype.withFaceLandmarks=function(n){return void 0===n&&(n=!1),new Dj(this.runAndExtendWithFaceDetections(),this.input,n)},x.prototype.withFaceExpressions=function(){return new mj(this.runAndExtendWithFaceDetections(),this.input)},x.prototype.withAgeAndGender=function(){return new wj(this.runAndExtendWithFaceDetections(),this.input)},x}(_j);(function(n){function x(){return null!==n&&n.apply(this,arguments)||this}km(x,n),x.prototype.run=function(){return Cm(this,void 0,void 0,function(){var n,x;return Am(this,function(t){switch(t.label){case 0:return[4,new Tj(this.input,this.options)];case 1:return n=t.sent(),x=n[0],n.forEach(function(n){n.score>x.score&&(x=n)}),[2,x]}})})},x.prototype.runAndExtendWithFaceDetection=function(){var n=this;return new Promise(function(x){return Cm(n,void 0,void 0,function(){var n;return Am(this,function(t){switch(t.label){case 0:return[4,this.run()];case 1:return n=t.sent(),[2,x(n?lb({},n):void 0)]}})})})},x.prototype.withFaceLandmarks=function(n){return void 0===n&&(n=!1),new Oj(this.runAndExtendWithFaceDetection(),this.input,n)},x.prototype.withFaceExpressions=function(){return new bj(this.runAndExtendWithFaceDetection(),this.input)},x.prototype.withAgeAndGender=function(){return new kj(this.runAndExtendWithFaceDetection(),this.input)}})(_j);function Rj(n,x){return void 0===x&&(x=new pv),new Tj(n,x)}function Bj(n,x){if(n.length!==x.length)throw new Error("euclideanDistance: arr1.length !== arr2.length");var t=Array.from(n),e=Array.from(x);return Math.sqrt(t.map(function(n,x){return n-e[x]}).reduce(function(n,x){return n+Math.pow(x,2)},0))}(function(){function n(n,x){void 0===x&&(x=.6),this._distanceThreshold=x;var t=Array.isArray(n)?n:[n];if(!t.length)throw new Error("FaceRecognizer.constructor - expected atleast one input");var e=1,i=function(){return"person "+e++};this._labeledDescriptors=t.map(function(n){if(n instanceof ab)return n;if(n instanceof Float32Array)return new ab(i(),[n]);if(n.descriptor&&n.descriptor instanceof Float32Array)return new ab(i(),[n.descriptor]);throw new Error("FaceRecognizer.constructor - expected inputs to be of type LabeledFaceDescriptors | WithFaceDescriptor<any> | Float32Array | Array<LabeledFaceDescriptors | WithFaceDescriptor<any> | Float32Array>")})}Object.defineProperty(n.prototype,"labeledDescriptors",{get:function(){return this._labeledDescriptors},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"distanceThreshold",{get:function(){return this._distanceThreshold},enumerable:!0,configurable:!0}),n.prototype.computeMeanDistance=function(n,x){return x.map(function(x){return Bj(x,n)}).reduce(function(n,x){return n+x},0)/(x.length||1)},n.prototype.matchDescriptor=function(n){var x=this;return this.labeledDescriptors.map(function(t){var e=t.descriptors,i=t.label;return new hb(i,x.computeMeanDistance(n,e))}).reduce(function(n,x){return n.distance<x.distance?n:x})},n.prototype.findBestMatch=function(n){var x=this.matchDescriptor(n);return x.distance<this.distanceThreshold?x:new hb("unknown",x.distance)},n.prototype.toJSON=function(){return{distanceThreshold:this.distanceThreshold,labeledDescriptors:this.labeledDescriptors.map(function(n){return n.toJSON()})}},n.fromJSON=function(x){var t=x.labeledDescriptors.map(function(n){return ab.fromJSON(n)});return new n(t,x.distanceThreshold)}})();var Mj={name:"FaceDetection",emits:["face-detected","face-lost","error","detection-complete"],props:{videoWidth:{type:Number,default:240},videoHeight:{type:Number,default:240},minConfidence:{type:Number,default:.5},captureInterval:{type:Number,default:2e3},maxCaptures:{type:Number,default:1}},data(){return{modelPath:ae.getters.faceApiUrl,loading:!1,modelsLoaded:!1,cameraStarted:!1,cameraReady:!1,isDetecting:!1,stream:null,detectionInterval:null,capturedImages:[],lastCaptureTime:0}},created(){const n=window.location.href.split("?")?.[1]?.split("=")?.[1];n&&(this.modelPath=n);const x=localStorage.getItem("xc_modelPath");x&&(this.modelPath=x)},async mounted(){await this.loadModels(),await this.autoStartDetection()},beforeDestroy(){this.cleanup()},methods:{h_back(){this.$emit("back")},async loadModels(){try{this.loading=!0,await Promise.all([fj.tinyFaceDetector.loadFromUri(this.modelPath),fj.faceLandmark68Net.loadFromUri(this.modelPath),fj.faceRecognitionNet.loadFromUri(this.modelPath)]),this.modelsLoaded=!0,console.log("人脸检测模型加载完成")}catch(n){this.$emit("error",{type:"model-load-error",error:n})}finally{this.loading=!1}},async autoStartDetection(){if(this.modelsLoaded)try{await this.startCamera(),setTimeout(()=>{this.cameraReady&&this.startDetection()},1e3)}catch(n){console.error("自动开始检测失败:",n)}},async startCamera(){try{this.stream=await navigator.mediaDevices.getUserMedia({video:{width:this.videoWidth,height:this.videoHeight,facingMode:"user"}}),this.$refs.video.srcObject=this.stream,this.cameraStarted=!0}catch(n){console.error("摄像头启动失败:",n),this.$emit("error",{type:"camera-error",error:n})}},onVideoLoaded(){this.cameraReady=!0,console.log("摄像头准备就绪"),this.modelsLoaded&&!this.isDetecting&&setTimeout(()=>{this.startDetection()},500)},stopCamera(){this.stopDetection(),this.stream&&(this.stream.getTracks().forEach(n=>n.stop()),this.stream=null),this.cameraStarted=!1,this.cameraReady=!1},startDetection(){this.modelsLoaded&&this.cameraReady&&(this.isDetecting=!0,this.detectionInterval=setInterval(()=>{this.detectFaces()},100))},stopDetection(){this.isDetecting=!1,this.detectionInterval&&(clearInterval(this.detectionInterval),this.detectionInterval=null);const n=this.$refs.overlay,x=n.getContext("2d");x.clearRect(0,0,n.width,n.height)},toggleDetection(){this.isDetecting?this.stopDetection():this.startDetection()},async detectFaces(){const n=this.$refs.video,x=this.$refs.overlay;if(n&&x)try{const t=await Rj(n,new Mv).withFaceLandmarks().withFaceDescriptors(),e=x.getContext("2d");if(e.clearRect(0,0,x.width,x.height),t.length>0){t.forEach(n=>{const{x:x,y:t,width:i,height:r}=n.detection.box;e.strokeStyle="#00ff00",e.lineWidth=2,e.strokeRect(x,t,i,r),e.fillStyle="#00ff00",e.font="16px Arial",e.fillText(`${(100*n.detection.score).toFixed(1)}%`,x,t-10)});const n=Date.now();n-this.lastCaptureTime>this.captureInterval&&(this.captureHighConfidenceFaces(t),this.lastCaptureTime=n),this.$emit("face-detected",t),this.onFaceDetectedComplete(t)}else this.$emit("face-lost")}catch(t){console.error("人脸检测失败:",t),this.$emit("error",{type:"detection-error",error:t})}},captureHighConfidenceFaces(n){const x=this.$refs.video;n.forEach(n=>{if(n.detection.score>=this.minConfidence){const t=document.createElement("canvas"),e=t.getContext("2d"),{x:i,y:r,width:o,height:s}=n.detection.box,h=1,u=1,a=1,g=s*(1+h+a),l=o*(1+2*u),c=Math.max(0,i-o*u),d=Math.max(0,r-s*h),f=x.videoWidth||this.videoWidth,p=x.videoHeight||this.videoHeight,y=Math.max(0,c),m=Math.max(0,d),b=Math.min(l,f-y),z=Math.min(g,p-m);t.width=b,t.height=z,e.drawImage(x,y,m,b,z,0,0,b,z);const v=t.toDataURL("image/jpeg",.8);this.capturedImages.unshift({dataUrl:v,confidence:n.detection.score,timestamp:Date.now(),box:n.detection.box,expandedBox:{x:y,y:m,width:b,height:z}}),this.capturedImages.length>this.maxCaptures&&(this.capturedImages=this.capturedImages.slice(0,this.maxCaptures)),console.log("捕获到高置信度人脸:",n.detection.score)}})},async copyToClipboard(n){try{await navigator.clipboard.writeText(n),console.log("Base64已复制到剪贴板")}catch(x){console.error("复制失败:",x)}},onFaceDetectedComplete(n){this.stopDetection(),this.stopCamera(),this.$emit("detection-complete",{detections:n,capturedImages:this.capturedImages})},cleanup(){this.stopCamera(),this.capturedImages=[]},async restartAuthentication(){try{console.log("开始重新认证..."),this.cleanup(),this.capturedImages=[],this.lastCaptureTime=0,this.modelsLoaded||await this.loadModels(),await this.autoStartDetection(),this.$emit("restart-authentication")}catch(n){console.error("重新认证启动失败:",n),this.$emit("error",{type:"restart-error",error:n})}}}},Nj=Mj,Fj=Ie(Nj,Ei,Si,!1,null,"5308c508",null),Pj=Fj.exports,Lj=function(){var n=this,x=n._self._c;return x("div",{directives:[{name:"loading",rawName:"v-loading",value:n.loading,expression:"loading"}],staticClass:"face-picture"},[x("img",{attrs:{src:n.src,width:"100%",height:"100%"}}),x("div",{staticClass:"delete-batn",on:{click:n.handleDelete}},[x("i",{staticClass:"el-icon-delete",staticStyle:{size:"20px"}})])])},Hj=[],Uj={props:{row:Object},data(){return{src:null,loading:!1}},created(){},mounted(){this.loadFaceImage()},methods:{handleDelete(){this.handleClearFaceInfo()},loadFaceImage(){if(!this.row?.userId)return void console.warn("用户ID不存在,无法加载人脸信息");const n=!1;this.src=n?`/face/photo?userId=${this.row?.userId}`:ae.getters.authUrl+`/face/photo?userId=${this.row?.userId}`},handleClearFaceInfo(){this.$confirm("确定要清除人脸信息吗?","提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{this.loading=!0,fi({userId:this.row?.userId}).then(()=>{this.$emit("clear-face"),this.$message.success("人脸信息已清除")}).finally(()=>{this.loading=!1})}).catch(()=>{})}}},Vj=Uj,Wj=Ie(Vj,Lj,Hj,!1,null,"8a1623a6",null),Qj=Wj.exports,Gj={name:"FaceRegister",props:{row:Object,options:Array},components:{ChooseCameraOrPicture:vi,UploadPicture:Ai,FaceDetected:Pj,FacePicture:Qj},data(){const n=this.row?.userId;return{userId:n,chooseType:"loading",uploading:!1,userIdMissing:!1}},created(){this.checkFaceInfo()},methods:{checkFaceInfo(){di({userId:this.userId}).then(n=>{this.chooseType=n.data?"face-info":""})},handleBack(){this.chooseType=""},handleClose(){},handleChoose(n){this.chooseType="camera"===n?"camera":"picture"},handleClearFace(){this.checkFaceInfo()},handleRefresh(){window.location.reload()},handleUploadSuccess(){this.checkFaceInfo()},async handleDetectionComplete(n){if(this.userId)if(n.capturedImages&&0!==n.capturedImages.length)try{this.uploading=!0,this.chooseType="";const x=n.capturedImages[0],t=x.dataUrl,e=this.base64ToFile(t,"face-detected.jpg"),i=new FormData;i.append("file",e),i.append("userId",this.userId),i.append("userName",this.row?.row?.name||""),await ci(i),this.$message.success("人脸注册成功!"),this.checkFaceInfo()}catch(x){console.error("人脸上传失败:",x),this.chooseType=""}finally{this.uploading=!1}else this.$message.error("未检测到人脸图片");else this.$message.error("用户信息不完整,无法进行人脸注册")},base64ToFile(n,x){const t=n.split(","),e=t[0].match(/:(.*?);/)[1],i=atob(t[1]);let r=i.length;const o=new Uint8Array(r);while(r--)o[r]=i.charCodeAt(r);return new File([o],x,{type:e})}}},Kj=Gj,Yj=Ie(Kj,ui,ai,!1,null,"d4c502b4",null),Jj=Yj.exports,Xj=function(){var n=this,x=n._self._c;return x("div",{directives:[{name:"loading",rawName:"v-loading",value:n.loading,expression:"loading"}],staticClass:"p-12"},[x("el-table",{ref:"table",attrs:{data:n.tableData,stripe:"","header-cell-style":{background:"#f7f8fa"}},on:{"selection-change":n.h_selectionChange,"row-click":n.h_rowClick}},[x("el-table-column",{attrs:{type:"selection",width:"75"}}),x("el-table-column",{attrs:{type:"index",label:"序号",width:"80"}}),x("el-table-column",{attrs:{prop:"icCard",label:"身份卡号"}})],1),x("div",{staticClass:"flex-center mt-12"},[x("el-button",{staticStyle:{"border-radius":"8px",padding:"7px 20px"},attrs:{type:"primary",icon:"el-icon-circle-plus-outline"},on:{click:n.h_add}},[n._v("添加")]),x("el-button",{staticStyle:{"border-radius":"8px",padding:"7px 20px"},attrs:{icon:"el-icon-delete",type:"danger"},on:{click:n.h_remove}},[n._v("移除")])],1),n.visible?x("register-dialog",{attrs:{row:n.row},on:{closed:function(x){n.visible=!1},refresh:n.h_loadData}}):n._e()],1)},Zj=[];const $j=n=>li({url:"/userICCard/add",method:"post",data:n}),nw=n=>li({url:"/icCard/findNoBindICCard",method:"get",params:n}),xw=n=>li({url:"/userICCard/deleteByIcCard",method:"post",data:n}),tw=n=>li({url:"/userICCard/findByUserId",method:"get",params:n});var ew=function(){var n=this,x=n._self._c;return x("el-dialog",{attrs:{visible:n.visible,width:"580px",title:"normal"===n.component?"新增身份卡":"选择身份卡","append-to-body":""},on:{closed:n.closed,close:n.h_close}},["normal"===n.component?x("div",[x("div",{staticClass:"p-12 pr-32"},[x("el-form",{attrs:{model:n.form,"label-width":"100px"}},[x("el-form-item",{attrs:{label:"身份卡号"}},[x("el-input",{attrs:{placeholder:"请输入或者使用刷卡器刷卡"},model:{value:n.form.cardNo,callback:function(x){n.$set(n.form,"cardNo",x)},expression:"form.cardNo"}})],1)],1)],1),x("div",{staticClass:"select-section"},[x("el-button",{staticClass:"select-button",attrs:{type:"text"},on:{click:n.h_selectCard}},[n._v(" 选择已录入身份卡 >> ")])],1),x("div",{staticClass:"dialog-footer f_center",staticStyle:{"margin-top":"100px"}},[x("el-button",{attrs:{loading:n.loading},on:{click:n.h_close}},[n._v("取消")]),x("el-button",{attrs:{type:"primary",loading:n.loading},on:{click:n.h_submit}},[n._v("确定")])],1)]):n._e(),"table"===n.component?x("div",[x("card-table",{attrs:{loading:n.loading},on:{back:n.h_back,submit:n.h_submit}})],1):n._e()])},iw=[],rw=function(){var n=this,x=n._self._c;return x("div",{directives:[{name:"loading",rawName:"v-loading",value:n.loading,expression:"loading"}]},[x("el-table",{ref:"table",attrs:{data:n.tableData,stripe:"","header-cell-style":{background:"#f7f8fa"}},on:{"selection-change":n.h_selectionChange,"row-click":n.h_rowClick}},[x("el-table-column",{attrs:{type:"selection",width:"75"}}),x("el-table-column",{attrs:{type:"index",label:"序号",width:"80"}}),x("el-table-column",{attrs:{prop:"icCard",label:"IC卡号"}}),x("el-table-column",{attrs:{prop:"createdTime",label:"录入时间"}})],1),n._e(),x("div",{staticClass:"flex-center mt-42"},[x("el-button",{on:{click:n.h_back}},[n._v("返回")]),x("el-button",{attrs:{type:"primary"},on:{click:n.h_submit}},[n._v("确定")])],1)],1)},ow=[],sw={name:"CardTable",props:{loading:{type:Boolean,default:!1}},data(){return{tableData:[],selection:[],pagination:{current:1,size:5,total:0}}},created(){this.f_loadData()},methods:{h_rowClick(n){this.$refs.table.toggleRowSelection(n)},h_currentChange(n){this.table.pagination.current=n,this.f_loadData()},h_back(){this.$emit("back")},h_submit(){0!==this.selection.length?this.$emit("submit",this.selection):this.$message.warning("请选择要添加的IC卡")},f_loadData(){nw({keyword:null}).then(n=>{this.tableData=n.data})},h_selectionChange(n){this.selection=n}}},hw=sw,uw=Ie(hw,rw,ow,!1,null,"49d6fcb9",null),aw=uw.exports,gw={name:"RegisterDialog",components:{CardTable:aw},props:{row:{type:Object,default:()=>{}}},data(){return{loading:!1,component:"normal",visible:!1,form:{cardNo:""}}},created(){},mounted(){this.visible=!0,this.$authEventBus.$on("card",this.h_card)},beforeDestroy(){this.$authEventBus.$off("card",this.h_card)},methods:{h_card(n){0!==n.result&&200!==n.status||(this.form.cardNo=n.data)},h_back(){this.component="normal"},h_submit(n){this.loading=!0;let x={userId:this.row.userId,userName:this.row.row.name,icCards:[this.form.cardNo],tenantId:""};n&&(x={userId:this.row.userId,userName:this.row.row.name,icCards:n.map(n=>n.icCard),tenantId:""}),$j(x).then(()=>{this.$message.success("新增成功"),this.visible=!1,this.$emit("refresh")}).finally(()=>{this.loading=!1})},h_close(){this.visible=!1},closed(){this.$emit("closed")},h_selectCard(){this.component="table"}}},lw=gw,cw=Ie(lw,ew,iw,!1,null,"1e4a3a1e",null),dw=cw.exports,fw={name:"CardRegister",components:{RegisterDialog:dw},props:{row:{type:Object,default:()=>{}}},data(){return{tableData:[],selection:[],visible:!1,loading:!1}},created(){this.h_loadData()},methods:{h_rowClick(n){this.$refs.table.toggleRowSelection(n)},h_loadData(){this.loading=!0,tw({userId:this.row.userId}).then(n=>{this.tableData=n.data}).finally(()=>{this.loading=!1})},h_add(){this.visible=!0},h_remove(){this.$confirm("确定移除选中的身份卡吗?","提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{this.loading=!0,xw(this.selection.map(n=>n.icCardId)).then(()=>{this.$message.success("移除成功"),this.h_loadData()}).finally(()=>{this.loading=!1})}).catch(()=>{})},h_selectionChange(n){this.selection=n}}},pw=fw,yw=Ie(pw,Xj,Zj,!1,null,"6f88fce1",null),mw=yw.exports,bw=function(){var n=this,x=n._self._c;return x("div",{staticClass:"flex-center align-center h100 w100"},[x("div",{staticClass:"finger-dialog"},[x("div",{staticClass:"finger-register-content"},[x("div",{staticStyle:{color:"#333","font-size":"24px","margin-bottom":"12px","padding-top":"48px","text-align":"center","margin-top":"24px"}},[n._v(" "+n._s(n.stepTips)+" ")]),x("div",{staticStyle:{display:"flex","justify-content":"center","align-items":"center","padding-top":"50px"}},[x("div",{staticClass:"hand-area left-hand"},[x("div",{staticClass:"hand-image-wrapper"},[x("img",{staticClass:"hand-image",attrs:{src:n.leftHandleImg}}),x("div",{staticClass:"finger-buttons-overlay"},n._l(n.leftFingers,function(t,e){return x("div",{key:"left-"+e,class:["finger-circle",{active:n.selectedFinger&&n.selectedFinger.value===t.value,ready:!!t.fingerInfo}],style:{top:t.top+"px",left:t.left+"px"},on:{click:function(x){return n.handleSelectFinger(t)}}})}),0)])]),x("div",{staticClass:"hand-area right-hand"},[x("div",{staticClass:"hand-image-wrapper"},[x("img",{staticClass:"hand-image",attrs:{src:n.rightHandleImg}}),x("div",{staticClass:"finger-buttons-overlay"},n._l(n.rightFingers,function(t,e){return x("div",{key:"right-"+e,class:["finger-circle",{active:n.selectedFinger&&n.selectedFinger.value===t.value,ready:!!t.fingerInfo}],style:{top:t.top+"px",left:t.left+"px"},on:{click:function(x){return n.handleSelectFinger(t)}}})}),0)])]),x("div",{staticClass:"fingerprint-status"},[x("div",{staticClass:"fingerprint-image-container"},[x("div",{staticClass:"delete-button"},[n.selectedFinger&&n.selectedFinger.fingerInfo?x("el-button",{attrs:{type:"text",size:"large"},on:{click:n.handleDeleteFinger}},[x("i",{staticClass:"el-icon-delete",staticStyle:{"font-size":"20px",color:"#999"}})]):n._e()],1),x("img",{staticClass:"fingerprint-image",attrs:{src:n.realFingerprintImage}}),x("p",{staticClass:"status-text"},[n._v(" "+n._s(n.fingerStatusText)+" ")])])])])])])])},zw=[];function vw(n){return li({url:"/finger/maxFingerSeq",method:"post",data:n})}function jw(n){return li({url:"/finger/upload",method:"post",data:n})}function ww(n){return li({url:"/finger/findByUserId",method:"post",data:n})}function kw(n){return li({url:"/finger/delete",method:"post",params:n})}const qw="",Cw="",Aw="",Ew="",Sw="",Iw="",Dw="",Ow="";var _w={name:"FingerRegisterView",props:{row:{type:Object,default:()=>{}}},data(){return{fingerRegisterStep:0,currentFingerprintImage:"/public/finger-status-start.png",gifTimeoutId:null,selectedFinger:null,fingerTemp:null,fingerId:null,fid:null,loading:!1,leftFingers:[{label:"大拇指",value:"left-thumb",top:122,left:6,index:0,fingerInfo:null},{label:"食指",value:"left-index",top:20,left:60,index:1,fingerInfo:null},{label:"中指",value:"left-middle",top:3,left:98,index:2,fingerInfo:null},{label:"无名指",value:"left-ring",top:12,left:136,index:3,fingerInfo:null},{label:"小拇指",value:"left-little",top:35,left:176,index:4,fingerInfo:null}],rightFingers:[{label:"大拇指",value:"right-thumb",top:118,left:178,index:5,fingerInfo:null},{label:"食指",value:"right-index",top:16,left:121,index:6,fingerInfo:null},{label:"中指",value:"right-middle",top:0,left:83,index:7,fingerInfo:null},{label:"无名指",value:"right-ring",top:11,left:43,index:8,fingerInfo:null},{label:"小拇指",value:"right-little",top:42,left:5,index:9,fingerInfo:null}]}},computed:{userId(){return this.row.userId},devSn(){return ae.getters.getFingerprintDeviceSN},devType(){return 1},tenantId(){return null},leftHandleImg(){return this.selectedFinger&&this.selectedFinger.value.includes("left")?e(9165):e(288)},rightHandleImg(){return this.selectedFinger&&this.selectedFinger.value.includes("right")?e(4862):e(9637)},realFingerprintImage(){return"/public/finger-status-start.png"===this.currentFingerprintImage?Ow:"/public/finger-status-1.gif"===this.currentFingerprintImage?qw:"/public/finger-status-1-last.png"===this.currentFingerprintImage?Ew:"/public/finger-status-2.gif"===this.currentFingerprintImage?Cw:"/public/finger-status-2-last.png"===this.currentFingerprintImage?Sw:"/public/finger-status-3.gif"===this.currentFingerprintImage?Aw:"/public/finger-status-3-last.png"===this.currentFingerprintImage?Iw:"/public/finger-status-compeleted.png"===this.currentFingerprintImage?Dw:Ow},stepTips(){return-1===this.fingerRegisterStep?"指纹采集异常,请重试!":0===this.fingerRegisterStep?"请选择需要采集的手指":1===this.fingerRegisterStep?"请将手指放在设备上":2===this.fingerRegisterStep?"请再次将手指放在设备上":3===this.fingerRegisterStep?"最后一次将手指放在设备上":4===this.fingerRegisterStep?"正在指纹采集":5===this.fingerRegisterStep?"指纹采集成功":"未知状态"},fingerStatusText(){return-1===this.fingerRegisterStep?"指纹采集异常,请重试!":0===this.fingerRegisterStep?"采集指纹一共需要三次按压":1===this.fingerRegisterStep?"请将手指放在设备上":2===this.fingerRegisterStep?"请再次将手指放在设备上":3===this.fingerRegisterStep?"最后一次将手指放在设备上":4===this.fingerRegisterStep?"正在处理指纹数据...":5===this.fingerRegisterStep?"指纹采集成功":"准备采集指纹"}},watch:{fingerRegisterStep(n){clearTimeout(this.gifTimeoutId);const x=800;1===n||0===n||-1===n?this.currentFingerprintImage="/public/finger-status-start.png":2===n?(this.currentFingerprintImage="/public/finger-status-1.gif",this.gifTimeoutId=setTimeout(()=>{this.currentFingerprintImage="/public/finger-status-1-last.png"},x)):3===n?(this.currentFingerprintImage="/public/finger-status-2.gif",this.gifTimeoutId=setTimeout(()=>{this.currentFingerprintImage="/public/finger-status-2-last.png"},x)):4===n?(this.currentFingerprintImage="/public/finger-status-3.gif",this.gifTimeoutId=setTimeout(()=>{this.currentFingerprintImage="/public/finger-status-3-last.png"},x)):5===n&&(this.currentFingerprintImage="/public/finger-status-compeleted.png")}},mounted(){this.loadCurrentUserFingerInfo(),this.$authEventBus.$on("startCollectionMessage",this.startCollectionMessage)},beforeDestroy(){clearTimeout(this.gifTimeoutId),this.$authEventBus.$off("startCollectionMessage",this.startCollectionMessage),this.fingerRegisterStep>0&&this.fingerRegisterStep<5&&this.cancelCollection()},methods:{cancelCollection(){this.$authEventBus.$emit("cancelCollection")},handleCancelCollection(){this.$confirm("确定要退出指纹采集吗?","提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{this.cancelCollection(),this.$message.info("已退出指纹采集")}).catch(()=>{})},startCollectionMessage(n){if(console.log("startCollectionMessage:",n),200===n.status||0===n.result){const{count:x,temp:t,image:e}=n.data;console.log(`指纹采集进度: ${x}/4`),1===x?this.fingerRegisterStep=2:2===x?this.fingerRegisterStep=3:3===x?this.fingerRegisterStep=4:4===x&&(this.fingerRegisterStep=5,this.fingerTemp=t,console.log("✅ 指纹采集完成,获取到指纹模板"),this.$nextTick(()=>{this.addFingerprint()})),e&&console.log("收到指纹图像数据")}else console.error("指纹采集失败:",n.msg||"未知错误"),this.fingerRegisterStep=-1,this.$message?.error?.(n.msg||"指纹采集失败,请重试")},handleClose(){},async handleSelectFinger(n){if(this.fingerRegisterStep>0&&this.fingerRegisterStep<5)this.$message({message:"指纹采集尚未完成,请先完成当前采集",type:"warning"});else if(n.fingerInfo)this.selectedFinger=n;else try{const x=await vw({devSn:this.devSn,devType:this.devType,fingerNo:n.index,tenantId:this.tenantId,userId:this.userId});this.fingerId=x.data.fingerId,this.fid=x.data.fingerSeq,this.selectedFinger=n,this.fingerRegisterStep=1,this.fingerTemp=null,console.log(`开始采集 ${n.label} 指纹,fingerId: ${this.fingerId}, fid: ${this.fid}`),this.startCollection()}catch(x){console.error("获取指纹信息失败:",x)}},handleSaveFingerprint(){this.addFingerprint()},handleDeleteFinger(){this.$confirm("确定删除指纹吗?").then(()=>{kw({fingerId:this.selectedFinger.fingerInfo.id}).then(()=>{this.selectedFinger=null,this.fingerRegisterStep=0,this.$message.success("删除成功"),this.loadCurrentUserFingerInfo()})}).catch(()=>{})},startCollection(){this.$authEventBus.$emit("startCollection")},loadCurrentUserFingerInfo(){ww({devType:this.devType,tenantId:this.tenantId,userId:this.userId}).then(n=>{const x=n.data,t=this.leftFingers.map(n=>{const t=x.find(x=>x.fingerNo===n.index);return{...n,fingerInfo:t}}),e=this.rightFingers.map(n=>{const t=x.find(x=>x.fingerNo===n.index);return{...n,fingerInfo:t}});this.leftFingers=t,this.rightFingers=e})},addFingerprint(){this.fingerId?this.fingerTemp?this.selectedFinger?this.fid?(this.loading=!0,console.log("开始保存指纹到服务器..."),jw({data:this.fingerTemp,fingerId:this.fingerId}).then(()=>{console.log("✅ 指纹保存成功"),this.loadCurrentUserFingerInfo(),this.selectedFinger=null,this.fingerRegisterStep=0,this.fingerTemp=null,this.fingerId=null,this.fid=null,this.$message.success("指纹录入成功!")}).catch(n=>{console.error("❌ 指纹保存失败:",n),this.fingerRegisterStep=-1}).finally(()=>{this.loading=!1})):this.$message.error("未获取到指纹序列号"):this.$message.error("请先选择手指"):this.$message.error("未获取到指纹模板"):this.$message.error("未获取到指纹ID")}}},Tw=_w,Rw=Ie(Tw,bw,zw,!1,null,"334b3efe",null),Bw=Rw.exports,Mw={name:"auth-com",components:{FaceRegister:Jj,CardRegister:mw,FingerRegister:Bw},props:{authCollect:{type:Array,default:()=>[]},drawerInfo:{type:Object,default:()=>{}}},data(){return{authList:[],activeName:""}},computed:{modules(){return this.authCollect??[]},options(){return this.modules&&this.modules.find(n=>"face"===n.value).options||[]}},mounted(){this.h_init()},methods:{h_init(){this.modules.length&&(this.activeName=this.modules[0].value)}}},Nw=Mw,Fw=Ie(Nw,si,hi,!1,null,"4bde6ad6",null),Pw=Fw.exports,Lw=function(){var n=this,x=n._self._c;return x("div",{staticClass:"flex-center align-center h100"},[x("el-empty",{staticStyle:{"font-size":"20px"},attrs:{description:"请先保存用户信息"}})],1)},Hw=[],Uw={name:"empty-view"},Vw=Uw,Ww=Ie(Vw,Lw,Hw,!1,null,"9e253eac",null),Qw=Ww.exports,Gw={name:"user-drawer",components:{UserInfo:oi,AuthCom:Pw,EmptyView:Qw},props:{drawerStyle:{type:String,default:""},authCollect:{required:!1,type:Array,default:()=>[]},drawerInfo:{type:Object},userBeforeCreate:{type:Function,default:()=>!0}},data(){return{visible:!1,loading:!1}},mounted(){this.visible=!0},methods:{closed(){this.$emit("closed")},h_back(){this.visible=!1},async f_save(){const n=this.userBeforeCreate(this.$refs["user-info"].h_getFormData(),this.drawerInfo);this.userBeforeCreate&&!n||this.$refs["user-info"].h_validate().then(n=>{if(console.log("valid",n),!n)return;const x=this.$refs["user-info"].h_getFormData();this.loading=!0,ve({...x,organId:this.drawerInfo.organ.id,accountEnabled:x.accountEnabled}).then(()=>{this.$emit("refresh"),this.visible=!1}).catch(n=>{console.error("用户状态 err",n)}).finally(()=>{this.loading=!1})})}}},Kw=Gw,Yw=Ie(Kw,Xe,Ze,!1,null,"8c86d64a",null),Jw=Yw.exports,Xw=e(4747),Zw=e.n(Xw);class $w{constructor(n,x={}){this.url=n,this.options={reconnectInterval:5e3,maxReconnectAttempts:10,heartbeatInterval:12e4,...x},this.ws=null,this.reconnectAttempts=0,this.isConnected=!1,this.heartbeatTimer=null,this.eventListeners=new Map,this.onOpen=this.onOpen.bind(this),this.onMessage=this.onMessage.bind(this),this.onError=this.onError.bind(this),this.onClose=this.onClose.bind(this)}connect(){try{this.ws=new WebSocket(this.url),this.ws.onopen=this.onOpen,this.ws.onmessage=this.onMessage,this.ws.onerror=this.onError,this.ws.onclose=this.onClose}catch(n){console.error("WebSocket连接失败:",n),this.handleReconnect()}}onOpen(n){console.log("WebSocket连接成功"),this.isConnected=!0,this.reconnectAttempts=0,this.startHeartbeat(),this.emit("open",n)}onMessage(n){try{const x=JSON.parse(n.data);if(console.log("收到WebSocket消息:",x),"pong"===x.type)return;this.emit("message",x)}catch(x){console.error("解析WebSocket消息失败:",x),this.emit("message",n.data)}}onError(n){console.error("WebSocket错误:",n),this.emit("error",n)}onClose(n){console.log("WebSocket连接关闭:",n.code,n.reason),this.isConnected=!1,this.stopHeartbeat(),this.emit("close",n),1e3!==n.code&&this.handleReconnect()}send(n){if(!this.isConnected||this.ws.readyState!==WebSocket.OPEN)return console.warn("WebSocket未连接,无法发送消息"),!1;try{const x="string"===typeof n?n:JSON.stringify(n);return this.ws.send(x),console.log("发送WebSocket消息:",n),!0}catch(x){return console.error("发送WebSocket消息失败:",x),!1}}on(n,x){this.eventListeners.has(n)||this.eventListeners.set(n,[]),this.eventListeners.get(n).push(x)}off(n,x){const t=this.eventListeners.get(n);if(t){const n=t.indexOf(x);n>-1&&t.splice(n,1)}}emit(n,x){const t=this.eventListeners.get(n);t&&t.forEach(t=>{try{t(x)}catch(e){console.error(`事件监听器执行失败 [${n}]:`,e)}})}handleReconnect(){this.reconnectAttempts<this.options.maxReconnectAttempts?(this.reconnectAttempts++,console.log(`尝试重连WebSocket (${this.reconnectAttempts}/${this.options.maxReconnectAttempts})`),setTimeout(()=>{this.connect()},this.options.reconnectInterval)):(console.error("WebSocket重连次数已达上限"),this.emit("reconnectFailed"))}startHeartbeat(){this.stopHeartbeat(),this.heartbeatTimer=setInterval(()=>{this.isConnected&&this.send({type:"ping",timestamp:Date.now()})},this.options.heartbeatInterval)}stopHeartbeat(){this.heartbeatTimer&&(clearInterval(this.heartbeatTimer),this.heartbeatTimer=null)}close(){this.stopHeartbeat(),this.ws&&this.ws.close(1e3,"主动关闭"),this.isConnected=!1}getReadyState(){return this.ws?this.ws.readyState:WebSocket.CLOSED}isOpen(){return this.isConnected&&this.ws&&this.ws.readyState===WebSocket.OPEN}}var nk=$w,xk={name:"auth-manage",props:{drawerStyle:{type:String,default:""},authCollect:{required:!1,type:Array,default:()=>["face","finger","idCard"]},userBeforeCreate:{type:Function,default:()=>!0},beforeCreate:{type:Function,default:()=>!0},baseUrl:{type:String},authUrl:{type:String}},components:{OrganTree:Pe,UserTable:Je,UserDrawer:Jw},data(){return{visible:!1,drawerInfo:{},organTreeKey:"1",websocket:null,cardReader:null,fingerprintDeviceCount:0}},created(){this.baseUrl&&ae.commit("SET_BASE_URL",this.baseUrl),this.authUrl&&ae.commit("SET_AUTH_URL",this.authUrl)},mounted(){console.log("LD-AUTH打包时间为",Zw()(1758188577134).format("YYYY-MM-DD HH:mm:ss")),this.$authEventBus.$on("startCollection",this.handleStartCollection),this.$authEventBus.$on("cancelCollection",this.handleCancelCollection),this.initWebSocket()},beforeDestroy(){this.websocket&&(console.log("🔌 组件销毁,关闭WebSocket连接"),this.websocket.close(),this.websocket=null),this.$authEventBus.$off("startCollection",this.handleStartCollection),this.$authEventBus.$off("cancelCollection",this.handleCancelCollection)},methods:{handleCancelCollection(){this.websocket&&this.websocket.send({action:1010})},handleStartCollection(){if(ae.getters.getFingerprintDeviceSN){const n={action:1001};this.websocket.send(n)}},initWebSocket(){try{this.websocket=new nk(`${ae.state.websocketUrl}`,{reconnectInterval:5e3,maxReconnectAttempts:10,heartbeatInterval:12e4}),this.websocket.on("open",()=>{this.checkCardReaderConnection(),this.getFingerprintDeviceSN()}),this.websocket.on("message",n=>{console.log("📨 收到WebSocket消息:",n),this.handleWebSocketMessage(n)}),this.websocket.on("error",n=>{console.error("❌ WebSocket连接错误:",n)}),this.websocket.on("close",n=>{console.log("🔌 WebSocket连接已关闭:",n.code,n.reason),n.code}),this.websocket.on("reconnectFailed",()=>{console.error("💥 WebSocket重连失败,已达最大重连次数")}),this.websocket.connect()}catch(n){console.error("WebSocket初始化失败:",n)}},handleWebSocketMessage(n){if(n.action)switch(n.action){case 1009:this.handleFingerprintDeviceSNResponse(n);break;case 2001:this.handleCheckCardReaderResponse(n);break;case 2002:this.handleCardReaderListResponse(n);break;case 2003:this.handleOpenCardReaderResponse(n);break;case 2004:this.$authEventBus.$emit("card",n);break;case 1001:this.$authEventBus.$emit("startCollectionMessage",n);break;default:console.log("未知action类型:",n)}else switch(n.type){case"user_update":console.log("用户信息更新:",n.payload),this.f_userData();break;case"organ_update":console.log("组织架构更新:",n.payload),this.f_refreshTree();break;case"auth_status":console.log("认证状态更新:",n.payload),this.$message?.info?.(n.payload.message||"认证状态已更新");break;case"notification":console.log("系统通知:",n.payload),this.$message?.info?.(n.payload.message||"收到系统通知");break;default:console.log("未知消息类型:",n)}},sendWebSocketMessage(n,x={}){if(this.websocket&&this.websocket.isOpen()){const t={type:n,payload:x,timestamp:Date.now()};this.websocket.send(t),console.log("📤 发送WebSocket消息:",t)}},getFingerprintDeviceSN(){console.log("🔢 获取指纹设备SN码...");const n={action:1009};this.websocket.send(n),console.log("📤 发送获取指纹设备SN码消息:",n)},handleFingerprintDeviceSNResponse(n){if(console.log("📊 收到指纹设备SN响应:",n),200===n.status||0===n.result){const x=n.data?.sn||"";x?(console.log("✅ 获取到指纹设备SN:",x),ae.dispatch("updateFingerprintDeviceSN",x)):(console.warn("⚠️ 指纹设备SN为空"),ae.dispatch("updateFingerprintDeviceSN",""))}else console.error("❌ 获取指纹设备SN失败:",n.msg||"未知错误")},getFingerprintDeviceStatus(){return{deviceCount:this.fingerprintDeviceCount,hasDevice:this.fingerprintDeviceCount>0,deviceSN:this.$store.getters.getFingerprintDeviceSN}},refreshFingerprintDeviceCount(){this.websocket&&this.websocket.isOpen()?this.getFingerprintDeviceCount():console.warn("WebSocket未连接,无法获取指纹设备数量")},refreshFingerprintDeviceSN(){this.websocket&&this.websocket.isOpen()?this.getFingerprintDeviceSN():console.warn("WebSocket未连接,无法获取指纹设备SN")},refreshAllFingerprintInfo(){this.websocket&&this.websocket.isOpen()?(this.getFingerprintDeviceCount(),this.getFingerprintDeviceSN()):console.warn("WebSocket未连接,无法获取指纹设备信息")},checkCardReaderConnection(){console.log("🔍 检查读卡器连接状态...");const n={action:2001};this.websocket.send(n),console.log("📤 发送检查读卡器连接状态消息:",n)},handleCheckCardReaderResponse(n){console.log("📊 收到读卡器连接状态响应:",n),200===n.status||0===n.result?n.data&&n.data.isOpen?(this.cardReader=n.data.devName||"读卡器",console.log("✅ 读卡器已连接:",this.cardReader)):(console.log("⚠️ 读卡器未连接,开始获取读卡器列表..."),this.getCardReaderList()):(console.error("❌ 检查读卡器状态失败:",n.msg||"未知错误"),this.getCardReaderList())},getCardReaderList(){console.log("📡 请求获取读卡器列表...");const n={action:2002};this.websocket.send(n),console.log("📤 发送获取读卡器列表消息:",n)},handleCardReaderListResponse(n){if(console.log("📋 收到读卡器列表响应:",n),n.data&&Array.isArray(n.data)&&n.data.length>0){const x=n.data[0];console.log("🎯 找到读卡器:",x),this.openCardReader(x)}else console.warn("⚠️ 未找到可用的读卡器")},openCardReader(n){const x={action:2003,devName:n};this.websocket.send(x)},handleOpenCardReaderResponse(n){0===n.result||200===n.status?this.cardReader=n.devName||"读卡器":this.$message?.error?.(`读卡器打开失败: ${n.message||n.error||"未知错误"}`)},getCardReaderStatus(){return{isConnected:!!this.cardReader,deviceName:this.cardReader}},reinitCardReader(){this.cardReader=null,this.websocket&&this.websocket.isOpen()?this.checkCardReaderConnection():this.$message?.warning?.("WebSocket未连接,无法初始化读卡器")},getAllDeviceStatus(){return{fingerprint:this.getFingerprintDeviceStatus(),cardReader:this.getCardReaderStatus()}},refreshAllDevices(){this.websocket&&this.websocket.isOpen()?(this.refreshAllFingerprintInfo(),this.checkCardReaderConnection()):this.$message?.warning?.("WebSocket未连接,无法刷新设备状态")},f_refreshTree(){this.organTreeKey=this.organTreeKey+1},f_userData(n){n&&this.$set(this.drawerInfo,"organ",n),this.$refs["user-table"].f_init(this.drawerInfo.organ)},h_setVisible(){this.visible=!1},h_setUserId(n,x){this.$set(this.drawerInfo,"userId",n),this.$set(this.drawerInfo,"row",x),this.visible=!0}}},tk=xk,ek=Ie(tk,r,o,!1,null,"81b3c05e",null),ik=ek.exports;const rk=new(At());var ok=rk;const sk=function(n,x={}){sk.installed||(n.component(ik.name,ik),n.prototype.$authEventBus=ok,void 0!==x.baseUrl&&null!==x.baseUrl&&ae.commit("SET_BASE_URL",x.baseUrl),void 0!==x.authUrl&&null!==x.authUrl&&ae.commit("SET_AUTH_URL",x.authUrl),void 0!==x.websocketUrl&&null!==x.websocketUrl&&ae.commit("SET_WEBSOCKET_URL",x.websocketUrl),void 0!==x.faceApiUrl&&null!==x.faceApiUrl&&ae.commit("SET_FACE_API_URL",x.faceApiUrl))};var hk={install:sk,authManage:ik},uk=hk}(),i=i["default"],i}()});
70
+ var wm=function(n,x){return wm=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(n,x){n.__proto__=x}||function(n,x){for(var t in x)x.hasOwnProperty(t)&&(n[t]=x[t])},wm(n,x)};function km(n,x){function t(){this.constructor=n}wm(n,x),n.prototype=null===x?Object.create(x):(t.prototype=x.prototype,new t)}var qm=function(){return qm=Object.assign||function(n){for(var x,t=1,e=arguments.length;t<e;t++)for(var i in x=arguments[t],x)Object.prototype.hasOwnProperty.call(x,i)&&(n[i]=x[i]);return n},qm.apply(this,arguments)};function Cm(n,x,t,e){function i(n){return n instanceof t?n:new t(function(x){x(n)})}return new(t||(t=Promise))(function(t,r){function o(n){try{h(e.next(n))}catch(Di){r(Di)}}function s(n){try{h(e["throw"](n))}catch(Di){r(Di)}}function h(n){n.done?t(n.value):i(n.value).then(o,s)}h((e=e.apply(n,x||[])).next())})}function Am(n,x){var t,e,i,r,o={label:0,sent:function(){if(1&i[0])throw i[1];return i[1]},trys:[],ops:[]};return r={next:s(0),throw:s(1),return:s(2)},"function"===typeof Symbol&&(r[Symbol.iterator]=function(){return this}),r;function s(n){return function(x){return h([n,x])}}function h(r){if(t)throw new TypeError("Generator is already executing.");while(o)try{if(t=1,e&&(i=2&r[0]?e["return"]:r[0]?e["throw"]||((i=e["return"])&&i.call(e),0):e.next)&&!(i=i.call(e,r[1])).done)return i;switch(e=0,i&&(r=[2&r[0],i.value]),r[0]){case 0:case 1:i=r;break;case 4:return o.label++,{value:r[1],done:!1};case 5:o.label++,e=r[1],r=[0];continue;case 7:r=o.ops.pop(),o.trys.pop();continue;default:if(i=o.trys,!(i=i.length>0&&i[i.length-1])&&(6===r[0]||2===r[0])){o=0;continue}if(3===r[0]&&(!i||r[1]>i[0]&&r[1]<i[3])){o.label=r[1];break}if(6===r[0]&&o.label<i[1]){o.label=i[1],i=r;break}if(i&&o.label<i[2]){o.label=i[2],o.ops.push(r);break}i[2]&&o.ops.pop(),o.trys.pop();continue}r=x.call(n,o)}catch(Di){r=[6,Di],e=0}finally{t=i=0}if(5&r[0])throw r[1];return{value:r[0]?r[1]:void 0,done:!0}}}function Em(){for(var n=0,x=0,t=arguments.length;x<t;x++)n+=arguments[x].length;var e=Array(n),i=0;for(x=0;x<t;x++)for(var r=arguments[x],o=0,s=r.length;o<s;o++,i++)e[i]=r[o];return e}var Sm=function(){function n(n,x){if(!Lm(n)||!Lm(x))throw new Error("Dimensions.constructor - expected width and height to be valid numbers, instead have "+JSON.stringify({width:n,height:x}));this._width=n,this._height=x}return Object.defineProperty(n.prototype,"width",{get:function(){return this._width},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"height",{get:function(){return this._height},enumerable:!0,configurable:!0}),n.prototype.reverse=function(){return new n(1/this.width,1/this.height)},n}();function Im(n,x){return n instanceof Kr&&n.shape.length===x}function Dm(n){return Im(n,2)}function Om(n){return Im(n,3)}function _m(n){return Im(n,4)}function Tm(n){return n%1!==0}function Rm(n){return n%2===0}function Bm(n,x){void 0===x&&(x=2);var t=Math.pow(10,x);return Math.floor(n*t)/t}function Mm(n){return n&&n.width&&n.height}function Nm(n,x){var t=n.width,e=n.height,i=x/Math.max(e,t);return new Sm(Math.round(t*i),Math.round(e*i))}function Fm(n){return n.reduce(function(n,x){return n.add(x)},new Um(0,0)).div(new Um(n.length,n.length))}function Pm(n,x,t){return Array(n).fill(0).map(function(n,e){return x+e*t})}function Lm(n){return!!n&&n!==1/0&&n!==-1/0&&!isNaN(n)||0===n}function Hm(n){return Lm(n)&&0<=n&&n<=1}var Um=function(){function n(n,x){this._x=n,this._y=x}return Object.defineProperty(n.prototype,"x",{get:function(){return this._x},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"y",{get:function(){return this._y},enumerable:!0,configurable:!0}),n.prototype.add=function(x){return new n(this.x+x.x,this.y+x.y)},n.prototype.sub=function(x){return new n(this.x-x.x,this.y-x.y)},n.prototype.mul=function(x){return new n(this.x*x.x,this.y*x.y)},n.prototype.div=function(x){return new n(this.x/x.x,this.y/x.y)},n.prototype.abs=function(){return new n(Math.abs(this.x),Math.abs(this.y))},n.prototype.magnitude=function(){return Math.sqrt(Math.pow(this.x,2)+Math.pow(this.y,2))},n.prototype.floor=function(){return new n(Math.floor(this.x),Math.floor(this.y))},n}(),Vm=function(){function n(x,t){void 0===t&&(t=!0);var e=x||{},i=[e.left,e.top,e.right,e.bottom].every(Lm),r=[e.x,e.y,e.width,e.height].every(Lm);if(!r&&!i)throw new Error("Box.constructor - expected box to be IBoundingBox | IRect, instead have "+JSON.stringify(e));var o=r?[e.x,e.y,e.width,e.height]:[e.left,e.top,e.right-e.left,e.bottom-e.top],s=o[0],h=o[1],u=o[2],a=o[3];n.assertIsValidBox({x:s,y:h,width:u,height:a},"Box.constructor",t),this._x=s,this._y=h,this._width=u,this._height=a}return n.isRect=function(n){return!!n&&[n.x,n.y,n.width,n.height].every(Lm)},n.assertIsValidBox=function(x,t,e){if(void 0===e&&(e=!1),!n.isRect(x))throw new Error(t+" - invalid box: "+JSON.stringify(x)+", expected object with properties x, y, width, height");if(!e&&(x.width<0||x.height<0))throw new Error(t+" - width ("+x.width+") and height ("+x.height+") must be positive numbers")},Object.defineProperty(n.prototype,"x",{get:function(){return this._x},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"y",{get:function(){return this._y},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"width",{get:function(){return this._width},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"height",{get:function(){return this._height},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"left",{get:function(){return this.x},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"top",{get:function(){return this.y},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"right",{get:function(){return this.x+this.width},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"bottom",{get:function(){return this.y+this.height},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"area",{get:function(){return this.width*this.height},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"topLeft",{get:function(){return new Um(this.left,this.top)},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"topRight",{get:function(){return new Um(this.right,this.top)},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"bottomLeft",{get:function(){return new Um(this.left,this.bottom)},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"bottomRight",{get:function(){return new Um(this.right,this.bottom)},enumerable:!0,configurable:!0}),n.prototype.round=function(){var x=[this.x,this.y,this.width,this.height].map(function(n){return Math.round(n)}),t=x[0],e=x[1],i=x[2],r=x[3];return new n({x:t,y:e,width:i,height:r})},n.prototype.floor=function(){var x=[this.x,this.y,this.width,this.height].map(function(n){return Math.floor(n)}),t=x[0],e=x[1],i=x[2],r=x[3];return new n({x:t,y:e,width:i,height:r})},n.prototype.toSquare=function(){var x=this,t=x.x,e=x.y,i=x.width,r=x.height,o=Math.abs(i-r);return i<r&&(t-=o/2,i+=o),r<i&&(e-=o/2,r+=o),new n({x:t,y:e,width:i,height:r})},n.prototype.rescale=function(x){var t=Mm(x)?x.width:x,e=Mm(x)?x.height:x;return new n({x:this.x*t,y:this.y*e,width:this.width*t,height:this.height*e})},n.prototype.pad=function(x,t){var e=[this.x-x/2,this.y-t/2,this.width+x,this.height+t],i=e[0],r=e[1],o=e[2],s=e[3];return new n({x:i,y:r,width:o,height:s})},n.prototype.clipAtImageBorders=function(x,t){var e=this,i=e.x,r=e.y,o=e.right,s=e.bottom,h=Math.max(i,0),u=Math.max(r,0),a=o-h,g=s-u,l=Math.min(a,x-h),c=Math.min(g,t-u);return new n({x:h,y:u,width:l,height:c}).floor()},n.prototype.shift=function(x,t){var e=this,i=e.width,r=e.height,o=this.x+x,s=this.y+t;return new n({x:o,y:s,width:i,height:r})},n.prototype.padAtBorders=function(n,x){var t=this.width+1,e=this.height+1,i=1,r=1,o=t,s=e,h=this.left,u=this.top,a=this.right,g=this.bottom;return a>x&&(o=-a+x+t,a=x),g>n&&(s=-g+n+e,g=n),h<1&&(s=2-h,h=1),u<1&&(s=2-u,u=1),{dy:r,edy:s,dx:i,edx:o,y:u,ey:g,x:h,ex:a,w:t,h:e}},n.prototype.calibrate=function(x){return new n({left:this.left+x.left*this.width,top:this.top+x.top*this.height,right:this.right+x.right*this.width,bottom:this.bottom+x.bottom*this.height}).toSquare().round()},n}(),Wm=function(n){function x(x,t,e,i,r){return void 0===r&&(r=!1),n.call(this,{left:x,top:t,right:e,bottom:i},r)||this}return km(x,n),x}(Vm),Qm=function(){function n(n,x,t,e,i){this._imageDims=new Sm(i.width,i.height),this._score=n,this._classScore=x,this._className=t,this._box=new Vm(e).rescale(this._imageDims)}return Object.defineProperty(n.prototype,"score",{get:function(){return this._score},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"classScore",{get:function(){return this._classScore},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"className",{get:function(){return this._className},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"box",{get:function(){return this._box},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"imageDims",{get:function(){return this._imageDims},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"imageWidth",{get:function(){return this.imageDims.width},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"imageHeight",{get:function(){return this.imageDims.height},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"relativeBox",{get:function(){return new Vm(this._box).rescale(this.imageDims.reverse())},enumerable:!0,configurable:!0}),n.prototype.forSize=function(x,t){return new n(this.score,this.classScore,this.className,this.relativeBox,{width:x,height:t})},n}(),Gm=function(n){function x(x,t,e){return n.call(this,x,x,"",t,e)||this}return km(x,n),x.prototype.forSize=function(t,e){var i=n.prototype.forSize.call(this,t,e),r=i.score,o=i.relativeBox,s=i.imageDims;return new x(r,o,s)},x}(Qm);function Km(n){var x=n.map(function(n){return n.x}),t=n.map(function(n){return n.y}),e=x.reduce(function(n,x){return x<n?x:n},1/0),i=t.reduce(function(n,x){return x<n?x:n},1/0),r=x.reduce(function(n,x){return n<x?x:n},0),o=t.reduce(function(n,x){return n<x?x:n},0);return new Wm(e,i,r,o)}function Ym(n,x,t){void 0===t&&(t=!0);var e=Math.max(0,Math.min(n.right,x.right)-Math.max(n.left,x.left)),i=Math.max(0,Math.min(n.bottom,x.bottom)-Math.max(n.top,x.top)),r=e*i;return t?r/(n.area+x.area-r):r/Math.min(n.area,x.area)}function Jm(n,x,t,e){void 0===e&&(e=!0);var i=x.map(function(n,x){return{score:n,boxIndex:x}}).sort(function(n,x){return n.score-x.score}).map(function(n){return n.boxIndex}),r=[],o=function(){var x=i.pop();r.push(x);for(var o=i,s=[],h=0;h<o.length;h++){var u=o[h],a=n[x],g=n[u];s.push(Ym(a,g,e))}i=i.filter(function(n,x){return s[x]<=t})};while(i.length>0)o();return r}function Xm(n,x){return bs(function(){var t=x[0],e=x[1],i=x[2],r=$s(Em(n.shape.slice(0,3),[1]),t),o=$s(Em(n.shape.slice(0,3),[1]),e),s=$s(Em(n.shape.slice(0,3),[1]),i),h=ih([r,o,s],3);return vd(n,h)})}function Zm(n,x){return void 0===x&&(x=!1),bs(function(){var t=n.shape.slice(1),e=t[0],i=t[1];if(e===i)return n;var r=Math.abs(e-i),o=Math.round(r*(x?.5:1)),s=e>i?2:1,h=function(x){var t=n.shape.slice();return t[s]=x,$s(t,0)},u=h(o),a=r-u.shape[s],g=x&&a?h(a):null,l=[g,n,u].filter(function(n){return!!n}).map(function(n){return n.toFloat()});return ih(l,s)})}function $m(n){return 1/(1+Math.exp(-n))}var nb,xb=function(n){function x(x,t,e,i,r){return void 0===r&&(r=!1),n.call(this,{x:x,y:t,width:e,height:i},r)||this}return km(x,n),x}(Vm),tb=.5,eb=.43,ib=.45,rb=function(){function n(n,x,t){void 0===t&&(t=new Um(0,0));var e=x.width,i=x.height;this._imgDims=new Sm(e,i),this._shift=t,this._positions=n.map(function(n){return n.mul(new Um(e,i)).add(t)})}return Object.defineProperty(n.prototype,"shift",{get:function(){return new Um(this._shift.x,this._shift.y)},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"imageWidth",{get:function(){return this._imgDims.width},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"imageHeight",{get:function(){return this._imgDims.height},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"positions",{get:function(){return this._positions},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"relativePositions",{get:function(){var n=this;return this._positions.map(function(x){return x.sub(n._shift).div(new Um(n.imageWidth,n.imageHeight))})},enumerable:!0,configurable:!0}),n.prototype.forSize=function(n,x){return new this.constructor(this.relativePositions,{width:n,height:x})},n.prototype.shiftBy=function(n,x){return new this.constructor(this.relativePositions,this._imgDims,new Um(n,x))},n.prototype.shiftByPoint=function(n){return this.shiftBy(n.x,n.y)},n.prototype.align=function(n,x){if(void 0===x&&(x={}),n){var t=n instanceof Gm?n.box.floor():new Vm(n);return this.shiftBy(t.x,t.y).align(null,x)}var e=Object.assign({},{useDlibAlignment:!1,minBoxPadding:.2},x),i=e.useDlibAlignment,r=e.minBoxPadding;return i?this.alignDlib():this.alignMinBbox(r)},n.prototype.alignDlib=function(){var n=this.getRefPointsForAlignment(),x=n[0],t=n[1],e=n[2],i=function(n){return e.sub(n).magnitude()},r=(i(x)+i(t))/2,o=Math.floor(r/ib),s=Fm(n),h=Math.floor(Math.max(0,s.x-tb*o)),u=Math.floor(Math.max(0,s.y-eb*o));return new xb(h,u,Math.min(o,this.imageWidth+h),Math.min(o,this.imageHeight+u))},n.prototype.alignMinBbox=function(n){var x=Km(this.positions);return x.pad(x.width*n,x.height*n)},n.prototype.getRefPointsForAlignment=function(){throw new Error("getRefPointsForAlignment not implemented by base class")},n}(),ob=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.getRefPointsForAlignment=function(){var n=this.positions;return[n[0],n[1],Fm([n[3],n[4]])]},x}(rb),sb=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.getJawOutline=function(){return this.positions.slice(0,17)},x.prototype.getLeftEyeBrow=function(){return this.positions.slice(17,22)},x.prototype.getRightEyeBrow=function(){return this.positions.slice(22,27)},x.prototype.getNose=function(){return this.positions.slice(27,36)},x.prototype.getLeftEye=function(){return this.positions.slice(36,42)},x.prototype.getRightEye=function(){return this.positions.slice(42,48)},x.prototype.getMouth=function(){return this.positions.slice(48,68)},x.prototype.getRefPointsForAlignment=function(){return[this.getLeftEye(),this.getRightEye(),this.getMouth()].map(Fm)},x}(rb),hb=function(){function n(n,x){this._label=n,this._distance=x}return Object.defineProperty(n.prototype,"label",{get:function(){return this._label},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"distance",{get:function(){return this._distance},enumerable:!0,configurable:!0}),n.prototype.toString=function(n){return void 0===n&&(n=!0),this.label+(n?" ("+Bm(this.distance)+")":"")},n}(),ub=function(n){function x(x,t){var e=n.call(this,x)||this;return e._label=t,e}return km(x,n),x.assertIsValidLabeledBox=function(n,x){if(Vm.assertIsValidBox(n,x),!Lm(n.label))throw new Error(x+" - expected property label ("+n.label+") to be a number")},Object.defineProperty(x.prototype,"label",{get:function(){return this._label},enumerable:!0,configurable:!0}),x}(Vm),ab=function(){function n(n,x){if("string"!==typeof n)throw new Error("LabeledFaceDescriptors - constructor expected label to be a string");if(!Array.isArray(x)||x.some(function(n){return!(n instanceof Float32Array)}))throw new Error("LabeledFaceDescriptors - constructor expected descriptors to be an array of Float32Array");this._label=n,this._descriptors=x}return Object.defineProperty(n.prototype,"label",{get:function(){return this._label},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"descriptors",{get:function(){return this._descriptors},enumerable:!0,configurable:!0}),n.prototype.toJSON=function(){return{label:this.label,descriptors:this.descriptors.map(function(n){return Array.from(n)})}},n.fromJSON=function(x){var t=x.descriptors.map(function(n){return new Float32Array(n)});return new n(x.label,t)},n}();(function(n){function x(x,t,e,i){var r=n.call(this,x,t)||this;return r._score=e,r._classScore=i,r}km(x,n),x.assertIsValidPredictedBox=function(n,x){if(ub.assertIsValidLabeledBox(n,x),!Hm(n.score)||!Hm(n.classScore))throw new Error(x+" - expected properties score ("+n.score+") and ("+n.classScore+") to be a number between [0, 1]")},Object.defineProperty(x.prototype,"score",{get:function(){return this._score},enumerable:!0,configurable:!0}),Object.defineProperty(x.prototype,"classScore",{get:function(){return this._classScore},enumerable:!0,configurable:!0})})(ub);function gb(n){return n["detection"]instanceof Gm}function lb(n,x){var t={detection:x};return Object.assign({},n,t)}function cb(){var n=window["fetch"]||function(){throw new Error("fetch - missing fetch implementation for browser environment")},x=function(){throw new Error("readFile - filesystem not available for browser environment")};return{Canvas:HTMLCanvasElement,CanvasRenderingContext2D:CanvasRenderingContext2D,Image:HTMLImageElement,ImageData:ImageData,Video:HTMLVideoElement,createCanvasElement:function(){return document.createElement("canvas")},createImageElement:function(){return document.createElement("img")},fetch:n,readFile:x}}function db(n){var x="";if(!n)try{n=e(Object(function(){var n=new Error("Cannot find module 'fs'");throw n.code="MODULE_NOT_FOUND",n}()))}catch(i){x=i.toString()}var t=n?function(x){return new Promise(function(t,e){n.readFile(x,function(n,x){return n?e(n):t(x)})})}:function(){throw new Error("readFile - failed to require fs in nodejs environment with error: "+x)};return{readFile:t}}function fb(){var n=e.g["Canvas"]||e.g["HTMLCanvasElement"],x=e.g["Image"]||e.g["HTMLImageElement"],t=function(){if(n)return new n;throw new Error("createCanvasElement - missing Canvas implementation for nodejs environment")},i=function(){if(x)return new x;throw new Error("createImageElement - missing Image implementation for nodejs environment")},r=e.g["fetch"]||function(){throw new Error("fetch - missing fetch implementation for nodejs environment")},o=db();return qm({Canvas:n||function(){function n(){}return n}(),CanvasRenderingContext2D:e.g["CanvasRenderingContext2D"]||function(){function n(){}return n}(),Image:x||function(){function n(){}return n}(),ImageData:e.g["ImageData"]||function(){function n(){}return n}(),Video:e.g["HTMLVideoElement"]||function(){function n(){}return n}(),createCanvasElement:t,createImageElement:i,fetch:r},o)}function pb(){return"object"===typeof window&&"undefined"!==typeof document&&"undefined"!==typeof HTMLImageElement&&"undefined"!==typeof HTMLCanvasElement&&"undefined"!==typeof HTMLVideoElement&&"undefined"!==typeof ImageData&&"undefined"!==typeof CanvasRenderingContext2D}function yb(){return"object"===typeof e.g&&"undefined"!==typeof process&&!!process.version}function mb(){if(!nb)throw new Error("getEnv - environment is not defined, check isNodejs() and isBrowser()");return nb}function bb(n){nb=n}function zb(){pb()&&bb(cb()),yb()&&bb(fb())}function vb(n){if(nb||zb(),!nb)throw new Error("monkeyPatch - environment is not defined, check isNodejs() and isBrowser()");var x=n.Canvas,t=void 0===x?nb.Canvas:x,e=n.Image,i=void 0===e?nb.Image:e;nb.Canvas=t,nb.Image=i,nb.createCanvasElement=n.createCanvasElement||function(){return new t},nb.createImageElement=n.createImageElement||function(){return new i},nb.ImageData=n.ImageData||nb.ImageData,nb.Video=n.Video||nb.Video,nb.fetch=n.fetch||nb.fetch,nb.readFile=n.readFile||nb.readFile}var jb,wb={getEnv:mb,setEnv:bb,initialize:zb,createBrowserEnv:cb,createFileSystem:db,createNodejsEnv:fb,monkeyPatch:vb,isBrowser:pb,isNodejs:yb};function kb(n){return wb.isNodejs()||"string"!==typeof n?n:document.getElementById(n)}function qb(n){var x=wb.getEnv(),t=x.Canvas,e=x.CanvasRenderingContext2D;if(n instanceof e)return n;var i=kb(n);if(!(i instanceof t))throw new Error("resolveContext2d - expected canvas to be of instance of Canvas");var r=i.getContext("2d");if(!r)throw new Error("resolveContext2d - canvas 2d context is null");return r}zb(),function(n){n["TOP_LEFT"]="TOP_LEFT",n["TOP_RIGHT"]="TOP_RIGHT",n["BOTTOM_LEFT"]="BOTTOM_LEFT",n["BOTTOM_RIGHT"]="BOTTOM_RIGHT"}(jb||(jb={}));var Cb=function(){function n(n){void 0===n&&(n={});var x=n.anchorPosition,t=n.backgroundColor,e=n.fontColor,i=n.fontSize,r=n.fontStyle,o=n.padding;this.anchorPosition=x||jb.TOP_LEFT,this.backgroundColor=t||"rgba(0, 0, 0, 0.5)",this.fontColor=e||"rgba(255, 255, 255, 1)",this.fontSize=i||14,this.fontStyle=r||"Georgia",this.padding=o||4}return n}(),Ab=function(){function n(x,t,e){void 0===e&&(e={}),this.text="string"===typeof x?[x]:x instanceof n?x.text:x,this.anchor=t,this.options=new Cb(e)}return n.prototype.measureWidth=function(n){var x=this.options.padding;return this.text.map(function(x){return n.measureText(x).width}).reduce(function(n,x){return n<x?x:n},0)+2*x},n.prototype.measureHeight=function(){var n=this.options,x=n.fontSize,t=n.padding;return this.text.length*x+2*t},n.prototype.getUpperLeft=function(n,x){var t=this.options.anchorPosition,e=t===jb.BOTTOM_RIGHT||t===jb.TOP_RIGHT,i=t===jb.BOTTOM_LEFT||t===jb.BOTTOM_RIGHT,r=this.measureWidth(n),o=this.measureHeight(),s=e?this.anchor.x-r:this.anchor.x,h=i?this.anchor.y-o:this.anchor.y;if(x){var u=x.width,a=x.height,g=Math.max(Math.min(s,u-r),0),l=Math.max(Math.min(h,a-o),0);return{x:g,y:l}}return{x:s,y:h}},n.prototype.draw=function(n){var x=kb(n),t=qb(x),e=this.options,i=e.backgroundColor,r=e.fontColor,o=e.fontSize,s=e.fontStyle,h=e.padding;t.font=o+"px "+s;var u=this.measureWidth(t),a=this.measureHeight();t.fillStyle=i;var g=this.getUpperLeft(t,x);t.fillRect(g.x,g.y,u,a),t.fillStyle=r,this.text.forEach(function(n,x){var e=h+g.x,i=h+g.y+(x+1)*o;t.fillText(n,e,i)})},n}(),Eb=function(){function n(n){void 0===n&&(n={});var x=n.boxColor,t=n.lineWidth,e=n.label,i=n.drawLabelOptions;this.boxColor=x||"rgba(0, 0, 255, 1)",this.lineWidth=t||2,this.label=e;var r={anchorPosition:jb.BOTTOM_LEFT,backgroundColor:this.boxColor};this.drawLabelOptions=new Cb(Object.assign({},r,i))}return n}();(function(){function n(n,x){void 0===x&&(x={}),this.box=new Vm(n),this.options=new Eb(x)}n.prototype.draw=function(n){var x=qb(n),t=this.options,e=t.boxColor,i=t.lineWidth,r=this.box,o=r.x,s=r.y,h=r.width,u=r.height;x.strokeStyle=e,x.lineWidth=i,x.strokeRect(o,s,h,u);var a=this.options.label;a&&new Ab([a],{x:o-i/2,y:s},this.options.drawLabelOptions).draw(n)}})();function Sb(n){var x=wb.getEnv(),t=x.Image,e=x.Video;return n instanceof t&&n.complete||n instanceof e&&n.readyState>=3}function Ib(n){return new Promise(function(x,t){if(n instanceof wb.getEnv().Canvas||Sb(n))return x();function e(n){n.currentTarget&&(n.currentTarget.removeEventListener("load",e),n.currentTarget.removeEventListener("error",i),x(n))}function i(n){n.currentTarget&&(n.currentTarget.removeEventListener("load",e),n.currentTarget.removeEventListener("error",i),t(n))}n.addEventListener("load",e),n.addEventListener("error",i)})}function Db(n){var x=wb.getEnv(),t=x.Image,e=x.Video;return n instanceof t?new Sm(n.naturalWidth,n.naturalHeight):n instanceof e?new Sm(n.videoWidth,n.videoHeight):new Sm(n.width,n.height)}function Ob(n){var x=n.width,t=n.height,e=wb.getEnv().createCanvasElement,i=e();return i.width=x,i.height=t,i}function _b(n,x){var t=wb.getEnv().ImageData;if(!(n instanceof t)&&!Sb(n))throw new Error("createCanvasFromMedia - media has not finished loading yet");var e=x||Db(n),i=e.width,r=e.height,o=Ob({width:i,height:r});return n instanceof t?qb(o).putImageData(n,0,0):qb(o).drawImage(n,0,0,i,r),o}function Tb(n,x){return Cm(this,void 0,void 0,function(){var t,e,i,r,o,s;return Am(this,function(h){switch(h.label){case 0:return t=x||wb.getEnv().createCanvasElement(),e=n.shape.slice(_m(n)?1:0),i=e[0],r=e[1],o=e[2],s=bs(function(){return n.as3D(i,r,o).toInt()}),[4,im.toPixels(s,t)];case 1:return h.sent(),s.dispose(),[2,t]}})})}function Rb(n){var x=wb.getEnv(),t=x.Image,e=x.Canvas,i=x.Video;return n instanceof t||n instanceof e||n instanceof i}function Bb(n,x,t){void 0===t&&(t=!1);var e=wb.getEnv(),i=e.Image,r=e.Canvas;if(!(n instanceof i||n instanceof r))throw new Error("imageToSquare - expected arg0 to be HTMLImageElement | HTMLCanvasElement");var o=Db(n),s=x/Math.max(o.height,o.width),h=s*o.width,u=s*o.height,a=Ob({width:x,height:x}),g=n instanceof r?n:_b(n),l=Math.abs(h-u)/2,c=t&&h<u?l:0,d=t&&u<h?l:0;return qb(a).drawImage(g,c,d,h,u),a}var Mb=function(){function n(n,x){var t=this;if(void 0===x&&(x=!1),this._imageTensors=[],this._canvases=[],this._treatAsBatchInput=!1,this._inputDimensions=[],!Array.isArray(n))throw new Error("NetInput.constructor - expected inputs to be an Array of TResolvedNetInput or to be instanceof tf.Tensor4D, instead have "+n);this._treatAsBatchInput=x,this._batchSize=n.length,n.forEach(function(n,x){if(Om(n))return t._imageTensors[x]=n,void(t._inputDimensions[x]=n.shape);if(_m(n)){var e=n.shape[0];if(1!==e)throw new Error("NetInput - tf.Tensor4D with batchSize "+e+" passed, but not supported in input array");return t._imageTensors[x]=n,void(t._inputDimensions[x]=n.shape.slice(1))}var i=n instanceof wb.getEnv().Canvas?n:_b(n);t._canvases[x]=i,t._inputDimensions[x]=[i.height,i.width,3]})}return Object.defineProperty(n.prototype,"imageTensors",{get:function(){return this._imageTensors},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"canvases",{get:function(){return this._canvases},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"isBatchInput",{get:function(){return this.batchSize>1||this._treatAsBatchInput},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"batchSize",{get:function(){return this._batchSize},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"inputDimensions",{get:function(){return this._inputDimensions},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"inputSize",{get:function(){return this._inputSize},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"reshapedInputDimensions",{get:function(){var n=this;return Pm(this.batchSize,0,1).map(function(x,t){return n.getReshapedInputDimensions(t)})},enumerable:!0,configurable:!0}),n.prototype.getInput=function(n){return this.canvases[n]||this.imageTensors[n]},n.prototype.getInputDimensions=function(n){return this._inputDimensions[n]},n.prototype.getInputHeight=function(n){return this._inputDimensions[n][0]},n.prototype.getInputWidth=function(n){return this._inputDimensions[n][1]},n.prototype.getReshapedInputDimensions=function(n){if("number"!==typeof this.inputSize)throw new Error("getReshapedInputDimensions - inputSize not set, toBatchTensor has not been called yet");var x=this.getInputWidth(n),t=this.getInputHeight(n);return Nm({width:x,height:t},this.inputSize)},n.prototype.toBatchTensor=function(n,x){var t=this;return void 0===x&&(x=!0),this._inputSize=n,bs(function(){var e=Pm(t.batchSize,0,1).map(function(e){var i=t.getInput(e);if(i instanceof Kr){var r=_m(i)?i:i.expandDims();return r=Zm(r,x),r.shape[1]===n&&r.shape[2]===n||(r=Tp.resizeBilinear(r,[n,n])),r.as3D(n,n,3)}if(i instanceof wb.getEnv().Canvas)return im.fromPixels(Bb(i,n,x));throw new Error("toBatchTensor - at batchIdx "+e+", expected input to be instanceof tf.Tensor or instanceof HTMLCanvasElement, instead have "+i)}),i=Qh(e.map(function(n){return n.toFloat()})).as4D(t.batchSize,n,n,3);return i})},n}();function Nb(n){return Cm(this,void 0,void 0,function(){var x,t,e;return Am(this,function(i){switch(i.label){case 0:if(n instanceof Mb)return[2,n];if(x=Array.isArray(n)?n:[n],!x.length)throw new Error("toNetInput - empty array passed as input");return t=function(x){return Array.isArray(n)?" at input index "+x+":":""},e=x.map(kb),e.forEach(function(n,e){if(!Rb(n)&&!Om(n)&&!_m(n)){if("string"===typeof x[e])throw new Error("toNetInput -"+t(e)+" string passed, but could not resolve HTMLElement for element id "+x[e]);throw new Error("toNetInput -"+t(e)+" expected media to be of type HTMLImageElement | HTMLVideoElement | HTMLCanvasElement | tf.Tensor3D, or to be an element id")}if(_m(n)){var i=n.shape[0];if(1!==i)throw new Error("toNetInput -"+t(e)+" tf.Tensor4D with batchSize "+i+" passed, but not supported in input array")}}),[4,Promise.all(e.map(function(n){return Rb(n)&&Ib(n)}))];case 1:return i.sent(),[2,new Mb(e,Array.isArray(n))]}})})}function Fb(n,x){return Cm(this,void 0,void 0,function(){var t,e,i,r,o,s,h;return Am(this,function(u){switch(u.label){case 0:return t=wb.getEnv().Canvas,e=n,n instanceof t?[3,5]:[4,Nb(n)];case 1:if(i=u.sent(),i.batchSize>1)throw new Error("extractFaces - batchSize > 1 not supported");return r=i.getInput(0),r instanceof t?(o=r,[3,4]):[3,2];case 2:return[4,Tb(r)];case 3:o=u.sent(),u.label=4;case 4:e=o,u.label=5;case 5:return s=qb(e),h=x.map(function(n){return n instanceof Gm?n.forSize(e.width,e.height).box.floor():n}).map(function(n){return n.clipAtImageBorders(e.width,e.height)}),[2,h.map(function(n){var x=n.x,t=n.y,e=n.width,i=n.height,r=Ob({width:e,height:i});return qb(r).putImageData(s.getImageData(x,t,e,i),0,0),r})]}})})}function Pb(n,x){return Cm(this,void 0,void 0,function(){return Am(this,function(t){if(!Om(n)&&!_m(n))throw new Error("extractFaceTensors - expected image tensor to be 3D or 4D");if(_m(n)&&n.shape[0]>1)throw new Error("extractFaceTensors - batchSize > 1 not supported");return[2,bs(function(){var t=n.shape.slice(_m(n)?1:0),e=t[0],i=t[1],r=t[2],o=x.map(function(n){return n instanceof Gm?n.forSize(i,e).box:n}).map(function(n){return n.clipAtImageBorders(i,e)}),s=o.map(function(x){var t=x.x,o=x.y,s=x.width,h=x.height;return bf(n.as3D(e,i,r),[o,t,0],[h,s,r])});return s})]})})}function Lb(n,x){return Cm(this,void 0,void 0,function(){var t,e;return Am(this,function(i){switch(i.label){case 0:return t=wb.getEnv().fetch,[4,t(n,x)];case 1:if(e=i.sent(),!(e.status<400))throw new Error("failed to fetch: ("+e.status+") "+e.statusText+", from url: "+e.url);return[2,e]}})})}function Hb(n){return Cm(this,void 0,void 0,function(){return Am(this,function(x){switch(x.label){case 0:return[4,Lb(n)];case 1:return[2,x.sent().json()]}})})}function Ub(n,x){var t=x+"-weights_manifest.json";if(!n)return{modelBaseUri:"",manifestUri:t};if("/"===n)return{modelBaseUri:"/",manifestUri:"/"+t};var e=n.startsWith("http://")?"http://":n.startsWith("https://")?"https://":"";n=n.replace(e,"");var i=n.split("/").filter(function(n){return n}),r=n.endsWith(".json")?i[i.length-1]:t,o=e+(n.endsWith(".json")?i.slice(0,i.length-1):i).join("/");return o=n.startsWith("/")?"/"+o:o,{modelBaseUri:o,manifestUri:"/"===o?"/"+r:o+"/"+r}}function Vb(n,x){return Cm(this,void 0,void 0,function(){var t,e,i,r;return Am(this,function(o){switch(o.label){case 0:return t=Ub(n,x),e=t.manifestUri,i=t.modelBaseUri,[4,Hb(e)];case 1:return r=o.sent(),[2,xm.loadWeights(r,i)]}})})}var Wb=function(){function n(n){this._name=n,this._params=void 0,this._paramMappings=[]}return Object.defineProperty(n.prototype,"params",{get:function(){return this._params},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"paramMappings",{get:function(){return this._paramMappings},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"isLoaded",{get:function(){return!!this.params},enumerable:!0,configurable:!0}),n.prototype.getParamFromPath=function(n){var x=this.traversePropertyPath(n),t=x.obj,e=x.objProp;return t[e]},n.prototype.reassignParamFromPath=function(n,x){var t=this.traversePropertyPath(n),e=t.obj,i=t.objProp;e[i].dispose(),e[i]=x},n.prototype.getParamList=function(){var n=this;return this._paramMappings.map(function(x){var t=x.paramPath;return{path:t,tensor:n.getParamFromPath(t)}})},n.prototype.getTrainableParams=function(){return this.getParamList().filter(function(n){return n.tensor instanceof no})},n.prototype.getFrozenParams=function(){return this.getParamList().filter(function(n){return!(n.tensor instanceof no)})},n.prototype.variable=function(){var n=this;this.getFrozenParams().forEach(function(x){var t=x.path,e=x.tensor;n.reassignParamFromPath(t,e.variable())})},n.prototype.freeze=function(){var n=this;this.getTrainableParams().forEach(function(x){var t=x.path,e=x.tensor,i=Ls(e.dataSync());e.dispose(),n.reassignParamFromPath(t,i)})},n.prototype.dispose=function(n){void 0===n&&(n=!0),this.getParamList().forEach(function(x){if(n&&x.tensor.isDisposed)throw new Error("param tensor has already been disposed for path "+x.path);x.tensor.dispose()}),this._params=void 0},n.prototype.serializeParams=function(){return new Float32Array(this.getParamList().map(function(n){var x=n.tensor;return Array.from(x.dataSync())}).reduce(function(n,x){return n.concat(x)}))},n.prototype.load=function(n){return Cm(this,void 0,void 0,function(){return Am(this,function(x){switch(x.label){case 0:return n instanceof Float32Array?(this.extractWeights(n),[2]):[4,this.loadFromUri(n)];case 1:return x.sent(),[2]}})})},n.prototype.loadFromUri=function(n){return Cm(this,void 0,void 0,function(){var x;return Am(this,function(t){switch(t.label){case 0:if(n&&"string"!==typeof n)throw new Error(this._name+".loadFromUri - expected model uri");return[4,Vb(n,this.getDefaultModelName())];case 1:return x=t.sent(),this.loadFromWeightMap(x),[2]}})})},n.prototype.loadFromDisk=function(n){return Cm(this,void 0,void 0,function(){var x,t,e,i,r,o,s,h,u,a;return Am(this,function(g){switch(g.label){case 0:if(n&&"string"!==typeof n)throw new Error(this._name+".loadFromDisk - expected model file path");return x=wb.getEnv().readFile,t=Ub(n,this.getDefaultModelName()),e=t.manifestUri,i=t.modelBaseUri,r=function(n){return Promise.all(n.map(function(n){return x(n).then(function(n){return n.buffer})}))},o=xm.weightsLoaderFactory(r),u=(h=JSON).parse,[4,x(e)];case 1:return s=u.apply(h,[g.sent().toString()]),[4,o(s,i)];case 2:return a=g.sent(),this.loadFromWeightMap(a),[2]}})})},n.prototype.loadFromWeightMap=function(n){var x=this.extractParamsFromWeigthMap(n),t=x.paramMappings,e=x.params;this._paramMappings=t,this._params=e},n.prototype.extractWeights=function(n){var x=this.extractParams(n),t=x.paramMappings,e=x.params;this._paramMappings=t,this._params=e},n.prototype.traversePropertyPath=function(n){if(!this.params)throw new Error("traversePropertyPath - model has no loaded params");var x=n.split("/").reduce(function(x,t){if(!x.nextObj.hasOwnProperty(t))throw new Error("traversePropertyPath - object does not have property "+t+", for path "+n);return{obj:x.nextObj,objProp:t,nextObj:x.nextObj[t]}},{nextObj:this.params}),t=x.obj,e=x.objProp;if(!t||!e||!(t[e]instanceof Kr))throw new Error("traversePropertyPath - parameter is not a tensor, for path "+n);return{obj:t,objProp:e}},n}();function Qb(n,x,t){return bs(function(){var e=Xd(n,x.depthwise_filter,x.pointwise_filter,t,"same");return e=td(e,x.bias),e})}function Gb(n,x,t){return void 0===t&&(t=!1),bs(function(){var e=Bf(t?td(Vd(n,x.conv0.filters,[2,2],"same"),x.conv0.bias):Qb(n,x.conv0,[2,2])),i=Qb(e,x.conv1,[1,1]),r=Bf(td(e,i)),o=Qb(r,x.conv2,[1,1]);return Bf(td(e,td(i,o)))})}function Kb(n,x,t,e){return void 0===t&&(t=!1),void 0===e&&(e=!0),bs(function(){var i=Bf(t?td(Vd(n,x.conv0.filters,e?[2,2]:[1,1],"same"),x.conv0.bias):Qb(n,x.conv0,e?[2,2]:[1,1])),r=Qb(i,x.conv1,[1,1]),o=Bf(td(i,r)),s=Qb(o,x.conv2,[1,1]),h=Bf(td(i,td(r,s))),u=Qb(h,x.conv3,[1,1]);return Bf(td(i,td(r,td(s,u))))})}function Yb(n,x,t,e){return void 0===t&&(t="same"),void 0===e&&(e=!1),bs(function(){var i=td(Vd(n,x.filters,[1,1],t),x.bias);return e?Bf(i):i})}function Jb(n,x){Object.keys(n).forEach(function(t){x.some(function(n){return n.originalPath===t})||n[t].dispose()})}function Xb(n,x){return function(t,e,i,r){var o=Gs(n(t*e*i*i),[i,i,t,e]),s=Vs(n(e));return x.push({paramPath:r+"/filters"},{paramPath:r+"/bias"}),{filters:o,bias:s}}}function Zb(n,x){return function(t,e,i){var r=Ws(n(t*e),[t,e]),o=Vs(n(e));return x.push({paramPath:i+"/weights"},{paramPath:i+"/bias"}),{weights:r,bias:o}}}var $b=function(){function n(n,x,t){this.depthwise_filter=n,this.pointwise_filter=x,this.bias=t}return n}();function nz(n,x){return function(t,e,i){var r=Gs(n(9*t),[3,3,t,1]),o=Gs(n(t*e),[1,1,t,e]),s=Vs(n(e));return x.push({paramPath:i+"/depthwise_filter"},{paramPath:i+"/pointwise_filter"},{paramPath:i+"/bias"}),new $b(r,o,s)}}function xz(n){return function(x){var t=n(x+"/depthwise_filter",4),e=n(x+"/pointwise_filter",4),i=n(x+"/bias",1);return new $b(t,e,i)}}function tz(n,x){return function(t,e,i){var r=n[t];if(!Im(r,e))throw new Error("expected weightMap["+t+"] to be a Tensor"+e+"D, instead have "+r);return x.push({originalPath:t,paramPath:i||t}),r}}function ez(n){var x=n;function t(n){var t=x.slice(0,n);return x=x.slice(n),t}function e(){return x}return{extractWeights:t,getRemainingWeights:e}}function iz(n,x){var t=Xb(n,x),e=nz(n,x);function i(n,x,i,r){void 0===r&&(r=!1);var o=r?t(n,x,3,i+"/conv0"):e(n,x,i+"/conv0"),s=e(x,x,i+"/conv1"),h=e(x,x,i+"/conv2");return{conv0:o,conv1:s,conv2:h}}function r(n,x,t,r){void 0===r&&(r=!1);var o=i(n,x,t,r),s=o.conv0,h=o.conv1,u=o.conv2,a=e(x,x,t+"/conv3");return{conv0:s,conv1:h,conv2:u,conv3:a}}return{extractDenseBlock3Params:i,extractDenseBlock4Params:r}}function rz(n){var x=[],t=ez(n),e=t.extractWeights,i=t.getRemainingWeights,r=iz(e,x).extractDenseBlock4Params,o=r(3,32,"dense0",!0),s=r(32,64,"dense1"),h=r(64,128,"dense2"),u=r(128,256,"dense3");if(0!==i().length)throw new Error("weights remaing after extract: "+i().length);return{paramMappings:x,params:{dense0:o,dense1:s,dense2:h,dense3:u}}}function oz(n){return function(x){var t=n(x+"/filters",4),e=n(x+"/bias",1);return{filters:t,bias:e}}}function sz(n,x){var t=tz(n,x),e=oz(t),i=xz(t);function r(n,x){void 0===x&&(x=!1);var t=x?e(n+"/conv0"):i(n+"/conv0"),r=i(n+"/conv1"),o=i(n+"/conv2");return{conv0:t,conv1:r,conv2:o}}function o(n,x){void 0===x&&(x=!1);var t=x?e(n+"/conv0"):i(n+"/conv0"),r=i(n+"/conv1"),o=i(n+"/conv2"),s=i(n+"/conv3");return{conv0:t,conv1:r,conv2:o,conv3:s}}return{extractDenseBlock3Params:r,extractDenseBlock4Params:o}}function hz(n){var x=[],t=sz(n,x).extractDenseBlock4Params,e={dense0:t("dense0",!0),dense1:t("dense1"),dense2:t("dense2"),dense3:t("dense3")};return Jb(n,x),{params:e,paramMappings:x}}var uz=function(n){function x(){return n.call(this,"FaceFeatureExtractor")||this}return km(x,n),x.prototype.forwardInput=function(n){var x=this.params;if(!x)throw new Error("FaceFeatureExtractor - load model before inference");return bs(function(){var t=n.toBatchTensor(112,!0),e=[122.782,117.001,104.298],i=Xm(t,e).div(Us(255)),r=Kb(i,x.dense0,!0);return r=Kb(r,x.dense1),r=Kb(r,x.dense2),r=Kb(r,x.dense3),r=lf(r,[7,7],[2,2],"valid"),r})},x.prototype.forward=function(n){return Cm(this,void 0,void 0,function(){var x;return Am(this,function(t){switch(t.label){case 0:return x=this.forwardInput,[4,Nb(n)];case 1:return[2,x.apply(this,[t.sent()])]}})})},x.prototype.getDefaultModelName=function(){return"face_feature_extractor_model"},x.prototype.extractParamsFromWeigthMap=function(n){return hz(n)},x.prototype.extractParams=function(n){return rz(n)},x}(Wb);function az(n,x){return bs(function(){return td(nf(n,x.weights),x.bias)})}function gz(n,x,t){var e=[],i=ez(n),r=i.extractWeights,o=i.getRemainingWeights,s=Zb(r,e),h=s(x,t,"fc");if(0!==o().length)throw new Error("weights remaing after extract: "+o().length);return{paramMappings:e,params:{fc:h}}}function lz(n){var x=[],t=tz(n,x);function e(n){var x=t(n+"/weights",2),e=t(n+"/bias",1);return{weights:x,bias:e}}var i={fc:e("fc")};return Jb(n,x),{params:i,paramMappings:x}}function cz(n){var x={},t={};return Object.keys(n).forEach(function(e){var i=e.startsWith("fc")?t:x;i[e]=n[e]}),{featureExtractorMap:x,classifierMap:t}}var dz=function(n){function x(x,t){var e=n.call(this,x)||this;return e._faceFeatureExtractor=t,e}return km(x,n),Object.defineProperty(x.prototype,"faceFeatureExtractor",{get:function(){return this._faceFeatureExtractor},enumerable:!0,configurable:!0}),x.prototype.runNet=function(n){var x=this,t=this.params;if(!t)throw new Error(this._name+" - load model before inference");return bs(function(){var e=n instanceof Mb?x.faceFeatureExtractor.forwardInput(n):n;return az(e.as2D(e.shape[0],-1),t.fc)})},x.prototype.dispose=function(x){void 0===x&&(x=!0),this.faceFeatureExtractor.dispose(x),n.prototype.dispose.call(this,x)},x.prototype.loadClassifierParams=function(n){var x=this.extractClassifierParams(n),t=x.params,e=x.paramMappings;this._params=t,this._paramMappings=e},x.prototype.extractClassifierParams=function(n){return gz(n,this.getClassifierChannelsIn(),this.getClassifierChannelsOut())},x.prototype.extractParamsFromWeigthMap=function(n){var x=cz(n),t=x.featureExtractorMap,e=x.classifierMap;return this.faceFeatureExtractor.loadFromWeightMap(t),lz(e)},x.prototype.extractParams=function(n){var x=this.getClassifierChannelsIn(),t=this.getClassifierChannelsOut(),e=t*x+t,i=n.slice(0,n.length-e),r=n.slice(n.length-e);return this.faceFeatureExtractor.extractWeights(i),this.extractClassifierParams(r)},x}(Wb),fz=["neutral","happy","sad","angry","fearful","disgusted","surprised"],pz=function(){function n(n){var x=this;if(7!==n.length)throw new Error("FaceExpressions.constructor - expected probabilities.length to be 7, have: "+n.length);fz.forEach(function(t,e){x[t]=n[e]})}return n.prototype.asSortedArray=function(){var n=this;return fz.map(function(x){return{expression:x,probability:n[x]}}).sort(function(n,x){return x.probability-n.probability})},n}(),yz=function(n){function x(x){return void 0===x&&(x=new uz),n.call(this,"FaceExpressionNet",x)||this}return km(x,n),x.prototype.forwardInput=function(n){var x=this;return bs(function(){return yu(x.runNet(n))})},x.prototype.forward=function(n){return Cm(this,void 0,void 0,function(){var x;return Am(this,function(t){switch(t.label){case 0:return x=this.forwardInput,[4,Nb(n)];case 1:return[2,x.apply(this,[t.sent()])]}})})},x.prototype.predictExpressions=function(n){return Cm(this,void 0,void 0,function(){var x,t,e,i,r=this;return Am(this,function(o){switch(o.label){case 0:return[4,Nb(n)];case 1:return x=o.sent(),[4,this.forwardInput(x)];case 2:return t=o.sent(),[4,Promise.all(Yh(t).map(function(n){return Cm(r,void 0,void 0,function(){var x;return Am(this,function(t){switch(t.label){case 0:return[4,n.data()];case 1:return x=t.sent(),n.dispose(),[2,x]}})})}))];case 3:return e=o.sent(),t.dispose(),i=e.map(function(n){return new pz(n)}),[2,x.isBatchInput?i:i[0]]}})})},x.prototype.getDefaultModelName=function(){return"face_expression_model"},x.prototype.getClassifierChannelsIn=function(){return 256},x.prototype.getClassifierChannelsOut=function(){return 7},x}(dz);function mz(n,x){var t={expressions:x};return Object.assign({},n,t)}function bz(n){return gb(n)&&n["landmarks"]instanceof rb&&n["unshiftedLandmarks"]instanceof rb&&n["alignedRect"]instanceof Gm}function zz(n,x){var t=n.detection.box,e=x.shiftBy(t.x,t.y),i=e.align(),r=n.detection.imageDims,o=new Gm(n.detection.score,i.rescale(r.reverse()),r),s={landmarks:e,unshiftedLandmarks:x,alignedRect:o};return Object.assign({},n,s)}var vz=function(){function n(n){void 0===n&&(n={});var x=n.drawLines,t=void 0===x||x,e=n.drawPoints,i=void 0===e||e,r=n.lineWidth,o=n.lineColor,s=n.pointSize,h=n.pointColor;this.drawLines=t,this.drawPoints=i,this.lineWidth=r||1,this.pointSize=s||2,this.lineColor=o||"rgba(0, 255, 255, 1)",this.pointColor=h||"rgba(255, 0, 255, 1)"}return n}();(function(){function n(n,x){void 0===x&&(x={}),this.faceLandmarks=n,this.options=new vz(x)}n.prototype.draw=function(n){var x=qb(n),t=this.options,e=t.drawLines,i=t.drawPoints,r=t.lineWidth,o=t.lineColor,s=t.pointSize,h=t.pointColor;if(e&&this.faceLandmarks instanceof sb&&(x.strokeStyle=o,x.lineWidth=r,jm(x,this.faceLandmarks.getJawOutline()),jm(x,this.faceLandmarks.getLeftEyeBrow()),jm(x,this.faceLandmarks.getRightEyeBrow()),jm(x,this.faceLandmarks.getNose()),jm(x,this.faceLandmarks.getLeftEye(),!0),jm(x,this.faceLandmarks.getRightEye(),!0),jm(x,this.faceLandmarks.getMouth(),!0)),i){x.strokeStyle=h,x.fillStyle=h;var u=function(n){x.beginPath(),x.arc(n.x,n.y,s,0,2*Math.PI),x.fill()};this.faceLandmarks.positions.forEach(u)}}})();function jz(n,x){var t=Xb(n,x),e=nz(n,x);function i(n,x,i){var r=e(n,x,i+"/separable_conv0"),o=e(x,x,i+"/separable_conv1"),s=t(n,x,1,i+"/expansion_conv");return{separable_conv0:r,separable_conv1:o,expansion_conv:s}}function r(n,x){var t=e(n,n,x+"/separable_conv0"),i=e(n,n,x+"/separable_conv1"),r=e(n,n,x+"/separable_conv2");return{separable_conv0:t,separable_conv1:i,separable_conv2:r}}return{extractConvParams:t,extractSeparableConvParams:e,extractReductionBlockParams:i,extractMainBlockParams:r}}function wz(n,x){var t=[],e=ez(n),i=e.extractWeights,r=e.getRemainingWeights,o=jz(i,t),s=o.extractConvParams,h=o.extractSeparableConvParams,u=o.extractReductionBlockParams,a=o.extractMainBlockParams,g=s(3,32,3,"entry_flow/conv_in"),l=u(32,64,"entry_flow/reduction_block_0"),c=u(64,128,"entry_flow/reduction_block_1"),d={conv_in:g,reduction_block_0:l,reduction_block_1:c},f={};Pm(x,0,1).forEach(function(n){f["main_block_"+n]=a(128,"middle_flow/main_block_"+n)});var p=u(128,256,"exit_flow/reduction_block"),y=h(256,512,"exit_flow/separable_conv"),m={reduction_block:p,separable_conv:y};if(0!==r().length)throw new Error("weights remaing after extract: "+r().length);return{paramMappings:t,params:{entry_flow:d,middle_flow:f,exit_flow:m}}}function kz(n,x){var t=tz(n,x),e=oz(t),i=xz(t);function r(n){var x=i(n+"/separable_conv0"),t=i(n+"/separable_conv1"),r=e(n+"/expansion_conv");return{separable_conv0:x,separable_conv1:t,expansion_conv:r}}function o(n){var x=i(n+"/separable_conv0"),t=i(n+"/separable_conv1"),e=i(n+"/separable_conv2");return{separable_conv0:x,separable_conv1:t,separable_conv2:e}}return{extractConvParams:e,extractSeparableConvParams:i,extractReductionBlockParams:r,extractMainBlockParams:o}}function qz(n,x){var t=[],e=kz(n,t),i=e.extractConvParams,r=e.extractSeparableConvParams,o=e.extractReductionBlockParams,s=e.extractMainBlockParams,h=i("entry_flow/conv_in"),u=o("entry_flow/reduction_block_0"),a=o("entry_flow/reduction_block_1"),g={conv_in:h,reduction_block_0:u,reduction_block_1:a},l={};Pm(x,0,1).forEach(function(n){l["main_block_"+n]=s("middle_flow/main_block_"+n)});var c=o("exit_flow/reduction_block"),d=r("exit_flow/separable_conv"),f={reduction_block:c,separable_conv:d};return Jb(n,t),{params:{entry_flow:g,middle_flow:l,exit_flow:f},paramMappings:t}}function Cz(n,x,t){return td(Vd(n,x.filters,t,"same"),x.bias)}function Az(n,x,t){void 0===t&&(t=!0);var e=t?Bf(n):n;return e=Qb(e,x.separable_conv0,[1,1]),e=Qb(Bf(e),x.separable_conv1,[1,1]),e=gf(e,[3,3],[2,2],"same"),e=td(e,Cz(n,x.expansion_conv,[2,2])),e}function Ez(n,x){var t=Qb(Bf(n),x.separable_conv0,[1,1]);return t=Qb(Bf(t),x.separable_conv1,[1,1]),t=Qb(Bf(t),x.separable_conv2,[1,1]),t=td(t,n),t}var Sz,Iz=function(n){function x(x){var t=n.call(this,"TinyXception")||this;return t._numMainBlocks=x,t}return km(x,n),x.prototype.forwardInput=function(n){var x=this,t=this.params;if(!t)throw new Error("TinyXception - load model before inference");return bs(function(){var e=n.toBatchTensor(112,!0),i=[122.782,117.001,104.298],r=Xm(e,i).div(Us(256)),o=Bf(Cz(r,t.entry_flow.conv_in,[2,2]));return o=Az(o,t.entry_flow.reduction_block_0,!1),o=Az(o,t.entry_flow.reduction_block_1),Pm(x._numMainBlocks,0,1).forEach(function(n){o=Ez(o,t.middle_flow["main_block_"+n])}),o=Az(o,t.exit_flow.reduction_block),o=Bf(Qb(o,t.exit_flow.separable_conv,[1,1])),o})},x.prototype.forward=function(n){return Cm(this,void 0,void 0,function(){var x;return Am(this,function(t){switch(t.label){case 0:return x=this.forwardInput,[4,Nb(n)];case 1:return[2,x.apply(this,[t.sent()])]}})})},x.prototype.getDefaultModelName=function(){return"tiny_xception_model"},x.prototype.extractParamsFromWeigthMap=function(n){return qz(n,this._numMainBlocks)},x.prototype.extractParams=function(n){return wz(n,this._numMainBlocks)},x}(Wb);function Dz(n){var x=[],t=ez(n),e=t.extractWeights,i=t.getRemainingWeights,r=Zb(e,x),o=r(512,1,"fc/age"),s=r(512,2,"fc/gender");if(0!==i().length)throw new Error("weights remaing after extract: "+i().length);return{paramMappings:x,params:{fc:{age:o,gender:s}}}}function Oz(n){var x=[],t=tz(n,x);function e(n){var x=t(n+"/weights",2),e=t(n+"/bias",1);return{weights:x,bias:e}}var i={fc:{age:e("fc/age"),gender:e("fc/gender")}};return Jb(n,x),{params:i,paramMappings:x}}(function(n){n["FEMALE"]="female",n["MALE"]="male"})(Sz||(Sz={}));var _z=function(n){function x(x){void 0===x&&(x=new Iz(2));var t=n.call(this,"AgeGenderNet")||this;return t._faceFeatureExtractor=x,t}return km(x,n),Object.defineProperty(x.prototype,"faceFeatureExtractor",{get:function(){return this._faceFeatureExtractor},enumerable:!0,configurable:!0}),x.prototype.runNet=function(n){var x=this,t=this.params;if(!t)throw new Error(this._name+" - load model before inference");return bs(function(){var e=n instanceof Mb?x.faceFeatureExtractor.forwardInput(n):n,i=lf(e,[7,7],[2,2],"valid").as2D(e.shape[0],-1),r=az(i,t.fc.age).as1D(),o=az(i,t.fc.gender);return{age:r,gender:o}})},x.prototype.forwardInput=function(n){var x=this;return bs(function(){var t=x.runNet(n),e=t.age,i=t.gender;return{age:e,gender:yu(i)}})},x.prototype.forward=function(n){return Cm(this,void 0,void 0,function(){var x;return Am(this,function(t){switch(t.label){case 0:return x=this.forwardInput,[4,Nb(n)];case 1:return[2,x.apply(this,[t.sent()])]}})})},x.prototype.predictAgeAndGender=function(n){return Cm(this,void 0,void 0,function(){var x,t,e,i,r,o,s=this;return Am(this,function(h){switch(h.label){case 0:return[4,Nb(n)];case 1:return x=h.sent(),[4,this.forwardInput(x)];case 2:return t=h.sent(),e=Yh(t.age),i=Yh(t.gender),r=e.map(function(n,x){return{ageTensor:n,genderTensor:i[x]}}),[4,Promise.all(r.map(function(n){var x=n.ageTensor,t=n.genderTensor;return Cm(s,void 0,void 0,function(){var n,e,i,r,o;return Am(this,function(s){switch(s.label){case 0:return[4,x.data()];case 1:return n=s.sent()[0],[4,t.data()];case 2:return e=s.sent()[0],i=e>.5,r=i?Sz.MALE:Sz.FEMALE,o=i?e:1-e,x.dispose(),t.dispose(),[2,{age:n,gender:r,genderProbability:o}]}})})}))];case 3:return o=h.sent(),t.age.dispose(),t.gender.dispose(),[2,x.isBatchInput?o:o[0]]}})})},x.prototype.getDefaultModelName=function(){return"age_gender_model"},x.prototype.dispose=function(x){void 0===x&&(x=!0),this.faceFeatureExtractor.dispose(x),n.prototype.dispose.call(this,x)},x.prototype.loadClassifierParams=function(n){var x=this.extractClassifierParams(n),t=x.params,e=x.paramMappings;this._params=t,this._paramMappings=e},x.prototype.extractClassifierParams=function(n){return Dz(n)},x.prototype.extractParamsFromWeigthMap=function(n){var x=cz(n),t=x.featureExtractorMap,e=x.classifierMap;return this.faceFeatureExtractor.loadFromWeightMap(t),Oz(e)},x.prototype.extractParams=function(n){var x=1539,t=n.slice(0,n.length-x),e=n.slice(n.length-x);return this.faceFeatureExtractor.extractWeights(t),this.extractClassifierParams(e)},x}(Wb),Tz=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.postProcess=function(n,x,t){var e=t.map(function(n){var t=n.width,e=n.height,i=x/Math.max(e,t);return{width:t*i,height:e*i}}),i=e.length;return bs(function(){var t=function(n,x){return Qh([$s([68],n),$s([68],x)],1).as2D(1,136).as1D()},r=function(n,x){var t=e[n],i=t.width,r=t.height;return x(i,r)?Math.abs(i-r)/2:0},o=function(n){return r(n,function(n,x){return n<x})},s=function(n){return r(n,function(n,x){return x<n})},h=n.mul($s([i,136],x)).sub(Qh(Array.from(Array(i),function(n,x){return t(o(x),s(x))}))).div(Qh(Array.from(Array(i),function(n,x){return t(e[x].width,e[x].height)})));return h})},x.prototype.forwardInput=function(n){var x=this;return bs(function(){var t=x.runNet(n);return x.postProcess(t,n.inputSize,n.inputDimensions.map(function(n){var x=n[0],t=n[1];return{height:x,width:t}}))})},x.prototype.forward=function(n){return Cm(this,void 0,void 0,function(){var x;return Am(this,function(t){switch(t.label){case 0:return x=this.forwardInput,[4,Nb(n)];case 1:return[2,x.apply(this,[t.sent()])]}})})},x.prototype.detectLandmarks=function(n){return Cm(this,void 0,void 0,function(){var x,t,e,i=this;return Am(this,function(r){switch(r.label){case 0:return[4,Nb(n)];case 1:return x=r.sent(),t=bs(function(){return Yh(i.forwardInput(x))}),[4,Promise.all(t.map(function(n,t){return Cm(i,void 0,void 0,function(){var e,i,r,o,s;return Am(this,function(h){switch(h.label){case 0:return r=(i=Array).from,[4,n.data()];case 1:return e=r.apply(i,[h.sent()]),o=e.filter(function(n,x){return Rm(x)}),s=e.filter(function(n,x){return!Rm(x)}),[2,new sb(Array(68).fill(0).map(function(n,x){return new Um(o[x],s[x])}),{height:x.getInputHeight(t),width:x.getInputWidth(t)})]}})})}))];case 2:return e=r.sent(),t.forEach(function(n){return n.dispose()}),[2,x.isBatchInput?e:e[0]]}})})},x.prototype.getClassifierChannelsOut=function(){return 136},x}(dz),Rz=function(n){function x(x){return void 0===x&&(x=new uz),n.call(this,"FaceLandmark68Net",x)||this}return km(x,n),x.prototype.getDefaultModelName=function(){return"face_landmark_68_model"},x.prototype.getClassifierChannelsIn=function(){return 256},x}(Tz);function Bz(n){var x=[],t=sz(n,x).extractDenseBlock3Params,e={dense0:t("dense0",!0),dense1:t("dense1"),dense2:t("dense2")};return Jb(n,x),{params:e,paramMappings:x}}function Mz(n){var x=[],t=ez(n),e=t.extractWeights,i=t.getRemainingWeights,r=iz(e,x).extractDenseBlock3Params,o=r(3,32,"dense0",!0),s=r(32,64,"dense1"),h=r(64,128,"dense2");if(0!==i().length)throw new Error("weights remaing after extract: "+i().length);return{paramMappings:x,params:{dense0:o,dense1:s,dense2:h}}}var Nz=function(n){function x(){return n.call(this,"TinyFaceFeatureExtractor")||this}return km(x,n),x.prototype.forwardInput=function(n){var x=this.params;if(!x)throw new Error("TinyFaceFeatureExtractor - load model before inference");return bs(function(){var t=n.toBatchTensor(112,!0),e=[122.782,117.001,104.298],i=Xm(t,e).div(Us(255)),r=Gb(i,x.dense0,!0);return r=Gb(r,x.dense1),r=Gb(r,x.dense2),r=lf(r,[14,14],[2,2],"valid"),r})},x.prototype.forward=function(n){return Cm(this,void 0,void 0,function(){var x;return Am(this,function(t){switch(t.label){case 0:return x=this.forwardInput,[4,Nb(n)];case 1:return[2,x.apply(this,[t.sent()])]}})})},x.prototype.getDefaultModelName=function(){return"face_feature_extractor_tiny_model"},x.prototype.extractParamsFromWeigthMap=function(n){return Bz(n)},x.prototype.extractParams=function(n){return Mz(n)},x}(Wb),Fz=function(n){function x(x){return void 0===x&&(x=new Nz),n.call(this,"FaceLandmark68TinyNet",x)||this}return km(x,n),x.prototype.getDefaultModelName=function(){return"face_landmark_68_tiny_model"},x.prototype.getClassifierChannelsIn=function(){return 128},x}(Tz);(function(n){function x(){return null!==n&&n.apply(this,arguments)||this}km(x,n)})(Rz);function Pz(n,x){return td(pd(n,x.weights),x.biases)}function Lz(n,x,t,e,i){void 0===i&&(i="same");var r=x.conv,o=r.filters,s=r.bias,h=Vd(n,o,t,i);return h=td(h,s),h=Pz(h,x.scale),e?Bf(h):h}function Hz(n,x){return Lz(n,x,[1,1],!0)}function Uz(n,x){return Lz(n,x,[1,1],!1)}function Vz(n,x){return Lz(n,x,[2,2],!0,"valid")}function Wz(n,x){function t(x,t,e){var i=n(x),r=i.length/(t*e*e);if(Tm(r))throw new Error("depth has to be an integer: "+r+", weights.length: "+i.length+", numFilters: "+t+", filterSize: "+e);return bs(function(){return Ff(Gs(i,[t,r,e,e]),[2,3,1,0])})}function e(e,i,r,o){var s=t(e,i,r),h=Vs(n(i));return x.push({paramPath:o+"/filters"},{paramPath:o+"/bias"}),{filters:s,bias:h}}function i(t,e){var i=Vs(n(t)),r=Vs(n(t));return x.push({paramPath:e+"/weights"},{paramPath:e+"/biases"}),{weights:i,biases:r}}function r(n,x,t,r){var o=e(n,x,t,r+"/conv"),s=i(x,r+"/scale");return{conv:o,scale:s}}function o(n,x,t,e,i){void 0===i&&(i=!1);var o=r((i?.5:1)*n,x,t,e+"/conv1"),s=r(n,x,t,e+"/conv2");return{conv1:o,conv2:s}}return{extractConvLayerParams:r,extractResidualLayerParams:o}}function Qz(n){var x=ez(n),t=x.extractWeights,e=x.getRemainingWeights,i=[],r=Wz(t,i),o=r.extractConvLayerParams,s=r.extractResidualLayerParams,h=o(4704,32,7,"conv32_down"),u=s(9216,32,3,"conv32_1"),a=s(9216,32,3,"conv32_2"),g=s(9216,32,3,"conv32_3"),l=s(36864,64,3,"conv64_down",!0),c=s(36864,64,3,"conv64_1"),d=s(36864,64,3,"conv64_2"),f=s(36864,64,3,"conv64_3"),p=s(147456,128,3,"conv128_down",!0),y=s(147456,128,3,"conv128_1"),m=s(147456,128,3,"conv128_2"),b=s(589824,256,3,"conv256_down",!0),z=s(589824,256,3,"conv256_1"),v=s(589824,256,3,"conv256_2"),j=s(589824,256,3,"conv256_down_out"),w=bs(function(){return Ff(Ws(t(32768),[128,256]),[1,0])});if(i.push({paramPath:"fc"}),0!==e().length)throw new Error("weights remaing after extract: "+e().length);var k={conv32_down:h,conv32_1:u,conv32_2:a,conv32_3:g,conv64_down:l,conv64_1:c,conv64_2:d,conv64_3:f,conv128_down:p,conv128_1:y,conv128_2:m,conv256_down:b,conv256_1:z,conv256_2:v,conv256_down_out:j,fc:w};return{params:k,paramMappings:i}}function Gz(n,x){var t=tz(n,x);function e(n){var x=t(n+"/scale/weights",1),e=t(n+"/scale/biases",1);return{weights:x,biases:e}}function i(n){var x=t(n+"/conv/filters",4),i=t(n+"/conv/bias",1),r=e(n);return{conv:{filters:x,bias:i},scale:r}}function r(n){return{conv1:i(n+"/conv1"),conv2:i(n+"/conv2")}}return{extractConvLayerParams:i,extractResidualLayerParams:r}}function Kz(n){var x=[],t=Gz(n,x),e=t.extractConvLayerParams,i=t.extractResidualLayerParams,r=e("conv32_down"),o=i("conv32_1"),s=i("conv32_2"),h=i("conv32_3"),u=i("conv64_down"),a=i("conv64_1"),g=i("conv64_2"),l=i("conv64_3"),c=i("conv128_down"),d=i("conv128_1"),f=i("conv128_2"),p=i("conv256_down"),y=i("conv256_1"),m=i("conv256_2"),b=i("conv256_down_out"),z=n["fc"];if(x.push({originalPath:"fc",paramPath:"fc"}),!Dm(z))throw new Error("expected weightMap[fc] to be a Tensor2D, instead have "+z);var v={conv32_down:r,conv32_1:o,conv32_2:s,conv32_3:h,conv64_down:u,conv64_1:a,conv64_2:g,conv64_3:l,conv128_down:c,conv128_1:d,conv128_2:f,conv256_down:p,conv256_1:y,conv256_2:m,conv256_down_out:b,fc:z};return Jb(n,x),{params:v,paramMappings:x}}function Yz(n,x){var t=Hz(n,x.conv1);return t=Uz(t,x.conv2),t=td(t,n),t=Bf(t),t}function Jz(n,x){var t=Vz(n,x.conv1);t=Uz(t,x.conv2);var e=lf(n,2,2,"valid"),i=Zs(e.shape),r=e.shape[3]!==t.shape[3],o=e.shape[1]!==t.shape[1]||e.shape[2]!==t.shape[2];if(o){var s=Em(t.shape);s[1]=1;var h=Zs(s);t=ih([t,h],1);var u=Em(t.shape);u[2]=1;var a=Zs(u);t=ih([t,a],2)}return e=r?ih([e,i],3):e,t=td(e,t),t=Bf(t),t}var Xz=function(n){function x(){return n.call(this,"FaceRecognitionNet")||this}return km(x,n),x.prototype.forwardInput=function(n){var x=this.params;if(!x)throw new Error("FaceRecognitionNet - load model before inference");return bs(function(){var t=n.toBatchTensor(150,!0).toFloat(),e=[122.782,117.001,104.298],i=Xm(t,e).div(Us(256)),r=Vz(i,x.conv32_down);r=gf(r,3,2,"valid"),r=Yz(r,x.conv32_1),r=Yz(r,x.conv32_2),r=Yz(r,x.conv32_3),r=Jz(r,x.conv64_down),r=Yz(r,x.conv64_1),r=Yz(r,x.conv64_2),r=Yz(r,x.conv64_3),r=Jz(r,x.conv128_down),r=Yz(r,x.conv128_1),r=Yz(r,x.conv128_2),r=Jz(r,x.conv256_down),r=Yz(r,x.conv256_1),r=Yz(r,x.conv256_2),r=Jz(r,x.conv256_down_out);var o=r.mean([1,2]),s=nf(o,x.fc);return s})},x.prototype.forward=function(n){return Cm(this,void 0,void 0,function(){var x;return Am(this,function(t){switch(t.label){case 0:return x=this.forwardInput,[4,Nb(n)];case 1:return[2,x.apply(this,[t.sent()])]}})})},x.prototype.computeFaceDescriptor=function(n){return Cm(this,void 0,void 0,function(){var x,t,e,i=this;return Am(this,function(r){switch(r.label){case 0:return[4,Nb(n)];case 1:return x=r.sent(),t=bs(function(){return Yh(i.forwardInput(x))}),[4,Promise.all(t.map(function(n){return n.data()}))];case 2:return e=r.sent(),t.forEach(function(n){return n.dispose()}),[2,x.isBatchInput?e:e[0]]}})})},x.prototype.getDefaultModelName=function(){return"face_recognition_model"},x.prototype.extractParamsFromWeigthMap=function(n){return Kz(n)},x.prototype.extractParams=function(n){return Qz(n)},x}(Wb);function Zz(n,x,t){var e={gender:x,genderProbability:t};return Object.assign({},n,e)}var $z=function(){function n(n){var x=void 0===n?{}:n,t=x.minFaceSize,e=x.scaleFactor,i=x.maxNumScales,r=x.scoreThresholds,o=x.scaleSteps;if(this._name="MtcnnOptions",this._minFaceSize=t||20,this._scaleFactor=e||.709,this._maxNumScales=i||10,this._scoreThresholds=r||[.6,.7,.7],this._scaleSteps=o,"number"!==typeof this._minFaceSize||this._minFaceSize<0)throw new Error(this._name+" - expected minFaceSize to be a number > 0");if("number"!==typeof this._scaleFactor||this._scaleFactor<=0||this._scaleFactor>=1)throw new Error(this._name+" - expected scaleFactor to be a number between 0 and 1");if("number"!==typeof this._maxNumScales||this._maxNumScales<0)throw new Error(this._name+" - expected maxNumScales to be a number > 0");if(!Array.isArray(this._scoreThresholds)||3!==this._scoreThresholds.length||this._scoreThresholds.some(function(n){return"number"!==typeof n}))throw new Error(this._name+" - expected scoreThresholds to be an array of numbers of length 3");if(this._scaleSteps&&(!Array.isArray(this._scaleSteps)||this._scaleSteps.some(function(n){return"number"!==typeof n})))throw new Error(this._name+" - expected scaleSteps to be an array of numbers")}return Object.defineProperty(n.prototype,"minFaceSize",{get:function(){return this._minFaceSize},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"scaleFactor",{get:function(){return this._scaleFactor},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"maxNumScales",{get:function(){return this._maxNumScales},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"scoreThresholds",{get:function(){return this._scoreThresholds},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"scaleSteps",{get:function(){return this._scaleSteps},enumerable:!0,configurable:!0}),n}();function nv(n,x){function t(t,e){var i=Gs(n(9*t),[3,3,t,1]),r=Vs(n(t)),o=Vs(n(t)),s=Vs(n(t)),h=Vs(n(t));return x.push({paramPath:e+"/filters"},{paramPath:e+"/batch_norm_scale"},{paramPath:e+"/batch_norm_offset"},{paramPath:e+"/batch_norm_mean"},{paramPath:e+"/batch_norm_variance"}),{filters:i,batch_norm_scale:r,batch_norm_offset:o,batch_norm_mean:s,batch_norm_variance:h}}function e(t,e,i,r,o){var s=Gs(n(t*e*i*i),[i,i,t,e]),h=Vs(n(e));return x.push({paramPath:r+"/filters"},{paramPath:r+"/"+(o?"batch_norm_offset":"bias")}),{filters:s,bias:h}}function i(n,x,t,i){var r=e(n,x,t,i,!0),o=r.filters,s=r.bias;return{filters:o,batch_norm_offset:s}}function r(n,x,e){var r=t(n,e+"/depthwise_conv"),o=i(n,x,1,e+"/pointwise_conv");return{depthwise_conv:r,pointwise_conv:o}}function o(){var n=i(3,32,3,"mobilenetv1/conv_0"),x=r(32,64,"mobilenetv1/conv_1"),t=r(64,128,"mobilenetv1/conv_2"),e=r(128,128,"mobilenetv1/conv_3"),o=r(128,256,"mobilenetv1/conv_4"),s=r(256,256,"mobilenetv1/conv_5"),h=r(256,512,"mobilenetv1/conv_6"),u=r(512,512,"mobilenetv1/conv_7"),a=r(512,512,"mobilenetv1/conv_8"),g=r(512,512,"mobilenetv1/conv_9"),l=r(512,512,"mobilenetv1/conv_10"),c=r(512,512,"mobilenetv1/conv_11"),d=r(512,1024,"mobilenetv1/conv_12"),f=r(1024,1024,"mobilenetv1/conv_13");return{conv_0:n,conv_1:x,conv_2:t,conv_3:e,conv_4:o,conv_5:s,conv_6:h,conv_7:u,conv_8:a,conv_9:g,conv_10:l,conv_11:c,conv_12:d,conv_13:f}}function s(){var n=i(1024,256,1,"prediction_layer/conv_0"),x=i(256,512,3,"prediction_layer/conv_1"),t=i(512,128,1,"prediction_layer/conv_2"),r=i(128,256,3,"prediction_layer/conv_3"),o=i(256,128,1,"prediction_layer/conv_4"),s=i(128,256,3,"prediction_layer/conv_5"),h=i(256,64,1,"prediction_layer/conv_6"),u=i(64,128,3,"prediction_layer/conv_7"),a=e(512,12,1,"prediction_layer/box_predictor_0/box_encoding_predictor"),g=e(512,9,1,"prediction_layer/box_predictor_0/class_predictor"),l=e(1024,24,1,"prediction_layer/box_predictor_1/box_encoding_predictor"),c=e(1024,18,1,"prediction_layer/box_predictor_1/class_predictor"),d=e(512,24,1,"prediction_layer/box_predictor_2/box_encoding_predictor"),f=e(512,18,1,"prediction_layer/box_predictor_2/class_predictor"),p=e(256,24,1,"prediction_layer/box_predictor_3/box_encoding_predictor"),y=e(256,18,1,"prediction_layer/box_predictor_3/class_predictor"),m=e(256,24,1,"prediction_layer/box_predictor_4/box_encoding_predictor"),b=e(256,18,1,"prediction_layer/box_predictor_4/class_predictor"),z=e(128,24,1,"prediction_layer/box_predictor_5/box_encoding_predictor"),v=e(128,18,1,"prediction_layer/box_predictor_5/class_predictor"),j={box_encoding_predictor:a,class_predictor:g},w={box_encoding_predictor:l,class_predictor:c},k={box_encoding_predictor:d,class_predictor:f},q={box_encoding_predictor:p,class_predictor:y},C={box_encoding_predictor:m,class_predictor:b},A={box_encoding_predictor:z,class_predictor:v};return{conv_0:n,conv_1:x,conv_2:t,conv_3:r,conv_4:o,conv_5:s,conv_6:h,conv_7:u,box_predictor_0:j,box_predictor_1:w,box_predictor_2:k,box_predictor_3:q,box_predictor_4:C,box_predictor_5:A}}return{extractMobilenetV1Params:o,extractPredictionLayerParams:s}}function xv(n){var x=[],t=ez(n),e=t.extractWeights,i=t.getRemainingWeights,r=nv(e,x),o=r.extractMobilenetV1Params,s=r.extractPredictionLayerParams,h=o(),u=s(),a=Qs(e(20472),[1,5118,4]),g={extra_dim:a};if(x.push({paramPath:"output_layer/extra_dim"}),0!==i().length)throw new Error("weights remaing after extract: "+i().length);return{params:{mobilenetv1:h,prediction_layer:u,output_layer:g},paramMappings:x}}function tv(n,x){var t=tz(n,x);function e(n,x,e){var i=t(n+"/Conv2d_"+x+"_pointwise/weights",4,e+"/filters"),r=t(n+"/Conv2d_"+x+"_pointwise/convolution_bn_offset",1,e+"/batch_norm_offset");return{filters:i,batch_norm_offset:r}}function i(n){var x="mobilenetv1/conv_"+n,i="MobilenetV1/Conv2d_"+n+"_depthwise",r=x+"/depthwise_conv",o=x+"/pointwise_conv",s=t(i+"/depthwise_weights",4,r+"/filters"),h=t(i+"/BatchNorm/gamma",1,r+"/batch_norm_scale"),u=t(i+"/BatchNorm/beta",1,r+"/batch_norm_offset"),a=t(i+"/BatchNorm/moving_mean",1,r+"/batch_norm_mean"),g=t(i+"/BatchNorm/moving_variance",1,r+"/batch_norm_variance");return{depthwise_conv:{filters:s,batch_norm_scale:h,batch_norm_offset:u,batch_norm_mean:a,batch_norm_variance:g},pointwise_conv:e("MobilenetV1",n,o)}}function r(){return{conv_0:e("MobilenetV1",0,"mobilenetv1/conv_0"),conv_1:i(1),conv_2:i(2),conv_3:i(3),conv_4:i(4),conv_5:i(5),conv_6:i(6),conv_7:i(7),conv_8:i(8),conv_9:i(9),conv_10:i(10),conv_11:i(11),conv_12:i(12),conv_13:i(13)}}function o(n,x){var e=t(n+"/weights",4,x+"/filters"),i=t(n+"/biases",1,x+"/bias");return{filters:e,bias:i}}function s(n){var x=o("Prediction/BoxPredictor_"+n+"/BoxEncodingPredictor","prediction_layer/box_predictor_"+n+"/box_encoding_predictor"),t=o("Prediction/BoxPredictor_"+n+"/ClassPredictor","prediction_layer/box_predictor_"+n+"/class_predictor");return{box_encoding_predictor:x,class_predictor:t}}function h(){return{conv_0:e("Prediction",0,"prediction_layer/conv_0"),conv_1:e("Prediction",1,"prediction_layer/conv_1"),conv_2:e("Prediction",2,"prediction_layer/conv_2"),conv_3:e("Prediction",3,"prediction_layer/conv_3"),conv_4:e("Prediction",4,"prediction_layer/conv_4"),conv_5:e("Prediction",5,"prediction_layer/conv_5"),conv_6:e("Prediction",6,"prediction_layer/conv_6"),conv_7:e("Prediction",7,"prediction_layer/conv_7"),box_predictor_0:s(0),box_predictor_1:s(1),box_predictor_2:s(2),box_predictor_3:s(3),box_predictor_4:s(4),box_predictor_5:s(5)}}return{extractMobilenetV1Params:r,extractPredictionLayerParams:h}}function ev(n){var x=[],t=tv(n,x),e=t.extractMobilenetV1Params,i=t.extractPredictionLayerParams,r=n["Output/extra_dim"];if(x.push({originalPath:"Output/extra_dim",paramPath:"output_layer/extra_dim"}),!Om(r))throw new Error("expected weightMap['Output/extra_dim'] to be a Tensor3D, instead have "+r);var o={mobilenetv1:e(),prediction_layer:i(),output_layer:{extra_dim:r}};return Jb(n,x),{params:o,paramMappings:x}}function iv(n,x,t){return bs(function(){var e=Vd(n,x.filters,t,"same");return e=td(e,x.batch_norm_offset),ac(e,0,6)})}var rv=.0010000000474974513;function ov(n,x,t){return bs(function(){var e=Kd(n,x.filters,t,"same");return e=Qc(e,x.batch_norm_mean,x.batch_norm_variance,x.batch_norm_offset,x.batch_norm_scale,rv),ac(e,0,6)})}function sv(n){return[2,4,6,12].some(function(x){return x===n})?[2,2]:[1,1]}function hv(n,x){return bs(function(){var t=null,e=iv(n,x.conv_0,[2,2]),i=[x.conv_1,x.conv_2,x.conv_3,x.conv_4,x.conv_5,x.conv_6,x.conv_7,x.conv_8,x.conv_9,x.conv_10,x.conv_11,x.conv_12,x.conv_13];if(i.forEach(function(n,x){var i=x+1,r=sv(i);e=ov(e,n.depthwise_conv,r),e=iv(e,n.pointwise_conv,[1,1]),11===i&&(t=e)}),null===t)throw new Error("mobileNetV1 - output of conv layer 11 is null");return{out:e,conv11:t}})}function uv(n,x,t,e,i){var r=n.shape[0],o=Math.min(t,r),s=x.map(function(n,x){return{score:n,boxIndex:x}}).filter(function(n){return n.score>i}).sort(function(n,x){return x.score-n.score}),h=function(n){return n<=e?1:0},u=[];return s.forEach(function(x){if(!(u.length>=o)){for(var t=x.score,e=u.length-1;e>=0;--e){var r=av(n,x.boxIndex,u[e]);if(0!==r&&(x.score*=h(r),x.score<=i))break}t===x.score&&u.push(x.boxIndex)}}),u}function av(n,x,t){var e=n.arraySync(),i=Math.min(e[x][0],e[x][2]),r=Math.min(e[x][1],e[x][3]),o=Math.max(e[x][0],e[x][2]),s=Math.max(e[x][1],e[x][3]),h=Math.min(e[t][0],e[t][2]),u=Math.min(e[t][1],e[t][3]),a=Math.max(e[t][0],e[t][2]),g=Math.max(e[t][1],e[t][3]),l=(o-i)*(s-r),c=(a-h)*(g-u);if(l<=0||c<=0)return 0;var d=Math.max(i,h),f=Math.max(r,u),p=Math.min(o,a),y=Math.min(s,g),m=Math.max(p-d,0)*Math.max(y-f,0);return m/(l+c-m)}function gv(n){var x=Yh(Ff(n,[1,0])),t=[vd(x[2],x[0]),vd(x[3],x[1])],e=[td(x[0],od(t[0],Us(2))),td(x[1],od(t[1],Us(2)))];return{sizes:t,centers:e}}function lv(n,x){var t=gv(n),e=t.sizes,i=t.centers,r=Yh(Ff(x,[1,0])),o=od(pd(dc(od(r[2],Us(5))),e[0]),Us(2)),s=td(pd(od(r[0],Us(10)),e[0]),i[0]),h=od(pd(dc(od(r[3],Us(5))),e[1]),Us(2)),u=td(pd(od(r[1],Us(10)),e[1]),i[1]);return Ff(Qh([vd(s,o),vd(u,h),td(s,o),td(u,h)]),[1,0])}function cv(n,x,t){return bs(function(){var e=n.shape[0],i=lv(Uh(Gh(t.extra_dim,[e,1,1]),[-1,4]),Uh(n,[-1,4]));i=Uh(i,[e,i.shape[0]/e,4]);var r=kc(pf(x,[0,0,1],[-1,-1,-1])),o=pf(r,[0,0,0],[-1,-1,1]);o=Uh(o,[e,o.shape[1]]);var s=Yh(i),h=Yh(o);return{boxes:s,scores:h}})}function dv(n,x){return bs(function(){var t=n.shape[0],e=Uh(Yb(n,x.box_encoding_predictor),[t,-1,1,4]),i=Uh(Yb(n,x.class_predictor),[t,-1,3]);return{boxPredictionEncoding:e,classPrediction:i}})}function fv(n,x,t){return bs(function(){var e=iv(n,t.conv_0,[1,1]),i=iv(e,t.conv_1,[2,2]),r=iv(i,t.conv_2,[1,1]),o=iv(r,t.conv_3,[2,2]),s=iv(o,t.conv_4,[1,1]),h=iv(s,t.conv_5,[2,2]),u=iv(h,t.conv_6,[1,1]),a=iv(u,t.conv_7,[2,2]),g=dv(x,t.box_predictor_0),l=dv(n,t.box_predictor_1),c=dv(i,t.box_predictor_2),d=dv(o,t.box_predictor_3),f=dv(h,t.box_predictor_4),p=dv(a,t.box_predictor_5),y=ih([g.boxPredictionEncoding,l.boxPredictionEncoding,c.boxPredictionEncoding,d.boxPredictionEncoding,f.boxPredictionEncoding,p.boxPredictionEncoding],1),m=ih([g.classPrediction,l.classPrediction,c.classPrediction,d.classPrediction,f.classPrediction,p.classPrediction],1);return{boxPredictions:y,classPredictions:m}})}var pv=function(){function n(n){var x=void 0===n?{}:n,t=x.minConfidence,e=x.maxResults;if(this._name="SsdMobilenetv1Options",this._minConfidence=t||.5,this._maxResults=e||100,"number"!==typeof this._minConfidence||this._minConfidence<=0||this._minConfidence>=1)throw new Error(this._name+" - expected minConfidence to be a number between 0 and 1");if("number"!==typeof this._maxResults)throw new Error(this._name+" - expected maxResults to be a number")}return Object.defineProperty(n.prototype,"minConfidence",{get:function(){return this._minConfidence},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"maxResults",{get:function(){return this._maxResults},enumerable:!0,configurable:!0}),n}(),yv=function(n){function x(){return n.call(this,"SsdMobilenetv1")||this}return km(x,n),x.prototype.forwardInput=function(n){var x=this.params;if(!x)throw new Error("SsdMobilenetv1 - load model before inference");return bs(function(){var t=n.toBatchTensor(512,!1).toFloat(),e=vd(pd(t,Us(.007843137718737125)),Us(1)),i=hv(e,x.mobilenetv1),r=fv(i.out,i.conv11,x.prediction_layer),o=r.boxPredictions,s=r.classPredictions;return cv(o,s,x.output_layer)})},x.prototype.forward=function(n){return Cm(this,void 0,void 0,function(){var x;return Am(this,function(t){switch(t.label){case 0:return x=this.forwardInput,[4,Nb(n)];case 1:return[2,x.apply(this,[t.sent()])]}})})},x.prototype.locateFaces=function(n,x){return void 0===x&&(x={}),Cm(this,void 0,void 0,function(){var t,e,i,r,o,s,h,u,a,g,l,c,d,f,p,y,m,b,z,v,j;return Am(this,function(w){switch(w.label){case 0:return t=new pv(x),e=t.maxResults,i=t.minConfidence,[4,Nb(n)];case 1:for(r=w.sent(),o=this.forwardInput(r),s=o.boxes,h=o.scores,u=s[0],a=h[0],g=1;g<s.length;g++)s[g].dispose(),h[g].dispose();return d=(c=Array).from,[4,a.data()];case 2:return l=d.apply(c,[w.sent()]),f=.5,p=uv(u,l,e,f,i),y=r.getReshapedInputDimensions(0),m=r.inputSize,b=m/y.width,z=m/y.height,v=u.arraySync(),j=p.map(function(n){var x=[Math.max(0,v[n][0]),Math.min(1,v[n][2])].map(function(n){return n*z}),t=x[0],e=x[1],i=[Math.max(0,v[n][1]),Math.min(1,v[n][3])].map(function(n){return n*b}),o=i[0],s=i[1];return new Gm(l[n],new xb(o,t,s-o,e-t),{height:r.getInputHeight(0),width:r.getInputWidth(0)})}),u.dispose(),a.dispose(),[2,j]}})})},x.prototype.getDefaultModelName=function(){return"ssd_mobilenetv1_model"},x.prototype.extractParamsFromWeigthMap=function(n){return ev(n)},x.prototype.extractParams=function(n){return xv(n)},x}(Wb);(function(n){function x(){return null!==n&&n.apply(this,arguments)||this}km(x,n)})(yv);var mv,bv=.4,zv=[new Um(.738768,.874946),new Um(2.42204,2.65704),new Um(4.30971,7.04493),new Um(10.246,4.59428),new Um(12.6868,11.8741)],vv=[new Um(1.603231,2.094468),new Um(6.041143,7.080126),new Um(2.882459,3.518061),new Um(4.266906,5.178857),new Um(9.041765,10.66308)],jv=[117.001,114.697,97.404],wv="tiny_yolov2_model",kv="tiny_yolov2_separable_conv_model",qv=function(n){return"number"===typeof n};function Cv(n){if(!n)throw new Error("invalid config: "+n);if("boolean"!==typeof n.withSeparableConvs)throw new Error("config.withSeparableConvs has to be a boolean, have: "+n.withSeparableConvs);if(!qv(n.iouThreshold)||n.iouThreshold<0||n.iouThreshold>1)throw new Error("config.iouThreshold has to be a number between [0, 1], have: "+n.iouThreshold);if(!Array.isArray(n.classes)||!n.classes.length||!n.classes.every(function(n){return"string"===typeof n}))throw new Error("config.classes has to be an array class names: string[], have: "+JSON.stringify(n.classes));if(!Array.isArray(n.anchors)||!n.anchors.length||!n.anchors.map(function(n){return n||{}}).every(function(n){return qv(n.x)&&qv(n.y)}))throw new Error("config.anchors has to be an array of { x: number, y: number }, have: "+JSON.stringify(n.anchors));if(n.meanRgb&&(!Array.isArray(n.meanRgb)||3!==n.meanRgb.length||!n.meanRgb.every(qv)))throw new Error("config.meanRgb has to be an array of shape [number, number, number], have: "+JSON.stringify(n.meanRgb))}function Av(n){return bs(function(){var x=pd(n,Us(.10000000149011612));return td(Bf(vd(n,x)),x)})}function Ev(n,x){return bs(function(){var t=Th(n,[[0,0],[1,1],[1,1],[0,0]]);return t=Vd(t,x.conv.filters,[1,1],"valid"),t=vd(t,x.bn.sub),t=pd(t,x.bn.truediv),t=td(t,x.conv.bias),Av(t)})}function Sv(n,x){return bs(function(){var t=Th(n,[[0,0],[1,1],[1,1],[0,0]]);return t=Xd(t,x.depthwise_filter,x.pointwise_filter,[1,1],"valid"),t=td(t,x.bias),Av(t)})}function Iv(n,x){var t=Xb(n,x);function e(t,e){var i=Vs(n(t)),r=Vs(n(t));return x.push({paramPath:e+"/sub"},{paramPath:e+"/truediv"}),{sub:i,truediv:r}}function i(n,x,i){var r=t(n,x,3,i+"/conv"),o=e(x,i+"/bn");return{conv:r,bn:o}}var r=nz(n,x);return{extractConvParams:t,extractConvWithBatchNormParams:i,extractSeparableConvParams:r}}function Dv(n,x,t,e){var i,r=ez(n),o=r.extractWeights,s=r.getRemainingWeights,h=[],u=Iv(o,h),a=u.extractConvParams,g=u.extractConvWithBatchNormParams,l=u.extractSeparableConvParams;if(x.withSeparableConvs){var c=e[0],d=e[1],f=e[2],p=e[3],y=e[4],m=e[5],b=e[6],z=e[7],v=e[8],j=x.isFirstLayerConv2d?a(c,d,3,"conv0"):l(c,d,"conv0"),w=l(d,f,"conv1"),k=l(f,p,"conv2"),q=l(p,y,"conv3"),C=l(y,m,"conv4"),A=l(m,b,"conv5"),E=z?l(b,z,"conv6"):void 0,S=v?l(z,v,"conv7"):void 0,I=a(v||z||b,5*t,1,"conv8");i={conv0:j,conv1:w,conv2:k,conv3:q,conv4:C,conv5:A,conv6:E,conv7:S,conv8:I}}else{c=e[0],d=e[1],f=e[2],p=e[3],y=e[4],m=e[5],b=e[6],z=e[7],v=e[8],j=g(c,d,"conv0"),w=g(d,f,"conv1"),k=g(f,p,"conv2"),q=g(p,y,"conv3"),C=g(y,m,"conv4"),A=g(m,b,"conv5"),E=g(b,z,"conv6"),S=g(z,v,"conv7"),I=a(v,5*t,1,"conv8");i={conv0:j,conv1:w,conv2:k,conv3:q,conv4:C,conv5:A,conv6:E,conv7:S,conv8:I}}if(0!==s().length)throw new Error("weights remaing after extract: "+s().length);return{params:i,paramMappings:h}}function Ov(n,x){var t=tz(n,x);function e(n){var x=t(n+"/sub",1),e=t(n+"/truediv",1);return{sub:x,truediv:e}}function i(n){var x=t(n+"/filters",4),e=t(n+"/bias",1);return{filters:x,bias:e}}function r(n){var x=i(n+"/conv"),t=e(n+"/bn");return{conv:x,bn:t}}var o=xz(t);return{extractConvParams:i,extractConvWithBatchNormParams:r,extractSeparableConvParams:o}}function _v(n,x){var t,e=[],i=Ov(n,e),r=i.extractConvParams,o=i.extractConvWithBatchNormParams,s=i.extractSeparableConvParams;if(x.withSeparableConvs){var h=x.filterSizes&&x.filterSizes.length||9;t={conv0:x.isFirstLayerConv2d?r("conv0"):s("conv0"),conv1:s("conv1"),conv2:s("conv2"),conv3:s("conv3"),conv4:s("conv4"),conv5:s("conv5"),conv6:h>7?s("conv6"):void 0,conv7:h>8?s("conv7"):void 0,conv8:r("conv8")}}else t={conv0:o("conv0"),conv1:o("conv1"),conv2:o("conv2"),conv3:o("conv3"),conv4:o("conv4"),conv5:o("conv5"),conv6:o("conv6"),conv7:o("conv7"),conv8:r("conv8")};return Jb(n,e),{params:t,paramMappings:e}}(function(n){n[n["XS"]=224]="XS",n[n["SM"]=320]="SM",n[n["MD"]=416]="MD",n[n["LG"]=608]="LG"})(mv||(mv={}));var Tv=function(){function n(n){var x=void 0===n?{}:n,t=x.inputSize,e=x.scoreThreshold;if(this._name="TinyYolov2Options",this._inputSize=t||416,this._scoreThreshold=e||.5,"number"!==typeof this._inputSize||this._inputSize%32!==0)throw new Error(this._name+" - expected inputSize to be a number divisible by 32");if("number"!==typeof this._scoreThreshold||this._scoreThreshold<=0||this._scoreThreshold>=1)throw new Error(this._name+" - expected scoreThreshold to be a number between 0 and 1")}return Object.defineProperty(n.prototype,"inputSize",{get:function(){return this._inputSize},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"scoreThreshold",{get:function(){return this._scoreThreshold},enumerable:!0,configurable:!0}),n}(),Rv=function(n){function x(x){var t=n.call(this,"TinyYolov2")||this;return Cv(x),t._config=x,t}return km(x,n),Object.defineProperty(x.prototype,"config",{get:function(){return this._config},enumerable:!0,configurable:!0}),Object.defineProperty(x.prototype,"withClassScores",{get:function(){return this.config.withClassScores||this.config.classes.length>1},enumerable:!0,configurable:!0}),Object.defineProperty(x.prototype,"boxEncodingSize",{get:function(){return 5+(this.withClassScores?this.config.classes.length:0)},enumerable:!0,configurable:!0}),x.prototype.runTinyYolov2=function(n,x){var t=Ev(n,x.conv0);return t=gf(t,[2,2],[2,2],"same"),t=Ev(t,x.conv1),t=gf(t,[2,2],[2,2],"same"),t=Ev(t,x.conv2),t=gf(t,[2,2],[2,2],"same"),t=Ev(t,x.conv3),t=gf(t,[2,2],[2,2],"same"),t=Ev(t,x.conv4),t=gf(t,[2,2],[2,2],"same"),t=Ev(t,x.conv5),t=gf(t,[2,2],[1,1],"same"),t=Ev(t,x.conv6),t=Ev(t,x.conv7),Yb(t,x.conv8,"valid",!1)},x.prototype.runMobilenet=function(n,x){var t=this.config.isFirstLayerConv2d?Av(Yb(n,x.conv0,"valid",!1)):Sv(n,x.conv0);return t=gf(t,[2,2],[2,2],"same"),t=Sv(t,x.conv1),t=gf(t,[2,2],[2,2],"same"),t=Sv(t,x.conv2),t=gf(t,[2,2],[2,2],"same"),t=Sv(t,x.conv3),t=gf(t,[2,2],[2,2],"same"),t=Sv(t,x.conv4),t=gf(t,[2,2],[2,2],"same"),t=Sv(t,x.conv5),t=gf(t,[2,2],[1,1],"same"),t=x.conv6?Sv(t,x.conv6):t,t=x.conv7?Sv(t,x.conv7):t,Yb(t,x.conv8,"valid",!1)},x.prototype.forwardInput=function(n,x){var t=this,e=this.params;if(!e)throw new Error("TinyYolov2 - load model before inference");return bs(function(){var i=n.toBatchTensor(x,!1).toFloat();return i=t.config.meanRgb?Xm(i,t.config.meanRgb):i,i=i.div(Us(256)),t.config.withSeparableConvs?t.runMobilenet(i,e):t.runTinyYolov2(i,e)})},x.prototype.forward=function(n,x){return Cm(this,void 0,void 0,function(){var t;return Am(this,function(e){switch(e.label){case 0:return t=this.forwardInput,[4,Nb(n)];case 1:return[4,t.apply(this,[e.sent(),x])];case 2:return[2,e.sent()]}})})},x.prototype.detect=function(n,x){return void 0===x&&(x={}),Cm(this,void 0,void 0,function(){var t,e,i,r,o,s,h,u,a,g,l,c,d,f,p=this;return Am(this,function(y){switch(y.label){case 0:return t=new Tv(x),e=t.inputSize,i=t.scoreThreshold,[4,Nb(n)];case 1:return r=y.sent(),[4,this.forwardInput(r,e)];case 2:return o=y.sent(),s=bs(function(){return Yh(o)[0].expandDims()}),h={width:r.getInputWidth(0),height:r.getInputHeight(0)},[4,this.extractBoxes(s,r.getReshapedInputDimensions(0),i)];case 3:return u=y.sent(),o.dispose(),s.dispose(),a=u.map(function(n){return n.box}),g=u.map(function(n){return n.score}),l=u.map(function(n){return n.classScore}),c=u.map(function(n){return p.config.classes[n.label]}),d=Jm(a.map(function(n){return n.rescale(e)}),g,this.config.iouThreshold,!0),f=d.map(function(n){return new Qm(g[n],l[n],c[n],a[n],h)}),[2,f]}})})},x.prototype.getDefaultModelName=function(){return""},x.prototype.extractParamsFromWeigthMap=function(n){return _v(n,this.config)},x.prototype.extractParams=function(n){var t=this.config.filterSizes||x.DEFAULT_FILTER_SIZES,e=t?t.length:void 0;if(7!==e&&8!==e&&9!==e)throw new Error("TinyYolov2 - expected 7 | 8 | 9 convolutional filters, but found "+e+" filterSizes in config");return Dv(n,this.config,this.boxEncodingSize,t)},x.prototype.extractBoxes=function(n,x,t){return Cm(this,void 0,void 0,function(){var e,i,r,o,s,h,u,a,g,l,c,d,f,p,y,m,b,z,v,j,w,k,q,C,A,E,S,I,D,O=this;return Am(this,function(_){switch(_.label){case 0:return e=x.width,i=x.height,r=Math.max(e,i),o=r/e,s=r/i,h=n.shape[1],u=this.config.anchors.length,a=bs(function(){var x=n.reshape([h,h,u,O.boxEncodingSize]),t=x.slice([0,0,0,0],[h,h,u,4]),e=x.slice([0,0,0,4],[h,h,u,1]),i=O.withClassScores?yu(x.slice([0,0,0,5],[h,h,u,O.config.classes.length]),3):Us(0);return[t,e,i]}),g=a[0],l=a[1],c=a[2],d=[],[4,l.array()];case 1:return f=_.sent(),[4,g.array()];case 2:p=_.sent(),y=0,_.label=3;case 3:if(!(y<h))return[3,12];m=0,_.label=4;case 4:if(!(m<h))return[3,11];b=0,_.label=5;case 5:return b<u?(z=$m(f[y][m][b][0]),!t||z>t?(v=(m+$m(p[y][m][b][0]))/h*o,j=(y+$m(p[y][m][b][1]))/h*s,w=Math.exp(p[y][m][b][2])*this.config.anchors[b].x/h*o,k=Math.exp(p[y][m][b][3])*this.config.anchors[b].y/h*s,q=v-w/2,C=j-k/2,A={row:y,col:m,anchor:b},this.withClassScores?[4,this.extractPredictedClass(c,A)]:[3,7]):[3,9]):[3,10];case 6:return D=_.sent(),[3,8];case 7:D={classScore:1,label:0},_.label=8;case 8:E=D,S=E.classScore,I=E.label,d.push(qm({box:new Wm(q,C,q+w,C+k),score:z,classScore:z*S,label:I},A)),_.label=9;case 9:return b++,[3,5];case 10:return m++,[3,4];case 11:return y++,[3,3];case 12:return g.dispose(),l.dispose(),c.dispose(),[2,d]}})})},x.prototype.extractPredictedClass=function(n,x){return Cm(this,void 0,void 0,function(){var t,e,i,r;return Am(this,function(o){switch(o.label){case 0:return t=x.row,e=x.col,i=x.anchor,[4,n.array()];case 1:return r=o.sent(),[2,Array(this.config.classes.length).fill(0).map(function(n,x){return r[t][e][i][x]}).map(function(n,x){return{classScore:n,label:x}}).reduce(function(n,x){return n.classScore>x.classScore?n:x})]}})})},x.DEFAULT_FILTER_SIZES=[3,16,32,64,128,256,512,1024,1024],x}(Wb),Bv=function(n){function x(x){void 0===x&&(x=!0);var t=this,e=Object.assign({},{withSeparableConvs:x,iouThreshold:bv,classes:["face"]},x?{anchors:vv,meanRgb:jv}:{anchors:zv,withClassScores:!0});return t=n.call(this,e)||this,t}return km(x,n),Object.defineProperty(x.prototype,"withSeparableConvs",{get:function(){return this.config.withSeparableConvs},enumerable:!0,configurable:!0}),Object.defineProperty(x.prototype,"anchors",{get:function(){return this.config.anchors},enumerable:!0,configurable:!0}),x.prototype.locateFaces=function(n,x){return Cm(this,void 0,void 0,function(){var t;return Am(this,function(e){switch(e.label){case 0:return[4,this.detect(n,x)];case 1:return t=e.sent(),[2,t.map(function(n){return new Gm(n.score,n.relativeBox,{width:n.imageWidth,height:n.imageHeight})})]}})})},x.prototype.getDefaultModelName=function(){return this.withSeparableConvs?kv:wv},x.prototype.extractParamsFromWeigthMap=function(x){return n.prototype.extractParamsFromWeigthMap.call(this,x)},x}(Rv);var Mv=function(n){function x(){var x=null!==n&&n.apply(this,arguments)||this;return x._name="TinyFaceDetectorOptions",x}return km(x,n),x}(Tv),Nv=function(){function n(){}return n.prototype.then=function(n){return Cm(this,void 0,void 0,function(){var x;return Am(this,function(t){switch(t.label){case 0:return x=n,[4,this.run()];case 1:return[2,x.apply(void 0,[t.sent()])]}})})},n.prototype.run=function(){return Cm(this,void 0,void 0,function(){return Am(this,function(n){throw new Error("ComposableTask - run is not implemented")})})},n}();function Fv(n,x){var t={descriptor:x};return Object.assign({},n,t)}function Pv(n,x,t,e,i){return void 0===i&&(i=function(n){var x=n.alignedRect;return x}),Cm(this,void 0,void 0,function(){var r,o,s,h,u;return Am(this,function(a){switch(a.label){case 0:return r=n.map(function(n){return bz(n)?i(n):n.detection}),s=e,s?[3,5]:x instanceof Kr?[4,Pb(x,r)]:[3,2];case 1:return h=a.sent(),[3,4];case 2:return[4,Fb(x,r)];case 3:h=a.sent(),a.label=4;case 4:s=h,a.label=5;case 5:return o=s,[4,t(o)];case 6:return u=a.sent(),o.forEach(function(n){return n instanceof Kr&&n.dispose()}),[2,u]}})})}function Lv(n,x,t,e,i){return Cm(this,void 0,void 0,function(){var r=this;return Am(this,function(o){return[2,Pv([n],x,function(n){return Cm(r,void 0,void 0,function(){return Am(this,function(x){return[2,t(n[0])]})})},e,i)]})})}function Hv(n){return bs(function(){return Qh(Yh(n,3).reverse(),3)})}var Uv=2,Vv=12;function Wv(n,x){var t=Xb(n,x),e=Zb(n,x);function i(t,e){var i=Vs(n(t));return x.push({paramPath:e}),i}function r(n,x,e){void 0===e&&(e=!1);var r=t(n[0],n[1],3,x+"/conv1"),o=i(n[1],x+"/prelu1_alpha"),s=t(n[1],n[2],3,x+"/conv2"),h=i(n[2],x+"/prelu2_alpha"),u=t(n[2],n[3],e?2:3,x+"/conv3"),a=i(n[3],x+"/prelu3_alpha");return{conv1:r,prelu1_alpha:o,conv2:s,prelu2_alpha:h,conv3:u,prelu3_alpha:a}}function o(){var n=r([3,10,16,32],"pnet"),x=t(32,2,1,"pnet/conv4_1"),e=t(32,4,1,"pnet/conv4_2");return qm(qm({},n),{conv4_1:x,conv4_2:e})}function s(){var n=r([3,28,48,64],"rnet",!0),x=e(576,128,"rnet/fc1"),t=i(128,"rnet/prelu4_alpha"),o=e(128,2,"rnet/fc2_1"),s=e(128,4,"rnet/fc2_2");return qm(qm({},n),{fc1:x,prelu4_alpha:t,fc2_1:o,fc2_2:s})}function h(){var n=r([3,32,64,64],"onet"),x=t(64,128,2,"onet/conv4"),o=i(128,"onet/prelu4_alpha"),s=e(1152,256,"onet/fc1"),h=i(256,"onet/prelu5_alpha"),u=e(256,2,"onet/fc2_1"),a=e(256,4,"onet/fc2_2"),g=e(256,10,"onet/fc2_3");return qm(qm({},n),{conv4:x,prelu4_alpha:o,fc1:s,prelu5_alpha:h,fc2_1:u,fc2_2:a,fc2_3:g})}return{extractPNetParams:o,extractRNetParams:s,extractONetParams:h}}function Qv(n){var x=ez(n),t=x.extractWeights,e=x.getRemainingWeights,i=[],r=Wv(t,i),o=r.extractPNetParams,s=r.extractRNetParams,h=r.extractONetParams,u=o(),a=s(),g=h();if(0!==e().length)throw new Error("weights remaing after extract: "+e().length);return{params:{pnet:u,rnet:a,onet:g},paramMappings:i}}function Gv(n,x){var t=tz(n,x);function e(n){var x=t(n+"/weights",4,n+"/filters"),e=t(n+"/bias",1);return{filters:x,bias:e}}function i(n){var x=t(n+"/weights",2),e=t(n+"/bias",1);return{weights:x,bias:e}}function r(n){return t(n,1)}function o(n){var x=e(n+"/conv1"),t=r(n+"/prelu1_alpha"),i=e(n+"/conv2"),o=r(n+"/prelu2_alpha"),s=e(n+"/conv3"),h=r(n+"/prelu3_alpha");return{conv1:x,prelu1_alpha:t,conv2:i,prelu2_alpha:o,conv3:s,prelu3_alpha:h}}function s(){var n=o("pnet"),x=e("pnet/conv4_1"),t=e("pnet/conv4_2");return qm(qm({},n),{conv4_1:x,conv4_2:t})}function h(){var n=o("rnet"),x=i("rnet/fc1"),t=r("rnet/prelu4_alpha"),e=i("rnet/fc2_1"),s=i("rnet/fc2_2");return qm(qm({},n),{fc1:x,prelu4_alpha:t,fc2_1:e,fc2_2:s})}function u(){var n=o("onet"),x=e("onet/conv4"),t=r("onet/prelu4_alpha"),s=i("onet/fc1"),h=r("onet/prelu5_alpha"),u=i("onet/fc2_1"),a=i("onet/fc2_2"),g=i("onet/fc2_3");return qm(qm({},n),{conv4:x,prelu4_alpha:t,fc1:s,prelu5_alpha:h,fc2_1:u,fc2_2:a,fc2_3:g})}return{extractPNetParams:s,extractRNetParams:h,extractONetParams:u}}function Kv(n){var x=[],t=Gv(n,x),e=t.extractPNetParams,i=t.extractRNetParams,r=t.extractONetParams,o=e(),s=i(),h=r();return Jb(n,x),{params:{pnet:o,rnet:s,onet:h},paramMappings:x}}function Yv(n,x){var t=x[0],e=x[1];return{height:Math.floor(t*n),width:Math.floor(e*n)}}function Jv(n,x,t){var e=t[0],i=t[1],r=Vv/n,o=[],s=Math.min(e,i)*r,h=0;while(s>=12)o.push(r*Math.pow(x,h)),s*=x,h+=1;return o}var Xv=function(n){function x(x,t,e,i){return n.call(this,{left:x,top:t,right:e,bottom:i},!0)||this}return km(x,n),x}(Vm);function Zv(n){return bs(function(){return pd(vd(n,Us(127.5)),Us(.0078125))})}function $v(n,x){return bs(function(){return td(Bf(n),pd(x,zc(Bf(zc(n)))))})}function nj(n,x,t){return void 0===t&&(t=!1),bs(function(){var e=Yb(n,x.conv1,"valid");return e=$v(e,x.prelu1_alpha),e=gf(e,t?[2,2]:[3,3],[2,2],"same"),e=Yb(e,x.conv2,"valid"),e=$v(e,x.prelu2_alpha),e=t?e:gf(e,[3,3],[2,2],"valid"),e=Yb(e,x.conv3,"valid"),e=$v(e,x.prelu3_alpha),e})}function xj(n,x){return bs(function(){var t=nj(n,x,!0),e=Yb(t,x.conv4_1,"valid"),i=Ih(Af(e,3),3),r=yu(vd(e,i),3),o=Yb(t,x.conv4_2,"valid");return{prob:r,regions:o}})}function tj(n,x){return bs(function(){var t=Yv(x,n.shape.slice(1)),e=t.height,i=t.width,r=Tp.resizeBilinear(n,[e,i]),o=Zv(r);return Ff(o,[0,2,1,3])})}function ej(n,x,t,e){for(var i=[],r=n.arraySync(),o=0;o<n.shape[0];o++)for(var s=0;s<n.shape[1];s++)r[o][s]>=e&&i.push(new Um(s,o));var h=i.map(function(n){var e=new Wm(Math.round((n.y*Uv+1)/t),Math.round((n.x*Uv+1)/t),Math.round((n.y*Uv+Vv)/t),Math.round((n.x*Uv+Vv)/t)),i=r[n.y][n.x],o=x.arraySync(),s=new Xv(o[n.y][n.x][0],o[n.y][n.x][1],o[n.y][n.x][2],o[n.y][n.x][3]);return{cell:e,score:i,region:s}});return h}function ij(n,x,t,e,i){i.stage1=[];var r=x.map(function(x){return bs(function(){var t={scale:x},i=tj(n,x),r=Date.now(),o=xj(i,e),s=o.prob,h=o.regions;t.pnet=Date.now()-r;var u=Yh(Yh(s,3)[1])[0],a=Yh(h)[0];return{scoresTensor:u,regionsTensor:a,scale:x,statsForScale:t}})}),o=r.map(function(n){var x=n.scoresTensor,e=n.regionsTensor,r=n.scale,o=n.statsForScale,s=ej(x,e,r,t);if(x.dispose(),e.dispose(),!s.length)return i.stage1.push(o),[];var h=Date.now(),u=Jm(s.map(function(n){return n.cell}),s.map(function(n){return n.score}),.5);return o.nms=Date.now()-h,o.numBoxes=u.length,i.stage1.push(o),u.map(function(n){return s[n]})}),s=o.reduce(function(n,x){return n.concat(x)},[]),h=[],u=[];if(s.length>0){var a=Date.now(),g=Jm(s.map(function(n){return n.cell}),s.map(function(n){return n.score}),.7);i.stage1_nms=Date.now()-a,u=g.map(function(n){return s[n].score}),h=g.map(function(n){return s[n]}).map(function(n){var x=n.cell,t=n.region;return new Wm(x.left+t.left*x.width,x.top+t.top*x.height,x.right+t.right*x.width,x.bottom+t.bottom*x.height).toSquare().round()})}return{boxes:h,scores:u}}function rj(n,x,t){var e=t.width,i=t.height;return Cm(this,void 0,void 0,function(){var t,r,o,s=this;return Am(this,function(h){switch(h.label){case 0:return t=qb(n),[4,Promise.all(x.map(function(x){return Cm(s,void 0,void 0,function(){var e,i,r,o,s,h,u,a;return Am(this,function(g){return e=x.padAtBorders(n.height,n.width),i=e.y,r=e.ey,o=e.x,s=e.ex,h=o-1,u=i-1,a=t.getImageData(h,u,s-h,r-u),[2,wb.isNodejs()?_b(a):createImageBitmap(a)]})})}))];case 1:return r=h.sent(),o=[],r.forEach(function(n){var x=Ob({width:e,height:i}),t=qb(x);t.drawImage(n,0,0,e,i);for(var r=t.getImageData(0,0,e,i).data,s=[],h=0;h<r.length;h+=4)s.push(r[h+2]),s.push(r[h+1]),s.push(r[h]);o.push(s)}),[2,o.map(function(n){var x=bs(function(){var x=Ff(Gs(n,[1,e,i,3]),[0,2,1,3]).toFloat();return Zv(x)});return x})]}})})}function oj(n,x){return bs(function(){var t=nj(n,x),e=Uh(t,[t.shape[0],x.fc1.weights.shape[0]]),i=az(e,x.fc1),r=$v(i,x.prelu4_alpha),o=az(r,x.fc2_1),s=Ih(Af(o,1),1),h=yu(vd(o,s),1),u=az(r,x.fc2_2),a=Yh(h,1)[1];return{scores:a,regions:u}})}function sj(n,x,t,e,i){return Cm(this,void 0,void 0,function(){var r,o,s,h,u,a,g,l,c,d,f,p,y,m;return Am(this,function(b){switch(b.label){case 0:return r=Date.now(),[4,rj(n,x,{width:24,height:24})];case 1:return o=b.sent(),i.stage2_extractImagePatches=Date.now()-r,r=Date.now(),s=o.map(function(n){var x=oj(n,e);return n.dispose(),x}),i.stage2_rnet=Date.now()-r,h=s.length>1?ih(s.map(function(n){return n.scores})):s[0].scores,g=(a=Array).from,[4,h.data()];case 2:return u=g.apply(a,[b.sent()]),h.dispose(),l=u.map(function(n,x){return{score:n,idx:x}}).filter(function(n){return n.score>t}).map(function(n){var x=n.idx;return x}),c=l.map(function(n){return x[n]}),d=l.map(function(n){return u[n]}),f=[],p=[],c.length>0&&(r=Date.now(),y=Jm(c,d,.7),i.stage2_nms=Date.now()-r,m=y.map(function(n){var x=s[l[n]].regions.arraySync();return new Xv(x[0][0],x[0][1],x[0][2],x[0][3])}),p=y.map(function(n){return d[n]}),f=y.map(function(n,x){return c[n].calibrate(m[x])})),s.forEach(function(n){n.regions.dispose(),n.scores.dispose()}),[2,{boxes:f,scores:p}]}})})}function hj(n,x){return bs(function(){var t=nj(n,x);t=gf(t,[2,2],[2,2],"same"),t=Yb(t,x.conv4,"valid"),t=$v(t,x.prelu4_alpha);var e=Uh(t,[t.shape[0],x.fc1.weights.shape[0]]),i=az(e,x.fc1),r=$v(i,x.prelu5_alpha),o=az(r,x.fc2_1),s=Ih(Af(o,1),1),h=yu(vd(o,s),1),u=az(r,x.fc2_2),a=az(r,x.fc2_3),g=Yh(h,1)[1];return{scores:g,regions:u,points:a}})}function uj(n,x,t,e,i){return Cm(this,void 0,void 0,function(){var r,o,s,h,u,a,g,l,c,d,f,p,y,m,b;return Am(this,function(z){switch(z.label){case 0:return r=Date.now(),[4,rj(n,x,{width:48,height:48})];case 1:return o=z.sent(),i.stage3_extractImagePatches=Date.now()-r,r=Date.now(),s=o.map(function(n){var x=hj(n,e);return n.dispose(),x}),i.stage3_onet=Date.now()-r,h=s.length>1?ih(s.map(function(n){return n.scores})):s[0].scores,g=(a=Array).from,[4,h.data()];case 2:return u=g.apply(a,[z.sent()]),h.dispose(),l=u.map(function(n,x){return{score:n,idx:x}}).filter(function(n){return n.score>t}).map(function(n){var x=n.idx;return x}),c=l.map(function(n){var x=s[n].regions.arraySync();return new Xv(x[0][0],x[0][1],x[0][2],x[0][3])}),d=l.map(function(n,t){return x[n].calibrate(c[t])}),f=l.map(function(n){return u[n]}),p=[],y=[],m=[],d.length>0&&(r=Date.now(),b=Jm(d,f,.7,!1),i.stage3_nms=Date.now()-r,p=b.map(function(n){return d[n]}),y=b.map(function(n){return f[n]}),m=b.map(function(n,x){return Array(5).fill(0).map(function(t,e){var i=s[n].points.arraySync();return new Um(i[0][e]*(p[x].width+1)+p[x].left,i[0][e+5]*(p[x].height+1)+p[x].top)})})),s.forEach(function(n){n.regions.dispose(),n.scores.dispose(),n.points.dispose()}),[2,{boxes:p,scores:y,points:m}]}})})}var aj=function(n){function x(){return n.call(this,"Mtcnn")||this}return km(x,n),x.prototype.load=function(x){return Cm(this,void 0,void 0,function(){return Am(this,function(t){return console.warn("mtcnn is deprecated and will be removed soon"),[2,n.prototype.load.call(this,x)]})})},x.prototype.loadFromDisk=function(x){return Cm(this,void 0,void 0,function(){return Am(this,function(t){return console.warn("mtcnn is deprecated and will be removed soon"),[2,n.prototype.loadFromDisk.call(this,x)]})})},x.prototype.forwardInput=function(n,x){return void 0===x&&(x={}),Cm(this,void 0,void 0,function(){var t,e,i,r,o,s,h,u,a,g,l,c,d,f,p,y,m,b,z,v,j;return Am(this,function(w){switch(w.label){case 0:if(t=this.params,!t)throw new Error("Mtcnn - load model before inference");if(e=n.canvases[0],!e)throw new Error("Mtcnn - inputCanvas is not defined, note that passing tensors into Mtcnn.forwardInput is not supported yet.");return i={},r=Date.now(),o=bs(function(){return Hv(Ih(im.fromPixels(e)).toFloat())}),s=function(n){return o.dispose(),i.total=Date.now()-r,n},h=o.shape.slice(1),u=h[0],a=h[1],g=new $z(x),l=g.minFaceSize,c=g.scaleFactor,d=g.maxNumScales,f=g.scoreThresholds,p=g.scaleSteps,y=(p||Jv(l,c,[u,a])).filter(function(n){var x=Yv(n,[u,a]);return Math.min(x.width,x.height)>Vv}).slice(0,d),i.scales=y,i.pyramid=y.map(function(n){return Yv(n,[u,a])}),m=Date.now(),[4,ij(o,y,f[0],t.pnet,i)];case 1:return b=w.sent(),i.total_stage1=Date.now()-m,b.boxes.length?(i.stage2_numInputBoxes=b.boxes.length,m=Date.now(),[4,sj(e,b.boxes,f[1],t.rnet,i)]):[2,s({results:[],stats:i})];case 2:return z=w.sent(),i.total_stage2=Date.now()-m,z.boxes.length?(i.stage3_numInputBoxes=z.boxes.length,m=Date.now(),[4,uj(e,z.boxes,f[2],t.onet,i)]):[2,s({results:[],stats:i})];case 3:return v=w.sent(),i.total_stage3=Date.now()-m,j=v.boxes.map(function(n,x){return zz(lb({},new Gm(v.scores[x],new xb(n.left/a,n.top/u,n.width/a,n.height/u),{height:u,width:a})),new ob(v.points[x].map(function(x){return x.sub(new Um(n.left,n.top)).div(new Um(n.width,n.height))}),{width:n.width,height:n.height}))}),[2,s({results:j,stats:i})]}})})},x.prototype.forward=function(n,x){return void 0===x&&(x={}),Cm(this,void 0,void 0,function(){var t;return Am(this,function(e){switch(e.label){case 0:return t=this.forwardInput,[4,Nb(n)];case 1:return[4,t.apply(this,[e.sent(),x])];case 2:return[2,e.sent().results]}})})},x.prototype.forwardWithStats=function(n,x){return void 0===x&&(x={}),Cm(this,void 0,void 0,function(){var t;return Am(this,function(e){switch(e.label){case 0:return t=this.forwardInput,[4,Nb(n)];case 1:return[2,t.apply(this,[e.sent(),x])]}})})},x.prototype.getDefaultModelName=function(){return"mtcnn_model"},x.prototype.extractParamsFromWeigthMap=function(n){return Kv(n)},x.prototype.extractParams=function(n){return Qv(n)},x}(Wb),gj=.4,lj=[new Um(1.603231,2.094468),new Um(6.041143,7.080126),new Um(2.882459,3.518061),new Um(4.266906,5.178857),new Um(9.041765,10.66308)],cj=[117.001,114.697,97.404],dj=function(n){function x(){var x=this,t={withSeparableConvs:!0,iouThreshold:gj,classes:["face"],anchors:lj,meanRgb:cj,isFirstLayerConv2d:!0,filterSizes:[3,16,32,64,128,256,512]};return x=n.call(this,t)||this,x}return km(x,n),Object.defineProperty(x.prototype,"anchors",{get:function(){return this.config.anchors},enumerable:!0,configurable:!0}),x.prototype.locateFaces=function(n,x){return Cm(this,void 0,void 0,function(){var t;return Am(this,function(e){switch(e.label){case 0:return[4,this.detect(n,x)];case 1:return t=e.sent(),[2,t.map(function(n){return new Gm(n.score,n.relativeBox,{width:n.imageWidth,height:n.imageHeight})})]}})})},x.prototype.getDefaultModelName=function(){return"tiny_face_detector_model"},x.prototype.extractParamsFromWeigthMap=function(x){return n.prototype.extractParamsFromWeigthMap.call(this,x)},x}(Rv),fj={ssdMobilenetv1:new yv,tinyFaceDetector:new dj,tinyYolov2:new Bv,mtcnn:new aj,faceLandmark68Net:new Rz,faceLandmark68TinyNet:new Fz,faceRecognitionNet:new Xz,faceExpressionNet:new yz,ageGenderNet:new _z};function pj(n,x){var t={age:x};return Object.assign({},n,t)}var yj=function(n){function x(x,t,e){var i=n.call(this)||this;return i.parentTask=x,i.input=t,i.extractedFaces=e,i}return km(x,n),x}(Nv),mj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.run=function(){return Cm(this,void 0,void 0,function(){var n,x,t=this;return Am(this,function(e){switch(e.label){case 0:return[4,this.parentTask];case 1:return n=e.sent(),[4,Pv(n,this.input,function(n){return Cm(t,void 0,void 0,function(){return Am(this,function(x){switch(x.label){case 0:return[4,Promise.all(n.map(function(n){return fj.faceExpressionNet.predictExpressions(n)}))];case 1:return[2,x.sent()]}})})},this.extractedFaces)];case 2:return x=e.sent(),[2,n.map(function(n,t){return mz(n,x[t])})]}})})},x.prototype.withAgeAndGender=function(){return new wj(this,this.input)},x}(yj),bj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.run=function(){return Cm(this,void 0,void 0,function(){var n,x;return Am(this,function(t){switch(t.label){case 0:return[4,this.parentTask];case 1:return n=t.sent(),n?[4,Lv(n,this.input,function(n){return fj.faceExpressionNet.predictExpressions(n)},this.extractedFaces)]:[2];case 2:return x=t.sent(),[2,mz(n,x)]}})})},x.prototype.withAgeAndGender=function(){return new kj(this,this.input)},x}(yj),zj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.withAgeAndGender=function(){return new qj(this,this.input)},x.prototype.withFaceDescriptors=function(){return new Ej(this,this.input)},x}(mj),vj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.withAgeAndGender=function(){return new Cj(this,this.input)},x.prototype.withFaceDescriptor=function(){return new Sj(this,this.input)},x}(bj),jj=function(n){function x(x,t,e){var i=n.call(this)||this;return i.parentTask=x,i.input=t,i.extractedFaces=e,i}return km(x,n),x}(Nv),wj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.run=function(){return Cm(this,void 0,void 0,function(){var n,x,t=this;return Am(this,function(e){switch(e.label){case 0:return[4,this.parentTask];case 1:return n=e.sent(),[4,Pv(n,this.input,function(n){return Cm(t,void 0,void 0,function(){return Am(this,function(x){switch(x.label){case 0:return[4,Promise.all(n.map(function(n){return fj.ageGenderNet.predictAgeAndGender(n)}))];case 1:return[2,x.sent()]}})})},this.extractedFaces)];case 2:return x=e.sent(),[2,n.map(function(n,t){var e=x[t],i=e.age,r=e.gender,o=e.genderProbability;return pj(Zz(n,r,o),i)})]}})})},x.prototype.withFaceExpressions=function(){return new mj(this,this.input)},x}(jj),kj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.run=function(){return Cm(this,void 0,void 0,function(){var n,x,t,e,i;return Am(this,function(r){switch(r.label){case 0:return[4,this.parentTask];case 1:return n=r.sent(),n?[4,Lv(n,this.input,function(n){return fj.ageGenderNet.predictAgeAndGender(n)},this.extractedFaces)]:[2];case 2:return x=r.sent(),t=x.age,e=x.gender,i=x.genderProbability,[2,pj(Zz(n,e,i),t)]}})})},x.prototype.withFaceExpressions=function(){return new bj(this,this.input)},x}(jj),qj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.withFaceExpressions=function(){return new zj(this,this.input)},x.prototype.withFaceDescriptors=function(){return new Ej(this,this.input)},x}(wj),Cj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.withFaceExpressions=function(){return new vj(this,this.input)},x.prototype.withFaceDescriptor=function(){return new Sj(this,this.input)},x}(kj),Aj=function(n){function x(x,t){var e=n.call(this)||this;return e.parentTask=x,e.input=t,e}return km(x,n),x}(Nv),Ej=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.run=function(){return Cm(this,void 0,void 0,function(){var n,x;return Am(this,function(t){switch(t.label){case 0:return[4,this.parentTask];case 1:return n=t.sent(),[4,Pv(n,this.input,function(n){return Promise.all(n.map(function(n){return fj.faceRecognitionNet.computeFaceDescriptor(n)}))},null,function(n){return n.landmarks.align(null,{useDlibAlignment:!0})})];case 2:return x=t.sent(),[2,x.map(function(x,t){return Fv(n[t],x)})]}})})},x.prototype.withFaceExpressions=function(){return new zj(this,this.input)},x.prototype.withAgeAndGender=function(){return new qj(this,this.input)},x}(Aj),Sj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.run=function(){return Cm(this,void 0,void 0,function(){var n,x;return Am(this,function(t){switch(t.label){case 0:return[4,this.parentTask];case 1:return n=t.sent(),n?[4,Lv(n,this.input,function(n){return fj.faceRecognitionNet.computeFaceDescriptor(n)},null,function(n){return n.landmarks.align(null,{useDlibAlignment:!0})})]:[2];case 2:return x=t.sent(),[2,Fv(n,x)]}})})},x.prototype.withFaceExpressions=function(){return new vj(this,this.input)},x.prototype.withAgeAndGender=function(){return new Cj(this,this.input)},x}(Aj),Ij=function(n){function x(x,t,e){var i=n.call(this)||this;return i.parentTask=x,i.input=t,i.useTinyLandmarkNet=e,i}return km(x,n),Object.defineProperty(x.prototype,"landmarkNet",{get:function(){return this.useTinyLandmarkNet?fj.faceLandmark68TinyNet:fj.faceLandmark68Net},enumerable:!0,configurable:!0}),x}(Nv),Dj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.run=function(){return Cm(this,void 0,void 0,function(){var n,x,t,e,i,r=this;return Am(this,function(o){switch(o.label){case 0:return[4,this.parentTask];case 1:return n=o.sent(),x=n.map(function(n){return n.detection}),this.input instanceof Kr?[4,Pb(this.input,x)]:[3,3];case 2:return e=o.sent(),[3,5];case 3:return[4,Fb(this.input,x)];case 4:e=o.sent(),o.label=5;case 5:return t=e,[4,Promise.all(t.map(function(n){return r.landmarkNet.detectLandmarks(n)}))];case 6:return i=o.sent(),t.forEach(function(n){return n instanceof Kr&&n.dispose()}),[2,n.map(function(n,x){return zz(n,i[x])})]}})})},x.prototype.withFaceExpressions=function(){return new zj(this,this.input)},x.prototype.withAgeAndGender=function(){return new qj(this,this.input)},x.prototype.withFaceDescriptors=function(){return new Ej(this,this.input)},x}(Ij),Oj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.run=function(){return Cm(this,void 0,void 0,function(){var n,x,t,e,i;return Am(this,function(r){switch(r.label){case 0:return[4,this.parentTask];case 1:return n=r.sent(),n?(x=n.detection,this.input instanceof Kr?[4,Pb(this.input,[x])]:[3,3]):[2];case 2:return e=r.sent(),[3,5];case 3:return[4,Fb(this.input,[x])];case 4:e=r.sent(),r.label=5;case 5:return t=e,[4,this.landmarkNet.detectLandmarks(t[0])];case 6:return i=r.sent(),t.forEach(function(n){return n instanceof Kr&&n.dispose()}),[2,zz(n,i)]}})})},x.prototype.withFaceExpressions=function(){return new vj(this,this.input)},x.prototype.withAgeAndGender=function(){return new Cj(this,this.input)},x.prototype.withFaceDescriptor=function(){return new Sj(this,this.input)},x}(Ij),_j=function(n){function x(x,t){void 0===t&&(t=new pv);var e=n.call(this)||this;return e.input=x,e.options=t,e}return km(x,n),x}(Nv),Tj=function(n){function x(){return null!==n&&n.apply(this,arguments)||this}return km(x,n),x.prototype.run=function(){return Cm(this,void 0,void 0,function(){var n,x,t,e;return Am(this,function(i){switch(i.label){case 0:return n=this,x=n.input,t=n.options,t instanceof $z?[4,fj.mtcnn.forward(x,t)]:[3,2];case 1:return[2,i.sent().map(function(n){return n.detection})];case 2:if(e=t instanceof Mv?function(n){return fj.tinyFaceDetector.locateFaces(n,t)}:t instanceof pv?function(n){return fj.ssdMobilenetv1.locateFaces(n,t)}:t instanceof Tv?function(n){return fj.tinyYolov2.locateFaces(n,t)}:null,!e)throw new Error("detectFaces - expected options to be instance of TinyFaceDetectorOptions | SsdMobilenetv1Options | MtcnnOptions | TinyYolov2Options");return[2,e(x)]}})})},x.prototype.runAndExtendWithFaceDetections=function(){var n=this;return new Promise(function(x){return Cm(n,void 0,void 0,function(){var n;return Am(this,function(t){switch(t.label){case 0:return[4,this.run()];case 1:return n=t.sent(),[2,x(n.map(function(n){return lb({},n)}))]}})})})},x.prototype.withFaceLandmarks=function(n){return void 0===n&&(n=!1),new Dj(this.runAndExtendWithFaceDetections(),this.input,n)},x.prototype.withFaceExpressions=function(){return new mj(this.runAndExtendWithFaceDetections(),this.input)},x.prototype.withAgeAndGender=function(){return new wj(this.runAndExtendWithFaceDetections(),this.input)},x}(_j);(function(n){function x(){return null!==n&&n.apply(this,arguments)||this}km(x,n),x.prototype.run=function(){return Cm(this,void 0,void 0,function(){var n,x;return Am(this,function(t){switch(t.label){case 0:return[4,new Tj(this.input,this.options)];case 1:return n=t.sent(),x=n[0],n.forEach(function(n){n.score>x.score&&(x=n)}),[2,x]}})})},x.prototype.runAndExtendWithFaceDetection=function(){var n=this;return new Promise(function(x){return Cm(n,void 0,void 0,function(){var n;return Am(this,function(t){switch(t.label){case 0:return[4,this.run()];case 1:return n=t.sent(),[2,x(n?lb({},n):void 0)]}})})})},x.prototype.withFaceLandmarks=function(n){return void 0===n&&(n=!1),new Oj(this.runAndExtendWithFaceDetection(),this.input,n)},x.prototype.withFaceExpressions=function(){return new bj(this.runAndExtendWithFaceDetection(),this.input)},x.prototype.withAgeAndGender=function(){return new kj(this.runAndExtendWithFaceDetection(),this.input)}})(_j);function Rj(n,x){return void 0===x&&(x=new pv),new Tj(n,x)}function Bj(n,x){if(n.length!==x.length)throw new Error("euclideanDistance: arr1.length !== arr2.length");var t=Array.from(n),e=Array.from(x);return Math.sqrt(t.map(function(n,x){return n-e[x]}).reduce(function(n,x){return n+Math.pow(x,2)},0))}(function(){function n(n,x){void 0===x&&(x=.6),this._distanceThreshold=x;var t=Array.isArray(n)?n:[n];if(!t.length)throw new Error("FaceRecognizer.constructor - expected atleast one input");var e=1,i=function(){return"person "+e++};this._labeledDescriptors=t.map(function(n){if(n instanceof ab)return n;if(n instanceof Float32Array)return new ab(i(),[n]);if(n.descriptor&&n.descriptor instanceof Float32Array)return new ab(i(),[n.descriptor]);throw new Error("FaceRecognizer.constructor - expected inputs to be of type LabeledFaceDescriptors | WithFaceDescriptor<any> | Float32Array | Array<LabeledFaceDescriptors | WithFaceDescriptor<any> | Float32Array>")})}Object.defineProperty(n.prototype,"labeledDescriptors",{get:function(){return this._labeledDescriptors},enumerable:!0,configurable:!0}),Object.defineProperty(n.prototype,"distanceThreshold",{get:function(){return this._distanceThreshold},enumerable:!0,configurable:!0}),n.prototype.computeMeanDistance=function(n,x){return x.map(function(x){return Bj(x,n)}).reduce(function(n,x){return n+x},0)/(x.length||1)},n.prototype.matchDescriptor=function(n){var x=this;return this.labeledDescriptors.map(function(t){var e=t.descriptors,i=t.label;return new hb(i,x.computeMeanDistance(n,e))}).reduce(function(n,x){return n.distance<x.distance?n:x})},n.prototype.findBestMatch=function(n){var x=this.matchDescriptor(n);return x.distance<this.distanceThreshold?x:new hb("unknown",x.distance)},n.prototype.toJSON=function(){return{distanceThreshold:this.distanceThreshold,labeledDescriptors:this.labeledDescriptors.map(function(n){return n.toJSON()})}},n.fromJSON=function(x){var t=x.labeledDescriptors.map(function(n){return ab.fromJSON(n)});return new n(t,x.distanceThreshold)}})();var Mj={name:"FaceDetection",emits:["face-detected","face-lost","error","detection-complete"],props:{videoWidth:{type:Number,default:240},videoHeight:{type:Number,default:240},minConfidence:{type:Number,default:.5},captureInterval:{type:Number,default:2e3},maxCaptures:{type:Number,default:1}},data(){return{modelPath:ae.getters.faceApiUrl,loading:!1,modelsLoaded:!1,cameraStarted:!1,cameraReady:!1,isDetecting:!1,stream:null,detectionInterval:null,capturedImages:[],lastCaptureTime:0}},created(){const n=window.location.href.split("?")?.[1]?.split("=")?.[1];n&&(this.modelPath=n);const x=localStorage.getItem("xc_modelPath");x&&(this.modelPath=x)},async mounted(){await this.loadModels(),await this.autoStartDetection()},beforeDestroy(){this.cleanup()},methods:{h_back(){this.$emit("back")},async loadModels(){try{this.loading=!0,await Promise.all([fj.tinyFaceDetector.loadFromUri(this.modelPath),fj.faceLandmark68Net.loadFromUri(this.modelPath),fj.faceRecognitionNet.loadFromUri(this.modelPath)]),this.modelsLoaded=!0,console.log("人脸检测模型加载完成")}catch(n){this.$emit("error",{type:"model-load-error",error:n})}finally{this.loading=!1}},async autoStartDetection(){if(this.modelsLoaded)try{await this.startCamera(),setTimeout(()=>{this.cameraReady&&this.startDetection()},1e3)}catch(n){console.error("自动开始检测失败:",n)}},async startCamera(){try{this.stream=await navigator.mediaDevices.getUserMedia({video:{width:this.videoWidth,height:this.videoHeight,facingMode:"user"}}),this.$refs.video.srcObject=this.stream,this.cameraStarted=!0}catch(n){console.error("摄像头启动失败:",n),this.$emit("error",{type:"camera-error",error:n})}},onVideoLoaded(){this.cameraReady=!0,console.log("摄像头准备就绪"),this.modelsLoaded&&!this.isDetecting&&setTimeout(()=>{this.startDetection()},500)},stopCamera(){this.stopDetection(),this.stream&&(this.stream.getTracks().forEach(n=>n.stop()),this.stream=null),this.cameraStarted=!1,this.cameraReady=!1},startDetection(){this.modelsLoaded&&this.cameraReady&&(this.isDetecting=!0,this.detectionInterval=setInterval(()=>{this.detectFaces()},100))},stopDetection(){this.isDetecting=!1,this.detectionInterval&&(clearInterval(this.detectionInterval),this.detectionInterval=null);const n=this.$refs.overlay,x=n.getContext("2d");x.clearRect(0,0,n.width,n.height)},toggleDetection(){this.isDetecting?this.stopDetection():this.startDetection()},async detectFaces(){const n=this.$refs.video,x=this.$refs.overlay;if(n&&x)try{const t=await Rj(n,new Mv).withFaceLandmarks().withFaceDescriptors(),e=x.getContext("2d");if(e.clearRect(0,0,x.width,x.height),t.length>0){t.forEach(n=>{const{x:x,y:t,width:i,height:r}=n.detection.box;e.strokeStyle="#00ff00",e.lineWidth=2,e.strokeRect(x,t,i,r),e.fillStyle="#00ff00",e.font="16px Arial",e.fillText(`${(100*n.detection.score).toFixed(1)}%`,x,t-10)});const n=Date.now();n-this.lastCaptureTime>this.captureInterval&&(this.captureHighConfidenceFaces(t),this.lastCaptureTime=n),this.$emit("face-detected",t),this.onFaceDetectedComplete(t)}else this.$emit("face-lost")}catch(t){console.error("人脸检测失败:",t),this.$emit("error",{type:"detection-error",error:t})}},captureHighConfidenceFaces(n){const x=this.$refs.video;n.forEach(n=>{if(n.detection.score>=this.minConfidence){const t=document.createElement("canvas"),e=t.getContext("2d"),{x:i,y:r,width:o,height:s}=n.detection.box,h=1,u=1,a=1,g=s*(1+h+a),l=o*(1+2*u),c=Math.max(0,i-o*u),d=Math.max(0,r-s*h),f=x.videoWidth||this.videoWidth,p=x.videoHeight||this.videoHeight,y=Math.max(0,c),m=Math.max(0,d),b=Math.min(l,f-y),z=Math.min(g,p-m);t.width=b,t.height=z,e.drawImage(x,y,m,b,z,0,0,b,z);const v=t.toDataURL("image/jpeg",.8);this.capturedImages.unshift({dataUrl:v,confidence:n.detection.score,timestamp:Date.now(),box:n.detection.box,expandedBox:{x:y,y:m,width:b,height:z}}),this.capturedImages.length>this.maxCaptures&&(this.capturedImages=this.capturedImages.slice(0,this.maxCaptures)),console.log("捕获到高置信度人脸:",n.detection.score)}})},async copyToClipboard(n){try{await navigator.clipboard.writeText(n),console.log("Base64已复制到剪贴板")}catch(x){console.error("复制失败:",x)}},onFaceDetectedComplete(n){this.stopDetection(),this.stopCamera(),this.$emit("detection-complete",{detections:n,capturedImages:this.capturedImages})},cleanup(){this.stopCamera(),this.capturedImages=[]},async restartAuthentication(){try{console.log("开始重新认证..."),this.cleanup(),this.capturedImages=[],this.lastCaptureTime=0,this.modelsLoaded||await this.loadModels(),await this.autoStartDetection(),this.$emit("restart-authentication")}catch(n){console.error("重新认证启动失败:",n),this.$emit("error",{type:"restart-error",error:n})}}}},Nj=Mj,Fj=Ie(Nj,Ei,Si,!1,null,"5308c508",null),Pj=Fj.exports,Lj=function(){var n=this,x=n._self._c;return x("div",{directives:[{name:"loading",rawName:"v-loading",value:n.loading,expression:"loading"}],staticClass:"face-picture"},[x("img",{attrs:{src:n.src,width:"100%",height:"100%"}}),x("div",{staticClass:"delete-batn",on:{click:n.handleDelete}},[x("i",{staticClass:"el-icon-delete",staticStyle:{size:"20px"}})])])},Hj=[],Uj={props:{row:Object},data(){return{src:null,loading:!1}},created(){},mounted(){this.loadFaceImage()},methods:{handleDelete(){this.handleClearFaceInfo()},loadFaceImage(){if(!this.row?.userId)return void console.warn("用户ID不存在,无法加载人脸信息");const n=!1;this.src=n?`/face/photo?userId=${this.row?.userId}`:ae.getters.authUrl+`/face/photo?userId=${this.row?.userId}`},handleClearFaceInfo(){this.$confirm("确定要清除人脸信息吗?","提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{this.loading=!0,fi({userId:this.row?.userId}).then(()=>{this.$emit("clear-face"),this.$message.success("人脸信息已清除")}).finally(()=>{this.loading=!1})}).catch(()=>{})}}},Vj=Uj,Wj=Ie(Vj,Lj,Hj,!1,null,"8a1623a6",null),Qj=Wj.exports,Gj={name:"FaceRegister",props:{row:Object,options:Array},components:{ChooseCameraOrPicture:vi,UploadPicture:Ai,FaceDetected:Pj,FacePicture:Qj},data(){const n=this.row?.userId;return{userId:n,chooseType:"loading",uploading:!1,userIdMissing:!1}},created(){this.checkFaceInfo()},methods:{checkFaceInfo(){di({userId:this.userId}).then(n=>{this.chooseType=n.data?"face-info":""})},handleBack(){this.chooseType=""},handleClose(){},handleChoose(n){this.chooseType="camera"===n?"camera":"picture"},handleClearFace(){this.checkFaceInfo()},handleRefresh(){window.location.reload()},handleUploadSuccess(){this.checkFaceInfo()},async handleDetectionComplete(n){if(this.userId)if(n.capturedImages&&0!==n.capturedImages.length)try{this.uploading=!0,this.chooseType="";const x=n.capturedImages[0],t=x.dataUrl,e=this.base64ToFile(t,"face-detected.jpg"),i=new FormData;i.append("file",e),i.append("userId",this.userId),i.append("userName",this.row?.row?.name||""),await ci(i),this.$message.success("人脸注册成功!"),this.checkFaceInfo()}catch(x){console.error("人脸上传失败:",x),this.chooseType=""}finally{this.uploading=!1}else this.$message.error("未检测到人脸图片");else this.$message.error("用户信息不完整,无法进行人脸注册")},base64ToFile(n,x){const t=n.split(","),e=t[0].match(/:(.*?);/)[1],i=atob(t[1]);let r=i.length;const o=new Uint8Array(r);while(r--)o[r]=i.charCodeAt(r);return new File([o],x,{type:e})}}},Kj=Gj,Yj=Ie(Kj,ui,ai,!1,null,"d4c502b4",null),Jj=Yj.exports,Xj=function(){var n=this,x=n._self._c;return x("div",{directives:[{name:"loading",rawName:"v-loading",value:n.loading,expression:"loading"}],staticClass:"p-12"},[x("el-table",{ref:"table",attrs:{data:n.tableData,stripe:"","header-cell-style":{background:"#f7f8fa"}},on:{"selection-change":n.h_selectionChange,"row-click":n.h_rowClick}},[x("el-table-column",{attrs:{type:"selection",width:"75"}}),x("el-table-column",{attrs:{type:"index",label:"序号",width:"80"}}),x("el-table-column",{attrs:{prop:"icCard",label:"身份卡号"}})],1),x("div",{staticClass:"flex-center mt-12"},[x("el-button",{staticStyle:{"border-radius":"8px",padding:"7px 20px"},attrs:{type:"primary",icon:"el-icon-circle-plus-outline"},on:{click:n.h_add}},[n._v("添加")]),x("el-button",{staticStyle:{"border-radius":"8px",padding:"7px 20px"},attrs:{icon:"el-icon-delete",type:"danger"},on:{click:n.h_remove}},[n._v("移除")])],1),n.visible?x("register-dialog",{attrs:{row:n.row},on:{closed:function(x){n.visible=!1},refresh:n.h_loadData}}):n._e()],1)},Zj=[];const $j=n=>li({url:"/userICCard/add",method:"post",data:n}),nw=n=>li({url:"/icCard/findNoBindICCard",method:"get",params:n}),xw=n=>li({url:"/userICCard/deleteByIcCard",method:"post",data:n}),tw=n=>li({url:"/userICCard/findByUserId",method:"get",params:n});var ew=function(){var n=this,x=n._self._c;return x("el-dialog",{attrs:{visible:n.visible,width:"580px",title:"normal"===n.component?"新增身份卡":"选择身份卡","append-to-body":""},on:{closed:n.closed,close:n.h_close}},["normal"===n.component?x("div",[x("div",{staticClass:"p-12 pr-32"},[x("el-form",{attrs:{model:n.form,"label-width":"100px"}},[x("el-form-item",{attrs:{label:"身份卡号"}},[x("el-input",{attrs:{placeholder:"请输入或者使用刷卡器刷卡"},model:{value:n.form.cardNo,callback:function(x){n.$set(n.form,"cardNo",x)},expression:"form.cardNo"}})],1)],1)],1),x("div",{staticClass:"select-section"},[x("el-button",{staticClass:"select-button",attrs:{type:"text"},on:{click:n.h_selectCard}},[n._v(" 选择已录入身份卡 >> ")])],1),x("div",{staticClass:"dialog-footer f_center",staticStyle:{"margin-top":"100px"}},[x("el-button",{attrs:{loading:n.loading},on:{click:n.h_close}},[n._v("取消")]),x("el-button",{attrs:{type:"primary",loading:n.loading},on:{click:function(x){return n.h_submit(null)}}},[n._v("确定")])],1)]):n._e(),"table"===n.component?x("div",[x("card-table",{attrs:{loading:n.loading},on:{back:n.h_back,submit:n.h_submit}})],1):n._e()])},iw=[],rw=function(){var n=this,x=n._self._c;return x("div",{directives:[{name:"loading",rawName:"v-loading",value:n.loading,expression:"loading"}]},[x("el-table",{ref:"table",attrs:{data:n.tableData,stripe:"","header-cell-style":{background:"#f7f8fa"}},on:{"selection-change":n.h_selectionChange,"row-click":n.h_rowClick}},[x("el-table-column",{attrs:{type:"selection",width:"75"}}),x("el-table-column",{attrs:{type:"index",label:"序号",width:"80"}}),x("el-table-column",{attrs:{prop:"icCard",label:"IC卡号"}}),x("el-table-column",{attrs:{prop:"createdTime",label:"录入时间"}})],1),n._e(),x("div",{staticClass:"flex-center mt-42"},[x("el-button",{on:{click:n.h_back}},[n._v("返回")]),x("el-button",{attrs:{type:"primary"},on:{click:n.h_submit}},[n._v("确定")])],1)],1)},ow=[],sw={name:"CardTable",props:{loading:{type:Boolean,default:!1}},data(){return{tableData:[],selection:[],pagination:{current:1,size:5,total:0}}},created(){this.f_loadData()},methods:{h_rowClick(n){this.$refs.table.toggleRowSelection(n)},h_currentChange(n){this.table.pagination.current=n,this.f_loadData()},h_back(){this.$emit("back")},h_submit(){0!==this.selection.length?this.$emit("submit",this.selection):this.$message.warning("请选择要添加的IC卡")},f_loadData(){nw({keyword:null}).then(n=>{this.tableData=n.data})},h_selectionChange(n){this.selection=n}}},hw=sw,uw=Ie(hw,rw,ow,!1,null,"49d6fcb9",null),aw=uw.exports,gw={name:"RegisterDialog",components:{CardTable:aw},props:{row:{type:Object,default:()=>{}}},data(){return{loading:!1,component:"normal",visible:!1,form:{cardNo:""}}},created(){},mounted(){this.visible=!0,this.$authEventBus.$on("card",this.h_card)},beforeDestroy(){this.$authEventBus.$off("card",this.h_card)},methods:{h_card(n){0!==n.result&&200!==n.status||(this.form.cardNo=n.data)},h_back(){this.component="normal"},h_submit(n){this.loading=!0,console.log("cardInfos",n);let x={userId:this.row.userId,userName:this.row.row.name,icCards:[this.form.cardNo],tenantId:""};n&&(x={userId:this.row.userId,userName:this.row.row.name,icCards:n.map(n=>n.icCard),tenantId:""}),$j(x).then(()=>{this.$message.success("新增成功"),this.visible=!1,this.$emit("refresh")}).finally(()=>{this.loading=!1})},h_close(){this.visible=!1},closed(){this.$emit("closed")},h_selectCard(){this.component="table"}}},lw=gw,cw=Ie(lw,ew,iw,!1,null,"37d5a920",null),dw=cw.exports,fw={name:"CardRegister",components:{RegisterDialog:dw},props:{row:{type:Object,default:()=>{}}},data(){return{tableData:[],selection:[],visible:!1,loading:!1}},created(){this.h_loadData()},methods:{h_rowClick(n){this.$refs.table.toggleRowSelection(n)},h_loadData(){this.loading=!0,tw({userId:this.row.userId}).then(n=>{this.tableData=n.data}).finally(()=>{this.loading=!1})},h_add(){this.visible=!0},h_remove(){this.$confirm("确定移除选中的身份卡吗?","提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{this.loading=!0,xw(this.selection.map(n=>n.icCardId)).then(()=>{this.$message.success("移除成功"),this.h_loadData()}).finally(()=>{this.loading=!1})}).catch(()=>{})},h_selectionChange(n){this.selection=n}}},pw=fw,yw=Ie(pw,Xj,Zj,!1,null,"6f88fce1",null),mw=yw.exports,bw=function(){var n=this,x=n._self._c;return x("div",{staticClass:"flex-center align-center h100 w100"},[x("div",{staticClass:"finger-dialog"},[x("div",{staticClass:"finger-register-content"},[x("div",{staticStyle:{color:"#333","font-size":"24px","margin-bottom":"12px","padding-top":"48px","text-align":"center","margin-top":"24px"}},[n._v(" "+n._s(n.stepTips)+" ")]),x("div",{staticStyle:{display:"flex","justify-content":"center","align-items":"center","padding-top":"50px"}},[x("div",{staticClass:"hand-area left-hand"},[x("div",{staticClass:"hand-image-wrapper"},[x("img",{staticClass:"hand-image",attrs:{src:n.leftHandleImg}}),x("div",{staticClass:"finger-buttons-overlay"},n._l(n.leftFingers,function(t,e){return x("div",{key:"left-"+e,class:["finger-circle",{active:n.selectedFinger&&n.selectedFinger.value===t.value,ready:!!t.fingerInfo}],style:{top:t.top+"px",left:t.left+"px"},on:{click:function(x){return n.handleSelectFinger(t)}}})}),0)])]),x("div",{staticClass:"hand-area right-hand"},[x("div",{staticClass:"hand-image-wrapper"},[x("img",{staticClass:"hand-image",attrs:{src:n.rightHandleImg}}),x("div",{staticClass:"finger-buttons-overlay"},n._l(n.rightFingers,function(t,e){return x("div",{key:"right-"+e,class:["finger-circle",{active:n.selectedFinger&&n.selectedFinger.value===t.value,ready:!!t.fingerInfo}],style:{top:t.top+"px",left:t.left+"px"},on:{click:function(x){return n.handleSelectFinger(t)}}})}),0)])]),x("div",{staticClass:"fingerprint-status"},[x("div",{staticClass:"fingerprint-image-container"},[x("div",{staticClass:"delete-button"},[n.selectedFinger&&n.selectedFinger.fingerInfo?x("el-button",{attrs:{type:"text",size:"large"},on:{click:n.handleDeleteFinger}},[x("i",{staticClass:"el-icon-delete",staticStyle:{"font-size":"20px",color:"#999"}})]):n._e()],1),x("img",{staticClass:"fingerprint-image",attrs:{src:n.realFingerprintImage}}),x("p",{staticClass:"status-text"},[n._v(" "+n._s(n.fingerStatusText)+" ")])])])])])])])},zw=[];function vw(n){return li({url:"/finger/maxFingerSeq",method:"post",data:n})}function jw(n){return li({url:"/finger/upload",method:"post",data:n})}function ww(n){return li({url:"/finger/findByUserId",method:"post",data:n})}function kw(n){return li({url:"/finger/delete",method:"post",params:n})}const qw="",Cw="",Aw="",Ew="",Sw="",Iw="",Dw="",Ow="";var _w={name:"FingerRegisterView",props:{row:{type:Object,default:()=>{}}},data(){return{fingerRegisterStep:0,currentFingerprintImage:"/public/finger-status-start.png",gifTimeoutId:null,selectedFinger:null,fingerTemp:null,fingerId:null,fid:null,loading:!1,leftFingers:[{label:"大拇指",value:"left-thumb",top:122,left:6,index:0,fingerInfo:null},{label:"食指",value:"left-index",top:20,left:60,index:1,fingerInfo:null},{label:"中指",value:"left-middle",top:3,left:98,index:2,fingerInfo:null},{label:"无名指",value:"left-ring",top:12,left:136,index:3,fingerInfo:null},{label:"小拇指",value:"left-little",top:35,left:176,index:4,fingerInfo:null}],rightFingers:[{label:"大拇指",value:"right-thumb",top:118,left:178,index:5,fingerInfo:null},{label:"食指",value:"right-index",top:16,left:121,index:6,fingerInfo:null},{label:"中指",value:"right-middle",top:0,left:83,index:7,fingerInfo:null},{label:"无名指",value:"right-ring",top:11,left:43,index:8,fingerInfo:null},{label:"小拇指",value:"right-little",top:42,left:5,index:9,fingerInfo:null}]}},computed:{userId(){return this.row.userId},devSn(){return ae.getters.getFingerprintDeviceSN},devType(){return 1},tenantId(){return null},leftHandleImg(){return this.selectedFinger&&this.selectedFinger.value.includes("left")?e(9165):e(288)},rightHandleImg(){return this.selectedFinger&&this.selectedFinger.value.includes("right")?e(4862):e(9637)},realFingerprintImage(){return"/public/finger-status-start.png"===this.currentFingerprintImage?Ow:"/public/finger-status-1.gif"===this.currentFingerprintImage?qw:"/public/finger-status-1-last.png"===this.currentFingerprintImage?Ew:"/public/finger-status-2.gif"===this.currentFingerprintImage?Cw:"/public/finger-status-2-last.png"===this.currentFingerprintImage?Sw:"/public/finger-status-3.gif"===this.currentFingerprintImage?Aw:"/public/finger-status-3-last.png"===this.currentFingerprintImage?Iw:"/public/finger-status-compeleted.png"===this.currentFingerprintImage?Dw:Ow},stepTips(){return-1===this.fingerRegisterStep?"指纹采集异常,请重试!":0===this.fingerRegisterStep?"请选择需要采集的手指":1===this.fingerRegisterStep?"请将手指放在设备上":2===this.fingerRegisterStep?"请再次将手指放在设备上":3===this.fingerRegisterStep?"最后一次将手指放在设备上":4===this.fingerRegisterStep?"正在指纹采集":5===this.fingerRegisterStep?"指纹采集成功":"未知状态"},fingerStatusText(){return-1===this.fingerRegisterStep?"指纹采集异常,请重试!":0===this.fingerRegisterStep?"采集指纹一共需要三次按压":1===this.fingerRegisterStep?"请将手指放在设备上":2===this.fingerRegisterStep?"请再次将手指放在设备上":3===this.fingerRegisterStep?"最后一次将手指放在设备上":4===this.fingerRegisterStep?"正在处理指纹数据...":5===this.fingerRegisterStep?"指纹采集成功":"准备采集指纹"}},watch:{fingerRegisterStep(n){clearTimeout(this.gifTimeoutId);const x=800;1===n||0===n||-1===n?this.currentFingerprintImage="/public/finger-status-start.png":2===n?(this.currentFingerprintImage="/public/finger-status-1.gif",this.gifTimeoutId=setTimeout(()=>{this.currentFingerprintImage="/public/finger-status-1-last.png"},x)):3===n?(this.currentFingerprintImage="/public/finger-status-2.gif",this.gifTimeoutId=setTimeout(()=>{this.currentFingerprintImage="/public/finger-status-2-last.png"},x)):4===n?(this.currentFingerprintImage="/public/finger-status-3.gif",this.gifTimeoutId=setTimeout(()=>{this.currentFingerprintImage="/public/finger-status-3-last.png"},x)):5===n&&(this.currentFingerprintImage="/public/finger-status-compeleted.png")}},mounted(){this.loadCurrentUserFingerInfo(),this.$authEventBus.$on("startCollectionMessage",this.startCollectionMessage)},beforeDestroy(){clearTimeout(this.gifTimeoutId),this.$authEventBus.$off("startCollectionMessage",this.startCollectionMessage),this.fingerRegisterStep>0&&this.fingerRegisterStep<5&&this.cancelCollection()},methods:{cancelCollection(){this.$authEventBus.$emit("cancelCollection")},handleCancelCollection(){this.$confirm("确定要退出指纹采集吗?","提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{this.cancelCollection(),this.$message.info("已退出指纹采集")}).catch(()=>{})},startCollectionMessage(n){if(console.log("startCollectionMessage:",n),200===n.status||0===n.result){const{count:x,temp:t,image:e}=n.data;console.log(`指纹采集进度: ${x}/4`),1===x?this.fingerRegisterStep=2:2===x?this.fingerRegisterStep=3:3===x?this.fingerRegisterStep=4:4===x&&(this.fingerRegisterStep=5,this.fingerTemp=t,console.log("✅ 指纹采集完成,获取到指纹模板"),this.$nextTick(()=>{this.addFingerprint()})),e&&console.log("收到指纹图像数据")}else console.error("指纹采集失败:",n.msg||"未知错误"),this.fingerRegisterStep=-1,this.$message?.error?.(n.msg||"指纹采集失败,请重试")},handleClose(){},async handleSelectFinger(n){if(this.fingerRegisterStep>0&&this.fingerRegisterStep<5)this.$message({message:"指纹采集尚未完成,请先完成当前采集",type:"warning"});else if(n.fingerInfo)this.selectedFinger=n;else try{const x=await vw({devSn:this.devSn,devType:this.devType,fingerNo:n.index,tenantId:this.tenantId,userId:this.userId});this.fingerId=x.data.fingerId,this.fid=x.data.fingerSeq,this.selectedFinger=n,this.fingerRegisterStep=1,this.fingerTemp=null,console.log(`开始采集 ${n.label} 指纹,fingerId: ${this.fingerId}, fid: ${this.fid}`),this.startCollection()}catch(x){console.error("获取指纹信息失败:",x)}},handleSaveFingerprint(){this.addFingerprint()},handleDeleteFinger(){this.$confirm("确定删除指纹吗?").then(()=>{kw({fingerId:this.selectedFinger.fingerInfo.id}).then(()=>{this.selectedFinger=null,this.fingerRegisterStep=0,this.$message.success("删除成功"),this.loadCurrentUserFingerInfo()})}).catch(()=>{})},startCollection(){this.$authEventBus.$emit("startCollection")},loadCurrentUserFingerInfo(){ww({devType:this.devType,tenantId:this.tenantId,userId:this.userId}).then(n=>{const x=n.data,t=this.leftFingers.map(n=>{const t=x.find(x=>x.fingerNo===n.index);return{...n,fingerInfo:t}}),e=this.rightFingers.map(n=>{const t=x.find(x=>x.fingerNo===n.index);return{...n,fingerInfo:t}});this.leftFingers=t,this.rightFingers=e})},addFingerprint(){this.fingerId?this.fingerTemp?this.selectedFinger?this.fid?(this.loading=!0,console.log("开始保存指纹到服务器..."),jw({data:this.fingerTemp,fingerId:this.fingerId}).then(()=>{console.log("✅ 指纹保存成功"),this.loadCurrentUserFingerInfo(),this.selectedFinger=null,this.fingerRegisterStep=0,this.fingerTemp=null,this.fingerId=null,this.fid=null,this.$message.success("指纹录入成功!")}).catch(n=>{console.error("❌ 指纹保存失败:",n),this.fingerRegisterStep=-1}).finally(()=>{this.loading=!1})):this.$message.error("未获取到指纹序列号"):this.$message.error("请先选择手指"):this.$message.error("未获取到指纹模板"):this.$message.error("未获取到指纹ID")}}},Tw=_w,Rw=Ie(Tw,bw,zw,!1,null,"334b3efe",null),Bw=Rw.exports,Mw={name:"auth-com",components:{FaceRegister:Jj,CardRegister:mw,FingerRegister:Bw},props:{authCollect:{type:Array,default:()=>[]},drawerInfo:{type:Object,default:()=>{}}},data(){return{authList:[],activeName:""}},computed:{modules(){return this.authCollect??[]},options(){return this.modules&&this.modules.find(n=>"face"===n.value).options||[]}},mounted(){this.h_init()},methods:{h_init(){this.modules.length&&(this.activeName=this.modules[0].value)}}},Nw=Mw,Fw=Ie(Nw,si,hi,!1,null,"4bde6ad6",null),Pw=Fw.exports,Lw=function(){var n=this,x=n._self._c;return x("div",{staticClass:"flex-center align-center h100"},[x("el-empty",{staticStyle:{"font-size":"20px"},attrs:{description:"请先保存用户信息"}})],1)},Hw=[],Uw={name:"empty-view"},Vw=Uw,Ww=Ie(Vw,Lw,Hw,!1,null,"9e253eac",null),Qw=Ww.exports,Gw={name:"user-drawer",components:{UserInfo:oi,AuthCom:Pw,EmptyView:Qw},props:{drawerStyle:{type:String,default:""},authCollect:{required:!1,type:Array,default:()=>[]},drawerInfo:{type:Object},userBeforeCreate:{type:Function,default:()=>!0}},data(){return{visible:!1,loading:!1}},mounted(){this.visible=!0},methods:{closed(){this.$emit("closed")},h_back(){this.visible=!1},async f_save(){const n=this.userBeforeCreate(this.$refs["user-info"].h_getFormData(),this.drawerInfo);this.userBeforeCreate&&!n||this.$refs["user-info"].h_validate().then(n=>{if(console.log("valid",n),!n)return;const x=this.$refs["user-info"].h_getFormData();this.loading=!0,ve({...x,organId:this.drawerInfo.organ.id,accountEnabled:x.accountEnabled}).then(()=>{this.$emit("refresh"),this.visible=!1}).catch(n=>{console.error("用户状态 err",n)}).finally(()=>{this.loading=!1})})}}},Kw=Gw,Yw=Ie(Kw,Xe,Ze,!1,null,"8c86d64a",null),Jw=Yw.exports,Xw=e(4747),Zw=e.n(Xw);class $w{constructor(n,x={}){this.url=n,this.options={reconnectInterval:5e3,maxReconnectAttempts:10,heartbeatInterval:12e4,...x},this.ws=null,this.reconnectAttempts=0,this.isConnected=!1,this.heartbeatTimer=null,this.eventListeners=new Map,this.onOpen=this.onOpen.bind(this),this.onMessage=this.onMessage.bind(this),this.onError=this.onError.bind(this),this.onClose=this.onClose.bind(this)}connect(){try{this.ws=new WebSocket(this.url),this.ws.onopen=this.onOpen,this.ws.onmessage=this.onMessage,this.ws.onerror=this.onError,this.ws.onclose=this.onClose}catch(n){console.error("WebSocket连接失败:",n),this.handleReconnect()}}onOpen(n){console.log("WebSocket连接成功"),this.isConnected=!0,this.reconnectAttempts=0,this.startHeartbeat(),this.emit("open",n)}onMessage(n){try{const x=JSON.parse(n.data);if(console.log("收到WebSocket消息:",x),"pong"===x.type)return;this.emit("message",x)}catch(x){console.error("解析WebSocket消息失败:",x),this.emit("message",n.data)}}onError(n){console.error("WebSocket错误:",n),this.emit("error",n)}onClose(n){console.log("WebSocket连接关闭:",n.code,n.reason),this.isConnected=!1,this.stopHeartbeat(),this.emit("close",n),1e3!==n.code&&this.handleReconnect()}send(n){if(!this.isConnected||this.ws.readyState!==WebSocket.OPEN)return console.warn("WebSocket未连接,无法发送消息"),!1;try{const x="string"===typeof n?n:JSON.stringify(n);return this.ws.send(x),console.log("发送WebSocket消息:",n),!0}catch(x){return console.error("发送WebSocket消息失败:",x),!1}}on(n,x){this.eventListeners.has(n)||this.eventListeners.set(n,[]),this.eventListeners.get(n).push(x)}off(n,x){const t=this.eventListeners.get(n);if(t){const n=t.indexOf(x);n>-1&&t.splice(n,1)}}emit(n,x){const t=this.eventListeners.get(n);t&&t.forEach(t=>{try{t(x)}catch(e){console.error(`事件监听器执行失败 [${n}]:`,e)}})}handleReconnect(){this.reconnectAttempts<this.options.maxReconnectAttempts?(this.reconnectAttempts++,console.log(`尝试重连WebSocket (${this.reconnectAttempts}/${this.options.maxReconnectAttempts})`),setTimeout(()=>{this.connect()},this.options.reconnectInterval)):(console.error("WebSocket重连次数已达上限"),this.emit("reconnectFailed"))}startHeartbeat(){this.stopHeartbeat(),this.heartbeatTimer=setInterval(()=>{this.isConnected&&this.send({type:"ping",timestamp:Date.now()})},this.options.heartbeatInterval)}stopHeartbeat(){this.heartbeatTimer&&(clearInterval(this.heartbeatTimer),this.heartbeatTimer=null)}close(){this.stopHeartbeat(),this.ws&&this.ws.close(1e3,"主动关闭"),this.isConnected=!1}getReadyState(){return this.ws?this.ws.readyState:WebSocket.CLOSED}isOpen(){return this.isConnected&&this.ws&&this.ws.readyState===WebSocket.OPEN}}var nk=$w,xk={name:"auth-manage",props:{drawerStyle:{type:String,default:""},authCollect:{required:!1,type:Array,default:()=>["face","finger","idCard"]},userBeforeCreate:{type:Function,default:()=>!0},beforeCreate:{type:Function,default:()=>!0},baseUrl:{type:String},authUrl:{type:String}},components:{OrganTree:Pe,UserTable:Je,UserDrawer:Jw},data(){return{visible:!1,drawerInfo:{},organTreeKey:"1",websocket:null,cardReader:null,fingerprintDeviceCount:0}},created(){this.baseUrl&&ae.commit("SET_BASE_URL",this.baseUrl),this.authUrl&&ae.commit("SET_AUTH_URL",this.authUrl)},mounted(){console.log("LD-AUTH打包时间为",Zw()(1758247181910).format("YYYY-MM-DD HH:mm:ss")),this.$authEventBus.$on("startCollection",this.handleStartCollection),this.$authEventBus.$on("cancelCollection",this.handleCancelCollection),this.initWebSocket()},beforeDestroy(){this.websocket&&(console.log("🔌 组件销毁,关闭WebSocket连接"),this.websocket.close(),this.websocket=null),this.$authEventBus.$off("startCollection",this.handleStartCollection),this.$authEventBus.$off("cancelCollection",this.handleCancelCollection)},methods:{handleCancelCollection(){this.websocket&&this.websocket.send({action:1010})},handleStartCollection(){if(ae.getters.getFingerprintDeviceSN){const n={action:1001};this.websocket.send(n)}},initWebSocket(){try{this.websocket=new nk(`${ae.state.websocketUrl}`,{reconnectInterval:5e3,maxReconnectAttempts:10,heartbeatInterval:12e4}),this.websocket.on("open",()=>{this.checkCardReaderConnection(),this.getFingerprintDeviceSN()}),this.websocket.on("message",n=>{console.log("📨 收到WebSocket消息:",n),this.handleWebSocketMessage(n)}),this.websocket.on("error",n=>{console.error("❌ WebSocket连接错误:",n)}),this.websocket.on("close",n=>{console.log("🔌 WebSocket连接已关闭:",n.code,n.reason),n.code}),this.websocket.on("reconnectFailed",()=>{console.error("💥 WebSocket重连失败,已达最大重连次数")}),this.websocket.connect()}catch(n){console.error("WebSocket初始化失败:",n)}},handleWebSocketMessage(n){if(n.action)switch(n.action){case 1009:this.handleFingerprintDeviceSNResponse(n);break;case 2001:this.handleCheckCardReaderResponse(n);break;case 2002:this.handleCardReaderListResponse(n);break;case 2003:this.handleOpenCardReaderResponse(n);break;case 2004:this.$authEventBus.$emit("card",n);break;case 1001:this.$authEventBus.$emit("startCollectionMessage",n);break;default:console.log("未知action类型:",n)}else switch(n.type){case"user_update":console.log("用户信息更新:",n.payload),this.f_userData();break;case"organ_update":console.log("组织架构更新:",n.payload),this.f_refreshTree();break;case"auth_status":console.log("认证状态更新:",n.payload),this.$message?.info?.(n.payload.message||"认证状态已更新");break;case"notification":console.log("系统通知:",n.payload),this.$message?.info?.(n.payload.message||"收到系统通知");break;default:console.log("未知消息类型:",n)}},sendWebSocketMessage(n,x={}){if(this.websocket&&this.websocket.isOpen()){const t={type:n,payload:x,timestamp:Date.now()};this.websocket.send(t),console.log("📤 发送WebSocket消息:",t)}},getFingerprintDeviceSN(){console.log("🔢 获取指纹设备SN码...");const n={action:1009};this.websocket.send(n),console.log("📤 发送获取指纹设备SN码消息:",n)},handleFingerprintDeviceSNResponse(n){if(console.log("📊 收到指纹设备SN响应:",n),200===n.status||0===n.result){const x=n.data?.sn||"";x?(console.log("✅ 获取到指纹设备SN:",x),ae.dispatch("updateFingerprintDeviceSN",x)):(console.warn("⚠️ 指纹设备SN为空"),ae.dispatch("updateFingerprintDeviceSN",""))}else console.error("❌ 获取指纹设备SN失败:",n.msg||"未知错误")},getFingerprintDeviceStatus(){return{deviceCount:this.fingerprintDeviceCount,hasDevice:this.fingerprintDeviceCount>0,deviceSN:this.$store.getters.getFingerprintDeviceSN}},refreshFingerprintDeviceCount(){this.websocket&&this.websocket.isOpen()?this.getFingerprintDeviceCount():console.warn("WebSocket未连接,无法获取指纹设备数量")},refreshFingerprintDeviceSN(){this.websocket&&this.websocket.isOpen()?this.getFingerprintDeviceSN():console.warn("WebSocket未连接,无法获取指纹设备SN")},refreshAllFingerprintInfo(){this.websocket&&this.websocket.isOpen()?(this.getFingerprintDeviceCount(),this.getFingerprintDeviceSN()):console.warn("WebSocket未连接,无法获取指纹设备信息")},checkCardReaderConnection(){console.log("🔍 检查读卡器连接状态...");const n={action:2001};this.websocket.send(n),console.log("📤 发送检查读卡器连接状态消息:",n)},handleCheckCardReaderResponse(n){console.log("📊 收到读卡器连接状态响应:",n),200===n.status||0===n.result?n.data&&n.data.isOpen?(this.cardReader=n.data.devName||"读卡器",console.log("✅ 读卡器已连接:",this.cardReader)):(console.log("⚠️ 读卡器未连接,开始获取读卡器列表..."),this.getCardReaderList()):(console.error("❌ 检查读卡器状态失败:",n.msg||"未知错误"),this.getCardReaderList())},getCardReaderList(){console.log("📡 请求获取读卡器列表...");const n={action:2002};this.websocket.send(n),console.log("📤 发送获取读卡器列表消息:",n)},handleCardReaderListResponse(n){if(console.log("📋 收到读卡器列表响应:",n),n.data&&Array.isArray(n.data)&&n.data.length>0){const x=n.data[0];console.log("🎯 找到读卡器:",x),this.openCardReader(x)}else console.warn("⚠️ 未找到可用的读卡器")},openCardReader(n){const x={action:2003,devName:n};this.websocket.send(x)},handleOpenCardReaderResponse(n){0===n.result||200===n.status?this.cardReader=n.devName||"读卡器":this.$message?.error?.(`读卡器打开失败: ${n.message||n.error||"未知错误"}`)},getCardReaderStatus(){return{isConnected:!!this.cardReader,deviceName:this.cardReader}},reinitCardReader(){this.cardReader=null,this.websocket&&this.websocket.isOpen()?this.checkCardReaderConnection():this.$message?.warning?.("WebSocket未连接,无法初始化读卡器")},getAllDeviceStatus(){return{fingerprint:this.getFingerprintDeviceStatus(),cardReader:this.getCardReaderStatus()}},refreshAllDevices(){this.websocket&&this.websocket.isOpen()?(this.refreshAllFingerprintInfo(),this.checkCardReaderConnection()):this.$message?.warning?.("WebSocket未连接,无法刷新设备状态")},f_refreshTree(){this.organTreeKey=this.organTreeKey+1},f_userData(n){n&&this.$set(this.drawerInfo,"organ",n),this.$refs["user-table"].f_init(this.drawerInfo.organ)},h_setVisible(){this.visible=!1},h_setUserId(n,x){this.$set(this.drawerInfo,"userId",n),this.$set(this.drawerInfo,"row",x),this.visible=!0}}},tk=xk,ek=Ie(tk,r,o,!1,null,"81b3c05e",null),ik=ek.exports;const rk=new(At());var ok=rk;const sk=function(n,x={}){sk.installed||(n.component(ik.name,ik),n.prototype.$authEventBus=ok,void 0!==x.baseUrl&&null!==x.baseUrl&&ae.commit("SET_BASE_URL",x.baseUrl),void 0!==x.authUrl&&null!==x.authUrl&&ae.commit("SET_AUTH_URL",x.authUrl),void 0!==x.websocketUrl&&null!==x.websocketUrl&&ae.commit("SET_WEBSOCKET_URL",x.websocketUrl),void 0!==x.faceApiUrl&&null!==x.faceApiUrl&&ae.commit("SET_FACE_API_URL",x.faceApiUrl))};var hk={install:sk,authManage:ik},uk=hk}(),i=i["default"],i}()});