From 6bb7dd26fd21132398d47822ed54911aa95c0ea4 Mon Sep 17 00:00:00 2001 From: Vladimir Mandic Date: Sun, 29 May 2022 21:12:18 -0400 Subject: [PATCH] updated facemesh and attention models --- CHANGELOG.md | 12 +- TODO.md | 7 + demo/faceid/index.js.map | 2 +- demo/typescript/index.js | 4 +- demo/typescript/index.js.map | 4 +- demo/typescript/index.ts | 6 +- dist/human.esm-nobundle.js | 20 +- dist/human.esm-nobundle.js.map | 6 +- dist/human.esm.js | 15070 ++++++++-------- dist/human.esm.js.map | 6 +- dist/human.js | 897 +- dist/human.node-gpu.js | 20 +- dist/human.node-wasm.js | 20 +- dist/human.node.js | 20 +- dist/tfjs.esm.js | 745 +- models/facemesh-attention.bin | Bin 0 -> 2382414 bytes models/facemesh-attention.json | 2177 +++ models/facemesh-detection-full.bin | Bin 1026192 -> 0 bytes models/facemesh-detection-full.json | 495 - models/facemesh.bin | Bin 2955780 -> 1477958 bytes models/facemesh.json | 494 +- package.json | 12 +- src/draw/face.ts | 8 +- src/face/attention.ts | 95 +- src/face/constants.ts | 263 + src/face/facemesh.ts | 13 +- src/face/facemeshcoords.ts | 16 +- test/build.log | 49 +- test/test-main.js | 16 +- test/test.log | 1368 +- typedoc/classes/Env.html | 2 +- typedoc/classes/GraphModel.html | 16 +- typedoc/classes/Human.html | 6 +- typedoc/classes/Tensor.html | 2 +- typedoc/classes/models.Models.html | 2 +- typedoc/enums/Rank.html | 2 +- typedoc/index.html | 2 +- typedoc/interfaces/BodyConfig.html | 2 +- typedoc/interfaces/BodyKeypoint.html | 2 +- typedoc/interfaces/BodyResult.html | 2 +- typedoc/interfaces/Config.html | 4 +- typedoc/interfaces/FaceAntiSpoofConfig.html | 2 +- typedoc/interfaces/FaceAttentionConfig.html | 2 +- typedoc/interfaces/FaceConfig.html | 2 +- typedoc/interfaces/FaceDescriptionConfig.html | 2 +- typedoc/interfaces/FaceDetectorConfig.html | 2 +- typedoc/interfaces/FaceEmotionConfig.html | 2 +- typedoc/interfaces/FaceIrisConfig.html | 2 +- typedoc/interfaces/FaceLivenessConfig.html | 2 +- typedoc/interfaces/FaceMeshConfig.html | 2 +- typedoc/interfaces/FaceResult.html | 2 +- typedoc/interfaces/FilterConfig.html | 2 +- typedoc/interfaces/GenericConfig.html | 2 +- typedoc/interfaces/GestureConfig.html | 2 +- typedoc/interfaces/HandConfig.html | 2 +- typedoc/interfaces/HandResult.html | 2 +- typedoc/interfaces/ObjectConfig.html | 2 +- typedoc/interfaces/ObjectResult.html | 2 +- typedoc/interfaces/PersonResult.html | 2 +- typedoc/interfaces/Result.html | 2 +- typedoc/interfaces/SegmentationConfig.html | 2 +- typedoc/modules/Tensor.html | 2 +- typedoc/modules/draw.html | 2 +- typedoc/modules/match.html | 2 +- typedoc/modules/models.html | 2 +- wiki | 2 +- 66 files changed, 12102 insertions(+), 9835 deletions(-) create mode 100644 models/facemesh-attention.bin create mode 100644 models/facemesh-attention.json delete mode 100644 models/facemesh-detection-full.bin delete mode 100644 models/facemesh-detection-full.json create mode 100644 src/face/constants.ts diff --git a/CHANGELOG.md b/CHANGELOG.md index 5a7fde4f..2906ed31 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,6 +1,6 @@ # @vladmandic/human - Version: **2.7.3** + Version: **2.8.0** Description: **Human: AI-powered 3D Face Detection & Rotation Tracking, Face Description & Recognition, Body Pose Tracking, 3D Hand & Finger Tracking, Iris Analysis, Age & Gender & Emotion Prediction, Gesture Recognition** Author: **Vladimir Mandic ** @@ -9,11 +9,15 @@ ## Changelog +### **HEAD -> main** 2022/05/24 mandic00@live.com + + +### **2.7.4** 2022/05/24 mandic00@live.com + + ### **2.7.3** 2022/05/24 mandic00@live.com - -### **origin/main** 2022/05/22 mandic00@live.com - +- add face.mesh.keepinvalid config flag - initial work for new facemesh model ### **2.7.2** 2022/05/12 mandic00@live.com diff --git a/TODO.md b/TODO.md index 5c8ac7aa..24665425 100644 --- a/TODO.md +++ b/TODO.md @@ -29,3 +29,10 @@ Feature is automatically disabled in NodeJS without user impact ## Pending Release Notes +- Updated **FaceMesh-Landmarks** models +- Added **FaceMesh-with-Attention** model is disabled by defauls, enable using + `config.face.mesh.attention = true` +- If **FaceMesh-with-Attention** model is anbled, Iris model gets disabled + as its functionality is superseded by attention model +- Results include more detailed face mesh annotations + `result.face[].annotations` diff --git a/demo/faceid/index.js.map b/demo/faceid/index.js.map index de684c96..5a55cff7 100644 --- a/demo/faceid/index.js.map +++ b/demo/faceid/index.js.map @@ -2,6 +2,6 @@ "version": 3, "sources": ["index.ts", "indexdb.ts"], "sourcesContent": ["/**\n * Human demo for browsers\n * @default Human Library\n * @summary \n * @author \n * @copyright \n * @license MIT\n */\n\nimport { Human, TensorLike, FaceResult } from '../../dist/human.esm.js'; // equivalent of @vladmandic/Human\nimport * as indexDb from './indexdb'; // methods to deal with indexdb\n\nconst humanConfig = { // user configuration for human, used to fine-tune behavior\n modelBasePath: '../../models',\n filter: { equalization: true }, // lets run with histogram equilizer\n face: {\n enabled: true,\n detector: { rotation: true, return: true, cropFactor: 1.6, mask: false }, // return tensor is used to get detected face image\n description: { enabled: true }, // default model for face descriptor extraction is faceres\n mobilefacenet: { enabled: false, modelPath: 'https://vladmandic.github.io/human-models/models/mobilefacenet.json' }, // alternative model\n iris: { enabled: true }, // needed to determine gaze direction\n emotion: { enabled: false }, // not needed\n antispoof: { enabled: true }, // enable optional antispoof module\n liveness: { enabled: true }, // enable optional liveness module\n },\n body: { enabled: false },\n hand: { enabled: false },\n object: { enabled: false },\n gesture: { enabled: true }, // parses face and iris gestures\n};\n\n// const matchOptions = { order: 2, multiplier: 1000, min: 0.0, max: 1.0 }; // for embedding model\nconst matchOptions = { order: 2, multiplier: 25, min: 0.2, max: 0.8 }; // for faceres model\n\nconst options = {\n minConfidence: 0.6, // overal face confidence for box, face, gender, real, live\n minSize: 224, // min input to face descriptor model before degradation\n maxTime: 10000, // max time before giving up\n blinkMin: 10, // minimum duration of a valid blink\n blinkMax: 800, // maximum duration of a valid blink\n threshold: 0.5, // minimum similarity\n mask: humanConfig.face.detector.mask,\n rotation: humanConfig.face.detector.rotation,\n cropFactor: humanConfig.face.detector.cropFactor,\n ...matchOptions,\n};\n\nconst ok = { // must meet all rules\n faceCount: false,\n faceConfidence: false,\n facingCenter: false,\n lookingCenter: false,\n blinkDetected: false,\n faceSize: false,\n antispoofCheck: false,\n livenessCheck: false,\n elapsedMs: 0, // total time while waiting for valid face\n};\nconst allOk = () => ok.faceCount && ok.faceSize && ok.blinkDetected && ok.facingCenter && ok.lookingCenter && ok.faceConfidence && ok.antispoofCheck && ok.livenessCheck;\nconst current: { face: FaceResult | null, record: indexDb.FaceRecord | null } = { face: null, record: null }; // current face record and matched database record\n\nconst blink = { // internal timers for blink start/end/duration\n start: 0,\n end: 0,\n time: 0,\n};\n\n// let db: Array<{ name: string, source: string, embedding: number[] }> = []; // holds loaded face descriptor database\nconst human = new Human(humanConfig); // create instance of human with overrides from user configuration\n\nhuman.env['perfadd'] = false; // is performance data showing instant or total values\nhuman.draw.options.font = 'small-caps 18px \"Lato\"'; // set font used to draw labels when using draw methods\nhuman.draw.options.lineHeight = 20;\n\nconst dom = { // grab instances of dom objects so we dont have to look them up later\n video: document.getElementById('video') as HTMLVideoElement,\n canvas: document.getElementById('canvas') as HTMLCanvasElement,\n log: document.getElementById('log') as HTMLPreElement,\n fps: document.getElementById('fps') as HTMLPreElement,\n match: document.getElementById('match') as HTMLDivElement,\n name: document.getElementById('name') as HTMLInputElement,\n save: document.getElementById('save') as HTMLSpanElement,\n delete: document.getElementById('delete') as HTMLSpanElement,\n retry: document.getElementById('retry') as HTMLDivElement,\n source: document.getElementById('source') as HTMLCanvasElement,\n ok: document.getElementById('ok') as HTMLDivElement,\n};\nconst timestamp = { detect: 0, draw: 0 }; // holds information used to calculate performance and possible memory leaks\nconst fps = { detect: 0, draw: 0 }; // holds calculated fps information for both detect and screen refresh\nlet startTime = 0;\n\nconst log = (...msg) => { // helper method to output messages\n dom.log.innerText += msg.join(' ') + '\\n';\n // eslint-disable-next-line no-console\n console.log(...msg);\n};\nconst printFPS = (msg) => dom.fps.innerText = msg; // print status element\n\nasync function webCam() { // initialize webcam\n printFPS('starting webcam...');\n // @ts-ignore resizeMode is not yet defined in tslib\n const cameraOptions: MediaStreamConstraints = { audio: false, video: { facingMode: 'user', resizeMode: 'none', width: { ideal: document.body.clientWidth } } };\n const stream: MediaStream = await navigator.mediaDevices.getUserMedia(cameraOptions);\n const ready = new Promise((resolve) => { dom.video.onloadeddata = () => resolve(true); });\n dom.video.srcObject = stream;\n dom.video.play();\n await ready;\n dom.canvas.width = dom.video.videoWidth;\n dom.canvas.height = dom.video.videoHeight;\n if (human.env.initial) log('video:', dom.video.videoWidth, dom.video.videoHeight, '|', stream.getVideoTracks()[0].label);\n dom.canvas.onclick = () => { // pause when clicked on screen and resume on next click\n if (dom.video.paused) dom.video.play();\n else dom.video.pause();\n };\n}\n\nasync function detectionLoop() { // main detection loop\n if (!dom.video.paused) {\n if (current.face && current.face.tensor) human.tf.dispose(current.face.tensor); // dispose previous tensor\n await human.detect(dom.video); // actual detection; were not capturing output in a local variable as it can also be reached via human.result\n const now = human.now();\n fps.detect = 1000 / (now - timestamp.detect);\n timestamp.detect = now;\n requestAnimationFrame(detectionLoop); // start new frame immediately\n }\n}\n\nasync function validationLoop(): Promise { // main screen refresh loop\n const interpolated = await human.next(human.result); // smoothen result using last-known results\n await human.draw.canvas(dom.video, dom.canvas); // draw canvas to screen\n await human.draw.all(dom.canvas, interpolated); // draw labels, boxes, lines, etc.\n const now = human.now();\n fps.draw = 1000 / (now - timestamp.draw);\n timestamp.draw = now;\n printFPS(`fps: ${fps.detect.toFixed(1).padStart(5, ' ')} detect | ${fps.draw.toFixed(1).padStart(5, ' ')} draw`); // write status\n ok.faceCount = human.result.face.length === 1; // must be exactly detected face\n if (ok.faceCount) { // skip the rest if no face\n const gestures: string[] = Object.values(human.result.gesture).map((gesture) => gesture.gesture); // flatten all gestures\n if (gestures.includes('blink left eye') || gestures.includes('blink right eye')) blink.start = human.now(); // blink starts when eyes get closed\n if (blink.start > 0 && !gestures.includes('blink left eye') && !gestures.includes('blink right eye')) blink.end = human.now(); // if blink started how long until eyes are back open\n ok.blinkDetected = ok.blinkDetected || (Math.abs(blink.end - blink.start) > options.blinkMin && Math.abs(blink.end - blink.start) < options.blinkMax);\n if (ok.blinkDetected && blink.time === 0) blink.time = Math.trunc(blink.end - blink.start);\n ok.facingCenter = gestures.includes('facing center');\n ok.lookingCenter = gestures.includes('looking center'); // must face camera and look at camera\n ok.faceConfidence = (human.result.face[0].boxScore || 0) > options.minConfidence && (human.result.face[0].faceScore || 0) > options.minConfidence && (human.result.face[0].genderScore || 0) > options.minConfidence;\n ok.antispoofCheck = (human.result.face[0].real || 0) > options.minConfidence;\n ok.livenessCheck = (human.result.face[0].live || 0) > options.minConfidence;\n ok.faceSize = human.result.face[0].box[2] >= options.minSize && human.result.face[0].box[3] >= options.minSize;\n }\n let y = 32;\n for (const [key, val] of Object.entries(ok)) {\n let el = document.getElementById(`ok-${key}`);\n if (!el) {\n el = document.createElement('div');\n el.innerText = key;\n el.className = 'ok';\n el.style.top = `${y}px`;\n dom.ok.appendChild(el);\n }\n if (typeof val === 'boolean') el.style.backgroundColor = val ? 'lightgreen' : 'lightcoral';\n else el.innerText = `${key}:${val}`;\n y += 28;\n }\n if (allOk()) { // all criteria met\n dom.video.pause();\n return human.result.face[0];\n }\n if (ok.elapsedMs > options.maxTime) { // give up\n dom.video.pause();\n return human.result.face[0];\n } else { // run again\n ok.elapsedMs = Math.trunc(human.now() - startTime);\n return new Promise((resolve) => {\n setTimeout(async () => {\n const res = await validationLoop(); // run validation loop until conditions are met\n if (res) resolve(human.result.face[0]); // recursive promise resolve\n }, 30); // use to slow down refresh from max refresh rate to target of 30 fps\n });\n }\n}\n\nasync function saveRecords() {\n if (dom.name.value.length > 0) {\n const image = dom.canvas.getContext('2d')?.getImageData(0, 0, dom.canvas.width, dom.canvas.height) as ImageData;\n const rec = { id: 0, name: dom.name.value, descriptor: current.face?.embedding as number[], image };\n await indexDb.save(rec);\n log('saved face record:', rec.name);\n } else {\n log('invalid name');\n }\n}\n\nasync function deleteRecord() {\n if (current.record && current.record.id > 0) {\n await indexDb.remove(current.record);\n }\n}\n\nasync function detectFace() {\n dom.canvas.getContext('2d')?.clearRect(0, 0, options.minSize, options.minSize);\n if (!current.face || !current.face.tensor || !current.face.embedding) return false;\n // eslint-disable-next-line no-console\n console.log('face record:', current.face);\n human.tf.browser.toPixels(current.face.tensor as unknown as TensorLike, dom.canvas);\n if (await indexDb.count() === 0) {\n log('face database is empty');\n document.body.style.background = 'black';\n dom.delete.style.display = 'none';\n return false;\n }\n const db = await indexDb.load();\n const descriptors = db.map((rec) => rec.descriptor);\n const res = await human.match(current.face.embedding, descriptors, matchOptions);\n current.record = db[res.index] || null;\n if (current.record) {\n log(`best match: ${current.record.name} | id: ${current.record.id} | similarity: ${Math.round(1000 * res.similarity) / 10}%`);\n dom.name.value = current.record.name;\n dom.source.style.display = '';\n dom.source.getContext('2d')?.putImageData(current.record.image, 0, 0);\n }\n document.body.style.background = res.similarity > options.threshold ? 'darkgreen' : 'maroon';\n return res.similarity > options.threshold;\n}\n\nasync function main() { // main entry point\n ok.faceCount = false;\n ok.faceConfidence = false;\n ok.facingCenter = false;\n ok.blinkDetected = false;\n ok.faceSize = false;\n ok.antispoofCheck = false;\n ok.livenessCheck = false;\n ok.elapsedMs = 0;\n dom.match.style.display = 'none';\n dom.retry.style.display = 'none';\n dom.source.style.display = 'none';\n document.body.style.background = 'black';\n await webCam();\n await detectionLoop(); // start detection loop\n startTime = human.now();\n current.face = await validationLoop(); // start validation loop\n dom.canvas.width = current.face?.tensor?.shape[1] || options.minSize;\n dom.canvas.height = current.face?.tensor?.shape[0] || options.minSize;\n dom.source.width = dom.canvas.width;\n dom.source.height = dom.canvas.height;\n dom.canvas.style.width = '';\n dom.match.style.display = 'flex';\n dom.save.style.display = 'flex';\n dom.delete.style.display = 'flex';\n dom.retry.style.display = 'block';\n if (!allOk()) { // is all criteria met?\n log('did not find valid face');\n return false;\n } else {\n return detectFace();\n }\n}\n\nasync function init() {\n log('human version:', human.version, '| tfjs version:', human.tf.version['tfjs-core']);\n log('options:', JSON.stringify(options).replace(/{|}|\"|\\[|\\]/g, '').replace(/,/g, ' '));\n printFPS('loading...');\n log('known face records:', await indexDb.count());\n await webCam(); // start webcam\n await human.load(); // preload all models\n printFPS('initializing...');\n dom.retry.addEventListener('click', main);\n dom.save.addEventListener('click', saveRecords);\n dom.delete.addEventListener('click', deleteRecord);\n await human.warmup(); // warmup function to initialize backend for future faster detection\n await main();\n}\n\nwindow.onload = init;\n", "let db: IDBDatabase; // instance of indexdb\n\nconst database = 'human';\nconst table = 'person';\n\nexport type FaceRecord = { id: number, name: string, descriptor: number[], image: ImageData };\n\n// eslint-disable-next-line no-console\nconst log = (...msg) => console.log('indexdb', ...msg);\n\nexport async function open() {\n if (db) return true;\n return new Promise((resolve) => {\n const request: IDBOpenDBRequest = indexedDB.open(database, 1);\n request.onerror = (evt) => log('error:', evt);\n request.onupgradeneeded = (evt: IDBVersionChangeEvent) => { // create if doesnt exist\n log('create:', evt.target);\n db = (evt.target as IDBOpenDBRequest).result;\n db.createObjectStore(table, { keyPath: 'id', autoIncrement: true });\n };\n request.onsuccess = (evt) => { // open\n db = (evt.target as IDBOpenDBRequest).result as IDBDatabase;\n log('open:', db);\n resolve(true);\n };\n });\n}\n\nexport async function load(): Promise {\n const faceDB: Array = [];\n if (!db) await open(); // open or create if not already done\n return new Promise((resolve) => {\n const cursor: IDBRequest = db.transaction([table], 'readwrite').objectStore(table).openCursor(null, 'next');\n cursor.onerror = (evt) => log('load error:', evt);\n cursor.onsuccess = (evt) => {\n if ((evt.target as IDBRequest).result) {\n faceDB.push((evt.target as IDBRequest).result.value);\n (evt.target as IDBRequest).result.continue();\n } else {\n resolve(faceDB);\n }\n };\n });\n}\n\nexport async function count(): Promise {\n if (!db) await open(); // open or create if not already done\n return new Promise((resolve) => {\n const store: IDBRequest = db.transaction([table], 'readwrite').objectStore(table).count();\n store.onerror = (evt) => log('count error:', evt);\n store.onsuccess = () => resolve(store.result);\n });\n}\n\nexport async function save(faceRecord: FaceRecord) {\n if (!db) await open(); // open or create if not already done\n const newRecord = { name: faceRecord.name, descriptor: faceRecord.descriptor, image: faceRecord.image }; // omit id as its autoincrement\n db.transaction([table], 'readwrite').objectStore(table).put(newRecord);\n log('save:', newRecord);\n}\n\nexport async function remove(faceRecord: FaceRecord) {\n if (!db) await open(); // open or create if not already done\n db.transaction([table], 'readwrite').objectStore(table).delete(faceRecord.id); // delete based on id\n log('delete:', faceRecord);\n}\n"], - "mappings": "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", + "mappings": "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", "names": [] } diff --git a/demo/typescript/index.js b/demo/typescript/index.js index c6f2596e..09621031 100644 --- a/demo/typescript/index.js +++ b/demo/typescript/index.js @@ -4,8 +4,8 @@ author: ' */ -import{Human as p}from"../../dist/human.esm.js";var w={modelBasePath:"../../models",filter:{enabled:!0,equalization:!1},face:{enabled:!0,detector:{rotation:!1},mesh:{enabled:!0},attention:{enabled:!1},iris:{enabled:!0},description:{enabled:!0},emotion:{enabled:!0}},body:{enabled:!0},hand:{enabled:!0},object:{enabled:!1},gesture:{enabled:!0}},t=new p(w);t.env.perfadd=!1;t.draw.options.font='small-caps 18px "Lato"';t.draw.options.lineHeight=20;var e={video:document.getElementById("video"),canvas:document.getElementById("canvas"),log:document.getElementById("log"),fps:document.getElementById("status"),perf:document.getElementById("performance")},i={detect:0,draw:0,tensors:0},d={detect:0,draw:0},s=(...a)=>{e.log.innerText+=a.join(" ")+` -`,console.log(...a)},r=a=>e.fps.innerText=a,b=a=>e.perf.innerText="tensors:"+t.tf.memory().numTensors+" | performance: "+JSON.stringify(a).replace(/"|{|}/g,"").replace(/,/g," | ");async function h(){r("starting webcam...");let a={audio:!1,video:{facingMode:"user",resizeMode:"none",width:{ideal:document.body.clientWidth},height:{ideal:document.body.clientHeight}}},n=await navigator.mediaDevices.getUserMedia(a),m=new Promise(f=>{e.video.onloadeddata=()=>f(!0)});e.video.srcObject=n,e.video.play(),await m,e.canvas.width=e.video.videoWidth,e.canvas.height=e.video.videoHeight;let o=n.getVideoTracks()[0],g=o.getCapabilities?o.getCapabilities():"",u=o.getSettings?o.getSettings():"",v=o.getConstraints?o.getConstraints():"";s("video:",e.video.videoWidth,e.video.videoHeight,o.label,{stream:n,track:o,settings:u,constraints:v,capabilities:g}),e.canvas.onclick=()=>{e.video.paused?e.video.play():e.video.pause()}}async function c(){if(!e.video.paused){await t.detect(e.video);let n=t.tf.memory().numTensors;n-i.tensors!==0&&s("allocated tensors:",n-i.tensors),i.tensors=n}let a=t.now();d.detect=1e3/(a-i.detect),i.detect=a,requestAnimationFrame(c)}async function l(){if(!e.video.paused){let n=await t.next(t.result);await t.draw.canvas(e.video,e.canvas),await t.draw.all(e.canvas,n),b(n.performance)}let a=t.now();d.draw=1e3/(a-i.draw),i.draw=a,r(e.video.paused?"paused":`fps: ${d.detect.toFixed(1).padStart(5," ")} detect | ${d.draw.toFixed(1).padStart(5," ")} draw`),setTimeout(l,30)}async function y(){s("human version:",t.version,"| tfjs version:",t.tf.version["tfjs-core"]),s("platform:",t.env.platform,"| agent:",t.env.agent),r("loading..."),await t.load(),s("backend:",t.tf.getBackend(),"| available:",t.env.backends),s("loaded models:",Object.values(t.models).filter(a=>a!==null).length),r("initializing..."),await t.warmup(),await h(),await c(),await l()}window.onload=y; +import{Human as p}from"../../dist/human.esm.js";var w={async:!0,modelBasePath:"../../models",filter:{enabled:!0,equalization:!1},cacheSensitivity:0,face:{enabled:!0,detector:{rotation:!1},mesh:{enabled:!0},attention:{enabled:!1},iris:{enabled:!0},description:{enabled:!0},emotion:{enabled:!0}},body:{enabled:!0},hand:{enabled:!0},object:{enabled:!1},gesture:{enabled:!0}},t=new p(w);t.env.perfadd=!1;t.draw.options.font='small-caps 18px "Lato"';t.draw.options.lineHeight=20;var e={video:document.getElementById("video"),canvas:document.getElementById("canvas"),log:document.getElementById("log"),fps:document.getElementById("status"),perf:document.getElementById("performance")},o={detect:0,draw:0,tensors:0},d={detect:0,draw:0},s=(...a)=>{e.log.innerText+=a.join(" ")+` +`,console.log(...a)},r=a=>e.fps.innerText=a,b=a=>e.perf.innerText="tensors:"+t.tf.memory().numTensors+" | performance: "+JSON.stringify(a).replace(/"|{|}/g,"").replace(/,/g," | ");async function h(){r("starting webcam...");let a={audio:!1,video:{facingMode:"user",resizeMode:"none",width:{ideal:document.body.clientWidth},height:{ideal:document.body.clientHeight}}},n=await navigator.mediaDevices.getUserMedia(a),m=new Promise(f=>{e.video.onloadeddata=()=>f(!0)});e.video.srcObject=n,e.video.play(),await m,e.canvas.width=e.video.videoWidth,e.canvas.height=e.video.videoHeight;let i=n.getVideoTracks()[0],g=i.getCapabilities?i.getCapabilities():"",u=i.getSettings?i.getSettings():"",v=i.getConstraints?i.getConstraints():"";s("video:",e.video.videoWidth,e.video.videoHeight,i.label,{stream:n,track:i,settings:u,constraints:v,capabilities:g}),e.canvas.onclick=()=>{e.video.paused?e.video.play():e.video.pause()}}async function c(){if(!e.video.paused){await t.detect(e.video);let n=t.tf.memory().numTensors;n-o.tensors!==0&&s("allocated tensors:",n-o.tensors),o.tensors=n}let a=t.now();d.detect=1e3/(a-o.detect),o.detect=a,requestAnimationFrame(c)}async function l(){if(!e.video.paused){let n=await t.next(t.result);await t.draw.canvas(e.video,e.canvas),await t.draw.all(e.canvas,n),b(n.performance)}let a=t.now();d.draw=1e3/(a-o.draw),o.draw=a,r(e.video.paused?"paused":`fps: ${d.detect.toFixed(1).padStart(5," ")} detect | ${d.draw.toFixed(1).padStart(5," ")} draw`),setTimeout(l,30)}async function y(){s("human version:",t.version,"| tfjs version:",t.tf.version["tfjs-core"]),s("platform:",t.env.platform,"| agent:",t.env.agent),r("loading..."),await t.load(),s("backend:",t.tf.getBackend(),"| available:",t.env.backends),s("loaded models:",Object.values(t.models).filter(a=>a!==null).length),r("initializing..."),await t.warmup(),await h(),await c(),await l()}window.onload=y; /** * Human demo for browsers * @default Human Library diff --git a/demo/typescript/index.js.map b/demo/typescript/index.js.map index 55868453..5540c5f2 100644 --- a/demo/typescript/index.js.map +++ b/demo/typescript/index.js.map @@ -1,7 +1,7 @@ { "version": 3, "sources": ["index.ts"], - "sourcesContent": ["/**\n * Human demo for browsers\n * @default Human Library\n * @summary \n * @author \n * @copyright \n * @license MIT\n */\n\nimport { Human, Config } from '../../dist/human.esm.js'; // equivalent of @vladmandic/Human\n\nconst humanConfig: Partial = { // user configuration for human, used to fine-tune behavior\n // backend: 'webgpu' as const,\n // async: true,\n modelBasePath: '../../models',\n filter: { enabled: true, equalization: false },\n // cacheSensitivity: 0,\n face: { enabled: true, detector: { rotation: false }, mesh: { enabled: true }, attention: { enabled: false }, iris: { enabled: true }, description: { enabled: true }, emotion: { enabled: true } },\n body: { enabled: true },\n hand: { enabled: true },\n object: { enabled: false },\n gesture: { enabled: true },\n};\n\nconst human = new Human(humanConfig); // create instance of human with overrides from user configuration\n\nhuman.env['perfadd'] = false; // is performance data showing instant or total values\nhuman.draw.options.font = 'small-caps 18px \"Lato\"'; // set font used to draw labels when using draw methods\nhuman.draw.options.lineHeight = 20;\n\nconst dom = { // grab instances of dom objects so we dont have to look them up later\n video: document.getElementById('video') as HTMLVideoElement,\n canvas: document.getElementById('canvas') as HTMLCanvasElement,\n log: document.getElementById('log') as HTMLPreElement,\n fps: document.getElementById('status') as HTMLPreElement,\n perf: document.getElementById('performance') as HTMLDivElement,\n};\nconst timestamp = { detect: 0, draw: 0, tensors: 0 }; // holds information used to calculate performance and possible memory leaks\nconst fps = { detect: 0, draw: 0 }; // holds calculated fps information for both detect and screen refresh\n\nconst log = (...msg) => { // helper method to output messages\n dom.log.innerText += msg.join(' ') + '\\n';\n // eslint-disable-next-line no-console\n console.log(...msg);\n};\nconst status = (msg) => dom.fps.innerText = msg; // print status element\nconst perf = (msg) => dom.perf.innerText = 'tensors:' + human.tf.memory().numTensors + ' | performance: ' + JSON.stringify(msg).replace(/\"|{|}/g, '').replace(/,/g, ' | '); // print performance element\n\nasync function webCam() { // initialize webcam\n status('starting webcam...');\n // @ts-ignore resizeMode is not yet defined in tslib\n const options: MediaStreamConstraints = { audio: false, video: { facingMode: 'user', resizeMode: 'none', width: { ideal: document.body.clientWidth }, height: { ideal: document.body.clientHeight } } };\n const stream: MediaStream = await navigator.mediaDevices.getUserMedia(options);\n const ready = new Promise((resolve) => { dom.video.onloadeddata = () => resolve(true); });\n dom.video.srcObject = stream;\n dom.video.play();\n await ready;\n dom.canvas.width = dom.video.videoWidth;\n dom.canvas.height = dom.video.videoHeight;\n const track: MediaStreamTrack = stream.getVideoTracks()[0];\n const capabilities: MediaTrackCapabilities | string = track.getCapabilities ? track.getCapabilities() : '';\n const settings: MediaTrackSettings | string = track.getSettings ? track.getSettings() : '';\n const constraints: MediaTrackConstraints | string = track.getConstraints ? track.getConstraints() : '';\n log('video:', dom.video.videoWidth, dom.video.videoHeight, track.label, { stream, track, settings, constraints, capabilities });\n dom.canvas.onclick = () => { // pause when clicked on screen and resume on next click\n if (dom.video.paused) dom.video.play();\n else dom.video.pause();\n };\n}\n\nasync function detectionLoop() { // main detection loop\n if (!dom.video.paused) {\n // console.log('profiling data:', await human.profile(dom.video));\n await human.detect(dom.video); // actual detection; were not capturing output in a local variable as it can also be reached via human.result\n const tensors = human.tf.memory().numTensors; // check current tensor usage for memory leaks\n if (tensors - timestamp.tensors !== 0) log('allocated tensors:', tensors - timestamp.tensors); // printed on start and each time there is a tensor leak\n timestamp.tensors = tensors;\n }\n const now = human.now();\n fps.detect = 1000 / (now - timestamp.detect);\n timestamp.detect = now;\n requestAnimationFrame(detectionLoop); // start new frame immediately\n}\n\nasync function drawLoop() { // main screen refresh loop\n if (!dom.video.paused) {\n const interpolated = await human.next(human.result); // smoothen result using last-known results\n await human.draw.canvas(dom.video, dom.canvas); // draw canvas to screen\n await human.draw.all(dom.canvas, interpolated); // draw labels, boxes, lines, etc.\n perf(interpolated.performance); // write performance data\n }\n const now = human.now();\n fps.draw = 1000 / (now - timestamp.draw);\n timestamp.draw = now;\n status(dom.video.paused ? 'paused' : `fps: ${fps.detect.toFixed(1).padStart(5, ' ')} detect | ${fps.draw.toFixed(1).padStart(5, ' ')} draw`); // write status\n // requestAnimationFrame(drawLoop); // refresh at screen refresh rate\n setTimeout(drawLoop, 30); // use to slow down refresh from max refresh rate to target of 30 fps\n}\n\nasync function main() { // main entry point\n log('human version:', human.version, '| tfjs version:', human.tf.version['tfjs-core']);\n log('platform:', human.env.platform, '| agent:', human.env.agent);\n status('loading...');\n await human.load(); // preload all models\n log('backend:', human.tf.getBackend(), '| available:', human.env.backends);\n log('loaded models:', Object.values(human.models).filter((model) => model !== null).length);\n status('initializing...');\n await human.warmup(); // warmup function to initialize backend for future faster detection\n await webCam(); // start webcam\n await detectionLoop(); // start detection loop\n await drawLoop(); // start draw loop\n}\n\nwindow.onload = main;\n"], - "mappings": "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", + "sourcesContent": ["/**\n * Human demo for browsers\n * @default Human Library\n * @summary \n * @author \n * @copyright \n * @license MIT\n */\n\nimport { Human, Config } from '../../dist/human.esm.js'; // equivalent of @vladmandic/Human\n\nconst humanConfig: Partial = { // user configuration for human, used to fine-tune behavior\n // backend: 'webgpu' as const,\n // wasmPath: 'https://cdn.jsdelivr.net/npm/@tensorflow/tfjs-backend-wasm@3.18.0/dist/',\n async: true,\n modelBasePath: '../../models',\n filter: { enabled: true, equalization: false },\n //\n cacheSensitivity: 0,\n face: { enabled: true, detector: { rotation: false }, mesh: { enabled: true }, attention: { enabled: false }, iris: { enabled: true }, description: { enabled: true }, emotion: { enabled: true } },\n body: { enabled: true },\n hand: { enabled: true },\n object: { enabled: false },\n gesture: { enabled: true },\n};\n\nconst human = new Human(humanConfig); // create instance of human with overrides from user configuration\n\nhuman.env['perfadd'] = false; // is performance data showing instant or total values\nhuman.draw.options.font = 'small-caps 18px \"Lato\"'; // set font used to draw labels when using draw methods\nhuman.draw.options.lineHeight = 20;\n\nconst dom = { // grab instances of dom objects so we dont have to look them up later\n video: document.getElementById('video') as HTMLVideoElement,\n canvas: document.getElementById('canvas') as HTMLCanvasElement,\n log: document.getElementById('log') as HTMLPreElement,\n fps: document.getElementById('status') as HTMLPreElement,\n perf: document.getElementById('performance') as HTMLDivElement,\n};\nconst timestamp = { detect: 0, draw: 0, tensors: 0 }; // holds information used to calculate performance and possible memory leaks\nconst fps = { detect: 0, draw: 0 }; // holds calculated fps information for both detect and screen refresh\n\nconst log = (...msg) => { // helper method to output messages\n dom.log.innerText += msg.join(' ') + '\\n';\n // eslint-disable-next-line no-console\n console.log(...msg);\n};\nconst status = (msg) => dom.fps.innerText = msg; // print status element\nconst perf = (msg) => dom.perf.innerText = 'tensors:' + human.tf.memory().numTensors + ' | performance: ' + JSON.stringify(msg).replace(/\"|{|}/g, '').replace(/,/g, ' | '); // print performance element\n\nasync function webCam() { // initialize webcam\n status('starting webcam...');\n // @ts-ignore resizeMode is not yet defined in tslib\n const options: MediaStreamConstraints = { audio: false, video: { facingMode: 'user', resizeMode: 'none', width: { ideal: document.body.clientWidth }, height: { ideal: document.body.clientHeight } } };\n const stream: MediaStream = await navigator.mediaDevices.getUserMedia(options);\n const ready = new Promise((resolve) => { dom.video.onloadeddata = () => resolve(true); });\n dom.video.srcObject = stream;\n dom.video.play();\n await ready;\n dom.canvas.width = dom.video.videoWidth;\n dom.canvas.height = dom.video.videoHeight;\n const track: MediaStreamTrack = stream.getVideoTracks()[0];\n const capabilities: MediaTrackCapabilities | string = track.getCapabilities ? track.getCapabilities() : '';\n const settings: MediaTrackSettings | string = track.getSettings ? track.getSettings() : '';\n const constraints: MediaTrackConstraints | string = track.getConstraints ? track.getConstraints() : '';\n log('video:', dom.video.videoWidth, dom.video.videoHeight, track.label, { stream, track, settings, constraints, capabilities });\n dom.canvas.onclick = () => { // pause when clicked on screen and resume on next click\n if (dom.video.paused) dom.video.play();\n else dom.video.pause();\n };\n}\n\nasync function detectionLoop() { // main detection loop\n if (!dom.video.paused) {\n // console.log('profiling data:', await human.profile(dom.video));\n await human.detect(dom.video); // actual detection; were not capturing output in a local variable as it can also be reached via human.result\n const tensors = human.tf.memory().numTensors; // check current tensor usage for memory leaks\n if (tensors - timestamp.tensors !== 0) log('allocated tensors:', tensors - timestamp.tensors); // printed on start and each time there is a tensor leak\n timestamp.tensors = tensors;\n }\n const now = human.now();\n fps.detect = 1000 / (now - timestamp.detect);\n timestamp.detect = now;\n requestAnimationFrame(detectionLoop); // start new frame immediately\n}\n\nasync function drawLoop() { // main screen refresh loop\n if (!dom.video.paused) {\n const interpolated = await human.next(human.result); // smoothen result using last-known results\n await human.draw.canvas(dom.video, dom.canvas); // draw canvas to screen\n await human.draw.all(dom.canvas, interpolated); // draw labels, boxes, lines, etc.\n perf(interpolated.performance); // write performance data\n }\n const now = human.now();\n fps.draw = 1000 / (now - timestamp.draw);\n timestamp.draw = now;\n status(dom.video.paused ? 'paused' : `fps: ${fps.detect.toFixed(1).padStart(5, ' ')} detect | ${fps.draw.toFixed(1).padStart(5, ' ')} draw`); // write status\n // requestAnimationFrame(drawLoop); // refresh at screen refresh rate\n setTimeout(drawLoop, 30); // use to slow down refresh from max refresh rate to target of 30 fps\n}\n\nasync function main() { // main entry point\n log('human version:', human.version, '| tfjs version:', human.tf.version['tfjs-core']);\n log('platform:', human.env.platform, '| agent:', human.env.agent);\n status('loading...');\n await human.load(); // preload all models\n log('backend:', human.tf.getBackend(), '| available:', human.env.backends);\n log('loaded models:', Object.values(human.models).filter((model) => model !== null).length);\n status('initializing...');\n await human.warmup(); // warmup function to initialize backend for future faster detection\n await webCam(); // start webcam\n await detectionLoop(); // start detection loop\n await drawLoop(); // start draw loop\n}\n\nwindow.onload = main;\n"], + "mappings": ";;;;;;AASA,gDATA,AAWA,GAAM,GAA+B,CAGnC,MAAO,GACP,cAAe,eACf,OAAQ,CAAE,QAAS,GAAM,aAAc,EAAM,EAE7C,iBAAkB,EAClB,KAAM,CAAE,QAAS,GAAM,SAAU,CAAE,SAAU,EAAM,EAAG,KAAM,CAAE,QAAS,EAAK,EAAG,UAAW,CAAE,QAAS,EAAM,EAAG,KAAM,CAAE,QAAS,EAAK,EAAG,YAAa,CAAE,QAAS,EAAK,EAAG,QAAS,CAAE,QAAS,EAAK,CAAE,EAClM,KAAM,CAAE,QAAS,EAAK,EACtB,KAAM,CAAE,QAAS,EAAK,EACtB,OAAQ,CAAE,QAAS,EAAM,EACzB,QAAS,CAAE,QAAS,EAAK,CAC3B,EAEM,EAAQ,GAAI,GAAM,CAAW,EAEnC,EAAM,IAAI,QAAa,GACvB,EAAM,KAAK,QAAQ,KAAO,yBAC1B,EAAM,KAAK,QAAQ,WAAa,GAEhC,GAAM,GAAM,CACV,MAAO,SAAS,eAAe,OAAO,EACtC,OAAQ,SAAS,eAAe,QAAQ,EACxC,IAAK,SAAS,eAAe,KAAK,EAClC,IAAK,SAAS,eAAe,QAAQ,EACrC,KAAM,SAAS,eAAe,aAAa,CAC7C,EACM,EAAY,CAAE,OAAQ,EAAG,KAAM,EAAG,QAAS,CAAE,EAC7C,EAAM,CAAE,OAAQ,EAAG,KAAM,CAAE,EAE3B,EAAM,IAAI,IAAQ,CACtB,EAAI,IAAI,WAAa,EAAI,KAAK,GAAG,EAAI;AAAA,EAErC,QAAQ,IAAI,GAAG,CAAG,CACpB,EACM,EAAS,AAAC,GAAQ,EAAI,IAAI,UAAY,EACtC,EAAO,AAAC,GAAQ,EAAI,KAAK,UAAY,WAAa,EAAM,GAAG,OAAO,EAAE,WAAa,mBAAqB,KAAK,UAAU,CAAG,EAAE,QAAQ,SAAU,EAAE,EAAE,QAAQ,KAAM,KAAK,EAEzK,kBAAwB,CACtB,EAAO,oBAAoB,EAE3B,GAAM,GAAkC,CAAE,MAAO,GAAO,MAAO,CAAE,WAAY,OAAQ,WAAY,OAAQ,MAAO,CAAE,MAAO,SAAS,KAAK,WAAY,EAAG,OAAQ,CAAE,MAAO,SAAS,KAAK,YAAa,CAAE,CAAE,EAChM,EAAsB,KAAM,WAAU,aAAa,aAAa,CAAO,EACvE,EAAQ,GAAI,SAAQ,AAAC,GAAY,CAAE,EAAI,MAAM,aAAe,IAAM,EAAQ,EAAI,CAAG,CAAC,EACxF,EAAI,MAAM,UAAY,EACtB,EAAI,MAAM,KAAK,EACf,KAAM,GACN,EAAI,OAAO,MAAQ,EAAI,MAAM,WAC7B,EAAI,OAAO,OAAS,EAAI,MAAM,YAC9B,GAAM,GAA0B,EAAO,eAAe,EAAE,GAClD,EAAgD,EAAM,gBAAkB,EAAM,gBAAgB,EAAI,GAClG,EAAwC,EAAM,YAAc,EAAM,YAAY,EAAI,GAClF,EAA8C,EAAM,eAAiB,EAAM,eAAe,EAAI,GACpG,EAAI,SAAU,EAAI,MAAM,WAAY,EAAI,MAAM,YAAa,EAAM,MAAO,CAAE,SAAQ,QAAO,WAAU,cAAa,cAAa,CAAC,EAC9H,EAAI,OAAO,QAAU,IAAM,CACzB,AAAI,EAAI,MAAM,OAAQ,EAAI,MAAM,KAAK,EAChC,EAAI,MAAM,MAAM,CACvB,CACF,CAEA,kBAA+B,CAC7B,GAAI,CAAC,EAAI,MAAM,OAAQ,CAErB,KAAM,GAAM,OAAO,EAAI,KAAK,EAC5B,GAAM,GAAU,EAAM,GAAG,OAAO,EAAE,WAClC,AAAI,EAAU,EAAU,UAAY,GAAG,EAAI,qBAAsB,EAAU,EAAU,OAAO,EAC5F,EAAU,QAAU,CACtB,CACA,GAAM,GAAM,EAAM,IAAI,EACtB,EAAI,OAAS,IAAQ,GAAM,EAAU,QACrC,EAAU,OAAS,EACnB,sBAAsB,CAAa,CACrC,CAEA,kBAA0B,CACxB,GAAI,CAAC,EAAI,MAAM,OAAQ,CACrB,GAAM,GAAe,KAAM,GAAM,KAAK,EAAM,MAAM,EAClD,KAAM,GAAM,KAAK,OAAO,EAAI,MAAO,EAAI,MAAM,EAC7C,KAAM,GAAM,KAAK,IAAI,EAAI,OAAQ,CAAY,EAC7C,EAAK,EAAa,WAAW,CAC/B,CACA,GAAM,GAAM,EAAM,IAAI,EACtB,EAAI,KAAO,IAAQ,GAAM,EAAU,MACnC,EAAU,KAAO,EACjB,EAAO,EAAI,MAAM,OAAS,SAAW,QAAQ,EAAI,OAAO,QAAQ,CAAC,EAAE,SAAS,EAAG,GAAG,cAAc,EAAI,KAAK,QAAQ,CAAC,EAAE,SAAS,EAAG,GAAG,QAAQ,EAE3I,WAAW,EAAU,EAAE,CACzB,CAEA,kBAAsB,CACpB,EAAI,iBAAkB,EAAM,QAAS,kBAAmB,EAAM,GAAG,QAAQ,YAAY,EACrF,EAAI,YAAa,EAAM,IAAI,SAAU,WAAY,EAAM,IAAI,KAAK,EAChE,EAAO,YAAY,EACnB,KAAM,GAAM,KAAK,EACjB,EAAI,WAAY,EAAM,GAAG,WAAW,EAAG,eAAgB,EAAM,IAAI,QAAQ,EACzE,EAAI,iBAAkB,OAAO,OAAO,EAAM,MAAM,EAAE,OAAO,AAAC,GAAU,IAAU,IAAI,EAAE,MAAM,EAC1F,EAAO,iBAAiB,EACxB,KAAM,GAAM,OAAO,EACnB,KAAM,GAAO,EACb,KAAM,GAAc,EACpB,KAAM,GAAS,CACjB,CAEA,OAAO,OAAS", "names": [] } diff --git a/demo/typescript/index.ts b/demo/typescript/index.ts index 92e68e51..b5a836b7 100644 --- a/demo/typescript/index.ts +++ b/demo/typescript/index.ts @@ -11,10 +11,12 @@ import { Human, Config } from '../../dist/human.esm.js'; // equivalent of @vladm const humanConfig: Partial = { // user configuration for human, used to fine-tune behavior // backend: 'webgpu' as const, - // async: true, + // wasmPath: 'https://cdn.jsdelivr.net/npm/@tensorflow/tfjs-backend-wasm@3.18.0/dist/', + async: true, modelBasePath: '../../models', filter: { enabled: true, equalization: false }, - // cacheSensitivity: 0, + // + cacheSensitivity: 0, face: { enabled: true, detector: { rotation: false }, mesh: { enabled: true }, attention: { enabled: false }, iris: { enabled: true }, description: { enabled: true }, emotion: { enabled: true } }, body: { enabled: true }, hand: { enabled: true }, diff --git a/dist/human.esm-nobundle.js b/dist/human.esm-nobundle.js index ef5a2658..941611c3 100644 --- a/dist/human.esm-nobundle.js +++ b/dist/human.esm-nobundle.js @@ -4,7 +4,7 @@ author: ' */ -var Xt=Object.defineProperty;var mn=Object.getOwnPropertyDescriptor;var pn=Object.getOwnPropertyNames;var un=Object.prototype.hasOwnProperty;var hn=(e,t,o)=>t in e?Xt(e,t,{enumerable:!0,configurable:!0,writable:!0,value:o}):e[t]=o;var ne=(e,t)=>{for(var o in t)Xt(e,o,{get:t[o],enumerable:!0})},T2=(e,t,o,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let r of pn(t))!un.call(e,r)&&r!==o&&Xt(e,r,{get:()=>t[r],enumerable:!(n=mn(t,r))||n.enumerable});return e},q=(e,t,o)=>(T2(e,t,"default"),o&&T2(o,t,"default"));var T=(e,t,o)=>(hn(e,typeof t!="symbol"?t+"":t,o),o),k2=(e,t,o)=>{if(!t.has(e))throw TypeError("Cannot "+o)};var He=(e,t,o)=>(k2(e,t,"read from private field"),o?o.call(e):t.get(e)),Ve=(e,t,o)=>{if(t.has(e))throw TypeError("Cannot add the same private member more than once");t instanceof WeakSet?t.add(e):t.set(e,o)},Ze=(e,t,o,n)=>(k2(e,t,"write to private field"),n?n.call(e,o):t.set(e,o),o);function u(...e){let t=new Date,o=`${t.getHours().toString().padStart(2,"0")}:${t.getMinutes().toString().padStart(2,"0")}:${t.getSeconds().toString().padStart(2,"0")}.${t.getMilliseconds().toString().padStart(3,"0")}`;e&&console.log(o,"Human:",...e)}function E2(e,t){let o=e.endsWith("/")?"":"/",r=t.startsWith(".")||t.startsWith("/")||t.startsWith("http:")||t.startsWith("https:")||t.startsWith("file:")?`${t}`:`${e}${o}${t}`;if(!r.toLocaleLowerCase().includes(".json"))throw new Error(`modelpath error: expecting json file: ${r}`);return r}var b=()=>typeof performance!="undefined"?performance.now():parseInt((Number(process.hrtime.bigint())/1e3/1e3).toString());function qt(e,t,o="config",n=[]){for(let r of Object.keys(t))if(typeof t[r]=="object")qt(e[r],t[r],r,n);else{let s=e&&typeof e[r]!="undefined";s||n.push({reason:"unknown property",where:`${o}.${r} = ${t[r]}`});let a=e&&typeof e[r]==typeof t[r];s&&!a&&n.push({reason:"property type mismatch",where:`${o}.${r} = ${t[r]}`,expected:typeof e[r]})}return t.debug&&o==="config"&&n.length>0&&u("invalid configuration",n),n}function K(...e){let t=o=>o&&typeof o=="object";return e.reduce((o,n)=>(Object.keys(n||{}).forEach(r=>{let s=o[r],a=n[r];Array.isArray(s)&&Array.isArray(a)?o[r]=s.concat(...a):t(s)&&t(a)?o[r]=K(s,a):o[r]=a}),o),{})}var re={backend:"",modelBasePath:"",cacheModels:!0,wasmPath:"",wasmPlatformFetch:!1,debug:!0,async:!0,warmup:"full",cacheSensitivity:.7,skipAllowed:!1,deallocate:!1,filter:{enabled:!0,equalization:!1,width:0,height:0,flip:!1,return:!0,brightness:0,contrast:0,sharpness:0,blur:0,saturation:0,hue:0,negative:!1,sepia:!1,vintage:!1,kodachrome:!1,technicolor:!1,polaroid:!1,pixelate:0},gesture:{enabled:!0},face:{enabled:!0,detector:{modelPath:"blazeface.json",rotation:!0,maxDetected:1,skipFrames:99,skipTime:2500,minConfidence:.2,iouThreshold:.1,mask:!1,return:!1},mesh:{enabled:!0,modelPath:"facemesh.json",keepInvalid:!1},attention:{enabled:!1,modelPath:"facemesh-attention.json"},iris:{enabled:!0,modelPath:"iris.json"},emotion:{enabled:!0,minConfidence:.1,skipFrames:99,skipTime:1500,modelPath:"emotion.json"},description:{enabled:!0,modelPath:"faceres.json",skipFrames:99,skipTime:3e3,minConfidence:.1},antispoof:{enabled:!1,skipFrames:99,skipTime:4e3,modelPath:"antispoof.json"},liveness:{enabled:!1,skipFrames:99,skipTime:4e3,modelPath:"liveness.json"}},body:{enabled:!0,modelPath:"movenet-lightning.json",maxDetected:-1,minConfidence:.3,skipFrames:1,skipTime:200},hand:{enabled:!0,rotation:!0,skipFrames:99,skipTime:1e3,minConfidence:.5,iouThreshold:.2,maxDetected:-1,landmarks:!0,detector:{modelPath:"handtrack.json"},skeleton:{modelPath:"handlandmark-full.json"}},object:{enabled:!1,modelPath:"mb3-centernet.json",minConfidence:.2,iouThreshold:.4,maxDetected:10,skipFrames:99,skipTime:2e3},segmentation:{enabled:!1,modelPath:"selfie.json",blur:8}};var A={};ne(A,{GraphModel:()=>Ut,Tensor:()=>pe,version:()=>De});q(A,MA);q(A,RA);import*as MA from"@tensorflow/tfjs/dist/index.js";import*as RA from"@tensorflow/tfjs-backend-webgl/dist/index.js";import{Tensor as pe}from"@tensorflow/tfjs/dist/index.js";import{GraphModel as Ut}from"@tensorflow/tfjs-converter/dist/index";var bn="3.18.0",gn="3.18.0",Pn="3.18.0",vn="3.18.0",Mn="3.18.0",Rn="3.18.0",wn="3.18.0",De={tfjs:bn,"tfjs-core":gn,"tfjs-data":Pn,"tfjs-layers":vn,"tfjs-converter":Mn,"tfjs-backend-webgl":Rn,"tfjs-backend-wasm":wn};var z2=` +var Y2=Object.defineProperty;var ho=Object.getOwnPropertyDescriptor;var bo=Object.getOwnPropertyNames;var go=Object.prototype.hasOwnProperty;var Po=(e,t,o)=>t in e?Y2(e,t,{enumerable:!0,configurable:!0,writable:!0,value:o}):e[t]=o;var ne=(e,t)=>{for(var o in t)Y2(e,o,{get:t[o],enumerable:!0})},z1=(e,t,o,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let r of bo(t))!go.call(e,r)&&r!==o&&Y2(e,r,{get:()=>t[r],enumerable:!(n=ho(t,r))||n.enumerable});return e},q=(e,t,o)=>(z1(e,t,"default"),o&&z1(o,t,"default"));var w=(e,t,o)=>(Po(e,typeof t!="symbol"?t+"":t,o),o),S1=(e,t,o)=>{if(!t.has(e))throw TypeError("Cannot "+o)};var Ze=(e,t,o)=>(S1(e,t,"read from private field"),o?o.call(e):t.get(e)),De=(e,t,o)=>{if(t.has(e))throw TypeError("Cannot add the same private member more than once");t instanceof WeakSet?t.add(e):t.set(e,o)},Xe=(e,t,o,n)=>(S1(e,t,"write to private field"),n?n.call(e,o):t.set(e,o),o);function u(...e){let t=new Date,o=`${t.getHours().toString().padStart(2,"0")}:${t.getMinutes().toString().padStart(2,"0")}:${t.getSeconds().toString().padStart(2,"0")}.${t.getMilliseconds().toString().padStart(3,"0")}`;e&&console.log(o,"Human:",...e)}function j1(e,t){let o=e.endsWith("/")?"":"/",r=t.startsWith(".")||t.startsWith("/")||t.startsWith("http:")||t.startsWith("https:")||t.startsWith("file:")?`${t}`:`${e}${o}${t}`;if(!r.toLocaleLowerCase().includes(".json"))throw new Error(`modelpath error: expecting json file: ${r}`);return r}var b=()=>typeof performance!="undefined"?performance.now():parseInt((Number(process.hrtime.bigint())/1e3/1e3).toString());function K2(e,t,o="config",n=[]){for(let r of Object.keys(t))if(typeof t[r]=="object")K2(e[r],t[r],r,n);else{let s=e&&typeof e[r]!="undefined";s||n.push({reason:"unknown property",where:`${o}.${r} = ${t[r]}`});let a=e&&typeof e[r]==typeof t[r];s&&!a&&n.push({reason:"property type mismatch",where:`${o}.${r} = ${t[r]}`,expected:typeof e[r]})}return t.debug&&o==="config"&&n.length>0&&u("invalid configuration",n),n}function J(...e){let t=o=>o&&typeof o=="object";return e.reduce((o,n)=>(Object.keys(n||{}).forEach(r=>{let s=o[r],a=n[r];Array.isArray(s)&&Array.isArray(a)?o[r]=s.concat(...a):t(s)&&t(a)?o[r]=J(s,a):o[r]=a}),o),{})}var re={backend:"",modelBasePath:"",cacheModels:!0,wasmPath:"",wasmPlatformFetch:!1,debug:!0,async:!0,warmup:"full",cacheSensitivity:.7,skipAllowed:!1,deallocate:!1,filter:{enabled:!0,equalization:!1,width:0,height:0,flip:!1,return:!0,brightness:0,contrast:0,sharpness:0,blur:0,saturation:0,hue:0,negative:!1,sepia:!1,vintage:!1,kodachrome:!1,technicolor:!1,polaroid:!1,pixelate:0},gesture:{enabled:!0},face:{enabled:!0,detector:{modelPath:"blazeface.json",rotation:!0,maxDetected:1,skipFrames:99,skipTime:2500,minConfidence:.2,iouThreshold:.1,mask:!1,return:!1},mesh:{enabled:!0,modelPath:"facemesh.json",keepInvalid:!1},attention:{enabled:!1,modelPath:"facemesh-attention.json"},iris:{enabled:!0,modelPath:"iris.json"},emotion:{enabled:!0,minConfidence:.1,skipFrames:99,skipTime:1500,modelPath:"emotion.json"},description:{enabled:!0,modelPath:"faceres.json",skipFrames:99,skipTime:3e3,minConfidence:.1},antispoof:{enabled:!1,skipFrames:99,skipTime:4e3,modelPath:"antispoof.json"},liveness:{enabled:!1,skipFrames:99,skipTime:4e3,modelPath:"liveness.json"}},body:{enabled:!0,modelPath:"movenet-lightning.json",maxDetected:-1,minConfidence:.3,skipFrames:1,skipTime:200},hand:{enabled:!0,rotation:!0,skipFrames:99,skipTime:1e3,minConfidence:.5,iouThreshold:.2,maxDetected:-1,landmarks:!0,detector:{modelPath:"handtrack.json"},skeleton:{modelPath:"handlandmark-full.json"}},object:{enabled:!1,modelPath:"mb3-centernet.json",minConfidence:.2,iouThreshold:.4,maxDetected:10,skipFrames:99,skipTime:2e3},segmentation:{enabled:!1,modelPath:"selfie.json",blur:8}};var A={};ne(A,{GraphModel:()=>J2,Tensor:()=>he,version:()=>qe});q(A,Lr);q(A,Fr);import*as Lr from"@tensorflow/tfjs/dist/index.js";import*as Fr from"@tensorflow/tfjs-backend-webgl/dist/index.js";import{Tensor as he}from"@tensorflow/tfjs/dist/index.js";import{GraphModel as J2}from"@tensorflow/tfjs-converter/dist/index";var Mo="3.18.0",Ro="3.18.0",To="3.18.0",vo="3.18.0",wo="3.18.0",ko="3.18.0",Eo="3.18.0",qe={tfjs:Mo,"tfjs-core":Ro,"tfjs-data":To,"tfjs-layers":vo,"tfjs-converter":wo,"tfjs-backend-webgl":ko,"tfjs-backend-wasm":Eo};var C1=` precision highp float; attribute vec2 pos; attribute vec2 uv; @@ -14,7 +14,7 @@ var Xt=Object.defineProperty;var mn=Object.getOwnPropertyDescriptor;var pn=Objec vUv = uv; gl_Position = vec4(pos.x, pos.y*flipY, 0.0, 1.); } -`;var j2=` +`;var I1=` precision highp float; varying vec2 vUv; uniform sampler2D texture; @@ -26,7 +26,7 @@ var Xt=Object.defineProperty;var mn=Object.getOwnPropertyDescriptor;var pn=Objec gl_FragColor.b = m[10] * c.r + m[11] * c.g + m[12] * c.b + m[13] * c.a + m[14]; gl_FragColor.a = m[15] * c.r + m[16] * c.g + m[17] * c.b + m[18] * c.a + m[19]; } -`,S2=` +`,N1=` precision highp float; varying vec2 vUv; uniform sampler2D texture; @@ -38,7 +38,7 @@ var Xt=Object.defineProperty;var mn=Object.getOwnPropertyDescriptor;var pn=Objec gl_FragColor.b = m[10] * c.r + m[11] * c.g + m[12] * c.b + m[14]; gl_FragColor.a = c.a; } -`,C2=` +`,O1=` precision highp float; varying vec2 vUv; uniform vec2 size; @@ -51,7 +51,7 @@ var Xt=Object.defineProperty;var mn=Object.getOwnPropertyDescriptor;var pn=Objec vec2 coord = pixelate(vUv, size); gl_FragColor += texture2D(texture, coord); } -`,W2=` +`,W1=` precision highp float; varying vec2 vUv; uniform sampler2D texture; @@ -74,7 +74,7 @@ var Xt=Object.defineProperty;var mn=Object.getOwnPropertyDescriptor;var pn=Objec gl_FragColor += texture2D(texture, vUv + vec2( 6.0*px.x, 6.0*px.y))*0.00895781211794; gl_FragColor += texture2D(texture, vUv + vec2( 7.0*px.x, 7.0*px.y))*0.0044299121055113265; } -`,O2=` +`,L1=` precision highp float; varying vec2 vUv; uniform sampler2D texture; @@ -96,7 +96,7 @@ var Xt=Object.defineProperty;var mn=Object.getOwnPropertyDescriptor;var pn=Objec c31 * m[6] + c32 * m[7] + c33 * m[8]; gl_FragColor.a = c22.a; } -`;var Jt=(e,t,o)=>{let n=new RegExp("\\b"+t+" \\w+ (\\w+)","ig");e.replace(n,(r,s)=>(o[s]=0,r))},Yt=class{constructor(t,o,n){T(this,"uniform",{});T(this,"attribute",{});T(this,"gl");T(this,"id");T(this,"compile",(t,o)=>{let n=this.gl.createShader(o);return n?(this.gl.shaderSource(n,t),this.gl.compileShader(n),this.gl.getShaderParameter(n,this.gl.COMPILE_STATUS)?n:(u(`filter: gl compile failed: ${this.gl.getShaderInfoLog(n)}`),null)):(u("filter: could not create shader"),null)});this.gl=t;let r=this.compile(o,this.gl.VERTEX_SHADER),s=this.compile(n,this.gl.FRAGMENT_SHADER);if(this.id=this.gl.createProgram(),!(!r||!s)){if(!this.id){u("filter: could not create webgl program");return}if(this.gl.attachShader(this.id,r),this.gl.attachShader(this.id,s),this.gl.linkProgram(this.id),!this.gl.getProgramParameter(this.id,this.gl.LINK_STATUS)){u(`filter: gl link failed: ${this.gl.getProgramInfoLog(this.id)}`);return}this.gl.useProgram(this.id),Jt(o,"attribute",this.attribute);for(let a in this.attribute)this.attribute[a]=this.gl.getAttribLocation(this.id,a);Jt(o,"uniform",this.uniform),Jt(n,"uniform",this.uniform);for(let a in this.uniform)this.uniform[a]=this.gl.getUniformLocation(this.id,a)}}};function L2(){let e=0,t=null,o=!1,n=-1,r=[null,null],s=[],a=null,i=null,l=i0(100,100),x={},d={INTERMEDIATE:1},y=l.getContext("webgl");if(!y){u("filter: cannot get webgl context");return}this.gl=y;function c(g,f){if(!(g===l.width&&f===l.height)){if(l.width=g,l.height=f,!a){let v=new Float32Array([-1,-1,0,1,1,-1,1,1,-1,1,0,0,-1,1,0,0,1,-1,1,1,1,1,1,0]);a=y.createBuffer(),y.bindBuffer(y.ARRAY_BUFFER,a),y.bufferData(y.ARRAY_BUFFER,v,y.STATIC_DRAW),y.pixelStorei(y.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!0)}y.viewport(0,0,l.width,l.height),r=[null,null]}}function m(g,f){let v=y.createFramebuffer();y.bindFramebuffer(y.FRAMEBUFFER,v);let S=y.createRenderbuffer();y.bindRenderbuffer(y.RENDERBUFFER,S);let k=y.createTexture();return y.bindTexture(y.TEXTURE_2D,k),y.texImage2D(y.TEXTURE_2D,0,y.RGBA,g,f,0,y.RGBA,y.UNSIGNED_BYTE,null),y.texParameteri(y.TEXTURE_2D,y.TEXTURE_MAG_FILTER,y.LINEAR),y.texParameteri(y.TEXTURE_2D,y.TEXTURE_MIN_FILTER,y.LINEAR),y.texParameteri(y.TEXTURE_2D,y.TEXTURE_WRAP_S,y.CLAMP_TO_EDGE),y.texParameteri(y.TEXTURE_2D,y.TEXTURE_WRAP_T,y.CLAMP_TO_EDGE),y.framebufferTexture2D(y.FRAMEBUFFER,y.COLOR_ATTACHMENT0,y.TEXTURE_2D,k,0),y.bindTexture(y.TEXTURE_2D,null),y.bindFramebuffer(y.FRAMEBUFFER,null),{fbo:v,texture:k}}function h(g){return r[g]=r[g]||m(l.width,l.height),r[g]}function p(g=0){if(!i)return;let f=null,v=null,S=!1;e===0?f=t:f=h(n).texture||null,e++,o&&!(g&d.INTERMEDIATE)?(v=null,S=e%2===0):(n=(n+1)%2,v=h(n).fbo||null),y.bindTexture(y.TEXTURE_2D,f),y.bindFramebuffer(y.FRAMEBUFFER,v),y.uniform1f(i.uniform.flipY,S?-1:1),y.drawArrays(y.TRIANGLES,0,6)}function M(g){if(x[g])return i=x[g],y.useProgram((i?i.id:null)||null),i;if(i=new Yt(y,z2,g),!i)return u("filter: could not get webgl program"),null;let f=Float32Array.BYTES_PER_ELEMENT,v=4*f;return y.enableVertexAttribArray(i.attribute.pos),y.vertexAttribPointer(i.attribute.pos,2,y.FLOAT,!1,v,0*f),y.enableVertexAttribArray(i.attribute.uv),y.vertexAttribPointer(i.attribute.uv,2,y.FLOAT,!1,v,2*f),x[g]=i,i}let P={colorMatrix:g=>{let f=new Float32Array(g);f[4]/=255,f[9]/=255,f[14]/=255,f[19]/=255;let v=f[18]===1&&f[3]===0&&f[8]===0&&f[13]===0&&f[15]===0&&f[16]===0&&f[17]===0&&f[19]===0?S2:j2,S=M(v);!S||(y.uniform1fv(S.uniform.m,f),p())},brightness:g=>{let f=(g||0)+1;P.colorMatrix([f,0,0,0,0,0,f,0,0,0,0,0,f,0,0,0,0,0,1,0])},saturation:g=>{let f=(g||0)*2/3+1,v=(f-1)*-.5;P.colorMatrix([f,v,v,0,0,v,f,v,0,0,v,v,f,0,0,0,0,0,1,0])},desaturate:()=>{P.saturation(-1)},contrast:g=>{let f=(g||0)+1,v=-128*(f-1);P.colorMatrix([f,0,0,0,v,0,f,0,0,v,0,0,f,0,v,0,0,0,1,0])},negative:()=>{P.contrast(-2)},hue:g=>{g=(g||0)/180*Math.PI;let f=Math.cos(g),v=Math.sin(g),S=.213,k=.715,W=.072;P.colorMatrix([S+f*(1-S)+v*-S,k+f*-k+v*-k,W+f*-W+v*(1-W),0,0,S+f*-S+v*.143,k+f*(1-k)+v*.14,W+f*-W+v*-.283,0,0,S+f*-S+v*-(1-S),k+f*-k+v*k,W+f*(1-W)+v*W,0,0,0,0,0,1,0])},desaturateLuminance:()=>{P.colorMatrix([.2764723,.929708,.0938197,0,-37.1,.2764723,.929708,.0938197,0,-37.1,.2764723,.929708,.0938197,0,-37.1,0,0,0,1,0])},sepia:()=>{P.colorMatrix([.393,.7689999,.18899999,0,0,.349,.6859999,.16799999,0,0,.272,.5339999,.13099999,0,0,0,0,0,1,0])},brownie:()=>{P.colorMatrix([.5997023498159715,.34553243048391263,-.2708298674538042,0,47.43192855600873,-.037703249837783157,.8609577587992641,.15059552388459913,0,-36.96841498319127,.24113635128153335,-.07441037908422492,.44972182064877153,0,-7.562075277591283,0,0,0,1,0])},vintagePinhole:()=>{P.colorMatrix([.6279345635605994,.3202183420819367,-.03965408211312453,0,9.651285835294123,.02578397704808868,.6441188644374771,.03259127616149294,0,7.462829176470591,.0466055556782719,-.0851232987247891,.5241648018700465,0,5.159190588235296,0,0,0,1,0])},kodachrome:()=>{P.colorMatrix([1.1285582396593525,-.3967382283601348,-.03992559172921793,0,63.72958762196502,-.16404339962244616,1.0835251566291304,-.05498805115633132,0,24.732407896706203,-.16786010706155763,-.5603416277695248,1.6014850761964943,0,35.62982807460946,0,0,0,1,0])},technicolor:()=>{P.colorMatrix([1.9125277891456083,-.8545344976951645,-.09155508482755585,0,11.793603434377337,-.3087833385928097,1.7658908555458428,-.10601743074722245,0,-70.35205161461398,-.231103377548616,-.7501899197440212,1.847597816108189,0,30.950940869491138,0,0,0,1,0])},polaroid:()=>{P.colorMatrix([1.438,-.062,-.062,0,0,-.122,1.378,-.122,0,0,-.016,-.016,1.483,0,0,0,0,0,1,0])},shiftToBGR:()=>{P.colorMatrix([0,0,1,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,1,0])},convolution:g=>{let f=new Float32Array(g),v=1/l.width,S=1/l.height,k=M(O2);!k||(y.uniform1fv(k.uniform.m,f),y.uniform2f(k.uniform.px,v,S),p())},detectEdges:()=>{P.convolution.call(this,[0,1,0,1,-4,1,0,1,0])},sobelX:()=>{P.convolution.call(this,[-1,0,1,-2,0,2,-1,0,1])},sobelY:()=>{P.convolution.call(this,[-1,-2,-1,0,0,0,1,2,1])},sharpen:g=>{let f=g||1;P.convolution.call(this,[0,-1*f,0,-1*f,1+4*f,-1*f,0,-1*f,0])},emboss:g=>{let f=g||1;P.convolution.call(this,[-2*f,-1*f,0,-1*f,1,1*f,0,1*f,2*f])},blur:g=>{let f=g/7/l.width,v=g/7/l.height,S=M(W2);!S||(y.uniform2f(S.uniform.px,0,v),p(d.INTERMEDIATE),y.uniform2f(S.uniform.px,f,0),p())},pixelate:g=>{let f=g/l.width,v=g/l.height,S=M(C2);!S||(y.uniform2f(S.uniform.size,f,v),p())}};this.add=function(g){let f=Array.prototype.slice.call(arguments,1),v=P[g];s.push({func:v,args:f})},this.reset=function(){s=[]},this.get=function(){return s},this.apply=function(g){c(g.width,g.height),e=0,t||(t=y.createTexture()),y.bindTexture(y.TEXTURE_2D,t),y.texParameteri(y.TEXTURE_2D,y.TEXTURE_WRAP_S,y.CLAMP_TO_EDGE),y.texParameteri(y.TEXTURE_2D,y.TEXTURE_WRAP_T,y.CLAMP_TO_EDGE),y.texParameteri(y.TEXTURE_2D,y.TEXTURE_MIN_FILTER,y.NEAREST),y.texParameteri(y.TEXTURE_2D,y.TEXTURE_MAG_FILTER,y.NEAREST),y.texImage2D(y.TEXTURE_2D,0,y.RGBA,y.RGBA,y.UNSIGNED_BYTE,g);for(let f=0;fm.data())),a=.99*Math.max(s[0][0],s[1][0],s[2][0]),i=[A.sub(o[0],n[0]),A.sub(o[1],n[1]),A.sub(o[2],n[2])],l=[A.sub(r[0],n[0]),A.sub(r[1],n[1]),A.sub(r[2],n[2])],x=[A.div(a,l[0]),A.div(a,l[1]),A.div(a,l[2])],d=[A.mul(i[0],x[0]),A.mul(i[1],x[1]),A.mul(i[2],x[2])],y=A.stack([d[0],d[1],d[2]],2),c=A.reshape(y,[1,t.shape[0],t.shape[1],3]);return A.dispose([...o,...n,...r,...i,...l,...x,...d,y,t]),c}var rt=3840,B=null,$=null,ue=null,U,I0={inputSum:0,cacheDiff:1,sumMethod:0,inputTensor:void 0};function i0(e,t){let o;if(w.browser)if(w.worker){if(typeof OffscreenCanvas=="undefined")throw new Error("canvas error: attempted to run in web worker but OffscreenCanvas is not supported");o=new OffscreenCanvas(e,t)}else{if(typeof document=="undefined")throw new Error("canvas error: attempted to run in browser but DOM is not defined");o=document.createElement("canvas"),o.width=e,o.height=t}else typeof w.Canvas!="undefined"?o=new w.Canvas(e,t):typeof globalThis.Canvas!="undefined"&&(o=new globalThis.Canvas(e,t));return o}function At(e,t){let o=t||i0(e.width,e.height);return o.getContext("2d").drawImage(e,0,0),o}async function he(e,t,o=!0){if(!e)return t.debug&&u("input error: input is missing"),{tensor:null,canvas:null};if(!(e instanceof pe)&&!(typeof Image!="undefined"&&e instanceof Image)&&!(typeof w.Canvas!="undefined"&&e instanceof w.Canvas)&&!(typeof globalThis.Canvas!="undefined"&&e instanceof globalThis.Canvas)&&!(typeof ImageData!="undefined"&&e instanceof ImageData)&&!(typeof ImageBitmap!="undefined"&&e instanceof ImageBitmap)&&!(typeof HTMLImageElement!="undefined"&&e instanceof HTMLImageElement)&&!(typeof HTMLMediaElement!="undefined"&&e instanceof HTMLMediaElement)&&!(typeof HTMLVideoElement!="undefined"&&e instanceof HTMLVideoElement)&&!(typeof HTMLCanvasElement!="undefined"&&e instanceof HTMLCanvasElement)&&!(typeof OffscreenCanvas!="undefined"&&e instanceof OffscreenCanvas))throw new Error("input error: type is not recognized");if(e instanceof pe){let n=null;if(e.isDisposedInternal)throw new Error("input error: attempted to use tensor but it is disposed");if(!e.shape)throw new Error("input error: attempted to use tensor without a shape");if(e.shape.length===3){if(e.shape[2]===3)n=A.expandDims(e,0);else if(e.shape[2]===4){let r=A.slice3d(e,[0,0,0],[-1,-1,3]);n=A.expandDims(r,0),A.dispose(r)}}else e.shape.length===4&&(e.shape[3]===3?n=A.clone(e):e.shape[3]===4&&(n=A.slice4d(e,[0,0,0,0],[-1,-1,-1,3])));if(n==null||n.shape.length!==4||n.shape[0]!==1||n.shape[3]!==3)throw new Error(`input error: attempted to use tensor with unrecognized shape: ${e.shape}`);if(n.dtype==="int32"){let r=A.cast(n,"float32");A.dispose(n),n=r}return{tensor:n,canvas:t.filter.return?$:null}}else{if(typeof e.readyState!="undefined"&&e.readyState<=2)return t.debug&&u("input stream is not ready"),{tensor:null,canvas:B};let n=e.naturalWidth||e.videoWidth||e.width||e.shape&&e.shape[1]>0,r=e.naturalHeight||e.videoHeight||e.height||e.shape&&e.shape[2]>0;if(!n||!r)return t.debug&&u("cannot determine input dimensions"),{tensor:null,canvas:B};let s=n,a=r;if(s>rt&&(s=rt,a=Math.trunc(s*r/n)),a>rt&&(a=rt,s=Math.trunc(a*n/r)),(t.filter.width||0)>0?s=t.filter.width:(t.filter.height||0)>0&&(s=n*((t.filter.height||0)/r)),(t.filter.height||0)>0?a=t.filter.height:(t.filter.width||0)>0&&(a=r*((t.filter.width||0)/n)),!s||!a)throw new Error("input error: cannot determine dimension");(!B||(B==null?void 0:B.width)!==s||(B==null?void 0:B.height)!==a)&&(B=i0(s,a));let i=B.getContext("2d");if(typeof ImageData!="undefined"&&e instanceof ImageData?i.putImageData(e,0,0):t.filter.flip&&typeof i.translate!="undefined"?(i.translate(n,0),i.scale(-1,1),i.drawImage(e,0,0,n,r,0,0,B==null?void 0:B.width,B==null?void 0:B.height),i.setTransform(1,0,0,1,0,0)):i.drawImage(e,0,0,n,r,0,0,B==null?void 0:B.width,B==null?void 0:B.height),(!$||B.width!==$.width||(B==null?void 0:B.height)!==($==null?void 0:$.height))&&($=i0(B.width,B.height)),t.filter.enabled&&w.webgl.supported?(U||(U=w.browser?new L2:null),w.filter=!!U,!U||!U.add?(t.debug&&u("input process error: cannot initialize filters"),w.webgl.supported=!1,t.filter.enabled=!1,At(B,$)):(U.reset(),t.filter.brightness!==0&&U.add("brightness",t.filter.brightness),t.filter.contrast!==0&&U.add("contrast",t.filter.contrast),t.filter.sharpness!==0&&U.add("sharpen",t.filter.sharpness),t.filter.blur!==0&&U.add("blur",t.filter.blur),t.filter.saturation!==0&&U.add("saturation",t.filter.saturation),t.filter.hue!==0&&U.add("hue",t.filter.hue),t.filter.negative&&U.add("negative"),t.filter.sepia&&U.add("sepia"),t.filter.vintage&&U.add("brownie"),t.filter.sepia&&U.add("sepia"),t.filter.kodachrome&&U.add("kodachrome"),t.filter.technicolor&&U.add("technicolor"),t.filter.polaroid&&U.add("polaroid"),t.filter.pixelate!==0&&U.add("pixelate",t.filter.pixelate),U.get()>0?$=U.apply(B):$=U.draw(B))):(At(B,$),U&&(U=null),w.filter=!!U),!o)return{tensor:null,canvas:$};if(!$)throw new Error("canvas error: cannot create output");let l,x=3;if(typeof ImageData!="undefined"&&e instanceof ImageData||e.data&&e.width&&e.height)if(w.browser&&A.browser)l=A.browser?A.browser.fromPixels(e):null;else{x=e.data.length/e.height/e.width;let c=new Uint8Array(e.data.buffer);l=A.tensor(c,[e.height,e.width,x],"int32")}else if((!ue||$.width!==ue.width||$.height!==ue.height)&&(ue=i0($.width,$.height)),A.browser&&w.browser)t.backend==="webgl"||t.backend==="humangl"||t.backend==="webgpu"?l=A.browser.fromPixels($):(ue=At($),l=A.browser.fromPixels(ue));else{let h=At($).getContext("2d").getImageData(0,0,s,a);x=h.data.length/s/a;let p=new Uint8Array(h.data.buffer);l=A.tensor(p,[s,a,x])}if(x===4){let c=A.slice3d(l,[0,0,0],[-1,-1,3]);A.dispose(l),l=c}if(!l)throw new Error("input error: cannot create tensor");let d=A.cast(l,"float32"),y=t.filter.equalization?await nt(d):A.expandDims(d,0);return A.dispose([l,d]),{tensor:y,canvas:t.filter.return?$:null}}}async function I2(e,t){let o=!1;if(e.cacheSensitivity===0||!t.shape||t.shape.length!==4||t.shape[1]>2048||t.shape[2]>2048)return o;if(!I0.inputTensor)I0.inputTensor=A.clone(t);else if(I0.inputTensor.shape[1]!==t.shape[1]||I0.inputTensor.shape[2]!==t.shape[2])A.dispose(I0.inputTensor),I0.inputTensor=A.clone(t);else{let n={};n.diff=A.sub(t,I0.inputTensor),n.squared=A.mul(n.diff,n.diff),n.sum=A.sum(n.squared);let s=(await n.sum.data())[0]/(t.shape[1]||1)/(t.shape[2]||1)/255/3;A.dispose([I0.inputTensor,n.diff,n.squared,n.sum]),I0.inputTensor=A.clone(t),o=s<=(e.cacheSensitivity||0)}return o}async function N2(e,t,o){let n={};if(!t||!o||t.shape.length!==4||t.shape.length!==o.shape.length)return e.debug||u("invalid input tensor or tensor shapes do not match:",t.shape,o.shape),0;if(t.shape[0]!==1||o.shape[0]!==1||t.shape[3]!==3||o.shape[3]!==3)return e.debug||u("input tensors must be of shape [1, height, width, 3]:",t.shape,o.shape),0;n.input1=A.clone(t),n.input2=t.shape[1]!==o.shape[1]||t.shape[2]!==o.shape[2]?A.image.resizeBilinear(o,[t.shape[1],t.shape[2]]):A.clone(o),n.diff=A.sub(n.input1,n.input2),n.squared=A.mul(n.diff,n.diff),n.sum=A.sum(n.squared);let s=(await n.sum.data())[0]/(t.shape[1]||1)/(t.shape[2]||1)/255/3;return A.dispose([n.input1,n.input2,n.diff,n.squared,n.sum]),s}var Kt=class{constructor(){T(this,"browser");T(this,"node");T(this,"worker");T(this,"platform","");T(this,"agent","");T(this,"backends",[]);T(this,"initial");T(this,"filter");T(this,"tfjs");T(this,"offscreen");T(this,"perfadd",!1);T(this,"wasm",{supported:void 0,backend:void 0,simd:void 0,multithread:void 0});T(this,"webgl",{supported:void 0,backend:void 0,version:void 0,renderer:void 0});T(this,"webgpu",{supported:void 0,backend:void 0,adapter:void 0});T(this,"cpu",{model:void 0,flags:[]});T(this,"kernels",[]);T(this,"Canvas");T(this,"Image");T(this,"ImageData");if(this.browser=typeof navigator!="undefined",this.node=typeof process!="undefined"&&typeof process.versions!="undefined"&&typeof process.versions.node!="undefined",this.tfjs={version:De["tfjs-core"]},this.offscreen=typeof OffscreenCanvas!="undefined",this.initial=!0,this.worker=this.browser&&this.offscreen?typeof WorkerGlobalScope!="undefined":void 0,typeof navigator!="undefined"){let t=navigator.userAgent.match(/\(([^()]+)\)/g);if(t&&t[0]){let o=t[0].match(/\(([^()]+)\)/g);this.platform=o&&o[0]?o[0].replace(/\(|\)/g,""):"",this.agent=navigator.userAgent.replace(t[0],""),this.platform[1]&&(this.agent=this.agent.replace(t[1],"")),this.agent=this.agent.replace(/ /g," ")}}else typeof process!="undefined"&&(this.platform=`${process.platform} ${process.arch}`,this.agent=`NodeJS ${process.version}`)}async updateBackend(){this.backends=Object.keys(A.engine().registryFactory),this.wasm.supported=typeof WebAssembly!="undefined",this.wasm.backend=this.backends.includes("wasm"),this.wasm.supported&&this.wasm.backend&&A.getBackend()==="wasm"&&(this.wasm.simd=await A.env().getAsync("WASM_HAS_SIMD_SUPPORT"),this.wasm.multithread=await A.env().getAsync("WASM_HAS_MULTITHREAD_SUPPORT"));let t=i0(100,100),o=t?t.getContext("webgl2"):void 0;if(this.webgl.supported=typeof o!="undefined",this.webgl.backend=this.backends.includes("webgl"),this.webgl.supported&&this.webgl.backend&&(A.getBackend()==="webgl"||A.getBackend()==="humangl")){let n=A.backend().gpgpu!=="undefined"?await A.backend().getGPGPUContext().gl:null;n&&(this.webgl.version=n.getParameter(n.VERSION),this.webgl.renderer=n.getParameter(n.RENDERER))}this.webgpu.supported=this.browser&&typeof navigator.gpu!="undefined",this.webgpu.backend=this.backends.includes("webgpu");try{this.webgpu.supported&&(this.webgpu.adapter=(await navigator.gpu.requestAdapter()).name)}catch(n){this.webgpu.supported=!1}try{this.kernels=A.getKernelsForBackend(A.getBackend()).map(n=>n.kernelName.toLowerCase())}catch(n){}}async updateCPU(){let t={model:"",flags:[]};this.node&&this.platform.startsWith("linux"),this.cpu?this.cpu=t:Object.defineProperty(this,"cpu",{value:t})}},w=new Kt;var N0={cacheModels:!1,verbose:!0,debug:!1,modelBasePath:""};async function zn(e,t){return N0.debug&&u("load model fetch:",e,t),fetch(e,t)}function F2(e){N0.cacheModels=e.cacheModels,N0.verbose=e.debug,N0.modelBasePath=e.modelBasePath}async function I(e){let t=E2(N0.modelBasePath,e||"");t.toLowerCase().endsWith(".json")||(t+=".json");let o=t.split("/"),n="indexeddb://"+o[o.length-1].replace(".json",""),r=await A.io.listModels(),s=N0.cacheModels&&Object.keys(r).includes(n),a=typeof fetch=="undefined"?{}:{fetchFunc:(x,d)=>zn(x,d)},i=new Ut(s?n:t,a),l=!1;try{i.findIOHandler(),N0.debug&&u("model load handler:",i.handler);let x=await i.handler.load();i.loadSync(x),N0.verbose&&u("load model:",i.modelUrl),l=!0}catch(x){u("error loading model:",t,x)}if(l&&N0.cacheModels&&!s)try{let x=await i.save(n);u("model saved:",n,x)}catch(x){u("error saving model:",t,x)}return i}var Qt="2.7.3";var y2={};ne(y2,{Models:()=>$e,load:()=>i2,reset:()=>Gt,validate:()=>l2});var v0,_t=[],Cn=["white","black","asian","indian","other"],Wn=[15,23,28,35.5,45.5,55.5,65],B2=0,G2=0,$t=Number.MAX_SAFE_INTEGER;async function H2(e){return w.initial&&(v0=null),v0?e.debug&&u("cached model:",v0.modelUrl):v0=await I(e.face.gear),v0}async function e5(e,t,o,n){var a,i;if(!v0)return{age:0,gender:"unknown",genderScore:0,race:[]};let r=$t<(((a=t.face.gear)==null?void 0:a.skipFrames)||0),s=(((i=t.face.gear)==null?void 0:i.skipTime)||0)>b()-G2;return t.skipAllowed&&s&&r&&B2===n&&_t[o]?($t++,_t[o]):($t=0,new Promise(async l=>{var P,g;if(!(v0!=null&&v0.inputs[0].shape))return;let x={},d=[[0,.1,.9,.9]];x.resize=A.image.cropAndResize(e,d,[0],[v0.inputs[0].shape[2],v0.inputs[0].shape[1]]);let y={age:0,gender:"unknown",genderScore:0,race:[]};(P=t.face.gear)!=null&&P.enabled&&([x.age,x.gender,x.race]=v0.execute(x.resize,["age_output","gender_output","race_output"]));let c=await x.gender.data();y.gender=c[0]>c[1]?"male":"female",y.genderScore=Math.round(100*(c[0]>c[1]?c[0]:c[1]))/100;let m=await x.race.data();for(let f=0;f(((g=t.face.gear)==null?void 0:g.minConfidence)||.2)&&y.race.push({score:Math.round(100*m[f])/100,race:Cn[f]});y.race.sort((f,v)=>v.score-f.score);let p=Array.from(await x.age.data()).map((f,v)=>[Wn[v],f]).sort((f,v)=>v[1]-f[1]),M=p[0][0];for(let f=1;fA.dispose(x[f])),_t[o]=y,B2=n,G2=b(),l(y)}))}var N={tf255:255,tf1:1,tf2:2,tf05:.5,tf127:127.5,rgb:[.2989,.587,.114]};function Z2(){N.tf255=A.scalar(255,"float32"),N.tf1=A.scalar(1,"float32"),N.tf2=A.scalar(2,"float32"),N.tf05=A.scalar(.5,"float32"),N.tf127=A.scalar(127.5,"float32"),N.rgb=A.tensor1d([.2989,.587,.114],"float32")}var x0,st=[],D2=0,X2=0,t5=Number.MAX_SAFE_INTEGER;async function q2(e){return w.initial&&(x0=null),x0?e.debug&&u("cached model:",x0.modelUrl):x0=await I(e.face.ssrnet.modelPathAge),x0}async function o5(e,t,o,n){var a,i,l,x;if(!x0)return{age:0};let r=t5<(((a=t.face.ssrnet)==null?void 0:a.skipFrames)||0),s=(((i=t.face.ssrnet)==null?void 0:i.skipTime)||0)>b()-X2;return t.skipAllowed&&r&&s&&D2===n&&((l=st[o])==null?void 0:l.age)&&((x=st[o])==null?void 0:x.age)>0?(t5++,st[o]):(t5=0,new Promise(async d=>{if(!(x0!=null&&x0.inputs)||!x0.inputs[0]||!x0.inputs[0].shape)return;let y={};y.resize=A.image.resizeBilinear(e,[x0.inputs[0].shape[2],x0.inputs[0].shape[1]],!1),y.enhance=A.mul(y.resize,N.tf255);let c={age:0};if(t.face.ssrnet.enabled&&(y.age=x0.execute(y.enhance)),y.age){let m=await y.age.data();c.age=Math.trunc(10*m[0])/10}Object.keys(y).forEach(m=>A.dispose(y[m])),st[o]=c,D2=n,X2=b(),d(c)}))}var M0,at=[],J2=0,Y2=0,n5=Number.MAX_SAFE_INTEGER,r5=[.2989,.587,.114];async function K2(e){return w.initial&&(M0=null),M0?e.debug&&u("cached model:",M0.modelUrl):M0=await I(e.face.ssrnet.modelPathGender),M0}async function A5(e,t,o,n){var a,i,l,x;if(!M0)return{gender:"unknown",genderScore:0};let r=n5<(((a=t.face.ssrnet)==null?void 0:a.skipFrames)||0),s=(((i=t.face.ssrnet)==null?void 0:i.skipTime)||0)>b()-Y2;return t.skipAllowed&&r&&s&&J2===n&&((l=at[o])==null?void 0:l.gender)&&((x=at[o])==null?void 0:x.genderScore)>0?(n5++,at[o]):(n5=0,new Promise(async d=>{if(!(M0!=null&&M0.inputs[0].shape))return;let y={};y.resize=A.image.resizeBilinear(e,[M0.inputs[0].shape[2],M0.inputs[0].shape[1]],!1),y.enhance=A.tidy(()=>{let[h,p,M]=A.split(y.resize,3,3),P=A.mul(h,r5[0]),g=A.mul(p,r5[1]),f=A.mul(M,r5[2]),v=A.addN([P,g,f]);return A.mul(A.sub(v,N.tf05),2)});let c={gender:"unknown",genderScore:0};t.face.ssrnet.enabled&&(y.gender=M0.execute(y.enhance));let m=await y.gender.data();c.gender=m[0]>m[1]?"female":"male",c.genderScore=m[0]>m[1]?Math.trunc(100*m[0])/100:Math.trunc(100*m[1])/100,Object.keys(y).forEach(h=>A.dispose(y[h])),at[o]=c,J2=n,Y2=b(),d(c)}))}var r0,it=[],s5=Number.MAX_SAFE_INTEGER,_2=0,$2=0;async function e1(e){var t;return w.initial&&(r0=null),r0?e.debug&&u("cached model:",r0.modelUrl):r0=await I((t=e.face.antispoof)==null?void 0:t.modelPath),r0}async function a5(e,t,o,n){var a,i;if(!r0)return 0;let r=(((a=t.face.antispoof)==null?void 0:a.skipTime)||0)>b()-$2,s=s5<(((i=t.face.antispoof)==null?void 0:i.skipFrames)||0);return t.skipAllowed&&r&&s&&_2===n&&it[o]?(s5++,it[o]):(s5=0,new Promise(async l=>{let x=A.image.resizeBilinear(e,[r0!=null&&r0.inputs[0].shape?r0.inputs[0].shape[2]:0,r0!=null&&r0.inputs[0].shape?r0.inputs[0].shape[1]:0],!1),d=r0==null?void 0:r0.execute(x),y=(await d.data())[0];it[o]=Math.round(100*y)/100,_2=n,$2=b(),A.dispose([x,d]),l(it[o])}))}var R0={silhouette:[10,338,297,332,284,251,389,356,454,323,361,288,397,365,379,378,400,377,152,148,176,149,150,136,172,58,132,93,234,127,162,21,54,103,67,109],lipsUpperOuter:[61,185,40,39,37,0,267,269,270,409,291],lipsLowerOuter:[146,91,181,84,17,314,405,321,375,291],lipsUpperInner:[78,191,80,81,82,13,312,311,310,415,308],lipsLowerInner:[78,95,88,178,87,14,317,402,318,324,308],rightEyeUpper0:[246,161,160,159,158,157,173],rightEyeLower0:[33,7,163,144,145,153,154,155,133],rightEyeUpper1:[247,30,29,27,28,56,190],rightEyeLower1:[130,25,110,24,23,22,26,112,243],rightEyeUpper2:[113,225,224,223,222,221,189],rightEyeLower2:[226,31,228,229,230,231,232,233,244],rightEyeLower3:[143,111,117,118,119,120,121,128,245],rightEyebrowUpper:[156,70,63,105,66,107,55,193],rightEyebrowLower:[35,124,46,53,52,65],rightEyeIris:[473,474,475,476,477],leftEyeUpper0:[466,388,387,386,385,384,398],leftEyeLower0:[263,249,390,373,374,380,381,382,362],leftEyeUpper1:[467,260,259,257,258,286,414],leftEyeLower1:[359,255,339,254,253,252,256,341,463],leftEyeUpper2:[342,445,444,443,442,441,413],leftEyeLower2:[446,261,448,449,450,451,452,453,464],leftEyeLower3:[372,340,346,347,348,349,350,357,465],leftEyebrowUpper:[383,300,293,334,296,336,285,417],leftEyebrowLower:[265,353,276,283,282,295],leftEyeIris:[468,469,470,471,472],midwayBetweenEyes:[168],noseTip:[1],noseBottom:[2],noseRightCorner:[98],noseLeftCorner:[327],rightCheek:[205],leftCheek:[425]},i5={count:468,mouth:13,symmetryLine:[13,R0.midwayBetweenEyes[0]]},Ae={leftEye:0,rightEye:1,nose:2,mouth:3,leftEar:4,rightEar:5,symmetryLine:[3,2]},l5=[{key:"EyeUpper0",indices:[9,10,11,12,13,14,15]},{key:"EyeUpper1",indices:[25,26,27,28,29,30,31]},{key:"EyeUpper2",indices:[41,42,43,44,45,46,47]},{key:"EyeLower0",indices:[0,1,2,3,4,5,6,7,8]},{key:"EyeLower1",indices:[16,17,18,19,20,21,22,23,24]},{key:"EyeLower2",indices:[32,33,34,35,36,37,38,39,40]},{key:"EyeLower3",indices:[54,55,56,57,58,59,60,61,62]},{key:"EyebrowUpper",indices:[63,64,65,66,67,68,69,70]},{key:"EyebrowLower",indices:[48,49,50,51,52,53]}],qe=[[.499976992607117,.652534008026123],[.500025987625122,.547487020492554],[.499974012374878,.602371990680695],[.482113003730774,.471979022026062],[.500150978565216,.527155995368958],[.499909996986389,.498252987861633],[.499523013830185,.40106201171875],[.289712011814117,.380764007568359],[.499954998493195,.312398016452789],[.499987006187439,.269918978214264],[.500023007392883,.107050001621246],[.500023007392883,.666234016418457],[.5000159740448,.679224014282227],[.500023007392883,.692348003387451],[.499976992607117,.695277988910675],[.499976992607117,.70593398809433],[.499976992607117,.719385027885437],[.499976992607117,.737019002437592],[.499967992305756,.781370997428894],[.499816000461578,.562981009483337],[.473773002624512,.573909997940063],[.104906998574734,.254140973091125],[.365929991006851,.409575998783112],[.338757991790771,.41302502155304],[.311120003461838,.409460008144379],[.274657994508743,.389131009578705],[.393361985683441,.403706014156342],[.345234006643295,.344011008739471],[.370094001293182,.346076011657715],[.319321990013123,.347265005111694],[.297903001308441,.353591024875641],[.24779200553894,.410809993743896],[.396889001131058,.842755019664764],[.280097991228104,.375599980354309],[.106310002505779,.399955987930298],[.2099249958992,.391353011131287],[.355807989835739,.534406006336212],[.471751004457474,.65040397644043],[.474155008792877,.680191993713379],[.439785003662109,.657229006290436],[.414617002010345,.66654098033905],[.450374007225037,.680860996246338],[.428770989179611,.682690978050232],[.374971002340317,.727805018424988],[.486716985702515,.547628998756409],[.485300987958908,.527395009994507],[.257764995098114,.314490020275116],[.401223003864288,.455172002315521],[.429818987846375,.548614978790283],[.421351999044418,.533740997314453],[.276895999908447,.532056987285614],[.483370006084442,.499586999416351],[.33721199631691,.282882988452911],[.296391993761063,.293242990970612],[.169294998049736,.193813979625702],[.447580009698868,.302609980106354],[.392390012741089,.353887975215912],[.354490011930466,.696784019470215],[.067304998636246,.730105042457581],[.442739009857178,.572826027870178],[.457098007202148,.584792017936707],[.381974011659622,.694710969924927],[.392388999462128,.694203019142151],[.277076005935669,.271932005882263],[.422551989555359,.563233017921448],[.385919004678726,.281364023685455],[.383103013038635,.255840003490448],[.331431001424789,.119714021682739],[.229923993349075,.232002973556519],[.364500999450684,.189113974571228],[.229622006416321,.299540996551514],[.173287004232407,.278747975826263],[.472878992557526,.666198015213013],[.446828007698059,.668527007102966],[.422762006521225,.673889994621277],[.445307999849319,.580065965652466],[.388103008270264,.693961024284363],[.403039008378983,.706539988517761],[.403629004955292,.693953037261963],[.460041999816895,.557139039039612],[.431158006191254,.692366003990173],[.452181994915009,.692366003990173],[.475387006998062,.692366003990173],[.465828001499176,.779190003871918],[.472328990697861,.736225962638855],[.473087012767792,.717857003211975],[.473122000694275,.704625964164734],[.473033010959625,.695277988910675],[.427942007780075,.695277988910675],[.426479011774063,.703539967536926],[.423162013292313,.711845993995667],[.4183090031147,.720062971115112],[.390094995498657,.639572978019714],[.013953999616206,.560034036636353],[.499913990497589,.58014702796936],[.413199990987778,.69539999961853],[.409626007080078,.701822996139526],[.468080013990402,.601534962654114],[.422728985548019,.585985004901886],[.463079988956451,.593783974647522],[.37211999297142,.47341400384903],[.334562003612518,.496073007583618],[.411671012639999,.546965003013611],[.242175996303558,.14767599105835],[.290776997804642,.201445996761322],[.327338010072708,.256527006626129],[.399509996175766,.748921036720276],[.441727995872498,.261676013469696],[.429764986038208,.187834024429321],[.412198007106781,.108901023864746],[.288955003023148,.398952007293701],[.218936994671822,.435410976409912],[.41278201341629,.398970007896423],[.257135003805161,.355440020561218],[.427684992551804,.437960982322693],[.448339998722076,.536936044692993],[.178560003638268,.45755398273468],[.247308000922203,.457193970680237],[.286267012357712,.467674970626831],[.332827985286713,.460712015628815],[.368755996227264,.447206974029541],[.398963987827301,.432654976844788],[.476410001516342,.405806005001068],[.189241006970406,.523923993110657],[.228962004184723,.348950982093811],[.490725994110107,.562400996685028],[.404670000076294,.485132992267609],[.019469000399113,.401564002037048],[.426243007183075,.420431017875671],[.396993011236191,.548797011375427],[.266469985246658,.376977026462555],[.439121007919312,.51895797252655],[.032313998788595,.644356966018677],[.419054001569748,.387154996395111],[.462783008813858,.505746960639954],[.238978996872902,.779744982719421],[.198220998048782,.831938028335571],[.107550002634525,.540755033493042],[.183610007166862,.740257024765015],[.134409993886948,.333683013916016],[.385764002799988,.883153975009918],[.490967005491257,.579378008842468],[.382384985685349,.508572995662689],[.174399003386497,.397670984268188],[.318785011768341,.39623498916626],[.343364000320435,.400596976280212],[.396100014448166,.710216999053955],[.187885001301765,.588537991046906],[.430987000465393,.944064974784851],[.318993002176285,.898285031318665],[.266247987747192,.869701027870178],[.500023007392883,.190576016902924],[.499976992607117,.954452991485596],[.366169989109039,.398822009563446],[.393207013607025,.39553701877594],[.410373002290726,.391080021858215],[.194993004202843,.342101991176605],[.388664990663528,.362284004688263],[.365961998701096,.355970978736877],[.343364000320435,.355356991291046],[.318785011768341,.35834002494812],[.301414996385574,.363156020641327],[.058132998645306,.319076001644135],[.301414996385574,.387449026107788],[.499987989664078,.618434011936188],[.415838003158569,.624195992946625],[.445681989192963,.566076993942261],[.465844005346298,.620640993118286],[.49992299079895,.351523995399475],[.288718998432159,.819945991039276],[.335278987884521,.852819979190826],[.440512001514435,.902418971061707],[.128294005990028,.791940987110138],[.408771991729736,.373893976211548],[.455606997013092,.451801002025604],[.499877005815506,.908990025520325],[.375436991453171,.924192011356354],[.11421000212431,.615022003650665],[.448662012815475,.695277988910675],[.4480200111866,.704632043838501],[.447111994028091,.715808033943176],[.444831997156143,.730794012546539],[.430011987686157,.766808986663818],[.406787008047104,.685672998428345],[.400738000869751,.681069016456604],[.392399996519089,.677703022956848],[.367855995893478,.663918972015381],[.247923001646996,.601333022117615],[.452769994735718,.420849978923798],[.43639200925827,.359887003898621],[.416164010763168,.368713974952698],[.413385987281799,.692366003990173],[.228018000721931,.683571994304657],[.468268007040024,.352671027183533],[.411361992359161,.804327011108398],[.499989002943039,.469825029373169],[.479153990745544,.442654013633728],[.499974012374878,.439637005329132],[.432112008333206,.493588984012604],[.499886006116867,.866917014122009],[.49991300702095,.821729004383087],[.456548988819122,.819200992584229],[.344549000263214,.745438992977142],[.37890899181366,.574010014533997],[.374292999505997,.780184984207153],[.319687992334366,.570737957954407],[.357154995203018,.604269981384277],[.295284003019333,.621580958366394],[.447750002145767,.862477004528046],[.410986006259918,.508723020553589],[.31395098567009,.775308012962341],[.354128003120422,.812552988529205],[.324548006057739,.703992962837219],[.189096003770828,.646299958229065],[.279776990413666,.71465802192688],[.1338230073452,.682700991630554],[.336768001317978,.644733011722565],[.429883986711502,.466521978378296],[.455527991056442,.548622965812683],[.437114000320435,.558896005153656],[.467287987470627,.529924988746643],[.414712011814117,.335219979286194],[.37704598903656,.322777986526489],[.344107985496521,.320150971412659],[.312875986099243,.32233202457428],[.283526003360748,.333190023899078],[.241245999932289,.382785975933075],[.102986000478268,.468762993812561],[.267612010240555,.424560010433197],[.297879010438919,.433175981044769],[.333433985710144,.433878004550934],[.366427004337311,.426115989685059],[.396012008190155,.416696012020111],[.420121014118195,.41022801399231],[.007561000064015,.480777025222778],[.432949006557465,.569517970085144],[.458638995885849,.479089021682739],[.473466008901596,.545744001865387],[.476087987422943,.563830018043518],[.468472003936768,.555056989192963],[.433990985155106,.582361996173859],[.483518004417419,.562983989715576],[.482482999563217,.57784903049469],[.42645001411438,.389798998832703],[.438998997211456,.39649498462677],[.450067013502121,.400434017181396],[.289712011814117,.368252992630005],[.276670008897781,.363372981548309],[.517862021923065,.471948027610779],[.710287988185883,.380764007568359],[.526226997375488,.573909997940063],[.895093023777008,.254140973091125],[.634069979190826,.409575998783112],[.661242008209229,.41302502155304],[.688880026340485,.409460008144379],[.725341975688934,.389131009578705],[.606630027294159,.40370500087738],[.654766023159027,.344011008739471],[.629905998706818,.346076011657715],[.680678009986877,.347265005111694],[.702096998691559,.353591024875641],[.75221198797226,.410804986953735],[.602918028831482,.842862963676453],[.719901978969574,.375599980354309],[.893692970275879,.399959981441498],[.790081977844238,.391354024410248],[.643998026847839,.534487962722778],[.528249025344849,.65040397644043],[.525849997997284,.680191040039062],[.560214996337891,.657229006290436],[.585384011268616,.66654098033905],[.549625992774963,.680860996246338],[.57122802734375,.682691991329193],[.624852001667023,.72809898853302],[.513050019741058,.547281980514526],[.51509702205658,.527251958847046],[.742246985435486,.314507007598877],[.598631024360657,.454979002475739],[.570338010787964,.548575043678284],[.578631997108459,.533622980117798],[.723087012767792,.532054007053375],[.516445994377136,.499638974666595],[.662801027297974,.282917976379395],[.70362401008606,.293271005153656],[.830704987049103,.193813979625702],[.552385985851288,.302568018436432],[.607609987258911,.353887975215912],[.645429015159607,.696707010269165],[.932694971561432,.730105042457581],[.557260990142822,.572826027870178],[.542901992797852,.584792017936707],[.6180260181427,.694710969924927],[.607590973377228,.694203019142151],[.722943007946014,.271963000297546],[.577413976192474,.563166975975037],[.614082992076874,.281386971473694],[.616907000541687,.255886018276215],[.668509006500244,.119913995265961],[.770092010498047,.232020974159241],[.635536015033722,.189248979091644],[.77039098739624,.299556016921997],[.826722025871277,.278755009174347],[.527121007442474,.666198015213013],[.553171992301941,.668527007102966],[.577238023281097,.673889994621277],[.554691970348358,.580065965652466],[.611896991729736,.693961024284363],[.59696102142334,.706539988517761],[.596370995044708,.693953037261963],[.539958000183105,.557139039039612],[.568841993808746,.692366003990173],[.547818005084991,.692366003990173],[.52461302280426,.692366003990173],[.534089982509613,.779141008853912],[.527670979499817,.736225962638855],[.526912987232208,.717857003211975],[.526877999305725,.704625964164734],[.526966989040375,.695277988910675],[.572058022022247,.695277988910675],[.573521018028259,.703539967536926],[.57683801651001,.711845993995667],[.581691026687622,.720062971115112],[.609944999217987,.639909982681274],[.986046016216278,.560034036636353],[.5867999792099,.69539999961853],[.590372025966644,.701822996139526],[.531915009021759,.601536989212036],[.577268004417419,.585934996604919],[.536915004253387,.593786001205444],[.627542972564697,.473352015018463],[.665585994720459,.495950996875763],[.588353991508484,.546862006187439],[.757824003696442,.14767599105835],[.709249973297119,.201507985591888],[.672684013843536,.256581008434296],[.600408971309662,.74900496006012],[.55826598405838,.261672019958496],[.570303976535797,.187870979309082],[.588165998458862,.109044015407562],[.711045026779175,.398952007293701],[.781069993972778,.435405015945435],[.587247014045715,.398931980133057],[.742869973182678,.355445981025696],[.572156012058258,.437651991844177],[.55186802148819,.536570012569427],[.821442008018494,.457556009292603],[.752701997756958,.457181990146637],[.71375697851181,.467626988887787],[.66711300611496,.460672974586487],[.631101012229919,.447153985500336],[.6008620262146,.432473003864288],[.523481011390686,.405627012252808],[.810747981071472,.523926019668579],[.771045982837677,.348959028720856],[.509127020835876,.562718033790588],[.595292985439301,.485023975372314],[.980530977249146,.401564002037048],[.573499977588654,.420000016689301],[.602994978427887,.548687994480133],[.733529984951019,.376977026462555],[.560611009597778,.519016981124878],[.967685997486115,.644356966018677],[.580985009670258,.387160003185272],[.537728011608124,.505385041236877],[.760966002941132,.779752969741821],[.801778972148895,.831938028335571],[.892440974712372,.54076099395752],[.816350996494293,.740260004997253],[.865594983100891,.333687007427216],[.614073991775513,.883246004581451],[.508952975273132,.579437971115112],[.617941975593567,.508316040039062],[.825608015060425,.397674977779388],[.681214988231659,.39623498916626],[.656635999679565,.400596976280212],[.603900015354156,.710216999053955],[.81208598613739,.588539004325867],[.56801301240921,.944564998149872],[.681007981300354,.898285031318665],[.733752012252808,.869701027870178],[.633830010890961,.398822009563446],[.606792986392975,.39553701877594],[.589659988880157,.391062021255493],[.805015981197357,.342108011245728],[.611334979534149,.362284004688263],[.634037971496582,.355970978736877],[.656635999679565,.355356991291046],[.681214988231659,.35834002494812],[.698584973812103,.363156020641327],[.941866993904114,.319076001644135],[.698584973812103,.387449026107788],[.584177017211914,.624107003211975],[.554318010807037,.566076993942261],[.534153997898102,.62064003944397],[.711217999458313,.819975018501282],[.664629995822906,.852871000766754],[.559099972248077,.902631998062134],[.871706008911133,.791940987110138],[.591234028339386,.373893976211548],[.544341027736664,.451583981513977],[.624562978744507,.924192011356354],[.88577002286911,.615028977394104],[.551338016986847,.695277988910675],[.551980018615723,.704632043838501],[.552887976169586,.715808033943176],[.555167973041534,.730794012546539],[.569944024085999,.767035007476807],[.593203008174896,.685675978660583],[.599261999130249,.681069016456604],[.607599973678589,.677703022956848],[.631937980651855,.663500010967255],[.752032995223999,.601315021514893],[.547226011753082,.420395016670227],[.563543975353241,.359827995300293],[.583841025829315,.368713974952698],[.586614012718201,.692366003990173],[.771915018558502,.683578014373779],[.531597018241882,.352482974529266],[.588370978832245,.804440975189209],[.52079701423645,.442565023899078],[.567984998226166,.493479013442993],[.543282985687256,.819254994392395],[.655317008495331,.745514988899231],[.621008992195129,.574018001556396],[.625559985637665,.78031200170517],[.680198013782501,.570719003677368],[.64276397228241,.604337990283966],[.704662978649139,.621529996395111],[.552012026309967,.862591981887817],[.589071989059448,.508637011051178],[.685944974422455,.775357007980347],[.645735025405884,.812640011310577],[.675342977046967,.703978002071381],[.810858011245728,.646304965019226],[.72012197971344,.714666962623596],[.866151988506317,.682704985141754],[.663187026977539,.644596993923187],[.570082008838654,.466325998306274],[.544561982154846,.548375964164734],[.562758982181549,.558784961700439],[.531987011432648,.530140042304993],[.585271000862122,.335177004337311],[.622952997684479,.32277899980545],[.655896008014679,.320163011550903],[.687132000923157,.322345972061157],[.716481983661652,.333200991153717],[.758756995201111,.382786989212036],[.897013008594513,.468769013881683],[.732392013072968,.424547016620636],[.70211398601532,.433162987232208],[.66652500629425,.433866024017334],[.633504986763,.426087975502014],[.603875994682312,.416586995124817],[.579657971858978,.409945011138916],[.992439985275269,.480777025222778],[.567192018032074,.569419980049133],[.54136598110199,.478899002075195],[.526564002037048,.546118021011353],[.523913025856018,.563830018043518],[.531529009342194,.555056989192963],[.566035985946655,.582329034805298],[.51631098985672,.563053965568542],[.5174720287323,.577877044677734],[.573594987392426,.389806985855103],[.560697972774506,.395331978797913],[.549755990505219,.399751007556915],[.710287988185883,.368252992630005],[.723330020904541,.363372981548309]],se=[127,34,139,11,0,37,232,231,120,72,37,39,128,121,47,232,121,128,104,69,67,175,171,148,157,154,155,118,50,101,73,39,40,9,151,108,48,115,131,194,204,211,74,40,185,80,42,183,40,92,186,230,229,118,202,212,214,83,18,17,76,61,146,160,29,30,56,157,173,106,204,194,135,214,192,203,165,98,21,71,68,51,45,4,144,24,23,77,146,91,205,50,187,201,200,18,91,106,182,90,91,181,85,84,17,206,203,36,148,171,140,92,40,39,193,189,244,159,158,28,247,246,161,236,3,196,54,68,104,193,168,8,117,228,31,189,193,55,98,97,99,126,47,100,166,79,218,155,154,26,209,49,131,135,136,150,47,126,217,223,52,53,45,51,134,211,170,140,67,69,108,43,106,91,230,119,120,226,130,247,63,53,52,238,20,242,46,70,156,78,62,96,46,53,63,143,34,227,173,155,133,123,117,111,44,125,19,236,134,51,216,206,205,154,153,22,39,37,167,200,201,208,36,142,100,57,212,202,20,60,99,28,158,157,35,226,113,160,159,27,204,202,210,113,225,46,43,202,204,62,76,77,137,123,116,41,38,72,203,129,142,64,98,240,49,102,64,41,73,74,212,216,207,42,74,184,169,170,211,170,149,176,105,66,69,122,6,168,123,147,187,96,77,90,65,55,107,89,90,180,101,100,120,63,105,104,93,137,227,15,86,85,129,102,49,14,87,86,55,8,9,100,47,121,145,23,22,88,89,179,6,122,196,88,95,96,138,172,136,215,58,172,115,48,219,42,80,81,195,3,51,43,146,61,171,175,199,81,82,38,53,46,225,144,163,110,246,33,7,52,65,66,229,228,117,34,127,234,107,108,69,109,108,151,48,64,235,62,78,191,129,209,126,111,35,143,163,161,246,117,123,50,222,65,52,19,125,141,221,55,65,3,195,197,25,7,33,220,237,44,70,71,139,122,193,245,247,130,33,71,21,162,153,158,159,170,169,150,188,174,196,216,186,92,144,160,161,2,97,167,141,125,241,164,167,37,72,38,12,145,159,160,38,82,13,63,68,71,226,35,111,158,153,154,101,50,205,206,92,165,209,198,217,165,167,97,220,115,218,133,112,243,239,238,241,214,135,169,190,173,133,171,208,32,125,44,237,86,87,178,85,86,179,84,85,180,83,84,181,201,83,182,137,93,132,76,62,183,61,76,184,57,61,185,212,57,186,214,207,187,34,143,156,79,239,237,123,137,177,44,1,4,201,194,32,64,102,129,213,215,138,59,166,219,242,99,97,2,94,141,75,59,235,24,110,228,25,130,226,23,24,229,22,23,230,26,22,231,112,26,232,189,190,243,221,56,190,28,56,221,27,28,222,29,27,223,30,29,224,247,30,225,238,79,20,166,59,75,60,75,240,147,177,215,20,79,166,187,147,213,112,233,244,233,128,245,128,114,188,114,217,174,131,115,220,217,198,236,198,131,134,177,132,58,143,35,124,110,163,7,228,110,25,356,389,368,11,302,267,452,350,349,302,303,269,357,343,277,452,453,357,333,332,297,175,152,377,384,398,382,347,348,330,303,304,270,9,336,337,278,279,360,418,262,431,304,408,409,310,415,407,270,409,410,450,348,347,422,430,434,313,314,17,306,307,375,387,388,260,286,414,398,335,406,418,364,367,416,423,358,327,251,284,298,281,5,4,373,374,253,307,320,321,425,427,411,421,313,18,321,405,406,320,404,405,315,16,17,426,425,266,377,400,369,322,391,269,417,465,464,386,257,258,466,260,388,456,399,419,284,332,333,417,285,8,346,340,261,413,441,285,327,460,328,355,371,329,392,439,438,382,341,256,429,420,360,364,394,379,277,343,437,443,444,283,275,440,363,431,262,369,297,338,337,273,375,321,450,451,349,446,342,467,293,334,282,458,461,462,276,353,383,308,324,325,276,300,293,372,345,447,382,398,362,352,345,340,274,1,19,456,248,281,436,427,425,381,256,252,269,391,393,200,199,428,266,330,329,287,273,422,250,462,328,258,286,384,265,353,342,387,259,257,424,431,430,342,353,276,273,335,424,292,325,307,366,447,345,271,303,302,423,266,371,294,455,460,279,278,294,271,272,304,432,434,427,272,407,408,394,430,431,395,369,400,334,333,299,351,417,168,352,280,411,325,319,320,295,296,336,319,403,404,330,348,349,293,298,333,323,454,447,15,16,315,358,429,279,14,15,316,285,336,9,329,349,350,374,380,252,318,402,403,6,197,419,318,319,325,367,364,365,435,367,397,344,438,439,272,271,311,195,5,281,273,287,291,396,428,199,311,271,268,283,444,445,373,254,339,263,466,249,282,334,296,449,347,346,264,447,454,336,296,299,338,10,151,278,439,455,292,407,415,358,371,355,340,345,372,390,249,466,346,347,280,442,443,282,19,94,370,441,442,295,248,419,197,263,255,359,440,275,274,300,383,368,351,412,465,263,467,466,301,368,389,380,374,386,395,378,379,412,351,419,436,426,322,373,390,388,2,164,393,370,462,461,164,0,267,302,11,12,374,373,387,268,12,13,293,300,301,446,261,340,385,384,381,330,266,425,426,423,391,429,355,437,391,327,326,440,457,438,341,382,362,459,457,461,434,430,394,414,463,362,396,369,262,354,461,457,316,403,402,315,404,403,314,405,404,313,406,405,421,418,406,366,401,361,306,408,407,291,409,408,287,410,409,432,436,410,434,416,411,264,368,383,309,438,457,352,376,401,274,275,4,421,428,262,294,327,358,433,416,367,289,455,439,462,370,326,2,326,370,305,460,455,254,449,448,255,261,446,253,450,449,252,451,450,256,452,451,341,453,452,413,464,463,441,413,414,258,442,441,257,443,442,259,444,443,260,445,444,467,342,445,459,458,250,289,392,290,290,328,460,376,433,435,250,290,392,411,416,433,341,463,464,453,464,465,357,465,412,343,412,399,360,363,440,437,399,456,420,456,363,401,435,288,372,383,353,339,255,249,448,261,255,133,243,190,133,155,112,33,246,247,33,130,25,398,384,286,362,398,414,362,463,341,263,359,467,263,249,255,466,467,260,75,60,166,238,239,79,162,127,139,72,11,37,121,232,120,73,72,39,114,128,47,233,232,128,103,104,67,152,175,148,173,157,155,119,118,101,74,73,40,107,9,108,49,48,131,32,194,211,184,74,185,191,80,183,185,40,186,119,230,118,210,202,214,84,83,17,77,76,146,161,160,30,190,56,173,182,106,194,138,135,192,129,203,98,54,21,68,5,51,4,145,144,23,90,77,91,207,205,187,83,201,18,181,91,182,180,90,181,16,85,17,205,206,36,176,148,140,165,92,39,245,193,244,27,159,28,30,247,161,174,236,196,103,54,104,55,193,8,111,117,31,221,189,55,240,98,99,142,126,100,219,166,218,112,155,26,198,209,131,169,135,150,114,47,217,224,223,53,220,45,134,32,211,140,109,67,108,146,43,91,231,230,120,113,226,247,105,63,52,241,238,242,124,46,156,95,78,96,70,46,63,116,143,227,116,123,111,1,44,19,3,236,51,207,216,205,26,154,22,165,39,167,199,200,208,101,36,100,43,57,202,242,20,99,56,28,157,124,35,113,29,160,27,211,204,210,124,113,46,106,43,204,96,62,77,227,137,116,73,41,72,36,203,142,235,64,240,48,49,64,42,41,74,214,212,207,183,42,184,210,169,211,140,170,176,104,105,69,193,122,168,50,123,187,89,96,90,66,65,107,179,89,180,119,101,120,68,63,104,234,93,227,16,15,85,209,129,49,15,14,86,107,55,9,120,100,121,153,145,22,178,88,179,197,6,196,89,88,96,135,138,136,138,215,172,218,115,219,41,42,81,5,195,51,57,43,61,208,171,199,41,81,38,224,53,225,24,144,110,105,52,66,118,229,117,227,34,234,66,107,69,10,109,151,219,48,235,183,62,191,142,129,126,116,111,143,7,163,246,118,117,50,223,222,52,94,19,141,222,221,65,196,3,197,45,220,44,156,70,139,188,122,245,139,71,162,145,153,159,149,170,150,122,188,196,206,216,92,163,144,161,164,2,167,242,141,241,0,164,37,11,72,12,144,145,160,12,38,13,70,63,71,31,226,111,157,158,154,36,101,205,203,206,165,126,209,217,98,165,97,237,220,218,237,239,241,210,214,169,140,171,32,241,125,237,179,86,178,180,85,179,181,84,180,182,83,181,194,201,182,177,137,132,184,76,183,185,61,184,186,57,185,216,212,186,192,214,187,139,34,156,218,79,237,147,123,177,45,44,4,208,201,32,98,64,129,192,213,138,235,59,219,141,242,97,97,2,141,240,75,235,229,24,228,31,25,226,230,23,229,231,22,230,232,26,231,233,112,232,244,189,243,189,221,190,222,28,221,223,27,222,224,29,223,225,30,224,113,247,225,99,60,240,213,147,215,60,20,166,192,187,213,243,112,244,244,233,245,245,128,188,188,114,174,134,131,220,174,217,236,236,198,134,215,177,58,156,143,124,25,110,7,31,228,25,264,356,368,0,11,267,451,452,349,267,302,269,350,357,277,350,452,357,299,333,297,396,175,377,381,384,382,280,347,330,269,303,270,151,9,337,344,278,360,424,418,431,270,304,409,272,310,407,322,270,410,449,450,347,432,422,434,18,313,17,291,306,375,259,387,260,424,335,418,434,364,416,391,423,327,301,251,298,275,281,4,254,373,253,375,307,321,280,425,411,200,421,18,335,321,406,321,320,405,314,315,17,423,426,266,396,377,369,270,322,269,413,417,464,385,386,258,248,456,419,298,284,333,168,417,8,448,346,261,417,413,285,326,327,328,277,355,329,309,392,438,381,382,256,279,429,360,365,364,379,355,277,437,282,443,283,281,275,363,395,431,369,299,297,337,335,273,321,348,450,349,359,446,467,283,293,282,250,458,462,300,276,383,292,308,325,283,276,293,264,372,447,346,352,340,354,274,19,363,456,281,426,436,425,380,381,252,267,269,393,421,200,428,371,266,329,432,287,422,290,250,328,385,258,384,446,265,342,386,387,257,422,424,430,445,342,276,422,273,424,306,292,307,352,366,345,268,271,302,358,423,371,327,294,460,331,279,294,303,271,304,436,432,427,304,272,408,395,394,431,378,395,400,296,334,299,6,351,168,376,352,411,307,325,320,285,295,336,320,319,404,329,330,349,334,293,333,366,323,447,316,15,315,331,358,279,317,14,316,8,285,9,277,329,350,253,374,252,319,318,403,351,6,419,324,318,325,397,367,365,288,435,397,278,344,439,310,272,311,248,195,281,375,273,291,175,396,199,312,311,268,276,283,445,390,373,339,295,282,296,448,449,346,356,264,454,337,336,299,337,338,151,294,278,455,308,292,415,429,358,355,265,340,372,388,390,466,352,346,280,295,442,282,354,19,370,285,441,295,195,248,197,457,440,274,301,300,368,417,351,465,251,301,389,385,380,386,394,395,379,399,412,419,410,436,322,387,373,388,326,2,393,354,370,461,393,164,267,268,302,12,386,374,387,312,268,13,298,293,301,265,446,340,380,385,381,280,330,425,322,426,391,420,429,437,393,391,326,344,440,438,458,459,461,364,434,394,428,396,262,274,354,457,317,316,402,316,315,403,315,314,404,314,313,405,313,421,406,323,366,361,292,306,407,306,291,408,291,287,409,287,432,410,427,434,411,372,264,383,459,309,457,366,352,401,1,274,4,418,421,262,331,294,358,435,433,367,392,289,439,328,462,326,94,2,370,289,305,455,339,254,448,359,255,446,254,253,449,253,252,450,252,256,451,256,341,452,414,413,463,286,441,414,286,258,441,258,257,442,257,259,443,259,260,444,260,467,445,309,459,250,305,289,290,305,290,460,401,376,435,309,250,392,376,411,433,453,341,464,357,453,465,343,357,412,437,343,399,344,360,440,420,437,456,360,420,363,361,401,288,265,372,353,390,339,249,339,448,255];var Ln=[127,234,132,58,172,150,149,148,152,377,378,379,397,288,361,454,356,70,63,105,66,107,336,296,334,293,300,168,6,195,4,98,97,2,326,327,33,160,158,133,153,144,362,385,387,263,373,380,57,40,37,0,267,270,287,321,314,17,84,91,78,81,13,311,308,402,14,178],In=[33,133,362,263,1,62,308,159,145,386,374,6,102,331,2,13,14,70,105,107,336,334,300,54,10,284,50,280,234,454,58,288,152],Nn=[33,133,362,263,1,78,308],qA=Ln.map(e=>qe[e]),UA=In.map(e=>qe[e]),JA=Nn.map(e=>qe[e]);function q0(e){let t=e.map(o=>o[0]);return t.push(e[e.length-1][1]),t}var Fn=[[61,146],[146,91],[91,181],[181,84],[84,17],[17,314],[314,405],[405,321],[321,375],[375,291],[61,185],[185,40],[40,39],[39,37],[37,0],[0,267],[267,269],[269,270],[270,409],[409,291],[78,95],[95,88],[88,178],[178,87],[87,14],[14,317],[317,402],[402,318],[318,324],[324,308],[78,191],[191,80],[80,81],[81,82],[82,13],[13,312],[312,311],[311,310],[310,415],[415,308]],Bn=[[263,249],[249,390],[390,373],[373,374],[374,380],[380,381],[381,382],[382,362],[263,466],[466,388],[388,387],[387,386],[386,385],[385,384],[384,398],[398,362]],Gn=[[276,283],[283,282],[282,295],[295,285],[300,293],[293,334],[334,296],[296,336]],Hn=[[474,475],[475,476],[476,477],[477,474]],Vn=[[33,7],[7,163],[163,144],[144,145],[145,153],[153,154],[154,155],[155,133],[33,246],[246,161],[161,160],[160,159],[159,158],[158,157],[157,173],[173,133]],Zn=[[46,53],[53,52],[52,65],[65,55],[70,63],[63,105],[105,66],[66,107]],Dn=[[469,470],[470,471],[471,472],[472,469]],Xn=[[10,338],[338,297],[297,332],[332,284],[284,251],[251,389],[389,356],[356,454],[454,323],[323,361],[361,288],[288,397],[397,365],[365,379],[379,378],[378,400],[400,377],[377,152],[152,148],[148,176],[176,149],[149,150],[150,136],[136,172],[172,58],[58,132],[132,93],[93,234],[234,127],[127,162],[162,21],[21,54],[54,103],[103,67],[67,109],[109,10]],YA={lips:q0(Fn),leftEye:q0(Bn),leftEyebrow:q0(Gn),leftIris:q0(Hn),rightEye:q0(Vn),rightEyebrow:q0(Zn),rightIris:q0(Dn),faceOval:q0(Xn)};var be=e=>[Math.abs(e.endPoint[0]-e.startPoint[0]),Math.abs(e.endPoint[1]-e.startPoint[1])],lt=e=>[e.startPoint[0]+(e.endPoint[0]-e.startPoint[0])/2,e.startPoint[1]+(e.endPoint[1]-e.startPoint[1])/2,1],yt=(e,t)=>e?[Math.trunc(Math.max(0,e.startPoint[0])),Math.trunc(Math.max(0,e.startPoint[1])),Math.trunc(Math.min(t.shape[2]||0,e.endPoint[0])-Math.max(0,e.startPoint[0])),Math.trunc(Math.min(t.shape[1]||0,e.endPoint[1])-Math.max(0,e.startPoint[1]))]:[0,0,0,0],xt=(e,t)=>e?[e.startPoint[0]/(t.shape[2]||0),e.startPoint[1]/(t.shape[1]||0),(e.endPoint[0]-e.startPoint[0])/(t.shape[2]||0),(e.endPoint[1]-e.startPoint[1])/(t.shape[1]||0)]:[0,0,0,0],r1=(e,t)=>{let o=[e.startPoint[0]*t[0],e.startPoint[1]*t[1]],n=[e.endPoint[0]*t[0],e.endPoint[1]*t[1]];return{startPoint:o,endPoint:n,landmarks:e.landmarks,confidence:e.confidence}},x5=(e,t,o)=>{let n=t.shape[1],r=t.shape[2],s=[e.startPoint[1]/n,e.startPoint[0]/r,e.endPoint[1]/n,e.endPoint[0]/r],a=A.image.cropAndResize(t,[s],[0],o),i=A.div(a,N.tf255);return A.dispose(a),i},ct=(e,t)=>{let o=lt(e),n=be(e),r=[t*n[0]/2,t*n[1]/2];return{startPoint:[o[0]-r[0],o[1]-r[1]],endPoint:[o[0]+r[0],o[1]+r[1]],landmarks:e.landmarks,confidence:e.confidence}},dt=e=>{let t=lt(e),o=be(e),n=Math.max(...o)/2;return{startPoint:[Math.round(t[0]-n),Math.round(t[1]-n)],endPoint:[Math.round(t[0]+n),Math.round(t[1]+n)],landmarks:e.landmarks,confidence:e.confidence}},A1=e=>{let t=e.map(n=>n[0]),o=e.map(n=>n[1]);return{startPoint:[Math.min(...t),Math.min(...o)],endPoint:[Math.max(...t),Math.max(...o)],landmarks:e}},c5=[[1,0,0],[0,1,0],[0,0,1]],qn=e=>e-2*Math.PI*Math.floor((e+Math.PI)/(2*Math.PI)),Un=(e,t)=>qn(Math.PI/2-Math.atan2(-(t[1]-e[1]),t[0]-e[0]));var o1=(e,t)=>[[1,0,e],[0,1,t],[0,0,1]],ae=(e,t)=>{let o=0;for(let n=0;n{let o=[];for(let n=0;n{let o=[],n=e.length;for(let r=0;r{let o=Math.cos(e),n=Math.sin(e),r=[[o,-n,0],[n,o,0],[0,0,1]],s=o1(t[0],t[1]),a=n1(s,r),i=o1(-t[0],-t[1]);return n1(a,i)},Yn=e=>{let t=[[e[0][0],e[1][0]],[e[0][1],e[1][1]]],o=[e[0][2],e[1][2]],n=[-ae(t[0],o),-ae(t[1],o)];return[t[0].concat(n[0]),t[1].concat(n[1]),[0,0,1]]},Kn=(e,t)=>[ae(e,t[0]),ae(e,t[1])];function a1(e){let t=e===192?{strides:[4],anchors:[1]}:{strides:[e/16,e/8],anchors:[2,6]},o=[];for(let n=0;n[s[0]/r*(m[0]-r/2),s[1]/r*(m[1]-r/2),m[2]||0]),i=o&&o!==0&&Math.abs(o)>.2,l=i?s1(o,[0,0]):c5,x=i?a.map(m=>[...Kn(m,l),m[2]]):a,d=i?Yn(n):c5,y=lt(t),c=[ae(y,d[0]),ae(y,d[1])];return x.map(m=>[Math.trunc(m[0]+c[0]),Math.trunc(m[1]+c[1]),Math.trunc(m[2]||0)])}function l1(e,t,o,n){let r=t.landmarks.length>=i5.count?i5.symmetryLine:Ae.symmetryLine,s=0,a=c5,i;if(e&&w.kernels.includes("rotatewithoffset"))if(s=Un(t.landmarks[r[0]],t.landmarks[r[1]]),s&&s!==0&&Math.abs(s)>.2){let x=lt(t),d=[x[0]/o.shape[2],x[1]/o.shape[1]],y=A.image.rotateWithOffset(o,s,0,d);a=s1(-s,x),i=x5(t,y,[n,n]),A.dispose(y)}else i=x5(t,o,[n,n]);else i=x5(t,o,[n,n]);return[s,a,i]}var Qn=e=>{let t=e.map(n=>n[0]),o=e.map(n=>n[1]);return[Math.min(...t)+(Math.max(...t)-Math.min(...t))/2,Math.min(...o)+(Math.max(...o)-Math.min(...o))/2]},y1=(e,t)=>{let o=Qn(e),n=be(t);return{startPoint:[o[0]-n[0]/2,o[1]-n[1]/2],endPoint:[o[0]+n[0]/2,o[1]+n[1]/2]}};var x1=6,_n=1.4,z0,c1=null,U0=0,Ue=null,ge=()=>U0;async function d1(e){var t;return w.initial&&(z0=null),z0?e.debug&&u("cached model:",z0.modelUrl):z0=await I((t=e.face.detector)==null?void 0:t.modelPath),U0=z0.inputs[0].shape?z0.inputs[0].shape[2]:0,Ue=A.scalar(U0,"int32"),c1=A.tensor2d(a1(U0)),z0}function $n(e){let t={};t.boxStarts=A.slice(e,[0,1],[-1,2]),t.centers=A.add(t.boxStarts,c1),t.boxSizes=A.slice(e,[0,3],[-1,2]),t.boxSizesNormalized=A.div(t.boxSizes,Ue),t.centersNormalized=A.div(t.centers,Ue),t.halfBoxSize=A.div(t.boxSizesNormalized,N.tf2),t.starts=A.sub(t.centersNormalized,t.halfBoxSize),t.ends=A.add(t.centersNormalized,t.halfBoxSize),t.startNormalized=A.mul(t.starts,Ue),t.endNormalized=A.mul(t.ends,Ue);let o=A.concat2d([t.startNormalized,t.endNormalized],1);return Object.keys(t).forEach(n=>A.dispose(t[n])),o}async function f1(e,t){var i,l,x,d;if(!e||e.isDisposedInternal||e.shape.length!==4||e.shape[1]<1||e.shape[2]<1)return[];let o={};o.resized=A.image.resizeBilinear(e,[U0,U0]),o.div=A.div(o.resized,N.tf127),o.normalized=A.sub(o.div,N.tf05);let n=z0==null?void 0:z0.execute(o.normalized);if(Array.isArray(n)&&n.length>2){let y=n.sort((c,m)=>c.size-m.size);o.concat384=A.concat([y[0],y[2]],2),o.concat512=A.concat([y[1],y[3]],2),o.concat=A.concat([o.concat512,o.concat384],1),o.batch=A.squeeze(o.concat,0)}else Array.isArray(n)?o.batch=A.squeeze(n[0]):o.batch=A.squeeze(n);A.dispose(n),o.boxes=$n(o.batch),o.logits=A.slice(o.batch,[0,0],[-1,1]),o.sigmoid=A.sigmoid(o.logits),o.scores=A.squeeze(o.sigmoid),o.nms=await A.image.nonMaxSuppressionAsync(o.boxes,o.scores,((i=t.face.detector)==null?void 0:i.maxDetected)||0,((l=t.face.detector)==null?void 0:l.iouThreshold)||0,((x=t.face.detector)==null?void 0:x.minConfidence)||0);let r=await o.nms.array(),s=[],a=await o.scores.data();for(let y=0;y(((d=t.face.detector)==null?void 0:d.minConfidence)||0)){let m={};m.bbox=A.slice(o.boxes,[r[y],0],[1,-1]),m.slice=A.slice(o.batch,[r[y],x1-1],[1,-1]),m.squeeze=A.squeeze(m.slice),m.landmarks=A.reshape(m.squeeze,[x1,-1]);let h=await m.bbox.data(),p={startPoint:[h[0],h[1]],endPoint:[h[2],h[3]],landmarks:await m.landmarks.array(),confidence:c},M=r1(p,[(e.shape[2]||0)/U0,(e.shape[1]||0)/U0]),P=ct(M,t.face.scale||_n),g=dt(P);s.push(g),Object.keys(m).forEach(f=>A.dispose(m[f]))}}return Object.keys(o).forEach(y=>A.dispose(o[y])),s}var ft={};ne(ft,{connected:()=>m5,kpt:()=>f5});var f5=["nose","leftEyeInside","leftEye","leftEyeOutside","rightEyeInside","rightEye","rightEyeOutside","leftEar","rightEar","leftMouth","rightMouth","leftShoulder","rightShoulder","leftElbow","rightElbow","leftWrist","rightWrist","leftPinky","rightPinky","leftIndex","rightIndex","leftThumb","rightThumb","leftHip","rightHip","leftKnee","rightKnee","leftAnkle","rightAnkle","leftHeel","rightHeel","leftFoot","rightFoot","bodyCenter","bodyTop","leftPalm","leftHand","rightPalm","rightHand"],m5={shoulders:["leftShoulder","rightShoulder"],hips:["rightHip","leftHip"],mouth:["leftMouth","rightMouth"],leftLegUpper:["leftHip","leftKnee"],leftLegLower:["leftKnee","leftAnkle"],leftFoot:["leftAnkle","leftHeel","leftFoot"],leftTorso:["leftShoulder","leftHip"],leftArmUpper:["leftShoulder","leftElbow"],leftArmLower:["leftElbow","leftWrist"],leftHand:["leftWrist","leftPalm"],leftHandPinky:["leftPalm","leftPinky"],leftHandIndex:["leftPalm","leftIndex"],leftHandThumb:["leftPalm","leftThumb"],leftEyeOutline:["leftEyeInside","leftEyeOutside"],rightLegUpper:["rightHip","rightKnee"],rightLegLower:["rightKnee","rightAnkle"],rightFoot:["rightAnkle","rightHeel","rightFoot"],rightTorso:["rightShoulder","rightHip"],rightArmUpper:["rightShoulder","rightElbow"],rightArmLower:["rightElbow","rightWrist"],rightHand:["rightWrist","rightPalm"],rightHandPinky:["rightPalm","rightPinky"],rightHandIndex:["rightPalm","rightIndex"],rightHandThumb:["rightPalm","rightThumb"],rightEyeOutline:["rightEyeInside","rightEyeOutside"]};var p1=224,er,tr=5,mt=[8,16,32,32,32];async function u1(){let e=[],t=0;for(;to.x)),y:A.tensor1d(e.map(o=>o.y))}}function F0(e,t=[1,1]){let o=[e.map(i=>i[0]),e.map(i=>i[1])],n=[Math.min(...o[0]),Math.min(...o[1])],r=[Math.max(...o[0]),Math.max(...o[1])],s=[n[0],n[1],r[0]-n[0],r[1]-n[1]],a=[s[0]/t[0],s[1]/t[1],s[2]/t[0],s[3]/t[1]];return{box:s,boxRaw:a}}function h1(e,t=[1,1]){let o=[e.map(x=>x[0]),e.map(x=>x[1])],n=[Math.min(...o[0]),Math.min(...o[1])],r=[Math.max(...o[0]),Math.max(...o[1])],s=[(n[0]+r[0])/2,(n[1]+r[1])/2],a=Math.max(s[0]-n[0],s[1]-n[1],-s[0]+r[0],-s[1]+r[1]),i=[Math.trunc(s[0]-a),Math.trunc(s[1]-a),Math.trunc(2*a),Math.trunc(2*a)],l=[i[0]/t[0],i[1]/t[1],i[2]/t[0],i[3]/t[1]];return{box:i,boxRaw:l}}function pt(e,t){let o=[e[2]*t,e[3]*t];return[e[0]-(o[0]-e[2])/2,e[1]-(o[1]-e[3])/2,o[0],o[1]]}var P1={initial:!0},c0={detector:null,landmarks:null},Pe={detector:[224,224],landmarks:[256,256]},p5=Number.MAX_SAFE_INTEGER,nr={landmarks:["ld_3d","activation_segmentation","activation_heatmap","world_3d","output_poseflag"],detector:[]},ht=null,Je,J0=[[0,0],[0,0],[0,0],[0,0]],b1=0,g1=e=>1-1/(1+Math.exp(e));async function v1(e){if(P1.initial&&(c0.detector=null),!c0.detector&&e.body.detector&&e.body.detector.modelPath){c0.detector=await I(e.body.detector.modelPath);let t=Object.values(c0.detector.modelSignature.inputs);Pe.detector[0]=Array.isArray(t)?parseInt(t[0].tensorShape.dim[1].size):0,Pe.detector[1]=Array.isArray(t)?parseInt(t[0].tensorShape.dim[2].size):0}else e.debug&&c0.detector&&u("cached model:",c0.detector.modelUrl);return await u1(),c0.detector}async function M1(e){if(P1.initial&&(c0.landmarks=null),c0.landmarks)e.debug&&u("cached model:",c0.landmarks.modelUrl);else{c0.landmarks=await I(e.body.modelPath);let t=Object.values(c0.landmarks.modelSignature.inputs);Pe.landmarks[0]=Array.isArray(t)?parseInt(t[0].tensorShape.dim[1].size):0,Pe.landmarks[1]=Array.isArray(t)?parseInt(t[0].tensorShape.dim[2].size):0}return c0.landmarks}async function rr(e,t){let o={};if(!e.shape||!e.shape[1]||!e.shape[2])return e;let n;if(Je&&(o.cropped=A.image.cropAndResize(e,[Je],[0],[e.shape[1],e.shape[2]])),e.shape[1]!==e.shape[2]){let r=[e.shape[2]>e.shape[1]?Math.trunc((e.shape[2]-e.shape[1])/2):0,e.shape[2]>e.shape[1]?Math.trunc((e.shape[2]-e.shape[1])/2):0],s=[e.shape[1]>e.shape[2]?Math.trunc((e.shape[1]-e.shape[2])/2):0,e.shape[1]>e.shape[2]?Math.trunc((e.shape[1]-e.shape[2])/2):0];J0=[[0,0],r,s,[0,0]],o.pad=A.pad(o.cropped||e,J0),o.resize=A.image.resizeBilinear(o.pad,[t,t]),n=A.div(o.resize,N.tf255)}else e.shape[1]!==t?(o.resize=A.image.resizeBilinear(o.cropped||e,[t,t]),n=A.div(o.resize,N.tf255)):n=A.div(o.cropped||e,N.tf255);return Object.keys(o).forEach(r=>A.dispose(o[r])),n}function Ar(e,t){for(let o of e)o.position=[Math.trunc(o.position[0]*(t[0]+J0[2][0]+J0[2][1])/t[0]-J0[2][0]),Math.trunc(o.position[1]*(t[1]+J0[1][0]+J0[1][1])/t[1]-J0[1][0]),o.position[2]],o.positionRaw=[o.position[0]/t[0],o.position[1]/t[1],2*o.position[2]/(t[0]+t[1])];if(Je)for(let o of e)o.positionRaw=[o.positionRaw[0]+Je[1],o.positionRaw[1]+Je[0],o.positionRaw[2]],o.position=[Math.trunc(o.positionRaw[0]*t[0]),Math.trunc(o.positionRaw[1]*t[1]),o.positionRaw[2]];return e}async function sr(e){let t=e.find(i=>i.part==="leftPalm"),o=e.find(i=>i.part==="leftWrist"),n=e.find(i=>i.part==="leftIndex");t.position[2]=((o.position[2]||0)+(n.position[2]||0))/2;let r=e.find(i=>i.part==="rightPalm"),s=e.find(i=>i.part==="rightWrist"),a=e.find(i=>i.part==="rightIndex");r.position[2]=((s.position[2]||0)+(a.position[2]||0))/2}async function ar(e,t,o){var h;let n={};[n.ld,n.segmentation,n.heatmap,n.world,n.poseflag]=(h=c0.landmarks)==null?void 0:h.execute(e,nr.landmarks);let r=(await n.poseflag.data())[0],s=await n.ld.data(),a=await n.world.data();Object.keys(n).forEach(p=>A.dispose(n[p]));let i=[],l=5;for(let p=0;pp.position),y=F0(d,[o[0],o[1]]),c={};for(let[p,M]of Object.entries(m5)){let P=[];for(let g=0;gS.part===M[g]),v=x.find(S=>S.part===M[g+1]);f&&v&&P.push([f.position,v.position])}c[p]=P}return{id:0,score:Math.trunc(100*r)/100,box:y.box,boxRaw:y.boxRaw,keypoints:x,annotations:c}}async function u5(e,t){let o=[e.shape[2]||0,e.shape[1]||0],n=(t.body.skipTime||0)>b()-b1,r=p5<(t.body.skipFrames||0);if(t.skipAllowed&&n&&r&&ht!==null)p5++;else{let s={};s.landmarks=await rr(e,256),ht=await ar(s.landmarks,t,o),Object.keys(s).forEach(a=>A.dispose(s[a])),b1=b(),p5=0}return ht?[ht]:[]}var ve=[{class:1,label:"person"},{class:2,label:"bicycle"},{class:3,label:"car"},{class:4,label:"motorcycle"},{class:5,label:"airplane"},{class:6,label:"bus"},{class:7,label:"train"},{class:8,label:"truck"},{class:9,label:"boat"},{class:10,label:"traffic light"},{class:11,label:"fire hydrant"},{class:12,label:"stop sign"},{class:13,label:"parking meter"},{class:14,label:"bench"},{class:15,label:"bird"},{class:16,label:"cat"},{class:17,label:"dog"},{class:18,label:"horse"},{class:19,label:"sheep"},{class:20,label:"cow"},{class:21,label:"elephant"},{class:22,label:"bear"},{class:23,label:"zebra"},{class:24,label:"giraffe"},{class:25,label:"backpack"},{class:26,label:"umbrella"},{class:27,label:"handbag"},{class:28,label:"tie"},{class:29,label:"suitcase"},{class:30,label:"frisbee"},{class:31,label:"skis"},{class:32,label:"snowboard"},{class:33,label:"sports ball"},{class:34,label:"kite"},{class:35,label:"baseball bat"},{class:36,label:"baseball glove"},{class:37,label:"skateboard"},{class:38,label:"surfboard"},{class:39,label:"tennis racket"},{class:40,label:"bottle"},{class:41,label:"wine glass"},{class:42,label:"cup"},{class:43,label:"fork"},{class:44,label:"knife"},{class:45,label:"spoon"},{class:46,label:"bowl"},{class:47,label:"banana"},{class:48,label:"apple"},{class:49,label:"sandwich"},{class:50,label:"orange"},{class:51,label:"broccoli"},{class:52,label:"carrot"},{class:53,label:"hot dog"},{class:54,label:"pizza"},{class:55,label:"donut"},{class:56,label:"cake"},{class:57,label:"chair"},{class:58,label:"couch"},{class:59,label:"potted plant"},{class:60,label:"bed"},{class:61,label:"dining table"},{class:62,label:"toilet"},{class:63,label:"tv"},{class:64,label:"laptop"},{class:65,label:"mouse"},{class:66,label:"remote"},{class:67,label:"keyboard"},{class:68,label:"cell phone"},{class:69,label:"microwave"},{class:70,label:"oven"},{class:71,label:"toaster"},{class:72,label:"sink"},{class:73,label:"refrigerator"},{class:74,label:"book"},{class:75,label:"clock"},{class:76,label:"vase"},{class:77,label:"scissors"},{class:78,label:"teddy bear"},{class:79,label:"hair drier"},{class:80,label:"toothbrush"}];var B0,ie=0,h5=[],w1=0,b5=Number.MAX_SAFE_INTEGER;async function T1(e){if(w.initial&&(B0=null),B0)e.debug&&u("cached model:",B0.modelUrl);else{B0=await I(e.object.modelPath);let t=Object.values(B0.modelSignature.inputs);ie=Array.isArray(t)?parseInt(t[0].tensorShape.dim[2].size):0}return B0}async function ir(e,t,o){if(!e)return[];let n={},r=[],s=await e.array();n.squeeze=A.squeeze(e);let a=A.split(n.squeeze,6,1);n.stack=A.stack([a[1],a[0],a[3],a[2]],1),n.boxes=A.squeeze(n.stack),n.scores=A.squeeze(a[4]),n.classes=A.squeeze(a[5]),A.dispose([e,...a]),n.nms=await A.image.nonMaxSuppressionAsync(n.boxes,n.scores,o.object.maxDetected,o.object.iouThreshold,o.object.minConfidence||0);let i=await n.nms.data(),l=0;for(let x of Array.from(i)){let d=Math.trunc(100*s[0][x][4])/100,y=s[0][x][5],c=ve[y].label,[m,h]=[s[0][x][0]/ie,s[0][x][1]/ie],p=[m,h,s[0][x][2]/ie-m,s[0][x][3]/ie-h],M=[Math.trunc(p[0]*t[0]),Math.trunc(p[1]*t[1]),Math.trunc(p[2]*t[0]),Math.trunc(p[3]*t[1])];r.push({id:l++,score:d,class:y,label:c,box:M,boxRaw:p})}return Object.keys(n).forEach(x=>A.dispose(n[x])),r}async function g5(e,t){let o=(t.object.skipTime||0)>b()-w1,n=b5<(t.object.skipFrames||0);return t.skipAllowed&&o&&n&&h5.length>0?(b5++,h5):(b5=0,new Promise(async r=>{let s=[e.shape[2]||0,e.shape[1]||0],a=A.image.resizeBilinear(e,[ie,ie]),i=t.object.enabled?B0==null?void 0:B0.execute(a,["tower_0/detections"]):null;w1=b(),A.dispose(a);let l=await ir(i,s,t);h5=l,r(l)}))}var bt={};ne(bt,{connected:()=>v5,kpt:()=>P5});var P5=["head","neck","rightShoulder","rightElbow","rightWrist","chest","leftShoulder","leftElbow","leftWrist","bodyCenter","rightHip","rightKnee","rightAnkle","leftHip","leftKnee","leftAnkle"],v5={leftLeg:["leftHip","leftKnee","leftAnkle"],rightLeg:["rightHip","rightKnee","rightAnkle"],torso:["leftShoulder","rightShoulder","rightHip","leftHip","leftShoulder"],leftArm:["leftShoulder","leftElbow","leftWrist"],rightArm:["rightShoulder","rightElbow","rightWrist"],head:[]};var A0,E1=0,l0={id:0,keypoints:[],box:[0,0,0,0],boxRaw:[0,0,0,0],score:0,annotations:{}},M5=Number.MAX_SAFE_INTEGER;async function z1(e){return w.initial&&(A0=null),A0?e.debug&&u("cached model:",A0.modelUrl):A0=await I(e.body.modelPath),A0}async function lr(e,t){let[o,n]=e.shape,r=A.reshape(e,[n*o]),s=A.max(r,0),a=(await s.data())[0];if(A.dispose([r,s]),a>t){let i=A.argMax(r,0),l=A.mod(i,o),x=(await l.data())[0],d=A.div(i,A.scalar(o,"int32")),y=(await d.data())[0];return A.dispose([l,d]),[x,y,a]}return[0,0,a]}async function R5(e,t){let o=(t.body.skipTime||0)>b()-E1,n=M5<(t.body.skipFrames||0);return t.skipAllowed&&o&&n&&Object.keys(l0.keypoints).length>0?(M5++,[l0]):(M5=0,new Promise(async r=>{var y;let s=A.tidy(()=>{if(!(A0!=null&&A0.inputs[0].shape))return null;let c=A.image.resizeBilinear(e,[A0.inputs[0].shape[2],A0.inputs[0].shape[1]],!1),m=A.mul(c,N.tf2);return A.sub(m,N.tf1)}),a;if(t.body.enabled&&(a=A0==null?void 0:A0.execute(s)),E1=b(),A.dispose(s),a){l0.keypoints.length=0;let c=a.squeeze();A.dispose(a);let m=c.unstack(2);A.dispose(c);for(let h=0;h(((y=t.body)==null?void 0:y.minConfidence)||0)&&l0.keypoints.push({score:Math.round(100*P)/100,part:P5[h],positionRaw:[p/A0.inputs[0].shape[2],M/A0.inputs[0].shape[1]],position:[Math.round(e.shape[2]*p/A0.inputs[0].shape[2]),Math.round(e.shape[1]*M/A0.inputs[0].shape[1])]})}m.forEach(h=>A.dispose(h))}l0.score=l0.keypoints.reduce((c,m)=>m.score>c?m.score:c,0);let i=l0.keypoints.map(c=>c.position[0]),l=l0.keypoints.map(c=>c.position[1]);l0.box=[Math.min(...i),Math.min(...l),Math.max(...i)-Math.min(...i),Math.max(...l)-Math.min(...l)];let x=l0.keypoints.map(c=>c.positionRaw[0]),d=l0.keypoints.map(c=>c.positionRaw[1]);l0.boxRaw=[Math.min(...x),Math.min(...d),Math.max(...x)-Math.min(...x),Math.max(...d)-Math.min(...d)];for(let[c,m]of Object.entries(v5)){let h=[];for(let p=0;pg.part===m[p]),P=l0.keypoints.find(g=>g.part===m[p+1]);M&&P&&M.score>(t.body.minConfidence||0)&&P.score>(t.body.minConfidence||0)&&h.push([M.position,P.position])}l0.annotations[c]=h}r([l0])}))}var yr=["angry","disgust","fear","happy","sad","surprise","neutral"],g0,gt=[],S1=0,C1=0,w5=Number.MAX_SAFE_INTEGER;async function W1(e){var t;return w.initial&&(g0=null),g0?e.debug&&u("cached model:",g0.modelUrl):g0=await I((t=e.face.emotion)==null?void 0:t.modelPath),g0}async function T5(e,t,o,n){var a,i;if(!g0)return[];let r=w5<(((a=t.face.emotion)==null?void 0:a.skipFrames)||0),s=(((i=t.face.emotion)==null?void 0:i.skipTime)||0)>b()-C1;return t.skipAllowed&&s&&r&&S1===n&>[o]&>[o].length>0?(w5++,gt[o]):(w5=0,new Promise(async l=>{var d,y;let x=[];if((d=t.face.emotion)!=null&&d.enabled){let c={},m=g0!=null&&g0.inputs[0].shape?g0.inputs[0].shape[2]:0;c.resize=A.image.resizeBilinear(e,[m,m],!1),c.channels=A.mul(c.resize,N.rgb),c.grayscale=A.sum(c.channels,3,!0),c.grayscaleSub=A.sub(c.grayscale,N.tf05),c.grayscaleMul=A.mul(c.grayscaleSub,N.tf2),c.emotion=g0==null?void 0:g0.execute(c.grayscaleMul),C1=b();let h=await c.emotion.data();for(let p=0;p(((y=t.face.emotion)==null?void 0:y.minConfidence)||0)&&x.push({score:Math.min(.99,Math.trunc(100*h[p])/100),emotion:yr[p]});x.sort((p,M)=>M.score-p.score),Object.keys(c).forEach(p=>A.dispose(c[p]))}gt[o]=x,S1=n,l(x)}))}var d0,k5=[],L1=0,I1=0,N1=Number.MAX_SAFE_INTEGER;async function F1(e){return w.initial&&(d0=null),d0?e.debug&&u("cached model:",d0.modelUrl):d0=await I(e.face.mobilefacenet.modelPath),d0}async function E5(e,t,o,n){var a,i;if(!d0)return[];let r=N1<(((a=t.face.embedding)==null?void 0:a.skipFrames)||0),s=(((i=t.face.embedding)==null?void 0:i.skipTime)||0)>b()-I1;return t.skipAllowed&&s&&r&&L1===n&&k5[o]?(N1++,k5[o]):new Promise(async l=>{var d;let x=[];if(((d=t.face.embedding)==null?void 0:d.enabled)&&(d0==null?void 0:d0.inputs[0].shape)){let y={};y.crop=A.image.resizeBilinear(e,[d0.inputs[0].shape[2],d0.inputs[0].shape[1]],!1),y.data=d0==null?void 0:d0.execute(y.crop);let c=await y.data.data();x=Array.from(c)}k5[o]=x,L1=n,I1=b(),l(x)})}var G0,Y0=0,xr=2.3,z5=R0.leftEyeLower0,j5=R0.rightEyeLower0,Me={leftBounds:[z5[0],z5[z5.length-1]],rightBounds:[j5[0],j5[j5.length-1]]},Re={upperCenter:3,lowerCenter:4,index:71,numCoordinates:76};async function Z1(e){var t;return w.initial&&(G0=null),G0?e.debug&&u("cached model:",G0.modelUrl):G0=await I((t=e.face.iris)==null?void 0:t.modelPath),Y0=G0.inputs[0].shape?G0.inputs[0].shape[2]:0,Y0===-1&&(Y0=64),G0}function Pt(e,t,o,n){for(let r=0;r{let t=e[Me.leftBounds[0]][2],o=e[Me.rightBounds[0]][2];return t-o},G1=(e,t,o,n,r,s=!1)=>{let a=dt(ct(A1([e[o],e[n]]),xr)),i=be(a),l=A.image.cropAndResize(t,[[a.startPoint[1]/r,a.startPoint[0]/r,a.endPoint[1]/r,a.endPoint[0]/r]],[0],[Y0,Y0]);if(s&&w.kernels.includes("flipleftright")){let x=A.image.flipLeftRight(l);A.dispose(l),l=x}return{box:a,boxSize:i,crop:l}},H1=(e,t,o,n=!1)=>{let r=[];for(let s=0;s{let n=e[R0[`${o}EyeUpper0`][Re.upperCenter]][2],r=e[R0[`${o}EyeLower0`][Re.lowerCenter]][2],s=(n+r)/2;return t.map((a,i)=>{let l=s;return i===2?l=n:i===4&&(l=r),[a[0],a[1],l]})};async function D1(e,t,o,n){if(!G0)return o.debug&&u("face mesh iris detection requested, but model is not loaded"),e;let{box:r,boxSize:s,crop:a}=G1(e,t,Me.leftBounds[0],Me.leftBounds[1],n,!0),{box:i,boxSize:l,crop:x}=G1(e,t,Me.rightBounds[0],Me.rightBounds[1],n,!0),d=A.concat([a,x]);A.dispose(a),A.dispose(x);let y=G0.execute(d);A.dispose(d);let c=await y.data();A.dispose(y);let m=c.slice(0,Re.numCoordinates*3),{rawCoords:h,iris:p}=H1(m,r,s,!0),M=c.slice(Re.numCoordinates*3),{rawCoords:P,iris:g}=H1(M,i,l,!1),f=cr(e);Math.abs(f)<30?(Pt(e,h,"left",null),Pt(e,P,"right",null)):f<1?Pt(e,h,"left",["EyeUpper0","EyeLower0"]):Pt(e,P,"right",["EyeUpper0","EyeLower0"]);let v=V1(e,p,"left"),S=V1(e,g,"right");return e.concat(v).concat(S)}var f0={eyeLLower:[33,7,163,144,145,153,154,155,133],eyeRLower:[263,249,390,373,374,380,381,382,362],lips:[185,96,90,181,84,17,314,405,320,307,409,40,39,73,37,0,267,269,270,409,40,88,178,178,87,14,268,402,318,324,409,80,41,38,87,12,268,303,318,324,185,95,80,81,85,16,315,404,319,325,409,40,39,73,72,0,302,303,270,408,185,88,88,81,82,15,316,403,319,324,409,80,41,38,87,12,268,303,318,324],eyeL:[33,7,163,144,145,153,154,155,133,246,161,160,159,158,157,173,130,25,110,24,23,22,26,112,243,247,30,29,27,28,56,190,226,31,228,229,230,231,232,233,244,113,225,224,223,222,221,189,35,124,46,53,52,65,143,111,117,118,119,120,121,128,245,156,70,63,105,66,107,55,193],eyeR:[263,249,390,373,374,380,381,382,362,466,388,387,386,385,384,398,359,255,339,254,253,252,256,341,463,467,260,259,257,258,286,414,446,261,448,449,450,451,452,453,464,342,445,444,443,442,441,413,265,353,276,283,282,295,372,340,346,347,348,349,350,357,465,383,300,293,334,296,336,285,417]};async function q1(e,t){let o={irisL:t[3].dataSync(),irisR:t[1].dataSync(),eyeL:t[0].dataSync(),eyeR:t[6].dataSync(),lips:t[5].dataSync()},n=f0.eyeRLower.reduce((s,a)=>s+=e[a][2],0)/f0.eyeRLower.length;for(let s=0;ss+=e[a][2],0)/f0.eyeLLower.length;for(let s=0;sb()-j0.timestamp,n=j0.skipped<(((l=t.face.detector)==null?void 0:l.skipFrames)||0);!t.skipAllowed||!o||!n||j0.boxes.length===0?(j0.boxes=await f1(e,t),j0.timestamp=b(),j0.skipped=0):j0.skipped++;let r=[],s=[],a=0;for(let g=0;gF.shape[F.shape.length-1]===1),L=W.find(F=>F.shape[F.shape.length-1]===1404),D=await C.data();k.faceScore=Math.round(100*D[0])/100;let H=A.reshape(L,[-1,3]),Z=await H.array();if(k.faceScore<(((m=t.face.detector)==null?void 0:m.minConfidence)||1)){if(f.confidence=k.faceScore,(h=t.face.mesh)!=null&&h.keepInvalid){k.box=yt(f,e),k.boxRaw=xt(f,e),k.score=k.boxScore,k.mesh=f.landmarks.map(F=>[(f.startPoint[0]+f.endPoint[0])/2+(f.endPoint[0]+f.startPoint[0])*F[0]/ge(),(f.startPoint[1]+f.endPoint[1])/2+(f.endPoint[1]+f.startPoint[1])*F[1]/ge()]),k.meshRaw=k.mesh.map(F=>[F[0]/(e.shape[2]||0),F[1]/(e.shape[1]||0),(F[2]||0)/le]);for(let F of Object.keys(Ae))k.annotations[F]=[k.mesh[Ae[F]]]}}else{(p=t.face.attention)!=null&&p.enabled?Z=await q1(Z,W):(M=t.face.iris)!=null&&M.enabled&&(Z=await D1(Z,k.tensor,t,le)),k.mesh=i1(Z,f,v,S,le),k.meshRaw=k.mesh.map(z=>[z[0]/(e.shape[2]||0),z[1]/(e.shape[1]||0),(z[2]||0)/le]);for(let z of Object.keys(R0))k.annotations[z]=R0[z].map(h0=>k.mesh[h0]);k.score=k.faceScore;let F={...y1(k.mesh,f),confidence:f.confidence,landmarks:f.landmarks};k.box=yt(F,e),k.boxRaw=xt(F,e),s.push(F)}A.dispose([...W,H])}else{k.box=yt(f,e),k.boxRaw=xt(f,e),k.score=k.boxScore,k.mesh=f.landmarks.map(W=>[(f.startPoint[0]+f.endPoint[0])/2+(f.endPoint[0]+f.startPoint[0])*W[0]/ge(),(f.startPoint[1]+f.endPoint[1])/2+(f.endPoint[1]+f.startPoint[1])*W[1]/ge()]),k.meshRaw=k.mesh.map(W=>[W[0]/(e.shape[2]||0),W[1]/(e.shape[1]||0),(W[2]||0)/le]);for(let W of Object.keys(Ae))k.annotations[W]=[k.mesh[Ae[W]]]}k.score>(((P=t.face.detector)==null?void 0:P.minConfidence)||1)?r.push(k):A.dispose(k.tensor)}return j0.boxes=s,r}async function J1(e){var t,o,n;return w.initial&&(S0=null),S0?e.debug&&u("cached model:",S0.modelUrl):(t=e.face.attention)!=null&&t.enabled?S0=await I((o=e.face.attention)==null?void 0:o.modelPath):S0=await I((n=e.face.mesh)==null?void 0:n.modelPath),le=S0.inputs[0].shape?S0.inputs[0].shape[2]:0,S0}var Y1=se,K1=qe;var m0,vt=[],Q1=0,_1=0,C5=Number.MAX_SAFE_INTEGER;async function $1(e){var t;return w.initial&&(m0=null),m0?e.debug&&u("cached model:",m0.modelUrl):m0=await I((t=e.face.description)==null?void 0:t.modelPath),m0}function W5(e){let t=e.image||e.tensor||e;if(!(m0!=null&&m0.inputs[0].shape))return t;let o=A.image.resizeBilinear(t,[m0.inputs[0].shape[2],m0.inputs[0].shape[1]],!1),n=A.mul(o,N.tf255);return A.dispose(o),n}async function O5(e,t,o,n){var a,i,l,x;if(!m0)return{age:0,gender:"unknown",genderScore:0,descriptor:[]};let r=C5<(((a=t.face.description)==null?void 0:a.skipFrames)||0),s=(((i=t.face.description)==null?void 0:i.skipTime)||0)>b()-Q1;return t.skipAllowed&&r&&s&&_1===n&&((l=vt[o])==null?void 0:l.age)&&((x=vt[o])==null?void 0:x.age)>0?(C5++,vt[o]):(C5=0,new Promise(async d=>{var c,m;let y={age:0,gender:"unknown",genderScore:0,descriptor:[]};if((c=t.face.description)!=null&&c.enabled){let h=W5(e),p=m0==null?void 0:m0.execute(h);Q1=b(),A.dispose(h);let P=await(await p.find(L=>L.shape[1]===1)).data(),g=Math.trunc(200*Math.abs(P[0]-.5))/100;g>(((m=t.face.description)==null?void 0:m.minConfidence)||0)&&(y.gender=P[0]<=.5?"female":"male",y.genderScore=Math.min(.99,g));let f=A.argMax(p.find(L=>L.shape[1]===100),1),v=(await f.data())[0];A.dispose(f);let k=await p.find(L=>L.shape[1]===100).data();y.age=Math.round(k[v-1]>k[v+1]?10*v-100*k[v-1]:10*v+100*k[v+1])/10;let W=p.find(L=>L.shape[1]===1024),C=W?await W.data():[];y.descriptor=Array.from(C),p.forEach(L=>A.dispose(L))}vt[o]=y,_1=n,d(y)}))}function Mt(e){return[Math.abs(e.endPoint[0]-e.startPoint[0]),Math.abs(e.endPoint[1]-e.startPoint[1])]}function Ye(e){return[e.startPoint[0]+(e.endPoint[0]-e.startPoint[0])/2,e.startPoint[1]+(e.endPoint[1]-e.startPoint[1])/2]}function oo(e,t,o){let n=t.shape[1],r=t.shape[2],s=[[e.startPoint[1]/n,e.startPoint[0]/r,e.endPoint[1]/n,e.endPoint[0]/r]];return A.image.cropAndResize(t,s,[0],o)}function no(e,t){let o=[e.startPoint[0]*t[0],e.startPoint[1]*t[1]],n=[e.endPoint[0]*t[0],e.endPoint[1]*t[1]],r=e.palmLandmarks.map(s=>[s[0]*t[0],s[1]*t[1]]);return{startPoint:o,endPoint:n,palmLandmarks:r,confidence:e.confidence}}function Rt(e,t=1.5){let o=Ye(e),n=Mt(e),r=[t*n[0]/2,t*n[1]/2],s=[o[0]-r[0],o[1]-r[1]],a=[o[0]+r[0],o[1]+r[1]];return{startPoint:s,endPoint:a,palmLandmarks:e.palmLandmarks}}function wt(e){let t=Ye(e),o=Mt(e),r=Math.max(...o)/2,s=[t[0]-r,t[1]-r],a=[t[0]+r,t[1]+r];return{startPoint:s,endPoint:a,palmLandmarks:e.palmLandmarks}}function fr(e){return e-2*Math.PI*Math.floor((e+Math.PI)/(2*Math.PI))}function ro(e,t){let o=Math.PI/2-Math.atan2(-(t[1]-e[1]),t[0]-e[0]);return fr(o)}var eo=(e,t)=>[[1,0,e],[0,1,t],[0,0,1]];function K0(e,t){let o=0;for(let n=0;n[o.x,o.y]),this.anchorsTensor=A.tensor2d(this.anchors),this.inputSize=this.model&&this.model.inputs&&this.model.inputs[0].shape?this.model.inputs[0].shape[2]:0,this.inputSizeTensor=A.tensor1d([this.inputSize,this.inputSize]),this.doubleInputSizeTensor=A.tensor1d([this.inputSize*2,this.inputSize*2])}normalizeBoxes(t){let o={};o.boxOffsets=A.slice(t,[0,0],[-1,2]),o.boxSizes=A.slice(t,[0,2],[-1,2]),o.div=A.div(o.boxOffsets,this.inputSizeTensor),o.boxCenterPoints=A.add(o.div,this.anchorsTensor),o.halfBoxSizes=A.div(o.boxSizes,this.doubleInputSizeTensor),o.sub=A.sub(o.boxCenterPoints,o.halfBoxSizes),o.startPoints=A.mul(o.sub,this.inputSizeTensor),o.add=A.add(o.boxCenterPoints,o.halfBoxSizes),o.endPoints=A.mul(o.add,this.inputSizeTensor);let n=A.concat2d([o.startPoints,o.endPoints],1);return Object.keys(o).forEach(r=>A.dispose(o[r])),n}normalizeLandmarks(t,o){let n={};n.reshape=A.reshape(t,[-1,7,2]),n.div=A.div(n.reshape,this.inputSizeTensor),n.landmarks=A.add(n.div,this.anchors[o]);let r=A.mul(n.landmarks,this.inputSizeTensor);return Object.keys(n).forEach(s=>A.dispose(n[s])),r}async predict(t,o){let n={};n.resize=A.image.resizeBilinear(t,[this.inputSize,this.inputSize]),n.div=A.div(n.resize,N.tf127),n.image=A.sub(n.div,N.tf1),n.batched=this.model.execute(n.image),n.predictions=A.squeeze(n.batched),n.slice=A.slice(n.predictions,[0,0],[-1,1]),n.sigmoid=A.sigmoid(n.slice),n.scores=A.squeeze(n.sigmoid);let r=await n.scores.data();n.boxes=A.slice(n.predictions,[0,1],[-1,4]),n.norm=this.normalizeBoxes(n.boxes),n.nms=await A.image.nonMaxSuppressionAsync(n.norm,n.scores,3*o.hand.maxDetected,o.hand.iouThreshold,o.hand.minConfidence);let s=await n.nms.array(),a=[];for(let i of s){let l={};l.box=A.slice(n.norm,[i,0],[1,-1]),l.slice=A.slice(n.predictions,[i,5],[1,14]),l.norm=this.normalizeLandmarks(l.slice,i),l.palmLandmarks=A.reshape(l.norm,[-1,2]);let x=await l.box.data(),d=x.slice(0,2),y=x.slice(2,4),c=await l.palmLandmarks.array(),m={startPoint:d,endPoint:y,palmLandmarks:c,confidence:r[i]},h=no(m,[t.shape[2]/this.inputSize,t.shape[1]/this.inputSize]);a.push(h),Object.keys(l).forEach(p=>A.dispose(l[p]))}return Object.keys(n).forEach(i=>A.dispose(n[i])),a}};var hr=5,io=1.65,lo=[0,5,9,13,17,1,2],br=0,gr=2,yo=0,kt=class{constructor(t,o){T(this,"handDetector");T(this,"handPoseModel");T(this,"inputSize");T(this,"storedBoxes");T(this,"skipped");T(this,"detectedHands");this.handDetector=t,this.handPoseModel=o,this.inputSize=this.handPoseModel&&this.handPoseModel.inputs[0].shape?this.handPoseModel.inputs[0].shape[2]:0,this.storedBoxes=[],this.skipped=Number.MAX_SAFE_INTEGER,this.detectedHands=0}calculateLandmarksBoundingBox(t){let o=t.map(a=>a[0]),n=t.map(a=>a[1]),r=[Math.min(...o),Math.min(...n)],s=[Math.max(...o),Math.max(...n)];return{startPoint:r,endPoint:s}}getBoxForPalmLandmarks(t,o){let n=t.map(s=>N5([...s,1],o)),r=this.calculateLandmarksBoundingBox(n);return Rt(wt(r),hr)}getBoxForHandLandmarks(t){let o=this.calculateLandmarksBoundingBox(t),n=Rt(wt(o),io);n.palmLandmarks=[];for(let r=0;r[a[0]*(m[0]-this.inputSize/2),a[1]*(m[1]-this.inputSize/2),a[2]*m[2]]),l=I5(n,[0,0]),x=i.map(m=>[...N5(m,l),m[2]]),d=Ao(r),y=[...Ye(o),1],c=[K0(y,d[0]),K0(y,d[1])];return x.map(m=>[Math.trunc(m[0]+c[0]),Math.trunc(m[1]+c[1]),Math.trunc(m[2])])}async estimateHands(t,o){let n=!1,r,s=(o.hand.skipTime||0)>b()-yo,a=this.skipped<(o.hand.skipFrames||0);o.skipAllowed&&s&&a&&(r=await this.handDetector.predict(t,o),this.skipped=0),o.skipAllowed&&this.skipped++,r&&r.length>0&&(r.length!==this.detectedHands&&this.detectedHands!==o.hand.maxDetected||!o.hand.landmarks)&&(this.detectedHands=0,this.storedBoxes=[...r],this.storedBoxes.length>0&&(n=!0));let i=[];for(let l=0;l=o.hand.minConfidence/4){let S=A.reshape(f,[-1,3]),k=await S.array();A.dispose(f),A.dispose(S);let W=this.transformRawCoords(k,p,d,h),C=this.getBoxForHandLandmarks(W);this.storedBoxes[l]={...C,confidence:v};let L={landmarks:W,confidence:v,boxConfidence:x.confidence,fingerConfidence:v,box:{topLeft:C.startPoint,bottomRight:C.endPoint}};i.push(L)}else this.storedBoxes[l]=null;A.dispose(f)}else{let d=Rt(wt(x),io),y={confidence:x.confidence,boxConfidence:x.confidence,fingerConfidence:0,box:{topLeft:d.startPoint,bottomRight:d.endPoint},landmarks:[]};i.push(y)}}return this.storedBoxes=this.storedBoxes.filter(l=>l!==null),this.detectedHands=i.length,i.length>o.hand.maxDetected&&(i.length=o.hand.maxDetected),i}};var y0={thumb:0,index:1,middle:2,ring:3,pinky:4,all:[0,1,2,3,4],nameMapping:{0:"thumb",1:"index",2:"middle",3:"ring",4:"pinky"},pointsMapping:{0:[[0,1],[1,2],[2,3],[3,4]],1:[[0,5],[5,6],[6,7],[7,8]],2:[[0,9],[9,10],[10,11],[11,12]],3:[[0,13],[13,14],[14,15],[15,16]],4:[[0,17],[17,18],[18,19],[19,20]]},getName:e=>y0.nameMapping[e],getPoints:e=>y0.pointsMapping[e]},_0={none:0,half:1,full:2,nameMapping:{0:"none",1:"half",2:"full"},getName:e=>_0.nameMapping[e]},Y={verticalUp:0,verticalDown:1,horizontalLeft:2,horizontalRight:3,diagonalUpRight:4,diagonalUpLeft:5,diagonalDownRight:6,diagonalDownLeft:7,nameMapping:{0:"verticalUp",1:"verticalDown",2:"horizontalLeft",3:"horizontalRight",4:"diagonalUpRight",5:"diagonalUpLeft",6:"diagonalDownRight",7:"diagonalDownLeft"},getName:e=>Y.nameMapping[e]},Q0=class{constructor(t){T(this,"name");T(this,"curls");T(this,"directions");T(this,"weights");T(this,"weightsRelative");this.name=t,this.curls={},this.directions={},this.weights=[1,1,1,1,1],this.weightsRelative=[1,1,1,1,1]}curl(t,o,n){typeof this.curls[t]=="undefined"&&(this.curls[t]=[]),this.curls[t].push([o,n])}direction(t,o,n){this.directions[t]||(this.directions[t]=[]),this.directions[t].push([o,n])}weight(t,o){this.weights[t]=o;let n=this.weights.reduce((r,s)=>r+s,0);this.weightsRelative=this.weights.map(r=>r*5/n)}matchAgainst(t,o){let n=0;for(let r in t){let s=t[r],a=this.curls[r];if(typeof a=="undefined"){n+=this.weightsRelative[r];continue}for(let[i,l]of a)if(s===i){n+=l*this.weightsRelative[r];break}}for(let r in o){let s=o[r],a=this.directions[r];if(typeof a=="undefined"){n+=this.weightsRelative[r];continue}for(let[i,l]of a)if(s===i){n+=l*this.weightsRelative[r];break}}return n/10}};var{thumb:w0,index:H0,middle:V0,ring:ye,pinky:xe}=y0,{none:T0,half:vr,full:k0}=_0,{verticalUp:we,verticalDown:F3,horizontalLeft:F5,horizontalRight:Mr,diagonalUpRight:Rr,diagonalUpLeft:Te,diagonalDownRight:B3,diagonalDownLeft:G3}=Y,$0=new Q0("thumbs up");$0.curl(w0,T0,1);$0.direction(w0,we,1);$0.direction(w0,Te,.25);$0.direction(w0,Rr,.25);for(let e of[y0.index,y0.middle,y0.ring,y0.pinky])$0.curl(e,k0,1),$0.direction(e,F5,1),$0.direction(e,Mr,1);var e0=new Q0("victory");e0.curl(w0,vr,.5);e0.curl(w0,T0,.5);e0.direction(w0,we,1);e0.direction(w0,Te,1);e0.curl(H0,T0,1);e0.direction(H0,we,.75);e0.direction(H0,Te,1);e0.curl(V0,T0,1);e0.direction(V0,we,1);e0.direction(V0,Te,.75);e0.curl(ye,k0,1);e0.direction(ye,we,.2);e0.direction(ye,Te,1);e0.direction(ye,F5,.2);e0.curl(xe,k0,1);e0.direction(xe,we,.2);e0.direction(xe,Te,1);e0.direction(xe,F5,.2);e0.weight(H0,2);e0.weight(V0,2);var ee=new Q0("point");ee.curl(w0,k0,1);ee.curl(H0,T0,.5);ee.curl(V0,k0,.5);ee.curl(ye,k0,.5);ee.curl(xe,k0,.5);ee.weight(H0,2);ee.weight(V0,2);var te=new Q0("middle finger");te.curl(w0,T0,1);te.curl(H0,k0,.5);te.curl(V0,k0,.5);te.curl(ye,k0,.5);te.curl(xe,k0,.5);te.weight(H0,2);te.weight(V0,2);var ke=new Q0("open palm");ke.curl(w0,T0,.75);ke.curl(H0,T0,.75);ke.curl(V0,T0,.75);ke.curl(ye,T0,.75);ke.curl(xe,T0,.75);var xo=[$0,e0,ee,te,ke];var wr=.7,ce={HALF_CURL_START_LIMIT:60,NO_CURL_START_LIMIT:130,DISTANCE_VOTE_POWER:1.1,SINGLE_ANGLE_VOTE_POWER:.9,TOTAL_ANGLE_VOTE_POWER:1.6};function co(e,t,o,n){let r=(t-n)/(e-o),s=Math.atan(r)*180/Math.PI;return s<=0?s=-s:s>0&&(s=180-s),s}function mo(e,t){if(!e||!t)return[0,0];let o=co(e[0],e[1],t[0],t[1]);if(e.length===2)return o;let n=co(e[1],e[2],t[1],t[2]);return[o,n]}function fo(e,t=1){let o=0,n=0,r=0;return e>=75&&e<=105?o=1*t:e>=25&&e<=155?n=1*t:r=1*t,[o,n,r]}function Tr(e,t,o){let n=e[0]-t[0],r=e[0]-o[0],s=t[0]-o[0],a=e[1]-t[1],i=e[1]-o[1],l=t[1]-o[1],x=e[2]-t[2],d=e[2]-o[2],y=t[2]-o[2],c=Math.sqrt(n*n+a*a+x*x),m=Math.sqrt(r*r+i*i+d*d),h=Math.sqrt(s*s+l*l+y*y),p=(h*h+c*c-m*m)/(2*h*c);p>1?p=1:p<-1&&(p=-1);let M=Math.acos(p);M=57.2958*M%180;let P;return M>ce.NO_CURL_START_LIMIT?P=_0.none:M>ce.HALF_CURL_START_LIMIT?P=_0.half:P=_0.full,P}function po(e,t,o,n){let r;return n===Math.abs(e)?e>0?r=Y.horizontalLeft:r=Y.horizontalRight:n===Math.abs(t)?t>0?r=Y.horizontalLeft:r=Y.horizontalRight:o>0?r=Y.horizontalLeft:r=Y.horizontalRight,r}function uo(e,t,o,n){let r;return n===Math.abs(e)?e<0?r=Y.verticalDown:r=Y.verticalUp:n===Math.abs(t)?t<0?r=Y.verticalDown:r=Y.verticalUp:o<0?r=Y.verticalDown:r=Y.verticalUp,r}function kr(e,t,o,n,r,s,a,i){let l,x=uo(e,t,o,n),d=po(r,s,a,i);return x===Y.verticalUp?d===Y.horizontalLeft?l=Y.diagonalUpLeft:l=Y.diagonalUpRight:d===Y.horizontalLeft?l=Y.diagonalDownLeft:l=Y.diagonalDownRight,l}function Er(e,t,o,n){let r=e[0]-t[0],s=e[0]-o[0],a=t[0]-o[0],i=e[1]-t[1],l=e[1]-o[1],x=t[1]-o[1],d=Math.max(Math.abs(r),Math.abs(s),Math.abs(a)),y=Math.max(Math.abs(i),Math.abs(l),Math.abs(x)),c=0,m=0,h=0,p=y/(d+1e-5);p>1.5?c+=ce.DISTANCE_VOTE_POWER:p>.66?m+=ce.DISTANCE_VOTE_POWER:h+=ce.DISTANCE_VOTE_POWER;let M=Math.sqrt(r*r+i*i),P=Math.sqrt(s*s+l*l),g=Math.sqrt(a*a+x*x),f=Math.max(M,P,g),v=e[0],S=e[1],k=o[0],W=o[1];f===M?(k=o[0],W=o[1]):f===g&&(v=t[0],S=t[1]);let D=mo([v,S],[k,W]),H=fo(D,ce.TOTAL_ANGLE_VOTE_POWER);c+=H[0],m+=H[1],h+=H[2];for(let F of n){let z=fo(F,ce.SINGLE_ANGLE_VOTE_POWER);c+=z[0],m+=z[1],h+=z[2]}let Z;return c===Math.max(c,m,h)?Z=uo(l,i,x,y):h===Math.max(m,h)?Z=po(s,r,a,d):Z=kr(l,i,x,y,s,r,a,d),Z}function ho(e){let t=[],o=[],n=[],r=[];if(!e)return{curls:n,directions:r};for(let s of y0.all){let a=y0.getPoints(s),i=[],l=[];for(let x of a){let d=e[x[0]],y=e[x[1]],c=mo(d,y),m=c[0],h=c[1];i.push(m),l.push(h)}t.push(i),o.push(l)}for(let s of y0.all){let a=s===y0.thumb?1:0,i=y0.getPoints(s),l=e[i[a][0]],x=e[i[a+1][1]],d=e[i[3][1]],y=Tr(l,x,d),c=Er(l,x,d,t[s].slice(a));n[s]=y,r[s]=c}return{curls:n,directions:r}}function Et(e){if(!e||e.length===0)return null;let t=ho(e),o={};for(let n of y0.all)o[y0.getName(n)]={curl:_0.getName(t.curls[n]),direction:Y.getName(t.directions[n])};return o}function bo(e){let t=[];if(!e||e.length===0)return t;let o=ho(e);for(let n of xo){let r=n.matchAgainst(o.curls,o.directions);r>=wr&&t.push({name:n.name,confidence:r})}return t}var go={thumb:[1,2,3,4],index:[5,6,7,8],middle:[9,10,11,12],ring:[13,14,15,16],pinky:[17,18,19,20],palm:[0]},Ee,ze,Po;async function G5(e,t){let o=await Po.estimateHands(e,t);if(!o)return[];let n=[];for(let r=0;ro[r].landmarks[y]);let a=o[r].landmarks,i=[Number.MAX_SAFE_INTEGER,Number.MAX_SAFE_INTEGER,0,0],l=[0,0,0,0];if(a&&a.length>0){for(let d of a)d[0]i[2]&&(i[2]=d[0]),d[1]>i[3]&&(i[3]=d[1]);i[2]-=i[0],i[3]-=i[1],l=[i[0]/(e.shape[2]||0),i[1]/(e.shape[1]||0),i[2]/(e.shape[2]||0),i[3]/(e.shape[1]||0)]}else i=o[r].box?[Math.trunc(Math.max(0,o[r].box.topLeft[0])),Math.trunc(Math.max(0,o[r].box.topLeft[1])),Math.trunc(Math.min(e.shape[2]||0,o[r].box.bottomRight[0])-Math.max(0,o[r].box.topLeft[0])),Math.trunc(Math.min(e.shape[1]||0,o[r].box.bottomRight[1])-Math.max(0,o[r].box.topLeft[1]))]:[0,0,0,0],l=[o[r].box.topLeft[0]/(e.shape[2]||0),o[r].box.topLeft[1]/(e.shape[1]||0),(o[r].box.bottomRight[0]-o[r].box.topLeft[0])/(e.shape[2]||0),(o[r].box.bottomRight[1]-o[r].box.topLeft[1])/(e.shape[1]||0)];let x=Et(a);n.push({id:r,score:Math.round(100*o[r].confidence)/100,boxScore:Math.round(100*o[r].boxConfidence)/100,fingerScore:Math.round(100*o[r].fingerConfidence)/100,label:"hand",box:i,boxRaw:l,keypoints:a,annotations:s,landmarks:x})}return n}async function H5(e){var o,n;w.initial&&(Ee=null,ze=null),!Ee||!ze?[Ee,ze]=await Promise.all([e.hand.enabled?I((o=e.hand.detector)==null?void 0:o.modelPath):null,e.hand.landmarks?I((n=e.hand.skeleton)==null?void 0:n.modelPath):null]):(e.debug&&u("cached model:",Ee.modelUrl),e.debug&&u("cached model:",ze.modelUrl));let t=new Tt(Ee);return Po=new kt(t,ze),[Ee,ze]}var o0=[null,null],zr=["StatefulPartitionedCall/Postprocessor/Slice","StatefulPartitionedCall/Postprocessor/ExpandDims_1"],oe=[[0,0],[0,0]],jr=["hand","fist","pinch","point","face","tip","pinchtip"],Mo=4,Ro=1.6,Sr=512,Cr=1.4,zt=Number.MAX_SAFE_INTEGER,V5=0,Z0=[0,0],Q={boxes:[],hands:[]},wo={thumb:[1,2,3,4],index:[5,6,7,8],middle:[9,10,11,12],ring:[13,14,15,16],pinky:[17,18,19,20],base:[0],palm:[0,17,13,9,5,1,0]};async function To(e){var t;if(w.initial&&(o0[0]=null),o0[0])e.debug&&u("cached model:",o0[0].modelUrl);else{jt(["tensorlistreserve","enter","tensorlistfromtensor","merge","loopcond","switch","exit","tensorliststack","nextiteration","tensorlistsetitem","tensorlistgetitem","reciprocal","shape","split","where"],e),o0[0]=await I((t=e.hand.detector)==null?void 0:t.modelPath);let o=Object.values(o0[0].modelSignature.inputs);oe[0][0]=Array.isArray(o)?parseInt(o[0].tensorShape.dim[1].size):0,oe[0][1]=Array.isArray(o)?parseInt(o[0].tensorShape.dim[2].size):0}return o0[0]}async function ko(e){var t;if(w.initial&&(o0[1]=null),o0[1])e.debug&&u("cached model:",o0[1].modelUrl);else{o0[1]=await I((t=e.hand.skeleton)==null?void 0:t.modelPath);let o=Object.values(o0[1].modelSignature.inputs);oe[1][0]=Array.isArray(o)?parseInt(o[0].tensorShape.dim[1].size):0,oe[1][1]=Array.isArray(o)?parseInt(o[0].tensorShape.dim[2].size):0}return o0[1]}async function Wr(e,t){let o=[];if(!e||!o0[0])return o;let n={},r=(e.shape[2]||1)/(e.shape[1]||1),s=Math.min(Math.round((e.shape[1]||0)/8)*8,Sr),a=Math.round(s*r/8)*8;n.resize=A.image.resizeBilinear(e,[s,a]),n.cast=A.cast(n.resize,"int32"),[n.rawScores,n.rawBoxes]=await o0[0].executeAsync(n.cast,zr),n.boxes=A.squeeze(n.rawBoxes,[0,2]),n.scores=A.squeeze(n.rawScores,[0]);let i=A.unstack(n.scores,1);A.dispose(i[Mo]),i.splice(Mo,1),n.filtered=A.stack(i,1),A.dispose(i),n.max=A.max(n.filtered,1),n.argmax=A.argMax(n.filtered,1);let l=0;n.nms=await A.image.nonMaxSuppressionAsync(n.boxes,n.max,(t.hand.maxDetected||0)+1,t.hand.iouThreshold||0,t.hand.minConfidence||1);let x=await n.nms.data(),d=await n.max.data(),y=await n.argmax.data();for(let c of Array.from(x)){let m=A.slice(n.boxes,c,1),h=await m.data();A.dispose(m);let p=[h[1],h[0],h[3]-h[1],h[2]-h[0]],M=pt(p,Cr),P=[Math.trunc(p[0]*Z0[0]),Math.trunc(p[1]*Z0[1]),Math.trunc(p[2]*Z0[0]),Math.trunc(p[3]*Z0[1])],g=d[c],f=jr[y[c]],v={id:l++,score:g,box:P,boxRaw:M,label:f};o.push(v)}return Object.keys(n).forEach(c=>A.dispose(n[c])),o.sort((c,m)=>m.score-c.score),o.length>(t.hand.maxDetected||1)&&(o.length=t.hand.maxDetected||1),o}async function Z5(e,t,o){let n={id:t.id,score:Math.round(100*t.score)/100,boxScore:Math.round(100*t.score)/100,fingerScore:0,box:t.box,boxRaw:t.boxRaw,label:t.label,keypoints:[],landmarks:{},annotations:{}};if(e&&o0[1]&&o.hand.landmarks&&t.score>(o.hand.minConfidence||0)){let r={},s=[t.boxRaw[1],t.boxRaw[0],t.boxRaw[3]+t.boxRaw[1],t.boxRaw[2]+t.boxRaw[0]];r.crop=A.image.cropAndResize(e,[s],[0],[oe[1][0],oe[1][1]],"bilinear"),r.div=A.div(r.crop,N.tf255),[r.score,r.keypoints]=o0[1].execute(r.div,["Identity_1","Identity"]);let a=(await r.score.data())[0],i=(100-Math.trunc(100/(1+Math.exp(a))))/100;if(i>=(o.hand.minConfidence||0)){n.fingerScore=i,r.reshaped=A.reshape(r.keypoints,[-1,3]);let d=(await r.reshaped.array()).map(y=>[y[0]/oe[1][1],y[1]/oe[1][0],y[2]||0]).map(y=>[y[0]*t.boxRaw[2],y[1]*t.boxRaw[3],y[2]||0]);n.keypoints=d.map(y=>[Z0[0]*(y[0]+t.boxRaw[0]),Z0[1]*(y[1]+t.boxRaw[1]),y[2]||0]),n.landmarks=Et(n.keypoints);for(let y of Object.keys(wo))n.annotations[y]=wo[y].map(c=>n.landmarks&&n.keypoints[c]?n.keypoints[c]:null)}Object.keys(r).forEach(l=>A.dispose(r[l]))}return n}async function D5(e,t){var r,s;if(!o0[0]||!o0[1]||!((r=o0[0])!=null&&r.inputs[0].shape)||!((s=o0[1])!=null&&s.inputs[0].shape))return[];Z0=[e.shape[2]||0,e.shape[1]||0],zt++;let o=(t.hand.skipTime||0)>b()-V5,n=zt<(t.hand.skipFrames||0);return t.skipAllowed&&o&&n?Q.hands:new Promise(async a=>{let i=3*(t.hand.skipTime||0)>b()-V5,l=zt<3*(t.hand.skipFrames||0);t.skipAllowed&&Q.hands.length===t.hand.maxDetected?Q.hands=await Promise.all(Q.boxes.map(d=>Z5(e,d,t))):t.skipAllowed&&i&&l&&Q.hands.length>0?Q.hands=await Promise.all(Q.boxes.map(d=>Z5(e,d,t))):(Q.boxes=await Wr(e,t),V5=b(),Q.hands=await Promise.all(Q.boxes.map(d=>Z5(e,d,t))),zt=0);let x=[...Q.boxes];if(Q.boxes.length=0,t.cacheSensitivity>0)for(let d=0;d.05&&y.box[3]/(e.shape[1]||1)>.05&&Q.hands[d].fingerScore&&Q.hands[d].fingerScore>(t.hand.minConfidence||0)){let c=pt(y.box,Ro),m=pt(y.boxRaw,Ro);Q.boxes.push({...x[d],box:c,boxRaw:m})}}for(let d=0;db()-jo,s=X5<(((i=t.face.liveness)==null?void 0:i.skipFrames)||0);return t.skipAllowed&&r&&s&&zo===n&&St[o]?(X5++,St[o]):(X5=0,new Promise(async l=>{let x=A.image.resizeBilinear(e,[s0!=null&&s0.inputs[0].shape?s0.inputs[0].shape[2]:0,s0!=null&&s0.inputs[0].shape?s0.inputs[0].shape[1]:0],!1),d=s0==null?void 0:s0.execute(x),y=(await d.data())[0];St[o]=Math.round(100*y)/100,zo=n,jo=b(),A.dispose([x,d]),l(St[o])}))}var Ke={};ne(Ke,{connected:()=>Wt,horizontal:()=>U5,kpt:()=>Ct,relative:()=>Y5,vertical:()=>J5});var Ct=["nose","leftEye","rightEye","leftEar","rightEar","leftShoulder","rightShoulder","leftElbow","rightElbow","leftWrist","rightWrist","leftHip","rightHip","leftKnee","rightKnee","leftAnkle","rightAnkle"],U5=[["leftEye","rightEye"],["leftEar","rightEar"],["leftShoulder","rightShoulder"],["leftElbow","rightElbow"],["leftWrist","rightWrist"],["leftHip","rightHip"],["leftKnee","rightKnee"],["leftAnkle","rightAnkle"]],J5=[["leftKnee","leftShoulder"],["rightKnee","rightShoulder"],["leftAnkle","leftKnee"],["rightAnkle","rightKnee"]],Y5=[[["leftHip","rightHip"],["leftShoulder","rightShoulder"]],[["leftElbow","rightElbow"],["leftShoulder","rightShoulder"]]],Wt={leftLeg:["leftHip","leftKnee","leftAnkle"],rightLeg:["rightHip","rightKnee","rightAnkle"],torso:["leftShoulder","rightShoulder","rightHip","leftHip","leftShoulder"],leftArm:["leftShoulder","leftElbow","leftWrist"],rightArm:["rightShoulder","rightElbow","rightWrist"],head:[]};var Wo=.005,p0={keypoints:[],padding:[[0,0],[0,0],[0,0],[0,0]]};function K5(e){for(let t of U5){let o=e.keypoints.findIndex(r=>r.part===t[0]),n=e.keypoints.findIndex(r=>r.part===t[1]);if(e.keypoints[o]&&e.keypoints[n]&&e.keypoints[o].position[0]r&&r.part===t[0]),n=e.keypoints.findIndex(r=>r&&r.part===t[1]);e.keypoints[o]&&e.keypoints[n]&&e.keypoints[o].position[1]x&&x.part===t[0]),r=e.keypoints.findIndex(x=>x&&x.part===t[1]),s=e.keypoints.findIndex(x=>x&&x.part===o[0]),a=e.keypoints.findIndex(x=>x&&x.part===o[1]);if(!e.keypoints[s]||!e.keypoints[a])continue;let i=e.keypoints[n]?[Math.abs(e.keypoints[s].position[0]-e.keypoints[n].position[0]),Math.abs(e.keypoints[a].position[0]-e.keypoints[n].position[0])]:[0,0],l=e.keypoints[r]?[Math.abs(e.keypoints[a].position[0]-e.keypoints[r].position[0]),Math.abs(e.keypoints[s].position[0]-e.keypoints[r].position[0])]:[0,0];if(i[0]>i[1]||l[0]>l[1]){let x=e.keypoints[n];e.keypoints[n]=e.keypoints[r],e.keypoints[r]=x}}}function Oo(e){for(let t=0;te.shape[1]?Math.trunc((e.shape[2]-e.shape[1])/2):0,e.shape[2]>e.shape[1]?Math.trunc((e.shape[2]-e.shape[1])/2):0],[e.shape[1]>e.shape[2]?Math.trunc((e.shape[1]-e.shape[2])/2):0,e.shape[1]>e.shape[2]?Math.trunc((e.shape[1]-e.shape[2])/2):0],[0,0]],o.pad=A.pad(e,p0.padding),o.resize=A.image.resizeBilinear(o.pad,[t,t]);let n=A.cast(o.resize,"int32");return Object.keys(o).forEach(r=>A.dispose(o[r])),n}function Io(e,t){e.keypoints=e.keypoints.filter(n=>n&&n.position);for(let n of e.keypoints)n.position=[n.position[0]*(t[0]+p0.padding[2][0]+p0.padding[2][1])/t[0]-p0.padding[2][0],n.position[1]*(t[1]+p0.padding[1][0]+p0.padding[1][1])/t[1]-p0.padding[1][0]],n.positionRaw=[n.position[0]/t[0],n.position[1]/t[1]];let o=F0(e.keypoints.map(n=>n.position),t);return e.box=o.box,e.boxRaw=o.boxRaw,e}var u0,Ot=0,Q5=Number.MAX_SAFE_INTEGER,de={boxes:[],bodies:[],last:0};async function No(e){return w.initial&&(u0=null),u0?e.debug&&u("cached model:",u0.modelUrl):(jt(["size"],e),u0=await I(e.body.modelPath)),Ot=u0.inputs[0].shape?u0.inputs[0].shape[2]:0,Ot<64&&(Ot=256),u0}async function Lr(e,t,o){let n=e[0][0],r=[],s=0;for(let d=0;dt.body.minConfidence){let y=[n[d][1],n[d][0]];r.push({score:Math.round(100*s)/100,part:Ct[d],positionRaw:y,position:[Math.round((o.shape[2]||0)*y[0]),Math.round((o.shape[1]||0)*y[1])]})}s=r.reduce((d,y)=>y.score>d?y.score:d,0);let a=[],i=F0(r.map(d=>d.position),[o.shape[2],o.shape[1]]),l={};for(let[d,y]of Object.entries(Wt)){let c=[];for(let m=0;mM.part===y[m]),p=r.find(M=>M.part===y[m+1]);h&&p&&h.score>(t.body.minConfidence||0)&&p.score>(t.body.minConfidence||0)&&c.push([h.position,p.position])}l[d]=c}let x={id:0,score:s,box:i.box,boxRaw:i.boxRaw,keypoints:r,annotations:l};return K5(x),a.push(x),a}async function Ir(e,t,o){let n=[];for(let r=0;rt.body.minConfidence){let i=[];for(let y=0;y<17;y++){let c=s[3*y+2];if(c>t.body.minConfidence){let m=[s[3*y+1],s[3*y+0]];i.push({part:Ct[y],score:Math.round(100*c)/100,positionRaw:m,position:[Math.round((o.shape[2]||0)*m[0]),Math.round((o.shape[1]||0)*m[1])]})}}let l=F0(i.map(y=>y.position),[o.shape[2],o.shape[1]]),x={};for(let[y,c]of Object.entries(Wt)){let m=[];for(let h=0;hP.part===c[h]),M=i.find(P=>P.part===c[h+1]);p&&M&&p.score>(t.body.minConfidence||0)&&M.score>(t.body.minConfidence||0)&&m.push([p.position,M.position])}x[y]=m}let d={id:r,score:a,box:l.box,boxRaw:l.boxRaw,keypoints:[...i],annotations:x};K5(d),n.push(d)}}return n.sort((r,s)=>s.score-r.score),n.length>t.body.maxDetected&&(n.length=t.body.maxDetected),n}async function _5(e,t){if(!u0||!(u0!=null&&u0.inputs[0].shape))return[];t.skipAllowed||(de.boxes.length=0),Q5++;let o=(t.body.skipTime||0)>b()-de.last,n=Q5<(t.body.skipFrames||0);return t.skipAllowed&&o&&n?de.bodies:new Promise(async r=>{let s={};Q5=0,s.input=Lo(e,Ot),s.res=u0==null?void 0:u0.execute(s.input),de.last=b();let a=await s.res.array();de.bodies=s.res.shape[2]===17?await Lr(a,t,e):await Ir(a,t,e);for(let i of de.bodies)Io(i,[e.shape[2]||1,e.shape[1]||1]),Oo(i.keypoints);Object.keys(s).forEach(i=>A.dispose(s[i])),r(de.bodies)})}var je,Lt=[],Bo=0,$5=Number.MAX_SAFE_INTEGER,Nt=0,It=2.5;async function Go(e){if(!je||w.initial){je=await I(e.object.modelPath);let t=Object.values(je.modelSignature.inputs);Nt=Array.isArray(t)?parseInt(t[0].tensorShape.dim[2].size):0}else e.debug&&u("cached model:",je.modelUrl);return je}async function Nr(e,t,o){let n=0,r=[];for(let l of[1,2,4])A.tidy(async()=>{let x=l*13,d=A.squeeze(e.find(p=>p.shape[1]===x**2&&(p.shape[2]||0)===ve.length)),y=A.squeeze(e.find(p=>p.shape[1]===x**2&&(p.shape[2]||0)(o.object.minConfidence||0)&&M!==61){let g=(.5+Math.trunc(p%x))/x,f=(.5+Math.trunc(p/x))/x,v=m[p].map(Z=>Z*(x/l/Nt)),[S,k]=[g-It/l*v[0],f-It/l*v[1]],[W,C]=[g+It/l*v[2]-S,f+It/l*v[3]-k],L=[S,k,W,C];L=L.map(Z=>Math.max(0,Math.min(Z,1)));let D=[L[0]*t[0],L[1]*t[1],L[2]*t[0],L[3]*t[1]],H={id:n++,score:Math.round(100*P)/100,class:M+1,label:ve[M].label,box:D.map(Z=>Math.trunc(Z)),boxRaw:L};r.push(H)}}});e.forEach(l=>A.dispose(l));let s=r.map(l=>[l.boxRaw[1],l.boxRaw[0],l.boxRaw[3],l.boxRaw[2]]),a=r.map(l=>l.score),i=[];if(s&&s.length>0){let l=await A.image.nonMaxSuppressionAsync(s,a,o.object.maxDetected,o.object.iouThreshold,o.object.minConfidence);i=await l.data(),A.dispose(l)}return r=r.filter((l,x)=>i.includes(x)).sort((l,x)=>x.score-l.score),r}async function e2(e,t){let o=(t.object.skipTime||0)>b()-Bo,n=$5<(t.object.skipFrames||0);return t.skipAllowed&&o&&n&&Lt.length>0?($5++,Lt):($5=0,!w.kernels.includes("mod")||!w.kernels.includes("sparsetodense")?Lt:new Promise(async r=>{let s=[e.shape[2]||0,e.shape[1]||0],a=A.image.resizeBilinear(e,[Nt,Nt],!1),i=A.div(a,N.tf255),l=i.transpose([0,3,1,2]);A.dispose(i),A.dispose(a);let x;t.object.enabled&&(x=je.execute(l)),Bo=b(),A.dispose(l);let d=await Nr(x,s,t);Lt=d,r(d)}))}var _e=["nose","leftEye","rightEye","leftEar","rightEar","leftShoulder","rightShoulder","leftElbow","rightElbow","leftWrist","rightWrist","leftHip","rightHip","leftKnee","rightKnee","leftAnkle","rightAnkle"],Fr=_e.length,Qe=_e.reduce((e,t,o)=>(e[t]=o,e),{}),Br=[["leftHip","leftShoulder"],["leftElbow","leftShoulder"],["leftElbow","leftWrist"],["leftHip","leftKnee"],["leftKnee","leftAnkle"],["rightHip","rightShoulder"],["rightElbow","rightShoulder"],["rightElbow","rightWrist"],["rightHip","rightKnee"],["rightKnee","rightAnkle"],["leftShoulder","rightShoulder"],["leftHip","rightHip"]],ys=Br.map(([e,t])=>[Qe[e],Qe[t]]),Vo=[["nose","leftEye"],["leftEye","leftEar"],["nose","rightEye"],["rightEye","rightEar"],["nose","leftShoulder"],["leftShoulder","leftElbow"],["leftElbow","leftWrist"],["leftShoulder","leftHip"],["leftHip","leftKnee"],["leftKnee","leftAnkle"],["nose","rightShoulder"],["rightShoulder","rightElbow"],["rightElbow","rightWrist"],["rightShoulder","rightHip"],["rightHip","rightKnee"],["rightKnee","rightAnkle"]];function Zo(e){let t=e.reduce(({maxX:o,maxY:n,minX:r,minY:s},{position:{x:a,y:i}})=>({maxX:Math.max(o,a),maxY:Math.max(n,i),minX:Math.min(r,a),minY:Math.min(s,i)}),{maxX:Number.NEGATIVE_INFINITY,maxY:Number.NEGATIVE_INFINITY,minX:Number.POSITIVE_INFINITY,minY:Number.POSITIVE_INFINITY});return[t.minX,t.minY,t.maxX-t.minX,t.maxY-t.minY]}function Do(e,[t,o],[n,r]){let s=t/n,a=o/r,i=(x,d)=>({id:d,score:x.score,boxRaw:[x.box[0]/r,x.box[1]/n,x.box[2]/r,x.box[3]/n],box:[Math.trunc(x.box[0]*a),Math.trunc(x.box[1]*s),Math.trunc(x.box[2]*a),Math.trunc(x.box[3]*s)],keypoints:x.keypoints.map(({score:y,part:c,position:m})=>({score:y,part:c,position:[Math.trunc(m.x*a),Math.trunc(m.y*s)],positionRaw:[m.x/n,m.y/n]})),annotations:{}});return e.map((x,d)=>i(x,d))}var Ft=class{constructor(t,o){T(this,"priorityQueue");T(this,"numberOfElements");T(this,"getElementValue");this.priorityQueue=new Array(t),this.numberOfElements=-1,this.getElementValue=o}enqueue(t){this.priorityQueue[++this.numberOfElements]=t,this.swim(this.numberOfElements)}dequeue(){let t=this.priorityQueue[0];return this.exchange(0,this.numberOfElements--),this.sink(0),this.priorityQueue[this.numberOfElements+1]=null,t}empty(){return this.numberOfElements===-1}size(){return this.numberOfElements+1}all(){return this.priorityQueue.slice(0,this.numberOfElements+1)}max(){return this.priorityQueue[0]}swim(t){for(;t>0&&this.less(Math.floor(t/2),t);)this.exchange(t,Math.floor(t/2)),t=Math.floor(t/2)}sink(t){for(;2*t<=this.numberOfElements;){let o=2*t;if(oo?o:e}function Xo(e,t,o,n){let r=o-e,s=n-t;return r*r+s*s}function r2(e,t){return{x:e.x+t.x,y:e.y+t.y}}var E0,Hr=["MobilenetV1/offset_2/BiasAdd","MobilenetV1/heatmap_2/BiasAdd","MobilenetV1/displacement_fwd_2/BiasAdd","MobilenetV1/displacement_bwd_2/BiasAdd"],Bt=1,Se=16,Vr=50**2;function qo(e,t,o,n,r,s,a=2){let i=P=>({y:s.get(P.y,P.x,e),x:s.get(P.y,P.x,s.shape[2]/2+e)}),l=(P,g,f)=>({y:n2(Math.round(P.y/Se),0,g-1),x:n2(Math.round(P.x/Se),0,f-1)}),[x,d]=n.shape,y=l(t.position,x,d),c=i(y),h=r2(t.position,c);for(let P=0;P[Qe[c],Qe[m]]),a=s.map(([,c])=>c),i=s.map(([c])=>c),l=t.shape[2],x=a.length,d=new Array(l),y=o2(e.part,Se,o);d[e.part.id]={score:e.score,part:_e[e.part.id],position:y};for(let c=x-1;c>=0;--c){let m=a[c],h=i[c];d[m]&&!d[h]&&(d[h]=qo(c,d[m],h,t,o,r))}for(let c=0;ct){i=!1;break}if(!i)break}return i}function Xr(e,t){let[o,n,r]=t.shape,s=new Ft(o*n*r,({score:a})=>a);for(let a=0;a{var a;let s=(a=r[n])==null?void 0:a.position;return s?Xo(o,t,s.y,s.x)<=Vr:!1})}function qr(e,t){return t.reduce((n,{position:r,score:s},a)=>(Uo(e,r,a)||(n+=s),n),0)/t.length}function Ur(e,t,o,n,r,s){let a=[],i=Xr(s,t);for(;a.lengthm.score>s);let y=qr(a,d),c=Zo(d);y>s&&a.push({keypoints:d,box:c,score:Math.round(100*y)/100})}return a}async function A2(e,t){let o=A.tidy(()=>{if(!E0.inputs[0].shape)return[];let a=A.image.resizeBilinear(e,[E0.inputs[0].shape[2],E0.inputs[0].shape[1]]),i=A.sub(A.div(A.cast(a,"float32"),127.5),1),x=E0.execute(i,Hr).map(d=>A.squeeze(d,[0]));return x[1]=A.sigmoid(x[1]),x}),n=await Promise.all(o.map(a=>a.buffer()));for(let a of o)A.dispose(a);let r=await Ur(n[0],n[1],n[2],n[3],t.body.maxDetected,t.body.minConfidence);return E0.inputs[0].shape?Do(r,[e.shape[1],e.shape[2]],[E0.inputs[0].shape[2],E0.inputs[0].shape[1]]):[]}async function Jo(e){return!E0||w.initial?E0=await I(e.body.modelPath):e.debug&&u("cached model:",E0.modelUrl),E0}var C0,s2=!1;async function a2(e){return!C0||w.initial?C0=await I(e.segmentation.modelPath):e.debug&&u("cached model:",C0.modelUrl),C0}async function Ko(e,t,o){var p,M;if(s2)return{data:[],canvas:null,alpha:null};s2=!0,C0||await a2(o);let n=await he(e,o),r=((p=n.tensor)==null?void 0:p.shape[2])||0,s=((M=n.tensor)==null?void 0:M.shape[1])||0;if(!n.tensor)return{data:[],canvas:null,alpha:null};let a={};a.resize=A.image.resizeBilinear(n.tensor,[C0.inputs[0].shape?C0.inputs[0].shape[1]:0,C0.inputs[0].shape?C0.inputs[0].shape[2]:0],!1),A.dispose(n.tensor),a.norm=A.div(a.resize,N.tf255),a.res=C0.execute(a.norm),a.squeeze=A.squeeze(a.res,0),a.squeeze.shape[2]===2?(a.softmax=A.softmax(a.squeeze),[a.bg,a.fg]=A.unstack(a.softmax,2),a.expand=A.expandDims(a.fg,2),a.pad=A.expandDims(a.expand,0),a.crop=A.image.cropAndResize(a.pad,[[0,0,.5,.5]],[0],[r,s]),a.data=A.squeeze(a.crop,0)):a.data=A.image.resizeBilinear(a.squeeze,[s,r]);let i=Array.from(await a.data.data());if(w.node&&!w.Canvas&&typeof ImageData=="undefined")return o.debug&&u("canvas support missing"),Object.keys(a).forEach(P=>A.dispose(a[P])),{data:i,canvas:null,alpha:null};let l=i0(r,s);A.browser&&await A.browser.toPixels(a.data,l);let x=l.getContext("2d");o.segmentation.blur&&o.segmentation.blur>0&&(x.filter=`blur(${o.segmentation.blur}px)`);let d=x.getImageData(0,0,r,s),y=i0(r,s),c=y.getContext("2d");n.canvas&&c.drawImage(n.canvas,0,0),c.globalCompositeOperation="darken",o.segmentation.blur&&o.segmentation.blur>0&&(c.filter=`blur(${o.segmentation.blur}px)`),c.drawImage(l,0,0),c.globalCompositeOperation="source-over",c.filter="none";let m=c.getImageData(0,0,r,s);for(let P=0;PA.dispose(a[P])),s2=!1,{data:i,canvas:y,alpha:l}}var $e=class{constructor(){T(this,"ssrnetage",null);T(this,"gear",null);T(this,"blazeposedetect",null);T(this,"blazepose",null);T(this,"centernet",null);T(this,"efficientpose",null);T(this,"mobilefacenet",null);T(this,"emotion",null);T(this,"facedetect",null);T(this,"faceiris",null);T(this,"facemesh",null);T(this,"faceres",null);T(this,"ssrnetgender",null);T(this,"handpose",null);T(this,"handskeleton",null);T(this,"handtrack",null);T(this,"liveness",null);T(this,"movenet",null);T(this,"nanodet",null);T(this,"posenet",null);T(this,"segmentation",null);T(this,"antispoof",null)}};function Gt(e){for(let t of Object.keys(e.models))e.models[t]=null}async function i2(e){var t,o,n,r,s,a,i,l,x,d,y,c,m,h,p,M,P,g,f,v,S,k,W,C,L,D,H,Z,F,z,h0;w.initial&&Gt(e),e.config.hand.enabled&&(!e.models.handpose&&((o=(t=e.config.hand.detector)==null?void 0:t.modelPath)==null?void 0:o.includes("handdetect"))&&([e.models.handpose,e.models.handskeleton]=await H5(e.config)),!e.models.handskeleton&&e.config.hand.landmarks&&((r=(n=e.config.hand.detector)==null?void 0:n.modelPath)==null?void 0:r.includes("handdetect"))&&([e.models.handpose,e.models.handskeleton]=await H5(e.config))),e.config.body.enabled&&!e.models.blazepose&&((a=(s=e.config.body)==null?void 0:s.modelPath)==null?void 0:a.includes("blazepose"))&&(e.models.blazepose=M1(e.config)),e.config.body.enabled&&!e.models.blazeposedetect&&e.config.body.detector&&e.config.body.detector.modelPath&&(e.models.blazeposedetect=v1(e.config)),e.config.body.enabled&&!e.models.efficientpose&&((l=(i=e.config.body)==null?void 0:i.modelPath)==null?void 0:l.includes("efficientpose"))&&(e.models.efficientpose=z1(e.config)),e.config.body.enabled&&!e.models.movenet&&((d=(x=e.config.body)==null?void 0:x.modelPath)==null?void 0:d.includes("movenet"))&&(e.models.movenet=No(e.config)),e.config.body.enabled&&!e.models.posenet&&((c=(y=e.config.body)==null?void 0:y.modelPath)==null?void 0:c.includes("posenet"))&&(e.models.posenet=Jo(e.config)),e.config.face.enabled&&!e.models.facedetect&&(e.models.facedetect=d1(e.config)),e.config.face.enabled&&((m=e.config.face.antispoof)==null?void 0:m.enabled)&&!e.models.antispoof&&(e.models.antispoof=e1(e.config)),e.config.face.enabled&&((h=e.config.face.liveness)==null?void 0:h.enabled)&&!e.models.liveness&&(e.models.liveness=So(e.config)),e.config.face.enabled&&((p=e.config.face.description)==null?void 0:p.enabled)&&!e.models.faceres&&(e.models.faceres=$1(e.config)),e.config.face.enabled&&((M=e.config.face.emotion)==null?void 0:M.enabled)&&!e.models.emotion&&(e.models.emotion=W1(e.config)),e.config.face.enabled&&((P=e.config.face.iris)==null?void 0:P.enabled)&&!((g=e.config.face.attention)!=null&&g.enabled)&&!e.models.faceiris&&(e.models.faceiris=Z1(e.config)),e.config.face.enabled&&((f=e.config.face.mesh)==null?void 0:f.enabled)&&!e.models.facemesh&&(e.models.facemesh=J1(e.config)),e.config.face.enabled&&((v=e.config.face.gear)==null?void 0:v.enabled)&&!e.models.gear&&(e.models.gear=H2(e.config)),e.config.face.enabled&&((S=e.config.face.ssrnet)==null?void 0:S.enabled)&&!e.models.ssrnetage&&(e.models.ssrnetage=q2(e.config)),e.config.face.enabled&&((k=e.config.face.ssrnet)==null?void 0:k.enabled)&&!e.models.ssrnetgender&&(e.models.ssrnetgender=K2(e.config)),e.config.face.enabled&&((W=e.config.face.mobilefacenet)==null?void 0:W.enabled)&&!e.models.mobilefacenet&&(e.models.mobilefacenet=F1(e.config)),e.config.hand.enabled&&!e.models.handtrack&&((L=(C=e.config.hand.detector)==null?void 0:C.modelPath)==null?void 0:L.includes("handtrack"))&&(e.models.handtrack=To(e.config)),e.config.hand.enabled&&e.config.hand.landmarks&&!e.models.handskeleton&&((H=(D=e.config.hand.detector)==null?void 0:D.modelPath)==null?void 0:H.includes("handtrack"))&&(e.models.handskeleton=ko(e.config)),e.config.object.enabled&&!e.models.centernet&&((F=(Z=e.config.object)==null?void 0:Z.modelPath)==null?void 0:F.includes("centernet"))&&(e.models.centernet=T1(e.config)),e.config.object.enabled&&!e.models.nanodet&&((h0=(z=e.config.object)==null?void 0:z.modelPath)==null?void 0:h0.includes("nanodet"))&&(e.models.nanodet=Go(e.config)),e.config.segmentation.enabled&&!e.models.segmentation&&(e.models.segmentation=a2(e.config));for await(let b0 of Object.keys(e.models))e.models[b0]&&typeof e.models[b0]!="undefined"&&(e.models[b0]=await e.models[b0])}async function l2(e){let t=["const","placeholder","noop","pad","squeeze","add","sub","mul","div"];for(let o of Object.keys(e.models)){let n=e.models[o];if(!n)continue;let r=[],s=n==null?void 0:n.executor;if(s&&s.graph.nodes)for(let i of Object.values(s.graph.nodes)){let l=i.op.toLowerCase();r.includes(l)||r.push(l)}else!s&&e.config.debug&&u("model signature not determined:",o);let a=[];for(let i of r)!t.includes(i)&&!e.env.kernels.includes(i)&&!e.env.kernels.includes(i.replace("_",""))&&!e.env.kernels.includes(i.replace("native",""))&&!e.env.kernels.includes(i.replace("v2",""))&&a.push(i);e.config.debug&&a.length>0&&u("model validation failed:",o,a)}}var J={name:"humangl",priority:999,canvas:null,gl:null,extensions:[],webGLattr:{alpha:!1,antialias:!1,premultipliedAlpha:!1,preserveDrawingBuffer:!1,depth:!1,stencil:!1,failIfMajorPerformanceCaveat:!1,desynchronized:!0}};function Jr(){let e=J.gl;!e||(J.extensions=e.getSupportedExtensions())}async function _o(e){var t;if(e.config.backend==="humangl"&&(J.name in A.engine().registry&&(!J.gl||!J.gl.getParameter(J.gl.VERSION))&&(u("error: humangl backend invalid context"),Gt(e)),!A.findBackend(J.name))){try{J.canvas=await i0(100,100)}catch(n){u("error: cannot create canvas:",n);return}try{if(J.gl=(t=J.canvas)==null?void 0:t.getContext("webgl2",J.webGLattr),!J.gl.getParameter(J.gl.VERSION).includes("2.0")){u("override: using fallback webgl backend as webgl 2.0 is not detected"),e.config.backend="webgl";return}J.canvas&&(J.canvas.addEventListener("webglcontextlost",async r=>{throw u("error: humangl:",r.type),u("possible browser memory leak using webgl or conflict with multiple backend registrations"),e.emit("error"),new Error("backend error: webgl context lost")}),J.canvas.addEventListener("webglcontextrestored",r=>{u("error: humangl context restored:",r)}),J.canvas.addEventListener("webglcontextcreationerror",r=>{u("error: humangl context create:",r)}))}catch(n){u("error: cannot get WebGL context:",n);return}try{A.setWebGLContext(2,J.gl)}catch(n){u("error: cannot set WebGL context:",n);return}try{let n=new A.GPGPUContext(J.gl);A.registerBackend(J.name,()=>new A.MathBackendWebGL(n),J.priority)}catch(n){u("error: cannot register WebGL backend:",n);return}try{A.getKernelsForBackend("webgl").forEach(r=>{let s={...r,backendName:J.name};A.registerKernel(s)})}catch(n){u("error: cannot update WebGL backend registration:",n);return}let o=A.backend().getGPGPUContext?A.backend().getGPGPUContext().gl:null;if(o)u(`humangl webgl version:${o.getParameter(o.VERSION)} renderer:${o.getParameter(o.RENDERER)}`);else{u("error: no current gl context:",o,J.gl);return}try{A.ENV.set("WEBGL_VERSION",2)}catch(n){u("error: cannot set WebGL backend flags:",n);return}Jr(),u("backend registered:",J.name)}}function Yr(){if(!w.kernels.includes("mod")){let e={kernelName:"Mod",backendName:A.getBackend(),kernelFunc:t=>A.tidy(()=>A.sub(t.inputs.a,A.mul(A.div(t.inputs.a,t.inputs.b),t.inputs.b)))};A.registerKernel(e),w.kernels.push("mod")}if(!w.kernels.includes("floormod")){let e={kernelName:"FloorMod",backendName:A.getBackend(),kernelFunc:t=>A.tidy(()=>A.floorDiv(t.inputs.a/t.inputs.b)*t.inputs.b+A.mod(t.inputs.a,t.inputs.b))};A.registerKernel(e),w.kernels.push("floormod")}}async function Ht(e,t=!1){if(e.state="backend",t||w.initial||e.config.backend&&e.config.backend.length>0&&A.getBackend()!==e.config.backend){let o=b();if(e.config.backend&&e.config.backend.length>0){if(typeof window=="undefined"&&typeof WorkerGlobalScope!="undefined"&&e.config.debug&&e.config.debug&&u("running inside web worker"),w.browser&&e.config.backend==="tensorflow"&&(e.config.debug&&u("override: backend set to tensorflow while running in browser"),e.config.backend="humangl"),w.node&&(e.config.backend==="webgl"||e.config.backend==="humangl")&&(e.config.debug&&u(`override: backend set to ${e.config.backend} while running in nodejs`),e.config.backend="tensorflow"),w.browser&&e.config.backend==="webgpu")if(typeof navigator=="undefined"||typeof navigator.gpu=="undefined")u("override: backend set to webgpu but browser does not support webgpu"),e.config.backend="humangl";else{let r=await navigator.gpu.requestAdapter();e.config.debug&&u("enumerated webgpu adapter:",r)}e.config.backend==="humangl"&&await _o(e);let n=Object.keys(A.engine().registryFactory);if(e.config.debug&&u("available backends:",n),n.includes(e.config.backend)||(u(`error: backend ${e.config.backend} not found in registry`),e.config.backend=w.node?"tensorflow":"webgl",e.config.debug&&u(`override: setting backend ${e.config.backend}`)),e.config.debug&&u("setting backend:",e.config.backend),e.config.backend==="wasm"){if(e.config.debug&&u("wasm path:",e.config.wasmPath),typeof(A==null?void 0:A.setWasmPaths)!="undefined")await A.setWasmPaths(e.config.wasmPath,e.config.wasmPlatformFetch);else throw new Error("backend error: attempting to use wasm backend but wasm path is not set");let r=await A.env().getAsync("WASM_HAS_SIMD_SUPPORT"),s=await A.env().getAsync("WASM_HAS_MULTITHREAD_SUPPORT");e.config.debug&&u(`wasm execution: ${r?"SIMD":"no SIMD"} ${s?"multithreaded":"singlethreaded"}`),e.config.debug&&!r&&u("warning: wasm simd support is not enabled")}try{await A.setBackend(e.config.backend),await A.ready(),Z2()}catch(r){return u("error: cannot set backend:",e.config.backend,r),!1}}if(A.getBackend()==="humangl"&&(A.ENV.set("CHECK_COMPUTATION_FOR_ERRORS",!1),A.ENV.set("WEBGL_CPU_FORWARD",!0),A.ENV.set("WEBGL_USE_SHAPES_UNIFORMS",!0),A.ENV.set("CPU_HANDOFF_SIZE_THRESHOLD",256),typeof e.config.deallocate!="undefined"&&e.config.deallocate&&(u("changing webgl: WEBGL_DELETE_TEXTURE_THRESHOLD:",!0),A.ENV.set("WEBGL_DELETE_TEXTURE_THRESHOLD",0)),A.backend().getGPGPUContext)){let n=await A.backend().getGPGPUContext().gl;e.config.debug&&u(`gl version:${n.getParameter(n.VERSION)} renderer:${n.getParameter(n.RENDERER)}`)}A.getBackend(),A.enableProdMode(),await A.ready(),e.performance.initBackend=Math.trunc(b()-o),e.config.backend=A.getBackend(),await w.updateBackend(),Yr()}return!0}function jt(e,t){for(let o of e){let n={kernelName:o,backendName:t.backend,kernelFunc:()=>{t.debug&&u("kernelFunc",o,t.backend)}};A.registerKernel(n)}w.kernels=A.getKernelsForBackend(A.getBackend()).map(o=>o.kernelName.toLowerCase())}var tn={};ne(tn,{all:()=>p2,body:()=>We,canvas:()=>m2,face:()=>Ce,gesture:()=>Ie,hand:()=>Oe,object:()=>Le,options:()=>a0,person:()=>f2});var P0=e=>{if(!e)u("draw error: invalid canvas");else if(!e.getContext)u("draw error: canvas context not defined");else{let t=e.getContext("2d");if(!t)u("draw error: cannot get canvas context");else return t}return null},fe=e=>Math.round(e*180/Math.PI),D0=(e,t)=>{if(!t.useDepth||typeof e=="undefined")return t.color;let o=Uint8ClampedArray.from([127+2*e,127-2*e,255]);return`rgba(${o[0]}, ${o[1]}, ${o[2]}, ${t.alpha})`};function X0(e,t,o,n,r){e.fillStyle=D0(n,r),e.beginPath(),e.arc(t,o,r.pointSize,0,2*Math.PI),e.fill()}function W0(e,t,o,n,r,s){if(e.beginPath(),e.lineWidth=s.lineWidth,s.useCurves){let a=(t+t+n)/2,i=(o+o+r)/2;e.ellipse(a,i,n/2,r/2,0,0,2*Math.PI)}else e.moveTo(t+s.roundRect,o),e.lineTo(t+n-s.roundRect,o),e.quadraticCurveTo(t+n,o,t+n,o+s.roundRect),e.lineTo(t+n,o+r-s.roundRect),e.quadraticCurveTo(t+n,o+r,t+n-s.roundRect,o+r),e.lineTo(t+s.roundRect,o+r),e.quadraticCurveTo(t,o+r,t,o+r-s.roundRect),e.lineTo(t,o+s.roundRect),e.quadraticCurveTo(t,o,t+s.roundRect,o),e.closePath();e.stroke()}function x2(e,t,o){if(!(t.length<2)){e.beginPath(),e.moveTo(t[0][0],t[0][1]);for(let n of t)e.strokeStyle=D0(n[2],o),e.lineTo(Math.trunc(n[0]),Math.trunc(n[1]));e.stroke(),o.fillPolygons&&(e.closePath(),e.fill())}}function en(e,t,o){if(!(t.length<2)){if(e.lineWidth=o.lineWidth,!o.useCurves||t.length<=2){x2(e,t,o);return}e.moveTo(t[0][0],t[0][1]);for(let n=0;n0){let n=e.emotion.map(r=>`${Math.trunc(100*r.score)}% ${r.emotion}`);n.length>3&&(n.length=3),o.push(n.join(" "))}e.rotation&&e.rotation.angle&&e.rotation.gaze&&(e.rotation.angle.roll&&o.push(`roll: ${fe(e.rotation.angle.roll)}\xB0 yaw:${fe(e.rotation.angle.yaw)}\xB0 pitch:${fe(e.rotation.angle.pitch)}\xB0`),e.rotation.gaze.bearing&&o.push(`gaze: ${fe(e.rotation.gaze.bearing)}\xB0`)),o.length===0&&o.push("face"),t.fillStyle=G.color;for(let n=o.length-1;n>=0;n--){let r=Math.max(e.box[0],0),s=n*G.lineHeight+e.box[1];G.shadowColor&&G.shadowColor!==""&&(t.fillStyle=G.shadowColor,t.fillText(o[n],r+5,s+16)),t.fillStyle=G.labelColor,t.fillText(o[n],r+4,s+15)}}}function _r(e,t){if(e.annotations&&e.annotations.leftEyeIris&&e.annotations.leftEyeIris[0]){t.strokeStyle=G.useDepth?"rgba(255, 200, 255, 0.3)":G.color,t.beginPath();let o=Math.abs(e.annotations.leftEyeIris[3][0]-e.annotations.leftEyeIris[1][0])/2,n=Math.abs(e.annotations.leftEyeIris[4][1]-e.annotations.leftEyeIris[2][1])/2;t.ellipse(e.annotations.leftEyeIris[0][0],e.annotations.leftEyeIris[0][1],o,n,0,0,2*Math.PI),t.stroke(),G.fillPolygons&&(t.fillStyle=G.useDepth?"rgba(255, 255, 200, 0.3)":G.color,t.fill())}if(e.annotations&&e.annotations.rightEyeIris&&e.annotations.rightEyeIris[0]){t.strokeStyle=G.useDepth?"rgba(255, 200, 255, 0.3)":G.color,t.beginPath();let o=Math.abs(e.annotations.rightEyeIris[3][0]-e.annotations.rightEyeIris[1][0])/2,n=Math.abs(e.annotations.rightEyeIris[4][1]-e.annotations.rightEyeIris[2][1])/2;t.ellipse(e.annotations.rightEyeIris[0][0],e.annotations.rightEyeIris[0][1],o,n,0,0,2*Math.PI),t.stroke(),G.fillPolygons&&(t.fillStyle=G.useDepth?"rgba(255, 255, 200, 0.3)":G.color,t.fill())}}function $r(e,t){var o;if(G.drawGaze&&((o=e.rotation)==null?void 0:o.angle)&&typeof Path2D!="undefined"){t.strokeStyle="pink";let n=e.box[0]+e.box[2]/2-e.box[3]*fe(e.rotation.angle.yaw)/90,r=e.box[1]+e.box[3]/2+e.box[2]*fe(e.rotation.angle.pitch)/90,s=new Path2D(` +`;var Q2=(e,t,o)=>{let n=new RegExp("\\b"+t+" \\w+ (\\w+)","ig");e.replace(n,(r,s)=>(o[s]=0,r))},_2=class{constructor(t,o,n){w(this,"uniform",{});w(this,"attribute",{});w(this,"gl");w(this,"id");w(this,"compile",(t,o)=>{let n=this.gl.createShader(o);return n?(this.gl.shaderSource(n,t),this.gl.compileShader(n),this.gl.getShaderParameter(n,this.gl.COMPILE_STATUS)?n:(u(`filter: gl compile failed: ${this.gl.getShaderInfoLog(n)}`),null)):(u("filter: could not create shader"),null)});this.gl=t;let r=this.compile(o,this.gl.VERTEX_SHADER),s=this.compile(n,this.gl.FRAGMENT_SHADER);if(this.id=this.gl.createProgram(),!(!r||!s)){if(!this.id){u("filter: could not create webgl program");return}if(this.gl.attachShader(this.id,r),this.gl.attachShader(this.id,s),this.gl.linkProgram(this.id),!this.gl.getProgramParameter(this.id,this.gl.LINK_STATUS)){u(`filter: gl link failed: ${this.gl.getProgramInfoLog(this.id)}`);return}this.gl.useProgram(this.id),Q2(o,"attribute",this.attribute);for(let a in this.attribute)this.attribute[a]=this.gl.getAttribLocation(this.id,a);Q2(o,"uniform",this.uniform),Q2(n,"uniform",this.uniform);for(let a in this.uniform)this.uniform[a]=this.gl.getUniformLocation(this.id,a)}}};function F1(){let e=0,t=null,o=!1,n=-1,r=[null,null],s=[],a=null,i=null,l=l0(100,100),x={},d={INTERMEDIATE:1},y=l.getContext("webgl");if(!y){u("filter: cannot get webgl context");return}this.gl=y;function c(g,f){if(!(g===l.width&&f===l.height)){if(l.width=g,l.height=f,!a){let M=new Float32Array([-1,-1,0,1,1,-1,1,1,-1,1,0,0,-1,1,0,0,1,-1,1,1,1,1,1,0]);a=y.createBuffer(),y.bindBuffer(y.ARRAY_BUFFER,a),y.bufferData(y.ARRAY_BUFFER,M,y.STATIC_DRAW),y.pixelStorei(y.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!0)}y.viewport(0,0,l.width,l.height),r=[null,null]}}function m(g,f){let M=y.createFramebuffer();y.bindFramebuffer(y.FRAMEBUFFER,M);let j=y.createRenderbuffer();y.bindRenderbuffer(y.RENDERBUFFER,j);let k=y.createTexture();return y.bindTexture(y.TEXTURE_2D,k),y.texImage2D(y.TEXTURE_2D,0,y.RGBA,g,f,0,y.RGBA,y.UNSIGNED_BYTE,null),y.texParameteri(y.TEXTURE_2D,y.TEXTURE_MAG_FILTER,y.LINEAR),y.texParameteri(y.TEXTURE_2D,y.TEXTURE_MIN_FILTER,y.LINEAR),y.texParameteri(y.TEXTURE_2D,y.TEXTURE_WRAP_S,y.CLAMP_TO_EDGE),y.texParameteri(y.TEXTURE_2D,y.TEXTURE_WRAP_T,y.CLAMP_TO_EDGE),y.framebufferTexture2D(y.FRAMEBUFFER,y.COLOR_ATTACHMENT0,y.TEXTURE_2D,k,0),y.bindTexture(y.TEXTURE_2D,null),y.bindFramebuffer(y.FRAMEBUFFER,null),{fbo:M,texture:k}}function h(g){return r[g]=r[g]||m(l.width,l.height),r[g]}function p(g=0){if(!i)return;let f=null,M=null,j=!1;e===0?f=t:f=h(n).texture||null,e++,o&&!(g&d.INTERMEDIATE)?(M=null,j=e%2===0):(n=(n+1)%2,M=h(n).fbo||null),y.bindTexture(y.TEXTURE_2D,f),y.bindFramebuffer(y.FRAMEBUFFER,M),y.uniform1f(i.uniform.flipY,j?-1:1),y.drawArrays(y.TRIANGLES,0,6)}function R(g){if(x[g])return i=x[g],y.useProgram((i?i.id:null)||null),i;if(i=new _2(y,C1,g),!i)return u("filter: could not get webgl program"),null;let f=Float32Array.BYTES_PER_ELEMENT,M=4*f;return y.enableVertexAttribArray(i.attribute.pos),y.vertexAttribPointer(i.attribute.pos,2,y.FLOAT,!1,M,0*f),y.enableVertexAttribArray(i.attribute.uv),y.vertexAttribPointer(i.attribute.uv,2,y.FLOAT,!1,M,2*f),x[g]=i,i}let P={colorMatrix:g=>{let f=new Float32Array(g);f[4]/=255,f[9]/=255,f[14]/=255,f[19]/=255;let M=f[18]===1&&f[3]===0&&f[8]===0&&f[13]===0&&f[15]===0&&f[16]===0&&f[17]===0&&f[19]===0?N1:I1,j=R(M);!j||(y.uniform1fv(j.uniform.m,f),p())},brightness:g=>{let f=(g||0)+1;P.colorMatrix([f,0,0,0,0,0,f,0,0,0,0,0,f,0,0,0,0,0,1,0])},saturation:g=>{let f=(g||0)*2/3+1,M=(f-1)*-.5;P.colorMatrix([f,M,M,0,0,M,f,M,0,0,M,M,f,0,0,0,0,0,1,0])},desaturate:()=>{P.saturation(-1)},contrast:g=>{let f=(g||0)+1,M=-128*(f-1);P.colorMatrix([f,0,0,0,M,0,f,0,0,M,0,0,f,0,M,0,0,0,1,0])},negative:()=>{P.contrast(-2)},hue:g=>{g=(g||0)/180*Math.PI;let f=Math.cos(g),M=Math.sin(g),j=.213,k=.715,I=.072;P.colorMatrix([j+f*(1-j)+M*-j,k+f*-k+M*-k,I+f*-I+M*(1-I),0,0,j+f*-j+M*.143,k+f*(1-k)+M*.14,I+f*-I+M*-.283,0,0,j+f*-j+M*-(1-j),k+f*-k+M*k,I+f*(1-I)+M*I,0,0,0,0,0,1,0])},desaturateLuminance:()=>{P.colorMatrix([.2764723,.929708,.0938197,0,-37.1,.2764723,.929708,.0938197,0,-37.1,.2764723,.929708,.0938197,0,-37.1,0,0,0,1,0])},sepia:()=>{P.colorMatrix([.393,.7689999,.18899999,0,0,.349,.6859999,.16799999,0,0,.272,.5339999,.13099999,0,0,0,0,0,1,0])},brownie:()=>{P.colorMatrix([.5997023498159715,.34553243048391263,-.2708298674538042,0,47.43192855600873,-.037703249837783157,.8609577587992641,.15059552388459913,0,-36.96841498319127,.24113635128153335,-.07441037908422492,.44972182064877153,0,-7.562075277591283,0,0,0,1,0])},vintagePinhole:()=>{P.colorMatrix([.6279345635605994,.3202183420819367,-.03965408211312453,0,9.651285835294123,.02578397704808868,.6441188644374771,.03259127616149294,0,7.462829176470591,.0466055556782719,-.0851232987247891,.5241648018700465,0,5.159190588235296,0,0,0,1,0])},kodachrome:()=>{P.colorMatrix([1.1285582396593525,-.3967382283601348,-.03992559172921793,0,63.72958762196502,-.16404339962244616,1.0835251566291304,-.05498805115633132,0,24.732407896706203,-.16786010706155763,-.5603416277695248,1.6014850761964943,0,35.62982807460946,0,0,0,1,0])},technicolor:()=>{P.colorMatrix([1.9125277891456083,-.8545344976951645,-.09155508482755585,0,11.793603434377337,-.3087833385928097,1.7658908555458428,-.10601743074722245,0,-70.35205161461398,-.231103377548616,-.7501899197440212,1.847597816108189,0,30.950940869491138,0,0,0,1,0])},polaroid:()=>{P.colorMatrix([1.438,-.062,-.062,0,0,-.122,1.378,-.122,0,0,-.016,-.016,1.483,0,0,0,0,0,1,0])},shiftToBGR:()=>{P.colorMatrix([0,0,1,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,1,0])},convolution:g=>{let f=new Float32Array(g),M=1/l.width,j=1/l.height,k=R(L1);!k||(y.uniform1fv(k.uniform.m,f),y.uniform2f(k.uniform.px,M,j),p())},detectEdges:()=>{P.convolution.call(this,[0,1,0,1,-4,1,0,1,0])},sobelX:()=>{P.convolution.call(this,[-1,0,1,-2,0,2,-1,0,1])},sobelY:()=>{P.convolution.call(this,[-1,-2,-1,0,0,0,1,2,1])},sharpen:g=>{let f=g||1;P.convolution.call(this,[0,-1*f,0,-1*f,1+4*f,-1*f,0,-1*f,0])},emboss:g=>{let f=g||1;P.convolution.call(this,[-2*f,-1*f,0,-1*f,1,1*f,0,1*f,2*f])},blur:g=>{let f=g/7/l.width,M=g/7/l.height,j=R(W1);!j||(y.uniform2f(j.uniform.px,0,M),p(d.INTERMEDIATE),y.uniform2f(j.uniform.px,f,0),p())},pixelate:g=>{let f=g/l.width,M=g/l.height,j=R(O1);!j||(y.uniform2f(j.uniform.size,f,M),p())}};this.add=function(g){let f=Array.prototype.slice.call(arguments,1),M=P[g];s.push({func:M,args:f})},this.reset=function(){s=[]},this.get=function(){return s},this.apply=function(g){c(g.width,g.height),e=0,t||(t=y.createTexture()),y.bindTexture(y.TEXTURE_2D,t),y.texParameteri(y.TEXTURE_2D,y.TEXTURE_WRAP_S,y.CLAMP_TO_EDGE),y.texParameteri(y.TEXTURE_2D,y.TEXTURE_WRAP_T,y.CLAMP_TO_EDGE),y.texParameteri(y.TEXTURE_2D,y.TEXTURE_MIN_FILTER,y.NEAREST),y.texParameteri(y.TEXTURE_2D,y.TEXTURE_MAG_FILTER,y.NEAREST),y.texImage2D(y.TEXTURE_2D,0,y.RGBA,y.RGBA,y.UNSIGNED_BYTE,g);for(let f=0;fm.data())),a=.99*Math.max(s[0][0],s[1][0],s[2][0]),i=[A.sub(o[0],n[0]),A.sub(o[1],n[1]),A.sub(o[2],n[2])],l=[A.sub(r[0],n[0]),A.sub(r[1],n[1]),A.sub(r[2],n[2])],x=[A.div(a,l[0]),A.div(a,l[1]),A.div(a,l[2])],d=[A.mul(i[0],x[0]),A.mul(i[1],x[1]),A.mul(i[2],x[2])],y=A.stack([d[0],d[1],d[2]],2),c=A.reshape(y,[1,t.shape[0],t.shape[1],3]);return A.dispose([...o,...n,...r,...i,...l,...x,...d,y,t]),c}var a2=3840,G=null,$=null,be=null,U,O0={inputSum:0,cacheDiff:1,sumMethod:0,inputTensor:void 0};function l0(e,t){let o;if(v.browser)if(v.worker){if(typeof OffscreenCanvas=="undefined")throw new Error("canvas error: attempted to run in web worker but OffscreenCanvas is not supported");o=new OffscreenCanvas(e,t)}else{if(typeof document=="undefined")throw new Error("canvas error: attempted to run in browser but DOM is not defined");o=document.createElement("canvas"),o.width=e,o.height=t}else typeof v.Canvas!="undefined"?o=new v.Canvas(e,t):typeof globalThis.Canvas!="undefined"&&(o=new globalThis.Canvas(e,t));return o}function i2(e,t){let o=t||l0(e.width,e.height);return o.getContext("2d").drawImage(e,0,0),o}async function ge(e,t,o=!0){if(!e)return t.debug&&u("input error: input is missing"),{tensor:null,canvas:null};if(!(e instanceof he)&&!(typeof Image!="undefined"&&e instanceof Image)&&!(typeof v.Canvas!="undefined"&&e instanceof v.Canvas)&&!(typeof globalThis.Canvas!="undefined"&&e instanceof globalThis.Canvas)&&!(typeof ImageData!="undefined"&&e instanceof ImageData)&&!(typeof ImageBitmap!="undefined"&&e instanceof ImageBitmap)&&!(typeof HTMLImageElement!="undefined"&&e instanceof HTMLImageElement)&&!(typeof HTMLMediaElement!="undefined"&&e instanceof HTMLMediaElement)&&!(typeof HTMLVideoElement!="undefined"&&e instanceof HTMLVideoElement)&&!(typeof HTMLCanvasElement!="undefined"&&e instanceof HTMLCanvasElement)&&!(typeof OffscreenCanvas!="undefined"&&e instanceof OffscreenCanvas))throw new Error("input error: type is not recognized");if(e instanceof he){let n=null;if(e.isDisposedInternal)throw new Error("input error: attempted to use tensor but it is disposed");if(!e.shape)throw new Error("input error: attempted to use tensor without a shape");if(e.shape.length===3){if(e.shape[2]===3)n=A.expandDims(e,0);else if(e.shape[2]===4){let r=A.slice3d(e,[0,0,0],[-1,-1,3]);n=A.expandDims(r,0),A.dispose(r)}}else e.shape.length===4&&(e.shape[3]===3?n=A.clone(e):e.shape[3]===4&&(n=A.slice4d(e,[0,0,0,0],[-1,-1,-1,3])));if(n==null||n.shape.length!==4||n.shape[0]!==1||n.shape[3]!==3)throw new Error(`input error: attempted to use tensor with unrecognized shape: ${e.shape}`);if(n.dtype==="int32"){let r=A.cast(n,"float32");A.dispose(n),n=r}return{tensor:n,canvas:t.filter.return?$:null}}else{if(typeof e.readyState!="undefined"&&e.readyState<=2)return t.debug&&u("input stream is not ready"),{tensor:null,canvas:G};let n=e.naturalWidth||e.videoWidth||e.width||e.shape&&e.shape[1]>0,r=e.naturalHeight||e.videoHeight||e.height||e.shape&&e.shape[2]>0;if(!n||!r)return t.debug&&u("cannot determine input dimensions"),{tensor:null,canvas:G};let s=n,a=r;if(s>a2&&(s=a2,a=Math.trunc(s*r/n)),a>a2&&(a=a2,s=Math.trunc(a*n/r)),(t.filter.width||0)>0?s=t.filter.width:(t.filter.height||0)>0&&(s=n*((t.filter.height||0)/r)),(t.filter.height||0)>0?a=t.filter.height:(t.filter.width||0)>0&&(a=r*((t.filter.width||0)/n)),!s||!a)throw new Error("input error: cannot determine dimension");(!G||(G==null?void 0:G.width)!==s||(G==null?void 0:G.height)!==a)&&(G=l0(s,a));let i=G.getContext("2d");if(typeof ImageData!="undefined"&&e instanceof ImageData?i.putImageData(e,0,0):t.filter.flip&&typeof i.translate!="undefined"?(i.translate(n,0),i.scale(-1,1),i.drawImage(e,0,0,n,r,0,0,G==null?void 0:G.width,G==null?void 0:G.height),i.setTransform(1,0,0,1,0,0)):i.drawImage(e,0,0,n,r,0,0,G==null?void 0:G.width,G==null?void 0:G.height),(!$||G.width!==$.width||(G==null?void 0:G.height)!==($==null?void 0:$.height))&&($=l0(G.width,G.height)),t.filter.enabled&&v.webgl.supported?(U||(U=v.browser?new F1:null),v.filter=!!U,!U||!U.add?(t.debug&&u("input process error: cannot initialize filters"),v.webgl.supported=!1,t.filter.enabled=!1,i2(G,$)):(U.reset(),t.filter.brightness!==0&&U.add("brightness",t.filter.brightness),t.filter.contrast!==0&&U.add("contrast",t.filter.contrast),t.filter.sharpness!==0&&U.add("sharpen",t.filter.sharpness),t.filter.blur!==0&&U.add("blur",t.filter.blur),t.filter.saturation!==0&&U.add("saturation",t.filter.saturation),t.filter.hue!==0&&U.add("hue",t.filter.hue),t.filter.negative&&U.add("negative"),t.filter.sepia&&U.add("sepia"),t.filter.vintage&&U.add("brownie"),t.filter.sepia&&U.add("sepia"),t.filter.kodachrome&&U.add("kodachrome"),t.filter.technicolor&&U.add("technicolor"),t.filter.polaroid&&U.add("polaroid"),t.filter.pixelate!==0&&U.add("pixelate",t.filter.pixelate),U.get()>0?$=U.apply(G):$=U.draw(G))):(i2(G,$),U&&(U=null),v.filter=!!U),!o)return{tensor:null,canvas:$};if(!$)throw new Error("canvas error: cannot create output");let l,x=3;if(typeof ImageData!="undefined"&&e instanceof ImageData||e.data&&e.width&&e.height)if(v.browser&&A.browser)l=A.browser?A.browser.fromPixels(e):null;else{x=e.data.length/e.height/e.width;let c=new Uint8Array(e.data.buffer);l=A.tensor(c,[e.height,e.width,x],"int32")}else if((!be||$.width!==be.width||$.height!==be.height)&&(be=l0($.width,$.height)),A.browser&&v.browser)t.backend==="webgl"||t.backend==="humangl"||t.backend==="webgpu"?l=A.browser.fromPixels($):(be=i2($),l=A.browser.fromPixels(be));else{let h=i2($).getContext("2d").getImageData(0,0,s,a);x=h.data.length/s/a;let p=new Uint8Array(h.data.buffer);l=A.tensor(p,[s,a,x])}if(x===4){let c=A.slice3d(l,[0,0,0],[-1,-1,3]);A.dispose(l),l=c}if(!l)throw new Error("input error: cannot create tensor");let d=A.cast(l,"float32"),y=t.filter.equalization?await s2(d):A.expandDims(d,0);return A.dispose([l,d]),{tensor:y,canvas:t.filter.return?$:null}}}async function G1(e,t){let o=!1;if(e.cacheSensitivity===0||!t.shape||t.shape.length!==4||t.shape[1]>2048||t.shape[2]>2048)return o;if(!O0.inputTensor)O0.inputTensor=A.clone(t);else if(O0.inputTensor.shape[1]!==t.shape[1]||O0.inputTensor.shape[2]!==t.shape[2])A.dispose(O0.inputTensor),O0.inputTensor=A.clone(t);else{let n={};n.diff=A.sub(t,O0.inputTensor),n.squared=A.mul(n.diff,n.diff),n.sum=A.sum(n.squared);let s=(await n.sum.data())[0]/(t.shape[1]||1)/(t.shape[2]||1)/255/3;A.dispose([O0.inputTensor,n.diff,n.squared,n.sum]),O0.inputTensor=A.clone(t),o=s<=(e.cacheSensitivity||0)}return o}async function B1(e,t,o){let n={};if(!t||!o||t.shape.length!==4||t.shape.length!==o.shape.length)return e.debug||u("invalid input tensor or tensor shapes do not match:",t.shape,o.shape),0;if(t.shape[0]!==1||o.shape[0]!==1||t.shape[3]!==3||o.shape[3]!==3)return e.debug||u("input tensors must be of shape [1, height, width, 3]:",t.shape,o.shape),0;n.input1=A.clone(t),n.input2=t.shape[1]!==o.shape[1]||t.shape[2]!==o.shape[2]?A.image.resizeBilinear(o,[t.shape[1],t.shape[2]]):A.clone(o),n.diff=A.sub(n.input1,n.input2),n.squared=A.mul(n.diff,n.diff),n.sum=A.sum(n.squared);let s=(await n.sum.data())[0]/(t.shape[1]||1)/(t.shape[2]||1)/255/3;return A.dispose([n.input1,n.input2,n.diff,n.squared,n.sum]),s}var $2=class{constructor(){w(this,"browser");w(this,"node");w(this,"worker");w(this,"platform","");w(this,"agent","");w(this,"backends",[]);w(this,"initial");w(this,"filter");w(this,"tfjs");w(this,"offscreen");w(this,"perfadd",!1);w(this,"wasm",{supported:void 0,backend:void 0,simd:void 0,multithread:void 0});w(this,"webgl",{supported:void 0,backend:void 0,version:void 0,renderer:void 0});w(this,"webgpu",{supported:void 0,backend:void 0,adapter:void 0});w(this,"cpu",{model:void 0,flags:[]});w(this,"kernels",[]);w(this,"Canvas");w(this,"Image");w(this,"ImageData");if(this.browser=typeof navigator!="undefined",this.node=typeof process!="undefined"&&typeof process.versions!="undefined"&&typeof process.versions.node!="undefined",this.tfjs={version:qe["tfjs-core"]},this.offscreen=typeof OffscreenCanvas!="undefined",this.initial=!0,this.worker=this.browser&&this.offscreen?typeof WorkerGlobalScope!="undefined":void 0,typeof navigator!="undefined"){let t=navigator.userAgent.match(/\(([^()]+)\)/g);if(t&&t[0]){let o=t[0].match(/\(([^()]+)\)/g);this.platform=o&&o[0]?o[0].replace(/\(|\)/g,""):"",this.agent=navigator.userAgent.replace(t[0],""),this.platform[1]&&(this.agent=this.agent.replace(t[1],"")),this.agent=this.agent.replace(/ /g," ")}}else typeof process!="undefined"&&(this.platform=`${process.platform} ${process.arch}`,this.agent=`NodeJS ${process.version}`)}async updateBackend(){this.backends=Object.keys(A.engine().registryFactory),this.wasm.supported=typeof WebAssembly!="undefined",this.wasm.backend=this.backends.includes("wasm"),this.wasm.supported&&this.wasm.backend&&A.getBackend()==="wasm"&&(this.wasm.simd=await A.env().getAsync("WASM_HAS_SIMD_SUPPORT"),this.wasm.multithread=await A.env().getAsync("WASM_HAS_MULTITHREAD_SUPPORT"));let t=l0(100,100),o=t?t.getContext("webgl2"):void 0;if(this.webgl.supported=typeof o!="undefined",this.webgl.backend=this.backends.includes("webgl"),this.webgl.supported&&this.webgl.backend&&(A.getBackend()==="webgl"||A.getBackend()==="humangl")){let n=A.backend().gpgpu!=="undefined"?await A.backend().getGPGPUContext().gl:null;n&&(this.webgl.version=n.getParameter(n.VERSION),this.webgl.renderer=n.getParameter(n.RENDERER))}this.webgpu.supported=this.browser&&typeof navigator.gpu!="undefined",this.webgpu.backend=this.backends.includes("webgpu");try{this.webgpu.supported&&(this.webgpu.adapter=(await navigator.gpu.requestAdapter()).name)}catch(n){this.webgpu.supported=!1}try{this.kernels=A.getKernelsForBackend(A.getBackend()).map(n=>n.kernelName.toLowerCase())}catch(n){}}async updateCPU(){let t={model:"",flags:[]};this.node&&this.platform.startsWith("linux"),this.cpu?this.cpu=t:Object.defineProperty(this,"cpu",{value:t})}},v=new $2;var W0={cacheModels:!1,verbose:!0,debug:!1,modelBasePath:""};async function Co(e,t){return W0.debug&&u("load model fetch:",e,t),fetch(e,t)}function H1(e){W0.cacheModels=e.cacheModels,W0.verbose=e.debug,W0.modelBasePath=e.modelBasePath}async function W(e){let t=j1(W0.modelBasePath,e||"");t.toLowerCase().endsWith(".json")||(t+=".json");let o=t.split("/"),n="indexeddb://"+o[o.length-1].replace(".json",""),r=await A.io.listModels(),s=W0.cacheModels&&Object.keys(r).includes(n),a=typeof fetch=="undefined"?{}:{fetchFunc:(x,d)=>Co(x,d)},i=new J2(s?n:t,a),l=!1;try{i.findIOHandler(),W0.debug&&u("model load handler:",i.handler);let x=await i.handler.load();i.loadSync(x),W0.verbose&&u("load model:",i.modelUrl),l=!0}catch(x){u("error loading model:",t,x)}if(l&&W0.cacheModels&&!s)try{let x=await i.save(n);u("model saved:",n,x)}catch(x){u("error saving model:",t,x)}return i}var e5="2.8.0";var d1={};ne(d1,{Models:()=>o2,load:()=>x1,reset:()=>Z2,validate:()=>c1});var M0,t5=[],Oo=["white","black","asian","indian","other"],Wo=[15,23,28,35.5,45.5,55.5,65],V1=0,Z1=0,o5=Number.MAX_SAFE_INTEGER;async function D1(e){return v.initial&&(M0=null),M0?e.debug&&u("cached model:",M0.modelUrl):M0=await W(e.face.gear),M0}async function n5(e,t,o,n){var a,i;if(!M0)return{age:0,gender:"unknown",genderScore:0,race:[]};let r=o5<(((a=t.face.gear)==null?void 0:a.skipFrames)||0),s=(((i=t.face.gear)==null?void 0:i.skipTime)||0)>b()-Z1;return t.skipAllowed&&s&&r&&V1===n&&t5[o]?(o5++,t5[o]):(o5=0,new Promise(async l=>{var P,g;if(!(M0!=null&&M0.inputs[0].shape))return;let x={},d=[[0,.1,.9,.9]];x.resize=A.image.cropAndResize(e,d,[0],[M0.inputs[0].shape[2],M0.inputs[0].shape[1]]);let y={age:0,gender:"unknown",genderScore:0,race:[]};(P=t.face.gear)!=null&&P.enabled&&([x.age,x.gender,x.race]=M0.execute(x.resize,["age_output","gender_output","race_output"]));let c=await x.gender.data();y.gender=c[0]>c[1]?"male":"female",y.genderScore=Math.round(100*(c[0]>c[1]?c[0]:c[1]))/100;let m=await x.race.data();for(let f=0;f(((g=t.face.gear)==null?void 0:g.minConfidence)||.2)&&y.race.push({score:Math.round(100*m[f])/100,race:Oo[f]});y.race.sort((f,M)=>M.score-f.score);let p=Array.from(await x.age.data()).map((f,M)=>[Wo[M],f]).sort((f,M)=>M[1]-f[1]),R=p[0][0];for(let f=1;fA.dispose(x[f])),t5[o]=y,V1=n,Z1=b(),l(y)}))}var L={tf255:255,tf1:1,tf2:2,tf05:.5,tf127:127.5,rgb:[.2989,.587,.114]};function q1(){L.tf255=A.scalar(255,"float32"),L.tf1=A.scalar(1,"float32"),L.tf2=A.scalar(2,"float32"),L.tf05=A.scalar(.5,"float32"),L.tf127=A.scalar(127.5,"float32"),L.rgb=A.tensor1d([.2989,.587,.114],"float32")}var c0,l2=[],U1=0,Y1=0,r5=Number.MAX_SAFE_INTEGER;async function K1(e){return v.initial&&(c0=null),c0?e.debug&&u("cached model:",c0.modelUrl):c0=await W(e.face.ssrnet.modelPathAge),c0}async function A5(e,t,o,n){var a,i,l,x;if(!c0)return{age:0};let r=r5<(((a=t.face.ssrnet)==null?void 0:a.skipFrames)||0),s=(((i=t.face.ssrnet)==null?void 0:i.skipTime)||0)>b()-Y1;return t.skipAllowed&&r&&s&&U1===n&&((l=l2[o])==null?void 0:l.age)&&((x=l2[o])==null?void 0:x.age)>0?(r5++,l2[o]):(r5=0,new Promise(async d=>{if(!(c0!=null&&c0.inputs)||!c0.inputs[0]||!c0.inputs[0].shape)return;let y={};y.resize=A.image.resizeBilinear(e,[c0.inputs[0].shape[2],c0.inputs[0].shape[1]],!1),y.enhance=A.mul(y.resize,L.tf255);let c={age:0};if(t.face.ssrnet.enabled&&(y.age=c0.execute(y.enhance)),y.age){let m=await y.age.data();c.age=Math.trunc(10*m[0])/10}Object.keys(y).forEach(m=>A.dispose(y[m])),l2[o]=c,U1=n,Y1=b(),d(c)}))}var R0,y2=[],Q1=0,_1=0,s5=Number.MAX_SAFE_INTEGER,a5=[.2989,.587,.114];async function $1(e){return v.initial&&(R0=null),R0?e.debug&&u("cached model:",R0.modelUrl):R0=await W(e.face.ssrnet.modelPathGender),R0}async function i5(e,t,o,n){var a,i,l,x;if(!R0)return{gender:"unknown",genderScore:0};let r=s5<(((a=t.face.ssrnet)==null?void 0:a.skipFrames)||0),s=(((i=t.face.ssrnet)==null?void 0:i.skipTime)||0)>b()-_1;return t.skipAllowed&&r&&s&&Q1===n&&((l=y2[o])==null?void 0:l.gender)&&((x=y2[o])==null?void 0:x.genderScore)>0?(s5++,y2[o]):(s5=0,new Promise(async d=>{if(!(R0!=null&&R0.inputs[0].shape))return;let y={};y.resize=A.image.resizeBilinear(e,[R0.inputs[0].shape[2],R0.inputs[0].shape[1]],!1),y.enhance=A.tidy(()=>{let[h,p,R]=A.split(y.resize,3,3),P=A.mul(h,a5[0]),g=A.mul(p,a5[1]),f=A.mul(R,a5[2]),M=A.addN([P,g,f]);return A.mul(A.sub(M,L.tf05),2)});let c={gender:"unknown",genderScore:0};t.face.ssrnet.enabled&&(y.gender=R0.execute(y.enhance));let m=await y.gender.data();c.gender=m[0]>m[1]?"female":"male",c.genderScore=m[0]>m[1]?Math.trunc(100*m[0])/100:Math.trunc(100*m[1])/100,Object.keys(y).forEach(h=>A.dispose(y[h])),y2[o]=c,Q1=n,_1=b(),d(c)}))}var r0,x2=[],l5=Number.MAX_SAFE_INTEGER,tt=0,ot=0;async function nt(e){var t;return v.initial&&(r0=null),r0?e.debug&&u("cached model:",r0.modelUrl):r0=await W((t=e.face.antispoof)==null?void 0:t.modelPath),r0}async function y5(e,t,o,n){var a,i;if(!r0)return 0;let r=(((a=t.face.antispoof)==null?void 0:a.skipTime)||0)>b()-ot,s=l5<(((i=t.face.antispoof)==null?void 0:i.skipFrames)||0);return t.skipAllowed&&r&&s&&tt===n&&x2[o]?(l5++,x2[o]):(l5=0,new Promise(async l=>{let x=A.image.resizeBilinear(e,[r0!=null&&r0.inputs[0].shape?r0.inputs[0].shape[2]:0,r0!=null&&r0.inputs[0].shape?r0.inputs[0].shape[1]:0],!1),d=r0==null?void 0:r0.execute(x),y=(await d.data())[0];x2[o]=Math.round(100*y)/100,tt=n,ot=b(),A.dispose([x,d]),l(x2[o])}))}var T0={silhouette:[10,338,297,332,284,251,389,356,454,323,361,288,397,365,379,378,400,377,152,148,176,149,150,136,172,58,132,93,234,127,162,21,54,103,67,109],lipsUpperOuter:[185,40,39,37,0,267,269,270,409],lipsLowerOuter:[61,146,91,181,84,17,314,405,321,375,291],lipsUpperInner:[191,80,81,82,13,312,311,310,415],lipsLowerInner:[78,95,88,178,87,14,317,402,318,324,308],lipsLowerSemiOuter:[76,77,90,180,85,16,315,404,320,307,306],lipsUpperSemiOuter:[184,74,73,72,11,302,303,304,408],lipsLowerSemiInner:[62,96,89,179,86,15,316,403,319,325,292],lipsUpperSemiInner:[183,42,41,38,12,268,271,272,407],rightEyeUpper0:[246,161,160,159,158,157,173],rightEyeLower0:[33,7,163,144,145,153,154,155,133],rightEyeUpper1:[247,30,29,27,28,56,190],rightEyeLower1:[130,25,110,24,23,22,26,112,243],rightEyeUpper2:[113,225,224,223,222,221,189],rightEyeLower2:[226,31,228,229,230,231,232,233,244],rightEyeLower3:[143,111,117,118,119,120,121,128,245],rightEyebrowUpper:[156,70,63,105,66,107,55,193],rightEyebrowLower:[35,124,46,53,52,65],rightEyeIris:[473,474,475,476,477],leftEyeUpper0:[466,388,387,386,385,384,398],leftEyeLower0:[263,249,390,373,374,380,381,382,362],leftEyeUpper1:[467,260,259,257,258,286,414],leftEyeLower1:[359,255,339,254,253,252,256,341,463],leftEyeUpper2:[342,445,444,443,442,441,413],leftEyeLower2:[446,261,448,449,450,451,452,453,464],leftEyeLower3:[372,340,346,347,348,349,350,357,465],leftEyebrowUpper:[383,300,293,334,296,336,285,417],leftEyebrowLower:[265,353,276,283,282,295],leftEyeIris:[468,469,470,471,472],midwayBetweenEyes:[168],noseTip:[1],noseBottom:[2],noseRightCorner:[98],noseLeftCorner:[327],rightCheek:[205],leftCheek:[425]},x5={count:468,mouth:13,symmetryLine:[13,T0.midwayBetweenEyes[0]]},Ae={leftEye:0,rightEye:1,nose:2,mouth:3,leftEar:4,rightEar:5,symmetryLine:[3,2]},c5=[{key:"EyeUpper0",indices:[9,10,11,12,13,14,15]},{key:"EyeUpper1",indices:[25,26,27,28,29,30,31]},{key:"EyeUpper2",indices:[41,42,43,44,45,46,47]},{key:"EyeLower0",indices:[0,1,2,3,4,5,6,7,8]},{key:"EyeLower1",indices:[16,17,18,19,20,21,22,23,24]},{key:"EyeLower2",indices:[32,33,34,35,36,37,38,39,40]},{key:"EyeLower3",indices:[54,55,56,57,58,59,60,61,62]},{key:"EyebrowUpper",indices:[63,64,65,66,67,68,69,70]},{key:"EyebrowLower",indices:[48,49,50,51,52,53]}],Ye=[[.499976992607117,.652534008026123],[.500025987625122,.547487020492554],[.499974012374878,.602371990680695],[.482113003730774,.471979022026062],[.500150978565216,.527155995368958],[.499909996986389,.498252987861633],[.499523013830185,.40106201171875],[.289712011814117,.380764007568359],[.499954998493195,.312398016452789],[.499987006187439,.269918978214264],[.500023007392883,.107050001621246],[.500023007392883,.666234016418457],[.5000159740448,.679224014282227],[.500023007392883,.692348003387451],[.499976992607117,.695277988910675],[.499976992607117,.70593398809433],[.499976992607117,.719385027885437],[.499976992607117,.737019002437592],[.499967992305756,.781370997428894],[.499816000461578,.562981009483337],[.473773002624512,.573909997940063],[.104906998574734,.254140973091125],[.365929991006851,.409575998783112],[.338757991790771,.41302502155304],[.311120003461838,.409460008144379],[.274657994508743,.389131009578705],[.393361985683441,.403706014156342],[.345234006643295,.344011008739471],[.370094001293182,.346076011657715],[.319321990013123,.347265005111694],[.297903001308441,.353591024875641],[.24779200553894,.410809993743896],[.396889001131058,.842755019664764],[.280097991228104,.375599980354309],[.106310002505779,.399955987930298],[.2099249958992,.391353011131287],[.355807989835739,.534406006336212],[.471751004457474,.65040397644043],[.474155008792877,.680191993713379],[.439785003662109,.657229006290436],[.414617002010345,.66654098033905],[.450374007225037,.680860996246338],[.428770989179611,.682690978050232],[.374971002340317,.727805018424988],[.486716985702515,.547628998756409],[.485300987958908,.527395009994507],[.257764995098114,.314490020275116],[.401223003864288,.455172002315521],[.429818987846375,.548614978790283],[.421351999044418,.533740997314453],[.276895999908447,.532056987285614],[.483370006084442,.499586999416351],[.33721199631691,.282882988452911],[.296391993761063,.293242990970612],[.169294998049736,.193813979625702],[.447580009698868,.302609980106354],[.392390012741089,.353887975215912],[.354490011930466,.696784019470215],[.067304998636246,.730105042457581],[.442739009857178,.572826027870178],[.457098007202148,.584792017936707],[.381974011659622,.694710969924927],[.392388999462128,.694203019142151],[.277076005935669,.271932005882263],[.422551989555359,.563233017921448],[.385919004678726,.281364023685455],[.383103013038635,.255840003490448],[.331431001424789,.119714021682739],[.229923993349075,.232002973556519],[.364500999450684,.189113974571228],[.229622006416321,.299540996551514],[.173287004232407,.278747975826263],[.472878992557526,.666198015213013],[.446828007698059,.668527007102966],[.422762006521225,.673889994621277],[.445307999849319,.580065965652466],[.388103008270264,.693961024284363],[.403039008378983,.706539988517761],[.403629004955292,.693953037261963],[.460041999816895,.557139039039612],[.431158006191254,.692366003990173],[.452181994915009,.692366003990173],[.475387006998062,.692366003990173],[.465828001499176,.779190003871918],[.472328990697861,.736225962638855],[.473087012767792,.717857003211975],[.473122000694275,.704625964164734],[.473033010959625,.695277988910675],[.427942007780075,.695277988910675],[.426479011774063,.703539967536926],[.423162013292313,.711845993995667],[.4183090031147,.720062971115112],[.390094995498657,.639572978019714],[.013953999616206,.560034036636353],[.499913990497589,.58014702796936],[.413199990987778,.69539999961853],[.409626007080078,.701822996139526],[.468080013990402,.601534962654114],[.422728985548019,.585985004901886],[.463079988956451,.593783974647522],[.37211999297142,.47341400384903],[.334562003612518,.496073007583618],[.411671012639999,.546965003013611],[.242175996303558,.14767599105835],[.290776997804642,.201445996761322],[.327338010072708,.256527006626129],[.399509996175766,.748921036720276],[.441727995872498,.261676013469696],[.429764986038208,.187834024429321],[.412198007106781,.108901023864746],[.288955003023148,.398952007293701],[.218936994671822,.435410976409912],[.41278201341629,.398970007896423],[.257135003805161,.355440020561218],[.427684992551804,.437960982322693],[.448339998722076,.536936044692993],[.178560003638268,.45755398273468],[.247308000922203,.457193970680237],[.286267012357712,.467674970626831],[.332827985286713,.460712015628815],[.368755996227264,.447206974029541],[.398963987827301,.432654976844788],[.476410001516342,.405806005001068],[.189241006970406,.523923993110657],[.228962004184723,.348950982093811],[.490725994110107,.562400996685028],[.404670000076294,.485132992267609],[.019469000399113,.401564002037048],[.426243007183075,.420431017875671],[.396993011236191,.548797011375427],[.266469985246658,.376977026462555],[.439121007919312,.51895797252655],[.032313998788595,.644356966018677],[.419054001569748,.387154996395111],[.462783008813858,.505746960639954],[.238978996872902,.779744982719421],[.198220998048782,.831938028335571],[.107550002634525,.540755033493042],[.183610007166862,.740257024765015],[.134409993886948,.333683013916016],[.385764002799988,.883153975009918],[.490967005491257,.579378008842468],[.382384985685349,.508572995662689],[.174399003386497,.397670984268188],[.318785011768341,.39623498916626],[.343364000320435,.400596976280212],[.396100014448166,.710216999053955],[.187885001301765,.588537991046906],[.430987000465393,.944064974784851],[.318993002176285,.898285031318665],[.266247987747192,.869701027870178],[.500023007392883,.190576016902924],[.499976992607117,.954452991485596],[.366169989109039,.398822009563446],[.393207013607025,.39553701877594],[.410373002290726,.391080021858215],[.194993004202843,.342101991176605],[.388664990663528,.362284004688263],[.365961998701096,.355970978736877],[.343364000320435,.355356991291046],[.318785011768341,.35834002494812],[.301414996385574,.363156020641327],[.058132998645306,.319076001644135],[.301414996385574,.387449026107788],[.499987989664078,.618434011936188],[.415838003158569,.624195992946625],[.445681989192963,.566076993942261],[.465844005346298,.620640993118286],[.49992299079895,.351523995399475],[.288718998432159,.819945991039276],[.335278987884521,.852819979190826],[.440512001514435,.902418971061707],[.128294005990028,.791940987110138],[.408771991729736,.373893976211548],[.455606997013092,.451801002025604],[.499877005815506,.908990025520325],[.375436991453171,.924192011356354],[.11421000212431,.615022003650665],[.448662012815475,.695277988910675],[.4480200111866,.704632043838501],[.447111994028091,.715808033943176],[.444831997156143,.730794012546539],[.430011987686157,.766808986663818],[.406787008047104,.685672998428345],[.400738000869751,.681069016456604],[.392399996519089,.677703022956848],[.367855995893478,.663918972015381],[.247923001646996,.601333022117615],[.452769994735718,.420849978923798],[.43639200925827,.359887003898621],[.416164010763168,.368713974952698],[.413385987281799,.692366003990173],[.228018000721931,.683571994304657],[.468268007040024,.352671027183533],[.411361992359161,.804327011108398],[.499989002943039,.469825029373169],[.479153990745544,.442654013633728],[.499974012374878,.439637005329132],[.432112008333206,.493588984012604],[.499886006116867,.866917014122009],[.49991300702095,.821729004383087],[.456548988819122,.819200992584229],[.344549000263214,.745438992977142],[.37890899181366,.574010014533997],[.374292999505997,.780184984207153],[.319687992334366,.570737957954407],[.357154995203018,.604269981384277],[.295284003019333,.621580958366394],[.447750002145767,.862477004528046],[.410986006259918,.508723020553589],[.31395098567009,.775308012962341],[.354128003120422,.812552988529205],[.324548006057739,.703992962837219],[.189096003770828,.646299958229065],[.279776990413666,.71465802192688],[.1338230073452,.682700991630554],[.336768001317978,.644733011722565],[.429883986711502,.466521978378296],[.455527991056442,.548622965812683],[.437114000320435,.558896005153656],[.467287987470627,.529924988746643],[.414712011814117,.335219979286194],[.37704598903656,.322777986526489],[.344107985496521,.320150971412659],[.312875986099243,.32233202457428],[.283526003360748,.333190023899078],[.241245999932289,.382785975933075],[.102986000478268,.468762993812561],[.267612010240555,.424560010433197],[.297879010438919,.433175981044769],[.333433985710144,.433878004550934],[.366427004337311,.426115989685059],[.396012008190155,.416696012020111],[.420121014118195,.41022801399231],[.007561000064015,.480777025222778],[.432949006557465,.569517970085144],[.458638995885849,.479089021682739],[.473466008901596,.545744001865387],[.476087987422943,.563830018043518],[.468472003936768,.555056989192963],[.433990985155106,.582361996173859],[.483518004417419,.562983989715576],[.482482999563217,.57784903049469],[.42645001411438,.389798998832703],[.438998997211456,.39649498462677],[.450067013502121,.400434017181396],[.289712011814117,.368252992630005],[.276670008897781,.363372981548309],[.517862021923065,.471948027610779],[.710287988185883,.380764007568359],[.526226997375488,.573909997940063],[.895093023777008,.254140973091125],[.634069979190826,.409575998783112],[.661242008209229,.41302502155304],[.688880026340485,.409460008144379],[.725341975688934,.389131009578705],[.606630027294159,.40370500087738],[.654766023159027,.344011008739471],[.629905998706818,.346076011657715],[.680678009986877,.347265005111694],[.702096998691559,.353591024875641],[.75221198797226,.410804986953735],[.602918028831482,.842862963676453],[.719901978969574,.375599980354309],[.893692970275879,.399959981441498],[.790081977844238,.391354024410248],[.643998026847839,.534487962722778],[.528249025344849,.65040397644043],[.525849997997284,.680191040039062],[.560214996337891,.657229006290436],[.585384011268616,.66654098033905],[.549625992774963,.680860996246338],[.57122802734375,.682691991329193],[.624852001667023,.72809898853302],[.513050019741058,.547281980514526],[.51509702205658,.527251958847046],[.742246985435486,.314507007598877],[.598631024360657,.454979002475739],[.570338010787964,.548575043678284],[.578631997108459,.533622980117798],[.723087012767792,.532054007053375],[.516445994377136,.499638974666595],[.662801027297974,.282917976379395],[.70362401008606,.293271005153656],[.830704987049103,.193813979625702],[.552385985851288,.302568018436432],[.607609987258911,.353887975215912],[.645429015159607,.696707010269165],[.932694971561432,.730105042457581],[.557260990142822,.572826027870178],[.542901992797852,.584792017936707],[.6180260181427,.694710969924927],[.607590973377228,.694203019142151],[.722943007946014,.271963000297546],[.577413976192474,.563166975975037],[.614082992076874,.281386971473694],[.616907000541687,.255886018276215],[.668509006500244,.119913995265961],[.770092010498047,.232020974159241],[.635536015033722,.189248979091644],[.77039098739624,.299556016921997],[.826722025871277,.278755009174347],[.527121007442474,.666198015213013],[.553171992301941,.668527007102966],[.577238023281097,.673889994621277],[.554691970348358,.580065965652466],[.611896991729736,.693961024284363],[.59696102142334,.706539988517761],[.596370995044708,.693953037261963],[.539958000183105,.557139039039612],[.568841993808746,.692366003990173],[.547818005084991,.692366003990173],[.52461302280426,.692366003990173],[.534089982509613,.779141008853912],[.527670979499817,.736225962638855],[.526912987232208,.717857003211975],[.526877999305725,.704625964164734],[.526966989040375,.695277988910675],[.572058022022247,.695277988910675],[.573521018028259,.703539967536926],[.57683801651001,.711845993995667],[.581691026687622,.720062971115112],[.609944999217987,.639909982681274],[.986046016216278,.560034036636353],[.5867999792099,.69539999961853],[.590372025966644,.701822996139526],[.531915009021759,.601536989212036],[.577268004417419,.585934996604919],[.536915004253387,.593786001205444],[.627542972564697,.473352015018463],[.665585994720459,.495950996875763],[.588353991508484,.546862006187439],[.757824003696442,.14767599105835],[.709249973297119,.201507985591888],[.672684013843536,.256581008434296],[.600408971309662,.74900496006012],[.55826598405838,.261672019958496],[.570303976535797,.187870979309082],[.588165998458862,.109044015407562],[.711045026779175,.398952007293701],[.781069993972778,.435405015945435],[.587247014045715,.398931980133057],[.742869973182678,.355445981025696],[.572156012058258,.437651991844177],[.55186802148819,.536570012569427],[.821442008018494,.457556009292603],[.752701997756958,.457181990146637],[.71375697851181,.467626988887787],[.66711300611496,.460672974586487],[.631101012229919,.447153985500336],[.6008620262146,.432473003864288],[.523481011390686,.405627012252808],[.810747981071472,.523926019668579],[.771045982837677,.348959028720856],[.509127020835876,.562718033790588],[.595292985439301,.485023975372314],[.980530977249146,.401564002037048],[.573499977588654,.420000016689301],[.602994978427887,.548687994480133],[.733529984951019,.376977026462555],[.560611009597778,.519016981124878],[.967685997486115,.644356966018677],[.580985009670258,.387160003185272],[.537728011608124,.505385041236877],[.760966002941132,.779752969741821],[.801778972148895,.831938028335571],[.892440974712372,.54076099395752],[.816350996494293,.740260004997253],[.865594983100891,.333687007427216],[.614073991775513,.883246004581451],[.508952975273132,.579437971115112],[.617941975593567,.508316040039062],[.825608015060425,.397674977779388],[.681214988231659,.39623498916626],[.656635999679565,.400596976280212],[.603900015354156,.710216999053955],[.81208598613739,.588539004325867],[.56801301240921,.944564998149872],[.681007981300354,.898285031318665],[.733752012252808,.869701027870178],[.633830010890961,.398822009563446],[.606792986392975,.39553701877594],[.589659988880157,.391062021255493],[.805015981197357,.342108011245728],[.611334979534149,.362284004688263],[.634037971496582,.355970978736877],[.656635999679565,.355356991291046],[.681214988231659,.35834002494812],[.698584973812103,.363156020641327],[.941866993904114,.319076001644135],[.698584973812103,.387449026107788],[.584177017211914,.624107003211975],[.554318010807037,.566076993942261],[.534153997898102,.62064003944397],[.711217999458313,.819975018501282],[.664629995822906,.852871000766754],[.559099972248077,.902631998062134],[.871706008911133,.791940987110138],[.591234028339386,.373893976211548],[.544341027736664,.451583981513977],[.624562978744507,.924192011356354],[.88577002286911,.615028977394104],[.551338016986847,.695277988910675],[.551980018615723,.704632043838501],[.552887976169586,.715808033943176],[.555167973041534,.730794012546539],[.569944024085999,.767035007476807],[.593203008174896,.685675978660583],[.599261999130249,.681069016456604],[.607599973678589,.677703022956848],[.631937980651855,.663500010967255],[.752032995223999,.601315021514893],[.547226011753082,.420395016670227],[.563543975353241,.359827995300293],[.583841025829315,.368713974952698],[.586614012718201,.692366003990173],[.771915018558502,.683578014373779],[.531597018241882,.352482974529266],[.588370978832245,.804440975189209],[.52079701423645,.442565023899078],[.567984998226166,.493479013442993],[.543282985687256,.819254994392395],[.655317008495331,.745514988899231],[.621008992195129,.574018001556396],[.625559985637665,.78031200170517],[.680198013782501,.570719003677368],[.64276397228241,.604337990283966],[.704662978649139,.621529996395111],[.552012026309967,.862591981887817],[.589071989059448,.508637011051178],[.685944974422455,.775357007980347],[.645735025405884,.812640011310577],[.675342977046967,.703978002071381],[.810858011245728,.646304965019226],[.72012197971344,.714666962623596],[.866151988506317,.682704985141754],[.663187026977539,.644596993923187],[.570082008838654,.466325998306274],[.544561982154846,.548375964164734],[.562758982181549,.558784961700439],[.531987011432648,.530140042304993],[.585271000862122,.335177004337311],[.622952997684479,.32277899980545],[.655896008014679,.320163011550903],[.687132000923157,.322345972061157],[.716481983661652,.333200991153717],[.758756995201111,.382786989212036],[.897013008594513,.468769013881683],[.732392013072968,.424547016620636],[.70211398601532,.433162987232208],[.66652500629425,.433866024017334],[.633504986763,.426087975502014],[.603875994682312,.416586995124817],[.579657971858978,.409945011138916],[.992439985275269,.480777025222778],[.567192018032074,.569419980049133],[.54136598110199,.478899002075195],[.526564002037048,.546118021011353],[.523913025856018,.563830018043518],[.531529009342194,.555056989192963],[.566035985946655,.582329034805298],[.51631098985672,.563053965568542],[.5174720287323,.577877044677734],[.573594987392426,.389806985855103],[.560697972774506,.395331978797913],[.549755990505219,.399751007556915],[.710287988185883,.368252992630005],[.723330020904541,.363372981548309]],se=[127,34,139,11,0,37,232,231,120,72,37,39,128,121,47,232,121,128,104,69,67,175,171,148,157,154,155,118,50,101,73,39,40,9,151,108,48,115,131,194,204,211,74,40,185,80,42,183,40,92,186,230,229,118,202,212,214,83,18,17,76,61,146,160,29,30,56,157,173,106,204,194,135,214,192,203,165,98,21,71,68,51,45,4,144,24,23,77,146,91,205,50,187,201,200,18,91,106,182,90,91,181,85,84,17,206,203,36,148,171,140,92,40,39,193,189,244,159,158,28,247,246,161,236,3,196,54,68,104,193,168,8,117,228,31,189,193,55,98,97,99,126,47,100,166,79,218,155,154,26,209,49,131,135,136,150,47,126,217,223,52,53,45,51,134,211,170,140,67,69,108,43,106,91,230,119,120,226,130,247,63,53,52,238,20,242,46,70,156,78,62,96,46,53,63,143,34,227,173,155,133,123,117,111,44,125,19,236,134,51,216,206,205,154,153,22,39,37,167,200,201,208,36,142,100,57,212,202,20,60,99,28,158,157,35,226,113,160,159,27,204,202,210,113,225,46,43,202,204,62,76,77,137,123,116,41,38,72,203,129,142,64,98,240,49,102,64,41,73,74,212,216,207,42,74,184,169,170,211,170,149,176,105,66,69,122,6,168,123,147,187,96,77,90,65,55,107,89,90,180,101,100,120,63,105,104,93,137,227,15,86,85,129,102,49,14,87,86,55,8,9,100,47,121,145,23,22,88,89,179,6,122,196,88,95,96,138,172,136,215,58,172,115,48,219,42,80,81,195,3,51,43,146,61,171,175,199,81,82,38,53,46,225,144,163,110,246,33,7,52,65,66,229,228,117,34,127,234,107,108,69,109,108,151,48,64,235,62,78,191,129,209,126,111,35,143,163,161,246,117,123,50,222,65,52,19,125,141,221,55,65,3,195,197,25,7,33,220,237,44,70,71,139,122,193,245,247,130,33,71,21,162,153,158,159,170,169,150,188,174,196,216,186,92,144,160,161,2,97,167,141,125,241,164,167,37,72,38,12,145,159,160,38,82,13,63,68,71,226,35,111,158,153,154,101,50,205,206,92,165,209,198,217,165,167,97,220,115,218,133,112,243,239,238,241,214,135,169,190,173,133,171,208,32,125,44,237,86,87,178,85,86,179,84,85,180,83,84,181,201,83,182,137,93,132,76,62,183,61,76,184,57,61,185,212,57,186,214,207,187,34,143,156,79,239,237,123,137,177,44,1,4,201,194,32,64,102,129,213,215,138,59,166,219,242,99,97,2,94,141,75,59,235,24,110,228,25,130,226,23,24,229,22,23,230,26,22,231,112,26,232,189,190,243,221,56,190,28,56,221,27,28,222,29,27,223,30,29,224,247,30,225,238,79,20,166,59,75,60,75,240,147,177,215,20,79,166,187,147,213,112,233,244,233,128,245,128,114,188,114,217,174,131,115,220,217,198,236,198,131,134,177,132,58,143,35,124,110,163,7,228,110,25,356,389,368,11,302,267,452,350,349,302,303,269,357,343,277,452,453,357,333,332,297,175,152,377,384,398,382,347,348,330,303,304,270,9,336,337,278,279,360,418,262,431,304,408,409,310,415,407,270,409,410,450,348,347,422,430,434,313,314,17,306,307,375,387,388,260,286,414,398,335,406,418,364,367,416,423,358,327,251,284,298,281,5,4,373,374,253,307,320,321,425,427,411,421,313,18,321,405,406,320,404,405,315,16,17,426,425,266,377,400,369,322,391,269,417,465,464,386,257,258,466,260,388,456,399,419,284,332,333,417,285,8,346,340,261,413,441,285,327,460,328,355,371,329,392,439,438,382,341,256,429,420,360,364,394,379,277,343,437,443,444,283,275,440,363,431,262,369,297,338,337,273,375,321,450,451,349,446,342,467,293,334,282,458,461,462,276,353,383,308,324,325,276,300,293,372,345,447,382,398,362,352,345,340,274,1,19,456,248,281,436,427,425,381,256,252,269,391,393,200,199,428,266,330,329,287,273,422,250,462,328,258,286,384,265,353,342,387,259,257,424,431,430,342,353,276,273,335,424,292,325,307,366,447,345,271,303,302,423,266,371,294,455,460,279,278,294,271,272,304,432,434,427,272,407,408,394,430,431,395,369,400,334,333,299,351,417,168,352,280,411,325,319,320,295,296,336,319,403,404,330,348,349,293,298,333,323,454,447,15,16,315,358,429,279,14,15,316,285,336,9,329,349,350,374,380,252,318,402,403,6,197,419,318,319,325,367,364,365,435,367,397,344,438,439,272,271,311,195,5,281,273,287,291,396,428,199,311,271,268,283,444,445,373,254,339,263,466,249,282,334,296,449,347,346,264,447,454,336,296,299,338,10,151,278,439,455,292,407,415,358,371,355,340,345,372,390,249,466,346,347,280,442,443,282,19,94,370,441,442,295,248,419,197,263,255,359,440,275,274,300,383,368,351,412,465,263,467,466,301,368,389,380,374,386,395,378,379,412,351,419,436,426,322,373,390,388,2,164,393,370,462,461,164,0,267,302,11,12,374,373,387,268,12,13,293,300,301,446,261,340,385,384,381,330,266,425,426,423,391,429,355,437,391,327,326,440,457,438,341,382,362,459,457,461,434,430,394,414,463,362,396,369,262,354,461,457,316,403,402,315,404,403,314,405,404,313,406,405,421,418,406,366,401,361,306,408,407,291,409,408,287,410,409,432,436,410,434,416,411,264,368,383,309,438,457,352,376,401,274,275,4,421,428,262,294,327,358,433,416,367,289,455,439,462,370,326,2,326,370,305,460,455,254,449,448,255,261,446,253,450,449,252,451,450,256,452,451,341,453,452,413,464,463,441,413,414,258,442,441,257,443,442,259,444,443,260,445,444,467,342,445,459,458,250,289,392,290,290,328,460,376,433,435,250,290,392,411,416,433,341,463,464,453,464,465,357,465,412,343,412,399,360,363,440,437,399,456,420,456,363,401,435,288,372,383,353,339,255,249,448,261,255,133,243,190,133,155,112,33,246,247,33,130,25,398,384,286,362,398,414,362,463,341,263,359,467,263,249,255,466,467,260,75,60,166,238,239,79,162,127,139,72,11,37,121,232,120,73,72,39,114,128,47,233,232,128,103,104,67,152,175,148,173,157,155,119,118,101,74,73,40,107,9,108,49,48,131,32,194,211,184,74,185,191,80,183,185,40,186,119,230,118,210,202,214,84,83,17,77,76,146,161,160,30,190,56,173,182,106,194,138,135,192,129,203,98,54,21,68,5,51,4,145,144,23,90,77,91,207,205,187,83,201,18,181,91,182,180,90,181,16,85,17,205,206,36,176,148,140,165,92,39,245,193,244,27,159,28,30,247,161,174,236,196,103,54,104,55,193,8,111,117,31,221,189,55,240,98,99,142,126,100,219,166,218,112,155,26,198,209,131,169,135,150,114,47,217,224,223,53,220,45,134,32,211,140,109,67,108,146,43,91,231,230,120,113,226,247,105,63,52,241,238,242,124,46,156,95,78,96,70,46,63,116,143,227,116,123,111,1,44,19,3,236,51,207,216,205,26,154,22,165,39,167,199,200,208,101,36,100,43,57,202,242,20,99,56,28,157,124,35,113,29,160,27,211,204,210,124,113,46,106,43,204,96,62,77,227,137,116,73,41,72,36,203,142,235,64,240,48,49,64,42,41,74,214,212,207,183,42,184,210,169,211,140,170,176,104,105,69,193,122,168,50,123,187,89,96,90,66,65,107,179,89,180,119,101,120,68,63,104,234,93,227,16,15,85,209,129,49,15,14,86,107,55,9,120,100,121,153,145,22,178,88,179,197,6,196,89,88,96,135,138,136,138,215,172,218,115,219,41,42,81,5,195,51,57,43,61,208,171,199,41,81,38,224,53,225,24,144,110,105,52,66,118,229,117,227,34,234,66,107,69,10,109,151,219,48,235,183,62,191,142,129,126,116,111,143,7,163,246,118,117,50,223,222,52,94,19,141,222,221,65,196,3,197,45,220,44,156,70,139,188,122,245,139,71,162,145,153,159,149,170,150,122,188,196,206,216,92,163,144,161,164,2,167,242,141,241,0,164,37,11,72,12,144,145,160,12,38,13,70,63,71,31,226,111,157,158,154,36,101,205,203,206,165,126,209,217,98,165,97,237,220,218,237,239,241,210,214,169,140,171,32,241,125,237,179,86,178,180,85,179,181,84,180,182,83,181,194,201,182,177,137,132,184,76,183,185,61,184,186,57,185,216,212,186,192,214,187,139,34,156,218,79,237,147,123,177,45,44,4,208,201,32,98,64,129,192,213,138,235,59,219,141,242,97,97,2,141,240,75,235,229,24,228,31,25,226,230,23,229,231,22,230,232,26,231,233,112,232,244,189,243,189,221,190,222,28,221,223,27,222,224,29,223,225,30,224,113,247,225,99,60,240,213,147,215,60,20,166,192,187,213,243,112,244,244,233,245,245,128,188,188,114,174,134,131,220,174,217,236,236,198,134,215,177,58,156,143,124,25,110,7,31,228,25,264,356,368,0,11,267,451,452,349,267,302,269,350,357,277,350,452,357,299,333,297,396,175,377,381,384,382,280,347,330,269,303,270,151,9,337,344,278,360,424,418,431,270,304,409,272,310,407,322,270,410,449,450,347,432,422,434,18,313,17,291,306,375,259,387,260,424,335,418,434,364,416,391,423,327,301,251,298,275,281,4,254,373,253,375,307,321,280,425,411,200,421,18,335,321,406,321,320,405,314,315,17,423,426,266,396,377,369,270,322,269,413,417,464,385,386,258,248,456,419,298,284,333,168,417,8,448,346,261,417,413,285,326,327,328,277,355,329,309,392,438,381,382,256,279,429,360,365,364,379,355,277,437,282,443,283,281,275,363,395,431,369,299,297,337,335,273,321,348,450,349,359,446,467,283,293,282,250,458,462,300,276,383,292,308,325,283,276,293,264,372,447,346,352,340,354,274,19,363,456,281,426,436,425,380,381,252,267,269,393,421,200,428,371,266,329,432,287,422,290,250,328,385,258,384,446,265,342,386,387,257,422,424,430,445,342,276,422,273,424,306,292,307,352,366,345,268,271,302,358,423,371,327,294,460,331,279,294,303,271,304,436,432,427,304,272,408,395,394,431,378,395,400,296,334,299,6,351,168,376,352,411,307,325,320,285,295,336,320,319,404,329,330,349,334,293,333,366,323,447,316,15,315,331,358,279,317,14,316,8,285,9,277,329,350,253,374,252,319,318,403,351,6,419,324,318,325,397,367,365,288,435,397,278,344,439,310,272,311,248,195,281,375,273,291,175,396,199,312,311,268,276,283,445,390,373,339,295,282,296,448,449,346,356,264,454,337,336,299,337,338,151,294,278,455,308,292,415,429,358,355,265,340,372,388,390,466,352,346,280,295,442,282,354,19,370,285,441,295,195,248,197,457,440,274,301,300,368,417,351,465,251,301,389,385,380,386,394,395,379,399,412,419,410,436,322,387,373,388,326,2,393,354,370,461,393,164,267,268,302,12,386,374,387,312,268,13,298,293,301,265,446,340,380,385,381,280,330,425,322,426,391,420,429,437,393,391,326,344,440,438,458,459,461,364,434,394,428,396,262,274,354,457,317,316,402,316,315,403,315,314,404,314,313,405,313,421,406,323,366,361,292,306,407,306,291,408,291,287,409,287,432,410,427,434,411,372,264,383,459,309,457,366,352,401,1,274,4,418,421,262,331,294,358,435,433,367,392,289,439,328,462,326,94,2,370,289,305,455,339,254,448,359,255,446,254,253,449,253,252,450,252,256,451,256,341,452,414,413,463,286,441,414,286,258,441,258,257,442,257,259,443,259,260,444,260,467,445,309,459,250,305,289,290,305,290,460,401,376,435,309,250,392,376,411,433,453,341,464,357,453,465,343,357,412,437,343,399,344,360,440,420,437,456,360,420,363,361,401,288,265,372,353,390,339,249,339,448,255];var Fo=[127,234,132,58,172,150,149,148,152,377,378,379,397,288,361,454,356,70,63,105,66,107,336,296,334,293,300,168,6,195,4,98,97,2,326,327,33,160,158,133,153,144,362,385,387,263,373,380,57,40,37,0,267,270,287,321,314,17,84,91,78,81,13,311,308,402,14,178],Go=[33,133,362,263,1,62,308,159,145,386,374,6,102,331,2,13,14,70,105,107,336,334,300,54,10,284,50,280,234,454,58,288,152],Bo=[33,133,362,263,1,78,308],sA=Fo.map(e=>Ye[e]),aA=Go.map(e=>Ye[e]),iA=Bo.map(e=>Ye[e]);function X0(e){let t=e.map(o=>o[0]);return t.push(e[e.length-1][1]),t}var Ho=[[61,146],[146,91],[91,181],[181,84],[84,17],[17,314],[314,405],[405,321],[321,375],[375,291],[61,185],[185,40],[40,39],[39,37],[37,0],[0,267],[267,269],[269,270],[270,409],[409,291],[78,95],[95,88],[88,178],[178,87],[87,14],[14,317],[317,402],[402,318],[318,324],[324,308],[78,191],[191,80],[80,81],[81,82],[82,13],[13,312],[312,311],[311,310],[310,415],[415,308]],Vo=[[263,249],[249,390],[390,373],[373,374],[374,380],[380,381],[381,382],[382,362],[263,466],[466,388],[388,387],[387,386],[386,385],[385,384],[384,398],[398,362]],Zo=[[276,283],[283,282],[282,295],[295,285],[300,293],[293,334],[334,296],[296,336]],Do=[[474,475],[475,476],[476,477],[477,474]],Xo=[[33,7],[7,163],[163,144],[144,145],[145,153],[153,154],[154,155],[155,133],[33,246],[246,161],[161,160],[160,159],[159,158],[158,157],[157,173],[173,133]],qo=[[46,53],[53,52],[52,65],[65,55],[70,63],[63,105],[105,66],[66,107]],Uo=[[469,470],[470,471],[471,472],[472,469]],Yo=[[10,338],[338,297],[297,332],[332,284],[284,251],[251,389],[389,356],[356,454],[454,323],[323,361],[361,288],[288,397],[397,365],[365,379],[379,378],[378,400],[400,377],[377,152],[152,148],[148,176],[176,149],[149,150],[150,136],[136,172],[172,58],[58,132],[132,93],[93,234],[234,127],[127,162],[162,21],[21,54],[54,103],[103,67],[67,109],[109,10]],lA={lips:X0(Ho),leftEye:X0(Vo),leftEyebrow:X0(Zo),leftIris:X0(Do),rightEye:X0(Xo),rightEyebrow:X0(qo),rightIris:X0(Uo),faceOval:X0(Yo)};var Pe=e=>[Math.abs(e.endPoint[0]-e.startPoint[0]),Math.abs(e.endPoint[1]-e.startPoint[1])],c2=e=>[e.startPoint[0]+(e.endPoint[0]-e.startPoint[0])/2,e.startPoint[1]+(e.endPoint[1]-e.startPoint[1])/2,1],d2=(e,t)=>e?[Math.trunc(Math.max(0,e.startPoint[0])),Math.trunc(Math.max(0,e.startPoint[1])),Math.trunc(Math.min(t.shape[2]||0,e.endPoint[0])-Math.max(0,e.startPoint[0])),Math.trunc(Math.min(t.shape[1]||0,e.endPoint[1])-Math.max(0,e.startPoint[1]))]:[0,0,0,0],f2=(e,t)=>e?[e.startPoint[0]/(t.shape[2]||0),e.startPoint[1]/(t.shape[1]||0),(e.endPoint[0]-e.startPoint[0])/(t.shape[2]||0),(e.endPoint[1]-e.startPoint[1])/(t.shape[1]||0)]:[0,0,0,0],at=(e,t)=>{let o=[e.startPoint[0]*t[0],e.startPoint[1]*t[1]],n=[e.endPoint[0]*t[0],e.endPoint[1]*t[1]];return{startPoint:o,endPoint:n,landmarks:e.landmarks,confidence:e.confidence}},f5=(e,t,o)=>{let n=t.shape[1],r=t.shape[2],s=[e.startPoint[1]/n,e.startPoint[0]/r,e.endPoint[1]/n,e.endPoint[0]/r],a=A.image.cropAndResize(t,[s],[0],o),i=A.div(a,L.tf255);return A.dispose(a),i},m2=(e,t)=>{let o=c2(e),n=Pe(e),r=[t*n[0]/2,t*n[1]/2];return{startPoint:[o[0]-r[0],o[1]-r[1]],endPoint:[o[0]+r[0],o[1]+r[1]],landmarks:e.landmarks,confidence:e.confidence}},p2=e=>{let t=c2(e),o=Pe(e),n=Math.max(...o)/2;return{startPoint:[Math.round(t[0]-n),Math.round(t[1]-n)],endPoint:[Math.round(t[0]+n),Math.round(t[1]+n)],landmarks:e.landmarks,confidence:e.confidence}},it=e=>{let t=e.map(n=>n[0]),o=e.map(n=>n[1]);return{startPoint:[Math.min(...t),Math.min(...o)],endPoint:[Math.max(...t),Math.max(...o)],landmarks:e}},m5=[[1,0,0],[0,1,0],[0,0,1]],Ko=e=>e-2*Math.PI*Math.floor((e+Math.PI)/(2*Math.PI)),Jo=(e,t)=>Ko(Math.PI/2-Math.atan2(-(t[1]-e[1]),t[0]-e[0]));var At=(e,t)=>[[1,0,e],[0,1,t],[0,0,1]],ae=(e,t)=>{let o=0;for(let n=0;n{let o=[];for(let n=0;n{let o=[],n=e.length;for(let r=0;r{let o=Math.cos(e),n=Math.sin(e),r=[[o,-n,0],[n,o,0],[0,0,1]],s=At(t[0],t[1]),a=st(s,r),i=At(-t[0],-t[1]);return st(a,i)},_o=e=>{let t=[[e[0][0],e[1][0]],[e[0][1],e[1][1]]],o=[e[0][2],e[1][2]],n=[-ae(t[0],o),-ae(t[1],o)];return[t[0].concat(n[0]),t[1].concat(n[1]),[0,0,1]]},$o=(e,t)=>[ae(e,t[0]),ae(e,t[1])];function yt(e){let t=e===192?{strides:[4],anchors:[1]}:{strides:[e/16,e/8],anchors:[2,6]},o=[];for(let n=0;n[s[0]/r*(m[0]-r/2),s[1]/r*(m[1]-r/2),m[2]||0]),i=o&&o!==0&&Math.abs(o)>.2,l=i?lt(o,[0,0]):m5,x=i?a.map(m=>[...$o(m,l),m[2]]):a,d=i?_o(n):m5,y=c2(t),c=[ae(y,d[0]),ae(y,d[1])];return x.map(m=>[Math.trunc(m[0]+c[0]),Math.trunc(m[1]+c[1]),Math.trunc(m[2]||0)])}function ct(e,t,o,n){let r=t.landmarks.length>=x5.count?x5.symmetryLine:Ae.symmetryLine,s=0,a=m5,i;if(e&&v.kernels.includes("rotatewithoffset"))if(s=Jo(t.landmarks[r[0]],t.landmarks[r[1]]),s&&s!==0&&Math.abs(s)>.2){let x=c2(t),d=[x[0]/o.shape[2],x[1]/o.shape[1]],y=A.image.rotateWithOffset(o,s,0,d);a=lt(-s,x),i=f5(t,y,[n,n]),A.dispose(y)}else i=f5(t,o,[n,n]);else i=f5(t,o,[n,n]);return[s,a,i]}var en=e=>{let t=e.map(n=>n[0]),o=e.map(n=>n[1]);return[Math.min(...t)+(Math.max(...t)-Math.min(...t))/2,Math.min(...o)+(Math.max(...o)-Math.min(...o))/2]},dt=(e,t)=>{let o=en(e),n=Pe(t);return{startPoint:[o[0]-n[0]/2,o[1]-n[1]/2],endPoint:[o[0]+n[0]/2,o[1]+n[1]/2]}};var ft=6,tn=1.4,z0,mt=null,q0=0,Ke=null,Me=()=>q0;async function pt(e){var t;return v.initial&&(z0=null),z0?e.debug&&u("cached model:",z0.modelUrl):z0=await W((t=e.face.detector)==null?void 0:t.modelPath),q0=z0.inputs[0].shape?z0.inputs[0].shape[2]:0,Ke=A.scalar(q0,"int32"),mt=A.tensor2d(yt(q0)),z0}function on(e){let t={};t.boxStarts=A.slice(e,[0,1],[-1,2]),t.centers=A.add(t.boxStarts,mt),t.boxSizes=A.slice(e,[0,3],[-1,2]),t.boxSizesNormalized=A.div(t.boxSizes,Ke),t.centersNormalized=A.div(t.centers,Ke),t.halfBoxSize=A.div(t.boxSizesNormalized,L.tf2),t.starts=A.sub(t.centersNormalized,t.halfBoxSize),t.ends=A.add(t.centersNormalized,t.halfBoxSize),t.startNormalized=A.mul(t.starts,Ke),t.endNormalized=A.mul(t.ends,Ke);let o=A.concat2d([t.startNormalized,t.endNormalized],1);return Object.keys(t).forEach(n=>A.dispose(t[n])),o}async function ut(e,t){var i,l,x,d;if(!e||e.isDisposedInternal||e.shape.length!==4||e.shape[1]<1||e.shape[2]<1)return[];let o={};o.resized=A.image.resizeBilinear(e,[q0,q0]),o.div=A.div(o.resized,L.tf127),o.normalized=A.sub(o.div,L.tf05);let n=z0==null?void 0:z0.execute(o.normalized);if(Array.isArray(n)&&n.length>2){let y=n.sort((c,m)=>c.size-m.size);o.concat384=A.concat([y[0],y[2]],2),o.concat512=A.concat([y[1],y[3]],2),o.concat=A.concat([o.concat512,o.concat384],1),o.batch=A.squeeze(o.concat,0)}else Array.isArray(n)?o.batch=A.squeeze(n[0]):o.batch=A.squeeze(n);A.dispose(n),o.boxes=on(o.batch),o.logits=A.slice(o.batch,[0,0],[-1,1]),o.sigmoid=A.sigmoid(o.logits),o.scores=A.squeeze(o.sigmoid),o.nms=await A.image.nonMaxSuppressionAsync(o.boxes,o.scores,((i=t.face.detector)==null?void 0:i.maxDetected)||0,((l=t.face.detector)==null?void 0:l.iouThreshold)||0,((x=t.face.detector)==null?void 0:x.minConfidence)||0);let r=await o.nms.array(),s=[],a=await o.scores.data();for(let y=0;y(((d=t.face.detector)==null?void 0:d.minConfidence)||0)){let m={};m.bbox=A.slice(o.boxes,[r[y],0],[1,-1]),m.slice=A.slice(o.batch,[r[y],ft-1],[1,-1]),m.squeeze=A.squeeze(m.slice),m.landmarks=A.reshape(m.squeeze,[ft,-1]);let h=await m.bbox.data(),p={startPoint:[h[0],h[1]],endPoint:[h[2],h[3]],landmarks:await m.landmarks.array(),confidence:c},R=at(p,[(e.shape[2]||0)/q0,(e.shape[1]||0)/q0]),P=m2(R,t.face.scale||tn),g=p2(P);s.push(g),Object.keys(m).forEach(f=>A.dispose(m[f]))}}return Object.keys(o).forEach(y=>A.dispose(o[y])),s}var u2={};ne(u2,{connected:()=>h5,kpt:()=>u5});var u5=["nose","leftEyeInside","leftEye","leftEyeOutside","rightEyeInside","rightEye","rightEyeOutside","leftEar","rightEar","leftMouth","rightMouth","leftShoulder","rightShoulder","leftElbow","rightElbow","leftWrist","rightWrist","leftPinky","rightPinky","leftIndex","rightIndex","leftThumb","rightThumb","leftHip","rightHip","leftKnee","rightKnee","leftAnkle","rightAnkle","leftHeel","rightHeel","leftFoot","rightFoot","bodyCenter","bodyTop","leftPalm","leftHand","rightPalm","rightHand"],h5={shoulders:["leftShoulder","rightShoulder"],hips:["rightHip","leftHip"],mouth:["leftMouth","rightMouth"],leftLegUpper:["leftHip","leftKnee"],leftLegLower:["leftKnee","leftAnkle"],leftFoot:["leftAnkle","leftHeel","leftFoot"],leftTorso:["leftShoulder","leftHip"],leftArmUpper:["leftShoulder","leftElbow"],leftArmLower:["leftElbow","leftWrist"],leftHand:["leftWrist","leftPalm"],leftHandPinky:["leftPalm","leftPinky"],leftHandIndex:["leftPalm","leftIndex"],leftHandThumb:["leftPalm","leftThumb"],leftEyeOutline:["leftEyeInside","leftEyeOutside"],rightLegUpper:["rightHip","rightKnee"],rightLegLower:["rightKnee","rightAnkle"],rightFoot:["rightAnkle","rightHeel","rightFoot"],rightTorso:["rightShoulder","rightHip"],rightArmUpper:["rightShoulder","rightElbow"],rightArmLower:["rightElbow","rightWrist"],rightHand:["rightWrist","rightPalm"],rightHandPinky:["rightPalm","rightPinky"],rightHandIndex:["rightPalm","rightIndex"],rightHandThumb:["rightPalm","rightThumb"],rightEyeOutline:["rightEyeInside","rightEyeOutside"]};var bt=224,nn,rn=5,h2=[8,16,32,32,32];async function gt(){let e=[],t=0;for(;to.x)),y:A.tensor1d(e.map(o=>o.y))}}function L0(e,t=[1,1]){let o=[e.map(i=>i[0]),e.map(i=>i[1])],n=[Math.min(...o[0]),Math.min(...o[1])],r=[Math.max(...o[0]),Math.max(...o[1])],s=[n[0],n[1],r[0]-n[0],r[1]-n[1]],a=[s[0]/t[0],s[1]/t[1],s[2]/t[0],s[3]/t[1]];return{box:s,boxRaw:a}}function Pt(e,t=[1,1]){let o=[e.map(x=>x[0]),e.map(x=>x[1])],n=[Math.min(...o[0]),Math.min(...o[1])],r=[Math.max(...o[0]),Math.max(...o[1])],s=[(n[0]+r[0])/2,(n[1]+r[1])/2],a=Math.max(s[0]-n[0],s[1]-n[1],-s[0]+r[0],-s[1]+r[1]),i=[Math.trunc(s[0]-a),Math.trunc(s[1]-a),Math.trunc(2*a),Math.trunc(2*a)],l=[i[0]/t[0],i[1]/t[1],i[2]/t[0],i[3]/t[1]];return{box:i,boxRaw:l}}function b2(e,t){let o=[e[2]*t,e[3]*t];return[e[0]-(o[0]-e[2])/2,e[1]-(o[1]-e[3])/2,o[0],o[1]]}var Tt={initial:!0},d0={detector:null,landmarks:null},Re={detector:[224,224],landmarks:[256,256]},b5=Number.MAX_SAFE_INTEGER,sn={landmarks:["ld_3d","activation_segmentation","activation_heatmap","world_3d","output_poseflag"],detector:[]},P2=null,Je,U0=[[0,0],[0,0],[0,0],[0,0]],Mt=0,Rt=e=>1-1/(1+Math.exp(e));async function vt(e){if(Tt.initial&&(d0.detector=null),!d0.detector&&e.body.detector&&e.body.detector.modelPath){d0.detector=await W(e.body.detector.modelPath);let t=Object.values(d0.detector.modelSignature.inputs);Re.detector[0]=Array.isArray(t)?parseInt(t[0].tensorShape.dim[1].size):0,Re.detector[1]=Array.isArray(t)?parseInt(t[0].tensorShape.dim[2].size):0}else e.debug&&d0.detector&&u("cached model:",d0.detector.modelUrl);return await gt(),d0.detector}async function wt(e){if(Tt.initial&&(d0.landmarks=null),d0.landmarks)e.debug&&u("cached model:",d0.landmarks.modelUrl);else{d0.landmarks=await W(e.body.modelPath);let t=Object.values(d0.landmarks.modelSignature.inputs);Re.landmarks[0]=Array.isArray(t)?parseInt(t[0].tensorShape.dim[1].size):0,Re.landmarks[1]=Array.isArray(t)?parseInt(t[0].tensorShape.dim[2].size):0}return d0.landmarks}async function an(e,t){let o={};if(!e.shape||!e.shape[1]||!e.shape[2])return e;let n;if(Je&&(o.cropped=A.image.cropAndResize(e,[Je],[0],[e.shape[1],e.shape[2]])),e.shape[1]!==e.shape[2]){let r=[e.shape[2]>e.shape[1]?Math.trunc((e.shape[2]-e.shape[1])/2):0,e.shape[2]>e.shape[1]?Math.trunc((e.shape[2]-e.shape[1])/2):0],s=[e.shape[1]>e.shape[2]?Math.trunc((e.shape[1]-e.shape[2])/2):0,e.shape[1]>e.shape[2]?Math.trunc((e.shape[1]-e.shape[2])/2):0];U0=[[0,0],r,s,[0,0]],o.pad=A.pad(o.cropped||e,U0),o.resize=A.image.resizeBilinear(o.pad,[t,t]),n=A.div(o.resize,L.tf255)}else e.shape[1]!==t?(o.resize=A.image.resizeBilinear(o.cropped||e,[t,t]),n=A.div(o.resize,L.tf255)):n=A.div(o.cropped||e,L.tf255);return Object.keys(o).forEach(r=>A.dispose(o[r])),n}function ln(e,t){for(let o of e)o.position=[Math.trunc(o.position[0]*(t[0]+U0[2][0]+U0[2][1])/t[0]-U0[2][0]),Math.trunc(o.position[1]*(t[1]+U0[1][0]+U0[1][1])/t[1]-U0[1][0]),o.position[2]],o.positionRaw=[o.position[0]/t[0],o.position[1]/t[1],2*o.position[2]/(t[0]+t[1])];if(Je)for(let o of e)o.positionRaw=[o.positionRaw[0]+Je[1],o.positionRaw[1]+Je[0],o.positionRaw[2]],o.position=[Math.trunc(o.positionRaw[0]*t[0]),Math.trunc(o.positionRaw[1]*t[1]),o.positionRaw[2]];return e}async function yn(e){let t=e.find(i=>i.part==="leftPalm"),o=e.find(i=>i.part==="leftWrist"),n=e.find(i=>i.part==="leftIndex");t.position[2]=((o.position[2]||0)+(n.position[2]||0))/2;let r=e.find(i=>i.part==="rightPalm"),s=e.find(i=>i.part==="rightWrist"),a=e.find(i=>i.part==="rightIndex");r.position[2]=((s.position[2]||0)+(a.position[2]||0))/2}async function xn(e,t,o){var h;let n={};[n.ld,n.segmentation,n.heatmap,n.world,n.poseflag]=(h=d0.landmarks)==null?void 0:h.execute(e,sn.landmarks);let r=(await n.poseflag.data())[0],s=await n.ld.data(),a=await n.world.data();Object.keys(n).forEach(p=>A.dispose(n[p]));let i=[],l=5;for(let p=0;pp.position),y=L0(d,[o[0],o[1]]),c={};for(let[p,R]of Object.entries(h5)){let P=[];for(let g=0;gj.part===R[g]),M=x.find(j=>j.part===R[g+1]);f&&M&&P.push([f.position,M.position])}c[p]=P}return{id:0,score:Math.trunc(100*r)/100,box:y.box,boxRaw:y.boxRaw,keypoints:x,annotations:c}}async function g5(e,t){let o=[e.shape[2]||0,e.shape[1]||0],n=(t.body.skipTime||0)>b()-Mt,r=b5<(t.body.skipFrames||0);if(t.skipAllowed&&n&&r&&P2!==null)b5++;else{let s={};s.landmarks=await an(e,256),P2=await xn(s.landmarks,t,o),Object.keys(s).forEach(a=>A.dispose(s[a])),Mt=b(),b5=0}return P2?[P2]:[]}var Te=[{class:1,label:"person"},{class:2,label:"bicycle"},{class:3,label:"car"},{class:4,label:"motorcycle"},{class:5,label:"airplane"},{class:6,label:"bus"},{class:7,label:"train"},{class:8,label:"truck"},{class:9,label:"boat"},{class:10,label:"traffic light"},{class:11,label:"fire hydrant"},{class:12,label:"stop sign"},{class:13,label:"parking meter"},{class:14,label:"bench"},{class:15,label:"bird"},{class:16,label:"cat"},{class:17,label:"dog"},{class:18,label:"horse"},{class:19,label:"sheep"},{class:20,label:"cow"},{class:21,label:"elephant"},{class:22,label:"bear"},{class:23,label:"zebra"},{class:24,label:"giraffe"},{class:25,label:"backpack"},{class:26,label:"umbrella"},{class:27,label:"handbag"},{class:28,label:"tie"},{class:29,label:"suitcase"},{class:30,label:"frisbee"},{class:31,label:"skis"},{class:32,label:"snowboard"},{class:33,label:"sports ball"},{class:34,label:"kite"},{class:35,label:"baseball bat"},{class:36,label:"baseball glove"},{class:37,label:"skateboard"},{class:38,label:"surfboard"},{class:39,label:"tennis racket"},{class:40,label:"bottle"},{class:41,label:"wine glass"},{class:42,label:"cup"},{class:43,label:"fork"},{class:44,label:"knife"},{class:45,label:"spoon"},{class:46,label:"bowl"},{class:47,label:"banana"},{class:48,label:"apple"},{class:49,label:"sandwich"},{class:50,label:"orange"},{class:51,label:"broccoli"},{class:52,label:"carrot"},{class:53,label:"hot dog"},{class:54,label:"pizza"},{class:55,label:"donut"},{class:56,label:"cake"},{class:57,label:"chair"},{class:58,label:"couch"},{class:59,label:"potted plant"},{class:60,label:"bed"},{class:61,label:"dining table"},{class:62,label:"toilet"},{class:63,label:"tv"},{class:64,label:"laptop"},{class:65,label:"mouse"},{class:66,label:"remote"},{class:67,label:"keyboard"},{class:68,label:"cell phone"},{class:69,label:"microwave"},{class:70,label:"oven"},{class:71,label:"toaster"},{class:72,label:"sink"},{class:73,label:"refrigerator"},{class:74,label:"book"},{class:75,label:"clock"},{class:76,label:"vase"},{class:77,label:"scissors"},{class:78,label:"teddy bear"},{class:79,label:"hair drier"},{class:80,label:"toothbrush"}];var F0,ie=0,P5=[],Et=0,M5=Number.MAX_SAFE_INTEGER;async function zt(e){if(v.initial&&(F0=null),F0)e.debug&&u("cached model:",F0.modelUrl);else{F0=await W(e.object.modelPath);let t=Object.values(F0.modelSignature.inputs);ie=Array.isArray(t)?parseInt(t[0].tensorShape.dim[2].size):0}return F0}async function cn(e,t,o){if(!e)return[];let n={},r=[],s=await e.array();n.squeeze=A.squeeze(e);let a=A.split(n.squeeze,6,1);n.stack=A.stack([a[1],a[0],a[3],a[2]],1),n.boxes=A.squeeze(n.stack),n.scores=A.squeeze(a[4]),n.classes=A.squeeze(a[5]),A.dispose([e,...a]),n.nms=await A.image.nonMaxSuppressionAsync(n.boxes,n.scores,o.object.maxDetected,o.object.iouThreshold,o.object.minConfidence||0);let i=await n.nms.data(),l=0;for(let x of Array.from(i)){let d=Math.trunc(100*s[0][x][4])/100,y=s[0][x][5],c=Te[y].label,[m,h]=[s[0][x][0]/ie,s[0][x][1]/ie],p=[m,h,s[0][x][2]/ie-m,s[0][x][3]/ie-h],R=[Math.trunc(p[0]*t[0]),Math.trunc(p[1]*t[1]),Math.trunc(p[2]*t[0]),Math.trunc(p[3]*t[1])];r.push({id:l++,score:d,class:y,label:c,box:R,boxRaw:p})}return Object.keys(n).forEach(x=>A.dispose(n[x])),r}async function R5(e,t){let o=(t.object.skipTime||0)>b()-Et,n=M5<(t.object.skipFrames||0);return t.skipAllowed&&o&&n&&P5.length>0?(M5++,P5):(M5=0,new Promise(async r=>{let s=[e.shape[2]||0,e.shape[1]||0],a=A.image.resizeBilinear(e,[ie,ie]),i=t.object.enabled?F0==null?void 0:F0.execute(a,["tower_0/detections"]):null;Et=b(),A.dispose(a);let l=await cn(i,s,t);P5=l,r(l)}))}var M2={};ne(M2,{connected:()=>v5,kpt:()=>T5});var T5=["head","neck","rightShoulder","rightElbow","rightWrist","chest","leftShoulder","leftElbow","leftWrist","bodyCenter","rightHip","rightKnee","rightAnkle","leftHip","leftKnee","leftAnkle"],v5={leftLeg:["leftHip","leftKnee","leftAnkle"],rightLeg:["rightHip","rightKnee","rightAnkle"],torso:["leftShoulder","rightShoulder","rightHip","leftHip","leftShoulder"],leftArm:["leftShoulder","leftElbow","leftWrist"],rightArm:["rightShoulder","rightElbow","rightWrist"],head:[]};var A0,jt=0,y0={id:0,keypoints:[],box:[0,0,0,0],boxRaw:[0,0,0,0],score:0,annotations:{}},w5=Number.MAX_SAFE_INTEGER;async function Ct(e){return v.initial&&(A0=null),A0?e.debug&&u("cached model:",A0.modelUrl):A0=await W(e.body.modelPath),A0}async function dn(e,t){let[o,n]=e.shape,r=A.reshape(e,[n*o]),s=A.max(r,0),a=(await s.data())[0];if(A.dispose([r,s]),a>t){let i=A.argMax(r,0),l=A.mod(i,o),x=(await l.data())[0],d=A.div(i,A.scalar(o,"int32")),y=(await d.data())[0];return A.dispose([l,d]),[x,y,a]}return[0,0,a]}async function k5(e,t){let o=(t.body.skipTime||0)>b()-jt,n=w5<(t.body.skipFrames||0);return t.skipAllowed&&o&&n&&Object.keys(y0.keypoints).length>0?(w5++,[y0]):(w5=0,new Promise(async r=>{var y;let s=A.tidy(()=>{if(!(A0!=null&&A0.inputs[0].shape))return null;let c=A.image.resizeBilinear(e,[A0.inputs[0].shape[2],A0.inputs[0].shape[1]],!1),m=A.mul(c,L.tf2);return A.sub(m,L.tf1)}),a;if(t.body.enabled&&(a=A0==null?void 0:A0.execute(s)),jt=b(),A.dispose(s),a){y0.keypoints.length=0;let c=a.squeeze();A.dispose(a);let m=c.unstack(2);A.dispose(c);for(let h=0;h(((y=t.body)==null?void 0:y.minConfidence)||0)&&y0.keypoints.push({score:Math.round(100*P)/100,part:T5[h],positionRaw:[p/A0.inputs[0].shape[2],R/A0.inputs[0].shape[1]],position:[Math.round(e.shape[2]*p/A0.inputs[0].shape[2]),Math.round(e.shape[1]*R/A0.inputs[0].shape[1])]})}m.forEach(h=>A.dispose(h))}y0.score=y0.keypoints.reduce((c,m)=>m.score>c?m.score:c,0);let i=y0.keypoints.map(c=>c.position[0]),l=y0.keypoints.map(c=>c.position[1]);y0.box=[Math.min(...i),Math.min(...l),Math.max(...i)-Math.min(...i),Math.max(...l)-Math.min(...l)];let x=y0.keypoints.map(c=>c.positionRaw[0]),d=y0.keypoints.map(c=>c.positionRaw[1]);y0.boxRaw=[Math.min(...x),Math.min(...d),Math.max(...x)-Math.min(...x),Math.max(...d)-Math.min(...d)];for(let[c,m]of Object.entries(v5)){let h=[];for(let p=0;pg.part===m[p]),P=y0.keypoints.find(g=>g.part===m[p+1]);R&&P&&R.score>(t.body.minConfidence||0)&&P.score>(t.body.minConfidence||0)&&h.push([R.position,P.position])}y0.annotations[c]=h}r([y0])}))}var fn=["angry","disgust","fear","happy","sad","surprise","neutral"],g0,R2=[],Nt=0,Ot=0,E5=Number.MAX_SAFE_INTEGER;async function Wt(e){var t;return v.initial&&(g0=null),g0?e.debug&&u("cached model:",g0.modelUrl):g0=await W((t=e.face.emotion)==null?void 0:t.modelPath),g0}async function z5(e,t,o,n){var a,i;if(!g0)return[];let r=E5<(((a=t.face.emotion)==null?void 0:a.skipFrames)||0),s=(((i=t.face.emotion)==null?void 0:i.skipTime)||0)>b()-Ot;return t.skipAllowed&&s&&r&&Nt===n&&R2[o]&&R2[o].length>0?(E5++,R2[o]):(E5=0,new Promise(async l=>{var d,y;let x=[];if((d=t.face.emotion)!=null&&d.enabled){let c={},m=g0!=null&&g0.inputs[0].shape?g0.inputs[0].shape[2]:0;c.resize=A.image.resizeBilinear(e,[m,m],!1),c.channels=A.mul(c.resize,L.rgb),c.grayscale=A.sum(c.channels,3,!0),c.grayscaleSub=A.sub(c.grayscale,L.tf05),c.grayscaleMul=A.mul(c.grayscaleSub,L.tf2),c.emotion=g0==null?void 0:g0.execute(c.grayscaleMul),Ot=b();let h=await c.emotion.data();for(let p=0;p(((y=t.face.emotion)==null?void 0:y.minConfidence)||0)&&x.push({score:Math.min(.99,Math.trunc(100*h[p])/100),emotion:fn[p]});x.sort((p,R)=>R.score-p.score),Object.keys(c).forEach(p=>A.dispose(c[p]))}R2[o]=x,Nt=n,l(x)}))}var f0,S5=[],Ft=0,Gt=0,Bt=Number.MAX_SAFE_INTEGER;async function Ht(e){return v.initial&&(f0=null),f0?e.debug&&u("cached model:",f0.modelUrl):f0=await W(e.face.mobilefacenet.modelPath),f0}async function j5(e,t,o,n){var a,i;if(!f0)return[];let r=Bt<(((a=t.face.embedding)==null?void 0:a.skipFrames)||0),s=(((i=t.face.embedding)==null?void 0:i.skipTime)||0)>b()-Gt;return t.skipAllowed&&s&&r&&Ft===n&&S5[o]?(Bt++,S5[o]):new Promise(async l=>{var d;let x=[];if(((d=t.face.embedding)==null?void 0:d.enabled)&&(f0==null?void 0:f0.inputs[0].shape)){let y={};y.crop=A.image.resizeBilinear(e,[f0.inputs[0].shape[2],f0.inputs[0].shape[1]],!1),y.data=f0==null?void 0:f0.execute(y.crop);let c=await y.data.data();x=Array.from(c)}S5[o]=x,Ft=n,Gt=b(),l(x)})}var G0,Y0=0,mn=2.3,C5=T0.leftEyeLower0,I5=T0.rightEyeLower0,ve={leftBounds:[C5[0],C5[C5.length-1]],rightBounds:[I5[0],I5[I5.length-1]]},we={upperCenter:3,lowerCenter:4,index:71,numCoordinates:76};async function qt(e){var t;return v.initial&&(G0=null),G0?e.debug&&u("cached model:",G0.modelUrl):G0=await W((t=e.face.iris)==null?void 0:t.modelPath),Y0=G0.inputs[0].shape?G0.inputs[0].shape[2]:0,Y0===-1&&(Y0=64),G0}function T2(e,t,o,n){for(let r=0;r{let t=e[ve.leftBounds[0]][2],o=e[ve.rightBounds[0]][2];return t-o},Zt=(e,t,o,n,r,s=!1)=>{let a=p2(m2(it([e[o],e[n]]),mn)),i=Pe(a),l=A.image.cropAndResize(t,[[a.startPoint[1]/r,a.startPoint[0]/r,a.endPoint[1]/r,a.endPoint[0]/r]],[0],[Y0,Y0]);if(s&&v.kernels.includes("flipleftright")){let x=A.image.flipLeftRight(l);A.dispose(l),l=x}return{box:a,boxSize:i,crop:l}},Dt=(e,t,o,n=!1)=>{let r=[];for(let s=0;s{let n=e[T0[`${o}EyeUpper0`][we.upperCenter]][2],r=e[T0[`${o}EyeLower0`][we.lowerCenter]][2],s=(n+r)/2;return t.map((a,i)=>{let l=s;return i===2?l=n:i===4&&(l=r),[a[0],a[1],l]})};async function Ut(e,t,o,n){if(!G0)return o.debug&&u("face mesh iris detection requested, but model is not loaded"),e;let{box:r,boxSize:s,crop:a}=Zt(e,t,ve.leftBounds[0],ve.leftBounds[1],n,!0),{box:i,boxSize:l,crop:x}=Zt(e,t,ve.rightBounds[0],ve.rightBounds[1],n,!0),d=A.concat([a,x]);A.dispose(a),A.dispose(x);let y=G0.execute(d);A.dispose(d);let c=await y.data();A.dispose(y);let m=c.slice(0,we.numCoordinates*3),{rawCoords:h,iris:p}=Dt(m,r,s,!0),R=c.slice(we.numCoordinates*3),{rawCoords:P,iris:g}=Dt(R,i,l,!1),f=pn(e);Math.abs(f)<30?(T2(e,h,"left",null),T2(e,P,"right",null)):f<1?T2(e,h,"left",["EyeUpper0","EyeLower0"]):T2(e,P,"right",["EyeUpper0","EyeLower0"]);let M=Xt(e,p,"left"),j=Xt(e,g,"right");return e.concat(M).concat(j)}var un=[[61,146],[146,91],[91,181],[181,84],[84,17],[17,314],[314,405],[405,321],[321,375],[375,291],[61,185],[185,40],[40,39],[39,37],[37,0],[0,267],[267,269],[269,270],[270,409],[409,291],[78,95],[95,88],[88,178],[178,87],[87,14],[14,317],[317,402],[402,318],[318,324],[324,308],[78,191],[191,80],[80,81],[81,82],[82,13],[13,312],[312,311],[311,310],[310,415],[415,308]],hn=[[263,249],[249,390],[390,373],[373,374],[374,380],[380,381],[381,382],[382,362],[263,466],[466,388],[388,387],[387,386],[386,385],[385,384],[384,398],[398,362]],bn=[[276,283],[283,282],[282,295],[295,285],[300,293],[293,334],[334,296],[296,336]],gn=[[474,475],[475,476],[476,477],[477,474]],Pn=[[33,7],[7,163],[163,144],[144,145],[145,153],[153,154],[154,155],[155,133],[33,246],[246,161],[161,160],[160,159],[159,158],[158,157],[157,173],[173,133]],Mn=[[46,53],[53,52],[52,65],[65,55],[70,63],[63,105],[105,66],[66,107]],Rn=[[469,470],[470,471],[471,472],[472,469]],Tn=[[10,338],[338,297],[297,332],[332,284],[284,251],[251,389],[389,356],[356,454],[454,323],[323,361],[361,288],[288,397],[397,365],[365,379],[379,378],[378,400],[400,377],[377,152],[152,148],[148,176],[176,149],[149,150],[150,136],[136,172],[172,58],[58,132],[132,93],[93,234],[234,127],[127,162],[162,21],[21,54],[54,103],[103,67],[67,109],[109,10]];function K0(e){let t=e.map(o=>o[0]);return t.push(e[e.length-1][1]),t}var vn={lips:K0(un),leftEye:K0(hn),leftEyebrow:K0(bn),leftIris:K0(gn),rightEye:K0(Pn),rightEyebrow:K0(Mn),rightIris:K0(Rn),faceOval:K0(Tn)},wn=Object.entries(vn).map(([e,t])=>t.map(o=>[o,e])).flat(),FA=new Map(wn),Qe=[61,146,91,181,84,17,314,405,321,375,291,185,40,39,37,0,267,269,270,409,78,95,88,178,87,14,317,402,318,324,308,191,80,81,82,13,312,311,310,415,76,77,90,180,85,16,315,404,320,307,306,184,74,73,72,11,302,303,304,408,62,96,89,179,86,15,316,403,319,325,292,183,42,41,38,12,268,271,272,407],le=[33,7,163,144,145,153,154,155,133,246,161,160,159,158,157,173,130,25,110,24,23,22,26,112,243,247,30,29,27,28,56,190,226,31,228,229,230,231,232,233,244,113,225,224,223,222,221,189,35,124,46,53,52,65,143,111,117,118,119,120,121,128,245,156,70,63,105,66,107,55,193],ye=[263,249,390,373,374,380,381,382,362,466,388,387,386,385,384,398,359,255,339,254,253,252,256,341,463,467,260,259,257,258,286,414,446,261,448,449,450,451,452,453,464,342,445,444,443,442,441,413,265,353,276,283,282,295,372,340,346,347,348,349,350,357,465,383,300,293,334,296,336,285,417];async function Jt(e,t){let o={lips:t.filter(s=>s.size===160)[0].dataSync(),irisL:t.filter(s=>s.size===10)[0].dataSync(),eyeL:t.filter(s=>s.size===142)[0].dataSync(),irisR:t.filter(s=>s.size===10)[1].dataSync(),eyeR:t.filter(s=>s.size===142)[1].dataSync()},n=le.reduce((s,a)=>s+=e[a][2],0)/le.length;for(let s=0;ss+=e[a][2],0)/ye.length;for(let s=0;sb()-S0.timestamp,n=S0.skipped<(((l=t.face.detector)==null?void 0:l.skipFrames)||0);!t.skipAllowed||!o||!n||S0.boxes.length===0?(S0.boxes=await ut(e,t),S0.timestamp=b(),S0.skipped=0):S0.skipped++;let r=[],s=[],a=0;for(let g=0;gF.shape[F.shape.length-1]===1),O=I.find(F=>F.shape[F.shape.length-1]===1404),D=C.dataSync();k.faceScore=Math.round(100*D[0])/100;let H=A.reshape(O,[-1,3]),Z=await H.array();if(k.faceScore<(((m=t.face.detector)==null?void 0:m.minConfidence)||1)){if(f.confidence=k.faceScore,(h=t.face.mesh)!=null&&h.keepInvalid){k.box=d2(f,e),k.boxRaw=f2(f,e),k.score=k.boxScore,k.mesh=f.landmarks.map(F=>[(f.startPoint[0]+f.endPoint[0])/2+(f.endPoint[0]+f.startPoint[0])*F[0]/Me(),(f.startPoint[1]+f.endPoint[1])/2+(f.endPoint[1]+f.startPoint[1])*F[1]/Me()]),k.meshRaw=k.mesh.map(F=>[F[0]/(e.shape[2]||0),F[1]/(e.shape[1]||0),(F[2]||0)/xe]);for(let F of Object.keys(Ae))k.annotations[F]=[k.mesh[Ae[F]]]}}else{(p=t.face.attention)!=null&&p.enabled?Z=await Jt(Z,I):(R=t.face.iris)!=null&&R.enabled&&(Z=await Ut(Z,k.tensor,t,xe)),k.mesh=xt(Z,f,M,j,xe),k.meshRaw=k.mesh.map(z=>[z[0]/(e.shape[2]||0),z[1]/(e.shape[1]||0),(z[2]||0)/xe]);for(let z of Object.keys(T0))k.annotations[z]=T0[z].map(h0=>k.mesh[h0]);k.score=k.faceScore;let F={...dt(k.mesh,f),confidence:f.confidence,landmarks:f.landmarks};k.box=d2(F,e),k.boxRaw=f2(F,e),s.push(F)}A.dispose([...I,H])}else{k.box=d2(f,e),k.boxRaw=f2(f,e),k.score=k.boxScore,k.mesh=f.landmarks.map(I=>[(f.startPoint[0]+f.endPoint[0])/2+(f.endPoint[0]+f.startPoint[0])*I[0]/Me(),(f.startPoint[1]+f.endPoint[1])/2+(f.endPoint[1]+f.startPoint[1])*I[1]/Me()]),k.meshRaw=k.mesh.map(I=>[I[0]/(e.shape[2]||0),I[1]/(e.shape[1]||0),(I[2]||0)/xe]);for(let I of Object.keys(Ae))k.annotations[I]=[k.mesh[Ae[I]]]}k.score>(((P=t.face.detector)==null?void 0:P.minConfidence)||1)?r.push(k):A.dispose(k.tensor)}return S0.boxes=s,r}async function _t(e){var t,o,n,r,s,a;return v.initial&&(s0=null),((o=(t=e==null?void 0:e.face)==null?void 0:t.attention)==null?void 0:o.enabled)&&(s0==null?void 0:s0.signature)&&Object.keys(((n=s0==null?void 0:s0.signature)==null?void 0:n.outputs)||{}).length<6&&(s0=null),s0?e.debug&&u("cached model:",s0.modelUrl):(r=e.face.attention)!=null&&r.enabled?s0=await W((s=e.face.attention)==null?void 0:s.modelPath):s0=await W((a=e.face.mesh)==null?void 0:a.modelPath),xe=s0.inputs[0].shape?s0.inputs[0].shape[2]:0,s0}var $t=se,e3=Ye;var m0,v2=[],t3=0,o3=0,O5=Number.MAX_SAFE_INTEGER;async function n3(e){var t;return v.initial&&(m0=null),m0?e.debug&&u("cached model:",m0.modelUrl):m0=await W((t=e.face.description)==null?void 0:t.modelPath),m0}function W5(e){let t=e.image||e.tensor||e;if(!(m0!=null&&m0.inputs[0].shape))return t;let o=A.image.resizeBilinear(t,[m0.inputs[0].shape[2],m0.inputs[0].shape[1]],!1),n=A.mul(o,L.tf255);return A.dispose(o),n}async function L5(e,t,o,n){var a,i,l,x;if(!m0)return{age:0,gender:"unknown",genderScore:0,descriptor:[]};let r=O5<(((a=t.face.description)==null?void 0:a.skipFrames)||0),s=(((i=t.face.description)==null?void 0:i.skipTime)||0)>b()-t3;return t.skipAllowed&&r&&s&&o3===n&&((l=v2[o])==null?void 0:l.age)&&((x=v2[o])==null?void 0:x.age)>0?(O5++,v2[o]):(O5=0,new Promise(async d=>{var c,m;let y={age:0,gender:"unknown",genderScore:0,descriptor:[]};if((c=t.face.description)!=null&&c.enabled){let h=W5(e),p=m0==null?void 0:m0.execute(h);t3=b(),A.dispose(h);let P=await(await p.find(O=>O.shape[1]===1)).data(),g=Math.trunc(200*Math.abs(P[0]-.5))/100;g>(((m=t.face.description)==null?void 0:m.minConfidence)||0)&&(y.gender=P[0]<=.5?"female":"male",y.genderScore=Math.min(.99,g));let f=A.argMax(p.find(O=>O.shape[1]===100),1),M=(await f.data())[0];A.dispose(f);let k=await p.find(O=>O.shape[1]===100).data();y.age=Math.round(k[M-1]>k[M+1]?10*M-100*k[M-1]:10*M+100*k[M+1])/10;let I=p.find(O=>O.shape[1]===1024),C=I?await I.data():[];y.descriptor=Array.from(C),p.forEach(O=>A.dispose(O))}v2[o]=y,o3=n,d(y)}))}function w2(e){return[Math.abs(e.endPoint[0]-e.startPoint[0]),Math.abs(e.endPoint[1]-e.startPoint[1])]}function _e(e){return[e.startPoint[0]+(e.endPoint[0]-e.startPoint[0])/2,e.startPoint[1]+(e.endPoint[1]-e.startPoint[1])/2]}function s3(e,t,o){let n=t.shape[1],r=t.shape[2],s=[[e.startPoint[1]/n,e.startPoint[0]/r,e.endPoint[1]/n,e.endPoint[0]/r]];return A.image.cropAndResize(t,s,[0],o)}function a3(e,t){let o=[e.startPoint[0]*t[0],e.startPoint[1]*t[1]],n=[e.endPoint[0]*t[0],e.endPoint[1]*t[1]],r=e.palmLandmarks.map(s=>[s[0]*t[0],s[1]*t[1]]);return{startPoint:o,endPoint:n,palmLandmarks:r,confidence:e.confidence}}function k2(e,t=1.5){let o=_e(e),n=w2(e),r=[t*n[0]/2,t*n[1]/2],s=[o[0]-r[0],o[1]-r[1]],a=[o[0]+r[0],o[1]+r[1]];return{startPoint:s,endPoint:a,palmLandmarks:e.palmLandmarks}}function E2(e){let t=_e(e),o=w2(e),r=Math.max(...o)/2,s=[t[0]-r,t[1]-r],a=[t[0]+r,t[1]+r];return{startPoint:s,endPoint:a,palmLandmarks:e.palmLandmarks}}function En(e){return e-2*Math.PI*Math.floor((e+Math.PI)/(2*Math.PI))}function i3(e,t){let o=Math.PI/2-Math.atan2(-(t[1]-e[1]),t[0]-e[0]);return En(o)}var r3=(e,t)=>[[1,0,e],[0,1,t],[0,0,1]];function J0(e,t){let o=0;for(let n=0;n[o.x,o.y]),this.anchorsTensor=A.tensor2d(this.anchors),this.inputSize=this.model&&this.model.inputs&&this.model.inputs[0].shape?this.model.inputs[0].shape[2]:0,this.inputSizeTensor=A.tensor1d([this.inputSize,this.inputSize]),this.doubleInputSizeTensor=A.tensor1d([this.inputSize*2,this.inputSize*2])}normalizeBoxes(t){let o={};o.boxOffsets=A.slice(t,[0,0],[-1,2]),o.boxSizes=A.slice(t,[0,2],[-1,2]),o.div=A.div(o.boxOffsets,this.inputSizeTensor),o.boxCenterPoints=A.add(o.div,this.anchorsTensor),o.halfBoxSizes=A.div(o.boxSizes,this.doubleInputSizeTensor),o.sub=A.sub(o.boxCenterPoints,o.halfBoxSizes),o.startPoints=A.mul(o.sub,this.inputSizeTensor),o.add=A.add(o.boxCenterPoints,o.halfBoxSizes),o.endPoints=A.mul(o.add,this.inputSizeTensor);let n=A.concat2d([o.startPoints,o.endPoints],1);return Object.keys(o).forEach(r=>A.dispose(o[r])),n}normalizeLandmarks(t,o){let n={};n.reshape=A.reshape(t,[-1,7,2]),n.div=A.div(n.reshape,this.inputSizeTensor),n.landmarks=A.add(n.div,this.anchors[o]);let r=A.mul(n.landmarks,this.inputSizeTensor);return Object.keys(n).forEach(s=>A.dispose(n[s])),r}async predict(t,o){let n={};n.resize=A.image.resizeBilinear(t,[this.inputSize,this.inputSize]),n.div=A.div(n.resize,L.tf127),n.image=A.sub(n.div,L.tf1),n.batched=this.model.execute(n.image),n.predictions=A.squeeze(n.batched),n.slice=A.slice(n.predictions,[0,0],[-1,1]),n.sigmoid=A.sigmoid(n.slice),n.scores=A.squeeze(n.sigmoid);let r=await n.scores.data();n.boxes=A.slice(n.predictions,[0,1],[-1,4]),n.norm=this.normalizeBoxes(n.boxes),n.nms=await A.image.nonMaxSuppressionAsync(n.norm,n.scores,3*o.hand.maxDetected,o.hand.iouThreshold,o.hand.minConfidence);let s=await n.nms.array(),a=[];for(let i of s){let l={};l.box=A.slice(n.norm,[i,0],[1,-1]),l.slice=A.slice(n.predictions,[i,5],[1,14]),l.norm=this.normalizeLandmarks(l.slice,i),l.palmLandmarks=A.reshape(l.norm,[-1,2]);let x=await l.box.data(),d=x.slice(0,2),y=x.slice(2,4),c=await l.palmLandmarks.array(),m={startPoint:d,endPoint:y,palmLandmarks:c,confidence:r[i]},h=a3(m,[t.shape[2]/this.inputSize,t.shape[1]/this.inputSize]);a.push(h),Object.keys(l).forEach(p=>A.dispose(l[p]))}return Object.keys(n).forEach(i=>A.dispose(n[i])),a}};var Cn=5,c3=1.65,d3=[0,5,9,13,17,1,2],In=0,Nn=2,f3=0,S2=class{constructor(t,o){w(this,"handDetector");w(this,"handPoseModel");w(this,"inputSize");w(this,"storedBoxes");w(this,"skipped");w(this,"detectedHands");this.handDetector=t,this.handPoseModel=o,this.inputSize=this.handPoseModel&&this.handPoseModel.inputs[0].shape?this.handPoseModel.inputs[0].shape[2]:0,this.storedBoxes=[],this.skipped=Number.MAX_SAFE_INTEGER,this.detectedHands=0}calculateLandmarksBoundingBox(t){let o=t.map(a=>a[0]),n=t.map(a=>a[1]),r=[Math.min(...o),Math.min(...n)],s=[Math.max(...o),Math.max(...n)];return{startPoint:r,endPoint:s}}getBoxForPalmLandmarks(t,o){let n=t.map(s=>B5([...s,1],o)),r=this.calculateLandmarksBoundingBox(n);return k2(E2(r),Cn)}getBoxForHandLandmarks(t){let o=this.calculateLandmarksBoundingBox(t),n=k2(E2(o),c3);n.palmLandmarks=[];for(let r=0;r[a[0]*(m[0]-this.inputSize/2),a[1]*(m[1]-this.inputSize/2),a[2]*m[2]]),l=G5(n,[0,0]),x=i.map(m=>[...B5(m,l),m[2]]),d=l3(r),y=[..._e(o),1],c=[J0(y,d[0]),J0(y,d[1])];return x.map(m=>[Math.trunc(m[0]+c[0]),Math.trunc(m[1]+c[1]),Math.trunc(m[2])])}async estimateHands(t,o){let n=!1,r,s=(o.hand.skipTime||0)>b()-f3,a=this.skipped<(o.hand.skipFrames||0);o.skipAllowed&&s&&a&&(r=await this.handDetector.predict(t,o),this.skipped=0),o.skipAllowed&&this.skipped++,r&&r.length>0&&(r.length!==this.detectedHands&&this.detectedHands!==o.hand.maxDetected||!o.hand.landmarks)&&(this.detectedHands=0,this.storedBoxes=[...r],this.storedBoxes.length>0&&(n=!0));let i=[];for(let l=0;l=o.hand.minConfidence/4){let j=A.reshape(f,[-1,3]),k=await j.array();A.dispose(f),A.dispose(j);let I=this.transformRawCoords(k,p,d,h),C=this.getBoxForHandLandmarks(I);this.storedBoxes[l]={...C,confidence:M};let O={landmarks:I,confidence:M,boxConfidence:x.confidence,fingerConfidence:M,box:{topLeft:C.startPoint,bottomRight:C.endPoint}};i.push(O)}else this.storedBoxes[l]=null;A.dispose(f)}else{let d=k2(E2(x),c3),y={confidence:x.confidence,boxConfidence:x.confidence,fingerConfidence:0,box:{topLeft:d.startPoint,bottomRight:d.endPoint},landmarks:[]};i.push(y)}}return this.storedBoxes=this.storedBoxes.filter(l=>l!==null),this.detectedHands=i.length,i.length>o.hand.maxDetected&&(i.length=o.hand.maxDetected),i}};var x0={thumb:0,index:1,middle:2,ring:3,pinky:4,all:[0,1,2,3,4],nameMapping:{0:"thumb",1:"index",2:"middle",3:"ring",4:"pinky"},pointsMapping:{0:[[0,1],[1,2],[2,3],[3,4]],1:[[0,5],[5,6],[6,7],[7,8]],2:[[0,9],[9,10],[10,11],[11,12]],3:[[0,13],[13,14],[14,15],[15,16]],4:[[0,17],[17,18],[18,19],[19,20]]},getName:e=>x0.nameMapping[e],getPoints:e=>x0.pointsMapping[e]},_0={none:0,half:1,full:2,nameMapping:{0:"none",1:"half",2:"full"},getName:e=>_0.nameMapping[e]},K={verticalUp:0,verticalDown:1,horizontalLeft:2,horizontalRight:3,diagonalUpRight:4,diagonalUpLeft:5,diagonalDownRight:6,diagonalDownLeft:7,nameMapping:{0:"verticalUp",1:"verticalDown",2:"horizontalLeft",3:"horizontalRight",4:"diagonalUpRight",5:"diagonalUpLeft",6:"diagonalDownRight",7:"diagonalDownLeft"},getName:e=>K.nameMapping[e]},Q0=class{constructor(t){w(this,"name");w(this,"curls");w(this,"directions");w(this,"weights");w(this,"weightsRelative");this.name=t,this.curls={},this.directions={},this.weights=[1,1,1,1,1],this.weightsRelative=[1,1,1,1,1]}curl(t,o,n){typeof this.curls[t]=="undefined"&&(this.curls[t]=[]),this.curls[t].push([o,n])}direction(t,o,n){this.directions[t]||(this.directions[t]=[]),this.directions[t].push([o,n])}weight(t,o){this.weights[t]=o;let n=this.weights.reduce((r,s)=>r+s,0);this.weightsRelative=this.weights.map(r=>r*5/n)}matchAgainst(t,o){let n=0;for(let r in t){let s=t[r],a=this.curls[r];if(typeof a=="undefined"){n+=this.weightsRelative[r];continue}for(let[i,l]of a)if(s===i){n+=l*this.weightsRelative[r];break}}for(let r in o){let s=o[r],a=this.directions[r];if(typeof a=="undefined"){n+=this.weightsRelative[r];continue}for(let[i,l]of a)if(s===i){n+=l*this.weightsRelative[r];break}}return n/10}};var{thumb:v0,index:B0,middle:H0,ring:ce,pinky:de}=x0,{none:w0,half:Wn,full:k0}=_0,{verticalUp:ke,verticalDown:$A,horizontalLeft:H5,horizontalRight:Ln,diagonalUpRight:Fn,diagonalUpLeft:Ee,diagonalDownRight:e7,diagonalDownLeft:t7}=K,$0=new Q0("thumbs up");$0.curl(v0,w0,1);$0.direction(v0,ke,1);$0.direction(v0,Ee,.25);$0.direction(v0,Fn,.25);for(let e of[x0.index,x0.middle,x0.ring,x0.pinky])$0.curl(e,k0,1),$0.direction(e,H5,1),$0.direction(e,Ln,1);var e0=new Q0("victory");e0.curl(v0,Wn,.5);e0.curl(v0,w0,.5);e0.direction(v0,ke,1);e0.direction(v0,Ee,1);e0.curl(B0,w0,1);e0.direction(B0,ke,.75);e0.direction(B0,Ee,1);e0.curl(H0,w0,1);e0.direction(H0,ke,1);e0.direction(H0,Ee,.75);e0.curl(ce,k0,1);e0.direction(ce,ke,.2);e0.direction(ce,Ee,1);e0.direction(ce,H5,.2);e0.curl(de,k0,1);e0.direction(de,ke,.2);e0.direction(de,Ee,1);e0.direction(de,H5,.2);e0.weight(B0,2);e0.weight(H0,2);var ee=new Q0("point");ee.curl(v0,k0,1);ee.curl(B0,w0,.5);ee.curl(H0,k0,.5);ee.curl(ce,k0,.5);ee.curl(de,k0,.5);ee.weight(B0,2);ee.weight(H0,2);var te=new Q0("middle finger");te.curl(v0,w0,1);te.curl(B0,k0,.5);te.curl(H0,k0,.5);te.curl(ce,k0,.5);te.curl(de,k0,.5);te.weight(B0,2);te.weight(H0,2);var ze=new Q0("open palm");ze.curl(v0,w0,.75);ze.curl(B0,w0,.75);ze.curl(H0,w0,.75);ze.curl(ce,w0,.75);ze.curl(de,w0,.75);var m3=[$0,e0,ee,te,ze];var Gn=.7,fe={HALF_CURL_START_LIMIT:60,NO_CURL_START_LIMIT:130,DISTANCE_VOTE_POWER:1.1,SINGLE_ANGLE_VOTE_POWER:.9,TOTAL_ANGLE_VOTE_POWER:1.6};function p3(e,t,o,n){let r=(t-n)/(e-o),s=Math.atan(r)*180/Math.PI;return s<=0?s=-s:s>0&&(s=180-s),s}function h3(e,t){if(!e||!t)return[0,0];let o=p3(e[0],e[1],t[0],t[1]);if(e.length===2)return o;let n=p3(e[1],e[2],t[1],t[2]);return[o,n]}function u3(e,t=1){let o=0,n=0,r=0;return e>=75&&e<=105?o=1*t:e>=25&&e<=155?n=1*t:r=1*t,[o,n,r]}function Bn(e,t,o){let n=e[0]-t[0],r=e[0]-o[0],s=t[0]-o[0],a=e[1]-t[1],i=e[1]-o[1],l=t[1]-o[1],x=e[2]-t[2],d=e[2]-o[2],y=t[2]-o[2],c=Math.sqrt(n*n+a*a+x*x),m=Math.sqrt(r*r+i*i+d*d),h=Math.sqrt(s*s+l*l+y*y),p=(h*h+c*c-m*m)/(2*h*c);p>1?p=1:p<-1&&(p=-1);let R=Math.acos(p);R=57.2958*R%180;let P;return R>fe.NO_CURL_START_LIMIT?P=_0.none:R>fe.HALF_CURL_START_LIMIT?P=_0.half:P=_0.full,P}function b3(e,t,o,n){let r;return n===Math.abs(e)?e>0?r=K.horizontalLeft:r=K.horizontalRight:n===Math.abs(t)?t>0?r=K.horizontalLeft:r=K.horizontalRight:o>0?r=K.horizontalLeft:r=K.horizontalRight,r}function g3(e,t,o,n){let r;return n===Math.abs(e)?e<0?r=K.verticalDown:r=K.verticalUp:n===Math.abs(t)?t<0?r=K.verticalDown:r=K.verticalUp:o<0?r=K.verticalDown:r=K.verticalUp,r}function Hn(e,t,o,n,r,s,a,i){let l,x=g3(e,t,o,n),d=b3(r,s,a,i);return x===K.verticalUp?d===K.horizontalLeft?l=K.diagonalUpLeft:l=K.diagonalUpRight:d===K.horizontalLeft?l=K.diagonalDownLeft:l=K.diagonalDownRight,l}function Vn(e,t,o,n){let r=e[0]-t[0],s=e[0]-o[0],a=t[0]-o[0],i=e[1]-t[1],l=e[1]-o[1],x=t[1]-o[1],d=Math.max(Math.abs(r),Math.abs(s),Math.abs(a)),y=Math.max(Math.abs(i),Math.abs(l),Math.abs(x)),c=0,m=0,h=0,p=y/(d+1e-5);p>1.5?c+=fe.DISTANCE_VOTE_POWER:p>.66?m+=fe.DISTANCE_VOTE_POWER:h+=fe.DISTANCE_VOTE_POWER;let R=Math.sqrt(r*r+i*i),P=Math.sqrt(s*s+l*l),g=Math.sqrt(a*a+x*x),f=Math.max(R,P,g),M=e[0],j=e[1],k=o[0],I=o[1];f===R?(k=o[0],I=o[1]):f===g&&(M=t[0],j=t[1]);let D=h3([M,j],[k,I]),H=u3(D,fe.TOTAL_ANGLE_VOTE_POWER);c+=H[0],m+=H[1],h+=H[2];for(let F of n){let z=u3(F,fe.SINGLE_ANGLE_VOTE_POWER);c+=z[0],m+=z[1],h+=z[2]}let Z;return c===Math.max(c,m,h)?Z=g3(l,i,x,y):h===Math.max(m,h)?Z=b3(s,r,a,d):Z=Hn(l,i,x,y,s,r,a,d),Z}function P3(e){let t=[],o=[],n=[],r=[];if(!e)return{curls:n,directions:r};for(let s of x0.all){let a=x0.getPoints(s),i=[],l=[];for(let x of a){let d=e[x[0]],y=e[x[1]],c=h3(d,y),m=c[0],h=c[1];i.push(m),l.push(h)}t.push(i),o.push(l)}for(let s of x0.all){let a=s===x0.thumb?1:0,i=x0.getPoints(s),l=e[i[a][0]],x=e[i[a+1][1]],d=e[i[3][1]],y=Bn(l,x,d),c=Vn(l,x,d,t[s].slice(a));n[s]=y,r[s]=c}return{curls:n,directions:r}}function j2(e){if(!e||e.length===0)return null;let t=P3(e),o={};for(let n of x0.all)o[x0.getName(n)]={curl:_0.getName(t.curls[n]),direction:K.getName(t.directions[n])};return o}function M3(e){let t=[];if(!e||e.length===0)return t;let o=P3(e);for(let n of m3){let r=n.matchAgainst(o.curls,o.directions);r>=Gn&&t.push({name:n.name,confidence:r})}return t}var R3={thumb:[1,2,3,4],index:[5,6,7,8],middle:[9,10,11,12],ring:[13,14,15,16],pinky:[17,18,19,20],palm:[0]},Se,je,T3;async function Z5(e,t){let o=await T3.estimateHands(e,t);if(!o)return[];let n=[];for(let r=0;ro[r].landmarks[y]);let a=o[r].landmarks,i=[Number.MAX_SAFE_INTEGER,Number.MAX_SAFE_INTEGER,0,0],l=[0,0,0,0];if(a&&a.length>0){for(let d of a)d[0]i[2]&&(i[2]=d[0]),d[1]>i[3]&&(i[3]=d[1]);i[2]-=i[0],i[3]-=i[1],l=[i[0]/(e.shape[2]||0),i[1]/(e.shape[1]||0),i[2]/(e.shape[2]||0),i[3]/(e.shape[1]||0)]}else i=o[r].box?[Math.trunc(Math.max(0,o[r].box.topLeft[0])),Math.trunc(Math.max(0,o[r].box.topLeft[1])),Math.trunc(Math.min(e.shape[2]||0,o[r].box.bottomRight[0])-Math.max(0,o[r].box.topLeft[0])),Math.trunc(Math.min(e.shape[1]||0,o[r].box.bottomRight[1])-Math.max(0,o[r].box.topLeft[1]))]:[0,0,0,0],l=[o[r].box.topLeft[0]/(e.shape[2]||0),o[r].box.topLeft[1]/(e.shape[1]||0),(o[r].box.bottomRight[0]-o[r].box.topLeft[0])/(e.shape[2]||0),(o[r].box.bottomRight[1]-o[r].box.topLeft[1])/(e.shape[1]||0)];let x=j2(a);n.push({id:r,score:Math.round(100*o[r].confidence)/100,boxScore:Math.round(100*o[r].boxConfidence)/100,fingerScore:Math.round(100*o[r].fingerConfidence)/100,label:"hand",box:i,boxRaw:l,keypoints:a,annotations:s,landmarks:x})}return n}async function D5(e){var o,n;v.initial&&(Se=null,je=null),!Se||!je?[Se,je]=await Promise.all([e.hand.enabled?W((o=e.hand.detector)==null?void 0:o.modelPath):null,e.hand.landmarks?W((n=e.hand.skeleton)==null?void 0:n.modelPath):null]):(e.debug&&u("cached model:",Se.modelUrl),e.debug&&u("cached model:",je.modelUrl));let t=new z2(Se);return T3=new S2(t,je),[Se,je]}var o0=[null,null],Zn=["StatefulPartitionedCall/Postprocessor/Slice","StatefulPartitionedCall/Postprocessor/ExpandDims_1"],oe=[[0,0],[0,0]],Dn=["hand","fist","pinch","point","face","tip","pinchtip"],w3=4,k3=1.6,Xn=512,qn=1.4,C2=Number.MAX_SAFE_INTEGER,X5=0,V0=[0,0],Q={boxes:[],hands:[]},E3={thumb:[1,2,3,4],index:[5,6,7,8],middle:[9,10,11,12],ring:[13,14,15,16],pinky:[17,18,19,20],base:[0],palm:[0,17,13,9,5,1,0]};async function z3(e){var t;if(v.initial&&(o0[0]=null),o0[0])e.debug&&u("cached model:",o0[0].modelUrl);else{I2(["tensorlistreserve","enter","tensorlistfromtensor","merge","loopcond","switch","exit","tensorliststack","nextiteration","tensorlistsetitem","tensorlistgetitem","reciprocal","shape","split","where"],e),o0[0]=await W((t=e.hand.detector)==null?void 0:t.modelPath);let o=Object.values(o0[0].modelSignature.inputs);oe[0][0]=Array.isArray(o)?parseInt(o[0].tensorShape.dim[1].size):0,oe[0][1]=Array.isArray(o)?parseInt(o[0].tensorShape.dim[2].size):0}return o0[0]}async function S3(e){var t;if(v.initial&&(o0[1]=null),o0[1])e.debug&&u("cached model:",o0[1].modelUrl);else{o0[1]=await W((t=e.hand.skeleton)==null?void 0:t.modelPath);let o=Object.values(o0[1].modelSignature.inputs);oe[1][0]=Array.isArray(o)?parseInt(o[0].tensorShape.dim[1].size):0,oe[1][1]=Array.isArray(o)?parseInt(o[0].tensorShape.dim[2].size):0}return o0[1]}async function Un(e,t){let o=[];if(!e||!o0[0])return o;let n={},r=(e.shape[2]||1)/(e.shape[1]||1),s=Math.min(Math.round((e.shape[1]||0)/8)*8,Xn),a=Math.round(s*r/8)*8;n.resize=A.image.resizeBilinear(e,[s,a]),n.cast=A.cast(n.resize,"int32"),[n.rawScores,n.rawBoxes]=await o0[0].executeAsync(n.cast,Zn),n.boxes=A.squeeze(n.rawBoxes,[0,2]),n.scores=A.squeeze(n.rawScores,[0]);let i=A.unstack(n.scores,1);A.dispose(i[w3]),i.splice(w3,1),n.filtered=A.stack(i,1),A.dispose(i),n.max=A.max(n.filtered,1),n.argmax=A.argMax(n.filtered,1);let l=0;n.nms=await A.image.nonMaxSuppressionAsync(n.boxes,n.max,(t.hand.maxDetected||0)+1,t.hand.iouThreshold||0,t.hand.minConfidence||1);let x=await n.nms.data(),d=await n.max.data(),y=await n.argmax.data();for(let c of Array.from(x)){let m=A.slice(n.boxes,c,1),h=await m.data();A.dispose(m);let p=[h[1],h[0],h[3]-h[1],h[2]-h[0]],R=b2(p,qn),P=[Math.trunc(p[0]*V0[0]),Math.trunc(p[1]*V0[1]),Math.trunc(p[2]*V0[0]),Math.trunc(p[3]*V0[1])],g=d[c],f=Dn[y[c]],M={id:l++,score:g,box:P,boxRaw:R,label:f};o.push(M)}return Object.keys(n).forEach(c=>A.dispose(n[c])),o.sort((c,m)=>m.score-c.score),o.length>(t.hand.maxDetected||1)&&(o.length=t.hand.maxDetected||1),o}async function q5(e,t,o){let n={id:t.id,score:Math.round(100*t.score)/100,boxScore:Math.round(100*t.score)/100,fingerScore:0,box:t.box,boxRaw:t.boxRaw,label:t.label,keypoints:[],landmarks:{},annotations:{}};if(e&&o0[1]&&o.hand.landmarks&&t.score>(o.hand.minConfidence||0)){let r={},s=[t.boxRaw[1],t.boxRaw[0],t.boxRaw[3]+t.boxRaw[1],t.boxRaw[2]+t.boxRaw[0]];r.crop=A.image.cropAndResize(e,[s],[0],[oe[1][0],oe[1][1]],"bilinear"),r.div=A.div(r.crop,L.tf255),[r.score,r.keypoints]=o0[1].execute(r.div,["Identity_1","Identity"]);let a=(await r.score.data())[0],i=(100-Math.trunc(100/(1+Math.exp(a))))/100;if(i>=(o.hand.minConfidence||0)){n.fingerScore=i,r.reshaped=A.reshape(r.keypoints,[-1,3]);let d=(await r.reshaped.array()).map(y=>[y[0]/oe[1][1],y[1]/oe[1][0],y[2]||0]).map(y=>[y[0]*t.boxRaw[2],y[1]*t.boxRaw[3],y[2]||0]);n.keypoints=d.map(y=>[V0[0]*(y[0]+t.boxRaw[0]),V0[1]*(y[1]+t.boxRaw[1]),y[2]||0]),n.landmarks=j2(n.keypoints);for(let y of Object.keys(E3))n.annotations[y]=E3[y].map(c=>n.landmarks&&n.keypoints[c]?n.keypoints[c]:null)}Object.keys(r).forEach(l=>A.dispose(r[l]))}return n}async function U5(e,t){var r,s;if(!o0[0]||!o0[1]||!((r=o0[0])!=null&&r.inputs[0].shape)||!((s=o0[1])!=null&&s.inputs[0].shape))return[];V0=[e.shape[2]||0,e.shape[1]||0],C2++;let o=(t.hand.skipTime||0)>b()-X5,n=C2<(t.hand.skipFrames||0);return t.skipAllowed&&o&&n?Q.hands:new Promise(async a=>{let i=3*(t.hand.skipTime||0)>b()-X5,l=C2<3*(t.hand.skipFrames||0);t.skipAllowed&&Q.hands.length===t.hand.maxDetected?Q.hands=await Promise.all(Q.boxes.map(d=>q5(e,d,t))):t.skipAllowed&&i&&l&&Q.hands.length>0?Q.hands=await Promise.all(Q.boxes.map(d=>q5(e,d,t))):(Q.boxes=await Un(e,t),X5=b(),Q.hands=await Promise.all(Q.boxes.map(d=>q5(e,d,t))),C2=0);let x=[...Q.boxes];if(Q.boxes.length=0,t.cacheSensitivity>0)for(let d=0;d.05&&y.box[3]/(e.shape[1]||1)>.05&&Q.hands[d].fingerScore&&Q.hands[d].fingerScore>(t.hand.minConfidence||0)){let c=b2(y.box,k3),m=b2(y.boxRaw,k3);Q.boxes.push({...x[d],box:c,boxRaw:m})}}for(let d=0;db()-I3,s=Y5<(((i=t.face.liveness)==null?void 0:i.skipFrames)||0);return t.skipAllowed&&r&&s&&C3===n&&N2[o]?(Y5++,N2[o]):(Y5=0,new Promise(async l=>{let x=A.image.resizeBilinear(e,[a0!=null&&a0.inputs[0].shape?a0.inputs[0].shape[2]:0,a0!=null&&a0.inputs[0].shape?a0.inputs[0].shape[1]:0],!1),d=a0==null?void 0:a0.execute(x),y=(await d.data())[0];N2[o]=Math.round(100*y)/100,C3=n,I3=b(),A.dispose([x,d]),l(N2[o])}))}var $e={};ne($e,{connected:()=>W2,horizontal:()=>J5,kpt:()=>O2,relative:()=>_5,vertical:()=>Q5});var O2=["nose","leftEye","rightEye","leftEar","rightEar","leftShoulder","rightShoulder","leftElbow","rightElbow","leftWrist","rightWrist","leftHip","rightHip","leftKnee","rightKnee","leftAnkle","rightAnkle"],J5=[["leftEye","rightEye"],["leftEar","rightEar"],["leftShoulder","rightShoulder"],["leftElbow","rightElbow"],["leftWrist","rightWrist"],["leftHip","rightHip"],["leftKnee","rightKnee"],["leftAnkle","rightAnkle"]],Q5=[["leftKnee","leftShoulder"],["rightKnee","rightShoulder"],["leftAnkle","leftKnee"],["rightAnkle","rightKnee"]],_5=[[["leftHip","rightHip"],["leftShoulder","rightShoulder"]],[["leftElbow","rightElbow"],["leftShoulder","rightShoulder"]]],W2={leftLeg:["leftHip","leftKnee","leftAnkle"],rightLeg:["rightHip","rightKnee","rightAnkle"],torso:["leftShoulder","rightShoulder","rightHip","leftHip","leftShoulder"],leftArm:["leftShoulder","leftElbow","leftWrist"],rightArm:["rightShoulder","rightElbow","rightWrist"],head:[]};var W3=.005,p0={keypoints:[],padding:[[0,0],[0,0],[0,0],[0,0]]};function $5(e){for(let t of J5){let o=e.keypoints.findIndex(r=>r.part===t[0]),n=e.keypoints.findIndex(r=>r.part===t[1]);if(e.keypoints[o]&&e.keypoints[n]&&e.keypoints[o].position[0]r&&r.part===t[0]),n=e.keypoints.findIndex(r=>r&&r.part===t[1]);e.keypoints[o]&&e.keypoints[n]&&e.keypoints[o].position[1]x&&x.part===t[0]),r=e.keypoints.findIndex(x=>x&&x.part===t[1]),s=e.keypoints.findIndex(x=>x&&x.part===o[0]),a=e.keypoints.findIndex(x=>x&&x.part===o[1]);if(!e.keypoints[s]||!e.keypoints[a])continue;let i=e.keypoints[n]?[Math.abs(e.keypoints[s].position[0]-e.keypoints[n].position[0]),Math.abs(e.keypoints[a].position[0]-e.keypoints[n].position[0])]:[0,0],l=e.keypoints[r]?[Math.abs(e.keypoints[a].position[0]-e.keypoints[r].position[0]),Math.abs(e.keypoints[s].position[0]-e.keypoints[r].position[0])]:[0,0];if(i[0]>i[1]||l[0]>l[1]){let x=e.keypoints[n];e.keypoints[n]=e.keypoints[r],e.keypoints[r]=x}}}function L3(e){for(let t=0;te.shape[1]?Math.trunc((e.shape[2]-e.shape[1])/2):0,e.shape[2]>e.shape[1]?Math.trunc((e.shape[2]-e.shape[1])/2):0],[e.shape[1]>e.shape[2]?Math.trunc((e.shape[1]-e.shape[2])/2):0,e.shape[1]>e.shape[2]?Math.trunc((e.shape[1]-e.shape[2])/2):0],[0,0]],o.pad=A.pad(e,p0.padding),o.resize=A.image.resizeBilinear(o.pad,[t,t]);let n=A.cast(o.resize,"int32");return Object.keys(o).forEach(r=>A.dispose(o[r])),n}function G3(e,t){e.keypoints=e.keypoints.filter(n=>n&&n.position);for(let n of e.keypoints)n.position=[n.position[0]*(t[0]+p0.padding[2][0]+p0.padding[2][1])/t[0]-p0.padding[2][0],n.position[1]*(t[1]+p0.padding[1][0]+p0.padding[1][1])/t[1]-p0.padding[1][0]],n.positionRaw=[n.position[0]/t[0],n.position[1]/t[1]];let o=L0(e.keypoints.map(n=>n.position),t);return e.box=o.box,e.boxRaw=o.boxRaw,e}var u0,L2=0,e1=Number.MAX_SAFE_INTEGER,me={boxes:[],bodies:[],last:0};async function B3(e){return v.initial&&(u0=null),u0?e.debug&&u("cached model:",u0.modelUrl):(I2(["size"],e),u0=await W(e.body.modelPath)),L2=u0.inputs[0].shape?u0.inputs[0].shape[2]:0,L2<64&&(L2=256),u0}async function Kn(e,t,o){let n=e[0][0],r=[],s=0;for(let d=0;dt.body.minConfidence){let y=[n[d][1],n[d][0]];r.push({score:Math.round(100*s)/100,part:O2[d],positionRaw:y,position:[Math.round((o.shape[2]||0)*y[0]),Math.round((o.shape[1]||0)*y[1])]})}s=r.reduce((d,y)=>y.score>d?y.score:d,0);let a=[],i=L0(r.map(d=>d.position),[o.shape[2],o.shape[1]]),l={};for(let[d,y]of Object.entries(W2)){let c=[];for(let m=0;mR.part===y[m]),p=r.find(R=>R.part===y[m+1]);h&&p&&h.score>(t.body.minConfidence||0)&&p.score>(t.body.minConfidence||0)&&c.push([h.position,p.position])}l[d]=c}let x={id:0,score:s,box:i.box,boxRaw:i.boxRaw,keypoints:r,annotations:l};return $5(x),a.push(x),a}async function Jn(e,t,o){let n=[];for(let r=0;rt.body.minConfidence){let i=[];for(let y=0;y<17;y++){let c=s[3*y+2];if(c>t.body.minConfidence){let m=[s[3*y+1],s[3*y+0]];i.push({part:O2[y],score:Math.round(100*c)/100,positionRaw:m,position:[Math.round((o.shape[2]||0)*m[0]),Math.round((o.shape[1]||0)*m[1])]})}}let l=L0(i.map(y=>y.position),[o.shape[2],o.shape[1]]),x={};for(let[y,c]of Object.entries(W2)){let m=[];for(let h=0;hP.part===c[h]),R=i.find(P=>P.part===c[h+1]);p&&R&&p.score>(t.body.minConfidence||0)&&R.score>(t.body.minConfidence||0)&&m.push([p.position,R.position])}x[y]=m}let d={id:r,score:a,box:l.box,boxRaw:l.boxRaw,keypoints:[...i],annotations:x};$5(d),n.push(d)}}return n.sort((r,s)=>s.score-r.score),n.length>t.body.maxDetected&&(n.length=t.body.maxDetected),n}async function t1(e,t){if(!u0||!(u0!=null&&u0.inputs[0].shape))return[];t.skipAllowed||(me.boxes.length=0),e1++;let o=(t.body.skipTime||0)>b()-me.last,n=e1<(t.body.skipFrames||0);return t.skipAllowed&&o&&n?me.bodies:new Promise(async r=>{let s={};e1=0,s.input=F3(e,L2),s.res=u0==null?void 0:u0.execute(s.input),me.last=b();let a=await s.res.array();me.bodies=s.res.shape[2]===17?await Kn(a,t,e):await Jn(a,t,e);for(let i of me.bodies)G3(i,[e.shape[2]||1,e.shape[1]||1]),L3(i.keypoints);Object.keys(s).forEach(i=>A.dispose(s[i])),r(me.bodies)})}var Ce,F2=[],V3=0,o1=Number.MAX_SAFE_INTEGER,B2=0,G2=2.5;async function Z3(e){if(!Ce||v.initial){Ce=await W(e.object.modelPath);let t=Object.values(Ce.modelSignature.inputs);B2=Array.isArray(t)?parseInt(t[0].tensorShape.dim[2].size):0}else e.debug&&u("cached model:",Ce.modelUrl);return Ce}async function Qn(e,t,o){let n=0,r=[];for(let l of[1,2,4])A.tidy(async()=>{let x=l*13,d=A.squeeze(e.find(p=>p.shape[1]===x**2&&(p.shape[2]||0)===Te.length)),y=A.squeeze(e.find(p=>p.shape[1]===x**2&&(p.shape[2]||0)(o.object.minConfidence||0)&&R!==61){let g=(.5+Math.trunc(p%x))/x,f=(.5+Math.trunc(p/x))/x,M=m[p].map(Z=>Z*(x/l/B2)),[j,k]=[g-G2/l*M[0],f-G2/l*M[1]],[I,C]=[g+G2/l*M[2]-j,f+G2/l*M[3]-k],O=[j,k,I,C];O=O.map(Z=>Math.max(0,Math.min(Z,1)));let D=[O[0]*t[0],O[1]*t[1],O[2]*t[0],O[3]*t[1]],H={id:n++,score:Math.round(100*P)/100,class:R+1,label:Te[R].label,box:D.map(Z=>Math.trunc(Z)),boxRaw:O};r.push(H)}}});e.forEach(l=>A.dispose(l));let s=r.map(l=>[l.boxRaw[1],l.boxRaw[0],l.boxRaw[3],l.boxRaw[2]]),a=r.map(l=>l.score),i=[];if(s&&s.length>0){let l=await A.image.nonMaxSuppressionAsync(s,a,o.object.maxDetected,o.object.iouThreshold,o.object.minConfidence);i=await l.data(),A.dispose(l)}return r=r.filter((l,x)=>i.includes(x)).sort((l,x)=>x.score-l.score),r}async function n1(e,t){let o=(t.object.skipTime||0)>b()-V3,n=o1<(t.object.skipFrames||0);return t.skipAllowed&&o&&n&&F2.length>0?(o1++,F2):(o1=0,!v.kernels.includes("mod")||!v.kernels.includes("sparsetodense")?F2:new Promise(async r=>{let s=[e.shape[2]||0,e.shape[1]||0],a=A.image.resizeBilinear(e,[B2,B2],!1),i=A.div(a,L.tf255),l=i.transpose([0,3,1,2]);A.dispose(i),A.dispose(a);let x;t.object.enabled&&(x=Ce.execute(l)),V3=b(),A.dispose(l);let d=await Qn(x,s,t);F2=d,r(d)}))}var t2=["nose","leftEye","rightEye","leftEar","rightEar","leftShoulder","rightShoulder","leftElbow","rightElbow","leftWrist","rightWrist","leftHip","rightHip","leftKnee","rightKnee","leftAnkle","rightAnkle"],_n=t2.length,e2=t2.reduce((e,t,o)=>(e[t]=o,e),{}),$n=[["leftHip","leftShoulder"],["leftElbow","leftShoulder"],["leftElbow","leftWrist"],["leftHip","leftKnee"],["leftKnee","leftAnkle"],["rightHip","rightShoulder"],["rightElbow","rightShoulder"],["rightElbow","rightWrist"],["rightHip","rightKnee"],["rightKnee","rightAnkle"],["leftShoulder","rightShoulder"],["leftHip","rightHip"]],v7=$n.map(([e,t])=>[e2[e],e2[t]]),X3=[["nose","leftEye"],["leftEye","leftEar"],["nose","rightEye"],["rightEye","rightEar"],["nose","leftShoulder"],["leftShoulder","leftElbow"],["leftElbow","leftWrist"],["leftShoulder","leftHip"],["leftHip","leftKnee"],["leftKnee","leftAnkle"],["nose","rightShoulder"],["rightShoulder","rightElbow"],["rightElbow","rightWrist"],["rightShoulder","rightHip"],["rightHip","rightKnee"],["rightKnee","rightAnkle"]];function q3(e){let t=e.reduce(({maxX:o,maxY:n,minX:r,minY:s},{position:{x:a,y:i}})=>({maxX:Math.max(o,a),maxY:Math.max(n,i),minX:Math.min(r,a),minY:Math.min(s,i)}),{maxX:Number.NEGATIVE_INFINITY,maxY:Number.NEGATIVE_INFINITY,minX:Number.POSITIVE_INFINITY,minY:Number.POSITIVE_INFINITY});return[t.minX,t.minY,t.maxX-t.minX,t.maxY-t.minY]}function U3(e,[t,o],[n,r]){let s=t/n,a=o/r,i=(x,d)=>({id:d,score:x.score,boxRaw:[x.box[0]/r,x.box[1]/n,x.box[2]/r,x.box[3]/n],box:[Math.trunc(x.box[0]*a),Math.trunc(x.box[1]*s),Math.trunc(x.box[2]*a),Math.trunc(x.box[3]*s)],keypoints:x.keypoints.map(({score:y,part:c,position:m})=>({score:y,part:c,position:[Math.trunc(m.x*a),Math.trunc(m.y*s)],positionRaw:[m.x/n,m.y/n]})),annotations:{}});return e.map((x,d)=>i(x,d))}var H2=class{constructor(t,o){w(this,"priorityQueue");w(this,"numberOfElements");w(this,"getElementValue");this.priorityQueue=new Array(t),this.numberOfElements=-1,this.getElementValue=o}enqueue(t){this.priorityQueue[++this.numberOfElements]=t,this.swim(this.numberOfElements)}dequeue(){let t=this.priorityQueue[0];return this.exchange(0,this.numberOfElements--),this.sink(0),this.priorityQueue[this.numberOfElements+1]=null,t}empty(){return this.numberOfElements===-1}size(){return this.numberOfElements+1}all(){return this.priorityQueue.slice(0,this.numberOfElements+1)}max(){return this.priorityQueue[0]}swim(t){for(;t>0&&this.less(Math.floor(t/2),t);)this.exchange(t,Math.floor(t/2)),t=Math.floor(t/2)}sink(t){for(;2*t<=this.numberOfElements;){let o=2*t;if(oo?o:e}function Y3(e,t,o,n){let r=o-e,s=n-t;return r*r+s*s}function a1(e,t){return{x:e.x+t.x,y:e.y+t.y}}var E0,tr=["MobilenetV1/offset_2/BiasAdd","MobilenetV1/heatmap_2/BiasAdd","MobilenetV1/displacement_fwd_2/BiasAdd","MobilenetV1/displacement_bwd_2/BiasAdd"],V2=1,Ie=16,or=50**2;function K3(e,t,o,n,r,s,a=2){let i=P=>({y:s.get(P.y,P.x,e),x:s.get(P.y,P.x,s.shape[2]/2+e)}),l=(P,g,f)=>({y:s1(Math.round(P.y/Ie),0,g-1),x:s1(Math.round(P.x/Ie),0,f-1)}),[x,d]=n.shape,y=l(t.position,x,d),c=i(y),h=a1(t.position,c);for(let P=0;P[e2[c],e2[m]]),a=s.map(([,c])=>c),i=s.map(([c])=>c),l=t.shape[2],x=a.length,d=new Array(l),y=A1(e.part,Ie,o);d[e.part.id]={score:e.score,part:t2[e.part.id],position:y};for(let c=x-1;c>=0;--c){let m=a[c],h=i[c];d[m]&&!d[h]&&(d[h]=K3(c,d[m],h,t,o,r))}for(let c=0;ct){i=!1;break}if(!i)break}return i}function Ar(e,t){let[o,n,r]=t.shape,s=new H2(o*n*r,({score:a})=>a);for(let a=0;a{var a;let s=(a=r[n])==null?void 0:a.position;return s?Y3(o,t,s.y,s.x)<=or:!1})}function sr(e,t){return t.reduce((n,{position:r,score:s},a)=>(J3(e,r,a)||(n+=s),n),0)/t.length}function ar(e,t,o,n,r,s){let a=[],i=Ar(s,t);for(;a.lengthm.score>s);let y=sr(a,d),c=q3(d);y>s&&a.push({keypoints:d,box:c,score:Math.round(100*y)/100})}return a}async function i1(e,t){let o=A.tidy(()=>{if(!E0.inputs[0].shape)return[];let a=A.image.resizeBilinear(e,[E0.inputs[0].shape[2],E0.inputs[0].shape[1]]),i=A.sub(A.div(A.cast(a,"float32"),127.5),1),x=E0.execute(i,tr).map(d=>A.squeeze(d,[0]));return x[1]=A.sigmoid(x[1]),x}),n=await Promise.all(o.map(a=>a.buffer()));for(let a of o)A.dispose(a);let r=await ar(n[0],n[1],n[2],n[3],t.body.maxDetected,t.body.minConfidence);return E0.inputs[0].shape?U3(r,[e.shape[1],e.shape[2]],[E0.inputs[0].shape[2],E0.inputs[0].shape[1]]):[]}async function Q3(e){return!E0||v.initial?E0=await W(e.body.modelPath):e.debug&&u("cached model:",E0.modelUrl),E0}var j0,l1=!1;async function y1(e){return!j0||v.initial?j0=await W(e.segmentation.modelPath):e.debug&&u("cached model:",j0.modelUrl),j0}async function $3(e,t,o){var p,R;if(l1)return{data:[],canvas:null,alpha:null};l1=!0,j0||await y1(o);let n=await ge(e,o),r=((p=n.tensor)==null?void 0:p.shape[2])||0,s=((R=n.tensor)==null?void 0:R.shape[1])||0;if(!n.tensor)return{data:[],canvas:null,alpha:null};let a={};a.resize=A.image.resizeBilinear(n.tensor,[j0.inputs[0].shape?j0.inputs[0].shape[1]:0,j0.inputs[0].shape?j0.inputs[0].shape[2]:0],!1),A.dispose(n.tensor),a.norm=A.div(a.resize,L.tf255),a.res=j0.execute(a.norm),a.squeeze=A.squeeze(a.res,0),a.squeeze.shape[2]===2?(a.softmax=A.softmax(a.squeeze),[a.bg,a.fg]=A.unstack(a.softmax,2),a.expand=A.expandDims(a.fg,2),a.pad=A.expandDims(a.expand,0),a.crop=A.image.cropAndResize(a.pad,[[0,0,.5,.5]],[0],[r,s]),a.data=A.squeeze(a.crop,0)):a.data=A.image.resizeBilinear(a.squeeze,[s,r]);let i=Array.from(await a.data.data());if(v.node&&!v.Canvas&&typeof ImageData=="undefined")return o.debug&&u("canvas support missing"),Object.keys(a).forEach(P=>A.dispose(a[P])),{data:i,canvas:null,alpha:null};let l=l0(r,s);A.browser&&await A.browser.toPixels(a.data,l);let x=l.getContext("2d");o.segmentation.blur&&o.segmentation.blur>0&&(x.filter=`blur(${o.segmentation.blur}px)`);let d=x.getImageData(0,0,r,s),y=l0(r,s),c=y.getContext("2d");n.canvas&&c.drawImage(n.canvas,0,0),c.globalCompositeOperation="darken",o.segmentation.blur&&o.segmentation.blur>0&&(c.filter=`blur(${o.segmentation.blur}px)`),c.drawImage(l,0,0),c.globalCompositeOperation="source-over",c.filter="none";let m=c.getImageData(0,0,r,s);for(let P=0;PA.dispose(a[P])),l1=!1,{data:i,canvas:y,alpha:l}}var o2=class{constructor(){w(this,"ssrnetage",null);w(this,"gear",null);w(this,"blazeposedetect",null);w(this,"blazepose",null);w(this,"centernet",null);w(this,"efficientpose",null);w(this,"mobilefacenet",null);w(this,"emotion",null);w(this,"facedetect",null);w(this,"faceiris",null);w(this,"facemesh",null);w(this,"faceres",null);w(this,"ssrnetgender",null);w(this,"handpose",null);w(this,"handskeleton",null);w(this,"handtrack",null);w(this,"liveness",null);w(this,"movenet",null);w(this,"nanodet",null);w(this,"posenet",null);w(this,"segmentation",null);w(this,"antispoof",null)}};function Z2(e){for(let t of Object.keys(e.models))e.models[t]=null}async function x1(e){var t,o,n,r,s,a,i,l,x,d,y,c,m,h,p,R,P,g,f,M,j,k,I,C,O,D,H,Z,F,z,h0;v.initial&&Z2(e),e.config.hand.enabled&&(!e.models.handpose&&((o=(t=e.config.hand.detector)==null?void 0:t.modelPath)==null?void 0:o.includes("handdetect"))&&([e.models.handpose,e.models.handskeleton]=await D5(e.config)),!e.models.handskeleton&&e.config.hand.landmarks&&((r=(n=e.config.hand.detector)==null?void 0:n.modelPath)==null?void 0:r.includes("handdetect"))&&([e.models.handpose,e.models.handskeleton]=await D5(e.config))),e.config.body.enabled&&!e.models.blazepose&&((a=(s=e.config.body)==null?void 0:s.modelPath)==null?void 0:a.includes("blazepose"))&&(e.models.blazepose=wt(e.config)),e.config.body.enabled&&!e.models.blazeposedetect&&e.config.body.detector&&e.config.body.detector.modelPath&&(e.models.blazeposedetect=vt(e.config)),e.config.body.enabled&&!e.models.efficientpose&&((l=(i=e.config.body)==null?void 0:i.modelPath)==null?void 0:l.includes("efficientpose"))&&(e.models.efficientpose=Ct(e.config)),e.config.body.enabled&&!e.models.movenet&&((d=(x=e.config.body)==null?void 0:x.modelPath)==null?void 0:d.includes("movenet"))&&(e.models.movenet=B3(e.config)),e.config.body.enabled&&!e.models.posenet&&((c=(y=e.config.body)==null?void 0:y.modelPath)==null?void 0:c.includes("posenet"))&&(e.models.posenet=Q3(e.config)),e.config.face.enabled&&!e.models.facedetect&&(e.models.facedetect=pt(e.config)),e.config.face.enabled&&((m=e.config.face.antispoof)==null?void 0:m.enabled)&&!e.models.antispoof&&(e.models.antispoof=nt(e.config)),e.config.face.enabled&&((h=e.config.face.liveness)==null?void 0:h.enabled)&&!e.models.liveness&&(e.models.liveness=N3(e.config)),e.config.face.enabled&&((p=e.config.face.description)==null?void 0:p.enabled)&&!e.models.faceres&&(e.models.faceres=n3(e.config)),e.config.face.enabled&&((R=e.config.face.emotion)==null?void 0:R.enabled)&&!e.models.emotion&&(e.models.emotion=Wt(e.config)),e.config.face.enabled&&((P=e.config.face.iris)==null?void 0:P.enabled)&&!((g=e.config.face.attention)!=null&&g.enabled)&&!e.models.faceiris&&(e.models.faceiris=qt(e.config)),e.config.face.enabled&&((f=e.config.face.mesh)==null?void 0:f.enabled)&&!e.models.facemesh&&(e.models.facemesh=_t(e.config)),e.config.face.enabled&&((M=e.config.face.gear)==null?void 0:M.enabled)&&!e.models.gear&&(e.models.gear=D1(e.config)),e.config.face.enabled&&((j=e.config.face.ssrnet)==null?void 0:j.enabled)&&!e.models.ssrnetage&&(e.models.ssrnetage=K1(e.config)),e.config.face.enabled&&((k=e.config.face.ssrnet)==null?void 0:k.enabled)&&!e.models.ssrnetgender&&(e.models.ssrnetgender=$1(e.config)),e.config.face.enabled&&((I=e.config.face.mobilefacenet)==null?void 0:I.enabled)&&!e.models.mobilefacenet&&(e.models.mobilefacenet=Ht(e.config)),e.config.hand.enabled&&!e.models.handtrack&&((O=(C=e.config.hand.detector)==null?void 0:C.modelPath)==null?void 0:O.includes("handtrack"))&&(e.models.handtrack=z3(e.config)),e.config.hand.enabled&&e.config.hand.landmarks&&!e.models.handskeleton&&((H=(D=e.config.hand.detector)==null?void 0:D.modelPath)==null?void 0:H.includes("handtrack"))&&(e.models.handskeleton=S3(e.config)),e.config.object.enabled&&!e.models.centernet&&((F=(Z=e.config.object)==null?void 0:Z.modelPath)==null?void 0:F.includes("centernet"))&&(e.models.centernet=zt(e.config)),e.config.object.enabled&&!e.models.nanodet&&((h0=(z=e.config.object)==null?void 0:z.modelPath)==null?void 0:h0.includes("nanodet"))&&(e.models.nanodet=Z3(e.config)),e.config.segmentation.enabled&&!e.models.segmentation&&(e.models.segmentation=y1(e.config));for await(let b0 of Object.keys(e.models))e.models[b0]&&typeof e.models[b0]!="undefined"&&(e.models[b0]=await e.models[b0])}async function c1(e){let t=["const","placeholder","noop","pad","squeeze","add","sub","mul","div"];for(let o of Object.keys(e.models)){let n=e.models[o];if(!n)continue;let r=[],s=n==null?void 0:n.executor;if(s&&s.graph.nodes)for(let i of Object.values(s.graph.nodes)){let l=i.op.toLowerCase();r.includes(l)||r.push(l)}else!s&&e.config.debug&&u("model signature not determined:",o);let a=[];for(let i of r)!t.includes(i)&&!e.env.kernels.includes(i)&&!e.env.kernels.includes(i.replace("_",""))&&!e.env.kernels.includes(i.replace("native",""))&&!e.env.kernels.includes(i.replace("v2",""))&&a.push(i);e.config.debug&&a.length>0&&u("model validation failed:",o,a)}}var Y={name:"humangl",priority:999,canvas:null,gl:null,extensions:[],webGLattr:{alpha:!1,antialias:!1,premultipliedAlpha:!1,preserveDrawingBuffer:!1,depth:!1,stencil:!1,failIfMajorPerformanceCaveat:!1,desynchronized:!0}};function ir(){let e=Y.gl;!e||(Y.extensions=e.getSupportedExtensions())}async function to(e){var t;if(e.config.backend==="humangl"&&(Y.name in A.engine().registry&&(!Y.gl||!Y.gl.getParameter(Y.gl.VERSION))&&(u("error: humangl backend invalid context"),Z2(e)),!A.findBackend(Y.name))){try{Y.canvas=await l0(100,100)}catch(n){u("error: cannot create canvas:",n);return}try{if(Y.gl=(t=Y.canvas)==null?void 0:t.getContext("webgl2",Y.webGLattr),!Y.gl.getParameter(Y.gl.VERSION).includes("2.0")){u("override: using fallback webgl backend as webgl 2.0 is not detected"),e.config.backend="webgl";return}Y.canvas&&(Y.canvas.addEventListener("webglcontextlost",async r=>{throw u("error: humangl:",r.type),u("possible browser memory leak using webgl or conflict with multiple backend registrations"),e.emit("error"),new Error("backend error: webgl context lost")}),Y.canvas.addEventListener("webglcontextrestored",r=>{u("error: humangl context restored:",r)}),Y.canvas.addEventListener("webglcontextcreationerror",r=>{u("error: humangl context create:",r)}))}catch(n){u("error: cannot get WebGL context:",n);return}try{A.setWebGLContext(2,Y.gl)}catch(n){u("error: cannot set WebGL context:",n);return}try{let n=new A.GPGPUContext(Y.gl);A.registerBackend(Y.name,()=>new A.MathBackendWebGL(n),Y.priority)}catch(n){u("error: cannot register WebGL backend:",n);return}try{A.getKernelsForBackend("webgl").forEach(r=>{let s={...r,backendName:Y.name};A.registerKernel(s)})}catch(n){u("error: cannot update WebGL backend registration:",n);return}let o=A.backend().getGPGPUContext?A.backend().getGPGPUContext().gl:null;if(o)u(`humangl webgl version:${o.getParameter(o.VERSION)} renderer:${o.getParameter(o.RENDERER)}`);else{u("error: no current gl context:",o,Y.gl);return}try{A.ENV.set("WEBGL_VERSION",2)}catch(n){u("error: cannot set WebGL backend flags:",n);return}ir(),u("backend registered:",Y.name)}}function lr(){if(!v.kernels.includes("mod")){let e={kernelName:"Mod",backendName:A.getBackend(),kernelFunc:t=>A.tidy(()=>A.sub(t.inputs.a,A.mul(A.div(t.inputs.a,t.inputs.b),t.inputs.b)))};A.registerKernel(e),v.kernels.push("mod")}if(!v.kernels.includes("floormod")){let e={kernelName:"FloorMod",backendName:A.getBackend(),kernelFunc:t=>A.tidy(()=>A.floorDiv(t.inputs.a/t.inputs.b)*t.inputs.b+A.mod(t.inputs.a,t.inputs.b))};A.registerKernel(e),v.kernels.push("floormod")}}async function D2(e,t=!1){if(e.state="backend",t||v.initial||e.config.backend&&e.config.backend.length>0&&A.getBackend()!==e.config.backend){let o=b();if(e.config.backend&&e.config.backend.length>0){if(typeof window=="undefined"&&typeof WorkerGlobalScope!="undefined"&&e.config.debug&&e.config.debug&&u("running inside web worker"),v.browser&&e.config.backend==="tensorflow"&&(e.config.debug&&u("override: backend set to tensorflow while running in browser"),e.config.backend="humangl"),v.node&&(e.config.backend==="webgl"||e.config.backend==="humangl")&&(e.config.debug&&u(`override: backend set to ${e.config.backend} while running in nodejs`),e.config.backend="tensorflow"),v.browser&&e.config.backend==="webgpu")if(typeof navigator=="undefined"||typeof navigator.gpu=="undefined")u("override: backend set to webgpu but browser does not support webgpu"),e.config.backend="humangl";else{let r=await navigator.gpu.requestAdapter();e.config.debug&&u("enumerated webgpu adapter:",r)}e.config.backend==="humangl"&&await to(e);let n=Object.keys(A.engine().registryFactory);if(e.config.debug&&u("available backends:",n),n.includes(e.config.backend)||(u(`error: backend ${e.config.backend} not found in registry`),e.config.backend=v.node?"tensorflow":"webgl",e.config.debug&&u(`override: setting backend ${e.config.backend}`)),e.config.debug&&u("setting backend:",e.config.backend),e.config.backend==="wasm"){if(e.config.debug&&u("wasm path:",e.config.wasmPath),typeof(A==null?void 0:A.setWasmPaths)!="undefined")await A.setWasmPaths(e.config.wasmPath,e.config.wasmPlatformFetch);else throw new Error("backend error: attempting to use wasm backend but wasm path is not set");let r=await A.env().getAsync("WASM_HAS_SIMD_SUPPORT"),s=await A.env().getAsync("WASM_HAS_MULTITHREAD_SUPPORT");e.config.debug&&u(`wasm execution: ${r?"SIMD":"no SIMD"} ${s?"multithreaded":"singlethreaded"}`),e.config.debug&&!r&&u("warning: wasm simd support is not enabled")}try{await A.setBackend(e.config.backend),await A.ready(),q1()}catch(r){return u("error: cannot set backend:",e.config.backend,r),!1}}if(A.getBackend()==="humangl"&&(A.ENV.set("CHECK_COMPUTATION_FOR_ERRORS",!1),A.ENV.set("WEBGL_CPU_FORWARD",!0),A.ENV.set("WEBGL_USE_SHAPES_UNIFORMS",!0),A.ENV.set("CPU_HANDOFF_SIZE_THRESHOLD",256),typeof e.config.deallocate!="undefined"&&e.config.deallocate&&(u("changing webgl: WEBGL_DELETE_TEXTURE_THRESHOLD:",!0),A.ENV.set("WEBGL_DELETE_TEXTURE_THRESHOLD",0)),A.backend().getGPGPUContext)){let n=await A.backend().getGPGPUContext().gl;e.config.debug&&u(`gl version:${n.getParameter(n.VERSION)} renderer:${n.getParameter(n.RENDERER)}`)}A.getBackend(),A.enableProdMode(),await A.ready(),e.performance.initBackend=Math.trunc(b()-o),e.config.backend=A.getBackend(),await v.updateBackend(),lr()}return!0}function I2(e,t){for(let o of e){let n={kernelName:o,backendName:t.backend,kernelFunc:()=>{t.debug&&u("kernelFunc",o,t.backend)}};A.registerKernel(n)}v.kernels=A.getKernelsForBackend(A.getBackend()).map(o=>o.kernelName.toLowerCase())}var ro={};ne(ro,{all:()=>b1,body:()=>Oe,canvas:()=>h1,face:()=>Ne,gesture:()=>Fe,hand:()=>We,object:()=>Le,options:()=>i0,person:()=>u1});var P0=e=>{if(!e)u("draw error: invalid canvas");else if(!e.getContext)u("draw error: canvas context not defined");else{let t=e.getContext("2d");if(!t)u("draw error: cannot get canvas context");else return t}return null},pe=e=>Math.round(e*180/Math.PI),Z0=(e,t)=>{if(!t.useDepth||typeof e=="undefined")return t.color;let o=Uint8ClampedArray.from([127+2*e,127-2*e,255]);return`rgba(${o[0]}, ${o[1]}, ${o[2]}, ${t.alpha})`};function D0(e,t,o,n,r){e.fillStyle=Z0(n,r),e.beginPath(),e.arc(t,o,r.pointSize,0,2*Math.PI),e.fill()}function C0(e,t,o,n,r,s){if(e.beginPath(),e.lineWidth=s.lineWidth,s.useCurves){let a=(t+t+n)/2,i=(o+o+r)/2;e.ellipse(a,i,n/2,r/2,0,0,2*Math.PI)}else e.moveTo(t+s.roundRect,o),e.lineTo(t+n-s.roundRect,o),e.quadraticCurveTo(t+n,o,t+n,o+s.roundRect),e.lineTo(t+n,o+r-s.roundRect),e.quadraticCurveTo(t+n,o+r,t+n-s.roundRect,o+r),e.lineTo(t+s.roundRect,o+r),e.quadraticCurveTo(t,o+r,t,o+r-s.roundRect),e.lineTo(t,o+s.roundRect),e.quadraticCurveTo(t,o,t+s.roundRect,o),e.closePath();e.stroke()}function f1(e,t,o){if(!(t.length<2)){e.beginPath(),e.moveTo(t[0][0],t[0][1]);for(let n of t)e.strokeStyle=Z0(n[2],o),e.lineTo(Math.trunc(n[0]),Math.trunc(n[1]));e.stroke(),o.fillPolygons&&(e.closePath(),e.fill())}}function no(e,t,o){if(!(t.length<2)){if(e.lineWidth=o.lineWidth,!o.useCurves||t.length<=2){f1(e,t,o);return}e.moveTo(t[0][0],t[0][1]);for(let n=0;n0){let n=e.emotion.map(r=>`${Math.trunc(100*r.score)}% ${r.emotion}`);n.length>3&&(n.length=3),o.push(n.join(" "))}e.rotation&&e.rotation.angle&&e.rotation.gaze&&(e.rotation.angle.roll&&o.push(`roll: ${pe(e.rotation.angle.roll)}\xB0 yaw:${pe(e.rotation.angle.yaw)}\xB0 pitch:${pe(e.rotation.angle.pitch)}\xB0`),e.rotation.gaze.bearing&&o.push(`gaze: ${pe(e.rotation.gaze.bearing)}\xB0`)),o.length===0&&o.push("face"),t.fillStyle=B.color;for(let n=o.length-1;n>=0;n--){let r=Math.max(e.box[0],0),s=n*B.lineHeight+e.box[1];B.shadowColor&&B.shadowColor!==""&&(t.fillStyle=B.shadowColor,t.fillText(o[n],r+5,s+16)),t.fillStyle=B.labelColor,t.fillText(o[n],r+4,s+15)}}}function cr(e,t){if(e.annotations&&e.annotations.leftEyeIris&&e.annotations.leftEyeIris[0]){t.strokeStyle=B.useDepth?"rgba(255, 200, 255, 0.3)":B.color,t.beginPath();let o=Math.abs(e.annotations.leftEyeIris[3][0]-e.annotations.leftEyeIris[1][0])/2,n=Math.abs(e.annotations.leftEyeIris[4][1]-e.annotations.leftEyeIris[2][1])/2;t.ellipse(e.annotations.leftEyeIris[0][0],e.annotations.leftEyeIris[0][1],o,n,0,0,2*Math.PI),t.stroke(),B.fillPolygons&&(t.fillStyle=B.useDepth?"rgba(255, 255, 200, 0.3)":B.color,t.fill())}if(e.annotations&&e.annotations.rightEyeIris&&e.annotations.rightEyeIris[0]){t.strokeStyle=B.useDepth?"rgba(255, 200, 255, 0.3)":B.color,t.beginPath();let o=Math.abs(e.annotations.rightEyeIris[3][0]-e.annotations.rightEyeIris[1][0])/2,n=Math.abs(e.annotations.rightEyeIris[4][1]-e.annotations.rightEyeIris[2][1])/2;t.ellipse(e.annotations.rightEyeIris[0][0],e.annotations.rightEyeIris[0][1],o,n,0,0,2*Math.PI),t.stroke(),B.fillPolygons&&(t.fillStyle=B.useDepth?"rgba(255, 255, 200, 0.3)":B.color,t.fill())}}function dr(e,t){var o;if(B.drawGaze&&((o=e.rotation)==null?void 0:o.angle)&&typeof Path2D!="undefined"){t.strokeStyle="pink";let n=e.box[0]+e.box[2]/2-e.box[3]*pe(e.rotation.angle.yaw)/90,r=e.box[1]+e.box[3]/2+e.box[2]*pe(e.rotation.angle.pitch)/90,s=new Path2D(` M ${e.box[0]+e.box[2]/2} ${e.box[1]} C ${n} ${e.box[1]}, @@ -108,7 +108,7 @@ var Xt=Object.defineProperty;var mn=Object.getOwnPropertyDescriptor;var pn=Objec ${e.box[0]} ${r}, ${e.box[0]+e.box[2]} ${r}, ${e.box[0]+e.box[2]} ${e.box[1]+e.box[3]/2} - `);t.stroke(a),t.stroke(s)}}function eA(e,t){var o,n,r,s;if(G.drawGaze&&((n=(o=e.rotation)==null?void 0:o.gaze)==null?void 0:n.strength)&&((s=(r=e.rotation)==null?void 0:r.gaze)==null?void 0:s.bearing)&&e.annotations.leftEyeIris&&e.annotations.rightEyeIris&&e.annotations.leftEyeIris[0]&&e.annotations.rightEyeIris[0]){t.strokeStyle="pink",t.fillStyle="pink";let a=[e.annotations.leftEyeIris[0][0]+Math.sin(e.rotation.gaze.bearing)*e.rotation.gaze.strength*e.box[3],e.annotations.leftEyeIris[0][1]+Math.cos(e.rotation.gaze.bearing)*e.rotation.gaze.strength*e.box[2]];c2(t,[e.annotations.leftEyeIris[0][0],e.annotations.leftEyeIris[0][1]],[a[0],a[1]],4);let i=[e.annotations.rightEyeIris[0][0]+Math.sin(e.rotation.gaze.bearing)*e.rotation.gaze.strength*e.box[3],e.annotations.rightEyeIris[0][1]+Math.cos(e.rotation.gaze.bearing)*e.rotation.gaze.strength*e.box[2]];c2(t,[e.annotations.rightEyeIris[0][0],e.annotations.rightEyeIris[0][1]],[i[0],i[1]],4)}}function tA(e,t){if(G.drawPolygons&&e.mesh.length>=468){t.lineWidth=1;for(let o=0;oe.mesh[r]);x2(t,n,G)}_r(e,t)}}function oA(e,t){if(G.drawPoints&&e.mesh.length>=468)for(let o=0;o0&&(oA(r,n),tA(r,n),$r(r,n),eA(r,n))}}async function We(e,t,o){var s;let n=K(a0,o);if(!t||!e)return;let r=P0(e);if(!!r){r.lineJoin="round";for(let a=0;a0)for(let a of s.keypoints)r.fillStyle=D0(a[2],n),X0(r,a[0],a[1],0,n);if(n.drawLabels&&s.annotations){let a=(i,l)=>{if(!i||i.length===0||!i[0])return;let x=i[i.length-1][2]||-256;r.fillStyle=D0(x,n),r.fillText(l,i[i.length-1][0]+4,i[i.length-1][1]+4)};r.font=n.font,a(s.annotations.index,"index"),a(s.annotations.middle,"middle"),a(s.annotations.ring,"ring"),a(s.annotations.pinky,"pinky"),a(s.annotations.thumb,"thumb"),a(s.annotations.palm,"palm")}if(n.drawPolygons&&s.annotations){let a=i=>{if(!(!i||i.length===0||!i[0]))for(let l=0;l0?l-1:0][0],i[l>0?l-1:0][1]),r.lineTo(i[l][0],i[l][1]),r.stroke()}};r.lineWidth=n.lineWidth,a(s.annotations.index),a(s.annotations.middle),a(s.annotations.ring),a(s.annotations.pinky),a(s.annotations.thumb)}}}}async function Le(e,t,o){let n=K(a0,o);if(!t||!e)return;let r=P0(e);if(!!r){r.lineJoin="round",r.font=n.font;for(let s of t)if(n.drawBoxes){if(r.strokeStyle=n.color,r.fillStyle=n.color,W0(r,s.box[0],s.box[1],s.box[2],s.box[3],n),n.drawLabels){let a=`${s.label} ${Math.round(100*s.score)}%`;n.shadowColor&&n.shadowColor!==""&&(r.fillStyle=n.shadowColor,r.fillText(a,s.box[0]+3,1+s.box[1]+n.lineHeight,s.box[2])),r.fillStyle=n.labelColor,r.fillText(a,s.box[0]+2,0+s.box[1]+n.lineHeight,s.box[2])}r.stroke()}}}async function Ie(e,t,o){let n=K(a0,o);if(!(!t||!e)&&n.drawGestures){let r=P0(e);if(!r)return;r.font=n.font,r.fillStyle=n.color;let s=1;for(let a=0;a1&&l[1].length>0){let x=i[1]>0?`#${i[1]}`:"",d=`${i[0]} ${x}: ${l[1]}`;n.shadowColor&&n.shadowColor!==""&&(r.fillStyle=n.shadowColor,r.fillText(d,8,2+s*n.lineHeight)),r.fillStyle=n.labelColor,r.fillText(d,6,0+s*n.lineHeight),s+=1}}}}var d2=0;async function f2(e,t,o){let n=K(a0,o);if(!t||!e)return;let r=P0(e);if(!!r){r.lineJoin="round",r.font=n.font;for(let s=0;st!=o[r].y>t&&e<(o[r].x-o[s].x)*(t-o[s].y)/(o[r].y-o[s].y)+o[s].x&&(n=!n);return n}async function on(e){if(!e.tensor||!e.mesh||e.mesh.length<100)return e.tensor;let t=e.tensor.shape[2]||0,o=e.tensor.shape[1]||0,n=await e.tensor.buffer(),r=[];for(let a of R0.silhouette)r.push({x:(e.mesh[a][0]-e.box[0])/e.box[2],y:(e.mesh[a][1]-e.box[1])/e.box[3]});Ne&&Ne>0&&(r=r.map(a=>({x:a.x>.5?a.x+Ne:a.x-Ne,y:a.y>.5?a.y+Ne:a.y-Ne})));for(let a=0;a{let t=(y,c)=>Math.atan2(y[1]-c[1],y[0]-c[0]);if(!e.annotations.rightEyeIris||!e.annotations.leftEyeIris)return{bearing:0,strength:0};let o=[0,-.1],n=1,r=(e.mesh[33][2]||0)>(e.mesh[263][2]||0),s=r?e.mesh[473]:e.mesh[468],a=r?[(e.mesh[133][0]+e.mesh[33][0])/2,(e.mesh[133][1]+e.mesh[33][1])/2]:[(e.mesh[263][0]+e.mesh[362][0])/2,(e.mesh[263][1]+e.mesh[362][1])/2],i=r?[e.mesh[133][0]-e.mesh[33][0],e.mesh[23][1]-e.mesh[27][1]]:[e.mesh[263][0]-e.mesh[362][0],e.mesh[253][1]-e.mesh[257][1]],l=[(a[0]-s[0])/i[0]-o[0],n*(s[1]-a[1])/i[1]-o[1]],x=Math.sqrt(l[0]*l[0]+l[1]*l[1]);return x=Math.min(x,e.boxRaw[2]/2,e.boxRaw[3]/2),{bearing:(t([0,0],l)+Math.PI/2)%Math.PI,strength:x}},nn=(e,t)=>{let o=p=>{let M=Math.sqrt(p[0]*p[0]+p[1]*p[1]+p[2]*p[2]);return p[0]/=M,p[1]/=M,p[2]/=M,p},n=(p,M)=>{let P=p[0]-M[0],g=p[1]-M[1],f=p[2]-M[2];return[P,g,f]},r=(p,M)=>{let P=p[1]*M[2]-p[2]*M[1],g=p[2]*M[0]-p[0]*M[2],f=p[0]*M[1]-p[1]*M[0];return[P,g,f]},s=p=>{let[M,P,g,f,v,S,k,W,C]=p,L,D,H;return f<1?f>-1?(H=Math.asin(f),D=Math.atan2(-k,M),L=Math.atan2(-S,v)):(H=-Math.PI/2,D=-Math.atan2(W,C),L=0):(H=Math.PI/2,D=Math.atan2(W,C),L=0),isNaN(L)&&(L=0),isNaN(D)&&(D=0),isNaN(H)&&(H=0),{pitch:2*-L,yaw:2*-D,roll:2*-H}},a=e.meshRaw;if(!a||a.length<300)return{angle:{pitch:0,yaw:0,roll:0},matrix:[1,0,0,0,1,0,0,0,1],gaze:{bearing:0,strength:0}};let i=Math.max(e.boxRaw[2]*t[0],e.boxRaw[3]*t[1])/1.5,l=[a[10],a[152],a[234],a[454]].map(p=>[p[0]*t[0]/i,p[1]*t[1]/i,p[2]]),x=o(n(l[1],l[0])),d=o(n(l[3],l[2])),y=o(r(d,x));d=r(x,y);let c=[d[0],d[1],d[2],x[0],x[1],x[2],y[0],y[1],y[2]],m=s(c),h=a.length===478?sA(e):{bearing:0,strength:0};return{angle:m,matrix:c,gaze:h}};var h2=async(e,t)=>{var m,h,p,M,P,g,f,v,S,k,W,C,L,D,H,Z,F,z,h0,b0,R,t0;let o=b(),n,r,s,a,i,l,x,d,y=[];e.state="run:face";let c=await U1(t,e.config);if(e.performance.face=w.perfadd?(e.performance.face||0)+Math.trunc(b()-o):Math.trunc(b()-o),!t.shape||t.shape.length!==4)return[];if(!c)return[];for(let E=0;E200?nn(c[E],[t.shape[2],t.shape[1]]):null;e.analyze("Start Emotion:"),e.config.async?a=(h=e.config.face.emotion)!=null&&h.enabled?T5(c[E].tensor||A.tensor([]),e.config,E,c.length):[]:(e.state="run:emotion",o=b(),a=(p=e.config.face.emotion)!=null&&p.enabled?await T5(c[E].tensor||A.tensor([]),e.config,E,c.length):[],e.performance.emotion=w.perfadd?(e.performance.emotion||0)+Math.trunc(b()-o):Math.trunc(b()-o)),e.analyze("End Emotion:"),e.analyze("Start AntiSpoof:"),e.config.async?l=(M=e.config.face.antispoof)!=null&&M.enabled?a5(c[E].tensor||A.tensor([]),e.config,E,c.length):0:(e.state="run:antispoof",o=b(),l=(P=e.config.face.antispoof)!=null&&P.enabled?await a5(c[E].tensor||A.tensor([]),e.config,E,c.length):0,e.performance.antispoof=w.perfadd?(e.performance.antispoof||0)+Math.trunc(b()-o):Math.trunc(b()-o)),e.analyze("End AntiSpoof:"),e.analyze("Start Liveness:"),e.config.async?x=(g=e.config.face.liveness)!=null&&g.enabled?q5(c[E].tensor||A.tensor([]),e.config,E,c.length):0:(e.state="run:liveness",o=b(),x=(f=e.config.face.liveness)!=null&&f.enabled?await q5(c[E].tensor||A.tensor([]),e.config,E,c.length):0,e.performance.liveness=w.perfadd?(e.performance.antispoof||0)+Math.trunc(b()-o):Math.trunc(b()-o)),e.analyze("End Liveness:"),e.analyze("Start GEAR:"),e.config.async?r=(v=e.config.face.gear)!=null&&v.enabled?e5(c[E].tensor||A.tensor([]),e.config,E,c.length):null:(e.state="run:gear",o=b(),r=(S=e.config.face.gear)!=null&&S.enabled?await e5(c[E].tensor||A.tensor([]),e.config,E,c.length):null,e.performance.gear=Math.trunc(b()-o)),e.analyze("End GEAR:"),e.analyze("Start SSRNet:"),e.config.async?(n=(k=e.config.face.ssrnet)!=null&&k.enabled?o5(c[E].tensor||A.tensor([]),e.config,E,c.length):null,s=(W=e.config.face.ssrnet)!=null&&W.enabled?A5(c[E].tensor||A.tensor([]),e.config,E,c.length):null):(e.state="run:ssrnet",o=b(),n=(C=e.config.face.ssrnet)!=null&&C.enabled?await o5(c[E].tensor||A.tensor([]),e.config,E,c.length):null,s=(L=e.config.face.ssrnet)!=null&&L.enabled?await A5(c[E].tensor||A.tensor([]),e.config,E,c.length):null,e.performance.ssrnet=Math.trunc(b()-o)),e.analyze("End SSRNet:"),e.analyze("Start MobileFaceNet:"),e.config.async?i=(D=e.config.face.mobilefacenet)!=null&&D.enabled?E5(c[E].tensor||A.tensor([]),e.config,E,c.length):null:(e.state="run:mobilefacenet",o=b(),i=(H=e.config.face.mobilefacenet)!=null&&H.enabled?await E5(c[E].tensor||A.tensor([]),e.config,E,c.length):null,e.performance.mobilefacenet=Math.trunc(b()-o)),e.analyze("End MobileFaceNet:"),e.analyze("Start Description:"),e.config.async?d=(Z=e.config.face.description)!=null&&Z.enabled?O5(c[E].tensor||A.tensor([]),e.config,E,c.length):null:(e.state="run:description",o=b(),d=(F=e.config.face.description)!=null&&F.enabled?await O5(c[E].tensor||A.tensor([]),e.config,E,c.length):null,e.performance.description=w.perfadd?(e.performance.description||0)+Math.trunc(b()-o):Math.trunc(b()-o)),e.analyze("End Description:"),e.config.async&&([n,s,a,i,d,r,l,x]=await Promise.all([n,s,a,i,d,r,l,x])),e.analyze("Finish Face:"),((z=e.config.face.ssrnet)==null?void 0:z.enabled)&&n&&s&&(d={...d,age:n.age,gender:s.gender,genderScore:s.genderScore}),((h0=e.config.face.gear)==null?void 0:h0.enabled)&&r&&(d={...d,age:r.age,gender:r.gender,genderScore:r.genderScore,race:r.race}),((b0=e.config.face.mobilefacenet)==null?void 0:b0.enabled)&&i&&(d.descriptor=i),(R=e.config.face.iris)!=null&&R.enabled;let _=c[E].annotations&&c[E].annotations.leftEyeIris&&c[E].annotations.leftEyeIris[0]&&c[E].annotations.rightEyeIris&&c[E].annotations.rightEyeIris[0]&&c[E].annotations.leftEyeIris.length>0&&c[E].annotations.rightEyeIris.length>0&&c[E].annotations.leftEyeIris[0]!==null&&c[E].annotations.rightEyeIris[0]!==null?Math.max(Math.abs(c[E].annotations.leftEyeIris[3][0]-c[E].annotations.leftEyeIris[1][0]),Math.abs(c[E].annotations.rightEyeIris[4][1]-c[E].annotations.rightEyeIris[2][1]))/t.shape[2]:0,n0=(t0=e.config.face.detector)!=null&&t0.return?A.squeeze(c[E].tensor):null;A.dispose(c[E].tensor),c[E].tensor&&delete c[E].tensor;let O={...c[E],id:E};d!=null&&d.age&&(O.age=d.age),d!=null&&d.gender&&(O.gender=d.gender),d!=null&&d.genderScore&&(O.genderScore=d==null?void 0:d.genderScore),d!=null&&d.descriptor&&(O.embedding=d==null?void 0:d.descriptor),d!=null&&d.race&&(O.race=d==null?void 0:d.race),a&&(O.emotion=a),l&&(O.real=l),x&&(O.live=x),_&&_!==0&&(O.iris=Math.trunc(500/_/11.7)/100),X&&(O.rotation=X),n0&&(O.tensor=n0),y.push(O),e.analyze("End Face")}return e.analyze("End FaceMesh:"),e.config.async&&(e.performance.face&&delete e.performance.face,e.performance.age&&delete e.performance.age,e.performance.gender&&delete e.performance.gender,e.performance.emotion&&delete e.performance.emotion),y};var rn=e=>{if(!e)return[];let t=[];for(let o=0;ol.part==="leftWrist"),r=e[o].keypoints.find(l=>l.part==="rightWrist"),s=e[o].keypoints.find(l=>l.part==="nose");s&&n&&r&&n.position[1]l.part==="leftShoulder"),i=e[o].keypoints.find(l=>l.part==="rightShoulder");a&&i&&Math.abs(a.positionRaw[1]-i.positionRaw[1])>.1&&t.push({body:o,gesture:`leaning ${a.position[1]>i.position[1]?"left":"right"}`})}return t},An=e=>{if(!e)return[];let t=[];for(let o=0;o450){let n=(e[o].mesh[33][2]||0)-(e[o].mesh[263][2]||0),r=e[o].mesh[33][0]-e[o].mesh[263][0];Math.abs(n/r)<=.15?t.push({face:o,gesture:"facing center"}):t.push({face:o,gesture:`facing ${n<0?"left":"right"}`}),Math.abs(e[o].mesh[374][1]-e[o].mesh[386][1])/Math.abs(e[o].mesh[443][1]-e[o].mesh[450][1])<.2&&t.push({face:o,gesture:"blink left eye"}),Math.abs(e[o].mesh[145][1]-e[o].mesh[159][1])/Math.abs(e[o].mesh[223][1]-e[o].mesh[230][1])<.2&&t.push({face:o,gesture:"blink right eye"});let i=Math.min(100,500*Math.abs(e[o].mesh[13][1]-e[o].mesh[14][1])/Math.abs(e[o].mesh[10][1]-e[o].mesh[152][1]));i>10&&t.push({face:o,gesture:`mouth ${Math.trunc(i)}% open`});let l=e[o].mesh[152][2]||0;Math.abs(l)>10&&t.push({face:o,gesture:`head ${l<0?"up":"down"}`})}return t},sn=e=>{if(!e)return[];let t=[];for(let o=0;o.06||c>.06)&&(x=!1),y>c?y>.05&&t.push({iris:o,gesture:"looking right"}):c>.05&&t.push({iris:o,gesture:"looking left"});let m=Math.abs(e[o].mesh[145][1]-e[o].annotations.rightEyeIris[0][1])/e[o].box[3],h=Math.abs(e[o].mesh[374][1]-e[o].annotations.leftEyeIris[0][1])/e[o].box[3];(h<.01||m<.01||h>.022||m>.022)&&(x=!1),(h<.01||m<.01)&&t.push({iris:o,gesture:"looking down"}),(h>.022||m>.022)&&t.push({iris:o,gesture:"looking up"}),x&&t.push({iris:o,gesture:"looking center"})}return t},an=e=>{if(!e)return[];let t=[];for(let o=0;o0){let r=n.reduce((a,i)=>(a.position[2]||0)<(i.position[2]||0)?a:i);t.push({hand:o,gesture:`${r.name} forward`});let s=n.reduce((a,i)=>a.position[1]((r-1)*j.body[R].box[V]+O)/r),E=e.body[R].boxRaw.map((O,V)=>((r-1)*j.body[R].boxRaw[V]+O)/r),X=e.body[R].keypoints.map((O,V)=>{var O0,L0,Be,Ge,me,v2,M2,R2,w2;return{score:O.score,part:O.part,position:[j.body[R].keypoints[V]?((r-1)*(j.body[R].keypoints[V].position[0]||0)+(O.position[0]||0))/r:O.position[0],j.body[R].keypoints[V]?((r-1)*(j.body[R].keypoints[V].position[1]||0)+(O.position[1]||0))/r:O.position[1],j.body[R].keypoints[V]?((r-1)*(j.body[R].keypoints[V].position[2]||0)+(O.position[2]||0))/r:O.position[2]],positionRaw:[j.body[R].keypoints[V]?((r-1)*(j.body[R].keypoints[V].positionRaw[0]||0)+(O.positionRaw[0]||0))/r:O.positionRaw[0],j.body[R].keypoints[V]?((r-1)*(j.body[R].keypoints[V].positionRaw[1]||0)+(O.positionRaw[1]||0))/r:O.positionRaw[1],j.body[R].keypoints[V]?((r-1)*(j.body[R].keypoints[V].positionRaw[2]||0)+(O.positionRaw[2]||0))/r:O.positionRaw[2]],distance:[j.body[R].keypoints[V]?((r-1)*(((O0=j.body[R].keypoints[V].distance)==null?void 0:O0[0])||0)+(((L0=O.distance)==null?void 0:L0[0])||0))/r:(Be=O.distance)==null?void 0:Be[0],j.body[R].keypoints[V]?((r-1)*(((Ge=j.body[R].keypoints[V].distance)==null?void 0:Ge[1])||0)+(((me=O.distance)==null?void 0:me[1])||0))/r:(v2=O.distance)==null?void 0:v2[1],j.body[R].keypoints[V]?((r-1)*(((M2=j.body[R].keypoints[V].distance)==null?void 0:M2[2])||0)+(((R2=O.distance)==null?void 0:R2[2])||0))/r:(w2=O.distance)==null?void 0:w2[2]]}}),_={},n0={connected:{}};(i=(a=t.body)==null?void 0:a.modelPath)!=null&&i.includes("efficientpose")?n0=bt:(x=(l=t.body)==null?void 0:l.modelPath)!=null&&x.includes("blazepose")?n0=ft:(y=(d=t.body)==null?void 0:d.modelPath)!=null&&y.includes("movenet")&&(n0=Ke);for(let[O,V]of Object.entries(n0.connected)){let O0=[];for(let L0=0;L0me.part===V[L0]),Ge=X.find(me=>me.part===V[L0+1]);Be&&Ge&&O0.push([Be.position,Ge.position])}_[O]=O0}j.body[R]={...e.body[R],box:t0,boxRaw:E,keypoints:X,annotations:_}}if(!j.hand||e.hand.length!==j.hand.length)j.hand=JSON.parse(JSON.stringify(e.hand));else for(let R=0;R((r-1)*j.hand[R].box[O]+n0)/r),E=e.hand[R].boxRaw.map((n0,O)=>((r-1)*j.hand[R].boxRaw[O]+n0)/r);j.hand[R].keypoints.length!==e.hand[R].keypoints.length&&(j.hand[R].keypoints=e.hand[R].keypoints);let X=e.hand[R].keypoints&&e.hand[R].keypoints.length>0?e.hand[R].keypoints.map((n0,O)=>n0.map((V,O0)=>((r-1)*(j.hand[R].keypoints[O][O0]||1)+(V||0))/r)):[],_={};if(Object.keys(j.hand[R].annotations).length!==Object.keys(e.hand[R].annotations).length)j.hand[R].annotations=e.hand[R].annotations,_=j.hand[R].annotations;else if(e.hand[R].annotations)for(let n0 of Object.keys(e.hand[R].annotations))_[n0]=e.hand[R].annotations[n0]&&e.hand[R].annotations[n0][0]?e.hand[R].annotations[n0].map((O,V)=>O.map((O0,L0)=>((r-1)*j.hand[R].annotations[n0][V][L0]+O0)/r)):null;j.hand[R]={...e.hand[R],box:t0,boxRaw:E,keypoints:X,annotations:_}}if(!j.face||e.face.length!==j.face.length)j.face=JSON.parse(JSON.stringify(e.face));else for(let R=0;R((r-1)*j.face[R].box[_]+X)/r),E=e.face[R].boxRaw.map((X,_)=>((r-1)*j.face[R].boxRaw[_]+X)/r);if(e.face[R].rotation){let X={matrix:[0,0,0,0,0,0,0,0,0],angle:{roll:0,yaw:0,pitch:0},gaze:{bearing:0,strength:0}};X.matrix=(c=e.face[R].rotation)==null?void 0:c.matrix,X.angle={roll:((r-1)*(((h=(m=j.face[R].rotation)==null?void 0:m.angle)==null?void 0:h.roll)||0)+(((M=(p=e.face[R].rotation)==null?void 0:p.angle)==null?void 0:M.roll)||0))/r,yaw:((r-1)*(((g=(P=j.face[R].rotation)==null?void 0:P.angle)==null?void 0:g.yaw)||0)+(((v=(f=e.face[R].rotation)==null?void 0:f.angle)==null?void 0:v.yaw)||0))/r,pitch:((r-1)*(((k=(S=j.face[R].rotation)==null?void 0:S.angle)==null?void 0:k.pitch)||0)+(((C=(W=e.face[R].rotation)==null?void 0:W.angle)==null?void 0:C.pitch)||0))/r},X.gaze={bearing:((r-1)*(((D=(L=j.face[R].rotation)==null?void 0:L.gaze)==null?void 0:D.bearing)||0)+(((Z=(H=e.face[R].rotation)==null?void 0:H.gaze)==null?void 0:Z.bearing)||0))/r,strength:((r-1)*(((z=(F=j.face[R].rotation)==null?void 0:F.gaze)==null?void 0:z.strength)||0)+(((b0=(h0=e.face[R].rotation)==null?void 0:h0.gaze)==null?void 0:b0.strength)||0))/r},j.face[R]={...e.face[R],rotation:X,box:t0,boxRaw:E}}j.face[R]={...e.face[R],box:t0,boxRaw:E}}if(!j.object||e.object.length!==j.object.length)j.object=JSON.parse(JSON.stringify(e.object));else for(let R=0;R((r-1)*j.object[R].box[_]+X)/r),E=e.object[R].boxRaw.map((X,_)=>((r-1)*j.object[R].boxRaw[_]+X)/r);j.object[R]={...e.object[R],box:t0,boxRaw:E}}if(e.persons){let R=e.persons;if(!j.persons||R.length!==j.persons.length)j.persons=JSON.parse(JSON.stringify(R));else for(let t0=0;t0((r-1)*j.persons[t0].box[X]+E)/r)}e.gesture&&(j.gesture=e.gesture);let s=b();return b2=w.perfadd?b2+Math.round(s-o):Math.round(s-o),e.performance&&(j.performance={...e.performance,interpolate:b2}),j}var xn={};ne(xn,{distance:()=>et,match:()=>P2,similarity:()=>g2});function et(e,t,o={order:2,multiplier:25}){let n=0;for(let r=0;r{if(e===0)return 1;let r=t===2?Math.sqrt(e):e**(1/t),s=(1-r/100-o)/(n-o);return Math.max(Math.min(s,1),0)};function g2(e,t,o={order:2,multiplier:25,min:.2,max:.8}){let n=et(e,t,o);return yn(n,o.order||2,o.min||0,o.max||1)}function P2(e,t,o={order:2,multiplier:25,threshold:0,min:.2,max:.8}){if(!Array.isArray(e)||!Array.isArray(t)||e.length<64||t.length===0||e.length!==t[0].length)return{index:-1,distance:Number.POSITIVE_INFINITY,similarity:0};let n=Number.MAX_SAFE_INTEGER,r=-1;for(let a=0;az.box[0]&&W.box[0]z.box[1]&&W.box[1]+W.box[3]C.body.box[0]&&z.box[0]+z.box[2]C.body.box[1]&&z.box[1]+z.box[3]C.body.box[0]&&z.box[1]+z.box[3]>C.body.box[1]&&z.box[1]+z.box[3]{z&&z.length===4&&(L.push(z[0],z[0]+z[2]),D.push(z[1],z[1]+z[3]))};H((P=C.face)==null?void 0:P.box),H((g=C.body)==null?void 0:g.box),H((v=(f=C.hands)==null?void 0:f.left)==null?void 0:v.box),H((k=(S=C.hands)==null?void 0:S.right)==null?void 0:k.box);let Z=Math.min(...L),F=Math.min(...D);C.box=[Z,F,Math.max(...L)-Z,Math.max(...D)-F],r&&r[1]&&r[2]&&(C.boxRaw=[C.box[0]/r[2],C.box[1]/r[1],C.box[2]/r[2],C.box[3]/r[1]]),a.push(C)}return a}var Vt=` + `);t.stroke(a),t.stroke(s)}}function fr(e,t){var o,n,r,s;if(B.drawGaze&&((n=(o=e.rotation)==null?void 0:o.gaze)==null?void 0:n.strength)&&((s=(r=e.rotation)==null?void 0:r.gaze)==null?void 0:s.bearing)&&e.annotations.leftEyeIris&&e.annotations.rightEyeIris&&e.annotations.leftEyeIris[0]&&e.annotations.rightEyeIris[0]){t.strokeStyle="pink",t.fillStyle="pink";let a=[e.annotations.leftEyeIris[0][0]+Math.sin(e.rotation.gaze.bearing)*e.rotation.gaze.strength*e.box[3],e.annotations.leftEyeIris[0][1]+Math.cos(e.rotation.gaze.bearing)*e.rotation.gaze.strength*e.box[2]];m1(t,[e.annotations.leftEyeIris[0][0],e.annotations.leftEyeIris[0][1]],[a[0],a[1]],4);let i=[e.annotations.rightEyeIris[0][0]+Math.sin(e.rotation.gaze.bearing)*e.rotation.gaze.strength*e.box[3],e.annotations.rightEyeIris[0][1]+Math.cos(e.rotation.gaze.bearing)*e.rotation.gaze.strength*e.box[2]];m1(t,[e.annotations.rightEyeIris[0][0],e.annotations.rightEyeIris[0][1]],[i[0],i[1]],4)}}function mr(e,t){if(B.drawPolygons&&e.mesh.length>=468){t.lineWidth=1;for(let o=0;oe.mesh[r]);f1(t,n,B)}cr(e,t)}}function pr(e,t){if(B.drawPoints&&e.mesh.length>=468)for(let o=0;o0&&(pr(r,n),mr(r,n),dr(r,n),fr(r,n))}}async function Oe(e,t,o){var s;let n=J(i0,o);if(!t||!e)return;let r=P0(e);if(!!r){r.lineJoin="round";for(let a=0;a0)for(let a of s.keypoints)r.fillStyle=Z0(a[2],n),D0(r,a[0],a[1],0,n);if(n.drawLabels&&s.annotations){let a=(i,l)=>{if(!i||i.length===0||!i[0])return;let x=i[i.length-1][2]||-256;r.fillStyle=Z0(x,n),r.fillText(l,i[i.length-1][0]+4,i[i.length-1][1]+4)};r.font=n.font,a(s.annotations.index,"index"),a(s.annotations.middle,"middle"),a(s.annotations.ring,"ring"),a(s.annotations.pinky,"pinky"),a(s.annotations.thumb,"thumb"),a(s.annotations.palm,"palm")}if(n.drawPolygons&&s.annotations){let a=i=>{if(!(!i||i.length===0||!i[0]))for(let l=0;l0?l-1:0][0],i[l>0?l-1:0][1]),r.lineTo(i[l][0],i[l][1]),r.stroke()}};r.lineWidth=n.lineWidth,a(s.annotations.index),a(s.annotations.middle),a(s.annotations.ring),a(s.annotations.pinky),a(s.annotations.thumb)}}}}async function Le(e,t,o){let n=J(i0,o);if(!t||!e)return;let r=P0(e);if(!!r){r.lineJoin="round",r.font=n.font;for(let s of t)if(n.drawBoxes){if(r.strokeStyle=n.color,r.fillStyle=n.color,C0(r,s.box[0],s.box[1],s.box[2],s.box[3],n),n.drawLabels){let a=`${s.label} ${Math.round(100*s.score)}%`;n.shadowColor&&n.shadowColor!==""&&(r.fillStyle=n.shadowColor,r.fillText(a,s.box[0]+3,1+s.box[1]+n.lineHeight,s.box[2])),r.fillStyle=n.labelColor,r.fillText(a,s.box[0]+2,0+s.box[1]+n.lineHeight,s.box[2])}r.stroke()}}}async function Fe(e,t,o){let n=J(i0,o);if(!(!t||!e)&&n.drawGestures){let r=P0(e);if(!r)return;r.font=n.font,r.fillStyle=n.color;let s=1;for(let a=0;a1&&l[1].length>0){let x=i[1]>0?`#${i[1]}`:"",d=`${i[0]} ${x}: ${l[1]}`;n.shadowColor&&n.shadowColor!==""&&(r.fillStyle=n.shadowColor,r.fillText(d,8,2+s*n.lineHeight)),r.fillStyle=n.labelColor,r.fillText(d,6,0+s*n.lineHeight),s+=1}}}}var p1=0;async function u1(e,t,o){let n=J(i0,o);if(!t||!e)return;let r=P0(e);if(!!r){r.lineJoin="round",r.font=n.font;for(let s=0;st!=o[r].y>t&&e<(o[r].x-o[s].x)*(t-o[s].y)/(o[r].y-o[s].y)+o[s].x&&(n=!n);return n}async function Ao(e){if(!e.tensor||!e.mesh||e.mesh.length<100)return e.tensor;let t=e.tensor.shape[2]||0,o=e.tensor.shape[1]||0,n=await e.tensor.buffer(),r=[];for(let a of T0.silhouette)r.push({x:(e.mesh[a][0]-e.box[0])/e.box[2],y:(e.mesh[a][1]-e.box[1])/e.box[3]});Ge&&Ge>0&&(r=r.map(a=>({x:a.x>.5?a.x+Ge:a.x-Ge,y:a.y>.5?a.y+Ge:a.y-Ge})));for(let a=0;a{let t=(y,c)=>Math.atan2(y[1]-c[1],y[0]-c[0]);if(!e.annotations.rightEyeIris||!e.annotations.leftEyeIris)return{bearing:0,strength:0};let o=[0,-.1],n=1,r=(e.mesh[33][2]||0)>(e.mesh[263][2]||0),s=r?e.mesh[473]:e.mesh[468],a=r?[(e.mesh[133][0]+e.mesh[33][0])/2,(e.mesh[133][1]+e.mesh[33][1])/2]:[(e.mesh[263][0]+e.mesh[362][0])/2,(e.mesh[263][1]+e.mesh[362][1])/2],i=r?[e.mesh[133][0]-e.mesh[33][0],e.mesh[23][1]-e.mesh[27][1]]:[e.mesh[263][0]-e.mesh[362][0],e.mesh[253][1]-e.mesh[257][1]],l=[(a[0]-s[0])/i[0]-o[0],n*(s[1]-a[1])/i[1]-o[1]],x=Math.sqrt(l[0]*l[0]+l[1]*l[1]);return x=Math.min(x,e.boxRaw[2]/2,e.boxRaw[3]/2),{bearing:(t([0,0],l)+Math.PI/2)%Math.PI,strength:x}},so=(e,t)=>{let o=p=>{let R=Math.sqrt(p[0]*p[0]+p[1]*p[1]+p[2]*p[2]);return p[0]/=R,p[1]/=R,p[2]/=R,p},n=(p,R)=>{let P=p[0]-R[0],g=p[1]-R[1],f=p[2]-R[2];return[P,g,f]},r=(p,R)=>{let P=p[1]*R[2]-p[2]*R[1],g=p[2]*R[0]-p[0]*R[2],f=p[0]*R[1]-p[1]*R[0];return[P,g,f]},s=p=>{let[R,P,g,f,M,j,k,I,C]=p,O,D,H;return f<1?f>-1?(H=Math.asin(f),D=Math.atan2(-k,R),O=Math.atan2(-j,M)):(H=-Math.PI/2,D=-Math.atan2(I,C),O=0):(H=Math.PI/2,D=Math.atan2(I,C),O=0),isNaN(O)&&(O=0),isNaN(D)&&(D=0),isNaN(H)&&(H=0),{pitch:2*-O,yaw:2*-D,roll:2*-H}},a=e.meshRaw;if(!a||a.length<300)return{angle:{pitch:0,yaw:0,roll:0},matrix:[1,0,0,0,1,0,0,0,1],gaze:{bearing:0,strength:0}};let i=Math.max(e.boxRaw[2]*t[0],e.boxRaw[3]*t[1])/1.5,l=[a[10],a[152],a[234],a[454]].map(p=>[p[0]*t[0]/i,p[1]*t[1]/i,p[2]]),x=o(n(l[1],l[0])),d=o(n(l[3],l[2])),y=o(r(d,x));d=r(x,y);let c=[d[0],d[1],d[2],x[0],x[1],x[2],y[0],y[1],y[2]],m=s(c),h=a.length===478?gr(e):{bearing:0,strength:0};return{angle:m,matrix:c,gaze:h}};var P1=async(e,t)=>{var m,h,p,R,P,g,f,M,j,k,I,C,O,D,H,Z,F,z,h0,b0,T,t0;let o=b(),n,r,s,a,i,l,x,d,y=[];e.state="run:face";let c=await Qt(t,e.config);if(e.performance.face=v.perfadd?(e.performance.face||0)+Math.trunc(b()-o):Math.trunc(b()-o),!t.shape||t.shape.length!==4)return[];if(!c)return[];for(let E=0;E200?so(c[E],[t.shape[2],t.shape[1]]):null;e.analyze("Start Emotion:"),e.config.async?a=(h=e.config.face.emotion)!=null&&h.enabled?z5(c[E].tensor||A.tensor([]),e.config,E,c.length):[]:(e.state="run:emotion",o=b(),a=(p=e.config.face.emotion)!=null&&p.enabled?await z5(c[E].tensor||A.tensor([]),e.config,E,c.length):[],e.performance.emotion=v.perfadd?(e.performance.emotion||0)+Math.trunc(b()-o):Math.trunc(b()-o)),e.analyze("End Emotion:"),e.analyze("Start AntiSpoof:"),e.config.async?l=(R=e.config.face.antispoof)!=null&&R.enabled?y5(c[E].tensor||A.tensor([]),e.config,E,c.length):0:(e.state="run:antispoof",o=b(),l=(P=e.config.face.antispoof)!=null&&P.enabled?await y5(c[E].tensor||A.tensor([]),e.config,E,c.length):0,e.performance.antispoof=v.perfadd?(e.performance.antispoof||0)+Math.trunc(b()-o):Math.trunc(b()-o)),e.analyze("End AntiSpoof:"),e.analyze("Start Liveness:"),e.config.async?x=(g=e.config.face.liveness)!=null&&g.enabled?K5(c[E].tensor||A.tensor([]),e.config,E,c.length):0:(e.state="run:liveness",o=b(),x=(f=e.config.face.liveness)!=null&&f.enabled?await K5(c[E].tensor||A.tensor([]),e.config,E,c.length):0,e.performance.liveness=v.perfadd?(e.performance.antispoof||0)+Math.trunc(b()-o):Math.trunc(b()-o)),e.analyze("End Liveness:"),e.analyze("Start GEAR:"),e.config.async?r=(M=e.config.face.gear)!=null&&M.enabled?n5(c[E].tensor||A.tensor([]),e.config,E,c.length):null:(e.state="run:gear",o=b(),r=(j=e.config.face.gear)!=null&&j.enabled?await n5(c[E].tensor||A.tensor([]),e.config,E,c.length):null,e.performance.gear=Math.trunc(b()-o)),e.analyze("End GEAR:"),e.analyze("Start SSRNet:"),e.config.async?(n=(k=e.config.face.ssrnet)!=null&&k.enabled?A5(c[E].tensor||A.tensor([]),e.config,E,c.length):null,s=(I=e.config.face.ssrnet)!=null&&I.enabled?i5(c[E].tensor||A.tensor([]),e.config,E,c.length):null):(e.state="run:ssrnet",o=b(),n=(C=e.config.face.ssrnet)!=null&&C.enabled?await A5(c[E].tensor||A.tensor([]),e.config,E,c.length):null,s=(O=e.config.face.ssrnet)!=null&&O.enabled?await i5(c[E].tensor||A.tensor([]),e.config,E,c.length):null,e.performance.ssrnet=Math.trunc(b()-o)),e.analyze("End SSRNet:"),e.analyze("Start MobileFaceNet:"),e.config.async?i=(D=e.config.face.mobilefacenet)!=null&&D.enabled?j5(c[E].tensor||A.tensor([]),e.config,E,c.length):null:(e.state="run:mobilefacenet",o=b(),i=(H=e.config.face.mobilefacenet)!=null&&H.enabled?await j5(c[E].tensor||A.tensor([]),e.config,E,c.length):null,e.performance.mobilefacenet=Math.trunc(b()-o)),e.analyze("End MobileFaceNet:"),e.analyze("Start Description:"),e.config.async?d=(Z=e.config.face.description)!=null&&Z.enabled?L5(c[E].tensor||A.tensor([]),e.config,E,c.length):null:(e.state="run:description",o=b(),d=(F=e.config.face.description)!=null&&F.enabled?await L5(c[E].tensor||A.tensor([]),e.config,E,c.length):null,e.performance.description=v.perfadd?(e.performance.description||0)+Math.trunc(b()-o):Math.trunc(b()-o)),e.analyze("End Description:"),e.config.async&&([n,s,a,i,d,r,l,x]=await Promise.all([n,s,a,i,d,r,l,x])),e.analyze("Finish Face:"),((z=e.config.face.ssrnet)==null?void 0:z.enabled)&&n&&s&&(d={...d,age:n.age,gender:s.gender,genderScore:s.genderScore}),((h0=e.config.face.gear)==null?void 0:h0.enabled)&&r&&(d={...d,age:r.age,gender:r.gender,genderScore:r.genderScore,race:r.race}),((b0=e.config.face.mobilefacenet)==null?void 0:b0.enabled)&&i&&(d.descriptor=i),(T=e.config.face.iris)!=null&&T.enabled;let _=c[E].annotations&&c[E].annotations.leftEyeIris&&c[E].annotations.leftEyeIris[0]&&c[E].annotations.rightEyeIris&&c[E].annotations.rightEyeIris[0]&&c[E].annotations.leftEyeIris.length>0&&c[E].annotations.rightEyeIris.length>0&&c[E].annotations.leftEyeIris[0]!==null&&c[E].annotations.rightEyeIris[0]!==null?Math.max(Math.abs(c[E].annotations.leftEyeIris[3][0]-c[E].annotations.leftEyeIris[1][0]),Math.abs(c[E].annotations.rightEyeIris[4][1]-c[E].annotations.rightEyeIris[2][1]))/t.shape[2]:0,n0=(t0=e.config.face.detector)!=null&&t0.return?A.squeeze(c[E].tensor):null;A.dispose(c[E].tensor),c[E].tensor&&delete c[E].tensor;let N={...c[E],id:E};d!=null&&d.age&&(N.age=d.age),d!=null&&d.gender&&(N.gender=d.gender),d!=null&&d.genderScore&&(N.genderScore=d==null?void 0:d.genderScore),d!=null&&d.descriptor&&(N.embedding=d==null?void 0:d.descriptor),d!=null&&d.race&&(N.race=d==null?void 0:d.race),a&&(N.emotion=a),l&&(N.real=l),x&&(N.live=x),_&&_!==0&&(N.iris=Math.trunc(500/_/11.7)/100),X&&(N.rotation=X),n0&&(N.tensor=n0),y.push(N),e.analyze("End Face")}return e.analyze("End FaceMesh:"),e.config.async&&(e.performance.face&&delete e.performance.face,e.performance.age&&delete e.performance.age,e.performance.gender&&delete e.performance.gender,e.performance.emotion&&delete e.performance.emotion),y};var ao=e=>{if(!e)return[];let t=[];for(let o=0;ol.part==="leftWrist"),r=e[o].keypoints.find(l=>l.part==="rightWrist"),s=e[o].keypoints.find(l=>l.part==="nose");s&&n&&r&&n.position[1]l.part==="leftShoulder"),i=e[o].keypoints.find(l=>l.part==="rightShoulder");a&&i&&Math.abs(a.positionRaw[1]-i.positionRaw[1])>.1&&t.push({body:o,gesture:`leaning ${a.position[1]>i.position[1]?"left":"right"}`})}return t},io=e=>{if(!e)return[];let t=[];for(let o=0;o450){let n=(e[o].mesh[33][2]||0)-(e[o].mesh[263][2]||0),r=e[o].mesh[33][0]-e[o].mesh[263][0];Math.abs(n/r)<=.15?t.push({face:o,gesture:"facing center"}):t.push({face:o,gesture:`facing ${n<0?"left":"right"}`}),Math.abs(e[o].mesh[374][1]-e[o].mesh[386][1])/Math.abs(e[o].mesh[443][1]-e[o].mesh[450][1])<.2&&t.push({face:o,gesture:"blink left eye"}),Math.abs(e[o].mesh[145][1]-e[o].mesh[159][1])/Math.abs(e[o].mesh[223][1]-e[o].mesh[230][1])<.2&&t.push({face:o,gesture:"blink right eye"});let i=Math.min(100,500*Math.abs(e[o].mesh[13][1]-e[o].mesh[14][1])/Math.abs(e[o].mesh[10][1]-e[o].mesh[152][1]));i>10&&t.push({face:o,gesture:`mouth ${Math.trunc(i)}% open`});let l=e[o].mesh[152][2]||0;Math.abs(l)>10&&t.push({face:o,gesture:`head ${l<0?"up":"down"}`})}return t},lo=e=>{if(!e)return[];let t=[];for(let o=0;o.06||c>.06)&&(x=!1),y>c?y>.05&&t.push({iris:o,gesture:"looking right"}):c>.05&&t.push({iris:o,gesture:"looking left"});let m=Math.abs(e[o].mesh[145][1]-e[o].annotations.rightEyeIris[0][1])/e[o].box[3],h=Math.abs(e[o].mesh[374][1]-e[o].annotations.leftEyeIris[0][1])/e[o].box[3];(h<.01||m<.01||h>.022||m>.022)&&(x=!1),(h<.01||m<.01)&&t.push({iris:o,gesture:"looking down"}),(h>.022||m>.022)&&t.push({iris:o,gesture:"looking up"}),x&&t.push({iris:o,gesture:"looking center"})}return t},yo=e=>{if(!e)return[];let t=[];for(let o=0;o0){let r=n.reduce((a,i)=>(a.position[2]||0)<(i.position[2]||0)?a:i);t.push({hand:o,gesture:`${r.name} forward`});let s=n.reduce((a,i)=>a.position[1]((r-1)*S.body[T].box[V]+N)/r),E=e.body[T].boxRaw.map((N,V)=>((r-1)*S.body[T].boxRaw[V]+N)/r),X=e.body[T].keypoints.map((N,V)=>{var I0,N0,He,Ve,ue,v1,w1,k1,E1;return{score:N.score,part:N.part,position:[S.body[T].keypoints[V]?((r-1)*(S.body[T].keypoints[V].position[0]||0)+(N.position[0]||0))/r:N.position[0],S.body[T].keypoints[V]?((r-1)*(S.body[T].keypoints[V].position[1]||0)+(N.position[1]||0))/r:N.position[1],S.body[T].keypoints[V]?((r-1)*(S.body[T].keypoints[V].position[2]||0)+(N.position[2]||0))/r:N.position[2]],positionRaw:[S.body[T].keypoints[V]?((r-1)*(S.body[T].keypoints[V].positionRaw[0]||0)+(N.positionRaw[0]||0))/r:N.positionRaw[0],S.body[T].keypoints[V]?((r-1)*(S.body[T].keypoints[V].positionRaw[1]||0)+(N.positionRaw[1]||0))/r:N.positionRaw[1],S.body[T].keypoints[V]?((r-1)*(S.body[T].keypoints[V].positionRaw[2]||0)+(N.positionRaw[2]||0))/r:N.positionRaw[2]],distance:[S.body[T].keypoints[V]?((r-1)*(((I0=S.body[T].keypoints[V].distance)==null?void 0:I0[0])||0)+(((N0=N.distance)==null?void 0:N0[0])||0))/r:(He=N.distance)==null?void 0:He[0],S.body[T].keypoints[V]?((r-1)*(((Ve=S.body[T].keypoints[V].distance)==null?void 0:Ve[1])||0)+(((ue=N.distance)==null?void 0:ue[1])||0))/r:(v1=N.distance)==null?void 0:v1[1],S.body[T].keypoints[V]?((r-1)*(((w1=S.body[T].keypoints[V].distance)==null?void 0:w1[2])||0)+(((k1=N.distance)==null?void 0:k1[2])||0))/r:(E1=N.distance)==null?void 0:E1[2]]}}),_={},n0={connected:{}};(i=(a=t.body)==null?void 0:a.modelPath)!=null&&i.includes("efficientpose")?n0=M2:(x=(l=t.body)==null?void 0:l.modelPath)!=null&&x.includes("blazepose")?n0=u2:(y=(d=t.body)==null?void 0:d.modelPath)!=null&&y.includes("movenet")&&(n0=$e);for(let[N,V]of Object.entries(n0.connected)){let I0=[];for(let N0=0;N0ue.part===V[N0]),Ve=X.find(ue=>ue.part===V[N0+1]);He&&Ve&&I0.push([He.position,Ve.position])}_[N]=I0}S.body[T]={...e.body[T],box:t0,boxRaw:E,keypoints:X,annotations:_}}if(!S.hand||e.hand.length!==S.hand.length)S.hand=JSON.parse(JSON.stringify(e.hand));else for(let T=0;T((r-1)*S.hand[T].box[N]+n0)/r),E=e.hand[T].boxRaw.map((n0,N)=>((r-1)*S.hand[T].boxRaw[N]+n0)/r);S.hand[T].keypoints.length!==e.hand[T].keypoints.length&&(S.hand[T].keypoints=e.hand[T].keypoints);let X=e.hand[T].keypoints&&e.hand[T].keypoints.length>0?e.hand[T].keypoints.map((n0,N)=>n0.map((V,I0)=>((r-1)*(S.hand[T].keypoints[N][I0]||1)+(V||0))/r)):[],_={};if(Object.keys(S.hand[T].annotations).length!==Object.keys(e.hand[T].annotations).length)S.hand[T].annotations=e.hand[T].annotations,_=S.hand[T].annotations;else if(e.hand[T].annotations)for(let n0 of Object.keys(e.hand[T].annotations))_[n0]=e.hand[T].annotations[n0]&&e.hand[T].annotations[n0][0]?e.hand[T].annotations[n0].map((N,V)=>N.map((I0,N0)=>((r-1)*S.hand[T].annotations[n0][V][N0]+I0)/r)):null;S.hand[T]={...e.hand[T],box:t0,boxRaw:E,keypoints:X,annotations:_}}if(!S.face||e.face.length!==S.face.length)S.face=JSON.parse(JSON.stringify(e.face));else for(let T=0;T((r-1)*S.face[T].box[_]+X)/r),E=e.face[T].boxRaw.map((X,_)=>((r-1)*S.face[T].boxRaw[_]+X)/r);if(e.face[T].rotation){let X={matrix:[0,0,0,0,0,0,0,0,0],angle:{roll:0,yaw:0,pitch:0},gaze:{bearing:0,strength:0}};X.matrix=(c=e.face[T].rotation)==null?void 0:c.matrix,X.angle={roll:((r-1)*(((h=(m=S.face[T].rotation)==null?void 0:m.angle)==null?void 0:h.roll)||0)+(((R=(p=e.face[T].rotation)==null?void 0:p.angle)==null?void 0:R.roll)||0))/r,yaw:((r-1)*(((g=(P=S.face[T].rotation)==null?void 0:P.angle)==null?void 0:g.yaw)||0)+(((M=(f=e.face[T].rotation)==null?void 0:f.angle)==null?void 0:M.yaw)||0))/r,pitch:((r-1)*(((k=(j=S.face[T].rotation)==null?void 0:j.angle)==null?void 0:k.pitch)||0)+(((C=(I=e.face[T].rotation)==null?void 0:I.angle)==null?void 0:C.pitch)||0))/r},X.gaze={bearing:((r-1)*(((D=(O=S.face[T].rotation)==null?void 0:O.gaze)==null?void 0:D.bearing)||0)+(((Z=(H=e.face[T].rotation)==null?void 0:H.gaze)==null?void 0:Z.bearing)||0))/r,strength:((r-1)*(((z=(F=S.face[T].rotation)==null?void 0:F.gaze)==null?void 0:z.strength)||0)+(((b0=(h0=e.face[T].rotation)==null?void 0:h0.gaze)==null?void 0:b0.strength)||0))/r},S.face[T]={...e.face[T],rotation:X,box:t0,boxRaw:E}}S.face[T]={...e.face[T],box:t0,boxRaw:E}}if(!S.object||e.object.length!==S.object.length)S.object=JSON.parse(JSON.stringify(e.object));else for(let T=0;T((r-1)*S.object[T].box[_]+X)/r),E=e.object[T].boxRaw.map((X,_)=>((r-1)*S.object[T].boxRaw[_]+X)/r);S.object[T]={...e.object[T],box:t0,boxRaw:E}}if(e.persons){let T=e.persons;if(!S.persons||T.length!==S.persons.length)S.persons=JSON.parse(JSON.stringify(T));else for(let t0=0;t0((r-1)*S.persons[t0].box[X]+E)/r)}e.gesture&&(S.gesture=e.gesture);let s=b();return M1=v.perfadd?M1+Math.round(s-o):Math.round(s-o),e.performance&&(S.performance={...e.performance,interpolate:M1}),S}var fo={};ne(fo,{distance:()=>n2,match:()=>T1,similarity:()=>R1});function n2(e,t,o={order:2,multiplier:25}){let n=0;for(let r=0;r{if(e===0)return 1;let r=t===2?Math.sqrt(e):e**(1/t),s=(1-r/100-o)/(n-o);return Math.max(Math.min(s,1),0)};function R1(e,t,o={order:2,multiplier:25,min:.2,max:.8}){let n=n2(e,t,o);return co(n,o.order||2,o.min||0,o.max||1)}function T1(e,t,o={order:2,multiplier:25,threshold:0,min:.2,max:.8}){if(!Array.isArray(e)||!Array.isArray(t)||e.length<64||t.length===0||e.length!==t[0].length)return{index:-1,distance:Number.POSITIVE_INFINITY,similarity:0};let n=Number.MAX_SAFE_INTEGER,r=-1;for(let a=0;az.box[0]&&I.box[0]z.box[1]&&I.box[1]+I.box[3]C.body.box[0]&&z.box[0]+z.box[2]C.body.box[1]&&z.box[1]+z.box[3]C.body.box[0]&&z.box[1]+z.box[3]>C.body.box[1]&&z.box[1]+z.box[3]{z&&z.length===4&&(O.push(z[0],z[0]+z[2]),D.push(z[1],z[1]+z[3]))};H((P=C.face)==null?void 0:P.box),H((g=C.body)==null?void 0:g.box),H((M=(f=C.hands)==null?void 0:f.left)==null?void 0:M.box),H((k=(j=C.hands)==null?void 0:j.right)==null?void 0:k.box);let Z=Math.min(...O),F=Math.min(...D);C.box=[Z,F,Math.max(...O)-Z,Math.max(...D)-F],r&&r[1]&&r[2]&&(C.boxRaw=[C.box[0]/r[2],C.box[1]/r[1],C.box[2]/r[2],C.box[3]/r[1]]),a.push(C)}return a}var X2=` /9j/4AAQSkZJRgABAQEAYABgAAD/4QBoRXhpZgAATU0AKgAAAAgABAEaAAUAAAABAAAAPgEbAAUA AAABAAAARgEoAAMAAAABAAIAAAExAAIAAAARAAAATgAAAAAAAABgAAAAAQAAAGAAAAABcGFpbnQu bmV0IDQuMi4xMwAA/9sAQwAGBAUGBQQGBgUGBwcGCAoQCgoJCQoUDg8MEBcUGBgXFBYWGh0lHxob @@ -259,7 +259,7 @@ PQ4GJ+ashuK0MhWaoWcA0AaOmASMK7jRNPWYBmHyiuepO2x10qfcv6vYxCzYqoGK4HVYVTJrmb5l c6oaM5TUJ8EgGsG4kLNUHT0M64OaqMMikSRsuKbnFMRLG3zVehOaGNE445NNlnVFpDMu6uie9Vo1 8z5mOAOST2pDK91cNN+5tsrH3PrW54a06KxT7fdrlh/q1Pc+tJ6IUdZGvHPLezMcnBOWbsPap5r3 ylFtbdT1xUWNWzU0/Zbwlgfmx8zGsHWtRHmMqE59aAMyNifvHPc1f0gtPdqkY5JosJHeNci2tktY -euPnNY+oXWZEVJNrZ9aun8SIq/CzodHuriIokhDIR1ronbKZr0o6o8ipoz//2Q==`,Zt=` +euPnNY+oXWZEVJNrZ9aun8SIq/CzodHuriIokhDIR1ronbKZr0o6o8ipoz//2Q==`,q2=` /9j/4AAQSkZJRgABAQAAAQABAAD/2wBDAAsICAoIBwsKCQoNDAsNERwSEQ8PESIZGhQcKSQrKigk JyctMkA3LTA9MCcnOEw5PUNFSElIKzZPVU5GVEBHSEX/2wBDAQwNDREPESESEiFFLicuRUVFRUVF RUVFRUVFRUVFRUVFRUVFRUVFRUVFRUVFRUVFRUVFRUVFRUVFRUVFRUVFRUX/wAARCASwBLADASIA @@ -827,7 +827,7 @@ AAAAAAJAAAAAAAAAAAAAABAJEAAAAAAAAAAAAAAAIEoBKAAAAAAAAAAAAAAABAlAAAAAAAIAAAAA BAkBAkBAkBAlACEgMZjdjbFW8bWrEx8YWANb6Fp+bfwab+vLDKMFK9qxH5L0bAr8OPRPKz2AY7J2 SbAjYZAI2E7AIEgIEgIEgMdkSy2NgY7MdlmyNoBXsxmFuyNgVTVjNV3KjlBRNTlXTVHKCrlIqt5T lBhEMohlFerLlBjEMohMVTEARDKCITsAk2AEgAAAkAAAAAAAAAAAAAAAAAAAAAAAASAAAAAAAAD/ -2Q==`;async function cA(e){let t=(r,s="application/octet-stream")=>fetch(`data:${s};base64,${r}`).then(a=>a.blob()),o,n;switch(e.config.warmup){case"face":o=await t(Vt);break;case"body":case"full":o=await t(Zt);break;default:o=null}if(o){let r=await createImageBitmap(o);n=await e.detect(r,e.config),r.close()}return n}async function dA(e){return new Promise(t=>{let o;switch(e.config.warmup){case"face":o="data:image/jpeg;base64,"+Vt;break;case"full":case"body":o="data:image/jpeg;base64,"+Zt;break;default:o=null}let n;if(typeof Image!="undefined")n=new Image;else if(w.Image)n=new w.Image;else return;n.onload=async()=>{let r=i0(n.naturalWidth,n.naturalHeight);if(!r)u("Warmup: Canvas not found"),t(void 0);else{let s=r.getContext("2d");s&&s.drawImage(n,0,0);let a=await e.image(r),i=await e.detect(a.tensor,e.config);t(i)}},o?n.src=o:t(void 0)})}async function fA(e){let t=r=>Buffer.from(r,"base64"),o;e.config.warmup==="face"?o=t(Vt):o=t(Zt);let n;if("node"in A){let r=A.node.decodeJpeg(o),s=r.expandDims(0);e.tf.dispose(r),n=await e.detect(s,e.config),e.tf.dispose(s)}else e.config.debug&&u("Warmup tfjs-node not loaded");return n}async function mA(e){let t;return typeof createImageBitmap=="function"?t=await cA(e):typeof Image!="undefined"||w.Canvas!==void 0?t=await dA(e):t=await fA(e),t}async function pA(e){let t=A.getBackend(),o=A.backend();if(t!=="webgl"&&t!=="humangl"||!o||!o.checkCompileCompletion)return;A.env().set("ENGINE_COMPILE_ONLY",!0);let n=A.engine().state.numTensors,r=[];for(let[i,l]of Object.entries(e).filter(([x,d])=>x!==null&&d!==null)){let x=l.inputs&&l.inputs[0]&&l.inputs[0].shape?[...l.inputs[0].shape]:[1,64,64,3],d=l.inputs&&l.inputs[0]&&l.inputs[0].dtype?l.inputs[0].dtype:"float32";for(let c=0;cA.dispose(m)):A.dispose(c)}catch(c){u("compile fail model:",i)}A.dispose(y)}let s=await o.checkCompileCompletionAsync();o.getUniformLocations(),u("compile pass models:",r),u("compile pass kernels:",s.length),A.env().set("ENGINE_COMPILE_ONLY",!1);let a=A.engine().state.numTensors;a-n>0&&u("tensor leak:",a-n)}async function dn(e,t){let o=b();return e.state="warmup",t&&(e.config=K(e.config,t)),!e.config.warmup||e.config.warmup.length===0||e.config.warmup==="none"?{face:[],body:[],hand:[],gesture:[],object:[],performance:e.performance,timestamp:b(),persons:[],error:null}:new Promise(async n=>{await pA(e.models);let r=await mA(e),s=b();e.config.debug&&u("warmup",e.config.warmup,Math.round(s-o),"ms"),e.emit("warmup"),n(r)})}var Fe,tt,ot,Dt,fn=class{constructor(t){T(this,"version");T(this,"config");T(this,"result");T(this,"state");T(this,"process");T(this,"tf");T(this,"env");T(this,"draw");T(this,"models");T(this,"events");T(this,"faceTriangulation");T(this,"faceUVMap");T(this,"performance");Ve(this,Fe,void 0);Ve(this,tt,void 0);Ve(this,ot,void 0);T(this,"gl");T(this,"analyze",(...t)=>{if(!He(this,tt))return;let o=this.tf.engine().state.numTensors,n=He(this,Fe);Ze(this,Fe,o);let r=o-n;r!==0&&u(...t,r)});Ve(this,Dt,t=>{if(!He(this,ot))return null;if(!t)return"input is not defined";if(this.env.node&&!(t instanceof pe))return"input must be a tensor";try{this.tf.getBackend()}catch(o){return"backend not loaded"}return null});T(this,"similarity",g2);T(this,"distance",et);T(this,"match",P2);T(this,"emit",t=>{var o;this.events&&this.events.dispatchEvent&&((o=this.events)==null||o.dispatchEvent(new Event(t)))});this.env=w,re.wasmPath=De["tfjs-core"].includes("-")?"https://vladmandic.github.io/tfjs/dist/":`https://cdn.jsdelivr.net/npm/@tensorflow/tfjs-backend-wasm@${A.version_core}/dist/`,re.modelBasePath=w.browser?"../models/":"file://models/",re.backend=w.browser?"humangl":"tensorflow",this.version=Qt,Object.defineProperty(this,"version",{value:Qt}),this.config=JSON.parse(JSON.stringify(re)),Object.seal(this.config),this.config.cacheModels=typeof indexedDB!="undefined",t&&(this.config=K(this.config,t)),F2(this.config),this.tf=A,this.state="idle",Ze(this,Fe,0),Ze(this,tt,!1),Ze(this,ot,!1),this.performance={},this.events=typeof EventTarget!="undefined"?new EventTarget:void 0,this.models=new $e,this.draw={options:a0,canvas:(o,n)=>m2(o,n),face:(o,n,r)=>Ce(o,n,r),body:(o,n,r)=>We(o,n,r),hand:(o,n,r)=>Oe(o,n,r),gesture:(o,n,r)=>Ie(o,n,r),object:(o,n,r)=>Le(o,n,r),person:(o,n,r)=>f2(o,n,r),all:(o,n,r)=>p2(o,n,r)},this.result={face:[],body:[],hand:[],gesture:[],object:[],performance:{},timestamp:0,persons:[],error:null},this.process={tensor:null,canvas:null},this.faceTriangulation=Y1,this.faceUVMap=K1,this.gl=J,this.emit("create")}reset(){let t=this.config.backend;this.config=JSON.parse(JSON.stringify(re)),this.config.backend=t}validate(t){return qt(re,t||this.config)}now(){return b()}image(t,o=!0){return he(t,this.config,o)}async segmentation(t,o){return Ko(t,o,this.config)}enhance(t){return W5(t)}compare(t,o){return N2(this.config,t,o)}async init(){await Ht(this,!0),await this.tf.ready()}async load(t){this.state="load";let o=b(),n=Object.values(this.models).filter(a=>a).length;t&&(this.config=K(this.config,t)),this.env.initial&&(this.config.debug&&u(`version: ${this.version}`),this.config.debug&&u(`tfjs version: ${this.tf.version["tfjs-core"]}`),await Ht(this)||u("error: backend check failed"),await A.ready(),this.env.browser&&(this.config.debug&&u("configuration:",this.config),this.config.debug&&u("environment:",this.env),this.config.debug&&u("tf flags:",this.tf.ENV.flags))),await i2(this),this.env.initial&&this.config.debug&&u("tf engine state:",this.tf.engine().state.numBytes,"bytes",this.tf.engine().state.numTensors,"tensors"),this.env.initial=!1,Object.values(this.models).filter(a=>a).length!==n&&(await l2(this),this.emit("load"));let s=Math.trunc(b()-o);s>(this.performance.loadModels||0)&&(this.performance.loadModels=this.env.perfadd?(this.performance.loadModels||0)+s:s)}next(t=this.result){return ln(t,this.config)}async warmup(t){let o=b(),n=await dn(this,t),r=b();return this.performance.warmup=Math.trunc(r-o),n}async profile(t,o){let n=await this.tf.profile(()=>this.detect(t,o)),r={};for(let i of n.kernels)r[i.name]?r[i.name]+=i.kernelTimeMs:r[i.name]=i.kernelTimeMs;let s=[];Object.entries(r).forEach(i=>s.push({name:i[0],ms:i[1]})),s.sort((i,l)=>l.ms-i.ms),s.length=20;let a={};for(let i of s)a[i.name]=i.ms;return a}async detect(t,o){return this.state="detect",new Promise(async n=>{var M,P,g,f,v,S,k,W,C,L,D,H,Z,F,z,h0,b0,R,t0,E,X,_;this.state="config";let r;this.config=K(this.config,o),this.state="check";let s=He(this,Dt).call(this,t);s&&(u(s,t),this.emit("error"),n({face:[],body:[],hand:[],gesture:[],object:[],performance:this.performance,timestamp:b(),persons:[],error:s}));let a=b();await Ht(this),await this.load(),r=b(),this.state="image";let i=await he(t,this.config);if(this.process=i,this.performance.inputProcess=this.env.perfadd?(this.performance.inputProcess||0)+Math.trunc(b()-r):Math.trunc(b()-r),this.analyze("Get Image:"),!i.tensor){this.config.debug&&u("could not convert input to tensor"),this.emit("error"),n({face:[],body:[],hand:[],gesture:[],object:[],performance:this.performance,timestamp:b(),persons:[],error:"could not convert input to tensor"});return}this.emit("image"),r=b(),this.config.skipAllowed=await I2(this.config,i.tensor),this.performance.totalFrames||(this.performance.totalFrames=0),this.performance.cachedFrames||(this.performance.cachedFrames=0),this.performance.totalFrames++,this.config.skipAllowed&&this.performance.cachedFrames++,this.performance.cacheCheck=this.env.perfadd?(this.performance.cacheCheck||0)+Math.trunc(b()-r):Math.trunc(b()-r),this.analyze("Check Changed:");let l=[],x=[],d=[],y=[];this.state="detect:face",this.config.async?(l=this.config.face.enabled?h2(this,i.tensor):[],this.performance.face&&delete this.performance.face):(r=b(),l=this.config.face.enabled?await h2(this,i.tensor):[],this.performance.face=this.env.perfadd?(this.performance.face||0)+Math.trunc(b()-r):Math.trunc(b()-r)),this.config.async&&(this.config.body.maxDetected===-1||this.config.hand.maxDetected===-1)&&(l=await l),this.analyze("Start Body:"),this.state="detect:body";let c=this.config.body.maxDetected===-1?K(this.config,{body:{maxDetected:this.config.face.enabled?1*l.length:1}}):this.config;this.config.async?((M=this.config.body.modelPath)!=null&&M.includes("posenet")?x=this.config.body.enabled?A2(i.tensor,c):[]:(P=this.config.body.modelPath)!=null&&P.includes("blazepose")?x=this.config.body.enabled?u5(i.tensor,c):[]:(g=this.config.body.modelPath)!=null&&g.includes("efficientpose")?x=this.config.body.enabled?R5(i.tensor,c):[]:(f=this.config.body.modelPath)!=null&&f.includes("movenet")&&(x=this.config.body.enabled?_5(i.tensor,c):[]),this.performance.body&&delete this.performance.body):(r=b(),(v=this.config.body.modelPath)!=null&&v.includes("posenet")?x=this.config.body.enabled?await A2(i.tensor,c):[]:(S=this.config.body.modelPath)!=null&&S.includes("blazepose")?x=this.config.body.enabled?await u5(i.tensor,c):[]:(k=this.config.body.modelPath)!=null&&k.includes("efficientpose")?x=this.config.body.enabled?await R5(i.tensor,c):[]:(W=this.config.body.modelPath)!=null&&W.includes("movenet")&&(x=this.config.body.enabled?await _5(i.tensor,c):[]),this.performance.body=this.env.perfadd?(this.performance.body||0)+Math.trunc(b()-r):Math.trunc(b()-r)),this.analyze("End Body:"),this.analyze("Start Hand:"),this.state="detect:hand";let m=this.config.hand.maxDetected===-1?K(this.config,{hand:{maxDetected:this.config.face.enabled?2*l.length:1}}):this.config;this.config.async?((L=(C=this.config.hand.detector)==null?void 0:C.modelPath)!=null&&L.includes("handdetect")?d=this.config.hand.enabled?G5(i.tensor,m):[]:(H=(D=this.config.hand.detector)==null?void 0:D.modelPath)!=null&&H.includes("handtrack")&&(d=this.config.hand.enabled?D5(i.tensor,m):[]),this.performance.hand&&delete this.performance.hand):(r=b(),(F=(Z=this.config.hand.detector)==null?void 0:Z.modelPath)!=null&&F.includes("handdetect")?d=this.config.hand.enabled?await G5(i.tensor,m):[]:(h0=(z=this.config.hand.detector)==null?void 0:z.modelPath)!=null&&h0.includes("handtrack")&&(d=this.config.hand.enabled?await D5(i.tensor,m):[]),this.performance.hand=this.env.perfadd?(this.performance.hand||0)+Math.trunc(b()-r):Math.trunc(b()-r)),this.analyze("End Hand:"),this.analyze("Start Object:"),this.state="detect:object",this.config.async?((b0=this.config.object.modelPath)!=null&&b0.includes("nanodet")?y=this.config.object.enabled?e2(i.tensor,this.config):[]:(R=this.config.object.modelPath)!=null&&R.includes("centernet")&&(y=this.config.object.enabled?g5(i.tensor,this.config):[]),this.performance.object&&delete this.performance.object):(r=b(),(t0=this.config.object.modelPath)!=null&&t0.includes("nanodet")?y=this.config.object.enabled?await e2(i.tensor,this.config):[]:(E=this.config.object.modelPath)!=null&&E.includes("centernet")&&(y=this.config.object.enabled?await g5(i.tensor,this.config):[]),this.performance.object=this.env.perfadd?(this.performance.object||0)+Math.trunc(b()-r):Math.trunc(b()-r)),this.analyze("End Object:"),this.state="detect:await",this.config.async&&([l,x,d,y]=await Promise.all([l,x,d,y])),this.state="detect:gesture";let h=[];this.config.gesture.enabled&&(r=b(),h=[...An(l),...rn(x),...an(d),...sn(l)],this.config.async?this.performance.gesture&&delete this.performance.gesture:this.performance.gesture=this.env.perfadd?(this.performance.gesture||0)+Math.trunc(b()-r):Math.trunc(b()-r)),this.performance.total=this.env.perfadd?(this.performance.total||0)+Math.trunc(b()-a):Math.trunc(b()-a);let p=((_=(X=this.process)==null?void 0:X.tensor)==null?void 0:_.shape)||[];this.result={face:l,body:x,hand:d,gesture:h,object:y,performance:this.performance,canvas:this.process.canvas,timestamp:Date.now(),error:null,get persons(){return cn(l,x,d,h,p)}},A.dispose(i.tensor),this.emit("detect"),this.state="idle",n(this.result)})}};Fe=new WeakMap,tt=new WeakMap,ot=new WeakMap,Dt=new WeakMap;export{fn as Human,fn as default,re as defaults,tn as draw,w as env,xn as match,y2 as models}; +2Q==`;async function wr(e){let t=(r,s="application/octet-stream")=>fetch(`data:${s};base64,${r}`).then(a=>a.blob()),o,n;switch(e.config.warmup){case"face":o=await t(X2);break;case"body":case"full":o=await t(q2);break;default:o=null}if(o){let r=await createImageBitmap(o);n=await e.detect(r,e.config),r.close()}return n}async function kr(e){return new Promise(t=>{let o;switch(e.config.warmup){case"face":o="data:image/jpeg;base64,"+X2;break;case"full":case"body":o="data:image/jpeg;base64,"+q2;break;default:o=null}let n;if(typeof Image!="undefined")n=new Image;else if(v.Image)n=new v.Image;else return;n.onload=async()=>{let r=l0(n.naturalWidth,n.naturalHeight);if(!r)u("Warmup: Canvas not found"),t(void 0);else{let s=r.getContext("2d");s&&s.drawImage(n,0,0);let a=await e.image(r),i=await e.detect(a.tensor,e.config);t(i)}},o?n.src=o:t(void 0)})}async function Er(e){let t=r=>Buffer.from(r,"base64"),o;e.config.warmup==="face"?o=t(X2):o=t(q2);let n;if("node"in A){let r=A.node.decodeJpeg(o),s=r.expandDims(0);e.tf.dispose(r),n=await e.detect(s,e.config),e.tf.dispose(s)}else e.config.debug&&u("Warmup tfjs-node not loaded");return n}async function zr(e){let t;return typeof createImageBitmap=="function"?t=await wr(e):typeof Image!="undefined"||v.Canvas!==void 0?t=await kr(e):t=await Er(e),t}async function Sr(e){let t=A.getBackend(),o=A.backend();if(t!=="webgl"&&t!=="humangl"||!o||!o.checkCompileCompletion)return;A.env().set("ENGINE_COMPILE_ONLY",!0);let n=A.engine().state.numTensors,r=[];for(let[i,l]of Object.entries(e).filter(([x,d])=>x!==null&&d!==null)){let x=l.inputs&&l.inputs[0]&&l.inputs[0].shape?[...l.inputs[0].shape]:[1,64,64,3],d=l.inputs&&l.inputs[0]&&l.inputs[0].dtype?l.inputs[0].dtype:"float32";for(let c=0;cA.dispose(m)):A.dispose(c)}catch(c){u("compile fail model:",i)}A.dispose(y)}let s=await o.checkCompileCompletionAsync();o.getUniformLocations(),u("compile pass models:",r),u("compile pass kernels:",s.length),A.env().set("ENGINE_COMPILE_ONLY",!1);let a=A.engine().state.numTensors;a-n>0&&u("tensor leak:",a-n)}async function po(e,t){let o=b();return e.state="warmup",t&&(e.config=J(e.config,t)),!e.config.warmup||e.config.warmup.length===0||e.config.warmup==="none"?{face:[],body:[],hand:[],gesture:[],object:[],performance:e.performance,timestamp:b(),persons:[],error:null}:new Promise(async n=>{await Sr(e.models);let r=await zr(e),s=b();e.config.debug&&u("warmup",e.config.warmup,Math.round(s-o),"ms"),e.emit("warmup"),n(r)})}var Be,r2,A2,U2,uo=class{constructor(t){w(this,"version");w(this,"config");w(this,"result");w(this,"state");w(this,"process");w(this,"tf");w(this,"env");w(this,"draw");w(this,"models");w(this,"events");w(this,"faceTriangulation");w(this,"faceUVMap");w(this,"performance");De(this,Be,void 0);De(this,r2,void 0);De(this,A2,void 0);w(this,"gl");w(this,"analyze",(...t)=>{if(!Ze(this,r2))return;let o=this.tf.engine().state.numTensors,n=Ze(this,Be);Xe(this,Be,o);let r=o-n;r!==0&&u(...t,r)});De(this,U2,t=>{if(!Ze(this,A2))return null;if(!t)return"input is not defined";if(this.env.node&&!(t instanceof he))return"input must be a tensor";try{this.tf.getBackend()}catch(o){return"backend not loaded"}return null});w(this,"similarity",R1);w(this,"distance",n2);w(this,"match",T1);w(this,"emit",t=>{var o;this.events&&this.events.dispatchEvent&&((o=this.events)==null||o.dispatchEvent(new Event(t)))});this.env=v,re.wasmPath=qe["tfjs-core"].includes("-")?"https://vladmandic.github.io/tfjs/dist/":`https://cdn.jsdelivr.net/npm/@tensorflow/tfjs-backend-wasm@${A.version_core}/dist/`,re.modelBasePath=v.browser?"../models/":"file://models/",re.backend=v.browser?"humangl":"tensorflow",this.version=e5,Object.defineProperty(this,"version",{value:e5}),this.config=JSON.parse(JSON.stringify(re)),Object.seal(this.config),this.config.cacheModels=typeof indexedDB!="undefined",t&&(this.config=J(this.config,t)),H1(this.config),this.tf=A,this.state="idle",Xe(this,Be,0),Xe(this,r2,!1),Xe(this,A2,!1),this.performance={},this.events=typeof EventTarget!="undefined"?new EventTarget:void 0,this.models=new o2,this.draw={options:i0,canvas:(o,n)=>h1(o,n),face:(o,n,r)=>Ne(o,n,r),body:(o,n,r)=>Oe(o,n,r),hand:(o,n,r)=>We(o,n,r),gesture:(o,n,r)=>Fe(o,n,r),object:(o,n,r)=>Le(o,n,r),person:(o,n,r)=>u1(o,n,r),all:(o,n,r)=>b1(o,n,r)},this.result={face:[],body:[],hand:[],gesture:[],object:[],performance:{},timestamp:0,persons:[],error:null},this.process={tensor:null,canvas:null},this.faceTriangulation=$t,this.faceUVMap=e3,this.gl=Y,this.emit("create")}reset(){let t=this.config.backend;this.config=JSON.parse(JSON.stringify(re)),this.config.backend=t}validate(t){return K2(re,t||this.config)}now(){return b()}image(t,o=!0){return ge(t,this.config,o)}async segmentation(t,o){return $3(t,o,this.config)}enhance(t){return W5(t)}compare(t,o){return B1(this.config,t,o)}async init(){await D2(this,!0),await this.tf.ready()}async load(t){this.state="load";let o=b(),n=Object.values(this.models).filter(a=>a).length;t&&(this.config=J(this.config,t)),this.env.initial&&(this.config.debug&&u(`version: ${this.version}`),this.config.debug&&u(`tfjs version: ${this.tf.version["tfjs-core"]}`),await D2(this)||u("error: backend check failed"),await A.ready(),this.env.browser&&(this.config.debug&&u("configuration:",this.config),this.config.debug&&u("environment:",this.env),this.config.debug&&u("tf flags:",this.tf.ENV.flags))),await x1(this),this.env.initial&&this.config.debug&&u("tf engine state:",this.tf.engine().state.numBytes,"bytes",this.tf.engine().state.numTensors,"tensors"),this.env.initial=!1,Object.values(this.models).filter(a=>a).length!==n&&(await c1(this),this.emit("load"));let s=Math.trunc(b()-o);s>(this.performance.loadModels||0)&&(this.performance.loadModels=this.env.perfadd?(this.performance.loadModels||0)+s:s)}next(t=this.result){return xo(t,this.config)}async warmup(t){let o=b(),n=await po(this,t),r=b();return this.performance.warmup=Math.trunc(r-o),n}async profile(t,o){let n=await this.tf.profile(()=>this.detect(t,o)),r={};for(let i of n.kernels)r[i.name]?r[i.name]+=i.kernelTimeMs:r[i.name]=i.kernelTimeMs;let s=[];Object.entries(r).forEach(i=>s.push({name:i[0],ms:i[1]})),s.sort((i,l)=>l.ms-i.ms),s.length=20;let a={};for(let i of s)a[i.name]=i.ms;return a}async detect(t,o){return this.state="detect",new Promise(async n=>{var R,P,g,f,M,j,k,I,C,O,D,H,Z,F,z,h0,b0,T,t0,E,X,_;this.state="config";let r;this.config=J(this.config,o),this.state="check";let s=Ze(this,U2).call(this,t);s&&(u(s,t),this.emit("error"),n({face:[],body:[],hand:[],gesture:[],object:[],performance:this.performance,timestamp:b(),persons:[],error:s}));let a=b();await D2(this),await this.load(),r=b(),this.state="image";let i=await ge(t,this.config);if(this.process=i,this.performance.inputProcess=this.env.perfadd?(this.performance.inputProcess||0)+Math.trunc(b()-r):Math.trunc(b()-r),this.analyze("Get Image:"),!i.tensor){this.config.debug&&u("could not convert input to tensor"),this.emit("error"),n({face:[],body:[],hand:[],gesture:[],object:[],performance:this.performance,timestamp:b(),persons:[],error:"could not convert input to tensor"});return}this.emit("image"),r=b(),this.config.skipAllowed=await G1(this.config,i.tensor),this.performance.totalFrames||(this.performance.totalFrames=0),this.performance.cachedFrames||(this.performance.cachedFrames=0),this.performance.totalFrames++,this.config.skipAllowed&&this.performance.cachedFrames++,this.performance.cacheCheck=this.env.perfadd?(this.performance.cacheCheck||0)+Math.trunc(b()-r):Math.trunc(b()-r),this.analyze("Check Changed:");let l=[],x=[],d=[],y=[];this.state="detect:face",this.config.async?(l=this.config.face.enabled?P1(this,i.tensor):[],this.performance.face&&delete this.performance.face):(r=b(),l=this.config.face.enabled?await P1(this,i.tensor):[],this.performance.face=this.env.perfadd?(this.performance.face||0)+Math.trunc(b()-r):Math.trunc(b()-r)),this.config.async&&(this.config.body.maxDetected===-1||this.config.hand.maxDetected===-1)&&(l=await l),this.analyze("Start Body:"),this.state="detect:body";let c=this.config.body.maxDetected===-1?J(this.config,{body:{maxDetected:this.config.face.enabled?1*l.length:1}}):this.config;this.config.async?((R=this.config.body.modelPath)!=null&&R.includes("posenet")?x=this.config.body.enabled?i1(i.tensor,c):[]:(P=this.config.body.modelPath)!=null&&P.includes("blazepose")?x=this.config.body.enabled?g5(i.tensor,c):[]:(g=this.config.body.modelPath)!=null&&g.includes("efficientpose")?x=this.config.body.enabled?k5(i.tensor,c):[]:(f=this.config.body.modelPath)!=null&&f.includes("movenet")&&(x=this.config.body.enabled?t1(i.tensor,c):[]),this.performance.body&&delete this.performance.body):(r=b(),(M=this.config.body.modelPath)!=null&&M.includes("posenet")?x=this.config.body.enabled?await i1(i.tensor,c):[]:(j=this.config.body.modelPath)!=null&&j.includes("blazepose")?x=this.config.body.enabled?await g5(i.tensor,c):[]:(k=this.config.body.modelPath)!=null&&k.includes("efficientpose")?x=this.config.body.enabled?await k5(i.tensor,c):[]:(I=this.config.body.modelPath)!=null&&I.includes("movenet")&&(x=this.config.body.enabled?await t1(i.tensor,c):[]),this.performance.body=this.env.perfadd?(this.performance.body||0)+Math.trunc(b()-r):Math.trunc(b()-r)),this.analyze("End Body:"),this.analyze("Start Hand:"),this.state="detect:hand";let m=this.config.hand.maxDetected===-1?J(this.config,{hand:{maxDetected:this.config.face.enabled?2*l.length:1}}):this.config;this.config.async?((O=(C=this.config.hand.detector)==null?void 0:C.modelPath)!=null&&O.includes("handdetect")?d=this.config.hand.enabled?Z5(i.tensor,m):[]:(H=(D=this.config.hand.detector)==null?void 0:D.modelPath)!=null&&H.includes("handtrack")&&(d=this.config.hand.enabled?U5(i.tensor,m):[]),this.performance.hand&&delete this.performance.hand):(r=b(),(F=(Z=this.config.hand.detector)==null?void 0:Z.modelPath)!=null&&F.includes("handdetect")?d=this.config.hand.enabled?await Z5(i.tensor,m):[]:(h0=(z=this.config.hand.detector)==null?void 0:z.modelPath)!=null&&h0.includes("handtrack")&&(d=this.config.hand.enabled?await U5(i.tensor,m):[]),this.performance.hand=this.env.perfadd?(this.performance.hand||0)+Math.trunc(b()-r):Math.trunc(b()-r)),this.analyze("End Hand:"),this.analyze("Start Object:"),this.state="detect:object",this.config.async?((b0=this.config.object.modelPath)!=null&&b0.includes("nanodet")?y=this.config.object.enabled?n1(i.tensor,this.config):[]:(T=this.config.object.modelPath)!=null&&T.includes("centernet")&&(y=this.config.object.enabled?R5(i.tensor,this.config):[]),this.performance.object&&delete this.performance.object):(r=b(),(t0=this.config.object.modelPath)!=null&&t0.includes("nanodet")?y=this.config.object.enabled?await n1(i.tensor,this.config):[]:(E=this.config.object.modelPath)!=null&&E.includes("centernet")&&(y=this.config.object.enabled?await R5(i.tensor,this.config):[]),this.performance.object=this.env.perfadd?(this.performance.object||0)+Math.trunc(b()-r):Math.trunc(b()-r)),this.analyze("End Object:"),this.state="detect:await",this.config.async&&([l,x,d,y]=await Promise.all([l,x,d,y])),this.state="detect:gesture";let h=[];this.config.gesture.enabled&&(r=b(),h=[...io(l),...ao(x),...yo(d),...lo(l)],this.config.async?this.performance.gesture&&delete this.performance.gesture:this.performance.gesture=this.env.perfadd?(this.performance.gesture||0)+Math.trunc(b()-r):Math.trunc(b()-r)),this.performance.total=this.env.perfadd?(this.performance.total||0)+Math.trunc(b()-a):Math.trunc(b()-a);let p=((_=(X=this.process)==null?void 0:X.tensor)==null?void 0:_.shape)||[];this.result={face:l,body:x,hand:d,gesture:h,object:y,performance:this.performance,canvas:this.process.canvas,timestamp:Date.now(),error:null,get persons(){return mo(l,x,d,h,p)}},A.dispose(i.tensor),this.emit("detect"),this.state="idle",n(this.result)})}};Be=new WeakMap,r2=new WeakMap,A2=new WeakMap,U2=new WeakMap;export{uo as Human,uo as default,re as defaults,ro as draw,v as env,fo as match,d1 as models}; /** * Human main module * @default Human Library diff --git a/dist/human.esm-nobundle.js.map b/dist/human.esm-nobundle.js.map index 5fa062bd..ec4b6ed8 100644 --- a/dist/human.esm-nobundle.js.map +++ b/dist/human.esm-nobundle.js.map @@ -1,7 +1,7 @@ { "version": 3, - "sources": ["../src/util/util.ts", "../src/config.ts", "tfjs.esm.js", "../src/image/imagefxshaders.ts", "../src/image/imagefx.ts", "../src/image/enhance.ts", "../src/image/image.ts", "../src/util/env.ts", "../src/tfjs/load.ts", "../src/models.ts", "../src/gear/gear.ts", "../src/tfjs/constants.ts", "../src/gear/ssrnet-age.ts", "../src/gear/ssrnet-gender.ts", "../src/face/antispoof.ts", "../src/face/facemeshcoords.ts", "../src/face/facemeshutil.ts", "../src/face/blazeface.ts", "../src/body/blazeposecoords.ts", "../src/body/blazeposedetector.ts", "../src/util/box.ts", "../src/body/blazepose.ts", "../src/object/labels.ts", "../src/object/centernet.ts", "../src/body/efficientposecoords.ts", "../src/body/efficientpose.ts", "../src/gear/emotion.ts", "../src/face/mobilefacenet.ts", "../src/face/iris.ts", "../src/face/attention.ts", "../src/face/facemesh.ts", "../src/face/faceres.ts", "../src/hand/handposeutil.ts", "../src/hand/handposeanchors.ts", "../src/hand/handposedetector.ts", "../src/hand/handposepipeline.ts", "../src/hand/fingerdef.ts", "../src/hand/fingergesture.ts", "../src/hand/fingerpose.ts", "../src/hand/handpose.ts", "../src/hand/handtrack.ts", "../src/face/liveness.ts", "../src/body/movenetcoords.ts", "../src/body/movenetfix.ts", "../src/body/movenet.ts", "../src/object/nanodet.ts", "../src/body/posenetutils.ts", "../src/body/posenet.ts", "../src/segmentation/segmentation.ts", "../src/tfjs/humangl.ts", "../src/tfjs/backend.ts", "../src/draw/draw.ts", "../src/draw/primitives.ts", "../src/draw/options.ts", "../src/draw/face.ts", "../src/draw/body.ts", "../src/draw/hand.ts", "../src/draw/object.ts", "../src/draw/gesture.ts", "../src/face/mask.ts", "../src/face/angles.ts", "../src/face/face.ts", "../src/gesture/gesture.ts", "../src/util/interpolate.ts", "../src/face/match.ts", "../src/util/persons.ts", "../src/sample.ts", "../src/warmup.ts", "../src/human.ts"], - "sourcesContent": ["import type { Config } from '../exports';\n\n/**\n * Simple helper functions used accross codebase\n */\n\n// helper function: wrapper around console output\nexport function log(...msg): void {\n const dt = new Date();\n const ts = `${dt.getHours().toString().padStart(2, '0')}:${dt.getMinutes().toString().padStart(2, '0')}:${dt.getSeconds().toString().padStart(2, '0')}.${dt.getMilliseconds().toString().padStart(3, '0')}`;\n // eslint-disable-next-line no-console\n if (msg) console.log(ts, 'Human:', ...msg);\n}\n\n// helper function: join two paths\nexport function join(folder: string, file: string): string {\n const separator = folder.endsWith('/') ? '' : '/';\n const skipJoin = file.startsWith('.') || file.startsWith('/') || file.startsWith('http:') || file.startsWith('https:') || file.startsWith('file:');\n const path = skipJoin ? `${file}` : `${folder}${separator}${file}`;\n if (!path.toLocaleLowerCase().includes('.json')) throw new Error(`modelpath error: expecting json file: ${path}`);\n return path;\n}\n\n// helper function: gets elapsed time on both browser and nodejs\nexport const now = () => {\n if (typeof performance !== 'undefined') return performance.now();\n return parseInt((Number(process.hrtime.bigint()) / 1000 / 1000).toString());\n};\n\n// helper function: checks current config validity\nexport function validate(defaults: Partial, config: Partial, parent = 'config', msgs: Array<{ reason: string, where: string, expected?: string }> = []) {\n for (const key of Object.keys(config)) {\n if (typeof config[key] === 'object') {\n validate(defaults[key], config[key], key, msgs);\n } else {\n const defined = defaults && (typeof defaults[key] !== 'undefined');\n if (!defined) msgs.push({ reason: 'unknown property', where: `${parent}.${key} = ${config[key]}` });\n const same = defaults && typeof defaults[key] === typeof config[key];\n if (defined && !same) msgs.push({ reason: 'property type mismatch', where: `${parent}.${key} = ${config[key]}`, expected: typeof defaults[key] });\n }\n // ok = ok && defined && same;\n }\n if (config.debug && parent === 'config' && msgs.length > 0) log('invalid configuration', msgs);\n return msgs;\n}\n\n// helper function: perform deep merge of multiple objects so it allows full inheritance with overrides\nexport function mergeDeep(...objects) {\n const isObject = (obj) => obj && typeof obj === 'object';\n return objects.reduce((prev, obj) => {\n Object.keys(obj || {}).forEach((key) => {\n const pVal = prev[key];\n const oVal = obj[key];\n if (Array.isArray(pVal) && Array.isArray(oVal)) prev[key] = pVal.concat(...oVal);\n else if (isObject(pVal) && isObject(oVal)) prev[key] = mergeDeep(pVal, oVal);\n else prev[key] = oVal;\n });\n return prev;\n }, {});\n}\n\n// helper function: return min and max from input array\nexport const minmax = (data: Array) => data.reduce((acc: Array, val) => {\n acc[0] = (acc[0] === undefined || val < acc[0]) ? val : acc[0];\n acc[1] = (acc[1] === undefined || val > acc[1]) ? val : acc[1];\n return acc;\n}, []);\n\n// helper function: async wait\nexport async function wait(time: number) {\n const waiting = new Promise((resolve) => { setTimeout(() => resolve(true), time); });\n await waiting;\n}\n", "/* eslint-disable indent */\n/* eslint-disable no-multi-spaces */\n\n/** Generic config type inherited by all module types */\nexport interface GenericConfig {\n /** is module enabled? */\n enabled: boolean,\n /** path to model json file (relative to `modelBasePath` */\n modelPath: string,\n /** how many max frames to go without re-running model if cached results are acceptable\n * for two-phase models such as face and hand caching applies to bounding boxes detection only */\n skipFrames: number,\n /** how many max milliseconds to go without re-running model if cached results are acceptable\n * for two-phase models such as face and hand caching applies to bounding boxes detection only */\n skipTime: number,\n}\n\n/** Detector part of face configuration */\nexport interface FaceDetectorConfig extends GenericConfig {\n /** is face rotation correction performed after detecting face?\n * used to correctly analyze faces under high angles\n */\n rotation: boolean,\n /** maximum number of detected faces */\n maxDetected: number,\n /** minimum confidence for a detected face before results are discarded */\n minConfidence: number,\n /** minimum overlap between two detected faces before one is discarded */\n iouThreshold: number,\n /** should child models perform on masked image of a face */\n mask: boolean,\n /** should face detection return processed and cropped face tensor that can with an external model for addtional processing?\n * if enabled it must be manually deallocated to avoid memory leak */\n return: boolean,\n}\n\n/** Mesh part of face configuration */\nexport interface FaceMeshConfig extends GenericConfig {\n /** Keep detected faces that cannot be verified using facemesh */\n keepInvalid: boolean\n}\n\n/** Iris part of face configuration */\nexport interface FaceIrisConfig extends GenericConfig {}\n\n/** Attention part of face configuration */\nexport interface FaceAttentionConfig extends GenericConfig {}\n\n/** Description or face embedding part of face configuration\n * - also used by age and gender detection\n */\nexport interface FaceDescriptionConfig extends GenericConfig {\n /** minimum confidence for a detected face before results are discarded */\n minConfidence: number,\n}\n\n/** Emotion part of face configuration */\nexport interface FaceEmotionConfig extends GenericConfig {\n /** minimum confidence for a detected face before results are discarded */\n minConfidence: number,\n}\n\n/** Anti-spoofing part of face configuration */\nexport interface FaceAntiSpoofConfig extends GenericConfig {}\n\n/** Liveness part of face configuration */\nexport interface FaceLivenessConfig extends GenericConfig {}\n\n/** Configures all face-specific options: face detection, mesh analysis, age, gender, emotion detection and face description */\nexport interface FaceConfig extends GenericConfig {\n detector: Partial,\n mesh: Partial,\n attention: Partial,\n iris: Partial,\n description: Partial,\n emotion: Partial,\n antispoof: Partial,\n liveness: Partial,\n}\n\n/** Configures all body detection specific options */\nexport interface BodyConfig extends GenericConfig {\n /** maximum number of detected bodies */\n maxDetected: number,\n /** minimum confidence for a detected body before results are discarded */\n minConfidence: number,\n /* experimental\n /** experimental: detector used for body model before actual analysis\n detector?: {\n /** experimental: enable body detector before body landmarks\n enabled: boolean,\n /** experimental: path to optional body detector model json file\n modelPath: string,\n /** experimental: minimum confidence for a detected body before results are discarded\n minConfidence: number,\n /** experimental: minimum overlap between two detected bodies before one is discarded\n iouThreshold: number\n },\n */\n}\n\n/** Configures all hand detection specific options */\nexport interface HandConfig extends GenericConfig {\n /** should hand rotation correction be performed after hand detection? */\n rotation: boolean,\n /** minimum confidence for a detected hand before results are discarded */\n minConfidence: number,\n /** minimum overlap between two detected hands before one is discarded */\n iouThreshold: number,\n /** maximum number of detected hands */\n maxDetected: number,\n /** should hand landmarks be detected or just return detected hand box */\n landmarks: boolean,\n detector: {\n /** path to hand detector model json */\n modelPath?: string,\n },\n skeleton: {\n /** path to hand skeleton model json */\n modelPath?: string,\n },\n}\n\n/** Configures all object detection specific options */\nexport interface ObjectConfig extends GenericConfig {\n /** minimum confidence for a detected objects before results are discarded */\n minConfidence: number,\n /** minimum overlap between two detected objects before one is discarded */\n iouThreshold: number,\n /** maximum number of detected objects */\n maxDetected: number,\n}\n\n/** Configures all body segmentation module\n * removes background from input containing person\n * if segmentation is enabled it will run as preprocessing task before any other model\n * alternatively leave it disabled and use it on-demand using human.segmentation method which can\n * remove background or replace it with user-provided background\n*/\nexport interface SegmentationConfig extends GenericConfig {\n /** blur segmentation output by pixels for more realistic image */\n blur: number,\n}\n\n/** Run input through image filters before inference\n * - available only in Browser environments\n * - image filters run with near-zero latency as they are executed on the GPU using WebGL\n*/\nexport interface FilterConfig {\n /** are image filters enabled? */\n enabled: boolean,\n /** perform image histogram equalization\n * - equalization is performed on input as a whole and detected face before its passed for further analysis\n */\n equalization: boolean,\n /** resize input width\n * - if both width and height are set to 0, there is no resizing\n * - if just one is set, second one is scaled automatically\n * - if both are set, values are used as-is\n */\n width: number,\n /** resize input height\n * - if both width and height are set to 0, there is no resizing\n * - if just one is set, second one is scaled automatically\n * - if both are set, values are used as-is\n */\n height: number,\n /** return processed canvas imagedata in result */\n return: boolean,\n /** flip input as mirror image */\n flip: boolean,\n /** range: -1 (darken) to 1 (lighten) */\n brightness: number,\n /** range: -1 (reduce contrast) to 1 (increase contrast) */\n contrast: number,\n /** range: 0 (no sharpening) to 1 (maximum sharpening) */\n sharpness: number,\n /** range: 0 (no blur) to N (blur radius in pixels) */\n blur: number\n /** range: -1 (reduce saturation) to 1 (increase saturation) */\n saturation: number,\n /** range: 0 (no change) to 360 (hue rotation in degrees) */\n hue: number,\n /** image negative */\n negative: boolean,\n /** image sepia colors */\n sepia: boolean,\n /** image vintage colors */\n vintage: boolean,\n /** image kodachrome colors */\n kodachrome: boolean,\n /** image technicolor colors */\n technicolor: boolean,\n /** image polaroid camera effect */\n polaroid: boolean,\n /** range: 0 (no pixelate) to N (number of pixels to pixelate) */\n pixelate: number,\n}\n\n/** Controlls gesture detection */\nexport interface GestureConfig {\n /** is gesture detection enabled? */\n enabled: boolean,\n}\n/** Possible TensorFlow backends */\nexport type BackendType = ['cpu', 'wasm', 'webgl', 'humangl', 'tensorflow', 'webgpu'];\n\n/** Possible values for `human.warmup` */\nexport type WarmupType = ['' | 'none' | 'face' | 'full' | 'body'];\n\n/**\n * Configuration interface definition for **Human** library\n * Contains all configurable parameters\n * Defaults: [config](https://github.com/vladmandic/human/blob/main/src/config.ts#L262)\n */\nexport interface Config {\n /** Backend used for TFJS operations\n * valid build-in backends are:\n * - Browser: `cpu`, `wasm`, `webgl`, `humangl`, `webgpu`\n * - NodeJS: `cpu`, `wasm`, `tensorflow`\n * default: `humangl` for browser and `tensorflow` for nodejs\n */\n backend: '' | 'cpu' | 'wasm' | 'webgl' | 'humangl' | 'tensorflow' | 'webgpu',\n\n /** Path to *.wasm files if backend is set to `wasm`\n *\n * default: auto-detects to link to CDN `jsdelivr` when running in browser\n */\n wasmPath: string,\n\n /** Force WASM loader to use platform fetch\n *\n * default: auto-detects to link to CDN `jsdelivr` when running in browser\n */\n wasmPlatformFetch: boolean,\n\n /** Print debug statements to console\n *\n * default: `true`\n */\n debug: boolean,\n\n /** Perform model loading and inference concurrently or sequentially\n *\n * default: `true`\n */\n async: boolean,\n\n /** What to use for `human.warmup()`\n * - warmup pre-initializes all models for faster inference but can take significant time on startup\n * - used by `webgl`, `humangl` and `webgpu` backends\n *\n * default: `full`\n */\n warmup: '' | 'none' | 'face' | 'full' | 'body',\n\n /** Base model path (typically starting with file://, http:// or https://) for all models\n * - individual modelPath values are relative to this path\n *\n * default: `../models/` for browsers and `file://models/` for nodejs\n */\n modelBasePath: string,\n\n /** Cache models in IndexDB on first sucessfull load\n * default: true if indexdb is available (browsers), false if its not (nodejs)\n */\n cacheModels: boolean,\n\n /** Cache sensitivity\n * - values 0..1 where 0.01 means reset cache if input changed more than 1%\n * - set to 0 to disable caching\n *\n * default: 0.7\n */\n cacheSensitivity: number;\n\n /** Perform immediate garbage collection on deallocated tensors instead of caching them */\n deallocate: boolean;\n\n /** Internal Variable */\n skipAllowed: boolean;\n\n /** Filter config {@link FilterConfig} */\n filter: Partial,\n\n /** Gesture config {@link GestureConfig} */\n gesture: Partial;\n\n /** Face config {@link FaceConfig} */\n face: Partial,\n\n /** Body config {@link BodyConfig} */\n body: Partial,\n\n /** Hand config {@link HandConfig} */\n hand: Partial,\n\n /** Object config {@link ObjectConfig} */\n object: Partial,\n\n /** Segmentation config {@link SegmentationConfig} */\n segmentation: Partial,\n}\n\n/** - [See all default Config values...](https://github.com/vladmandic/human/blob/main/src/config.ts#L262) */\nconst config: Config = {\n backend: '',\n modelBasePath: '',\n cacheModels: true,\n wasmPath: '',\n wasmPlatformFetch: false,\n debug: true,\n async: true,\n warmup: 'full',\n cacheSensitivity: 0.70,\n skipAllowed: false,\n deallocate: false,\n filter: {\n enabled: true,\n equalization: false,\n width: 0,\n height: 0,\n flip: false,\n return: true,\n brightness: 0,\n contrast: 0,\n sharpness: 0,\n blur: 0,\n saturation: 0,\n hue: 0,\n negative: false,\n sepia: false,\n vintage: false,\n kodachrome: false,\n technicolor: false,\n polaroid: false,\n pixelate: 0,\n },\n gesture: {\n enabled: true,\n },\n face: {\n enabled: true,\n detector: {\n modelPath: 'blazeface.json',\n rotation: true,\n maxDetected: 1,\n skipFrames: 99,\n skipTime: 2500,\n minConfidence: 0.2,\n iouThreshold: 0.1,\n mask: false,\n return: false,\n },\n mesh: {\n enabled: true,\n modelPath: 'facemesh.json',\n keepInvalid: false,\n },\n attention: {\n enabled: false,\n modelPath: 'facemesh-attention.json',\n },\n iris: {\n enabled: true,\n modelPath: 'iris.json',\n },\n emotion: {\n enabled: true,\n minConfidence: 0.1,\n skipFrames: 99,\n skipTime: 1500,\n modelPath: 'emotion.json',\n },\n description: {\n enabled: true,\n modelPath: 'faceres.json',\n skipFrames: 99,\n skipTime: 3000,\n minConfidence: 0.1,\n },\n antispoof: {\n enabled: false,\n skipFrames: 99,\n skipTime: 4000,\n modelPath: 'antispoof.json',\n },\n liveness: {\n enabled: false,\n skipFrames: 99,\n skipTime: 4000,\n modelPath: 'liveness.json',\n },\n },\n body: {\n enabled: true,\n modelPath: 'movenet-lightning.json',\n maxDetected: -1,\n minConfidence: 0.3,\n skipFrames: 1,\n skipTime: 200,\n },\n hand: {\n enabled: true,\n rotation: true,\n skipFrames: 99,\n skipTime: 1000,\n minConfidence: 0.50,\n iouThreshold: 0.2,\n maxDetected: -1,\n landmarks: true,\n detector: {\n modelPath: 'handtrack.json',\n },\n skeleton: {\n modelPath: 'handlandmark-full.json',\n },\n },\n object: {\n enabled: false,\n modelPath: 'mb3-centernet.json',\n minConfidence: 0.2,\n iouThreshold: 0.4,\n maxDetected: 10,\n skipFrames: 99,\n skipTime: 2000,\n },\n segmentation: {\n enabled: false,\n modelPath: 'selfie.json',\n blur: 8,\n },\n};\n\nexport { config as defaults };\n", "/*\n Human\n homepage: \n author: '\n*/\n\nexport*from\"@tensorflow/tfjs/dist/index.js\";export*from\"@tensorflow/tfjs-backend-webgl/dist/index.js\";var r=\"3.18.0\",e=\"3.18.0\",a=\"3.18.0\",o=\"3.18.0\",t=\"3.18.0\",s=\"3.18.0\",f=\"3.18.0\",v={tfjs:r,\"tfjs-core\":e,\"tfjs-data\":a,\"tfjs-layers\":o,\"tfjs-converter\":t,\"tfjs-backend-webgl\":s,\"tfjs-backend-wasm\":f};import{Tensor as d}from\"@tensorflow/tfjs/dist/index.js\";import{GraphModel as b}from\"@tensorflow/tfjs-converter/dist/index\";export{b as GraphModel,d as Tensor,v as version};\n", "export const vertexIdentity = `\n precision highp float;\n attribute vec2 pos;\n attribute vec2 uv;\n varying vec2 vUv;\n uniform float flipY;\n void main(void) {\n vUv = uv;\n gl_Position = vec4(pos.x, pos.y*flipY, 0.0, 1.);\n }\n`;\n\nexport const fragmentIdentity = `\n precision highp float;\n varying vec2 vUv;\n uniform sampler2D texture;\n void main(void) {\n gl_FragColor = texture2D(texture, vUv);\n }\n`;\n\nexport const colorMatrixWithAlpha = `\n precision highp float;\n varying vec2 vUv;\n uniform sampler2D texture;\n uniform float m[20];\n void main(void) {\n vec4 c = texture2D(texture, vUv);\n gl_FragColor.r = m[0] * c.r + m[1] * c.g + m[2] * c.b + m[3] * c.a + m[4];\n gl_FragColor.g = m[5] * c.r + m[6] * c.g + m[7] * c.b + m[8] * c.a + m[9];\n gl_FragColor.b = m[10] * c.r + m[11] * c.g + m[12] * c.b + m[13] * c.a + m[14];\n gl_FragColor.a = m[15] * c.r + m[16] * c.g + m[17] * c.b + m[18] * c.a + m[19];\n }\n`;\n\nexport const colorMatrixWithoutAlpha = `\n precision highp float;\n varying vec2 vUv;\n uniform sampler2D texture;\n uniform float m[20];\n void main(void) {\n vec4 c = texture2D(texture, vUv);\n gl_FragColor.r = m[0] * c.r + m[1] * c.g + m[2] * c.b + m[4];\n gl_FragColor.g = m[5] * c.r + m[6] * c.g + m[7] * c.b + m[9];\n gl_FragColor.b = m[10] * c.r + m[11] * c.g + m[12] * c.b + m[14];\n gl_FragColor.a = c.a;\n }\n`;\n\nexport const pixelate = `\n precision highp float;\n varying vec2 vUv;\n uniform vec2 size;\n uniform sampler2D texture;\n vec2 pixelate(vec2 coord, vec2 size) {\n return floor( coord / size ) * size;\n }\n void main(void) {\n gl_FragColor = vec4(0.0);\n vec2 coord = pixelate(vUv, size);\n gl_FragColor += texture2D(texture, coord);\n }\n`;\n\nexport const blur = `\n precision highp float;\n varying vec2 vUv;\n uniform sampler2D texture;\n uniform vec2 px;\n void main(void) {\n gl_FragColor = vec4(0.0);\n gl_FragColor += texture2D(texture, vUv + vec2(-7.0*px.x, -7.0*px.y))*0.0044299121055113265;\n gl_FragColor += texture2D(texture, vUv + vec2(-6.0*px.x, -6.0*px.y))*0.00895781211794;\n gl_FragColor += texture2D(texture, vUv + vec2(-5.0*px.x, -5.0*px.y))*0.0215963866053;\n gl_FragColor += texture2D(texture, vUv + vec2(-4.0*px.x, -4.0*px.y))*0.0443683338718;\n gl_FragColor += texture2D(texture, vUv + vec2(-3.0*px.x, -3.0*px.y))*0.0776744219933;\n gl_FragColor += texture2D(texture, vUv + vec2(-2.0*px.x, -2.0*px.y))*0.115876621105;\n gl_FragColor += texture2D(texture, vUv + vec2(-1.0*px.x, -1.0*px.y))*0.147308056121;\n gl_FragColor += texture2D(texture, vUv )*0.159576912161;\n gl_FragColor += texture2D(texture, vUv + vec2( 1.0*px.x, 1.0*px.y))*0.147308056121;\n gl_FragColor += texture2D(texture, vUv + vec2( 2.0*px.x, 2.0*px.y))*0.115876621105;\n gl_FragColor += texture2D(texture, vUv + vec2( 3.0*px.x, 3.0*px.y))*0.0776744219933;\n gl_FragColor += texture2D(texture, vUv + vec2( 4.0*px.x, 4.0*px.y))*0.0443683338718;\n gl_FragColor += texture2D(texture, vUv + vec2( 5.0*px.x, 5.0*px.y))*0.0215963866053;\n gl_FragColor += texture2D(texture, vUv + vec2( 6.0*px.x, 6.0*px.y))*0.00895781211794;\n gl_FragColor += texture2D(texture, vUv + vec2( 7.0*px.x, 7.0*px.y))*0.0044299121055113265;\n }\n`;\n\nexport const convolution = `\n precision highp float;\n varying vec2 vUv;\n uniform sampler2D texture;\n uniform vec2 px;\n uniform float m[9];\n void main(void) {\n vec4 c11 = texture2D(texture, vUv - px); // top left\n vec4 c12 = texture2D(texture, vec2(vUv.x, vUv.y - px.y)); // top center\n vec4 c13 = texture2D(texture, vec2(vUv.x + px.x, vUv.y - px.y)); // top right\n vec4 c21 = texture2D(texture, vec2(vUv.x - px.x, vUv.y) ); // mid left\n vec4 c22 = texture2D(texture, vUv); // mid center\n vec4 c23 = texture2D(texture, vec2(vUv.x + px.x, vUv.y) ); // mid right\n vec4 c31 = texture2D(texture, vec2(vUv.x - px.x, vUv.y + px.y) ); // bottom left\n vec4 c32 = texture2D(texture, vec2(vUv.x, vUv.y + px.y) ); // bottom center\n vec4 c33 = texture2D(texture, vUv + px ); // bottom right\n gl_FragColor = \n c11 * m[0] + c12 * m[1] + c22 * m[2] +\n c21 * m[3] + c22 * m[4] + c23 * m[5] +\n c31 * m[6] + c32 * m[7] + c33 * m[8];\n gl_FragColor.a = c22.a;\n }\n`;\n", "/**\n * Image Filters in WebGL algoritm implementation\n * Based on: [WebGLImageFilter](https://github.com/phoboslab/WebGLImageFilter)\n */\n\nimport * as shaders from './imagefxshaders';\nimport { canvas } from './image';\nimport { log } from '../util/util';\n\nconst collect = (source, prefix, collection) => {\n const r = new RegExp('\\\\b' + prefix + ' \\\\w+ (\\\\w+)', 'ig');\n source.replace(r, (match, name) => {\n collection[name] = 0;\n return match;\n });\n};\n\nclass GLProgram {\n uniform = {};\n attribute = {};\n gl: WebGLRenderingContext;\n id: WebGLProgram;\n\n constructor(gl, vertexSource, fragmentSource) {\n this.gl = gl;\n const vertexShader = this.compile(vertexSource, this.gl.VERTEX_SHADER);\n const fragmentShader = this.compile(fragmentSource, this.gl.FRAGMENT_SHADER);\n this.id = this.gl.createProgram() as WebGLProgram;\n if (!vertexShader || !fragmentShader) return;\n if (!this.id) {\n log('filter: could not create webgl program');\n return;\n }\n this.gl.attachShader(this.id, vertexShader);\n this.gl.attachShader(this.id, fragmentShader);\n this.gl.linkProgram(this.id);\n if (!this.gl.getProgramParameter(this.id, this.gl.LINK_STATUS)) {\n log(`filter: gl link failed: ${this.gl.getProgramInfoLog(this.id)}`);\n return;\n }\n this.gl.useProgram(this.id);\n collect(vertexSource, 'attribute', this.attribute); // Collect attributes\n for (const a in this.attribute) this.attribute[a] = this.gl.getAttribLocation(this.id, a);\n collect(vertexSource, 'uniform', this.uniform); // Collect uniforms\n collect(fragmentSource, 'uniform', this.uniform);\n for (const u in this.uniform) this.uniform[u] = this.gl.getUniformLocation(this.id, u);\n }\n\n compile = (source, type): WebGLShader | null => {\n const shader = this.gl.createShader(type) as WebGLShader;\n if (!shader) {\n log('filter: could not create shader');\n return null;\n }\n this.gl.shaderSource(shader, source);\n this.gl.compileShader(shader);\n if (!this.gl.getShaderParameter(shader, this.gl.COMPILE_STATUS)) {\n log(`filter: gl compile failed: ${this.gl.getShaderInfoLog(shader)}`);\n return null;\n }\n return shader;\n };\n}\n\n// function that is instantiated as class so it has private this members\n/**\n * @class GLImageFilter\n * @property {function} reset reset current filter chain\n * @property {function} add add specified filter to filter chain\n * @property {function} apply execute filter chain and draw result\n * @property {function} draw just draw input to result\n */\n\nexport function GLImageFilter() {\n let drawCount = 0;\n let sourceTexture: WebGLTexture | null = null;\n let lastInChain = false;\n let currentFramebufferIndex = -1;\n let tempFramebuffers: [null, null] | [{ fbo: WebGLFramebuffer | null, texture: WebGLTexture | null }] = [null, null];\n let filterChain: Record[] = [];\n let vertexBuffer: WebGLBuffer | null = null;\n let currentProgram: GLProgram | null = null;\n const fxcanvas = canvas(100, 100);\n const shaderProgramCache = { }; // key is the shader program source, value is the compiled program\n const DRAW = { INTERMEDIATE: 1 };\n const gl = fxcanvas.getContext('webgl') as WebGLRenderingContext;\n if (!gl) {\n log('filter: cannot get webgl context');\n return;\n }\n // @ts-ignore used for sanity checks outside of imagefx\n this.gl = gl;\n\n function resize(width, height) {\n if (width === fxcanvas.width && height === fxcanvas.height) return; // Same width/height? Nothing to do here\n fxcanvas.width = width;\n fxcanvas.height = height;\n if (!vertexBuffer) { // Create the context if we don't have it yet\n const vertices = new Float32Array([-1, -1, 0, 1, 1, -1, 1, 1, -1, 1, 0, 0, -1, 1, 0, 0, 1, -1, 1, 1, 1, 1, 1, 0]); // Create the vertex buffer for the two triangles [x, y, u, v] * 6\n vertexBuffer = gl.createBuffer();\n gl.bindBuffer(gl.ARRAY_BUFFER, vertexBuffer);\n gl.bufferData(gl.ARRAY_BUFFER, vertices, gl.STATIC_DRAW);\n gl.pixelStorei(gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, true);\n }\n gl.viewport(0, 0, fxcanvas.width, fxcanvas.height);\n tempFramebuffers = [null, null]; // Delete old temp framebuffers\n }\n\n function createFramebufferTexture(width, height) {\n const fbo = gl.createFramebuffer() as WebGLFramebuffer;\n gl.bindFramebuffer(gl.FRAMEBUFFER, fbo);\n const renderbuffer = gl.createRenderbuffer();\n gl.bindRenderbuffer(gl.RENDERBUFFER, renderbuffer);\n const texture = gl.createTexture() as WebGLTexture;\n gl.bindTexture(gl.TEXTURE_2D, texture);\n gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, width, height, 0, gl.RGBA, gl.UNSIGNED_BYTE, null);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\n gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, texture, 0);\n gl.bindTexture(gl.TEXTURE_2D, null);\n gl.bindFramebuffer(gl.FRAMEBUFFER, null);\n return { fbo, texture };\n }\n\n function getTempFramebuffer(index): { fbo: WebGLFramebuffer | null, texture: WebGLTexture | null } {\n tempFramebuffers[index] = tempFramebuffers[index] || createFramebufferTexture(fxcanvas.width, fxcanvas.height);\n return tempFramebuffers[index] as { fbo: WebGLFramebuffer, texture: WebGLTexture };\n }\n\n function draw(flags = 0) {\n if (!currentProgram) return;\n let source: WebGLTexture | null = null;\n let target: WebGLFramebuffer | null = null;\n let flipY = false;\n if (drawCount === 0) source = sourceTexture; // First draw call - use the source texture\n else source = getTempFramebuffer(currentFramebufferIndex).texture || null; // All following draw calls use the temp buffer last drawn to\n drawCount++;\n if (lastInChain && !(flags & DRAW.INTERMEDIATE)) { // Last filter in our chain - draw directly to the WebGL Canvas. We may also have to flip the image vertically now\n target = null;\n flipY = drawCount % 2 === 0;\n } else {\n currentFramebufferIndex = (currentFramebufferIndex + 1) % 2;\n target = getTempFramebuffer(currentFramebufferIndex).fbo || null; // Intermediate draw call - get a temp buffer to draw to\n }\n gl.bindTexture(gl.TEXTURE_2D, source); // Bind the source and target and draw the two triangles\n gl.bindFramebuffer(gl.FRAMEBUFFER, target);\n gl.uniform1f(currentProgram.uniform['flipY'], (flipY ? -1 : 1));\n gl.drawArrays(gl.TRIANGLES, 0, 6);\n }\n\n function compileShader(fragmentSource): GLProgram | null {\n if (shaderProgramCache[fragmentSource]) {\n currentProgram = shaderProgramCache[fragmentSource];\n gl.useProgram((currentProgram ? currentProgram.id : null) || null);\n return currentProgram as GLProgram;\n }\n currentProgram = new GLProgram(gl, shaders.vertexIdentity, fragmentSource);\n if (!currentProgram) {\n log('filter: could not get webgl program');\n return null;\n }\n const floatSize = Float32Array.BYTES_PER_ELEMENT;\n const vertSize = 4 * floatSize;\n gl.enableVertexAttribArray(currentProgram.attribute['pos']);\n gl.vertexAttribPointer(currentProgram.attribute['pos'], 2, gl.FLOAT, false, vertSize, 0 * floatSize);\n gl.enableVertexAttribArray(currentProgram.attribute['uv']);\n gl.vertexAttribPointer(currentProgram.attribute['uv'], 2, gl.FLOAT, false, vertSize, 2 * floatSize);\n shaderProgramCache[fragmentSource] = currentProgram;\n return currentProgram as GLProgram;\n }\n\n const filter = {\n colorMatrix: (matrix) => { // general color matrix filter\n const m = new Float32Array(matrix);\n m[4] /= 255;\n m[9] /= 255;\n m[14] /= 255;\n m[19] /= 255;\n const shader = (m[18] === 1 && m[3] === 0 && m[8] === 0 && m[13] === 0 && m[15] === 0 && m[16] === 0 && m[17] === 0 && m[19] === 0) // Can we ignore the alpha value? Makes things a bit faster.\n ? shaders.colorMatrixWithoutAlpha\n : shaders.colorMatrixWithAlpha;\n const program = compileShader(shader);\n if (!program) return;\n gl.uniform1fv(program.uniform['m'], m);\n draw();\n },\n\n brightness: (brightness) => {\n const b = (brightness || 0) + 1;\n filter.colorMatrix([\n b, 0, 0, 0, 0,\n 0, b, 0, 0, 0,\n 0, 0, b, 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n saturation: (amount) => {\n const x = (amount || 0) * 2 / 3 + 1;\n const y = ((x - 1) * -0.5);\n filter.colorMatrix([\n x, y, y, 0, 0,\n y, x, y, 0, 0,\n y, y, x, 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n desaturate: () => {\n filter.saturation(-1);\n },\n\n contrast: (amount) => {\n const v = (amount || 0) + 1;\n const o = -128 * (v - 1);\n filter.colorMatrix([\n v, 0, 0, 0, o,\n 0, v, 0, 0, o,\n 0, 0, v, 0, o,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n negative: () => {\n filter.contrast(-2);\n },\n\n hue: (rotation) => {\n rotation = (rotation || 0) / 180 * Math.PI;\n const cos = Math.cos(rotation);\n const sin = Math.sin(rotation);\n const lumR = 0.213;\n const lumG = 0.715;\n const lumB = 0.072;\n filter.colorMatrix([\n lumR + cos * (1 - lumR) + sin * (-lumR), lumG + cos * (-lumG) + sin * (-lumG), lumB + cos * (-lumB) + sin * (1 - lumB), 0, 0,\n lumR + cos * (-lumR) + sin * (0.143), lumG + cos * (1 - lumG) + sin * (0.140), lumB + cos * (-lumB) + sin * (-0.283), 0, 0,\n lumR + cos * (-lumR) + sin * (-(1 - lumR)), lumG + cos * (-lumG) + sin * (lumG), lumB + cos * (1 - lumB) + sin * (lumB), 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n desaturateLuminance: () => {\n filter.colorMatrix([\n 0.2764723, 0.9297080, 0.0938197, 0, -37.1,\n 0.2764723, 0.9297080, 0.0938197, 0, -37.1,\n 0.2764723, 0.9297080, 0.0938197, 0, -37.1,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n sepia: () => {\n filter.colorMatrix([\n 0.393, 0.7689999, 0.18899999, 0, 0,\n 0.349, 0.6859999, 0.16799999, 0, 0,\n 0.272, 0.5339999, 0.13099999, 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n brownie: () => {\n filter.colorMatrix([\n 0.5997023498159715, 0.34553243048391263, -0.2708298674538042, 0, 47.43192855600873,\n -0.037703249837783157, 0.8609577587992641, 0.15059552388459913, 0, -36.96841498319127,\n 0.24113635128153335, -0.07441037908422492, 0.44972182064877153, 0, -7.562075277591283,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n vintagePinhole: () => {\n filter.colorMatrix([\n 0.6279345635605994, 0.3202183420819367, -0.03965408211312453, 0, 9.651285835294123,\n 0.02578397704808868, 0.6441188644374771, 0.03259127616149294, 0, 7.462829176470591,\n 0.0466055556782719, -0.0851232987247891, 0.5241648018700465, 0, 5.159190588235296,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n kodachrome: () => {\n filter.colorMatrix([\n 1.1285582396593525, -0.3967382283601348, -0.03992559172921793, 0, 63.72958762196502,\n -0.16404339962244616, 1.0835251566291304, -0.05498805115633132, 0, 24.732407896706203,\n -0.16786010706155763, -0.5603416277695248, 1.6014850761964943, 0, 35.62982807460946,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n technicolor: () => {\n filter.colorMatrix([\n 1.9125277891456083, -0.8545344976951645, -0.09155508482755585, 0, 11.793603434377337,\n -0.3087833385928097, 1.7658908555458428, -0.10601743074722245, 0, -70.35205161461398,\n -0.231103377548616, -0.7501899197440212, 1.847597816108189, 0, 30.950940869491138,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n polaroid: () => {\n filter.colorMatrix([\n 1.438, -0.062, -0.062, 0, 0,\n -0.122, 1.378, -0.122, 0, 0,\n -0.016, -0.016, 1.483, 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n shiftToBGR: () => {\n filter.colorMatrix([\n 0, 0, 1, 0, 0,\n 0, 1, 0, 0, 0,\n 1, 0, 0, 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n convolution: (matrix) => { // general convolution Filter\n const m = new Float32Array(matrix);\n const pixelSizeX = 1 / fxcanvas.width;\n const pixelSizeY = 1 / fxcanvas.height;\n const program = compileShader(shaders.convolution);\n if (!program) return;\n gl.uniform1fv(program.uniform['m'], m);\n gl.uniform2f(program.uniform['px'], pixelSizeX, pixelSizeY);\n draw();\n },\n\n detectEdges: () => {\n // @ts-ignore this\n filter.convolution.call(this, [\n 0, 1, 0,\n 1, -4, 1,\n 0, 1, 0,\n ]);\n },\n\n sobelX: () => {\n // @ts-ignore this\n filter.convolution.call(this, [\n -1, 0, 1,\n -2, 0, 2,\n -1, 0, 1,\n ]);\n },\n\n sobelY: () => {\n // @ts-ignore this\n filter.convolution.call(this, [\n -1, -2, -1,\n 0, 0, 0,\n 1, 2, 1,\n ]);\n },\n\n sharpen: (amount) => {\n const a = amount || 1;\n // @ts-ignore this\n filter.convolution.call(this, [\n 0, -1 * a, 0,\n -1 * a, 1 + 4 * a, -1 * a,\n 0, -1 * a, 0,\n ]);\n },\n\n emboss: (size) => {\n const s = size || 1;\n // @ts-ignore this\n filter.convolution.call(this, [\n -2 * s, -1 * s, 0,\n -1 * s, 1, 1 * s,\n 0, 1 * s, 2 * s,\n ]);\n },\n\n blur: (size) => {\n const blurSizeX = (size / 7) / fxcanvas.width;\n const blurSizeY = (size / 7) / fxcanvas.height;\n const program = compileShader(shaders.blur);\n if (!program) return;\n // Vertical\n gl.uniform2f(program.uniform['px'], 0, blurSizeY);\n draw(DRAW.INTERMEDIATE);\n // Horizontal\n gl.uniform2f(program.uniform['px'], blurSizeX, 0);\n draw();\n },\n\n pixelate: (size) => {\n const blurSizeX = (size) / fxcanvas.width;\n const blurSizeY = (size) / fxcanvas.height;\n const program = compileShader(shaders.pixelate);\n if (!program) return;\n gl.uniform2f(program.uniform['size'], blurSizeX, blurSizeY);\n draw();\n },\n };\n\n // @ts-ignore this\n this.add = function (name) {\n // eslint-disable-next-line prefer-rest-params\n const args = Array.prototype.slice.call(arguments, 1);\n const func = filter[name];\n filterChain.push({ func, args });\n };\n\n // @ts-ignore this\n this.reset = function () {\n filterChain = [];\n };\n\n // @ts-ignore this\n this.get = function () {\n return filterChain;\n };\n\n // @ts-ignore this\n this.apply = function (image) {\n resize(image.width, image.height);\n drawCount = 0;\n if (!sourceTexture) sourceTexture = gl.createTexture(); // Create the texture for the input image if we haven't yet\n gl.bindTexture(gl.TEXTURE_2D, sourceTexture);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.NEAREST);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.NEAREST);\n gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, image);\n for (let i = 0; i < filterChain.length; i++) {\n lastInChain = (i === filterChain.length - 1);\n const f = filterChain[i];\n // @ts-ignore function assigment\n f.func.apply(this, f.args || []);\n }\n return fxcanvas;\n };\n\n // @ts-ignore this\n this.draw = function (image) {\n this.add('brightness', 0);\n return this.apply(image);\n };\n}\n", "/**\n * Image enhancements\n */\n\nimport * as tf from '../../dist/tfjs.esm.js';\nimport type { Tensor } from '../exports';\n\nexport async function histogramEqualization(inputImage: Tensor): Promise {\n // const maxValue = 254; // using 255 results in values slightly larger than 1 due to math rounding errors\n const squeeze = inputImage.shape.length === 4 ? tf.squeeze(inputImage) : inputImage;\n const channels = tf.split(squeeze, 3, 2);\n const min: Tensor[] = [tf.min(channels[0]), tf.min(channels[1]), tf.min(channels[2])];\n const max: Tensor[] = [tf.max(channels[0]), tf.max(channels[1]), tf.max(channels[2])];\n const absMax = await Promise.all(max.map((channel) => channel.data()));\n const maxValue = 0.99 * Math.max(absMax[0][0], absMax[1][0], absMax[2][0]);\n const sub = [tf.sub(channels[0], min[0]), tf.sub(channels[1], min[1]), tf.sub(channels[2], min[2])];\n const range = [tf.sub(max[0], min[0]), tf.sub(max[1], min[1]), tf.sub(max[2], min[2])];\n const fact = [tf.div(maxValue, range[0]), tf.div(maxValue, range[1]), tf.div(maxValue, range[2])];\n const enh = [tf.mul(sub[0], fact[0]), tf.mul(sub[1], fact[1]), tf.mul(sub[2], fact[2])];\n const rgb = tf.stack([enh[0], enh[1], enh[2]], 2);\n const reshape = tf.reshape(rgb, [1, squeeze.shape[0], squeeze.shape[1], 3]);\n tf.dispose([...channels, ...min, ...max, ...sub, ...range, ...fact, ...enh, rgb, squeeze]);\n return reshape; // output shape is [1, height, width, 3]\n}\n", "/**\n * Image Processing algorithm implementation\n */\n\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as fxImage from './imagefx';\nimport type { Input, AnyCanvas, Tensor, Config } from '../exports';\nimport { env } from '../util/env';\nimport { log } from '../util/util';\nimport * as enhance from './enhance';\n\nconst maxSize = 3840;\n// internal temp canvases\nlet inCanvas: AnyCanvas | null = null; // use global variable to avoid recreating canvas on each frame\nlet outCanvas: AnyCanvas | null = null; // use global variable to avoid recreating canvas on each frame\nlet tmpCanvas: AnyCanvas | null = null; // use global variable to avoid recreating canvas on each frame\n// @ts-ignore // imagefx is js module that should be converted to a class\nlet fx: fxImage.GLImageFilter | null; // instance of imagefx\n\nconst last: { inputSum: number, cacheDiff: number, sumMethod: number, inputTensor: undefined | Tensor } = {\n inputSum: 0,\n cacheDiff: 1,\n sumMethod: 0,\n inputTensor: undefined,\n};\n\nexport function canvas(width: number, height: number): AnyCanvas {\n let c;\n if (env.browser) { // browser defines canvas object\n if (env.worker) { // if runing in web worker use OffscreenCanvas\n if (typeof OffscreenCanvas === 'undefined') throw new Error('canvas error: attempted to run in web worker but OffscreenCanvas is not supported');\n c = new OffscreenCanvas(width, height);\n } else { // otherwise use DOM canvas\n if (typeof document === 'undefined') throw new Error('canvas error: attempted to run in browser but DOM is not defined');\n c = document.createElement('canvas');\n c.width = width;\n c.height = height;\n }\n } else { // if not running in browser, there is no \"default\" canvas object, so we need monkey patch or fail\n // @ts-ignore // env.canvas is an external monkey-patch\n if (typeof env.Canvas !== 'undefined') c = new env.Canvas(width, height);\n else if (typeof globalThis.Canvas !== 'undefined') c = new globalThis.Canvas(width, height);\n // else throw new Error('canvas error: attempted to use canvas in nodejs without canvas support installed');\n }\n return c;\n}\n\n// helper function to copy canvas from input to output\nexport function copy(input: AnyCanvas, output?: AnyCanvas) {\n const outputCanvas = output || canvas(input.width, input.height);\n const ctx = outputCanvas.getContext('2d') as CanvasRenderingContext2D;\n ctx.drawImage(input, 0, 0);\n return outputCanvas;\n}\n\n// process input image and return tensor\n// input can be tensor, imagedata, htmlimageelement, htmlvideoelement\n// input is resized and run through imagefx filter\nexport async function process(input: Input, config: Config, getTensor: boolean = true): Promise<{ tensor: Tensor | null, canvas: AnyCanvas | null }> {\n if (!input) {\n // throw new Error('input is missing');\n if (config.debug) log('input error: input is missing');\n return { tensor: null, canvas: null }; // video may become temporarily unavailable due to onresize\n }\n // sanity checks since different browsers do not implement all dom elements\n if (\n !(input instanceof tf.Tensor)\n && !(typeof Image !== 'undefined' && input instanceof Image)\n && !(typeof env.Canvas !== 'undefined' && input instanceof env.Canvas)\n && !(typeof globalThis.Canvas !== 'undefined' && input instanceof globalThis.Canvas)\n && !(typeof ImageData !== 'undefined' && input instanceof ImageData)\n && !(typeof ImageBitmap !== 'undefined' && input instanceof ImageBitmap)\n && !(typeof HTMLImageElement !== 'undefined' && input instanceof HTMLImageElement)\n && !(typeof HTMLMediaElement !== 'undefined' && input instanceof HTMLMediaElement)\n && !(typeof HTMLVideoElement !== 'undefined' && input instanceof HTMLVideoElement)\n && !(typeof HTMLCanvasElement !== 'undefined' && input instanceof HTMLCanvasElement)\n && !(typeof OffscreenCanvas !== 'undefined' && input instanceof OffscreenCanvas)\n ) {\n throw new Error('input error: type is not recognized');\n }\n if (input instanceof tf.Tensor) { // if input is tensor use as-is without filters but correct shape as needed\n let tensor: Tensor | null = null;\n if ((input as Tensor)['isDisposedInternal']) throw new Error('input error: attempted to use tensor but it is disposed');\n if (!(input as Tensor)['shape']) throw new Error('input error: attempted to use tensor without a shape');\n if ((input as Tensor).shape.length === 3) { // [height, width, 3 || 4]\n if ((input as Tensor).shape[2] === 3) { // [height, width, 3] so add batch\n tensor = tf.expandDims(input, 0);\n } else if ((input as Tensor).shape[2] === 4) { // [height, width, 4] so strip alpha and add batch\n const rgb = tf.slice3d(input, [0, 0, 0], [-1, -1, 3]);\n tensor = tf.expandDims(rgb, 0);\n tf.dispose(rgb);\n }\n } else if ((input as Tensor).shape.length === 4) { // [1, width, height, 3 || 4]\n if ((input as Tensor).shape[3] === 3) { // [1, width, height, 3] just clone\n tensor = tf.clone(input);\n } else if ((input as Tensor).shape[3] === 4) { // [1, width, height, 4] so strip alpha\n tensor = tf.slice4d(input, [0, 0, 0, 0], [-1, -1, -1, 3]);\n }\n }\n // at the end shape must be [1, height, width, 3]\n if (tensor == null || tensor.shape.length !== 4 || tensor.shape[0] !== 1 || tensor.shape[3] !== 3) throw new Error(`input error: attempted to use tensor with unrecognized shape: ${input['shape']}`);\n if ((tensor as Tensor).dtype === 'int32') {\n const cast = tf.cast(tensor, 'float32');\n tf.dispose(tensor);\n tensor = cast;\n }\n return { tensor, canvas: (config.filter.return ? outCanvas : null) };\n } else {\n // check if resizing will be needed\n if (typeof input['readyState'] !== 'undefined' && input['readyState'] <= 2) {\n if (config.debug) log('input stream is not ready');\n return { tensor: null, canvas: inCanvas }; // video may become temporarily unavailable due to onresize\n }\n const originalWidth = input['naturalWidth'] || input['videoWidth'] || input['width'] || (input['shape'] && (input['shape'][1] > 0));\n const originalHeight = input['naturalHeight'] || input['videoHeight'] || input['height'] || (input['shape'] && (input['shape'][2] > 0));\n if (!originalWidth || !originalHeight) {\n if (config.debug) log('cannot determine input dimensions');\n return { tensor: null, canvas: inCanvas }; // video may become temporarily unavailable due to onresize\n }\n let targetWidth = originalWidth;\n let targetHeight = originalHeight;\n if (targetWidth > maxSize) {\n targetWidth = maxSize;\n targetHeight = Math.trunc(targetWidth * originalHeight / originalWidth);\n }\n if (targetHeight > maxSize) {\n targetHeight = maxSize;\n targetWidth = Math.trunc(targetHeight * originalWidth / originalHeight);\n }\n\n // create our canvas and resize it if needed\n if ((config.filter.width || 0) > 0) targetWidth = config.filter.width;\n else if ((config.filter.height || 0) > 0) targetWidth = originalWidth * ((config.filter.height || 0) / originalHeight);\n if ((config.filter.height || 0) > 0) targetHeight = config.filter.height;\n else if ((config.filter.width || 0) > 0) targetHeight = originalHeight * ((config.filter.width || 0) / originalWidth);\n if (!targetWidth || !targetHeight) throw new Error('input error: cannot determine dimension');\n if (!inCanvas || (inCanvas?.width !== targetWidth) || (inCanvas?.height !== targetHeight)) inCanvas = canvas(targetWidth, targetHeight);\n\n // draw input to our canvas\n const inCtx = inCanvas.getContext('2d') as CanvasRenderingContext2D;\n if ((typeof ImageData !== 'undefined') && (input instanceof ImageData)) {\n inCtx.putImageData(input, 0, 0);\n } else {\n if (config.filter.flip && typeof inCtx.translate !== 'undefined') {\n inCtx.translate(originalWidth, 0);\n inCtx.scale(-1, 1);\n inCtx.drawImage(input as AnyCanvas, 0, 0, originalWidth, originalHeight, 0, 0, inCanvas?.width, inCanvas?.height);\n inCtx.setTransform(1, 0, 0, 1, 0, 0); // resets transforms to defaults\n } else {\n inCtx.drawImage(input as AnyCanvas, 0, 0, originalWidth, originalHeight, 0, 0, inCanvas?.width, inCanvas?.height);\n }\n }\n\n if (!outCanvas || (inCanvas.width !== outCanvas.width) || (inCanvas?.height !== outCanvas?.height)) outCanvas = canvas(inCanvas.width, inCanvas.height); // init output canvas\n\n // imagefx transforms using gl from input canvas to output canvas\n if (config.filter.enabled && env.webgl.supported) {\n if (!fx) fx = env.browser ? new fxImage.GLImageFilter() : null; // && (typeof document !== 'undefined')\n env.filter = !!fx;\n if (!fx || !fx.add) {\n if (config.debug) log('input process error: cannot initialize filters');\n env.webgl.supported = false;\n config.filter.enabled = false;\n copy(inCanvas, outCanvas); // filter failed to initialize\n // return { tensor: null, canvas: inCanvas };\n } else {\n fx.reset();\n if (config.filter.brightness !== 0) fx.add('brightness', config.filter.brightness);\n if (config.filter.contrast !== 0) fx.add('contrast', config.filter.contrast);\n if (config.filter.sharpness !== 0) fx.add('sharpen', config.filter.sharpness);\n if (config.filter.blur !== 0) fx.add('blur', config.filter.blur);\n if (config.filter.saturation !== 0) fx.add('saturation', config.filter.saturation);\n if (config.filter.hue !== 0) fx.add('hue', config.filter.hue);\n if (config.filter.negative) fx.add('negative');\n if (config.filter.sepia) fx.add('sepia');\n if (config.filter.vintage) fx.add('brownie');\n if (config.filter.sepia) fx.add('sepia');\n if (config.filter.kodachrome) fx.add('kodachrome');\n if (config.filter.technicolor) fx.add('technicolor');\n if (config.filter.polaroid) fx.add('polaroid');\n if (config.filter.pixelate !== 0) fx.add('pixelate', config.filter.pixelate);\n if (fx.get() > 0) outCanvas = fx.apply(inCanvas);\n else outCanvas = fx.draw(inCanvas);\n }\n } else {\n copy(inCanvas, outCanvas); // if no filters applied, output canvas is input canvas\n if (fx) fx = null;\n env.filter = !!fx;\n }\n\n if (!getTensor) return { tensor: null, canvas: outCanvas }; // just canvas was requested\n if (!outCanvas) throw new Error('canvas error: cannot create output');\n\n // create tensor from image unless input was a tensor already\n let pixels;\n let depth = 3;\n if ((typeof ImageData !== 'undefined' && input instanceof ImageData) || (input['data'] && input['width'] && input['height'])) { // if input is imagedata, just use it\n if (env.browser && tf.browser) {\n pixels = tf.browser ? tf.browser.fromPixels(input) : null;\n } else {\n depth = input['data'].length / input['height'] / input['width'];\n // const arr = Uint8Array.from(input['data']);\n const arr = new Uint8Array(input['data']['buffer']);\n pixels = tf.tensor(arr, [input['height'], input['width'], depth], 'int32');\n }\n } else {\n if (!tmpCanvas || (outCanvas.width !== tmpCanvas.width) || (outCanvas.height !== tmpCanvas.height)) tmpCanvas = canvas(outCanvas.width, outCanvas.height); // init output canvas\n if (tf.browser && env.browser) {\n if (config.backend === 'webgl' || config.backend === 'humangl' || config.backend === 'webgpu') {\n pixels = tf.browser.fromPixels(outCanvas); // safe to reuse since both backend and context are gl based\n } else {\n tmpCanvas = copy(outCanvas); // cannot use output canvas as it already has gl context so we do a silly one more canvas\n pixels = tf.browser.fromPixels(tmpCanvas);\n }\n } else {\n const tempCanvas = copy(outCanvas); // cannot use output canvas as it already has gl context so we do a silly one more canvas\n const tempCtx = tempCanvas.getContext('2d') as CanvasRenderingContext2D;\n const tempData = tempCtx.getImageData(0, 0, targetWidth, targetHeight);\n depth = tempData.data.length / targetWidth / targetHeight;\n const arr = new Uint8Array(tempData.data.buffer);\n pixels = tf.tensor(arr, [targetWidth, targetHeight, depth]);\n }\n }\n if (depth === 4) { // rgba to rgb\n const rgb = tf.slice3d(pixels, [0, 0, 0], [-1, -1, 3]); // strip alpha channel\n tf.dispose(pixels);\n pixels = rgb;\n }\n if (!pixels) throw new Error('input error: cannot create tensor');\n const casted = tf.cast(pixels, 'float32');\n const tensor = config.filter.equalization ? await enhance.histogramEqualization(casted) : tf.expandDims(casted, 0);\n tf.dispose([pixels, casted]);\n return { tensor, canvas: (config.filter.return ? outCanvas : null) };\n }\n}\n\n/*\nconst checksum = async (input: Tensor): Promise => { // use tf sum or js based sum loop depending on which is faster\n const resizeFact = 48;\n const reduced: Tensor = tf.image.resizeBilinear(input, [Math.trunc((input.shape[1] || 1) / resizeFact), Math.trunc((input.shape[2] || 1) / resizeFact)]);\n const tfSum = async (): Promise => {\n const sumT = tf.sum(reduced);\n const sum0 = await sumT.data();\n tf.dispose(sumT);\n return sum0[0];\n };\n const jsSum = async (): Promise => {\n const reducedData = await reduced.data(); // raw image rgb array\n let sum0 = 0;\n for (let i = 0; i < reducedData.length / 3; i++) sum0 += reducedData[3 * i + 2]; // look only at green value of each pixel\n return sum0;\n };\n if (last.sumMethod === 0) {\n const t0 = now();\n await jsSum();\n const t1 = now();\n await tfSum();\n const t2 = now();\n last.sumMethod = t1 - t0 < t2 - t1 ? 1 : 2;\n }\n const res = last.sumMethod === 1 ? await jsSum() : await tfSum();\n tf.dispose(reduced);\n return res;\n};\n*/\n\nexport async function skip(config: Partial, input: Tensor) {\n let skipFrame = false;\n if (config.cacheSensitivity === 0 || !input.shape || input.shape.length !== 4 || input.shape[1] > 2048 || input.shape[2] > 2048) return skipFrame; // cache disabled or input is invalid or too large for cache analysis\n\n /*\n const checkSum = await checksum(input);\n const diff = 100 * (Math.max(checkSum, last.inputSum) / Math.min(checkSum, last.inputSum) - 1);\n last.inputSum = checkSum;\n // if previous frame was skipped, skip this frame if changed more than cacheSensitivity\n // if previous frame was not skipped, then look for cacheSensitivity or difference larger than one in previous frame to avoid resetting cache in subsequent frames unnecessarily\n let skipFrame = diff < Math.max(config.cacheSensitivity, last.cacheDiff);\n // if difference is above 10x threshold, don't use last value to force reset cache for significant change of scenes or images\n last.cacheDiff = diff > 10 * config.cacheSensitivity ? 0 : diff;\n skipFrame = skipFrame && (last.cacheDiff > 0); // if no cached diff value then force no skip\n */\n\n if (!last.inputTensor) {\n last.inputTensor = tf.clone(input);\n } else if (last.inputTensor.shape[1] !== input.shape[1] || last.inputTensor.shape[2] !== input.shape[2]) { // input resolution changed\n tf.dispose(last.inputTensor);\n last.inputTensor = tf.clone(input);\n } else {\n const t: Record = {};\n t.diff = tf.sub(input, last.inputTensor);\n t.squared = tf.mul(t.diff, t.diff);\n t.sum = tf.sum(t.squared);\n const diffSum = await t.sum.data();\n const diffRelative = diffSum[0] / (input.shape[1] || 1) / (input.shape[2] || 1) / 255 / 3; // squared difference relative to input resolution and averaged per channel\n tf.dispose([last.inputTensor, t.diff, t.squared, t.sum]);\n last.inputTensor = tf.clone(input);\n skipFrame = diffRelative <= (config.cacheSensitivity || 0);\n }\n return skipFrame;\n}\n\nexport async function compare(config: Partial, input1: Tensor, input2: Tensor): Promise {\n const t: Record = {};\n if (!input1 || !input2 || input1.shape.length !== 4 || input1.shape.length !== input2.shape.length) {\n if (!config.debug) log('invalid input tensor or tensor shapes do not match:', input1.shape, input2.shape);\n return 0;\n }\n if (input1.shape[0] !== 1 || input2.shape[0] !== 1 || input1.shape[3] !== 3 || input2.shape[3] !== 3) {\n if (!config.debug) log('input tensors must be of shape [1, height, width, 3]:', input1.shape, input2.shape);\n return 0;\n }\n t.input1 = tf.clone(input1);\n t.input2 = (input1.shape[1] !== input2.shape[1] || input1.shape[2] !== input2.shape[2]) ? tf.image.resizeBilinear(input2, [input1.shape[1], input1.shape[2]]) : tf.clone(input2);\n t.diff = tf.sub(t.input1, t.input2);\n t.squared = tf.mul(t.diff, t.diff);\n t.sum = tf.sum(t.squared);\n const diffSum = await t.sum.data();\n const diffRelative = diffSum[0] / (input1.shape[1] || 1) / (input1.shape[2] || 1) / 255 / 3;\n tf.dispose([t.input1, t.input2, t.diff, t.squared, t.sum]);\n return diffRelative;\n}\n", "import * as tf from '../../dist/tfjs.esm.js';\nimport * as image from '../image/image';\n\n/** Env class that holds detected capabilities */\nexport class Env {\n /** Running in Browser */\n browser: boolean;\n /** Running in NodeJS */\n node: boolean;\n /** Running in WebWorker thread */\n worker: boolean;\n /** Detected platform */\n platform: string = '';\n /** Detected agent */\n agent: string = '';\n /** List of supported backends */\n backends: string[] = [];\n /** Has any work been performed so far */\n initial: boolean;\n /** Are image filters supported? */\n filter: boolean | undefined;\n /** TFJS instance details */\n tfjs: {\n version: undefined | string,\n };\n /** Is offscreenCanvas supported? */\n offscreen: undefined | boolean;\n /** Are performance counter instant values or additive */\n perfadd: boolean = false;\n /** WASM detected capabilities */\n wasm: {\n supported: undefined | boolean,\n backend: undefined | boolean,\n simd: undefined | boolean,\n multithread: undefined | boolean,\n } = {\n supported: undefined,\n backend: undefined,\n simd: undefined,\n multithread: undefined,\n };\n /** WebGL detected capabilities */\n webgl: {\n supported: undefined | boolean,\n backend: undefined | boolean,\n version: undefined | string,\n renderer: undefined | string,\n } = {\n supported: undefined,\n backend: undefined,\n version: undefined,\n renderer: undefined,\n };\n /** WebGPU detected capabilities */\n webgpu: {\n supported: undefined | boolean,\n backend: undefined | boolean,\n adapter: undefined | string,\n } = {\n supported: undefined,\n backend: undefined,\n adapter: undefined,\n };\n /** CPU info */\n cpu: {\n model: undefined | string,\n flags: string[],\n } = {\n model: undefined,\n flags: [],\n };\n /** List of supported kernels for current backend */\n kernels: string[] = [];\n /** MonkeyPatch for Canvas */\n Canvas: undefined;\n /** MonkeyPatch for Image */\n Image: undefined;\n /** MonkeyPatch for ImageData */\n ImageData: undefined;\n\n constructor() {\n this.browser = typeof navigator !== 'undefined';\n this.node = (typeof process !== 'undefined') && (typeof process.versions !== 'undefined') && (typeof process.versions.node !== 'undefined');\n this.tfjs = { version: tf.version['tfjs-core'] };\n this.offscreen = typeof OffscreenCanvas !== 'undefined';\n this.initial = true;\n // @ts-ignore WorkerGlobalScope evaluated in browser only\n this.worker = this.browser && this.offscreen ? (typeof WorkerGlobalScope !== 'undefined') : undefined;\n if (typeof navigator !== 'undefined') {\n const raw = navigator.userAgent.match(/\\(([^()]+)\\)/g);\n if (raw && raw[0]) {\n const platformMatch = raw[0].match(/\\(([^()]+)\\)/g);\n this.platform = (platformMatch && platformMatch[0]) ? platformMatch[0].replace(/\\(|\\)/g, '') : '';\n this.agent = navigator.userAgent.replace(raw[0], '');\n if (this.platform[1]) this.agent = this.agent.replace(raw[1], '');\n this.agent = this.agent.replace(/ /g, ' ');\n // chrome offscreencanvas gpu memory leak\n /*\n const isChrome = env.agent.match(/Chrome\\/.[0-9]/g);\n const verChrome = isChrome && isChrome[0] ? isChrome[0].split('/')[1] : 0;\n if (verChrome > 92 && verChrome < 96) {\n log('disabling offscreenCanvas due to browser error:', isChrome ? isChrome[0] : 'unknown');\n this.offscreen = false;\n }\n */\n }\n } else if (typeof process !== 'undefined') {\n this.platform = `${process.platform} ${process.arch}`;\n this.agent = `NodeJS ${process.version}`;\n }\n }\n\n /** update backend information */\n async updateBackend() {\n // analyze backends\n this.backends = Object.keys(tf.engine().registryFactory);\n this.wasm.supported = typeof WebAssembly !== 'undefined';\n this.wasm.backend = this.backends.includes('wasm');\n if (this.wasm.supported && this.wasm.backend && tf.getBackend() === 'wasm') {\n this.wasm.simd = await tf.env().getAsync('WASM_HAS_SIMD_SUPPORT');\n this.wasm.multithread = await tf.env().getAsync('WASM_HAS_MULTITHREAD_SUPPORT');\n }\n const c = image.canvas(100, 100);\n const ctx = c ? c.getContext('webgl2') : undefined; // causes too many gl contexts\n // const ctx = typeof tf.backend().getGPGPUContext !== undefined ? tf.backend().getGPGPUContext : null;\n this.webgl.supported = typeof ctx !== 'undefined';\n this.webgl.backend = this.backends.includes('webgl');\n if (this.webgl.supported && this.webgl.backend && (tf.getBackend() === 'webgl' || tf.getBackend() === 'humangl')) {\n // @ts-ignore getGPGPUContext only exists on WebGL backend\n const gl = tf.backend().gpgpu !== 'undefined' ? await tf.backend().getGPGPUContext().gl : null;\n if (gl) {\n this.webgl.version = gl.getParameter(gl.VERSION);\n this.webgl.renderer = gl.getParameter(gl.RENDERER);\n }\n }\n // @ts-ignore navigator.gpu is only defined when webgpu is available in browser\n this.webgpu.supported = this.browser && typeof navigator['gpu'] !== 'undefined';\n this.webgpu.backend = this.backends.includes('webgpu');\n try {\n // @ts-ignore navigator.gpu is only defined when webgpu is available in browser\n if (this.webgpu.supported) this.webgpu.adapter = (await navigator['gpu'].requestAdapter()).name;\n } catch {\n this.webgpu.supported = false;\n }\n try {\n this.kernels = tf.getKernelsForBackend(tf.getBackend()).map((kernel) => kernel.kernelName.toLowerCase());\n } catch { /**/ }\n }\n\n /** update cpu information */\n async updateCPU() {\n const cpu = { model: '', flags: [] };\n if (this.node && this.platform.startsWith('linux')) {\n /*\n // eslint-disable-next-line global-require\n const fs = require('fs');\n try {\n const data = fs.readFileSync('/proc/cpuinfo').toString();\n for (const line of data.split('\\n')) {\n if (line.startsWith('model name')) {\n cpu.model = line.match(/:(.*)/g)[0].replace(':', '').trim();\n }\n if (line.startsWith('flags')) {\n cpu.flags = line.match(/:(.*)/g)[0].replace(':', '').trim().split(' ').sort();\n }\n }\n } catch { }\n */\n }\n if (!this['cpu']) Object.defineProperty(this, 'cpu', { value: cpu });\n else this['cpu'] = cpu;\n }\n}\n\nexport const env = new Env();\n", "import { log, join } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport type { GraphModel } from './types';\nimport type { Config } from '../config';\n\nconst options = {\n cacheModels: false,\n verbose: true,\n debug: false,\n modelBasePath: '',\n};\n\nasync function httpHandler(url, init?): Promise {\n if (options.debug) log('load model fetch:', url, init);\n return fetch(url, init);\n}\n\nexport function setModelLoadOptions(config: Config) {\n options.cacheModels = config.cacheModels;\n options.verbose = config.debug;\n options.modelBasePath = config.modelBasePath;\n}\n\nexport async function loadModel(modelPath: string | undefined): Promise {\n let modelUrl = join(options.modelBasePath, modelPath || '');\n if (!modelUrl.toLowerCase().endsWith('.json')) modelUrl += '.json';\n const modelPathSegments = modelUrl.split('/');\n const cachedModelName = 'indexeddb://' + modelPathSegments[modelPathSegments.length - 1].replace('.json', ''); // generate short model name for cache\n const cachedModels = await tf.io.listModels(); // list all models already in cache\n const modelCached = options.cacheModels && Object.keys(cachedModels).includes(cachedModelName); // is model found in cache\n const tfLoadOptions = typeof fetch === 'undefined' ? {} : { fetchFunc: (url, init?) => httpHandler(url, init) };\n const model: GraphModel = new tf.GraphModel(modelCached ? cachedModelName : modelUrl, tfLoadOptions) as unknown as GraphModel; // create model prototype and decide if load from cache or from original modelurl\n let loaded = false;\n try {\n // @ts-ignore private function\n model.findIOHandler(); // decide how to actually load a model\n // @ts-ignore private property\n if (options.debug) log('model load handler:', model.handler);\n // @ts-ignore private property\n const artifacts = await model.handler.load(); // load manifest\n model.loadSync(artifacts); // load weights\n if (options.verbose) log('load model:', model['modelUrl']);\n loaded = true;\n } catch (err) {\n log('error loading model:', modelUrl, err);\n }\n if (loaded && options.cacheModels && !modelCached) { // save model to cache\n try {\n const saveResult = await model.save(cachedModelName);\n log('model saved:', cachedModelName, saveResult);\n } catch (err) {\n log('error saving model:', modelUrl, err);\n }\n }\n return model;\n}\n", "/**\n * Loader and Validator for all models used by Human\n */\n\nimport { env } from './util/env';\nimport { log } from './util/util';\nimport * as gear from './gear/gear';\nimport * as ssrnetAge from './gear/ssrnet-age';\nimport * as ssrnetGender from './gear/ssrnet-gender';\nimport * as antispoof from './face/antispoof';\nimport * as blazeface from './face/blazeface';\nimport * as blazepose from './body/blazepose';\nimport * as centernet from './object/centernet';\nimport * as efficientpose from './body/efficientpose';\nimport * as emotion from './gear/emotion';\nimport * as mobilefacenet from './face/mobilefacenet';\nimport * as facemesh from './face/facemesh';\nimport * as faceres from './face/faceres';\nimport * as handpose from './hand/handpose';\nimport * as handtrack from './hand/handtrack';\nimport * as iris from './face/iris';\nimport * as liveness from './face/liveness';\nimport * as movenet from './body/movenet';\nimport * as nanodet from './object/nanodet';\nimport * as posenet from './body/posenet';\nimport * as segmentation from './segmentation/segmentation';\nimport type { GraphModel } from './tfjs/types';\nimport type { Human } from './human';\n\n/** Instances of all possible TFJS Graph Models used by Human\n * - loaded as needed based on configuration\n * - initialized explictly with `human.load()` method\n * - initialized implicity on first call to `human.detect()`\n * - each model can be `null` if not loaded, instance of `GraphModel` if loaded or `Promise` if loading\n */\nexport class Models {\n ssrnetage: null | GraphModel | Promise = null;\n gear: null | GraphModel | Promise = null;\n blazeposedetect: null | GraphModel | Promise = null;\n blazepose: null | GraphModel | Promise = null;\n centernet: null | GraphModel | Promise = null;\n efficientpose: null | GraphModel | Promise = null;\n mobilefacenet: null | GraphModel | Promise = null;\n emotion: null | GraphModel | Promise = null;\n facedetect: null | GraphModel | Promise = null;\n faceiris: null | GraphModel | Promise = null;\n facemesh: null | GraphModel | Promise = null;\n faceres: null | GraphModel | Promise = null;\n ssrnetgender: null | GraphModel | Promise = null;\n handpose: null | GraphModel | Promise = null;\n handskeleton: null | GraphModel | Promise = null;\n handtrack: null | GraphModel | Promise = null;\n liveness: null | GraphModel | Promise = null;\n movenet: null | GraphModel | Promise = null;\n nanodet: null | GraphModel | Promise = null;\n posenet: null | GraphModel | Promise = null;\n segmentation: null | GraphModel | Promise = null;\n antispoof: null | GraphModel | Promise = null;\n}\n\nexport function reset(instance: Human): void {\n // if (instance.config.debug) log('resetting loaded models');\n for (const model of Object.keys(instance.models)) instance.models[model as keyof Models] = null;\n}\n\n/** Load method preloads all instance.configured models on-demand */\nexport async function load(instance: Human): Promise {\n if (env.initial) reset(instance);\n if (instance.config.hand.enabled) { // handpose model is a combo that must be loaded as a whole\n if (!instance.models.handpose && instance.config.hand.detector?.modelPath?.includes('handdetect')) [instance.models.handpose, instance.models.handskeleton] = await handpose.load(instance.config);\n if (!instance.models.handskeleton && instance.config.hand.landmarks && instance.config.hand.detector?.modelPath?.includes('handdetect')) [instance.models.handpose, instance.models.handskeleton] = await handpose.load(instance.config);\n }\n if (instance.config.body.enabled && !instance.models.blazepose && instance.config.body?.modelPath?.includes('blazepose')) instance.models.blazepose = blazepose.loadPose(instance.config);\n // @ts-ignore optional model\n if (instance.config.body.enabled && !instance.models.blazeposedetect && instance.config.body['detector'] && instance.config.body['detector']['modelPath']) instance.models.blazeposedetect = blazepose.loadDetect(instance.config);\n if (instance.config.body.enabled && !instance.models.efficientpose && instance.config.body?.modelPath?.includes('efficientpose')) instance.models.efficientpose = efficientpose.load(instance.config);\n if (instance.config.body.enabled && !instance.models.movenet && instance.config.body?.modelPath?.includes('movenet')) instance.models.movenet = movenet.load(instance.config);\n if (instance.config.body.enabled && !instance.models.posenet && instance.config.body?.modelPath?.includes('posenet')) instance.models.posenet = posenet.load(instance.config);\n if (instance.config.face.enabled && !instance.models.facedetect) instance.models.facedetect = blazeface.load(instance.config);\n if (instance.config.face.enabled && instance.config.face.antispoof?.enabled && !instance.models.antispoof) instance.models.antispoof = antispoof.load(instance.config);\n if (instance.config.face.enabled && instance.config.face.liveness?.enabled && !instance.models.liveness) instance.models.liveness = liveness.load(instance.config);\n if (instance.config.face.enabled && instance.config.face.description?.enabled && !instance.models.faceres) instance.models.faceres = faceres.load(instance.config);\n if (instance.config.face.enabled && instance.config.face.emotion?.enabled && !instance.models.emotion) instance.models.emotion = emotion.load(instance.config);\n if (instance.config.face.enabled && instance.config.face.iris?.enabled && !instance.config.face.attention?.enabled && !instance.models.faceiris) instance.models.faceiris = iris.load(instance.config);\n if (instance.config.face.enabled && instance.config.face.mesh?.enabled && !instance.models.facemesh) instance.models.facemesh = facemesh.load(instance.config);\n // @ts-ignore optional model\n if (instance.config.face.enabled && instance.config.face['gear']?.enabled && !instance.models.gear) instance.models.gear = gear.load(instance.config);\n // @ts-ignore optional model\n if (instance.config.face.enabled && instance.config.face['ssrnet']?.enabled && !instance.models.ssrnetage) instance.models.ssrnetage = ssrnetAge.load(instance.config);\n // @ts-ignore optional model\n if (instance.config.face.enabled && instance.config.face['ssrnet']?.enabled && !instance.models.ssrnetgender) instance.models.ssrnetgender = ssrnetGender.load(instance.config);\n // @ts-ignore optional model\n if (instance.config.face.enabled && instance.config.face['mobilefacenet']?.enabled && !instance.models.mobilefacenet) instance.models.mobilefacenet = mobilefacenet.load(instance.config);\n if (instance.config.hand.enabled && !instance.models.handtrack && instance.config.hand.detector?.modelPath?.includes('handtrack')) instance.models.handtrack = handtrack.loadDetect(instance.config);\n if (instance.config.hand.enabled && instance.config.hand.landmarks && !instance.models.handskeleton && instance.config.hand.detector?.modelPath?.includes('handtrack')) instance.models.handskeleton = handtrack.loadSkeleton(instance.config);\n if (instance.config.object.enabled && !instance.models.centernet && instance.config.object?.modelPath?.includes('centernet')) instance.models.centernet = centernet.load(instance.config);\n if (instance.config.object.enabled && !instance.models.nanodet && instance.config.object?.modelPath?.includes('nanodet')) instance.models.nanodet = nanodet.load(instance.config);\n if (instance.config.segmentation.enabled && !instance.models.segmentation) instance.models.segmentation = segmentation.load(instance.config);\n\n // models are loaded in parallel asynchronously so lets wait until they are actually loaded\n for await (const model of Object.keys(instance.models)) {\n if (instance.models[model as keyof Models] && typeof instance.models[model as keyof Models] !== 'undefined') instance.models[model as keyof Models] = await instance.models[model as keyof Models];\n }\n}\n\nexport async function validate(instance: Human): Promise {\n interface Op { name: string, category: string, op: string }\n const simpleOps = ['const', 'placeholder', 'noop', 'pad', 'squeeze', 'add', 'sub', 'mul', 'div'];\n for (const defined of Object.keys(instance.models)) {\n const model: GraphModel | null = instance.models[defined as keyof Models] as GraphModel | null;\n if (!model) continue;\n const ops: string[] = [];\n // @ts-ignore // executor is a private method\n const executor = model?.executor;\n if (executor && executor.graph.nodes) {\n for (const kernel of Object.values(executor.graph.nodes)) {\n const op = (kernel as Op).op.toLowerCase();\n if (!ops.includes(op)) ops.push(op);\n }\n } else {\n if (!executor && instance.config.debug) log('model signature not determined:', defined);\n }\n const missing: string[] = [];\n for (const op of ops) {\n if (!simpleOps.includes(op) // exclude simple ops\n && !instance.env.kernels.includes(op) // check actual kernel ops\n && !instance.env.kernels.includes(op.replace('_', '')) // check variation without _\n && !instance.env.kernels.includes(op.replace('native', '')) // check standard variation\n && !instance.env.kernels.includes(op.replace('v2', ''))) { // check non-versioned variation\n missing.push(op);\n }\n }\n // log('model validation ops:', defined, ops);\n if (instance.config.debug && missing.length > 0) log('model validation failed:', defined, missing);\n }\n}\n", "/**\n * GEAR [gender/emotion/age/race] model implementation\n *\n * Based on: [**GEAR Predictor**](https://github.com/Udolf15/GEAR-Predictor)\n */\n\nimport { log, now } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport type { Gender, Race } from '../result';\nimport type { Config } from '../config';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport { env } from '../util/env';\n\nexport type GearType = { age: number, gender: Gender, genderScore: number, race: Array<{ score: number, race: Race }> }\nlet model: GraphModel | null;\nconst last: Array = [];\nconst raceNames = ['white', 'black', 'asian', 'indian', 'other'];\nconst ageWeights = [15, 23, 28, 35.5, 45.5, 55.5, 65];\nlet lastCount = 0;\nlet lastTime = 0;\nlet skipped = Number.MAX_SAFE_INTEGER;\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport async function load(config: Config) {\n if (env.initial) model = null;\n if (!model) model = await loadModel(config.face['gear']);\n else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport async function predict(image: Tensor, config: Config, idx: number, count: number): Promise {\n if (!model) return { age: 0, gender: 'unknown', genderScore: 0, race: [] };\n const skipFrame = skipped < (config.face['gear']?.skipFrames || 0);\n const skipTime = (config.face['gear']?.skipTime || 0) > (now() - lastTime);\n if (config.skipAllowed && skipTime && skipFrame && (lastCount === count) && last[idx]) {\n skipped++;\n return last[idx];\n }\n skipped = 0;\n return new Promise(async (resolve) => {\n if (!model?.inputs[0].shape) return;\n const t: Record = {};\n // t.resize = tf.image.resizeBilinear(image, [model?.inputs[0].shape[2], model?.inputs[0].shape[1]], false);\n const box = [[0.0, 0.10, 0.90, 0.90]]; // empyrical values for top, left, bottom, right\n t.resize = tf.image.cropAndResize(image, box, [0], [model.inputs[0].shape[2], model.inputs[0].shape[1]]);\n const obj: GearType = { age: 0, gender: 'unknown', genderScore: 0, race: [] };\n if (config.face['gear']?.enabled) [t.age, t.gender, t.race] = model.execute(t.resize, ['age_output', 'gender_output', 'race_output']) as Tensor[];\n const gender = await t.gender.data();\n obj.gender = gender[0] > gender[1] ? 'male' : 'female';\n obj.genderScore = Math.round(100 * (gender[0] > gender[1] ? gender[0] : gender[1])) / 100;\n const race = await t.race.data();\n for (let i = 0; i < race.length; i++) {\n if (race[i] > (config.face['gear']?.minConfidence || 0.2)) obj.race.push({ score: Math.round(100 * race[i]) / 100, race: raceNames[i] as Race });\n }\n obj.race.sort((a, b) => b.score - a.score);\n // {0: 'Below20', 1: '21-25', 2: '26-30', 3: '31-40',4: '41-50', 5: '51-60', 6: 'Above60'}\n const ageDistribution = Array.from(await t.age.data());\n const ageSorted = ageDistribution.map((a, i) => [ageWeights[i], a]).sort((a, b) => b[1] - a[1]);\n let age = ageSorted[0][0]; // pick best starting point\n for (let i = 1; i < ageSorted.length; i++) age += ageSorted[i][1] * (ageSorted[i][0] - age); // adjust with each other choice by weight\n obj.age = Math.round(10 * age) / 10;\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n last[idx] = obj;\n lastCount = count;\n lastTime = now();\n resolve(obj);\n });\n}\n", "import * as tf from '../../dist/tfjs.esm.js';\nimport type { Tensor } from './types';\n\nexport const constants: Record = {\n tf255: 255,\n tf1: 1,\n tf2: 2,\n tf05: 0.5,\n tf127: 127.5,\n rgb: [0.2989, 0.5870, 0.1140],\n};\n\nexport function init() {\n constants.tf255 = tf.scalar(255, 'float32');\n constants.tf1 = tf.scalar(1, 'float32');\n constants.tf2 = tf.scalar(2, 'float32');\n constants.tf05 = tf.scalar(0.5, 'float32');\n constants.tf127 = tf.scalar(127.5, 'float32');\n constants.rgb = tf.tensor1d([0.2989, 0.5870, 0.1140], 'float32'); // factors for red/green/blue colors when converting to grayscale\n}\n", "/**\n * Age model implementation\n *\n * Based on: [**SSR-Net**](https://github.com/shamangary/SSR-Net)\n */\n\nimport { log, now } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport { env } from '../util/env';\nimport { constants } from '../tfjs/constants';\nimport type { Config } from '../config';\nimport type { GraphModel, Tensor } from '../tfjs/types';\n\nlet model: GraphModel | null;\nconst last: Array<{ age: number }> = [];\nlet lastCount = 0;\nlet lastTime = 0;\nlet skipped = Number.MAX_SAFE_INTEGER;\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport async function load(config: Config) {\n if (env.initial) model = null;\n if (!model) model = await loadModel(config.face['ssrnet'].modelPathAge);\n else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport async function predict(image: Tensor, config: Config, idx: number, count: number): Promise<{ age: number }> {\n if (!model) return { age: 0 };\n const skipFrame = skipped < (config.face['ssrnet']?.skipFrames || 0);\n const skipTime = (config.face['ssrnet']?.skipTime || 0) > (now() - lastTime);\n if (config.skipAllowed && skipFrame && skipTime && (lastCount === count) && last[idx]?.age && (last[idx]?.age > 0)) {\n skipped++;\n return last[idx];\n }\n skipped = 0;\n return new Promise(async (resolve) => {\n if (!model?.inputs || !model.inputs[0] || !model.inputs[0].shape) return;\n const t: Record = {};\n t.resize = tf.image.resizeBilinear(image, [model.inputs[0].shape[2], model.inputs[0].shape[1]], false);\n t.enhance = tf.mul(t.resize, constants.tf255);\n const obj = { age: 0 };\n if (config.face['ssrnet'].enabled) t.age = model.execute(t.enhance) as Tensor;\n if (t.age) {\n const data = await t.age.data();\n obj.age = Math.trunc(10 * data[0]) / 10;\n }\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n last[idx] = obj;\n lastCount = count;\n lastTime = now();\n resolve(obj);\n });\n}\n", "/**\n * Gender model implementation\n *\n * Based on: [**SSR-Net**](https://github.com/shamangary/SSR-Net)\n */\n\nimport { log, now } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport { constants } from '../tfjs/constants';\nimport type { Gender } from '../result';\nimport type { Config } from '../config';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport { env } from '../util/env';\n\nlet model: GraphModel | null;\nconst last: Array<{ gender: Gender, genderScore: number }> = [];\nlet lastCount = 0;\nlet lastTime = 0;\nlet skipped = Number.MAX_SAFE_INTEGER;\n\n// tuning values\nconst rgb = [0.2989, 0.5870, 0.1140]; // factors for red/green/blue colors when converting to grayscale\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport async function load(config: Config | any) {\n if (env.initial) model = null;\n if (!model) model = await loadModel(config.face['ssrnet'].modelPathGender);\n else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport async function predict(image: Tensor, config: Config, idx, count): Promise<{ gender: Gender, genderScore: number }> {\n if (!model) return { gender: 'unknown', genderScore: 0 };\n const skipFrame = skipped < (config.face['ssrnet']?.skipFrames || 0);\n const skipTime = (config.face['ssrnet']?.skipTime || 0) > (now() - lastTime);\n if (config.skipAllowed && skipFrame && skipTime && (lastCount === count) && last[idx]?.gender && (last[idx]?.genderScore > 0)) {\n skipped++;\n return last[idx];\n }\n skipped = 0;\n return new Promise(async (resolve) => {\n if (!model?.inputs[0].shape) return;\n const t: Record = {};\n t.resize = tf.image.resizeBilinear(image, [model.inputs[0].shape[2], model.inputs[0].shape[1]], false);\n t.enhance = tf.tidy(() => {\n const [red, green, blue] = tf.split(t.resize, 3, 3);\n const redNorm = tf.mul(red, rgb[0]);\n const greenNorm = tf.mul(green, rgb[1]);\n const blueNorm = tf.mul(blue, rgb[2]);\n const grayscale = tf.addN([redNorm, greenNorm, blueNorm]);\n const normalize = tf.mul(tf.sub(grayscale, constants.tf05), 2); // range grayscale:-1..1\n return normalize;\n });\n const obj: { gender: Gender, genderScore: number } = { gender: 'unknown', genderScore: 0 };\n if (config.face['ssrnet'].enabled) t.gender = model.execute(t.enhance) as Tensor;\n const data = await t.gender.data();\n obj.gender = data[0] > data[1] ? 'female' : 'male'; // returns two values 0..1, bigger one is prediction\n obj.genderScore = data[0] > data[1] ? (Math.trunc(100 * data[0]) / 100) : (Math.trunc(100 * data[1]) / 100);\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n last[idx] = obj;\n lastCount = count;\n lastTime = now();\n resolve(obj);\n });\n}\n", "/**\n * Anti-spoofing model implementation\n */\n\nimport { log, now } from '../util/util';\nimport type { Config } from '../config';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport { env } from '../util/env';\n\nlet model: GraphModel | null;\nconst cached: Array = [];\nlet skipped = Number.MAX_SAFE_INTEGER;\nlet lastCount = 0;\nlet lastTime = 0;\n\nexport async function load(config: Config): Promise {\n if (env.initial) model = null;\n if (!model) model = await loadModel(config.face.antispoof?.modelPath);\n else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\nexport async function predict(image: Tensor, config: Config, idx: number, count: number): Promise {\n if (!model) return 0;\n const skipTime = (config.face.antispoof?.skipTime || 0) > (now() - lastTime);\n const skipFrame = skipped < (config.face.antispoof?.skipFrames || 0);\n if (config.skipAllowed && skipTime && skipFrame && (lastCount === count) && cached[idx]) {\n skipped++;\n return cached[idx];\n }\n skipped = 0;\n return new Promise(async (resolve) => {\n const resize = tf.image.resizeBilinear(image, [model?.inputs[0].shape ? model.inputs[0].shape[2] : 0, model?.inputs[0].shape ? model.inputs[0].shape[1] : 0], false);\n const res = model?.execute(resize) as Tensor;\n const num = (await res.data())[0];\n cached[idx] = Math.round(100 * num) / 100;\n lastCount = count;\n lastTime = now();\n tf.dispose([resize, res]);\n resolve(cached[idx]);\n });\n}\n", "/**\n * BlazeFace, FaceMesh & Iris model implementation\n * See `facemesh.ts` for entry point\n */\n\nexport const meshAnnotations: Record = {\n silhouette: [\n 10, 338, 297, 332, 284, 251, 389, 356, 454, 323, 361, 288,\n 397, 365, 379, 378, 400, 377, 152, 148, 176, 149, 150, 136,\n 172, 58, 132, 93, 234, 127, 162, 21, 54, 103, 67, 109,\n ],\n lipsUpperOuter: [61, 185, 40, 39, 37, 0, 267, 269, 270, 409, 291], // 11\n lipsLowerOuter: [146, 91, 181, 84, 17, 314, 405, 321, 375, 291], // 10\n lipsUpperInner: [78, 191, 80, 81, 82, 13, 312, 311, 310, 415, 308], // 11\n lipsLowerInner: [78, 95, 88, 178, 87, 14, 317, 402, 318, 324, 308], // 11\n rightEyeUpper0: [246, 161, 160, 159, 158, 157, 173], // 7\n rightEyeLower0: [33, 7, 163, 144, 145, 153, 154, 155, 133], // 9\n rightEyeUpper1: [247, 30, 29, 27, 28, 56, 190], // 7\n rightEyeLower1: [130, 25, 110, 24, 23, 22, 26, 112, 243], // 9\n rightEyeUpper2: [113, 225, 224, 223, 222, 221, 189], // 7\n rightEyeLower2: [226, 31, 228, 229, 230, 231, 232, 233, 244], // 9\n rightEyeLower3: [143, 111, 117, 118, 119, 120, 121, 128, 245], // 9\n rightEyebrowUpper: [156, 70, 63, 105, 66, 107, 55, 193], // 8\n rightEyebrowLower: [35, 124, 46, 53, 52, 65], // 6\n rightEyeIris: [473, 474, 475, 476, 477], // 5\n leftEyeUpper0: [466, 388, 387, 386, 385, 384, 398],\n leftEyeLower0: [263, 249, 390, 373, 374, 380, 381, 382, 362],\n leftEyeUpper1: [467, 260, 259, 257, 258, 286, 414],\n leftEyeLower1: [359, 255, 339, 254, 253, 252, 256, 341, 463],\n leftEyeUpper2: [342, 445, 444, 443, 442, 441, 413],\n leftEyeLower2: [446, 261, 448, 449, 450, 451, 452, 453, 464],\n leftEyeLower3: [372, 340, 346, 347, 348, 349, 350, 357, 465],\n leftEyebrowUpper: [383, 300, 293, 334, 296, 336, 285, 417],\n leftEyebrowLower: [265, 353, 276, 283, 282, 295],\n leftEyeIris: [468, 469, 470, 471, 472],\n midwayBetweenEyes: [168],\n noseTip: [1],\n noseBottom: [2],\n noseRightCorner: [98],\n noseLeftCorner: [327],\n rightCheek: [205],\n leftCheek: [425],\n};\n\nexport const meshLandmarks: Record = {\n count: 468,\n mouth: 13,\n symmetryLine: [13, meshAnnotations['midwayBetweenEyes'][0]],\n};\n\nexport const blazeFaceLandmarks: Record = {\n leftEye: 0,\n rightEye: 1,\n nose: 2,\n mouth: 3,\n leftEar: 4,\n rightEar: 5,\n symmetryLine: [3, 2],\n};\n\nexport const irisIndices: Array<{ key: string, indices: number[] }> = [ // A mapping from facemesh model keypoints to iris model keypoints.\n { key: 'EyeUpper0', indices: [9, 10, 11, 12, 13, 14, 15] }, // 7 x 3d\n { key: 'EyeUpper1', indices: [25, 26, 27, 28, 29, 30, 31] }, // 7 x 3d\n { key: 'EyeUpper2', indices: [41, 42, 43, 44, 45, 46, 47] }, // 7 x 3d\n { key: 'EyeLower0', indices: [0, 1, 2, 3, 4, 5, 6, 7, 8] }, // 7 x 3d\n { key: 'EyeLower1', indices: [16, 17, 18, 19, 20, 21, 22, 23, 24] }, // 9 x 3d\n { key: 'EyeLower2', indices: [32, 33, 34, 35, 36, 37, 38, 39, 40] }, // 9 x 3d\n { key: 'EyeLower3', indices: [54, 55, 56, 57, 58, 59, 60, 61, 62] }, // 9 x 3d\n { key: 'EyebrowUpper', indices: [63, 64, 65, 66, 67, 68, 69, 70] }, // 8 x 3d\n { key: 'EyebrowLower', indices: [48, 49, 50, 51, 52, 53] }, // 6 x 3d\n];\n\nexport const UV468: [number, number][] = [\n [0.499976992607117, 0.652534008026123],\n [0.500025987625122, 0.547487020492554],\n [0.499974012374878, 0.602371990680695],\n [0.482113003730774, 0.471979022026062],\n [0.500150978565216, 0.527155995368958],\n [0.499909996986389, 0.498252987861633],\n [0.499523013830185, 0.40106201171875],\n [0.289712011814117, 0.380764007568359],\n [0.499954998493195, 0.312398016452789],\n [0.499987006187439, 0.269918978214264],\n [0.500023007392883, 0.107050001621246],\n [0.500023007392883, 0.666234016418457],\n [0.5000159740448, 0.679224014282227],\n [0.500023007392883, 0.692348003387451],\n [0.499976992607117, 0.695277988910675],\n [0.499976992607117, 0.70593398809433],\n [0.499976992607117, 0.719385027885437],\n [0.499976992607117, 0.737019002437592],\n [0.499967992305756, 0.781370997428894],\n [0.499816000461578, 0.562981009483337],\n [0.473773002624512, 0.573909997940063],\n [0.104906998574734, 0.254140973091125],\n [0.365929991006851, 0.409575998783112],\n [0.338757991790771, 0.41302502155304],\n [0.311120003461838, 0.409460008144379],\n [0.274657994508743, 0.389131009578705],\n [0.393361985683441, 0.403706014156342],\n [0.345234006643295, 0.344011008739471],\n [0.370094001293182, 0.346076011657715],\n [0.319321990013123, 0.347265005111694],\n [0.297903001308441, 0.353591024875641],\n [0.24779200553894, 0.410809993743896],\n [0.396889001131058, 0.842755019664764],\n [0.280097991228104, 0.375599980354309],\n [0.106310002505779, 0.399955987930298],\n [0.2099249958992, 0.391353011131287],\n [0.355807989835739, 0.534406006336212],\n [0.471751004457474, 0.65040397644043],\n [0.474155008792877, 0.680191993713379],\n [0.439785003662109, 0.657229006290436],\n [0.414617002010345, 0.66654098033905],\n [0.450374007225037, 0.680860996246338],\n [0.428770989179611, 0.682690978050232],\n [0.374971002340317, 0.727805018424988],\n [0.486716985702515, 0.547628998756409],\n [0.485300987958908, 0.527395009994507],\n [0.257764995098114, 0.314490020275116],\n [0.401223003864288, 0.455172002315521],\n [0.429818987846375, 0.548614978790283],\n [0.421351999044418, 0.533740997314453],\n [0.276895999908447, 0.532056987285614],\n [0.483370006084442, 0.499586999416351],\n [0.33721199631691, 0.282882988452911],\n [0.296391993761063, 0.293242990970612],\n [0.169294998049736, 0.193813979625702],\n [0.447580009698868, 0.302609980106354],\n [0.392390012741089, 0.353887975215912],\n [0.354490011930466, 0.696784019470215],\n [0.067304998636246, 0.730105042457581],\n [0.442739009857178, 0.572826027870178],\n [0.457098007202148, 0.584792017936707],\n [0.381974011659622, 0.694710969924927],\n [0.392388999462128, 0.694203019142151],\n [0.277076005935669, 0.271932005882263],\n [0.422551989555359, 0.563233017921448],\n [0.385919004678726, 0.281364023685455],\n [0.383103013038635, 0.255840003490448],\n [0.331431001424789, 0.119714021682739],\n [0.229923993349075, 0.232002973556519],\n [0.364500999450684, 0.189113974571228],\n [0.229622006416321, 0.299540996551514],\n [0.173287004232407, 0.278747975826263],\n [0.472878992557526, 0.666198015213013],\n [0.446828007698059, 0.668527007102966],\n [0.422762006521225, 0.673889994621277],\n [0.445307999849319, 0.580065965652466],\n [0.388103008270264, 0.693961024284363],\n [0.403039008378983, 0.706539988517761],\n [0.403629004955292, 0.693953037261963],\n [0.460041999816895, 0.557139039039612],\n [0.431158006191254, 0.692366003990173],\n [0.452181994915009, 0.692366003990173],\n [0.475387006998062, 0.692366003990173],\n [0.465828001499176, 0.779190003871918],\n [0.472328990697861, 0.736225962638855],\n [0.473087012767792, 0.717857003211975],\n [0.473122000694275, 0.704625964164734],\n [0.473033010959625, 0.695277988910675],\n [0.427942007780075, 0.695277988910675],\n [0.426479011774063, 0.703539967536926],\n [0.423162013292313, 0.711845993995667],\n [0.4183090031147, 0.720062971115112],\n [0.390094995498657, 0.639572978019714],\n [0.013953999616206, 0.560034036636353],\n [0.499913990497589, 0.58014702796936],\n [0.413199990987778, 0.69539999961853],\n [0.409626007080078, 0.701822996139526],\n [0.468080013990402, 0.601534962654114],\n [0.422728985548019, 0.585985004901886],\n [0.463079988956451, 0.593783974647522],\n [0.37211999297142, 0.47341400384903],\n [0.334562003612518, 0.496073007583618],\n [0.411671012639999, 0.546965003013611],\n [0.242175996303558, 0.14767599105835],\n [0.290776997804642, 0.201445996761322],\n [0.327338010072708, 0.256527006626129],\n [0.399509996175766, 0.748921036720276],\n [0.441727995872498, 0.261676013469696],\n [0.429764986038208, 0.187834024429321],\n [0.412198007106781, 0.108901023864746],\n [0.288955003023148, 0.398952007293701],\n [0.218936994671822, 0.435410976409912],\n [0.41278201341629, 0.398970007896423],\n [0.257135003805161, 0.355440020561218],\n [0.427684992551804, 0.437960982322693],\n [0.448339998722076, 0.536936044692993],\n [0.178560003638268, 0.45755398273468],\n [0.247308000922203, 0.457193970680237],\n [0.286267012357712, 0.467674970626831],\n [0.332827985286713, 0.460712015628815],\n [0.368755996227264, 0.447206974029541],\n [0.398963987827301, 0.432654976844788],\n [0.476410001516342, 0.405806005001068],\n [0.189241006970406, 0.523923993110657],\n [0.228962004184723, 0.348950982093811],\n [0.490725994110107, 0.562400996685028],\n [0.404670000076294, 0.485132992267609],\n [0.019469000399113, 0.401564002037048],\n [0.426243007183075, 0.420431017875671],\n [0.396993011236191, 0.548797011375427],\n [0.266469985246658, 0.376977026462555],\n [0.439121007919312, 0.51895797252655],\n [0.032313998788595, 0.644356966018677],\n [0.419054001569748, 0.387154996395111],\n [0.462783008813858, 0.505746960639954],\n [0.238978996872902, 0.779744982719421],\n [0.198220998048782, 0.831938028335571],\n [0.107550002634525, 0.540755033493042],\n [0.183610007166862, 0.740257024765015],\n [0.134409993886948, 0.333683013916016],\n [0.385764002799988, 0.883153975009918],\n [0.490967005491257, 0.579378008842468],\n [0.382384985685349, 0.508572995662689],\n [0.174399003386497, 0.397670984268188],\n [0.318785011768341, 0.39623498916626],\n [0.343364000320435, 0.400596976280212],\n [0.396100014448166, 0.710216999053955],\n [0.187885001301765, 0.588537991046906],\n [0.430987000465393, 0.944064974784851],\n [0.318993002176285, 0.898285031318665],\n [0.266247987747192, 0.869701027870178],\n [0.500023007392883, 0.190576016902924],\n [0.499976992607117, 0.954452991485596],\n [0.366169989109039, 0.398822009563446],\n [0.393207013607025, 0.39553701877594],\n [0.410373002290726, 0.391080021858215],\n [0.194993004202843, 0.342101991176605],\n [0.388664990663528, 0.362284004688263],\n [0.365961998701096, 0.355970978736877],\n [0.343364000320435, 0.355356991291046],\n [0.318785011768341, 0.35834002494812],\n [0.301414996385574, 0.363156020641327],\n [0.058132998645306, 0.319076001644135],\n [0.301414996385574, 0.387449026107788],\n [0.499987989664078, 0.618434011936188],\n [0.415838003158569, 0.624195992946625],\n [0.445681989192963, 0.566076993942261],\n [0.465844005346298, 0.620640993118286],\n [0.49992299079895, 0.351523995399475],\n [0.288718998432159, 0.819945991039276],\n [0.335278987884521, 0.852819979190826],\n [0.440512001514435, 0.902418971061707],\n [0.128294005990028, 0.791940987110138],\n [0.408771991729736, 0.373893976211548],\n [0.455606997013092, 0.451801002025604],\n [0.499877005815506, 0.908990025520325],\n [0.375436991453171, 0.924192011356354],\n [0.11421000212431, 0.615022003650665],\n [0.448662012815475, 0.695277988910675],\n [0.4480200111866, 0.704632043838501],\n [0.447111994028091, 0.715808033943176],\n [0.444831997156143, 0.730794012546539],\n [0.430011987686157, 0.766808986663818],\n [0.406787008047104, 0.685672998428345],\n [0.400738000869751, 0.681069016456604],\n [0.392399996519089, 0.677703022956848],\n [0.367855995893478, 0.663918972015381],\n [0.247923001646996, 0.601333022117615],\n [0.452769994735718, 0.420849978923798],\n [0.43639200925827, 0.359887003898621],\n [0.416164010763168, 0.368713974952698],\n [0.413385987281799, 0.692366003990173],\n [0.228018000721931, 0.683571994304657],\n [0.468268007040024, 0.352671027183533],\n [0.411361992359161, 0.804327011108398],\n [0.499989002943039, 0.469825029373169],\n [0.479153990745544, 0.442654013633728],\n [0.499974012374878, 0.439637005329132],\n [0.432112008333206, 0.493588984012604],\n [0.499886006116867, 0.866917014122009],\n [0.49991300702095, 0.821729004383087],\n [0.456548988819122, 0.819200992584229],\n [0.344549000263214, 0.745438992977142],\n [0.37890899181366, 0.574010014533997],\n [0.374292999505997, 0.780184984207153],\n [0.319687992334366, 0.570737957954407],\n [0.357154995203018, 0.604269981384277],\n [0.295284003019333, 0.621580958366394],\n [0.447750002145767, 0.862477004528046],\n [0.410986006259918, 0.508723020553589],\n [0.31395098567009, 0.775308012962341],\n [0.354128003120422, 0.812552988529205],\n [0.324548006057739, 0.703992962837219],\n [0.189096003770828, 0.646299958229065],\n [0.279776990413666, 0.71465802192688],\n [0.1338230073452, 0.682700991630554],\n [0.336768001317978, 0.644733011722565],\n [0.429883986711502, 0.466521978378296],\n [0.455527991056442, 0.548622965812683],\n [0.437114000320435, 0.558896005153656],\n [0.467287987470627, 0.529924988746643],\n [0.414712011814117, 0.335219979286194],\n [0.37704598903656, 0.322777986526489],\n [0.344107985496521, 0.320150971412659],\n [0.312875986099243, 0.32233202457428],\n [0.283526003360748, 0.333190023899078],\n [0.241245999932289, 0.382785975933075],\n [0.102986000478268, 0.468762993812561],\n [0.267612010240555, 0.424560010433197],\n [0.297879010438919, 0.433175981044769],\n [0.333433985710144, 0.433878004550934],\n [0.366427004337311, 0.426115989685059],\n [0.396012008190155, 0.416696012020111],\n [0.420121014118195, 0.41022801399231],\n [0.007561000064015, 0.480777025222778],\n [0.432949006557465, 0.569517970085144],\n [0.458638995885849, 0.479089021682739],\n [0.473466008901596, 0.545744001865387],\n [0.476087987422943, 0.563830018043518],\n [0.468472003936768, 0.555056989192963],\n [0.433990985155106, 0.582361996173859],\n [0.483518004417419, 0.562983989715576],\n [0.482482999563217, 0.57784903049469],\n [0.42645001411438, 0.389798998832703],\n [0.438998997211456, 0.39649498462677],\n [0.450067013502121, 0.400434017181396],\n [0.289712011814117, 0.368252992630005],\n [0.276670008897781, 0.363372981548309],\n [0.517862021923065, 0.471948027610779],\n [0.710287988185883, 0.380764007568359],\n [0.526226997375488, 0.573909997940063],\n [0.895093023777008, 0.254140973091125],\n [0.634069979190826, 0.409575998783112],\n [0.661242008209229, 0.41302502155304],\n [0.688880026340485, 0.409460008144379],\n [0.725341975688934, 0.389131009578705],\n [0.606630027294159, 0.40370500087738],\n [0.654766023159027, 0.344011008739471],\n [0.629905998706818, 0.346076011657715],\n [0.680678009986877, 0.347265005111694],\n [0.702096998691559, 0.353591024875641],\n [0.75221198797226, 0.410804986953735],\n [0.602918028831482, 0.842862963676453],\n [0.719901978969574, 0.375599980354309],\n [0.893692970275879, 0.399959981441498],\n [0.790081977844238, 0.391354024410248],\n [0.643998026847839, 0.534487962722778],\n [0.528249025344849, 0.65040397644043],\n [0.525849997997284, 0.680191040039062],\n [0.560214996337891, 0.657229006290436],\n [0.585384011268616, 0.66654098033905],\n [0.549625992774963, 0.680860996246338],\n [0.57122802734375, 0.682691991329193],\n [0.624852001667023, 0.72809898853302],\n [0.513050019741058, 0.547281980514526],\n [0.51509702205658, 0.527251958847046],\n [0.742246985435486, 0.314507007598877],\n [0.598631024360657, 0.454979002475739],\n [0.570338010787964, 0.548575043678284],\n [0.578631997108459, 0.533622980117798],\n [0.723087012767792, 0.532054007053375],\n [0.516445994377136, 0.499638974666595],\n [0.662801027297974, 0.282917976379395],\n [0.70362401008606, 0.293271005153656],\n [0.830704987049103, 0.193813979625702],\n [0.552385985851288, 0.302568018436432],\n [0.607609987258911, 0.353887975215912],\n [0.645429015159607, 0.696707010269165],\n [0.932694971561432, 0.730105042457581],\n [0.557260990142822, 0.572826027870178],\n [0.542901992797852, 0.584792017936707],\n [0.6180260181427, 0.694710969924927],\n [0.607590973377228, 0.694203019142151],\n [0.722943007946014, 0.271963000297546],\n [0.577413976192474, 0.563166975975037],\n [0.614082992076874, 0.281386971473694],\n [0.616907000541687, 0.255886018276215],\n [0.668509006500244, 0.119913995265961],\n [0.770092010498047, 0.232020974159241],\n [0.635536015033722, 0.189248979091644],\n [0.77039098739624, 0.299556016921997],\n [0.826722025871277, 0.278755009174347],\n [0.527121007442474, 0.666198015213013],\n [0.553171992301941, 0.668527007102966],\n [0.577238023281097, 0.673889994621277],\n [0.554691970348358, 0.580065965652466],\n [0.611896991729736, 0.693961024284363],\n [0.59696102142334, 0.706539988517761],\n [0.596370995044708, 0.693953037261963],\n [0.539958000183105, 0.557139039039612],\n [0.568841993808746, 0.692366003990173],\n [0.547818005084991, 0.692366003990173],\n [0.52461302280426, 0.692366003990173],\n [0.534089982509613, 0.779141008853912],\n [0.527670979499817, 0.736225962638855],\n [0.526912987232208, 0.717857003211975],\n [0.526877999305725, 0.704625964164734],\n [0.526966989040375, 0.695277988910675],\n [0.572058022022247, 0.695277988910675],\n [0.573521018028259, 0.703539967536926],\n [0.57683801651001, 0.711845993995667],\n [0.581691026687622, 0.720062971115112],\n [0.609944999217987, 0.639909982681274],\n [0.986046016216278, 0.560034036636353],\n [0.5867999792099, 0.69539999961853],\n [0.590372025966644, 0.701822996139526],\n [0.531915009021759, 0.601536989212036],\n [0.577268004417419, 0.585934996604919],\n [0.536915004253387, 0.593786001205444],\n [0.627542972564697, 0.473352015018463],\n [0.665585994720459, 0.495950996875763],\n [0.588353991508484, 0.546862006187439],\n [0.757824003696442, 0.14767599105835],\n [0.709249973297119, 0.201507985591888],\n [0.672684013843536, 0.256581008434296],\n [0.600408971309662, 0.74900496006012],\n [0.55826598405838, 0.261672019958496],\n [0.570303976535797, 0.187870979309082],\n [0.588165998458862, 0.109044015407562],\n [0.711045026779175, 0.398952007293701],\n [0.781069993972778, 0.435405015945435],\n [0.587247014045715, 0.398931980133057],\n [0.742869973182678, 0.355445981025696],\n [0.572156012058258, 0.437651991844177],\n [0.55186802148819, 0.536570012569427],\n [0.821442008018494, 0.457556009292603],\n [0.752701997756958, 0.457181990146637],\n [0.71375697851181, 0.467626988887787],\n [0.66711300611496, 0.460672974586487],\n [0.631101012229919, 0.447153985500336],\n [0.6008620262146, 0.432473003864288],\n [0.523481011390686, 0.405627012252808],\n [0.810747981071472, 0.523926019668579],\n [0.771045982837677, 0.348959028720856],\n [0.509127020835876, 0.562718033790588],\n [0.595292985439301, 0.485023975372314],\n [0.980530977249146, 0.401564002037048],\n [0.573499977588654, 0.420000016689301],\n [0.602994978427887, 0.548687994480133],\n [0.733529984951019, 0.376977026462555],\n [0.560611009597778, 0.519016981124878],\n [0.967685997486115, 0.644356966018677],\n [0.580985009670258, 0.387160003185272],\n [0.537728011608124, 0.505385041236877],\n [0.760966002941132, 0.779752969741821],\n [0.801778972148895, 0.831938028335571],\n [0.892440974712372, 0.54076099395752],\n [0.816350996494293, 0.740260004997253],\n [0.865594983100891, 0.333687007427216],\n [0.614073991775513, 0.883246004581451],\n [0.508952975273132, 0.579437971115112],\n [0.617941975593567, 0.508316040039062],\n [0.825608015060425, 0.397674977779388],\n [0.681214988231659, 0.39623498916626],\n [0.656635999679565, 0.400596976280212],\n [0.603900015354156, 0.710216999053955],\n [0.81208598613739, 0.588539004325867],\n [0.56801301240921, 0.944564998149872],\n [0.681007981300354, 0.898285031318665],\n [0.733752012252808, 0.869701027870178],\n [0.633830010890961, 0.398822009563446],\n [0.606792986392975, 0.39553701877594],\n [0.589659988880157, 0.391062021255493],\n [0.805015981197357, 0.342108011245728],\n [0.611334979534149, 0.362284004688263],\n [0.634037971496582, 0.355970978736877],\n [0.656635999679565, 0.355356991291046],\n [0.681214988231659, 0.35834002494812],\n [0.698584973812103, 0.363156020641327],\n [0.941866993904114, 0.319076001644135],\n [0.698584973812103, 0.387449026107788],\n [0.584177017211914, 0.624107003211975],\n [0.554318010807037, 0.566076993942261],\n [0.534153997898102, 0.62064003944397],\n [0.711217999458313, 0.819975018501282],\n [0.664629995822906, 0.852871000766754],\n [0.559099972248077, 0.902631998062134],\n [0.871706008911133, 0.791940987110138],\n [0.591234028339386, 0.373893976211548],\n [0.544341027736664, 0.451583981513977],\n [0.624562978744507, 0.924192011356354],\n [0.88577002286911, 0.615028977394104],\n [0.551338016986847, 0.695277988910675],\n [0.551980018615723, 0.704632043838501],\n [0.552887976169586, 0.715808033943176],\n [0.555167973041534, 0.730794012546539],\n [0.569944024085999, 0.767035007476807],\n [0.593203008174896, 0.685675978660583],\n [0.599261999130249, 0.681069016456604],\n [0.607599973678589, 0.677703022956848],\n [0.631937980651855, 0.663500010967255],\n [0.752032995223999, 0.601315021514893],\n [0.547226011753082, 0.420395016670227],\n [0.563543975353241, 0.359827995300293],\n [0.583841025829315, 0.368713974952698],\n [0.586614012718201, 0.692366003990173],\n [0.771915018558502, 0.683578014373779],\n [0.531597018241882, 0.352482974529266],\n [0.588370978832245, 0.804440975189209],\n [0.52079701423645, 0.442565023899078],\n [0.567984998226166, 0.493479013442993],\n [0.543282985687256, 0.819254994392395],\n [0.655317008495331, 0.745514988899231],\n [0.621008992195129, 0.574018001556396],\n [0.625559985637665, 0.78031200170517],\n [0.680198013782501, 0.570719003677368],\n [0.64276397228241, 0.604337990283966],\n [0.704662978649139, 0.621529996395111],\n [0.552012026309967, 0.862591981887817],\n [0.589071989059448, 0.508637011051178],\n [0.685944974422455, 0.775357007980347],\n [0.645735025405884, 0.812640011310577],\n [0.675342977046967, 0.703978002071381],\n [0.810858011245728, 0.646304965019226],\n [0.72012197971344, 0.714666962623596],\n [0.866151988506317, 0.682704985141754],\n [0.663187026977539, 0.644596993923187],\n [0.570082008838654, 0.466325998306274],\n [0.544561982154846, 0.548375964164734],\n [0.562758982181549, 0.558784961700439],\n [0.531987011432648, 0.530140042304993],\n [0.585271000862122, 0.335177004337311],\n [0.622952997684479, 0.32277899980545],\n [0.655896008014679, 0.320163011550903],\n [0.687132000923157, 0.322345972061157],\n [0.716481983661652, 0.333200991153717],\n [0.758756995201111, 0.382786989212036],\n [0.897013008594513, 0.468769013881683],\n [0.732392013072968, 0.424547016620636],\n [0.70211398601532, 0.433162987232208],\n [0.66652500629425, 0.433866024017334],\n [0.633504986763, 0.426087975502014],\n [0.603875994682312, 0.416586995124817],\n [0.579657971858978, 0.409945011138916],\n [0.992439985275269, 0.480777025222778],\n [0.567192018032074, 0.569419980049133],\n [0.54136598110199, 0.478899002075195],\n [0.526564002037048, 0.546118021011353],\n [0.523913025856018, 0.563830018043518],\n [0.531529009342194, 0.555056989192963],\n [0.566035985946655, 0.582329034805298],\n [0.51631098985672, 0.563053965568542],\n [0.5174720287323, 0.577877044677734],\n [0.573594987392426, 0.389806985855103],\n [0.560697972774506, 0.395331978797913],\n [0.549755990505219, 0.399751007556915],\n [0.710287988185883, 0.368252992630005],\n [0.723330020904541, 0.363372981548309],\n];\n\nexport const TRI468: Array = [\n 127, 34, 139, 11, 0, 37, 232, 231, 120, 72, 37, 39, 128, 121, 47, 232, 121, 128, 104, 69, 67, 175, 171, 148, 157, 154, 155, 118, 50, 101, 73, 39, 40, 9,\n 151, 108, 48, 115, 131, 194, 204, 211, 74, 40, 185, 80, 42, 183, 40, 92, 186, 230, 229, 118, 202, 212, 214, 83, 18, 17, 76, 61, 146, 160, 29, 30, 56,\n 157, 173, 106, 204, 194, 135, 214, 192, 203, 165, 98, 21, 71, 68, 51, 45, 4, 144, 24, 23, 77, 146, 91, 205, 50, 187, 201, 200, 18, 91, 106, 182, 90, 91,\n 181, 85, 84, 17, 206, 203, 36, 148, 171, 140, 92, 40, 39, 193, 189, 244, 159, 158, 28, 247, 246, 161, 236, 3, 196, 54, 68, 104, 193, 168, 8, 117,\n 228, 31, 189, 193, 55, 98, 97, 99, 126, 47, 100, 166, 79, 218, 155, 154, 26, 209, 49, 131, 135, 136, 150, 47, 126, 217, 223, 52, 53, 45, 51, 134, 211,\n 170, 140, 67, 69, 108, 43, 106, 91, 230, 119, 120, 226, 130, 247, 63, 53, 52, 238, 20, 242, 46, 70, 156, 78, 62, 96, 46, 53, 63, 143, 34, 227, 173,\n 155, 133, 123, 117, 111, 44, 125, 19, 236, 134, 51, 216, 206, 205, 154, 153, 22, 39, 37, 167, 200, 201, 208, 36, 142, 100, 57, 212, 202, 20, 60, 99, 28,\n 158, 157, 35, 226, 113, 160, 159, 27, 204, 202, 210, 113, 225, 46, 43, 202, 204, 62, 76, 77, 137, 123, 116, 41, 38, 72, 203, 129, 142, 64, 98, 240, 49,\n 102, 64, 41, 73, 74, 212, 216, 207, 42, 74, 184, 169, 170, 211, 170, 149, 176, 105, 66, 69, 122, 6, 168, 123, 147, 187, 96, 77, 90, 65, 55, 107, 89,\n 90, 180, 101, 100, 120, 63, 105, 104, 93, 137, 227, 15, 86, 85, 129, 102, 49, 14, 87, 86, 55, 8, 9, 100, 47, 121, 145, 23, 22, 88, 89, 179, 6, 122,\n 196, 88, 95, 96, 138, 172, 136, 215, 58, 172, 115, 48, 219, 42, 80, 81, 195, 3, 51, 43, 146, 61, 171, 175, 199, 81, 82, 38, 53, 46, 225, 144, 163, 110,\n 246, 33, 7, 52, 65, 66, 229, 228, 117, 34, 127, 234, 107, 108, 69, 109, 108, 151, 48, 64, 235, 62, 78, 191, 129, 209, 126, 111, 35, 143, 163, 161, 246,\n 117, 123, 50, 222, 65, 52, 19, 125, 141, 221, 55, 65, 3, 195, 197, 25, 7, 33, 220, 237, 44, 70, 71, 139, 122, 193, 245, 247, 130, 33, 71, 21, 162,\n 153, 158, 159, 170, 169, 150, 188, 174, 196, 216, 186, 92, 144, 160, 161, 2, 97, 167, 141, 125, 241, 164, 167, 37, 72, 38, 12, 145, 159, 160, 38, 82, 13,\n 63, 68, 71, 226, 35, 111, 158, 153, 154, 101, 50, 205, 206, 92, 165, 209, 198, 217, 165, 167, 97, 220, 115, 218, 133, 112, 243, 239, 238, 241, 214,\n 135, 169, 190, 173, 133, 171, 208, 32, 125, 44, 237, 86, 87, 178, 85, 86, 179, 84, 85, 180, 83, 84, 181, 201, 83, 182, 137, 93, 132, 76, 62, 183, 61,\n 76, 184, 57, 61, 185, 212, 57, 186, 214, 207, 187, 34, 143, 156, 79, 239, 237, 123, 137, 177, 44, 1, 4, 201, 194, 32, 64, 102, 129, 213, 215, 138, 59,\n 166, 219, 242, 99, 97, 2, 94, 141, 75, 59, 235, 24, 110, 228, 25, 130, 226, 23, 24, 229, 22, 23, 230, 26, 22, 231, 112, 26, 232, 189, 190, 243, 221, 56,\n 190, 28, 56, 221, 27, 28, 222, 29, 27, 223, 30, 29, 224, 247, 30, 225, 238, 79, 20, 166, 59, 75, 60, 75, 240, 147, 177, 215, 20, 79, 166, 187, 147, 213,\n 112, 233, 244, 233, 128, 245, 128, 114, 188, 114, 217, 174, 131, 115, 220, 217, 198, 236, 198, 131, 134, 177, 132, 58, 143, 35, 124, 110, 163, 7, 228,\n 110, 25, 356, 389, 368, 11, 302, 267, 452, 350, 349, 302, 303, 269, 357, 343, 277, 452, 453, 357, 333, 332, 297, 175, 152, 377, 384, 398, 382, 347,\n 348, 330, 303, 304, 270, 9, 336, 337, 278, 279, 360, 418, 262, 431, 304, 408, 409, 310, 415, 407, 270, 409, 410, 450, 348, 347, 422, 430, 434, 313,\n 314, 17, 306, 307, 375, 387, 388, 260, 286, 414, 398, 335, 406, 418, 364, 367, 416, 423, 358, 327, 251, 284, 298, 281, 5, 4, 373, 374, 253, 307, 320,\n 321, 425, 427, 411, 421, 313, 18, 321, 405, 406, 320, 404, 405, 315, 16, 17, 426, 425, 266, 377, 400, 369, 322, 391, 269, 417, 465, 464, 386, 257, 258,\n 466, 260, 388, 456, 399, 419, 284, 332, 333, 417, 285, 8, 346, 340, 261, 413, 441, 285, 327, 460, 328, 355, 371, 329, 392, 439, 438, 382, 341, 256,\n 429, 420, 360, 364, 394, 379, 277, 343, 437, 443, 444, 283, 275, 440, 363, 431, 262, 369, 297, 338, 337, 273, 375, 321, 450, 451, 349, 446, 342, 467,\n 293, 334, 282, 458, 461, 462, 276, 353, 383, 308, 324, 325, 276, 300, 293, 372, 345, 447, 382, 398, 362, 352, 345, 340, 274, 1, 19, 456, 248, 281, 436,\n 427, 425, 381, 256, 252, 269, 391, 393, 200, 199, 428, 266, 330, 329, 287, 273, 422, 250, 462, 328, 258, 286, 384, 265, 353, 342, 387, 259, 257, 424,\n 431, 430, 342, 353, 276, 273, 335, 424, 292, 325, 307, 366, 447, 345, 271, 303, 302, 423, 266, 371, 294, 455, 460, 279, 278, 294, 271, 272, 304, 432,\n 434, 427, 272, 407, 408, 394, 430, 431, 395, 369, 400, 334, 333, 299, 351, 417, 168, 352, 280, 411, 325, 319, 320, 295, 296, 336, 319, 403, 404, 330,\n 348, 349, 293, 298, 333, 323, 454, 447, 15, 16, 315, 358, 429, 279, 14, 15, 316, 285, 336, 9, 329, 349, 350, 374, 380, 252, 318, 402, 403, 6, 197, 419,\n 318, 319, 325, 367, 364, 365, 435, 367, 397, 344, 438, 439, 272, 271, 311, 195, 5, 281, 273, 287, 291, 396, 428, 199, 311, 271, 268, 283, 444, 445,\n 373, 254, 339, 263, 466, 249, 282, 334, 296, 449, 347, 346, 264, 447, 454, 336, 296, 299, 338, 10, 151, 278, 439, 455, 292, 407, 415, 358, 371, 355,\n 340, 345, 372, 390, 249, 466, 346, 347, 280, 442, 443, 282, 19, 94, 370, 441, 442, 295, 248, 419, 197, 263, 255, 359, 440, 275, 274, 300, 383, 368,\n 351, 412, 465, 263, 467, 466, 301, 368, 389, 380, 374, 386, 395, 378, 379, 412, 351, 419, 436, 426, 322, 373, 390, 388, 2, 164, 393, 370, 462, 461,\n 164, 0, 267, 302, 11, 12, 374, 373, 387, 268, 12, 13, 293, 300, 301, 446, 261, 340, 385, 384, 381, 330, 266, 425, 426, 423, 391, 429, 355, 437, 391,\n 327, 326, 440, 457, 438, 341, 382, 362, 459, 457, 461, 434, 430, 394, 414, 463, 362, 396, 369, 262, 354, 461, 457, 316, 403, 402, 315, 404, 403, 314,\n 405, 404, 313, 406, 405, 421, 418, 406, 366, 401, 361, 306, 408, 407, 291, 409, 408, 287, 410, 409, 432, 436, 410, 434, 416, 411, 264, 368, 383, 309,\n 438, 457, 352, 376, 401, 274, 275, 4, 421, 428, 262, 294, 327, 358, 433, 416, 367, 289, 455, 439, 462, 370, 326, 2, 326, 370, 305, 460, 455, 254,\n 449, 448, 255, 261, 446, 253, 450, 449, 252, 451, 450, 256, 452, 451, 341, 453, 452, 413, 464, 463, 441, 413, 414, 258, 442, 441, 257, 443, 442, 259,\n 444, 443, 260, 445, 444, 467, 342, 445, 459, 458, 250, 289, 392, 290, 290, 328, 460, 376, 433, 435, 250, 290, 392, 411, 416, 433, 341, 463, 464, 453,\n 464, 465, 357, 465, 412, 343, 412, 399, 360, 363, 440, 437, 399, 456, 420, 456, 363, 401, 435, 288, 372, 383, 353, 339, 255, 249, 448, 261, 255, 133,\n 243, 190, 133, 155, 112, 33, 246, 247, 33, 130, 25, 398, 384, 286, 362, 398, 414, 362, 463, 341, 263, 359, 467, 263, 249, 255, 466, 467, 260, 75, 60,\n 166, 238, 239, 79, 162, 127, 139, 72, 11, 37, 121, 232, 120, 73, 72, 39, 114, 128, 47, 233, 232, 128, 103, 104, 67, 152, 175, 148, 173, 157, 155,\n 119, 118, 101, 74, 73, 40, 107, 9, 108, 49, 48, 131, 32, 194, 211, 184, 74, 185, 191, 80, 183, 185, 40, 186, 119, 230, 118, 210, 202, 214, 84, 83, 17,\n 77, 76, 146, 161, 160, 30, 190, 56, 173, 182, 106, 194, 138, 135, 192, 129, 203, 98, 54, 21, 68, 5, 51, 4, 145, 144, 23, 90, 77, 91, 207, 205, 187, 83,\n 201, 18, 181, 91, 182, 180, 90, 181, 16, 85, 17, 205, 206, 36, 176, 148, 140, 165, 92, 39, 245, 193, 244, 27, 159, 28, 30, 247, 161, 174, 236, 196,\n 103, 54, 104, 55, 193, 8, 111, 117, 31, 221, 189, 55, 240, 98, 99, 142, 126, 100, 219, 166, 218, 112, 155, 26, 198, 209, 131, 169, 135, 150, 114, 47,\n 217, 224, 223, 53, 220, 45, 134, 32, 211, 140, 109, 67, 108, 146, 43, 91, 231, 230, 120, 113, 226, 247, 105, 63, 52, 241, 238, 242, 124, 46, 156, 95,\n 78, 96, 70, 46, 63, 116, 143, 227, 116, 123, 111, 1, 44, 19, 3, 236, 51, 207, 216, 205, 26, 154, 22, 165, 39, 167, 199, 200, 208, 101, 36, 100, 43,\n 57, 202, 242, 20, 99, 56, 28, 157, 124, 35, 113, 29, 160, 27, 211, 204, 210, 124, 113, 46, 106, 43, 204, 96, 62, 77, 227, 137, 116, 73, 41, 72, 36, 203,\n 142, 235, 64, 240, 48, 49, 64, 42, 41, 74, 214, 212, 207, 183, 42, 184, 210, 169, 211, 140, 170, 176, 104, 105, 69, 193, 122, 168, 50, 123, 187, 89, 96,\n 90, 66, 65, 107, 179, 89, 180, 119, 101, 120, 68, 63, 104, 234, 93, 227, 16, 15, 85, 209, 129, 49, 15, 14, 86, 107, 55, 9, 120, 100, 121, 153, 145, 22,\n 178, 88, 179, 197, 6, 196, 89, 88, 96, 135, 138, 136, 138, 215, 172, 218, 115, 219, 41, 42, 81, 5, 195, 51, 57, 43, 61, 208, 171, 199, 41, 81, 38,\n 224, 53, 225, 24, 144, 110, 105, 52, 66, 118, 229, 117, 227, 34, 234, 66, 107, 69, 10, 109, 151, 219, 48, 235, 183, 62, 191, 142, 129, 126, 116, 111,\n 143, 7, 163, 246, 118, 117, 50, 223, 222, 52, 94, 19, 141, 222, 221, 65, 196, 3, 197, 45, 220, 44, 156, 70, 139, 188, 122, 245, 139, 71, 162, 145,\n 153, 159, 149, 170, 150, 122, 188, 196, 206, 216, 92, 163, 144, 161, 164, 2, 167, 242, 141, 241, 0, 164, 37, 11, 72, 12, 144, 145, 160, 12, 38, 13, 70,\n 63, 71, 31, 226, 111, 157, 158, 154, 36, 101, 205, 203, 206, 165, 126, 209, 217, 98, 165, 97, 237, 220, 218, 237, 239, 241, 210, 214, 169, 140, 171, 32,\n 241, 125, 237, 179, 86, 178, 180, 85, 179, 181, 84, 180, 182, 83, 181, 194, 201, 182, 177, 137, 132, 184, 76, 183, 185, 61, 184, 186, 57, 185, 216, 212,\n 186, 192, 214, 187, 139, 34, 156, 218, 79, 237, 147, 123, 177, 45, 44, 4, 208, 201, 32, 98, 64, 129, 192, 213, 138, 235, 59, 219, 141, 242, 97, 97, 2,\n 141, 240, 75, 235, 229, 24, 228, 31, 25, 226, 230, 23, 229, 231, 22, 230, 232, 26, 231, 233, 112, 232, 244, 189, 243, 189, 221, 190, 222, 28, 221,\n 223, 27, 222, 224, 29, 223, 225, 30, 224, 113, 247, 225, 99, 60, 240, 213, 147, 215, 60, 20, 166, 192, 187, 213, 243, 112, 244, 244, 233, 245, 245,\n 128, 188, 188, 114, 174, 134, 131, 220, 174, 217, 236, 236, 198, 134, 215, 177, 58, 156, 143, 124, 25, 110, 7, 31, 228, 25, 264, 356, 368, 0, 11, 267,\n 451, 452, 349, 267, 302, 269, 350, 357, 277, 350, 452, 357, 299, 333, 297, 396, 175, 377, 381, 384, 382, 280, 347, 330, 269, 303, 270, 151, 9, 337,\n 344, 278, 360, 424, 418, 431, 270, 304, 409, 272, 310, 407, 322, 270, 410, 449, 450, 347, 432, 422, 434, 18, 313, 17, 291, 306, 375, 259, 387, 260,\n 424, 335, 418, 434, 364, 416, 391, 423, 327, 301, 251, 298, 275, 281, 4, 254, 373, 253, 375, 307, 321, 280, 425, 411, 200, 421, 18, 335, 321, 406,\n 321, 320, 405, 314, 315, 17, 423, 426, 266, 396, 377, 369, 270, 322, 269, 413, 417, 464, 385, 386, 258, 248, 456, 419, 298, 284, 333, 168, 417, 8,\n 448, 346, 261, 417, 413, 285, 326, 327, 328, 277, 355, 329, 309, 392, 438, 381, 382, 256, 279, 429, 360, 365, 364, 379, 355, 277, 437, 282, 443, 283,\n 281, 275, 363, 395, 431, 369, 299, 297, 337, 335, 273, 321, 348, 450, 349, 359, 446, 467, 283, 293, 282, 250, 458, 462, 300, 276, 383, 292, 308, 325,\n 283, 276, 293, 264, 372, 447, 346, 352, 340, 354, 274, 19, 363, 456, 281, 426, 436, 425, 380, 381, 252, 267, 269, 393, 421, 200, 428, 371, 266, 329,\n 432, 287, 422, 290, 250, 328, 385, 258, 384, 446, 265, 342, 386, 387, 257, 422, 424, 430, 445, 342, 276, 422, 273, 424, 306, 292, 307, 352, 366, 345,\n 268, 271, 302, 358, 423, 371, 327, 294, 460, 331, 279, 294, 303, 271, 304, 436, 432, 427, 304, 272, 408, 395, 394, 431, 378, 395, 400, 296, 334, 299,\n 6, 351, 168, 376, 352, 411, 307, 325, 320, 285, 295, 336, 320, 319, 404, 329, 330, 349, 334, 293, 333, 366, 323, 447, 316, 15, 315, 331, 358, 279,\n 317, 14, 316, 8, 285, 9, 277, 329, 350, 253, 374, 252, 319, 318, 403, 351, 6, 419, 324, 318, 325, 397, 367, 365, 288, 435, 397, 278, 344, 439, 310,\n 272, 311, 248, 195, 281, 375, 273, 291, 175, 396, 199, 312, 311, 268, 276, 283, 445, 390, 373, 339, 295, 282, 296, 448, 449, 346, 356, 264, 454, 337,\n 336, 299, 337, 338, 151, 294, 278, 455, 308, 292, 415, 429, 358, 355, 265, 340, 372, 388, 390, 466, 352, 346, 280, 295, 442, 282, 354, 19, 370, 285,\n 441, 295, 195, 248, 197, 457, 440, 274, 301, 300, 368, 417, 351, 465, 251, 301, 389, 385, 380, 386, 394, 395, 379, 399, 412, 419, 410, 436, 322, 387,\n 373, 388, 326, 2, 393, 354, 370, 461, 393, 164, 267, 268, 302, 12, 386, 374, 387, 312, 268, 13, 298, 293, 301, 265, 446, 340, 380, 385, 381, 280, 330,\n 425, 322, 426, 391, 420, 429, 437, 393, 391, 326, 344, 440, 438, 458, 459, 461, 364, 434, 394, 428, 396, 262, 274, 354, 457, 317, 316, 402, 316, 315,\n 403, 315, 314, 404, 314, 313, 405, 313, 421, 406, 323, 366, 361, 292, 306, 407, 306, 291, 408, 291, 287, 409, 287, 432, 410, 427, 434, 411, 372, 264,\n 383, 459, 309, 457, 366, 352, 401, 1, 274, 4, 418, 421, 262, 331, 294, 358, 435, 433, 367, 392, 289, 439, 328, 462, 326, 94, 2, 370, 289, 305, 455, 339,\n 254, 448, 359, 255, 446, 254, 253, 449, 253, 252, 450, 252, 256, 451, 256, 341, 452, 414, 413, 463, 286, 441, 414, 286, 258, 441, 258, 257, 442, 257,\n 259, 443, 259, 260, 444, 260, 467, 445, 309, 459, 250, 305, 289, 290, 305, 290, 460, 401, 376, 435, 309, 250, 392, 376, 411, 433, 453, 341, 464, 357,\n 453, 465, 343, 357, 412, 437, 343, 399, 344, 360, 440, 420, 437, 456, 360, 420, 363, 361, 401, 288, 265, 372, 353, 390, 339, 249, 339, 448, 255];\n\nexport const TRI68: Array = [0, 1, 36, 0, 36, 17, 1, 2, 41, 1, 41, 36, 2, 3, 31, 2, 31, 41, 3, 4, 48, 3, 48, 31, 4, 5, 48, 5, 6, 48, 6, 7, 59, 6, 59, 48, 7, 8, 58, 7, 58, 59,\n 8, 9, 56, 8, 56, 57, 8, 57, 58, 9, 10, 55, 9, 55, 56, 10, 11, 54, 10, 54, 55, 11, 12, 54, 12, 13, 54, 13, 14, 35, 13, 35, 54, 14, 15, 46, 14, 46, 35, 15, 16,\n 45, 15, 45, 46, 16, 26, 45, 17, 36, 18, 18, 37, 19, 18, 36, 37, 19, 38, 20, 19, 37, 38, 20, 39, 21, 20, 38, 39, 21, 39, 27, 22, 42, 23, 22, 27, 42, 23, 43, 24,\n 23, 42, 43, 24, 44, 25, 24, 43, 44, 25, 45, 26, 25, 44, 45, 27, 39, 28, 27, 28, 42, 28, 39, 29, 28, 29, 42, 29, 31, 30, 29, 30, 35, 29, 40, 31, 29, 35, 47, 29,\n 39, 40, 29, 47, 42, 30, 31, 32, 30, 32, 33, 30, 33, 34, 30, 34, 35, 31, 50, 32, 31, 40, 41, 31, 48, 49, 31, 49, 50, 32, 51, 33, 32, 50, 51, 33, 51, 34, 34, 52,\n 35, 34, 51, 52, 35, 46, 47, 35, 52, 53, 35, 53, 54, 36, 41, 37, 37, 40, 38, 37, 41, 40, 38, 40, 39, 42, 47, 43, 43, 47, 44, 44, 46, 45, 44, 47, 46, 48, 60, 49,\n 48, 59, 60, 49, 61, 50, 49, 60, 61, 50, 62, 51, 50, 61, 62, 51, 62, 52, 52, 63, 53, 52, 62, 63, 53, 64, 54, 53, 63, 64, 54, 64, 55, 55, 65, 56, 55, 64, 65, 56,\n 66, 57, 56, 65, 66, 57, 66, 58, 58, 67, 59, 58, 66, 67, 59, 67, 60, 60, 67, 61, 61, 66, 62, 61, 67, 66, 62, 66, 63, 63, 65, 64, 63, 66, 65, 21, 27, 22];\n\nexport const TRI33: Array = [\n /* eyes */ 0, 8, 7, 7, 8, 1, 2, 10, 9, 9, 10, 3,\n /* brows */ 17, 0, 18, 18, 0, 7, 18, 7, 19, 19, 7, 1, 19, 1, 11, 19, 11, 20, 21, 3, 22, 21, 9, 3, 20, 9, 21, 20, 2, 9, 20, 11, 2,\n /* 4head */ 23, 17, 18, 25, 21, 22, 24, 19, 20, 24, 18, 19, 24, 20, 21, 24, 23, 18, 24, 21, 25,\n /* nose */ 11, 12, 4, 11, 4, 13, 1, 12, 11, 11, 13, 2, 12, 14, 4, 4, 14, 13,\n /* up-lip */ 14, 5, 15, 14, 15, 6, 12, 5, 14, 14, 6, 13,\n /* cheeks */ 8, 12, 1, 2, 13, 10, 8, 26, 12, 10, 13, 27, 26, 5, 12, 13, 6, 27, 0, 26, 8, 10, 27, 3,\n /* chin */ 5, 32, 16, 16, 32, 6, 5, 30, 32, 6, 32, 31,\n /* cont */ 26, 30, 5, 27, 6, 31, 0, 28, 26, 3, 27, 29, 17, 28, 0, 3, 29, 22, 23, 28, 17, 22, 29, 25, 28, 30, 26, 27, 31, 29,\n];\n\nexport const TRI7: Array = [0, 4, 1, 2, 4, 3, 4, 5, 6];\n\nexport const VTX68: Array = [\n /* cont */ 127, 234, 132, 58, 172, 150, 149, 148, 152, 377, 378, 379, 397, 288, 361, 454, 356,\n /* brows */ 70, 63, 105, 66, 107, 336, 296, 334, 293, 300,\n /* nose */ 168, 6, 195, 4, 98, 97, 2, 326, 327,\n /* eyes */ 33, 160, 158, 133, 153, 144, 362, 385, 387, 263, 373, 380,\n /* lip */ 57, 40, 37, 0, 267, 270, 287, 321, 314, 17, 84, 91,\n /* mouth */ 78, 81, 13, 311, 308, 402, 14, 178,\n];\n\nexport const VTX33: Array = [33, 133, 362, 263, 1, 62, 308, 159, 145, 386, 374, 6, 102, 331, 2, 13, 14, 70, 105, 107, 336, 334, 300, 54, 10, 284, 50, 280, 234, 454, 58, 288, 152];\n\nexport const VTX7: Array = [33, 133, 362, 263, 1, 78, 308];\n\nexport const UV68 = VTX68.map((x) => UV468[x]);\n\nexport const UV33 = VTX33.map((x) => UV468[x]);\n\nexport const UV7 = VTX7.map((x) => UV468[x]);\n\n// https://github.com/tensorflow/tfjs-models/blob/master/face-landmarks-detection/src/constants.ts\n// https://github.com/google/mediapipe/mediapipe/python/solutions/face_mesh_connections.py\n\ntype PairArray = Array<[number, number]>;\n\nfunction connectionsToIndices(connections: PairArray) {\n const indices = connections.map((connection) => connection[0]);\n indices.push(connections[connections.length - 1][1]);\n return indices;\n}\n\nexport const pairsLips: PairArray = [\n [61, 146], [146, 91], [91, 181], [181, 84], [84, 17], [17, 314], [314, 405], [405, 321], [321, 375], [375, 291], [61, 185], [185, 40], [40, 39], [39, 37], [37, 0], [0, 267], [267, 269], [269, 270], [270, 409], [409, 291],\n [78, 95], [95, 88], [88, 178], [178, 87], [87, 14], [14, 317], [317, 402], [402, 318], [318, 324], [324, 308], [78, 191], [191, 80], [80, 81], [81, 82], [82, 13], [13, 312], [312, 311], [311, 310], [310, 415], [415, 308],\n];\n\nexport const pairsLeftEye: PairArray = [[263, 249], [249, 390], [390, 373], [373, 374], [374, 380], [380, 381], [381, 382], [382, 362], [263, 466], [466, 388], [388, 387], [387, 386], [386, 385], [385, 384], [384, 398], [398, 362]];\n\nexport const pairsLeftEyebrow: PairArray = [[276, 283], [283, 282], [282, 295], [295, 285], [300, 293], [293, 334], [334, 296], [296, 336]];\n\nexport const pairsLeftIris: PairArray = [[474, 475], [475, 476], [476, 477], [477, 474]];\n\nexport const pairsRightEye: PairArray = [[33, 7], [7, 163], [163, 144], [144, 145], [145, 153], [153, 154], [154, 155], [155, 133], [33, 246], [246, 161], [161, 160], [160, 159], [159, 158], [158, 157], [157, 173], [173, 133]];\n\nexport const pairsRightEyebrow: PairArray = [[46, 53], [53, 52], [52, 65], [65, 55], [70, 63], [63, 105], [105, 66], [66, 107]];\n\nexport const pairsRightIris: PairArray = [[469, 470], [470, 471], [471, 472], [472, 469]];\n\nexport const pairsFaceContour: PairArray = [\n [10, 338], [338, 297], [297, 332], [332, 284], [284, 251], [251, 389],\n [389, 356], [356, 454], [454, 323], [323, 361], [361, 288], [288, 397],\n [397, 365], [365, 379], [379, 378], [378, 400], [400, 377], [377, 152],\n [152, 148], [148, 176], [176, 149], [149, 150], [150, 136], [136, 172],\n [172, 58], [58, 132], [132, 93], [93, 234], [234, 127], [127, 162],\n [162, 21], [21, 54], [54, 103], [103, 67], [67, 109], [109, 10],\n];\n\nexport const contourKeypoints = {\n lips: connectionsToIndices(pairsLips),\n leftEye: connectionsToIndices(pairsLeftEye),\n leftEyebrow: connectionsToIndices(pairsLeftEyebrow),\n leftIris: connectionsToIndices(pairsLeftIris),\n rightEye: connectionsToIndices(pairsRightEye),\n rightEyebrow: connectionsToIndices(pairsRightEyebrow),\n rightIris: connectionsToIndices(pairsRightIris),\n faceOval: connectionsToIndices(pairsFaceContour),\n};\n\nexport const pairsFaceMesh: PairArray = [\n [127, 34], [34, 139], [139, 127], [11, 0], [0, 37], [37, 11],\n [232, 231], [231, 120], [120, 232], [72, 37], [37, 39], [39, 72],\n [128, 121], [121, 47], [47, 128], [232, 121], [121, 128], [128, 232],\n [104, 69], [69, 67], [67, 104], [175, 171], [171, 148], [148, 175],\n [118, 50], [50, 101], [101, 118], [73, 39], [39, 40], [40, 73],\n [9, 151], [151, 108], [108, 9], [48, 115], [115, 131], [131, 48],\n [194, 204], [204, 211], [211, 194], [74, 40], [40, 185], [185, 74],\n [80, 42], [42, 183], [183, 80], [40, 92], [92, 186], [186, 40],\n [230, 229], [229, 118], [118, 230], [202, 212], [212, 214], [214, 202],\n [83, 18], [18, 17], [17, 83], [76, 61], [61, 146], [146, 76],\n [160, 29], [29, 30], [30, 160], [56, 157], [157, 173], [173, 56],\n [106, 204], [204, 194], [194, 106], [135, 214], [214, 192], [192, 135],\n [203, 165], [165, 98], [98, 203], [21, 71], [71, 68], [68, 21],\n [51, 45], [45, 4], [4, 51], [144, 24], [24, 23], [23, 144],\n [77, 146], [146, 91], [91, 77], [205, 50], [50, 187], [187, 205],\n [201, 200], [200, 18], [18, 201], [91, 106], [106, 182], [182, 91],\n [90, 91], [91, 181], [181, 90], [85, 84], [84, 17], [17, 85],\n [206, 203], [203, 36], [36, 206], [148, 171], [171, 140], [140, 148],\n [92, 40], [40, 39], [39, 92], [193, 189], [189, 244], [244, 193],\n [159, 158], [158, 28], [28, 159], [247, 246], [246, 161], [161, 247],\n [236, 3], [3, 196], [196, 236], [54, 68], [68, 104], [104, 54],\n [193, 168], [168, 8], [8, 193], [117, 228], [228, 31], [31, 117],\n [189, 193], [193, 55], [55, 189], [98, 97], [97, 99], [99, 98],\n [126, 47], [47, 100], [100, 126], [166, 79], [79, 218], [218, 166],\n [155, 154], [154, 26], [26, 155], [209, 49], [49, 131], [131, 209],\n [135, 136], [136, 150], [150, 135], [47, 126], [126, 217], [217, 47],\n [223, 52], [52, 53], [53, 223], [45, 51], [51, 134], [134, 45],\n [211, 170], [170, 140], [140, 211], [67, 69], [69, 108], [108, 67],\n [43, 106], [106, 91], [91, 43], [230, 119], [119, 120], [120, 230],\n [226, 130], [130, 247], [247, 226], [63, 53], [53, 52], [52, 63],\n [238, 20], [20, 242], [242, 238], [46, 70], [70, 156], [156, 46],\n [78, 62], [62, 96], [96, 78], [46, 53], [53, 63], [63, 46],\n [143, 34], [34, 227], [227, 143], [123, 117], [117, 111], [111, 123],\n [44, 125], [125, 19], [19, 44], [236, 134], [134, 51], [51, 236],\n [216, 206], [206, 205], [205, 216], [154, 153], [153, 22], [22, 154],\n [39, 37], [37, 167], [167, 39], [200, 201], [201, 208], [208, 200],\n [36, 142], [142, 100], [100, 36], [57, 212], [212, 202], [202, 57],\n [20, 60], [60, 99], [99, 20], [28, 158], [158, 157], [157, 28],\n [35, 226], [226, 113], [113, 35], [160, 159], [159, 27], [27, 160],\n [204, 202], [202, 210], [210, 204], [113, 225], [225, 46], [46, 113],\n [43, 202], [202, 204], [204, 43], [62, 76], [76, 77], [77, 62],\n [137, 123], [123, 116], [116, 137], [41, 38], [38, 72], [72, 41],\n [203, 129], [129, 142], [142, 203], [64, 98], [98, 240], [240, 64],\n [49, 102], [102, 64], [64, 49], [41, 73], [73, 74], [74, 41],\n [212, 216], [216, 207], [207, 212], [42, 74], [74, 184], [184, 42],\n [169, 170], [170, 211], [211, 169], [170, 149], [149, 176], [176, 170],\n [105, 66], [66, 69], [69, 105], [122, 6], [6, 168], [168, 122],\n [123, 147], [147, 187], [187, 123], [96, 77], [77, 90], [90, 96],\n [65, 55], [55, 107], [107, 65], [89, 90], [90, 180], [180, 89],\n [101, 100], [100, 120], [120, 101], [63, 105], [105, 104], [104, 63],\n [93, 137], [137, 227], [227, 93], [15, 86], [86, 85], [85, 15],\n [129, 102], [102, 49], [49, 129], [14, 87], [87, 86], [86, 14],\n [55, 8], [8, 9], [9, 55], [100, 47], [47, 121], [121, 100],\n [145, 23], [23, 22], [22, 145], [88, 89], [89, 179], [179, 88],\n [6, 122], [122, 196], [196, 6], [88, 95], [95, 96], [96, 88],\n [138, 172], [172, 136], [136, 138], [215, 58], [58, 172], [172, 215],\n [115, 48], [48, 219], [219, 115], [42, 80], [80, 81], [81, 42],\n [195, 3], [3, 51], [51, 195], [43, 146], [146, 61], [61, 43],\n [171, 175], [175, 199], [199, 171], [81, 82], [82, 38], [38, 81],\n [53, 46], [46, 225], [225, 53], [144, 163], [163, 110], [110, 144],\n [52, 65], [65, 66], [66, 52], [229, 228], [228, 117], [117, 229],\n [34, 127], [127, 234], [234, 34], [107, 108], [108, 69], [69, 107],\n [109, 108], [108, 151], [151, 109], [48, 64], [64, 235], [235, 48],\n [62, 78], [78, 191], [191, 62], [129, 209], [209, 126], [126, 129],\n [111, 35], [35, 143], [143, 111], [117, 123], [123, 50], [50, 117],\n [222, 65], [65, 52], [52, 222], [19, 125], [125, 141], [141, 19],\n [221, 55], [55, 65], [65, 221], [3, 195], [195, 197], [197, 3],\n [25, 7], [7, 33], [33, 25], [220, 237], [237, 44], [44, 220],\n [70, 71], [71, 139], [139, 70], [122, 193], [193, 245], [245, 122],\n [247, 130], [130, 33], [33, 247], [71, 21], [21, 162], [162, 71],\n [170, 169], [169, 150], [150, 170], [188, 174], [174, 196], [196, 188],\n [216, 186], [186, 92], [92, 216], [2, 97], [97, 167], [167, 2],\n [141, 125], [125, 241], [241, 141], [164, 167], [167, 37], [37, 164],\n [72, 38], [38, 12], [12, 72], [38, 82], [82, 13], [13, 38],\n [63, 68], [68, 71], [71, 63], [226, 35], [35, 111], [111, 226],\n [101, 50], [50, 205], [205, 101], [206, 92], [92, 165], [165, 206],\n [209, 198], [198, 217], [217, 209], [165, 167], [167, 97], [97, 165],\n [220, 115], [115, 218], [218, 220], [133, 112], [112, 243], [243, 133],\n [239, 238], [238, 241], [241, 239], [214, 135], [135, 169], [169, 214],\n [190, 173], [173, 133], [133, 190], [171, 208], [208, 32], [32, 171],\n [125, 44], [44, 237], [237, 125], [86, 87], [87, 178], [178, 86],\n [85, 86], [86, 179], [179, 85], [84, 85], [85, 180], [180, 84],\n [83, 84], [84, 181], [181, 83], [201, 83], [83, 182], [182, 201],\n [137, 93], [93, 132], [132, 137], [76, 62], [62, 183], [183, 76],\n [61, 76], [76, 184], [184, 61], [57, 61], [61, 185], [185, 57],\n [212, 57], [57, 186], [186, 212], [214, 207], [207, 187], [187, 214],\n [34, 143], [143, 156], [156, 34], [79, 239], [239, 237], [237, 79],\n [123, 137], [137, 177], [177, 123], [44, 1], [1, 4], [4, 44],\n [201, 194], [194, 32], [32, 201], [64, 102], [102, 129], [129, 64],\n [213, 215], [215, 138], [138, 213], [59, 166], [166, 219], [219, 59],\n [242, 99], [99, 97], [97, 242], [2, 94], [94, 141], [141, 2],\n [75, 59], [59, 235], [235, 75], [24, 110], [110, 228], [228, 24],\n [25, 130], [130, 226], [226, 25], [23, 24], [24, 229], [229, 23],\n [22, 23], [23, 230], [230, 22], [26, 22], [22, 231], [231, 26],\n [112, 26], [26, 232], [232, 112], [189, 190], [190, 243], [243, 189],\n [221, 56], [56, 190], [190, 221], [28, 56], [56, 221], [221, 28],\n [27, 28], [28, 222], [222, 27], [29, 27], [27, 223], [223, 29],\n [30, 29], [29, 224], [224, 30], [247, 30], [30, 225], [225, 247],\n [238, 79], [79, 20], [20, 238], [166, 59], [59, 75], [75, 166],\n [60, 75], [75, 240], [240, 60], [147, 177], [177, 215], [215, 147],\n [20, 79], [79, 166], [166, 20], [187, 147], [147, 213], [213, 187],\n [112, 233], [233, 244], [244, 112], [233, 128], [128, 245], [245, 233],\n [128, 114], [114, 188], [188, 128], [114, 217], [217, 174], [174, 114],\n [131, 115], [115, 220], [220, 131], [217, 198], [198, 236], [236, 217],\n [198, 131], [131, 134], [134, 198], [177, 132], [132, 58], [58, 177],\n [143, 35], [35, 124], [124, 143], [110, 163], [163, 7], [7, 110],\n [228, 110], [110, 25], [25, 228], [356, 389], [389, 368], [368, 356],\n [11, 302], [302, 267], [267, 11], [452, 350], [350, 349], [349, 452],\n [302, 303], [303, 269], [269, 302], [357, 343], [343, 277], [277, 357],\n [452, 453], [453, 357], [357, 452], [333, 332], [332, 297], [297, 333],\n [175, 152], [152, 377], [377, 175], [347, 348], [348, 330], [330, 347],\n [303, 304], [304, 270], [270, 303], [9, 336], [336, 337], [337, 9],\n [278, 279], [279, 360], [360, 278], [418, 262], [262, 431], [431, 418],\n [304, 408], [408, 409], [409, 304], [310, 415], [415, 407], [407, 310],\n [270, 409], [409, 410], [410, 270], [450, 348], [348, 347], [347, 450],\n [422, 430], [430, 434], [434, 422], [313, 314], [314, 17], [17, 313],\n [306, 307], [307, 375], [375, 306], [387, 388], [388, 260], [260, 387],\n [286, 414], [414, 398], [398, 286], [335, 406], [406, 418], [418, 335],\n [364, 367], [367, 416], [416, 364], [423, 358], [358, 327], [327, 423],\n [251, 284], [284, 298], [298, 251], [281, 5], [5, 4], [4, 281],\n [373, 374], [374, 253], [253, 373], [307, 320], [320, 321], [321, 307],\n [425, 427], [427, 411], [411, 425], [421, 313], [313, 18], [18, 421],\n [321, 405], [405, 406], [406, 321], [320, 404], [404, 405], [405, 320],\n [315, 16], [16, 17], [17, 315], [426, 425], [425, 266], [266, 426],\n [377, 400], [400, 369], [369, 377], [322, 391], [391, 269], [269, 322],\n [417, 465], [465, 464], [464, 417], [386, 257], [257, 258], [258, 386],\n [466, 260], [260, 388], [388, 466], [456, 399], [399, 419], [419, 456],\n [284, 332], [332, 333], [333, 284], [417, 285], [285, 8], [8, 417],\n [346, 340], [340, 261], [261, 346], [413, 441], [441, 285], [285, 413],\n [327, 460], [460, 328], [328, 327], [355, 371], [371, 329], [329, 355],\n [392, 439], [439, 438], [438, 392], [382, 341], [341, 256], [256, 382],\n [429, 420], [420, 360], [360, 429], [364, 394], [394, 379], [379, 364],\n [277, 343], [343, 437], [437, 277], [443, 444], [444, 283], [283, 443],\n [275, 440], [440, 363], [363, 275], [431, 262], [262, 369], [369, 431],\n [297, 338], [338, 337], [337, 297], [273, 375], [375, 321], [321, 273],\n [450, 451], [451, 349], [349, 450], [446, 342], [342, 467], [467, 446],\n [293, 334], [334, 282], [282, 293], [458, 461], [461, 462], [462, 458],\n [276, 353], [353, 383], [383, 276], [308, 324], [324, 325], [325, 308],\n [276, 300], [300, 293], [293, 276], [372, 345], [345, 447], [447, 372],\n [352, 345], [345, 340], [340, 352], [274, 1], [1, 19], [19, 274],\n [456, 248], [248, 281], [281, 456], [436, 427], [427, 425], [425, 436],\n [381, 256], [256, 252], [252, 381], [269, 391], [391, 393], [393, 269],\n [200, 199], [199, 428], [428, 200], [266, 330], [330, 329], [329, 266],\n [287, 273], [273, 422], [422, 287], [250, 462], [462, 328], [328, 250],\n [258, 286], [286, 384], [384, 258], [265, 353], [353, 342], [342, 265],\n [387, 259], [259, 257], [257, 387], [424, 431], [431, 430], [430, 424],\n [342, 353], [353, 276], [276, 342], [273, 335], [335, 424], [424, 273],\n [292, 325], [325, 307], [307, 292], [366, 447], [447, 345], [345, 366],\n [271, 303], [303, 302], [302, 271], [423, 266], [266, 371], [371, 423],\n [294, 455], [455, 460], [460, 294], [279, 278], [278, 294], [294, 279],\n [271, 272], [272, 304], [304, 271], [432, 434], [434, 427], [427, 432],\n [272, 407], [407, 408], [408, 272], [394, 430], [430, 431], [431, 394],\n [395, 369], [369, 400], [400, 395], [334, 333], [333, 299], [299, 334],\n [351, 417], [417, 168], [168, 351], [352, 280], [280, 411], [411, 352],\n [325, 319], [319, 320], [320, 325], [295, 296], [296, 336], [336, 295],\n [319, 403], [403, 404], [404, 319], [330, 348], [348, 349], [349, 330],\n [293, 298], [298, 333], [333, 293], [323, 454], [454, 447], [447, 323],\n [15, 16], [16, 315], [315, 15], [358, 429], [429, 279], [279, 358],\n [14, 15], [15, 316], [316, 14], [285, 336], [336, 9], [9, 285],\n [329, 349], [349, 350], [350, 329], [374, 380], [380, 252], [252, 374],\n [318, 402], [402, 403], [403, 318], [6, 197], [197, 419], [419, 6],\n [318, 319], [319, 325], [325, 318], [367, 364], [364, 365], [365, 367],\n [435, 367], [367, 397], [397, 435], [344, 438], [438, 439], [439, 344],\n [272, 271], [271, 311], [311, 272], [195, 5], [5, 281], [281, 195],\n [273, 287], [287, 291], [291, 273], [396, 428], [428, 199], [199, 396],\n [311, 271], [271, 268], [268, 311], [283, 444], [444, 445], [445, 283],\n [373, 254], [254, 339], [339, 373], [282, 334], [334, 296], [296, 282],\n [449, 347], [347, 346], [346, 449], [264, 447], [447, 454], [454, 264],\n [336, 296], [296, 299], [299, 336], [338, 10], [10, 151], [151, 338],\n [278, 439], [439, 455], [455, 278], [292, 407], [407, 415], [415, 292],\n [358, 371], [371, 355], [355, 358], [340, 345], [345, 372], [372, 340],\n [346, 347], [347, 280], [280, 346], [442, 443], [443, 282], [282, 442],\n [19, 94], [94, 370], [370, 19], [441, 442], [442, 295], [295, 441],\n [248, 419], [419, 197], [197, 248], [263, 255], [255, 359], [359, 263],\n [440, 275], [275, 274], [274, 440], [300, 383], [383, 368], [368, 300],\n [351, 412], [412, 465], [465, 351], [263, 467], [467, 466], [466, 263],\n [301, 368], [368, 389], [389, 301], [395, 378], [378, 379], [379, 395],\n [412, 351], [351, 419], [419, 412], [436, 426], [426, 322], [322, 436],\n [2, 164], [164, 393], [393, 2], [370, 462], [462, 461], [461, 370],\n [164, 0], [0, 267], [267, 164], [302, 11], [11, 12], [12, 302],\n [268, 12], [12, 13], [13, 268], [293, 300], [300, 301], [301, 293],\n [446, 261], [261, 340], [340, 446], [330, 266], [266, 425], [425, 330],\n [426, 423], [423, 391], [391, 426], [429, 355], [355, 437], [437, 429],\n [391, 327], [327, 326], [326, 391], [440, 457], [457, 438], [438, 440],\n [341, 382], [382, 362], [362, 341], [459, 457], [457, 461], [461, 459],\n [434, 430], [430, 394], [394, 434], [414, 463], [463, 362], [362, 414],\n [396, 369], [369, 262], [262, 396], [354, 461], [461, 457], [457, 354],\n [316, 403], [403, 402], [402, 316], [315, 404], [404, 403], [403, 315],\n [314, 405], [405, 404], [404, 314], [313, 406], [406, 405], [405, 313],\n [421, 418], [418, 406], [406, 421], [366, 401], [401, 361], [361, 366],\n [306, 408], [408, 407], [407, 306], [291, 409], [409, 408], [408, 291],\n [287, 410], [410, 409], [409, 287], [432, 436], [436, 410], [410, 432],\n [434, 416], [416, 411], [411, 434], [264, 368], [368, 383], [383, 264],\n [309, 438], [438, 457], [457, 309], [352, 376], [376, 401], [401, 352],\n [274, 275], [275, 4], [4, 274], [421, 428], [428, 262], [262, 421],\n [294, 327], [327, 358], [358, 294], [433, 416], [416, 367], [367, 433],\n [289, 455], [455, 439], [439, 289], [462, 370], [370, 326], [326, 462],\n [2, 326], [326, 370], [370, 2], [305, 460], [460, 455], [455, 305],\n [254, 449], [449, 448], [448, 254], [255, 261], [261, 446], [446, 255],\n [253, 450], [450, 449], [449, 253], [252, 451], [451, 450], [450, 252],\n [256, 452], [452, 451], [451, 256], [341, 453], [453, 452], [452, 341],\n [413, 464], [464, 463], [463, 413], [441, 413], [413, 414], [414, 441],\n [258, 442], [442, 441], [441, 258], [257, 443], [443, 442], [442, 257],\n [259, 444], [444, 443], [443, 259], [260, 445], [445, 444], [444, 260],\n [467, 342], [342, 445], [445, 467], [459, 458], [458, 250], [250, 459],\n [289, 392], [392, 290], [290, 289], [290, 328], [328, 460], [460, 290],\n [376, 433], [433, 435], [435, 376], [250, 290], [290, 392], [392, 250],\n [411, 416], [416, 433], [433, 411], [341, 463], [463, 464], [464, 341],\n [453, 464], [464, 465], [465, 453], [357, 465], [465, 412], [412, 357],\n [343, 412], [412, 399], [399, 343], [360, 363], [363, 440], [440, 360],\n [437, 399], [399, 456], [456, 437], [420, 456], [456, 363], [363, 420],\n [401, 435], [435, 288], [288, 401], [372, 383], [383, 353], [353, 372],\n [339, 255], [255, 249], [249, 339], [448, 261], [261, 255], [255, 448],\n [133, 243], [243, 190], [190, 133], [133, 155], [155, 112], [112, 133],\n [33, 246], [246, 247], [247, 33], [33, 130], [130, 25], [25, 33],\n [398, 384], [384, 286], [286, 398], [362, 398], [398, 414], [414, 362],\n [362, 463], [463, 341], [341, 362], [263, 359], [359, 467], [467, 263],\n [263, 249], [249, 255], [255, 263], [466, 467], [467, 260], [260, 466],\n [75, 60], [60, 166], [166, 75], [238, 239], [239, 79], [79, 238],\n [162, 127], [127, 139], [139, 162], [72, 11], [11, 37], [37, 72],\n [121, 232], [232, 120], [120, 121], [73, 72], [72, 39], [39, 73],\n [114, 128], [128, 47], [47, 114], [233, 232], [232, 128], [128, 233],\n [103, 104], [104, 67], [67, 103], [152, 175], [175, 148], [148, 152],\n [119, 118], [118, 101], [101, 119], [74, 73], [73, 40], [40, 74],\n [107, 9], [9, 108], [108, 107], [49, 48], [48, 131], [131, 49],\n [32, 194], [194, 211], [211, 32], [184, 74], [74, 185], [185, 184],\n [191, 80], [80, 183], [183, 191], [185, 40], [40, 186], [186, 185],\n [119, 230], [230, 118], [118, 119], [210, 202], [202, 214], [214, 210],\n [84, 83], [83, 17], [17, 84], [77, 76], [76, 146], [146, 77],\n [161, 160], [160, 30], [30, 161], [190, 56], [56, 173], [173, 190],\n [182, 106], [106, 194], [194, 182], [138, 135], [135, 192], [192, 138],\n [129, 203], [203, 98], [98, 129], [54, 21], [21, 68], [68, 54],\n [5, 51], [51, 4], [4, 5], [145, 144], [144, 23], [23, 145],\n [90, 77], [77, 91], [91, 90], [207, 205], [205, 187], [187, 207],\n [83, 201], [201, 18], [18, 83], [181, 91], [91, 182], [182, 181],\n [180, 90], [90, 181], [181, 180], [16, 85], [85, 17], [17, 16],\n [205, 206], [206, 36], [36, 205], [176, 148], [148, 140], [140, 176],\n [165, 92], [92, 39], [39, 165], [245, 193], [193, 244], [244, 245],\n [27, 159], [159, 28], [28, 27], [30, 247], [247, 161], [161, 30],\n [174, 236], [236, 196], [196, 174], [103, 54], [54, 104], [104, 103],\n [55, 193], [193, 8], [8, 55], [111, 117], [117, 31], [31, 111],\n [221, 189], [189, 55], [55, 221], [240, 98], [98, 99], [99, 240],\n [142, 126], [126, 100], [100, 142], [219, 166], [166, 218], [218, 219],\n [112, 155], [155, 26], [26, 112], [198, 209], [209, 131], [131, 198],\n [169, 135], [135, 150], [150, 169], [114, 47], [47, 217], [217, 114],\n [224, 223], [223, 53], [53, 224], [220, 45], [45, 134], [134, 220],\n [32, 211], [211, 140], [140, 32], [109, 67], [67, 108], [108, 109],\n [146, 43], [43, 91], [91, 146], [231, 230], [230, 120], [120, 231],\n [113, 226], [226, 247], [247, 113], [105, 63], [63, 52], [52, 105],\n [241, 238], [238, 242], [242, 241], [124, 46], [46, 156], [156, 124],\n [95, 78], [78, 96], [96, 95], [70, 46], [46, 63], [63, 70],\n [116, 143], [143, 227], [227, 116], [116, 123], [123, 111], [111, 116],\n [1, 44], [44, 19], [19, 1], [3, 236], [236, 51], [51, 3],\n [207, 216], [216, 205], [205, 207], [26, 154], [154, 22], [22, 26],\n [165, 39], [39, 167], [167, 165], [199, 200], [200, 208], [208, 199],\n [101, 36], [36, 100], [100, 101], [43, 57], [57, 202], [202, 43],\n [242, 20], [20, 99], [99, 242], [56, 28], [28, 157], [157, 56],\n [124, 35], [35, 113], [113, 124], [29, 160], [160, 27], [27, 29],\n [211, 204], [204, 210], [210, 211], [124, 113], [113, 46], [46, 124],\n [106, 43], [43, 204], [204, 106], [96, 62], [62, 77], [77, 96],\n [227, 137], [137, 116], [116, 227], [73, 41], [41, 72], [72, 73],\n [36, 203], [203, 142], [142, 36], [235, 64], [64, 240], [240, 235],\n [48, 49], [49, 64], [64, 48], [42, 41], [41, 74], [74, 42],\n [214, 212], [212, 207], [207, 214], [183, 42], [42, 184], [184, 183],\n [210, 169], [169, 211], [211, 210], [140, 170], [170, 176], [176, 140],\n [104, 105], [105, 69], [69, 104], [193, 122], [122, 168], [168, 193],\n [50, 123], [123, 187], [187, 50], [89, 96], [96, 90], [90, 89],\n [66, 65], [65, 107], [107, 66], [179, 89], [89, 180], [180, 179],\n [119, 101], [101, 120], [120, 119], [68, 63], [63, 104], [104, 68],\n [234, 93], [93, 227], [227, 234], [16, 15], [15, 85], [85, 16],\n [209, 129], [129, 49], [49, 209], [15, 14], [14, 86], [86, 15],\n [107, 55], [55, 9], [9, 107], [120, 100], [100, 121], [121, 120],\n [153, 145], [145, 22], [22, 153], [178, 88], [88, 179], [179, 178],\n [197, 6], [6, 196], [196, 197], [89, 88], [88, 96], [96, 89],\n [135, 138], [138, 136], [136, 135], [138, 215], [215, 172], [172, 138],\n [218, 115], [115, 219], [219, 218], [41, 42], [42, 81], [81, 41],\n [5, 195], [195, 51], [51, 5], [57, 43], [43, 61], [61, 57],\n [208, 171], [171, 199], [199, 208], [41, 81], [81, 38], [38, 41],\n [224, 53], [53, 225], [225, 224], [24, 144], [144, 110], [110, 24],\n [105, 52], [52, 66], [66, 105], [118, 229], [229, 117], [117, 118],\n [227, 34], [34, 234], [234, 227], [66, 107], [107, 69], [69, 66],\n [10, 109], [109, 151], [151, 10], [219, 48], [48, 235], [235, 219],\n [183, 62], [62, 191], [191, 183], [142, 129], [129, 126], [126, 142],\n [116, 111], [111, 143], [143, 116], [118, 117], [117, 50], [50, 118],\n [223, 222], [222, 52], [52, 223], [94, 19], [19, 141], [141, 94],\n [222, 221], [221, 65], [65, 222], [196, 3], [3, 197], [197, 196],\n [45, 220], [220, 44], [44, 45], [156, 70], [70, 139], [139, 156],\n [188, 122], [122, 245], [245, 188], [139, 71], [71, 162], [162, 139],\n [149, 170], [170, 150], [150, 149], [122, 188], [188, 196], [196, 122],\n [206, 216], [216, 92], [92, 206], [164, 2], [2, 167], [167, 164],\n [242, 141], [141, 241], [241, 242], [0, 164], [164, 37], [37, 0],\n [11, 72], [72, 12], [12, 11], [12, 38], [38, 13], [13, 12],\n [70, 63], [63, 71], [71, 70], [31, 226], [226, 111], [111, 31],\n [36, 101], [101, 205], [205, 36], [203, 206], [206, 165], [165, 203],\n [126, 209], [209, 217], [217, 126], [98, 165], [165, 97], [97, 98],\n [237, 220], [220, 218], [218, 237], [237, 239], [239, 241], [241, 237],\n [210, 214], [214, 169], [169, 210], [140, 171], [171, 32], [32, 140],\n [241, 125], [125, 237], [237, 241], [179, 86], [86, 178], [178, 179],\n [180, 85], [85, 179], [179, 180], [181, 84], [84, 180], [180, 181],\n [182, 83], [83, 181], [181, 182], [194, 201], [201, 182], [182, 194],\n [177, 137], [137, 132], [132, 177], [184, 76], [76, 183], [183, 184],\n [185, 61], [61, 184], [184, 185], [186, 57], [57, 185], [185, 186],\n [216, 212], [212, 186], [186, 216], [192, 214], [214, 187], [187, 192],\n [139, 34], [34, 156], [156, 139], [218, 79], [79, 237], [237, 218],\n [147, 123], [123, 177], [177, 147], [45, 44], [44, 4], [4, 45],\n [208, 201], [201, 32], [32, 208], [98, 64], [64, 129], [129, 98],\n [192, 213], [213, 138], [138, 192], [235, 59], [59, 219], [219, 235],\n [141, 242], [242, 97], [97, 141], [97, 2], [2, 141], [141, 97],\n [240, 75], [75, 235], [235, 240], [229, 24], [24, 228], [228, 229],\n [31, 25], [25, 226], [226, 31], [230, 23], [23, 229], [229, 230],\n [231, 22], [22, 230], [230, 231], [232, 26], [26, 231], [231, 232],\n [233, 112], [112, 232], [232, 233], [244, 189], [189, 243], [243, 244],\n [189, 221], [221, 190], [190, 189], [222, 28], [28, 221], [221, 222],\n [223, 27], [27, 222], [222, 223], [224, 29], [29, 223], [223, 224],\n [225, 30], [30, 224], [224, 225], [113, 247], [247, 225], [225, 113],\n [99, 60], [60, 240], [240, 99], [213, 147], [147, 215], [215, 213],\n [60, 20], [20, 166], [166, 60], [192, 187], [187, 213], [213, 192],\n [243, 112], [112, 244], [244, 243], [244, 233], [233, 245], [245, 244],\n [245, 128], [128, 188], [188, 245], [188, 114], [114, 174], [174, 188],\n [134, 131], [131, 220], [220, 134], [174, 217], [217, 236], [236, 174],\n [236, 198], [198, 134], [134, 236], [215, 177], [177, 58], [58, 215],\n [156, 143], [143, 124], [124, 156], [25, 110], [110, 7], [7, 25],\n [31, 228], [228, 25], [25, 31], [264, 356], [356, 368], [368, 264],\n [0, 11], [11, 267], [267, 0], [451, 452], [452, 349], [349, 451],\n [267, 302], [302, 269], [269, 267], [350, 357], [357, 277], [277, 350],\n [350, 452], [452, 357], [357, 350], [299, 333], [333, 297], [297, 299],\n [396, 175], [175, 377], [377, 396], [280, 347], [347, 330], [330, 280],\n [269, 303], [303, 270], [270, 269], [151, 9], [9, 337], [337, 151],\n [344, 278], [278, 360], [360, 344], [424, 418], [418, 431], [431, 424],\n [270, 304], [304, 409], [409, 270], [272, 310], [310, 407], [407, 272],\n [322, 270], [270, 410], [410, 322], [449, 450], [450, 347], [347, 449],\n [432, 422], [422, 434], [434, 432], [18, 313], [313, 17], [17, 18],\n [291, 306], [306, 375], [375, 291], [259, 387], [387, 260], [260, 259],\n [424, 335], [335, 418], [418, 424], [434, 364], [364, 416], [416, 434],\n [391, 423], [423, 327], [327, 391], [301, 251], [251, 298], [298, 301],\n [275, 281], [281, 4], [4, 275], [254, 373], [373, 253], [253, 254],\n [375, 307], [307, 321], [321, 375], [280, 425], [425, 411], [411, 280],\n [200, 421], [421, 18], [18, 200], [335, 321], [321, 406], [406, 335],\n [321, 320], [320, 405], [405, 321], [314, 315], [315, 17], [17, 314],\n [423, 426], [426, 266], [266, 423], [396, 377], [377, 369], [369, 396],\n [270, 322], [322, 269], [269, 270], [413, 417], [417, 464], [464, 413],\n [385, 386], [386, 258], [258, 385], [248, 456], [456, 419], [419, 248],\n [298, 284], [284, 333], [333, 298], [168, 417], [417, 8], [8, 168],\n [448, 346], [346, 261], [261, 448], [417, 413], [413, 285], [285, 417],\n [326, 327], [327, 328], [328, 326], [277, 355], [355, 329], [329, 277],\n [309, 392], [392, 438], [438, 309], [381, 382], [382, 256], [256, 381],\n [279, 429], [429, 360], [360, 279], [365, 364], [364, 379], [379, 365],\n [355, 277], [277, 437], [437, 355], [282, 443], [443, 283], [283, 282],\n [281, 275], [275, 363], [363, 281], [395, 431], [431, 369], [369, 395],\n [299, 297], [297, 337], [337, 299], [335, 273], [273, 321], [321, 335],\n [348, 450], [450, 349], [349, 348], [359, 446], [446, 467], [467, 359],\n [283, 293], [293, 282], [282, 283], [250, 458], [458, 462], [462, 250],\n [300, 276], [276, 383], [383, 300], [292, 308], [308, 325], [325, 292],\n [283, 276], [276, 293], [293, 283], [264, 372], [372, 447], [447, 264],\n [346, 352], [352, 340], [340, 346], [354, 274], [274, 19], [19, 354],\n [363, 456], [456, 281], [281, 363], [426, 436], [436, 425], [425, 426],\n [380, 381], [381, 252], [252, 380], [267, 269], [269, 393], [393, 267],\n [421, 200], [200, 428], [428, 421], [371, 266], [266, 329], [329, 371],\n [432, 287], [287, 422], [422, 432], [290, 250], [250, 328], [328, 290],\n [385, 258], [258, 384], [384, 385], [446, 265], [265, 342], [342, 446],\n [386, 387], [387, 257], [257, 386], [422, 424], [424, 430], [430, 422],\n [445, 342], [342, 276], [276, 445], [422, 273], [273, 424], [424, 422],\n [306, 292], [292, 307], [307, 306], [352, 366], [366, 345], [345, 352],\n [268, 271], [271, 302], [302, 268], [358, 423], [423, 371], [371, 358],\n [327, 294], [294, 460], [460, 327], [331, 279], [279, 294], [294, 331],\n [303, 271], [271, 304], [304, 303], [436, 432], [432, 427], [427, 436],\n [304, 272], [272, 408], [408, 304], [395, 394], [394, 431], [431, 395],\n [378, 395], [395, 400], [400, 378], [296, 334], [334, 299], [299, 296],\n [6, 351], [351, 168], [168, 6], [376, 352], [352, 411], [411, 376],\n [307, 325], [325, 320], [320, 307], [285, 295], [295, 336], [336, 285],\n [320, 319], [319, 404], [404, 320], [329, 330], [330, 349], [349, 329],\n [334, 293], [293, 333], [333, 334], [366, 323], [323, 447], [447, 366],\n [316, 15], [15, 315], [315, 316], [331, 358], [358, 279], [279, 331],\n [317, 14], [14, 316], [316, 317], [8, 285], [285, 9], [9, 8],\n [277, 329], [329, 350], [350, 277], [253, 374], [374, 252], [252, 253],\n [319, 318], [318, 403], [403, 319], [351, 6], [6, 419], [419, 351],\n [324, 318], [318, 325], [325, 324], [397, 367], [367, 365], [365, 397],\n [288, 435], [435, 397], [397, 288], [278, 344], [344, 439], [439, 278],\n [310, 272], [272, 311], [311, 310], [248, 195], [195, 281], [281, 248],\n [375, 273], [273, 291], [291, 375], [175, 396], [396, 199], [199, 175],\n [312, 311], [311, 268], [268, 312], [276, 283], [283, 445], [445, 276],\n [390, 373], [373, 339], [339, 390], [295, 282], [282, 296], [296, 295],\n [448, 449], [449, 346], [346, 448], [356, 264], [264, 454], [454, 356],\n [337, 336], [336, 299], [299, 337], [337, 338], [338, 151], [151, 337],\n [294, 278], [278, 455], [455, 294], [308, 292], [292, 415], [415, 308],\n [429, 358], [358, 355], [355, 429], [265, 340], [340, 372], [372, 265],\n [352, 346], [346, 280], [280, 352], [295, 442], [442, 282], [282, 295],\n [354, 19], [19, 370], [370, 354], [285, 441], [441, 295], [295, 285],\n [195, 248], [248, 197], [197, 195], [457, 440], [440, 274], [274, 457],\n [301, 300], [300, 368], [368, 301], [417, 351], [351, 465], [465, 417],\n [251, 301], [301, 389], [389, 251], [394, 395], [395, 379], [379, 394],\n [399, 412], [412, 419], [419, 399], [410, 436], [436, 322], [322, 410],\n [326, 2], [2, 393], [393, 326], [354, 370], [370, 461], [461, 354],\n [393, 164], [164, 267], [267, 393], [268, 302], [302, 12], [12, 268],\n [312, 268], [268, 13], [13, 312], [298, 293], [293, 301], [301, 298],\n [265, 446], [446, 340], [340, 265], [280, 330], [330, 425], [425, 280],\n [322, 426], [426, 391], [391, 322], [420, 429], [429, 437], [437, 420],\n [393, 391], [391, 326], [326, 393], [344, 440], [440, 438], [438, 344],\n [458, 459], [459, 461], [461, 458], [364, 434], [434, 394], [394, 364],\n [428, 396], [396, 262], [262, 428], [274, 354], [354, 457], [457, 274],\n [317, 316], [316, 402], [402, 317], [316, 315], [315, 403], [403, 316],\n [315, 314], [314, 404], [404, 315], [314, 313], [313, 405], [405, 314],\n [313, 421], [421, 406], [406, 313], [323, 366], [366, 361], [361, 323],\n [292, 306], [306, 407], [407, 292], [306, 291], [291, 408], [408, 306],\n [291, 287], [287, 409], [409, 291], [287, 432], [432, 410], [410, 287],\n [427, 434], [434, 411], [411, 427], [372, 264], [264, 383], [383, 372],\n [459, 309], [309, 457], [457, 459], [366, 352], [352, 401], [401, 366],\n [1, 274], [274, 4], [4, 1], [418, 421], [421, 262], [262, 418],\n [331, 294], [294, 358], [358, 331], [435, 433], [433, 367], [367, 435],\n [392, 289], [289, 439], [439, 392], [328, 462], [462, 326], [326, 328],\n [94, 2], [2, 370], [370, 94], [289, 305], [305, 455], [455, 289],\n [339, 254], [254, 448], [448, 339], [359, 255], [255, 446], [446, 359],\n [254, 253], [253, 449], [449, 254], [253, 252], [252, 450], [450, 253],\n [252, 256], [256, 451], [451, 252], [256, 341], [341, 452], [452, 256],\n [414, 413], [413, 463], [463, 414], [286, 441], [441, 414], [414, 286],\n [286, 258], [258, 441], [441, 286], [258, 257], [257, 442], [442, 258],\n [257, 259], [259, 443], [443, 257], [259, 260], [260, 444], [444, 259],\n [260, 467], [467, 445], [445, 260], [309, 459], [459, 250], [250, 309],\n [305, 289], [289, 290], [290, 305], [305, 290], [290, 460], [460, 305],\n [401, 376], [376, 435], [435, 401], [309, 250], [250, 392], [392, 309],\n [376, 411], [411, 433], [433, 376], [453, 341], [341, 464], [464, 453],\n [357, 453], [453, 465], [465, 357], [343, 357], [357, 412], [412, 343],\n [437, 343], [343, 399], [399, 437], [344, 360], [360, 440], [440, 344],\n [420, 437], [437, 456], [456, 420], [360, 420], [420, 363], [363, 360],\n [361, 401], [401, 288], [288, 361], [265, 372], [372, 353], [353, 265],\n [390, 339], [339, 249], [249, 390], [339, 448], [448, 255], [255, 339],\n];\n", "/**\n * BlazeFace, FaceMesh & Iris model implementation\n * See `facemesh.ts` for entry point\n */\n\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as coords from './facemeshcoords';\nimport { constants } from '../tfjs/constants';\nimport type { Box, Point } from '../result';\nimport { env } from '../util/env';\n\nexport const createBox = (startEndTensor) => ({ startPoint: tf.slice(startEndTensor, [0, 0], [-1, 2]), endPoint: tf.slice(startEndTensor, [0, 2], [-1, 2]) });\n\nexport const disposeBox = (t) => tf.dispose([t.startPoint, t.endPoint]);\n\nexport const getBoxSize = (box): [number, number] => [Math.abs(box.endPoint[0] - box.startPoint[0]), Math.abs(box.endPoint[1] - box.startPoint[1])];\n\nexport const getBoxCenter = (box): [number, number, number] => [box.startPoint[0] + (box.endPoint[0] - box.startPoint[0]) / 2, box.startPoint[1] + (box.endPoint[1] - box.startPoint[1]) / 2, 1];\n\nexport const clampBox = (box, input): Box => (box ? [\n Math.trunc(Math.max(0, box.startPoint[0])),\n Math.trunc(Math.max(0, box.startPoint[1])),\n Math.trunc(Math.min((input.shape[2] || 0), box.endPoint[0]) - Math.max(0, box.startPoint[0])),\n Math.trunc(Math.min((input.shape[1] || 0), box.endPoint[1]) - Math.max(0, box.startPoint[1])),\n] : [0, 0, 0, 0]);\n\nexport const getRawBox = (box, input): Box => (box ? [\n box.startPoint[0] / (input.shape[2] || 0),\n box.startPoint[1] / (input.shape[1] || 0),\n (box.endPoint[0] - box.startPoint[0]) / (input.shape[2] || 0),\n (box.endPoint[1] - box.startPoint[1]) / (input.shape[1] || 0),\n] : [0, 0, 0, 0]);\n\nexport const scaleBoxCoordinates = (box, factor) => {\n const startPoint: Point = [box.startPoint[0] * factor[0], box.startPoint[1] * factor[1]];\n const endPoint: Point = [box.endPoint[0] * factor[0], box.endPoint[1] * factor[1]];\n return { startPoint, endPoint, landmarks: box.landmarks, confidence: box.confidence };\n};\n\nexport const cutAndResize = (box, image, cropSize) => {\n const h = image.shape[1];\n const w = image.shape[2];\n const cutBox = [box.startPoint[1] / h, box.startPoint[0] / w, box.endPoint[1] / h, box.endPoint[0] / w];\n const crop = tf.image.cropAndResize(image, [cutBox], [0], cropSize);\n const norm = tf.div(crop, constants.tf255);\n tf.dispose(crop);\n return norm;\n};\n\nexport const enlargeBox = (box, factor) => {\n const center = getBoxCenter(box);\n const size = getBoxSize(box);\n const halfSize: [number, number] = [factor * size[0] / 2, factor * size[1] / 2];\n return { startPoint: [center[0] - halfSize[0], center[1] - halfSize[1]] as Point, endPoint: [center[0] + halfSize[0], center[1] + halfSize[1]] as Point, landmarks: box.landmarks, confidence: box.confidence };\n};\n\nexport const squarifyBox = (box) => {\n const centers = getBoxCenter(box);\n const size = getBoxSize(box);\n const halfSize = Math.max(...size) / 2;\n return { startPoint: [Math.round(centers[0] - halfSize), Math.round(centers[1] - halfSize)] as Point, endPoint: [Math.round(centers[0] + halfSize), Math.round(centers[1] + halfSize)] as Point, landmarks: box.landmarks, confidence: box.confidence };\n};\n\nexport const calculateLandmarksBoundingBox = (landmarks) => {\n const x = landmarks.map((d) => d[0]);\n const y = landmarks.map((d) => d[1]);\n return { startPoint: [Math.min(...x), Math.min(...y)] as Point, endPoint: [Math.max(...x), Math.max(...y)] as Point, landmarks };\n};\n\nexport const fixedRotationMatrix = [[1, 0, 0], [0, 1, 0], [0, 0, 1]];\n\nexport const normalizeRadians = (angle) => angle - 2 * Math.PI * Math.floor((angle + Math.PI) / (2 * Math.PI));\n\nexport const computeRotation = (point1, point2) => normalizeRadians(Math.PI / 2 - Math.atan2(-(point2[1] - point1[1]), point2[0] - point1[0]));\n\nexport const radToDegrees = (rad) => rad * 180 / Math.PI;\n\nexport const buildTranslationMatrix = (x, y) => [[1, 0, x], [0, 1, y], [0, 0, 1]];\n\nexport const dot = (v1: number[], v2: number[]) => {\n let product = 0;\n for (let i = 0; i < v1.length; i++) product += v1[i] * v2[i];\n return product;\n};\n\nexport const getColumnFrom2DArr = (arr, columnIndex) => {\n const column: Array = [];\n for (let i = 0; i < arr.length; i++) column.push(arr[i][columnIndex]);\n return column;\n};\n\nexport const multiplyTransformMatrices = (mat1, mat2) => {\n const product: Array = [];\n const size = mat1.length;\n for (let row = 0; row < size; row++) {\n product.push([]);\n for (let col = 0; col < size; col++) product[row].push(dot(mat1[row], getColumnFrom2DArr(mat2, col)));\n }\n return product;\n};\n\nexport const buildRotationMatrix = (rotation, center) => {\n const cosA = Math.cos(rotation);\n const sinA = Math.sin(rotation);\n const rotationMatrix = [[cosA, -sinA, 0], [sinA, cosA, 0], [0, 0, 1]];\n const translationMatrix = buildTranslationMatrix(center[0], center[1]);\n const translationTimesRotation = multiplyTransformMatrices(translationMatrix, rotationMatrix);\n const negativeTranslationMatrix = buildTranslationMatrix(-center[0], -center[1]);\n return multiplyTransformMatrices(translationTimesRotation, negativeTranslationMatrix);\n};\n\nexport const invertTransformMatrix = (matrix) => {\n const rotationComponent = [[matrix[0][0], matrix[1][0]], [matrix[0][1], matrix[1][1]]];\n const translationComponent = [matrix[0][2], matrix[1][2]];\n const invertedTranslation = [-dot(rotationComponent[0], translationComponent), -dot(rotationComponent[1], translationComponent)];\n return [rotationComponent[0].concat(invertedTranslation[0]), rotationComponent[1].concat(invertedTranslation[1]), [0, 0, 1]];\n};\n\nexport const rotatePoint = (homogeneousCoordinate, rotationMatrix) => [dot(homogeneousCoordinate, rotationMatrix[0]), dot(homogeneousCoordinate, rotationMatrix[1])];\n\nexport const xyDistanceBetweenPoints = (a, b) => Math.sqrt(((a[0] - b[0]) ** 2) + ((a[1] - b[1]) ** 2));\n\nexport function generateAnchors(inputSize) {\n const spec = inputSize === 192\n ? { strides: [4], anchors: [1] } // facemesh-detector\n : { strides: [inputSize / 16, inputSize / 8], anchors: [2, 6] }; // blazeface\n const anchors: Array<[number, number]> = [];\n for (let i = 0; i < spec.strides.length; i++) {\n const stride = spec.strides[i];\n const gridRows = Math.floor((inputSize + stride - 1) / stride);\n const gridCols = Math.floor((inputSize + stride - 1) / stride);\n const anchorsNum = spec.anchors[i];\n for (let gridY = 0; gridY < gridRows; gridY++) {\n const anchorY = stride * (gridY + 0.5);\n for (let gridX = 0; gridX < gridCols; gridX++) {\n const anchorX = stride * (gridX + 0.5);\n for (let n = 0; n < anchorsNum; n++) anchors.push([anchorX, anchorY]);\n }\n }\n }\n return anchors;\n}\n\nexport function transformRawCoords(coordsRaw, box, angle, rotationMatrix, inputSize) {\n const boxSize = getBoxSize(box);\n const coordsScaled = coordsRaw.map((coord) => ([ // scaled around zero-point\n (boxSize[0] / inputSize) * (coord[0] - (inputSize / 2)),\n (boxSize[1] / inputSize) * (coord[1] - (inputSize / 2)),\n (coord[2] || 0),\n ]));\n const largeAngle = angle && (angle !== 0) && (Math.abs(angle) > 0.2);\n const coordsRotationMatrix = largeAngle ? buildRotationMatrix(angle, [0, 0]) : fixedRotationMatrix;\n const coordsRotated = largeAngle ? coordsScaled.map((coord) => ([...rotatePoint(coord, coordsRotationMatrix), coord[2]])) : coordsScaled;\n const inverseRotationMatrix = largeAngle ? invertTransformMatrix(rotationMatrix) : fixedRotationMatrix;\n const boxCenter = getBoxCenter(box);\n const offsets = [dot(boxCenter, inverseRotationMatrix[0]), dot(boxCenter, inverseRotationMatrix[1])];\n return coordsRotated.map((coord) => ([\n Math.trunc(coord[0] + offsets[0]),\n Math.trunc(coord[1] + offsets[1]),\n Math.trunc(coord[2] || 0),\n ]));\n}\n\nexport function correctFaceRotation(rotate, box, input, inputSize) {\n const symmetryLine = (box.landmarks.length >= coords.meshLandmarks.count)\n ? coords.meshLandmarks.symmetryLine\n : coords.blazeFaceLandmarks.symmetryLine;\n let angle = 0; // default\n let rotationMatrix = fixedRotationMatrix; // default\n let face; // default\n\n if (rotate && env.kernels.includes('rotatewithoffset')) { // rotateWithOffset is not defined for tfjs-node\n angle = computeRotation(box.landmarks[symmetryLine[0]], box.landmarks[symmetryLine[1]]);\n const largeAngle = angle && (angle !== 0) && (Math.abs(angle) > 0.2);\n if (largeAngle) { // perform rotation only if angle is sufficiently high\n const center: Point = getBoxCenter(box);\n const centerRaw: Point = [center[0] / input.shape[2], center[1] / input.shape[1]];\n const rotated = tf.image.rotateWithOffset(input, angle, 0, centerRaw);\n rotationMatrix = buildRotationMatrix(-angle, center);\n face = cutAndResize(box, rotated, [inputSize, inputSize]);\n tf.dispose(rotated);\n } else {\n face = cutAndResize(box, input, [inputSize, inputSize]);\n }\n } else {\n face = cutAndResize(box, input, [inputSize, inputSize]);\n }\n return [angle, rotationMatrix, face];\n}\n\nexport const findFaceCenter = (mesh) => {\n const x = mesh.map((m) => m[0]);\n const y = mesh.map((m) => m[1]);\n // weighted center\n /*\n const sum = (arr: number[]) => arr.reduce((prev, curr) => prev + curr, 0);\n return [sum(x) / mesh.length, sum(y) / mesh.length];\n */\n // absolute center\n return [Math.min(...x) + (Math.max(...x) - Math.min(...x)) / 2, Math.min(...y) + (Math.max(...y) - Math.min(...y)) / 2];\n};\n\nexport const calculateFaceBox = (mesh, previousBox) => {\n const center = findFaceCenter(mesh);\n const boxSize = getBoxSize(previousBox);\n const calculatedBox = {\n startPoint: [center[0] - boxSize[0] / 2, center[1] - boxSize[1] / 2] as Point,\n endPoint: [center[0] + boxSize[0] / 2, center[1] + boxSize[1] / 2] as Point,\n };\n return calculatedBox;\n};\n", "/**\n * BlazeFace, FaceMesh & Iris model implementation\n * See `facemesh.ts` for entry point\n */\n\nimport { log } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as util from './facemeshutil';\nimport { loadModel } from '../tfjs/load';\nimport { constants } from '../tfjs/constants';\nimport type { Config } from '../config';\nimport type { Tensor, GraphModel } from '../tfjs/types';\nimport { env } from '../util/env';\nimport type { Point } from '../result';\n\nconst keypointsCount = 6;\nconst faceBoxScaleFactor = 1.4;\nlet model: GraphModel | null;\nlet anchors: Tensor | null = null;\nlet inputSize = 0;\nlet inputSizeT: Tensor | null = null;\n\ntype DetectBox = { startPoint: Point, endPoint: Point, landmarks: Array, confidence: number };\n\nexport const size = () => inputSize;\n\nexport async function load(config: Config): Promise {\n if (env.initial) model = null;\n if (!model) model = await loadModel(config.face.detector?.modelPath);\n else if (config.debug) log('cached model:', model['modelUrl']);\n inputSize = model.inputs[0].shape ? model.inputs[0].shape[2] : 0;\n inputSizeT = tf.scalar(inputSize, 'int32') as Tensor;\n anchors = tf.tensor2d(util.generateAnchors(inputSize)) as Tensor;\n return model;\n}\n\nfunction decodeBounds(boxOutputs: Tensor) {\n const t: Record = {};\n t.boxStarts = tf.slice(boxOutputs, [0, 1], [-1, 2]);\n t.centers = tf.add(t.boxStarts, anchors);\n t.boxSizes = tf.slice(boxOutputs, [0, 3], [-1, 2]);\n t.boxSizesNormalized = tf.div(t.boxSizes, inputSizeT);\n t.centersNormalized = tf.div(t.centers, inputSizeT);\n t.halfBoxSize = tf.div(t.boxSizesNormalized, constants.tf2);\n t.starts = tf.sub(t.centersNormalized, t.halfBoxSize);\n t.ends = tf.add(t.centersNormalized, t.halfBoxSize);\n t.startNormalized = tf.mul(t.starts, inputSizeT);\n t.endNormalized = tf.mul(t.ends, inputSizeT);\n const boxes = tf.concat2d([t.startNormalized, t.endNormalized], 1);\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n return boxes;\n}\n\nexport async function getBoxes(inputImage: Tensor, config: Config) {\n // sanity check on input\n if ((!inputImage) || (inputImage['isDisposedInternal']) || (inputImage.shape.length !== 4) || (inputImage.shape[1] < 1) || (inputImage.shape[2] < 1)) return [];\n const t: Record = {};\n t.resized = tf.image.resizeBilinear(inputImage, [inputSize, inputSize]);\n t.div = tf.div(t.resized, constants.tf127);\n t.normalized = tf.sub(t.div, constants.tf05);\n const res = model?.execute(t.normalized) as Tensor[];\n if (Array.isArray(res) && res.length > 2) { // pinto converted model?\n const sorted = res.sort((a, b) => a.size - b.size);\n t.concat384 = tf.concat([sorted[0], sorted[2]], 2); // dim: 384, 1 + 16\n t.concat512 = tf.concat([sorted[1], sorted[3]], 2); // dim: 512, 1 + 16\n t.concat = tf.concat([t.concat512, t.concat384], 1);\n t.batch = tf.squeeze(t.concat, 0);\n } else if (Array.isArray(res)) { // new facemesh-detection tfhub model\n t.batch = tf.squeeze(res[0]);\n } else { // original blazeface tfhub model\n t.batch = tf.squeeze(res);\n }\n tf.dispose(res);\n t.boxes = decodeBounds(t.batch);\n t.logits = tf.slice(t.batch, [0, 0], [-1, 1]);\n t.sigmoid = tf.sigmoid(t.logits);\n t.scores = tf.squeeze(t.sigmoid);\n t.nms = await tf.image.nonMaxSuppressionAsync(t.boxes, t.scores, (config.face.detector?.maxDetected || 0), (config.face.detector?.iouThreshold || 0), (config.face.detector?.minConfidence || 0));\n const nms = await t.nms.array() as number[];\n const boxes: Array = [];\n const scores = await t.scores.data();\n for (let i = 0; i < nms.length; i++) {\n const confidence = scores[nms[i]];\n if (confidence > (config.face.detector?.minConfidence || 0)) {\n const b: Record = {};\n b.bbox = tf.slice(t.boxes, [nms[i], 0], [1, -1]);\n b.slice = tf.slice(t.batch, [nms[i], keypointsCount - 1], [1, -1]);\n b.squeeze = tf.squeeze(b.slice);\n b.landmarks = tf.reshape(b.squeeze, [keypointsCount, -1]);\n const points = await b.bbox.data();\n const rawBox = {\n startPoint: [points[0], points[1]] as Point,\n endPoint: [points[2], points[3]] as Point,\n landmarks: (await b.landmarks.array()) as Point[],\n confidence,\n };\n const scaledBox = util.scaleBoxCoordinates(rawBox, [(inputImage.shape[2] || 0) / inputSize, (inputImage.shape[1] || 0) / inputSize]);\n const enlargedBox = util.enlargeBox(scaledBox, config.face['scale'] || faceBoxScaleFactor);\n const squaredBox = util.squarifyBox(enlargedBox);\n boxes.push(squaredBox);\n Object.keys(b).forEach((tensor) => tf.dispose(b[tensor]));\n }\n }\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n return boxes;\n}\n", "/* eslint-disable no-multi-spaces */\n\nexport const kpt: Array = [\n 'nose', // 0\n 'leftEyeInside', // 1\n 'leftEye', // 2\n 'leftEyeOutside', // 3\n 'rightEyeInside', // 4\n 'rightEye', // 5\n 'rightEyeOutside', // 6\n 'leftEar', // 7\n 'rightEar', // 8\n 'leftMouth', // 9\n 'rightMouth', // 10\n 'leftShoulder', // 11\n 'rightShoulder', // 12\n 'leftElbow', // 13\n 'rightElbow', // 14\n 'leftWrist', // 15\n 'rightWrist', // 16\n 'leftPinky', // 17\n 'rightPinky', // 18\n 'leftIndex', // 19\n 'rightIndex', // 20\n 'leftThumb', // 21\n 'rightThumb', // 22\n 'leftHip', // 23\n 'rightHip', // 24\n 'leftKnee', // 25\n 'rightKnee', // 26\n 'leftAnkle', // 27\n 'rightAnkle', // 28\n 'leftHeel', // 29\n 'rightHeel', // 30\n 'leftFoot', // 31\n 'rightFoot', // 32\n 'bodyCenter', // 33\n 'bodyTop', // 34\n 'leftPalm', // 35 // z-coord not ok\n 'leftHand', // 36 // similar to wrist but z-coord not ok\n 'rightPalm', // 37 // z-coord not ok\n 'rightHand', // 38 // similar to wrist but z-coord not ok\n];\n\nexport const connected: Record = {\n shoulders: ['leftShoulder', 'rightShoulder'],\n hips: ['rightHip', 'leftHip'],\n mouth: ['leftMouth', 'rightMouth'],\n leftLegUpper: ['leftHip', 'leftKnee'],\n leftLegLower: ['leftKnee', 'leftAnkle'],\n leftFoot: ['leftAnkle', 'leftHeel', 'leftFoot'],\n leftTorso: ['leftShoulder', 'leftHip'],\n leftArmUpper: ['leftShoulder', 'leftElbow'],\n leftArmLower: ['leftElbow', 'leftWrist'],\n leftHand: ['leftWrist', 'leftPalm'],\n leftHandPinky: ['leftPalm', 'leftPinky'],\n leftHandIndex: ['leftPalm', 'leftIndex'],\n leftHandThumb: ['leftPalm', 'leftThumb'],\n leftEyeOutline: ['leftEyeInside', 'leftEyeOutside'],\n rightLegUpper: ['rightHip', 'rightKnee'],\n rightLegLower: ['rightKnee', 'rightAnkle'],\n rightFoot: ['rightAnkle', 'rightHeel', 'rightFoot'],\n rightTorso: ['rightShoulder', 'rightHip'],\n rightArmUpper: ['rightShoulder', 'rightElbow'],\n rightArmLower: ['rightElbow', 'rightWrist'],\n rightHand: ['rightWrist', 'rightPalm'],\n rightHandPinky: ['rightPalm', 'rightPinky'],\n rightHandIndex: ['rightPalm', 'rightIndex'],\n rightHandThumb: ['rightPalm', 'rightThumb'],\n rightEyeOutline: ['rightEyeInside', 'rightEyeOutside'],\n};\n", "import * as tf from '../../dist/tfjs.esm.js';\nimport type { Tensor } from '../tfjs/types';\nimport type { Box } from '../result';\nimport type { Config } from '../config';\n\ninterface DetectedBox { box: Box, boxRaw: Box, score: number }\n\nconst inputSize = 224;\nlet anchorTensor: { x, y };\nconst numLayers = 5;\nconst strides = [8, 16, 32, 32, 32];\n\nexport async function createAnchors() {\n const anchors: Array<{ x: number, y: number }> = [];\n let layerId = 0;\n while (layerId < numLayers) {\n let anchorCount = 0;\n let lastSameStrideLayer = layerId;\n while (lastSameStrideLayer < strides.length && strides[lastSameStrideLayer] === strides[layerId]) {\n anchorCount += 2;\n lastSameStrideLayer++;\n }\n const stride = strides[layerId];\n const featureMapHeight = Math.ceil(inputSize / stride);\n const featureMapWidth = Math.ceil(inputSize / stride);\n for (let y = 0; y < featureMapHeight; ++y) {\n for (let x = 0; x < featureMapWidth; ++x) {\n for (let anchorId = 0; anchorId < anchorCount; ++anchorId) {\n anchors.push({ x: (x + 0.5) / featureMapWidth, y: (y + 0.5) / featureMapHeight });\n }\n }\n }\n layerId = lastSameStrideLayer;\n }\n anchorTensor = { x: tf.tensor1d(anchors.map((a) => a.x)), y: tf.tensor1d(anchors.map((a) => a.y)) };\n}\n\nconst cropFactor = [5.0, 5.0];\nfunction decodeBoxes(boxesTensor, anchor): Tensor {\n return tf.tidy(() => {\n const split = tf.split(boxesTensor, 12, 1); // first 4 are box data [x,y,w,h] and 4 are keypoints data [x,y] for total of 12\n let xCenter = tf.squeeze(split[0]);\n let yCenter = tf.squeeze(split[1]);\n let width = tf.squeeze(split[2]);\n let height = tf.squeeze(split[3]);\n xCenter = tf.add(tf.div(xCenter, inputSize), anchor.x);\n yCenter = tf.add(tf.div(yCenter, inputSize), anchor.y);\n width = tf.mul(tf.div(width, inputSize), cropFactor[0]);\n height = tf.mul(tf.div(height, inputSize), cropFactor[1]);\n const xMin = tf.sub(xCenter, tf.div(width, 2));\n const yMin = tf.sub(yCenter, tf.div(height, 2));\n const boxes = tf.stack([xMin, yMin, width, height], 1);\n return boxes;\n });\n}\n\nexport async function decode(boxesTensor: Tensor, logitsTensor: Tensor, config: Config, outputSize: [number, number]): Promise {\n const t: Record = {};\n t.boxes = decodeBoxes(boxesTensor, anchorTensor);\n t.scores = tf.sigmoid(logitsTensor);\n t.argmax = tf.argMax(t.scores);\n const i = (await t.argmax.data())[0] as number;\n const scores = await t.scores.data();\n const detected: Array<{ box: Box, boxRaw: Box, score: number }> = [];\n const minScore = (config.body['detector'] && config.body['detector']['minConfidence']) ? config.body['detector']['minConfidence'] : 0;\n if (scores[i] >= minScore) {\n const boxes = await t.boxes.array();\n const boxRaw: Box = boxes[i];\n const box: Box = [boxRaw[0] * outputSize[0], boxRaw[1] * outputSize[1], boxRaw[2] * outputSize[0], boxRaw[3] * outputSize[1]];\n // console.log(box);\n detected.push({ box, boxRaw, score: scores[i] });\n }\n /*\n t.nms = await tf.image.nonMaxSuppressionAsync(t.boxes, t.scores, 1, config.body.detector?.minConfidence || 0.1, config.body.detector?.iouThreshold || 0.1);\n const boxes = t.boxes.arraySync();\n const scores = t.scores.dataSync();\n const nms = t.nms.dataSync();\n const detected: Array = [];\n for (const i of Array.from(nms)) {\n const boxRaw: Box = boxes[i];\n const box: Box = [boxRaw[0] * outputSize[0], boxRaw[0] * outputSize[1], boxRaw[3] * outputSize[0], boxRaw[2] * outputSize[1]];\n detected.push({ box, boxRaw, score: scores[i] });\n }\n */\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n return detected;\n}\n", "import type { Point, Box } from '../result';\n\nexport function calc(keypoints: Array, outputSize: [number, number] = [1, 1]) {\n const coords = [keypoints.map((pt) => pt[0]), keypoints.map((pt) => pt[1])]; // all x/y coords\n const min = [Math.min(...coords[0]), Math.min(...coords[1])];\n const max = [Math.max(...coords[0]), Math.max(...coords[1])];\n const box: Box = [min[0], min[1], max[0] - min[0], max[1] - min[1]];\n const boxRaw: Box = [box[0] / outputSize[0], box[1] / outputSize[1], box[2] / outputSize[0], box[3] / outputSize[1]];\n return { box, boxRaw };\n}\n\nexport function square(keypoints: Array, outputSize: [number, number] = [1, 1]) {\n const coords = [keypoints.map((pt) => pt[0]), keypoints.map((pt) => pt[1])]; // all x/y coords\n const min = [Math.min(...coords[0]), Math.min(...coords[1])];\n const max = [Math.max(...coords[0]), Math.max(...coords[1])];\n const center = [(min[0] + max[0]) / 2, (min[1] + max[1]) / 2]; // find center x and y coord of all fingers\n const dist = Math.max(center[0] - min[0], center[1] - min[1], -center[0] + max[0], -center[1] + max[1]); // largest distance from center in any direction\n const box: Box = [Math.trunc(center[0] - dist), Math.trunc(center[1] - dist), Math.trunc(2 * dist), Math.trunc(2 * dist)];\n const boxRaw: Box = [box[0] / outputSize[0], box[1] / outputSize[1], box[2] / outputSize[0], box[3] / outputSize[1]];\n return { box, boxRaw };\n}\n\nexport function scale(box: Box, scaleFact: number) {\n const dist = [box[2] * scaleFact, box[3] * scaleFact];\n const newBox: Box = [\n box[0] - (dist[0] - box[2]) / 2,\n box[1] - (dist[1] - box[3]) / 2,\n dist[0],\n dist[1],\n ];\n return newBox;\n}\n\nexport function crop(box: Box) { // [y1, x1, y2, x2] clamped to 0..1\n const yxBox: Box = [Math.max(0, box[1]), Math.max(0, box[0]), Math.min(1, box[3] + box[1]), Math.min(1, box[2] + box[0])];\n return yxBox;\n}\n", "/**\n * BlazePose model implementation\n */\n\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport { constants } from '../tfjs/constants';\nimport { log, now } from '../util/util';\nimport type { BodyKeypoint, BodyResult, BodyLandmark, Box, Point, BodyAnnotation } from '../result';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport type { Config } from '../config';\nimport * as coords from './blazeposecoords';\nimport * as detect from './blazeposedetector';\nimport * as box from '../util/box';\n\nconst env = { initial: true };\n// const models: [GraphModel | null, GraphModel | null] = [null, null];\nconst models: { detector: GraphModel | null, landmarks: GraphModel | null } = { detector: null, landmarks: null };\nconst inputSize: { detector: [number, number], landmarks: [number, number] } = { detector: [224, 224], landmarks: [256, 256] };\nlet skipped = Number.MAX_SAFE_INTEGER;\nconst outputNodes: { detector: string[], landmarks: string[] } = {\n landmarks: ['ld_3d', 'activation_segmentation', 'activation_heatmap', 'world_3d', 'output_poseflag'],\n detector: [],\n};\n\nlet cache: BodyResult | null = null;\nlet cropBox: Box | undefined;\nlet padding: [number, number][] = [[0, 0], [0, 0], [0, 0], [0, 0]];\nlet lastTime = 0;\n\nconst sigmoid = (x) => (1 - (1 / (1 + Math.exp(x))));\n\nexport async function loadDetect(config: Config): Promise {\n if (env.initial) models.detector = null;\n if (!models.detector && config.body['detector'] && config.body['detector']['modelPath'] || '') {\n models.detector = await loadModel(config.body['detector']['modelPath']);\n const inputs = Object.values(models.detector.modelSignature['inputs']);\n inputSize.detector[0] = Array.isArray(inputs) ? parseInt(inputs[0].tensorShape.dim[1].size) : 0;\n inputSize.detector[1] = Array.isArray(inputs) ? parseInt(inputs[0].tensorShape.dim[2].size) : 0;\n } else if (config.debug && models.detector) log('cached model:', models.detector['modelUrl']);\n await detect.createAnchors();\n return models.detector as GraphModel;\n}\n\nexport async function loadPose(config: Config): Promise {\n if (env.initial) models.landmarks = null;\n if (!models.landmarks) {\n models.landmarks = await loadModel(config.body.modelPath);\n const inputs = Object.values(models.landmarks.modelSignature['inputs']);\n inputSize.landmarks[0] = Array.isArray(inputs) ? parseInt(inputs[0].tensorShape.dim[1].size) : 0;\n inputSize.landmarks[1] = Array.isArray(inputs) ? parseInt(inputs[0].tensorShape.dim[2].size) : 0;\n } else if (config.debug) log('cached model:', models.landmarks['modelUrl']);\n return models.landmarks;\n}\n\nexport async function load(config: Config): Promise<[GraphModel | null, GraphModel | null]> {\n if (!models.detector) await loadDetect(config);\n if (!models.landmarks) await loadPose(config);\n return [models.detector, models.landmarks];\n}\n\nasync function prepareImage(input: Tensor, size: number): Promise {\n const t: Record = {};\n if (!input.shape || !input.shape[1] || !input.shape[2]) return input;\n let final: Tensor;\n if (cropBox) {\n t.cropped = tf.image.cropAndResize(input, [cropBox], [0], [input.shape[1], input.shape[2]]); // if we have cached box use it to crop input\n }\n if (input.shape[1] !== input.shape[2]) { // only pad if width different than height\n const height: [number, number] = [\n input.shape[2] > input.shape[1] ? Math.trunc((input.shape[2] - input.shape[1]) / 2) : 0,\n input.shape[2] > input.shape[1] ? Math.trunc((input.shape[2] - input.shape[1]) / 2) : 0,\n ];\n const width: [number, number] = [\n input.shape[1] > input.shape[2] ? Math.trunc((input.shape[1] - input.shape[2]) / 2) : 0,\n input.shape[1] > input.shape[2] ? Math.trunc((input.shape[1] - input.shape[2]) / 2) : 0,\n ];\n padding = [\n [0, 0], // dont touch batch\n height, // height before&after\n width, // width before&after\n [0, 0], // dont touch rbg\n ];\n t.pad = tf.pad(t.cropped || input, padding); // use cropped box if it exists\n t.resize = tf.image.resizeBilinear(t.pad, [size, size]);\n final = tf.div(t.resize, constants.tf255);\n } else if (input.shape[1] !== size) { // if input needs resizing\n t.resize = tf.image.resizeBilinear(t.cropped || input, [size, size]);\n final = tf.div(t.resize, constants.tf255);\n } else { // if input is already in a correct resolution just normalize it\n final = tf.div(t.cropped || input, constants.tf255);\n }\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n return final;\n}\n\nfunction rescaleKeypoints(keypoints: Array, outputSize: [number, number]): Array {\n for (const kpt of keypoints) { // first rescale due to padding\n kpt.position = [\n Math.trunc(kpt.position[0] * (outputSize[0] + padding[2][0] + padding[2][1]) / outputSize[0] - padding[2][0]),\n Math.trunc(kpt.position[1] * (outputSize[1] + padding[1][0] + padding[1][1]) / outputSize[1] - padding[1][0]),\n kpt.position[2] as number,\n ];\n kpt.positionRaw = [kpt.position[0] / outputSize[0], kpt.position[1] / outputSize[1], 2 * (kpt.position[2] as number) / (outputSize[0] + outputSize[1])];\n }\n if (cropBox) { // second rescale due to cropping\n for (const kpt of keypoints) {\n kpt.positionRaw = [\n kpt.positionRaw[0] + cropBox[1], // correct offset due to crop\n kpt.positionRaw[1] + cropBox[0], // correct offset due to crop\n kpt.positionRaw[2] as number,\n ];\n kpt.position = [\n Math.trunc(kpt.positionRaw[0] * outputSize[0]),\n Math.trunc(kpt.positionRaw[1] * outputSize[1]),\n kpt.positionRaw[2] as number,\n ];\n }\n }\n return keypoints;\n}\n\nasync function fixKeypoints(keypoints: Array) {\n // palm z-coord is incorrect around near-zero so we approximate it\n const leftPalm = keypoints.find((k) => k.part === 'leftPalm') as BodyKeypoint;\n const leftWrist = keypoints.find((k) => k.part === 'leftWrist') as BodyKeypoint;\n const leftIndex = keypoints.find((k) => k.part === 'leftIndex') as BodyKeypoint;\n leftPalm.position[2] = ((leftWrist.position[2] || 0) + (leftIndex.position[2] || 0)) / 2;\n const rightPalm = keypoints.find((k) => k.part === 'rightPalm') as BodyKeypoint;\n const rightWrist = keypoints.find((k) => k.part === 'rightWrist') as BodyKeypoint;\n const rightIndex = keypoints.find((k) => k.part === 'rightIndex') as BodyKeypoint;\n rightPalm.position[2] = ((rightWrist.position[2] || 0) + (rightIndex.position[2] || 0)) / 2;\n}\n\nasync function detectLandmarks(input: Tensor, config: Config, outputSize: [number, number]): Promise {\n /**\n * t.ld: 39 keypoints [x,y,z,score,presence] normalized to input size\n * t.segmentation:\n * t.heatmap:\n * t.world: 39 keypoints [x,y,z] normalized to -1..1\n * t.poseflag: body score\n */\n const t: Record = {};\n [t.ld/* 1,195(39*5) */, t.segmentation/* 1,256,256,1 */, t.heatmap/* 1,64,64,39 */, t.world/* 1,117(39*3) */, t.poseflag/* 1,1 */] = models.landmarks?.execute(input, outputNodes.landmarks) as Tensor[]; // run model\n const poseScore = (await t.poseflag.data())[0];\n const points = await t.ld.data();\n const distances = await t.world.data();\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor])); // dont need tensors after this\n const keypointsRelative: Array = [];\n const depth = 5; // each points has x,y,z,visibility,presence\n for (let i = 0; i < points.length / depth; i++) {\n const score = sigmoid(points[depth * i + 3]);\n const presence = sigmoid(points[depth * i + 4]);\n const adjScore = Math.trunc(100 * score * presence * poseScore) / 100;\n const positionRaw: Point = [points[depth * i + 0] / inputSize.landmarks[0], points[depth * i + 1] / inputSize.landmarks[1], points[depth * i + 2] + 0];\n const position: Point = [Math.trunc(outputSize[0] * positionRaw[0]), Math.trunc(outputSize[1] * positionRaw[1]), positionRaw[2] as number];\n const distance: Point = [distances[depth * i + 0], distances[depth * i + 1], distances[depth * i + 2] + 0];\n keypointsRelative.push({ part: coords.kpt[i] as BodyLandmark, positionRaw, position, distance, score: adjScore });\n }\n if (poseScore < (config.body.minConfidence || 0)) return null;\n fixKeypoints(keypointsRelative);\n const keypoints: Array = rescaleKeypoints(keypointsRelative, outputSize); // keypoints were relative to input image which is padded\n const kpts = keypoints.map((k) => k.position);\n const boxes = box.calc(kpts, [outputSize[0], outputSize[1]]); // now find boxes based on rescaled keypoints\n const annotations: Record = {} as Record;\n for (const [name, indexes] of Object.entries(coords.connected)) {\n const pt: Array = [];\n for (let i = 0; i < indexes.length - 1; i++) {\n const pt0 = keypoints.find((kpt) => kpt.part === indexes[i]);\n const pt1 = keypoints.find((kpt) => kpt.part === indexes[i + 1]);\n if (pt0 && pt1) pt.push([pt0.position, pt1.position]);\n }\n annotations[name] = pt;\n }\n const body = { id: 0, score: Math.trunc(100 * poseScore) / 100, box: boxes.box, boxRaw: boxes.boxRaw, keypoints, annotations };\n return body;\n}\n\n/*\ninterface DetectedBox { box: Box, boxRaw: Box, score: number }\n\nfunction rescaleBoxes(boxes: Array, outputSize: [number, number]): Array {\n for (const b of boxes) {\n b.box = [\n Math.trunc(b.box[0] * (outputSize[0] + padding[2][0] + padding[2][1]) / outputSize[0]),\n Math.trunc(b.box[1] * (outputSize[1] + padding[1][0] + padding[1][1]) / outputSize[1]),\n Math.trunc(b.box[2] * (outputSize[0] + padding[2][0] + padding[2][1]) / outputSize[0]),\n Math.trunc(b.box[3] * (outputSize[1] + padding[1][0] + padding[1][1]) / outputSize[1]),\n ];\n b.boxRaw = [b.box[0] / outputSize[0], b.box[1] / outputSize[1], b.box[2] / outputSize[0], b.box[3] / outputSize[1]];\n }\n return boxes;\n}\n\nasync function detectBoxes(input: Tensor, config: Config, outputSize: [number, number]) {\n const t: Record = {};\n t.res = models.detector?.execute(input, ['Identity']) as Tensor; //\n t.logitsRaw = tf.slice(t.res, [0, 0, 0], [1, -1, 1]);\n t.boxesRaw = tf.slice(t.res, [0, 0, 1], [1, -1, -1]);\n t.logits = tf.squeeze(t.logitsRaw);\n t.boxes = tf.squeeze(t.boxesRaw);\n const boxes = await detect.decode(t.boxes, t.logits, config, outputSize);\n rescaleBoxes(boxes, outputSize);\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n return boxes;\n}\n*/\n\nexport async function predict(input: Tensor, config: Config): Promise {\n const outputSize: [number, number] = [input.shape[2] || 0, input.shape[1] || 0];\n const skipTime = (config.body.skipTime || 0) > (now() - lastTime);\n const skipFrame = skipped < (config.body.skipFrames || 0);\n if (config.skipAllowed && skipTime && skipFrame && cache !== null) {\n skipped++;\n } else {\n const t: Record = {};\n /*\n if (config.body['detector'] && config.body['detector']['enabled']) {\n t.detector = await prepareImage(input, 224);\n const boxes = await detectBoxes(t.detector, config, outputSize);\n }\n */\n t.landmarks = await prepareImage(input, 256); // padded and resized\n cache = await detectLandmarks(t.landmarks, config, outputSize);\n /*\n cropBox = [0, 0, 1, 1]; // reset crop coordinates\n if (cache?.boxRaw && config.skipAllowed) {\n const cx = (2.0 * cache.boxRaw[0] + cache.boxRaw[2]) / 2;\n const cy = (2.0 * cache.boxRaw[1] + cache.boxRaw[3]) / 2;\n let size = cache.boxRaw[2] > cache.boxRaw[3] ? cache.boxRaw[2] : cache.boxRaw[3];\n size = (size * 1.0) / 2; // enlarge and half it\n if (cx > 0.1 && cx < 0.9 && cy > 0.1 && cy < 0.9 && size > 0.1) { // only update if box is sane\n const y = 0; // cy - size;\n const x = cx - size;\n cropBox = [y, x, y + 1, x + 1]; // [y0,x0,y1,x1] used for cropping but width/height are not yet implemented so we only reposition image to center of body\n }\n }\n */\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n lastTime = now();\n skipped = 0;\n }\n return cache ? [cache] : [];\n}\n", "/**\n * CoCo Labels used by object detection implementations\n */\nexport const labels = [\n { class: 1, label: 'person' },\n { class: 2, label: 'bicycle' },\n { class: 3, label: 'car' },\n { class: 4, label: 'motorcycle' },\n { class: 5, label: 'airplane' },\n { class: 6, label: 'bus' },\n { class: 7, label: 'train' },\n { class: 8, label: 'truck' },\n { class: 9, label: 'boat' },\n { class: 10, label: 'traffic light' },\n { class: 11, label: 'fire hydrant' },\n { class: 12, label: 'stop sign' },\n { class: 13, label: 'parking meter' },\n { class: 14, label: 'bench' },\n { class: 15, label: 'bird' },\n { class: 16, label: 'cat' },\n { class: 17, label: 'dog' },\n { class: 18, label: 'horse' },\n { class: 19, label: 'sheep' },\n { class: 20, label: 'cow' },\n { class: 21, label: 'elephant' },\n { class: 22, label: 'bear' },\n { class: 23, label: 'zebra' },\n { class: 24, label: 'giraffe' },\n { class: 25, label: 'backpack' },\n { class: 26, label: 'umbrella' },\n { class: 27, label: 'handbag' },\n { class: 28, label: 'tie' },\n { class: 29, label: 'suitcase' },\n { class: 30, label: 'frisbee' },\n { class: 31, label: 'skis' },\n { class: 32, label: 'snowboard' },\n { class: 33, label: 'sports ball' },\n { class: 34, label: 'kite' },\n { class: 35, label: 'baseball bat' },\n { class: 36, label: 'baseball glove' },\n { class: 37, label: 'skateboard' },\n { class: 38, label: 'surfboard' },\n { class: 39, label: 'tennis racket' },\n { class: 40, label: 'bottle' },\n { class: 41, label: 'wine glass' },\n { class: 42, label: 'cup' },\n { class: 43, label: 'fork' },\n { class: 44, label: 'knife' },\n { class: 45, label: 'spoon' },\n { class: 46, label: 'bowl' },\n { class: 47, label: 'banana' },\n { class: 48, label: 'apple' },\n { class: 49, label: 'sandwich' },\n { class: 50, label: 'orange' },\n { class: 51, label: 'broccoli' },\n { class: 52, label: 'carrot' },\n { class: 53, label: 'hot dog' },\n { class: 54, label: 'pizza' },\n { class: 55, label: 'donut' },\n { class: 56, label: 'cake' },\n { class: 57, label: 'chair' },\n { class: 58, label: 'couch' },\n { class: 59, label: 'potted plant' },\n { class: 60, label: 'bed' },\n { class: 61, label: 'dining table' },\n { class: 62, label: 'toilet' },\n { class: 63, label: 'tv' },\n { class: 64, label: 'laptop' },\n { class: 65, label: 'mouse' },\n { class: 66, label: 'remote' },\n { class: 67, label: 'keyboard' },\n { class: 68, label: 'cell phone' },\n { class: 69, label: 'microwave' },\n { class: 70, label: 'oven' },\n { class: 71, label: 'toaster' },\n { class: 72, label: 'sink' },\n { class: 73, label: 'refrigerator' },\n { class: 74, label: 'book' },\n { class: 75, label: 'clock' },\n { class: 76, label: 'vase' },\n { class: 77, label: 'scissors' },\n { class: 78, label: 'teddy bear' },\n { class: 79, label: 'hair drier' },\n { class: 80, label: 'toothbrush' },\n];\n", "/**\n * CenterNet object detection model implementation\n *\n * Based on: [**NanoDet**](https://github.com/RangiLyu/nanodet)\n */\n\nimport { log, now } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport { labels } from './labels';\nimport type { ObjectResult, ObjectType, Box } from '../result';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport type { Config } from '../config';\nimport { env } from '../util/env';\n\nlet model: GraphModel | null;\nlet inputSize = 0;\nlet last: ObjectResult[] = [];\nlet lastTime = 0;\nlet skipped = Number.MAX_SAFE_INTEGER;\n\nexport async function load(config: Config): Promise {\n if (env.initial) model = null;\n if (!model) {\n // fakeOps(['floormod'], config);\n model = await loadModel(config.object.modelPath);\n const inputs = Object.values(model.modelSignature['inputs']);\n inputSize = Array.isArray(inputs) ? parseInt(inputs[0].tensorShape.dim[2].size) : 0;\n } else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\nasync function process(res: Tensor | null, outputShape: [number, number], config: Config) {\n if (!res) return [];\n const t: Record = {};\n const results: Array = [];\n const detections = await res.array() as number[][][];\n t.squeeze = tf.squeeze(res);\n const arr = tf.split(t.squeeze, 6, 1) as Tensor[]; // x1, y1, x2, y2, score, class\n t.stack = tf.stack([arr[1], arr[0], arr[3], arr[2]], 1); // reorder dims as tf.nms expects y, x\n t.boxes = tf.squeeze(t.stack);\n t.scores = tf.squeeze(arr[4]);\n t.classes = tf.squeeze(arr[5]);\n tf.dispose([res, ...arr]);\n t.nms = await tf.image.nonMaxSuppressionAsync(t.boxes, t.scores, config.object.maxDetected, config.object.iouThreshold, (config.object.minConfidence || 0));\n const nms = await t.nms.data();\n let i = 0;\n for (const id of Array.from(nms)) {\n const score = Math.trunc(100 * detections[0][id][4]) / 100;\n const classVal = detections[0][id][5];\n const label = labels[classVal].label as ObjectType;\n const [x, y] = [\n detections[0][id][0] / inputSize,\n detections[0][id][1] / inputSize,\n ];\n const boxRaw: Box = [\n x,\n y,\n detections[0][id][2] / inputSize - x,\n detections[0][id][3] / inputSize - y,\n ];\n const box: Box = [\n Math.trunc(boxRaw[0] * outputShape[0]),\n Math.trunc(boxRaw[1] * outputShape[1]),\n Math.trunc(boxRaw[2] * outputShape[0]),\n Math.trunc(boxRaw[3] * outputShape[1]),\n ];\n results.push({ id: i++, score, class: classVal, label, box, boxRaw });\n }\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n return results;\n}\n\nexport async function predict(input: Tensor, config: Config): Promise {\n const skipTime = (config.object.skipTime || 0) > (now() - lastTime);\n const skipFrame = skipped < (config.object.skipFrames || 0);\n if (config.skipAllowed && skipTime && skipFrame && (last.length > 0)) {\n skipped++;\n return last;\n }\n skipped = 0;\n return new Promise(async (resolve) => {\n const outputSize = [input.shape[2] || 0, input.shape[1] || 0] as [number, number];\n const resize = tf.image.resizeBilinear(input, [inputSize, inputSize]);\n const objectT = config.object.enabled ? model?.execute(resize, ['tower_0/detections']) as Tensor : null;\n lastTime = now();\n tf.dispose(resize);\n\n const obj = await process(objectT, outputSize, config);\n last = obj;\n\n resolve(obj);\n });\n}\n", "export const kpt: Array = [\n 'head',\n 'neck',\n 'rightShoulder',\n 'rightElbow',\n 'rightWrist',\n 'chest',\n 'leftShoulder',\n 'leftElbow',\n 'leftWrist',\n 'bodyCenter',\n 'rightHip',\n 'rightKnee',\n 'rightAnkle',\n 'leftHip',\n 'leftKnee',\n 'leftAnkle',\n];\n\nexport const connected: Record = {\n leftLeg: ['leftHip', 'leftKnee', 'leftAnkle'],\n rightLeg: ['rightHip', 'rightKnee', 'rightAnkle'],\n torso: ['leftShoulder', 'rightShoulder', 'rightHip', 'leftHip', 'leftShoulder'],\n leftArm: ['leftShoulder', 'leftElbow', 'leftWrist'],\n rightArm: ['rightShoulder', 'rightElbow', 'rightWrist'],\n head: [],\n};\n", "/**\n * EfficientPose model implementation\n *\n * Based on: [**EfficientPose**](https://github.com/daniegr/EfficientPose)\n */\n\nimport { log, now } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport * as coords from './efficientposecoords';\nimport { constants } from '../tfjs/constants';\nimport type { BodyResult, Point, BodyLandmark, BodyAnnotation } from '../result';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport type { Config } from '../config';\nimport { env } from '../util/env';\n\nlet model: GraphModel | null;\nlet lastTime = 0;\nconst cache: BodyResult = { id: 0, keypoints: [], box: [0, 0, 0, 0], boxRaw: [0, 0, 0, 0], score: 0, annotations: {} as Record };\n\n// const keypoints: Array = [];\n// let box: Box = [0, 0, 0, 0];\n// let boxRaw: Box = [0, 0, 0, 0];\n// let score = 0;\nlet skipped = Number.MAX_SAFE_INTEGER;\n\nexport async function load(config: Config): Promise {\n if (env.initial) model = null;\n if (!model) model = await loadModel(config.body.modelPath);\n else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\n// performs argmax and max functions on a 2d tensor\nasync function max2d(inputs, minScore) {\n const [width, height] = inputs.shape;\n const reshaped = tf.reshape(inputs, [height * width]); // combine all data\n const max = tf.max(reshaped, 0);\n const newScore = (await max.data())[0]; // get highest score\n tf.dispose([reshaped, max]);\n if (newScore > minScore) { // skip coordinate calculation is score is too low\n const coordinates = tf.argMax(reshaped, 0);\n const mod = tf.mod(coordinates, width);\n const x = (await mod.data())[0];\n const div = tf.div(coordinates, tf.scalar(width, 'int32'));\n const y = (await div.data())[0];\n tf.dispose([mod, div]);\n return [x, y, newScore];\n }\n return [0, 0, newScore];\n}\n\nexport async function predict(image: Tensor, config: Config): Promise {\n const skipTime = (config.body.skipTime || 0) > (now() - lastTime);\n const skipFrame = skipped < (config.body.skipFrames || 0);\n if (config.skipAllowed && skipTime && skipFrame && Object.keys(cache.keypoints).length > 0) {\n skipped++;\n return [cache];\n }\n skipped = 0;\n return new Promise(async (resolve) => {\n const tensor = tf.tidy(() => {\n if (!model?.inputs[0].shape) return null;\n const resize = tf.image.resizeBilinear(image, [model.inputs[0].shape[2], model.inputs[0].shape[1]], false);\n const enhance = tf.mul(resize, constants.tf2);\n const norm = tf.sub(enhance, constants.tf1);\n return norm;\n });\n\n let resT;\n if (config.body.enabled) resT = model?.execute(tensor);\n lastTime = now();\n tf.dispose(tensor);\n\n if (resT) {\n cache.keypoints.length = 0;\n const squeeze = resT.squeeze();\n tf.dispose(resT);\n // body parts are basically just a stack of 2d tensors\n const stack = squeeze.unstack(2);\n tf.dispose(squeeze);\n // process each unstacked tensor as a separate body part\n for (let id = 0; id < stack.length; id++) {\n // actual processing to get coordinates and score\n const [x, y, partScore] = await max2d(stack[id], config.body.minConfidence);\n if (partScore > (config.body?.minConfidence || 0)) {\n cache.keypoints.push({\n score: Math.round(100 * partScore) / 100,\n part: coords.kpt[id] as BodyLandmark,\n positionRaw: [ // normalized to 0..1\n // @ts-ignore model is not undefined here\n x / model.inputs[0].shape[2], y / model.inputs[0].shape[1],\n ],\n position: [ // normalized to input image size\n // @ts-ignore model is not undefined here\n Math.round(image.shape[2] * x / model.inputs[0].shape[2]), Math.round(image.shape[1] * y / model.inputs[0].shape[1]),\n ],\n });\n }\n }\n stack.forEach((s) => tf.dispose(s));\n }\n cache.score = cache.keypoints.reduce((prev, curr) => (curr.score > prev ? curr.score : prev), 0);\n const x = cache.keypoints.map((a) => a.position[0]);\n const y = cache.keypoints.map((a) => a.position[1]);\n cache.box = [\n Math.min(...x),\n Math.min(...y),\n Math.max(...x) - Math.min(...x),\n Math.max(...y) - Math.min(...y),\n ];\n const xRaw = cache.keypoints.map((a) => a.positionRaw[0]);\n const yRaw = cache.keypoints.map((a) => a.positionRaw[1]);\n cache.boxRaw = [\n Math.min(...xRaw),\n Math.min(...yRaw),\n Math.max(...xRaw) - Math.min(...xRaw),\n Math.max(...yRaw) - Math.min(...yRaw),\n ];\n for (const [name, indexes] of Object.entries(coords.connected)) {\n const pt: Array = [];\n for (let i = 0; i < indexes.length - 1; i++) {\n const pt0 = cache.keypoints.find((kpt) => kpt.part === indexes[i]);\n const pt1 = cache.keypoints.find((kpt) => kpt.part === indexes[i + 1]);\n if (pt0 && pt1 && pt0.score > (config.body.minConfidence || 0) && pt1.score > (config.body.minConfidence || 0)) pt.push([pt0.position, pt1.position]);\n }\n cache.annotations[name] = pt;\n }\n resolve([cache]);\n });\n}\n", "/**\n * Emotion model implementation\n *\n * [**Oarriaga**](https://github.com/oarriaga/face_classification)\n */\n\nimport type { Emotion } from '../result';\nimport { log, now } from '../util/util';\nimport type { Config } from '../config';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport { env } from '../util/env';\nimport { constants } from '../tfjs/constants';\n\nconst annotations = ['angry', 'disgust', 'fear', 'happy', 'sad', 'surprise', 'neutral'];\nlet model: GraphModel | null;\nconst last: Array> = [];\nlet lastCount = 0;\nlet lastTime = 0;\nlet skipped = Number.MAX_SAFE_INTEGER;\n\nexport async function load(config: Config): Promise {\n if (env.initial) model = null;\n if (!model) model = await loadModel(config.face.emotion?.modelPath);\n else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\nexport async function predict(image: Tensor, config: Config, idx: number, count: number): Promise> {\n if (!model) return [];\n const skipFrame = skipped < (config.face.emotion?.skipFrames || 0);\n const skipTime = (config.face.emotion?.skipTime || 0) > (now() - lastTime);\n if (config.skipAllowed && skipTime && skipFrame && (lastCount === count) && last[idx] && (last[idx].length > 0)) {\n skipped++;\n return last[idx];\n }\n skipped = 0;\n return new Promise(async (resolve) => {\n const obj: Array<{ score: number, emotion: Emotion }> = [];\n if (config.face.emotion?.enabled) {\n const t: Record = {};\n const inputSize = model?.inputs[0].shape ? model.inputs[0].shape[2] : 0;\n t.resize = tf.image.resizeBilinear(image, [inputSize, inputSize], false);\n // const box = [[0.15, 0.15, 0.85, 0.85]]; // empyrical values for top, left, bottom, right\n // const resize = tf.image.cropAndResize(image, box, [0], [inputSize, inputSize]);\n // [t.red, t.green, t.blue] = tf.split(t.resize, 3, 3);\n // weighted rgb to grayscale: https://www.mathworks.com/help/matlab/ref/rgb2gray.html\n // t.redNorm = tf.mul(t.red, rgb[0]);\n // t.greenNorm = tf.mul(t.green, rgb[1]);\n // t.blueNorm = tf.mul(t.blue, rgb[2]);\n // t.grayscale = tf.addN([t.redNorm, t.greenNorm, t.blueNorm]);\n t.channels = tf.mul(t.resize, constants.rgb);\n t.grayscale = tf.sum(t.channels, 3, true);\n t.grayscaleSub = tf.sub(t.grayscale, constants.tf05);\n t.grayscaleMul = tf.mul(t.grayscaleSub, constants.tf2);\n t.emotion = model?.execute(t.grayscaleMul) as Tensor; // result is already in range 0..1, no need for additional activation\n lastTime = now();\n const data = await t.emotion.data();\n for (let i = 0; i < data.length; i++) {\n if (data[i] > (config.face.emotion?.minConfidence || 0)) obj.push({ score: Math.min(0.99, Math.trunc(100 * data[i]) / 100), emotion: annotations[i] as Emotion });\n }\n obj.sort((a, b) => b.score - a.score);\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n }\n last[idx] = obj;\n lastCount = count;\n resolve(obj);\n });\n}\n", "/**\n * EfficientPose model implementation\n *\n * Based on: [**BecauseofAI MobileFace**](https://github.com/becauseofAI/MobileFace)\n *\n * Obsolete and replaced by `faceres` that performs age/gender/descriptor analysis\n */\n\nimport { log, now } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport type { Tensor, GraphModel } from '../tfjs/types';\nimport type { Config } from '../config';\nimport { env } from '../util/env';\n\nlet model: GraphModel | null;\nconst last: Array = [];\nlet lastCount = 0;\nlet lastTime = 0;\nlet skipped = Number.MAX_SAFE_INTEGER;\n\nexport async function load(config: Config): Promise {\n if (env.initial) model = null;\n if (!model) model = await loadModel(config.face['mobilefacenet'].modelPath);\n else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\n/*\n// convert to black&white to avoid colorization impact\nconst rgb = [0.2989, 0.5870, 0.1140]; // factors for red/green/blue colors when converting to grayscale: https://www.mathworks.com/help/matlab/ref/rgb2gray.html\nconst [red, green, blue] = tf.split(crop, 3, 3);\nconst redNorm = tf.mul(red, rgb[0]);\nconst greenNorm = tf.mul(green, rgb[1]);\nconst blueNorm = tf.mul(blue, rgb[2]);\nconst grayscale = tf.addN([redNorm, greenNorm, blueNorm]);\nconst merge = tf.stack([grayscale, grayscale, grayscale], 3).squeeze(4);\n\n// optional increase image contrast\n// or do it per-channel so mean is done on each channel\n// or do it based on histogram\nconst mean = merge.mean();\nconst factor = 5;\nconst contrast = merge.sub(mean).mul(factor).add(mean);\n*/\n\nexport async function predict(input: Tensor, config: Config, idx, count): Promise {\n if (!model) return [];\n const skipFrame = skipped < (config.face['embedding']?.skipFrames || 0);\n const skipTime = (config.face['embedding']?.skipTime || 0) > (now() - lastTime);\n if (config.skipAllowed && skipTime && skipFrame && (lastCount === count) && last[idx]) {\n skipped++;\n return last[idx];\n }\n return new Promise(async (resolve) => {\n let data: Array = [];\n if (config.face['embedding']?.enabled && model?.inputs[0].shape) {\n const t: Record = {};\n t.crop = tf.image.resizeBilinear(input, [model.inputs[0].shape[2], model.inputs[0].shape[1]], false); // just resize to fit the embedding model\n // do a tight crop of image and resize it to fit the model\n // const box = [[0.05, 0.15, 0.85, 0.85]]; // empyrical values for top, left, bottom, right\n // t.crop = tf.image.cropAndResize(input, box, [0], [model.inputs[0].shape[2], model.inputs[0].shape[1]]);\n t.data = model?.execute(t.crop) as Tensor;\n /*\n // optional normalize outputs with l2 normalization\n const scaled = tf.tidy(() => {\n const l2 = res.norm('euclidean');\n const scale = res.div(l2);\n return scale;\n });\n\n // optional reduce feature vector complexity\n const reshape = tf.reshape(res, [128, 2]); // split 256 vectors into 128 x 2\n const reduce = reshape.logSumExp(1); // reduce 2nd dimension by calculating logSumExp on it\n */\n const output = await t.data.data();\n data = Array.from(output); // convert typed array to simple array\n }\n last[idx] = data;\n lastCount = count;\n lastTime = now();\n resolve(data);\n });\n}\n", "import * as coords from './facemeshcoords';\nimport * as util from './facemeshutil';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport type { Tensor, GraphModel } from '../tfjs/types';\nimport { env } from '../util/env';\nimport { log } from '../util/util';\nimport { loadModel } from '../tfjs/load';\nimport type { Config } from '../config';\nimport type { Point } from '../result';\n\nlet model: GraphModel | null;\nlet inputSize = 0;\n\nconst irisEnlarge = 2.3;\n\nconst leftOutline = coords.meshAnnotations['leftEyeLower0'];\nconst rightOutline = coords.meshAnnotations['rightEyeLower0'];\n\nconst eyeLandmarks = {\n leftBounds: [leftOutline[0], leftOutline[leftOutline.length - 1]],\n rightBounds: [rightOutline[0], rightOutline[rightOutline.length - 1]],\n};\n\nconst irisLandmarks = {\n upperCenter: 3,\n lowerCenter: 4,\n index: 71,\n numCoordinates: 76,\n};\n\nexport async function load(config: Config): Promise {\n if (env.initial) model = null;\n if (!model) model = await loadModel(config.face.iris?.modelPath);\n else if (config.debug) log('cached model:', model['modelUrl']);\n inputSize = model.inputs[0].shape ? model.inputs[0].shape[2] : 0;\n if (inputSize === -1) inputSize = 64;\n return model;\n}\n\n// Replace the raw coordinates returned by facemesh with refined iris model coordinates and update the z coordinate to be an average of the original and the new.\nexport function replaceIrisCoords(rawCoords, newCoords, prefix, keys) {\n for (let i = 0; i < coords.irisIndices.length; i++) {\n const { key, indices } = coords.irisIndices[i];\n const originalIndices = coords.meshAnnotations[`${prefix}${key}`];\n if (!keys || keys.includes(key)) {\n for (let j = 0; j < indices.length; j++) {\n const index = indices[j];\n rawCoords[originalIndices[j]] = [\n newCoords[index][0],\n newCoords[index][1],\n (newCoords[index][2] + rawCoords[originalIndices[j]][2]) / 2,\n ];\n }\n }\n }\n}\n\nexport const getLeftToRightEyeDepthDifference = (rawCoords) => {\n const leftEyeZ = rawCoords[eyeLandmarks.leftBounds[0]][2];\n const rightEyeZ = rawCoords[eyeLandmarks.rightBounds[0]][2];\n return leftEyeZ - rightEyeZ;\n};\n\n// Returns a box describing a cropped region around the eye fit for passing to the iris model.\nexport const getEyeBox = (rawCoords, face, eyeInnerCornerIndex, eyeOuterCornerIndex, meshSize, flip = false) => {\n const box = util.squarifyBox(util.enlargeBox(util.calculateLandmarksBoundingBox([rawCoords[eyeInnerCornerIndex], rawCoords[eyeOuterCornerIndex]]), irisEnlarge));\n const boxSize = util.getBoxSize(box);\n let crop = tf.image.cropAndResize(face, [[\n box.startPoint[1] / meshSize,\n box.startPoint[0] / meshSize, box.endPoint[1] / meshSize,\n box.endPoint[0] / meshSize,\n ]], [0], [inputSize, inputSize]);\n if (flip && env.kernels.includes('flipleftright')) {\n const flipped = tf.image.flipLeftRight(crop); // flipLeftRight is not defined for tfjs-node\n tf.dispose(crop);\n crop = flipped;\n }\n return { box, boxSize, crop };\n};\n\n// Given a cropped image of an eye, returns the coordinates of the contours surrounding the eye and the iris.\nexport const getEyeCoords = (eyeData, eyeBox, eyeBoxSize, flip = false) => {\n const eyeRawCoords: Array = [];\n for (let i = 0; i < irisLandmarks.numCoordinates; i++) {\n const x = eyeData[i * 3];\n const y = eyeData[i * 3 + 1];\n const z = eyeData[i * 3 + 2];\n eyeRawCoords.push([\n (flip ? (1 - (x / inputSize)) : (x / inputSize)) * eyeBoxSize[0] + eyeBox.startPoint[0],\n (y / inputSize) * eyeBoxSize[1] + eyeBox.startPoint[1], z,\n ]);\n }\n return { rawCoords: eyeRawCoords, iris: eyeRawCoords.slice(irisLandmarks.index) };\n};\n\n// The z-coordinates returned for the iris are unreliable, so we take the z values from the surrounding keypoints.\nexport const getAdjustedIrisCoords = (rawCoords, irisCoords, direction) => {\n const upperCenterZ = rawCoords[coords.meshAnnotations[`${direction}EyeUpper0`][irisLandmarks.upperCenter]][2];\n const lowerCenterZ = rawCoords[coords.meshAnnotations[`${direction}EyeLower0`][irisLandmarks.lowerCenter]][2];\n const averageZ = (upperCenterZ + lowerCenterZ) / 2;\n // Iris indices: 0: center | 1: right | 2: above | 3: left | 4: below\n return irisCoords.map((coord, i) => {\n let z = averageZ;\n if (i === 2) {\n z = upperCenterZ;\n } else if (i === 4) {\n z = lowerCenterZ;\n }\n return [coord[0], coord[1], z];\n });\n};\n\nexport async function augmentIris(rawCoords, face, config, meshSize) {\n if (!model) {\n if (config.debug) log('face mesh iris detection requested, but model is not loaded');\n return rawCoords;\n }\n const { box: leftEyeBox, boxSize: leftEyeBoxSize, crop: leftEyeCrop } = getEyeBox(rawCoords, face, eyeLandmarks.leftBounds[0], eyeLandmarks.leftBounds[1], meshSize, true);\n const { box: rightEyeBox, boxSize: rightEyeBoxSize, crop: rightEyeCrop } = getEyeBox(rawCoords, face, eyeLandmarks.rightBounds[0], eyeLandmarks.rightBounds[1], meshSize, true);\n const combined = tf.concat([leftEyeCrop, rightEyeCrop]);\n tf.dispose(leftEyeCrop);\n tf.dispose(rightEyeCrop);\n const eyePredictions = model.execute(combined) as Tensor;\n tf.dispose(combined);\n const eyePredictionsData = await eyePredictions.data();\n tf.dispose(eyePredictions);\n const leftEyeData = eyePredictionsData.slice(0, irisLandmarks.numCoordinates * 3);\n const { rawCoords: leftEyeRawCoords, iris: leftIrisRawCoords } = getEyeCoords(leftEyeData, leftEyeBox, leftEyeBoxSize, true);\n const rightEyeData = eyePredictionsData.slice(irisLandmarks.numCoordinates * 3);\n const { rawCoords: rightEyeRawCoords, iris: rightIrisRawCoords } = getEyeCoords(rightEyeData, rightEyeBox, rightEyeBoxSize, false);\n const leftToRightEyeDepthDifference = getLeftToRightEyeDepthDifference(rawCoords);\n if (Math.abs(leftToRightEyeDepthDifference) < 30) { // User is looking straight ahead.\n replaceIrisCoords(rawCoords, leftEyeRawCoords, 'left', null);\n replaceIrisCoords(rawCoords, rightEyeRawCoords, 'right', null);\n // If the user is looking to the left or to the right, the iris coordinates tend to diverge too much from the mesh coordinates for them to be merged so we only update a single contour line above and below the eye.\n } else if (leftToRightEyeDepthDifference < 1) { // User is looking towards the right.\n replaceIrisCoords(rawCoords, leftEyeRawCoords, 'left', ['EyeUpper0', 'EyeLower0']);\n } else { // User is looking towards the left.\n replaceIrisCoords(rawCoords, rightEyeRawCoords, 'right', ['EyeUpper0', 'EyeLower0']);\n }\n const adjustedLeftIrisCoords = getAdjustedIrisCoords(rawCoords, leftIrisRawCoords, 'left');\n const adjustedRightIrisCoords = getAdjustedIrisCoords(rawCoords, rightIrisRawCoords, 'right');\n const newCoords = rawCoords.concat(adjustedLeftIrisCoords).concat(adjustedRightIrisCoords);\n return newCoords;\n}\n", "import type { Tensor } from '../tfjs/types';\n\nexport const attentionDefinitions = {\n eyeLLower: [33, 7, 163, 144, 145, 153, 154, 155, 133], // 9\n eyeRLower: [263, 249, 390, 373, 374, 380, 381, 382, 362], // 9\n // eslint-disable-next-line max-len\n lips: [185, 96, 90, 181, 84, 17, 314, 405, 320, 307, 409, 40, 39, 73, 37, 0, 267, 269, 270, 409, 40, 88, 178, 178, 87, 14, 268, 402, 318, 324, 409, 80, 41, 38, 87, 12, 268, 303, 318, 324, 185, 95, 80, 81, 85, 16, 315, 404, 319, 325, 409, 40, 39, 73, 72, 0, 302, 303, 270, 408, 185, 88, 88, 81, 82, 15, 316, 403, 319, 324, 409, 80, 41, 38, 87, 12, 268, 303, 318, 324],\n // eslint-disable-next-line max-len\n eyeL: [33, 7, 163, 144, 145, 153, 154, 155, 133, 246, 161, 160, 159, 158, 157, 173, 130, 25, 110, 24, 23, 22, 26, 112, 243, 247, 30, 29, 27, 28, 56, 190, 226, 31, 228, 229, 230, 231, 232, 233, 244, 113, 225, 224, 223, 222, 221, 189, 35, 124, 46, 53, 52, 65, 143, 111, 117, 118, 119, 120, 121, 128, 245, 156, 70, 63, 105, 66, 107, 55, 193],\n // eslint-disable-next-line max-len\n eyeR: [263, 249, 390, 373, 374, 380, 381, 382, 362, 466, 388, 387, 386, 385, 384, 398, 359, 255, 339, 254, 253, 252, 256, 341, 463, 467, 260, 259, 257, 258, 286, 414, 446, 261, 448, 449, 450, 451, 452, 453, 464, 342, 445, 444, 443, 442, 441, 413, 265, 353, 276, 283, 282, 295, 372, 340, 346, 347, 348, 349, 350, 357, 465, 383, 300, 293, 334, 296, 336, 285, 417],\n};\n\n// function used to determine heuristic mapping\n// values in attentionDefinitions are based on top values from 200 iterations\n/*\nconst historyRes: number[][] = [];\n\nconst getMostCommon = (arr): number => {\n const count: Record = {};\n arr.forEach((el) => {\n count[el] = (count[el] || 0) + 1;\n });\n const res: string[] = Object.keys(count).reduce((acc: string[], val, ind) => {\n if (!ind || count[val] > count[acc[0]]) return [val];\n if (count[val] === count[acc[0]]) acc.push(val);\n return acc;\n }, []);\n return parseInt(res[0]);\n};\n\nfunction replaceClosestPoint(rawCoords, newCoords) {\n const currentRes: number[] = [];\n for (let i = 0; i < newCoords.length / 2; i++) {\n let minDist = Number.MAX_VALUE;\n let minDistIdx = -1;\n const pts = rawCoords.map((r) => [r[0], r[1]]);\n for (let j = 0; j < rawCoords.length; j++) {\n const x = pts[j][0] - newCoords[2 * i + 0];\n const y = pts[j][1] - newCoords[2 * i + 1];\n const dist = (x * x) + (y * y);\n if (dist < minDist) {\n minDist = dist;\n minDistIdx = j;\n }\n }\n currentRes.push(minDistIdx);\n rawCoords[minDistIdx] = [newCoords[2 * i + 0], newCoords[2 * i + 1], rawCoords[minDistIdx][2]];\n }\n historyRes.push(currentRes);\n if (historyRes.length % 50 === 0) {\n const invertRes: number[][] = [];\n for (let i = 0; i < currentRes.length; i++) {\n const indexRes = historyRes.map((j) => j[i]);\n invertRes.push(indexRes);\n }\n const mostCommon: number[] = invertRes.map((r) => getMostCommon(r));\n console.log(mostCommon);\n }\n return rawCoords;\n}\n*/\n\nexport async function augment(rawCoords, results: Tensor[]) {\n const t: Record = { // all attention models produce 2d results so it needs to be later augmented with correct z-coords\n irisL: results[3].dataSync() as Float32Array, // 5 x 2d // output_left_iris\n irisR: results[1].dataSync() as Float32Array, // 5 x 2d // output_right_iris\n eyeL: results[0].dataSync() as Float32Array, // 71 x 2d // output_left_eye\n eyeR: results[6].dataSync() as Float32Array, // 71 x 2d // output_right_eye\n lips: results[5].dataSync() as Float32Array, // 80 x 2d // output_lips\n // flag: results[4], // already processed in parent // conv_faceflag\n // mesh: results[2], // already have it in rawCoords // output_mesh_identity\n };\n\n // rawCoords = replaceClosestPoint(rawCoords, t.eyeL);\n // rawCoords = replaceClosestPoint(rawCoords, t.eyeR);\n // rawCoords = replaceClosestPoint(rawCoords, t.lips);\n\n // augment iris: adds additional 5 keypoints per eye\n const irisRDepth = attentionDefinitions.eyeRLower.reduce((prev, curr) => prev += rawCoords[curr][2], 0) / attentionDefinitions.eyeRLower.length; // get average z-coord for iris\n for (let i = 0; i < t.irisR.length / 2; i++) rawCoords.push([t.irisR[2 * i + 0], t.irisR[2 * i + 1], irisRDepth]);\n const irisLDepth = attentionDefinitions.eyeLLower.reduce((prev, curr) => prev += rawCoords[curr][2], 0) / attentionDefinitions.eyeLLower.length; // get average z-coord for iris\n for (let i = 0; i < t.irisL.length / 2; i++) rawCoords.push([t.irisL[2 * i + 0], t.irisL[2 * i + 1], irisLDepth]);\n\n // augment eyes: replaces eye keypoints based on heuristic mapping\n for (let i = 0; i < t.eyeL.length / 2; i++) rawCoords[attentionDefinitions.eyeL[i]] = [t.eyeL[2 * i + 0], t.eyeL[2 * i + 1], rawCoords[attentionDefinitions.eyeL[i]][2]];\n // for (let i = 0; i < t.eyeL.length / 2; i++) rawCoords.push([t.eyeL[2 * i + 0], t.eyeL[2 * i + 1], 0]);\n for (let i = 0; i < t.eyeR.length / 2; i++) rawCoords[attentionDefinitions.eyeR[i]] = [t.eyeR[2 * i + 0], t.eyeR[2 * i + 1], rawCoords[attentionDefinitions.eyeR[i]][2]];\n // for (let i = 0; i < t.eyeR.length / 2; i++) rawCoords.push([t.eyeR[2 * i + 0], t.eyeR[2 * i + 1], 0]);\n\n // augment lips: replaces eye keypoints based on heuristic mapping\n for (let i = 0; i < t.lips.length / 2; i++) rawCoords[attentionDefinitions.lips[i]] = [t.lips[2 * i + 0], t.lips[2 * i + 1], rawCoords[attentionDefinitions.lips[i]][2]];\n // for (let i = 0; i < t.lips.length / 2; i++) rawCoords.push([t.lips[2 * i + 0], t.lips[2 * i + 1], 0]);\n\n return rawCoords;\n}\n", "/**\n * BlazeFace, FaceMesh & Iris model implementation\n *\n * Based on:\n * - [**MediaPipe BlazeFace**](https://drive.google.com/file/d/1f39lSzU5Oq-j_OXgS67KfN5wNsoeAZ4V/view)\n * - Facial Spacial Geometry: [**MediaPipe FaceMesh**](https://drive.google.com/file/d/1VFC_wIpw4O7xBOiTgUldl79d9LA-LsnA/view)\n * - Eye Iris Details: [**MediaPipe Iris**](https://drive.google.com/file/d/1bsWbokp9AklH2ANjCfmjqEzzxO1CNbMu/view)\n */\n\nimport { log, now } from '../util/util';\nimport { loadModel } from '../tfjs/load';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as blazeface from './blazeface';\nimport * as util from './facemeshutil';\nimport * as coords from './facemeshcoords';\nimport * as iris from './iris';\nimport * as attention from './attention';\nimport { histogramEqualization } from '../image/enhance';\nimport { env } from '../util/env';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport type { FaceResult, FaceLandmark, Point } from '../result';\nimport type { Config } from '../config';\n\ntype DetectBox = { startPoint: Point, endPoint: Point, landmarks: Array, confidence: number };\n\nconst cache = {\n boxes: [] as DetectBox[],\n skipped: Number.MAX_SAFE_INTEGER,\n timestamp: 0,\n};\n\nlet model: GraphModel | null = null;\nlet inputSize = 0;\n\nexport async function predict(input: Tensor, config: Config): Promise {\n // reset cached boxes\n const skipTime = (config.face.detector?.skipTime || 0) > (now() - cache.timestamp);\n const skipFrame = cache.skipped < (config.face.detector?.skipFrames || 0);\n if (!config.skipAllowed || !skipTime || !skipFrame || cache.boxes.length === 0) {\n cache.boxes = await blazeface.getBoxes(input, config); // get results from blazeface detector\n cache.timestamp = now();\n cache.skipped = 0;\n } else {\n cache.skipped++;\n }\n const faces: Array = [];\n const newCache: Array = [];\n let id = 0;\n for (let i = 0; i < cache.boxes.length; i++) {\n const box = cache.boxes[i];\n let angle = 0;\n let rotationMatrix;\n const face: FaceResult = { // init face result\n id: id++,\n mesh: [],\n meshRaw: [],\n box: [0, 0, 0, 0],\n boxRaw: [0, 0, 0, 0],\n score: 0,\n boxScore: 0,\n faceScore: 0,\n annotations: {} as Record,\n };\n\n // optional rotation correction based on detector data only if mesh is disabled otherwise perform it later when we have more accurate mesh data. if no rotation correction this function performs crop\n [angle, rotationMatrix, face.tensor] = util.correctFaceRotation(config.face.detector?.rotation, box, input, config.face.mesh?.enabled ? inputSize : blazeface.size());\n if (config?.filter?.equalization) {\n const equilized = await histogramEqualization(face.tensor as Tensor);\n tf.dispose(face.tensor);\n face.tensor = equilized;\n }\n face.boxScore = Math.round(100 * box.confidence) / 100;\n if (!config.face.mesh?.enabled) { // mesh not enabled, return resuts from detector only\n face.box = util.clampBox(box, input);\n face.boxRaw = util.getRawBox(box, input);\n face.score = face.boxScore;\n face.mesh = box.landmarks.map((pt) => [\n ((box.startPoint[0] + box.endPoint[0])) / 2 + ((box.endPoint[0] + box.startPoint[0]) * pt[0] / blazeface.size()),\n ((box.startPoint[1] + box.endPoint[1])) / 2 + ((box.endPoint[1] + box.startPoint[1]) * pt[1] / blazeface.size()),\n ]);\n face.meshRaw = face.mesh.map((pt) => [pt[0] / (input.shape[2] || 0), pt[1] / (input.shape[1] || 0), (pt[2] || 0) / inputSize]);\n for (const key of Object.keys(coords.blazeFaceLandmarks)) {\n face.annotations[key] = [face.mesh[coords.blazeFaceLandmarks[key] as number]]; // add annotations\n }\n } else if (!model) { // mesh enabled, but not loaded\n if (config.debug) log('face mesh detection requested, but model is not loaded');\n } else { // mesh enabled\n const results = model.execute(face.tensor as Tensor) as Array;\n const confidence = results.find((t) => t.shape[t.shape.length - 1] === 1) as Tensor;\n const contourCoords = results.find((t) => t.shape[t.shape.length - 1] === 1404) as Tensor;\n const faceConfidence = await confidence.data();\n face.faceScore = Math.round(100 * faceConfidence[0]) / 100;\n const coordsReshaped = tf.reshape(contourCoords, [-1, 3]);\n let rawCoords = await coordsReshaped.array();\n if (face.faceScore < (config.face.detector?.minConfidence || 1)) { // low confidence in detected mesh\n box.confidence = face.faceScore; // reset confidence of cached box\n if (config.face.mesh?.keepInvalid) {\n face.box = util.clampBox(box, input);\n face.boxRaw = util.getRawBox(box, input);\n face.score = face.boxScore;\n face.mesh = box.landmarks.map((pt) => [\n ((box.startPoint[0] + box.endPoint[0])) / 2 + ((box.endPoint[0] + box.startPoint[0]) * pt[0] / blazeface.size()),\n ((box.startPoint[1] + box.endPoint[1])) / 2 + ((box.endPoint[1] + box.startPoint[1]) * pt[1] / blazeface.size()),\n ]);\n face.meshRaw = face.mesh.map((pt) => [pt[0] / (input.shape[2] || 0), pt[1] / (input.shape[1] || 0), (pt[2] || 0) / inputSize]);\n for (const key of Object.keys(coords.blazeFaceLandmarks)) {\n face.annotations[key] = [face.mesh[coords.blazeFaceLandmarks[key] as number]]; // add annotations\n }\n }\n } else {\n if (config.face.attention?.enabled) {\n rawCoords = await attention.augment(rawCoords, results); // augment iris results using attention model results\n } else if (config.face.iris?.enabled) {\n rawCoords = await iris.augmentIris(rawCoords, face.tensor, config, inputSize); // run iris model and augment results\n }\n face.mesh = util.transformRawCoords(rawCoords, box, angle, rotationMatrix, inputSize); // get processed mesh\n face.meshRaw = face.mesh.map((pt) => [pt[0] / (input.shape[2] || 0), pt[1] / (input.shape[1] || 0), (pt[2] || 0) / inputSize]);\n for (const key of Object.keys(coords.meshAnnotations)) face.annotations[key] = coords.meshAnnotations[key].map((index) => face.mesh[index]); // add annotations\n face.score = face.faceScore;\n const calculatedBox = { ...util.calculateFaceBox(face.mesh, box), confidence: box.confidence, landmarks: box.landmarks };\n face.box = util.clampBox(calculatedBox, input);\n face.boxRaw = util.getRawBox(calculatedBox, input);\n newCache.push(calculatedBox);\n }\n tf.dispose([...results, coordsReshaped]);\n }\n if (face.score > (config.face.detector?.minConfidence || 1)) faces.push(face);\n else tf.dispose(face.tensor);\n }\n cache.boxes = newCache; // reset cache\n return faces;\n}\n\nexport async function load(config: Config): Promise {\n if (env.initial) model = null;\n if (!model) {\n if (config.face.attention?.enabled) model = await loadModel(config.face.attention?.modelPath);\n else model = await loadModel(config.face.mesh?.modelPath);\n } else if (config.debug) {\n log('cached model:', model['modelUrl']);\n }\n inputSize = model.inputs[0].shape ? model.inputs[0].shape[2] : 0;\n return model;\n}\n\nexport const triangulation = coords.TRI468;\nexport const uvmap = coords.UV468;\n", "/**\n * FaceRes model implementation\n *\n * Returns Age, Gender, Descriptor\n * Implements Face simmilarity function\n *\n * Based on: [**HSE-FaceRes**](https://github.com/HSE-asavchenko/HSE_FaceRec_tf)\n */\n\nimport { log, now } from '../util/util';\nimport { env } from '../util/env';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport { constants } from '../tfjs/constants';\nimport type { Tensor, GraphModel } from '../tfjs/types';\nimport type { Config } from '../config';\nimport type { Gender, Race } from '../result';\n\nexport type FaceRes = { age: number, gender: Gender, genderScore: number, descriptor: number[], race?: { score: number, race: Race }[] };\n\nlet model: GraphModel | null;\nconst last: Array<{\n age: number,\n gender: Gender,\n genderScore: number,\n descriptor: number[],\n}> = [];\n\nlet lastTime = 0;\nlet lastCount = 0;\nlet skipped = Number.MAX_SAFE_INTEGER;\n\nexport async function load(config: Config): Promise {\n if (env.initial) model = null;\n if (!model) model = await loadModel(config.face.description?.modelPath);\n else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\nexport function enhance(input): Tensor {\n const tensor = (input.image || input.tensor || input) as Tensor; // input received from detector is already normalized to 0..1, input is also assumed to be straightened\n if (!model?.inputs[0].shape) return tensor; // model has no shape so no point continuing\n const crop = tf.image.resizeBilinear(tensor, [model.inputs[0].shape[2], model.inputs[0].shape[1]], false);\n const norm = tf.mul(crop, constants.tf255);\n tf.dispose(crop);\n return norm;\n /*\n // do a tight crop of image and resize it to fit the model\n const box = [[0.05, 0.15, 0.85, 0.85]]; // empyrical values for top, left, bottom, right\n const crop = (tensor.shape.length === 3)\n ? tf.image.cropAndResize(tf.expandDims(tensor, 0), box, [0], [model.inputs[0].shape[2], model.inputs[0].shape[1]]) // add batch dimension if missing\n : tf.image.cropAndResize(tensor, box, [0], [model.inputs[0].shape[2], model.inputs[0].shape[1]]);\n */\n /*\n // convert to black&white to avoid colorization impact\n const rgb = [0.2989, 0.5870, 0.1140]; // factors for red/green/blue colors when converting to grayscale: https://www.mathworks.com/help/matlab/ref/rgb2gray.html\n const [red, green, blue] = tf.split(crop, 3, 3);\n const redNorm = tf.mul(red, rgb[0]);\n const greenNorm = tf.mul(green, rgb[1]);\n const blueNorm = tf.mul(blue, rgb[2]);\n const grayscale = tf.addN([redNorm, greenNorm, blueNorm]);\n const merge = tf.stack([grayscale, grayscale, grayscale], 3).squeeze(4);\n */\n}\n\nexport async function predict(image: Tensor, config: Config, idx: number, count: number): Promise {\n if (!model) return { age: 0, gender: 'unknown', genderScore: 0, descriptor: [] };\n const skipFrame = skipped < (config.face.description?.skipFrames || 0);\n const skipTime = (config.face.description?.skipTime || 0) > (now() - lastTime);\n if (config.skipAllowed && skipFrame && skipTime && (lastCount === count) && last[idx]?.age && (last[idx]?.age > 0)) {\n skipped++;\n return last[idx];\n }\n skipped = 0;\n return new Promise(async (resolve) => {\n const obj = {\n age: 0,\n gender: 'unknown',\n genderScore: 0,\n descriptor: [],\n };\n\n if (config.face.description?.enabled) {\n const enhanced = enhance(image);\n const resT = model?.execute(enhanced) as Tensor[];\n lastTime = now();\n tf.dispose(enhanced);\n const genderT = await resT.find((t) => t.shape[1] === 1) as Tensor;\n const gender = await genderT.data();\n const confidence = Math.trunc(200 * Math.abs((gender[0] - 0.5))) / 100;\n if (confidence > (config.face.description?.minConfidence || 0)) {\n obj.gender = gender[0] <= 0.5 ? 'female' : 'male';\n obj.genderScore = Math.min(0.99, confidence);\n }\n const argmax = tf.argMax(resT.find((t) => t.shape[1] === 100), 1);\n const age = (await argmax.data())[0];\n tf.dispose(argmax);\n const ageT = resT.find((t) => t.shape[1] === 100) as Tensor;\n const all = await ageT.data();\n obj.age = Math.round(all[age - 1] > all[age + 1] ? 10 * age - 100 * all[age - 1] : 10 * age + 100 * all[age + 1]) / 10;\n\n const desc = resT.find((t) => t.shape[1] === 1024);\n // const reshape = desc.reshape([128, 8]); // reshape large 1024-element descriptor to 128 x 8\n // const reduce = reshape.logSumExp(1); // reduce 2nd dimension by calculating logSumExp on it which leaves us with 128-element descriptor\n const descriptor = desc ? await desc.data() : [];\n obj.descriptor = Array.from(descriptor);\n resT.forEach((t) => tf.dispose(t));\n }\n last[idx] = obj;\n lastCount = count;\n resolve(obj);\n });\n}\n", "import * as tf from '../../dist/tfjs.esm.js';\nimport type { Point } from '../result';\n\nexport function getBoxSize(box) {\n return [\n Math.abs(box.endPoint[0] - box.startPoint[0]),\n Math.abs(box.endPoint[1] - box.startPoint[1]),\n ];\n}\n\nexport function getBoxCenter(box) {\n return [\n box.startPoint[0] + (box.endPoint[0] - box.startPoint[0]) / 2,\n box.startPoint[1] + (box.endPoint[1] - box.startPoint[1]) / 2,\n ];\n}\n\nexport function cutBoxFromImageAndResize(box, image, cropSize) {\n const h = image.shape[1];\n const w = image.shape[2];\n const boxes = [[\n box.startPoint[1] / h,\n box.startPoint[0] / w,\n box.endPoint[1] / h,\n box.endPoint[0] / w,\n ]];\n return tf.image.cropAndResize(image, boxes, [0], cropSize);\n}\n\nexport function scaleBoxCoordinates(box, factor) {\n const startPoint = [box.startPoint[0] * factor[0], box.startPoint[1] * factor[1]] as Point;\n const endPoint = [box.endPoint[0] * factor[0], box.endPoint[1] * factor[1]] as Point;\n const palmLandmarks = box.palmLandmarks.map((coord) => {\n const scaledCoord = [coord[0] * factor[0], coord[1] * factor[1]];\n return scaledCoord;\n });\n return { startPoint, endPoint, palmLandmarks, confidence: box.confidence };\n}\n\nexport function enlargeBox(box, factor = 1.5) {\n const center = getBoxCenter(box);\n const size = getBoxSize(box);\n const newHalfSize = [factor * size[0] / 2, factor * size[1] / 2];\n const startPoint = [center[0] - newHalfSize[0], center[1] - newHalfSize[1]] as Point;\n const endPoint = [center[0] + newHalfSize[0], center[1] + newHalfSize[1]] as Point;\n return { startPoint, endPoint, palmLandmarks: box.palmLandmarks };\n}\n\nexport function squarifyBox(box) {\n const centers = getBoxCenter(box);\n const size = getBoxSize(box);\n const maxEdge = Math.max(...size);\n const halfSize = maxEdge / 2;\n const startPoint = [centers[0] - halfSize, centers[1] - halfSize] as Point;\n const endPoint = [centers[0] + halfSize, centers[1] + halfSize] as Point;\n return { startPoint, endPoint, palmLandmarks: box.palmLandmarks };\n}\n\nexport function shiftBox(box, shiftFactor) {\n const boxSize = [\n box.endPoint[0] - box.startPoint[0],\n box.endPoint[1] - box.startPoint[1],\n ];\n const shiftVector = [boxSize[0] * shiftFactor[0], boxSize[1] * shiftFactor[1]];\n const startPoint = [box.startPoint[0] + shiftVector[0], box.startPoint[1] + shiftVector[1]] as Point;\n const endPoint = [box.endPoint[0] + shiftVector[0], box.endPoint[1] + shiftVector[1]] as Point;\n return { startPoint, endPoint, palmLandmarks: box.palmLandmarks };\n}\n\nexport function normalizeRadians(angle) {\n return angle - 2 * Math.PI * Math.floor((angle + Math.PI) / (2 * Math.PI));\n}\n\nexport function computeRotation(point1, point2) {\n const radians = Math.PI / 2 - Math.atan2(-(point2[1] - point1[1]), point2[0] - point1[0]);\n return normalizeRadians(radians);\n}\n\nexport const buildTranslationMatrix = (x, y) => [[1, 0, x], [0, 1, y], [0, 0, 1]];\n\nexport function dot(v1, v2) {\n let product = 0;\n for (let i = 0; i < v1.length; i++) {\n product += v1[i] * v2[i];\n }\n return product;\n}\n\nexport function getColumnFrom2DArr(arr, columnIndex) {\n const column: Array = [];\n for (let i = 0; i < arr.length; i++) {\n column.push(arr[i][columnIndex]);\n }\n return column;\n}\n\nexport function multiplyTransformMatrices(mat1, mat2) {\n const product: Array = [];\n const size = mat1.length;\n for (let row = 0; row < size; row++) {\n product.push([]);\n for (let col = 0; col < size; col++) {\n product[row].push(dot(mat1[row], getColumnFrom2DArr(mat2, col)));\n }\n }\n return product;\n}\n\nexport function buildRotationMatrix(rotation, center) {\n const cosA = Math.cos(rotation);\n const sinA = Math.sin(rotation);\n const rotationMatrix = [[cosA, -sinA, 0], [sinA, cosA, 0], [0, 0, 1]];\n const translationMatrix = buildTranslationMatrix(center[0], center[1]);\n const translationTimesRotation = multiplyTransformMatrices(translationMatrix, rotationMatrix);\n const negativeTranslationMatrix = buildTranslationMatrix(-center[0], -center[1]);\n return multiplyTransformMatrices(translationTimesRotation, negativeTranslationMatrix);\n}\n\nexport function invertTransformMatrix(matrix) {\n const rotationComponent = [[matrix[0][0], matrix[1][0]], [matrix[0][1], matrix[1][1]]];\n const translationComponent = [matrix[0][2], matrix[1][2]];\n const invertedTranslation = [\n -dot(rotationComponent[0], translationComponent),\n -dot(rotationComponent[1], translationComponent),\n ];\n return [\n rotationComponent[0].concat(invertedTranslation[0]),\n rotationComponent[1].concat(invertedTranslation[1]),\n [0, 0, 1],\n ];\n}\n\nexport function rotatePoint(homogeneousCoordinate, rotationMatrix) {\n return [\n dot(homogeneousCoordinate, rotationMatrix[0]),\n dot(homogeneousCoordinate, rotationMatrix[1]),\n ];\n}\n", "/**\n * HandPose model implementation constants\n * See `handpose.ts` for entry point\n */\n\nexport const anchors = [\n { x: 0.015625, y: 0.015625 },\n { x: 0.015625, y: 0.015625 },\n { x: 0.046875, y: 0.015625 },\n { x: 0.046875, y: 0.015625 },\n { x: 0.078125, y: 0.015625 },\n { x: 0.078125, y: 0.015625 },\n { x: 0.109375, y: 0.015625 },\n { x: 0.109375, y: 0.015625 },\n { x: 0.140625, y: 0.015625 },\n { x: 0.140625, y: 0.015625 },\n { x: 0.171875, y: 0.015625 },\n { x: 0.171875, y: 0.015625 },\n { x: 0.203125, y: 0.015625 },\n { x: 0.203125, y: 0.015625 },\n { x: 0.234375, y: 0.015625 },\n { x: 0.234375, y: 0.015625 },\n { x: 0.265625, y: 0.015625 },\n { x: 0.265625, y: 0.015625 },\n { x: 0.296875, y: 0.015625 },\n { x: 0.296875, y: 0.015625 },\n { x: 0.328125, y: 0.015625 },\n { x: 0.328125, y: 0.015625 },\n { x: 0.359375, y: 0.015625 },\n { x: 0.359375, y: 0.015625 },\n { x: 0.390625, y: 0.015625 },\n { x: 0.390625, y: 0.015625 },\n { x: 0.421875, y: 0.015625 },\n { x: 0.421875, y: 0.015625 },\n { x: 0.453125, y: 0.015625 },\n { x: 0.453125, y: 0.015625 },\n { x: 0.484375, y: 0.015625 },\n { x: 0.484375, y: 0.015625 },\n { x: 0.515625, y: 0.015625 },\n { x: 0.515625, y: 0.015625 },\n { x: 0.546875, y: 0.015625 },\n { x: 0.546875, y: 0.015625 },\n { x: 0.578125, y: 0.015625 },\n { x: 0.578125, y: 0.015625 },\n { x: 0.609375, y: 0.015625 },\n { x: 0.609375, y: 0.015625 },\n { x: 0.640625, y: 0.015625 },\n { x: 0.640625, y: 0.015625 },\n { x: 0.671875, y: 0.015625 },\n { x: 0.671875, y: 0.015625 },\n { x: 0.703125, y: 0.015625 },\n { x: 0.703125, y: 0.015625 },\n { x: 0.734375, y: 0.015625 },\n { x: 0.734375, y: 0.015625 },\n { x: 0.765625, y: 0.015625 },\n { x: 0.765625, y: 0.015625 },\n { x: 0.796875, y: 0.015625 },\n { x: 0.796875, y: 0.015625 },\n { x: 0.828125, y: 0.015625 },\n { x: 0.828125, y: 0.015625 },\n { x: 0.859375, y: 0.015625 },\n { x: 0.859375, y: 0.015625 },\n { x: 0.890625, y: 0.015625 },\n { x: 0.890625, y: 0.015625 },\n { x: 0.921875, y: 0.015625 },\n { x: 0.921875, y: 0.015625 },\n { x: 0.953125, y: 0.015625 },\n { x: 0.953125, y: 0.015625 },\n { x: 0.984375, y: 0.015625 },\n { x: 0.984375, y: 0.015625 },\n { x: 0.015625, y: 0.046875 },\n { x: 0.015625, y: 0.046875 },\n { x: 0.046875, y: 0.046875 },\n { x: 0.046875, y: 0.046875 },\n { x: 0.078125, y: 0.046875 },\n { x: 0.078125, y: 0.046875 },\n { x: 0.109375, y: 0.046875 },\n { x: 0.109375, y: 0.046875 },\n { x: 0.140625, y: 0.046875 },\n { x: 0.140625, y: 0.046875 },\n { x: 0.171875, y: 0.046875 },\n { x: 0.171875, y: 0.046875 },\n { x: 0.203125, y: 0.046875 },\n { x: 0.203125, y: 0.046875 },\n { x: 0.234375, y: 0.046875 },\n { x: 0.234375, y: 0.046875 },\n { x: 0.265625, y: 0.046875 },\n { x: 0.265625, y: 0.046875 },\n { x: 0.296875, y: 0.046875 },\n { x: 0.296875, y: 0.046875 },\n { x: 0.328125, y: 0.046875 },\n { x: 0.328125, y: 0.046875 },\n { x: 0.359375, y: 0.046875 },\n { x: 0.359375, y: 0.046875 },\n { x: 0.390625, y: 0.046875 },\n { x: 0.390625, y: 0.046875 },\n { x: 0.421875, y: 0.046875 },\n { x: 0.421875, y: 0.046875 },\n { x: 0.453125, y: 0.046875 },\n { x: 0.453125, y: 0.046875 },\n { x: 0.484375, y: 0.046875 },\n { x: 0.484375, y: 0.046875 },\n { x: 0.515625, y: 0.046875 },\n { x: 0.515625, y: 0.046875 },\n { x: 0.546875, y: 0.046875 },\n { x: 0.546875, y: 0.046875 },\n { x: 0.578125, y: 0.046875 },\n { x: 0.578125, y: 0.046875 },\n { x: 0.609375, y: 0.046875 },\n { x: 0.609375, y: 0.046875 },\n { x: 0.640625, y: 0.046875 },\n { x: 0.640625, y: 0.046875 },\n { x: 0.671875, y: 0.046875 },\n { x: 0.671875, y: 0.046875 },\n { x: 0.703125, y: 0.046875 },\n { x: 0.703125, y: 0.046875 },\n { x: 0.734375, y: 0.046875 },\n { x: 0.734375, y: 0.046875 },\n { x: 0.765625, y: 0.046875 },\n { x: 0.765625, y: 0.046875 },\n { x: 0.796875, y: 0.046875 },\n { x: 0.796875, y: 0.046875 },\n { x: 0.828125, y: 0.046875 },\n { x: 0.828125, y: 0.046875 },\n { x: 0.859375, y: 0.046875 },\n { x: 0.859375, y: 0.046875 },\n { x: 0.890625, y: 0.046875 },\n { x: 0.890625, y: 0.046875 },\n { x: 0.921875, y: 0.046875 },\n { x: 0.921875, y: 0.046875 },\n { x: 0.953125, y: 0.046875 },\n { x: 0.953125, y: 0.046875 },\n { x: 0.984375, y: 0.046875 },\n { x: 0.984375, y: 0.046875 },\n { x: 0.015625, y: 0.078125 },\n { x: 0.015625, y: 0.078125 },\n { x: 0.046875, y: 0.078125 },\n { x: 0.046875, y: 0.078125 },\n { x: 0.078125, y: 0.078125 },\n { x: 0.078125, y: 0.078125 },\n { x: 0.109375, y: 0.078125 },\n { x: 0.109375, y: 0.078125 },\n { x: 0.140625, y: 0.078125 },\n { x: 0.140625, y: 0.078125 },\n { x: 0.171875, y: 0.078125 },\n { x: 0.171875, y: 0.078125 },\n { x: 0.203125, y: 0.078125 },\n { x: 0.203125, y: 0.078125 },\n { x: 0.234375, y: 0.078125 },\n { x: 0.234375, y: 0.078125 },\n { x: 0.265625, y: 0.078125 },\n { x: 0.265625, y: 0.078125 },\n { x: 0.296875, y: 0.078125 },\n { x: 0.296875, y: 0.078125 },\n { x: 0.328125, y: 0.078125 },\n { x: 0.328125, y: 0.078125 },\n { x: 0.359375, y: 0.078125 },\n { x: 0.359375, y: 0.078125 },\n { x: 0.390625, y: 0.078125 },\n { x: 0.390625, y: 0.078125 },\n { x: 0.421875, y: 0.078125 },\n { x: 0.421875, y: 0.078125 },\n { x: 0.453125, y: 0.078125 },\n { x: 0.453125, y: 0.078125 },\n { x: 0.484375, y: 0.078125 },\n { x: 0.484375, y: 0.078125 },\n { x: 0.515625, y: 0.078125 },\n { x: 0.515625, y: 0.078125 },\n { x: 0.546875, y: 0.078125 },\n { x: 0.546875, y: 0.078125 },\n { x: 0.578125, y: 0.078125 },\n { x: 0.578125, y: 0.078125 },\n { x: 0.609375, y: 0.078125 },\n { x: 0.609375, y: 0.078125 },\n { x: 0.640625, y: 0.078125 },\n { x: 0.640625, y: 0.078125 },\n { x: 0.671875, y: 0.078125 },\n { x: 0.671875, y: 0.078125 },\n { x: 0.703125, y: 0.078125 },\n { x: 0.703125, y: 0.078125 },\n { x: 0.734375, y: 0.078125 },\n { x: 0.734375, y: 0.078125 },\n { x: 0.765625, y: 0.078125 },\n { x: 0.765625, y: 0.078125 },\n { x: 0.796875, y: 0.078125 },\n { x: 0.796875, y: 0.078125 },\n { x: 0.828125, y: 0.078125 },\n { x: 0.828125, y: 0.078125 },\n { x: 0.859375, y: 0.078125 },\n { x: 0.859375, y: 0.078125 },\n { x: 0.890625, y: 0.078125 },\n { x: 0.890625, y: 0.078125 },\n { x: 0.921875, y: 0.078125 },\n { x: 0.921875, y: 0.078125 },\n { x: 0.953125, y: 0.078125 },\n { x: 0.953125, y: 0.078125 },\n { x: 0.984375, y: 0.078125 },\n { x: 0.984375, y: 0.078125 },\n { x: 0.015625, y: 0.109375 },\n { x: 0.015625, y: 0.109375 },\n { x: 0.046875, y: 0.109375 },\n { x: 0.046875, y: 0.109375 },\n { x: 0.078125, y: 0.109375 },\n { x: 0.078125, y: 0.109375 },\n { x: 0.109375, y: 0.109375 },\n { x: 0.109375, y: 0.109375 },\n { x: 0.140625, y: 0.109375 },\n { x: 0.140625, y: 0.109375 },\n { x: 0.171875, y: 0.109375 },\n { x: 0.171875, y: 0.109375 },\n { x: 0.203125, y: 0.109375 },\n { x: 0.203125, y: 0.109375 },\n { x: 0.234375, y: 0.109375 },\n { x: 0.234375, y: 0.109375 },\n { x: 0.265625, y: 0.109375 },\n { x: 0.265625, y: 0.109375 },\n { x: 0.296875, y: 0.109375 },\n { x: 0.296875, y: 0.109375 },\n { x: 0.328125, y: 0.109375 },\n { x: 0.328125, y: 0.109375 },\n { x: 0.359375, y: 0.109375 },\n { x: 0.359375, y: 0.109375 },\n { x: 0.390625, y: 0.109375 },\n { x: 0.390625, y: 0.109375 },\n { x: 0.421875, y: 0.109375 },\n { x: 0.421875, y: 0.109375 },\n { x: 0.453125, y: 0.109375 },\n { x: 0.453125, y: 0.109375 },\n { x: 0.484375, y: 0.109375 },\n { x: 0.484375, y: 0.109375 },\n { x: 0.515625, y: 0.109375 },\n { x: 0.515625, y: 0.109375 },\n { x: 0.546875, y: 0.109375 },\n { x: 0.546875, y: 0.109375 },\n { x: 0.578125, y: 0.109375 },\n { x: 0.578125, y: 0.109375 },\n { x: 0.609375, y: 0.109375 },\n { x: 0.609375, y: 0.109375 },\n { x: 0.640625, y: 0.109375 },\n { x: 0.640625, y: 0.109375 },\n { x: 0.671875, y: 0.109375 },\n { x: 0.671875, y: 0.109375 },\n { x: 0.703125, y: 0.109375 },\n { x: 0.703125, y: 0.109375 },\n { x: 0.734375, y: 0.109375 },\n { x: 0.734375, y: 0.109375 },\n { x: 0.765625, y: 0.109375 },\n { x: 0.765625, y: 0.109375 },\n { x: 0.796875, y: 0.109375 },\n { x: 0.796875, y: 0.109375 },\n { x: 0.828125, y: 0.109375 },\n { x: 0.828125, y: 0.109375 },\n { x: 0.859375, y: 0.109375 },\n { x: 0.859375, y: 0.109375 },\n { x: 0.890625, y: 0.109375 },\n { x: 0.890625, y: 0.109375 },\n { x: 0.921875, y: 0.109375 },\n { x: 0.921875, y: 0.109375 },\n { x: 0.953125, y: 0.109375 },\n { x: 0.953125, y: 0.109375 },\n { x: 0.984375, y: 0.109375 },\n { x: 0.984375, y: 0.109375 },\n { x: 0.015625, y: 0.140625 },\n { x: 0.015625, y: 0.140625 },\n { x: 0.046875, y: 0.140625 },\n { x: 0.046875, y: 0.140625 },\n { x: 0.078125, y: 0.140625 },\n { x: 0.078125, y: 0.140625 },\n { x: 0.109375, y: 0.140625 },\n { x: 0.109375, y: 0.140625 },\n { x: 0.140625, y: 0.140625 },\n { x: 0.140625, y: 0.140625 },\n { x: 0.171875, y: 0.140625 },\n { x: 0.171875, y: 0.140625 },\n { x: 0.203125, y: 0.140625 },\n { x: 0.203125, y: 0.140625 },\n { x: 0.234375, y: 0.140625 },\n { x: 0.234375, y: 0.140625 },\n { x: 0.265625, y: 0.140625 },\n { x: 0.265625, y: 0.140625 },\n { x: 0.296875, y: 0.140625 },\n { x: 0.296875, y: 0.140625 },\n { x: 0.328125, y: 0.140625 },\n { x: 0.328125, y: 0.140625 },\n { x: 0.359375, y: 0.140625 },\n { x: 0.359375, y: 0.140625 },\n { x: 0.390625, y: 0.140625 },\n { x: 0.390625, y: 0.140625 },\n { x: 0.421875, y: 0.140625 },\n { x: 0.421875, y: 0.140625 },\n { x: 0.453125, y: 0.140625 },\n { x: 0.453125, y: 0.140625 },\n { x: 0.484375, y: 0.140625 },\n { x: 0.484375, y: 0.140625 },\n { x: 0.515625, y: 0.140625 },\n { x: 0.515625, y: 0.140625 },\n { x: 0.546875, y: 0.140625 },\n { x: 0.546875, y: 0.140625 },\n { x: 0.578125, y: 0.140625 },\n { x: 0.578125, y: 0.140625 },\n { x: 0.609375, y: 0.140625 },\n { x: 0.609375, y: 0.140625 },\n { x: 0.640625, y: 0.140625 },\n { x: 0.640625, y: 0.140625 },\n { x: 0.671875, y: 0.140625 },\n { x: 0.671875, y: 0.140625 },\n { x: 0.703125, y: 0.140625 },\n { x: 0.703125, y: 0.140625 },\n { x: 0.734375, y: 0.140625 },\n { x: 0.734375, y: 0.140625 },\n { x: 0.765625, y: 0.140625 },\n { x: 0.765625, y: 0.140625 },\n { x: 0.796875, y: 0.140625 },\n { x: 0.796875, y: 0.140625 },\n { x: 0.828125, y: 0.140625 },\n { x: 0.828125, y: 0.140625 },\n { x: 0.859375, y: 0.140625 },\n { x: 0.859375, y: 0.140625 },\n { x: 0.890625, y: 0.140625 },\n { x: 0.890625, y: 0.140625 },\n { x: 0.921875, y: 0.140625 },\n { x: 0.921875, y: 0.140625 },\n { x: 0.953125, y: 0.140625 },\n { x: 0.953125, y: 0.140625 },\n { x: 0.984375, y: 0.140625 },\n { x: 0.984375, y: 0.140625 },\n { x: 0.015625, y: 0.171875 },\n { x: 0.015625, y: 0.171875 },\n { x: 0.046875, y: 0.171875 },\n { x: 0.046875, y: 0.171875 },\n { x: 0.078125, y: 0.171875 },\n { x: 0.078125, y: 0.171875 },\n { x: 0.109375, y: 0.171875 },\n { x: 0.109375, y: 0.171875 },\n { x: 0.140625, y: 0.171875 },\n { x: 0.140625, y: 0.171875 },\n { x: 0.171875, y: 0.171875 },\n { x: 0.171875, y: 0.171875 },\n { x: 0.203125, y: 0.171875 },\n { x: 0.203125, y: 0.171875 },\n { x: 0.234375, y: 0.171875 },\n { x: 0.234375, y: 0.171875 },\n { x: 0.265625, y: 0.171875 },\n { x: 0.265625, y: 0.171875 },\n { x: 0.296875, y: 0.171875 },\n { x: 0.296875, y: 0.171875 },\n { x: 0.328125, y: 0.171875 },\n { x: 0.328125, y: 0.171875 },\n { x: 0.359375, y: 0.171875 },\n { x: 0.359375, y: 0.171875 },\n { x: 0.390625, y: 0.171875 },\n { x: 0.390625, y: 0.171875 },\n { x: 0.421875, y: 0.171875 },\n { x: 0.421875, y: 0.171875 },\n { x: 0.453125, y: 0.171875 },\n { x: 0.453125, y: 0.171875 },\n { x: 0.484375, y: 0.171875 },\n { x: 0.484375, y: 0.171875 },\n { x: 0.515625, y: 0.171875 },\n { x: 0.515625, y: 0.171875 },\n { x: 0.546875, y: 0.171875 },\n { x: 0.546875, y: 0.171875 },\n { x: 0.578125, y: 0.171875 },\n { x: 0.578125, y: 0.171875 },\n { x: 0.609375, y: 0.171875 },\n { x: 0.609375, y: 0.171875 },\n { x: 0.640625, y: 0.171875 },\n { x: 0.640625, y: 0.171875 },\n { x: 0.671875, y: 0.171875 },\n { x: 0.671875, y: 0.171875 },\n { x: 0.703125, y: 0.171875 },\n { x: 0.703125, y: 0.171875 },\n { x: 0.734375, y: 0.171875 },\n { x: 0.734375, y: 0.171875 },\n { x: 0.765625, y: 0.171875 },\n { x: 0.765625, y: 0.171875 },\n { x: 0.796875, y: 0.171875 },\n { x: 0.796875, y: 0.171875 },\n { x: 0.828125, y: 0.171875 },\n { x: 0.828125, y: 0.171875 },\n { x: 0.859375, y: 0.171875 },\n { x: 0.859375, y: 0.171875 },\n { x: 0.890625, y: 0.171875 },\n { x: 0.890625, y: 0.171875 },\n { x: 0.921875, y: 0.171875 },\n { x: 0.921875, y: 0.171875 },\n { x: 0.953125, y: 0.171875 },\n { x: 0.953125, y: 0.171875 },\n { x: 0.984375, y: 0.171875 },\n { x: 0.984375, y: 0.171875 },\n { x: 0.015625, y: 0.203125 },\n { x: 0.015625, y: 0.203125 },\n { x: 0.046875, y: 0.203125 },\n { x: 0.046875, y: 0.203125 },\n { x: 0.078125, y: 0.203125 },\n { x: 0.078125, y: 0.203125 },\n { x: 0.109375, y: 0.203125 },\n { x: 0.109375, y: 0.203125 },\n { x: 0.140625, y: 0.203125 },\n { x: 0.140625, y: 0.203125 },\n { x: 0.171875, y: 0.203125 },\n { x: 0.171875, y: 0.203125 },\n { x: 0.203125, y: 0.203125 },\n { x: 0.203125, y: 0.203125 },\n { x: 0.234375, y: 0.203125 },\n { x: 0.234375, y: 0.203125 },\n { x: 0.265625, y: 0.203125 },\n { x: 0.265625, y: 0.203125 },\n { x: 0.296875, y: 0.203125 },\n { x: 0.296875, y: 0.203125 },\n { x: 0.328125, y: 0.203125 },\n { x: 0.328125, y: 0.203125 },\n { x: 0.359375, y: 0.203125 },\n { x: 0.359375, y: 0.203125 },\n { x: 0.390625, y: 0.203125 },\n { x: 0.390625, y: 0.203125 },\n { x: 0.421875, y: 0.203125 },\n { x: 0.421875, y: 0.203125 },\n { x: 0.453125, y: 0.203125 },\n { x: 0.453125, y: 0.203125 },\n { x: 0.484375, y: 0.203125 },\n { x: 0.484375, y: 0.203125 },\n { x: 0.515625, y: 0.203125 },\n { x: 0.515625, y: 0.203125 },\n { x: 0.546875, y: 0.203125 },\n { x: 0.546875, y: 0.203125 },\n { x: 0.578125, y: 0.203125 },\n { x: 0.578125, y: 0.203125 },\n { x: 0.609375, y: 0.203125 },\n { x: 0.609375, y: 0.203125 },\n { x: 0.640625, y: 0.203125 },\n { x: 0.640625, y: 0.203125 },\n { x: 0.671875, y: 0.203125 },\n { x: 0.671875, y: 0.203125 },\n { x: 0.703125, y: 0.203125 },\n { x: 0.703125, y: 0.203125 },\n { x: 0.734375, y: 0.203125 },\n { x: 0.734375, y: 0.203125 },\n { x: 0.765625, y: 0.203125 },\n { x: 0.765625, y: 0.203125 },\n { x: 0.796875, y: 0.203125 },\n { x: 0.796875, y: 0.203125 },\n { x: 0.828125, y: 0.203125 },\n { x: 0.828125, y: 0.203125 },\n { x: 0.859375, y: 0.203125 },\n { x: 0.859375, y: 0.203125 },\n { x: 0.890625, y: 0.203125 },\n { x: 0.890625, y: 0.203125 },\n { x: 0.921875, y: 0.203125 },\n { x: 0.921875, y: 0.203125 },\n { x: 0.953125, y: 0.203125 },\n { x: 0.953125, y: 0.203125 },\n { x: 0.984375, y: 0.203125 },\n { x: 0.984375, y: 0.203125 },\n { x: 0.015625, y: 0.234375 },\n { x: 0.015625, y: 0.234375 },\n { x: 0.046875, y: 0.234375 },\n { x: 0.046875, y: 0.234375 },\n { x: 0.078125, y: 0.234375 },\n { x: 0.078125, y: 0.234375 },\n { x: 0.109375, y: 0.234375 },\n { x: 0.109375, y: 0.234375 },\n { x: 0.140625, y: 0.234375 },\n { x: 0.140625, y: 0.234375 },\n { x: 0.171875, y: 0.234375 },\n { x: 0.171875, y: 0.234375 },\n { x: 0.203125, y: 0.234375 },\n { x: 0.203125, y: 0.234375 },\n { x: 0.234375, y: 0.234375 },\n { x: 0.234375, y: 0.234375 },\n { x: 0.265625, y: 0.234375 },\n { x: 0.265625, y: 0.234375 },\n { x: 0.296875, y: 0.234375 },\n { x: 0.296875, y: 0.234375 },\n { x: 0.328125, y: 0.234375 },\n { x: 0.328125, y: 0.234375 },\n { x: 0.359375, y: 0.234375 },\n { x: 0.359375, y: 0.234375 },\n { x: 0.390625, y: 0.234375 },\n { x: 0.390625, y: 0.234375 },\n { x: 0.421875, y: 0.234375 },\n { x: 0.421875, y: 0.234375 },\n { x: 0.453125, y: 0.234375 },\n { x: 0.453125, y: 0.234375 },\n { x: 0.484375, y: 0.234375 },\n { x: 0.484375, y: 0.234375 },\n { x: 0.515625, y: 0.234375 },\n { x: 0.515625, y: 0.234375 },\n { x: 0.546875, y: 0.234375 },\n { x: 0.546875, y: 0.234375 },\n { x: 0.578125, y: 0.234375 },\n { x: 0.578125, y: 0.234375 },\n { x: 0.609375, y: 0.234375 },\n { x: 0.609375, y: 0.234375 },\n { x: 0.640625, y: 0.234375 },\n { x: 0.640625, y: 0.234375 },\n { x: 0.671875, y: 0.234375 },\n { x: 0.671875, y: 0.234375 },\n { x: 0.703125, y: 0.234375 },\n { x: 0.703125, y: 0.234375 },\n { x: 0.734375, y: 0.234375 },\n { x: 0.734375, y: 0.234375 },\n { x: 0.765625, y: 0.234375 },\n { x: 0.765625, y: 0.234375 },\n { x: 0.796875, y: 0.234375 },\n { x: 0.796875, y: 0.234375 },\n { x: 0.828125, y: 0.234375 },\n { x: 0.828125, y: 0.234375 },\n { x: 0.859375, y: 0.234375 },\n { x: 0.859375, y: 0.234375 },\n { x: 0.890625, y: 0.234375 },\n { x: 0.890625, y: 0.234375 },\n { x: 0.921875, y: 0.234375 },\n { x: 0.921875, y: 0.234375 },\n { x: 0.953125, y: 0.234375 },\n { x: 0.953125, y: 0.234375 },\n { x: 0.984375, y: 0.234375 },\n { x: 0.984375, y: 0.234375 },\n { x: 0.015625, y: 0.265625 },\n { x: 0.015625, y: 0.265625 },\n { x: 0.046875, y: 0.265625 },\n { x: 0.046875, y: 0.265625 },\n { x: 0.078125, y: 0.265625 },\n { x: 0.078125, y: 0.265625 },\n { x: 0.109375, y: 0.265625 },\n { x: 0.109375, y: 0.265625 },\n { x: 0.140625, y: 0.265625 },\n { x: 0.140625, y: 0.265625 },\n { x: 0.171875, y: 0.265625 },\n { x: 0.171875, y: 0.265625 },\n { x: 0.203125, y: 0.265625 },\n { x: 0.203125, y: 0.265625 },\n { x: 0.234375, y: 0.265625 },\n { x: 0.234375, y: 0.265625 },\n { x: 0.265625, y: 0.265625 },\n { x: 0.265625, y: 0.265625 },\n { x: 0.296875, y: 0.265625 },\n { x: 0.296875, y: 0.265625 },\n { x: 0.328125, y: 0.265625 },\n { x: 0.328125, y: 0.265625 },\n { x: 0.359375, y: 0.265625 },\n { x: 0.359375, y: 0.265625 },\n { x: 0.390625, y: 0.265625 },\n { x: 0.390625, y: 0.265625 },\n { x: 0.421875, y: 0.265625 },\n { x: 0.421875, y: 0.265625 },\n { x: 0.453125, y: 0.265625 },\n { x: 0.453125, y: 0.265625 },\n { x: 0.484375, y: 0.265625 },\n { x: 0.484375, y: 0.265625 },\n { x: 0.515625, y: 0.265625 },\n { x: 0.515625, y: 0.265625 },\n { x: 0.546875, y: 0.265625 },\n { x: 0.546875, y: 0.265625 },\n { x: 0.578125, y: 0.265625 },\n { x: 0.578125, y: 0.265625 },\n { x: 0.609375, y: 0.265625 },\n { x: 0.609375, y: 0.265625 },\n { x: 0.640625, y: 0.265625 },\n { x: 0.640625, y: 0.265625 },\n { x: 0.671875, y: 0.265625 },\n { x: 0.671875, y: 0.265625 },\n { x: 0.703125, y: 0.265625 },\n { x: 0.703125, y: 0.265625 },\n { x: 0.734375, y: 0.265625 },\n { x: 0.734375, y: 0.265625 },\n { x: 0.765625, y: 0.265625 },\n { x: 0.765625, y: 0.265625 },\n { x: 0.796875, y: 0.265625 },\n { x: 0.796875, y: 0.265625 },\n { x: 0.828125, y: 0.265625 },\n { x: 0.828125, y: 0.265625 },\n { x: 0.859375, y: 0.265625 },\n { x: 0.859375, y: 0.265625 },\n { x: 0.890625, y: 0.265625 },\n { x: 0.890625, y: 0.265625 },\n { x: 0.921875, y: 0.265625 },\n { x: 0.921875, y: 0.265625 },\n { x: 0.953125, y: 0.265625 },\n { x: 0.953125, y: 0.265625 },\n { x: 0.984375, y: 0.265625 },\n { x: 0.984375, y: 0.265625 },\n { x: 0.015625, y: 0.296875 },\n { x: 0.015625, y: 0.296875 },\n { x: 0.046875, y: 0.296875 },\n { x: 0.046875, y: 0.296875 },\n { x: 0.078125, y: 0.296875 },\n { x: 0.078125, y: 0.296875 },\n { x: 0.109375, y: 0.296875 },\n { x: 0.109375, y: 0.296875 },\n { x: 0.140625, y: 0.296875 },\n { x: 0.140625, y: 0.296875 },\n { x: 0.171875, y: 0.296875 },\n { x: 0.171875, y: 0.296875 },\n { x: 0.203125, y: 0.296875 },\n { x: 0.203125, y: 0.296875 },\n { x: 0.234375, y: 0.296875 },\n { x: 0.234375, y: 0.296875 },\n { x: 0.265625, y: 0.296875 },\n { x: 0.265625, y: 0.296875 },\n { x: 0.296875, y: 0.296875 },\n { x: 0.296875, y: 0.296875 },\n { x: 0.328125, y: 0.296875 },\n { x: 0.328125, y: 0.296875 },\n { x: 0.359375, y: 0.296875 },\n { x: 0.359375, y: 0.296875 },\n { x: 0.390625, y: 0.296875 },\n { x: 0.390625, y: 0.296875 },\n { x: 0.421875, y: 0.296875 },\n { x: 0.421875, y: 0.296875 },\n { x: 0.453125, y: 0.296875 },\n { x: 0.453125, y: 0.296875 },\n { x: 0.484375, y: 0.296875 },\n { x: 0.484375, y: 0.296875 },\n { x: 0.515625, y: 0.296875 },\n { x: 0.515625, y: 0.296875 },\n { x: 0.546875, y: 0.296875 },\n { x: 0.546875, y: 0.296875 },\n { x: 0.578125, y: 0.296875 },\n { x: 0.578125, y: 0.296875 },\n { x: 0.609375, y: 0.296875 },\n { x: 0.609375, y: 0.296875 },\n { x: 0.640625, y: 0.296875 },\n { x: 0.640625, y: 0.296875 },\n { x: 0.671875, y: 0.296875 },\n { x: 0.671875, y: 0.296875 },\n { x: 0.703125, y: 0.296875 },\n { x: 0.703125, y: 0.296875 },\n { x: 0.734375, y: 0.296875 },\n { x: 0.734375, y: 0.296875 },\n { x: 0.765625, y: 0.296875 },\n { x: 0.765625, y: 0.296875 },\n { x: 0.796875, y: 0.296875 },\n { x: 0.796875, y: 0.296875 },\n { x: 0.828125, y: 0.296875 },\n { x: 0.828125, y: 0.296875 },\n { x: 0.859375, y: 0.296875 },\n { x: 0.859375, y: 0.296875 },\n { x: 0.890625, y: 0.296875 },\n { x: 0.890625, y: 0.296875 },\n { x: 0.921875, y: 0.296875 },\n { x: 0.921875, y: 0.296875 },\n { x: 0.953125, y: 0.296875 },\n { x: 0.953125, y: 0.296875 },\n { x: 0.984375, y: 0.296875 },\n { x: 0.984375, y: 0.296875 },\n { x: 0.015625, y: 0.328125 },\n { x: 0.015625, y: 0.328125 },\n { x: 0.046875, y: 0.328125 },\n { x: 0.046875, y: 0.328125 },\n { x: 0.078125, y: 0.328125 },\n { x: 0.078125, y: 0.328125 },\n { x: 0.109375, y: 0.328125 },\n { x: 0.109375, y: 0.328125 },\n { x: 0.140625, y: 0.328125 },\n { x: 0.140625, y: 0.328125 },\n { x: 0.171875, y: 0.328125 },\n { x: 0.171875, y: 0.328125 },\n { x: 0.203125, y: 0.328125 },\n { x: 0.203125, y: 0.328125 },\n { x: 0.234375, y: 0.328125 },\n { x: 0.234375, y: 0.328125 },\n { x: 0.265625, y: 0.328125 },\n { x: 0.265625, y: 0.328125 },\n { x: 0.296875, y: 0.328125 },\n { x: 0.296875, y: 0.328125 },\n { x: 0.328125, y: 0.328125 },\n { x: 0.328125, y: 0.328125 },\n { x: 0.359375, y: 0.328125 },\n { x: 0.359375, y: 0.328125 },\n { x: 0.390625, y: 0.328125 },\n { x: 0.390625, y: 0.328125 },\n { x: 0.421875, y: 0.328125 },\n { x: 0.421875, y: 0.328125 },\n { x: 0.453125, y: 0.328125 },\n { x: 0.453125, y: 0.328125 },\n { x: 0.484375, y: 0.328125 },\n { x: 0.484375, y: 0.328125 },\n { x: 0.515625, y: 0.328125 },\n { x: 0.515625, y: 0.328125 },\n { x: 0.546875, y: 0.328125 },\n { x: 0.546875, y: 0.328125 },\n { x: 0.578125, y: 0.328125 },\n { x: 0.578125, y: 0.328125 },\n { x: 0.609375, y: 0.328125 },\n { x: 0.609375, y: 0.328125 },\n { x: 0.640625, y: 0.328125 },\n { x: 0.640625, y: 0.328125 },\n { x: 0.671875, y: 0.328125 },\n { x: 0.671875, y: 0.328125 },\n { x: 0.703125, y: 0.328125 },\n { x: 0.703125, y: 0.328125 },\n { x: 0.734375, y: 0.328125 },\n { x: 0.734375, y: 0.328125 },\n { x: 0.765625, y: 0.328125 },\n { x: 0.765625, y: 0.328125 },\n { x: 0.796875, y: 0.328125 },\n { x: 0.796875, y: 0.328125 },\n { x: 0.828125, y: 0.328125 },\n { x: 0.828125, y: 0.328125 },\n { x: 0.859375, y: 0.328125 },\n { x: 0.859375, y: 0.328125 },\n { x: 0.890625, y: 0.328125 },\n { x: 0.890625, y: 0.328125 },\n { x: 0.921875, y: 0.328125 },\n { x: 0.921875, y: 0.328125 },\n { x: 0.953125, y: 0.328125 },\n { x: 0.953125, y: 0.328125 },\n { x: 0.984375, y: 0.328125 },\n { x: 0.984375, y: 0.328125 },\n { x: 0.015625, y: 0.359375 },\n { x: 0.015625, y: 0.359375 },\n { x: 0.046875, y: 0.359375 },\n { x: 0.046875, y: 0.359375 },\n { x: 0.078125, y: 0.359375 },\n { x: 0.078125, y: 0.359375 },\n { x: 0.109375, y: 0.359375 },\n { x: 0.109375, y: 0.359375 },\n { x: 0.140625, y: 0.359375 },\n { x: 0.140625, y: 0.359375 },\n { x: 0.171875, y: 0.359375 },\n { x: 0.171875, y: 0.359375 },\n { x: 0.203125, y: 0.359375 },\n { x: 0.203125, y: 0.359375 },\n { x: 0.234375, y: 0.359375 },\n { x: 0.234375, y: 0.359375 },\n { x: 0.265625, y: 0.359375 },\n { x: 0.265625, y: 0.359375 },\n { x: 0.296875, y: 0.359375 },\n { x: 0.296875, y: 0.359375 },\n { x: 0.328125, y: 0.359375 },\n { x: 0.328125, y: 0.359375 },\n { x: 0.359375, y: 0.359375 },\n { x: 0.359375, y: 0.359375 },\n { x: 0.390625, y: 0.359375 },\n { x: 0.390625, y: 0.359375 },\n { x: 0.421875, y: 0.359375 },\n { x: 0.421875, y: 0.359375 },\n { x: 0.453125, y: 0.359375 },\n { x: 0.453125, y: 0.359375 },\n { x: 0.484375, y: 0.359375 },\n { x: 0.484375, y: 0.359375 },\n { x: 0.515625, y: 0.359375 },\n { x: 0.515625, y: 0.359375 },\n { x: 0.546875, y: 0.359375 },\n { x: 0.546875, y: 0.359375 },\n { x: 0.578125, y: 0.359375 },\n { x: 0.578125, y: 0.359375 },\n { x: 0.609375, y: 0.359375 },\n { x: 0.609375, y: 0.359375 },\n { x: 0.640625, y: 0.359375 },\n { x: 0.640625, y: 0.359375 },\n { x: 0.671875, y: 0.359375 },\n { x: 0.671875, y: 0.359375 },\n { x: 0.703125, y: 0.359375 },\n { x: 0.703125, y: 0.359375 },\n { x: 0.734375, y: 0.359375 },\n { x: 0.734375, y: 0.359375 },\n { x: 0.765625, y: 0.359375 },\n { x: 0.765625, y: 0.359375 },\n { x: 0.796875, y: 0.359375 },\n { x: 0.796875, y: 0.359375 },\n { x: 0.828125, y: 0.359375 },\n { x: 0.828125, y: 0.359375 },\n { x: 0.859375, y: 0.359375 },\n { x: 0.859375, y: 0.359375 },\n { x: 0.890625, y: 0.359375 },\n { x: 0.890625, y: 0.359375 },\n { x: 0.921875, y: 0.359375 },\n { x: 0.921875, y: 0.359375 },\n { x: 0.953125, y: 0.359375 },\n { x: 0.953125, y: 0.359375 },\n { x: 0.984375, y: 0.359375 },\n { x: 0.984375, y: 0.359375 },\n { x: 0.015625, y: 0.390625 },\n { x: 0.015625, y: 0.390625 },\n { x: 0.046875, y: 0.390625 },\n { x: 0.046875, y: 0.390625 },\n { x: 0.078125, y: 0.390625 },\n { x: 0.078125, y: 0.390625 },\n { x: 0.109375, y: 0.390625 },\n { x: 0.109375, y: 0.390625 },\n { x: 0.140625, y: 0.390625 },\n { x: 0.140625, y: 0.390625 },\n { x: 0.171875, y: 0.390625 },\n { x: 0.171875, y: 0.390625 },\n { x: 0.203125, y: 0.390625 },\n { x: 0.203125, y: 0.390625 },\n { x: 0.234375, y: 0.390625 },\n { x: 0.234375, y: 0.390625 },\n { x: 0.265625, y: 0.390625 },\n { x: 0.265625, y: 0.390625 },\n { x: 0.296875, y: 0.390625 },\n { x: 0.296875, y: 0.390625 },\n { x: 0.328125, y: 0.390625 },\n { x: 0.328125, y: 0.390625 },\n { x: 0.359375, y: 0.390625 },\n { x: 0.359375, y: 0.390625 },\n { x: 0.390625, y: 0.390625 },\n { x: 0.390625, y: 0.390625 },\n { x: 0.421875, y: 0.390625 },\n { x: 0.421875, y: 0.390625 },\n { x: 0.453125, y: 0.390625 },\n { x: 0.453125, y: 0.390625 },\n { x: 0.484375, y: 0.390625 },\n { x: 0.484375, y: 0.390625 },\n { x: 0.515625, y: 0.390625 },\n { x: 0.515625, y: 0.390625 },\n { x: 0.546875, y: 0.390625 },\n { x: 0.546875, y: 0.390625 },\n { x: 0.578125, y: 0.390625 },\n { x: 0.578125, y: 0.390625 },\n { x: 0.609375, y: 0.390625 },\n { x: 0.609375, y: 0.390625 },\n { x: 0.640625, y: 0.390625 },\n { x: 0.640625, y: 0.390625 },\n { x: 0.671875, y: 0.390625 },\n { x: 0.671875, y: 0.390625 },\n { x: 0.703125, y: 0.390625 },\n { x: 0.703125, y: 0.390625 },\n { x: 0.734375, y: 0.390625 },\n { x: 0.734375, y: 0.390625 },\n { x: 0.765625, y: 0.390625 },\n { x: 0.765625, y: 0.390625 },\n { x: 0.796875, y: 0.390625 },\n { x: 0.796875, y: 0.390625 },\n { x: 0.828125, y: 0.390625 },\n { x: 0.828125, y: 0.390625 },\n { x: 0.859375, y: 0.390625 },\n { x: 0.859375, y: 0.390625 },\n { x: 0.890625, y: 0.390625 },\n { x: 0.890625, y: 0.390625 },\n { x: 0.921875, y: 0.390625 },\n { x: 0.921875, y: 0.390625 },\n { x: 0.953125, y: 0.390625 },\n { x: 0.953125, y: 0.390625 },\n { x: 0.984375, y: 0.390625 },\n { x: 0.984375, y: 0.390625 },\n { x: 0.015625, y: 0.421875 },\n { x: 0.015625, y: 0.421875 },\n { x: 0.046875, y: 0.421875 },\n { x: 0.046875, y: 0.421875 },\n { x: 0.078125, y: 0.421875 },\n { x: 0.078125, y: 0.421875 },\n { x: 0.109375, y: 0.421875 },\n { x: 0.109375, y: 0.421875 },\n { x: 0.140625, y: 0.421875 },\n { x: 0.140625, y: 0.421875 },\n { x: 0.171875, y: 0.421875 },\n { x: 0.171875, y: 0.421875 },\n { x: 0.203125, y: 0.421875 },\n { x: 0.203125, y: 0.421875 },\n { x: 0.234375, y: 0.421875 },\n { x: 0.234375, y: 0.421875 },\n { x: 0.265625, y: 0.421875 },\n { x: 0.265625, y: 0.421875 },\n { x: 0.296875, y: 0.421875 },\n { x: 0.296875, y: 0.421875 },\n { x: 0.328125, y: 0.421875 },\n { x: 0.328125, y: 0.421875 },\n { x: 0.359375, y: 0.421875 },\n { x: 0.359375, y: 0.421875 },\n { x: 0.390625, y: 0.421875 },\n { x: 0.390625, y: 0.421875 },\n { x: 0.421875, y: 0.421875 },\n { x: 0.421875, y: 0.421875 },\n { x: 0.453125, y: 0.421875 },\n { x: 0.453125, y: 0.421875 },\n { x: 0.484375, y: 0.421875 },\n { x: 0.484375, y: 0.421875 },\n { x: 0.515625, y: 0.421875 },\n { x: 0.515625, y: 0.421875 },\n { x: 0.546875, y: 0.421875 },\n { x: 0.546875, y: 0.421875 },\n { x: 0.578125, y: 0.421875 },\n { x: 0.578125, y: 0.421875 },\n { x: 0.609375, y: 0.421875 },\n { x: 0.609375, y: 0.421875 },\n { x: 0.640625, y: 0.421875 },\n { x: 0.640625, y: 0.421875 },\n { x: 0.671875, y: 0.421875 },\n { x: 0.671875, y: 0.421875 },\n { x: 0.703125, y: 0.421875 },\n { x: 0.703125, y: 0.421875 },\n { x: 0.734375, y: 0.421875 },\n { x: 0.734375, y: 0.421875 },\n { x: 0.765625, y: 0.421875 },\n { x: 0.765625, y: 0.421875 },\n { x: 0.796875, y: 0.421875 },\n { x: 0.796875, y: 0.421875 },\n { x: 0.828125, y: 0.421875 },\n { x: 0.828125, y: 0.421875 },\n { x: 0.859375, y: 0.421875 },\n { x: 0.859375, y: 0.421875 },\n { x: 0.890625, y: 0.421875 },\n { x: 0.890625, y: 0.421875 },\n { x: 0.921875, y: 0.421875 },\n { x: 0.921875, y: 0.421875 },\n { x: 0.953125, y: 0.421875 },\n { x: 0.953125, y: 0.421875 },\n { x: 0.984375, y: 0.421875 },\n { x: 0.984375, y: 0.421875 },\n { x: 0.015625, y: 0.453125 },\n { x: 0.015625, y: 0.453125 },\n { x: 0.046875, y: 0.453125 },\n { x: 0.046875, y: 0.453125 },\n { x: 0.078125, y: 0.453125 },\n { x: 0.078125, y: 0.453125 },\n { x: 0.109375, y: 0.453125 },\n { x: 0.109375, y: 0.453125 },\n { x: 0.140625, y: 0.453125 },\n { x: 0.140625, y: 0.453125 },\n { x: 0.171875, y: 0.453125 },\n { x: 0.171875, y: 0.453125 },\n { x: 0.203125, y: 0.453125 },\n { x: 0.203125, y: 0.453125 },\n { x: 0.234375, y: 0.453125 },\n { x: 0.234375, y: 0.453125 },\n { x: 0.265625, y: 0.453125 },\n { x: 0.265625, y: 0.453125 },\n { x: 0.296875, y: 0.453125 },\n { x: 0.296875, y: 0.453125 },\n { x: 0.328125, y: 0.453125 },\n { x: 0.328125, y: 0.453125 },\n { x: 0.359375, y: 0.453125 },\n { x: 0.359375, y: 0.453125 },\n { x: 0.390625, y: 0.453125 },\n { x: 0.390625, y: 0.453125 },\n { x: 0.421875, y: 0.453125 },\n { x: 0.421875, y: 0.453125 },\n { x: 0.453125, y: 0.453125 },\n { x: 0.453125, y: 0.453125 },\n { x: 0.484375, y: 0.453125 },\n { x: 0.484375, y: 0.453125 },\n { x: 0.515625, y: 0.453125 },\n { x: 0.515625, y: 0.453125 },\n { x: 0.546875, y: 0.453125 },\n { x: 0.546875, y: 0.453125 },\n { x: 0.578125, y: 0.453125 },\n { x: 0.578125, y: 0.453125 },\n { x: 0.609375, y: 0.453125 },\n { x: 0.609375, y: 0.453125 },\n { x: 0.640625, y: 0.453125 },\n { x: 0.640625, y: 0.453125 },\n { x: 0.671875, y: 0.453125 },\n { x: 0.671875, y: 0.453125 },\n { x: 0.703125, y: 0.453125 },\n { x: 0.703125, y: 0.453125 },\n { x: 0.734375, y: 0.453125 },\n { x: 0.734375, y: 0.453125 },\n { x: 0.765625, y: 0.453125 },\n { x: 0.765625, y: 0.453125 },\n { x: 0.796875, y: 0.453125 },\n { x: 0.796875, y: 0.453125 },\n { x: 0.828125, y: 0.453125 },\n { x: 0.828125, y: 0.453125 },\n { x: 0.859375, y: 0.453125 },\n { x: 0.859375, y: 0.453125 },\n { x: 0.890625, y: 0.453125 },\n { x: 0.890625, y: 0.453125 },\n { x: 0.921875, y: 0.453125 },\n { x: 0.921875, y: 0.453125 },\n { x: 0.953125, y: 0.453125 },\n { x: 0.953125, y: 0.453125 },\n { x: 0.984375, y: 0.453125 },\n { x: 0.984375, y: 0.453125 },\n { x: 0.015625, y: 0.484375 },\n { x: 0.015625, y: 0.484375 },\n { x: 0.046875, y: 0.484375 },\n { x: 0.046875, y: 0.484375 },\n { x: 0.078125, y: 0.484375 },\n { x: 0.078125, y: 0.484375 },\n { x: 0.109375, y: 0.484375 },\n { x: 0.109375, y: 0.484375 },\n { x: 0.140625, y: 0.484375 },\n { x: 0.140625, y: 0.484375 },\n { x: 0.171875, y: 0.484375 },\n { x: 0.171875, y: 0.484375 },\n { x: 0.203125, y: 0.484375 },\n { x: 0.203125, y: 0.484375 },\n { x: 0.234375, y: 0.484375 },\n { x: 0.234375, y: 0.484375 },\n { x: 0.265625, y: 0.484375 },\n { x: 0.265625, y: 0.484375 },\n { x: 0.296875, y: 0.484375 },\n { x: 0.296875, y: 0.484375 },\n { x: 0.328125, y: 0.484375 },\n { x: 0.328125, y: 0.484375 },\n { x: 0.359375, y: 0.484375 },\n { x: 0.359375, y: 0.484375 },\n { x: 0.390625, y: 0.484375 },\n { x: 0.390625, y: 0.484375 },\n { x: 0.421875, y: 0.484375 },\n { x: 0.421875, y: 0.484375 },\n { x: 0.453125, y: 0.484375 },\n { x: 0.453125, y: 0.484375 },\n { x: 0.484375, y: 0.484375 },\n { x: 0.484375, y: 0.484375 },\n { x: 0.515625, y: 0.484375 },\n { x: 0.515625, y: 0.484375 },\n { x: 0.546875, y: 0.484375 },\n { x: 0.546875, y: 0.484375 },\n { x: 0.578125, y: 0.484375 },\n { x: 0.578125, y: 0.484375 },\n { x: 0.609375, y: 0.484375 },\n { x: 0.609375, y: 0.484375 },\n { x: 0.640625, y: 0.484375 },\n { x: 0.640625, y: 0.484375 },\n { x: 0.671875, y: 0.484375 },\n { x: 0.671875, y: 0.484375 },\n { x: 0.703125, y: 0.484375 },\n { x: 0.703125, y: 0.484375 },\n { x: 0.734375, y: 0.484375 },\n { x: 0.734375, y: 0.484375 },\n { x: 0.765625, y: 0.484375 },\n { x: 0.765625, y: 0.484375 },\n { x: 0.796875, y: 0.484375 },\n { x: 0.796875, y: 0.484375 },\n { x: 0.828125, y: 0.484375 },\n { x: 0.828125, y: 0.484375 },\n { x: 0.859375, y: 0.484375 },\n { x: 0.859375, y: 0.484375 },\n { x: 0.890625, y: 0.484375 },\n { x: 0.890625, y: 0.484375 },\n { x: 0.921875, y: 0.484375 },\n { x: 0.921875, y: 0.484375 },\n { x: 0.953125, y: 0.484375 },\n { x: 0.953125, y: 0.484375 },\n { x: 0.984375, y: 0.484375 },\n { x: 0.984375, y: 0.484375 },\n { x: 0.015625, y: 0.515625 },\n { x: 0.015625, y: 0.515625 },\n { x: 0.046875, y: 0.515625 },\n { x: 0.046875, y: 0.515625 },\n { x: 0.078125, y: 0.515625 },\n { x: 0.078125, y: 0.515625 },\n { x: 0.109375, y: 0.515625 },\n { x: 0.109375, y: 0.515625 },\n { x: 0.140625, y: 0.515625 },\n { x: 0.140625, y: 0.515625 },\n { x: 0.171875, y: 0.515625 },\n { x: 0.171875, y: 0.515625 },\n { x: 0.203125, y: 0.515625 },\n { x: 0.203125, y: 0.515625 },\n { x: 0.234375, y: 0.515625 },\n { x: 0.234375, y: 0.515625 },\n { x: 0.265625, y: 0.515625 },\n { x: 0.265625, y: 0.515625 },\n { x: 0.296875, y: 0.515625 },\n { x: 0.296875, y: 0.515625 },\n { x: 0.328125, y: 0.515625 },\n { x: 0.328125, y: 0.515625 },\n { x: 0.359375, y: 0.515625 },\n { x: 0.359375, y: 0.515625 },\n { x: 0.390625, y: 0.515625 },\n { x: 0.390625, y: 0.515625 },\n { x: 0.421875, y: 0.515625 },\n { x: 0.421875, y: 0.515625 },\n { x: 0.453125, y: 0.515625 },\n { x: 0.453125, y: 0.515625 },\n { x: 0.484375, y: 0.515625 },\n { x: 0.484375, y: 0.515625 },\n { x: 0.515625, y: 0.515625 },\n { x: 0.515625, y: 0.515625 },\n { x: 0.546875, y: 0.515625 },\n { x: 0.546875, y: 0.515625 },\n { x: 0.578125, y: 0.515625 },\n { x: 0.578125, y: 0.515625 },\n { x: 0.609375, y: 0.515625 },\n { x: 0.609375, y: 0.515625 },\n { x: 0.640625, y: 0.515625 },\n { x: 0.640625, y: 0.515625 },\n { x: 0.671875, y: 0.515625 },\n { x: 0.671875, y: 0.515625 },\n { x: 0.703125, y: 0.515625 },\n { x: 0.703125, y: 0.515625 },\n { x: 0.734375, y: 0.515625 },\n { x: 0.734375, y: 0.515625 },\n { x: 0.765625, y: 0.515625 },\n { x: 0.765625, y: 0.515625 },\n { x: 0.796875, y: 0.515625 },\n { x: 0.796875, y: 0.515625 },\n { x: 0.828125, y: 0.515625 },\n { x: 0.828125, y: 0.515625 },\n { x: 0.859375, y: 0.515625 },\n { x: 0.859375, y: 0.515625 },\n { x: 0.890625, y: 0.515625 },\n { x: 0.890625, y: 0.515625 },\n { x: 0.921875, y: 0.515625 },\n { x: 0.921875, y: 0.515625 },\n { x: 0.953125, y: 0.515625 },\n { x: 0.953125, y: 0.515625 },\n { x: 0.984375, y: 0.515625 },\n { x: 0.984375, y: 0.515625 },\n { x: 0.015625, y: 0.546875 },\n { x: 0.015625, y: 0.546875 },\n { x: 0.046875, y: 0.546875 },\n { x: 0.046875, y: 0.546875 },\n { x: 0.078125, y: 0.546875 },\n { x: 0.078125, y: 0.546875 },\n { x: 0.109375, y: 0.546875 },\n { x: 0.109375, y: 0.546875 },\n { x: 0.140625, y: 0.546875 },\n { x: 0.140625, y: 0.546875 },\n { x: 0.171875, y: 0.546875 },\n { x: 0.171875, y: 0.546875 },\n { x: 0.203125, y: 0.546875 },\n { x: 0.203125, y: 0.546875 },\n { x: 0.234375, y: 0.546875 },\n { x: 0.234375, y: 0.546875 },\n { x: 0.265625, y: 0.546875 },\n { x: 0.265625, y: 0.546875 },\n { x: 0.296875, y: 0.546875 },\n { x: 0.296875, y: 0.546875 },\n { x: 0.328125, y: 0.546875 },\n { x: 0.328125, y: 0.546875 },\n { x: 0.359375, y: 0.546875 },\n { x: 0.359375, y: 0.546875 },\n { x: 0.390625, y: 0.546875 },\n { x: 0.390625, y: 0.546875 },\n { x: 0.421875, y: 0.546875 },\n { x: 0.421875, y: 0.546875 },\n { x: 0.453125, y: 0.546875 },\n { x: 0.453125, y: 0.546875 },\n { x: 0.484375, y: 0.546875 },\n { x: 0.484375, y: 0.546875 },\n { x: 0.515625, y: 0.546875 },\n { x: 0.515625, y: 0.546875 },\n { x: 0.546875, y: 0.546875 },\n { x: 0.546875, y: 0.546875 },\n { x: 0.578125, y: 0.546875 },\n { x: 0.578125, y: 0.546875 },\n { x: 0.609375, y: 0.546875 },\n { x: 0.609375, y: 0.546875 },\n { x: 0.640625, y: 0.546875 },\n { x: 0.640625, y: 0.546875 },\n { x: 0.671875, y: 0.546875 },\n { x: 0.671875, y: 0.546875 },\n { x: 0.703125, y: 0.546875 },\n { x: 0.703125, y: 0.546875 },\n { x: 0.734375, y: 0.546875 },\n { x: 0.734375, y: 0.546875 },\n { x: 0.765625, y: 0.546875 },\n { x: 0.765625, y: 0.546875 },\n { x: 0.796875, y: 0.546875 },\n { x: 0.796875, y: 0.546875 },\n { x: 0.828125, y: 0.546875 },\n { x: 0.828125, y: 0.546875 },\n { x: 0.859375, y: 0.546875 },\n { x: 0.859375, y: 0.546875 },\n { x: 0.890625, y: 0.546875 },\n { x: 0.890625, y: 0.546875 },\n { x: 0.921875, y: 0.546875 },\n { x: 0.921875, y: 0.546875 },\n { x: 0.953125, y: 0.546875 },\n { x: 0.953125, y: 0.546875 },\n { x: 0.984375, y: 0.546875 },\n { x: 0.984375, y: 0.546875 },\n { x: 0.015625, y: 0.578125 },\n { x: 0.015625, y: 0.578125 },\n { x: 0.046875, y: 0.578125 },\n { x: 0.046875, y: 0.578125 },\n { x: 0.078125, y: 0.578125 },\n { x: 0.078125, y: 0.578125 },\n { x: 0.109375, y: 0.578125 },\n { x: 0.109375, y: 0.578125 },\n { x: 0.140625, y: 0.578125 },\n { x: 0.140625, y: 0.578125 },\n { x: 0.171875, y: 0.578125 },\n { x: 0.171875, y: 0.578125 },\n { x: 0.203125, y: 0.578125 },\n { x: 0.203125, y: 0.578125 },\n { x: 0.234375, y: 0.578125 },\n { x: 0.234375, y: 0.578125 },\n { x: 0.265625, y: 0.578125 },\n { x: 0.265625, y: 0.578125 },\n { x: 0.296875, y: 0.578125 },\n { x: 0.296875, y: 0.578125 },\n { x: 0.328125, y: 0.578125 },\n { x: 0.328125, y: 0.578125 },\n { x: 0.359375, y: 0.578125 },\n { x: 0.359375, y: 0.578125 },\n { x: 0.390625, y: 0.578125 },\n { x: 0.390625, y: 0.578125 },\n { x: 0.421875, y: 0.578125 },\n { x: 0.421875, y: 0.578125 },\n { x: 0.453125, y: 0.578125 },\n { x: 0.453125, y: 0.578125 },\n { x: 0.484375, y: 0.578125 },\n { x: 0.484375, y: 0.578125 },\n { x: 0.515625, y: 0.578125 },\n { x: 0.515625, y: 0.578125 },\n { x: 0.546875, y: 0.578125 },\n { x: 0.546875, y: 0.578125 },\n { x: 0.578125, y: 0.578125 },\n { x: 0.578125, y: 0.578125 },\n { x: 0.609375, y: 0.578125 },\n { x: 0.609375, y: 0.578125 },\n { x: 0.640625, y: 0.578125 },\n { x: 0.640625, y: 0.578125 },\n { x: 0.671875, y: 0.578125 },\n { x: 0.671875, y: 0.578125 },\n { x: 0.703125, y: 0.578125 },\n { x: 0.703125, y: 0.578125 },\n { x: 0.734375, y: 0.578125 },\n { x: 0.734375, y: 0.578125 },\n { x: 0.765625, y: 0.578125 },\n { x: 0.765625, y: 0.578125 },\n { x: 0.796875, y: 0.578125 },\n { x: 0.796875, y: 0.578125 },\n { x: 0.828125, y: 0.578125 },\n { x: 0.828125, y: 0.578125 },\n { x: 0.859375, y: 0.578125 },\n { x: 0.859375, y: 0.578125 },\n { x: 0.890625, y: 0.578125 },\n { x: 0.890625, y: 0.578125 },\n { x: 0.921875, y: 0.578125 },\n { x: 0.921875, y: 0.578125 },\n { x: 0.953125, y: 0.578125 },\n { x: 0.953125, y: 0.578125 },\n { x: 0.984375, y: 0.578125 },\n { x: 0.984375, y: 0.578125 },\n { x: 0.015625, y: 0.609375 },\n { x: 0.015625, y: 0.609375 },\n { x: 0.046875, y: 0.609375 },\n { x: 0.046875, y: 0.609375 },\n { x: 0.078125, y: 0.609375 },\n { x: 0.078125, y: 0.609375 },\n { x: 0.109375, y: 0.609375 },\n { x: 0.109375, y: 0.609375 },\n { x: 0.140625, y: 0.609375 },\n { x: 0.140625, y: 0.609375 },\n { x: 0.171875, y: 0.609375 },\n { x: 0.171875, y: 0.609375 },\n { x: 0.203125, y: 0.609375 },\n { x: 0.203125, y: 0.609375 },\n { x: 0.234375, y: 0.609375 },\n { x: 0.234375, y: 0.609375 },\n { x: 0.265625, y: 0.609375 },\n { x: 0.265625, y: 0.609375 },\n { x: 0.296875, y: 0.609375 },\n { x: 0.296875, y: 0.609375 },\n { x: 0.328125, y: 0.609375 },\n { x: 0.328125, y: 0.609375 },\n { x: 0.359375, y: 0.609375 },\n { x: 0.359375, y: 0.609375 },\n { x: 0.390625, y: 0.609375 },\n { x: 0.390625, y: 0.609375 },\n { x: 0.421875, y: 0.609375 },\n { x: 0.421875, y: 0.609375 },\n { x: 0.453125, y: 0.609375 },\n { x: 0.453125, y: 0.609375 },\n { x: 0.484375, y: 0.609375 },\n { x: 0.484375, y: 0.609375 },\n { x: 0.515625, y: 0.609375 },\n { x: 0.515625, y: 0.609375 },\n { x: 0.546875, y: 0.609375 },\n { x: 0.546875, y: 0.609375 },\n { x: 0.578125, y: 0.609375 },\n { x: 0.578125, y: 0.609375 },\n { x: 0.609375, y: 0.609375 },\n { x: 0.609375, y: 0.609375 },\n { x: 0.640625, y: 0.609375 },\n { x: 0.640625, y: 0.609375 },\n { x: 0.671875, y: 0.609375 },\n { x: 0.671875, y: 0.609375 },\n { x: 0.703125, y: 0.609375 },\n { x: 0.703125, y: 0.609375 },\n { x: 0.734375, y: 0.609375 },\n { x: 0.734375, y: 0.609375 },\n { x: 0.765625, y: 0.609375 },\n { x: 0.765625, y: 0.609375 },\n { x: 0.796875, y: 0.609375 },\n { x: 0.796875, y: 0.609375 },\n { x: 0.828125, y: 0.609375 },\n { x: 0.828125, y: 0.609375 },\n { x: 0.859375, y: 0.609375 },\n { x: 0.859375, y: 0.609375 },\n { x: 0.890625, y: 0.609375 },\n { x: 0.890625, y: 0.609375 },\n { x: 0.921875, y: 0.609375 },\n { x: 0.921875, y: 0.609375 },\n { x: 0.953125, y: 0.609375 },\n { x: 0.953125, y: 0.609375 },\n { x: 0.984375, y: 0.609375 },\n { x: 0.984375, y: 0.609375 },\n { x: 0.015625, y: 0.640625 },\n { x: 0.015625, y: 0.640625 },\n { x: 0.046875, y: 0.640625 },\n { x: 0.046875, y: 0.640625 },\n { x: 0.078125, y: 0.640625 },\n { x: 0.078125, y: 0.640625 },\n { x: 0.109375, y: 0.640625 },\n { x: 0.109375, y: 0.640625 },\n { x: 0.140625, y: 0.640625 },\n { x: 0.140625, y: 0.640625 },\n { x: 0.171875, y: 0.640625 },\n { x: 0.171875, y: 0.640625 },\n { x: 0.203125, y: 0.640625 },\n { x: 0.203125, y: 0.640625 },\n { x: 0.234375, y: 0.640625 },\n { x: 0.234375, y: 0.640625 },\n { x: 0.265625, y: 0.640625 },\n { x: 0.265625, y: 0.640625 },\n { x: 0.296875, y: 0.640625 },\n { x: 0.296875, y: 0.640625 },\n { x: 0.328125, y: 0.640625 },\n { x: 0.328125, y: 0.640625 },\n { x: 0.359375, y: 0.640625 },\n { x: 0.359375, y: 0.640625 },\n { x: 0.390625, y: 0.640625 },\n { x: 0.390625, y: 0.640625 },\n { x: 0.421875, y: 0.640625 },\n { x: 0.421875, y: 0.640625 },\n { x: 0.453125, y: 0.640625 },\n { x: 0.453125, y: 0.640625 },\n { x: 0.484375, y: 0.640625 },\n { x: 0.484375, y: 0.640625 },\n { x: 0.515625, y: 0.640625 },\n { x: 0.515625, y: 0.640625 },\n { x: 0.546875, y: 0.640625 },\n { x: 0.546875, y: 0.640625 },\n { x: 0.578125, y: 0.640625 },\n { x: 0.578125, y: 0.640625 },\n { x: 0.609375, y: 0.640625 },\n { x: 0.609375, y: 0.640625 },\n { x: 0.640625, y: 0.640625 },\n { x: 0.640625, y: 0.640625 },\n { x: 0.671875, y: 0.640625 },\n { x: 0.671875, y: 0.640625 },\n { x: 0.703125, y: 0.640625 },\n { x: 0.703125, y: 0.640625 },\n { x: 0.734375, y: 0.640625 },\n { x: 0.734375, y: 0.640625 },\n { x: 0.765625, y: 0.640625 },\n { x: 0.765625, y: 0.640625 },\n { x: 0.796875, y: 0.640625 },\n { x: 0.796875, y: 0.640625 },\n { x: 0.828125, y: 0.640625 },\n { x: 0.828125, y: 0.640625 },\n { x: 0.859375, y: 0.640625 },\n { x: 0.859375, y: 0.640625 },\n { x: 0.890625, y: 0.640625 },\n { x: 0.890625, y: 0.640625 },\n { x: 0.921875, y: 0.640625 },\n { x: 0.921875, y: 0.640625 },\n { x: 0.953125, y: 0.640625 },\n { x: 0.953125, y: 0.640625 },\n { x: 0.984375, y: 0.640625 },\n { x: 0.984375, y: 0.640625 },\n { x: 0.015625, y: 0.671875 },\n { x: 0.015625, y: 0.671875 },\n { x: 0.046875, y: 0.671875 },\n { x: 0.046875, y: 0.671875 },\n { x: 0.078125, y: 0.671875 },\n { x: 0.078125, y: 0.671875 },\n { x: 0.109375, y: 0.671875 },\n { x: 0.109375, y: 0.671875 },\n { x: 0.140625, y: 0.671875 },\n { x: 0.140625, y: 0.671875 },\n { x: 0.171875, y: 0.671875 },\n { x: 0.171875, y: 0.671875 },\n { x: 0.203125, y: 0.671875 },\n { x: 0.203125, y: 0.671875 },\n { x: 0.234375, y: 0.671875 },\n { x: 0.234375, y: 0.671875 },\n { x: 0.265625, y: 0.671875 },\n { x: 0.265625, y: 0.671875 },\n { x: 0.296875, y: 0.671875 },\n { x: 0.296875, y: 0.671875 },\n { x: 0.328125, y: 0.671875 },\n { x: 0.328125, y: 0.671875 },\n { x: 0.359375, y: 0.671875 },\n { x: 0.359375, y: 0.671875 },\n { x: 0.390625, y: 0.671875 },\n { x: 0.390625, y: 0.671875 },\n { x: 0.421875, y: 0.671875 },\n { x: 0.421875, y: 0.671875 },\n { x: 0.453125, y: 0.671875 },\n { x: 0.453125, y: 0.671875 },\n { x: 0.484375, y: 0.671875 },\n { x: 0.484375, y: 0.671875 },\n { x: 0.515625, y: 0.671875 },\n { x: 0.515625, y: 0.671875 },\n { x: 0.546875, y: 0.671875 },\n { x: 0.546875, y: 0.671875 },\n { x: 0.578125, y: 0.671875 },\n { x: 0.578125, y: 0.671875 },\n { x: 0.609375, y: 0.671875 },\n { x: 0.609375, y: 0.671875 },\n { x: 0.640625, y: 0.671875 },\n { x: 0.640625, y: 0.671875 },\n { x: 0.671875, y: 0.671875 },\n { x: 0.671875, y: 0.671875 },\n { x: 0.703125, y: 0.671875 },\n { x: 0.703125, y: 0.671875 },\n { x: 0.734375, y: 0.671875 },\n { x: 0.734375, y: 0.671875 },\n { x: 0.765625, y: 0.671875 },\n { x: 0.765625, y: 0.671875 },\n { x: 0.796875, y: 0.671875 },\n { x: 0.796875, y: 0.671875 },\n { x: 0.828125, y: 0.671875 },\n { x: 0.828125, y: 0.671875 },\n { x: 0.859375, y: 0.671875 },\n { x: 0.859375, y: 0.671875 },\n { x: 0.890625, y: 0.671875 },\n { x: 0.890625, y: 0.671875 },\n { x: 0.921875, y: 0.671875 },\n { x: 0.921875, y: 0.671875 },\n { x: 0.953125, y: 0.671875 },\n { x: 0.953125, y: 0.671875 },\n { x: 0.984375, y: 0.671875 },\n { x: 0.984375, y: 0.671875 },\n { x: 0.015625, y: 0.703125 },\n { x: 0.015625, y: 0.703125 },\n { x: 0.046875, y: 0.703125 },\n { x: 0.046875, y: 0.703125 },\n { x: 0.078125, y: 0.703125 },\n { x: 0.078125, y: 0.703125 },\n { x: 0.109375, y: 0.703125 },\n { x: 0.109375, y: 0.703125 },\n { x: 0.140625, y: 0.703125 },\n { x: 0.140625, y: 0.703125 },\n { x: 0.171875, y: 0.703125 },\n { x: 0.171875, y: 0.703125 },\n { x: 0.203125, y: 0.703125 },\n { x: 0.203125, y: 0.703125 },\n { x: 0.234375, y: 0.703125 },\n { x: 0.234375, y: 0.703125 },\n { x: 0.265625, y: 0.703125 },\n { x: 0.265625, y: 0.703125 },\n { x: 0.296875, y: 0.703125 },\n { x: 0.296875, y: 0.703125 },\n { x: 0.328125, y: 0.703125 },\n { x: 0.328125, y: 0.703125 },\n { x: 0.359375, y: 0.703125 },\n { x: 0.359375, y: 0.703125 },\n { x: 0.390625, y: 0.703125 },\n { x: 0.390625, y: 0.703125 },\n { x: 0.421875, y: 0.703125 },\n { x: 0.421875, y: 0.703125 },\n { x: 0.453125, y: 0.703125 },\n { x: 0.453125, y: 0.703125 },\n { x: 0.484375, y: 0.703125 },\n { x: 0.484375, y: 0.703125 },\n { x: 0.515625, y: 0.703125 },\n { x: 0.515625, y: 0.703125 },\n { x: 0.546875, y: 0.703125 },\n { x: 0.546875, y: 0.703125 },\n { x: 0.578125, y: 0.703125 },\n { x: 0.578125, y: 0.703125 },\n { x: 0.609375, y: 0.703125 },\n { x: 0.609375, y: 0.703125 },\n { x: 0.640625, y: 0.703125 },\n { x: 0.640625, y: 0.703125 },\n { x: 0.671875, y: 0.703125 },\n { x: 0.671875, y: 0.703125 },\n { x: 0.703125, y: 0.703125 },\n { x: 0.703125, y: 0.703125 },\n { x: 0.734375, y: 0.703125 },\n { x: 0.734375, y: 0.703125 },\n { x: 0.765625, y: 0.703125 },\n { x: 0.765625, y: 0.703125 },\n { x: 0.796875, y: 0.703125 },\n { x: 0.796875, y: 0.703125 },\n { x: 0.828125, y: 0.703125 },\n { x: 0.828125, y: 0.703125 },\n { x: 0.859375, y: 0.703125 },\n { x: 0.859375, y: 0.703125 },\n { x: 0.890625, y: 0.703125 },\n { x: 0.890625, y: 0.703125 },\n { x: 0.921875, y: 0.703125 },\n { x: 0.921875, y: 0.703125 },\n { x: 0.953125, y: 0.703125 },\n { x: 0.953125, y: 0.703125 },\n { x: 0.984375, y: 0.703125 },\n { x: 0.984375, y: 0.703125 },\n { x: 0.015625, y: 0.734375 },\n { x: 0.015625, y: 0.734375 },\n { x: 0.046875, y: 0.734375 },\n { x: 0.046875, y: 0.734375 },\n { x: 0.078125, y: 0.734375 },\n { x: 0.078125, y: 0.734375 },\n { x: 0.109375, y: 0.734375 },\n { x: 0.109375, y: 0.734375 },\n { x: 0.140625, y: 0.734375 },\n { x: 0.140625, y: 0.734375 },\n { x: 0.171875, y: 0.734375 },\n { x: 0.171875, y: 0.734375 },\n { x: 0.203125, y: 0.734375 },\n { x: 0.203125, y: 0.734375 },\n { x: 0.234375, y: 0.734375 },\n { x: 0.234375, y: 0.734375 },\n { x: 0.265625, y: 0.734375 },\n { x: 0.265625, y: 0.734375 },\n { x: 0.296875, y: 0.734375 },\n { x: 0.296875, y: 0.734375 },\n { x: 0.328125, y: 0.734375 },\n { x: 0.328125, y: 0.734375 },\n { x: 0.359375, y: 0.734375 },\n { x: 0.359375, y: 0.734375 },\n { x: 0.390625, y: 0.734375 },\n { x: 0.390625, y: 0.734375 },\n { x: 0.421875, y: 0.734375 },\n { x: 0.421875, y: 0.734375 },\n { x: 0.453125, y: 0.734375 },\n { x: 0.453125, y: 0.734375 },\n { x: 0.484375, y: 0.734375 },\n { x: 0.484375, y: 0.734375 },\n { x: 0.515625, y: 0.734375 },\n { x: 0.515625, y: 0.734375 },\n { x: 0.546875, y: 0.734375 },\n { x: 0.546875, y: 0.734375 },\n { x: 0.578125, y: 0.734375 },\n { x: 0.578125, y: 0.734375 },\n { x: 0.609375, y: 0.734375 },\n { x: 0.609375, y: 0.734375 },\n { x: 0.640625, y: 0.734375 },\n { x: 0.640625, y: 0.734375 },\n { x: 0.671875, y: 0.734375 },\n { x: 0.671875, y: 0.734375 },\n { x: 0.703125, y: 0.734375 },\n { x: 0.703125, y: 0.734375 },\n { x: 0.734375, y: 0.734375 },\n { x: 0.734375, y: 0.734375 },\n { x: 0.765625, y: 0.734375 },\n { x: 0.765625, y: 0.734375 },\n { x: 0.796875, y: 0.734375 },\n { x: 0.796875, y: 0.734375 },\n { x: 0.828125, y: 0.734375 },\n { x: 0.828125, y: 0.734375 },\n { x: 0.859375, y: 0.734375 },\n { x: 0.859375, y: 0.734375 },\n { x: 0.890625, y: 0.734375 },\n { x: 0.890625, y: 0.734375 },\n { x: 0.921875, y: 0.734375 },\n { x: 0.921875, y: 0.734375 },\n { x: 0.953125, y: 0.734375 },\n { x: 0.953125, y: 0.734375 },\n { x: 0.984375, y: 0.734375 },\n { x: 0.984375, y: 0.734375 },\n { x: 0.015625, y: 0.765625 },\n { x: 0.015625, y: 0.765625 },\n { x: 0.046875, y: 0.765625 },\n { x: 0.046875, y: 0.765625 },\n { x: 0.078125, y: 0.765625 },\n { x: 0.078125, y: 0.765625 },\n { x: 0.109375, y: 0.765625 },\n { x: 0.109375, y: 0.765625 },\n { x: 0.140625, y: 0.765625 },\n { x: 0.140625, y: 0.765625 },\n { x: 0.171875, y: 0.765625 },\n { x: 0.171875, y: 0.765625 },\n { x: 0.203125, y: 0.765625 },\n { x: 0.203125, y: 0.765625 },\n { x: 0.234375, y: 0.765625 },\n { x: 0.234375, y: 0.765625 },\n { x: 0.265625, y: 0.765625 },\n { x: 0.265625, y: 0.765625 },\n { x: 0.296875, y: 0.765625 },\n { x: 0.296875, y: 0.765625 },\n { x: 0.328125, y: 0.765625 },\n { x: 0.328125, y: 0.765625 },\n { x: 0.359375, y: 0.765625 },\n { x: 0.359375, y: 0.765625 },\n { x: 0.390625, y: 0.765625 },\n { x: 0.390625, y: 0.765625 },\n { x: 0.421875, y: 0.765625 },\n { x: 0.421875, y: 0.765625 },\n { x: 0.453125, y: 0.765625 },\n { x: 0.453125, y: 0.765625 },\n { x: 0.484375, y: 0.765625 },\n { x: 0.484375, y: 0.765625 },\n { x: 0.515625, y: 0.765625 },\n { x: 0.515625, y: 0.765625 },\n { x: 0.546875, y: 0.765625 },\n { x: 0.546875, y: 0.765625 },\n { x: 0.578125, y: 0.765625 },\n { x: 0.578125, y: 0.765625 },\n { x: 0.609375, y: 0.765625 },\n { x: 0.609375, y: 0.765625 },\n { x: 0.640625, y: 0.765625 },\n { x: 0.640625, y: 0.765625 },\n { x: 0.671875, y: 0.765625 },\n { x: 0.671875, y: 0.765625 },\n { x: 0.703125, y: 0.765625 },\n { x: 0.703125, y: 0.765625 },\n { x: 0.734375, y: 0.765625 },\n { x: 0.734375, y: 0.765625 },\n { x: 0.765625, y: 0.765625 },\n { x: 0.765625, y: 0.765625 },\n { x: 0.796875, y: 0.765625 },\n { x: 0.796875, y: 0.765625 },\n { x: 0.828125, y: 0.765625 },\n { x: 0.828125, y: 0.765625 },\n { x: 0.859375, y: 0.765625 },\n { x: 0.859375, y: 0.765625 },\n { x: 0.890625, y: 0.765625 },\n { x: 0.890625, y: 0.765625 },\n { x: 0.921875, y: 0.765625 },\n { x: 0.921875, y: 0.765625 },\n { x: 0.953125, y: 0.765625 },\n { x: 0.953125, y: 0.765625 },\n { x: 0.984375, y: 0.765625 },\n { x: 0.984375, y: 0.765625 },\n { x: 0.015625, y: 0.796875 },\n { x: 0.015625, y: 0.796875 },\n { x: 0.046875, y: 0.796875 },\n { x: 0.046875, y: 0.796875 },\n { x: 0.078125, y: 0.796875 },\n { x: 0.078125, y: 0.796875 },\n { x: 0.109375, y: 0.796875 },\n { x: 0.109375, y: 0.796875 },\n { x: 0.140625, y: 0.796875 },\n { x: 0.140625, y: 0.796875 },\n { x: 0.171875, y: 0.796875 },\n { x: 0.171875, y: 0.796875 },\n { x: 0.203125, y: 0.796875 },\n { x: 0.203125, y: 0.796875 },\n { x: 0.234375, y: 0.796875 },\n { x: 0.234375, y: 0.796875 },\n { x: 0.265625, y: 0.796875 },\n { x: 0.265625, y: 0.796875 },\n { x: 0.296875, y: 0.796875 },\n { x: 0.296875, y: 0.796875 },\n { x: 0.328125, y: 0.796875 },\n { x: 0.328125, y: 0.796875 },\n { x: 0.359375, y: 0.796875 },\n { x: 0.359375, y: 0.796875 },\n { x: 0.390625, y: 0.796875 },\n { x: 0.390625, y: 0.796875 },\n { x: 0.421875, y: 0.796875 },\n { x: 0.421875, y: 0.796875 },\n { x: 0.453125, y: 0.796875 },\n { x: 0.453125, y: 0.796875 },\n { x: 0.484375, y: 0.796875 },\n { x: 0.484375, y: 0.796875 },\n { x: 0.515625, y: 0.796875 },\n { x: 0.515625, y: 0.796875 },\n { x: 0.546875, y: 0.796875 },\n { x: 0.546875, y: 0.796875 },\n { x: 0.578125, y: 0.796875 },\n { x: 0.578125, y: 0.796875 },\n { x: 0.609375, y: 0.796875 },\n { x: 0.609375, y: 0.796875 },\n { x: 0.640625, y: 0.796875 },\n { x: 0.640625, y: 0.796875 },\n { x: 0.671875, y: 0.796875 },\n { x: 0.671875, y: 0.796875 },\n { x: 0.703125, y: 0.796875 },\n { x: 0.703125, y: 0.796875 },\n { x: 0.734375, y: 0.796875 },\n { x: 0.734375, y: 0.796875 },\n { x: 0.765625, y: 0.796875 },\n { x: 0.765625, y: 0.796875 },\n { x: 0.796875, y: 0.796875 },\n { x: 0.796875, y: 0.796875 },\n { x: 0.828125, y: 0.796875 },\n { x: 0.828125, y: 0.796875 },\n { x: 0.859375, y: 0.796875 },\n { x: 0.859375, y: 0.796875 },\n { x: 0.890625, y: 0.796875 },\n { x: 0.890625, y: 0.796875 },\n { x: 0.921875, y: 0.796875 },\n { x: 0.921875, y: 0.796875 },\n { x: 0.953125, y: 0.796875 },\n { x: 0.953125, y: 0.796875 },\n { x: 0.984375, y: 0.796875 },\n { x: 0.984375, y: 0.796875 },\n { x: 0.015625, y: 0.828125 },\n { x: 0.015625, y: 0.828125 },\n { x: 0.046875, y: 0.828125 },\n { x: 0.046875, y: 0.828125 },\n { x: 0.078125, y: 0.828125 },\n { x: 0.078125, y: 0.828125 },\n { x: 0.109375, y: 0.828125 },\n { x: 0.109375, y: 0.828125 },\n { x: 0.140625, y: 0.828125 },\n { x: 0.140625, y: 0.828125 },\n { x: 0.171875, y: 0.828125 },\n { x: 0.171875, y: 0.828125 },\n { x: 0.203125, y: 0.828125 },\n { x: 0.203125, y: 0.828125 },\n { x: 0.234375, y: 0.828125 },\n { x: 0.234375, y: 0.828125 },\n { x: 0.265625, y: 0.828125 },\n { x: 0.265625, y: 0.828125 },\n { x: 0.296875, y: 0.828125 },\n { x: 0.296875, y: 0.828125 },\n { x: 0.328125, y: 0.828125 },\n { x: 0.328125, y: 0.828125 },\n { x: 0.359375, y: 0.828125 },\n { x: 0.359375, y: 0.828125 },\n { x: 0.390625, y: 0.828125 },\n { x: 0.390625, y: 0.828125 },\n { x: 0.421875, y: 0.828125 },\n { x: 0.421875, y: 0.828125 },\n { x: 0.453125, y: 0.828125 },\n { x: 0.453125, y: 0.828125 },\n { x: 0.484375, y: 0.828125 },\n { x: 0.484375, y: 0.828125 },\n { x: 0.515625, y: 0.828125 },\n { x: 0.515625, y: 0.828125 },\n { x: 0.546875, y: 0.828125 },\n { x: 0.546875, y: 0.828125 },\n { x: 0.578125, y: 0.828125 },\n { x: 0.578125, y: 0.828125 },\n { x: 0.609375, y: 0.828125 },\n { x: 0.609375, y: 0.828125 },\n { x: 0.640625, y: 0.828125 },\n { x: 0.640625, y: 0.828125 },\n { x: 0.671875, y: 0.828125 },\n { x: 0.671875, y: 0.828125 },\n { x: 0.703125, y: 0.828125 },\n { x: 0.703125, y: 0.828125 },\n { x: 0.734375, y: 0.828125 },\n { x: 0.734375, y: 0.828125 },\n { x: 0.765625, y: 0.828125 },\n { x: 0.765625, y: 0.828125 },\n { x: 0.796875, y: 0.828125 },\n { x: 0.796875, y: 0.828125 },\n { x: 0.828125, y: 0.828125 },\n { x: 0.828125, y: 0.828125 },\n { x: 0.859375, y: 0.828125 },\n { x: 0.859375, y: 0.828125 },\n { x: 0.890625, y: 0.828125 },\n { x: 0.890625, y: 0.828125 },\n { x: 0.921875, y: 0.828125 },\n { x: 0.921875, y: 0.828125 },\n { x: 0.953125, y: 0.828125 },\n { x: 0.953125, y: 0.828125 },\n { x: 0.984375, y: 0.828125 },\n { x: 0.984375, y: 0.828125 },\n { x: 0.015625, y: 0.859375 },\n { x: 0.015625, y: 0.859375 },\n { x: 0.046875, y: 0.859375 },\n { x: 0.046875, y: 0.859375 },\n { x: 0.078125, y: 0.859375 },\n { x: 0.078125, y: 0.859375 },\n { x: 0.109375, y: 0.859375 },\n { x: 0.109375, y: 0.859375 },\n { x: 0.140625, y: 0.859375 },\n { x: 0.140625, y: 0.859375 },\n { x: 0.171875, y: 0.859375 },\n { x: 0.171875, y: 0.859375 },\n { x: 0.203125, y: 0.859375 },\n { x: 0.203125, y: 0.859375 },\n { x: 0.234375, y: 0.859375 },\n { x: 0.234375, y: 0.859375 },\n { x: 0.265625, y: 0.859375 },\n { x: 0.265625, y: 0.859375 },\n { x: 0.296875, y: 0.859375 },\n { x: 0.296875, y: 0.859375 },\n { x: 0.328125, y: 0.859375 },\n { x: 0.328125, y: 0.859375 },\n { x: 0.359375, y: 0.859375 },\n { x: 0.359375, y: 0.859375 },\n { x: 0.390625, y: 0.859375 },\n { x: 0.390625, y: 0.859375 },\n { x: 0.421875, y: 0.859375 },\n { x: 0.421875, y: 0.859375 },\n { x: 0.453125, y: 0.859375 },\n { x: 0.453125, y: 0.859375 },\n { x: 0.484375, y: 0.859375 },\n { x: 0.484375, y: 0.859375 },\n { x: 0.515625, y: 0.859375 },\n { x: 0.515625, y: 0.859375 },\n { x: 0.546875, y: 0.859375 },\n { x: 0.546875, y: 0.859375 },\n { x: 0.578125, y: 0.859375 },\n { x: 0.578125, y: 0.859375 },\n { x: 0.609375, y: 0.859375 },\n { x: 0.609375, y: 0.859375 },\n { x: 0.640625, y: 0.859375 },\n { x: 0.640625, y: 0.859375 },\n { x: 0.671875, y: 0.859375 },\n { x: 0.671875, y: 0.859375 },\n { x: 0.703125, y: 0.859375 },\n { x: 0.703125, y: 0.859375 },\n { x: 0.734375, y: 0.859375 },\n { x: 0.734375, y: 0.859375 },\n { x: 0.765625, y: 0.859375 },\n { x: 0.765625, y: 0.859375 },\n { x: 0.796875, y: 0.859375 },\n { x: 0.796875, y: 0.859375 },\n { x: 0.828125, y: 0.859375 },\n { x: 0.828125, y: 0.859375 },\n { x: 0.859375, y: 0.859375 },\n { x: 0.859375, y: 0.859375 },\n { x: 0.890625, y: 0.859375 },\n { x: 0.890625, y: 0.859375 },\n { x: 0.921875, y: 0.859375 },\n { x: 0.921875, y: 0.859375 },\n { x: 0.953125, y: 0.859375 },\n { x: 0.953125, y: 0.859375 },\n { x: 0.984375, y: 0.859375 },\n { x: 0.984375, y: 0.859375 },\n { x: 0.015625, y: 0.890625 },\n { x: 0.015625, y: 0.890625 },\n { x: 0.046875, y: 0.890625 },\n { x: 0.046875, y: 0.890625 },\n { x: 0.078125, y: 0.890625 },\n { x: 0.078125, y: 0.890625 },\n { x: 0.109375, y: 0.890625 },\n { x: 0.109375, y: 0.890625 },\n { x: 0.140625, y: 0.890625 },\n { x: 0.140625, y: 0.890625 },\n { x: 0.171875, y: 0.890625 },\n { x: 0.171875, y: 0.890625 },\n { x: 0.203125, y: 0.890625 },\n { x: 0.203125, y: 0.890625 },\n { x: 0.234375, y: 0.890625 },\n { x: 0.234375, y: 0.890625 },\n { x: 0.265625, y: 0.890625 },\n { x: 0.265625, y: 0.890625 },\n { x: 0.296875, y: 0.890625 },\n { x: 0.296875, y: 0.890625 },\n { x: 0.328125, y: 0.890625 },\n { x: 0.328125, y: 0.890625 },\n { x: 0.359375, y: 0.890625 },\n { x: 0.359375, y: 0.890625 },\n { x: 0.390625, y: 0.890625 },\n { x: 0.390625, y: 0.890625 },\n { x: 0.421875, y: 0.890625 },\n { x: 0.421875, y: 0.890625 },\n { x: 0.453125, y: 0.890625 },\n { x: 0.453125, y: 0.890625 },\n { x: 0.484375, y: 0.890625 },\n { x: 0.484375, y: 0.890625 },\n { x: 0.515625, y: 0.890625 },\n { x: 0.515625, y: 0.890625 },\n { x: 0.546875, y: 0.890625 },\n { x: 0.546875, y: 0.890625 },\n { x: 0.578125, y: 0.890625 },\n { x: 0.578125, y: 0.890625 },\n { x: 0.609375, y: 0.890625 },\n { x: 0.609375, y: 0.890625 },\n { x: 0.640625, y: 0.890625 },\n { x: 0.640625, y: 0.890625 },\n { x: 0.671875, y: 0.890625 },\n { x: 0.671875, y: 0.890625 },\n { x: 0.703125, y: 0.890625 },\n { x: 0.703125, y: 0.890625 },\n { x: 0.734375, y: 0.890625 },\n { x: 0.734375, y: 0.890625 },\n { x: 0.765625, y: 0.890625 },\n { x: 0.765625, y: 0.890625 },\n { x: 0.796875, y: 0.890625 },\n { x: 0.796875, y: 0.890625 },\n { x: 0.828125, y: 0.890625 },\n { x: 0.828125, y: 0.890625 },\n { x: 0.859375, y: 0.890625 },\n { x: 0.859375, y: 0.890625 },\n { x: 0.890625, y: 0.890625 },\n { x: 0.890625, y: 0.890625 },\n { x: 0.921875, y: 0.890625 },\n { x: 0.921875, y: 0.890625 },\n { x: 0.953125, y: 0.890625 },\n { x: 0.953125, y: 0.890625 },\n { x: 0.984375, y: 0.890625 },\n { x: 0.984375, y: 0.890625 },\n { x: 0.015625, y: 0.921875 },\n { x: 0.015625, y: 0.921875 },\n { x: 0.046875, y: 0.921875 },\n { x: 0.046875, y: 0.921875 },\n { x: 0.078125, y: 0.921875 },\n { x: 0.078125, y: 0.921875 },\n { x: 0.109375, y: 0.921875 },\n { x: 0.109375, y: 0.921875 },\n { x: 0.140625, y: 0.921875 },\n { x: 0.140625, y: 0.921875 },\n { x: 0.171875, y: 0.921875 },\n { x: 0.171875, y: 0.921875 },\n { x: 0.203125, y: 0.921875 },\n { x: 0.203125, y: 0.921875 },\n { x: 0.234375, y: 0.921875 },\n { x: 0.234375, y: 0.921875 },\n { x: 0.265625, y: 0.921875 },\n { x: 0.265625, y: 0.921875 },\n { x: 0.296875, y: 0.921875 },\n { x: 0.296875, y: 0.921875 },\n { x: 0.328125, y: 0.921875 },\n { x: 0.328125, y: 0.921875 },\n { x: 0.359375, y: 0.921875 },\n { x: 0.359375, y: 0.921875 },\n { x: 0.390625, y: 0.921875 },\n { x: 0.390625, y: 0.921875 },\n { x: 0.421875, y: 0.921875 },\n { x: 0.421875, y: 0.921875 },\n { x: 0.453125, y: 0.921875 },\n { x: 0.453125, y: 0.921875 },\n { x: 0.484375, y: 0.921875 },\n { x: 0.484375, y: 0.921875 },\n { x: 0.515625, y: 0.921875 },\n { x: 0.515625, y: 0.921875 },\n { x: 0.546875, y: 0.921875 },\n { x: 0.546875, y: 0.921875 },\n { x: 0.578125, y: 0.921875 },\n { x: 0.578125, y: 0.921875 },\n { x: 0.609375, y: 0.921875 },\n { x: 0.609375, y: 0.921875 },\n { x: 0.640625, y: 0.921875 },\n { x: 0.640625, y: 0.921875 },\n { x: 0.671875, y: 0.921875 },\n { x: 0.671875, y: 0.921875 },\n { x: 0.703125, y: 0.921875 },\n { x: 0.703125, y: 0.921875 },\n { x: 0.734375, y: 0.921875 },\n { x: 0.734375, y: 0.921875 },\n { x: 0.765625, y: 0.921875 },\n { x: 0.765625, y: 0.921875 },\n { x: 0.796875, y: 0.921875 },\n { x: 0.796875, y: 0.921875 },\n { x: 0.828125, y: 0.921875 },\n { x: 0.828125, y: 0.921875 },\n { x: 0.859375, y: 0.921875 },\n { x: 0.859375, y: 0.921875 },\n { x: 0.890625, y: 0.921875 },\n { x: 0.890625, y: 0.921875 },\n { x: 0.921875, y: 0.921875 },\n { x: 0.921875, y: 0.921875 },\n { x: 0.953125, y: 0.921875 },\n { x: 0.953125, y: 0.921875 },\n { x: 0.984375, y: 0.921875 },\n { x: 0.984375, y: 0.921875 },\n { x: 0.015625, y: 0.953125 },\n { x: 0.015625, y: 0.953125 },\n { x: 0.046875, y: 0.953125 },\n { x: 0.046875, y: 0.953125 },\n { x: 0.078125, y: 0.953125 },\n { x: 0.078125, y: 0.953125 },\n { x: 0.109375, y: 0.953125 },\n { x: 0.109375, y: 0.953125 },\n { x: 0.140625, y: 0.953125 },\n { x: 0.140625, y: 0.953125 },\n { x: 0.171875, y: 0.953125 },\n { x: 0.171875, y: 0.953125 },\n { x: 0.203125, y: 0.953125 },\n { x: 0.203125, y: 0.953125 },\n { x: 0.234375, y: 0.953125 },\n { x: 0.234375, y: 0.953125 },\n { x: 0.265625, y: 0.953125 },\n { x: 0.265625, y: 0.953125 },\n { x: 0.296875, y: 0.953125 },\n { x: 0.296875, y: 0.953125 },\n { x: 0.328125, y: 0.953125 },\n { x: 0.328125, y: 0.953125 },\n { x: 0.359375, y: 0.953125 },\n { x: 0.359375, y: 0.953125 },\n { x: 0.390625, y: 0.953125 },\n { x: 0.390625, y: 0.953125 },\n { x: 0.421875, y: 0.953125 },\n { x: 0.421875, y: 0.953125 },\n { x: 0.453125, y: 0.953125 },\n { x: 0.453125, y: 0.953125 },\n { x: 0.484375, y: 0.953125 },\n { x: 0.484375, y: 0.953125 },\n { x: 0.515625, y: 0.953125 },\n { x: 0.515625, y: 0.953125 },\n { x: 0.546875, y: 0.953125 },\n { x: 0.546875, y: 0.953125 },\n { x: 0.578125, y: 0.953125 },\n { x: 0.578125, y: 0.953125 },\n { x: 0.609375, y: 0.953125 },\n { x: 0.609375, y: 0.953125 },\n { x: 0.640625, y: 0.953125 },\n { x: 0.640625, y: 0.953125 },\n { x: 0.671875, y: 0.953125 },\n { x: 0.671875, y: 0.953125 },\n { x: 0.703125, y: 0.953125 },\n { x: 0.703125, y: 0.953125 },\n { x: 0.734375, y: 0.953125 },\n { x: 0.734375, y: 0.953125 },\n { x: 0.765625, y: 0.953125 },\n { x: 0.765625, y: 0.953125 },\n { x: 0.796875, y: 0.953125 },\n { x: 0.796875, y: 0.953125 },\n { x: 0.828125, y: 0.953125 },\n { x: 0.828125, y: 0.953125 },\n { x: 0.859375, y: 0.953125 },\n { x: 0.859375, y: 0.953125 },\n { x: 0.890625, y: 0.953125 },\n { x: 0.890625, y: 0.953125 },\n { x: 0.921875, y: 0.953125 },\n { x: 0.921875, y: 0.953125 },\n { x: 0.953125, y: 0.953125 },\n { x: 0.953125, y: 0.953125 },\n { x: 0.984375, y: 0.953125 },\n { x: 0.984375, y: 0.953125 },\n { x: 0.015625, y: 0.984375 },\n { x: 0.015625, y: 0.984375 },\n { x: 0.046875, y: 0.984375 },\n { x: 0.046875, y: 0.984375 },\n { x: 0.078125, y: 0.984375 },\n { x: 0.078125, y: 0.984375 },\n { x: 0.109375, y: 0.984375 },\n { x: 0.109375, y: 0.984375 },\n { x: 0.140625, y: 0.984375 },\n { x: 0.140625, y: 0.984375 },\n { x: 0.171875, y: 0.984375 },\n { x: 0.171875, y: 0.984375 },\n { x: 0.203125, y: 0.984375 },\n { x: 0.203125, y: 0.984375 },\n { x: 0.234375, y: 0.984375 },\n { x: 0.234375, y: 0.984375 },\n { x: 0.265625, y: 0.984375 },\n { x: 0.265625, y: 0.984375 },\n { x: 0.296875, y: 0.984375 },\n { x: 0.296875, y: 0.984375 },\n { x: 0.328125, y: 0.984375 },\n { x: 0.328125, y: 0.984375 },\n { x: 0.359375, y: 0.984375 },\n { x: 0.359375, y: 0.984375 },\n { x: 0.390625, y: 0.984375 },\n { x: 0.390625, y: 0.984375 },\n { x: 0.421875, y: 0.984375 },\n { x: 0.421875, y: 0.984375 },\n { x: 0.453125, y: 0.984375 },\n { x: 0.453125, y: 0.984375 },\n { x: 0.484375, y: 0.984375 },\n { x: 0.484375, y: 0.984375 },\n { x: 0.515625, y: 0.984375 },\n { x: 0.515625, y: 0.984375 },\n { x: 0.546875, y: 0.984375 },\n { x: 0.546875, y: 0.984375 },\n { x: 0.578125, y: 0.984375 },\n { x: 0.578125, y: 0.984375 },\n { x: 0.609375, y: 0.984375 },\n { x: 0.609375, y: 0.984375 },\n { x: 0.640625, y: 0.984375 },\n { x: 0.640625, y: 0.984375 },\n { x: 0.671875, y: 0.984375 },\n { x: 0.671875, y: 0.984375 },\n { x: 0.703125, y: 0.984375 },\n { x: 0.703125, y: 0.984375 },\n { x: 0.734375, y: 0.984375 },\n { x: 0.734375, y: 0.984375 },\n { x: 0.765625, y: 0.984375 },\n { x: 0.765625, y: 0.984375 },\n { x: 0.796875, y: 0.984375 },\n { x: 0.796875, y: 0.984375 },\n { x: 0.828125, y: 0.984375 },\n { x: 0.828125, y: 0.984375 },\n { x: 0.859375, y: 0.984375 },\n { x: 0.859375, y: 0.984375 },\n { x: 0.890625, y: 0.984375 },\n { x: 0.890625, y: 0.984375 },\n { x: 0.921875, y: 0.984375 },\n { x: 0.921875, y: 0.984375 },\n { x: 0.953125, y: 0.984375 },\n { x: 0.953125, y: 0.984375 },\n { x: 0.984375, y: 0.984375 },\n { x: 0.984375, y: 0.984375 },\n { x: 0.03125, y: 0.03125 },\n { x: 0.03125, y: 0.03125 },\n { x: 0.09375, y: 0.03125 },\n { x: 0.09375, y: 0.03125 },\n { x: 0.15625, y: 0.03125 },\n { x: 0.15625, y: 0.03125 },\n { x: 0.21875, y: 0.03125 },\n { x: 0.21875, y: 0.03125 },\n { x: 0.28125, y: 0.03125 },\n { x: 0.28125, y: 0.03125 },\n { x: 0.34375, y: 0.03125 },\n { x: 0.34375, y: 0.03125 },\n { x: 0.40625, y: 0.03125 },\n { x: 0.40625, y: 0.03125 },\n { x: 0.46875, y: 0.03125 },\n { x: 0.46875, y: 0.03125 },\n { x: 0.53125, y: 0.03125 },\n { x: 0.53125, y: 0.03125 },\n { x: 0.59375, y: 0.03125 },\n { x: 0.59375, y: 0.03125 },\n { x: 0.65625, y: 0.03125 },\n { x: 0.65625, y: 0.03125 },\n { x: 0.71875, y: 0.03125 },\n { x: 0.71875, y: 0.03125 },\n { x: 0.78125, y: 0.03125 },\n { x: 0.78125, y: 0.03125 },\n { x: 0.84375, y: 0.03125 },\n { x: 0.84375, y: 0.03125 },\n { x: 0.90625, y: 0.03125 },\n { x: 0.90625, y: 0.03125 },\n { x: 0.96875, y: 0.03125 },\n { x: 0.96875, y: 0.03125 },\n { x: 0.03125, y: 0.09375 },\n { x: 0.03125, y: 0.09375 },\n { x: 0.09375, y: 0.09375 },\n { x: 0.09375, y: 0.09375 },\n { x: 0.15625, y: 0.09375 },\n { x: 0.15625, y: 0.09375 },\n { x: 0.21875, y: 0.09375 },\n { x: 0.21875, y: 0.09375 },\n { x: 0.28125, y: 0.09375 },\n { x: 0.28125, y: 0.09375 },\n { x: 0.34375, y: 0.09375 },\n { x: 0.34375, y: 0.09375 },\n { x: 0.40625, y: 0.09375 },\n { x: 0.40625, y: 0.09375 },\n { x: 0.46875, y: 0.09375 },\n { x: 0.46875, y: 0.09375 },\n { x: 0.53125, y: 0.09375 },\n { x: 0.53125, y: 0.09375 },\n { x: 0.59375, y: 0.09375 },\n { x: 0.59375, y: 0.09375 },\n { x: 0.65625, y: 0.09375 },\n { x: 0.65625, y: 0.09375 },\n { x: 0.71875, y: 0.09375 },\n { x: 0.71875, y: 0.09375 },\n { x: 0.78125, y: 0.09375 },\n { x: 0.78125, y: 0.09375 },\n { x: 0.84375, y: 0.09375 },\n { x: 0.84375, y: 0.09375 },\n { x: 0.90625, y: 0.09375 },\n { x: 0.90625, y: 0.09375 },\n { x: 0.96875, y: 0.09375 },\n { x: 0.96875, y: 0.09375 },\n { x: 0.03125, y: 0.15625 },\n { x: 0.03125, y: 0.15625 },\n { x: 0.09375, y: 0.15625 },\n { x: 0.09375, y: 0.15625 },\n { x: 0.15625, y: 0.15625 },\n { x: 0.15625, y: 0.15625 },\n { x: 0.21875, y: 0.15625 },\n { x: 0.21875, y: 0.15625 },\n { x: 0.28125, y: 0.15625 },\n { x: 0.28125, y: 0.15625 },\n { x: 0.34375, y: 0.15625 },\n { x: 0.34375, y: 0.15625 },\n { x: 0.40625, y: 0.15625 },\n { x: 0.40625, y: 0.15625 },\n { x: 0.46875, y: 0.15625 },\n { x: 0.46875, y: 0.15625 },\n { x: 0.53125, y: 0.15625 },\n { x: 0.53125, y: 0.15625 },\n { x: 0.59375, y: 0.15625 },\n { x: 0.59375, y: 0.15625 },\n { x: 0.65625, y: 0.15625 },\n { x: 0.65625, y: 0.15625 },\n { x: 0.71875, y: 0.15625 },\n { x: 0.71875, y: 0.15625 },\n { x: 0.78125, y: 0.15625 },\n { x: 0.78125, y: 0.15625 },\n { x: 0.84375, y: 0.15625 },\n { x: 0.84375, y: 0.15625 },\n { x: 0.90625, y: 0.15625 },\n { x: 0.90625, y: 0.15625 },\n { x: 0.96875, y: 0.15625 },\n { x: 0.96875, y: 0.15625 },\n { x: 0.03125, y: 0.21875 },\n { x: 0.03125, y: 0.21875 },\n { x: 0.09375, y: 0.21875 },\n { x: 0.09375, y: 0.21875 },\n { x: 0.15625, y: 0.21875 },\n { x: 0.15625, y: 0.21875 },\n { x: 0.21875, y: 0.21875 },\n { x: 0.21875, y: 0.21875 },\n { x: 0.28125, y: 0.21875 },\n { x: 0.28125, y: 0.21875 },\n { x: 0.34375, y: 0.21875 },\n { x: 0.34375, y: 0.21875 },\n { x: 0.40625, y: 0.21875 },\n { x: 0.40625, y: 0.21875 },\n { x: 0.46875, y: 0.21875 },\n { x: 0.46875, y: 0.21875 },\n { x: 0.53125, y: 0.21875 },\n { x: 0.53125, y: 0.21875 },\n { x: 0.59375, y: 0.21875 },\n { x: 0.59375, y: 0.21875 },\n { x: 0.65625, y: 0.21875 },\n { x: 0.65625, y: 0.21875 },\n { x: 0.71875, y: 0.21875 },\n { x: 0.71875, y: 0.21875 },\n { x: 0.78125, y: 0.21875 },\n { x: 0.78125, y: 0.21875 },\n { x: 0.84375, y: 0.21875 },\n { x: 0.84375, y: 0.21875 },\n { x: 0.90625, y: 0.21875 },\n { x: 0.90625, y: 0.21875 },\n { x: 0.96875, y: 0.21875 },\n { x: 0.96875, y: 0.21875 },\n { x: 0.03125, y: 0.28125 },\n { x: 0.03125, y: 0.28125 },\n { x: 0.09375, y: 0.28125 },\n { x: 0.09375, y: 0.28125 },\n { x: 0.15625, y: 0.28125 },\n { x: 0.15625, y: 0.28125 },\n { x: 0.21875, y: 0.28125 },\n { x: 0.21875, y: 0.28125 },\n { x: 0.28125, y: 0.28125 },\n { x: 0.28125, y: 0.28125 },\n { x: 0.34375, y: 0.28125 },\n { x: 0.34375, y: 0.28125 },\n { x: 0.40625, y: 0.28125 },\n { x: 0.40625, y: 0.28125 },\n { x: 0.46875, y: 0.28125 },\n { x: 0.46875, y: 0.28125 },\n { x: 0.53125, y: 0.28125 },\n { x: 0.53125, y: 0.28125 },\n { x: 0.59375, y: 0.28125 },\n { x: 0.59375, y: 0.28125 },\n { x: 0.65625, y: 0.28125 },\n { x: 0.65625, y: 0.28125 },\n { x: 0.71875, y: 0.28125 },\n { x: 0.71875, y: 0.28125 },\n { x: 0.78125, y: 0.28125 },\n { x: 0.78125, y: 0.28125 },\n { x: 0.84375, y: 0.28125 },\n { x: 0.84375, y: 0.28125 },\n { x: 0.90625, y: 0.28125 },\n { x: 0.90625, y: 0.28125 },\n { x: 0.96875, y: 0.28125 },\n { x: 0.96875, y: 0.28125 },\n { x: 0.03125, y: 0.34375 },\n { x: 0.03125, y: 0.34375 },\n { x: 0.09375, y: 0.34375 },\n { x: 0.09375, y: 0.34375 },\n { x: 0.15625, y: 0.34375 },\n { x: 0.15625, y: 0.34375 },\n { x: 0.21875, y: 0.34375 },\n { x: 0.21875, y: 0.34375 },\n { x: 0.28125, y: 0.34375 },\n { x: 0.28125, y: 0.34375 },\n { x: 0.34375, y: 0.34375 },\n { x: 0.34375, y: 0.34375 },\n { x: 0.40625, y: 0.34375 },\n { x: 0.40625, y: 0.34375 },\n { x: 0.46875, y: 0.34375 },\n { x: 0.46875, y: 0.34375 },\n { x: 0.53125, y: 0.34375 },\n { x: 0.53125, y: 0.34375 },\n { x: 0.59375, y: 0.34375 },\n { x: 0.59375, y: 0.34375 },\n { x: 0.65625, y: 0.34375 },\n { x: 0.65625, y: 0.34375 },\n { x: 0.71875, y: 0.34375 },\n { x: 0.71875, y: 0.34375 },\n { x: 0.78125, y: 0.34375 },\n { x: 0.78125, y: 0.34375 },\n { x: 0.84375, y: 0.34375 },\n { x: 0.84375, y: 0.34375 },\n { x: 0.90625, y: 0.34375 },\n { x: 0.90625, y: 0.34375 },\n { x: 0.96875, y: 0.34375 },\n { x: 0.96875, y: 0.34375 },\n { x: 0.03125, y: 0.40625 },\n { x: 0.03125, y: 0.40625 },\n { x: 0.09375, y: 0.40625 },\n { x: 0.09375, y: 0.40625 },\n { x: 0.15625, y: 0.40625 },\n { x: 0.15625, y: 0.40625 },\n { x: 0.21875, y: 0.40625 },\n { x: 0.21875, y: 0.40625 },\n { x: 0.28125, y: 0.40625 },\n { x: 0.28125, y: 0.40625 },\n { x: 0.34375, y: 0.40625 },\n { x: 0.34375, y: 0.40625 },\n { x: 0.40625, y: 0.40625 },\n { x: 0.40625, y: 0.40625 },\n { x: 0.46875, y: 0.40625 },\n { x: 0.46875, y: 0.40625 },\n { x: 0.53125, y: 0.40625 },\n { x: 0.53125, y: 0.40625 },\n { x: 0.59375, y: 0.40625 },\n { x: 0.59375, y: 0.40625 },\n { x: 0.65625, y: 0.40625 },\n { x: 0.65625, y: 0.40625 },\n { x: 0.71875, y: 0.40625 },\n { x: 0.71875, y: 0.40625 },\n { x: 0.78125, y: 0.40625 },\n { x: 0.78125, y: 0.40625 },\n { x: 0.84375, y: 0.40625 },\n { x: 0.84375, y: 0.40625 },\n { x: 0.90625, y: 0.40625 },\n { x: 0.90625, y: 0.40625 },\n { x: 0.96875, y: 0.40625 },\n { x: 0.96875, y: 0.40625 },\n { x: 0.03125, y: 0.46875 },\n { x: 0.03125, y: 0.46875 },\n { x: 0.09375, y: 0.46875 },\n { x: 0.09375, y: 0.46875 },\n { x: 0.15625, y: 0.46875 },\n { x: 0.15625, y: 0.46875 },\n { x: 0.21875, y: 0.46875 },\n { x: 0.21875, y: 0.46875 },\n { x: 0.28125, y: 0.46875 },\n { x: 0.28125, y: 0.46875 },\n { x: 0.34375, y: 0.46875 },\n { x: 0.34375, y: 0.46875 },\n { x: 0.40625, y: 0.46875 },\n { x: 0.40625, y: 0.46875 },\n { x: 0.46875, y: 0.46875 },\n { x: 0.46875, y: 0.46875 },\n { x: 0.53125, y: 0.46875 },\n { x: 0.53125, y: 0.46875 },\n { x: 0.59375, y: 0.46875 },\n { x: 0.59375, y: 0.46875 },\n { x: 0.65625, y: 0.46875 },\n { x: 0.65625, y: 0.46875 },\n { x: 0.71875, y: 0.46875 },\n { x: 0.71875, y: 0.46875 },\n { x: 0.78125, y: 0.46875 },\n { x: 0.78125, y: 0.46875 },\n { x: 0.84375, y: 0.46875 },\n { x: 0.84375, y: 0.46875 },\n { x: 0.90625, y: 0.46875 },\n { x: 0.90625, y: 0.46875 },\n { x: 0.96875, y: 0.46875 },\n { x: 0.96875, y: 0.46875 },\n { x: 0.03125, y: 0.53125 },\n { x: 0.03125, y: 0.53125 },\n { x: 0.09375, y: 0.53125 },\n { x: 0.09375, y: 0.53125 },\n { x: 0.15625, y: 0.53125 },\n { x: 0.15625, y: 0.53125 },\n { x: 0.21875, y: 0.53125 },\n { x: 0.21875, y: 0.53125 },\n { x: 0.28125, y: 0.53125 },\n { x: 0.28125, y: 0.53125 },\n { x: 0.34375, y: 0.53125 },\n { x: 0.34375, y: 0.53125 },\n { x: 0.40625, y: 0.53125 },\n { x: 0.40625, y: 0.53125 },\n { x: 0.46875, y: 0.53125 },\n { x: 0.46875, y: 0.53125 },\n { x: 0.53125, y: 0.53125 },\n { x: 0.53125, y: 0.53125 },\n { x: 0.59375, y: 0.53125 },\n { x: 0.59375, y: 0.53125 },\n { x: 0.65625, y: 0.53125 },\n { x: 0.65625, y: 0.53125 },\n { x: 0.71875, y: 0.53125 },\n { x: 0.71875, y: 0.53125 },\n { x: 0.78125, y: 0.53125 },\n { x: 0.78125, y: 0.53125 },\n { x: 0.84375, y: 0.53125 },\n { x: 0.84375, y: 0.53125 },\n { x: 0.90625, y: 0.53125 },\n { x: 0.90625, y: 0.53125 },\n { x: 0.96875, y: 0.53125 },\n { x: 0.96875, y: 0.53125 },\n { x: 0.03125, y: 0.59375 },\n { x: 0.03125, y: 0.59375 },\n { x: 0.09375, y: 0.59375 },\n { x: 0.09375, y: 0.59375 },\n { x: 0.15625, y: 0.59375 },\n { x: 0.15625, y: 0.59375 },\n { x: 0.21875, y: 0.59375 },\n { x: 0.21875, y: 0.59375 },\n { x: 0.28125, y: 0.59375 },\n { x: 0.28125, y: 0.59375 },\n { x: 0.34375, y: 0.59375 },\n { x: 0.34375, y: 0.59375 },\n { x: 0.40625, y: 0.59375 },\n { x: 0.40625, y: 0.59375 },\n { x: 0.46875, y: 0.59375 },\n { x: 0.46875, y: 0.59375 },\n { x: 0.53125, y: 0.59375 },\n { x: 0.53125, y: 0.59375 },\n { x: 0.59375, y: 0.59375 },\n { x: 0.59375, y: 0.59375 },\n { x: 0.65625, y: 0.59375 },\n { x: 0.65625, y: 0.59375 },\n { x: 0.71875, y: 0.59375 },\n { x: 0.71875, y: 0.59375 },\n { x: 0.78125, y: 0.59375 },\n { x: 0.78125, y: 0.59375 },\n { x: 0.84375, y: 0.59375 },\n { x: 0.84375, y: 0.59375 },\n { x: 0.90625, y: 0.59375 },\n { x: 0.90625, y: 0.59375 },\n { x: 0.96875, y: 0.59375 },\n { x: 0.96875, y: 0.59375 },\n { x: 0.03125, y: 0.65625 },\n { x: 0.03125, y: 0.65625 },\n { x: 0.09375, y: 0.65625 },\n { x: 0.09375, y: 0.65625 },\n { x: 0.15625, y: 0.65625 },\n { x: 0.15625, y: 0.65625 },\n { x: 0.21875, y: 0.65625 },\n { x: 0.21875, y: 0.65625 },\n { x: 0.28125, y: 0.65625 },\n { x: 0.28125, y: 0.65625 },\n { x: 0.34375, y: 0.65625 },\n { x: 0.34375, y: 0.65625 },\n { x: 0.40625, y: 0.65625 },\n { x: 0.40625, y: 0.65625 },\n { x: 0.46875, y: 0.65625 },\n { x: 0.46875, y: 0.65625 },\n { x: 0.53125, y: 0.65625 },\n { x: 0.53125, y: 0.65625 },\n { x: 0.59375, y: 0.65625 },\n { x: 0.59375, y: 0.65625 },\n { x: 0.65625, y: 0.65625 },\n { x: 0.65625, y: 0.65625 },\n { x: 0.71875, y: 0.65625 },\n { x: 0.71875, y: 0.65625 },\n { x: 0.78125, y: 0.65625 },\n { x: 0.78125, y: 0.65625 },\n { x: 0.84375, y: 0.65625 },\n { x: 0.84375, y: 0.65625 },\n { x: 0.90625, y: 0.65625 },\n { x: 0.90625, y: 0.65625 },\n { x: 0.96875, y: 0.65625 },\n { x: 0.96875, y: 0.65625 },\n { x: 0.03125, y: 0.71875 },\n { x: 0.03125, y: 0.71875 },\n { x: 0.09375, y: 0.71875 },\n { x: 0.09375, y: 0.71875 },\n { x: 0.15625, y: 0.71875 },\n { x: 0.15625, y: 0.71875 },\n { x: 0.21875, y: 0.71875 },\n { x: 0.21875, y: 0.71875 },\n { x: 0.28125, y: 0.71875 },\n { x: 0.28125, y: 0.71875 },\n { x: 0.34375, y: 0.71875 },\n { x: 0.34375, y: 0.71875 },\n { x: 0.40625, y: 0.71875 },\n { x: 0.40625, y: 0.71875 },\n { x: 0.46875, y: 0.71875 },\n { x: 0.46875, y: 0.71875 },\n { x: 0.53125, y: 0.71875 },\n { x: 0.53125, y: 0.71875 },\n { x: 0.59375, y: 0.71875 },\n { x: 0.59375, y: 0.71875 },\n { x: 0.65625, y: 0.71875 },\n { x: 0.65625, y: 0.71875 },\n { x: 0.71875, y: 0.71875 },\n { x: 0.71875, y: 0.71875 },\n { x: 0.78125, y: 0.71875 },\n { x: 0.78125, y: 0.71875 },\n { x: 0.84375, y: 0.71875 },\n { x: 0.84375, y: 0.71875 },\n { x: 0.90625, y: 0.71875 },\n { x: 0.90625, y: 0.71875 },\n { x: 0.96875, y: 0.71875 },\n { x: 0.96875, y: 0.71875 },\n { x: 0.03125, y: 0.78125 },\n { x: 0.03125, y: 0.78125 },\n { x: 0.09375, y: 0.78125 },\n { x: 0.09375, y: 0.78125 },\n { x: 0.15625, y: 0.78125 },\n { x: 0.15625, y: 0.78125 },\n { x: 0.21875, y: 0.78125 },\n { x: 0.21875, y: 0.78125 },\n { x: 0.28125, y: 0.78125 },\n { x: 0.28125, y: 0.78125 },\n { x: 0.34375, y: 0.78125 },\n { x: 0.34375, y: 0.78125 },\n { x: 0.40625, y: 0.78125 },\n { x: 0.40625, y: 0.78125 },\n { x: 0.46875, y: 0.78125 },\n { x: 0.46875, y: 0.78125 },\n { x: 0.53125, y: 0.78125 },\n { x: 0.53125, y: 0.78125 },\n { x: 0.59375, y: 0.78125 },\n { x: 0.59375, y: 0.78125 },\n { x: 0.65625, y: 0.78125 },\n { x: 0.65625, y: 0.78125 },\n { x: 0.71875, y: 0.78125 },\n { x: 0.71875, y: 0.78125 },\n { x: 0.78125, y: 0.78125 },\n { x: 0.78125, y: 0.78125 },\n { x: 0.84375, y: 0.78125 },\n { x: 0.84375, y: 0.78125 },\n { x: 0.90625, y: 0.78125 },\n { x: 0.90625, y: 0.78125 },\n { x: 0.96875, y: 0.78125 },\n { x: 0.96875, y: 0.78125 },\n { x: 0.03125, y: 0.84375 },\n { x: 0.03125, y: 0.84375 },\n { x: 0.09375, y: 0.84375 },\n { x: 0.09375, y: 0.84375 },\n { x: 0.15625, y: 0.84375 },\n { x: 0.15625, y: 0.84375 },\n { x: 0.21875, y: 0.84375 },\n { x: 0.21875, y: 0.84375 },\n { x: 0.28125, y: 0.84375 },\n { x: 0.28125, y: 0.84375 },\n { x: 0.34375, y: 0.84375 },\n { x: 0.34375, y: 0.84375 },\n { x: 0.40625, y: 0.84375 },\n { x: 0.40625, y: 0.84375 },\n { x: 0.46875, y: 0.84375 },\n { x: 0.46875, y: 0.84375 },\n { x: 0.53125, y: 0.84375 },\n { x: 0.53125, y: 0.84375 },\n { x: 0.59375, y: 0.84375 },\n { x: 0.59375, y: 0.84375 },\n { x: 0.65625, y: 0.84375 },\n { x: 0.65625, y: 0.84375 },\n { x: 0.71875, y: 0.84375 },\n { x: 0.71875, y: 0.84375 },\n { x: 0.78125, y: 0.84375 },\n { x: 0.78125, y: 0.84375 },\n { x: 0.84375, y: 0.84375 },\n { x: 0.84375, y: 0.84375 },\n { x: 0.90625, y: 0.84375 },\n { x: 0.90625, y: 0.84375 },\n { x: 0.96875, y: 0.84375 },\n { x: 0.96875, y: 0.84375 },\n { x: 0.03125, y: 0.90625 },\n { x: 0.03125, y: 0.90625 },\n { x: 0.09375, y: 0.90625 },\n { x: 0.09375, y: 0.90625 },\n { x: 0.15625, y: 0.90625 },\n { x: 0.15625, y: 0.90625 },\n { x: 0.21875, y: 0.90625 },\n { x: 0.21875, y: 0.90625 },\n { x: 0.28125, y: 0.90625 },\n { x: 0.28125, y: 0.90625 },\n { x: 0.34375, y: 0.90625 },\n { x: 0.34375, y: 0.90625 },\n { x: 0.40625, y: 0.90625 },\n { x: 0.40625, y: 0.90625 },\n { x: 0.46875, y: 0.90625 },\n { x: 0.46875, y: 0.90625 },\n { x: 0.53125, y: 0.90625 },\n { x: 0.53125, y: 0.90625 },\n { x: 0.59375, y: 0.90625 },\n { x: 0.59375, y: 0.90625 },\n { x: 0.65625, y: 0.90625 },\n { x: 0.65625, y: 0.90625 },\n { x: 0.71875, y: 0.90625 },\n { x: 0.71875, y: 0.90625 },\n { x: 0.78125, y: 0.90625 },\n { x: 0.78125, y: 0.90625 },\n { x: 0.84375, y: 0.90625 },\n { x: 0.84375, y: 0.90625 },\n { x: 0.90625, y: 0.90625 },\n { x: 0.90625, y: 0.90625 },\n { x: 0.96875, y: 0.90625 },\n { x: 0.96875, y: 0.90625 },\n { x: 0.03125, y: 0.96875 },\n { x: 0.03125, y: 0.96875 },\n { x: 0.09375, y: 0.96875 },\n { x: 0.09375, y: 0.96875 },\n { x: 0.15625, y: 0.96875 },\n { x: 0.15625, y: 0.96875 },\n { x: 0.21875, y: 0.96875 },\n { x: 0.21875, y: 0.96875 },\n { x: 0.28125, y: 0.96875 },\n { x: 0.28125, y: 0.96875 },\n { x: 0.34375, y: 0.96875 },\n { x: 0.34375, y: 0.96875 },\n { x: 0.40625, y: 0.96875 },\n { x: 0.40625, y: 0.96875 },\n { x: 0.46875, y: 0.96875 },\n { x: 0.46875, y: 0.96875 },\n { x: 0.53125, y: 0.96875 },\n { x: 0.53125, y: 0.96875 },\n { x: 0.59375, y: 0.96875 },\n { x: 0.59375, y: 0.96875 },\n { x: 0.65625, y: 0.96875 },\n { x: 0.65625, y: 0.96875 },\n { x: 0.71875, y: 0.96875 },\n { x: 0.71875, y: 0.96875 },\n { x: 0.78125, y: 0.96875 },\n { x: 0.78125, y: 0.96875 },\n { x: 0.84375, y: 0.96875 },\n { x: 0.84375, y: 0.96875 },\n { x: 0.90625, y: 0.96875 },\n { x: 0.90625, y: 0.96875 },\n { x: 0.96875, y: 0.96875 },\n { x: 0.96875, y: 0.96875 },\n { x: 0.0625, y: 0.0625 },\n { x: 0.0625, y: 0.0625 },\n { x: 0.0625, y: 0.0625 },\n { x: 0.0625, y: 0.0625 },\n { x: 0.0625, y: 0.0625 },\n { x: 0.0625, y: 0.0625 },\n { x: 0.1875, y: 0.0625 },\n { x: 0.1875, y: 0.0625 },\n { x: 0.1875, y: 0.0625 },\n { x: 0.1875, y: 0.0625 },\n { x: 0.1875, y: 0.0625 },\n { x: 0.1875, y: 0.0625 },\n { x: 0.3125, y: 0.0625 },\n { x: 0.3125, y: 0.0625 },\n { x: 0.3125, y: 0.0625 },\n { x: 0.3125, y: 0.0625 },\n { x: 0.3125, y: 0.0625 },\n { x: 0.3125, y: 0.0625 },\n { x: 0.4375, y: 0.0625 },\n { x: 0.4375, y: 0.0625 },\n { x: 0.4375, y: 0.0625 },\n { x: 0.4375, y: 0.0625 },\n { x: 0.4375, y: 0.0625 },\n { x: 0.4375, y: 0.0625 },\n { x: 0.5625, y: 0.0625 },\n { x: 0.5625, y: 0.0625 },\n { x: 0.5625, y: 0.0625 },\n { x: 0.5625, y: 0.0625 },\n { x: 0.5625, y: 0.0625 },\n { x: 0.5625, y: 0.0625 },\n { x: 0.6875, y: 0.0625 },\n { x: 0.6875, y: 0.0625 },\n { x: 0.6875, y: 0.0625 },\n { x: 0.6875, y: 0.0625 },\n { x: 0.6875, y: 0.0625 },\n { x: 0.6875, y: 0.0625 },\n { x: 0.8125, y: 0.0625 },\n { x: 0.8125, y: 0.0625 },\n { x: 0.8125, y: 0.0625 },\n { x: 0.8125, y: 0.0625 },\n { x: 0.8125, y: 0.0625 },\n { x: 0.8125, y: 0.0625 },\n { x: 0.9375, y: 0.0625 },\n { x: 0.9375, y: 0.0625 },\n { x: 0.9375, y: 0.0625 },\n { x: 0.9375, y: 0.0625 },\n { x: 0.9375, y: 0.0625 },\n { x: 0.9375, y: 0.0625 },\n { x: 0.0625, y: 0.1875 },\n { x: 0.0625, y: 0.1875 },\n { x: 0.0625, y: 0.1875 },\n { x: 0.0625, y: 0.1875 },\n { x: 0.0625, y: 0.1875 },\n { x: 0.0625, y: 0.1875 },\n { x: 0.1875, y: 0.1875 },\n { x: 0.1875, y: 0.1875 },\n { x: 0.1875, y: 0.1875 },\n { x: 0.1875, y: 0.1875 },\n { x: 0.1875, y: 0.1875 },\n { x: 0.1875, y: 0.1875 },\n { x: 0.3125, y: 0.1875 },\n { x: 0.3125, y: 0.1875 },\n { x: 0.3125, y: 0.1875 },\n { x: 0.3125, y: 0.1875 },\n { x: 0.3125, y: 0.1875 },\n { x: 0.3125, y: 0.1875 },\n { x: 0.4375, y: 0.1875 },\n { x: 0.4375, y: 0.1875 },\n { x: 0.4375, y: 0.1875 },\n { x: 0.4375, y: 0.1875 },\n { x: 0.4375, y: 0.1875 },\n { x: 0.4375, y: 0.1875 },\n { x: 0.5625, y: 0.1875 },\n { x: 0.5625, y: 0.1875 },\n { x: 0.5625, y: 0.1875 },\n { x: 0.5625, y: 0.1875 },\n { x: 0.5625, y: 0.1875 },\n { x: 0.5625, y: 0.1875 },\n { x: 0.6875, y: 0.1875 },\n { x: 0.6875, y: 0.1875 },\n { x: 0.6875, y: 0.1875 },\n { x: 0.6875, y: 0.1875 },\n { x: 0.6875, y: 0.1875 },\n { x: 0.6875, y: 0.1875 },\n { x: 0.8125, y: 0.1875 },\n { x: 0.8125, y: 0.1875 },\n { x: 0.8125, y: 0.1875 },\n { x: 0.8125, y: 0.1875 },\n { x: 0.8125, y: 0.1875 },\n { x: 0.8125, y: 0.1875 },\n { x: 0.9375, y: 0.1875 },\n { x: 0.9375, y: 0.1875 },\n { x: 0.9375, y: 0.1875 },\n { x: 0.9375, y: 0.1875 },\n { x: 0.9375, y: 0.1875 },\n { x: 0.9375, y: 0.1875 },\n { x: 0.0625, y: 0.3125 },\n { x: 0.0625, y: 0.3125 },\n { x: 0.0625, y: 0.3125 },\n { x: 0.0625, y: 0.3125 },\n { x: 0.0625, y: 0.3125 },\n { x: 0.0625, y: 0.3125 },\n { x: 0.1875, y: 0.3125 },\n { x: 0.1875, y: 0.3125 },\n { x: 0.1875, y: 0.3125 },\n { x: 0.1875, y: 0.3125 },\n { x: 0.1875, y: 0.3125 },\n { x: 0.1875, y: 0.3125 },\n { x: 0.3125, y: 0.3125 },\n { x: 0.3125, y: 0.3125 },\n { x: 0.3125, y: 0.3125 },\n { x: 0.3125, y: 0.3125 },\n { x: 0.3125, y: 0.3125 },\n { x: 0.3125, y: 0.3125 },\n { x: 0.4375, y: 0.3125 },\n { x: 0.4375, y: 0.3125 },\n { x: 0.4375, y: 0.3125 },\n { x: 0.4375, y: 0.3125 },\n { x: 0.4375, y: 0.3125 },\n { x: 0.4375, y: 0.3125 },\n { x: 0.5625, y: 0.3125 },\n { x: 0.5625, y: 0.3125 },\n { x: 0.5625, y: 0.3125 },\n { x: 0.5625, y: 0.3125 },\n { x: 0.5625, y: 0.3125 },\n { x: 0.5625, y: 0.3125 },\n { x: 0.6875, y: 0.3125 },\n { x: 0.6875, y: 0.3125 },\n { x: 0.6875, y: 0.3125 },\n { x: 0.6875, y: 0.3125 },\n { x: 0.6875, y: 0.3125 },\n { x: 0.6875, y: 0.3125 },\n { x: 0.8125, y: 0.3125 },\n { x: 0.8125, y: 0.3125 },\n { x: 0.8125, y: 0.3125 },\n { x: 0.8125, y: 0.3125 },\n { x: 0.8125, y: 0.3125 },\n { x: 0.8125, y: 0.3125 },\n { x: 0.9375, y: 0.3125 },\n { x: 0.9375, y: 0.3125 },\n { x: 0.9375, y: 0.3125 },\n { x: 0.9375, y: 0.3125 },\n { x: 0.9375, y: 0.3125 },\n { x: 0.9375, y: 0.3125 },\n { x: 0.0625, y: 0.4375 },\n { x: 0.0625, y: 0.4375 },\n { x: 0.0625, y: 0.4375 },\n { x: 0.0625, y: 0.4375 },\n { x: 0.0625, y: 0.4375 },\n { x: 0.0625, y: 0.4375 },\n { x: 0.1875, y: 0.4375 },\n { x: 0.1875, y: 0.4375 },\n { x: 0.1875, y: 0.4375 },\n { x: 0.1875, y: 0.4375 },\n { x: 0.1875, y: 0.4375 },\n { x: 0.1875, y: 0.4375 },\n { x: 0.3125, y: 0.4375 },\n { x: 0.3125, y: 0.4375 },\n { x: 0.3125, y: 0.4375 },\n { x: 0.3125, y: 0.4375 },\n { x: 0.3125, y: 0.4375 },\n { x: 0.3125, y: 0.4375 },\n { x: 0.4375, y: 0.4375 },\n { x: 0.4375, y: 0.4375 },\n { x: 0.4375, y: 0.4375 },\n { x: 0.4375, y: 0.4375 },\n { x: 0.4375, y: 0.4375 },\n { x: 0.4375, y: 0.4375 },\n { x: 0.5625, y: 0.4375 },\n { x: 0.5625, y: 0.4375 },\n { x: 0.5625, y: 0.4375 },\n { x: 0.5625, y: 0.4375 },\n { x: 0.5625, y: 0.4375 },\n { x: 0.5625, y: 0.4375 },\n { x: 0.6875, y: 0.4375 },\n { x: 0.6875, y: 0.4375 },\n { x: 0.6875, y: 0.4375 },\n { x: 0.6875, y: 0.4375 },\n { x: 0.6875, y: 0.4375 },\n { x: 0.6875, y: 0.4375 },\n { x: 0.8125, y: 0.4375 },\n { x: 0.8125, y: 0.4375 },\n { x: 0.8125, y: 0.4375 },\n { x: 0.8125, y: 0.4375 },\n { x: 0.8125, y: 0.4375 },\n { x: 0.8125, y: 0.4375 },\n { x: 0.9375, y: 0.4375 },\n { x: 0.9375, y: 0.4375 },\n { x: 0.9375, y: 0.4375 },\n { x: 0.9375, y: 0.4375 },\n { x: 0.9375, y: 0.4375 },\n { x: 0.9375, y: 0.4375 },\n { x: 0.0625, y: 0.5625 },\n { x: 0.0625, y: 0.5625 },\n { x: 0.0625, y: 0.5625 },\n { x: 0.0625, y: 0.5625 },\n { x: 0.0625, y: 0.5625 },\n { x: 0.0625, y: 0.5625 },\n { x: 0.1875, y: 0.5625 },\n { x: 0.1875, y: 0.5625 },\n { x: 0.1875, y: 0.5625 },\n { x: 0.1875, y: 0.5625 },\n { x: 0.1875, y: 0.5625 },\n { x: 0.1875, y: 0.5625 },\n { x: 0.3125, y: 0.5625 },\n { x: 0.3125, y: 0.5625 },\n { x: 0.3125, y: 0.5625 },\n { x: 0.3125, y: 0.5625 },\n { x: 0.3125, y: 0.5625 },\n { x: 0.3125, y: 0.5625 },\n { x: 0.4375, y: 0.5625 },\n { x: 0.4375, y: 0.5625 },\n { x: 0.4375, y: 0.5625 },\n { x: 0.4375, y: 0.5625 },\n { x: 0.4375, y: 0.5625 },\n { x: 0.4375, y: 0.5625 },\n { x: 0.5625, y: 0.5625 },\n { x: 0.5625, y: 0.5625 },\n { x: 0.5625, y: 0.5625 },\n { x: 0.5625, y: 0.5625 },\n { x: 0.5625, y: 0.5625 },\n { x: 0.5625, y: 0.5625 },\n { x: 0.6875, y: 0.5625 },\n { x: 0.6875, y: 0.5625 },\n { x: 0.6875, y: 0.5625 },\n { x: 0.6875, y: 0.5625 },\n { x: 0.6875, y: 0.5625 },\n { x: 0.6875, y: 0.5625 },\n { x: 0.8125, y: 0.5625 },\n { x: 0.8125, y: 0.5625 },\n { x: 0.8125, y: 0.5625 },\n { x: 0.8125, y: 0.5625 },\n { x: 0.8125, y: 0.5625 },\n { x: 0.8125, y: 0.5625 },\n { x: 0.9375, y: 0.5625 },\n { x: 0.9375, y: 0.5625 },\n { x: 0.9375, y: 0.5625 },\n { x: 0.9375, y: 0.5625 },\n { x: 0.9375, y: 0.5625 },\n { x: 0.9375, y: 0.5625 },\n { x: 0.0625, y: 0.6875 },\n { x: 0.0625, y: 0.6875 },\n { x: 0.0625, y: 0.6875 },\n { x: 0.0625, y: 0.6875 },\n { x: 0.0625, y: 0.6875 },\n { x: 0.0625, y: 0.6875 },\n { x: 0.1875, y: 0.6875 },\n { x: 0.1875, y: 0.6875 },\n { x: 0.1875, y: 0.6875 },\n { x: 0.1875, y: 0.6875 },\n { x: 0.1875, y: 0.6875 },\n { x: 0.1875, y: 0.6875 },\n { x: 0.3125, y: 0.6875 },\n { x: 0.3125, y: 0.6875 },\n { x: 0.3125, y: 0.6875 },\n { x: 0.3125, y: 0.6875 },\n { x: 0.3125, y: 0.6875 },\n { x: 0.3125, y: 0.6875 },\n { x: 0.4375, y: 0.6875 },\n { x: 0.4375, y: 0.6875 },\n { x: 0.4375, y: 0.6875 },\n { x: 0.4375, y: 0.6875 },\n { x: 0.4375, y: 0.6875 },\n { x: 0.4375, y: 0.6875 },\n { x: 0.5625, y: 0.6875 },\n { x: 0.5625, y: 0.6875 },\n { x: 0.5625, y: 0.6875 },\n { x: 0.5625, y: 0.6875 },\n { x: 0.5625, y: 0.6875 },\n { x: 0.5625, y: 0.6875 },\n { x: 0.6875, y: 0.6875 },\n { x: 0.6875, y: 0.6875 },\n { x: 0.6875, y: 0.6875 },\n { x: 0.6875, y: 0.6875 },\n { x: 0.6875, y: 0.6875 },\n { x: 0.6875, y: 0.6875 },\n { x: 0.8125, y: 0.6875 },\n { x: 0.8125, y: 0.6875 },\n { x: 0.8125, y: 0.6875 },\n { x: 0.8125, y: 0.6875 },\n { x: 0.8125, y: 0.6875 },\n { x: 0.8125, y: 0.6875 },\n { x: 0.9375, y: 0.6875 },\n { x: 0.9375, y: 0.6875 },\n { x: 0.9375, y: 0.6875 },\n { x: 0.9375, y: 0.6875 },\n { x: 0.9375, y: 0.6875 },\n { x: 0.9375, y: 0.6875 },\n { x: 0.0625, y: 0.8125 },\n { x: 0.0625, y: 0.8125 },\n { x: 0.0625, y: 0.8125 },\n { x: 0.0625, y: 0.8125 },\n { x: 0.0625, y: 0.8125 },\n { x: 0.0625, y: 0.8125 },\n { x: 0.1875, y: 0.8125 },\n { x: 0.1875, y: 0.8125 },\n { x: 0.1875, y: 0.8125 },\n { x: 0.1875, y: 0.8125 },\n { x: 0.1875, y: 0.8125 },\n { x: 0.1875, y: 0.8125 },\n { x: 0.3125, y: 0.8125 },\n { x: 0.3125, y: 0.8125 },\n { x: 0.3125, y: 0.8125 },\n { x: 0.3125, y: 0.8125 },\n { x: 0.3125, y: 0.8125 },\n { x: 0.3125, y: 0.8125 },\n { x: 0.4375, y: 0.8125 },\n { x: 0.4375, y: 0.8125 },\n { x: 0.4375, y: 0.8125 },\n { x: 0.4375, y: 0.8125 },\n { x: 0.4375, y: 0.8125 },\n { x: 0.4375, y: 0.8125 },\n { x: 0.5625, y: 0.8125 },\n { x: 0.5625, y: 0.8125 },\n { x: 0.5625, y: 0.8125 },\n { x: 0.5625, y: 0.8125 },\n { x: 0.5625, y: 0.8125 },\n { x: 0.5625, y: 0.8125 },\n { x: 0.6875, y: 0.8125 },\n { x: 0.6875, y: 0.8125 },\n { x: 0.6875, y: 0.8125 },\n { x: 0.6875, y: 0.8125 },\n { x: 0.6875, y: 0.8125 },\n { x: 0.6875, y: 0.8125 },\n { x: 0.8125, y: 0.8125 },\n { x: 0.8125, y: 0.8125 },\n { x: 0.8125, y: 0.8125 },\n { x: 0.8125, y: 0.8125 },\n { x: 0.8125, y: 0.8125 },\n { x: 0.8125, y: 0.8125 },\n { x: 0.9375, y: 0.8125 },\n { x: 0.9375, y: 0.8125 },\n { x: 0.9375, y: 0.8125 },\n { x: 0.9375, y: 0.8125 },\n { x: 0.9375, y: 0.8125 },\n { x: 0.9375, y: 0.8125 },\n { x: 0.0625, y: 0.9375 },\n { x: 0.0625, y: 0.9375 },\n { x: 0.0625, y: 0.9375 },\n { x: 0.0625, y: 0.9375 },\n { x: 0.0625, y: 0.9375 },\n { x: 0.0625, y: 0.9375 },\n { x: 0.1875, y: 0.9375 },\n { x: 0.1875, y: 0.9375 },\n { x: 0.1875, y: 0.9375 },\n { x: 0.1875, y: 0.9375 },\n { x: 0.1875, y: 0.9375 },\n { x: 0.1875, y: 0.9375 },\n { x: 0.3125, y: 0.9375 },\n { x: 0.3125, y: 0.9375 },\n { x: 0.3125, y: 0.9375 },\n { x: 0.3125, y: 0.9375 },\n { x: 0.3125, y: 0.9375 },\n { x: 0.3125, y: 0.9375 },\n { x: 0.4375, y: 0.9375 },\n { x: 0.4375, y: 0.9375 },\n { x: 0.4375, y: 0.9375 },\n { x: 0.4375, y: 0.9375 },\n { x: 0.4375, y: 0.9375 },\n { x: 0.4375, y: 0.9375 },\n { x: 0.5625, y: 0.9375 },\n { x: 0.5625, y: 0.9375 },\n { x: 0.5625, y: 0.9375 },\n { x: 0.5625, y: 0.9375 },\n { x: 0.5625, y: 0.9375 },\n { x: 0.5625, y: 0.9375 },\n { x: 0.6875, y: 0.9375 },\n { x: 0.6875, y: 0.9375 },\n { x: 0.6875, y: 0.9375 },\n { x: 0.6875, y: 0.9375 },\n { x: 0.6875, y: 0.9375 },\n { x: 0.6875, y: 0.9375 },\n { x: 0.8125, y: 0.9375 },\n { x: 0.8125, y: 0.9375 },\n { x: 0.8125, y: 0.9375 },\n { x: 0.8125, y: 0.9375 },\n { x: 0.8125, y: 0.9375 },\n { x: 0.8125, y: 0.9375 },\n { x: 0.9375, y: 0.9375 },\n { x: 0.9375, y: 0.9375 },\n { x: 0.9375, y: 0.9375 },\n { x: 0.9375, y: 0.9375 },\n { x: 0.9375, y: 0.9375 },\n { x: 0.9375, y: 0.9375 },\n];\n", "/**\n * HandPose model implementation\n * See `handpose.ts` for entry point\n */\n\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as util from './handposeutil';\nimport * as anchors from './handposeanchors';\nimport { constants } from '../tfjs/constants';\nimport type { Tensor, GraphModel } from '../tfjs/types';\nimport type { Point } from '../result';\n\nexport class HandDetector {\n model: GraphModel;\n anchors: number[][];\n anchorsTensor: Tensor;\n inputSize: number;\n inputSizeTensor: Tensor;\n doubleInputSizeTensor: Tensor;\n\n constructor(model) {\n this.model = model;\n this.anchors = anchors.anchors.map((anchor) => [anchor.x, anchor.y]);\n this.anchorsTensor = tf.tensor2d(this.anchors);\n this.inputSize = (this.model && this.model.inputs && this.model.inputs[0].shape) ? this.model.inputs[0].shape[2] : 0;\n this.inputSizeTensor = tf.tensor1d([this.inputSize, this.inputSize]);\n this.doubleInputSizeTensor = tf.tensor1d([this.inputSize * 2, this.inputSize * 2]);\n }\n\n normalizeBoxes(boxes) {\n const t: Record = {};\n t.boxOffsets = tf.slice(boxes, [0, 0], [-1, 2]);\n t.boxSizes = tf.slice(boxes, [0, 2], [-1, 2]);\n t.div = tf.div(t.boxOffsets, this.inputSizeTensor);\n t.boxCenterPoints = tf.add(t.div, this.anchorsTensor);\n t.halfBoxSizes = tf.div(t.boxSizes, this.doubleInputSizeTensor);\n t.sub = tf.sub(t.boxCenterPoints, t.halfBoxSizes);\n t.startPoints = tf.mul(t.sub, this.inputSizeTensor);\n t.add = tf.add(t.boxCenterPoints, t.halfBoxSizes);\n t.endPoints = tf.mul(t.add, this.inputSizeTensor);\n const res = tf.concat2d([t.startPoints, t.endPoints], 1);\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n return res;\n }\n\n normalizeLandmarks(rawPalmLandmarks, index) {\n const t: Record = {};\n t.reshape = tf.reshape(rawPalmLandmarks, [-1, 7, 2]);\n t.div = tf.div(t.reshape, this.inputSizeTensor);\n t.landmarks = tf.add(t.div, this.anchors[index]);\n const res = tf.mul(t.landmarks, this.inputSizeTensor);\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n return res;\n }\n\n async predict(input, config): Promise<{ startPoint: Point; endPoint: Point, palmLandmarks: Point[]; confidence: number }[]> {\n const t: Record = {};\n t.resize = tf.image.resizeBilinear(input, [this.inputSize, this.inputSize]);\n t.div = tf.div(t.resize, constants.tf127);\n t.image = tf.sub(t.div, constants.tf1);\n t.batched = this.model.execute(t.image) as Tensor;\n t.predictions = tf.squeeze(t.batched);\n t.slice = tf.slice(t.predictions, [0, 0], [-1, 1]);\n t.sigmoid = tf.sigmoid(t.slice);\n t.scores = tf.squeeze(t.sigmoid);\n const scores = await t.scores.data();\n t.boxes = tf.slice(t.predictions, [0, 1], [-1, 4]);\n t.norm = this.normalizeBoxes(t.boxes);\n // box detection is flaky so we look for 3x boxes than we need results\n t.nms = await tf.image.nonMaxSuppressionAsync(t.norm, t.scores, 3 * config.hand.maxDetected, config.hand.iouThreshold, config.hand.minConfidence);\n const nms = await t.nms.array() as Array;\n const hands: Array<{ startPoint: Point; endPoint: Point; palmLandmarks: Point[]; confidence: number }> = [];\n for (const index of nms) {\n const p: Record = {};\n p.box = tf.slice(t.norm, [index, 0], [1, -1]);\n p.slice = tf.slice(t.predictions, [index, 5], [1, 14]);\n p.norm = this.normalizeLandmarks(p.slice, index);\n p.palmLandmarks = tf.reshape(p.norm, [-1, 2]);\n const box = await p.box.data();\n const startPoint = box.slice(0, 2) as unknown as Point;\n const endPoint = box.slice(2, 4) as unknown as Point;\n const palmLandmarks = await p.palmLandmarks.array();\n const hand = { startPoint, endPoint, palmLandmarks, confidence: scores[index] };\n const scaled = util.scaleBoxCoordinates(hand, [input.shape[2] / this.inputSize, input.shape[1] / this.inputSize]);\n hands.push(scaled);\n Object.keys(p).forEach((tensor) => tf.dispose(p[tensor]));\n }\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n return hands;\n }\n}\n", "/**\n * HandPose model implementation\n * See `handpose.ts` for entry point\n */\n\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as util from './handposeutil';\nimport type * as detector from './handposedetector';\nimport { constants } from '../tfjs/constants';\nimport type { Tensor, GraphModel } from '../tfjs/types';\nimport { env } from '../util/env';\nimport { now } from '../util/util';\nimport type { Point } from '../result';\n\nconst palmBoxEnlargeFactor = 5; // default 3\nconst handBoxEnlargeFactor = 1.65; // default 1.65\nconst palmLandmarkIds = [0, 5, 9, 13, 17, 1, 2];\nconst palmLandmarksPalmBase = 0;\nconst palmLandmarksMiddleFingerBase = 2;\nlet lastTime = 0;\n\nexport class HandPipeline {\n handDetector: detector.HandDetector;\n handPoseModel: GraphModel;\n inputSize: number;\n storedBoxes: Array<{ startPoint: Point; endPoint: Point; palmLandmarks: Point[]; confidence: number } | null>;\n skipped: number;\n detectedHands: number;\n\n constructor(handDetector, handPoseModel) {\n this.handDetector = handDetector;\n this.handPoseModel = handPoseModel;\n this.inputSize = this.handPoseModel && this.handPoseModel.inputs[0].shape ? this.handPoseModel.inputs[0].shape[2] : 0;\n this.storedBoxes = [];\n this.skipped = Number.MAX_SAFE_INTEGER;\n this.detectedHands = 0;\n }\n\n // eslint-disable-next-line class-methods-use-this\n calculateLandmarksBoundingBox(landmarks) {\n const xs = landmarks.map((d) => d[0]);\n const ys = landmarks.map((d) => d[1]);\n const startPoint = [Math.min(...xs), Math.min(...ys)];\n const endPoint = [Math.max(...xs), Math.max(...ys)];\n return { startPoint, endPoint };\n }\n\n getBoxForPalmLandmarks(palmLandmarks, rotationMatrix) {\n const rotatedPalmLandmarks = palmLandmarks.map((coord) => util.rotatePoint([...coord, 1], rotationMatrix));\n const boxAroundPalm = this.calculateLandmarksBoundingBox(rotatedPalmLandmarks);\n return util.enlargeBox(util.squarifyBox(boxAroundPalm), palmBoxEnlargeFactor);\n }\n\n getBoxForHandLandmarks(landmarks) {\n const boundingBox = this.calculateLandmarksBoundingBox(landmarks);\n const boxAroundHand = util.enlargeBox(util.squarifyBox(boundingBox), handBoxEnlargeFactor);\n boxAroundHand.palmLandmarks = [];\n for (let i = 0; i < palmLandmarkIds.length; i++) {\n boxAroundHand.palmLandmarks.push(landmarks[palmLandmarkIds[i]].slice(0, 2));\n }\n return boxAroundHand;\n }\n\n transformRawCoords(rawCoords, box2, angle, rotationMatrix) {\n const boxSize = util.getBoxSize(box2);\n const scaleFactor = [boxSize[0] / this.inputSize, boxSize[1] / this.inputSize, (boxSize[0] + boxSize[1]) / this.inputSize / 2];\n const coordsScaled = rawCoords.map((coord) => [\n scaleFactor[0] * (coord[0] - this.inputSize / 2),\n scaleFactor[1] * (coord[1] - this.inputSize / 2),\n scaleFactor[2] * coord[2],\n ]);\n const coordsRotationMatrix = util.buildRotationMatrix(angle, [0, 0]);\n const coordsRotated = coordsScaled.map((coord) => {\n const rotated = util.rotatePoint(coord, coordsRotationMatrix);\n return [...rotated, coord[2]];\n });\n const inverseRotationMatrix = util.invertTransformMatrix(rotationMatrix);\n const boxCenter = [...util.getBoxCenter(box2), 1];\n const originalBoxCenter = [\n util.dot(boxCenter, inverseRotationMatrix[0]),\n util.dot(boxCenter, inverseRotationMatrix[1]),\n ];\n return coordsRotated.map((coord) => [\n Math.trunc(coord[0] + originalBoxCenter[0]),\n Math.trunc(coord[1] + originalBoxCenter[1]),\n Math.trunc(coord[2]),\n ]);\n }\n\n async estimateHands(image, config) {\n let useFreshBox = false;\n\n // run new detector every skipFrames\n let boxes;\n const skipTime = (config.hand.skipTime || 0) > (now() - lastTime);\n const skipFrame = this.skipped < (config.hand.skipFrames || 0);\n if (config.skipAllowed && skipTime && skipFrame) {\n boxes = await this.handDetector.predict(image, config);\n this.skipped = 0;\n }\n if (config.skipAllowed) this.skipped++;\n\n // if detector result count doesn't match current working set, use it to reset current working set\n if (boxes && (boxes.length > 0) && ((boxes.length !== this.detectedHands) && (this.detectedHands !== config.hand.maxDetected) || !config.hand.landmarks)) {\n this.detectedHands = 0;\n this.storedBoxes = [...boxes];\n // for (const possible of boxes) this.storedBoxes.push(possible);\n if (this.storedBoxes.length > 0) useFreshBox = true;\n }\n const hands: Array<{ landmarks: Point[], confidence: number, boxConfidence: number, fingerConfidence: number, box: { topLeft: Point, bottomRight: Point } }> = [];\n\n // go through working set of boxes\n for (let i = 0; i < this.storedBoxes.length; i++) {\n const currentBox = this.storedBoxes[i];\n if (!currentBox) continue;\n if (config.hand.landmarks) {\n const angle = config.hand.rotation ? util.computeRotation(currentBox.palmLandmarks[palmLandmarksPalmBase], currentBox.palmLandmarks[palmLandmarksMiddleFingerBase]) : 0;\n const palmCenter = util.getBoxCenter(currentBox);\n const palmCenterNormalized = [palmCenter[0] / image.shape[2], palmCenter[1] / image.shape[1]];\n const rotatedImage = config.hand.rotation && env.kernels.includes('rotatewithoffset') ? tf.image.rotateWithOffset(image, angle, 0, palmCenterNormalized) : image.clone();\n const rotationMatrix = util.buildRotationMatrix(-angle, palmCenter);\n const newBox = useFreshBox ? this.getBoxForPalmLandmarks(currentBox.palmLandmarks, rotationMatrix) : currentBox;\n const croppedInput = util.cutBoxFromImageAndResize(newBox, rotatedImage, [this.inputSize, this.inputSize]);\n const handImage = tf.div(croppedInput, constants.tf255);\n tf.dispose(croppedInput);\n tf.dispose(rotatedImage);\n const [confidenceT, keypoints] = this.handPoseModel.execute(handImage) as Array;\n lastTime = now();\n tf.dispose(handImage);\n const confidence = (await confidenceT.data())[0];\n tf.dispose(confidenceT);\n if (confidence >= config.hand.minConfidence / 4) {\n const keypointsReshaped = tf.reshape(keypoints, [-1, 3]);\n const rawCoords = await keypointsReshaped.array();\n tf.dispose(keypoints);\n tf.dispose(keypointsReshaped);\n const coords = this.transformRawCoords(rawCoords, newBox, angle, rotationMatrix);\n const nextBoundingBox = this.getBoxForHandLandmarks(coords);\n this.storedBoxes[i] = { ...nextBoundingBox, confidence };\n const result = {\n landmarks: coords,\n confidence,\n boxConfidence: currentBox.confidence,\n fingerConfidence: confidence,\n box: { topLeft: nextBoundingBox.startPoint, bottomRight: nextBoundingBox.endPoint },\n };\n hands.push(result);\n } else {\n this.storedBoxes[i] = null;\n }\n tf.dispose(keypoints);\n } else {\n // const enlarged = box.enlargeBox(box.squarifyBox(box.shiftBox(currentBox, HAND_BOX_SHIFT_VECTOR)), handBoxEnlargeFactor);\n const enlarged = util.enlargeBox(util.squarifyBox(currentBox), handBoxEnlargeFactor);\n const result = {\n confidence: currentBox.confidence,\n boxConfidence: currentBox.confidence,\n fingerConfidence: 0,\n box: { topLeft: enlarged.startPoint, bottomRight: enlarged.endPoint },\n landmarks: [],\n };\n hands.push(result);\n }\n }\n this.storedBoxes = this.storedBoxes.filter((a) => a !== null);\n this.detectedHands = hands.length;\n if (hands.length > config.hand.maxDetected) hands.length = config.hand.maxDetected;\n return hands;\n }\n}\n", "/**\n * FingerPose algorithm implementation\n * See `fingerpose.ts` for entry point\n */\n\nexport const Finger = {\n thumb: 0,\n index: 1,\n middle: 2,\n ring: 3,\n pinky: 4,\n all: [0, 1, 2, 3, 4], // just for convenience\n nameMapping: { 0: 'thumb', 1: 'index', 2: 'middle', 3: 'ring', 4: 'pinky' },\n // Describes mapping of joints based on the 21 points returned by handpose.\n // [0] Palm\n // [1-4] Thumb\n // [5-8] Index\n // [9-12] Middle\n // [13-16] Ring\n // [17-20] Pinky\n pointsMapping: {\n 0: [[0, 1], [1, 2], [2, 3], [3, 4]],\n 1: [[0, 5], [5, 6], [6, 7], [7, 8]],\n 2: [[0, 9], [9, 10], [10, 11], [11, 12]],\n 3: [[0, 13], [13, 14], [14, 15], [15, 16]],\n 4: [[0, 17], [17, 18], [18, 19], [19, 20]],\n },\n getName: (value) => Finger.nameMapping[value],\n getPoints: (value) => Finger.pointsMapping[value],\n};\n\nexport const FingerCurl = {\n none: 0,\n half: 1,\n full: 2,\n nameMapping: { 0: 'none', 1: 'half', 2: 'full' },\n getName: (value) => FingerCurl.nameMapping[value],\n};\n\nexport const FingerDirection = {\n verticalUp: 0,\n verticalDown: 1,\n horizontalLeft: 2,\n horizontalRight: 3,\n diagonalUpRight: 4,\n diagonalUpLeft: 5,\n diagonalDownRight: 6,\n diagonalDownLeft: 7,\n nameMapping: { 0: 'verticalUp', 1: 'verticalDown', 2: 'horizontalLeft', 3: 'horizontalRight', 4: 'diagonalUpRight', 5: 'diagonalUpLeft', 6: 'diagonalDownRight', 7: 'diagonalDownLeft' },\n getName: (value) => FingerDirection.nameMapping[value],\n};\n\nexport class FingerGesture {\n name;\n curls;\n directions;\n weights;\n weightsRelative;\n\n constructor(name) {\n // name (should be unique)\n this.name = name;\n this.curls = {};\n this.directions = {};\n this.weights = [1.0, 1.0, 1.0, 1.0, 1.0];\n this.weightsRelative = [1.0, 1.0, 1.0, 1.0, 1.0];\n }\n\n curl(finger, curl, confidence) {\n if (typeof this.curls[finger] === 'undefined') this.curls[finger] = [];\n this.curls[finger].push([curl, confidence]);\n }\n\n direction(finger, position, confidence) {\n if (!this.directions[finger]) this.directions[finger] = [];\n this.directions[finger].push([position, confidence]);\n }\n\n weight(finger, weight) {\n this.weights[finger] = weight;\n // recalculate relative weights\n const total = this.weights.reduce((a, b) => a + b, 0);\n this.weightsRelative = this.weights.map((el) => el * 5 / total);\n }\n\n matchAgainst(detectedCurls, detectedDirections) {\n let confidence = 0.0;\n // look at the detected curl of each finger and compare with\n // the expected curl of this finger inside current gesture\n for (const fingerIdx in detectedCurls) {\n const detectedCurl = detectedCurls[fingerIdx];\n const expectedCurls = this.curls[fingerIdx];\n if (typeof expectedCurls === 'undefined') {\n // no curl description available for this finger\n // add default confidence of \"1\"\n confidence += this.weightsRelative[fingerIdx];\n continue;\n }\n // compare to each possible curl of this specific finger\n for (const [expectedCurl, score] of expectedCurls) {\n if (detectedCurl === expectedCurl) {\n confidence += score * this.weightsRelative[fingerIdx];\n break;\n }\n }\n }\n // same for detected direction of each finger\n for (const fingerIdx in detectedDirections) {\n const detectedDirection = detectedDirections[fingerIdx];\n const expectedDirections = this.directions[fingerIdx];\n if (typeof expectedDirections === 'undefined') {\n // no direction description available for this finger\n // add default confidence of \"1\"\n confidence += this.weightsRelative[fingerIdx];\n continue;\n }\n // compare to each possible direction of this specific finger\n for (const [expectedDirection, score] of expectedDirections) {\n if (detectedDirection === expectedDirection) {\n confidence += score * this.weightsRelative[fingerIdx];\n break;\n }\n }\n }\n return confidence / 10;\n }\n}\n", "/**\n * FingerPose algorithm implementation\n * See `fingerpose.ts` for entry point\n */\n\nimport { Finger, FingerCurl, FingerDirection, FingerGesture } from './fingerdef';\n\n// eslint-disable-next-line no-unused-vars, @typescript-eslint/no-unused-vars\nexport const { thumb, index, middle, ring, pinky } = Finger;\n// eslint-disable-next-line no-unused-vars, @typescript-eslint/no-unused-vars\nexport const { none, half, full } = FingerCurl;\n// eslint-disable-next-line no-unused-vars, @typescript-eslint/no-unused-vars\nexport const { verticalUp, verticalDown, horizontalLeft, horizontalRight, diagonalUpRight, diagonalUpLeft, diagonalDownRight, diagonalDownLeft } = FingerDirection;\n\n// describe thumbs up gesture \uD83D\uDC4D\nconst ThumbsUp = new FingerGesture('thumbs up');\nThumbsUp.curl(thumb, none, 1.0);\nThumbsUp.direction(thumb, verticalUp, 1.0);\nThumbsUp.direction(thumb, diagonalUpLeft, 0.25);\nThumbsUp.direction(thumb, diagonalUpRight, 0.25);\nfor (const finger of [Finger.index, Finger.middle, Finger.ring, Finger.pinky]) {\n ThumbsUp.curl(finger, full, 1.0);\n ThumbsUp.direction(finger, horizontalLeft, 1.0);\n ThumbsUp.direction(finger, horizontalRight, 1.0);\n}\n\n// describe Victory gesture \u270C\uFE0F\nconst Victory = new FingerGesture('victory');\nVictory.curl(thumb, half, 0.5);\nVictory.curl(thumb, none, 0.5);\nVictory.direction(thumb, verticalUp, 1.0);\nVictory.direction(thumb, diagonalUpLeft, 1.0);\nVictory.curl(index, none, 1.0);\nVictory.direction(index, verticalUp, 0.75);\nVictory.direction(index, diagonalUpLeft, 1.0);\nVictory.curl(middle, none, 1.0);\nVictory.direction(middle, verticalUp, 1.0);\nVictory.direction(middle, diagonalUpLeft, 0.75);\nVictory.curl(ring, full, 1.0);\nVictory.direction(ring, verticalUp, 0.2);\nVictory.direction(ring, diagonalUpLeft, 1.0);\nVictory.direction(ring, horizontalLeft, 0.2);\nVictory.curl(pinky, full, 1.0);\nVictory.direction(pinky, verticalUp, 0.2);\nVictory.direction(pinky, diagonalUpLeft, 1.0);\nVictory.direction(pinky, horizontalLeft, 0.2);\nVictory.weight(index, 2);\nVictory.weight(middle, 2);\n\n// describe Point gesture \u270C\uFE0F\nconst Point = new FingerGesture('point');\nPoint.curl(thumb, full, 1.0);\nPoint.curl(index, none, 0.5);\nPoint.curl(middle, full, 0.5);\nPoint.curl(ring, full, 0.5);\nPoint.curl(pinky, full, 0.5);\nPoint.weight(index, 2);\nPoint.weight(middle, 2);\n\n// describe Point gesture \u270C\uFE0F\nconst MiddleFinger = new FingerGesture('middle finger');\nMiddleFinger.curl(thumb, none, 1.0);\nMiddleFinger.curl(index, full, 0.5);\nMiddleFinger.curl(middle, full, 0.5);\nMiddleFinger.curl(ring, full, 0.5);\nMiddleFinger.curl(pinky, full, 0.5);\nMiddleFinger.weight(index, 2);\nMiddleFinger.weight(middle, 2);\n\n// describe Open Palm gesture \u270C\uFE0F\nconst OpenPalm = new FingerGesture('open palm');\nOpenPalm.curl(thumb, none, 0.75);\nOpenPalm.curl(index, none, 0.75);\nOpenPalm.curl(middle, none, 0.75);\nOpenPalm.curl(ring, none, 0.75);\nOpenPalm.curl(pinky, none, 0.75);\n\nexport default [ThumbsUp, Victory, Point, MiddleFinger, OpenPalm];\n", "/**\n * FingerPose algorithm implementation constants\n *\n * Based on: [**FingerPose***](https://github.com/andypotato/fingerpose)\n */\n\nimport { Finger, FingerCurl, FingerDirection } from './fingerdef';\nimport Gestures from '../hand/fingergesture';\n\nconst minConfidence = 0.7;\nconst options = {\n // curl estimation\n HALF_CURL_START_LIMIT: 60.0,\n NO_CURL_START_LIMIT: 130.0,\n // direction estimation\n DISTANCE_VOTE_POWER: 1.1,\n SINGLE_ANGLE_VOTE_POWER: 0.9,\n TOTAL_ANGLE_VOTE_POWER: 1.6,\n};\n\nfunction calculateSlope(point1x, point1y, point2x, point2y) {\n const value = (point1y - point2y) / (point1x - point2x);\n let slope = Math.atan(value) * 180 / Math.PI;\n if (slope <= 0) slope = -slope;\n else if (slope > 0) slope = 180 - slope;\n return slope;\n}\n\n// point1, point2 are 2d or 3d point arrays (xy[z])\n// returns either a single scalar (2d) or array of two slopes (3d)\nfunction getSlopes(point1, point2) {\n if (!point1 || !point2) return [0, 0];\n const slopeXY = calculateSlope(point1[0], point1[1], point2[0], point2[1]);\n if (point1.length === 2) return slopeXY;\n const slopeYZ = calculateSlope(point1[1], point1[2], point2[1], point2[2]);\n return [slopeXY, slopeYZ];\n}\n\nfunction angleOrientationAt(angle, weightageAt = 1.0) {\n let isVertical = 0;\n let isDiagonal = 0;\n let isHorizontal = 0;\n if (angle >= 75.0 && angle <= 105.0) isVertical = 1 * weightageAt;\n else if (angle >= 25.0 && angle <= 155.0) isDiagonal = 1 * weightageAt;\n else isHorizontal = 1 * weightageAt;\n return [isVertical, isDiagonal, isHorizontal];\n}\n\nfunction estimateFingerCurl(startPoint, midPoint, endPoint) {\n const start_mid_x_dist = startPoint[0] - midPoint[0];\n const start_end_x_dist = startPoint[0] - endPoint[0];\n const mid_end_x_dist = midPoint[0] - endPoint[0];\n const start_mid_y_dist = startPoint[1] - midPoint[1];\n const start_end_y_dist = startPoint[1] - endPoint[1];\n const mid_end_y_dist = midPoint[1] - endPoint[1];\n const start_mid_z_dist = startPoint[2] - midPoint[2];\n const start_end_z_dist = startPoint[2] - endPoint[2];\n const mid_end_z_dist = midPoint[2] - endPoint[2];\n const start_mid_dist = Math.sqrt(start_mid_x_dist * start_mid_x_dist + start_mid_y_dist * start_mid_y_dist + start_mid_z_dist * start_mid_z_dist);\n const start_end_dist = Math.sqrt(start_end_x_dist * start_end_x_dist + start_end_y_dist * start_end_y_dist + start_end_z_dist * start_end_z_dist);\n const mid_end_dist = Math.sqrt(mid_end_x_dist * mid_end_x_dist + mid_end_y_dist * mid_end_y_dist + mid_end_z_dist * mid_end_z_dist);\n let cos_in = (mid_end_dist * mid_end_dist + start_mid_dist * start_mid_dist - start_end_dist * start_end_dist) / (2 * mid_end_dist * start_mid_dist);\n if (cos_in > 1.0) cos_in = 1.0;\n else if (cos_in < -1.0) cos_in = -1.0;\n let angleOfCurve = Math.acos(cos_in);\n angleOfCurve = (57.2958 * angleOfCurve) % 180;\n let fingerCurl;\n if (angleOfCurve > options.NO_CURL_START_LIMIT) fingerCurl = FingerCurl.none;\n else if (angleOfCurve > options.HALF_CURL_START_LIMIT) fingerCurl = FingerCurl.half;\n else fingerCurl = FingerCurl.full;\n return fingerCurl;\n}\n\nfunction estimateHorizontalDirection(start_end_x_dist, start_mid_x_dist, mid_end_x_dist, max_dist_x) {\n let estimatedDirection;\n if (max_dist_x === Math.abs(start_end_x_dist)) {\n if (start_end_x_dist > 0) estimatedDirection = FingerDirection.horizontalLeft;\n else estimatedDirection = FingerDirection.horizontalRight;\n } else if (max_dist_x === Math.abs(start_mid_x_dist)) {\n if (start_mid_x_dist > 0) estimatedDirection = FingerDirection.horizontalLeft;\n else estimatedDirection = FingerDirection.horizontalRight;\n } else {\n if (mid_end_x_dist > 0) estimatedDirection = FingerDirection.horizontalLeft;\n else estimatedDirection = FingerDirection.horizontalRight;\n }\n return estimatedDirection;\n}\n\nfunction estimateVerticalDirection(start_end_y_dist, start_mid_y_dist, mid_end_y_dist, max_dist_y) {\n let estimatedDirection;\n if (max_dist_y === Math.abs(start_end_y_dist)) {\n if (start_end_y_dist < 0) estimatedDirection = FingerDirection.verticalDown;\n else estimatedDirection = FingerDirection.verticalUp;\n } else if (max_dist_y === Math.abs(start_mid_y_dist)) {\n if (start_mid_y_dist < 0) estimatedDirection = FingerDirection.verticalDown;\n else estimatedDirection = FingerDirection.verticalUp;\n } else {\n if (mid_end_y_dist < 0) estimatedDirection = FingerDirection.verticalDown;\n else estimatedDirection = FingerDirection.verticalUp;\n }\n return estimatedDirection;\n}\n\nfunction estimateDiagonalDirection(start_end_y_dist, start_mid_y_dist, mid_end_y_dist, max_dist_y, start_end_x_dist, start_mid_x_dist, mid_end_x_dist, max_dist_x) {\n let estimatedDirection;\n const reqd_vertical_direction = estimateVerticalDirection(start_end_y_dist, start_mid_y_dist, mid_end_y_dist, max_dist_y);\n const reqd_horizontal_direction = estimateHorizontalDirection(start_end_x_dist, start_mid_x_dist, mid_end_x_dist, max_dist_x);\n if (reqd_vertical_direction === FingerDirection.verticalUp) {\n if (reqd_horizontal_direction === FingerDirection.horizontalLeft) estimatedDirection = FingerDirection.diagonalUpLeft;\n else estimatedDirection = FingerDirection.diagonalUpRight;\n } else {\n if (reqd_horizontal_direction === FingerDirection.horizontalLeft) estimatedDirection = FingerDirection.diagonalDownLeft;\n else estimatedDirection = FingerDirection.diagonalDownRight;\n }\n return estimatedDirection;\n}\n\nfunction calculateFingerDirection(startPoint, midPoint, endPoint, fingerSlopes) {\n const start_mid_x_dist = startPoint[0] - midPoint[0];\n const start_end_x_dist = startPoint[0] - endPoint[0];\n const mid_end_x_dist = midPoint[0] - endPoint[0];\n const start_mid_y_dist = startPoint[1] - midPoint[1];\n const start_end_y_dist = startPoint[1] - endPoint[1];\n const mid_end_y_dist = midPoint[1] - endPoint[1];\n const max_dist_x = Math.max(Math.abs(start_mid_x_dist), Math.abs(start_end_x_dist), Math.abs(mid_end_x_dist));\n const max_dist_y = Math.max(Math.abs(start_mid_y_dist), Math.abs(start_end_y_dist), Math.abs(mid_end_y_dist));\n let voteVertical = 0.0;\n let voteDiagonal = 0.0;\n let voteHorizontal = 0.0;\n const start_end_x_y_dist_ratio = max_dist_y / (max_dist_x + 0.00001);\n if (start_end_x_y_dist_ratio > 1.5) voteVertical += options.DISTANCE_VOTE_POWER;\n else if (start_end_x_y_dist_ratio > 0.66) voteDiagonal += options.DISTANCE_VOTE_POWER;\n else voteHorizontal += options.DISTANCE_VOTE_POWER;\n const start_mid_dist = Math.sqrt(start_mid_x_dist * start_mid_x_dist + start_mid_y_dist * start_mid_y_dist);\n const start_end_dist = Math.sqrt(start_end_x_dist * start_end_x_dist + start_end_y_dist * start_end_y_dist);\n const mid_end_dist = Math.sqrt(mid_end_x_dist * mid_end_x_dist + mid_end_y_dist * mid_end_y_dist);\n const max_dist = Math.max(start_mid_dist, start_end_dist, mid_end_dist);\n let calc_start_point_x = startPoint[0];\n let calc_start_point_y = startPoint[1];\n let calc_end_point_x = endPoint[0];\n let calc_end_point_y = endPoint[1];\n if (max_dist === start_mid_dist) {\n calc_end_point_x = endPoint[0];\n calc_end_point_y = endPoint[1];\n } else if (max_dist === mid_end_dist) {\n calc_start_point_x = midPoint[0];\n calc_start_point_y = midPoint[1];\n }\n const calcStartPoint = [calc_start_point_x, calc_start_point_y];\n const calcEndPoint = [calc_end_point_x, calc_end_point_y];\n const totalAngle = getSlopes(calcStartPoint, calcEndPoint);\n const votes = angleOrientationAt(totalAngle, options.TOTAL_ANGLE_VOTE_POWER);\n voteVertical += votes[0];\n voteDiagonal += votes[1];\n voteHorizontal += votes[2];\n for (const fingerSlope of fingerSlopes) {\n const fingerVotes = angleOrientationAt(fingerSlope, options.SINGLE_ANGLE_VOTE_POWER);\n voteVertical += fingerVotes[0];\n voteDiagonal += fingerVotes[1];\n voteHorizontal += fingerVotes[2];\n }\n // in case of tie, highest preference goes to Vertical,\n // followed by horizontal and then diagonal\n let estimatedDirection;\n if (voteVertical === Math.max(voteVertical, voteDiagonal, voteHorizontal)) {\n estimatedDirection = estimateVerticalDirection(start_end_y_dist, start_mid_y_dist, mid_end_y_dist, max_dist_y);\n } else if (voteHorizontal === Math.max(voteDiagonal, voteHorizontal)) {\n estimatedDirection = estimateHorizontalDirection(start_end_x_dist, start_mid_x_dist, mid_end_x_dist, max_dist_x);\n } else {\n estimatedDirection = estimateDiagonalDirection(start_end_y_dist, start_mid_y_dist, mid_end_y_dist, max_dist_y, start_end_x_dist, start_mid_x_dist, mid_end_x_dist, max_dist_x);\n }\n return estimatedDirection;\n}\n\nfunction estimate(landmarks) {\n // step 1: calculate slopes\n const slopesXY: Array = [];\n const slopesYZ: Array = [];\n const fingerCurls: Array = [];\n const fingerDirections: Array = [];\n if (!landmarks) return { curls: fingerCurls, directions: fingerDirections };\n\n // step 1: calculate slopes\n for (const finger of Finger.all) {\n const points = Finger.getPoints(finger);\n const slopeAtXY: Array = [];\n const slopeAtYZ: Array = [];\n for (const point of points) {\n const point1 = landmarks[point[0]];\n const point2 = landmarks[point[1]];\n // calculate single slope\n const slopes = getSlopes(point1, point2);\n const slopeXY = slopes[0];\n const slopeYZ = slopes[1];\n slopeAtXY.push(slopeXY);\n slopeAtYZ.push(slopeYZ);\n }\n slopesXY.push(slopeAtXY);\n slopesYZ.push(slopeAtYZ);\n }\n\n // step 2: calculate orientations\n for (const finger of Finger.all) {\n // start finger predictions from palm - except for thumb\n const pointIndexAt = (finger === Finger.thumb) ? 1 : 0;\n const fingerPointsAt = Finger.getPoints(finger);\n const startPoint = landmarks[fingerPointsAt[pointIndexAt][0]];\n const midPoint = landmarks[fingerPointsAt[pointIndexAt + 1][1]];\n const endPoint = landmarks[fingerPointsAt[3][1]];\n // check if finger is curled\n const fingerCurled = estimateFingerCurl(startPoint, midPoint, endPoint);\n const fingerPosition = calculateFingerDirection(startPoint, midPoint, endPoint, slopesXY[finger].slice(pointIndexAt));\n fingerCurls[finger] = fingerCurled;\n fingerDirections[finger] = fingerPosition;\n }\n return { curls: fingerCurls, directions: fingerDirections };\n}\n\nexport function analyze(keypoints) { // get estimations of curl / direction for each finger\n if (!keypoints || keypoints.length === 0) return null;\n const estimatorRes = estimate(keypoints);\n const landmarks = {};\n for (const fingerIdx of Finger.all) {\n landmarks[Finger.getName(fingerIdx)] = {\n curl: FingerCurl.getName(estimatorRes.curls[fingerIdx]),\n direction: FingerDirection.getName(estimatorRes.directions[fingerIdx]),\n };\n }\n return landmarks;\n}\n\nexport function match(keypoints) { // compare gesture description to each known gesture\n const poses: Array<{ name: string, confidence: number }> = [];\n if (!keypoints || keypoints.length === 0) return poses;\n const estimatorRes = estimate(keypoints);\n for (const gesture of Gestures) {\n const confidence = gesture.matchAgainst(estimatorRes.curls, estimatorRes.directions);\n if (confidence >= minConfidence) poses.push({ name: gesture.name, confidence });\n }\n return poses;\n}\n", "/**\n * HandPose model implementation\n *\n * Based on: [**MediaPipe HandPose**](https://drive.google.com/file/d/1sv4sSb9BSNVZhLzxXJ0jBv9DqD-4jnAz/view)\n */\n\nimport { log } from '../util/util';\nimport * as handdetector from './handposedetector';\nimport * as handpipeline from './handposepipeline';\nimport * as fingerPose from './fingerpose';\nimport { loadModel } from '../tfjs/load';\nimport type { HandResult, Box, Point } from '../result';\nimport type { Tensor, GraphModel } from '../tfjs/types';\nimport type { Config } from '../config';\nimport { env } from '../util/env';\n\nconst meshAnnotations = {\n thumb: [1, 2, 3, 4],\n index: [5, 6, 7, 8],\n middle: [9, 10, 11, 12],\n ring: [13, 14, 15, 16],\n pinky: [17, 18, 19, 20],\n palm: [0],\n};\n\nlet handDetectorModel: GraphModel | null;\nlet handPoseModel: GraphModel | null;\nlet handPipeline: handpipeline.HandPipeline;\n\nexport async function predict(input: Tensor, config: Config): Promise {\n const predictions = await handPipeline.estimateHands(input, config);\n if (!predictions) return [];\n const hands: Array = [];\n for (let i = 0; i < predictions.length; i++) {\n const annotations = {};\n if (predictions[i].landmarks) {\n for (const key of Object.keys(meshAnnotations)) {\n annotations[key] = meshAnnotations[key].map((index) => predictions[i].landmarks[index]);\n }\n }\n const keypoints = predictions[i].landmarks as unknown as Array;\n let box: Box = [Number.MAX_SAFE_INTEGER, Number.MAX_SAFE_INTEGER, 0, 0]; // maximums so conditionals work\n let boxRaw: Box = [0, 0, 0, 0];\n if (keypoints && keypoints.length > 0) { // if we have landmarks, calculate box based on landmarks\n for (const pt of keypoints) {\n if (pt[0] < box[0]) box[0] = pt[0];\n if (pt[1] < box[1]) box[1] = pt[1];\n if (pt[0] > box[2]) box[2] = pt[0];\n if (pt[1] > box[3]) box[3] = pt[1];\n }\n box[2] -= box[0];\n box[3] -= box[1];\n boxRaw = [box[0] / (input.shape[2] || 0), box[1] / (input.shape[1] || 0), box[2] / (input.shape[2] || 0), box[3] / (input.shape[1] || 0)];\n } else { // otherwise use box from prediction\n box = predictions[i].box ? [\n Math.trunc(Math.max(0, predictions[i].box.topLeft[0])),\n Math.trunc(Math.max(0, predictions[i].box.topLeft[1])),\n Math.trunc(Math.min((input.shape[2] || 0), predictions[i].box.bottomRight[0]) - Math.max(0, predictions[i].box.topLeft[0])),\n Math.trunc(Math.min((input.shape[1] || 0), predictions[i].box.bottomRight[1]) - Math.max(0, predictions[i].box.topLeft[1])),\n ] : [0, 0, 0, 0];\n boxRaw = [\n (predictions[i].box.topLeft[0]) / (input.shape[2] || 0),\n (predictions[i].box.topLeft[1]) / (input.shape[1] || 0),\n (predictions[i].box.bottomRight[0] - predictions[i].box.topLeft[0]) / (input.shape[2] || 0),\n (predictions[i].box.bottomRight[1] - predictions[i].box.topLeft[1]) / (input.shape[1] || 0),\n ];\n }\n const landmarks = fingerPose.analyze(keypoints);\n hands.push({\n id: i,\n score: Math.round(100 * predictions[i].confidence) / 100,\n boxScore: Math.round(100 * predictions[i].boxConfidence) / 100,\n fingerScore: Math.round(100 * predictions[i].fingerConfidence) / 100,\n label: 'hand',\n box,\n boxRaw,\n keypoints,\n annotations: annotations as HandResult['annotations'],\n landmarks: landmarks as HandResult['landmarks'],\n });\n }\n return hands;\n}\n\nexport async function load(config: Config): Promise<[GraphModel | null, GraphModel | null]> {\n if (env.initial) {\n handDetectorModel = null;\n handPoseModel = null;\n }\n if (!handDetectorModel || !handPoseModel) {\n [handDetectorModel, handPoseModel] = await Promise.all([\n config.hand.enabled ? loadModel(config.hand.detector?.modelPath) : null,\n config.hand.landmarks ? loadModel(config.hand.skeleton?.modelPath) : null,\n ]);\n } else {\n if (config.debug) log('cached model:', handDetectorModel['modelUrl']);\n if (config.debug) log('cached model:', handPoseModel['modelUrl']);\n }\n const handDetector = new handdetector.HandDetector(handDetectorModel);\n handPipeline = new handpipeline.HandPipeline(handDetector, handPoseModel);\n return [handDetectorModel, handPoseModel];\n}\n", "/**\n * HandTrack model implementation\n *\n * Based on:\n * - Hand Detection & Skeleton: [**MediaPipe HandPose**](https://drive.google.com/file/d/1sv4sSb9BSNVZhLzxXJ0jBv9DqD-4jnAz/view)\n * - Hand Tracking: [**HandTracking**](https://github.com/victordibia/handtracking)\n */\n\nimport { log, now } from '../util/util';\nimport * as box from '../util/box';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport type { HandResult, HandType, Box, Point } from '../result';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport type { Config } from '../config';\nimport { env } from '../util/env';\nimport * as fingerPose from './fingerpose';\nimport { fakeOps } from '../tfjs/backend';\nimport { constants } from '../tfjs/constants';\n\nconst models: [GraphModel | null, GraphModel | null] = [null, null];\nconst modelOutputNodes = ['StatefulPartitionedCall/Postprocessor/Slice', 'StatefulPartitionedCall/Postprocessor/ExpandDims_1'];\n\nconst inputSize = [[0, 0], [0, 0]];\n\nconst classes = ['hand', 'fist', 'pinch', 'point', 'face', 'tip', 'pinchtip'];\nconst faceIndex = 4;\n\nconst boxExpandFact = 1.6;\nconst maxDetectorResolution = 512;\nconst detectorExpandFact = 1.4;\n\nlet skipped = Number.MAX_SAFE_INTEGER;\nlet lastTime = 0;\nlet outputSize: [number, number] = [0, 0];\n\ntype HandDetectResult = {\n id: number,\n score: number,\n box: Box,\n boxRaw: Box,\n label: HandType,\n}\n\nconst cache: {\n boxes: Array,\n hands: Array;\n} = {\n boxes: [],\n hands: [],\n};\n\nconst fingerMap = {\n /*\n thumb: [0, 1, 2, 3, 4],\n index: [0, 5, 6, 7, 8],\n middle: [0, 9, 10, 11, 12],\n ring: [0, 13, 14, 15, 16],\n pinky: [0, 17, 18, 19, 20],\n palm: [0],\n */\n thumb: [1, 2, 3, 4],\n index: [5, 6, 7, 8],\n middle: [9, 10, 11, 12],\n ring: [13, 14, 15, 16],\n pinky: [17, 18, 19, 20],\n base: [0],\n palm: [0, 17, 13, 9, 5, 1, 0],\n};\n\nexport async function loadDetect(config: Config): Promise {\n // HandTrack Model: Original: TFJS Port: \n if (env.initial) models[0] = null;\n if (!models[0]) {\n // handtrack model has some kernel ops defined in model but those are never referenced and non-existent in tfjs\n // ideally need to prune the model itself\n fakeOps(['tensorlistreserve', 'enter', 'tensorlistfromtensor', 'merge', 'loopcond', 'switch', 'exit', 'tensorliststack', 'nextiteration', 'tensorlistsetitem', 'tensorlistgetitem', 'reciprocal', 'shape', 'split', 'where'], config);\n models[0] = await loadModel(config.hand.detector?.modelPath);\n const inputs = Object.values(models[0].modelSignature['inputs']);\n inputSize[0][0] = Array.isArray(inputs) ? parseInt(inputs[0].tensorShape.dim[1].size) : 0;\n inputSize[0][1] = Array.isArray(inputs) ? parseInt(inputs[0].tensorShape.dim[2].size) : 0;\n } else if (config.debug) log('cached model:', models[0]['modelUrl']);\n return models[0];\n}\n\nexport async function loadSkeleton(config: Config): Promise {\n if (env.initial) models[1] = null;\n if (!models[1]) {\n models[1] = await loadModel(config.hand.skeleton?.modelPath);\n const inputs = Object.values(models[1].modelSignature['inputs']);\n inputSize[1][0] = Array.isArray(inputs) ? parseInt(inputs[0].tensorShape.dim[1].size) : 0;\n inputSize[1][1] = Array.isArray(inputs) ? parseInt(inputs[0].tensorShape.dim[2].size) : 0;\n } else if (config.debug) log('cached model:', models[1]['modelUrl']);\n return models[1];\n}\n\nexport async function load(config: Config): Promise<[GraphModel | null, GraphModel | null]> {\n if (!models[0]) await loadDetect(config);\n if (!models[1]) await loadSkeleton(config);\n return models;\n}\n\nasync function detectHands(input: Tensor, config: Config): Promise {\n const hands: HandDetectResult[] = [];\n if (!input || !models[0]) return hands;\n const t: Record = {};\n const ratio = (input.shape[2] || 1) / (input.shape[1] || 1);\n const height = Math.min(Math.round((input.shape[1] || 0) / 8) * 8, maxDetectorResolution); // use dynamic input size but cap at 512\n const width = Math.round(height * ratio / 8) * 8;\n t.resize = tf.image.resizeBilinear(input, [height, width]); // todo: resize with padding\n t.cast = tf.cast(t.resize, 'int32');\n [t.rawScores, t.rawBoxes] = await models[0].executeAsync(t.cast, modelOutputNodes) as Tensor[];\n t.boxes = tf.squeeze(t.rawBoxes, [0, 2]);\n t.scores = tf.squeeze(t.rawScores, [0]);\n const classScores: Array = tf.unstack(t.scores, 1); // unstack scores based on classes\n tf.dispose(classScores[faceIndex]);\n classScores.splice(faceIndex, 1); // remove faces\n t.filtered = tf.stack(classScores, 1); // restack\n tf.dispose(classScores);\n // t.filtered = t.scores;\n t.max = tf.max(t.filtered, 1); // max overall score\n t.argmax = tf.argMax(t.filtered, 1); // class index of max overall score\n let id = 0;\n t.nms = await tf.image.nonMaxSuppressionAsync(t.boxes, t.max, (config.hand.maxDetected || 0) + 1, config.hand.iouThreshold || 0, config.hand.minConfidence || 1);\n const nms = await t.nms.data();\n const scores = await t.max.data();\n const classNum = await t.argmax.data();\n for (const nmsIndex of Array.from(nms)) { // generates results for each class\n const boxSlice = tf.slice(t.boxes, nmsIndex, 1);\n const boxYX = await boxSlice.data();\n tf.dispose(boxSlice);\n const boxData: Box = [boxYX[1], boxYX[0], boxYX[3] - boxYX[1], boxYX[2] - boxYX[0]]; // yx box reshaped to standard box\n const boxRaw: Box = box.scale(boxData, detectorExpandFact);\n const boxFull: Box = [Math.trunc(boxData[0] * outputSize[0]), Math.trunc(boxData[1] * outputSize[1]), Math.trunc(boxData[2] * outputSize[0]), Math.trunc(boxData[3] * outputSize[1])];\n const score = scores[nmsIndex];\n const label = classes[classNum[nmsIndex]] as HandType;\n const hand: HandDetectResult = { id: id++, score, box: boxFull, boxRaw, label };\n hands.push(hand);\n }\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n hands.sort((a, b) => b.score - a.score);\n if (hands.length > (config.hand.maxDetected || 1)) hands.length = (config.hand.maxDetected || 1);\n return hands;\n}\n\nasync function detectFingers(input: Tensor, h: HandDetectResult, config: Config): Promise {\n const hand: HandResult = { // initial values inherited from hand detect\n id: h.id,\n score: Math.round(100 * h.score) / 100,\n boxScore: Math.round(100 * h.score) / 100,\n fingerScore: 0,\n box: h.box,\n boxRaw: h.boxRaw,\n label: h.label,\n keypoints: [],\n landmarks: {} as HandResult['landmarks'],\n annotations: {} as HandResult['annotations'],\n };\n if (input && models[1] && config.hand.landmarks && h.score > (config.hand.minConfidence || 0)) {\n const t: Record = {};\n const boxCrop = [h.boxRaw[1], h.boxRaw[0], h.boxRaw[3] + h.boxRaw[1], h.boxRaw[2] + h.boxRaw[0]] as Box;\n t.crop = tf.image.cropAndResize(input, [boxCrop], [0], [inputSize[1][0], inputSize[1][1]], 'bilinear');\n t.div = tf.div(t.crop, constants.tf255);\n [t.score, t.keypoints] = models[1].execute(t.div, ['Identity_1', 'Identity']) as Tensor[];\n const rawScore = (await t.score.data())[0];\n const score = (100 - Math.trunc(100 / (1 + Math.exp(rawScore)))) / 100; // reverse sigmoid value\n if (score >= (config.hand.minConfidence || 0)) {\n hand.fingerScore = score;\n t.reshaped = tf.reshape(t.keypoints, [-1, 3]);\n const coordsData: Point[] = await t.reshaped.array() as Point[];\n const coordsRaw: Point[] = coordsData.map((kpt) => [kpt[0] / inputSize[1][1], kpt[1] / inputSize[1][0], (kpt[2] || 0)]);\n const coordsNorm: Point[] = coordsRaw.map((kpt) => [kpt[0] * h.boxRaw[2], kpt[1] * h.boxRaw[3], (kpt[2] || 0)]);\n hand.keypoints = (coordsNorm).map((kpt) => [outputSize[0] * (kpt[0] + h.boxRaw[0]), outputSize[1] * (kpt[1] + h.boxRaw[1]), (kpt[2] || 0)]);\n hand.landmarks = fingerPose.analyze(hand.keypoints) as HandResult['landmarks']; // calculate finger gestures\n for (const key of Object.keys(fingerMap)) { // map keypoints to per-finger annotations\n hand.annotations[key] = fingerMap[key].map((index: number) => (hand.landmarks && hand.keypoints[index] ? hand.keypoints[index] : null));\n }\n }\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n }\n return hand;\n}\n\nexport async function predict(input: Tensor, config: Config): Promise {\n if (!models[0] || !models[1] || !models[0]?.inputs[0].shape || !models[1]?.inputs[0].shape) return []; // something is wrong with the model\n outputSize = [input.shape[2] || 0, input.shape[1] || 0];\n skipped++; // increment skip frames\n const skipTime = (config.hand.skipTime || 0) > (now() - lastTime);\n const skipFrame = skipped < (config.hand.skipFrames || 0);\n if (config.skipAllowed && skipTime && skipFrame) {\n return cache.hands; // return cached results without running anything\n }\n return new Promise(async (resolve) => {\n const skipTimeExtended = 3 * (config.hand.skipTime || 0) > (now() - lastTime);\n const skipFrameExtended = skipped < 3 * (config.hand.skipFrames || 0);\n if (config.skipAllowed && cache.hands.length === config.hand.maxDetected) { // we have all detected hands so we're definitely skipping\n cache.hands = await Promise.all(cache.boxes.map((handBox) => detectFingers(input, handBox, config)));\n } else if (config.skipAllowed && skipTimeExtended && skipFrameExtended && cache.hands.length > 0) { // we have some cached results: maybe not enough but anyhow continue for bit longer\n cache.hands = await Promise.all(cache.boxes.map((handBox) => detectFingers(input, handBox, config)));\n } else { // finally rerun detector\n cache.boxes = await detectHands(input, config);\n lastTime = now();\n cache.hands = await Promise.all(cache.boxes.map((handBox) => detectFingers(input, handBox, config)));\n skipped = 0;\n }\n\n const oldCache = [...cache.boxes];\n cache.boxes.length = 0; // reset cache\n if (config.cacheSensitivity > 0) {\n for (let i = 0; i < cache.hands.length; i++) {\n const boxKpt = box.square(cache.hands[i].keypoints, outputSize);\n if (boxKpt.box[2] / (input.shape[2] || 1) > 0.05 && boxKpt.box[3] / (input.shape[1] || 1) > 0.05 && cache.hands[i].fingerScore && cache.hands[i].fingerScore > (config.hand.minConfidence || 0)) {\n const boxScale = box.scale(boxKpt.box, boxExpandFact);\n const boxScaleRaw = box.scale(boxKpt.boxRaw, boxExpandFact);\n // const boxCrop = box.crop(boxScaleRaw);\n cache.boxes.push({ ...oldCache[i], box: boxScale, boxRaw: boxScaleRaw });\n }\n }\n }\n for (let i = 0; i < cache.hands.length; i++) { // replace detected boxes with calculated boxes in final output\n const bbox = box.calc(cache.hands[i].keypoints, outputSize);\n cache.hands[i].box = bbox.box;\n cache.hands[i].boxRaw = bbox.boxRaw;\n }\n resolve(cache.hands);\n });\n}\n", "/**\n * Anti-spoofing model implementation\n */\n\nimport { log, now } from '../util/util';\nimport { loadModel } from '../tfjs/load';\nimport type { Config } from '../config';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { env } from '../util/env';\n\nlet model: GraphModel | null;\nconst cached: Array = [];\nlet skipped = Number.MAX_SAFE_INTEGER;\nlet lastCount = 0;\nlet lastTime = 0;\n\nexport async function load(config: Config): Promise {\n if (env.initial) model = null;\n if (!model) model = await loadModel(config.face.liveness?.modelPath);\n else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\nexport async function predict(image: Tensor, config: Config, idx: number, count: number): Promise {\n if (!model) return 0;\n const skipTime = (config.face.liveness?.skipTime || 0) > (now() - lastTime);\n const skipFrame = skipped < (config.face.liveness?.skipFrames || 0);\n if (config.skipAllowed && skipTime && skipFrame && (lastCount === count) && cached[idx]) {\n skipped++;\n return cached[idx];\n }\n skipped = 0;\n return new Promise(async (resolve) => {\n const resize = tf.image.resizeBilinear(image, [model?.inputs[0].shape ? model.inputs[0].shape[2] : 0, model?.inputs[0].shape ? model.inputs[0].shape[1] : 0], false);\n const res = model?.execute(resize) as Tensor;\n const num = (await res.data())[0];\n cached[idx] = Math.round(100 * num) / 100;\n lastCount = count;\n lastTime = now();\n tf.dispose([resize, res]);\n resolve(cached[idx]);\n });\n}\n", "export const kpt: Array = [ // used to create part labels\n 'nose',\n 'leftEye',\n 'rightEye',\n 'leftEar',\n 'rightEar',\n 'leftShoulder',\n 'rightShoulder',\n 'leftElbow',\n 'rightElbow',\n 'leftWrist',\n 'rightWrist',\n 'leftHip',\n 'rightHip',\n 'leftKnee',\n 'rightKnee',\n 'leftAnkle',\n 'rightAnkle',\n];\n\nexport const horizontal: Array = [ // used to fix left vs right\n ['leftEye', 'rightEye'],\n ['leftEar', 'rightEar'],\n ['leftShoulder', 'rightShoulder'],\n ['leftElbow', 'rightElbow'],\n ['leftWrist', 'rightWrist'],\n ['leftHip', 'rightHip'],\n ['leftKnee', 'rightKnee'],\n ['leftAnkle', 'rightAnkle'],\n];\n\nexport const vertical: Array = [ // used to remove unlikely keypoint positions\n ['leftKnee', 'leftShoulder'],\n ['rightKnee', 'rightShoulder'],\n ['leftAnkle', 'leftKnee'],\n ['rightAnkle', 'rightKnee'],\n];\n\nexport const relative: Array = [ // used to match relative body parts\n [['leftHip', 'rightHip'], ['leftShoulder', 'rightShoulder']],\n [['leftElbow', 'rightElbow'], ['leftShoulder', 'rightShoulder']],\n];\n\nexport const connected: Record = { // used to create body outline in annotations\n leftLeg: ['leftHip', 'leftKnee', 'leftAnkle'],\n rightLeg: ['rightHip', 'rightKnee', 'rightAnkle'],\n torso: ['leftShoulder', 'rightShoulder', 'rightHip', 'leftHip', 'leftShoulder'],\n leftArm: ['leftShoulder', 'leftElbow', 'leftWrist'],\n rightArm: ['rightShoulder', 'rightElbow', 'rightWrist'],\n head: [],\n};\n", "import type { BodyKeypoint, BodyResult } from '../result';\nimport * as box from '../util/box';\nimport * as coords from './movenetcoords';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport type { Tensor } from '../tfjs/types';\n\nconst maxJitter = 0.005; // default allowed jitter is within 0.5%\n\nconst cache: {\n keypoints: Array,\n padding: [number, number][];\n} = {\n keypoints: [],\n padding: [[0, 0], [0, 0], [0, 0], [0, 0]],\n};\n\nexport function bodyParts(body: BodyResult) { // model sometimes mixes up left vs right keypoints so we fix them\n for (const pair of coords.horizontal) { // fix body parts left vs right\n const left = body.keypoints.findIndex((kp) => kp.part === pair[0]);\n const right = body.keypoints.findIndex((kp) => kp.part === pair[1]);\n if (body.keypoints[left] && body.keypoints[right]) {\n if (body.keypoints[left].position[0] < body.keypoints[right].position[0]) {\n const tmp = body.keypoints[left];\n body.keypoints[left] = body.keypoints[right];\n body.keypoints[right] = tmp;\n }\n }\n }\n for (const pair of coords.vertical) { // remove body parts with improbable vertical position\n const lower = body.keypoints.findIndex((kp) => (kp && kp.part === pair[0]));\n const higher = body.keypoints.findIndex((kp) => (kp && kp.part === pair[1]));\n if (body.keypoints[lower] && body.keypoints[higher]) {\n if (body.keypoints[lower].position[1] < body.keypoints[higher].position[1]) {\n body.keypoints.splice(lower, 1);\n }\n }\n }\n for (const [pair, compare] of coords.relative) { // rearrange body parts according to their relative position\n const left = body.keypoints.findIndex((kp) => (kp && kp.part === pair[0]));\n const right = body.keypoints.findIndex((kp) => (kp && kp.part === pair[1]));\n const leftTo = body.keypoints.findIndex((kp) => (kp && kp.part === compare[0]));\n const rightTo = body.keypoints.findIndex((kp) => (kp && kp.part === compare[1]));\n if (!body.keypoints[leftTo] || !body.keypoints[rightTo]) continue; // only if we have both compare points\n const distanceLeft = body.keypoints[left] ? [\n Math.abs(body.keypoints[leftTo].position[0] - body.keypoints[left].position[0]),\n Math.abs(body.keypoints[rightTo].position[0] - body.keypoints[left].position[0]),\n ] : [0, 0];\n const distanceRight = body.keypoints[right] ? [\n Math.abs(body.keypoints[rightTo].position[0] - body.keypoints[right].position[0]),\n Math.abs(body.keypoints[leftTo].position[0] - body.keypoints[right].position[0]),\n ] : [0, 0];\n if (distanceLeft[0] > distanceLeft[1] || distanceRight[0] > distanceRight[1]) { // should flip keypoints\n const tmp = body.keypoints[left];\n body.keypoints[left] = body.keypoints[right];\n body.keypoints[right] = tmp;\n }\n }\n}\n\nexport function jitter(keypoints: Array): Array {\n for (let i = 0; i < keypoints.length; i++) {\n if (keypoints[i] && cache.keypoints[i]) {\n const diff = [Math.abs(keypoints[i].positionRaw[0] - cache.keypoints[i].positionRaw[0]), Math.abs(keypoints[i].positionRaw[1] - cache.keypoints[i].positionRaw[1])];\n if (diff[0] < maxJitter && diff[1] < maxJitter) {\n keypoints[i] = cache.keypoints[i]; // below jitter so replace keypoint\n } else {\n cache.keypoints[i] = keypoints[i]; // above jitter so update cache\n }\n } else {\n cache.keypoints[i] = keypoints[i]; // cache for keypoint doesnt exist so create it here\n }\n }\n return keypoints;\n}\n\nexport function padInput(input: Tensor, inputSize: number): Tensor {\n const t: Record = {};\n if (!input.shape || !input.shape[1] || !input.shape[2]) return input;\n cache.padding = [\n [0, 0], // dont touch batch\n [input.shape[2] > input.shape[1] ? Math.trunc((input.shape[2] - input.shape[1]) / 2) : 0, input.shape[2] > input.shape[1] ? Math.trunc((input.shape[2] - input.shape[1]) / 2) : 0], // height before&after\n [input.shape[1] > input.shape[2] ? Math.trunc((input.shape[1] - input.shape[2]) / 2) : 0, input.shape[1] > input.shape[2] ? Math.trunc((input.shape[1] - input.shape[2]) / 2) : 0], // width before&after\n [0, 0], // dont touch rbg\n ];\n t.pad = tf.pad(input, cache.padding);\n t.resize = tf.image.resizeBilinear(t.pad, [inputSize, inputSize]);\n const final = tf.cast(t.resize, 'int32');\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n return final;\n}\n\nexport function rescaleBody(body: BodyResult, outputSize: [number, number]): BodyResult {\n body.keypoints = body.keypoints.filter((kpt) => kpt && kpt.position); // filter invalid keypoints\n for (const kpt of body.keypoints) {\n kpt.position = [\n kpt.position[0] * (outputSize[0] + cache.padding[2][0] + cache.padding[2][1]) / outputSize[0] - cache.padding[2][0],\n kpt.position[1] * (outputSize[1] + cache.padding[1][0] + cache.padding[1][1]) / outputSize[1] - cache.padding[1][0],\n ];\n kpt.positionRaw = [\n kpt.position[0] / outputSize[0], kpt.position[1] / outputSize[1],\n ];\n }\n const rescaledBoxes = box.calc(body.keypoints.map((pt) => pt.position), outputSize);\n body.box = rescaledBoxes.box;\n body.boxRaw = rescaledBoxes.boxRaw;\n return body;\n}\n", "/**\n * MoveNet model implementation\n *\n * Based on: [**MoveNet**](https://blog.tensorflow.org/2021/05/next-generation-pose-detection-with-movenet-and-tensorflowjs.html)\n */\n\nimport { log, now } from '../util/util';\nimport * as box from '../util/box';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as coords from './movenetcoords';\nimport * as fix from './movenetfix';\nimport { loadModel } from '../tfjs/load';\nimport type { BodyKeypoint, BodyResult, BodyLandmark, BodyAnnotation, Box, Point } from '../result';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport type { Config } from '../config';\nimport { fakeOps } from '../tfjs/backend';\nimport { env } from '../util/env';\n\nlet model: GraphModel | null;\nlet inputSize = 0;\nlet skipped = Number.MAX_SAFE_INTEGER;\n// const boxExpandFact = 1.5; // increase to 150%\n\nconst cache: {\n boxes: Array, // unused\n bodies: Array;\n last: number,\n} = {\n boxes: [],\n bodies: [],\n last: 0,\n};\n\nexport async function load(config: Config): Promise {\n if (env.initial) model = null;\n if (!model) {\n fakeOps(['size'], config);\n model = await loadModel(config.body.modelPath);\n } else if (config.debug) log('cached model:', model['modelUrl']);\n inputSize = model.inputs[0].shape ? model.inputs[0].shape[2] : 0;\n if (inputSize < 64) inputSize = 256;\n return model;\n}\n\nasync function parseSinglePose(res, config, image) {\n const kpt = res[0][0];\n const keypoints: Array = [];\n let score = 0;\n for (let id = 0; id < kpt.length; id++) {\n score = kpt[id][2];\n if (score > config.body.minConfidence) {\n const positionRaw: Point = [kpt[id][1], kpt[id][0]];\n keypoints.push({\n score: Math.round(100 * score) / 100,\n part: coords.kpt[id] as BodyLandmark,\n positionRaw,\n position: [ // normalized to input image size\n Math.round((image.shape[2] || 0) * positionRaw[0]),\n Math.round((image.shape[1] || 0) * positionRaw[1]),\n ],\n });\n }\n }\n score = keypoints.reduce((prev, curr) => (curr.score > prev ? curr.score : prev), 0);\n const bodies: Array = [];\n const newBox = box.calc(keypoints.map((pt) => pt.position), [image.shape[2], image.shape[1]]);\n const annotations: Record = {};\n for (const [name, indexes] of Object.entries(coords.connected)) {\n const pt: Array = [];\n for (let i = 0; i < indexes.length - 1; i++) {\n const pt0 = keypoints.find((kp) => kp.part === indexes[i]);\n const pt1 = keypoints.find((kp) => kp.part === indexes[i + 1]);\n if (pt0 && pt1 && pt0.score > (config.body.minConfidence || 0) && pt1.score > (config.body.minConfidence || 0)) pt.push([pt0.position, pt1.position]);\n }\n annotations[name] = pt;\n }\n const body: BodyResult = { id: 0, score, box: newBox.box, boxRaw: newBox.boxRaw, keypoints, annotations };\n fix.bodyParts(body);\n bodies.push(body);\n return bodies;\n}\n\nasync function parseMultiPose(res, config, image) {\n const bodies: Array = [];\n for (let id = 0; id < res[0].length; id++) {\n const kpt = res[0][id];\n const totalScore = Math.round(100 * kpt[51 + 4]) / 100;\n if (totalScore > config.body.minConfidence) {\n const keypoints: Array = [];\n for (let i = 0; i < 17; i++) {\n const score = kpt[3 * i + 2];\n if (score > config.body.minConfidence) {\n const positionRaw: Point = [kpt[3 * i + 1], kpt[3 * i + 0]];\n keypoints.push({\n part: coords.kpt[i] as BodyLandmark,\n score: Math.round(100 * score) / 100,\n positionRaw,\n position: [Math.round((image.shape[2] || 0) * positionRaw[0]), Math.round((image.shape[1] || 0) * positionRaw[1])],\n });\n }\n }\n const newBox = box.calc(keypoints.map((pt) => pt.position), [image.shape[2], image.shape[1]]);\n // movenet-multipose has built-in box details\n // const boxRaw: Box = [kpt[51 + 1], kpt[51 + 0], kpt[51 + 3] - kpt[51 + 1], kpt[51 + 2] - kpt[51 + 0]];\n // const box: Box = [Math.trunc(boxRaw[0] * (image.shape[2] || 0)), Math.trunc(boxRaw[1] * (image.shape[1] || 0)), Math.trunc(boxRaw[2] * (image.shape[2] || 0)), Math.trunc(boxRaw[3] * (image.shape[1] || 0))];\n const annotations: Record = {} as Record;\n for (const [name, indexes] of Object.entries(coords.connected)) {\n const pt: Array = [];\n for (let i = 0; i < indexes.length - 1; i++) {\n const pt0 = keypoints.find((kp) => kp.part === indexes[i]);\n const pt1 = keypoints.find((kp) => kp.part === indexes[i + 1]);\n if (pt0 && pt1 && pt0.score > (config.body.minConfidence || 0) && pt1.score > (config.body.minConfidence || 0)) pt.push([pt0.position, pt1.position]);\n }\n annotations[name] = pt;\n }\n const body: BodyResult = { id, score: totalScore, box: newBox.box, boxRaw: newBox.boxRaw, keypoints: [...keypoints], annotations };\n fix.bodyParts(body);\n bodies.push(body);\n }\n }\n bodies.sort((a, b) => b.score - a.score);\n if (bodies.length > config.body.maxDetected) bodies.length = config.body.maxDetected;\n return bodies;\n}\n\nexport async function predict(input: Tensor, config: Config): Promise {\n if (!model || !model?.inputs[0].shape) return []; // something is wrong with the model\n if (!config.skipAllowed) cache.boxes.length = 0; // allowed to use cache or not\n skipped++; // increment skip frames\n const skipTime = (config.body.skipTime || 0) > (now() - cache.last);\n const skipFrame = skipped < (config.body.skipFrames || 0);\n if (config.skipAllowed && skipTime && skipFrame) {\n return cache.bodies; // return cached results without running anything\n }\n return new Promise(async (resolve) => {\n const t: Record = {};\n skipped = 0;\n // run detection on squared input and cached boxes\n /*\n cache.bodies = []; // reset bodies result\n if (cache.boxes.length >= (config.body.maxDetected || 0)) { // if we have enough cached boxes run detection using cache\n for (let i = 0; i < cache.boxes.length; i++) { // run detection based on cached boxes\n t.crop = tf.image.cropAndResize(input, [cache.boxes[i]], [0], [inputSize, inputSize], 'bilinear');\n t.cast = tf.cast(t.crop, 'int32');\n // t.input = prepareImage(input);\n t.res = model?.execute(t.cast) as Tensor;\n const res = await t.res.array();\n const newBodies = (t.res.shape[2] === 17) ? await parseSinglePose(res, config, input, cache.boxes[i]) : await parseMultiPose(res, config, input, cache.boxes[i]);\n cache.bodies = cache.bodies.concat(newBodies);\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n }\n }\n if (cache.bodies.length !== config.body.maxDetected) { // did not find enough bodies based on cached boxes so run detection on full frame\n t.input = prepareImage(input);\n t.res = model?.execute(t.input) as Tensor;\n const res = await t.res.array();\n cache.bodies = (t.res.shape[2] === 17) ? await parseSinglePose(res, config, input, [0, 0, 1, 1]) : await parseMultiPose(res, config, input, [0, 0, 1, 1]);\n for (const body of cache.bodies) rescaleBody(body, [input.shape[2] || 1, input.shape[1] || 1]);\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n }\n cache.boxes.length = 0; // reset cache\n for (let i = 0; i < cache.bodies.length; i++) {\n if (cache.bodies[i].keypoints.length > (coords.kpt.length / 2)) { // only update cache if we detected at least half keypoints\n const scaledBox = box.scale(cache.bodies[i].boxRaw, boxExpandFact);\n const cropBox = box.crop(scaledBox);\n cache.boxes.push(cropBox);\n }\n }\n */\n\n // run detection on squared input and no cached boxes\n t.input = fix.padInput(input, inputSize);\n t.res = model?.execute(t.input) as Tensor;\n cache.last = now();\n const res = await t.res.array();\n cache.bodies = (t.res.shape[2] === 17)\n ? await parseSinglePose(res, config, input)\n : await parseMultiPose(res, config, input);\n for (const body of cache.bodies) {\n fix.rescaleBody(body, [input.shape[2] || 1, input.shape[1] || 1]);\n fix.jitter(body.keypoints);\n }\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n\n resolve(cache.bodies);\n });\n}\n", "/**\n * NanoDet object detection model implementation\n *\n * Based on: [**MB3-CenterNet**](https://github.com/610265158/mobilenetv3_centernet)\n */\n\nimport { log, now } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport { constants } from '../tfjs/constants';\nimport { labels } from './labels';\nimport type { ObjectResult, ObjectType, Box } from '../result';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport type { Config } from '../config';\nimport { env } from '../util/env';\n\nlet model: GraphModel;\nlet last: Array = [];\nlet lastTime = 0;\nlet skipped = Number.MAX_SAFE_INTEGER;\nlet inputSize = 0;\n\nconst scaleBox = 2.5; // increase box size\n\nexport async function load(config: Config): Promise {\n if (!model || env.initial) {\n model = await loadModel(config.object.modelPath);\n const inputs = Object.values(model.modelSignature['inputs']);\n inputSize = Array.isArray(inputs) ? parseInt(inputs[0].tensorShape.dim[2].size) : 0;\n } else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\nasync function process(res: Tensor[], outputShape: [number, number], config: Config) {\n let id = 0;\n let results: Array = [];\n for (const strideSize of [1, 2, 4]) { // try each stride size as it detects large/medium/small objects\n // find scores, boxes, classes\n tf.tidy(async () => { // wrap in tidy to automatically deallocate temp tensors\n const baseSize = strideSize * 13; // 13x13=169, 26x26=676, 52x52=2704\n // find boxes and scores output depending on stride\n const scoresT = tf.squeeze(res.find((a: Tensor) => (a.shape[1] === (baseSize ** 2) && (a.shape[2] || 0) === labels.length)));\n const featuresT = tf.squeeze(res.find((a: Tensor) => (a.shape[1] === (baseSize ** 2) && (a.shape[2] || 0) < labels.length)));\n const boxesMax = featuresT.reshape([-1, 4, featuresT.shape[1] / 4]); // reshape [output] to [4, output / 4] where number is number of different features inside each stride\n const boxIdx = await boxesMax.argMax(2).array(); // what we need is indexes of features with highest scores, not values itself\n const scores = await scoresT.array(); // optionally use exponential scores or just as-is\n for (let i = 0; i < scoresT.shape[0]; i++) { // total strides (x * y matrix)\n for (let j = 0; j < scoresT.shape[1]; j++) { // one score for each class\n const score = scores[i][j]; // get score for current position\n if (score > (config.object.minConfidence || 0) && j !== 61) {\n const cx = (0.5 + Math.trunc(i % baseSize)) / baseSize; // center.x normalized to range 0..1\n const cy = (0.5 + Math.trunc(i / baseSize)) / baseSize; // center.y normalized to range 0..1\n const boxOffset = boxIdx[i].map((a: number) => a * (baseSize / strideSize / inputSize)); // just grab indexes of features with highest scores\n const [x, y] = [\n cx - (scaleBox / strideSize * boxOffset[0]),\n cy - (scaleBox / strideSize * boxOffset[1]),\n ];\n const [w, h] = [\n cx + (scaleBox / strideSize * boxOffset[2]) - x,\n cy + (scaleBox / strideSize * boxOffset[3]) - y,\n ];\n let boxRaw: Box = [x, y, w, h]; // results normalized to range 0..1\n boxRaw = boxRaw.map((a) => Math.max(0, Math.min(a, 1))) as Box; // fix out-of-bounds coords\n const box = [ // results normalized to input image pixels\n boxRaw[0] * outputShape[0],\n boxRaw[1] * outputShape[1],\n boxRaw[2] * outputShape[0],\n boxRaw[3] * outputShape[1],\n ];\n const result = {\n id: id++,\n // strideSize,\n score: Math.round(100 * score) / 100,\n class: j + 1,\n label: labels[j].label as ObjectType,\n // center: [Math.trunc(outputShape[0] * cx), Math.trunc(outputShape[1] * cy)],\n // centerRaw: [cx, cy],\n box: box.map((a) => Math.trunc(a)) as Box,\n boxRaw,\n };\n results.push(result);\n }\n }\n }\n });\n }\n // deallocate tensors\n res.forEach((t) => tf.dispose(t));\n\n // normally nms is run on raw results, but since boxes need to be calculated this way we skip calulcation of\n // unnecessary boxes and run nms only on good candidates (basically it just does IOU analysis as scores are already filtered)\n const nmsBoxes = results.map((a) => [a.boxRaw[1], a.boxRaw[0], a.boxRaw[3], a.boxRaw[2]]); // switches coordinates from x,y to y,x as expected by tf.nms\n const nmsScores = results.map((a) => a.score);\n let nmsIdx: Array = [];\n if (nmsBoxes && nmsBoxes.length > 0) {\n const nms = await tf.image.nonMaxSuppressionAsync(nmsBoxes, nmsScores, config.object.maxDetected, config.object.iouThreshold, config.object.minConfidence);\n nmsIdx = await nms.data();\n tf.dispose(nms);\n }\n\n // filter & sort results\n results = results\n .filter((_val, idx) => nmsIdx.includes(idx))\n .sort((a, b) => (b.score - a.score));\n\n return results;\n}\n\nexport async function predict(image: Tensor, config: Config): Promise {\n const skipTime = (config.object.skipTime || 0) > (now() - lastTime);\n const skipFrame = skipped < (config.object.skipFrames || 0);\n if (config.skipAllowed && skipTime && skipFrame && (last.length > 0)) {\n skipped++;\n return last;\n }\n skipped = 0;\n if (!env.kernels.includes('mod') || !env.kernels.includes('sparsetodense')) return last;\n return new Promise(async (resolve) => {\n const outputSize = [image.shape[2] || 0, image.shape[1] || 0];\n const resize = tf.image.resizeBilinear(image, [inputSize, inputSize], false);\n const norm = tf.div(resize, constants.tf255);\n const transpose = norm.transpose([0, 3, 1, 2]);\n tf.dispose(norm);\n tf.dispose(resize);\n\n let objectT;\n if (config.object.enabled) objectT = model.execute(transpose);\n lastTime = now();\n tf.dispose(transpose);\n\n const obj = await process(objectT as Tensor[], outputSize as [number, number], config);\n last = obj;\n resolve(obj);\n });\n}\n", "/**\n * PoseNet body detection model implementation constants\n * See `posenet.ts` for entry point\n */\n\nimport type { Point, BodyResult, BodyAnnotation, BodyLandmark } from '../result';\n\nexport const partNames = [\n 'nose', 'leftEye', 'rightEye', 'leftEar', 'rightEar', 'leftShoulder',\n 'rightShoulder', 'leftElbow', 'rightElbow', 'leftWrist', 'rightWrist',\n 'leftHip', 'rightHip', 'leftKnee', 'rightKnee', 'leftAnkle', 'rightAnkle',\n];\n\nexport const count = partNames.length; // 17 keypoints\n\nexport const partIds = partNames.reduce((result, jointName, i) => {\n result[jointName] = i;\n return result;\n}, {});\n\nconst connectedPartNames = [\n ['leftHip', 'leftShoulder'], ['leftElbow', 'leftShoulder'],\n ['leftElbow', 'leftWrist'], ['leftHip', 'leftKnee'],\n ['leftKnee', 'leftAnkle'], ['rightHip', 'rightShoulder'],\n ['rightElbow', 'rightShoulder'], ['rightElbow', 'rightWrist'],\n ['rightHip', 'rightKnee'], ['rightKnee', 'rightAnkle'],\n ['leftShoulder', 'rightShoulder'], ['leftHip', 'rightHip'],\n];\nexport const connectedPartIndices = connectedPartNames.map(([jointNameA, jointNameB]) => ([partIds[jointNameA], partIds[jointNameB]]));\n\nexport const poseChain = [\n ['nose', 'leftEye'], ['leftEye', 'leftEar'], ['nose', 'rightEye'],\n ['rightEye', 'rightEar'], ['nose', 'leftShoulder'],\n ['leftShoulder', 'leftElbow'], ['leftElbow', 'leftWrist'],\n ['leftShoulder', 'leftHip'], ['leftHip', 'leftKnee'],\n ['leftKnee', 'leftAnkle'], ['nose', 'rightShoulder'],\n ['rightShoulder', 'rightElbow'], ['rightElbow', 'rightWrist'],\n ['rightShoulder', 'rightHip'], ['rightHip', 'rightKnee'],\n ['rightKnee', 'rightAnkle'],\n];\n\nexport function eitherPointDoesntMeetConfidence(a: number, b: number, minConfidence: number) {\n return (a < minConfidence || b < minConfidence);\n}\n\nexport function getAdjacentKeyPoints(keypoints, minConfidence: number) {\n return connectedPartIndices.reduce((result, [leftJoint, rightJoint]) => {\n if (eitherPointDoesntMeetConfidence(keypoints[leftJoint].score, keypoints[rightJoint].score, minConfidence)) {\n return result;\n }\n result.push([keypoints[leftJoint], keypoints[rightJoint]]);\n return result;\n }, []);\n}\n\nexport function getBoundingBox(keypoints): [number, number, number, number] {\n const coord = keypoints.reduce(({ maxX, maxY, minX, minY }, { position: { x, y } }) => ({\n maxX: Math.max(maxX, x),\n maxY: Math.max(maxY, y),\n minX: Math.min(minX, x),\n minY: Math.min(minY, y),\n }), {\n maxX: Number.NEGATIVE_INFINITY,\n maxY: Number.NEGATIVE_INFINITY,\n minX: Number.POSITIVE_INFINITY,\n minY: Number.POSITIVE_INFINITY,\n });\n return [coord.minX, coord.minY, coord.maxX - coord.minX, coord.maxY - coord.minY];\n}\n\nexport function scalePoses(poses, [height, width], [inputResolutionHeight, inputResolutionWidth]): Array {\n const scaleY = height / inputResolutionHeight;\n const scaleX = width / inputResolutionWidth;\n const scalePose = (pose, i): BodyResult => ({\n id: i,\n score: pose.score,\n boxRaw: [pose.box[0] / inputResolutionWidth, pose.box[1] / inputResolutionHeight, pose.box[2] / inputResolutionWidth, pose.box[3] / inputResolutionHeight],\n box: [Math.trunc(pose.box[0] * scaleX), Math.trunc(pose.box[1] * scaleY), Math.trunc(pose.box[2] * scaleX), Math.trunc(pose.box[3] * scaleY)],\n keypoints: pose.keypoints.map(({ score, part, position }) => ({\n score: score as number,\n part: part as BodyLandmark,\n position: [Math.trunc(position.x * scaleX), Math.trunc(position.y * scaleY)] as Point,\n positionRaw: [position.x / inputResolutionHeight, position.y / inputResolutionHeight] as Point,\n })),\n annotations: {} as Record,\n });\n const scaledPoses = poses.map((pose, i) => scalePose(pose, i));\n return scaledPoses;\n}\n\n// algorithm based on Coursera Lecture from Algorithms, Part 1: https://www.coursera.org/learn/algorithms-part1/lecture/ZjoSM/heapsort\nexport class MaxHeap {\n priorityQueue: Array; // don't touch\n numberOfElements: number;\n getElementValue: unknown; // function call\n\n constructor(maxSize, getElementValue) {\n this.priorityQueue = new Array(maxSize);\n this.numberOfElements = -1;\n this.getElementValue = getElementValue;\n }\n\n enqueue(x) {\n this.priorityQueue[++this.numberOfElements] = x;\n this.swim(this.numberOfElements);\n }\n\n dequeue() {\n const max = this.priorityQueue[0];\n this.exchange(0, this.numberOfElements--);\n this.sink(0);\n this.priorityQueue[this.numberOfElements + 1] = null;\n return max;\n }\n\n empty() { return this.numberOfElements === -1; }\n\n size() { return this.numberOfElements + 1; }\n\n all() { return this.priorityQueue.slice(0, this.numberOfElements + 1); }\n\n max() { return this.priorityQueue[0]; }\n\n swim(k) {\n while (k > 0 && this.less(Math.floor(k / 2), k)) {\n this.exchange(k, Math.floor(k / 2));\n k = Math.floor(k / 2);\n }\n }\n\n sink(k) {\n while (2 * k <= this.numberOfElements) {\n let j = 2 * k;\n if (j < this.numberOfElements && this.less(j, j + 1)) j++;\n if (!this.less(k, j)) break;\n this.exchange(k, j);\n k = j;\n }\n }\n\n getValueAt(i) {\n // @ts-ignore getter is of unknown type\n return this.getElementValue(this.priorityQueue[i]);\n }\n\n less(i, j) {\n return this.getValueAt(i) < this.getValueAt(j);\n }\n\n exchange(i, j) {\n const t = this.priorityQueue[i];\n this.priorityQueue[i] = this.priorityQueue[j];\n this.priorityQueue[j] = t;\n }\n}\n\nexport function getOffsetPoint(y, x, keypoint, offsets) {\n return {\n y: offsets.get(y, x, keypoint),\n x: offsets.get(y, x, keypoint + count),\n };\n}\n\nexport function getImageCoords(part, outputStride, offsets) {\n const { heatmapY, heatmapX, id: keypoint } = part;\n const { y, x } = getOffsetPoint(heatmapY, heatmapX, keypoint, offsets);\n return {\n x: part.heatmapX * outputStride + x,\n y: part.heatmapY * outputStride + y,\n };\n}\n\nexport function fillArray(element, size) {\n const result = new Array(size);\n for (let i = 0; i < size; i++) {\n result[i] = element;\n }\n return result;\n}\n\nexport function clamp(a, min, max) {\n if (a < min) return min;\n if (a > max) return max;\n return a;\n}\n\nexport function squaredDistance(y1, x1, y2, x2) {\n const dy = y2 - y1;\n const dx = x2 - x1;\n return dy * dy + dx * dx;\n}\n\nexport function addVectors(a, b) {\n return { x: a.x + b.x, y: a.y + b.y };\n}\n\nexport function clampVector(a, min, max) {\n return { y: clamp(a.y, min, max), x: clamp(a.x, min, max) };\n}\n", "/**\n * PoseNet body detection model implementation\n *\n * Based on: [**PoseNet**](https://medium.com/tensorflow/real-time-human-pose-estimation-in-the-browser-with-tensorflow-js-7dd0bc881cd5)\n */\n\nimport { log } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport type { BodyResult, BodyLandmark, Box } from '../result';\nimport type { Tensor, GraphModel } from '../tfjs/types';\nimport type { Config } from '../config';\nimport { env } from '../util/env';\nimport * as utils from './posenetutils';\n\nlet model: GraphModel;\nconst poseNetOutputs = ['MobilenetV1/offset_2/BiasAdd'/* offsets */, 'MobilenetV1/heatmap_2/BiasAdd'/* heatmapScores */, 'MobilenetV1/displacement_fwd_2/BiasAdd'/* displacementFwd */, 'MobilenetV1/displacement_bwd_2/BiasAdd'/* displacementBwd */];\nconst localMaximumRadius = 1;\nconst outputStride = 16;\nconst squaredNmsRadius = 50 ** 2;\n\nfunction traverse(edgeId, sourceKeypoint, targetId, scores, offsets, displacements, offsetRefineStep = 2) {\n const getDisplacement = (point) => ({\n y: displacements.get(point.y, point.x, edgeId),\n x: displacements.get(point.y, point.x, (displacements.shape[2] / 2) + edgeId),\n });\n const getStridedIndexNearPoint = (point, height, width) => ({\n y: utils.clamp(Math.round(point.y / outputStride), 0, height - 1),\n x: utils.clamp(Math.round(point.x / outputStride), 0, width - 1),\n });\n\n const [height, width] = scores.shape;\n // Nearest neighbor interpolation for the source->target displacements.\n const sourceKeypointIndices = getStridedIndexNearPoint(sourceKeypoint.position, height, width);\n const displacement = getDisplacement(sourceKeypointIndices);\n const displacedPoint = utils.addVectors(sourceKeypoint.position, displacement);\n let targetKeypoint = displacedPoint;\n for (let i = 0; i < offsetRefineStep; i++) {\n const targetKeypointIndices = getStridedIndexNearPoint(targetKeypoint, height, width);\n const offsetPoint = utils.getOffsetPoint(targetKeypointIndices.y, targetKeypointIndices.x, targetId, offsets);\n targetKeypoint = utils.addVectors(\n { x: targetKeypointIndices.x * outputStride, y: targetKeypointIndices.y * outputStride },\n { x: offsetPoint.x, y: offsetPoint.y },\n );\n }\n const targetKeyPointIndices = getStridedIndexNearPoint(targetKeypoint, height, width);\n const score = scores.get(targetKeyPointIndices.y, targetKeyPointIndices.x, targetId);\n return { position: targetKeypoint, part: utils.partNames[targetId], score };\n}\n\nexport function decodePose(root, scores, offsets, displacementsFwd, displacementsBwd) {\n const tuples = utils.poseChain.map(([parentJoinName, childJoinName]) => ([utils.partIds[parentJoinName], utils.partIds[childJoinName]]));\n const edgesFwd = tuples.map(([, childJointId]) => childJointId);\n const edgesBwd = tuples.map(([parentJointId]) => parentJointId);\n const numParts = scores.shape[2]; // [21,21,17]\n const numEdges = edgesFwd.length;\n const keypoints = new Array(numParts);\n // Start a new detection instance at the position of the root.\n const rootPoint = utils.getImageCoords(root.part, outputStride, offsets);\n keypoints[root.part.id] = {\n score: root.score,\n part: utils.partNames[root.part.id] as BodyLandmark,\n position: rootPoint,\n };\n // Decode the part positions upwards in the tree, following the backward displacements.\n for (let edge = numEdges - 1; edge >= 0; --edge) {\n const sourceId = edgesFwd[edge];\n const targetId = edgesBwd[edge];\n if (keypoints[sourceId] && !keypoints[targetId]) {\n keypoints[targetId] = traverse(edge, keypoints[sourceId], targetId, scores, offsets, displacementsBwd);\n }\n }\n // Decode the part positions downwards in the tree, following the forward displacements.\n for (let edge = 0; edge < numEdges; ++edge) {\n const sourceId = edgesBwd[edge];\n const targetId = edgesFwd[edge];\n if (keypoints[sourceId] && !keypoints[targetId]) {\n keypoints[targetId] = traverse(edge, keypoints[sourceId], targetId, scores, offsets, displacementsFwd);\n }\n }\n return keypoints;\n}\n\nfunction scoreIsMaximumInLocalWindow(keypointId, score, heatmapY, heatmapX, scores) {\n const [height, width] = scores.shape;\n let localMaximum = true;\n const yStart = Math.max(heatmapY - localMaximumRadius, 0);\n const yEnd = Math.min(heatmapY + localMaximumRadius + 1, height);\n for (let yCurrent = yStart; yCurrent < yEnd; ++yCurrent) {\n const xStart = Math.max(heatmapX - localMaximumRadius, 0);\n const xEnd = Math.min(heatmapX + localMaximumRadius + 1, width);\n for (let xCurrent = xStart; xCurrent < xEnd; ++xCurrent) {\n if (scores.get(yCurrent, xCurrent, keypointId) > score) {\n localMaximum = false;\n break;\n }\n }\n if (!localMaximum) break;\n }\n return localMaximum;\n}\n\nexport function buildPartWithScoreQueue(minConfidence, scores) {\n const [height, width, numKeypoints] = scores.shape;\n const queue = new utils.MaxHeap(height * width * numKeypoints, ({ score }) => score);\n for (let heatmapY = 0; heatmapY < height; ++heatmapY) {\n for (let heatmapX = 0; heatmapX < width; ++heatmapX) {\n for (let keypointId = 0; keypointId < numKeypoints; ++keypointId) {\n const score = scores.get(heatmapY, heatmapX, keypointId);\n // Only consider parts with score greater or equal to threshold as root candidates.\n if (score < minConfidence) continue;\n // Only consider keypoints whose score is maximum in a local window.\n if (scoreIsMaximumInLocalWindow(keypointId, score, heatmapY, heatmapX, scores)) queue.enqueue({ score, part: { heatmapY, heatmapX, id: keypointId } });\n }\n }\n }\n return queue;\n}\n\nfunction withinRadius(poses, { x, y }, keypointId) {\n return poses.some(({ keypoints }) => {\n const correspondingKeypoint = keypoints[keypointId]?.position;\n if (!correspondingKeypoint) return false;\n return utils.squaredDistance(y, x, correspondingKeypoint.y, correspondingKeypoint.x) <= squaredNmsRadius;\n });\n}\n\nfunction getInstanceScore(existingPoses, keypoints) {\n const notOverlappedKeypointScores = keypoints.reduce((result, { position, score }, keypointId) => {\n if (!withinRadius(existingPoses, position, keypointId)) result += score;\n return result;\n }, 0.0);\n return notOverlappedKeypointScores / keypoints.length;\n}\n\nexport function decode(offsets, scores, displacementsFwd, displacementsBwd, maxDetected, minConfidence) {\n const poses: Array<{ keypoints, box: Box, score: number }> = [];\n const queue = buildPartWithScoreQueue(minConfidence, scores);\n // Generate at most maxDetected object instances per image in decreasing root part score order.\n while (poses.length < maxDetected && !queue.empty()) {\n // The top element in the queue is the next root candidate.\n const root = queue.dequeue();\n // Part-based non-maximum suppression: We reject a root candidate if it is within a disk of `nmsRadius` pixels from the corresponding part of a previously detected instance.\n // @ts-ignore this one is tree walk\n const rootImageCoords = utils.getImageCoords(root.part, outputStride, offsets);\n // @ts-ignore this one is tree walk\n if (withinRadius(poses, rootImageCoords, root.part.id)) continue;\n // Else start a new detection instance at the position of the root.\n let keypoints = decodePose(root, scores, offsets, displacementsFwd, displacementsBwd);\n keypoints = keypoints.filter((a) => a.score > minConfidence);\n const score = getInstanceScore(poses, keypoints);\n const box = utils.getBoundingBox(keypoints);\n if (score > minConfidence) poses.push({ keypoints, box, score: Math.round(100 * score) / 100 });\n }\n return poses;\n}\n\nexport async function predict(input: Tensor, config: Config): Promise {\n /** posenet is mostly obsolete\n * caching is not implemented\n */\n const res = tf.tidy(() => {\n if (!model.inputs[0].shape) return [];\n const resized = tf.image.resizeBilinear(input, [model.inputs[0].shape[2], model.inputs[0].shape[1]]);\n const normalized = tf.sub(tf.div(tf.cast(resized, 'float32'), 127.5), 1.0);\n const results: Array = model.execute(normalized, poseNetOutputs) as Array;\n const results3d = results.map((y) => tf.squeeze(y, [0]));\n results3d[1] = tf.sigmoid(results3d[1]); // apply sigmoid on scores\n return results3d;\n });\n\n const buffers = await Promise.all(res.map((tensor: Tensor) => tensor.buffer()));\n for (const t of res) tf.dispose(t);\n\n const decoded = await decode(buffers[0], buffers[1], buffers[2], buffers[3], config.body.maxDetected, config.body.minConfidence);\n if (!model.inputs[0].shape) return [];\n const scaled = utils.scalePoses(decoded, [input.shape[1], input.shape[2]], [model.inputs[0].shape[2], model.inputs[0].shape[1]]) as BodyResult[];\n return scaled;\n}\n\nexport async function load(config: Config): Promise {\n if (!model || env.initial) model = await loadModel(config.body.modelPath);\n else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n", "/**\n * Image segmentation for body detection model\n *\n * Based on:\n * - [**MediaPipe Meet**](https://drive.google.com/file/d/1lnP1bRi9CSqQQXUHa13159vLELYDgDu0/preview)\n * - [**MediaPipe Selfie**](https://drive.google.com/file/d/1dCfozqknMa068vVsO2j_1FgZkW_e3VWv/preview)\n */\n\nimport { log } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport * as image from '../image/image';\nimport { constants } from '../tfjs/constants';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport type { Config } from '../config';\nimport { env } from '../util/env';\nimport type { Input, AnyCanvas } from '../exports';\n\nlet model: GraphModel;\nlet busy = false;\n\nexport async function load(config: Config): Promise {\n if (!model || env.initial) model = await loadModel(config.segmentation.modelPath);\n else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\nexport async function process(input: Input, background: Input | undefined, config: Config)\n: Promise<{ data: Array | Tensor, canvas: AnyCanvas | null, alpha: AnyCanvas | null }> {\n if (busy) return { data: [], canvas: null, alpha: null };\n busy = true;\n if (!model) await load(config);\n const inputImage = await image.process(input, config);\n const width = inputImage.tensor?.shape[2] || 0;\n const height = inputImage.tensor?.shape[1] || 0;\n if (!inputImage.tensor) return { data: [], canvas: null, alpha: null };\n const t: Record = {};\n\n t.resize = tf.image.resizeBilinear(inputImage.tensor, [model.inputs[0].shape ? model.inputs[0].shape[1] : 0, model.inputs[0].shape ? model.inputs[0].shape[2] : 0], false);\n tf.dispose(inputImage.tensor);\n t.norm = tf.div(t.resize, constants.tf255);\n t.res = model.execute(t.norm) as Tensor;\n\n t.squeeze = tf.squeeze(t.res, 0); // meet.shape:[1,256,256,1], selfie.shape:[1,144,256,2]\n if (t.squeeze.shape[2] === 2) {\n t.softmax = tf.softmax(t.squeeze); // model meet has two channels for fg and bg\n [t.bg, t.fg] = tf.unstack(t.softmax, 2);\n t.expand = tf.expandDims(t.fg, 2);\n t.pad = tf.expandDims(t.expand, 0);\n t.crop = tf.image.cropAndResize(t.pad, [[0, 0, 0.5, 0.5]], [0], [width, height]);\n // running sofmax before unstack creates 2x2 matrix so we only take upper-left quadrant\n // otherwise run softmax after unstack and use standard resize\n // resizeOutput = tf.image.resizeBilinear(expand, [input.tensor?.shape[1], input.tensor?.shape[2]]);\n t.data = tf.squeeze(t.crop, 0);\n } else {\n t.data = tf.image.resizeBilinear(t.squeeze, [height, width]); // model selfie has a single channel that we can use directly\n }\n const data = Array.from(await t.data.data()) as number[];\n\n if (env.node && !env.Canvas && (typeof ImageData === 'undefined')) {\n if (config.debug) log('canvas support missing');\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n return { data, canvas: null, alpha: null }; // running in nodejs so return alpha array as-is\n }\n\n const alphaCanvas = image.canvas(width, height);\n // @ts-ignore browser is not defined in tfjs-node\n if (tf.browser) await tf.browser.toPixels(t.data, alphaCanvas);\n const alphaCtx = alphaCanvas.getContext('2d') as CanvasRenderingContext2D;\n if (config.segmentation.blur && config.segmentation.blur > 0) alphaCtx.filter = `blur(${config.segmentation.blur}px)`; // use css filter for bluring, can be done with gaussian blur manually instead\n const alphaData = alphaCtx.getImageData(0, 0, width, height);\n\n const compositeCanvas = image.canvas(width, height);\n const compositeCtx = compositeCanvas.getContext('2d') as CanvasRenderingContext2D;\n if (inputImage.canvas) compositeCtx.drawImage(inputImage.canvas, 0, 0);\n compositeCtx.globalCompositeOperation = 'darken'; // https://developer.mozilla.org/en-US/docs/Web/API/CanvasRenderingContext2D/globalCompositeOperation // best options are: darken, color-burn, multiply\n if (config.segmentation.blur && config.segmentation.blur > 0) compositeCtx.filter = `blur(${config.segmentation.blur}px)`; // use css filter for bluring, can be done with gaussian blur manually instead\n compositeCtx.drawImage(alphaCanvas, 0, 0);\n compositeCtx.globalCompositeOperation = 'source-over'; // reset composite operation\n compositeCtx.filter = 'none'; // reset css filter\n const compositeData = compositeCtx.getImageData(0, 0, width, height);\n for (let i = 0; i < width * height; i++) compositeData.data[4 * i + 3] = alphaData.data[4 * i + 0]; // copy original alpha value to new composite canvas\n compositeCtx.putImageData(compositeData, 0, 0);\n\n let mergedCanvas: AnyCanvas | null = null;\n if (background && compositeCanvas) { // draw background with segmentation as overlay if background is present\n mergedCanvas = image.canvas(width, height);\n const bgImage = await image.process(background, config);\n tf.dispose(bgImage.tensor);\n const ctxMerge = mergedCanvas.getContext('2d') as CanvasRenderingContext2D;\n ctxMerge.drawImage(bgImage.canvas as HTMLCanvasElement, 0, 0, mergedCanvas.width, mergedCanvas.height);\n ctxMerge.drawImage(compositeCanvas, 0, 0);\n }\n\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n busy = false;\n // return { data, canvas: mergedCanvas || compositeCanvas, alpha: alphaCanvas };\n return { data, canvas: compositeCanvas, alpha: alphaCanvas };\n}\n", "/** TFJS custom backend registration */\n\nimport type { Human } from '../human';\nimport { log } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as image from '../image/image';\nimport * as models from '../models';\nimport type { AnyCanvas } from '../exports';\n// import { env } from '../env';\n\nexport const config = {\n name: 'humangl',\n priority: 999,\n canvas: null,\n gl: null,\n extensions: [],\n webGLattr: { // https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.2\n alpha: false,\n antialias: false,\n premultipliedAlpha: false,\n preserveDrawingBuffer: false,\n depth: false,\n stencil: false,\n failIfMajorPerformanceCaveat: false,\n desynchronized: true,\n },\n};\n\nfunction extensions(): void {\n /*\n https://www.khronos.org/registry/webgl/extensions/\n https://webglreport.com/?v=2\n */\n const gl = config.gl;\n if (!gl) return;\n config.extensions = gl.getSupportedExtensions() as string[];\n // gl.getExtension('KHR_parallel_shader_compile');\n}\n\n/**\n * Registers custom WebGL2 backend to be used by Human library\n *\n * @returns void\n */\nexport async function register(instance: Human): Promise {\n // force backend reload if gl context is not valid\n if (instance.config.backend !== 'humangl') return;\n if ((config.name in tf.engine().registry) && (!config.gl || !config.gl.getParameter(config.gl.VERSION))) {\n log('error: humangl backend invalid context');\n models.reset(instance);\n /*\n log('resetting humangl backend');\n await tf.removeBackend(config.name);\n await register(instance); // re-register\n */\n }\n if (!tf.findBackend(config.name)) {\n try {\n config.canvas = await image.canvas(100, 100);\n } catch (err) {\n log('error: cannot create canvas:', err);\n return;\n }\n try {\n config.gl = config.canvas?.getContext('webgl2', config.webGLattr) as WebGL2RenderingContext;\n const glv2 = config.gl.getParameter(config.gl.VERSION).includes('2.0');\n if (!glv2) {\n log('override: using fallback webgl backend as webgl 2.0 is not detected');\n instance.config.backend = 'webgl';\n return;\n }\n if (config.canvas) {\n config.canvas.addEventListener('webglcontextlost', async (e) => {\n log('error: humangl:', e.type);\n log('possible browser memory leak using webgl or conflict with multiple backend registrations');\n instance.emit('error');\n throw new Error('backend error: webgl context lost');\n // log('resetting humangl backend');\n // env.initial = true;\n // models.reset(instance);\n // await tf.removeBackend(config.name);\n // await register(instance); // re-register\n });\n config.canvas.addEventListener('webglcontextrestored', (e) => {\n log('error: humangl context restored:', e);\n });\n config.canvas.addEventListener('webglcontextcreationerror', (e) => {\n log('error: humangl context create:', e);\n });\n }\n } catch (err) {\n log('error: cannot get WebGL context:', err);\n return;\n }\n try {\n tf.setWebGLContext(2, config.gl);\n } catch (err) {\n log('error: cannot set WebGL context:', err);\n return;\n }\n try {\n const ctx = new tf.GPGPUContext(config.gl);\n tf.registerBackend(config.name, () => new tf.MathBackendWebGL(ctx), config.priority);\n } catch (err) {\n log('error: cannot register WebGL backend:', err);\n return;\n }\n try {\n const kernels = tf.getKernelsForBackend('webgl');\n kernels.forEach((kernelConfig) => {\n const newKernelConfig = { ...kernelConfig, backendName: config.name };\n tf.registerKernel(newKernelConfig);\n });\n } catch (err) {\n log('error: cannot update WebGL backend registration:', err);\n return;\n }\n const current = tf.backend().getGPGPUContext ? tf.backend().getGPGPUContext().gl : null;\n if (current) {\n log(`humangl webgl version:${current.getParameter(current.VERSION)} renderer:${current.getParameter(current.RENDERER)}`);\n } else {\n log('error: no current gl context:', current, config.gl);\n return;\n }\n try {\n tf.ENV.set('WEBGL_VERSION', 2);\n } catch (err) {\n log('error: cannot set WebGL backend flags:', err);\n return;\n }\n extensions();\n log('backend registered:', config.name);\n }\n}\n", "/** TFJS backend initialization and customization */\n\nimport type { Human } from '../human';\nimport { log, now } from '../util/util';\nimport { env } from '../util/env';\nimport * as humangl from './humangl';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as constants from './constants';\n\nfunction registerCustomOps() {\n if (!env.kernels.includes('mod')) {\n const kernelMod = {\n kernelName: 'Mod',\n backendName: tf.getBackend(),\n kernelFunc: (op) => tf.tidy(() => tf.sub(op.inputs.a, tf.mul(tf.div(op.inputs.a, op.inputs.b), op.inputs.b))),\n };\n tf.registerKernel(kernelMod);\n env.kernels.push('mod');\n }\n if (!env.kernels.includes('floormod')) {\n const kernelMod = {\n kernelName: 'FloorMod',\n backendName: tf.getBackend(),\n kernelFunc: (op) => tf.tidy(() => tf.floorDiv(op.inputs.a / op.inputs.b) * op.inputs.b + tf.mod(op.inputs.a, op.inputs.b)),\n };\n tf.registerKernel(kernelMod);\n env.kernels.push('floormod');\n }\n}\n\nexport async function check(instance: Human, force = false) {\n instance.state = 'backend';\n if (force || env.initial || (instance.config.backend && (instance.config.backend.length > 0) && (tf.getBackend() !== instance.config.backend))) {\n const timeStamp = now();\n\n if (instance.config.backend && instance.config.backend.length > 0) {\n // detect web worker\n // @ts-ignore ignore missing type for WorkerGlobalScope as that is the point\n if (typeof window === 'undefined' && typeof WorkerGlobalScope !== 'undefined' && instance.config.debug) {\n if (instance.config.debug) log('running inside web worker');\n }\n\n // force browser vs node backend\n if (env.browser && instance.config.backend === 'tensorflow') {\n if (instance.config.debug) log('override: backend set to tensorflow while running in browser');\n instance.config.backend = 'humangl';\n }\n if (env.node && (instance.config.backend === 'webgl' || instance.config.backend === 'humangl')) {\n if (instance.config.debug) log(`override: backend set to ${instance.config.backend} while running in nodejs`);\n instance.config.backend = 'tensorflow';\n }\n\n // handle webgpu\n if (env.browser && instance.config.backend === 'webgpu') {\n if (typeof navigator === 'undefined' || typeof navigator['gpu'] === 'undefined') {\n log('override: backend set to webgpu but browser does not support webgpu');\n instance.config.backend = 'humangl';\n } else {\n const adapter = await navigator['gpu'].requestAdapter();\n if (instance.config.debug) log('enumerated webgpu adapter:', adapter);\n }\n }\n\n // check available backends\n if (instance.config.backend === 'humangl') await humangl.register(instance);\n const available = Object.keys(tf.engine().registryFactory);\n if (instance.config.debug) log('available backends:', available);\n\n if (!available.includes(instance.config.backend)) {\n log(`error: backend ${instance.config.backend} not found in registry`);\n instance.config.backend = env.node ? 'tensorflow' : 'webgl';\n if (instance.config.debug) log(`override: setting backend ${instance.config.backend}`);\n }\n\n if (instance.config.debug) log('setting backend:', instance.config.backend);\n\n // customize wasm\n if (instance.config.backend === 'wasm') {\n if (instance.config.debug) log('wasm path:', instance.config.wasmPath);\n if (typeof tf?.setWasmPaths !== 'undefined') await tf.setWasmPaths(instance.config.wasmPath, instance.config.wasmPlatformFetch);\n else throw new Error('backend error: attempting to use wasm backend but wasm path is not set');\n const simd = await tf.env().getAsync('WASM_HAS_SIMD_SUPPORT');\n const mt = await tf.env().getAsync('WASM_HAS_MULTITHREAD_SUPPORT');\n if (instance.config.debug) log(`wasm execution: ${simd ? 'SIMD' : 'no SIMD'} ${mt ? 'multithreaded' : 'singlethreaded'}`);\n if (instance.config.debug && !simd) log('warning: wasm simd support is not enabled');\n }\n\n try {\n await tf.setBackend(instance.config.backend);\n await tf.ready();\n constants.init();\n } catch (err) {\n log('error: cannot set backend:', instance.config.backend, err);\n return false;\n }\n }\n\n // customize humangl\n if (tf.getBackend() === 'humangl') {\n tf.ENV.set('CHECK_COMPUTATION_FOR_ERRORS', false);\n tf.ENV.set('WEBGL_CPU_FORWARD', true);\n // tf.ENV.set('WEBGL_PACK_DEPTHWISECONV', false);\n tf.ENV.set('WEBGL_USE_SHAPES_UNIFORMS', true);\n tf.ENV.set('CPU_HANDOFF_SIZE_THRESHOLD', 256);\n // if (!instance.config.object.enabled) tf.ENV.set('WEBGL_FORCE_F16_TEXTURES', true); // safe to use 16bit precision\n if (typeof instance.config['deallocate'] !== 'undefined' && instance.config['deallocate']) { // hidden param\n log('changing webgl: WEBGL_DELETE_TEXTURE_THRESHOLD:', true);\n tf.ENV.set('WEBGL_DELETE_TEXTURE_THRESHOLD', 0);\n }\n if (tf.backend().getGPGPUContext) {\n const gl = await tf.backend().getGPGPUContext().gl;\n if (instance.config.debug) log(`gl version:${gl.getParameter(gl.VERSION)} renderer:${gl.getParameter(gl.RENDERER)}`);\n }\n }\n\n // customize webgpu\n if (tf.getBackend() === 'webgpu') {\n // tf.ENV.set('WEBGPU_CPU_HANDOFF_SIZE_THRESHOLD', 512);\n // tf.ENV.set('WEBGPU_DEFERRED_SUBMIT_BATCH_SIZE', 0);\n // tf.ENV.set('WEBGPU_CPU_FORWARD', true);\n }\n\n // wait for ready\n tf.enableProdMode();\n await tf.ready();\n\n instance.performance.initBackend = Math.trunc(now() - timeStamp);\n instance.config.backend = tf.getBackend();\n\n await env.updateBackend(); // update env on backend init\n registerCustomOps();\n // await env.updateBackend(); // update env on backend init\n }\n return true;\n}\n\n// register fake missing tfjs ops\nexport function fakeOps(kernelNames: Array, config) {\n // if (config.debug) log('registerKernel:', kernelNames);\n for (const kernelName of kernelNames) {\n const kernelConfig = {\n kernelName,\n backendName: config.backend,\n kernelFunc: () => { if (config.debug) log('kernelFunc', kernelName, config.backend); },\n // setupFunc: () => { if (config.debug) log('kernelFunc', kernelName, config.backend); },\n // disposeFunc: () => { if (config.debug) log('kernelFunc', kernelName, config.backend); },\n };\n tf.registerKernel(kernelConfig);\n }\n env.kernels = tf.getKernelsForBackend(tf.getBackend()).map((kernel) => kernel.kernelName.toLowerCase()); // re-scan registered ops\n}\n", "/**\n * Module that implements helper draw functions, exposed as human.draw\n */\n\nimport { mergeDeep, now } from '../util/util';\nimport { env } from '../util/env';\nimport { getCanvasContext, rect } from './primitives';\nimport { options } from './options';\nimport { face } from './face';\nimport { body } from './body';\nimport { hand } from './hand';\nimport { object } from './object';\nimport { gesture } from './gesture';\nimport type { Result, PersonResult } from '../result';\nimport type { AnyCanvas, DrawOptions } from '../exports';\n\nlet drawTime = 0;\n\nexport { options } from './options';\nexport { face } from './face';\nexport { body } from './body';\nexport { hand } from './hand';\nexport { object } from './object';\nexport { gesture } from './gesture';\n\n/** draw combined person results instead of individual detection result objects */\nexport async function person(inCanvas: AnyCanvas, result: Array, drawOptions?: Partial) {\n const localOptions = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n const ctx = getCanvasContext(inCanvas);\n if (!ctx) return;\n ctx.lineJoin = 'round';\n ctx.font = localOptions.font;\n\n for (let i = 0; i < result.length; i++) {\n if (localOptions.drawBoxes) {\n ctx.strokeStyle = localOptions.color;\n ctx.fillStyle = localOptions.color;\n rect(ctx, result[i].box[0], result[i].box[1], result[i].box[2], result[i].box[3], localOptions);\n if (localOptions.drawLabels) {\n const label = `person #${i}`;\n if (localOptions.shadowColor && localOptions.shadowColor !== '') {\n ctx.fillStyle = localOptions.shadowColor;\n ctx.fillText(label, result[i].box[0] + 3, 1 + result[i].box[1] + localOptions.lineHeight, result[i].box[2]);\n }\n ctx.fillStyle = localOptions.labelColor;\n ctx.fillText(label, result[i].box[0] + 2, 0 + result[i].box[1] + localOptions.lineHeight, result[i].box[2]);\n }\n ctx.stroke();\n }\n }\n}\n\n/** draw processed canvas */\nexport async function canvas(input: AnyCanvas | HTMLImageElement | HTMLVideoElement, output: AnyCanvas) {\n if (!input || !output) return;\n const ctx = getCanvasContext(output);\n if (!ctx) return;\n ctx.drawImage(input, 0, 0);\n}\n\n/** meta-function that performs draw for: canvas, face, body, hand */\nexport async function all(inCanvas: AnyCanvas, result: Result, drawOptions?: Partial) {\n if (!result || !result.performance || !result || !inCanvas) return null;\n const timeStamp = now();\n const localOptions = mergeDeep(options, drawOptions);\n const promise = Promise.all([\n face(inCanvas, result.face, localOptions),\n body(inCanvas, result.body, localOptions),\n hand(inCanvas, result.hand, localOptions),\n object(inCanvas, result.object, localOptions),\n gesture(inCanvas, result.gesture, localOptions), // gestures do not have buffering\n // person(inCanvas, result.persons, localOptions); // already included above\n ]);\n drawTime = env.perfadd ? drawTime + Math.round(now() - timeStamp) : Math.round(now() - timeStamp);\n result.performance.draw = drawTime;\n return promise;\n}\n", "import { log } from '../util/util';\nimport type { AnyCanvas } from '../exports';\nimport type { Point } from '../result';\nimport type { DrawOptions } from './options';\n\nexport const getCanvasContext = (input: AnyCanvas) => {\n if (!input) log('draw error: invalid canvas');\n else if (!input.getContext) log('draw error: canvas context not defined');\n else {\n const ctx = input.getContext('2d');\n if (!ctx) log('draw error: cannot get canvas context');\n else return ctx;\n }\n return null;\n};\n\nexport const rad2deg = (theta: number) => Math.round((theta * 180) / Math.PI);\n\nexport const colorDepth = (z: number | undefined, opt: DrawOptions): string => {\n if (!opt.useDepth || typeof z === 'undefined') return opt.color;\n const rgb = Uint8ClampedArray.from([127 + (2 * z), 127 - (2 * z), 255]);\n const color = `rgba(${rgb[0]}, ${rgb[1]}, ${rgb[2]}, ${opt.alpha})`;\n return color;\n};\n\nexport function point(ctx: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D, x: number, y: number, z: number | undefined, localOptions: DrawOptions) {\n ctx.fillStyle = colorDepth(z, localOptions);\n ctx.beginPath();\n ctx.arc(x, y, localOptions.pointSize, 0, 2 * Math.PI);\n ctx.fill();\n}\n\nexport function rect(ctx: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D, x: number, y: number, width: number, height: number, localOptions: DrawOptions) {\n ctx.beginPath();\n ctx.lineWidth = localOptions.lineWidth;\n if (localOptions.useCurves) {\n const cx = (x + x + width) / 2;\n const cy = (y + y + height) / 2;\n ctx.ellipse(cx, cy, width / 2, height / 2, 0, 0, 2 * Math.PI);\n } else {\n ctx.moveTo(x + localOptions.roundRect, y);\n ctx.lineTo(x + width - localOptions.roundRect, y);\n ctx.quadraticCurveTo(x + width, y, x + width, y + localOptions.roundRect);\n ctx.lineTo(x + width, y + height - localOptions.roundRect);\n ctx.quadraticCurveTo(x + width, y + height, x + width - localOptions.roundRect, y + height);\n ctx.lineTo(x + localOptions.roundRect, y + height);\n ctx.quadraticCurveTo(x, y + height, x, y + height - localOptions.roundRect);\n ctx.lineTo(x, y + localOptions.roundRect);\n ctx.quadraticCurveTo(x, y, x + localOptions.roundRect, y);\n ctx.closePath();\n }\n ctx.stroke();\n}\n\nexport function lines(ctx: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D, points: Point[], localOptions: DrawOptions) {\n if (points.length < 2) return;\n ctx.beginPath();\n ctx.moveTo(points[0][0], points[0][1]);\n for (const pt of points) {\n ctx.strokeStyle = colorDepth(pt[2], localOptions);\n ctx.lineTo(Math.trunc(pt[0]), Math.trunc(pt[1]));\n }\n ctx.stroke();\n if (localOptions.fillPolygons) {\n ctx.closePath();\n ctx.fill();\n }\n}\n\nexport function curves(ctx: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D, points: Point[], localOptions: DrawOptions) {\n if (points.length < 2) return;\n ctx.lineWidth = localOptions.lineWidth;\n if (!localOptions.useCurves || points.length <= 2) {\n lines(ctx, points, localOptions);\n return;\n }\n ctx.moveTo(points[0][0], points[0][1]);\n for (let i = 0; i < points.length - 2; i++) {\n const xc = (points[i][0] + points[i + 1][0]) / 2;\n const yc = (points[i][1] + points[i + 1][1]) / 2;\n ctx.quadraticCurveTo(points[i][0], points[i][1], xc, yc);\n }\n ctx.quadraticCurveTo(points[points.length - 2][0], points[points.length - 2][1], points[points.length - 1][0], points[points.length - 1][1]);\n ctx.stroke();\n if (localOptions.fillPolygons) {\n ctx.closePath();\n ctx.fill();\n }\n}\n\nexport function arrow(ctx: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D, from: Point, to: Point, radius = 5) {\n let angle;\n let x;\n let y;\n ctx.beginPath();\n ctx.moveTo(from[0], from[1]);\n ctx.lineTo(to[0], to[1]);\n angle = Math.atan2(to[1] - from[1], to[0] - from[0]);\n x = radius * Math.cos(angle) + to[0];\n y = radius * Math.sin(angle) + to[1];\n ctx.moveTo(x, y);\n angle += (1.0 / 3.0) * (2 * Math.PI);\n x = radius * Math.cos(angle) + to[0];\n y = radius * Math.sin(angle) + to[1];\n ctx.lineTo(x, y);\n angle += (1.0 / 3.0) * (2 * Math.PI);\n x = radius * Math.cos(angle) + to[0];\n y = radius * Math.sin(angle) + to[1];\n ctx.lineTo(x, y);\n ctx.closePath();\n ctx.stroke();\n ctx.fill();\n}\n", "/** Draw Options\n * - Accessed via `human.draw.options` or provided per each draw method as the drawOptions optional parameter\n */\nexport type DrawOptions = {\n /** draw line color */\n color: string,\n /** alpha value used for lines */\n alpha: number,\n /** label color */\n labelColor: string,\n /** label shadow color */\n shadowColor: string,\n /** label font */\n font: string,\n /** line spacing between labels */\n lineHeight: number,\n /** line width for drawn lines */\n lineWidth: number,\n /** size of drawn points */\n pointSize: number,\n /** draw rounded boxes by n pixels */\n roundRect: number,\n /** should points be drawn? */\n drawPoints: boolean,\n /** should labels be drawn? */\n drawLabels: boolean,\n /** should face attention keypoints be highlighted */\n drawAttention: boolean;\n /** should detected gestures be drawn? */\n drawGestures: boolean,\n /** should draw boxes around detection results? */\n drawBoxes: boolean,\n /** should draw polygons from detection points? */\n drawPolygons: boolean,\n /** should draw gaze arrows? */\n drawGaze: boolean,\n /** should fill polygons? */\n fillPolygons: boolean,\n /** use z-coordinate when available */\n useDepth: boolean,\n /** should lines be curved? */\n useCurves: boolean,\n}\n\n/** currently set draw options {@link DrawOptions} */\nexport const options: DrawOptions = {\n color: 'rgba(173, 216, 230, 0.6)', // 'lightblue' with light alpha channel\n labelColor: 'rgba(173, 216, 230, 1)', // 'lightblue' with dark alpha channel\n shadowColor: 'black',\n alpha: 0.5,\n font: 'small-caps 16px \"Segoe UI\"',\n lineHeight: 18,\n lineWidth: 4,\n pointSize: 2,\n roundRect: 8,\n drawPoints: false,\n drawLabels: true,\n drawBoxes: true,\n drawAttention: true,\n drawGestures: true,\n drawPolygons: true,\n drawGaze: true,\n fillPolygons: false,\n useDepth: true,\n useCurves: false,\n};\n", "import { TRI468 as triangulation } from '../face/facemeshcoords';\nimport { mergeDeep } from '../util/util';\nimport { getCanvasContext, rad2deg, rect, point, lines, arrow } from './primitives';\nimport { options } from './options';\nimport { attentionDefinitions } from '../face/attention';\nimport type { FaceResult } from '../result';\nimport type { AnyCanvas, DrawOptions } from '../exports';\n\nlet opt: DrawOptions;\n\nfunction drawLabels(f: FaceResult, ctx: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D) {\n if (opt.drawLabels) {\n // silly hack since fillText does not suport new line\n const labels:string[] = [];\n labels.push(`face: ${Math.trunc(100 * f.score)}%`);\n if (f.genderScore) labels.push(`${f.gender || ''} ${Math.trunc(100 * f.genderScore)}%`);\n if (f.age) labels.push(`age: ${f.age || ''}`);\n if (f.iris) labels.push(`distance: ${f.iris}`);\n if (f.real) labels.push(`real: ${Math.trunc(100 * f.real)}%`);\n if (f.live) labels.push(`live: ${Math.trunc(100 * f.live)}%`);\n if (f.emotion && f.emotion.length > 0) {\n const emotion = f.emotion.map((a) => `${Math.trunc(100 * a.score)}% ${a.emotion}`);\n if (emotion.length > 3) emotion.length = 3;\n labels.push(emotion.join(' '));\n }\n if (f.rotation && f.rotation.angle && f.rotation.gaze) {\n if (f.rotation.angle.roll) labels.push(`roll: ${rad2deg(f.rotation.angle.roll)}\u00B0 yaw:${rad2deg(f.rotation.angle.yaw)}\u00B0 pitch:${rad2deg(f.rotation.angle.pitch)}\u00B0`);\n if (f.rotation.gaze.bearing) labels.push(`gaze: ${rad2deg(f.rotation.gaze.bearing)}\u00B0`);\n }\n if (labels.length === 0) labels.push('face');\n ctx.fillStyle = opt.color;\n for (let i = labels.length - 1; i >= 0; i--) {\n const x = Math.max(f.box[0], 0);\n const y = i * opt.lineHeight + f.box[1];\n if (opt.shadowColor && opt.shadowColor !== '') {\n ctx.fillStyle = opt.shadowColor;\n ctx.fillText(labels[i], x + 5, y + 16);\n }\n ctx.fillStyle = opt.labelColor;\n ctx.fillText(labels[i], x + 4, y + 15);\n }\n }\n}\n\nfunction drawIrisElipse(f: FaceResult, ctx: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D) {\n // iris: array[center, left, top, right, bottom]\n if (f.annotations && f.annotations['leftEyeIris'] && f.annotations['leftEyeIris'][0]) {\n ctx.strokeStyle = opt.useDepth ? 'rgba(255, 200, 255, 0.3)' : opt.color;\n ctx.beginPath();\n const sizeX = Math.abs(f.annotations['leftEyeIris'][3][0] - f.annotations['leftEyeIris'][1][0]) / 2;\n const sizeY = Math.abs(f.annotations['leftEyeIris'][4][1] - f.annotations['leftEyeIris'][2][1]) / 2;\n ctx.ellipse(f.annotations['leftEyeIris'][0][0], f.annotations['leftEyeIris'][0][1], sizeX, sizeY, 0, 0, 2 * Math.PI);\n ctx.stroke();\n if (opt.fillPolygons) {\n ctx.fillStyle = opt.useDepth ? 'rgba(255, 255, 200, 0.3)' : opt.color;\n ctx.fill();\n }\n }\n if (f.annotations && f.annotations['rightEyeIris'] && f.annotations['rightEyeIris'][0]) {\n ctx.strokeStyle = opt.useDepth ? 'rgba(255, 200, 255, 0.3)' : opt.color;\n ctx.beginPath();\n const sizeX = Math.abs(f.annotations['rightEyeIris'][3][0] - f.annotations['rightEyeIris'][1][0]) / 2;\n const sizeY = Math.abs(f.annotations['rightEyeIris'][4][1] - f.annotations['rightEyeIris'][2][1]) / 2;\n ctx.ellipse(f.annotations['rightEyeIris'][0][0], f.annotations['rightEyeIris'][0][1], sizeX, sizeY, 0, 0, 2 * Math.PI);\n ctx.stroke();\n if (opt.fillPolygons) {\n ctx.fillStyle = opt.useDepth ? 'rgba(255, 255, 200, 0.3)' : opt.color;\n ctx.fill();\n }\n }\n}\n\nfunction drawGazeSpheres(f: FaceResult, ctx: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D) {\n if (opt.drawGaze && f.rotation?.angle && typeof Path2D !== 'undefined') {\n ctx.strokeStyle = 'pink';\n const valX = (f.box[0] + f.box[2] / 2) - (f.box[3] * rad2deg(f.rotation.angle.yaw) / 90);\n const valY = (f.box[1] + f.box[3] / 2) + (f.box[2] * rad2deg(f.rotation.angle.pitch) / 90);\n const pathV = new Path2D(`\n M ${f.box[0] + f.box[2] / 2} ${f.box[1]}\n C\n ${valX} ${f.box[1]},\n ${valX} ${f.box[1] + f.box[3]},\n ${f.box[0] + f.box[2] / 2} ${f.box[1] + f.box[3]}\n `);\n const pathH = new Path2D(`\n M ${f.box[0]} ${f.box[1] + f.box[3] / 2}\n C \n ${f.box[0]} ${valY},\n ${f.box[0] + f.box[2]} ${valY},\n ${f.box[0] + f.box[2]} ${f.box[1] + f.box[3] / 2}\n `);\n ctx.stroke(pathH);\n ctx.stroke(pathV);\n }\n}\n\nfunction drawGazeArrows(f: FaceResult, ctx: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D) {\n if (opt.drawGaze && f.rotation?.gaze?.strength && f.rotation?.gaze?.bearing && f.annotations['leftEyeIris'] && f.annotations['rightEyeIris'] && f.annotations['leftEyeIris'][0] && f.annotations['rightEyeIris'][0]) {\n ctx.strokeStyle = 'pink';\n ctx.fillStyle = 'pink';\n const leftGaze = [\n f.annotations['leftEyeIris'][0][0] + (Math.sin(f.rotation.gaze.bearing) * f.rotation.gaze.strength * f.box[3]),\n f.annotations['leftEyeIris'][0][1] + (Math.cos(f.rotation.gaze.bearing) * f.rotation.gaze.strength * f.box[2]),\n ];\n arrow(ctx, [f.annotations['leftEyeIris'][0][0], f.annotations['leftEyeIris'][0][1]], [leftGaze[0], leftGaze[1]], 4);\n const rightGaze = [\n f.annotations['rightEyeIris'][0][0] + (Math.sin(f.rotation.gaze.bearing) * f.rotation.gaze.strength * f.box[3]),\n f.annotations['rightEyeIris'][0][1] + (Math.cos(f.rotation.gaze.bearing) * f.rotation.gaze.strength * f.box[2]),\n ];\n arrow(ctx, [f.annotations['rightEyeIris'][0][0], f.annotations['rightEyeIris'][0][1]], [rightGaze[0], rightGaze[1]], 4);\n }\n}\n\nfunction drawFacePolygons(f: FaceResult, ctx: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D) {\n if (opt.drawPolygons && f.mesh.length >= 468) {\n ctx.lineWidth = 1;\n for (let i = 0; i < triangulation.length / 3; i++) {\n const points = [triangulation[i * 3 + 0], triangulation[i * 3 + 1], triangulation[i * 3 + 2]].map((index) => f.mesh[index]);\n lines(ctx, points, opt);\n }\n drawIrisElipse(f, ctx);\n }\n}\n\nfunction drawFacePoints(f: FaceResult, ctx: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D) {\n if (opt.drawPoints && f.mesh.length >= 468) {\n for (let i = 0; i < f.mesh.length; i++) {\n point(ctx, f.mesh[i][0], f.mesh[i][1], f.mesh[i][2], opt);\n if (opt.drawAttention) {\n if (attentionDefinitions.lips.includes(i)) point(ctx, f.mesh[i][0], f.mesh[i][1], (f.mesh[i][2] as number) + 127, opt);\n if (attentionDefinitions.eyeL.includes(i)) point(ctx, f.mesh[i][0], f.mesh[i][1], (f.mesh[i][2] as number) - 127, opt);\n if (attentionDefinitions.eyeR.includes(i)) point(ctx, f.mesh[i][0], f.mesh[i][1], (f.mesh[i][2] as number) - 127, opt);\n }\n }\n }\n}\n\nfunction drawFaceBoxes(f: FaceResult, ctx) {\n if (opt.drawBoxes) {\n rect(ctx, f.box[0], f.box[1], f.box[2], f.box[3], opt);\n }\n}\n\n/** draw detected faces */\nexport async function face(inCanvas: AnyCanvas, result: Array, drawOptions?: Partial) {\n opt = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n const ctx = getCanvasContext(inCanvas);\n if (!ctx) return;\n ctx.font = opt.font;\n ctx.strokeStyle = opt.color;\n ctx.fillStyle = opt.color;\n for (const f of result) {\n drawFaceBoxes(f, ctx);\n drawLabels(f, ctx);\n if (f.mesh && f.mesh.length > 0) {\n drawFacePoints(f, ctx);\n drawFacePolygons(f, ctx);\n drawGazeSpheres(f, ctx);\n drawGazeArrows(f, ctx);\n }\n }\n}\n", "import { mergeDeep } from '../util/util';\nimport { getCanvasContext, rect, point, curves, colorDepth } from './primitives';\nimport { options } from './options';\nimport type { BodyResult } from '../result';\nimport type { AnyCanvas, DrawOptions } from '../exports';\n\n/** draw detected bodies */\nexport async function body(inCanvas: AnyCanvas, result: Array, drawOptions?: Partial) {\n const localOptions = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n const ctx = getCanvasContext(inCanvas);\n if (!ctx) return;\n ctx.lineJoin = 'round';\n for (let i = 0; i < result.length; i++) {\n ctx.strokeStyle = localOptions.color;\n ctx.fillStyle = localOptions.color;\n ctx.lineWidth = localOptions.lineWidth;\n ctx.font = localOptions.font;\n if (localOptions.drawBoxes && result[i].box && result[i].box?.length === 4) {\n rect(ctx, result[i].box[0], result[i].box[1], result[i].box[2], result[i].box[3], localOptions);\n if (localOptions.drawLabels) {\n if (localOptions.shadowColor && localOptions.shadowColor !== '') {\n ctx.fillStyle = localOptions.shadowColor;\n ctx.fillText(`body ${100 * result[i].score}%`, result[i].box[0] + 3, 1 + result[i].box[1] + localOptions.lineHeight, result[i].box[2]);\n }\n ctx.fillStyle = localOptions.labelColor;\n ctx.fillText(`body ${100 * result[i].score}%`, result[i].box[0] + 2, 0 + result[i].box[1] + localOptions.lineHeight, result[i].box[2]);\n }\n }\n if (localOptions.drawPoints && result[i].keypoints) {\n for (let pt = 0; pt < result[i].keypoints.length; pt++) {\n if (!result[i].keypoints[pt].score || (result[i].keypoints[pt].score === 0)) continue;\n ctx.fillStyle = colorDepth(result[i].keypoints[pt].position[2], localOptions);\n point(ctx, result[i].keypoints[pt].position[0], result[i].keypoints[pt].position[1], 0, localOptions);\n }\n }\n if (localOptions.drawLabels && result[i].keypoints) {\n ctx.font = localOptions.font;\n for (const pt of result[i].keypoints) {\n if (!pt.score || (pt.score === 0)) continue;\n ctx.fillStyle = colorDepth(pt.position[2], localOptions);\n ctx.fillText(`${pt.part} ${Math.trunc(100 * pt.score)}%`, pt.position[0] + 4, pt.position[1] + 4);\n }\n }\n if (localOptions.drawPolygons && result[i].keypoints && result[i].annotations) {\n for (const part of Object.values(result[i].annotations)) {\n for (const connected of part) curves(ctx, connected, localOptions);\n }\n }\n }\n}\n", "import { mergeDeep } from '../util/util';\nimport { getCanvasContext, rect, point, colorDepth } from './primitives';\nimport { options } from './options';\nimport type { HandResult } from '../result';\nimport type { AnyCanvas, DrawOptions, Point } from '../exports';\n\n/** draw detected hands */\nexport async function hand(inCanvas: AnyCanvas, result: Array, drawOptions?: Partial) {\n const localOptions = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n const ctx = getCanvasContext(inCanvas);\n if (!ctx) return;\n ctx.lineJoin = 'round';\n ctx.font = localOptions.font;\n for (const h of result) {\n if (localOptions.drawBoxes) {\n ctx.strokeStyle = localOptions.color;\n ctx.fillStyle = localOptions.color;\n rect(ctx, h.box[0], h.box[1], h.box[2], h.box[3], localOptions);\n if (localOptions.drawLabels) {\n if (localOptions.shadowColor && localOptions.shadowColor !== '') {\n ctx.fillStyle = localOptions.shadowColor;\n ctx.fillText(`hand:${Math.trunc(100 * h.score)}%`, h.box[0] + 3, 1 + h.box[1] + localOptions.lineHeight, h.box[2]); // can use h.label\n }\n ctx.fillStyle = localOptions.labelColor;\n ctx.fillText(`hand:${Math.trunc(100 * h.score)}%`, h.box[0] + 2, 0 + h.box[1] + localOptions.lineHeight, h.box[2]); // can use h.label\n }\n ctx.stroke();\n }\n if (localOptions.drawPoints) {\n if (h.keypoints && h.keypoints.length > 0) {\n for (const pt of h.keypoints) {\n ctx.fillStyle = colorDepth(pt[2], localOptions);\n point(ctx, pt[0], pt[1], 0, localOptions);\n }\n }\n }\n if (localOptions.drawLabels && h.annotations) {\n const addHandLabel = (part: Array, title: string) => {\n if (!part || part.length === 0 || !part[0]) return;\n const z = part[part.length - 1][2] || -256;\n ctx.fillStyle = colorDepth(z, localOptions);\n ctx.fillText(title, part[part.length - 1][0] + 4, part[part.length - 1][1] + 4);\n };\n ctx.font = localOptions.font;\n addHandLabel(h.annotations['index'], 'index');\n addHandLabel(h.annotations['middle'], 'middle');\n addHandLabel(h.annotations['ring'], 'ring');\n addHandLabel(h.annotations['pinky'], 'pinky');\n addHandLabel(h.annotations['thumb'], 'thumb');\n addHandLabel(h.annotations['palm'], 'palm');\n }\n if (localOptions.drawPolygons && h.annotations) {\n const addHandLine = (part: Array) => {\n if (!part || part.length === 0 || !part[0]) return;\n for (let i = 0; i < part.length; i++) {\n ctx.beginPath();\n const z = part[i][2] || 0;\n ctx.strokeStyle = colorDepth(i * z, localOptions);\n ctx.moveTo(part[i > 0 ? i - 1 : 0][0], part[i > 0 ? i - 1 : 0][1]);\n ctx.lineTo(part[i][0], part[i][1]);\n ctx.stroke();\n }\n };\n ctx.lineWidth = localOptions.lineWidth;\n addHandLine(h.annotations['index']);\n addHandLine(h.annotations['middle']);\n addHandLine(h.annotations['ring']);\n addHandLine(h.annotations['pinky']);\n addHandLine(h.annotations['thumb']);\n // addPart(h.annotations.palm);\n }\n }\n}\n", "import { mergeDeep } from '../util/util';\nimport { getCanvasContext, rect } from './primitives';\nimport { options } from './options';\nimport type { ObjectResult } from '../result';\nimport type { AnyCanvas, DrawOptions } from '../exports';\n\n/** draw detected objects */\nexport async function object(inCanvas: AnyCanvas, result: Array, drawOptions?: Partial) {\n const localOptions = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n const ctx = getCanvasContext(inCanvas);\n if (!ctx) return;\n ctx.lineJoin = 'round';\n ctx.font = localOptions.font;\n for (const h of result) {\n if (localOptions.drawBoxes) {\n ctx.strokeStyle = localOptions.color;\n ctx.fillStyle = localOptions.color;\n rect(ctx, h.box[0], h.box[1], h.box[2], h.box[3], localOptions);\n if (localOptions.drawLabels) {\n const label = `${h.label} ${Math.round(100 * h.score)}%`;\n if (localOptions.shadowColor && localOptions.shadowColor !== '') {\n ctx.fillStyle = localOptions.shadowColor;\n ctx.fillText(label, h.box[0] + 3, 1 + h.box[1] + localOptions.lineHeight, h.box[2]);\n }\n ctx.fillStyle = localOptions.labelColor;\n ctx.fillText(label, h.box[0] + 2, 0 + h.box[1] + localOptions.lineHeight, h.box[2]);\n }\n ctx.stroke();\n }\n }\n}\n", "import { mergeDeep } from '../util/util';\nimport { getCanvasContext } from './primitives';\nimport { options } from './options';\nimport type { GestureResult } from '../result';\nimport type { AnyCanvas, DrawOptions } from '../exports';\n\n/** draw detected gestures */\nexport async function gesture(inCanvas: AnyCanvas, result: Array, drawOptions?: Partial) {\n const localOptions = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n if (localOptions.drawGestures) {\n const ctx = getCanvasContext(inCanvas);\n if (!ctx) return;\n ctx.font = localOptions.font;\n ctx.fillStyle = localOptions.color;\n let i = 1;\n for (let j = 0; j < result.length; j++) {\n let where: unknown[] = []; // what&where is a record\n let what: unknown[] = []; // what&where is a record\n [where, what] = Object.entries(result[j]);\n if ((what.length > 1) && ((what[1] as string).length > 0)) {\n const who = where[1] as number > 0 ? `#${where[1]}` : '';\n const label = `${where[0]} ${who}: ${what[1]}`;\n if (localOptions.shadowColor && localOptions.shadowColor !== '') {\n ctx.fillStyle = localOptions.shadowColor;\n ctx.fillText(label, 8, 2 + (i * localOptions.lineHeight));\n }\n ctx.fillStyle = localOptions.labelColor;\n ctx.fillText(label, 6, 0 + (i * localOptions.lineHeight));\n i += 1;\n }\n }\n }\n}\n", "import type { Tensor } from '../tfjs/types';\nimport type { FaceResult } from '../result';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { meshAnnotations } from './facemeshcoords';\n\nconst expandFact = 0.1;\nconst alpha = 0.5;\n\n// point inclusion in polygon based on https://wrf.ecse.rpi.edu/Research/Short_Notes/pnpoly.html\nfunction insidePoly(x: number, y: number, polygon: Array<{ x: number, y: number }>): boolean {\n let inside = false;\n let j = polygon.length - 1;\n for (let i = 0; i < polygon.length; j = i++) {\n if (((polygon[i].y > y) !== (polygon[j].y > y)) && (x < (polygon[j].x - polygon[i].x) * (y - polygon[i].y) / (polygon[j].y - polygon[i].y) + polygon[i].x)) inside = !inside;\n }\n return inside;\n}\n\nexport async function mask(face: FaceResult): Promise {\n if (!face.tensor) return face.tensor;\n if (!face.mesh || face.mesh.length < 100) return face.tensor;\n const width = face.tensor.shape[2] || 0;\n const height = face.tensor.shape[1] || 0;\n const buffer = await face.tensor.buffer();\n let silhouette: Array<{ x: number, y: number }> = [];\n for (const pt of meshAnnotations.silhouette) silhouette.push({ x: (face.mesh[pt][0] - face.box[0]) / face.box[2], y: (face.mesh[pt][1] - face.box[1]) / face.box[3] }); // add all silhouette points scaled to local box\n if (expandFact && expandFact > 0) silhouette = silhouette.map((pt) => ({ x: pt.x > 0.5 ? pt.x + expandFact : pt.x - expandFact, y: pt.y > 0.5 ? pt.y + expandFact : pt.y - expandFact })); // expand silhouette\n for (let x = 0; x < width; x++) {\n for (let y = 0; y < height; y++) {\n const inside = insidePoly(x / width, y / width, silhouette);\n if (!inside) {\n buffer.set(alpha * buffer.get(0, y, x, 0), 0, y, x, 0);\n buffer.set(alpha * buffer.get(0, y, x, 1), 0, y, x, 1);\n buffer.set(alpha * buffer.get(0, y, x, 2), 0, y, x, 2);\n }\n }\n }\n const output = buffer.toTensor();\n tf.dispose(buffer);\n return output;\n}\n", "import type { Point, FaceResult } from '../result';\n\ntype Vector = [number, number, number];\n\nconst calculateGaze = (face: FaceResult): { bearing: number, strength: number } => {\n const radians = (pt1: Point, pt2: Point) => Math.atan2(pt1[1] - pt2[1], pt1[0] - pt2[0]); // function to calculate angle between any two points\n if (!face.annotations['rightEyeIris'] || !face.annotations['leftEyeIris']) return { bearing: 0, strength: 0 };\n\n const offsetIris = [0, -0.1]; // iris center may not align with average of eye extremes\n const eyeRatio = 1; // factor to normalize changes x vs y\n\n const left = (face.mesh[33][2] || 0) > (face.mesh[263][2] || 0); // pick left or right eye depending which one is closer bazed on outsize point z axis\n const irisCenter = left ? face.mesh[473] : face.mesh[468];\n const eyeCenter = left // eye center is average of extreme points on x axis for both x and y, ignoring y extreme points as eyelids naturally open/close more when gazing up/down so relative point is less precise\n ? [(face.mesh[133][0] + face.mesh[33][0]) / 2, (face.mesh[133][1] + face.mesh[33][1]) / 2]\n : [(face.mesh[263][0] + face.mesh[362][0]) / 2, (face.mesh[263][1] + face.mesh[362][1]) / 2];\n const eyeSize = left // eye size is difference between extreme points for both x and y, used to normalize & squarify eye dimensions\n ? [face.mesh[133][0] - face.mesh[33][0], face.mesh[23][1] - face.mesh[27][1]]\n : [face.mesh[263][0] - face.mesh[362][0], face.mesh[253][1] - face.mesh[257][1]];\n const eyeDiff: Point = [ // x distance between extreme point and center point normalized with eye size\n (eyeCenter[0] - irisCenter[0]) / eyeSize[0] - offsetIris[0],\n eyeRatio * (irisCenter[1] - eyeCenter[1]) / eyeSize[1] - offsetIris[1],\n ];\n let strength = Math.sqrt((eyeDiff[0] * eyeDiff[0]) + (eyeDiff[1] * eyeDiff[1])); // vector length is a diagonal between two differences\n strength = Math.min(strength, face.boxRaw[2] / 2, face.boxRaw[3] / 2); // limit strength to half of box size to avoid clipping due to low precision\n const bearing = (radians([0, 0], eyeDiff) + (Math.PI / 2)) % Math.PI; // using eyeDiff instead eyeCenter/irisCenter combo due to manual adjustments and rotate clockwise 90degrees\n return { bearing, strength };\n};\n\nexport const calculateFaceAngle = (face: FaceResult, imageSize: [number, number]): {\n angle: { pitch: number, yaw: number, roll: number },\n matrix: [number, number, number, number, number, number, number, number, number],\n gaze: { bearing: number, strength: number },\n} => {\n // const degrees = (theta) => Math.abs(((theta * 180) / Math.PI) % 360);\n const normalize = (v: Vector): Vector => { // normalize vector\n const length = Math.sqrt(v[0] * v[0] + v[1] * v[1] + v[2] * v[2]);\n v[0] /= length;\n v[1] /= length;\n v[2] /= length;\n return v;\n };\n const subVectors = (a: Vector, b: Vector): Vector => { // vector subtraction (a - b)\n const x = a[0] - b[0];\n const y = a[1] - b[1];\n const z = a[2] - b[2];\n return [x, y, z];\n };\n const crossVectors = (a: Vector, b: Vector): Vector => { // vector cross product (a x b)\n const x = a[1] * b[2] - a[2] * b[1];\n const y = a[2] * b[0] - a[0] * b[2];\n const z = a[0] * b[1] - a[1] * b[0];\n return [x, y, z];\n };\n // 3x3 rotation matrix to Euler angles based on https://www.geometrictools.com/Documentation/EulerAngles.pdf\n const rotationMatrixToEulerAngle = (r: number[]): { pitch: number, yaw: number, roll: number } => {\n // eslint-disable-next-line no-unused-vars, @typescript-eslint/no-unused-vars\n const [r00, _r01, _r02, r10, r11, r12, r20, r21, r22] = r;\n let thetaX: number;\n let thetaY: number;\n let thetaZ: number;\n if (r10 < 1) { // YZX calculation\n if (r10 > -1) {\n thetaZ = Math.asin(r10);\n thetaY = Math.atan2(-r20, r00);\n thetaX = Math.atan2(-r12, r11);\n } else {\n thetaZ = -Math.PI / 2;\n thetaY = -Math.atan2(r21, r22);\n thetaX = 0;\n }\n } else {\n thetaZ = Math.PI / 2;\n thetaY = Math.atan2(r21, r22);\n thetaX = 0;\n }\n if (isNaN(thetaX)) thetaX = 0;\n if (isNaN(thetaY)) thetaY = 0;\n if (isNaN(thetaZ)) thetaZ = 0;\n return { pitch: 2 * -thetaX, yaw: 2 * -thetaY, roll: 2 * -thetaZ };\n };\n\n /*\n const meshToEulerAngle = (mesh) => { // simple Euler angle calculation based existing 3D mesh\n const radians = (a1, a2, b1, b2) => Math.atan2(b2 - a2, b1 - a1);\n return { // values are in radians in range of -pi/2 to pi/2 which is -90 to +90 degrees, value of 0 means center\n pitch: radians(mesh[10][1], mesh[10][2], mesh[152][1], mesh[152][2]), // looking at y,z of top and bottom points of the face // pitch is face move up/down\n yaw: radians(mesh[33][0], mesh[33][2], mesh[263][0], mesh[263][2]), // looking at x,z of outside corners of leftEye and rightEye // yaw is face turn left/right\n roll: radians(mesh[33][0], mesh[33][1], mesh[263][0], mesh[263][1]), // looking at x,y of outside corners of leftEye and rightEye // roll is face lean left/right\n };\n };\n */\n\n // initialize gaze and mesh\n const mesh = face.meshRaw;\n if (!mesh || mesh.length < 300) return { angle: { pitch: 0, yaw: 0, roll: 0 }, matrix: [1, 0, 0, 0, 1, 0, 0, 0, 1], gaze: { bearing: 0, strength: 0 } };\n\n const size = Math.max(face.boxRaw[2] * imageSize[0], face.boxRaw[3] * imageSize[1]) / 1.5;\n // top, bottom, left, right\n const pts: Point[] = [mesh[10], mesh[152], mesh[234], mesh[454]].map((pt) => [pt[0] * imageSize[0] / size, pt[1] * imageSize[1] / size, pt[2]] as Point); // make the xyz coordinates proportional, independent of the image/box size\n\n const y_axis = normalize(subVectors(pts[1] as Vector, pts[0] as Vector));\n let x_axis = normalize(subVectors(pts[3] as Vector, pts[2] as Vector));\n const z_axis = normalize(crossVectors(x_axis, y_axis));\n // adjust x_axis to make sure that all axes are perpendicular to each other\n x_axis = crossVectors(y_axis, z_axis);\n\n // Rotation Matrix from Axis Vectors - http://renderdan.blogspot.com/2006/05/rotation-matrix-from-axis-vectors.html\n // 3x3 rotation matrix is flatten to array in row-major order. Note that the rotation represented by this matrix is inverted.\n const matrix: [number, number, number, number, number, number, number, number, number] = [\n x_axis[0], x_axis[1], x_axis[2],\n y_axis[0], y_axis[1], y_axis[2],\n z_axis[0], z_axis[1], z_axis[2],\n ];\n const angle = rotationMatrixToEulerAngle(matrix);\n // const angle = meshToEulerAngle(mesh);\n\n // we have iris keypoints so we can calculate gaze direction\n const gaze = mesh.length === 478 ? calculateGaze(face) : { bearing: 0, strength: 0 };\n\n return { angle, matrix, gaze };\n};\n", "/**\n * Face algorithm implementation\n * Uses FaceMesh, Emotion and FaceRes models to create a unified pipeline\n */\n\nimport { log, now } from '../util/util';\nimport { env } from '../util/env';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as facemesh from './facemesh';\nimport * as emotion from '../gear/emotion';\nimport * as faceres from './faceres';\nimport * as mask from './mask';\nimport * as antispoof from './antispoof';\nimport * as liveness from './liveness';\nimport * as gear from '../gear/gear';\nimport * as ssrnetAge from '../gear/ssrnet-age';\nimport * as ssrnetGender from '../gear/ssrnet-gender';\nimport * as mobilefacenet from './mobilefacenet';\nimport type { FaceResult, Emotion, Gender, Race } from '../result';\nimport type { Tensor } from '../tfjs/types';\nimport type { Human } from '../human';\nimport { calculateFaceAngle } from './angles';\n\ntype DescRes = { age: number, gender: Gender, genderScore: number, descriptor: number[], race?: { score: number, race: Race }[] };\n\nexport const detectFace = async (instance: Human /* instance of human */, input: Tensor): Promise => {\n // run facemesh, includes blazeface and iris\n // eslint-disable-next-line no-async-promise-executor\n let timeStamp: number = now();\n let ageRes: { age: number } | Promise<{ age: number }> | null;\n let gearRes: gear.GearType | Promise | null;\n let genderRes: { gender: string, genderScore: number } | Promise<{ gender: string, genderScore: number }> | null;\n let emotionRes: { score: number, emotion: Emotion }[] | Promise<{ score: number, emotion: Emotion }[]>;\n let mobilefacenetRes: number[] | Promise | null;\n let antispoofRes: number | Promise | null;\n let livenessRes: number | Promise | null;\n let descRes: DescRes | Promise | null;\n\n const faceRes: Array = [];\n instance.state = 'run:face';\n\n const faces = await facemesh.predict(input, instance.config);\n instance.performance.face = env.perfadd ? (instance.performance.face || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n if (!input.shape || input.shape.length !== 4) return [];\n if (!faces) return [];\n // for (const face of faces) {\n for (let i = 0; i < faces.length; i++) {\n instance.analyze('Get Face');\n\n // is something went wrong, skip the face\n // @ts-ignore possibly undefied\n if (!faces[i].tensor || faces[i].tensor['isDisposedInternal']) {\n log('Face object is disposed:', faces[i].tensor);\n continue;\n }\n\n // optional face mask\n if (instance.config.face.detector?.mask) {\n const masked = await mask.mask(faces[i]);\n tf.dispose(faces[i].tensor);\n faces[i].tensor = masked as Tensor;\n }\n\n // calculate face angles\n const rotation = faces[i].mesh && (faces[i].mesh.length > 200) ? calculateFaceAngle(faces[i], [input.shape[2], input.shape[1]]) : null;\n\n // run emotion, inherits face from blazeface\n instance.analyze('Start Emotion:');\n if (instance.config.async) {\n emotionRes = instance.config.face.emotion?.enabled ? emotion.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : [];\n } else {\n instance.state = 'run:emotion';\n timeStamp = now();\n emotionRes = instance.config.face.emotion?.enabled ? await emotion.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : [];\n instance.performance.emotion = env.perfadd ? (instance.performance.emotion || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n }\n instance.analyze('End Emotion:');\n\n // run antispoof, inherits face from blazeface\n instance.analyze('Start AntiSpoof:');\n if (instance.config.async) {\n antispoofRes = instance.config.face.antispoof?.enabled ? antispoof.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : 0;\n } else {\n instance.state = 'run:antispoof';\n timeStamp = now();\n antispoofRes = instance.config.face.antispoof?.enabled ? await antispoof.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : 0;\n instance.performance.antispoof = env.perfadd ? (instance.performance.antispoof || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n }\n instance.analyze('End AntiSpoof:');\n\n // run liveness, inherits face from blazeface\n instance.analyze('Start Liveness:');\n if (instance.config.async) {\n livenessRes = instance.config.face.liveness?.enabled ? liveness.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : 0;\n } else {\n instance.state = 'run:liveness';\n timeStamp = now();\n livenessRes = instance.config.face.liveness?.enabled ? await liveness.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : 0;\n instance.performance.liveness = env.perfadd ? (instance.performance.antispoof || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n }\n instance.analyze('End Liveness:');\n\n // run gear, inherits face from blazeface\n instance.analyze('Start GEAR:');\n if (instance.config.async) {\n gearRes = instance.config.face['gear']?.enabled ? gear.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : null;\n } else {\n instance.state = 'run:gear';\n timeStamp = now();\n gearRes = instance.config.face['gear']?.enabled ? await gear.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : null;\n instance.performance.gear = Math.trunc(now() - timeStamp);\n }\n instance.analyze('End GEAR:');\n\n // run gear, inherits face from blazeface\n instance.analyze('Start SSRNet:');\n if (instance.config.async) {\n ageRes = instance.config.face['ssrnet']?.enabled ? ssrnetAge.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : null;\n genderRes = instance.config.face['ssrnet']?.enabled ? ssrnetGender.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : null;\n } else {\n instance.state = 'run:ssrnet';\n timeStamp = now();\n ageRes = instance.config.face['ssrnet']?.enabled ? await ssrnetAge.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : null;\n genderRes = instance.config.face['ssrnet']?.enabled ? await ssrnetGender.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : null;\n instance.performance.ssrnet = Math.trunc(now() - timeStamp);\n }\n instance.analyze('End SSRNet:');\n\n // run gear, inherits face from blazeface\n instance.analyze('Start MobileFaceNet:');\n if (instance.config.async) {\n mobilefacenetRes = instance.config.face['mobilefacenet']?.enabled ? mobilefacenet.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : null;\n } else {\n instance.state = 'run:mobilefacenet';\n timeStamp = now();\n mobilefacenetRes = instance.config.face['mobilefacenet']?.enabled ? await mobilefacenet.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : null;\n instance.performance.mobilefacenet = Math.trunc(now() - timeStamp);\n }\n instance.analyze('End MobileFaceNet:');\n\n // run emotion, inherits face from blazeface\n instance.analyze('Start Description:');\n if (instance.config.async) {\n descRes = instance.config.face.description?.enabled ? faceres.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : null;\n } else {\n instance.state = 'run:description';\n timeStamp = now();\n descRes = instance.config.face.description?.enabled ? await faceres.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : null;\n instance.performance.description = env.perfadd ? (instance.performance.description || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n }\n instance.analyze('End Description:');\n\n // if async wait for results\n if (instance.config.async) {\n [ageRes, genderRes, emotionRes, mobilefacenetRes, descRes, gearRes, antispoofRes, livenessRes] = await Promise.all([ageRes, genderRes, emotionRes, mobilefacenetRes, descRes, gearRes, antispoofRes, livenessRes]);\n }\n instance.analyze('Finish Face:');\n\n if (instance.config.face['ssrnet']?.enabled && ageRes && genderRes) { // override age/gender if ssrnet model is used\n descRes = {\n ...(descRes as DescRes),\n age: (ageRes as { age: number}).age,\n gender: (genderRes as { gender: Gender, genderScore: number }).gender,\n genderScore: (genderRes as { gender: Gender, genderScore: number }).genderScore,\n };\n }\n if (instance.config.face['gear']?.enabled && gearRes) { // override age/gender/race if gear model is used\n descRes = {\n ...(descRes as DescRes),\n age: (gearRes as gear.GearType).age,\n gender: (gearRes as gear.GearType).gender,\n genderScore: (gearRes as gear.GearType).genderScore,\n race: (gearRes as gear.GearType).race,\n };\n }\n if (instance.config.face['mobilefacenet']?.enabled && mobilefacenetRes) { // override descriptor if embedding model is used\n (descRes as DescRes).descriptor = mobilefacenetRes as number[];\n }\n\n // calculate iris distance\n // iris: array[ center, left, top, right, bottom]\n if (!instance.config.face.iris?.enabled) {\n // if (faces[i]?.annotations?.leftEyeIris) delete faces[i].annotations.leftEyeIris;\n // if (faces[i]?.annotations?.rightEyeIris) delete faces[i].annotations.rightEyeIris;\n }\n const irisSize = (faces[i].annotations && faces[i].annotations.leftEyeIris && faces[i].annotations.leftEyeIris[0] && faces[i].annotations.rightEyeIris && faces[i].annotations.rightEyeIris[0]\n && (faces[i].annotations.leftEyeIris.length > 0) && (faces[i].annotations.rightEyeIris.length > 0)\n && (faces[i].annotations.leftEyeIris[0] !== null) && (faces[i].annotations.rightEyeIris[0] !== null))\n ? Math.max(Math.abs(faces[i].annotations.leftEyeIris[3][0] - faces[i].annotations.leftEyeIris[1][0]), Math.abs(faces[i].annotations.rightEyeIris[4][1] - faces[i].annotations.rightEyeIris[2][1])) / input.shape[2]\n : 0; // note: average human iris size is 11.7mm\n\n // optionally return tensor\n const tensor = instance.config.face.detector?.return ? tf.squeeze(faces[i].tensor) : null;\n // dispose original face tensor\n tf.dispose(faces[i].tensor);\n // delete temp face image\n if (faces[i].tensor) delete faces[i].tensor;\n // combine results\n const res: FaceResult = {\n ...faces[i],\n id: i,\n };\n if ((descRes as DescRes)?.age) res.age = (descRes as DescRes).age as number;\n if ((descRes as DescRes)?.gender) res.gender = (descRes as DescRes).gender as Gender;\n if ((descRes as DescRes)?.genderScore) res.genderScore = (descRes as DescRes)?.genderScore as number;\n if ((descRes as DescRes)?.descriptor) res.embedding = (descRes as DescRes)?.descriptor as Array;\n if ((descRes as DescRes)?.race) res.race = (descRes as DescRes)?.race as { score: number, race: Race }[];\n if (emotionRes) res.emotion = emotionRes as Array<{ score: number, emotion: Emotion }>;\n if (antispoofRes) res.real = antispoofRes as number;\n if (livenessRes) res.live = livenessRes as number;\n if (irisSize && irisSize !== 0) res.iris = Math.trunc(500 / irisSize / 11.7) / 100;\n if (rotation) res.rotation = rotation;\n if (tensor) res.tensor = tensor;\n faceRes.push(res);\n instance.analyze('End Face');\n }\n instance.analyze('End FaceMesh:');\n if (instance.config.async) {\n if (instance.performance.face) delete instance.performance.face;\n if (instance.performance.age) delete instance.performance.age;\n if (instance.performance.gender) delete instance.performance.gender;\n if (instance.performance.emotion) delete instance.performance.emotion;\n }\n return faceRes;\n};\n", "/**\n * Gesture detection algorithm\n */\n\nimport type { GestureResult, BodyResult, FaceResult, HandResult, Point } from '../result';\nimport * as fingerPose from '../hand/fingerpose';\n\n/** face gesture type */\nexport type FaceGesture =\n `facing ${'left' | 'center' | 'right'}`\n | `blink ${'left' | 'right'} eye`\n | `mouth ${number}% open`\n | `head ${'up' | 'down'}`;\n\n/** iris gesture type */\nexport type IrisGesture =\n 'facing center'\n | `looking ${'left' | 'right' | 'up' | 'down'}`\n | 'looking center';\n\n/** body gesture type */\nexport type BodyGesture =\n `leaning ${'left' | 'right'}`\n | `raise ${'left' | 'right'} hand`\n | 'i give up';\n\n/** hand gesture type */\nexport type HandGesture =\n `${'thumb' | 'index' | 'middle' | 'ring' | 'pinky'} forward`\n | `${'thumb' | 'index' | 'middle' | 'ring' | 'pinky'} up`\n | 'victory'\n | 'thumbs up';\n\nexport const body = (res: BodyResult[]): GestureResult[] => {\n if (!res) return [];\n const gestures: Array<{ body: number, gesture: BodyGesture }> = [];\n for (let i = 0; i < res.length; i++) {\n // raising hands\n const leftWrist = res[i].keypoints.find((a) => (a.part === 'leftWrist'));\n const rightWrist = res[i].keypoints.find((a) => (a.part === 'rightWrist'));\n const nose = res[i].keypoints.find((a) => (a.part === 'nose'));\n if (nose && leftWrist && rightWrist && (leftWrist.position[1] < nose.position[1]) && (rightWrist.position[1] < nose.position[1])) gestures.push({ body: i, gesture: 'i give up' });\n else if (nose && leftWrist && (leftWrist.position[1] < nose.position[1])) gestures.push({ body: i, gesture: 'raise left hand' });\n else if (nose && rightWrist && (rightWrist.position[1] < nose.position[1])) gestures.push({ body: i, gesture: 'raise right hand' });\n\n // leaning\n const leftShoulder = res[i].keypoints.find((a) => (a.part === 'leftShoulder'));\n const rightShoulder = res[i].keypoints.find((a) => (a.part === 'rightShoulder'));\n if (leftShoulder && rightShoulder && Math.abs(leftShoulder.positionRaw[1] - rightShoulder.positionRaw[1]) > 0.1) {\n gestures.push({ body: i, gesture: `leaning ${(leftShoulder.position[1] > rightShoulder.position[1]) ? 'left' : 'right'}` });\n }\n }\n return gestures;\n};\n\nexport const face = (res: FaceResult[]): GestureResult[] => {\n if (!res) return [];\n const gestures: Array<{ face: number, gesture: FaceGesture }> = [];\n for (let i = 0; i < res.length; i++) {\n if (res[i].mesh && res[i].mesh.length > 450) {\n const zDiff = (res[i].mesh[33][2] || 0) - (res[i].mesh[263][2] || 0);\n const xDiff = res[i].mesh[33][0] - res[i].mesh[263][0];\n if (Math.abs(zDiff / xDiff) <= 0.15) gestures.push({ face: i, gesture: 'facing center' });\n else gestures.push({ face: i, gesture: `facing ${zDiff < 0 ? 'left' : 'right'}` });\n const openLeft = Math.abs(res[i].mesh[374][1] - res[i].mesh[386][1]) / Math.abs(res[i].mesh[443][1] - res[i].mesh[450][1]); // center of eye inner lid y coord div center of wider eye border y coord\n if (openLeft < 0.2) gestures.push({ face: i, gesture: 'blink left eye' });\n const openRight = Math.abs(res[i].mesh[145][1] - res[i].mesh[159][1]) / Math.abs(res[i].mesh[223][1] - res[i].mesh[230][1]); // center of eye inner lid y coord div center of wider eye border y coord\n if (openRight < 0.2) gestures.push({ face: i, gesture: 'blink right eye' });\n const mouthOpen = Math.min(100, 500 * Math.abs(res[i].mesh[13][1] - res[i].mesh[14][1]) / Math.abs(res[i].mesh[10][1] - res[i].mesh[152][1]));\n if (mouthOpen > 10) gestures.push({ face: i, gesture: `mouth ${Math.trunc(mouthOpen)}% open` });\n const chinDepth = res[i].mesh[152][2] || 0;\n if (Math.abs(chinDepth) > 10) gestures.push({ face: i, gesture: `head ${chinDepth < 0 ? 'up' : 'down'}` });\n }\n }\n return gestures;\n};\n\nexport const iris = (res: FaceResult[]): GestureResult[] => {\n if (!res) return [];\n const gestures: Array<{ iris: number, gesture: IrisGesture }> = [];\n for (let i = 0; i < res.length; i++) {\n if (!res[i].annotations || !res[i].annotations.leftEyeIris || !res[i].annotations.leftEyeIris[0] || !res[i].annotations.rightEyeIris || !res[i].annotations.rightEyeIris[0]) continue;\n const sizeXLeft = res[i].annotations.leftEyeIris[3][0] - res[i].annotations.leftEyeIris[1][0];\n const sizeYLeft = res[i].annotations.leftEyeIris[4][1] - res[i].annotations.leftEyeIris[2][1];\n const areaLeft = Math.abs(sizeXLeft * sizeYLeft);\n\n const sizeXRight = res[i].annotations.rightEyeIris[3][0] - res[i].annotations.rightEyeIris[1][0];\n const sizeYRight = res[i].annotations.rightEyeIris[4][1] - res[i].annotations.rightEyeIris[2][1];\n const areaRight = Math.abs(sizeXRight * sizeYRight);\n\n let center = false;\n const difference = Math.abs(areaLeft - areaRight) / Math.max(areaLeft, areaRight);\n if (difference < 0.25) {\n center = true;\n gestures.push({ iris: i, gesture: 'facing center' });\n }\n\n const leftIrisCenterX = Math.abs(res[i].mesh[263][0] - res[i].annotations.leftEyeIris[0][0]) / res[i].box[2];\n const rightIrisCenterX = Math.abs(res[i].mesh[33][0] - res[i].annotations.rightEyeIris[0][0]) / res[i].box[2];\n if (leftIrisCenterX > 0.06 || rightIrisCenterX > 0.06) center = false;\n if (leftIrisCenterX > rightIrisCenterX) { // check eye with bigger offset\n if (leftIrisCenterX > 0.05) gestures.push({ iris: i, gesture: 'looking right' });\n } else {\n if (rightIrisCenterX > 0.05) gestures.push({ iris: i, gesture: 'looking left' });\n }\n\n const rightIrisCenterY = Math.abs(res[i].mesh[145][1] - res[i].annotations.rightEyeIris[0][1]) / res[i].box[3];\n const leftIrisCenterY = Math.abs(res[i].mesh[374][1] - res[i].annotations.leftEyeIris[0][1]) / res[i].box[3];\n if (leftIrisCenterY < 0.01 || rightIrisCenterY < 0.01 || leftIrisCenterY > 0.022 || rightIrisCenterY > 0.022) center = false;\n if (leftIrisCenterY < 0.01 || rightIrisCenterY < 0.01) gestures.push({ iris: i, gesture: 'looking down' });\n if (leftIrisCenterY > 0.022 || rightIrisCenterY > 0.022) gestures.push({ iris: i, gesture: 'looking up' });\n\n // still center;\n if (center) gestures.push({ iris: i, gesture: 'looking center' });\n }\n return gestures;\n};\n\nexport const hand = (res: HandResult[]): GestureResult[] => {\n if (!res) return [];\n const gestures: Array<{ hand: number, gesture: HandGesture }> = [];\n for (let i = 0; i < res.length; i++) {\n const fingers: Array<{ name: string, position: Point }> = [];\n if (res[i]['annotations']) {\n for (const [finger, pos] of Object.entries(res[i]['annotations'])) {\n if (finger !== 'palmBase' && Array.isArray(pos) && pos[0]) fingers.push({ name: finger.toLowerCase(), position: pos[0] }); // get tip of each finger\n }\n }\n if (fingers && fingers.length > 0) {\n const closest = fingers.reduce((best, a) => ((best.position[2] || 0) < (a.position[2] || 0) ? best : a));\n gestures.push({ hand: i, gesture: `${closest.name} forward` as HandGesture });\n const highest = fingers.reduce((best, a) => (best.position[1] < a.position[1] ? best : a));\n gestures.push({ hand: i, gesture: `${highest.name} up` as HandGesture });\n }\n if (res[i]['keypoints']) {\n const poses = fingerPose.match(res[i]['keypoints']);\n for (const pose of poses) gestures.push({ hand: i, gesture: pose.name as HandGesture });\n }\n }\n return gestures;\n};\n", "/**\n * Results interpolation for smoothening of video detection results inbetween detected frames\n */\n\nimport type { Result, FaceResult, BodyResult, HandResult, ObjectResult, GestureResult, PersonResult, Box, Point, BodyLandmark, BodyAnnotation } from '../result';\nimport type { Config } from '../config';\n\nimport * as moveNetCoords from '../body/movenetcoords';\nimport * as blazePoseCoords from '../body/blazeposecoords';\nimport * as efficientPoseCoords from '../body/efficientposecoords';\nimport { now } from './util';\nimport { env } from './env';\n\nconst bufferedResult: Result = { face: [], body: [], hand: [], gesture: [], object: [], persons: [], performance: {}, timestamp: 0, error: null };\nlet interpolateTime = 0;\n\nexport function calc(newResult: Result, config: Config): Result {\n const t0 = now();\n if (!newResult) return { face: [], body: [], hand: [], gesture: [], object: [], persons: [], performance: {}, timestamp: 0, error: null };\n // each record is only updated using deep clone when number of detected record changes, otherwise it will converge by itself\n // otherwise bufferedResult is a shallow clone of result plus updated local calculated values\n // thus mixing by-reference and by-value assignments to minimize memory operations\n\n const elapsed = Date.now() - newResult.timestamp;\n // curve fitted: buffer = 8 - ln(delay)\n // interpolation formula: current = ((buffer - 1) * previous + live) / buffer\n // - at 50ms delay buffer = ~4.1 => 28% towards live data\n // - at 250ms delay buffer = ~2.5 => 40% towards live data\n // - at 500ms delay buffer = ~1.8 => 55% towards live data\n // - at 750ms delay buffer = ~1.4 => 71% towards live data\n // - at 1sec delay buffer = 1 which means live data is used\n const bufferedFactor = elapsed < 1000 ? 8 - Math.log(elapsed + 1) : 1;\n\n if (newResult.canvas) bufferedResult.canvas = newResult.canvas;\n if (newResult.error) bufferedResult.error = newResult.error;\n\n // interpolate body results\n if (!bufferedResult.body || (newResult.body.length !== bufferedResult.body.length)) {\n bufferedResult.body = JSON.parse(JSON.stringify(newResult.body as BodyResult[])); // deep clone once\n } else {\n for (let i = 0; i < newResult.body.length; i++) {\n const box = newResult.body[i].box // update box\n .map((newBoxCoord, j) => ((bufferedFactor - 1) * bufferedResult.body[i].box[j] + newBoxCoord) / bufferedFactor) as Box;\n const boxRaw = newResult.body[i].boxRaw // update boxRaw\n .map((newBoxCoord, j) => ((bufferedFactor - 1) * bufferedResult.body[i].boxRaw[j] + newBoxCoord) / bufferedFactor) as Box;\n const keypoints = (newResult.body[i].keypoints // update keypoints\n .map((newKpt, j) => ({\n score: newKpt.score,\n part: newKpt.part as BodyLandmark,\n position: [\n bufferedResult.body[i].keypoints[j] ? ((bufferedFactor - 1) * (bufferedResult.body[i].keypoints[j].position[0] || 0) + (newKpt.position[0] || 0)) / bufferedFactor : newKpt.position[0],\n bufferedResult.body[i].keypoints[j] ? ((bufferedFactor - 1) * (bufferedResult.body[i].keypoints[j].position[1] || 0) + (newKpt.position[1] || 0)) / bufferedFactor : newKpt.position[1],\n bufferedResult.body[i].keypoints[j] ? ((bufferedFactor - 1) * (bufferedResult.body[i].keypoints[j].position[2] || 0) + (newKpt.position[2] || 0)) / bufferedFactor : newKpt.position[2],\n ],\n positionRaw: [\n bufferedResult.body[i].keypoints[j] ? ((bufferedFactor - 1) * (bufferedResult.body[i].keypoints[j].positionRaw[0] || 0) + (newKpt.positionRaw[0] || 0)) / bufferedFactor : newKpt.positionRaw[0],\n bufferedResult.body[i].keypoints[j] ? ((bufferedFactor - 1) * (bufferedResult.body[i].keypoints[j].positionRaw[1] || 0) + (newKpt.positionRaw[1] || 0)) / bufferedFactor : newKpt.positionRaw[1],\n bufferedResult.body[i].keypoints[j] ? ((bufferedFactor - 1) * (bufferedResult.body[i].keypoints[j].positionRaw[2] || 0) + (newKpt.positionRaw[2] || 0)) / bufferedFactor : newKpt.positionRaw[2],\n ],\n distance: [\n bufferedResult.body[i].keypoints[j] ? ((bufferedFactor - 1) * (bufferedResult.body[i].keypoints[j].distance?.[0] || 0) + (newKpt.distance?.[0] || 0)) / bufferedFactor : newKpt.distance?.[0],\n bufferedResult.body[i].keypoints[j] ? ((bufferedFactor - 1) * (bufferedResult.body[i].keypoints[j].distance?.[1] || 0) + (newKpt.distance?.[1] || 0)) / bufferedFactor : newKpt.distance?.[1],\n bufferedResult.body[i].keypoints[j] ? ((bufferedFactor - 1) * (bufferedResult.body[i].keypoints[j].distance?.[2] || 0) + (newKpt.distance?.[2] || 0)) / bufferedFactor : newKpt.distance?.[2],\n ],\n }))) as Array<{ score: number, part: BodyLandmark, position: [number, number, number?], positionRaw: [number, number, number?] }>;\n\n const annotations: Record = {} as Record; // recreate annotations\n let coords = { connected: {} };\n if (config.body?.modelPath?.includes('efficientpose')) coords = efficientPoseCoords;\n else if (config.body?.modelPath?.includes('blazepose')) coords = blazePoseCoords;\n else if (config.body?.modelPath?.includes('movenet')) coords = moveNetCoords;\n for (const [name, indexes] of Object.entries(coords.connected as Record)) {\n const pt: Array = [];\n for (let j = 0; j < indexes.length - 1; j++) {\n const pt0 = keypoints.find((kp) => kp.part === indexes[j]);\n const pt1 = keypoints.find((kp) => kp.part === indexes[j + 1]);\n // if (pt0 && pt1 && pt0.score > (config.body.minConfidence || 0) && pt1.score > (config.body.minConfidence || 0)) pt.push([pt0.position, pt1.position]);\n if (pt0 && pt1) pt.push([pt0.position, pt1.position]);\n }\n annotations[name] = pt;\n }\n bufferedResult.body[i] = { ...newResult.body[i], box, boxRaw, keypoints, annotations: annotations as BodyResult['annotations'] }; // shallow clone plus updated values\n }\n }\n\n // interpolate hand results\n if (!bufferedResult.hand || (newResult.hand.length !== bufferedResult.hand.length)) {\n bufferedResult.hand = JSON.parse(JSON.stringify(newResult.hand as HandResult[])); // deep clone once\n } else {\n for (let i = 0; i < newResult.hand.length; i++) {\n const box = (newResult.hand[i].box// update box\n .map((b, j) => ((bufferedFactor - 1) * bufferedResult.hand[i].box[j] + b) / bufferedFactor)) as Box;\n const boxRaw = (newResult.hand[i].boxRaw // update boxRaw\n .map((b, j) => ((bufferedFactor - 1) * bufferedResult.hand[i].boxRaw[j] + b) / bufferedFactor)) as Box;\n if (bufferedResult.hand[i].keypoints.length !== newResult.hand[i].keypoints.length) bufferedResult.hand[i].keypoints = newResult.hand[i].keypoints; // reset keypoints as previous frame did not have them\n const keypoints = newResult.hand[i].keypoints && newResult.hand[i].keypoints.length > 0 ? newResult.hand[i].keypoints // update landmarks\n .map((landmark, j) => landmark\n .map((coord, k) => (((bufferedFactor - 1) * (bufferedResult.hand[i].keypoints[j][k] || 1) + (coord || 0)) / bufferedFactor)) as Point)\n : [];\n let annotations = {};\n if (Object.keys(bufferedResult.hand[i].annotations).length !== Object.keys(newResult.hand[i].annotations).length) {\n bufferedResult.hand[i].annotations = newResult.hand[i].annotations; // reset annotations as previous frame did not have them\n annotations = bufferedResult.hand[i].annotations;\n } else if (newResult.hand[i].annotations) {\n for (const key of Object.keys(newResult.hand[i].annotations)) { // update annotations\n annotations[key] = newResult.hand[i].annotations[key] && newResult.hand[i].annotations[key][0]\n ? newResult.hand[i].annotations[key]\n .map((val, j: number) => val\n .map((coord: number, k: number) => ((bufferedFactor - 1) * bufferedResult.hand[i].annotations[key][j][k] + coord) / bufferedFactor))\n : null;\n }\n }\n bufferedResult.hand[i] = { ...newResult.hand[i], box, boxRaw, keypoints, annotations: annotations as HandResult['annotations'] }; // shallow clone plus updated values\n }\n }\n\n // interpolate face results\n if (!bufferedResult.face || (newResult.face.length !== bufferedResult.face.length)) {\n bufferedResult.face = JSON.parse(JSON.stringify(newResult.face as FaceResult[])); // deep clone once\n } else {\n for (let i = 0; i < newResult.face.length; i++) {\n const box = (newResult.face[i].box // update box\n .map((b, j) => ((bufferedFactor - 1) * bufferedResult.face[i].box[j] + b) / bufferedFactor)) as Box;\n const boxRaw = (newResult.face[i].boxRaw // update boxRaw\n .map((b, j) => ((bufferedFactor - 1) * bufferedResult.face[i].boxRaw[j] + b) / bufferedFactor)) as Box;\n if (newResult.face[i].rotation) {\n const rotation: {\n matrix: [number, number, number, number, number, number, number, number, number],\n angle: { roll: number, yaw: number, pitch: number },\n gaze: { bearing: number, strength: number }\n } = { matrix: [0, 0, 0, 0, 0, 0, 0, 0, 0], angle: { roll: 0, yaw: 0, pitch: 0 }, gaze: { bearing: 0, strength: 0 } };\n rotation.matrix = newResult.face[i].rotation?.matrix as [number, number, number, number, number, number, number, number, number];\n rotation.angle = {\n roll: ((bufferedFactor - 1) * (bufferedResult.face[i].rotation?.angle?.roll || 0) + (newResult.face[i].rotation?.angle?.roll || 0)) / bufferedFactor,\n yaw: ((bufferedFactor - 1) * (bufferedResult.face[i].rotation?.angle?.yaw || 0) + (newResult.face[i].rotation?.angle?.yaw || 0)) / bufferedFactor,\n pitch: ((bufferedFactor - 1) * (bufferedResult.face[i].rotation?.angle?.pitch || 0) + (newResult.face[i].rotation?.angle?.pitch || 0)) / bufferedFactor,\n };\n rotation.gaze = {\n // not fully correct due projection on circle, also causes wrap-around draw on jump from negative to positive\n bearing: ((bufferedFactor - 1) * (bufferedResult.face[i].rotation?.gaze?.bearing || 0) + (newResult.face[i].rotation?.gaze?.bearing || 0)) / bufferedFactor,\n strength: ((bufferedFactor - 1) * (bufferedResult.face[i].rotation?.gaze?.strength || 0) + (newResult.face[i].rotation?.gaze?.strength || 0)) / bufferedFactor,\n };\n bufferedResult.face[i] = { ...newResult.face[i], rotation, box, boxRaw }; // shallow clone plus updated values\n }\n bufferedResult.face[i] = { ...newResult.face[i], box, boxRaw }; // shallow clone plus updated values\n }\n }\n\n // interpolate object detection results\n if (!bufferedResult.object || (newResult.object.length !== bufferedResult.object.length)) {\n bufferedResult.object = JSON.parse(JSON.stringify(newResult.object as ObjectResult[])); // deep clone once\n } else {\n for (let i = 0; i < newResult.object.length; i++) {\n const box = (newResult.object[i].box // update box\n .map((b, j) => ((bufferedFactor - 1) * bufferedResult.object[i].box[j] + b) / bufferedFactor)) as Box;\n const boxRaw = (newResult.object[i].boxRaw // update boxRaw\n .map((b, j) => ((bufferedFactor - 1) * bufferedResult.object[i].boxRaw[j] + b) / bufferedFactor)) as Box;\n bufferedResult.object[i] = { ...newResult.object[i], box, boxRaw }; // shallow clone plus updated values\n }\n }\n\n // interpolate person results\n if (newResult.persons) {\n const newPersons = newResult.persons; // trigger getter function\n if (!bufferedResult.persons || (newPersons.length !== bufferedResult.persons.length)) {\n bufferedResult.persons = JSON.parse(JSON.stringify(newPersons as PersonResult[]));\n } else {\n for (let i = 0; i < newPersons.length; i++) { // update person box, we don't update the rest as it's updated as reference anyhow\n bufferedResult.persons[i].box = (newPersons[i].box\n .map((box, j) => ((bufferedFactor - 1) * bufferedResult.persons[i].box[j] + box) / bufferedFactor)) as Box;\n }\n }\n }\n\n // just copy latest gestures without interpolation\n if (newResult.gesture) bufferedResult.gesture = newResult.gesture as GestureResult[];\n\n // append interpolation performance data\n const t1 = now();\n interpolateTime = env.perfadd ? interpolateTime + Math.round(t1 - t0) : Math.round(t1 - t0);\n if (newResult.performance) bufferedResult.performance = { ...newResult.performance, interpolate: interpolateTime };\n\n return bufferedResult;\n}\n", "/** Face descriptor type as number array */\nexport type Descriptor = Array\nexport type MatchOptions = { order?: number, threshold?: number, multiplier?: number, min?: number, max?: number } | undefined;\n\n/** Calculates distance between two descriptors\n * @param options - calculation options\n * - order - algorithm to use\n * Euclidean distance if `order` is 2 (default), Minkowski distance algorithm of nth order if `order` is higher than 2\n * - multiplier - by how much to enhance difference analysis in range of 1..100\n * default is 20 which normalizes results to similarity above 0.5 can be considered a match\n */\nexport function distance(descriptor1: Descriptor, descriptor2: Descriptor, options: MatchOptions = { order: 2, multiplier: 25 }) {\n // general minkowski distance, euclidean distance is limited case where order is 2\n let sum = 0;\n for (let i = 0; i < descriptor1.length; i++) {\n const diff = (!options.order || options.order === 2) ? (descriptor1[i] - descriptor2[i]) : (Math.abs(descriptor1[i] - descriptor2[i]));\n sum += (!options.order || options.order === 2) ? (diff * diff) : (diff ** options.order);\n }\n return (options.multiplier || 20) * sum;\n}\n\n// invert distance to similarity, normalize to given range and clamp\nconst normalizeDistance = (dist, order, min, max) => {\n if (dist === 0) return 1; // short circuit for identical inputs\n const root = order === 2 ? Math.sqrt(dist) : dist ** (1 / order); // take root of distance\n const norm = (1 - (root / 100) - min) / (max - min); // normalize to range\n const clamp = Math.max(Math.min(norm, 1), 0); // clamp to 0..1\n return clamp;\n};\n\n/** Calculates normalized similarity between two face descriptors based on their `distance`\n * @param options - calculation options\n * - order - algorithm to use\n * Euclidean distance if `order` is 2 (default), Minkowski distance algorithm of nth order if `order` is higher than 2\n * - multiplier - by how much to enhance difference analysis in range of 1..100\n * default is 20 which normalizes results to similarity above 0.5 can be considered a match\n * - min - normalize similarity result to a given range\n * - max - normalzie similarity resutl to a given range\n * default is 0.2...0.8\n * Returns similarity between two face descriptors normalized to 0..1 range where 0 is no similarity and 1 is perfect similarity\n */\nexport function similarity(descriptor1: Descriptor, descriptor2: Descriptor, options: MatchOptions = { order: 2, multiplier: 25, min: 0.2, max: 0.8 }) {\n const dist = distance(descriptor1, descriptor2, options);\n return normalizeDistance(dist, options.order || 2, options.min || 0, options.max || 1);\n}\n\n/** Matches given descriptor to a closest entry in array of descriptors\n * @param descriptor - face descriptor\n * @param descriptors - array of face descriptors to commpare given descriptor to\n * @param options - see `similarity` method for options description\n * Returns\n * - `index` index array index where best match was found or -1 if no matches\n * - `distance` calculated `distance` of given descriptor to the best match\n * - `similarity` calculated normalized `similarity` of given descriptor to the best match\n*/\nexport function match(descriptor: Descriptor, descriptors: Array, options: MatchOptions = { order: 2, multiplier: 25, threshold: 0, min: 0.2, max: 0.8 }) {\n if (!Array.isArray(descriptor) || !Array.isArray(descriptors) || descriptor.length < 64 || descriptors.length === 0 || descriptor.length !== descriptors[0].length) { // validate input\n return { index: -1, distance: Number.POSITIVE_INFINITY, similarity: 0 };\n }\n let lowestDistance = Number.MAX_SAFE_INTEGER;\n let index = -1;\n for (let i = 0; i < descriptors.length; i++) {\n const res = distance(descriptor, descriptors[i], options);\n if (res < lowestDistance) {\n lowestDistance = res;\n index = i;\n }\n if (lowestDistance < (options.threshold || 0)) break;\n }\n const normalizedSimilarity = normalizeDistance(lowestDistance, options.order || 2, options.min || 0, options.max || 1);\n return { index, distance: lowestDistance, similarity: normalizedSimilarity };\n}\n", "/**\n * Analyze detection Results and sort&combine them into per-person view\n */\n\nimport type { FaceResult, BodyResult, HandResult, GestureResult, PersonResult, Box } from '../result';\n\nexport function join(faces: Array, bodies: Array, hands: Array, gestures: Array, shape: Array | undefined): Array {\n let id = 0;\n const persons: Array = [];\n for (const face of faces) { // person is defined primarily by face and then we append other objects as found\n const person: PersonResult = { id: id++, face, body: null, hands: { left: null, right: null }, gestures: [], box: [0, 0, 0, 0] };\n for (const body of bodies) {\n if (face.box[0] > body.box[0] // x within body\n && face.box[0] < body.box[0] + body.box[2]\n && face.box[1] + face.box[3] > body.box[1] // y within body\n && face.box[1] + face.box[3] < body.box[1] + body.box[3]) {\n person.body = body;\n }\n }\n if (person.body) { // only try to join hands if body is found\n for (const hand of hands) {\n if (hand.box[0] + hand.box[2] > person.body.box[0] // x within body for left hand\n && hand.box[0] + hand.box[2] < person.body.box[0] + person.body.box[2]\n && hand.box[1] + hand.box[3] > person.body.box[1] // x within body for left hand\n && hand.box[1] + hand.box[3] < person.body.box[1] + person.body.box[3]) {\n if (person.hands) person.hands.left = hand;\n }\n if (hand.box[0] < person.body.box[0] + person.body.box[2] // x within body for right hand\n && hand.box[0] > person.body.box[0]\n && hand.box[1] + hand.box[3] > person.body.box[1] // x within body for right hand\n && hand.box[1] + hand.box[3] < person.body.box[1] + person.body.box[3]) {\n if (person.hands) person.hands.right = hand;\n }\n }\n }\n for (const gesture of gestures) { // append all gestures according to ids\n if (gesture['face'] !== undefined && gesture['face'] === face.id) person.gestures?.push(gesture);\n else if (gesture['iris'] !== undefined && gesture['iris'] === face.id) person.gestures?.push(gesture);\n else if (gesture['body'] !== undefined && gesture['body'] === person.body?.id) person.gestures?.push(gesture);\n else if (gesture['hand'] !== undefined && gesture['hand'] === person.hands?.left?.id) person.gestures?.push(gesture);\n else if (gesture['hand'] !== undefined && gesture['hand'] === person.hands?.right?.id) person.gestures?.push(gesture);\n }\n\n // create new overarching box from all boxes belonging to person\n const x: number[] = [];\n const y: number[] = [];\n const extractXY = (box: Box | undefined) => { // extract all [x, y] coordinates from boxes [x, y, width, height]\n if (box && box.length === 4) {\n x.push(box[0], box[0] + box[2]);\n y.push(box[1], box[1] + box[3]);\n }\n };\n extractXY(person.face?.box);\n extractXY(person.body?.box);\n extractXY(person.hands?.left?.box);\n extractXY(person.hands?.right?.box);\n const minX = Math.min(...x);\n const minY = Math.min(...y);\n person.box = [minX, minY, Math.max(...x) - minX, Math.max(...y) - minY]; // create new overarching box\n\n // shape is known so we calculate boxRaw as well\n if (shape && shape[1] && shape[2]) person.boxRaw = [person.box[0] / shape[2], person.box[1] / shape[1], person.box[2] / shape[2], person.box[3] / shape[1]];\n\n persons.push(person);\n }\n return persons;\n}\n", "/**\n * Embedded sample images used during warmup in dataURL format\n */\n\n// data:image/jpeg;base64,\nexport const face = `\n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`;\n\n// data:image/jpeg;base64,\nexport const body = `\n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\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAa2p1UYo5adbz+xbxMlvqJ1OqjDHLXree0ejmzNrWm953tPmTPWbWneZ7yoy5YhjrXXTjH8s75N\nmtkyxt0VZM2/m175N1V03yTKubMLXVXybeYLLX2VXy7eam+b0bOg4VquJW+rry4/O9uyZOq3UjVm\n9r25axMzPaIdvhns1kzbZddM0p5Y47z8/R2+HcF03Doi1a8+Xzvbv+TotJnjDXkt+K8ODHp8cY8N\nIpSO0RCwF2YAAAAAAAAACvUZYw6fJkntWN3k8dfHz2vLucdz8mkjFE9bz1+UOZosX1UzPm0nqI/W\nMYo9FlcPNklfFGeH/NshLGun+Cz6PtHZtVZWlRLS+jxPkRpIn7rdoupHTdA5s6SI+7H6Mfo+32Y2\n+To3neSIiZ7A0IjPXpXLePlMotGW3272t85datKzHZjbTVnsDj+FG/2Y/RlGP4R+jo20u7H6N1Ql\no+H8I/REY957R+jpfReiK6eOYHLtj2tttH6KrY/6Y/R2c+kjeJiFVtLG24hxpw7/AHY/RRkw9O37\nO99Hrt1YX0tfOBLjcGp4XF8c+u8fs9c4dcVcGemSI61nd3IneN1orQAAAAAAAAAAAAABFqxes1tE\nTE9JiUgPKcX4RbRXnNgiZwWnrH4XPi28PdXpW9JraImsxtMS8pxXhF9DecuGJtgmf+1TWW2N/la1\nL7N7T5e3Vy6W3hsYcvLbqzbO9jvvCzvDR0+XeO7crO6FmGSvRThy/RtVXJ92elvk2rRvDUzU7pl4\nizsd2J3jeBpcNz+Lg5LT7+Pp+Xk3W7js5eAAgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADs0NTrN96Yp6edkW8Wzm6+LNTq4pvTHO9vOfRoWtt\n1mes95YWvs1s2fZldddOczLPLn2ju0MmebT3YZc2/mpm3qqllN1drsbZIhr3yzvtHf4AsvlYYseb\nV5Yx4KTe0+UQ6nDvZ3UazbJqd8OKeu33peq0eh0+hxcmnxxWPOfOfm0mP+steT/ji8N9mKY9suum\nL37+HHaPm9DSlaVitKxWsdohI0Y22gAgAAAAAAAAAABXnyRhw3yT92Nwef4xm8bVzET0rPJH5d12\n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\nAOZE/OsPS29nuH27YrV+VpeV9pdPXhOtw49NG9Mld55+vXcTPd42I47qo7xSfyWV9oM8d8VJ/VxM\nd8l46xWF9cV7en6o/qLfxp2I9ob+eCv/AHMo9op89P8A/wBORGmyT5R+qfo2X8P7n9Q/jTsx7RR5\n6ef+4/8AuHftg/8A6cWcOSO9J/WEbWr3pY7Efzp2Lcfv5YK/9zWy8d1E/ZpSv5Oba1/+Hb9lc+LP\nbFt87I7E/wAabWbiurvEx4nL/pjZzc2bJkn372t85ZXx55/BX85lucC0vPxnTxlnnjm32mOiZqUu\nLJ2p4TwnVavNWaYbRTfre0bQ99pcH0bT0xb78vmtiIiNojaErMwAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAHnfarF7umzRHaZrLjYrdIen9ocPi8JyTt1xzF4eUw23rCm3R4r6bMy\nwt6kdTaWLdjswmNoZontsCm0K5XWjopnuDC0dGpqG5bs08/daKV672MjbSaif6oh6Z5f2LtvptRX\n0tEvUN3Jfo8f7cYve0eX4zV7B5z20xc/C8eSPuZIRficfXlcPaG7ino08HWIbePpLF2NuiyOyrHK\n3fZFSwuovHVfaVF4QK5YWTM9UT0EKry6Ps1Tn4zjn8NZn9nOtLseydObiWW34cf918fWfk+PYANn\nKAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAq1WKM+ly4p+/WYeBxTNd6zG0xO0\nvobw3FcP0bi2em20Tbmj5Srr418V9sa2Z7qKyzi07MXUylhaU7yjqhLCeiq3ddaFNxFYW7NLNG8t\nzya+WO6Va9J7FW66mvwidnrXiPY3Ny8RyUn71Jj9Ht3RPjk19HK9pMHj8D1ER3rHN+jqqtTjjNps\nuOe16zAifXzfTz7kNyndpYazS9qT0mszDdoxrsi6m8LazMq6zDOsq1ZEyrt1WWlXaUCqyq0rbKbi\nFdp6PReyFd8uqv8ACsfy83aXrPZHHto89/xX2/SP/dpj6y8vx6EBq5gAAAAAAAAAAAAAAAAAAAAA\n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\nNO67NbkhzNVnmInqzaOZrL93JyZeV0M1++7S02jvxDWxhxx033tPpC8Z6rrezWjmZyazJG2/u03h\n2vFibTHoqvamiwVwY+nLGzV0+SZ1Mx8G0/45tOhzJ5lXMc3UVXRdlF1HP+iYsDPLPPy49/tz1+Te\npSIr0ho6ak5Ms5J8o2q6NImOrHV7XX488ypzTtHXo0s9t6zG7c1G1qz6ubeZiZ3UatXJG3yauSO7\ncvMTEx5tPLb3prPRMVr0HB8vicNxf0+7+kt+LOJwTJyY/Bnz3tH93X36N58cWvq6LSyiyndMSlC7\nmZcymLJiwLosmJVRLKLAtiU7q4lMSCzc3YxJuDMRuAlKAEgAAAlAkAAAAAABKAEgAAAAAJAAAAAA\nAAAAAAAEgAAAAAAAAAAAAAkAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAhIAAACAAAASgAAAAAAEAAAA\nhGzJAImGMwzQDDZjNVuyNgUTVhNGxysZqDVmiu1G5NN2M4waM0+DCaN2cbGcQNGaMZq3JxMJxA1J\nqx2bU4kU09slorWNwa20z02RXHbJbl26QvtFovbHWkxEdJt5y2MOHlr2U1W3jx+1hiw8vSO63lmI\nXRTaEWmtY6snRHO1VpmJ+DjavpSZl2s8b7y4HFcnh0n0gha5ebJN55KRM2mdoiPN6fh+kpwXh0Wy\nRHj5Otp/s5Ps1p62y31+em9aTMYt/OfVfxTiPjZ52naI7fBrI5t66xz5+a1rW7yx0eSL6iZjtEOX\nqNbSletom3lENjh2fbHzbbWt3iVozruc+5ztWubf4M4ybpQ2Oboyrva0Vjza8WdDR4OkXt3n9ldX\nkaePP9VtYqctYhdvt5oivTeCZ2YOxXk6ubqMfV0b9mrljfqlFcq88k7z2U5axeItDa1OPessuC8P\nya7XRWYnwqdbT/ZMilvIu4dpslNdixXja8Y5tt85djZdbDWnGOesRtXFtuw6T27No5Kx2OrKYQlC\nExKJgBnEpiyvdlEgsizKLKollFgWxLKJVRLKJBbEp3VxLKJBnuMWQJEbpBIAAAJAAAABIAAAAAAA\nlAJAAAAAAAAAAAAAASAAAAAAAAAAAAAJAAAABAJABAlAAAAAAAAAAAAAAAAAAAAAAAAIAAAAAAAA\nAAABAJQAAAAgAABAAI2EoBGyJhkgGPKxmqxAKpownHC+YRMdN5BrTj67R3bOn01o7p01Iv71u89o\n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\n2Q==`;\n", "/**\n * Warmup algorithm that uses embedded images to exercise loaded models for faster future inference\n */\n\nimport { log, now, mergeDeep } from './util/util';\nimport * as sample from './sample';\nimport * as tf from '../dist/tfjs.esm.js';\nimport * as image from './image/image';\nimport { env } from './util/env';\nimport type { Config } from './config';\nimport type { Result } from './result';\nimport type { Human, Models } from './human';\nimport type { Tensor } from './tfjs/types';\n\nasync function warmupBitmap(instance: Human): Promise {\n const b64toBlob = (base64: string, type = 'application/octet-stream') => fetch(`data:${type};base64,${base64}`).then((res) => res.blob());\n let blob;\n let res;\n switch (instance.config.warmup) {\n case 'face': blob = await b64toBlob(sample.face); break;\n case 'body':\n case 'full': blob = await b64toBlob(sample.body); break;\n default: blob = null;\n }\n if (blob) {\n const bitmap = await createImageBitmap(blob);\n res = await instance.detect(bitmap, instance.config);\n bitmap.close();\n }\n return res;\n}\n\nasync function warmupCanvas(instance: Human): Promise {\n return new Promise((resolve) => {\n let src;\n // let size = 0;\n switch (instance.config.warmup) {\n case 'face':\n // size = 256;\n src = 'data:image/jpeg;base64,' + sample.face;\n break;\n case 'full':\n case 'body':\n // size = 1200;\n src = 'data:image/jpeg;base64,' + sample.body;\n break;\n default:\n src = null;\n }\n // src = encodeURI('../assets/human-sample-upper.jpg');\n let img: HTMLImageElement;\n if (typeof Image !== 'undefined') img = new Image();\n // @ts-ignore env.image is an external monkey-patch\n else if (env.Image) img = new env.Image();\n else return;\n img.onload = async () => {\n const canvas = image.canvas(img.naturalWidth, img.naturalHeight);\n if (!canvas) {\n log('Warmup: Canvas not found');\n resolve(undefined);\n } else {\n const ctx = canvas.getContext('2d');\n if (ctx) ctx.drawImage(img, 0, 0);\n // const data = ctx?.getImageData(0, 0, canvas.height, canvas.width);\n const tensor = await instance.image(canvas);\n const res = await instance.detect(tensor.tensor as Tensor, instance.config);\n resolve(res);\n }\n };\n if (src) img.src = src;\n else resolve(undefined);\n });\n}\n\nasync function warmupNode(instance: Human): Promise {\n const atob = (str: string) => Buffer.from(str, 'base64');\n let img;\n if (instance.config.warmup === 'face') img = atob(sample.face);\n else img = atob(sample.body);\n let res;\n if ('node' in tf) {\n // @ts-ignore tf.node may be undefined\n const data = tf['node'].decodeJpeg(img);\n const expanded = data.expandDims(0);\n instance.tf.dispose(data);\n // log('Input:', expanded);\n res = await instance.detect(expanded, instance.config);\n instance.tf.dispose(expanded);\n } else {\n if (instance.config.debug) log('Warmup tfjs-node not loaded');\n /*\n const input = await canvasJS.loadImage(img);\n const canvas = canvasJS.createCanvas(input.width, input.height);\n const ctx = canvas.getContext('2d');\n ctx.drawImage(img, 0, 0, input.width, input.height);\n res = await instance.detect(input, instance.config);\n */\n }\n return res;\n}\n\nasync function runInference(instance: Human) {\n let res: Result | undefined;\n if (typeof createImageBitmap === 'function') res = await warmupBitmap(instance);\n else if (typeof Image !== 'undefined' || env.Canvas !== undefined) res = await warmupCanvas(instance);\n else res = await warmupNode(instance);\n return res;\n}\n\n/** Runs pre-compile on all loaded models */\nexport async function runCompile(allModels: Models) {\n const backendType = tf.getBackend();\n const webGLBackend = tf.backend();\n if ((backendType !== 'webgl' && backendType !== 'humangl') || (!webGLBackend || !webGLBackend.checkCompileCompletion)) {\n // log('compile pass: skip');\n return;\n }\n tf.env().set('ENGINE_COMPILE_ONLY', true);\n const numTensorsStart = tf.engine().state.numTensors;\n const compiledModels: string[] = [];\n for (const [modelName, model] of Object.entries(allModels).filter(([key, val]) => (key !== null && val !== null))) {\n const shape = (model.inputs && model.inputs[0] && model.inputs[0].shape) ? [...model.inputs[0].shape] : [1, 64, 64, 3];\n const dtype = (model.inputs && model.inputs[0] && model.inputs[0].dtype) ? model.inputs[0].dtype : 'float32';\n for (let dim = 0; dim < shape.length; dim++) {\n if (shape[dim] === -1) shape[dim] = dim === 0 ? 1 : 64; // override batch number and any dynamic dimensions\n }\n const tensor = tf.zeros(shape, dtype);\n // const res = await model.executeAsync(tensor); // fails with current tfjs\n try {\n const res = model.execute(tensor);\n compiledModels.push(modelName);\n if (Array.isArray(res)) res.forEach((t) => tf.dispose(t));\n else tf.dispose(res);\n } catch {\n log('compile fail model:', modelName);\n }\n tf.dispose(tensor);\n }\n const kernels = await webGLBackend.checkCompileCompletionAsync();\n webGLBackend.getUniformLocations();\n log('compile pass models:', compiledModels);\n log('compile pass kernels:', kernels.length);\n tf.env().set('ENGINE_COMPILE_ONLY', false);\n const numTensorsEnd = tf.engine().state.numTensors;\n if ((numTensorsEnd - numTensorsStart) > 0) log('tensor leak:', numTensorsEnd - numTensorsStart);\n}\n\n/** Warmup method pre-initializes all configured models for faster inference\n * - can take significant time on startup\n * - only used in browser environments for `webgl` and `humangl` backends\n * @param userConfig?: Config\n*/\nexport async function warmup(instance: Human, userConfig?: Partial): Promise {\n const t0 = now();\n instance.state = 'warmup';\n if (userConfig) instance.config = mergeDeep(instance.config, userConfig) as Config;\n if (!instance.config.warmup || instance.config.warmup.length === 0 || instance.config.warmup === 'none') {\n return { face: [], body: [], hand: [], gesture: [], object: [], performance: instance.performance, timestamp: now(), persons: [], error: null };\n }\n return new Promise(async (resolve) => {\n await runCompile(instance.models);\n const res = await runInference(instance);\n const t1 = now();\n if (instance.config.debug) log('warmup', instance.config.warmup, Math.round(t1 - t0), 'ms');\n instance.emit('warmup');\n resolve(res);\n });\n}\n", "/**\n * Human main module\n * @default Human Library\n * @summary \n * @author \n * @copyright \n * @license MIT\n */\n\n// module imports\nimport { log, now, mergeDeep, validate } from './util/util';\nimport { defaults } from './config';\nimport { env, Env } from './util/env';\nimport { setModelLoadOptions } from './tfjs/load';\nimport * as tf from '../dist/tfjs.esm.js';\nimport * as app from '../package.json';\nimport * as backend from './tfjs/backend';\nimport * as blazepose from './body/blazepose';\nimport * as centernet from './object/centernet';\nimport * as draw from './draw/draw';\nimport * as efficientpose from './body/efficientpose';\nimport * as face from './face/face';\nimport * as facemesh from './face/facemesh';\nimport * as faceres from './face/faceres';\nimport * as gesture from './gesture/gesture';\nimport * as handpose from './hand/handpose';\nimport * as handtrack from './hand/handtrack';\nimport * as humangl from './tfjs/humangl';\nimport * as image from './image/image';\nimport * as interpolate from './util/interpolate';\nimport * as match from './face/match';\nimport * as models from './models';\nimport * as movenet from './body/movenet';\nimport * as nanodet from './object/nanodet';\nimport * as persons from './util/persons';\nimport * as posenet from './body/posenet';\nimport * as segmentation from './segmentation/segmentation';\nimport * as warmups from './warmup';\n// type definitions\nimport type { Input, Tensor, DrawOptions, Config, Result, FaceResult, HandResult, BodyResult, ObjectResult, GestureResult, PersonResult, AnyCanvas } from './exports';\n// type exports\nexport * from './exports';\n\n/** **Human** library main class\n *\n * All methods and properties are available only as members of Human class\n *\n * - Configuration object definition: {@link Config}\n * - Results object definition: {@link Result}\n * - Possible inputs: {@link Input}\n *\n * @param userConfig - {@link Config}\n * @returns instance of {@link Human}\n */\nexport class Human {\n /** Current version of Human library in *semver* format */\n version: string;\n\n /** Current configuration\n * - Defaults: [config](https://github.com/vladmandic/human/blob/main/src/config.ts#L262)\n */\n config: Config;\n\n /** Last known result of detect run\n * - Can be accessed anytime after initial detection\n */\n result: Result;\n\n /** Current state of Human library\n * - Can be polled to determine operations that are currently executed\n * - Progresses through: 'config', 'check', 'backend', 'load', 'run:', 'idle'\n */\n state: string;\n\n /** currenty processed image tensor and canvas */\n process: { tensor: Tensor | null, canvas: AnyCanvas | null };\n\n /** Instance of TensorFlow/JS used by Human\n * - Can be embedded or externally provided\n * [TFJS API]: {@link https://js.tensorflow.org/api/latest/}\n */\n tf;\n\n /** Object containing environment information used for diagnostics */\n env: Env;\n\n /** Draw helper classes that can draw detected objects on canvas using specified draw\n * - canvas: draws input to canvas\n * - options: are global settings for all draw operations, can be overriden for each draw method {@link DrawOptions}\n * - face, body, hand, gesture, object, person: draws detected results as overlays on canvas\n */\n draw: { canvas: typeof draw.canvas, face: typeof draw.face, body: typeof draw.body, hand: typeof draw.hand, gesture: typeof draw.gesture, object: typeof draw.object, person: typeof draw.person, all: typeof draw.all, options: DrawOptions };\n\n /** Currently loaded models\n * @internal\n * {@link Models}\n */\n models: models.Models;\n\n /** Container for events dispatched by Human\n * Possible events:\n * - `create`: triggered when Human object is instantiated\n * - `load`: triggered when models are loaded (explicitly or on-demand)\n * - `image`: triggered when input image is processed\n * - `result`: triggered when detection is complete\n * - `warmup`: triggered when warmup is complete\n * - `error`: triggered on some errors\n */\n events: EventTarget | undefined;\n /** Reference face triangualtion array of 468 points, used for triangle references between points */\n faceTriangulation: number[];\n /** Refernce UV map of 468 values, used for 3D mapping of the face mesh */\n faceUVMap: [number, number][];\n /** Performance object that contains values for all recently performed operations */\n performance: Record; // perf members are dynamically defined as needed\n #numTensors: number;\n #analyzeMemoryLeaks: boolean;\n #checkSanity: boolean;\n /** WebGL debug info */\n gl: Record;\n // definition end\n\n /** Constructor for **Human** library that is futher used for all operations\n * @param userConfig - user configuration object {@link Config}\n */\n constructor(userConfig?: Partial) {\n this.env = env;\n defaults.wasmPath = tf.version['tfjs-core'].includes('-') // custom build or official build\n ? 'https://vladmandic.github.io/tfjs/dist/'\n : `https://cdn.jsdelivr.net/npm/@tensorflow/tfjs-backend-wasm@${tf.version_core}/dist/`;\n defaults.modelBasePath = env.browser ? '../models/' : 'file://models/';\n defaults.backend = env.browser ? 'humangl' : 'tensorflow';\n this.version = app.version; // expose version property on instance of class\n Object.defineProperty(this, 'version', { value: app.version }); // expose version property directly on class itself\n this.config = JSON.parse(JSON.stringify(defaults));\n Object.seal(this.config);\n this.config.cacheModels = typeof indexedDB !== 'undefined';\n if (userConfig) this.config = mergeDeep(this.config, userConfig);\n setModelLoadOptions(this.config);\n this.tf = tf;\n this.state = 'idle';\n this.#numTensors = 0;\n this.#analyzeMemoryLeaks = false;\n this.#checkSanity = false;\n this.performance = {};\n this.events = (typeof EventTarget !== 'undefined') ? new EventTarget() : undefined;\n // object that contains all initialized models\n this.models = new models.Models();\n // reexport draw methods\n this.draw = {\n options: draw.options as DrawOptions,\n canvas: (input: AnyCanvas | HTMLImageElement | HTMLVideoElement, output: AnyCanvas) => draw.canvas(input, output),\n face: (output: AnyCanvas, result: FaceResult[], options?: Partial) => draw.face(output, result, options),\n body: (output: AnyCanvas, result: BodyResult[], options?: Partial) => draw.body(output, result, options),\n hand: (output: AnyCanvas, result: HandResult[], options?: Partial) => draw.hand(output, result, options),\n gesture: (output: AnyCanvas, result: GestureResult[], options?: Partial) => draw.gesture(output, result, options),\n object: (output: AnyCanvas, result: ObjectResult[], options?: Partial) => draw.object(output, result, options),\n person: (output: AnyCanvas, result: PersonResult[], options?: Partial) => draw.person(output, result, options),\n all: (output: AnyCanvas, result: Result, options?: Partial) => draw.all(output, result, options),\n };\n this.result = { face: [], body: [], hand: [], gesture: [], object: [], performance: {}, timestamp: 0, persons: [], error: null };\n // export access to image processing\n // @ts-ignore eslint-typescript cannot correctly infer type in anonymous function\n this.process = { tensor: null, canvas: null };\n // export raw access to underlying models\n this.faceTriangulation = facemesh.triangulation;\n this.faceUVMap = facemesh.uvmap;\n // set gl info\n this.gl = humangl.config;\n // include platform info\n this.emit('create');\n }\n\n /** internal function to measure tensor leaks */\n analyze = (...msg: string[]) => {\n if (!this.#analyzeMemoryLeaks) return;\n const currentTensors = this.tf.engine().state.numTensors;\n const previousTensors = this.#numTensors;\n this.#numTensors = currentTensors;\n const leaked = currentTensors - previousTensors;\n if (leaked !== 0) log(...msg, leaked);\n };\n\n /** internal function for quick sanity check on inputs @hidden */\n #sanity = (input: Input): null | string => {\n if (!this.#checkSanity) return null;\n if (!input) return 'input is not defined';\n if (this.env.node && !(input instanceof tf.Tensor)) return 'input must be a tensor';\n try {\n this.tf.getBackend();\n } catch {\n return 'backend not loaded';\n }\n return null;\n };\n\n /** Reset configuration to default values */\n reset(): void {\n const currentBackend = this.config.backend; // save backend;\n this.config = JSON.parse(JSON.stringify(defaults));\n this.config.backend = currentBackend;\n }\n\n /** Validate current configuration schema */\n validate(userConfig?: Partial) {\n return validate(defaults, userConfig || this.config);\n }\n\n /** Exports face matching methods {@link match#similarity} */\n public similarity = match.similarity;\n /** Exports face matching methods {@link match#distance} */\n public distance = match.distance;\n /** Exports face matching methods {@link match#match} */\n public match = match.match;\n\n /** Utility wrapper for performance.now() */\n now(): number {\n return now();\n }\n\n /** Process input as return canvas and tensor\n *\n * @param input - any input {@link Input}\n * @param getTensor - should image processing also return tensor or just canvas\n * Returns object with `tensor` and `canvas`\n */\n image(input: Input, getTensor: boolean = true) {\n return image.process(input, this.config, getTensor);\n }\n\n /** Segmentation method takes any input and returns processed canvas with body segmentation\n * - Segmentation is not triggered as part of detect process\n * @param input - {@link Input}\n * @param background - {@link Input}\n * - Optional parameter background is used to fill the background with specific input\n * Returns:\n * - `data` as raw data array with per-pixel segmentation values\n * - `canvas` as canvas which is input image filtered with segementation data and optionally merged with background image. canvas alpha values are set to segmentation values for easy merging\n * - `alpha` as grayscale canvas that represents segmentation alpha values\n */\n async segmentation(input: Input, background?: Input): Promise<{ data: number[] | Tensor, canvas: AnyCanvas | null, alpha: AnyCanvas | null }> {\n return segmentation.process(input, background, this.config);\n }\n\n /** Enhance method performs additional enhacements to face image previously detected for futher processing\n *\n * @param input - Tensor as provided in human.result.face[n].tensor\n * @returns Tensor\n */\n // eslint-disable-next-line class-methods-use-this\n enhance(input: Tensor): Tensor | null {\n return faceres.enhance(input);\n }\n\n /** Compare two input tensors for pixel simmilarity\n * - use `human.image` to process any valid input and get a tensor that can be used for compare\n * - when passing manually generated tensors:\n * - both input tensors must be in format [1, height, width, 3]\n * - if resolution of tensors does not match, second tensor will be resized to match resolution of the first tensor\n * - return value is pixel similarity score normalized by input resolution and rgb channels\n */\n compare(firstImageTensor: Tensor, secondImageTensor: Tensor): Promise {\n return image.compare(this.config, firstImageTensor, secondImageTensor);\n }\n\n /** Explicit backend initialization\n * - Normally done implicitly during initial load phase\n * - Call to explictly register and initialize TFJS backend without any other operations\n * - Use when changing backend during runtime\n */\n async init(): Promise {\n await backend.check(this, true);\n await this.tf.ready();\n }\n\n /** Load method preloads all configured models on-demand\n * - Not explicitly required as any required model is load implicitly on it's first run\n *\n * @param userConfig - {@link Config}\n */\n async load(userConfig?: Partial): Promise {\n this.state = 'load';\n const timeStamp = now();\n const count = Object.values(this.models).filter((model) => model).length;\n if (userConfig) this.config = mergeDeep(this.config, userConfig) as Config;\n\n if (this.env.initial) { // print version info on first run and check for correct backend setup\n if (this.config.debug) log(`version: ${this.version}`);\n if (this.config.debug) log(`tfjs version: ${this.tf.version['tfjs-core']}`);\n if (!await backend.check(this)) log('error: backend check failed');\n await tf.ready();\n if (this.env.browser) {\n if (this.config.debug) log('configuration:', this.config);\n if (this.config.debug) log('environment:', this.env);\n if (this.config.debug) log('tf flags:', this.tf.ENV['flags']);\n }\n }\n\n await models.load(this); // actually loads models\n if (this.env.initial && this.config.debug) log('tf engine state:', this.tf.engine().state.numBytes, 'bytes', this.tf.engine().state.numTensors, 'tensors'); // print memory stats on first run\n this.env.initial = false;\n\n const loaded = Object.values(this.models).filter((model) => model).length;\n if (loaded !== count) { // number of loaded models changed\n await models.validate(this); // validate kernel ops used by model against current backend\n this.emit('load');\n }\n\n const current = Math.trunc(now() - timeStamp);\n if (current > (this.performance.loadModels as number || 0)) this.performance.loadModels = this.env.perfadd ? (this.performance.loadModels || 0) + current : current;\n }\n\n /** emit event */\n emit = (event: string) => {\n if (this.events && this.events.dispatchEvent) this.events?.dispatchEvent(new Event(event));\n };\n\n /** Runs interpolation using last known result and returns smoothened result\n * Interpolation is based on time since last known result so can be called independently\n *\n * @param result - {@link Result} optional use specific result set to run interpolation on\n * @returns result - {@link Result}\n */\n next(result: Result = this.result): Result {\n return interpolate.calc(result, this.config) as Result;\n }\n\n /** Warmup method pre-initializes all configured models for faster inference\n * - can take significant time on startup\n * - only used for `webgl` and `humangl` backends\n * @param userConfig - {@link Config}\n * @returns result - {@link Result}\n */\n async warmup(userConfig?: Partial) {\n const t0 = now();\n const res = await warmups.warmup(this, userConfig);\n const t1 = now();\n this.performance.warmup = Math.trunc(t1 - t0);\n return res;\n }\n\n /** Run detect with tensorflow profiling\n * - result object will contain total exeuction time information for top-20 kernels\n * - actual detection object can be accessed via `human.result`\n */\n async profile(input: Input, userConfig?: Partial): Promise> {\n const profile = await this.tf.profile(() => this.detect(input, userConfig));\n const kernels: Record = {};\n for (const kernel of profile.kernels) { // sum kernel time values per kernel\n if (kernels[kernel.name]) kernels[kernel.name] += kernel.kernelTimeMs;\n else kernels[kernel.name] = kernel.kernelTimeMs;\n }\n const kernelArr: Array<{ name: string, ms: number }> = [];\n Object.entries(kernels).forEach((key) => kernelArr.push({ name: key[0], ms: key[1] as unknown as number })); // convert to array\n kernelArr.sort((a, b) => b.ms - a.ms); // sort\n kernelArr.length = 20; // crop\n const res: Record = {};\n for (const kernel of kernelArr) res[kernel.name] = kernel.ms; // create perf objects\n return res;\n }\n\n /** Main detection method\n * - Analyze configuration: {@link Config}\n * - Pre-process input: {@link Input}\n * - Run inference for all configured models\n * - Process and return result: {@link Result}\n *\n * @param input - {@link Input}\n * @param userConfig - {@link Config}\n * @returns result - {@link Result}\n */\n async detect(input: Input, userConfig?: Partial): Promise {\n // detection happens inside a promise\n this.state = 'detect';\n return new Promise(async (resolve) => {\n this.state = 'config';\n let timeStamp;\n\n // update configuration\n this.config = mergeDeep(this.config, userConfig) as Config;\n\n // sanity checks\n this.state = 'check';\n const error = this.#sanity(input);\n if (error) {\n log(error, input);\n this.emit('error');\n resolve({ face: [], body: [], hand: [], gesture: [], object: [], performance: this.performance, timestamp: now(), persons: [], error });\n }\n\n const timeStart = now();\n\n // configure backend if needed\n await backend.check(this);\n\n // load models if enabled\n await this.load();\n\n timeStamp = now();\n this.state = 'image';\n const img = await image.process(input, this.config) as { canvas: AnyCanvas, tensor: Tensor };\n this.process = img;\n this.performance.inputProcess = this.env.perfadd ? (this.performance.inputProcess || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n this.analyze('Get Image:');\n\n if (!img.tensor) {\n if (this.config.debug) log('could not convert input to tensor');\n this.emit('error');\n resolve({ face: [], body: [], hand: [], gesture: [], object: [], performance: this.performance, timestamp: now(), persons: [], error: 'could not convert input to tensor' });\n return;\n }\n this.emit('image');\n\n timeStamp = now();\n this.config.skipAllowed = await image.skip(this.config, img.tensor);\n if (!this.performance.totalFrames) this.performance.totalFrames = 0;\n if (!this.performance.cachedFrames) this.performance.cachedFrames = 0;\n (this.performance.totalFrames as number)++;\n if (this.config.skipAllowed) this.performance.cachedFrames++;\n this.performance.cacheCheck = this.env.perfadd ? (this.performance.cacheCheck || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n this.analyze('Check Changed:');\n\n // prepare where to store model results\n // keep them with weak typing as it can be promise or not\n let faceRes: FaceResult[] | Promise | never[] = [];\n let bodyRes: BodyResult[] | Promise | never[] = [];\n let handRes: HandResult[] | Promise | never[] = [];\n let objectRes: ObjectResult[] | Promise | never[] = [];\n\n // run face detection followed by all models that rely on face bounding box: face mesh, age, gender, emotion\n this.state = 'detect:face';\n if (this.config.async) {\n faceRes = this.config.face.enabled ? face.detectFace(this, img.tensor) : [];\n if (this.performance.face) delete this.performance.face;\n } else {\n timeStamp = now();\n faceRes = this.config.face.enabled ? await face.detectFace(this, img.tensor) : [];\n this.performance.face = this.env.perfadd ? (this.performance.face || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n }\n\n if (this.config.async && (this.config.body.maxDetected === -1 || this.config.hand.maxDetected === -1)) faceRes = await faceRes; // need face result for auto-detect number of hands or bodies\n\n // run body: can be posenet, blazepose, efficientpose, movenet\n this.analyze('Start Body:');\n this.state = 'detect:body';\n const bodyConfig = this.config.body.maxDetected === -1 ? mergeDeep(this.config, { body: { maxDetected: this.config.face.enabled ? 1 * (faceRes as FaceResult[]).length : 1 } }) : this.config; // autodetect number of bodies\n if (this.config.async) {\n if (this.config.body.modelPath?.includes('posenet')) bodyRes = this.config.body.enabled ? posenet.predict(img.tensor, bodyConfig) : [];\n else if (this.config.body.modelPath?.includes('blazepose')) bodyRes = this.config.body.enabled ? blazepose.predict(img.tensor, bodyConfig) : [];\n else if (this.config.body.modelPath?.includes('efficientpose')) bodyRes = this.config.body.enabled ? efficientpose.predict(img.tensor, bodyConfig) : [];\n else if (this.config.body.modelPath?.includes('movenet')) bodyRes = this.config.body.enabled ? movenet.predict(img.tensor, bodyConfig) : [];\n if (this.performance.body) delete this.performance.body;\n } else {\n timeStamp = now();\n if (this.config.body.modelPath?.includes('posenet')) bodyRes = this.config.body.enabled ? await posenet.predict(img.tensor, bodyConfig) : [];\n else if (this.config.body.modelPath?.includes('blazepose')) bodyRes = this.config.body.enabled ? await blazepose.predict(img.tensor, bodyConfig) : [];\n else if (this.config.body.modelPath?.includes('efficientpose')) bodyRes = this.config.body.enabled ? await efficientpose.predict(img.tensor, bodyConfig) : [];\n else if (this.config.body.modelPath?.includes('movenet')) bodyRes = this.config.body.enabled ? await movenet.predict(img.tensor, bodyConfig) : [];\n this.performance.body = this.env.perfadd ? (this.performance.body || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n }\n this.analyze('End Body:');\n\n // run handpose\n this.analyze('Start Hand:');\n this.state = 'detect:hand';\n const handConfig = this.config.hand.maxDetected === -1 ? mergeDeep(this.config, { hand: { maxDetected: this.config.face.enabled ? 2 * (faceRes as FaceResult[]).length : 1 } }) : this.config; // autodetect number of hands\n if (this.config.async) {\n if (this.config.hand.detector?.modelPath?.includes('handdetect')) handRes = this.config.hand.enabled ? handpose.predict(img.tensor, handConfig) : [];\n else if (this.config.hand.detector?.modelPath?.includes('handtrack')) handRes = this.config.hand.enabled ? handtrack.predict(img.tensor, handConfig) : [];\n if (this.performance.hand) delete this.performance.hand;\n } else {\n timeStamp = now();\n if (this.config.hand.detector?.modelPath?.includes('handdetect')) handRes = this.config.hand.enabled ? await handpose.predict(img.tensor, handConfig) : [];\n else if (this.config.hand.detector?.modelPath?.includes('handtrack')) handRes = this.config.hand.enabled ? await handtrack.predict(img.tensor, handConfig) : [];\n this.performance.hand = this.env.perfadd ? (this.performance.hand || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n }\n this.analyze('End Hand:');\n\n // run object detection\n this.analyze('Start Object:');\n this.state = 'detect:object';\n if (this.config.async) {\n if (this.config.object.modelPath?.includes('nanodet')) objectRes = this.config.object.enabled ? nanodet.predict(img.tensor, this.config) : [];\n else if (this.config.object.modelPath?.includes('centernet')) objectRes = this.config.object.enabled ? centernet.predict(img.tensor, this.config) : [];\n if (this.performance.object) delete this.performance.object;\n } else {\n timeStamp = now();\n if (this.config.object.modelPath?.includes('nanodet')) objectRes = this.config.object.enabled ? await nanodet.predict(img.tensor, this.config) : [];\n else if (this.config.object.modelPath?.includes('centernet')) objectRes = this.config.object.enabled ? await centernet.predict(img.tensor, this.config) : [];\n this.performance.object = this.env.perfadd ? (this.performance.object || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n }\n this.analyze('End Object:');\n\n // if async wait for results\n this.state = 'detect:await';\n if (this.config.async) [faceRes, bodyRes, handRes, objectRes] = await Promise.all([faceRes, bodyRes, handRes, objectRes]);\n\n // run gesture analysis last\n this.state = 'detect:gesture';\n let gestureRes: GestureResult[] = [];\n if (this.config.gesture.enabled) {\n timeStamp = now();\n gestureRes = [...gesture.face(faceRes as FaceResult[]), ...gesture.body(bodyRes as BodyResult[]), ...gesture.hand(handRes as HandResult[]), ...gesture.iris(faceRes as FaceResult[])];\n if (!this.config.async) this.performance.gesture = this.env.perfadd ? (this.performance.gesture || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n else if (this.performance.gesture) delete this.performance.gesture;\n }\n\n this.performance.total = this.env.perfadd ? (this.performance.total || 0) + Math.trunc(now() - timeStart) : Math.trunc(now() - timeStart);\n const shape = this.process?.tensor?.shape || [];\n this.result = {\n face: faceRes as FaceResult[],\n body: bodyRes as BodyResult[],\n hand: handRes as HandResult[],\n gesture: gestureRes,\n object: objectRes as ObjectResult[],\n performance: this.performance,\n canvas: this.process.canvas,\n timestamp: Date.now(),\n error: null,\n get persons() { return persons.join(faceRes as FaceResult[], bodyRes as BodyResult[], handRes as HandResult[], gestureRes, shape); },\n };\n\n // finally dispose input tensor\n tf.dispose(img.tensor);\n\n // log('Result:', result);\n this.emit('detect');\n this.state = 'idle';\n resolve(this.result);\n });\n }\n}\n\n/** Class Human as default export */\n/* eslint no-restricted-exports: [\"off\", { \"restrictedNamedExports\": [\"default\"] }] */\nexport { Human as default, match, draw, models };\n"], - "mappings": "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iB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,eAAiB,gBAAiB,EACnC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,eAAiB,gBAAiB,EACnC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,eAAgB,EACnC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,eAAiB,gBAAiB,EACnC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,eAAiB,gBAAiB,EACnC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,g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rC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,cAAgB,gBAAiB,EAClC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,eAAiB,gBAAiB,EACnC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,CACvC,EAEa,GAAwB,CACnC,IAAK,GAAI,IAAK,GAAI,EAAG,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,EACtJ,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,GAAI,GAClJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,EAAG,IAAK,GAAI,GAAI,GAAI,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,GACrJ,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,EAAG,IAC7I,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAClJ,IAAK,IAAK,GAAI,GAAI,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,GAAI,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,GACrJ,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,GACpJ,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,GACjJ,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,EAAG,EAAG,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,EAAG,IAC/I,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,IAAK,EAAG,GAAI,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IACnJ,IAAK,GAAI,EAAG,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IACnJ,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,EAAG,IAAK,IAAK,GAAI,EAAG,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAC9I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,EAAG,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GACtJ,GAAI,GAAI,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,GAClJ,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,EAAG,EAAG,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GACnJ,IAAK,IAAK,IAAK,GAAI,GAAI,EAAG,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GACrJ,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IACpJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,EAAG,IAClJ,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,EAAG,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACnJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,GAAI,IAAK,IAAK,IAAK,IACnJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IACnJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAChJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,EAAG,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAChJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAC7I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAClJ,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAC7I,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,EAAG,IAAK,GAAI,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GACnJ,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,EAAG,GAAI,EAAG,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GACpJ,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,GAAI,IAAK,GAAI,IAAK,EAAG,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAClJ,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAClJ,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,GAAI,GAAI,EAAG,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAChJ,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IACpJ,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GACrJ,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,GAAI,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,GACpJ,IAAK,GAAI,IAAK,IAAK,EAAG,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,EAAG,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAC/I,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,EAAG,IAAK,GAAI,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAC9I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GACpJ,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GACrJ,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IACpJ,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,EAAG,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,EACpJ,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAC9I,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,EAAG,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,EAAG,GAAI,IAClJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAC9I,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAChJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAChJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAC9I,IAAK,GAAI,IAAK,EAAG,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAChJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAClJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,EAAG,IAAK,IAAK,IAAK,IAAK,IACpJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAA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OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EA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AAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;A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", + "sources": ["../src/util/util.ts", "../src/config.ts", "tfjs.esm.js", "../src/image/imagefxshaders.ts", "../src/image/imagefx.ts", "../src/image/enhance.ts", "../src/image/image.ts", "../src/util/env.ts", "../src/tfjs/load.ts", "../src/models.ts", "../src/gear/gear.ts", "../src/tfjs/constants.ts", "../src/gear/ssrnet-age.ts", "../src/gear/ssrnet-gender.ts", "../src/face/antispoof.ts", "../src/face/facemeshcoords.ts", "../src/face/facemeshutil.ts", "../src/face/blazeface.ts", "../src/body/blazeposecoords.ts", "../src/body/blazeposedetector.ts", "../src/util/box.ts", "../src/body/blazepose.ts", "../src/object/labels.ts", "../src/object/centernet.ts", "../src/body/efficientposecoords.ts", "../src/body/efficientpose.ts", "../src/gear/emotion.ts", "../src/face/mobilefacenet.ts", "../src/face/iris.ts", "../src/face/constants.ts", "../src/face/attention.ts", "../src/face/facemesh.ts", "../src/face/faceres.ts", "../src/hand/handposeutil.ts", "../src/hand/handposeanchors.ts", "../src/hand/handposedetector.ts", "../src/hand/handposepipeline.ts", "../src/hand/fingerdef.ts", "../src/hand/fingergesture.ts", "../src/hand/fingerpose.ts", "../src/hand/handpose.ts", "../src/hand/handtrack.ts", "../src/face/liveness.ts", "../src/body/movenetcoords.ts", "../src/body/movenetfix.ts", "../src/body/movenet.ts", "../src/object/nanodet.ts", "../src/body/posenetutils.ts", "../src/body/posenet.ts", "../src/segmentation/segmentation.ts", "../src/tfjs/humangl.ts", "../src/tfjs/backend.ts", "../src/draw/draw.ts", "../src/draw/primitives.ts", "../src/draw/options.ts", "../src/draw/face.ts", "../src/draw/body.ts", "../src/draw/hand.ts", "../src/draw/object.ts", "../src/draw/gesture.ts", "../src/face/mask.ts", "../src/face/angles.ts", "../src/face/face.ts", "../src/gesture/gesture.ts", "../src/util/interpolate.ts", "../src/face/match.ts", "../src/util/persons.ts", "../src/sample.ts", "../src/warmup.ts", "../src/human.ts"], + "sourcesContent": ["import type { Config } from '../exports';\n\n/**\n * Simple helper functions used accross codebase\n */\n\n// helper function: wrapper around console output\nexport function log(...msg): void {\n const dt = new Date();\n const ts = `${dt.getHours().toString().padStart(2, '0')}:${dt.getMinutes().toString().padStart(2, '0')}:${dt.getSeconds().toString().padStart(2, '0')}.${dt.getMilliseconds().toString().padStart(3, '0')}`;\n // eslint-disable-next-line no-console\n if (msg) console.log(ts, 'Human:', ...msg);\n}\n\n// helper function: join two paths\nexport function join(folder: string, file: string): string {\n const separator = folder.endsWith('/') ? '' : '/';\n const skipJoin = file.startsWith('.') || file.startsWith('/') || file.startsWith('http:') || file.startsWith('https:') || file.startsWith('file:');\n const path = skipJoin ? `${file}` : `${folder}${separator}${file}`;\n if (!path.toLocaleLowerCase().includes('.json')) throw new Error(`modelpath error: expecting json file: ${path}`);\n return path;\n}\n\n// helper function: gets elapsed time on both browser and nodejs\nexport const now = () => {\n if (typeof performance !== 'undefined') return performance.now();\n return parseInt((Number(process.hrtime.bigint()) / 1000 / 1000).toString());\n};\n\n// helper function: checks current config validity\nexport function validate(defaults: Partial, config: Partial, parent = 'config', msgs: Array<{ reason: string, where: string, expected?: string }> = []) {\n for (const key of Object.keys(config)) {\n if (typeof config[key] === 'object') {\n validate(defaults[key], config[key], key, msgs);\n } else {\n const defined = defaults && (typeof defaults[key] !== 'undefined');\n if (!defined) msgs.push({ reason: 'unknown property', where: `${parent}.${key} = ${config[key]}` });\n const same = defaults && typeof defaults[key] === typeof config[key];\n if (defined && !same) msgs.push({ reason: 'property type mismatch', where: `${parent}.${key} = ${config[key]}`, expected: typeof defaults[key] });\n }\n // ok = ok && defined && same;\n }\n if (config.debug && parent === 'config' && msgs.length > 0) log('invalid configuration', msgs);\n return msgs;\n}\n\n// helper function: perform deep merge of multiple objects so it allows full inheritance with overrides\nexport function mergeDeep(...objects) {\n const isObject = (obj) => obj && typeof obj === 'object';\n return objects.reduce((prev, obj) => {\n Object.keys(obj || {}).forEach((key) => {\n const pVal = prev[key];\n const oVal = obj[key];\n if (Array.isArray(pVal) && Array.isArray(oVal)) prev[key] = pVal.concat(...oVal);\n else if (isObject(pVal) && isObject(oVal)) prev[key] = mergeDeep(pVal, oVal);\n else prev[key] = oVal;\n });\n return prev;\n }, {});\n}\n\n// helper function: return min and max from input array\nexport const minmax = (data: Array) => data.reduce((acc: Array, val) => {\n acc[0] = (acc[0] === undefined || val < acc[0]) ? val : acc[0];\n acc[1] = (acc[1] === undefined || val > acc[1]) ? val : acc[1];\n return acc;\n}, []);\n\n// helper function: async wait\nexport async function wait(time: number) {\n const waiting = new Promise((resolve) => { setTimeout(() => resolve(true), time); });\n await waiting;\n}\n", "/* eslint-disable indent */\n/* eslint-disable no-multi-spaces */\n\n/** Generic config type inherited by all module types */\nexport interface GenericConfig {\n /** is module enabled? */\n enabled: boolean,\n /** path to model json file (relative to `modelBasePath` */\n modelPath: string,\n /** how many max frames to go without re-running model if cached results are acceptable\n * for two-phase models such as face and hand caching applies to bounding boxes detection only */\n skipFrames: number,\n /** how many max milliseconds to go without re-running model if cached results are acceptable\n * for two-phase models such as face and hand caching applies to bounding boxes detection only */\n skipTime: number,\n}\n\n/** Detector part of face configuration */\nexport interface FaceDetectorConfig extends GenericConfig {\n /** is face rotation correction performed after detecting face?\n * used to correctly analyze faces under high angles\n */\n rotation: boolean,\n /** maximum number of detected faces */\n maxDetected: number,\n /** minimum confidence for a detected face before results are discarded */\n minConfidence: number,\n /** minimum overlap between two detected faces before one is discarded */\n iouThreshold: number,\n /** should child models perform on masked image of a face */\n mask: boolean,\n /** should face detection return processed and cropped face tensor that can with an external model for addtional processing?\n * if enabled it must be manually deallocated to avoid memory leak */\n return: boolean,\n}\n\n/** Mesh part of face configuration */\nexport interface FaceMeshConfig extends GenericConfig {\n /** Keep detected faces that cannot be verified using facemesh */\n keepInvalid: boolean\n}\n\n/** Iris part of face configuration */\nexport interface FaceIrisConfig extends GenericConfig {}\n\n/** Attention part of face configuration */\nexport interface FaceAttentionConfig extends GenericConfig {}\n\n/** Description or face embedding part of face configuration\n * - also used by age and gender detection\n */\nexport interface FaceDescriptionConfig extends GenericConfig {\n /** minimum confidence for a detected face before results are discarded */\n minConfidence: number,\n}\n\n/** Emotion part of face configuration */\nexport interface FaceEmotionConfig extends GenericConfig {\n /** minimum confidence for a detected face before results are discarded */\n minConfidence: number,\n}\n\n/** Anti-spoofing part of face configuration */\nexport interface FaceAntiSpoofConfig extends GenericConfig {}\n\n/** Liveness part of face configuration */\nexport interface FaceLivenessConfig extends GenericConfig {}\n\n/** Configures all face-specific options: face detection, mesh analysis, age, gender, emotion detection and face description */\nexport interface FaceConfig extends GenericConfig {\n detector: Partial,\n mesh: Partial,\n attention: Partial,\n iris: Partial,\n description: Partial,\n emotion: Partial,\n antispoof: Partial,\n liveness: Partial,\n}\n\n/** Configures all body detection specific options */\nexport interface BodyConfig extends GenericConfig {\n /** maximum number of detected bodies */\n maxDetected: number,\n /** minimum confidence for a detected body before results are discarded */\n minConfidence: number,\n /* experimental\n /** experimental: detector used for body model before actual analysis\n detector?: {\n /** experimental: enable body detector before body landmarks\n enabled: boolean,\n /** experimental: path to optional body detector model json file\n modelPath: string,\n /** experimental: minimum confidence for a detected body before results are discarded\n minConfidence: number,\n /** experimental: minimum overlap between two detected bodies before one is discarded\n iouThreshold: number\n },\n */\n}\n\n/** Configures all hand detection specific options */\nexport interface HandConfig extends GenericConfig {\n /** should hand rotation correction be performed after hand detection? */\n rotation: boolean,\n /** minimum confidence for a detected hand before results are discarded */\n minConfidence: number,\n /** minimum overlap between two detected hands before one is discarded */\n iouThreshold: number,\n /** maximum number of detected hands */\n maxDetected: number,\n /** should hand landmarks be detected or just return detected hand box */\n landmarks: boolean,\n detector: {\n /** path to hand detector model json */\n modelPath?: string,\n },\n skeleton: {\n /** path to hand skeleton model json */\n modelPath?: string,\n },\n}\n\n/** Configures all object detection specific options */\nexport interface ObjectConfig extends GenericConfig {\n /** minimum confidence for a detected objects before results are discarded */\n minConfidence: number,\n /** minimum overlap between two detected objects before one is discarded */\n iouThreshold: number,\n /** maximum number of detected objects */\n maxDetected: number,\n}\n\n/** Configures all body segmentation module\n * removes background from input containing person\n * if segmentation is enabled it will run as preprocessing task before any other model\n * alternatively leave it disabled and use it on-demand using human.segmentation method which can\n * remove background or replace it with user-provided background\n*/\nexport interface SegmentationConfig extends GenericConfig {\n /** blur segmentation output by pixels for more realistic image */\n blur: number,\n}\n\n/** Run input through image filters before inference\n * - available only in Browser environments\n * - image filters run with near-zero latency as they are executed on the GPU using WebGL\n*/\nexport interface FilterConfig {\n /** are image filters enabled? */\n enabled: boolean,\n /** perform image histogram equalization\n * - equalization is performed on input as a whole and detected face before its passed for further analysis\n */\n equalization: boolean,\n /** resize input width\n * - if both width and height are set to 0, there is no resizing\n * - if just one is set, second one is scaled automatically\n * - if both are set, values are used as-is\n */\n width: number,\n /** resize input height\n * - if both width and height are set to 0, there is no resizing\n * - if just one is set, second one is scaled automatically\n * - if both are set, values are used as-is\n */\n height: number,\n /** return processed canvas imagedata in result */\n return: boolean,\n /** flip input as mirror image */\n flip: boolean,\n /** range: -1 (darken) to 1 (lighten) */\n brightness: number,\n /** range: -1 (reduce contrast) to 1 (increase contrast) */\n contrast: number,\n /** range: 0 (no sharpening) to 1 (maximum sharpening) */\n sharpness: number,\n /** range: 0 (no blur) to N (blur radius in pixels) */\n blur: number\n /** range: -1 (reduce saturation) to 1 (increase saturation) */\n saturation: number,\n /** range: 0 (no change) to 360 (hue rotation in degrees) */\n hue: number,\n /** image negative */\n negative: boolean,\n /** image sepia colors */\n sepia: boolean,\n /** image vintage colors */\n vintage: boolean,\n /** image kodachrome colors */\n kodachrome: boolean,\n /** image technicolor colors */\n technicolor: boolean,\n /** image polaroid camera effect */\n polaroid: boolean,\n /** range: 0 (no pixelate) to N (number of pixels to pixelate) */\n pixelate: number,\n}\n\n/** Controlls gesture detection */\nexport interface GestureConfig {\n /** is gesture detection enabled? */\n enabled: boolean,\n}\n/** Possible TensorFlow backends */\nexport type BackendType = ['cpu', 'wasm', 'webgl', 'humangl', 'tensorflow', 'webgpu'];\n\n/** Possible values for `human.warmup` */\nexport type WarmupType = ['' | 'none' | 'face' | 'full' | 'body'];\n\n/**\n * Configuration interface definition for **Human** library\n * Contains all configurable parameters\n * Defaults: [config](https://github.com/vladmandic/human/blob/main/src/config.ts#L262)\n */\nexport interface Config {\n /** Backend used for TFJS operations\n * valid build-in backends are:\n * - Browser: `cpu`, `wasm`, `webgl`, `humangl`, `webgpu`\n * - NodeJS: `cpu`, `wasm`, `tensorflow`\n * default: `humangl` for browser and `tensorflow` for nodejs\n */\n backend: '' | 'cpu' | 'wasm' | 'webgl' | 'humangl' | 'tensorflow' | 'webgpu',\n\n /** Path to *.wasm files if backend is set to `wasm`\n *\n * default: auto-detects to link to CDN `jsdelivr` when running in browser\n */\n wasmPath: string,\n\n /** Force WASM loader to use platform fetch\n *\n * default: auto-detects to link to CDN `jsdelivr` when running in browser\n */\n wasmPlatformFetch: boolean,\n\n /** Print debug statements to console\n *\n * default: `true`\n */\n debug: boolean,\n\n /** Perform model loading and inference concurrently or sequentially\n *\n * default: `true`\n */\n async: boolean,\n\n /** What to use for `human.warmup()`\n * - warmup pre-initializes all models for faster inference but can take significant time on startup\n * - used by `webgl`, `humangl` and `webgpu` backends\n *\n * default: `full`\n */\n warmup: '' | 'none' | 'face' | 'full' | 'body',\n\n /** Base model path (typically starting with file://, http:// or https://) for all models\n * - individual modelPath values are relative to this path\n *\n * default: `../models/` for browsers and `file://models/` for nodejs\n */\n modelBasePath: string,\n\n /** Cache models in IndexDB on first sucessfull load\n * default: true if indexdb is available (browsers), false if its not (nodejs)\n */\n cacheModels: boolean,\n\n /** Cache sensitivity\n * - values 0..1 where 0.01 means reset cache if input changed more than 1%\n * - set to 0 to disable caching\n *\n * default: 0.7\n */\n cacheSensitivity: number;\n\n /** Perform immediate garbage collection on deallocated tensors instead of caching them */\n deallocate: boolean;\n\n /** Internal Variable */\n skipAllowed: boolean;\n\n /** Filter config {@link FilterConfig} */\n filter: Partial,\n\n /** Gesture config {@link GestureConfig} */\n gesture: Partial;\n\n /** Face config {@link FaceConfig} */\n face: Partial,\n\n /** Body config {@link BodyConfig} */\n body: Partial,\n\n /** Hand config {@link HandConfig} */\n hand: Partial,\n\n /** Object config {@link ObjectConfig} */\n object: Partial,\n\n /** Segmentation config {@link SegmentationConfig} */\n segmentation: Partial,\n}\n\n/** - [See all default Config values...](https://github.com/vladmandic/human/blob/main/src/config.ts#L262) */\nconst config: Config = {\n backend: '',\n modelBasePath: '',\n cacheModels: true,\n wasmPath: '',\n wasmPlatformFetch: false,\n debug: true,\n async: true,\n warmup: 'full',\n cacheSensitivity: 0.70,\n skipAllowed: false,\n deallocate: false,\n filter: {\n enabled: true,\n equalization: false,\n width: 0,\n height: 0,\n flip: false,\n return: true,\n brightness: 0,\n contrast: 0,\n sharpness: 0,\n blur: 0,\n saturation: 0,\n hue: 0,\n negative: false,\n sepia: false,\n vintage: false,\n kodachrome: false,\n technicolor: false,\n polaroid: false,\n pixelate: 0,\n },\n gesture: {\n enabled: true,\n },\n face: {\n enabled: true,\n detector: {\n modelPath: 'blazeface.json',\n rotation: true,\n maxDetected: 1,\n skipFrames: 99,\n skipTime: 2500,\n minConfidence: 0.2,\n iouThreshold: 0.1,\n mask: false,\n return: false,\n },\n mesh: {\n enabled: true,\n modelPath: 'facemesh.json',\n keepInvalid: false,\n },\n attention: {\n enabled: false,\n modelPath: 'facemesh-attention.json',\n },\n iris: {\n enabled: true,\n modelPath: 'iris.json',\n },\n emotion: {\n enabled: true,\n minConfidence: 0.1,\n skipFrames: 99,\n skipTime: 1500,\n modelPath: 'emotion.json',\n },\n description: {\n enabled: true,\n modelPath: 'faceres.json',\n skipFrames: 99,\n skipTime: 3000,\n minConfidence: 0.1,\n },\n antispoof: {\n enabled: false,\n skipFrames: 99,\n skipTime: 4000,\n modelPath: 'antispoof.json',\n },\n liveness: {\n enabled: false,\n skipFrames: 99,\n skipTime: 4000,\n modelPath: 'liveness.json',\n },\n },\n body: {\n enabled: true,\n modelPath: 'movenet-lightning.json',\n maxDetected: -1,\n minConfidence: 0.3,\n skipFrames: 1,\n skipTime: 200,\n },\n hand: {\n enabled: true,\n rotation: true,\n skipFrames: 99,\n skipTime: 1000,\n minConfidence: 0.50,\n iouThreshold: 0.2,\n maxDetected: -1,\n landmarks: true,\n detector: {\n modelPath: 'handtrack.json',\n },\n skeleton: {\n modelPath: 'handlandmark-full.json',\n },\n },\n object: {\n enabled: false,\n modelPath: 'mb3-centernet.json',\n minConfidence: 0.2,\n iouThreshold: 0.4,\n maxDetected: 10,\n skipFrames: 99,\n skipTime: 2000,\n },\n segmentation: {\n enabled: false,\n modelPath: 'selfie.json',\n blur: 8,\n },\n};\n\nexport { config as defaults };\n", "/*\n Human\n homepage: \n author: '\n*/\n\nexport*from\"@tensorflow/tfjs/dist/index.js\";export*from\"@tensorflow/tfjs-backend-webgl/dist/index.js\";var r=\"3.18.0\",e=\"3.18.0\",a=\"3.18.0\",o=\"3.18.0\",t=\"3.18.0\",s=\"3.18.0\",f=\"3.18.0\",v={tfjs:r,\"tfjs-core\":e,\"tfjs-data\":a,\"tfjs-layers\":o,\"tfjs-converter\":t,\"tfjs-backend-webgl\":s,\"tfjs-backend-wasm\":f};import{Tensor as d}from\"@tensorflow/tfjs/dist/index.js\";import{GraphModel as b}from\"@tensorflow/tfjs-converter/dist/index\";export{b as GraphModel,d as Tensor,v as version};\n", "export const vertexIdentity = `\n precision highp float;\n attribute vec2 pos;\n attribute vec2 uv;\n varying vec2 vUv;\n uniform float flipY;\n void main(void) {\n vUv = uv;\n gl_Position = vec4(pos.x, pos.y*flipY, 0.0, 1.);\n }\n`;\n\nexport const fragmentIdentity = `\n precision highp float;\n varying vec2 vUv;\n uniform sampler2D texture;\n void main(void) {\n gl_FragColor = texture2D(texture, vUv);\n }\n`;\n\nexport const colorMatrixWithAlpha = `\n precision highp float;\n varying vec2 vUv;\n uniform sampler2D texture;\n uniform float m[20];\n void main(void) {\n vec4 c = texture2D(texture, vUv);\n gl_FragColor.r = m[0] * c.r + m[1] * c.g + m[2] * c.b + m[3] * c.a + m[4];\n gl_FragColor.g = m[5] * c.r + m[6] * c.g + m[7] * c.b + m[8] * c.a + m[9];\n gl_FragColor.b = m[10] * c.r + m[11] * c.g + m[12] * c.b + m[13] * c.a + m[14];\n gl_FragColor.a = m[15] * c.r + m[16] * c.g + m[17] * c.b + m[18] * c.a + m[19];\n }\n`;\n\nexport const colorMatrixWithoutAlpha = `\n precision highp float;\n varying vec2 vUv;\n uniform sampler2D texture;\n uniform float m[20];\n void main(void) {\n vec4 c = texture2D(texture, vUv);\n gl_FragColor.r = m[0] * c.r + m[1] * c.g + m[2] * c.b + m[4];\n gl_FragColor.g = m[5] * c.r + m[6] * c.g + m[7] * c.b + m[9];\n gl_FragColor.b = m[10] * c.r + m[11] * c.g + m[12] * c.b + m[14];\n gl_FragColor.a = c.a;\n }\n`;\n\nexport const pixelate = `\n precision highp float;\n varying vec2 vUv;\n uniform vec2 size;\n uniform sampler2D texture;\n vec2 pixelate(vec2 coord, vec2 size) {\n return floor( coord / size ) * size;\n }\n void main(void) {\n gl_FragColor = vec4(0.0);\n vec2 coord = pixelate(vUv, size);\n gl_FragColor += texture2D(texture, coord);\n }\n`;\n\nexport const blur = `\n precision highp float;\n varying vec2 vUv;\n uniform sampler2D texture;\n uniform vec2 px;\n void main(void) {\n gl_FragColor = vec4(0.0);\n gl_FragColor += texture2D(texture, vUv + vec2(-7.0*px.x, -7.0*px.y))*0.0044299121055113265;\n gl_FragColor += texture2D(texture, vUv + vec2(-6.0*px.x, -6.0*px.y))*0.00895781211794;\n gl_FragColor += texture2D(texture, vUv + vec2(-5.0*px.x, -5.0*px.y))*0.0215963866053;\n gl_FragColor += texture2D(texture, vUv + vec2(-4.0*px.x, -4.0*px.y))*0.0443683338718;\n gl_FragColor += texture2D(texture, vUv + vec2(-3.0*px.x, -3.0*px.y))*0.0776744219933;\n gl_FragColor += texture2D(texture, vUv + vec2(-2.0*px.x, -2.0*px.y))*0.115876621105;\n gl_FragColor += texture2D(texture, vUv + vec2(-1.0*px.x, -1.0*px.y))*0.147308056121;\n gl_FragColor += texture2D(texture, vUv )*0.159576912161;\n gl_FragColor += texture2D(texture, vUv + vec2( 1.0*px.x, 1.0*px.y))*0.147308056121;\n gl_FragColor += texture2D(texture, vUv + vec2( 2.0*px.x, 2.0*px.y))*0.115876621105;\n gl_FragColor += texture2D(texture, vUv + vec2( 3.0*px.x, 3.0*px.y))*0.0776744219933;\n gl_FragColor += texture2D(texture, vUv + vec2( 4.0*px.x, 4.0*px.y))*0.0443683338718;\n gl_FragColor += texture2D(texture, vUv + vec2( 5.0*px.x, 5.0*px.y))*0.0215963866053;\n gl_FragColor += texture2D(texture, vUv + vec2( 6.0*px.x, 6.0*px.y))*0.00895781211794;\n gl_FragColor += texture2D(texture, vUv + vec2( 7.0*px.x, 7.0*px.y))*0.0044299121055113265;\n }\n`;\n\nexport const convolution = `\n precision highp float;\n varying vec2 vUv;\n uniform sampler2D texture;\n uniform vec2 px;\n uniform float m[9];\n void main(void) {\n vec4 c11 = texture2D(texture, vUv - px); // top left\n vec4 c12 = texture2D(texture, vec2(vUv.x, vUv.y - px.y)); // top center\n vec4 c13 = texture2D(texture, vec2(vUv.x + px.x, vUv.y - px.y)); // top right\n vec4 c21 = texture2D(texture, vec2(vUv.x - px.x, vUv.y) ); // mid left\n vec4 c22 = texture2D(texture, vUv); // mid center\n vec4 c23 = texture2D(texture, vec2(vUv.x + px.x, vUv.y) ); // mid right\n vec4 c31 = texture2D(texture, vec2(vUv.x - px.x, vUv.y + px.y) ); // bottom left\n vec4 c32 = texture2D(texture, vec2(vUv.x, vUv.y + px.y) ); // bottom center\n vec4 c33 = texture2D(texture, vUv + px ); // bottom right\n gl_FragColor = \n c11 * m[0] + c12 * m[1] + c22 * m[2] +\n c21 * m[3] + c22 * m[4] + c23 * m[5] +\n c31 * m[6] + c32 * m[7] + c33 * m[8];\n gl_FragColor.a = c22.a;\n }\n`;\n", "/**\n * Image Filters in WebGL algoritm implementation\n * Based on: [WebGLImageFilter](https://github.com/phoboslab/WebGLImageFilter)\n */\n\nimport * as shaders from './imagefxshaders';\nimport { canvas } from './image';\nimport { log } from '../util/util';\n\nconst collect = (source, prefix, collection) => {\n const r = new RegExp('\\\\b' + prefix + ' \\\\w+ (\\\\w+)', 'ig');\n source.replace(r, (match, name) => {\n collection[name] = 0;\n return match;\n });\n};\n\nclass GLProgram {\n uniform = {};\n attribute = {};\n gl: WebGLRenderingContext;\n id: WebGLProgram;\n\n constructor(gl, vertexSource, fragmentSource) {\n this.gl = gl;\n const vertexShader = this.compile(vertexSource, this.gl.VERTEX_SHADER);\n const fragmentShader = this.compile(fragmentSource, this.gl.FRAGMENT_SHADER);\n this.id = this.gl.createProgram() as WebGLProgram;\n if (!vertexShader || !fragmentShader) return;\n if (!this.id) {\n log('filter: could not create webgl program');\n return;\n }\n this.gl.attachShader(this.id, vertexShader);\n this.gl.attachShader(this.id, fragmentShader);\n this.gl.linkProgram(this.id);\n if (!this.gl.getProgramParameter(this.id, this.gl.LINK_STATUS)) {\n log(`filter: gl link failed: ${this.gl.getProgramInfoLog(this.id)}`);\n return;\n }\n this.gl.useProgram(this.id);\n collect(vertexSource, 'attribute', this.attribute); // Collect attributes\n for (const a in this.attribute) this.attribute[a] = this.gl.getAttribLocation(this.id, a);\n collect(vertexSource, 'uniform', this.uniform); // Collect uniforms\n collect(fragmentSource, 'uniform', this.uniform);\n for (const u in this.uniform) this.uniform[u] = this.gl.getUniformLocation(this.id, u);\n }\n\n compile = (source, type): WebGLShader | null => {\n const shader = this.gl.createShader(type) as WebGLShader;\n if (!shader) {\n log('filter: could not create shader');\n return null;\n }\n this.gl.shaderSource(shader, source);\n this.gl.compileShader(shader);\n if (!this.gl.getShaderParameter(shader, this.gl.COMPILE_STATUS)) {\n log(`filter: gl compile failed: ${this.gl.getShaderInfoLog(shader)}`);\n return null;\n }\n return shader;\n };\n}\n\n// function that is instantiated as class so it has private this members\n/**\n * @class GLImageFilter\n * @property {function} reset reset current filter chain\n * @property {function} add add specified filter to filter chain\n * @property {function} apply execute filter chain and draw result\n * @property {function} draw just draw input to result\n */\n\nexport function GLImageFilter() {\n let drawCount = 0;\n let sourceTexture: WebGLTexture | null = null;\n let lastInChain = false;\n let currentFramebufferIndex = -1;\n let tempFramebuffers: [null, null] | [{ fbo: WebGLFramebuffer | null, texture: WebGLTexture | null }] = [null, null];\n let filterChain: Record[] = [];\n let vertexBuffer: WebGLBuffer | null = null;\n let currentProgram: GLProgram | null = null;\n const fxcanvas = canvas(100, 100);\n const shaderProgramCache = { }; // key is the shader program source, value is the compiled program\n const DRAW = { INTERMEDIATE: 1 };\n const gl = fxcanvas.getContext('webgl') as WebGLRenderingContext;\n if (!gl) {\n log('filter: cannot get webgl context');\n return;\n }\n // @ts-ignore used for sanity checks outside of imagefx\n this.gl = gl;\n\n function resize(width, height) {\n if (width === fxcanvas.width && height === fxcanvas.height) return; // Same width/height? Nothing to do here\n fxcanvas.width = width;\n fxcanvas.height = height;\n if (!vertexBuffer) { // Create the context if we don't have it yet\n const vertices = new Float32Array([-1, -1, 0, 1, 1, -1, 1, 1, -1, 1, 0, 0, -1, 1, 0, 0, 1, -1, 1, 1, 1, 1, 1, 0]); // Create the vertex buffer for the two triangles [x, y, u, v] * 6\n vertexBuffer = gl.createBuffer();\n gl.bindBuffer(gl.ARRAY_BUFFER, vertexBuffer);\n gl.bufferData(gl.ARRAY_BUFFER, vertices, gl.STATIC_DRAW);\n gl.pixelStorei(gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, true);\n }\n gl.viewport(0, 0, fxcanvas.width, fxcanvas.height);\n tempFramebuffers = [null, null]; // Delete old temp framebuffers\n }\n\n function createFramebufferTexture(width, height) {\n const fbo = gl.createFramebuffer() as WebGLFramebuffer;\n gl.bindFramebuffer(gl.FRAMEBUFFER, fbo);\n const renderbuffer = gl.createRenderbuffer();\n gl.bindRenderbuffer(gl.RENDERBUFFER, renderbuffer);\n const texture = gl.createTexture() as WebGLTexture;\n gl.bindTexture(gl.TEXTURE_2D, texture);\n gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, width, height, 0, gl.RGBA, gl.UNSIGNED_BYTE, null);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\n gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, texture, 0);\n gl.bindTexture(gl.TEXTURE_2D, null);\n gl.bindFramebuffer(gl.FRAMEBUFFER, null);\n return { fbo, texture };\n }\n\n function getTempFramebuffer(index): { fbo: WebGLFramebuffer | null, texture: WebGLTexture | null } {\n tempFramebuffers[index] = tempFramebuffers[index] || createFramebufferTexture(fxcanvas.width, fxcanvas.height);\n return tempFramebuffers[index] as { fbo: WebGLFramebuffer, texture: WebGLTexture };\n }\n\n function draw(flags = 0) {\n if (!currentProgram) return;\n let source: WebGLTexture | null = null;\n let target: WebGLFramebuffer | null = null;\n let flipY = false;\n if (drawCount === 0) source = sourceTexture; // First draw call - use the source texture\n else source = getTempFramebuffer(currentFramebufferIndex).texture || null; // All following draw calls use the temp buffer last drawn to\n drawCount++;\n if (lastInChain && !(flags & DRAW.INTERMEDIATE)) { // Last filter in our chain - draw directly to the WebGL Canvas. We may also have to flip the image vertically now\n target = null;\n flipY = drawCount % 2 === 0;\n } else {\n currentFramebufferIndex = (currentFramebufferIndex + 1) % 2;\n target = getTempFramebuffer(currentFramebufferIndex).fbo || null; // Intermediate draw call - get a temp buffer to draw to\n }\n gl.bindTexture(gl.TEXTURE_2D, source); // Bind the source and target and draw the two triangles\n gl.bindFramebuffer(gl.FRAMEBUFFER, target);\n gl.uniform1f(currentProgram.uniform['flipY'], (flipY ? -1 : 1));\n gl.drawArrays(gl.TRIANGLES, 0, 6);\n }\n\n function compileShader(fragmentSource): GLProgram | null {\n if (shaderProgramCache[fragmentSource]) {\n currentProgram = shaderProgramCache[fragmentSource];\n gl.useProgram((currentProgram ? currentProgram.id : null) || null);\n return currentProgram as GLProgram;\n }\n currentProgram = new GLProgram(gl, shaders.vertexIdentity, fragmentSource);\n if (!currentProgram) {\n log('filter: could not get webgl program');\n return null;\n }\n const floatSize = Float32Array.BYTES_PER_ELEMENT;\n const vertSize = 4 * floatSize;\n gl.enableVertexAttribArray(currentProgram.attribute['pos']);\n gl.vertexAttribPointer(currentProgram.attribute['pos'], 2, gl.FLOAT, false, vertSize, 0 * floatSize);\n gl.enableVertexAttribArray(currentProgram.attribute['uv']);\n gl.vertexAttribPointer(currentProgram.attribute['uv'], 2, gl.FLOAT, false, vertSize, 2 * floatSize);\n shaderProgramCache[fragmentSource] = currentProgram;\n return currentProgram as GLProgram;\n }\n\n const filter = {\n colorMatrix: (matrix) => { // general color matrix filter\n const m = new Float32Array(matrix);\n m[4] /= 255;\n m[9] /= 255;\n m[14] /= 255;\n m[19] /= 255;\n const shader = (m[18] === 1 && m[3] === 0 && m[8] === 0 && m[13] === 0 && m[15] === 0 && m[16] === 0 && m[17] === 0 && m[19] === 0) // Can we ignore the alpha value? Makes things a bit faster.\n ? shaders.colorMatrixWithoutAlpha\n : shaders.colorMatrixWithAlpha;\n const program = compileShader(shader);\n if (!program) return;\n gl.uniform1fv(program.uniform['m'], m);\n draw();\n },\n\n brightness: (brightness) => {\n const b = (brightness || 0) + 1;\n filter.colorMatrix([\n b, 0, 0, 0, 0,\n 0, b, 0, 0, 0,\n 0, 0, b, 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n saturation: (amount) => {\n const x = (amount || 0) * 2 / 3 + 1;\n const y = ((x - 1) * -0.5);\n filter.colorMatrix([\n x, y, y, 0, 0,\n y, x, y, 0, 0,\n y, y, x, 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n desaturate: () => {\n filter.saturation(-1);\n },\n\n contrast: (amount) => {\n const v = (amount || 0) + 1;\n const o = -128 * (v - 1);\n filter.colorMatrix([\n v, 0, 0, 0, o,\n 0, v, 0, 0, o,\n 0, 0, v, 0, o,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n negative: () => {\n filter.contrast(-2);\n },\n\n hue: (rotation) => {\n rotation = (rotation || 0) / 180 * Math.PI;\n const cos = Math.cos(rotation);\n const sin = Math.sin(rotation);\n const lumR = 0.213;\n const lumG = 0.715;\n const lumB = 0.072;\n filter.colorMatrix([\n lumR + cos * (1 - lumR) + sin * (-lumR), lumG + cos * (-lumG) + sin * (-lumG), lumB + cos * (-lumB) + sin * (1 - lumB), 0, 0,\n lumR + cos * (-lumR) + sin * (0.143), lumG + cos * (1 - lumG) + sin * (0.140), lumB + cos * (-lumB) + sin * (-0.283), 0, 0,\n lumR + cos * (-lumR) + sin * (-(1 - lumR)), lumG + cos * (-lumG) + sin * (lumG), lumB + cos * (1 - lumB) + sin * (lumB), 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n desaturateLuminance: () => {\n filter.colorMatrix([\n 0.2764723, 0.9297080, 0.0938197, 0, -37.1,\n 0.2764723, 0.9297080, 0.0938197, 0, -37.1,\n 0.2764723, 0.9297080, 0.0938197, 0, -37.1,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n sepia: () => {\n filter.colorMatrix([\n 0.393, 0.7689999, 0.18899999, 0, 0,\n 0.349, 0.6859999, 0.16799999, 0, 0,\n 0.272, 0.5339999, 0.13099999, 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n brownie: () => {\n filter.colorMatrix([\n 0.5997023498159715, 0.34553243048391263, -0.2708298674538042, 0, 47.43192855600873,\n -0.037703249837783157, 0.8609577587992641, 0.15059552388459913, 0, -36.96841498319127,\n 0.24113635128153335, -0.07441037908422492, 0.44972182064877153, 0, -7.562075277591283,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n vintagePinhole: () => {\n filter.colorMatrix([\n 0.6279345635605994, 0.3202183420819367, -0.03965408211312453, 0, 9.651285835294123,\n 0.02578397704808868, 0.6441188644374771, 0.03259127616149294, 0, 7.462829176470591,\n 0.0466055556782719, -0.0851232987247891, 0.5241648018700465, 0, 5.159190588235296,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n kodachrome: () => {\n filter.colorMatrix([\n 1.1285582396593525, -0.3967382283601348, -0.03992559172921793, 0, 63.72958762196502,\n -0.16404339962244616, 1.0835251566291304, -0.05498805115633132, 0, 24.732407896706203,\n -0.16786010706155763, -0.5603416277695248, 1.6014850761964943, 0, 35.62982807460946,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n technicolor: () => {\n filter.colorMatrix([\n 1.9125277891456083, -0.8545344976951645, -0.09155508482755585, 0, 11.793603434377337,\n -0.3087833385928097, 1.7658908555458428, -0.10601743074722245, 0, -70.35205161461398,\n -0.231103377548616, -0.7501899197440212, 1.847597816108189, 0, 30.950940869491138,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n polaroid: () => {\n filter.colorMatrix([\n 1.438, -0.062, -0.062, 0, 0,\n -0.122, 1.378, -0.122, 0, 0,\n -0.016, -0.016, 1.483, 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n shiftToBGR: () => {\n filter.colorMatrix([\n 0, 0, 1, 0, 0,\n 0, 1, 0, 0, 0,\n 1, 0, 0, 0, 0,\n 0, 0, 0, 1, 0,\n ]);\n },\n\n convolution: (matrix) => { // general convolution Filter\n const m = new Float32Array(matrix);\n const pixelSizeX = 1 / fxcanvas.width;\n const pixelSizeY = 1 / fxcanvas.height;\n const program = compileShader(shaders.convolution);\n if (!program) return;\n gl.uniform1fv(program.uniform['m'], m);\n gl.uniform2f(program.uniform['px'], pixelSizeX, pixelSizeY);\n draw();\n },\n\n detectEdges: () => {\n // @ts-ignore this\n filter.convolution.call(this, [\n 0, 1, 0,\n 1, -4, 1,\n 0, 1, 0,\n ]);\n },\n\n sobelX: () => {\n // @ts-ignore this\n filter.convolution.call(this, [\n -1, 0, 1,\n -2, 0, 2,\n -1, 0, 1,\n ]);\n },\n\n sobelY: () => {\n // @ts-ignore this\n filter.convolution.call(this, [\n -1, -2, -1,\n 0, 0, 0,\n 1, 2, 1,\n ]);\n },\n\n sharpen: (amount) => {\n const a = amount || 1;\n // @ts-ignore this\n filter.convolution.call(this, [\n 0, -1 * a, 0,\n -1 * a, 1 + 4 * a, -1 * a,\n 0, -1 * a, 0,\n ]);\n },\n\n emboss: (size) => {\n const s = size || 1;\n // @ts-ignore this\n filter.convolution.call(this, [\n -2 * s, -1 * s, 0,\n -1 * s, 1, 1 * s,\n 0, 1 * s, 2 * s,\n ]);\n },\n\n blur: (size) => {\n const blurSizeX = (size / 7) / fxcanvas.width;\n const blurSizeY = (size / 7) / fxcanvas.height;\n const program = compileShader(shaders.blur);\n if (!program) return;\n // Vertical\n gl.uniform2f(program.uniform['px'], 0, blurSizeY);\n draw(DRAW.INTERMEDIATE);\n // Horizontal\n gl.uniform2f(program.uniform['px'], blurSizeX, 0);\n draw();\n },\n\n pixelate: (size) => {\n const blurSizeX = (size) / fxcanvas.width;\n const blurSizeY = (size) / fxcanvas.height;\n const program = compileShader(shaders.pixelate);\n if (!program) return;\n gl.uniform2f(program.uniform['size'], blurSizeX, blurSizeY);\n draw();\n },\n };\n\n // @ts-ignore this\n this.add = function (name) {\n // eslint-disable-next-line prefer-rest-params\n const args = Array.prototype.slice.call(arguments, 1);\n const func = filter[name];\n filterChain.push({ func, args });\n };\n\n // @ts-ignore this\n this.reset = function () {\n filterChain = [];\n };\n\n // @ts-ignore this\n this.get = function () {\n return filterChain;\n };\n\n // @ts-ignore this\n this.apply = function (image) {\n resize(image.width, image.height);\n drawCount = 0;\n if (!sourceTexture) sourceTexture = gl.createTexture(); // Create the texture for the input image if we haven't yet\n gl.bindTexture(gl.TEXTURE_2D, sourceTexture);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.NEAREST);\n gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.NEAREST);\n gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, image);\n for (let i = 0; i < filterChain.length; i++) {\n lastInChain = (i === filterChain.length - 1);\n const f = filterChain[i];\n // @ts-ignore function assigment\n f.func.apply(this, f.args || []);\n }\n return fxcanvas;\n };\n\n // @ts-ignore this\n this.draw = function (image) {\n this.add('brightness', 0);\n return this.apply(image);\n };\n}\n", "/**\n * Image enhancements\n */\n\nimport * as tf from '../../dist/tfjs.esm.js';\nimport type { Tensor } from '../exports';\n\nexport async function histogramEqualization(inputImage: Tensor): Promise {\n // const maxValue = 254; // using 255 results in values slightly larger than 1 due to math rounding errors\n const squeeze = inputImage.shape.length === 4 ? tf.squeeze(inputImage) : inputImage;\n const channels = tf.split(squeeze, 3, 2);\n const min: Tensor[] = [tf.min(channels[0]), tf.min(channels[1]), tf.min(channels[2])];\n const max: Tensor[] = [tf.max(channels[0]), tf.max(channels[1]), tf.max(channels[2])];\n const absMax = await Promise.all(max.map((channel) => channel.data()));\n const maxValue = 0.99 * Math.max(absMax[0][0], absMax[1][0], absMax[2][0]);\n const sub = [tf.sub(channels[0], min[0]), tf.sub(channels[1], min[1]), tf.sub(channels[2], min[2])];\n const range = [tf.sub(max[0], min[0]), tf.sub(max[1], min[1]), tf.sub(max[2], min[2])];\n const fact = [tf.div(maxValue, range[0]), tf.div(maxValue, range[1]), tf.div(maxValue, range[2])];\n const enh = [tf.mul(sub[0], fact[0]), tf.mul(sub[1], fact[1]), tf.mul(sub[2], fact[2])];\n const rgb = tf.stack([enh[0], enh[1], enh[2]], 2);\n const reshape = tf.reshape(rgb, [1, squeeze.shape[0], squeeze.shape[1], 3]);\n tf.dispose([...channels, ...min, ...max, ...sub, ...range, ...fact, ...enh, rgb, squeeze]);\n return reshape; // output shape is [1, height, width, 3]\n}\n", "/**\n * Image Processing algorithm implementation\n */\n\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as fxImage from './imagefx';\nimport type { Input, AnyCanvas, Tensor, Config } from '../exports';\nimport { env } from '../util/env';\nimport { log } from '../util/util';\nimport * as enhance from './enhance';\n\nconst maxSize = 3840;\n// internal temp canvases\nlet inCanvas: AnyCanvas | null = null; // use global variable to avoid recreating canvas on each frame\nlet outCanvas: AnyCanvas | null = null; // use global variable to avoid recreating canvas on each frame\nlet tmpCanvas: AnyCanvas | null = null; // use global variable to avoid recreating canvas on each frame\n// @ts-ignore // imagefx is js module that should be converted to a class\nlet fx: fxImage.GLImageFilter | null; // instance of imagefx\n\nconst last: { inputSum: number, cacheDiff: number, sumMethod: number, inputTensor: undefined | Tensor } = {\n inputSum: 0,\n cacheDiff: 1,\n sumMethod: 0,\n inputTensor: undefined,\n};\n\nexport function canvas(width: number, height: number): AnyCanvas {\n let c;\n if (env.browser) { // browser defines canvas object\n if (env.worker) { // if runing in web worker use OffscreenCanvas\n if (typeof OffscreenCanvas === 'undefined') throw new Error('canvas error: attempted to run in web worker but OffscreenCanvas is not supported');\n c = new OffscreenCanvas(width, height);\n } else { // otherwise use DOM canvas\n if (typeof document === 'undefined') throw new Error('canvas error: attempted to run in browser but DOM is not defined');\n c = document.createElement('canvas');\n c.width = width;\n c.height = height;\n }\n } else { // if not running in browser, there is no \"default\" canvas object, so we need monkey patch or fail\n // @ts-ignore // env.canvas is an external monkey-patch\n if (typeof env.Canvas !== 'undefined') c = new env.Canvas(width, height);\n else if (typeof globalThis.Canvas !== 'undefined') c = new globalThis.Canvas(width, height);\n // else throw new Error('canvas error: attempted to use canvas in nodejs without canvas support installed');\n }\n return c;\n}\n\n// helper function to copy canvas from input to output\nexport function copy(input: AnyCanvas, output?: AnyCanvas) {\n const outputCanvas = output || canvas(input.width, input.height);\n const ctx = outputCanvas.getContext('2d') as CanvasRenderingContext2D;\n ctx.drawImage(input, 0, 0);\n return outputCanvas;\n}\n\n// process input image and return tensor\n// input can be tensor, imagedata, htmlimageelement, htmlvideoelement\n// input is resized and run through imagefx filter\nexport async function process(input: Input, config: Config, getTensor: boolean = true): Promise<{ tensor: Tensor | null, canvas: AnyCanvas | null }> {\n if (!input) {\n // throw new Error('input is missing');\n if (config.debug) log('input error: input is missing');\n return { tensor: null, canvas: null }; // video may become temporarily unavailable due to onresize\n }\n // sanity checks since different browsers do not implement all dom elements\n if (\n !(input instanceof tf.Tensor)\n && !(typeof Image !== 'undefined' && input instanceof Image)\n && !(typeof env.Canvas !== 'undefined' && input instanceof env.Canvas)\n && !(typeof globalThis.Canvas !== 'undefined' && input instanceof globalThis.Canvas)\n && !(typeof ImageData !== 'undefined' && input instanceof ImageData)\n && !(typeof ImageBitmap !== 'undefined' && input instanceof ImageBitmap)\n && !(typeof HTMLImageElement !== 'undefined' && input instanceof HTMLImageElement)\n && !(typeof HTMLMediaElement !== 'undefined' && input instanceof HTMLMediaElement)\n && !(typeof HTMLVideoElement !== 'undefined' && input instanceof HTMLVideoElement)\n && !(typeof HTMLCanvasElement !== 'undefined' && input instanceof HTMLCanvasElement)\n && !(typeof OffscreenCanvas !== 'undefined' && input instanceof OffscreenCanvas)\n ) {\n throw new Error('input error: type is not recognized');\n }\n if (input instanceof tf.Tensor) { // if input is tensor use as-is without filters but correct shape as needed\n let tensor: Tensor | null = null;\n if ((input as Tensor)['isDisposedInternal']) throw new Error('input error: attempted to use tensor but it is disposed');\n if (!(input as Tensor)['shape']) throw new Error('input error: attempted to use tensor without a shape');\n if ((input as Tensor).shape.length === 3) { // [height, width, 3 || 4]\n if ((input as Tensor).shape[2] === 3) { // [height, width, 3] so add batch\n tensor = tf.expandDims(input, 0);\n } else if ((input as Tensor).shape[2] === 4) { // [height, width, 4] so strip alpha and add batch\n const rgb = tf.slice3d(input, [0, 0, 0], [-1, -1, 3]);\n tensor = tf.expandDims(rgb, 0);\n tf.dispose(rgb);\n }\n } else if ((input as Tensor).shape.length === 4) { // [1, width, height, 3 || 4]\n if ((input as Tensor).shape[3] === 3) { // [1, width, height, 3] just clone\n tensor = tf.clone(input);\n } else if ((input as Tensor).shape[3] === 4) { // [1, width, height, 4] so strip alpha\n tensor = tf.slice4d(input, [0, 0, 0, 0], [-1, -1, -1, 3]);\n }\n }\n // at the end shape must be [1, height, width, 3]\n if (tensor == null || tensor.shape.length !== 4 || tensor.shape[0] !== 1 || tensor.shape[3] !== 3) throw new Error(`input error: attempted to use tensor with unrecognized shape: ${input['shape']}`);\n if ((tensor as Tensor).dtype === 'int32') {\n const cast = tf.cast(tensor, 'float32');\n tf.dispose(tensor);\n tensor = cast;\n }\n return { tensor, canvas: (config.filter.return ? outCanvas : null) };\n } else {\n // check if resizing will be needed\n if (typeof input['readyState'] !== 'undefined' && input['readyState'] <= 2) {\n if (config.debug) log('input stream is not ready');\n return { tensor: null, canvas: inCanvas }; // video may become temporarily unavailable due to onresize\n }\n const originalWidth = input['naturalWidth'] || input['videoWidth'] || input['width'] || (input['shape'] && (input['shape'][1] > 0));\n const originalHeight = input['naturalHeight'] || input['videoHeight'] || input['height'] || (input['shape'] && (input['shape'][2] > 0));\n if (!originalWidth || !originalHeight) {\n if (config.debug) log('cannot determine input dimensions');\n return { tensor: null, canvas: inCanvas }; // video may become temporarily unavailable due to onresize\n }\n let targetWidth = originalWidth;\n let targetHeight = originalHeight;\n if (targetWidth > maxSize) {\n targetWidth = maxSize;\n targetHeight = Math.trunc(targetWidth * originalHeight / originalWidth);\n }\n if (targetHeight > maxSize) {\n targetHeight = maxSize;\n targetWidth = Math.trunc(targetHeight * originalWidth / originalHeight);\n }\n\n // create our canvas and resize it if needed\n if ((config.filter.width || 0) > 0) targetWidth = config.filter.width;\n else if ((config.filter.height || 0) > 0) targetWidth = originalWidth * ((config.filter.height || 0) / originalHeight);\n if ((config.filter.height || 0) > 0) targetHeight = config.filter.height;\n else if ((config.filter.width || 0) > 0) targetHeight = originalHeight * ((config.filter.width || 0) / originalWidth);\n if (!targetWidth || !targetHeight) throw new Error('input error: cannot determine dimension');\n if (!inCanvas || (inCanvas?.width !== targetWidth) || (inCanvas?.height !== targetHeight)) inCanvas = canvas(targetWidth, targetHeight);\n\n // draw input to our canvas\n const inCtx = inCanvas.getContext('2d') as CanvasRenderingContext2D;\n if ((typeof ImageData !== 'undefined') && (input instanceof ImageData)) {\n inCtx.putImageData(input, 0, 0);\n } else {\n if (config.filter.flip && typeof inCtx.translate !== 'undefined') {\n inCtx.translate(originalWidth, 0);\n inCtx.scale(-1, 1);\n inCtx.drawImage(input as AnyCanvas, 0, 0, originalWidth, originalHeight, 0, 0, inCanvas?.width, inCanvas?.height);\n inCtx.setTransform(1, 0, 0, 1, 0, 0); // resets transforms to defaults\n } else {\n inCtx.drawImage(input as AnyCanvas, 0, 0, originalWidth, originalHeight, 0, 0, inCanvas?.width, inCanvas?.height);\n }\n }\n\n if (!outCanvas || (inCanvas.width !== outCanvas.width) || (inCanvas?.height !== outCanvas?.height)) outCanvas = canvas(inCanvas.width, inCanvas.height); // init output canvas\n\n // imagefx transforms using gl from input canvas to output canvas\n if (config.filter.enabled && env.webgl.supported) {\n if (!fx) fx = env.browser ? new fxImage.GLImageFilter() : null; // && (typeof document !== 'undefined')\n env.filter = !!fx;\n if (!fx || !fx.add) {\n if (config.debug) log('input process error: cannot initialize filters');\n env.webgl.supported = false;\n config.filter.enabled = false;\n copy(inCanvas, outCanvas); // filter failed to initialize\n // return { tensor: null, canvas: inCanvas };\n } else {\n fx.reset();\n if (config.filter.brightness !== 0) fx.add('brightness', config.filter.brightness);\n if (config.filter.contrast !== 0) fx.add('contrast', config.filter.contrast);\n if (config.filter.sharpness !== 0) fx.add('sharpen', config.filter.sharpness);\n if (config.filter.blur !== 0) fx.add('blur', config.filter.blur);\n if (config.filter.saturation !== 0) fx.add('saturation', config.filter.saturation);\n if (config.filter.hue !== 0) fx.add('hue', config.filter.hue);\n if (config.filter.negative) fx.add('negative');\n if (config.filter.sepia) fx.add('sepia');\n if (config.filter.vintage) fx.add('brownie');\n if (config.filter.sepia) fx.add('sepia');\n if (config.filter.kodachrome) fx.add('kodachrome');\n if (config.filter.technicolor) fx.add('technicolor');\n if (config.filter.polaroid) fx.add('polaroid');\n if (config.filter.pixelate !== 0) fx.add('pixelate', config.filter.pixelate);\n if (fx.get() > 0) outCanvas = fx.apply(inCanvas);\n else outCanvas = fx.draw(inCanvas);\n }\n } else {\n copy(inCanvas, outCanvas); // if no filters applied, output canvas is input canvas\n if (fx) fx = null;\n env.filter = !!fx;\n }\n\n if (!getTensor) return { tensor: null, canvas: outCanvas }; // just canvas was requested\n if (!outCanvas) throw new Error('canvas error: cannot create output');\n\n // create tensor from image unless input was a tensor already\n let pixels;\n let depth = 3;\n if ((typeof ImageData !== 'undefined' && input instanceof ImageData) || (input['data'] && input['width'] && input['height'])) { // if input is imagedata, just use it\n if (env.browser && tf.browser) {\n pixels = tf.browser ? tf.browser.fromPixels(input) : null;\n } else {\n depth = input['data'].length / input['height'] / input['width'];\n // const arr = Uint8Array.from(input['data']);\n const arr = new Uint8Array(input['data']['buffer']);\n pixels = tf.tensor(arr, [input['height'], input['width'], depth], 'int32');\n }\n } else {\n if (!tmpCanvas || (outCanvas.width !== tmpCanvas.width) || (outCanvas.height !== tmpCanvas.height)) tmpCanvas = canvas(outCanvas.width, outCanvas.height); // init output canvas\n if (tf.browser && env.browser) {\n if (config.backend === 'webgl' || config.backend === 'humangl' || config.backend === 'webgpu') {\n pixels = tf.browser.fromPixels(outCanvas); // safe to reuse since both backend and context are gl based\n } else {\n tmpCanvas = copy(outCanvas); // cannot use output canvas as it already has gl context so we do a silly one more canvas\n pixels = tf.browser.fromPixels(tmpCanvas);\n }\n } else {\n const tempCanvas = copy(outCanvas); // cannot use output canvas as it already has gl context so we do a silly one more canvas\n const tempCtx = tempCanvas.getContext('2d') as CanvasRenderingContext2D;\n const tempData = tempCtx.getImageData(0, 0, targetWidth, targetHeight);\n depth = tempData.data.length / targetWidth / targetHeight;\n const arr = new Uint8Array(tempData.data.buffer);\n pixels = tf.tensor(arr, [targetWidth, targetHeight, depth]);\n }\n }\n if (depth === 4) { // rgba to rgb\n const rgb = tf.slice3d(pixels, [0, 0, 0], [-1, -1, 3]); // strip alpha channel\n tf.dispose(pixels);\n pixels = rgb;\n }\n if (!pixels) throw new Error('input error: cannot create tensor');\n const casted = tf.cast(pixels, 'float32');\n const tensor = config.filter.equalization ? await enhance.histogramEqualization(casted) : tf.expandDims(casted, 0);\n tf.dispose([pixels, casted]);\n return { tensor, canvas: (config.filter.return ? outCanvas : null) };\n }\n}\n\n/*\nconst checksum = async (input: Tensor): Promise => { // use tf sum or js based sum loop depending on which is faster\n const resizeFact = 48;\n const reduced: Tensor = tf.image.resizeBilinear(input, [Math.trunc((input.shape[1] || 1) / resizeFact), Math.trunc((input.shape[2] || 1) / resizeFact)]);\n const tfSum = async (): Promise => {\n const sumT = tf.sum(reduced);\n const sum0 = await sumT.data();\n tf.dispose(sumT);\n return sum0[0];\n };\n const jsSum = async (): Promise => {\n const reducedData = await reduced.data(); // raw image rgb array\n let sum0 = 0;\n for (let i = 0; i < reducedData.length / 3; i++) sum0 += reducedData[3 * i + 2]; // look only at green value of each pixel\n return sum0;\n };\n if (last.sumMethod === 0) {\n const t0 = now();\n await jsSum();\n const t1 = now();\n await tfSum();\n const t2 = now();\n last.sumMethod = t1 - t0 < t2 - t1 ? 1 : 2;\n }\n const res = last.sumMethod === 1 ? await jsSum() : await tfSum();\n tf.dispose(reduced);\n return res;\n};\n*/\n\nexport async function skip(config: Partial, input: Tensor) {\n let skipFrame = false;\n if (config.cacheSensitivity === 0 || !input.shape || input.shape.length !== 4 || input.shape[1] > 2048 || input.shape[2] > 2048) return skipFrame; // cache disabled or input is invalid or too large for cache analysis\n\n /*\n const checkSum = await checksum(input);\n const diff = 100 * (Math.max(checkSum, last.inputSum) / Math.min(checkSum, last.inputSum) - 1);\n last.inputSum = checkSum;\n // if previous frame was skipped, skip this frame if changed more than cacheSensitivity\n // if previous frame was not skipped, then look for cacheSensitivity or difference larger than one in previous frame to avoid resetting cache in subsequent frames unnecessarily\n let skipFrame = diff < Math.max(config.cacheSensitivity, last.cacheDiff);\n // if difference is above 10x threshold, don't use last value to force reset cache for significant change of scenes or images\n last.cacheDiff = diff > 10 * config.cacheSensitivity ? 0 : diff;\n skipFrame = skipFrame && (last.cacheDiff > 0); // if no cached diff value then force no skip\n */\n\n if (!last.inputTensor) {\n last.inputTensor = tf.clone(input);\n } else if (last.inputTensor.shape[1] !== input.shape[1] || last.inputTensor.shape[2] !== input.shape[2]) { // input resolution changed\n tf.dispose(last.inputTensor);\n last.inputTensor = tf.clone(input);\n } else {\n const t: Record = {};\n t.diff = tf.sub(input, last.inputTensor);\n t.squared = tf.mul(t.diff, t.diff);\n t.sum = tf.sum(t.squared);\n const diffSum = await t.sum.data();\n const diffRelative = diffSum[0] / (input.shape[1] || 1) / (input.shape[2] || 1) / 255 / 3; // squared difference relative to input resolution and averaged per channel\n tf.dispose([last.inputTensor, t.diff, t.squared, t.sum]);\n last.inputTensor = tf.clone(input);\n skipFrame = diffRelative <= (config.cacheSensitivity || 0);\n }\n return skipFrame;\n}\n\nexport async function compare(config: Partial, input1: Tensor, input2: Tensor): Promise {\n const t: Record = {};\n if (!input1 || !input2 || input1.shape.length !== 4 || input1.shape.length !== input2.shape.length) {\n if (!config.debug) log('invalid input tensor or tensor shapes do not match:', input1.shape, input2.shape);\n return 0;\n }\n if (input1.shape[0] !== 1 || input2.shape[0] !== 1 || input1.shape[3] !== 3 || input2.shape[3] !== 3) {\n if (!config.debug) log('input tensors must be of shape [1, height, width, 3]:', input1.shape, input2.shape);\n return 0;\n }\n t.input1 = tf.clone(input1);\n t.input2 = (input1.shape[1] !== input2.shape[1] || input1.shape[2] !== input2.shape[2]) ? tf.image.resizeBilinear(input2, [input1.shape[1], input1.shape[2]]) : tf.clone(input2);\n t.diff = tf.sub(t.input1, t.input2);\n t.squared = tf.mul(t.diff, t.diff);\n t.sum = tf.sum(t.squared);\n const diffSum = await t.sum.data();\n const diffRelative = diffSum[0] / (input1.shape[1] || 1) / (input1.shape[2] || 1) / 255 / 3;\n tf.dispose([t.input1, t.input2, t.diff, t.squared, t.sum]);\n return diffRelative;\n}\n", "import * as tf from '../../dist/tfjs.esm.js';\nimport * as image from '../image/image';\n\n/** Env class that holds detected capabilities */\nexport class Env {\n /** Running in Browser */\n browser: boolean;\n /** Running in NodeJS */\n node: boolean;\n /** Running in WebWorker thread */\n worker: boolean;\n /** Detected platform */\n platform: string = '';\n /** Detected agent */\n agent: string = '';\n /** List of supported backends */\n backends: string[] = [];\n /** Has any work been performed so far */\n initial: boolean;\n /** Are image filters supported? */\n filter: boolean | undefined;\n /** TFJS instance details */\n tfjs: {\n version: undefined | string,\n };\n /** Is offscreenCanvas supported? */\n offscreen: undefined | boolean;\n /** Are performance counter instant values or additive */\n perfadd: boolean = false;\n /** WASM detected capabilities */\n wasm: {\n supported: undefined | boolean,\n backend: undefined | boolean,\n simd: undefined | boolean,\n multithread: undefined | boolean,\n } = {\n supported: undefined,\n backend: undefined,\n simd: undefined,\n multithread: undefined,\n };\n /** WebGL detected capabilities */\n webgl: {\n supported: undefined | boolean,\n backend: undefined | boolean,\n version: undefined | string,\n renderer: undefined | string,\n } = {\n supported: undefined,\n backend: undefined,\n version: undefined,\n renderer: undefined,\n };\n /** WebGPU detected capabilities */\n webgpu: {\n supported: undefined | boolean,\n backend: undefined | boolean,\n adapter: undefined | string,\n } = {\n supported: undefined,\n backend: undefined,\n adapter: undefined,\n };\n /** CPU info */\n cpu: {\n model: undefined | string,\n flags: string[],\n } = {\n model: undefined,\n flags: [],\n };\n /** List of supported kernels for current backend */\n kernels: string[] = [];\n /** MonkeyPatch for Canvas */\n Canvas: undefined;\n /** MonkeyPatch for Image */\n Image: undefined;\n /** MonkeyPatch for ImageData */\n ImageData: undefined;\n\n constructor() {\n this.browser = typeof navigator !== 'undefined';\n this.node = (typeof process !== 'undefined') && (typeof process.versions !== 'undefined') && (typeof process.versions.node !== 'undefined');\n this.tfjs = { version: tf.version['tfjs-core'] };\n this.offscreen = typeof OffscreenCanvas !== 'undefined';\n this.initial = true;\n // @ts-ignore WorkerGlobalScope evaluated in browser only\n this.worker = this.browser && this.offscreen ? (typeof WorkerGlobalScope !== 'undefined') : undefined;\n if (typeof navigator !== 'undefined') {\n const raw = navigator.userAgent.match(/\\(([^()]+)\\)/g);\n if (raw && raw[0]) {\n const platformMatch = raw[0].match(/\\(([^()]+)\\)/g);\n this.platform = (platformMatch && platformMatch[0]) ? platformMatch[0].replace(/\\(|\\)/g, '') : '';\n this.agent = navigator.userAgent.replace(raw[0], '');\n if (this.platform[1]) this.agent = this.agent.replace(raw[1], '');\n this.agent = this.agent.replace(/ /g, ' ');\n // chrome offscreencanvas gpu memory leak\n /*\n const isChrome = env.agent.match(/Chrome\\/.[0-9]/g);\n const verChrome = isChrome && isChrome[0] ? isChrome[0].split('/')[1] : 0;\n if (verChrome > 92 && verChrome < 96) {\n log('disabling offscreenCanvas due to browser error:', isChrome ? isChrome[0] : 'unknown');\n this.offscreen = false;\n }\n */\n }\n } else if (typeof process !== 'undefined') {\n this.platform = `${process.platform} ${process.arch}`;\n this.agent = `NodeJS ${process.version}`;\n }\n }\n\n /** update backend information */\n async updateBackend() {\n // analyze backends\n this.backends = Object.keys(tf.engine().registryFactory);\n this.wasm.supported = typeof WebAssembly !== 'undefined';\n this.wasm.backend = this.backends.includes('wasm');\n if (this.wasm.supported && this.wasm.backend && tf.getBackend() === 'wasm') {\n this.wasm.simd = await tf.env().getAsync('WASM_HAS_SIMD_SUPPORT');\n this.wasm.multithread = await tf.env().getAsync('WASM_HAS_MULTITHREAD_SUPPORT');\n }\n const c = image.canvas(100, 100);\n const ctx = c ? c.getContext('webgl2') : undefined; // causes too many gl contexts\n // const ctx = typeof tf.backend().getGPGPUContext !== undefined ? tf.backend().getGPGPUContext : null;\n this.webgl.supported = typeof ctx !== 'undefined';\n this.webgl.backend = this.backends.includes('webgl');\n if (this.webgl.supported && this.webgl.backend && (tf.getBackend() === 'webgl' || tf.getBackend() === 'humangl')) {\n // @ts-ignore getGPGPUContext only exists on WebGL backend\n const gl = tf.backend().gpgpu !== 'undefined' ? await tf.backend().getGPGPUContext().gl : null;\n if (gl) {\n this.webgl.version = gl.getParameter(gl.VERSION);\n this.webgl.renderer = gl.getParameter(gl.RENDERER);\n }\n }\n // @ts-ignore navigator.gpu is only defined when webgpu is available in browser\n this.webgpu.supported = this.browser && typeof navigator['gpu'] !== 'undefined';\n this.webgpu.backend = this.backends.includes('webgpu');\n try {\n // @ts-ignore navigator.gpu is only defined when webgpu is available in browser\n if (this.webgpu.supported) this.webgpu.adapter = (await navigator['gpu'].requestAdapter()).name;\n } catch {\n this.webgpu.supported = false;\n }\n try {\n this.kernels = tf.getKernelsForBackend(tf.getBackend()).map((kernel) => kernel.kernelName.toLowerCase());\n } catch { /**/ }\n }\n\n /** update cpu information */\n async updateCPU() {\n const cpu = { model: '', flags: [] };\n if (this.node && this.platform.startsWith('linux')) {\n /*\n // eslint-disable-next-line global-require\n const fs = require('fs');\n try {\n const data = fs.readFileSync('/proc/cpuinfo').toString();\n for (const line of data.split('\\n')) {\n if (line.startsWith('model name')) {\n cpu.model = line.match(/:(.*)/g)[0].replace(':', '').trim();\n }\n if (line.startsWith('flags')) {\n cpu.flags = line.match(/:(.*)/g)[0].replace(':', '').trim().split(' ').sort();\n }\n }\n } catch { }\n */\n }\n if (!this['cpu']) Object.defineProperty(this, 'cpu', { value: cpu });\n else this['cpu'] = cpu;\n }\n}\n\nexport const env = new Env();\n", "import { log, join } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport type { GraphModel } from './types';\nimport type { Config } from '../config';\n\nconst options = {\n cacheModels: false,\n verbose: true,\n debug: false,\n modelBasePath: '',\n};\n\nasync function httpHandler(url, init?): Promise {\n if (options.debug) log('load model fetch:', url, init);\n return fetch(url, init);\n}\n\nexport function setModelLoadOptions(config: Config) {\n options.cacheModels = config.cacheModels;\n options.verbose = config.debug;\n options.modelBasePath = config.modelBasePath;\n}\n\nexport async function loadModel(modelPath: string | undefined): Promise {\n let modelUrl = join(options.modelBasePath, modelPath || '');\n if (!modelUrl.toLowerCase().endsWith('.json')) modelUrl += '.json';\n const modelPathSegments = modelUrl.split('/');\n const cachedModelName = 'indexeddb://' + modelPathSegments[modelPathSegments.length - 1].replace('.json', ''); // generate short model name for cache\n const cachedModels = await tf.io.listModels(); // list all models already in cache\n const modelCached = options.cacheModels && Object.keys(cachedModels).includes(cachedModelName); // is model found in cache\n const tfLoadOptions = typeof fetch === 'undefined' ? {} : { fetchFunc: (url, init?) => httpHandler(url, init) };\n const model: GraphModel = new tf.GraphModel(modelCached ? cachedModelName : modelUrl, tfLoadOptions) as unknown as GraphModel; // create model prototype and decide if load from cache or from original modelurl\n let loaded = false;\n try {\n // @ts-ignore private function\n model.findIOHandler(); // decide how to actually load a model\n // @ts-ignore private property\n if (options.debug) log('model load handler:', model.handler);\n // @ts-ignore private property\n const artifacts = await model.handler.load(); // load manifest\n model.loadSync(artifacts); // load weights\n if (options.verbose) log('load model:', model['modelUrl']);\n loaded = true;\n } catch (err) {\n log('error loading model:', modelUrl, err);\n }\n if (loaded && options.cacheModels && !modelCached) { // save model to cache\n try {\n const saveResult = await model.save(cachedModelName);\n log('model saved:', cachedModelName, saveResult);\n } catch (err) {\n log('error saving model:', modelUrl, err);\n }\n }\n return model;\n}\n", "/**\n * Loader and Validator for all models used by Human\n */\n\nimport { env } from './util/env';\nimport { log } from './util/util';\nimport * as gear from './gear/gear';\nimport * as ssrnetAge from './gear/ssrnet-age';\nimport * as ssrnetGender from './gear/ssrnet-gender';\nimport * as antispoof from './face/antispoof';\nimport * as blazeface from './face/blazeface';\nimport * as blazepose from './body/blazepose';\nimport * as centernet from './object/centernet';\nimport * as efficientpose from './body/efficientpose';\nimport * as emotion from './gear/emotion';\nimport * as mobilefacenet from './face/mobilefacenet';\nimport * as facemesh from './face/facemesh';\nimport * as faceres from './face/faceres';\nimport * as handpose from './hand/handpose';\nimport * as handtrack from './hand/handtrack';\nimport * as iris from './face/iris';\nimport * as liveness from './face/liveness';\nimport * as movenet from './body/movenet';\nimport * as nanodet from './object/nanodet';\nimport * as posenet from './body/posenet';\nimport * as segmentation from './segmentation/segmentation';\nimport type { GraphModel } from './tfjs/types';\nimport type { Human } from './human';\n\n/** Instances of all possible TFJS Graph Models used by Human\n * - loaded as needed based on configuration\n * - initialized explictly with `human.load()` method\n * - initialized implicity on first call to `human.detect()`\n * - each model can be `null` if not loaded, instance of `GraphModel` if loaded or `Promise` if loading\n */\nexport class Models {\n ssrnetage: null | GraphModel | Promise = null;\n gear: null | GraphModel | Promise = null;\n blazeposedetect: null | GraphModel | Promise = null;\n blazepose: null | GraphModel | Promise = null;\n centernet: null | GraphModel | Promise = null;\n efficientpose: null | GraphModel | Promise = null;\n mobilefacenet: null | GraphModel | Promise = null;\n emotion: null | GraphModel | Promise = null;\n facedetect: null | GraphModel | Promise = null;\n faceiris: null | GraphModel | Promise = null;\n facemesh: null | GraphModel | Promise = null;\n faceres: null | GraphModel | Promise = null;\n ssrnetgender: null | GraphModel | Promise = null;\n handpose: null | GraphModel | Promise = null;\n handskeleton: null | GraphModel | Promise = null;\n handtrack: null | GraphModel | Promise = null;\n liveness: null | GraphModel | Promise = null;\n movenet: null | GraphModel | Promise = null;\n nanodet: null | GraphModel | Promise = null;\n posenet: null | GraphModel | Promise = null;\n segmentation: null | GraphModel | Promise = null;\n antispoof: null | GraphModel | Promise = null;\n}\n\nexport function reset(instance: Human): void {\n // if (instance.config.debug) log('resetting loaded models');\n for (const model of Object.keys(instance.models)) instance.models[model as keyof Models] = null;\n}\n\n/** Load method preloads all instance.configured models on-demand */\nexport async function load(instance: Human): Promise {\n if (env.initial) reset(instance);\n if (instance.config.hand.enabled) { // handpose model is a combo that must be loaded as a whole\n if (!instance.models.handpose && instance.config.hand.detector?.modelPath?.includes('handdetect')) [instance.models.handpose, instance.models.handskeleton] = await handpose.load(instance.config);\n if (!instance.models.handskeleton && instance.config.hand.landmarks && instance.config.hand.detector?.modelPath?.includes('handdetect')) [instance.models.handpose, instance.models.handskeleton] = await handpose.load(instance.config);\n }\n if (instance.config.body.enabled && !instance.models.blazepose && instance.config.body?.modelPath?.includes('blazepose')) instance.models.blazepose = blazepose.loadPose(instance.config);\n // @ts-ignore optional model\n if (instance.config.body.enabled && !instance.models.blazeposedetect && instance.config.body['detector'] && instance.config.body['detector']['modelPath']) instance.models.blazeposedetect = blazepose.loadDetect(instance.config);\n if (instance.config.body.enabled && !instance.models.efficientpose && instance.config.body?.modelPath?.includes('efficientpose')) instance.models.efficientpose = efficientpose.load(instance.config);\n if (instance.config.body.enabled && !instance.models.movenet && instance.config.body?.modelPath?.includes('movenet')) instance.models.movenet = movenet.load(instance.config);\n if (instance.config.body.enabled && !instance.models.posenet && instance.config.body?.modelPath?.includes('posenet')) instance.models.posenet = posenet.load(instance.config);\n if (instance.config.face.enabled && !instance.models.facedetect) instance.models.facedetect = blazeface.load(instance.config);\n if (instance.config.face.enabled && instance.config.face.antispoof?.enabled && !instance.models.antispoof) instance.models.antispoof = antispoof.load(instance.config);\n if (instance.config.face.enabled && instance.config.face.liveness?.enabled && !instance.models.liveness) instance.models.liveness = liveness.load(instance.config);\n if (instance.config.face.enabled && instance.config.face.description?.enabled && !instance.models.faceres) instance.models.faceres = faceres.load(instance.config);\n if (instance.config.face.enabled && instance.config.face.emotion?.enabled && !instance.models.emotion) instance.models.emotion = emotion.load(instance.config);\n if (instance.config.face.enabled && instance.config.face.iris?.enabled && !instance.config.face.attention?.enabled && !instance.models.faceiris) instance.models.faceiris = iris.load(instance.config);\n if (instance.config.face.enabled && instance.config.face.mesh?.enabled && !instance.models.facemesh) instance.models.facemesh = facemesh.load(instance.config);\n // @ts-ignore optional model\n if (instance.config.face.enabled && instance.config.face['gear']?.enabled && !instance.models.gear) instance.models.gear = gear.load(instance.config);\n // @ts-ignore optional model\n if (instance.config.face.enabled && instance.config.face['ssrnet']?.enabled && !instance.models.ssrnetage) instance.models.ssrnetage = ssrnetAge.load(instance.config);\n // @ts-ignore optional model\n if (instance.config.face.enabled && instance.config.face['ssrnet']?.enabled && !instance.models.ssrnetgender) instance.models.ssrnetgender = ssrnetGender.load(instance.config);\n // @ts-ignore optional model\n if (instance.config.face.enabled && instance.config.face['mobilefacenet']?.enabled && !instance.models.mobilefacenet) instance.models.mobilefacenet = mobilefacenet.load(instance.config);\n if (instance.config.hand.enabled && !instance.models.handtrack && instance.config.hand.detector?.modelPath?.includes('handtrack')) instance.models.handtrack = handtrack.loadDetect(instance.config);\n if (instance.config.hand.enabled && instance.config.hand.landmarks && !instance.models.handskeleton && instance.config.hand.detector?.modelPath?.includes('handtrack')) instance.models.handskeleton = handtrack.loadSkeleton(instance.config);\n if (instance.config.object.enabled && !instance.models.centernet && instance.config.object?.modelPath?.includes('centernet')) instance.models.centernet = centernet.load(instance.config);\n if (instance.config.object.enabled && !instance.models.nanodet && instance.config.object?.modelPath?.includes('nanodet')) instance.models.nanodet = nanodet.load(instance.config);\n if (instance.config.segmentation.enabled && !instance.models.segmentation) instance.models.segmentation = segmentation.load(instance.config);\n\n // models are loaded in parallel asynchronously so lets wait until they are actually loaded\n for await (const model of Object.keys(instance.models)) {\n if (instance.models[model as keyof Models] && typeof instance.models[model as keyof Models] !== 'undefined') instance.models[model as keyof Models] = await instance.models[model as keyof Models];\n }\n}\n\nexport async function validate(instance: Human): Promise {\n interface Op { name: string, category: string, op: string }\n const simpleOps = ['const', 'placeholder', 'noop', 'pad', 'squeeze', 'add', 'sub', 'mul', 'div'];\n for (const defined of Object.keys(instance.models)) {\n const model: GraphModel | null = instance.models[defined as keyof Models] as GraphModel | null;\n if (!model) continue;\n const ops: string[] = [];\n // @ts-ignore // executor is a private method\n const executor = model?.executor;\n if (executor && executor.graph.nodes) {\n for (const kernel of Object.values(executor.graph.nodes)) {\n const op = (kernel as Op).op.toLowerCase();\n if (!ops.includes(op)) ops.push(op);\n }\n } else {\n if (!executor && instance.config.debug) log('model signature not determined:', defined);\n }\n const missing: string[] = [];\n for (const op of ops) {\n if (!simpleOps.includes(op) // exclude simple ops\n && !instance.env.kernels.includes(op) // check actual kernel ops\n && !instance.env.kernels.includes(op.replace('_', '')) // check variation without _\n && !instance.env.kernels.includes(op.replace('native', '')) // check standard variation\n && !instance.env.kernels.includes(op.replace('v2', ''))) { // check non-versioned variation\n missing.push(op);\n }\n }\n // log('model validation ops:', defined, ops);\n if (instance.config.debug && missing.length > 0) log('model validation failed:', defined, missing);\n }\n}\n", "/**\n * GEAR [gender/emotion/age/race] model implementation\n *\n * Based on: [**GEAR Predictor**](https://github.com/Udolf15/GEAR-Predictor)\n */\n\nimport { log, now } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport type { Gender, Race } from '../result';\nimport type { Config } from '../config';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport { env } from '../util/env';\n\nexport type GearType = { age: number, gender: Gender, genderScore: number, race: Array<{ score: number, race: Race }> }\nlet model: GraphModel | null;\nconst last: Array = [];\nconst raceNames = ['white', 'black', 'asian', 'indian', 'other'];\nconst ageWeights = [15, 23, 28, 35.5, 45.5, 55.5, 65];\nlet lastCount = 0;\nlet lastTime = 0;\nlet skipped = Number.MAX_SAFE_INTEGER;\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport async function load(config: Config) {\n if (env.initial) model = null;\n if (!model) model = await loadModel(config.face['gear']);\n else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport async function predict(image: Tensor, config: Config, idx: number, count: number): Promise {\n if (!model) return { age: 0, gender: 'unknown', genderScore: 0, race: [] };\n const skipFrame = skipped < (config.face['gear']?.skipFrames || 0);\n const skipTime = (config.face['gear']?.skipTime || 0) > (now() - lastTime);\n if (config.skipAllowed && skipTime && skipFrame && (lastCount === count) && last[idx]) {\n skipped++;\n return last[idx];\n }\n skipped = 0;\n return new Promise(async (resolve) => {\n if (!model?.inputs[0].shape) return;\n const t: Record = {};\n // t.resize = tf.image.resizeBilinear(image, [model?.inputs[0].shape[2], model?.inputs[0].shape[1]], false);\n const box = [[0.0, 0.10, 0.90, 0.90]]; // empyrical values for top, left, bottom, right\n t.resize = tf.image.cropAndResize(image, box, [0], [model.inputs[0].shape[2], model.inputs[0].shape[1]]);\n const obj: GearType = { age: 0, gender: 'unknown', genderScore: 0, race: [] };\n if (config.face['gear']?.enabled) [t.age, t.gender, t.race] = model.execute(t.resize, ['age_output', 'gender_output', 'race_output']) as Tensor[];\n const gender = await t.gender.data();\n obj.gender = gender[0] > gender[1] ? 'male' : 'female';\n obj.genderScore = Math.round(100 * (gender[0] > gender[1] ? gender[0] : gender[1])) / 100;\n const race = await t.race.data();\n for (let i = 0; i < race.length; i++) {\n if (race[i] > (config.face['gear']?.minConfidence || 0.2)) obj.race.push({ score: Math.round(100 * race[i]) / 100, race: raceNames[i] as Race });\n }\n obj.race.sort((a, b) => b.score - a.score);\n // {0: 'Below20', 1: '21-25', 2: '26-30', 3: '31-40',4: '41-50', 5: '51-60', 6: 'Above60'}\n const ageDistribution = Array.from(await t.age.data());\n const ageSorted = ageDistribution.map((a, i) => [ageWeights[i], a]).sort((a, b) => b[1] - a[1]);\n let age = ageSorted[0][0]; // pick best starting point\n for (let i = 1; i < ageSorted.length; i++) age += ageSorted[i][1] * (ageSorted[i][0] - age); // adjust with each other choice by weight\n obj.age = Math.round(10 * age) / 10;\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n last[idx] = obj;\n lastCount = count;\n lastTime = now();\n resolve(obj);\n });\n}\n", "import * as tf from '../../dist/tfjs.esm.js';\nimport type { Tensor } from './types';\n\nexport const constants: Record = {\n tf255: 255,\n tf1: 1,\n tf2: 2,\n tf05: 0.5,\n tf127: 127.5,\n rgb: [0.2989, 0.5870, 0.1140],\n};\n\nexport function init() {\n constants.tf255 = tf.scalar(255, 'float32');\n constants.tf1 = tf.scalar(1, 'float32');\n constants.tf2 = tf.scalar(2, 'float32');\n constants.tf05 = tf.scalar(0.5, 'float32');\n constants.tf127 = tf.scalar(127.5, 'float32');\n constants.rgb = tf.tensor1d([0.2989, 0.5870, 0.1140], 'float32'); // factors for red/green/blue colors when converting to grayscale\n}\n", "/**\n * Age model implementation\n *\n * Based on: [**SSR-Net**](https://github.com/shamangary/SSR-Net)\n */\n\nimport { log, now } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport { env } from '../util/env';\nimport { constants } from '../tfjs/constants';\nimport type { Config } from '../config';\nimport type { GraphModel, Tensor } from '../tfjs/types';\n\nlet model: GraphModel | null;\nconst last: Array<{ age: number }> = [];\nlet lastCount = 0;\nlet lastTime = 0;\nlet skipped = Number.MAX_SAFE_INTEGER;\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport async function load(config: Config) {\n if (env.initial) model = null;\n if (!model) model = await loadModel(config.face['ssrnet'].modelPathAge);\n else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport async function predict(image: Tensor, config: Config, idx: number, count: number): Promise<{ age: number }> {\n if (!model) return { age: 0 };\n const skipFrame = skipped < (config.face['ssrnet']?.skipFrames || 0);\n const skipTime = (config.face['ssrnet']?.skipTime || 0) > (now() - lastTime);\n if (config.skipAllowed && skipFrame && skipTime && (lastCount === count) && last[idx]?.age && (last[idx]?.age > 0)) {\n skipped++;\n return last[idx];\n }\n skipped = 0;\n return new Promise(async (resolve) => {\n if (!model?.inputs || !model.inputs[0] || !model.inputs[0].shape) return;\n const t: Record = {};\n t.resize = tf.image.resizeBilinear(image, [model.inputs[0].shape[2], model.inputs[0].shape[1]], false);\n t.enhance = tf.mul(t.resize, constants.tf255);\n const obj = { age: 0 };\n if (config.face['ssrnet'].enabled) t.age = model.execute(t.enhance) as Tensor;\n if (t.age) {\n const data = await t.age.data();\n obj.age = Math.trunc(10 * data[0]) / 10;\n }\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n last[idx] = obj;\n lastCount = count;\n lastTime = now();\n resolve(obj);\n });\n}\n", "/**\n * Gender model implementation\n *\n * Based on: [**SSR-Net**](https://github.com/shamangary/SSR-Net)\n */\n\nimport { log, now } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport { constants } from '../tfjs/constants';\nimport type { Gender } from '../result';\nimport type { Config } from '../config';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport { env } from '../util/env';\n\nlet model: GraphModel | null;\nconst last: Array<{ gender: Gender, genderScore: number }> = [];\nlet lastCount = 0;\nlet lastTime = 0;\nlet skipped = Number.MAX_SAFE_INTEGER;\n\n// tuning values\nconst rgb = [0.2989, 0.5870, 0.1140]; // factors for red/green/blue colors when converting to grayscale\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport async function load(config: Config | any) {\n if (env.initial) model = null;\n if (!model) model = await loadModel(config.face['ssrnet'].modelPathGender);\n else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport async function predict(image: Tensor, config: Config, idx, count): Promise<{ gender: Gender, genderScore: number }> {\n if (!model) return { gender: 'unknown', genderScore: 0 };\n const skipFrame = skipped < (config.face['ssrnet']?.skipFrames || 0);\n const skipTime = (config.face['ssrnet']?.skipTime || 0) > (now() - lastTime);\n if (config.skipAllowed && skipFrame && skipTime && (lastCount === count) && last[idx]?.gender && (last[idx]?.genderScore > 0)) {\n skipped++;\n return last[idx];\n }\n skipped = 0;\n return new Promise(async (resolve) => {\n if (!model?.inputs[0].shape) return;\n const t: Record = {};\n t.resize = tf.image.resizeBilinear(image, [model.inputs[0].shape[2], model.inputs[0].shape[1]], false);\n t.enhance = tf.tidy(() => {\n const [red, green, blue] = tf.split(t.resize, 3, 3);\n const redNorm = tf.mul(red, rgb[0]);\n const greenNorm = tf.mul(green, rgb[1]);\n const blueNorm = tf.mul(blue, rgb[2]);\n const grayscale = tf.addN([redNorm, greenNorm, blueNorm]);\n const normalize = tf.mul(tf.sub(grayscale, constants.tf05), 2); // range grayscale:-1..1\n return normalize;\n });\n const obj: { gender: Gender, genderScore: number } = { gender: 'unknown', genderScore: 0 };\n if (config.face['ssrnet'].enabled) t.gender = model.execute(t.enhance) as Tensor;\n const data = await t.gender.data();\n obj.gender = data[0] > data[1] ? 'female' : 'male'; // returns two values 0..1, bigger one is prediction\n obj.genderScore = data[0] > data[1] ? (Math.trunc(100 * data[0]) / 100) : (Math.trunc(100 * data[1]) / 100);\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n last[idx] = obj;\n lastCount = count;\n lastTime = now();\n resolve(obj);\n });\n}\n", "/**\n * Anti-spoofing model implementation\n */\n\nimport { log, now } from '../util/util';\nimport type { Config } from '../config';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport { env } from '../util/env';\n\nlet model: GraphModel | null;\nconst cached: Array = [];\nlet skipped = Number.MAX_SAFE_INTEGER;\nlet lastCount = 0;\nlet lastTime = 0;\n\nexport async function load(config: Config): Promise {\n if (env.initial) model = null;\n if (!model) model = await loadModel(config.face.antispoof?.modelPath);\n else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\nexport async function predict(image: Tensor, config: Config, idx: number, count: number): Promise {\n if (!model) return 0;\n const skipTime = (config.face.antispoof?.skipTime || 0) > (now() - lastTime);\n const skipFrame = skipped < (config.face.antispoof?.skipFrames || 0);\n if (config.skipAllowed && skipTime && skipFrame && (lastCount === count) && cached[idx]) {\n skipped++;\n return cached[idx];\n }\n skipped = 0;\n return new Promise(async (resolve) => {\n const resize = tf.image.resizeBilinear(image, [model?.inputs[0].shape ? model.inputs[0].shape[2] : 0, model?.inputs[0].shape ? model.inputs[0].shape[1] : 0], false);\n const res = model?.execute(resize) as Tensor;\n const num = (await res.data())[0];\n cached[idx] = Math.round(100 * num) / 100;\n lastCount = count;\n lastTime = now();\n tf.dispose([resize, res]);\n resolve(cached[idx]);\n });\n}\n", "/**\n * BlazeFace, FaceMesh & Iris model implementation\n * See `facemesh.ts` for entry point\n */\n\nexport const meshAnnotations: Record = {\n silhouette: [\n 10, 338, 297, 332, 284, 251, 389, 356, 454, 323, 361, 288,\n 397, 365, 379, 378, 400, 377, 152, 148, 176, 149, 150, 136,\n 172, 58, 132, 93, 234, 127, 162, 21, 54, 103, 67, 109,\n ],\n // lipsUpperOuter: [61, 185, 40, 39, 37, 0, 267, 269, 270, 409, 291], // 11\n // lipsLowerOuter: [146, 91, 181, 84, 17, 314, 405, 321, 375, 291], // 10\n // lipsUpperInner: [78, 191, 80, 81, 82, 13, 312, 311, 310, 415, 308], // 11\n // lipsLowerInner: [78, 95, 88, 178, 87, 14, 317, 402, 318, 324, 308], // 11\n lipsUpperOuter: [185, 40, 39, 37, 0, 267, 269, 270, 409],\n lipsLowerOuter: [61, 146, 91, 181, 84, 17, 314, 405, 321, 375, 291],\n lipsUpperInner: [191, 80, 81, 82, 13, 312, 311, 310, 415],\n lipsLowerInner: [78, 95, 88, 178, 87, 14, 317, 402, 318, 324, 308],\n lipsLowerSemiOuter: [76, 77, 90, 180, 85, 16, 315, 404, 320, 307, 306],\n lipsUpperSemiOuter: [184, 74, 73, 72, 11, 302, 303, 304, 408],\n lipsLowerSemiInner: [62, 96, 89, 179, 86, 15, 316, 403, 319, 325, 292],\n lipsUpperSemiInner: [183, 42, 41, 38, 12, 268, 271, 272, 407],\n rightEyeUpper0: [246, 161, 160, 159, 158, 157, 173], // 7\n rightEyeLower0: [33, 7, 163, 144, 145, 153, 154, 155, 133], // 9\n rightEyeUpper1: [247, 30, 29, 27, 28, 56, 190], // 7\n rightEyeLower1: [130, 25, 110, 24, 23, 22, 26, 112, 243], // 9\n rightEyeUpper2: [113, 225, 224, 223, 222, 221, 189], // 7\n rightEyeLower2: [226, 31, 228, 229, 230, 231, 232, 233, 244], // 9\n rightEyeLower3: [143, 111, 117, 118, 119, 120, 121, 128, 245], // 9\n rightEyebrowUpper: [156, 70, 63, 105, 66, 107, 55, 193], // 8\n rightEyebrowLower: [35, 124, 46, 53, 52, 65], // 6\n rightEyeIris: [473, 474, 475, 476, 477], // 5\n leftEyeUpper0: [466, 388, 387, 386, 385, 384, 398],\n leftEyeLower0: [263, 249, 390, 373, 374, 380, 381, 382, 362],\n leftEyeUpper1: [467, 260, 259, 257, 258, 286, 414],\n leftEyeLower1: [359, 255, 339, 254, 253, 252, 256, 341, 463],\n leftEyeUpper2: [342, 445, 444, 443, 442, 441, 413],\n leftEyeLower2: [446, 261, 448, 449, 450, 451, 452, 453, 464],\n leftEyeLower3: [372, 340, 346, 347, 348, 349, 350, 357, 465],\n leftEyebrowUpper: [383, 300, 293, 334, 296, 336, 285, 417],\n leftEyebrowLower: [265, 353, 276, 283, 282, 295],\n leftEyeIris: [468, 469, 470, 471, 472],\n midwayBetweenEyes: [168],\n noseTip: [1],\n noseBottom: [2],\n noseRightCorner: [98],\n noseLeftCorner: [327],\n rightCheek: [205],\n leftCheek: [425],\n};\n\nexport const meshLandmarks: Record = {\n count: 468,\n mouth: 13,\n symmetryLine: [13, meshAnnotations['midwayBetweenEyes'][0]],\n};\n\nexport const blazeFaceLandmarks: Record = {\n leftEye: 0,\n rightEye: 1,\n nose: 2,\n mouth: 3,\n leftEar: 4,\n rightEar: 5,\n symmetryLine: [3, 2],\n};\n\nexport const irisIndices: Array<{ key: string, indices: number[] }> = [ // A mapping from facemesh model keypoints to iris model keypoints.\n { key: 'EyeUpper0', indices: [9, 10, 11, 12, 13, 14, 15] }, // 7 x 3d\n { key: 'EyeUpper1', indices: [25, 26, 27, 28, 29, 30, 31] }, // 7 x 3d\n { key: 'EyeUpper2', indices: [41, 42, 43, 44, 45, 46, 47] }, // 7 x 3d\n { key: 'EyeLower0', indices: [0, 1, 2, 3, 4, 5, 6, 7, 8] }, // 7 x 3d\n { key: 'EyeLower1', indices: [16, 17, 18, 19, 20, 21, 22, 23, 24] }, // 9 x 3d\n { key: 'EyeLower2', indices: [32, 33, 34, 35, 36, 37, 38, 39, 40] }, // 9 x 3d\n { key: 'EyeLower3', indices: [54, 55, 56, 57, 58, 59, 60, 61, 62] }, // 9 x 3d\n { key: 'EyebrowUpper', indices: [63, 64, 65, 66, 67, 68, 69, 70] }, // 8 x 3d\n { key: 'EyebrowLower', indices: [48, 49, 50, 51, 52, 53] }, // 6 x 3d\n];\n\nexport const UV468: [number, number][] = [\n [0.499976992607117, 0.652534008026123],\n [0.500025987625122, 0.547487020492554],\n [0.499974012374878, 0.602371990680695],\n [0.482113003730774, 0.471979022026062],\n [0.500150978565216, 0.527155995368958],\n [0.499909996986389, 0.498252987861633],\n [0.499523013830185, 0.40106201171875],\n [0.289712011814117, 0.380764007568359],\n [0.499954998493195, 0.312398016452789],\n [0.499987006187439, 0.269918978214264],\n [0.500023007392883, 0.107050001621246],\n [0.500023007392883, 0.666234016418457],\n [0.5000159740448, 0.679224014282227],\n [0.500023007392883, 0.692348003387451],\n [0.499976992607117, 0.695277988910675],\n [0.499976992607117, 0.70593398809433],\n [0.499976992607117, 0.719385027885437],\n [0.499976992607117, 0.737019002437592],\n [0.499967992305756, 0.781370997428894],\n [0.499816000461578, 0.562981009483337],\n [0.473773002624512, 0.573909997940063],\n [0.104906998574734, 0.254140973091125],\n [0.365929991006851, 0.409575998783112],\n [0.338757991790771, 0.41302502155304],\n [0.311120003461838, 0.409460008144379],\n [0.274657994508743, 0.389131009578705],\n [0.393361985683441, 0.403706014156342],\n [0.345234006643295, 0.344011008739471],\n [0.370094001293182, 0.346076011657715],\n [0.319321990013123, 0.347265005111694],\n [0.297903001308441, 0.353591024875641],\n [0.24779200553894, 0.410809993743896],\n [0.396889001131058, 0.842755019664764],\n [0.280097991228104, 0.375599980354309],\n [0.106310002505779, 0.399955987930298],\n [0.2099249958992, 0.391353011131287],\n [0.355807989835739, 0.534406006336212],\n [0.471751004457474, 0.65040397644043],\n [0.474155008792877, 0.680191993713379],\n [0.439785003662109, 0.657229006290436],\n [0.414617002010345, 0.66654098033905],\n [0.450374007225037, 0.680860996246338],\n [0.428770989179611, 0.682690978050232],\n [0.374971002340317, 0.727805018424988],\n [0.486716985702515, 0.547628998756409],\n [0.485300987958908, 0.527395009994507],\n [0.257764995098114, 0.314490020275116],\n [0.401223003864288, 0.455172002315521],\n [0.429818987846375, 0.548614978790283],\n [0.421351999044418, 0.533740997314453],\n [0.276895999908447, 0.532056987285614],\n [0.483370006084442, 0.499586999416351],\n [0.33721199631691, 0.282882988452911],\n [0.296391993761063, 0.293242990970612],\n [0.169294998049736, 0.193813979625702],\n [0.447580009698868, 0.302609980106354],\n [0.392390012741089, 0.353887975215912],\n [0.354490011930466, 0.696784019470215],\n [0.067304998636246, 0.730105042457581],\n [0.442739009857178, 0.572826027870178],\n [0.457098007202148, 0.584792017936707],\n [0.381974011659622, 0.694710969924927],\n [0.392388999462128, 0.694203019142151],\n [0.277076005935669, 0.271932005882263],\n [0.422551989555359, 0.563233017921448],\n [0.385919004678726, 0.281364023685455],\n [0.383103013038635, 0.255840003490448],\n [0.331431001424789, 0.119714021682739],\n [0.229923993349075, 0.232002973556519],\n [0.364500999450684, 0.189113974571228],\n [0.229622006416321, 0.299540996551514],\n [0.173287004232407, 0.278747975826263],\n [0.472878992557526, 0.666198015213013],\n [0.446828007698059, 0.668527007102966],\n [0.422762006521225, 0.673889994621277],\n [0.445307999849319, 0.580065965652466],\n [0.388103008270264, 0.693961024284363],\n [0.403039008378983, 0.706539988517761],\n [0.403629004955292, 0.693953037261963],\n [0.460041999816895, 0.557139039039612],\n [0.431158006191254, 0.692366003990173],\n [0.452181994915009, 0.692366003990173],\n [0.475387006998062, 0.692366003990173],\n [0.465828001499176, 0.779190003871918],\n [0.472328990697861, 0.736225962638855],\n [0.473087012767792, 0.717857003211975],\n [0.473122000694275, 0.704625964164734],\n [0.473033010959625, 0.695277988910675],\n [0.427942007780075, 0.695277988910675],\n [0.426479011774063, 0.703539967536926],\n [0.423162013292313, 0.711845993995667],\n [0.4183090031147, 0.720062971115112],\n [0.390094995498657, 0.639572978019714],\n [0.013953999616206, 0.560034036636353],\n [0.499913990497589, 0.58014702796936],\n [0.413199990987778, 0.69539999961853],\n [0.409626007080078, 0.701822996139526],\n [0.468080013990402, 0.601534962654114],\n [0.422728985548019, 0.585985004901886],\n [0.463079988956451, 0.593783974647522],\n [0.37211999297142, 0.47341400384903],\n [0.334562003612518, 0.496073007583618],\n [0.411671012639999, 0.546965003013611],\n [0.242175996303558, 0.14767599105835],\n [0.290776997804642, 0.201445996761322],\n [0.327338010072708, 0.256527006626129],\n [0.399509996175766, 0.748921036720276],\n [0.441727995872498, 0.261676013469696],\n [0.429764986038208, 0.187834024429321],\n [0.412198007106781, 0.108901023864746],\n [0.288955003023148, 0.398952007293701],\n [0.218936994671822, 0.435410976409912],\n [0.41278201341629, 0.398970007896423],\n [0.257135003805161, 0.355440020561218],\n [0.427684992551804, 0.437960982322693],\n [0.448339998722076, 0.536936044692993],\n [0.178560003638268, 0.45755398273468],\n [0.247308000922203, 0.457193970680237],\n [0.286267012357712, 0.467674970626831],\n [0.332827985286713, 0.460712015628815],\n [0.368755996227264, 0.447206974029541],\n [0.398963987827301, 0.432654976844788],\n [0.476410001516342, 0.405806005001068],\n [0.189241006970406, 0.523923993110657],\n [0.228962004184723, 0.348950982093811],\n [0.490725994110107, 0.562400996685028],\n [0.404670000076294, 0.485132992267609],\n [0.019469000399113, 0.401564002037048],\n [0.426243007183075, 0.420431017875671],\n [0.396993011236191, 0.548797011375427],\n [0.266469985246658, 0.376977026462555],\n [0.439121007919312, 0.51895797252655],\n [0.032313998788595, 0.644356966018677],\n [0.419054001569748, 0.387154996395111],\n [0.462783008813858, 0.505746960639954],\n [0.238978996872902, 0.779744982719421],\n [0.198220998048782, 0.831938028335571],\n [0.107550002634525, 0.540755033493042],\n [0.183610007166862, 0.740257024765015],\n [0.134409993886948, 0.333683013916016],\n [0.385764002799988, 0.883153975009918],\n [0.490967005491257, 0.579378008842468],\n [0.382384985685349, 0.508572995662689],\n [0.174399003386497, 0.397670984268188],\n [0.318785011768341, 0.39623498916626],\n [0.343364000320435, 0.400596976280212],\n [0.396100014448166, 0.710216999053955],\n [0.187885001301765, 0.588537991046906],\n [0.430987000465393, 0.944064974784851],\n [0.318993002176285, 0.898285031318665],\n [0.266247987747192, 0.869701027870178],\n [0.500023007392883, 0.190576016902924],\n [0.499976992607117, 0.954452991485596],\n [0.366169989109039, 0.398822009563446],\n [0.393207013607025, 0.39553701877594],\n [0.410373002290726, 0.391080021858215],\n [0.194993004202843, 0.342101991176605],\n [0.388664990663528, 0.362284004688263],\n [0.365961998701096, 0.355970978736877],\n [0.343364000320435, 0.355356991291046],\n [0.318785011768341, 0.35834002494812],\n [0.301414996385574, 0.363156020641327],\n [0.058132998645306, 0.319076001644135],\n [0.301414996385574, 0.387449026107788],\n [0.499987989664078, 0.618434011936188],\n [0.415838003158569, 0.624195992946625],\n [0.445681989192963, 0.566076993942261],\n [0.465844005346298, 0.620640993118286],\n [0.49992299079895, 0.351523995399475],\n [0.288718998432159, 0.819945991039276],\n [0.335278987884521, 0.852819979190826],\n [0.440512001514435, 0.902418971061707],\n [0.128294005990028, 0.791940987110138],\n [0.408771991729736, 0.373893976211548],\n [0.455606997013092, 0.451801002025604],\n [0.499877005815506, 0.908990025520325],\n [0.375436991453171, 0.924192011356354],\n [0.11421000212431, 0.615022003650665],\n [0.448662012815475, 0.695277988910675],\n [0.4480200111866, 0.704632043838501],\n [0.447111994028091, 0.715808033943176],\n [0.444831997156143, 0.730794012546539],\n [0.430011987686157, 0.766808986663818],\n [0.406787008047104, 0.685672998428345],\n [0.400738000869751, 0.681069016456604],\n [0.392399996519089, 0.677703022956848],\n [0.367855995893478, 0.663918972015381],\n [0.247923001646996, 0.601333022117615],\n [0.452769994735718, 0.420849978923798],\n [0.43639200925827, 0.359887003898621],\n [0.416164010763168, 0.368713974952698],\n [0.413385987281799, 0.692366003990173],\n [0.228018000721931, 0.683571994304657],\n [0.468268007040024, 0.352671027183533],\n [0.411361992359161, 0.804327011108398],\n [0.499989002943039, 0.469825029373169],\n [0.479153990745544, 0.442654013633728],\n [0.499974012374878, 0.439637005329132],\n [0.432112008333206, 0.493588984012604],\n [0.499886006116867, 0.866917014122009],\n [0.49991300702095, 0.821729004383087],\n [0.456548988819122, 0.819200992584229],\n [0.344549000263214, 0.745438992977142],\n [0.37890899181366, 0.574010014533997],\n [0.374292999505997, 0.780184984207153],\n [0.319687992334366, 0.570737957954407],\n [0.357154995203018, 0.604269981384277],\n [0.295284003019333, 0.621580958366394],\n [0.447750002145767, 0.862477004528046],\n [0.410986006259918, 0.508723020553589],\n [0.31395098567009, 0.775308012962341],\n [0.354128003120422, 0.812552988529205],\n [0.324548006057739, 0.703992962837219],\n [0.189096003770828, 0.646299958229065],\n [0.279776990413666, 0.71465802192688],\n [0.1338230073452, 0.682700991630554],\n [0.336768001317978, 0.644733011722565],\n [0.429883986711502, 0.466521978378296],\n [0.455527991056442, 0.548622965812683],\n [0.437114000320435, 0.558896005153656],\n [0.467287987470627, 0.529924988746643],\n [0.414712011814117, 0.335219979286194],\n [0.37704598903656, 0.322777986526489],\n [0.344107985496521, 0.320150971412659],\n [0.312875986099243, 0.32233202457428],\n [0.283526003360748, 0.333190023899078],\n [0.241245999932289, 0.382785975933075],\n [0.102986000478268, 0.468762993812561],\n [0.267612010240555, 0.424560010433197],\n [0.297879010438919, 0.433175981044769],\n [0.333433985710144, 0.433878004550934],\n [0.366427004337311, 0.426115989685059],\n [0.396012008190155, 0.416696012020111],\n [0.420121014118195, 0.41022801399231],\n [0.007561000064015, 0.480777025222778],\n [0.432949006557465, 0.569517970085144],\n [0.458638995885849, 0.479089021682739],\n [0.473466008901596, 0.545744001865387],\n [0.476087987422943, 0.563830018043518],\n [0.468472003936768, 0.555056989192963],\n [0.433990985155106, 0.582361996173859],\n [0.483518004417419, 0.562983989715576],\n [0.482482999563217, 0.57784903049469],\n [0.42645001411438, 0.389798998832703],\n [0.438998997211456, 0.39649498462677],\n [0.450067013502121, 0.400434017181396],\n [0.289712011814117, 0.368252992630005],\n [0.276670008897781, 0.363372981548309],\n [0.517862021923065, 0.471948027610779],\n [0.710287988185883, 0.380764007568359],\n [0.526226997375488, 0.573909997940063],\n [0.895093023777008, 0.254140973091125],\n [0.634069979190826, 0.409575998783112],\n [0.661242008209229, 0.41302502155304],\n [0.688880026340485, 0.409460008144379],\n [0.725341975688934, 0.389131009578705],\n [0.606630027294159, 0.40370500087738],\n [0.654766023159027, 0.344011008739471],\n [0.629905998706818, 0.346076011657715],\n [0.680678009986877, 0.347265005111694],\n [0.702096998691559, 0.353591024875641],\n [0.75221198797226, 0.410804986953735],\n [0.602918028831482, 0.842862963676453],\n [0.719901978969574, 0.375599980354309],\n [0.893692970275879, 0.399959981441498],\n [0.790081977844238, 0.391354024410248],\n [0.643998026847839, 0.534487962722778],\n [0.528249025344849, 0.65040397644043],\n [0.525849997997284, 0.680191040039062],\n [0.560214996337891, 0.657229006290436],\n [0.585384011268616, 0.66654098033905],\n [0.549625992774963, 0.680860996246338],\n [0.57122802734375, 0.682691991329193],\n [0.624852001667023, 0.72809898853302],\n [0.513050019741058, 0.547281980514526],\n [0.51509702205658, 0.527251958847046],\n [0.742246985435486, 0.314507007598877],\n [0.598631024360657, 0.454979002475739],\n [0.570338010787964, 0.548575043678284],\n [0.578631997108459, 0.533622980117798],\n [0.723087012767792, 0.532054007053375],\n [0.516445994377136, 0.499638974666595],\n [0.662801027297974, 0.282917976379395],\n [0.70362401008606, 0.293271005153656],\n [0.830704987049103, 0.193813979625702],\n [0.552385985851288, 0.302568018436432],\n [0.607609987258911, 0.353887975215912],\n [0.645429015159607, 0.696707010269165],\n [0.932694971561432, 0.730105042457581],\n [0.557260990142822, 0.572826027870178],\n [0.542901992797852, 0.584792017936707],\n [0.6180260181427, 0.694710969924927],\n [0.607590973377228, 0.694203019142151],\n [0.722943007946014, 0.271963000297546],\n [0.577413976192474, 0.563166975975037],\n [0.614082992076874, 0.281386971473694],\n [0.616907000541687, 0.255886018276215],\n [0.668509006500244, 0.119913995265961],\n [0.770092010498047, 0.232020974159241],\n [0.635536015033722, 0.189248979091644],\n [0.77039098739624, 0.299556016921997],\n [0.826722025871277, 0.278755009174347],\n [0.527121007442474, 0.666198015213013],\n [0.553171992301941, 0.668527007102966],\n [0.577238023281097, 0.673889994621277],\n [0.554691970348358, 0.580065965652466],\n [0.611896991729736, 0.693961024284363],\n [0.59696102142334, 0.706539988517761],\n [0.596370995044708, 0.693953037261963],\n [0.539958000183105, 0.557139039039612],\n [0.568841993808746, 0.692366003990173],\n [0.547818005084991, 0.692366003990173],\n [0.52461302280426, 0.692366003990173],\n [0.534089982509613, 0.779141008853912],\n [0.527670979499817, 0.736225962638855],\n [0.526912987232208, 0.717857003211975],\n [0.526877999305725, 0.704625964164734],\n [0.526966989040375, 0.695277988910675],\n [0.572058022022247, 0.695277988910675],\n [0.573521018028259, 0.703539967536926],\n [0.57683801651001, 0.711845993995667],\n [0.581691026687622, 0.720062971115112],\n [0.609944999217987, 0.639909982681274],\n [0.986046016216278, 0.560034036636353],\n [0.5867999792099, 0.69539999961853],\n [0.590372025966644, 0.701822996139526],\n [0.531915009021759, 0.601536989212036],\n [0.577268004417419, 0.585934996604919],\n [0.536915004253387, 0.593786001205444],\n [0.627542972564697, 0.473352015018463],\n [0.665585994720459, 0.495950996875763],\n [0.588353991508484, 0.546862006187439],\n [0.757824003696442, 0.14767599105835],\n [0.709249973297119, 0.201507985591888],\n [0.672684013843536, 0.256581008434296],\n [0.600408971309662, 0.74900496006012],\n [0.55826598405838, 0.261672019958496],\n [0.570303976535797, 0.187870979309082],\n [0.588165998458862, 0.109044015407562],\n [0.711045026779175, 0.398952007293701],\n [0.781069993972778, 0.435405015945435],\n [0.587247014045715, 0.398931980133057],\n [0.742869973182678, 0.355445981025696],\n [0.572156012058258, 0.437651991844177],\n [0.55186802148819, 0.536570012569427],\n [0.821442008018494, 0.457556009292603],\n [0.752701997756958, 0.457181990146637],\n [0.71375697851181, 0.467626988887787],\n [0.66711300611496, 0.460672974586487],\n [0.631101012229919, 0.447153985500336],\n [0.6008620262146, 0.432473003864288],\n [0.523481011390686, 0.405627012252808],\n [0.810747981071472, 0.523926019668579],\n [0.771045982837677, 0.348959028720856],\n [0.509127020835876, 0.562718033790588],\n [0.595292985439301, 0.485023975372314],\n [0.980530977249146, 0.401564002037048],\n [0.573499977588654, 0.420000016689301],\n [0.602994978427887, 0.548687994480133],\n [0.733529984951019, 0.376977026462555],\n [0.560611009597778, 0.519016981124878],\n [0.967685997486115, 0.644356966018677],\n [0.580985009670258, 0.387160003185272],\n [0.537728011608124, 0.505385041236877],\n [0.760966002941132, 0.779752969741821],\n [0.801778972148895, 0.831938028335571],\n [0.892440974712372, 0.54076099395752],\n [0.816350996494293, 0.740260004997253],\n [0.865594983100891, 0.333687007427216],\n [0.614073991775513, 0.883246004581451],\n [0.508952975273132, 0.579437971115112],\n [0.617941975593567, 0.508316040039062],\n [0.825608015060425, 0.397674977779388],\n [0.681214988231659, 0.39623498916626],\n [0.656635999679565, 0.400596976280212],\n [0.603900015354156, 0.710216999053955],\n [0.81208598613739, 0.588539004325867],\n [0.56801301240921, 0.944564998149872],\n [0.681007981300354, 0.898285031318665],\n [0.733752012252808, 0.869701027870178],\n [0.633830010890961, 0.398822009563446],\n [0.606792986392975, 0.39553701877594],\n [0.589659988880157, 0.391062021255493],\n [0.805015981197357, 0.342108011245728],\n [0.611334979534149, 0.362284004688263],\n [0.634037971496582, 0.355970978736877],\n [0.656635999679565, 0.355356991291046],\n [0.681214988231659, 0.35834002494812],\n [0.698584973812103, 0.363156020641327],\n [0.941866993904114, 0.319076001644135],\n [0.698584973812103, 0.387449026107788],\n [0.584177017211914, 0.624107003211975],\n [0.554318010807037, 0.566076993942261],\n [0.534153997898102, 0.62064003944397],\n [0.711217999458313, 0.819975018501282],\n [0.664629995822906, 0.852871000766754],\n [0.559099972248077, 0.902631998062134],\n [0.871706008911133, 0.791940987110138],\n [0.591234028339386, 0.373893976211548],\n [0.544341027736664, 0.451583981513977],\n [0.624562978744507, 0.924192011356354],\n [0.88577002286911, 0.615028977394104],\n [0.551338016986847, 0.695277988910675],\n [0.551980018615723, 0.704632043838501],\n [0.552887976169586, 0.715808033943176],\n [0.555167973041534, 0.730794012546539],\n [0.569944024085999, 0.767035007476807],\n [0.593203008174896, 0.685675978660583],\n [0.599261999130249, 0.681069016456604],\n [0.607599973678589, 0.677703022956848],\n [0.631937980651855, 0.663500010967255],\n [0.752032995223999, 0.601315021514893],\n [0.547226011753082, 0.420395016670227],\n [0.563543975353241, 0.359827995300293],\n [0.583841025829315, 0.368713974952698],\n [0.586614012718201, 0.692366003990173],\n [0.771915018558502, 0.683578014373779],\n [0.531597018241882, 0.352482974529266],\n [0.588370978832245, 0.804440975189209],\n [0.52079701423645, 0.442565023899078],\n [0.567984998226166, 0.493479013442993],\n [0.543282985687256, 0.819254994392395],\n [0.655317008495331, 0.745514988899231],\n [0.621008992195129, 0.574018001556396],\n [0.625559985637665, 0.78031200170517],\n [0.680198013782501, 0.570719003677368],\n [0.64276397228241, 0.604337990283966],\n [0.704662978649139, 0.621529996395111],\n [0.552012026309967, 0.862591981887817],\n [0.589071989059448, 0.508637011051178],\n [0.685944974422455, 0.775357007980347],\n [0.645735025405884, 0.812640011310577],\n [0.675342977046967, 0.703978002071381],\n [0.810858011245728, 0.646304965019226],\n [0.72012197971344, 0.714666962623596],\n [0.866151988506317, 0.682704985141754],\n [0.663187026977539, 0.644596993923187],\n [0.570082008838654, 0.466325998306274],\n [0.544561982154846, 0.548375964164734],\n [0.562758982181549, 0.558784961700439],\n [0.531987011432648, 0.530140042304993],\n [0.585271000862122, 0.335177004337311],\n [0.622952997684479, 0.32277899980545],\n [0.655896008014679, 0.320163011550903],\n [0.687132000923157, 0.322345972061157],\n [0.716481983661652, 0.333200991153717],\n [0.758756995201111, 0.382786989212036],\n [0.897013008594513, 0.468769013881683],\n [0.732392013072968, 0.424547016620636],\n [0.70211398601532, 0.433162987232208],\n [0.66652500629425, 0.433866024017334],\n [0.633504986763, 0.426087975502014],\n [0.603875994682312, 0.416586995124817],\n [0.579657971858978, 0.409945011138916],\n [0.992439985275269, 0.480777025222778],\n [0.567192018032074, 0.569419980049133],\n [0.54136598110199, 0.478899002075195],\n [0.526564002037048, 0.546118021011353],\n [0.523913025856018, 0.563830018043518],\n [0.531529009342194, 0.555056989192963],\n [0.566035985946655, 0.582329034805298],\n [0.51631098985672, 0.563053965568542],\n [0.5174720287323, 0.577877044677734],\n [0.573594987392426, 0.389806985855103],\n [0.560697972774506, 0.395331978797913],\n [0.549755990505219, 0.399751007556915],\n [0.710287988185883, 0.368252992630005],\n [0.723330020904541, 0.363372981548309],\n];\n\nexport const TRI468: Array = [\n 127, 34, 139, 11, 0, 37, 232, 231, 120, 72, 37, 39, 128, 121, 47, 232, 121, 128, 104, 69, 67, 175, 171, 148, 157, 154, 155, 118, 50, 101, 73, 39, 40, 9,\n 151, 108, 48, 115, 131, 194, 204, 211, 74, 40, 185, 80, 42, 183, 40, 92, 186, 230, 229, 118, 202, 212, 214, 83, 18, 17, 76, 61, 146, 160, 29, 30, 56,\n 157, 173, 106, 204, 194, 135, 214, 192, 203, 165, 98, 21, 71, 68, 51, 45, 4, 144, 24, 23, 77, 146, 91, 205, 50, 187, 201, 200, 18, 91, 106, 182, 90, 91,\n 181, 85, 84, 17, 206, 203, 36, 148, 171, 140, 92, 40, 39, 193, 189, 244, 159, 158, 28, 247, 246, 161, 236, 3, 196, 54, 68, 104, 193, 168, 8, 117,\n 228, 31, 189, 193, 55, 98, 97, 99, 126, 47, 100, 166, 79, 218, 155, 154, 26, 209, 49, 131, 135, 136, 150, 47, 126, 217, 223, 52, 53, 45, 51, 134, 211,\n 170, 140, 67, 69, 108, 43, 106, 91, 230, 119, 120, 226, 130, 247, 63, 53, 52, 238, 20, 242, 46, 70, 156, 78, 62, 96, 46, 53, 63, 143, 34, 227, 173,\n 155, 133, 123, 117, 111, 44, 125, 19, 236, 134, 51, 216, 206, 205, 154, 153, 22, 39, 37, 167, 200, 201, 208, 36, 142, 100, 57, 212, 202, 20, 60, 99, 28,\n 158, 157, 35, 226, 113, 160, 159, 27, 204, 202, 210, 113, 225, 46, 43, 202, 204, 62, 76, 77, 137, 123, 116, 41, 38, 72, 203, 129, 142, 64, 98, 240, 49,\n 102, 64, 41, 73, 74, 212, 216, 207, 42, 74, 184, 169, 170, 211, 170, 149, 176, 105, 66, 69, 122, 6, 168, 123, 147, 187, 96, 77, 90, 65, 55, 107, 89,\n 90, 180, 101, 100, 120, 63, 105, 104, 93, 137, 227, 15, 86, 85, 129, 102, 49, 14, 87, 86, 55, 8, 9, 100, 47, 121, 145, 23, 22, 88, 89, 179, 6, 122,\n 196, 88, 95, 96, 138, 172, 136, 215, 58, 172, 115, 48, 219, 42, 80, 81, 195, 3, 51, 43, 146, 61, 171, 175, 199, 81, 82, 38, 53, 46, 225, 144, 163, 110,\n 246, 33, 7, 52, 65, 66, 229, 228, 117, 34, 127, 234, 107, 108, 69, 109, 108, 151, 48, 64, 235, 62, 78, 191, 129, 209, 126, 111, 35, 143, 163, 161, 246,\n 117, 123, 50, 222, 65, 52, 19, 125, 141, 221, 55, 65, 3, 195, 197, 25, 7, 33, 220, 237, 44, 70, 71, 139, 122, 193, 245, 247, 130, 33, 71, 21, 162,\n 153, 158, 159, 170, 169, 150, 188, 174, 196, 216, 186, 92, 144, 160, 161, 2, 97, 167, 141, 125, 241, 164, 167, 37, 72, 38, 12, 145, 159, 160, 38, 82, 13,\n 63, 68, 71, 226, 35, 111, 158, 153, 154, 101, 50, 205, 206, 92, 165, 209, 198, 217, 165, 167, 97, 220, 115, 218, 133, 112, 243, 239, 238, 241, 214,\n 135, 169, 190, 173, 133, 171, 208, 32, 125, 44, 237, 86, 87, 178, 85, 86, 179, 84, 85, 180, 83, 84, 181, 201, 83, 182, 137, 93, 132, 76, 62, 183, 61,\n 76, 184, 57, 61, 185, 212, 57, 186, 214, 207, 187, 34, 143, 156, 79, 239, 237, 123, 137, 177, 44, 1, 4, 201, 194, 32, 64, 102, 129, 213, 215, 138, 59,\n 166, 219, 242, 99, 97, 2, 94, 141, 75, 59, 235, 24, 110, 228, 25, 130, 226, 23, 24, 229, 22, 23, 230, 26, 22, 231, 112, 26, 232, 189, 190, 243, 221, 56,\n 190, 28, 56, 221, 27, 28, 222, 29, 27, 223, 30, 29, 224, 247, 30, 225, 238, 79, 20, 166, 59, 75, 60, 75, 240, 147, 177, 215, 20, 79, 166, 187, 147, 213,\n 112, 233, 244, 233, 128, 245, 128, 114, 188, 114, 217, 174, 131, 115, 220, 217, 198, 236, 198, 131, 134, 177, 132, 58, 143, 35, 124, 110, 163, 7, 228,\n 110, 25, 356, 389, 368, 11, 302, 267, 452, 350, 349, 302, 303, 269, 357, 343, 277, 452, 453, 357, 333, 332, 297, 175, 152, 377, 384, 398, 382, 347,\n 348, 330, 303, 304, 270, 9, 336, 337, 278, 279, 360, 418, 262, 431, 304, 408, 409, 310, 415, 407, 270, 409, 410, 450, 348, 347, 422, 430, 434, 313,\n 314, 17, 306, 307, 375, 387, 388, 260, 286, 414, 398, 335, 406, 418, 364, 367, 416, 423, 358, 327, 251, 284, 298, 281, 5, 4, 373, 374, 253, 307, 320,\n 321, 425, 427, 411, 421, 313, 18, 321, 405, 406, 320, 404, 405, 315, 16, 17, 426, 425, 266, 377, 400, 369, 322, 391, 269, 417, 465, 464, 386, 257, 258,\n 466, 260, 388, 456, 399, 419, 284, 332, 333, 417, 285, 8, 346, 340, 261, 413, 441, 285, 327, 460, 328, 355, 371, 329, 392, 439, 438, 382, 341, 256,\n 429, 420, 360, 364, 394, 379, 277, 343, 437, 443, 444, 283, 275, 440, 363, 431, 262, 369, 297, 338, 337, 273, 375, 321, 450, 451, 349, 446, 342, 467,\n 293, 334, 282, 458, 461, 462, 276, 353, 383, 308, 324, 325, 276, 300, 293, 372, 345, 447, 382, 398, 362, 352, 345, 340, 274, 1, 19, 456, 248, 281, 436,\n 427, 425, 381, 256, 252, 269, 391, 393, 200, 199, 428, 266, 330, 329, 287, 273, 422, 250, 462, 328, 258, 286, 384, 265, 353, 342, 387, 259, 257, 424,\n 431, 430, 342, 353, 276, 273, 335, 424, 292, 325, 307, 366, 447, 345, 271, 303, 302, 423, 266, 371, 294, 455, 460, 279, 278, 294, 271, 272, 304, 432,\n 434, 427, 272, 407, 408, 394, 430, 431, 395, 369, 400, 334, 333, 299, 351, 417, 168, 352, 280, 411, 325, 319, 320, 295, 296, 336, 319, 403, 404, 330,\n 348, 349, 293, 298, 333, 323, 454, 447, 15, 16, 315, 358, 429, 279, 14, 15, 316, 285, 336, 9, 329, 349, 350, 374, 380, 252, 318, 402, 403, 6, 197, 419,\n 318, 319, 325, 367, 364, 365, 435, 367, 397, 344, 438, 439, 272, 271, 311, 195, 5, 281, 273, 287, 291, 396, 428, 199, 311, 271, 268, 283, 444, 445,\n 373, 254, 339, 263, 466, 249, 282, 334, 296, 449, 347, 346, 264, 447, 454, 336, 296, 299, 338, 10, 151, 278, 439, 455, 292, 407, 415, 358, 371, 355,\n 340, 345, 372, 390, 249, 466, 346, 347, 280, 442, 443, 282, 19, 94, 370, 441, 442, 295, 248, 419, 197, 263, 255, 359, 440, 275, 274, 300, 383, 368,\n 351, 412, 465, 263, 467, 466, 301, 368, 389, 380, 374, 386, 395, 378, 379, 412, 351, 419, 436, 426, 322, 373, 390, 388, 2, 164, 393, 370, 462, 461,\n 164, 0, 267, 302, 11, 12, 374, 373, 387, 268, 12, 13, 293, 300, 301, 446, 261, 340, 385, 384, 381, 330, 266, 425, 426, 423, 391, 429, 355, 437, 391,\n 327, 326, 440, 457, 438, 341, 382, 362, 459, 457, 461, 434, 430, 394, 414, 463, 362, 396, 369, 262, 354, 461, 457, 316, 403, 402, 315, 404, 403, 314,\n 405, 404, 313, 406, 405, 421, 418, 406, 366, 401, 361, 306, 408, 407, 291, 409, 408, 287, 410, 409, 432, 436, 410, 434, 416, 411, 264, 368, 383, 309,\n 438, 457, 352, 376, 401, 274, 275, 4, 421, 428, 262, 294, 327, 358, 433, 416, 367, 289, 455, 439, 462, 370, 326, 2, 326, 370, 305, 460, 455, 254,\n 449, 448, 255, 261, 446, 253, 450, 449, 252, 451, 450, 256, 452, 451, 341, 453, 452, 413, 464, 463, 441, 413, 414, 258, 442, 441, 257, 443, 442, 259,\n 444, 443, 260, 445, 444, 467, 342, 445, 459, 458, 250, 289, 392, 290, 290, 328, 460, 376, 433, 435, 250, 290, 392, 411, 416, 433, 341, 463, 464, 453,\n 464, 465, 357, 465, 412, 343, 412, 399, 360, 363, 440, 437, 399, 456, 420, 456, 363, 401, 435, 288, 372, 383, 353, 339, 255, 249, 448, 261, 255, 133,\n 243, 190, 133, 155, 112, 33, 246, 247, 33, 130, 25, 398, 384, 286, 362, 398, 414, 362, 463, 341, 263, 359, 467, 263, 249, 255, 466, 467, 260, 75, 60,\n 166, 238, 239, 79, 162, 127, 139, 72, 11, 37, 121, 232, 120, 73, 72, 39, 114, 128, 47, 233, 232, 128, 103, 104, 67, 152, 175, 148, 173, 157, 155,\n 119, 118, 101, 74, 73, 40, 107, 9, 108, 49, 48, 131, 32, 194, 211, 184, 74, 185, 191, 80, 183, 185, 40, 186, 119, 230, 118, 210, 202, 214, 84, 83, 17,\n 77, 76, 146, 161, 160, 30, 190, 56, 173, 182, 106, 194, 138, 135, 192, 129, 203, 98, 54, 21, 68, 5, 51, 4, 145, 144, 23, 90, 77, 91, 207, 205, 187, 83,\n 201, 18, 181, 91, 182, 180, 90, 181, 16, 85, 17, 205, 206, 36, 176, 148, 140, 165, 92, 39, 245, 193, 244, 27, 159, 28, 30, 247, 161, 174, 236, 196,\n 103, 54, 104, 55, 193, 8, 111, 117, 31, 221, 189, 55, 240, 98, 99, 142, 126, 100, 219, 166, 218, 112, 155, 26, 198, 209, 131, 169, 135, 150, 114, 47,\n 217, 224, 223, 53, 220, 45, 134, 32, 211, 140, 109, 67, 108, 146, 43, 91, 231, 230, 120, 113, 226, 247, 105, 63, 52, 241, 238, 242, 124, 46, 156, 95,\n 78, 96, 70, 46, 63, 116, 143, 227, 116, 123, 111, 1, 44, 19, 3, 236, 51, 207, 216, 205, 26, 154, 22, 165, 39, 167, 199, 200, 208, 101, 36, 100, 43,\n 57, 202, 242, 20, 99, 56, 28, 157, 124, 35, 113, 29, 160, 27, 211, 204, 210, 124, 113, 46, 106, 43, 204, 96, 62, 77, 227, 137, 116, 73, 41, 72, 36, 203,\n 142, 235, 64, 240, 48, 49, 64, 42, 41, 74, 214, 212, 207, 183, 42, 184, 210, 169, 211, 140, 170, 176, 104, 105, 69, 193, 122, 168, 50, 123, 187, 89, 96,\n 90, 66, 65, 107, 179, 89, 180, 119, 101, 120, 68, 63, 104, 234, 93, 227, 16, 15, 85, 209, 129, 49, 15, 14, 86, 107, 55, 9, 120, 100, 121, 153, 145, 22,\n 178, 88, 179, 197, 6, 196, 89, 88, 96, 135, 138, 136, 138, 215, 172, 218, 115, 219, 41, 42, 81, 5, 195, 51, 57, 43, 61, 208, 171, 199, 41, 81, 38,\n 224, 53, 225, 24, 144, 110, 105, 52, 66, 118, 229, 117, 227, 34, 234, 66, 107, 69, 10, 109, 151, 219, 48, 235, 183, 62, 191, 142, 129, 126, 116, 111,\n 143, 7, 163, 246, 118, 117, 50, 223, 222, 52, 94, 19, 141, 222, 221, 65, 196, 3, 197, 45, 220, 44, 156, 70, 139, 188, 122, 245, 139, 71, 162, 145,\n 153, 159, 149, 170, 150, 122, 188, 196, 206, 216, 92, 163, 144, 161, 164, 2, 167, 242, 141, 241, 0, 164, 37, 11, 72, 12, 144, 145, 160, 12, 38, 13, 70,\n 63, 71, 31, 226, 111, 157, 158, 154, 36, 101, 205, 203, 206, 165, 126, 209, 217, 98, 165, 97, 237, 220, 218, 237, 239, 241, 210, 214, 169, 140, 171, 32,\n 241, 125, 237, 179, 86, 178, 180, 85, 179, 181, 84, 180, 182, 83, 181, 194, 201, 182, 177, 137, 132, 184, 76, 183, 185, 61, 184, 186, 57, 185, 216, 212,\n 186, 192, 214, 187, 139, 34, 156, 218, 79, 237, 147, 123, 177, 45, 44, 4, 208, 201, 32, 98, 64, 129, 192, 213, 138, 235, 59, 219, 141, 242, 97, 97, 2,\n 141, 240, 75, 235, 229, 24, 228, 31, 25, 226, 230, 23, 229, 231, 22, 230, 232, 26, 231, 233, 112, 232, 244, 189, 243, 189, 221, 190, 222, 28, 221,\n 223, 27, 222, 224, 29, 223, 225, 30, 224, 113, 247, 225, 99, 60, 240, 213, 147, 215, 60, 20, 166, 192, 187, 213, 243, 112, 244, 244, 233, 245, 245,\n 128, 188, 188, 114, 174, 134, 131, 220, 174, 217, 236, 236, 198, 134, 215, 177, 58, 156, 143, 124, 25, 110, 7, 31, 228, 25, 264, 356, 368, 0, 11, 267,\n 451, 452, 349, 267, 302, 269, 350, 357, 277, 350, 452, 357, 299, 333, 297, 396, 175, 377, 381, 384, 382, 280, 347, 330, 269, 303, 270, 151, 9, 337,\n 344, 278, 360, 424, 418, 431, 270, 304, 409, 272, 310, 407, 322, 270, 410, 449, 450, 347, 432, 422, 434, 18, 313, 17, 291, 306, 375, 259, 387, 260,\n 424, 335, 418, 434, 364, 416, 391, 423, 327, 301, 251, 298, 275, 281, 4, 254, 373, 253, 375, 307, 321, 280, 425, 411, 200, 421, 18, 335, 321, 406,\n 321, 320, 405, 314, 315, 17, 423, 426, 266, 396, 377, 369, 270, 322, 269, 413, 417, 464, 385, 386, 258, 248, 456, 419, 298, 284, 333, 168, 417, 8,\n 448, 346, 261, 417, 413, 285, 326, 327, 328, 277, 355, 329, 309, 392, 438, 381, 382, 256, 279, 429, 360, 365, 364, 379, 355, 277, 437, 282, 443, 283,\n 281, 275, 363, 395, 431, 369, 299, 297, 337, 335, 273, 321, 348, 450, 349, 359, 446, 467, 283, 293, 282, 250, 458, 462, 300, 276, 383, 292, 308, 325,\n 283, 276, 293, 264, 372, 447, 346, 352, 340, 354, 274, 19, 363, 456, 281, 426, 436, 425, 380, 381, 252, 267, 269, 393, 421, 200, 428, 371, 266, 329,\n 432, 287, 422, 290, 250, 328, 385, 258, 384, 446, 265, 342, 386, 387, 257, 422, 424, 430, 445, 342, 276, 422, 273, 424, 306, 292, 307, 352, 366, 345,\n 268, 271, 302, 358, 423, 371, 327, 294, 460, 331, 279, 294, 303, 271, 304, 436, 432, 427, 304, 272, 408, 395, 394, 431, 378, 395, 400, 296, 334, 299,\n 6, 351, 168, 376, 352, 411, 307, 325, 320, 285, 295, 336, 320, 319, 404, 329, 330, 349, 334, 293, 333, 366, 323, 447, 316, 15, 315, 331, 358, 279,\n 317, 14, 316, 8, 285, 9, 277, 329, 350, 253, 374, 252, 319, 318, 403, 351, 6, 419, 324, 318, 325, 397, 367, 365, 288, 435, 397, 278, 344, 439, 310,\n 272, 311, 248, 195, 281, 375, 273, 291, 175, 396, 199, 312, 311, 268, 276, 283, 445, 390, 373, 339, 295, 282, 296, 448, 449, 346, 356, 264, 454, 337,\n 336, 299, 337, 338, 151, 294, 278, 455, 308, 292, 415, 429, 358, 355, 265, 340, 372, 388, 390, 466, 352, 346, 280, 295, 442, 282, 354, 19, 370, 285,\n 441, 295, 195, 248, 197, 457, 440, 274, 301, 300, 368, 417, 351, 465, 251, 301, 389, 385, 380, 386, 394, 395, 379, 399, 412, 419, 410, 436, 322, 387,\n 373, 388, 326, 2, 393, 354, 370, 461, 393, 164, 267, 268, 302, 12, 386, 374, 387, 312, 268, 13, 298, 293, 301, 265, 446, 340, 380, 385, 381, 280, 330,\n 425, 322, 426, 391, 420, 429, 437, 393, 391, 326, 344, 440, 438, 458, 459, 461, 364, 434, 394, 428, 396, 262, 274, 354, 457, 317, 316, 402, 316, 315,\n 403, 315, 314, 404, 314, 313, 405, 313, 421, 406, 323, 366, 361, 292, 306, 407, 306, 291, 408, 291, 287, 409, 287, 432, 410, 427, 434, 411, 372, 264,\n 383, 459, 309, 457, 366, 352, 401, 1, 274, 4, 418, 421, 262, 331, 294, 358, 435, 433, 367, 392, 289, 439, 328, 462, 326, 94, 2, 370, 289, 305, 455, 339,\n 254, 448, 359, 255, 446, 254, 253, 449, 253, 252, 450, 252, 256, 451, 256, 341, 452, 414, 413, 463, 286, 441, 414, 286, 258, 441, 258, 257, 442, 257,\n 259, 443, 259, 260, 444, 260, 467, 445, 309, 459, 250, 305, 289, 290, 305, 290, 460, 401, 376, 435, 309, 250, 392, 376, 411, 433, 453, 341, 464, 357,\n 453, 465, 343, 357, 412, 437, 343, 399, 344, 360, 440, 420, 437, 456, 360, 420, 363, 361, 401, 288, 265, 372, 353, 390, 339, 249, 339, 448, 255];\n\nexport const TRI68: Array = [0, 1, 36, 0, 36, 17, 1, 2, 41, 1, 41, 36, 2, 3, 31, 2, 31, 41, 3, 4, 48, 3, 48, 31, 4, 5, 48, 5, 6, 48, 6, 7, 59, 6, 59, 48, 7, 8, 58, 7, 58, 59,\n 8, 9, 56, 8, 56, 57, 8, 57, 58, 9, 10, 55, 9, 55, 56, 10, 11, 54, 10, 54, 55, 11, 12, 54, 12, 13, 54, 13, 14, 35, 13, 35, 54, 14, 15, 46, 14, 46, 35, 15, 16,\n 45, 15, 45, 46, 16, 26, 45, 17, 36, 18, 18, 37, 19, 18, 36, 37, 19, 38, 20, 19, 37, 38, 20, 39, 21, 20, 38, 39, 21, 39, 27, 22, 42, 23, 22, 27, 42, 23, 43, 24,\n 23, 42, 43, 24, 44, 25, 24, 43, 44, 25, 45, 26, 25, 44, 45, 27, 39, 28, 27, 28, 42, 28, 39, 29, 28, 29, 42, 29, 31, 30, 29, 30, 35, 29, 40, 31, 29, 35, 47, 29,\n 39, 40, 29, 47, 42, 30, 31, 32, 30, 32, 33, 30, 33, 34, 30, 34, 35, 31, 50, 32, 31, 40, 41, 31, 48, 49, 31, 49, 50, 32, 51, 33, 32, 50, 51, 33, 51, 34, 34, 52,\n 35, 34, 51, 52, 35, 46, 47, 35, 52, 53, 35, 53, 54, 36, 41, 37, 37, 40, 38, 37, 41, 40, 38, 40, 39, 42, 47, 43, 43, 47, 44, 44, 46, 45, 44, 47, 46, 48, 60, 49,\n 48, 59, 60, 49, 61, 50, 49, 60, 61, 50, 62, 51, 50, 61, 62, 51, 62, 52, 52, 63, 53, 52, 62, 63, 53, 64, 54, 53, 63, 64, 54, 64, 55, 55, 65, 56, 55, 64, 65, 56,\n 66, 57, 56, 65, 66, 57, 66, 58, 58, 67, 59, 58, 66, 67, 59, 67, 60, 60, 67, 61, 61, 66, 62, 61, 67, 66, 62, 66, 63, 63, 65, 64, 63, 66, 65, 21, 27, 22];\n\nexport const TRI33: Array = [\n /* eyes */ 0, 8, 7, 7, 8, 1, 2, 10, 9, 9, 10, 3,\n /* brows */ 17, 0, 18, 18, 0, 7, 18, 7, 19, 19, 7, 1, 19, 1, 11, 19, 11, 20, 21, 3, 22, 21, 9, 3, 20, 9, 21, 20, 2, 9, 20, 11, 2,\n /* 4head */ 23, 17, 18, 25, 21, 22, 24, 19, 20, 24, 18, 19, 24, 20, 21, 24, 23, 18, 24, 21, 25,\n /* nose */ 11, 12, 4, 11, 4, 13, 1, 12, 11, 11, 13, 2, 12, 14, 4, 4, 14, 13,\n /* up-lip */ 14, 5, 15, 14, 15, 6, 12, 5, 14, 14, 6, 13,\n /* cheeks */ 8, 12, 1, 2, 13, 10, 8, 26, 12, 10, 13, 27, 26, 5, 12, 13, 6, 27, 0, 26, 8, 10, 27, 3,\n /* chin */ 5, 32, 16, 16, 32, 6, 5, 30, 32, 6, 32, 31,\n /* cont */ 26, 30, 5, 27, 6, 31, 0, 28, 26, 3, 27, 29, 17, 28, 0, 3, 29, 22, 23, 28, 17, 22, 29, 25, 28, 30, 26, 27, 31, 29,\n];\n\nexport const TRI7: Array = [0, 4, 1, 2, 4, 3, 4, 5, 6];\n\nexport const VTX68: Array = [\n /* cont */ 127, 234, 132, 58, 172, 150, 149, 148, 152, 377, 378, 379, 397, 288, 361, 454, 356,\n /* brows */ 70, 63, 105, 66, 107, 336, 296, 334, 293, 300,\n /* nose */ 168, 6, 195, 4, 98, 97, 2, 326, 327,\n /* eyes */ 33, 160, 158, 133, 153, 144, 362, 385, 387, 263, 373, 380,\n /* lip */ 57, 40, 37, 0, 267, 270, 287, 321, 314, 17, 84, 91,\n /* mouth */ 78, 81, 13, 311, 308, 402, 14, 178,\n];\n\nexport const VTX33: Array = [33, 133, 362, 263, 1, 62, 308, 159, 145, 386, 374, 6, 102, 331, 2, 13, 14, 70, 105, 107, 336, 334, 300, 54, 10, 284, 50, 280, 234, 454, 58, 288, 152];\n\nexport const VTX7: Array = [33, 133, 362, 263, 1, 78, 308];\n\nexport const UV68 = VTX68.map((x) => UV468[x]);\n\nexport const UV33 = VTX33.map((x) => UV468[x]);\n\nexport const UV7 = VTX7.map((x) => UV468[x]);\n\n// https://github.com/tensorflow/tfjs-models/blob/master/face-landmarks-detection/src/constants.ts\n// https://github.com/google/mediapipe/mediapipe/python/solutions/face_mesh_connections.py\n\ntype PairArray = Array<[number, number]>;\n\nfunction connectionsToIndices(connections: PairArray) {\n const indices = connections.map((connection) => connection[0]);\n indices.push(connections[connections.length - 1][1]);\n return indices;\n}\n\nexport const pairsLips: PairArray = [\n [61, 146], [146, 91], [91, 181], [181, 84], [84, 17], [17, 314], [314, 405], [405, 321], [321, 375], [375, 291], [61, 185], [185, 40], [40, 39], [39, 37], [37, 0], [0, 267], [267, 269], [269, 270], [270, 409], [409, 291],\n [78, 95], [95, 88], [88, 178], [178, 87], [87, 14], [14, 317], [317, 402], [402, 318], [318, 324], [324, 308], [78, 191], [191, 80], [80, 81], [81, 82], [82, 13], [13, 312], [312, 311], [311, 310], [310, 415], [415, 308],\n];\n\nexport const pairsLeftEye: PairArray = [[263, 249], [249, 390], [390, 373], [373, 374], [374, 380], [380, 381], [381, 382], [382, 362], [263, 466], [466, 388], [388, 387], [387, 386], [386, 385], [385, 384], [384, 398], [398, 362]];\n\nexport const pairsLeftEyebrow: PairArray = [[276, 283], [283, 282], [282, 295], [295, 285], [300, 293], [293, 334], [334, 296], [296, 336]];\n\nexport const pairsLeftIris: PairArray = [[474, 475], [475, 476], [476, 477], [477, 474]];\n\nexport const pairsRightEye: PairArray = [[33, 7], [7, 163], [163, 144], [144, 145], [145, 153], [153, 154], [154, 155], [155, 133], [33, 246], [246, 161], [161, 160], [160, 159], [159, 158], [158, 157], [157, 173], [173, 133]];\n\nexport const pairsRightEyebrow: PairArray = [[46, 53], [53, 52], [52, 65], [65, 55], [70, 63], [63, 105], [105, 66], [66, 107]];\n\nexport const pairsRightIris: PairArray = [[469, 470], [470, 471], [471, 472], [472, 469]];\n\nexport const pairsFaceContour: PairArray = [\n [10, 338], [338, 297], [297, 332], [332, 284], [284, 251], [251, 389],\n [389, 356], [356, 454], [454, 323], [323, 361], [361, 288], [288, 397],\n [397, 365], [365, 379], [379, 378], [378, 400], [400, 377], [377, 152],\n [152, 148], [148, 176], [176, 149], [149, 150], [150, 136], [136, 172],\n [172, 58], [58, 132], [132, 93], [93, 234], [234, 127], [127, 162],\n [162, 21], [21, 54], [54, 103], [103, 67], [67, 109], [109, 10],\n];\n\nexport const contourKeypoints = {\n lips: connectionsToIndices(pairsLips),\n leftEye: connectionsToIndices(pairsLeftEye),\n leftEyebrow: connectionsToIndices(pairsLeftEyebrow),\n leftIris: connectionsToIndices(pairsLeftIris),\n rightEye: connectionsToIndices(pairsRightEye),\n rightEyebrow: connectionsToIndices(pairsRightEyebrow),\n rightIris: connectionsToIndices(pairsRightIris),\n faceOval: connectionsToIndices(pairsFaceContour),\n};\n\nexport const pairsFaceMesh: PairArray = [\n [127, 34], [34, 139], [139, 127], [11, 0], [0, 37], [37, 11],\n [232, 231], [231, 120], [120, 232], [72, 37], [37, 39], [39, 72],\n [128, 121], [121, 47], [47, 128], [232, 121], [121, 128], [128, 232],\n [104, 69], [69, 67], [67, 104], [175, 171], [171, 148], [148, 175],\n [118, 50], [50, 101], [101, 118], [73, 39], [39, 40], [40, 73],\n [9, 151], [151, 108], [108, 9], [48, 115], [115, 131], [131, 48],\n [194, 204], [204, 211], [211, 194], [74, 40], [40, 185], [185, 74],\n [80, 42], [42, 183], [183, 80], [40, 92], [92, 186], [186, 40],\n [230, 229], [229, 118], [118, 230], [202, 212], [212, 214], [214, 202],\n [83, 18], [18, 17], [17, 83], [76, 61], [61, 146], [146, 76],\n [160, 29], [29, 30], [30, 160], [56, 157], [157, 173], [173, 56],\n [106, 204], [204, 194], [194, 106], [135, 214], [214, 192], [192, 135],\n [203, 165], [165, 98], [98, 203], [21, 71], [71, 68], [68, 21],\n [51, 45], [45, 4], [4, 51], [144, 24], [24, 23], [23, 144],\n [77, 146], [146, 91], [91, 77], [205, 50], [50, 187], [187, 205],\n [201, 200], [200, 18], [18, 201], [91, 106], [106, 182], [182, 91],\n [90, 91], [91, 181], [181, 90], [85, 84], [84, 17], [17, 85],\n [206, 203], [203, 36], [36, 206], [148, 171], [171, 140], [140, 148],\n [92, 40], [40, 39], [39, 92], [193, 189], [189, 244], [244, 193],\n [159, 158], [158, 28], [28, 159], [247, 246], [246, 161], [161, 247],\n [236, 3], [3, 196], [196, 236], [54, 68], [68, 104], [104, 54],\n [193, 168], [168, 8], [8, 193], [117, 228], [228, 31], [31, 117],\n [189, 193], [193, 55], [55, 189], [98, 97], [97, 99], [99, 98],\n [126, 47], [47, 100], [100, 126], [166, 79], [79, 218], [218, 166],\n [155, 154], [154, 26], [26, 155], [209, 49], [49, 131], [131, 209],\n [135, 136], [136, 150], [150, 135], [47, 126], [126, 217], [217, 47],\n [223, 52], [52, 53], [53, 223], [45, 51], [51, 134], [134, 45],\n [211, 170], [170, 140], [140, 211], [67, 69], [69, 108], [108, 67],\n [43, 106], [106, 91], [91, 43], [230, 119], [119, 120], [120, 230],\n [226, 130], [130, 247], [247, 226], [63, 53], [53, 52], [52, 63],\n [238, 20], [20, 242], [242, 238], [46, 70], [70, 156], [156, 46],\n [78, 62], [62, 96], [96, 78], [46, 53], [53, 63], [63, 46],\n [143, 34], [34, 227], [227, 143], [123, 117], [117, 111], [111, 123],\n [44, 125], [125, 19], [19, 44], [236, 134], [134, 51], [51, 236],\n [216, 206], [206, 205], [205, 216], [154, 153], [153, 22], [22, 154],\n [39, 37], [37, 167], [167, 39], [200, 201], [201, 208], [208, 200],\n [36, 142], [142, 100], [100, 36], [57, 212], [212, 202], [202, 57],\n [20, 60], [60, 99], [99, 20], [28, 158], [158, 157], [157, 28],\n [35, 226], [226, 113], [113, 35], [160, 159], [159, 27], [27, 160],\n [204, 202], [202, 210], [210, 204], [113, 225], [225, 46], [46, 113],\n [43, 202], [202, 204], [204, 43], [62, 76], [76, 77], [77, 62],\n [137, 123], [123, 116], [116, 137], [41, 38], [38, 72], [72, 41],\n [203, 129], [129, 142], [142, 203], [64, 98], [98, 240], [240, 64],\n [49, 102], [102, 64], [64, 49], [41, 73], [73, 74], [74, 41],\n [212, 216], [216, 207], [207, 212], [42, 74], [74, 184], [184, 42],\n [169, 170], [170, 211], [211, 169], [170, 149], [149, 176], [176, 170],\n [105, 66], [66, 69], [69, 105], [122, 6], [6, 168], [168, 122],\n [123, 147], [147, 187], [187, 123], [96, 77], [77, 90], [90, 96],\n [65, 55], [55, 107], [107, 65], [89, 90], [90, 180], [180, 89],\n [101, 100], [100, 120], [120, 101], [63, 105], [105, 104], [104, 63],\n [93, 137], [137, 227], [227, 93], [15, 86], [86, 85], [85, 15],\n [129, 102], [102, 49], [49, 129], [14, 87], [87, 86], [86, 14],\n [55, 8], [8, 9], [9, 55], [100, 47], [47, 121], [121, 100],\n [145, 23], [23, 22], [22, 145], [88, 89], [89, 179], [179, 88],\n [6, 122], [122, 196], [196, 6], [88, 95], [95, 96], [96, 88],\n [138, 172], [172, 136], [136, 138], [215, 58], [58, 172], [172, 215],\n [115, 48], [48, 219], [219, 115], [42, 80], [80, 81], [81, 42],\n [195, 3], [3, 51], [51, 195], [43, 146], [146, 61], [61, 43],\n [171, 175], [175, 199], [199, 171], [81, 82], [82, 38], [38, 81],\n [53, 46], [46, 225], [225, 53], [144, 163], [163, 110], [110, 144],\n [52, 65], [65, 66], [66, 52], [229, 228], [228, 117], [117, 229],\n [34, 127], [127, 234], [234, 34], [107, 108], [108, 69], [69, 107],\n [109, 108], [108, 151], [151, 109], [48, 64], [64, 235], [235, 48],\n [62, 78], [78, 191], [191, 62], [129, 209], [209, 126], [126, 129],\n [111, 35], [35, 143], [143, 111], [117, 123], [123, 50], [50, 117],\n [222, 65], [65, 52], [52, 222], [19, 125], [125, 141], [141, 19],\n [221, 55], [55, 65], [65, 221], [3, 195], [195, 197], [197, 3],\n [25, 7], [7, 33], [33, 25], [220, 237], [237, 44], [44, 220],\n [70, 71], [71, 139], [139, 70], [122, 193], [193, 245], [245, 122],\n [247, 130], [130, 33], [33, 247], [71, 21], [21, 162], [162, 71],\n [170, 169], [169, 150], [150, 170], [188, 174], [174, 196], [196, 188],\n [216, 186], [186, 92], [92, 216], [2, 97], [97, 167], [167, 2],\n [141, 125], [125, 241], [241, 141], [164, 167], [167, 37], [37, 164],\n [72, 38], [38, 12], [12, 72], [38, 82], [82, 13], [13, 38],\n [63, 68], [68, 71], [71, 63], [226, 35], [35, 111], [111, 226],\n [101, 50], [50, 205], [205, 101], [206, 92], [92, 165], [165, 206],\n [209, 198], [198, 217], [217, 209], [165, 167], [167, 97], [97, 165],\n [220, 115], [115, 218], [218, 220], [133, 112], [112, 243], [243, 133],\n [239, 238], [238, 241], [241, 239], [214, 135], [135, 169], [169, 214],\n [190, 173], [173, 133], [133, 190], [171, 208], [208, 32], [32, 171],\n [125, 44], [44, 237], [237, 125], [86, 87], [87, 178], [178, 86],\n [85, 86], [86, 179], [179, 85], [84, 85], [85, 180], [180, 84],\n [83, 84], [84, 181], [181, 83], [201, 83], [83, 182], [182, 201],\n [137, 93], [93, 132], [132, 137], [76, 62], [62, 183], [183, 76],\n [61, 76], [76, 184], [184, 61], [57, 61], [61, 185], [185, 57],\n [212, 57], [57, 186], [186, 212], [214, 207], [207, 187], [187, 214],\n [34, 143], [143, 156], [156, 34], [79, 239], [239, 237], [237, 79],\n [123, 137], [137, 177], [177, 123], [44, 1], [1, 4], [4, 44],\n [201, 194], [194, 32], [32, 201], [64, 102], [102, 129], [129, 64],\n [213, 215], [215, 138], [138, 213], [59, 166], [166, 219], [219, 59],\n [242, 99], [99, 97], [97, 242], [2, 94], [94, 141], [141, 2],\n [75, 59], [59, 235], [235, 75], [24, 110], [110, 228], [228, 24],\n [25, 130], [130, 226], [226, 25], [23, 24], [24, 229], [229, 23],\n [22, 23], [23, 230], [230, 22], [26, 22], [22, 231], [231, 26],\n [112, 26], [26, 232], [232, 112], [189, 190], [190, 243], [243, 189],\n [221, 56], [56, 190], [190, 221], [28, 56], [56, 221], [221, 28],\n [27, 28], [28, 222], [222, 27], [29, 27], [27, 223], [223, 29],\n [30, 29], [29, 224], [224, 30], [247, 30], [30, 225], [225, 247],\n [238, 79], [79, 20], [20, 238], [166, 59], [59, 75], [75, 166],\n [60, 75], [75, 240], [240, 60], [147, 177], [177, 215], [215, 147],\n [20, 79], [79, 166], [166, 20], [187, 147], [147, 213], [213, 187],\n [112, 233], [233, 244], [244, 112], [233, 128], [128, 245], [245, 233],\n [128, 114], [114, 188], [188, 128], [114, 217], [217, 174], [174, 114],\n [131, 115], [115, 220], [220, 131], [217, 198], [198, 236], [236, 217],\n [198, 131], [131, 134], [134, 198], [177, 132], [132, 58], [58, 177],\n [143, 35], [35, 124], [124, 143], [110, 163], [163, 7], [7, 110],\n [228, 110], [110, 25], [25, 228], [356, 389], [389, 368], [368, 356],\n [11, 302], [302, 267], [267, 11], [452, 350], [350, 349], [349, 452],\n [302, 303], [303, 269], [269, 302], [357, 343], [343, 277], [277, 357],\n [452, 453], [453, 357], [357, 452], [333, 332], [332, 297], [297, 333],\n [175, 152], [152, 377], [377, 175], [347, 348], [348, 330], [330, 347],\n [303, 304], [304, 270], [270, 303], [9, 336], [336, 337], [337, 9],\n [278, 279], [279, 360], [360, 278], [418, 262], [262, 431], [431, 418],\n [304, 408], [408, 409], [409, 304], [310, 415], [415, 407], [407, 310],\n [270, 409], [409, 410], [410, 270], [450, 348], [348, 347], [347, 450],\n [422, 430], [430, 434], [434, 422], [313, 314], [314, 17], [17, 313],\n [306, 307], [307, 375], [375, 306], [387, 388], [388, 260], [260, 387],\n [286, 414], [414, 398], [398, 286], [335, 406], [406, 418], [418, 335],\n [364, 367], [367, 416], [416, 364], [423, 358], [358, 327], [327, 423],\n [251, 284], [284, 298], [298, 251], [281, 5], [5, 4], [4, 281],\n [373, 374], [374, 253], [253, 373], [307, 320], [320, 321], [321, 307],\n [425, 427], [427, 411], [411, 425], [421, 313], [313, 18], [18, 421],\n [321, 405], [405, 406], [406, 321], [320, 404], [404, 405], [405, 320],\n [315, 16], [16, 17], [17, 315], [426, 425], [425, 266], [266, 426],\n [377, 400], [400, 369], [369, 377], [322, 391], [391, 269], [269, 322],\n [417, 465], [465, 464], [464, 417], [386, 257], [257, 258], [258, 386],\n [466, 260], [260, 388], [388, 466], [456, 399], [399, 419], [419, 456],\n [284, 332], [332, 333], [333, 284], [417, 285], [285, 8], [8, 417],\n [346, 340], [340, 261], [261, 346], [413, 441], [441, 285], [285, 413],\n [327, 460], [460, 328], [328, 327], [355, 371], [371, 329], [329, 355],\n [392, 439], [439, 438], [438, 392], [382, 341], [341, 256], [256, 382],\n [429, 420], [420, 360], [360, 429], [364, 394], [394, 379], [379, 364],\n [277, 343], [343, 437], [437, 277], [443, 444], [444, 283], [283, 443],\n [275, 440], [440, 363], [363, 275], [431, 262], [262, 369], [369, 431],\n [297, 338], [338, 337], [337, 297], [273, 375], [375, 321], [321, 273],\n [450, 451], [451, 349], [349, 450], [446, 342], [342, 467], [467, 446],\n [293, 334], [334, 282], [282, 293], [458, 461], [461, 462], [462, 458],\n [276, 353], [353, 383], [383, 276], [308, 324], [324, 325], [325, 308],\n [276, 300], [300, 293], [293, 276], [372, 345], [345, 447], [447, 372],\n [352, 345], [345, 340], [340, 352], [274, 1], [1, 19], [19, 274],\n [456, 248], [248, 281], [281, 456], [436, 427], [427, 425], [425, 436],\n [381, 256], [256, 252], [252, 381], [269, 391], [391, 393], [393, 269],\n [200, 199], [199, 428], [428, 200], [266, 330], [330, 329], [329, 266],\n [287, 273], [273, 422], [422, 287], [250, 462], [462, 328], [328, 250],\n [258, 286], [286, 384], [384, 258], [265, 353], [353, 342], [342, 265],\n [387, 259], [259, 257], [257, 387], [424, 431], [431, 430], [430, 424],\n [342, 353], [353, 276], [276, 342], [273, 335], [335, 424], [424, 273],\n [292, 325], [325, 307], [307, 292], [366, 447], [447, 345], [345, 366],\n [271, 303], [303, 302], [302, 271], [423, 266], [266, 371], [371, 423],\n [294, 455], [455, 460], [460, 294], [279, 278], [278, 294], [294, 279],\n [271, 272], [272, 304], [304, 271], [432, 434], [434, 427], [427, 432],\n [272, 407], [407, 408], [408, 272], [394, 430], [430, 431], [431, 394],\n [395, 369], [369, 400], [400, 395], [334, 333], [333, 299], [299, 334],\n [351, 417], [417, 168], [168, 351], [352, 280], [280, 411], [411, 352],\n [325, 319], [319, 320], [320, 325], [295, 296], [296, 336], [336, 295],\n [319, 403], [403, 404], [404, 319], [330, 348], [348, 349], [349, 330],\n [293, 298], [298, 333], [333, 293], [323, 454], [454, 447], [447, 323],\n [15, 16], [16, 315], [315, 15], [358, 429], [429, 279], [279, 358],\n [14, 15], [15, 316], [316, 14], [285, 336], [336, 9], [9, 285],\n [329, 349], [349, 350], [350, 329], [374, 380], [380, 252], [252, 374],\n [318, 402], [402, 403], [403, 318], [6, 197], [197, 419], [419, 6],\n [318, 319], [319, 325], [325, 318], [367, 364], [364, 365], [365, 367],\n [435, 367], [367, 397], [397, 435], [344, 438], [438, 439], [439, 344],\n [272, 271], [271, 311], [311, 272], [195, 5], [5, 281], [281, 195],\n [273, 287], [287, 291], [291, 273], [396, 428], [428, 199], [199, 396],\n [311, 271], [271, 268], [268, 311], [283, 444], [444, 445], [445, 283],\n [373, 254], [254, 339], [339, 373], [282, 334], [334, 296], [296, 282],\n [449, 347], [347, 346], [346, 449], [264, 447], [447, 454], [454, 264],\n [336, 296], [296, 299], [299, 336], [338, 10], [10, 151], [151, 338],\n [278, 439], [439, 455], [455, 278], [292, 407], [407, 415], [415, 292],\n [358, 371], [371, 355], [355, 358], [340, 345], [345, 372], [372, 340],\n [346, 347], [347, 280], [280, 346], [442, 443], [443, 282], [282, 442],\n [19, 94], [94, 370], [370, 19], [441, 442], [442, 295], [295, 441],\n [248, 419], [419, 197], [197, 248], [263, 255], [255, 359], [359, 263],\n [440, 275], [275, 274], [274, 440], [300, 383], [383, 368], [368, 300],\n [351, 412], [412, 465], [465, 351], [263, 467], [467, 466], [466, 263],\n [301, 368], [368, 389], [389, 301], [395, 378], [378, 379], [379, 395],\n [412, 351], [351, 419], [419, 412], [436, 426], [426, 322], [322, 436],\n [2, 164], [164, 393], [393, 2], [370, 462], [462, 461], [461, 370],\n [164, 0], [0, 267], [267, 164], [302, 11], [11, 12], [12, 302],\n [268, 12], [12, 13], [13, 268], [293, 300], [300, 301], [301, 293],\n [446, 261], [261, 340], [340, 446], [330, 266], [266, 425], [425, 330],\n [426, 423], [423, 391], [391, 426], [429, 355], [355, 437], [437, 429],\n [391, 327], [327, 326], [326, 391], [440, 457], [457, 438], [438, 440],\n [341, 382], [382, 362], [362, 341], [459, 457], [457, 461], [461, 459],\n [434, 430], [430, 394], [394, 434], [414, 463], [463, 362], [362, 414],\n [396, 369], [369, 262], [262, 396], [354, 461], [461, 457], [457, 354],\n [316, 403], [403, 402], [402, 316], [315, 404], [404, 403], [403, 315],\n [314, 405], [405, 404], [404, 314], [313, 406], [406, 405], [405, 313],\n [421, 418], [418, 406], [406, 421], [366, 401], [401, 361], [361, 366],\n [306, 408], [408, 407], [407, 306], [291, 409], [409, 408], [408, 291],\n [287, 410], [410, 409], [409, 287], [432, 436], [436, 410], [410, 432],\n [434, 416], [416, 411], [411, 434], [264, 368], [368, 383], [383, 264],\n [309, 438], [438, 457], [457, 309], [352, 376], [376, 401], [401, 352],\n [274, 275], [275, 4], [4, 274], [421, 428], [428, 262], [262, 421],\n [294, 327], [327, 358], [358, 294], [433, 416], [416, 367], [367, 433],\n [289, 455], [455, 439], [439, 289], [462, 370], [370, 326], [326, 462],\n [2, 326], [326, 370], [370, 2], [305, 460], [460, 455], [455, 305],\n [254, 449], [449, 448], [448, 254], [255, 261], [261, 446], [446, 255],\n [253, 450], [450, 449], [449, 253], [252, 451], [451, 450], [450, 252],\n [256, 452], [452, 451], [451, 256], [341, 453], [453, 452], [452, 341],\n [413, 464], [464, 463], [463, 413], [441, 413], [413, 414], [414, 441],\n [258, 442], [442, 441], [441, 258], [257, 443], [443, 442], [442, 257],\n [259, 444], [444, 443], [443, 259], [260, 445], [445, 444], [444, 260],\n [467, 342], [342, 445], [445, 467], [459, 458], [458, 250], [250, 459],\n [289, 392], [392, 290], [290, 289], [290, 328], [328, 460], [460, 290],\n [376, 433], [433, 435], [435, 376], [250, 290], [290, 392], [392, 250],\n [411, 416], [416, 433], [433, 411], [341, 463], [463, 464], [464, 341],\n [453, 464], [464, 465], [465, 453], [357, 465], [465, 412], [412, 357],\n [343, 412], [412, 399], [399, 343], [360, 363], [363, 440], [440, 360],\n [437, 399], [399, 456], [456, 437], [420, 456], [456, 363], [363, 420],\n [401, 435], [435, 288], [288, 401], [372, 383], [383, 353], [353, 372],\n [339, 255], [255, 249], [249, 339], [448, 261], [261, 255], [255, 448],\n [133, 243], [243, 190], [190, 133], [133, 155], [155, 112], [112, 133],\n [33, 246], [246, 247], [247, 33], [33, 130], [130, 25], [25, 33],\n [398, 384], [384, 286], [286, 398], [362, 398], [398, 414], [414, 362],\n [362, 463], [463, 341], [341, 362], [263, 359], [359, 467], [467, 263],\n [263, 249], [249, 255], [255, 263], [466, 467], [467, 260], [260, 466],\n [75, 60], [60, 166], [166, 75], [238, 239], [239, 79], [79, 238],\n [162, 127], [127, 139], [139, 162], [72, 11], [11, 37], [37, 72],\n [121, 232], [232, 120], [120, 121], [73, 72], [72, 39], [39, 73],\n [114, 128], [128, 47], [47, 114], [233, 232], [232, 128], [128, 233],\n [103, 104], [104, 67], [67, 103], [152, 175], [175, 148], [148, 152],\n [119, 118], [118, 101], [101, 119], [74, 73], [73, 40], [40, 74],\n [107, 9], [9, 108], [108, 107], [49, 48], [48, 131], [131, 49],\n [32, 194], [194, 211], [211, 32], [184, 74], [74, 185], [185, 184],\n [191, 80], [80, 183], [183, 191], [185, 40], [40, 186], [186, 185],\n [119, 230], [230, 118], [118, 119], [210, 202], [202, 214], [214, 210],\n [84, 83], [83, 17], [17, 84], [77, 76], [76, 146], [146, 77],\n [161, 160], [160, 30], [30, 161], [190, 56], [56, 173], [173, 190],\n [182, 106], [106, 194], [194, 182], [138, 135], [135, 192], [192, 138],\n [129, 203], [203, 98], [98, 129], [54, 21], [21, 68], [68, 54],\n [5, 51], [51, 4], [4, 5], [145, 144], [144, 23], [23, 145],\n [90, 77], [77, 91], [91, 90], [207, 205], [205, 187], [187, 207],\n [83, 201], [201, 18], [18, 83], [181, 91], [91, 182], [182, 181],\n [180, 90], [90, 181], [181, 180], [16, 85], [85, 17], [17, 16],\n [205, 206], [206, 36], [36, 205], [176, 148], [148, 140], [140, 176],\n [165, 92], [92, 39], [39, 165], [245, 193], [193, 244], [244, 245],\n [27, 159], [159, 28], [28, 27], [30, 247], [247, 161], [161, 30],\n [174, 236], [236, 196], [196, 174], [103, 54], [54, 104], [104, 103],\n [55, 193], [193, 8], [8, 55], [111, 117], [117, 31], [31, 111],\n [221, 189], [189, 55], [55, 221], [240, 98], [98, 99], [99, 240],\n [142, 126], [126, 100], [100, 142], [219, 166], [166, 218], [218, 219],\n [112, 155], [155, 26], [26, 112], [198, 209], [209, 131], [131, 198],\n [169, 135], [135, 150], [150, 169], [114, 47], [47, 217], [217, 114],\n [224, 223], [223, 53], [53, 224], [220, 45], [45, 134], [134, 220],\n [32, 211], [211, 140], [140, 32], [109, 67], [67, 108], [108, 109],\n [146, 43], [43, 91], [91, 146], [231, 230], [230, 120], [120, 231],\n [113, 226], [226, 247], [247, 113], [105, 63], [63, 52], [52, 105],\n [241, 238], [238, 242], [242, 241], [124, 46], [46, 156], [156, 124],\n [95, 78], [78, 96], [96, 95], [70, 46], [46, 63], [63, 70],\n [116, 143], [143, 227], [227, 116], [116, 123], [123, 111], [111, 116],\n [1, 44], [44, 19], [19, 1], [3, 236], [236, 51], [51, 3],\n [207, 216], [216, 205], [205, 207], [26, 154], [154, 22], [22, 26],\n [165, 39], [39, 167], [167, 165], [199, 200], [200, 208], [208, 199],\n [101, 36], [36, 100], [100, 101], [43, 57], [57, 202], [202, 43],\n [242, 20], [20, 99], [99, 242], [56, 28], [28, 157], [157, 56],\n [124, 35], [35, 113], [113, 124], [29, 160], [160, 27], [27, 29],\n [211, 204], [204, 210], [210, 211], [124, 113], [113, 46], [46, 124],\n [106, 43], [43, 204], [204, 106], [96, 62], [62, 77], [77, 96],\n [227, 137], [137, 116], [116, 227], [73, 41], [41, 72], [72, 73],\n [36, 203], [203, 142], [142, 36], [235, 64], [64, 240], [240, 235],\n [48, 49], [49, 64], [64, 48], [42, 41], [41, 74], [74, 42],\n [214, 212], [212, 207], [207, 214], [183, 42], [42, 184], [184, 183],\n [210, 169], [169, 211], [211, 210], [140, 170], [170, 176], [176, 140],\n [104, 105], [105, 69], [69, 104], [193, 122], [122, 168], [168, 193],\n [50, 123], [123, 187], [187, 50], [89, 96], [96, 90], [90, 89],\n [66, 65], [65, 107], [107, 66], [179, 89], [89, 180], [180, 179],\n [119, 101], [101, 120], [120, 119], [68, 63], [63, 104], [104, 68],\n [234, 93], [93, 227], [227, 234], [16, 15], [15, 85], [85, 16],\n [209, 129], [129, 49], [49, 209], [15, 14], [14, 86], [86, 15],\n [107, 55], [55, 9], [9, 107], [120, 100], [100, 121], [121, 120],\n [153, 145], [145, 22], [22, 153], [178, 88], [88, 179], [179, 178],\n [197, 6], [6, 196], [196, 197], [89, 88], [88, 96], [96, 89],\n [135, 138], [138, 136], [136, 135], [138, 215], [215, 172], [172, 138],\n [218, 115], [115, 219], [219, 218], [41, 42], [42, 81], [81, 41],\n [5, 195], [195, 51], [51, 5], [57, 43], [43, 61], [61, 57],\n [208, 171], [171, 199], [199, 208], [41, 81], [81, 38], [38, 41],\n [224, 53], [53, 225], [225, 224], [24, 144], [144, 110], [110, 24],\n [105, 52], [52, 66], [66, 105], [118, 229], [229, 117], [117, 118],\n [227, 34], [34, 234], [234, 227], [66, 107], [107, 69], [69, 66],\n [10, 109], [109, 151], [151, 10], [219, 48], [48, 235], [235, 219],\n [183, 62], [62, 191], [191, 183], [142, 129], [129, 126], [126, 142],\n [116, 111], [111, 143], [143, 116], [118, 117], [117, 50], [50, 118],\n [223, 222], [222, 52], [52, 223], [94, 19], [19, 141], [141, 94],\n [222, 221], [221, 65], [65, 222], [196, 3], [3, 197], [197, 196],\n [45, 220], [220, 44], [44, 45], [156, 70], [70, 139], [139, 156],\n [188, 122], [122, 245], [245, 188], [139, 71], [71, 162], [162, 139],\n [149, 170], [170, 150], [150, 149], [122, 188], [188, 196], [196, 122],\n [206, 216], [216, 92], [92, 206], [164, 2], [2, 167], [167, 164],\n [242, 141], [141, 241], [241, 242], [0, 164], [164, 37], [37, 0],\n [11, 72], [72, 12], [12, 11], [12, 38], [38, 13], [13, 12],\n [70, 63], [63, 71], [71, 70], [31, 226], [226, 111], [111, 31],\n [36, 101], [101, 205], [205, 36], [203, 206], [206, 165], [165, 203],\n [126, 209], [209, 217], [217, 126], [98, 165], [165, 97], [97, 98],\n [237, 220], [220, 218], [218, 237], [237, 239], [239, 241], [241, 237],\n [210, 214], [214, 169], [169, 210], [140, 171], [171, 32], [32, 140],\n [241, 125], [125, 237], [237, 241], [179, 86], [86, 178], [178, 179],\n [180, 85], [85, 179], [179, 180], [181, 84], [84, 180], [180, 181],\n [182, 83], [83, 181], [181, 182], [194, 201], [201, 182], [182, 194],\n [177, 137], [137, 132], [132, 177], [184, 76], [76, 183], [183, 184],\n [185, 61], [61, 184], [184, 185], [186, 57], [57, 185], [185, 186],\n [216, 212], [212, 186], [186, 216], [192, 214], [214, 187], [187, 192],\n [139, 34], [34, 156], [156, 139], [218, 79], [79, 237], [237, 218],\n [147, 123], [123, 177], [177, 147], [45, 44], [44, 4], [4, 45],\n [208, 201], [201, 32], [32, 208], [98, 64], [64, 129], [129, 98],\n [192, 213], [213, 138], [138, 192], [235, 59], [59, 219], [219, 235],\n [141, 242], [242, 97], [97, 141], [97, 2], [2, 141], [141, 97],\n [240, 75], [75, 235], [235, 240], [229, 24], [24, 228], [228, 229],\n [31, 25], [25, 226], [226, 31], [230, 23], [23, 229], [229, 230],\n [231, 22], [22, 230], [230, 231], [232, 26], [26, 231], [231, 232],\n [233, 112], [112, 232], [232, 233], [244, 189], [189, 243], [243, 244],\n [189, 221], [221, 190], [190, 189], [222, 28], [28, 221], [221, 222],\n [223, 27], [27, 222], [222, 223], [224, 29], [29, 223], [223, 224],\n [225, 30], [30, 224], [224, 225], [113, 247], [247, 225], [225, 113],\n [99, 60], [60, 240], [240, 99], [213, 147], [147, 215], [215, 213],\n [60, 20], [20, 166], [166, 60], [192, 187], [187, 213], [213, 192],\n [243, 112], [112, 244], [244, 243], [244, 233], [233, 245], [245, 244],\n [245, 128], [128, 188], [188, 245], [188, 114], [114, 174], [174, 188],\n [134, 131], [131, 220], [220, 134], [174, 217], [217, 236], [236, 174],\n [236, 198], [198, 134], [134, 236], [215, 177], [177, 58], [58, 215],\n [156, 143], [143, 124], [124, 156], [25, 110], [110, 7], [7, 25],\n [31, 228], [228, 25], [25, 31], [264, 356], [356, 368], [368, 264],\n [0, 11], [11, 267], [267, 0], [451, 452], [452, 349], [349, 451],\n [267, 302], [302, 269], [269, 267], [350, 357], [357, 277], [277, 350],\n [350, 452], [452, 357], [357, 350], [299, 333], [333, 297], [297, 299],\n [396, 175], [175, 377], [377, 396], [280, 347], [347, 330], [330, 280],\n [269, 303], [303, 270], [270, 269], [151, 9], [9, 337], [337, 151],\n [344, 278], [278, 360], [360, 344], [424, 418], [418, 431], [431, 424],\n [270, 304], [304, 409], [409, 270], [272, 310], [310, 407], [407, 272],\n [322, 270], [270, 410], [410, 322], [449, 450], [450, 347], [347, 449],\n [432, 422], [422, 434], [434, 432], [18, 313], [313, 17], [17, 18],\n [291, 306], [306, 375], [375, 291], [259, 387], [387, 260], [260, 259],\n [424, 335], [335, 418], [418, 424], [434, 364], [364, 416], [416, 434],\n [391, 423], [423, 327], [327, 391], [301, 251], [251, 298], [298, 301],\n [275, 281], [281, 4], [4, 275], [254, 373], [373, 253], [253, 254],\n [375, 307], [307, 321], [321, 375], [280, 425], [425, 411], [411, 280],\n [200, 421], [421, 18], [18, 200], [335, 321], [321, 406], [406, 335],\n [321, 320], [320, 405], [405, 321], [314, 315], [315, 17], [17, 314],\n [423, 426], [426, 266], [266, 423], [396, 377], [377, 369], [369, 396],\n [270, 322], [322, 269], [269, 270], [413, 417], [417, 464], [464, 413],\n [385, 386], [386, 258], [258, 385], [248, 456], [456, 419], [419, 248],\n [298, 284], [284, 333], [333, 298], [168, 417], [417, 8], [8, 168],\n [448, 346], [346, 261], [261, 448], [417, 413], [413, 285], [285, 417],\n [326, 327], [327, 328], [328, 326], [277, 355], [355, 329], [329, 277],\n [309, 392], [392, 438], [438, 309], [381, 382], [382, 256], [256, 381],\n [279, 429], [429, 360], [360, 279], [365, 364], [364, 379], [379, 365],\n [355, 277], [277, 437], [437, 355], [282, 443], [443, 283], [283, 282],\n [281, 275], [275, 363], [363, 281], [395, 431], [431, 369], [369, 395],\n [299, 297], [297, 337], [337, 299], [335, 273], [273, 321], [321, 335],\n [348, 450], [450, 349], [349, 348], [359, 446], [446, 467], [467, 359],\n [283, 293], [293, 282], [282, 283], [250, 458], [458, 462], [462, 250],\n [300, 276], [276, 383], [383, 300], [292, 308], [308, 325], [325, 292],\n [283, 276], [276, 293], [293, 283], [264, 372], [372, 447], [447, 264],\n [346, 352], [352, 340], [340, 346], [354, 274], [274, 19], [19, 354],\n [363, 456], [456, 281], [281, 363], [426, 436], [436, 425], [425, 426],\n [380, 381], [381, 252], [252, 380], [267, 269], [269, 393], [393, 267],\n [421, 200], [200, 428], [428, 421], [371, 266], [266, 329], [329, 371],\n [432, 287], [287, 422], [422, 432], [290, 250], [250, 328], [328, 290],\n [385, 258], [258, 384], [384, 385], [446, 265], [265, 342], [342, 446],\n [386, 387], [387, 257], [257, 386], [422, 424], [424, 430], [430, 422],\n [445, 342], [342, 276], [276, 445], [422, 273], [273, 424], [424, 422],\n [306, 292], [292, 307], [307, 306], [352, 366], [366, 345], [345, 352],\n [268, 271], [271, 302], [302, 268], [358, 423], [423, 371], [371, 358],\n [327, 294], [294, 460], [460, 327], [331, 279], [279, 294], [294, 331],\n [303, 271], [271, 304], [304, 303], [436, 432], [432, 427], [427, 436],\n [304, 272], [272, 408], [408, 304], [395, 394], [394, 431], [431, 395],\n [378, 395], [395, 400], [400, 378], [296, 334], [334, 299], [299, 296],\n [6, 351], [351, 168], [168, 6], [376, 352], [352, 411], [411, 376],\n [307, 325], [325, 320], [320, 307], [285, 295], [295, 336], [336, 285],\n [320, 319], [319, 404], [404, 320], [329, 330], [330, 349], [349, 329],\n [334, 293], [293, 333], [333, 334], [366, 323], [323, 447], [447, 366],\n [316, 15], [15, 315], [315, 316], [331, 358], [358, 279], [279, 331],\n [317, 14], [14, 316], [316, 317], [8, 285], [285, 9], [9, 8],\n [277, 329], [329, 350], [350, 277], [253, 374], [374, 252], [252, 253],\n [319, 318], [318, 403], [403, 319], [351, 6], [6, 419], [419, 351],\n [324, 318], [318, 325], [325, 324], [397, 367], [367, 365], [365, 397],\n [288, 435], [435, 397], [397, 288], [278, 344], [344, 439], [439, 278],\n [310, 272], [272, 311], [311, 310], [248, 195], [195, 281], [281, 248],\n [375, 273], [273, 291], [291, 375], [175, 396], [396, 199], [199, 175],\n [312, 311], [311, 268], [268, 312], [276, 283], [283, 445], [445, 276],\n [390, 373], [373, 339], [339, 390], [295, 282], [282, 296], [296, 295],\n [448, 449], [449, 346], [346, 448], [356, 264], [264, 454], [454, 356],\n [337, 336], [336, 299], [299, 337], [337, 338], [338, 151], [151, 337],\n [294, 278], [278, 455], [455, 294], [308, 292], [292, 415], [415, 308],\n [429, 358], [358, 355], [355, 429], [265, 340], [340, 372], [372, 265],\n [352, 346], [346, 280], [280, 352], [295, 442], [442, 282], [282, 295],\n [354, 19], [19, 370], [370, 354], [285, 441], [441, 295], [295, 285],\n [195, 248], [248, 197], [197, 195], [457, 440], [440, 274], [274, 457],\n [301, 300], [300, 368], [368, 301], [417, 351], [351, 465], [465, 417],\n [251, 301], [301, 389], [389, 251], [394, 395], [395, 379], [379, 394],\n [399, 412], [412, 419], [419, 399], [410, 436], [436, 322], [322, 410],\n [326, 2], [2, 393], [393, 326], [354, 370], [370, 461], [461, 354],\n [393, 164], [164, 267], [267, 393], [268, 302], [302, 12], [12, 268],\n [312, 268], [268, 13], [13, 312], [298, 293], [293, 301], [301, 298],\n [265, 446], [446, 340], [340, 265], [280, 330], [330, 425], [425, 280],\n [322, 426], [426, 391], [391, 322], [420, 429], [429, 437], [437, 420],\n [393, 391], [391, 326], [326, 393], [344, 440], [440, 438], [438, 344],\n [458, 459], [459, 461], [461, 458], [364, 434], [434, 394], [394, 364],\n [428, 396], [396, 262], [262, 428], [274, 354], [354, 457], [457, 274],\n [317, 316], [316, 402], [402, 317], [316, 315], [315, 403], [403, 316],\n [315, 314], [314, 404], [404, 315], [314, 313], [313, 405], [405, 314],\n [313, 421], [421, 406], [406, 313], [323, 366], [366, 361], [361, 323],\n [292, 306], [306, 407], [407, 292], [306, 291], [291, 408], [408, 306],\n [291, 287], [287, 409], [409, 291], [287, 432], [432, 410], [410, 287],\n [427, 434], [434, 411], [411, 427], [372, 264], [264, 383], [383, 372],\n [459, 309], [309, 457], [457, 459], [366, 352], [352, 401], [401, 366],\n [1, 274], [274, 4], [4, 1], [418, 421], [421, 262], [262, 418],\n [331, 294], [294, 358], [358, 331], [435, 433], [433, 367], [367, 435],\n [392, 289], [289, 439], [439, 392], [328, 462], [462, 326], [326, 328],\n [94, 2], [2, 370], [370, 94], [289, 305], [305, 455], [455, 289],\n [339, 254], [254, 448], [448, 339], [359, 255], [255, 446], [446, 359],\n [254, 253], [253, 449], [449, 254], [253, 252], [252, 450], [450, 253],\n [252, 256], [256, 451], [451, 252], [256, 341], [341, 452], [452, 256],\n [414, 413], [413, 463], [463, 414], [286, 441], [441, 414], [414, 286],\n [286, 258], [258, 441], [441, 286], [258, 257], [257, 442], [442, 258],\n [257, 259], [259, 443], [443, 257], [259, 260], [260, 444], [444, 259],\n [260, 467], [467, 445], [445, 260], [309, 459], [459, 250], [250, 309],\n [305, 289], [289, 290], [290, 305], [305, 290], [290, 460], [460, 305],\n [401, 376], [376, 435], [435, 401], [309, 250], [250, 392], [392, 309],\n [376, 411], [411, 433], [433, 376], [453, 341], [341, 464], [464, 453],\n [357, 453], [453, 465], [465, 357], [343, 357], [357, 412], [412, 343],\n [437, 343], [343, 399], [399, 437], [344, 360], [360, 440], [440, 344],\n [420, 437], [437, 456], [456, 420], [360, 420], [420, 363], [363, 360],\n [361, 401], [401, 288], [288, 361], [265, 372], [372, 353], [353, 265],\n [390, 339], [339, 249], [249, 390], [339, 448], [448, 255], [255, 339],\n];\n", "/**\n * BlazeFace, FaceMesh & Iris model implementation\n * See `facemesh.ts` for entry point\n */\n\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as coords from './facemeshcoords';\nimport { constants } from '../tfjs/constants';\nimport type { Box, Point } from '../result';\nimport { env } from '../util/env';\n\nexport const createBox = (startEndTensor) => ({ startPoint: tf.slice(startEndTensor, [0, 0], [-1, 2]), endPoint: tf.slice(startEndTensor, [0, 2], [-1, 2]) });\n\nexport const disposeBox = (t) => tf.dispose([t.startPoint, t.endPoint]);\n\nexport const getBoxSize = (box): [number, number] => [Math.abs(box.endPoint[0] - box.startPoint[0]), Math.abs(box.endPoint[1] - box.startPoint[1])];\n\nexport const getBoxCenter = (box): [number, number, number] => [box.startPoint[0] + (box.endPoint[0] - box.startPoint[0]) / 2, box.startPoint[1] + (box.endPoint[1] - box.startPoint[1]) / 2, 1];\n\nexport const clampBox = (box, input): Box => (box ? [\n Math.trunc(Math.max(0, box.startPoint[0])),\n Math.trunc(Math.max(0, box.startPoint[1])),\n Math.trunc(Math.min((input.shape[2] || 0), box.endPoint[0]) - Math.max(0, box.startPoint[0])),\n Math.trunc(Math.min((input.shape[1] || 0), box.endPoint[1]) - Math.max(0, box.startPoint[1])),\n] : [0, 0, 0, 0]);\n\nexport const getRawBox = (box, input): Box => (box ? [\n box.startPoint[0] / (input.shape[2] || 0),\n box.startPoint[1] / (input.shape[1] || 0),\n (box.endPoint[0] - box.startPoint[0]) / (input.shape[2] || 0),\n (box.endPoint[1] - box.startPoint[1]) / (input.shape[1] || 0),\n] : [0, 0, 0, 0]);\n\nexport const scaleBoxCoordinates = (box, factor) => {\n const startPoint: Point = [box.startPoint[0] * factor[0], box.startPoint[1] * factor[1]];\n const endPoint: Point = [box.endPoint[0] * factor[0], box.endPoint[1] * factor[1]];\n return { startPoint, endPoint, landmarks: box.landmarks, confidence: box.confidence };\n};\n\nexport const cutAndResize = (box, image, cropSize) => {\n const h = image.shape[1];\n const w = image.shape[2];\n const cutBox = [box.startPoint[1] / h, box.startPoint[0] / w, box.endPoint[1] / h, box.endPoint[0] / w];\n const crop = tf.image.cropAndResize(image, [cutBox], [0], cropSize);\n const norm = tf.div(crop, constants.tf255);\n tf.dispose(crop);\n return norm;\n};\n\nexport const enlargeBox = (box, factor) => {\n const center = getBoxCenter(box);\n const size = getBoxSize(box);\n const halfSize: [number, number] = [factor * size[0] / 2, factor * size[1] / 2];\n return { startPoint: [center[0] - halfSize[0], center[1] - halfSize[1]] as Point, endPoint: [center[0] + halfSize[0], center[1] + halfSize[1]] as Point, landmarks: box.landmarks, confidence: box.confidence };\n};\n\nexport const squarifyBox = (box) => {\n const centers = getBoxCenter(box);\n const size = getBoxSize(box);\n const halfSize = Math.max(...size) / 2;\n return { startPoint: [Math.round(centers[0] - halfSize), Math.round(centers[1] - halfSize)] as Point, endPoint: [Math.round(centers[0] + halfSize), Math.round(centers[1] + halfSize)] as Point, landmarks: box.landmarks, confidence: box.confidence };\n};\n\nexport const calculateLandmarksBoundingBox = (landmarks) => {\n const x = landmarks.map((d) => d[0]);\n const y = landmarks.map((d) => d[1]);\n return { startPoint: [Math.min(...x), Math.min(...y)] as Point, endPoint: [Math.max(...x), Math.max(...y)] as Point, landmarks };\n};\n\nexport const fixedRotationMatrix = [[1, 0, 0], [0, 1, 0], [0, 0, 1]];\n\nexport const normalizeRadians = (angle) => angle - 2 * Math.PI * Math.floor((angle + Math.PI) / (2 * Math.PI));\n\nexport const computeRotation = (point1, point2) => normalizeRadians(Math.PI / 2 - Math.atan2(-(point2[1] - point1[1]), point2[0] - point1[0]));\n\nexport const radToDegrees = (rad) => rad * 180 / Math.PI;\n\nexport const buildTranslationMatrix = (x, y) => [[1, 0, x], [0, 1, y], [0, 0, 1]];\n\nexport const dot = (v1: number[], v2: number[]) => {\n let product = 0;\n for (let i = 0; i < v1.length; i++) product += v1[i] * v2[i];\n return product;\n};\n\nexport const getColumnFrom2DArr = (arr, columnIndex) => {\n const column: Array = [];\n for (let i = 0; i < arr.length; i++) column.push(arr[i][columnIndex]);\n return column;\n};\n\nexport const multiplyTransformMatrices = (mat1, mat2) => {\n const product: Array = [];\n const size = mat1.length;\n for (let row = 0; row < size; row++) {\n product.push([]);\n for (let col = 0; col < size; col++) product[row].push(dot(mat1[row], getColumnFrom2DArr(mat2, col)));\n }\n return product;\n};\n\nexport const buildRotationMatrix = (rotation, center) => {\n const cosA = Math.cos(rotation);\n const sinA = Math.sin(rotation);\n const rotationMatrix = [[cosA, -sinA, 0], [sinA, cosA, 0], [0, 0, 1]];\n const translationMatrix = buildTranslationMatrix(center[0], center[1]);\n const translationTimesRotation = multiplyTransformMatrices(translationMatrix, rotationMatrix);\n const negativeTranslationMatrix = buildTranslationMatrix(-center[0], -center[1]);\n return multiplyTransformMatrices(translationTimesRotation, negativeTranslationMatrix);\n};\n\nexport const invertTransformMatrix = (matrix) => {\n const rotationComponent = [[matrix[0][0], matrix[1][0]], [matrix[0][1], matrix[1][1]]];\n const translationComponent = [matrix[0][2], matrix[1][2]];\n const invertedTranslation = [-dot(rotationComponent[0], translationComponent), -dot(rotationComponent[1], translationComponent)];\n return [rotationComponent[0].concat(invertedTranslation[0]), rotationComponent[1].concat(invertedTranslation[1]), [0, 0, 1]];\n};\n\nexport const rotatePoint = (homogeneousCoordinate, rotationMatrix) => [dot(homogeneousCoordinate, rotationMatrix[0]), dot(homogeneousCoordinate, rotationMatrix[1])];\n\nexport const xyDistanceBetweenPoints = (a, b) => Math.sqrt(((a[0] - b[0]) ** 2) + ((a[1] - b[1]) ** 2));\n\nexport function generateAnchors(inputSize) {\n const spec = inputSize === 192\n ? { strides: [4], anchors: [1] } // facemesh-detector\n : { strides: [inputSize / 16, inputSize / 8], anchors: [2, 6] }; // blazeface\n const anchors: Array<[number, number]> = [];\n for (let i = 0; i < spec.strides.length; i++) {\n const stride = spec.strides[i];\n const gridRows = Math.floor((inputSize + stride - 1) / stride);\n const gridCols = Math.floor((inputSize + stride - 1) / stride);\n const anchorsNum = spec.anchors[i];\n for (let gridY = 0; gridY < gridRows; gridY++) {\n const anchorY = stride * (gridY + 0.5);\n for (let gridX = 0; gridX < gridCols; gridX++) {\n const anchorX = stride * (gridX + 0.5);\n for (let n = 0; n < anchorsNum; n++) anchors.push([anchorX, anchorY]);\n }\n }\n }\n return anchors;\n}\n\nexport function transformRawCoords(coordsRaw, box, angle, rotationMatrix, inputSize) {\n const boxSize = getBoxSize(box);\n const coordsScaled = coordsRaw.map((coord) => ([ // scaled around zero-point\n (boxSize[0] / inputSize) * (coord[0] - (inputSize / 2)),\n (boxSize[1] / inputSize) * (coord[1] - (inputSize / 2)),\n (coord[2] || 0),\n ]));\n const largeAngle = angle && (angle !== 0) && (Math.abs(angle) > 0.2);\n const coordsRotationMatrix = largeAngle ? buildRotationMatrix(angle, [0, 0]) : fixedRotationMatrix;\n const coordsRotated = largeAngle ? coordsScaled.map((coord) => ([...rotatePoint(coord, coordsRotationMatrix), coord[2]])) : coordsScaled;\n const inverseRotationMatrix = largeAngle ? invertTransformMatrix(rotationMatrix) : fixedRotationMatrix;\n const boxCenter = getBoxCenter(box);\n const offsets = [dot(boxCenter, inverseRotationMatrix[0]), dot(boxCenter, inverseRotationMatrix[1])];\n return coordsRotated.map((coord) => ([\n Math.trunc(coord[0] + offsets[0]),\n Math.trunc(coord[1] + offsets[1]),\n Math.trunc(coord[2] || 0),\n ]));\n}\n\nexport function correctFaceRotation(rotate, box, input, inputSize) {\n const symmetryLine = (box.landmarks.length >= coords.meshLandmarks.count)\n ? coords.meshLandmarks.symmetryLine\n : coords.blazeFaceLandmarks.symmetryLine;\n let angle = 0; // default\n let rotationMatrix = fixedRotationMatrix; // default\n let face; // default\n\n if (rotate && env.kernels.includes('rotatewithoffset')) { // rotateWithOffset is not defined for tfjs-node\n angle = computeRotation(box.landmarks[symmetryLine[0]], box.landmarks[symmetryLine[1]]);\n const largeAngle = angle && (angle !== 0) && (Math.abs(angle) > 0.2);\n if (largeAngle) { // perform rotation only if angle is sufficiently high\n const center: Point = getBoxCenter(box);\n const centerRaw: Point = [center[0] / input.shape[2], center[1] / input.shape[1]];\n const rotated = tf.image.rotateWithOffset(input, angle, 0, centerRaw);\n rotationMatrix = buildRotationMatrix(-angle, center);\n face = cutAndResize(box, rotated, [inputSize, inputSize]);\n tf.dispose(rotated);\n } else {\n face = cutAndResize(box, input, [inputSize, inputSize]);\n }\n } else {\n face = cutAndResize(box, input, [inputSize, inputSize]);\n }\n return [angle, rotationMatrix, face];\n}\n\nexport const findFaceCenter = (mesh) => {\n const x = mesh.map((m) => m[0]);\n const y = mesh.map((m) => m[1]);\n // weighted center\n /*\n const sum = (arr: number[]) => arr.reduce((prev, curr) => prev + curr, 0);\n return [sum(x) / mesh.length, sum(y) / mesh.length];\n */\n // absolute center\n return [Math.min(...x) + (Math.max(...x) - Math.min(...x)) / 2, Math.min(...y) + (Math.max(...y) - Math.min(...y)) / 2];\n};\n\nexport const calculateFaceBox = (mesh, previousBox) => {\n const center = findFaceCenter(mesh);\n const boxSize = getBoxSize(previousBox);\n const calculatedBox = {\n startPoint: [center[0] - boxSize[0] / 2, center[1] - boxSize[1] / 2] as Point,\n endPoint: [center[0] + boxSize[0] / 2, center[1] + boxSize[1] / 2] as Point,\n };\n return calculatedBox;\n};\n", "/**\n * BlazeFace, FaceMesh & Iris model implementation\n * See `facemesh.ts` for entry point\n */\n\nimport { log } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as util from './facemeshutil';\nimport { loadModel } from '../tfjs/load';\nimport { constants } from '../tfjs/constants';\nimport type { Config } from '../config';\nimport type { Tensor, GraphModel } from '../tfjs/types';\nimport { env } from '../util/env';\nimport type { Point } from '../result';\n\nconst keypointsCount = 6;\nconst faceBoxScaleFactor = 1.4;\nlet model: GraphModel | null;\nlet anchors: Tensor | null = null;\nlet inputSize = 0;\nlet inputSizeT: Tensor | null = null;\n\ntype DetectBox = { startPoint: Point, endPoint: Point, landmarks: Array, confidence: number };\n\nexport const size = () => inputSize;\n\nexport async function load(config: Config): Promise {\n if (env.initial) model = null;\n if (!model) model = await loadModel(config.face.detector?.modelPath);\n else if (config.debug) log('cached model:', model['modelUrl']);\n inputSize = model.inputs[0].shape ? model.inputs[0].shape[2] : 0;\n inputSizeT = tf.scalar(inputSize, 'int32') as Tensor;\n anchors = tf.tensor2d(util.generateAnchors(inputSize)) as Tensor;\n return model;\n}\n\nfunction decodeBounds(boxOutputs: Tensor) {\n const t: Record = {};\n t.boxStarts = tf.slice(boxOutputs, [0, 1], [-1, 2]);\n t.centers = tf.add(t.boxStarts, anchors);\n t.boxSizes = tf.slice(boxOutputs, [0, 3], [-1, 2]);\n t.boxSizesNormalized = tf.div(t.boxSizes, inputSizeT);\n t.centersNormalized = tf.div(t.centers, inputSizeT);\n t.halfBoxSize = tf.div(t.boxSizesNormalized, constants.tf2);\n t.starts = tf.sub(t.centersNormalized, t.halfBoxSize);\n t.ends = tf.add(t.centersNormalized, t.halfBoxSize);\n t.startNormalized = tf.mul(t.starts, inputSizeT);\n t.endNormalized = tf.mul(t.ends, inputSizeT);\n const boxes = tf.concat2d([t.startNormalized, t.endNormalized], 1);\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n return boxes;\n}\n\nexport async function getBoxes(inputImage: Tensor, config: Config) {\n // sanity check on input\n if ((!inputImage) || (inputImage['isDisposedInternal']) || (inputImage.shape.length !== 4) || (inputImage.shape[1] < 1) || (inputImage.shape[2] < 1)) return [];\n const t: Record = {};\n t.resized = tf.image.resizeBilinear(inputImage, [inputSize, inputSize]);\n t.div = tf.div(t.resized, constants.tf127);\n t.normalized = tf.sub(t.div, constants.tf05);\n const res = model?.execute(t.normalized) as Tensor[];\n if (Array.isArray(res) && res.length > 2) { // pinto converted model?\n const sorted = res.sort((a, b) => a.size - b.size);\n t.concat384 = tf.concat([sorted[0], sorted[2]], 2); // dim: 384, 1 + 16\n t.concat512 = tf.concat([sorted[1], sorted[3]], 2); // dim: 512, 1 + 16\n t.concat = tf.concat([t.concat512, t.concat384], 1);\n t.batch = tf.squeeze(t.concat, 0);\n } else if (Array.isArray(res)) { // new facemesh-detection tfhub model\n t.batch = tf.squeeze(res[0]);\n } else { // original blazeface tfhub model\n t.batch = tf.squeeze(res);\n }\n tf.dispose(res);\n t.boxes = decodeBounds(t.batch);\n t.logits = tf.slice(t.batch, [0, 0], [-1, 1]);\n t.sigmoid = tf.sigmoid(t.logits);\n t.scores = tf.squeeze(t.sigmoid);\n t.nms = await tf.image.nonMaxSuppressionAsync(t.boxes, t.scores, (config.face.detector?.maxDetected || 0), (config.face.detector?.iouThreshold || 0), (config.face.detector?.minConfidence || 0));\n const nms = await t.nms.array() as number[];\n const boxes: Array = [];\n const scores = await t.scores.data();\n for (let i = 0; i < nms.length; i++) {\n const confidence = scores[nms[i]];\n if (confidence > (config.face.detector?.minConfidence || 0)) {\n const b: Record = {};\n b.bbox = tf.slice(t.boxes, [nms[i], 0], [1, -1]);\n b.slice = tf.slice(t.batch, [nms[i], keypointsCount - 1], [1, -1]);\n b.squeeze = tf.squeeze(b.slice);\n b.landmarks = tf.reshape(b.squeeze, [keypointsCount, -1]);\n const points = await b.bbox.data();\n const rawBox = {\n startPoint: [points[0], points[1]] as Point,\n endPoint: [points[2], points[3]] as Point,\n landmarks: (await b.landmarks.array()) as Point[],\n confidence,\n };\n const scaledBox = util.scaleBoxCoordinates(rawBox, [(inputImage.shape[2] || 0) / inputSize, (inputImage.shape[1] || 0) / inputSize]);\n const enlargedBox = util.enlargeBox(scaledBox, config.face['scale'] || faceBoxScaleFactor);\n const squaredBox = util.squarifyBox(enlargedBox);\n boxes.push(squaredBox);\n Object.keys(b).forEach((tensor) => tf.dispose(b[tensor]));\n }\n }\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n return boxes;\n}\n", "/* eslint-disable no-multi-spaces */\n\nexport const kpt: Array = [\n 'nose', // 0\n 'leftEyeInside', // 1\n 'leftEye', // 2\n 'leftEyeOutside', // 3\n 'rightEyeInside', // 4\n 'rightEye', // 5\n 'rightEyeOutside', // 6\n 'leftEar', // 7\n 'rightEar', // 8\n 'leftMouth', // 9\n 'rightMouth', // 10\n 'leftShoulder', // 11\n 'rightShoulder', // 12\n 'leftElbow', // 13\n 'rightElbow', // 14\n 'leftWrist', // 15\n 'rightWrist', // 16\n 'leftPinky', // 17\n 'rightPinky', // 18\n 'leftIndex', // 19\n 'rightIndex', // 20\n 'leftThumb', // 21\n 'rightThumb', // 22\n 'leftHip', // 23\n 'rightHip', // 24\n 'leftKnee', // 25\n 'rightKnee', // 26\n 'leftAnkle', // 27\n 'rightAnkle', // 28\n 'leftHeel', // 29\n 'rightHeel', // 30\n 'leftFoot', // 31\n 'rightFoot', // 32\n 'bodyCenter', // 33\n 'bodyTop', // 34\n 'leftPalm', // 35 // z-coord not ok\n 'leftHand', // 36 // similar to wrist but z-coord not ok\n 'rightPalm', // 37 // z-coord not ok\n 'rightHand', // 38 // similar to wrist but z-coord not ok\n];\n\nexport const connected: Record = {\n shoulders: ['leftShoulder', 'rightShoulder'],\n hips: ['rightHip', 'leftHip'],\n mouth: ['leftMouth', 'rightMouth'],\n leftLegUpper: ['leftHip', 'leftKnee'],\n leftLegLower: ['leftKnee', 'leftAnkle'],\n leftFoot: ['leftAnkle', 'leftHeel', 'leftFoot'],\n leftTorso: ['leftShoulder', 'leftHip'],\n leftArmUpper: ['leftShoulder', 'leftElbow'],\n leftArmLower: ['leftElbow', 'leftWrist'],\n leftHand: ['leftWrist', 'leftPalm'],\n leftHandPinky: ['leftPalm', 'leftPinky'],\n leftHandIndex: ['leftPalm', 'leftIndex'],\n leftHandThumb: ['leftPalm', 'leftThumb'],\n leftEyeOutline: ['leftEyeInside', 'leftEyeOutside'],\n rightLegUpper: ['rightHip', 'rightKnee'],\n rightLegLower: ['rightKnee', 'rightAnkle'],\n rightFoot: ['rightAnkle', 'rightHeel', 'rightFoot'],\n rightTorso: ['rightShoulder', 'rightHip'],\n rightArmUpper: ['rightShoulder', 'rightElbow'],\n rightArmLower: ['rightElbow', 'rightWrist'],\n rightHand: ['rightWrist', 'rightPalm'],\n rightHandPinky: ['rightPalm', 'rightPinky'],\n rightHandIndex: ['rightPalm', 'rightIndex'],\n rightHandThumb: ['rightPalm', 'rightThumb'],\n rightEyeOutline: ['rightEyeInside', 'rightEyeOutside'],\n};\n", "import * as tf from '../../dist/tfjs.esm.js';\nimport type { Tensor } from '../tfjs/types';\nimport type { Box } from '../result';\nimport type { Config } from '../config';\n\ninterface DetectedBox { box: Box, boxRaw: Box, score: number }\n\nconst inputSize = 224;\nlet anchorTensor: { x, y };\nconst numLayers = 5;\nconst strides = [8, 16, 32, 32, 32];\n\nexport async function createAnchors() {\n const anchors: Array<{ x: number, y: number }> = [];\n let layerId = 0;\n while (layerId < numLayers) {\n let anchorCount = 0;\n let lastSameStrideLayer = layerId;\n while (lastSameStrideLayer < strides.length && strides[lastSameStrideLayer] === strides[layerId]) {\n anchorCount += 2;\n lastSameStrideLayer++;\n }\n const stride = strides[layerId];\n const featureMapHeight = Math.ceil(inputSize / stride);\n const featureMapWidth = Math.ceil(inputSize / stride);\n for (let y = 0; y < featureMapHeight; ++y) {\n for (let x = 0; x < featureMapWidth; ++x) {\n for (let anchorId = 0; anchorId < anchorCount; ++anchorId) {\n anchors.push({ x: (x + 0.5) / featureMapWidth, y: (y + 0.5) / featureMapHeight });\n }\n }\n }\n layerId = lastSameStrideLayer;\n }\n anchorTensor = { x: tf.tensor1d(anchors.map((a) => a.x)), y: tf.tensor1d(anchors.map((a) => a.y)) };\n}\n\nconst cropFactor = [5.0, 5.0];\nfunction decodeBoxes(boxesTensor, anchor): Tensor {\n return tf.tidy(() => {\n const split = tf.split(boxesTensor, 12, 1); // first 4 are box data [x,y,w,h] and 4 are keypoints data [x,y] for total of 12\n let xCenter = tf.squeeze(split[0]);\n let yCenter = tf.squeeze(split[1]);\n let width = tf.squeeze(split[2]);\n let height = tf.squeeze(split[3]);\n xCenter = tf.add(tf.div(xCenter, inputSize), anchor.x);\n yCenter = tf.add(tf.div(yCenter, inputSize), anchor.y);\n width = tf.mul(tf.div(width, inputSize), cropFactor[0]);\n height = tf.mul(tf.div(height, inputSize), cropFactor[1]);\n const xMin = tf.sub(xCenter, tf.div(width, 2));\n const yMin = tf.sub(yCenter, tf.div(height, 2));\n const boxes = tf.stack([xMin, yMin, width, height], 1);\n return boxes;\n });\n}\n\nexport async function decode(boxesTensor: Tensor, logitsTensor: Tensor, config: Config, outputSize: [number, number]): Promise {\n const t: Record = {};\n t.boxes = decodeBoxes(boxesTensor, anchorTensor);\n t.scores = tf.sigmoid(logitsTensor);\n t.argmax = tf.argMax(t.scores);\n const i = (await t.argmax.data())[0] as number;\n const scores = await t.scores.data();\n const detected: Array<{ box: Box, boxRaw: Box, score: number }> = [];\n const minScore = (config.body['detector'] && config.body['detector']['minConfidence']) ? config.body['detector']['minConfidence'] : 0;\n if (scores[i] >= minScore) {\n const boxes = await t.boxes.array();\n const boxRaw: Box = boxes[i];\n const box: Box = [boxRaw[0] * outputSize[0], boxRaw[1] * outputSize[1], boxRaw[2] * outputSize[0], boxRaw[3] * outputSize[1]];\n // console.log(box);\n detected.push({ box, boxRaw, score: scores[i] });\n }\n /*\n t.nms = await tf.image.nonMaxSuppressionAsync(t.boxes, t.scores, 1, config.body.detector?.minConfidence || 0.1, config.body.detector?.iouThreshold || 0.1);\n const boxes = t.boxes.arraySync();\n const scores = t.scores.dataSync();\n const nms = t.nms.dataSync();\n const detected: Array = [];\n for (const i of Array.from(nms)) {\n const boxRaw: Box = boxes[i];\n const box: Box = [boxRaw[0] * outputSize[0], boxRaw[0] * outputSize[1], boxRaw[3] * outputSize[0], boxRaw[2] * outputSize[1]];\n detected.push({ box, boxRaw, score: scores[i] });\n }\n */\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n return detected;\n}\n", "import type { Point, Box } from '../result';\n\nexport function calc(keypoints: Array, outputSize: [number, number] = [1, 1]) {\n const coords = [keypoints.map((pt) => pt[0]), keypoints.map((pt) => pt[1])]; // all x/y coords\n const min = [Math.min(...coords[0]), Math.min(...coords[1])];\n const max = [Math.max(...coords[0]), Math.max(...coords[1])];\n const box: Box = [min[0], min[1], max[0] - min[0], max[1] - min[1]];\n const boxRaw: Box = [box[0] / outputSize[0], box[1] / outputSize[1], box[2] / outputSize[0], box[3] / outputSize[1]];\n return { box, boxRaw };\n}\n\nexport function square(keypoints: Array, outputSize: [number, number] = [1, 1]) {\n const coords = [keypoints.map((pt) => pt[0]), keypoints.map((pt) => pt[1])]; // all x/y coords\n const min = [Math.min(...coords[0]), Math.min(...coords[1])];\n const max = [Math.max(...coords[0]), Math.max(...coords[1])];\n const center = [(min[0] + max[0]) / 2, (min[1] + max[1]) / 2]; // find center x and y coord of all fingers\n const dist = Math.max(center[0] - min[0], center[1] - min[1], -center[0] + max[0], -center[1] + max[1]); // largest distance from center in any direction\n const box: Box = [Math.trunc(center[0] - dist), Math.trunc(center[1] - dist), Math.trunc(2 * dist), Math.trunc(2 * dist)];\n const boxRaw: Box = [box[0] / outputSize[0], box[1] / outputSize[1], box[2] / outputSize[0], box[3] / outputSize[1]];\n return { box, boxRaw };\n}\n\nexport function scale(box: Box, scaleFact: number) {\n const dist = [box[2] * scaleFact, box[3] * scaleFact];\n const newBox: Box = [\n box[0] - (dist[0] - box[2]) / 2,\n box[1] - (dist[1] - box[3]) / 2,\n dist[0],\n dist[1],\n ];\n return newBox;\n}\n\nexport function crop(box: Box) { // [y1, x1, y2, x2] clamped to 0..1\n const yxBox: Box = [Math.max(0, box[1]), Math.max(0, box[0]), Math.min(1, box[3] + box[1]), Math.min(1, box[2] + box[0])];\n return yxBox;\n}\n", "/**\n * BlazePose model implementation\n */\n\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport { constants } from '../tfjs/constants';\nimport { log, now } from '../util/util';\nimport type { BodyKeypoint, BodyResult, BodyLandmark, Box, Point, BodyAnnotation } from '../result';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport type { Config } from '../config';\nimport * as coords from './blazeposecoords';\nimport * as detect from './blazeposedetector';\nimport * as box from '../util/box';\n\nconst env = { initial: true };\n// const models: [GraphModel | null, GraphModel | null] = [null, null];\nconst models: { detector: GraphModel | null, landmarks: GraphModel | null } = { detector: null, landmarks: null };\nconst inputSize: { detector: [number, number], landmarks: [number, number] } = { detector: [224, 224], landmarks: [256, 256] };\nlet skipped = Number.MAX_SAFE_INTEGER;\nconst outputNodes: { detector: string[], landmarks: string[] } = {\n landmarks: ['ld_3d', 'activation_segmentation', 'activation_heatmap', 'world_3d', 'output_poseflag'],\n detector: [],\n};\n\nlet cache: BodyResult | null = null;\nlet cropBox: Box | undefined;\nlet padding: [number, number][] = [[0, 0], [0, 0], [0, 0], [0, 0]];\nlet lastTime = 0;\n\nconst sigmoid = (x) => (1 - (1 / (1 + Math.exp(x))));\n\nexport async function loadDetect(config: Config): Promise {\n if (env.initial) models.detector = null;\n if (!models.detector && config.body['detector'] && config.body['detector']['modelPath'] || '') {\n models.detector = await loadModel(config.body['detector']['modelPath']);\n const inputs = Object.values(models.detector.modelSignature['inputs']);\n inputSize.detector[0] = Array.isArray(inputs) ? parseInt(inputs[0].tensorShape.dim[1].size) : 0;\n inputSize.detector[1] = Array.isArray(inputs) ? parseInt(inputs[0].tensorShape.dim[2].size) : 0;\n } else if (config.debug && models.detector) log('cached model:', models.detector['modelUrl']);\n await detect.createAnchors();\n return models.detector as GraphModel;\n}\n\nexport async function loadPose(config: Config): Promise {\n if (env.initial) models.landmarks = null;\n if (!models.landmarks) {\n models.landmarks = await loadModel(config.body.modelPath);\n const inputs = Object.values(models.landmarks.modelSignature['inputs']);\n inputSize.landmarks[0] = Array.isArray(inputs) ? parseInt(inputs[0].tensorShape.dim[1].size) : 0;\n inputSize.landmarks[1] = Array.isArray(inputs) ? parseInt(inputs[0].tensorShape.dim[2].size) : 0;\n } else if (config.debug) log('cached model:', models.landmarks['modelUrl']);\n return models.landmarks;\n}\n\nexport async function load(config: Config): Promise<[GraphModel | null, GraphModel | null]> {\n if (!models.detector) await loadDetect(config);\n if (!models.landmarks) await loadPose(config);\n return [models.detector, models.landmarks];\n}\n\nasync function prepareImage(input: Tensor, size: number): Promise {\n const t: Record = {};\n if (!input.shape || !input.shape[1] || !input.shape[2]) return input;\n let final: Tensor;\n if (cropBox) {\n t.cropped = tf.image.cropAndResize(input, [cropBox], [0], [input.shape[1], input.shape[2]]); // if we have cached box use it to crop input\n }\n if (input.shape[1] !== input.shape[2]) { // only pad if width different than height\n const height: [number, number] = [\n input.shape[2] > input.shape[1] ? Math.trunc((input.shape[2] - input.shape[1]) / 2) : 0,\n input.shape[2] > input.shape[1] ? Math.trunc((input.shape[2] - input.shape[1]) / 2) : 0,\n ];\n const width: [number, number] = [\n input.shape[1] > input.shape[2] ? Math.trunc((input.shape[1] - input.shape[2]) / 2) : 0,\n input.shape[1] > input.shape[2] ? Math.trunc((input.shape[1] - input.shape[2]) / 2) : 0,\n ];\n padding = [\n [0, 0], // dont touch batch\n height, // height before&after\n width, // width before&after\n [0, 0], // dont touch rbg\n ];\n t.pad = tf.pad(t.cropped || input, padding); // use cropped box if it exists\n t.resize = tf.image.resizeBilinear(t.pad, [size, size]);\n final = tf.div(t.resize, constants.tf255);\n } else if (input.shape[1] !== size) { // if input needs resizing\n t.resize = tf.image.resizeBilinear(t.cropped || input, [size, size]);\n final = tf.div(t.resize, constants.tf255);\n } else { // if input is already in a correct resolution just normalize it\n final = tf.div(t.cropped || input, constants.tf255);\n }\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n return final;\n}\n\nfunction rescaleKeypoints(keypoints: Array, outputSize: [number, number]): Array {\n for (const kpt of keypoints) { // first rescale due to padding\n kpt.position = [\n Math.trunc(kpt.position[0] * (outputSize[0] + padding[2][0] + padding[2][1]) / outputSize[0] - padding[2][0]),\n Math.trunc(kpt.position[1] * (outputSize[1] + padding[1][0] + padding[1][1]) / outputSize[1] - padding[1][0]),\n kpt.position[2] as number,\n ];\n kpt.positionRaw = [kpt.position[0] / outputSize[0], kpt.position[1] / outputSize[1], 2 * (kpt.position[2] as number) / (outputSize[0] + outputSize[1])];\n }\n if (cropBox) { // second rescale due to cropping\n for (const kpt of keypoints) {\n kpt.positionRaw = [\n kpt.positionRaw[0] + cropBox[1], // correct offset due to crop\n kpt.positionRaw[1] + cropBox[0], // correct offset due to crop\n kpt.positionRaw[2] as number,\n ];\n kpt.position = [\n Math.trunc(kpt.positionRaw[0] * outputSize[0]),\n Math.trunc(kpt.positionRaw[1] * outputSize[1]),\n kpt.positionRaw[2] as number,\n ];\n }\n }\n return keypoints;\n}\n\nasync function fixKeypoints(keypoints: Array) {\n // palm z-coord is incorrect around near-zero so we approximate it\n const leftPalm = keypoints.find((k) => k.part === 'leftPalm') as BodyKeypoint;\n const leftWrist = keypoints.find((k) => k.part === 'leftWrist') as BodyKeypoint;\n const leftIndex = keypoints.find((k) => k.part === 'leftIndex') as BodyKeypoint;\n leftPalm.position[2] = ((leftWrist.position[2] || 0) + (leftIndex.position[2] || 0)) / 2;\n const rightPalm = keypoints.find((k) => k.part === 'rightPalm') as BodyKeypoint;\n const rightWrist = keypoints.find((k) => k.part === 'rightWrist') as BodyKeypoint;\n const rightIndex = keypoints.find((k) => k.part === 'rightIndex') as BodyKeypoint;\n rightPalm.position[2] = ((rightWrist.position[2] || 0) + (rightIndex.position[2] || 0)) / 2;\n}\n\nasync function detectLandmarks(input: Tensor, config: Config, outputSize: [number, number]): Promise {\n /**\n * t.ld: 39 keypoints [x,y,z,score,presence] normalized to input size\n * t.segmentation:\n * t.heatmap:\n * t.world: 39 keypoints [x,y,z] normalized to -1..1\n * t.poseflag: body score\n */\n const t: Record = {};\n [t.ld/* 1,195(39*5) */, t.segmentation/* 1,256,256,1 */, t.heatmap/* 1,64,64,39 */, t.world/* 1,117(39*3) */, t.poseflag/* 1,1 */] = models.landmarks?.execute(input, outputNodes.landmarks) as Tensor[]; // run model\n const poseScore = (await t.poseflag.data())[0];\n const points = await t.ld.data();\n const distances = await t.world.data();\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor])); // dont need tensors after this\n const keypointsRelative: Array = [];\n const depth = 5; // each points has x,y,z,visibility,presence\n for (let i = 0; i < points.length / depth; i++) {\n const score = sigmoid(points[depth * i + 3]);\n const presence = sigmoid(points[depth * i + 4]);\n const adjScore = Math.trunc(100 * score * presence * poseScore) / 100;\n const positionRaw: Point = [points[depth * i + 0] / inputSize.landmarks[0], points[depth * i + 1] / inputSize.landmarks[1], points[depth * i + 2] + 0];\n const position: Point = [Math.trunc(outputSize[0] * positionRaw[0]), Math.trunc(outputSize[1] * positionRaw[1]), positionRaw[2] as number];\n const distance: Point = [distances[depth * i + 0], distances[depth * i + 1], distances[depth * i + 2] + 0];\n keypointsRelative.push({ part: coords.kpt[i] as BodyLandmark, positionRaw, position, distance, score: adjScore });\n }\n if (poseScore < (config.body.minConfidence || 0)) return null;\n fixKeypoints(keypointsRelative);\n const keypoints: Array = rescaleKeypoints(keypointsRelative, outputSize); // keypoints were relative to input image which is padded\n const kpts = keypoints.map((k) => k.position);\n const boxes = box.calc(kpts, [outputSize[0], outputSize[1]]); // now find boxes based on rescaled keypoints\n const annotations: Record = {} as Record;\n for (const [name, indexes] of Object.entries(coords.connected)) {\n const pt: Array = [];\n for (let i = 0; i < indexes.length - 1; i++) {\n const pt0 = keypoints.find((kpt) => kpt.part === indexes[i]);\n const pt1 = keypoints.find((kpt) => kpt.part === indexes[i + 1]);\n if (pt0 && pt1) pt.push([pt0.position, pt1.position]);\n }\n annotations[name] = pt;\n }\n const body = { id: 0, score: Math.trunc(100 * poseScore) / 100, box: boxes.box, boxRaw: boxes.boxRaw, keypoints, annotations };\n return body;\n}\n\n/*\ninterface DetectedBox { box: Box, boxRaw: Box, score: number }\n\nfunction rescaleBoxes(boxes: Array, outputSize: [number, number]): Array {\n for (const b of boxes) {\n b.box = [\n Math.trunc(b.box[0] * (outputSize[0] + padding[2][0] + padding[2][1]) / outputSize[0]),\n Math.trunc(b.box[1] * (outputSize[1] + padding[1][0] + padding[1][1]) / outputSize[1]),\n Math.trunc(b.box[2] * (outputSize[0] + padding[2][0] + padding[2][1]) / outputSize[0]),\n Math.trunc(b.box[3] * (outputSize[1] + padding[1][0] + padding[1][1]) / outputSize[1]),\n ];\n b.boxRaw = [b.box[0] / outputSize[0], b.box[1] / outputSize[1], b.box[2] / outputSize[0], b.box[3] / outputSize[1]];\n }\n return boxes;\n}\n\nasync function detectBoxes(input: Tensor, config: Config, outputSize: [number, number]) {\n const t: Record = {};\n t.res = models.detector?.execute(input, ['Identity']) as Tensor; //\n t.logitsRaw = tf.slice(t.res, [0, 0, 0], [1, -1, 1]);\n t.boxesRaw = tf.slice(t.res, [0, 0, 1], [1, -1, -1]);\n t.logits = tf.squeeze(t.logitsRaw);\n t.boxes = tf.squeeze(t.boxesRaw);\n const boxes = await detect.decode(t.boxes, t.logits, config, outputSize);\n rescaleBoxes(boxes, outputSize);\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n return boxes;\n}\n*/\n\nexport async function predict(input: Tensor, config: Config): Promise {\n const outputSize: [number, number] = [input.shape[2] || 0, input.shape[1] || 0];\n const skipTime = (config.body.skipTime || 0) > (now() - lastTime);\n const skipFrame = skipped < (config.body.skipFrames || 0);\n if (config.skipAllowed && skipTime && skipFrame && cache !== null) {\n skipped++;\n } else {\n const t: Record = {};\n /*\n if (config.body['detector'] && config.body['detector']['enabled']) {\n t.detector = await prepareImage(input, 224);\n const boxes = await detectBoxes(t.detector, config, outputSize);\n }\n */\n t.landmarks = await prepareImage(input, 256); // padded and resized\n cache = await detectLandmarks(t.landmarks, config, outputSize);\n /*\n cropBox = [0, 0, 1, 1]; // reset crop coordinates\n if (cache?.boxRaw && config.skipAllowed) {\n const cx = (2.0 * cache.boxRaw[0] + cache.boxRaw[2]) / 2;\n const cy = (2.0 * cache.boxRaw[1] + cache.boxRaw[3]) / 2;\n let size = cache.boxRaw[2] > cache.boxRaw[3] ? cache.boxRaw[2] : cache.boxRaw[3];\n size = (size * 1.0) / 2; // enlarge and half it\n if (cx > 0.1 && cx < 0.9 && cy > 0.1 && cy < 0.9 && size > 0.1) { // only update if box is sane\n const y = 0; // cy - size;\n const x = cx - size;\n cropBox = [y, x, y + 1, x + 1]; // [y0,x0,y1,x1] used for cropping but width/height are not yet implemented so we only reposition image to center of body\n }\n }\n */\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n lastTime = now();\n skipped = 0;\n }\n return cache ? [cache] : [];\n}\n", "/**\n * CoCo Labels used by object detection implementations\n */\nexport const labels = [\n { class: 1, label: 'person' },\n { class: 2, label: 'bicycle' },\n { class: 3, label: 'car' },\n { class: 4, label: 'motorcycle' },\n { class: 5, label: 'airplane' },\n { class: 6, label: 'bus' },\n { class: 7, label: 'train' },\n { class: 8, label: 'truck' },\n { class: 9, label: 'boat' },\n { class: 10, label: 'traffic light' },\n { class: 11, label: 'fire hydrant' },\n { class: 12, label: 'stop sign' },\n { class: 13, label: 'parking meter' },\n { class: 14, label: 'bench' },\n { class: 15, label: 'bird' },\n { class: 16, label: 'cat' },\n { class: 17, label: 'dog' },\n { class: 18, label: 'horse' },\n { class: 19, label: 'sheep' },\n { class: 20, label: 'cow' },\n { class: 21, label: 'elephant' },\n { class: 22, label: 'bear' },\n { class: 23, label: 'zebra' },\n { class: 24, label: 'giraffe' },\n { class: 25, label: 'backpack' },\n { class: 26, label: 'umbrella' },\n { class: 27, label: 'handbag' },\n { class: 28, label: 'tie' },\n { class: 29, label: 'suitcase' },\n { class: 30, label: 'frisbee' },\n { class: 31, label: 'skis' },\n { class: 32, label: 'snowboard' },\n { class: 33, label: 'sports ball' },\n { class: 34, label: 'kite' },\n { class: 35, label: 'baseball bat' },\n { class: 36, label: 'baseball glove' },\n { class: 37, label: 'skateboard' },\n { class: 38, label: 'surfboard' },\n { class: 39, label: 'tennis racket' },\n { class: 40, label: 'bottle' },\n { class: 41, label: 'wine glass' },\n { class: 42, label: 'cup' },\n { class: 43, label: 'fork' },\n { class: 44, label: 'knife' },\n { class: 45, label: 'spoon' },\n { class: 46, label: 'bowl' },\n { class: 47, label: 'banana' },\n { class: 48, label: 'apple' },\n { class: 49, label: 'sandwich' },\n { class: 50, label: 'orange' },\n { class: 51, label: 'broccoli' },\n { class: 52, label: 'carrot' },\n { class: 53, label: 'hot dog' },\n { class: 54, label: 'pizza' },\n { class: 55, label: 'donut' },\n { class: 56, label: 'cake' },\n { class: 57, label: 'chair' },\n { class: 58, label: 'couch' },\n { class: 59, label: 'potted plant' },\n { class: 60, label: 'bed' },\n { class: 61, label: 'dining table' },\n { class: 62, label: 'toilet' },\n { class: 63, label: 'tv' },\n { class: 64, label: 'laptop' },\n { class: 65, label: 'mouse' },\n { class: 66, label: 'remote' },\n { class: 67, label: 'keyboard' },\n { class: 68, label: 'cell phone' },\n { class: 69, label: 'microwave' },\n { class: 70, label: 'oven' },\n { class: 71, label: 'toaster' },\n { class: 72, label: 'sink' },\n { class: 73, label: 'refrigerator' },\n { class: 74, label: 'book' },\n { class: 75, label: 'clock' },\n { class: 76, label: 'vase' },\n { class: 77, label: 'scissors' },\n { class: 78, label: 'teddy bear' },\n { class: 79, label: 'hair drier' },\n { class: 80, label: 'toothbrush' },\n];\n", "/**\n * CenterNet object detection model implementation\n *\n * Based on: [**NanoDet**](https://github.com/RangiLyu/nanodet)\n */\n\nimport { log, now } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport { labels } from './labels';\nimport type { ObjectResult, ObjectType, Box } from '../result';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport type { Config } from '../config';\nimport { env } from '../util/env';\n\nlet model: GraphModel | null;\nlet inputSize = 0;\nlet last: ObjectResult[] = [];\nlet lastTime = 0;\nlet skipped = Number.MAX_SAFE_INTEGER;\n\nexport async function load(config: Config): Promise {\n if (env.initial) model = null;\n if (!model) {\n // fakeOps(['floormod'], config);\n model = await loadModel(config.object.modelPath);\n const inputs = Object.values(model.modelSignature['inputs']);\n inputSize = Array.isArray(inputs) ? parseInt(inputs[0].tensorShape.dim[2].size) : 0;\n } else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\nasync function process(res: Tensor | null, outputShape: [number, number], config: Config) {\n if (!res) return [];\n const t: Record = {};\n const results: Array = [];\n const detections = await res.array() as number[][][];\n t.squeeze = tf.squeeze(res);\n const arr = tf.split(t.squeeze, 6, 1) as Tensor[]; // x1, y1, x2, y2, score, class\n t.stack = tf.stack([arr[1], arr[0], arr[3], arr[2]], 1); // reorder dims as tf.nms expects y, x\n t.boxes = tf.squeeze(t.stack);\n t.scores = tf.squeeze(arr[4]);\n t.classes = tf.squeeze(arr[5]);\n tf.dispose([res, ...arr]);\n t.nms = await tf.image.nonMaxSuppressionAsync(t.boxes, t.scores, config.object.maxDetected, config.object.iouThreshold, (config.object.minConfidence || 0));\n const nms = await t.nms.data();\n let i = 0;\n for (const id of Array.from(nms)) {\n const score = Math.trunc(100 * detections[0][id][4]) / 100;\n const classVal = detections[0][id][5];\n const label = labels[classVal].label as ObjectType;\n const [x, y] = [\n detections[0][id][0] / inputSize,\n detections[0][id][1] / inputSize,\n ];\n const boxRaw: Box = [\n x,\n y,\n detections[0][id][2] / inputSize - x,\n detections[0][id][3] / inputSize - y,\n ];\n const box: Box = [\n Math.trunc(boxRaw[0] * outputShape[0]),\n Math.trunc(boxRaw[1] * outputShape[1]),\n Math.trunc(boxRaw[2] * outputShape[0]),\n Math.trunc(boxRaw[3] * outputShape[1]),\n ];\n results.push({ id: i++, score, class: classVal, label, box, boxRaw });\n }\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n return results;\n}\n\nexport async function predict(input: Tensor, config: Config): Promise {\n const skipTime = (config.object.skipTime || 0) > (now() - lastTime);\n const skipFrame = skipped < (config.object.skipFrames || 0);\n if (config.skipAllowed && skipTime && skipFrame && (last.length > 0)) {\n skipped++;\n return last;\n }\n skipped = 0;\n return new Promise(async (resolve) => {\n const outputSize = [input.shape[2] || 0, input.shape[1] || 0] as [number, number];\n const resize = tf.image.resizeBilinear(input, [inputSize, inputSize]);\n const objectT = config.object.enabled ? model?.execute(resize, ['tower_0/detections']) as Tensor : null;\n lastTime = now();\n tf.dispose(resize);\n\n const obj = await process(objectT, outputSize, config);\n last = obj;\n\n resolve(obj);\n });\n}\n", "export const kpt: Array = [\n 'head',\n 'neck',\n 'rightShoulder',\n 'rightElbow',\n 'rightWrist',\n 'chest',\n 'leftShoulder',\n 'leftElbow',\n 'leftWrist',\n 'bodyCenter',\n 'rightHip',\n 'rightKnee',\n 'rightAnkle',\n 'leftHip',\n 'leftKnee',\n 'leftAnkle',\n];\n\nexport const connected: Record = {\n leftLeg: ['leftHip', 'leftKnee', 'leftAnkle'],\n rightLeg: ['rightHip', 'rightKnee', 'rightAnkle'],\n torso: ['leftShoulder', 'rightShoulder', 'rightHip', 'leftHip', 'leftShoulder'],\n leftArm: ['leftShoulder', 'leftElbow', 'leftWrist'],\n rightArm: ['rightShoulder', 'rightElbow', 'rightWrist'],\n head: [],\n};\n", "/**\n * EfficientPose model implementation\n *\n * Based on: [**EfficientPose**](https://github.com/daniegr/EfficientPose)\n */\n\nimport { log, now } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport * as coords from './efficientposecoords';\nimport { constants } from '../tfjs/constants';\nimport type { BodyResult, Point, BodyLandmark, BodyAnnotation } from '../result';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport type { Config } from '../config';\nimport { env } from '../util/env';\n\nlet model: GraphModel | null;\nlet lastTime = 0;\nconst cache: BodyResult = { id: 0, keypoints: [], box: [0, 0, 0, 0], boxRaw: [0, 0, 0, 0], score: 0, annotations: {} as Record };\n\n// const keypoints: Array = [];\n// let box: Box = [0, 0, 0, 0];\n// let boxRaw: Box = [0, 0, 0, 0];\n// let score = 0;\nlet skipped = Number.MAX_SAFE_INTEGER;\n\nexport async function load(config: Config): Promise {\n if (env.initial) model = null;\n if (!model) model = await loadModel(config.body.modelPath);\n else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\n// performs argmax and max functions on a 2d tensor\nasync function max2d(inputs, minScore) {\n const [width, height] = inputs.shape;\n const reshaped = tf.reshape(inputs, [height * width]); // combine all data\n const max = tf.max(reshaped, 0);\n const newScore = (await max.data())[0]; // get highest score\n tf.dispose([reshaped, max]);\n if (newScore > minScore) { // skip coordinate calculation is score is too low\n const coordinates = tf.argMax(reshaped, 0);\n const mod = tf.mod(coordinates, width);\n const x = (await mod.data())[0];\n const div = tf.div(coordinates, tf.scalar(width, 'int32'));\n const y = (await div.data())[0];\n tf.dispose([mod, div]);\n return [x, y, newScore];\n }\n return [0, 0, newScore];\n}\n\nexport async function predict(image: Tensor, config: Config): Promise {\n const skipTime = (config.body.skipTime || 0) > (now() - lastTime);\n const skipFrame = skipped < (config.body.skipFrames || 0);\n if (config.skipAllowed && skipTime && skipFrame && Object.keys(cache.keypoints).length > 0) {\n skipped++;\n return [cache];\n }\n skipped = 0;\n return new Promise(async (resolve) => {\n const tensor = tf.tidy(() => {\n if (!model?.inputs[0].shape) return null;\n const resize = tf.image.resizeBilinear(image, [model.inputs[0].shape[2], model.inputs[0].shape[1]], false);\n const enhance = tf.mul(resize, constants.tf2);\n const norm = tf.sub(enhance, constants.tf1);\n return norm;\n });\n\n let resT;\n if (config.body.enabled) resT = model?.execute(tensor);\n lastTime = now();\n tf.dispose(tensor);\n\n if (resT) {\n cache.keypoints.length = 0;\n const squeeze = resT.squeeze();\n tf.dispose(resT);\n // body parts are basically just a stack of 2d tensors\n const stack = squeeze.unstack(2);\n tf.dispose(squeeze);\n // process each unstacked tensor as a separate body part\n for (let id = 0; id < stack.length; id++) {\n // actual processing to get coordinates and score\n const [x, y, partScore] = await max2d(stack[id], config.body.minConfidence);\n if (partScore > (config.body?.minConfidence || 0)) {\n cache.keypoints.push({\n score: Math.round(100 * partScore) / 100,\n part: coords.kpt[id] as BodyLandmark,\n positionRaw: [ // normalized to 0..1\n // @ts-ignore model is not undefined here\n x / model.inputs[0].shape[2], y / model.inputs[0].shape[1],\n ],\n position: [ // normalized to input image size\n // @ts-ignore model is not undefined here\n Math.round(image.shape[2] * x / model.inputs[0].shape[2]), Math.round(image.shape[1] * y / model.inputs[0].shape[1]),\n ],\n });\n }\n }\n stack.forEach((s) => tf.dispose(s));\n }\n cache.score = cache.keypoints.reduce((prev, curr) => (curr.score > prev ? curr.score : prev), 0);\n const x = cache.keypoints.map((a) => a.position[0]);\n const y = cache.keypoints.map((a) => a.position[1]);\n cache.box = [\n Math.min(...x),\n Math.min(...y),\n Math.max(...x) - Math.min(...x),\n Math.max(...y) - Math.min(...y),\n ];\n const xRaw = cache.keypoints.map((a) => a.positionRaw[0]);\n const yRaw = cache.keypoints.map((a) => a.positionRaw[1]);\n cache.boxRaw = [\n Math.min(...xRaw),\n Math.min(...yRaw),\n Math.max(...xRaw) - Math.min(...xRaw),\n Math.max(...yRaw) - Math.min(...yRaw),\n ];\n for (const [name, indexes] of Object.entries(coords.connected)) {\n const pt: Array = [];\n for (let i = 0; i < indexes.length - 1; i++) {\n const pt0 = cache.keypoints.find((kpt) => kpt.part === indexes[i]);\n const pt1 = cache.keypoints.find((kpt) => kpt.part === indexes[i + 1]);\n if (pt0 && pt1 && pt0.score > (config.body.minConfidence || 0) && pt1.score > (config.body.minConfidence || 0)) pt.push([pt0.position, pt1.position]);\n }\n cache.annotations[name] = pt;\n }\n resolve([cache]);\n });\n}\n", "/**\n * Emotion model implementation\n *\n * [**Oarriaga**](https://github.com/oarriaga/face_classification)\n */\n\nimport type { Emotion } from '../result';\nimport { log, now } from '../util/util';\nimport type { Config } from '../config';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport { env } from '../util/env';\nimport { constants } from '../tfjs/constants';\n\nconst annotations = ['angry', 'disgust', 'fear', 'happy', 'sad', 'surprise', 'neutral'];\nlet model: GraphModel | null;\nconst last: Array> = [];\nlet lastCount = 0;\nlet lastTime = 0;\nlet skipped = Number.MAX_SAFE_INTEGER;\n\nexport async function load(config: Config): Promise {\n if (env.initial) model = null;\n if (!model) model = await loadModel(config.face.emotion?.modelPath);\n else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\nexport async function predict(image: Tensor, config: Config, idx: number, count: number): Promise> {\n if (!model) return [];\n const skipFrame = skipped < (config.face.emotion?.skipFrames || 0);\n const skipTime = (config.face.emotion?.skipTime || 0) > (now() - lastTime);\n if (config.skipAllowed && skipTime && skipFrame && (lastCount === count) && last[idx] && (last[idx].length > 0)) {\n skipped++;\n return last[idx];\n }\n skipped = 0;\n return new Promise(async (resolve) => {\n const obj: Array<{ score: number, emotion: Emotion }> = [];\n if (config.face.emotion?.enabled) {\n const t: Record = {};\n const inputSize = model?.inputs[0].shape ? model.inputs[0].shape[2] : 0;\n t.resize = tf.image.resizeBilinear(image, [inputSize, inputSize], false);\n // const box = [[0.15, 0.15, 0.85, 0.85]]; // empyrical values for top, left, bottom, right\n // const resize = tf.image.cropAndResize(image, box, [0], [inputSize, inputSize]);\n // [t.red, t.green, t.blue] = tf.split(t.resize, 3, 3);\n // weighted rgb to grayscale: https://www.mathworks.com/help/matlab/ref/rgb2gray.html\n // t.redNorm = tf.mul(t.red, rgb[0]);\n // t.greenNorm = tf.mul(t.green, rgb[1]);\n // t.blueNorm = tf.mul(t.blue, rgb[2]);\n // t.grayscale = tf.addN([t.redNorm, t.greenNorm, t.blueNorm]);\n t.channels = tf.mul(t.resize, constants.rgb);\n t.grayscale = tf.sum(t.channels, 3, true);\n t.grayscaleSub = tf.sub(t.grayscale, constants.tf05);\n t.grayscaleMul = tf.mul(t.grayscaleSub, constants.tf2);\n t.emotion = model?.execute(t.grayscaleMul) as Tensor; // result is already in range 0..1, no need for additional activation\n lastTime = now();\n const data = await t.emotion.data();\n for (let i = 0; i < data.length; i++) {\n if (data[i] > (config.face.emotion?.minConfidence || 0)) obj.push({ score: Math.min(0.99, Math.trunc(100 * data[i]) / 100), emotion: annotations[i] as Emotion });\n }\n obj.sort((a, b) => b.score - a.score);\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n }\n last[idx] = obj;\n lastCount = count;\n resolve(obj);\n });\n}\n", "/**\n * EfficientPose model implementation\n *\n * Based on: [**BecauseofAI MobileFace**](https://github.com/becauseofAI/MobileFace)\n *\n * Obsolete and replaced by `faceres` that performs age/gender/descriptor analysis\n */\n\nimport { log, now } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport type { Tensor, GraphModel } from '../tfjs/types';\nimport type { Config } from '../config';\nimport { env } from '../util/env';\n\nlet model: GraphModel | null;\nconst last: Array = [];\nlet lastCount = 0;\nlet lastTime = 0;\nlet skipped = Number.MAX_SAFE_INTEGER;\n\nexport async function load(config: Config): Promise {\n if (env.initial) model = null;\n if (!model) model = await loadModel(config.face['mobilefacenet'].modelPath);\n else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\n/*\n// convert to black&white to avoid colorization impact\nconst rgb = [0.2989, 0.5870, 0.1140]; // factors for red/green/blue colors when converting to grayscale: https://www.mathworks.com/help/matlab/ref/rgb2gray.html\nconst [red, green, blue] = tf.split(crop, 3, 3);\nconst redNorm = tf.mul(red, rgb[0]);\nconst greenNorm = tf.mul(green, rgb[1]);\nconst blueNorm = tf.mul(blue, rgb[2]);\nconst grayscale = tf.addN([redNorm, greenNorm, blueNorm]);\nconst merge = tf.stack([grayscale, grayscale, grayscale], 3).squeeze(4);\n\n// optional increase image contrast\n// or do it per-channel so mean is done on each channel\n// or do it based on histogram\nconst mean = merge.mean();\nconst factor = 5;\nconst contrast = merge.sub(mean).mul(factor).add(mean);\n*/\n\nexport async function predict(input: Tensor, config: Config, idx, count): Promise {\n if (!model) return [];\n const skipFrame = skipped < (config.face['embedding']?.skipFrames || 0);\n const skipTime = (config.face['embedding']?.skipTime || 0) > (now() - lastTime);\n if (config.skipAllowed && skipTime && skipFrame && (lastCount === count) && last[idx]) {\n skipped++;\n return last[idx];\n }\n return new Promise(async (resolve) => {\n let data: Array = [];\n if (config.face['embedding']?.enabled && model?.inputs[0].shape) {\n const t: Record = {};\n t.crop = tf.image.resizeBilinear(input, [model.inputs[0].shape[2], model.inputs[0].shape[1]], false); // just resize to fit the embedding model\n // do a tight crop of image and resize it to fit the model\n // const box = [[0.05, 0.15, 0.85, 0.85]]; // empyrical values for top, left, bottom, right\n // t.crop = tf.image.cropAndResize(input, box, [0], [model.inputs[0].shape[2], model.inputs[0].shape[1]]);\n t.data = model?.execute(t.crop) as Tensor;\n /*\n // optional normalize outputs with l2 normalization\n const scaled = tf.tidy(() => {\n const l2 = res.norm('euclidean');\n const scale = res.div(l2);\n return scale;\n });\n\n // optional reduce feature vector complexity\n const reshape = tf.reshape(res, [128, 2]); // split 256 vectors into 128 x 2\n const reduce = reshape.logSumExp(1); // reduce 2nd dimension by calculating logSumExp on it\n */\n const output = await t.data.data();\n data = Array.from(output); // convert typed array to simple array\n }\n last[idx] = data;\n lastCount = count;\n lastTime = now();\n resolve(data);\n });\n}\n", "import * as coords from './facemeshcoords';\nimport * as util from './facemeshutil';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport type { Tensor, GraphModel } from '../tfjs/types';\nimport { env } from '../util/env';\nimport { log } from '../util/util';\nimport { loadModel } from '../tfjs/load';\nimport type { Config } from '../config';\nimport type { Point } from '../result';\n\nlet model: GraphModel | null;\nlet inputSize = 0;\n\nconst irisEnlarge = 2.3;\n\nconst leftOutline = coords.meshAnnotations['leftEyeLower0'];\nconst rightOutline = coords.meshAnnotations['rightEyeLower0'];\n\nconst eyeLandmarks = {\n leftBounds: [leftOutline[0], leftOutline[leftOutline.length - 1]],\n rightBounds: [rightOutline[0], rightOutline[rightOutline.length - 1]],\n};\n\nconst irisLandmarks = {\n upperCenter: 3,\n lowerCenter: 4,\n index: 71,\n numCoordinates: 76,\n};\n\nexport async function load(config: Config): Promise {\n if (env.initial) model = null;\n if (!model) model = await loadModel(config.face.iris?.modelPath);\n else if (config.debug) log('cached model:', model['modelUrl']);\n inputSize = model.inputs[0].shape ? model.inputs[0].shape[2] : 0;\n if (inputSize === -1) inputSize = 64;\n return model;\n}\n\n// Replace the raw coordinates returned by facemesh with refined iris model coordinates and update the z coordinate to be an average of the original and the new.\nexport function replaceIrisCoords(rawCoords, newCoords, prefix, keys) {\n for (let i = 0; i < coords.irisIndices.length; i++) {\n const { key, indices } = coords.irisIndices[i];\n const originalIndices = coords.meshAnnotations[`${prefix}${key}`];\n if (!keys || keys.includes(key)) {\n for (let j = 0; j < indices.length; j++) {\n const index = indices[j];\n rawCoords[originalIndices[j]] = [\n newCoords[index][0],\n newCoords[index][1],\n (newCoords[index][2] + rawCoords[originalIndices[j]][2]) / 2,\n ];\n }\n }\n }\n}\n\nexport const getLeftToRightEyeDepthDifference = (rawCoords) => {\n const leftEyeZ = rawCoords[eyeLandmarks.leftBounds[0]][2];\n const rightEyeZ = rawCoords[eyeLandmarks.rightBounds[0]][2];\n return leftEyeZ - rightEyeZ;\n};\n\n// Returns a box describing a cropped region around the eye fit for passing to the iris model.\nexport const getEyeBox = (rawCoords, face, eyeInnerCornerIndex, eyeOuterCornerIndex, meshSize, flip = false) => {\n const box = util.squarifyBox(util.enlargeBox(util.calculateLandmarksBoundingBox([rawCoords[eyeInnerCornerIndex], rawCoords[eyeOuterCornerIndex]]), irisEnlarge));\n const boxSize = util.getBoxSize(box);\n let crop = tf.image.cropAndResize(face, [[\n box.startPoint[1] / meshSize,\n box.startPoint[0] / meshSize, box.endPoint[1] / meshSize,\n box.endPoint[0] / meshSize,\n ]], [0], [inputSize, inputSize]);\n if (flip && env.kernels.includes('flipleftright')) {\n const flipped = tf.image.flipLeftRight(crop); // flipLeftRight is not defined for tfjs-node\n tf.dispose(crop);\n crop = flipped;\n }\n return { box, boxSize, crop };\n};\n\n// Given a cropped image of an eye, returns the coordinates of the contours surrounding the eye and the iris.\nexport const getEyeCoords = (eyeData, eyeBox, eyeBoxSize, flip = false) => {\n const eyeRawCoords: Array = [];\n for (let i = 0; i < irisLandmarks.numCoordinates; i++) {\n const x = eyeData[i * 3];\n const y = eyeData[i * 3 + 1];\n const z = eyeData[i * 3 + 2];\n eyeRawCoords.push([\n (flip ? (1 - (x / inputSize)) : (x / inputSize)) * eyeBoxSize[0] + eyeBox.startPoint[0],\n (y / inputSize) * eyeBoxSize[1] + eyeBox.startPoint[1], z,\n ]);\n }\n return { rawCoords: eyeRawCoords, iris: eyeRawCoords.slice(irisLandmarks.index) };\n};\n\n// The z-coordinates returned for the iris are unreliable, so we take the z values from the surrounding keypoints.\nexport const getAdjustedIrisCoords = (rawCoords, irisCoords, direction) => {\n const upperCenterZ = rawCoords[coords.meshAnnotations[`${direction}EyeUpper0`][irisLandmarks.upperCenter]][2];\n const lowerCenterZ = rawCoords[coords.meshAnnotations[`${direction}EyeLower0`][irisLandmarks.lowerCenter]][2];\n const averageZ = (upperCenterZ + lowerCenterZ) / 2;\n // Iris indices: 0: center | 1: right | 2: above | 3: left | 4: below\n return irisCoords.map((coord, i) => {\n let z = averageZ;\n if (i === 2) {\n z = upperCenterZ;\n } else if (i === 4) {\n z = lowerCenterZ;\n }\n return [coord[0], coord[1], z];\n });\n};\n\nexport async function augmentIris(rawCoords, face, config, meshSize) {\n if (!model) {\n if (config.debug) log('face mesh iris detection requested, but model is not loaded');\n return rawCoords;\n }\n const { box: leftEyeBox, boxSize: leftEyeBoxSize, crop: leftEyeCrop } = getEyeBox(rawCoords, face, eyeLandmarks.leftBounds[0], eyeLandmarks.leftBounds[1], meshSize, true);\n const { box: rightEyeBox, boxSize: rightEyeBoxSize, crop: rightEyeCrop } = getEyeBox(rawCoords, face, eyeLandmarks.rightBounds[0], eyeLandmarks.rightBounds[1], meshSize, true);\n const combined = tf.concat([leftEyeCrop, rightEyeCrop]);\n tf.dispose(leftEyeCrop);\n tf.dispose(rightEyeCrop);\n const eyePredictions = model.execute(combined) as Tensor;\n tf.dispose(combined);\n const eyePredictionsData = await eyePredictions.data();\n tf.dispose(eyePredictions);\n const leftEyeData = eyePredictionsData.slice(0, irisLandmarks.numCoordinates * 3);\n const { rawCoords: leftEyeRawCoords, iris: leftIrisRawCoords } = getEyeCoords(leftEyeData, leftEyeBox, leftEyeBoxSize, true);\n const rightEyeData = eyePredictionsData.slice(irisLandmarks.numCoordinates * 3);\n const { rawCoords: rightEyeRawCoords, iris: rightIrisRawCoords } = getEyeCoords(rightEyeData, rightEyeBox, rightEyeBoxSize, false);\n const leftToRightEyeDepthDifference = getLeftToRightEyeDepthDifference(rawCoords);\n if (Math.abs(leftToRightEyeDepthDifference) < 30) { // User is looking straight ahead.\n replaceIrisCoords(rawCoords, leftEyeRawCoords, 'left', null);\n replaceIrisCoords(rawCoords, rightEyeRawCoords, 'right', null);\n // If the user is looking to the left or to the right, the iris coordinates tend to diverge too much from the mesh coordinates for them to be merged so we only update a single contour line above and below the eye.\n } else if (leftToRightEyeDepthDifference < 1) { // User is looking towards the right.\n replaceIrisCoords(rawCoords, leftEyeRawCoords, 'left', ['EyeUpper0', 'EyeLower0']);\n } else { // User is looking towards the left.\n replaceIrisCoords(rawCoords, rightEyeRawCoords, 'right', ['EyeUpper0', 'EyeLower0']);\n }\n const adjustedLeftIrisCoords = getAdjustedIrisCoords(rawCoords, leftIrisRawCoords, 'left');\n const adjustedRightIrisCoords = getAdjustedIrisCoords(rawCoords, rightIrisRawCoords, 'right');\n const newCoords = rawCoords.concat(adjustedLeftIrisCoords).concat(adjustedRightIrisCoords);\n return newCoords;\n}\n", "// @tensorflow/tfjs-models/face-landmark-detection/src/constants.ts\n// https://github.com/google/mediapipe/mediapipe/python/solutions/face_mesh_connections.py\n\ntype PairArray = Array<[number, number]>;\n\nconst LIPS_CONNECTIONS: PairArray = [\n [61, 146], [146, 91], [91, 181], [181, 84], [84, 17], [17, 314], [314, 405], [405, 321], [321, 375], [375, 291], [61, 185], [185, 40], [40, 39], [39, 37], [37, 0], [0, 267], [267, 269], [269, 270], [270, 409], [409, 291],\n [78, 95], [95, 88], [88, 178], [178, 87], [87, 14], [14, 317], [317, 402], [402, 318], [318, 324], [324, 308], [78, 191], [191, 80], [80, 81], [81, 82], [82, 13], [13, 312], [312, 311], [311, 310], [310, 415], [415, 308],\n];\n\nconst LEFT_EYE_CONNECTIONS: PairArray = [[263, 249], [249, 390], [390, 373], [373, 374], [374, 380], [380, 381], [381, 382], [382, 362], [263, 466], [466, 388], [388, 387], [387, 386], [386, 385], [385, 384], [384, 398], [398, 362]];\n\nconst LEFT_EYEBROW_CONNECTIONS: PairArray = [[276, 283], [283, 282], [282, 295], [295, 285], [300, 293], [293, 334], [334, 296], [296, 336]];\n\nconst LEFT_IRIS_CONNECTIONS: PairArray = [[474, 475], [475, 476], [476, 477], [477, 474]];\n\nconst RIGHT_EYE_CONNECTIONS: PairArray = [[33, 7], [7, 163], [163, 144], [144, 145], [145, 153], [153, 154], [154, 155], [155, 133], [33, 246], [246, 161], [161, 160], [160, 159], [159, 158], [158, 157], [157, 173], [173, 133]];\n\nconst RIGHT_EYEBROW_CONNECTIONS: PairArray = [[46, 53], [53, 52], [52, 65], [65, 55], [70, 63], [63, 105], [105, 66], [66, 107]];\n\nconst RIGHT_IRIS_CONNECTIONS: PairArray = [[469, 470], [470, 471], [471, 472], [472, 469]];\n\nconst FACE_OVAL_CONNECTIONS: PairArray = [\n [10, 338], [338, 297], [297, 332], [332, 284], [284, 251], [251, 389], [389, 356], [356, 454], [454, 323], [323, 361], [361, 288], [288, 397], [397, 365], [365, 379], [379, 378], [378, 400], [400, 377], [377, 152],\n [152, 148], [148, 176], [176, 149], [149, 150], [150, 136], [136, 172], [172, 58], [58, 132], [132, 93], [93, 234], [234, 127], [127, 162], [162, 21], [21, 54], [54, 103], [103, 67], [67, 109], [109, 10],\n];\n\nexport const MEDIAPIPE_FACE_MESH_CONNECTED_KEYPOINTS_PAIRS: PairArray = [\n [127, 34], [34, 139], [139, 127], [11, 0], [0, 37], [37, 11], [232, 231], [231, 120], [120, 232], [72, 37], [37, 39], [39, 72], [128, 121], [121, 47], [47, 128], [232, 121], [121, 128], [128, 232],\n [104, 69], [69, 67], [67, 104], [175, 171], [171, 148], [148, 175], [118, 50], [50, 101], [101, 118], [73, 39], [39, 40], [40, 73], [9, 151], [151, 108], [108, 9], [48, 115], [115, 131], [131, 48],\n [194, 204], [204, 211], [211, 194], [74, 40], [40, 185], [185, 74], [80, 42], [42, 183], [183, 80], [40, 92], [92, 186], [186, 40], [230, 229], [229, 118], [118, 230], [202, 212], [212, 214], [214, 202],\n [83, 18], [18, 17], [17, 83], [76, 61], [61, 146], [146, 76], [160, 29], [29, 30], [30, 160], [56, 157], [157, 173], [173, 56], [106, 204], [204, 194], [194, 106], [135, 214], [214, 192], [192, 135],\n [203, 165], [165, 98], [98, 203], [21, 71], [71, 68], [68, 21], [51, 45], [45, 4], [4, 51], [144, 24], [24, 23], [23, 144], [77, 146], [146, 91], [91, 77], [205, 50], [50, 187], [187, 205],\n [201, 200], [200, 18], [18, 201], [91, 106], [106, 182], [182, 91], [90, 91], [91, 181], [181, 90], [85, 84], [84, 17], [17, 85], [206, 203], [203, 36], [36, 206], [148, 171], [171, 140], [140, 148],\n [92, 40], [40, 39], [39, 92], [193, 189], [189, 244], [244, 193], [159, 158], [158, 28], [28, 159], [247, 246], [246, 161], [161, 247], [236, 3], [3, 196], [196, 236], [54, 68], [68, 104], [104, 54],\n [193, 168], [168, 8], [8, 193], [117, 228], [228, 31], [31, 117], [189, 193], [193, 55], [55, 189], [98, 97], [97, 99], [99, 98], [126, 47], [47, 100], [100, 126], [166, 79], [79, 218], [218, 166],\n [155, 154], [154, 26], [26, 155], [209, 49], [49, 131], [131, 209], [135, 136], [136, 150], [150, 135], [47, 126], [126, 217], [217, 47], [223, 52], [52, 53], [53, 223], [45, 51], [51, 134], [134, 45],\n [211, 170], [170, 140], [140, 211], [67, 69], [69, 108], [108, 67], [43, 106], [106, 91], [91, 43], [230, 119], [119, 120], [120, 230], [226, 130], [130, 247], [247, 226], [63, 53], [53, 52], [52, 63],\n [238, 20], [20, 242], [242, 238], [46, 70], [70, 156], [156, 46], [78, 62], [62, 96], [96, 78], [46, 53], [53, 63], [63, 46], [143, 34], [34, 227], [227, 143], [123, 117], [117, 111], [111, 123],\n [44, 125], [125, 19], [19, 44], [236, 134], [134, 51], [51, 236], [216, 206], [206, 205], [205, 216], [154, 153], [153, 22], [22, 154], [39, 37], [37, 167], [167, 39], [200, 201], [201, 208], [208, 200],\n [36, 142], [142, 100], [100, 36], [57, 212], [212, 202], [202, 57], [20, 60], [60, 99], [99, 20], [28, 158], [158, 157], [157, 28], [35, 226], [226, 113], [113, 35], [160, 159], [159, 27], [27, 160],\n [204, 202], [202, 210], [210, 204], [113, 225], [225, 46], [46, 113], [43, 202], [202, 204], [204, 43], [62, 76], [76, 77], [77, 62], [137, 123], [123, 116], [116, 137], [41, 38], [38, 72], [72, 41],\n [203, 129], [129, 142], [142, 203], [64, 98], [98, 240], [240, 64], [49, 102], [102, 64], [64, 49], [41, 73], [73, 74], [74, 41], [212, 216], [216, 207], [207, 212], [42, 74], [74, 184], [184, 42],\n [169, 170], [170, 211], [211, 169], [170, 149], [149, 176], [176, 170], [105, 66], [66, 69], [69, 105], [122, 6], [6, 168], [168, 122], [123, 147], [147, 187], [187, 123], [96, 77], [77, 90], [90, 96],\n [65, 55], [55, 107], [107, 65], [89, 90], [90, 180], [180, 89], [101, 100], [100, 120], [120, 101], [63, 105], [105, 104], [104, 63], [93, 137], [137, 227], [227, 93], [15, 86], [86, 85], [85, 15],\n [129, 102], [102, 49], [49, 129], [14, 87], [87, 86], [86, 14], [55, 8], [8, 9], [9, 55], [100, 47], [47, 121], [121, 100], [145, 23], [23, 22], [22, 145], [88, 89], [89, 179], [179, 88],\n [6, 122], [122, 196], [196, 6], [88, 95], [95, 96], [96, 88], [138, 172], [172, 136], [136, 138], [215, 58], [58, 172], [172, 215], [115, 48], [48, 219], [219, 115], [42, 80], [80, 81], [81, 42],\n [195, 3], [3, 51], [51, 195], [43, 146], [146, 61], [61, 43], [171, 175], [175, 199], [199, 171], [81, 82], [82, 38], [38, 81], [53, 46], [46, 225], [225, 53], [144, 163], [163, 110], [110, 144],\n [52, 65], [65, 66], [66, 52], [229, 228], [228, 117], [117, 229], [34, 127], [127, 234], [234, 34], [107, 108], [108, 69], [69, 107], [109, 108], [108, 151], [151, 109], [48, 64], [64, 235], [235, 48],\n [62, 78], [78, 191], [191, 62], [129, 209], [209, 126], [126, 129], [111, 35], [35, 143], [143, 111], [117, 123], [123, 50], [50, 117], [222, 65], [65, 52], [52, 222], [19, 125], [125, 141], [141, 19],\n [221, 55], [55, 65], [65, 221], [3, 195], [195, 197], [197, 3], [25, 7], [7, 33], [33, 25], [220, 237], [237, 44], [44, 220], [70, 71], [71, 139], [139, 70], [122, 193], [193, 245], [245, 122],\n [247, 130], [130, 33], [33, 247], [71, 21], [21, 162], [162, 71], [170, 169], [169, 150], [150, 170], [188, 174], [174, 196], [196, 188], [216, 186], [186, 92], [92, 216], [2, 97], [97, 167], [167, 2],\n [141, 125], [125, 241], [241, 141], [164, 167], [167, 37], [37, 164], [72, 38], [38, 12], [12, 72], [38, 82], [82, 13], [13, 38], [63, 68], [68, 71], [71, 63], [226, 35], [35, 111], [111, 226],\n [101, 50], [50, 205], [205, 101], [206, 92], [92, 165], [165, 206], [209, 198], [198, 217], [217, 209], [165, 167], [167, 97], [97, 165], [220, 115], [115, 218], [218, 220], [133, 112], [112, 243], [243, 133],\n [239, 238], [238, 241], [241, 239], [214, 135], [135, 169], [169, 214], [190, 173], [173, 133], [133, 190], [171, 208], [208, 32], [32, 171], [125, 44], [44, 237], [237, 125], [86, 87], [87, 178], [178, 86],\n [85, 86], [86, 179], [179, 85], [84, 85], [85, 180], [180, 84], [83, 84], [84, 181], [181, 83], [201, 83], [83, 182], [182, 201], [137, 93], [93, 132], [132, 137], [76, 62], [62, 183], [183, 76],\n [61, 76], [76, 184], [184, 61], [57, 61], [61, 185], [185, 57], [212, 57], [57, 186], [186, 212], [214, 207], [207, 187], [187, 214], [34, 143], [143, 156], [156, 34], [79, 239], [239, 237], [237, 79],\n [123, 137], [137, 177], [177, 123], [44, 1], [1, 4], [4, 44], [201, 194], [194, 32], [32, 201], [64, 102], [102, 129], [129, 64], [213, 215], [215, 138], [138, 213], [59, 166], [166, 219], [219, 59],\n [242, 99], [99, 97], [97, 242], [2, 94], [94, 141], [141, 2], [75, 59], [59, 235], [235, 75], [24, 110], [110, 228], [228, 24], [25, 130], [130, 226], [226, 25], [23, 24], [24, 229], [229, 23],\n [22, 23], [23, 230], [230, 22], [26, 22], [22, 231], [231, 26], [112, 26], [26, 232], [232, 112], [189, 190], [190, 243], [243, 189], [221, 56], [56, 190], [190, 221], [28, 56], [56, 221], [221, 28],\n [27, 28], [28, 222], [222, 27], [29, 27], [27, 223], [223, 29], [30, 29], [29, 224], [224, 30], [247, 30], [30, 225], [225, 247], [238, 79], [79, 20], [20, 238], [166, 59], [59, 75], [75, 166],\n [60, 75], [75, 240], [240, 60], [147, 177], [177, 215], [215, 147], [20, 79], [79, 166], [166, 20], [187, 147], [147, 213], [213, 187], [112, 233], [233, 244], [244, 112], [233, 128], [128, 245], [245, 233],\n [128, 114], [114, 188], [188, 128], [114, 217], [217, 174], [174, 114], [131, 115], [115, 220], [220, 131], [217, 198], [198, 236], [236, 217], [198, 131], [131, 134], [134, 198], [177, 132], [132, 58], [58, 177],\n [143, 35], [35, 124], [124, 143], [110, 163], [163, 7], [7, 110], [228, 110], [110, 25], [25, 228], [356, 389], [389, 368], [368, 356], [11, 302], [302, 267], [267, 11], [452, 350], [350, 349], [349, 452],\n [302, 303], [303, 269], [269, 302], [357, 343], [343, 277], [277, 357], [452, 453], [453, 357], [357, 452], [333, 332], [332, 297], [297, 333], [175, 152], [152, 377], [377, 175], [347, 348], [348, 330], [330, 347],\n [303, 304], [304, 270], [270, 303], [9, 336], [336, 337], [337, 9], [278, 279], [279, 360], [360, 278], [418, 262], [262, 431], [431, 418], [304, 408], [408, 409], [409, 304], [310, 415], [415, 407], [407, 310],\n [270, 409], [409, 410], [410, 270], [450, 348], [348, 347], [347, 450], [422, 430], [430, 434], [434, 422], [313, 314], [314, 17], [17, 313], [306, 307], [307, 375], [375, 306], [387, 388], [388, 260], [260, 387],\n [286, 414], [414, 398], [398, 286], [335, 406], [406, 418], [418, 335], [364, 367], [367, 416], [416, 364], [423, 358], [358, 327], [327, 423], [251, 284], [284, 298], [298, 251], [281, 5], [5, 4], [4, 281],\n [373, 374], [374, 253], [253, 373], [307, 320], [320, 321], [321, 307], [425, 427], [427, 411], [411, 425], [421, 313], [313, 18], [18, 421], [321, 405], [405, 406], [406, 321], [320, 404], [404, 405], [405, 320],\n [315, 16], [16, 17], [17, 315], [426, 425], [425, 266], [266, 426], [377, 400], [400, 369], [369, 377], [322, 391], [391, 269], [269, 322], [417, 465], [465, 464], [464, 417], [386, 257], [257, 258], [258, 386],\n [466, 260], [260, 388], [388, 466], [456, 399], [399, 419], [419, 456], [284, 332], [332, 333], [333, 284], [417, 285], [285, 8], [8, 417], [346, 340], [340, 261], [261, 346], [413, 441], [441, 285], [285, 413],\n [327, 460], [460, 328], [328, 327], [355, 371], [371, 329], [329, 355], [392, 439], [439, 438], [438, 392], [382, 341], [341, 256], [256, 382], [429, 420], [420, 360], [360, 429], [364, 394], [394, 379], [379, 364],\n [277, 343], [343, 437], [437, 277], [443, 444], [444, 283], [283, 443], [275, 440], [440, 363], [363, 275], [431, 262], [262, 369], [369, 431], [297, 338], [338, 337], [337, 297], [273, 375], [375, 321], [321, 273],\n [450, 451], [451, 349], [349, 450], [446, 342], [342, 467], [467, 446], [293, 334], [334, 282], [282, 293], [458, 461], [461, 462], [462, 458], [276, 353], [353, 383], [383, 276], [308, 324], [324, 325], [325, 308],\n [276, 300], [300, 293], [293, 276], [372, 345], [345, 447], [447, 372], [352, 345], [345, 340], [340, 352], [274, 1], [1, 19], [19, 274], [456, 248], [248, 281], [281, 456], [436, 427], [427, 425], [425, 436],\n [381, 256], [256, 252], [252, 381], [269, 391], [391, 393], [393, 269], [200, 199], [199, 428], [428, 200], [266, 330], [330, 329], [329, 266], [287, 273], [273, 422], [422, 287], [250, 462], [462, 328], [328, 250],\n [258, 286], [286, 384], [384, 258], [265, 353], [353, 342], [342, 265], [387, 259], [259, 257], [257, 387], [424, 431], [431, 430], [430, 424], [342, 353], [353, 276], [276, 342], [273, 335], [335, 424], [424, 273],\n [292, 325], [325, 307], [307, 292], [366, 447], [447, 345], [345, 366], [271, 303], [303, 302], [302, 271], [423, 266], [266, 371], [371, 423], [294, 455], [455, 460], [460, 294], [279, 278], [278, 294], [294, 279],\n [271, 272], [272, 304], [304, 271], [432, 434], [434, 427], [427, 432], [272, 407], [407, 408], [408, 272], [394, 430], [430, 431], [431, 394], [395, 369], [369, 400], [400, 395], [334, 333], [333, 299], [299, 334],\n [351, 417], [417, 168], [168, 351], [352, 280], [280, 411], [411, 352], [325, 319], [319, 320], [320, 325], [295, 296], [296, 336], [336, 295], [319, 403], [403, 404], [404, 319], [330, 348], [348, 349], [349, 330],\n [293, 298], [298, 333], [333, 293], [323, 454], [454, 447], [447, 323], [15, 16], [16, 315], [315, 15], [358, 429], [429, 279], [279, 358], [14, 15], [15, 316], [316, 14], [285, 336], [336, 9], [9, 285],\n [329, 349], [349, 350], [350, 329], [374, 380], [380, 252], [252, 374], [318, 402], [402, 403], [403, 318], [6, 197], [197, 419], [419, 6], [318, 319], [319, 325], [325, 318], [367, 364], [364, 365], [365, 367],\n [435, 367], [367, 397], [397, 435], [344, 438], [438, 439], [439, 344], [272, 271], [271, 311], [311, 272], [195, 5], [5, 281], [281, 195], [273, 287], [287, 291], [291, 273], [396, 428], [428, 199], [199, 396],\n [311, 271], [271, 268], [268, 311], [283, 444], [444, 445], [445, 283], [373, 254], [254, 339], [339, 373], [282, 334], [334, 296], [296, 282], [449, 347], [347, 346], [346, 449], [264, 447], [447, 454], [454, 264],\n [336, 296], [296, 299], [299, 336], [338, 10], [10, 151], [151, 338], [278, 439], [439, 455], [455, 278], [292, 407], [407, 415], [415, 292], [358, 371], [371, 355], [355, 358], [340, 345], [345, 372], [372, 340],\n [346, 347], [347, 280], [280, 346], [442, 443], [443, 282], [282, 442], [19, 94], [94, 370], [370, 19], [441, 442], [442, 295], [295, 441], [248, 419], [419, 197], [197, 248], [263, 255], [255, 359], [359, 263],\n [440, 275], [275, 274], [274, 440], [300, 383], [383, 368], [368, 300], [351, 412], [412, 465], [465, 351], [263, 467], [467, 466], [466, 263], [301, 368], [368, 389], [389, 301], [395, 378], [378, 379], [379, 395],\n [412, 351], [351, 419], [419, 412], [436, 426], [426, 322], [322, 436], [2, 164], [164, 393], [393, 2], [370, 462], [462, 461], [461, 370], [164, 0], [0, 267], [267, 164], [302, 11], [11, 12], [12, 302],\n [268, 12], [12, 13], [13, 268], [293, 300], [300, 301], [301, 293], [446, 261], [261, 340], [340, 446], [330, 266], [266, 425], [425, 330], [426, 423], [423, 391], [391, 426], [429, 355], [355, 437], [437, 429],\n [391, 327], [327, 326], [326, 391], [440, 457], [457, 438], [438, 440], [341, 382], [382, 362], [362, 341], [459, 457], [457, 461], [461, 459], [434, 430], [430, 394], [394, 434], [414, 463], [463, 362], [362, 414],\n [396, 369], [369, 262], [262, 396], [354, 461], [461, 457], [457, 354], [316, 403], [403, 402], [402, 316], [315, 404], [404, 403], [403, 315], [314, 405], [405, 404], [404, 314], [313, 406], [406, 405], [405, 313],\n [421, 418], [418, 406], [406, 421], [366, 401], [401, 361], [361, 366], [306, 408], [408, 407], [407, 306], [291, 409], [409, 408], [408, 291], [287, 410], [410, 409], [409, 287], [432, 436], [436, 410], [410, 432],\n [434, 416], [416, 411], [411, 434], [264, 368], [368, 383], [383, 264], [309, 438], [438, 457], [457, 309], [352, 376], [376, 401], [401, 352], [274, 275], [275, 4], [4, 274], [421, 428], [428, 262], [262, 421],\n [294, 327], [327, 358], [358, 294], [433, 416], [416, 367], [367, 433], [289, 455], [455, 439], [439, 289], [462, 370], [370, 326], [326, 462], [2, 326], [326, 370], [370, 2], [305, 460], [460, 455], [455, 305],\n [254, 449], [449, 448], [448, 254], [255, 261], [261, 446], [446, 255], [253, 450], [450, 449], [449, 253], [252, 451], [451, 450], [450, 252], [256, 452], [452, 451], [451, 256], [341, 453], [453, 452], [452, 341],\n [413, 464], [464, 463], [463, 413], [441, 413], [413, 414], [414, 441], [258, 442], [442, 441], [441, 258], [257, 443], [443, 442], [442, 257], [259, 444], [444, 443], [443, 259], [260, 445], [445, 444], [444, 260],\n [467, 342], [342, 445], [445, 467], [459, 458], [458, 250], [250, 459], [289, 392], [392, 290], [290, 289], [290, 328], [328, 460], [460, 290], [376, 433], [433, 435], [435, 376], [250, 290], [290, 392], [392, 250],\n [411, 416], [416, 433], [433, 411], [341, 463], [463, 464], [464, 341], [453, 464], [464, 465], [465, 453], [357, 465], [465, 412], [412, 357], [343, 412], [412, 399], [399, 343], [360, 363], [363, 440], [440, 360],\n [437, 399], [399, 456], [456, 437], [420, 456], [456, 363], [363, 420], [401, 435], [435, 288], [288, 401], [372, 383], [383, 353], [353, 372], [339, 255], [255, 249], [249, 339], [448, 261], [261, 255], [255, 448],\n [133, 243], [243, 190], [190, 133], [133, 155], [155, 112], [112, 133], [33, 246], [246, 247], [247, 33], [33, 130], [130, 25], [25, 33], [398, 384], [384, 286], [286, 398], [362, 398], [398, 414], [414, 362],\n [362, 463], [463, 341], [341, 362], [263, 359], [359, 467], [467, 263], [263, 249], [249, 255], [255, 263], [466, 467], [467, 260], [260, 466], [75, 60], [60, 166], [166, 75], [238, 239], [239, 79], [79, 238],\n [162, 127], [127, 139], [139, 162], [72, 11], [11, 37], [37, 72], [121, 232], [232, 120], [120, 121], [73, 72], [72, 39], [39, 73], [114, 128], [128, 47], [47, 114], [233, 232], [232, 128], [128, 233],\n [103, 104], [104, 67], [67, 103], [152, 175], [175, 148], [148, 152], [119, 118], [118, 101], [101, 119], [74, 73], [73, 40], [40, 74], [107, 9], [9, 108], [108, 107], [49, 48], [48, 131], [131, 49],\n [32, 194], [194, 211], [211, 32], [184, 74], [74, 185], [185, 184], [191, 80], [80, 183], [183, 191], [185, 40], [40, 186], [186, 185], [119, 230], [230, 118], [118, 119], [210, 202], [202, 214], [214, 210],\n [84, 83], [83, 17], [17, 84], [77, 76], [76, 146], [146, 77], [161, 160], [160, 30], [30, 161], [190, 56], [56, 173], [173, 190], [182, 106], [106, 194], [194, 182], [138, 135], [135, 192], [192, 138],\n [129, 203], [203, 98], [98, 129], [54, 21], [21, 68], [68, 54], [5, 51], [51, 4], [4, 5], [145, 144], [144, 23], [23, 145], [90, 77], [77, 91], [91, 90], [207, 205], [205, 187], [187, 207],\n [83, 201], [201, 18], [18, 83], [181, 91], [91, 182], [182, 181], [180, 90], [90, 181], [181, 180], [16, 85], [85, 17], [17, 16], [205, 206], [206, 36], [36, 205], [176, 148], [148, 140], [140, 176],\n [165, 92], [92, 39], [39, 165], [245, 193], [193, 244], [244, 245], [27, 159], [159, 28], [28, 27], [30, 247], [247, 161], [161, 30], [174, 236], [236, 196], [196, 174], [103, 54], [54, 104], [104, 103],\n [55, 193], [193, 8], [8, 55], [111, 117], [117, 31], [31, 111], [221, 189], [189, 55], [55, 221], [240, 98], [98, 99], [99, 240], [142, 126], [126, 100], [100, 142], [219, 166], [166, 218], [218, 219],\n [112, 155], [155, 26], [26, 112], [198, 209], [209, 131], [131, 198], [169, 135], [135, 150], [150, 169], [114, 47], [47, 217], [217, 114], [224, 223], [223, 53], [53, 224], [220, 45], [45, 134], [134, 220],\n [32, 211], [211, 140], [140, 32], [109, 67], [67, 108], [108, 109], [146, 43], [43, 91], [91, 146], [231, 230], [230, 120], [120, 231], [113, 226], [226, 247], [247, 113], [105, 63], [63, 52], [52, 105],\n [241, 238], [238, 242], [242, 241], [124, 46], [46, 156], [156, 124], [95, 78], [78, 96], [96, 95], [70, 46], [46, 63], [63, 70], [116, 143], [143, 227], [227, 116], [116, 123], [123, 111], [111, 116],\n [1, 44], [44, 19], [19, 1], [3, 236], [236, 51], [51, 3], [207, 216], [216, 205], [205, 207], [26, 154], [154, 22], [22, 26], [165, 39], [39, 167], [167, 165], [199, 200], [200, 208], [208, 199],\n [101, 36], [36, 100], [100, 101], [43, 57], [57, 202], [202, 43], [242, 20], [20, 99], [99, 242], [56, 28], [28, 157], [157, 56], [124, 35], [35, 113], [113, 124], [29, 160], [160, 27], [27, 29],\n [211, 204], [204, 210], [210, 211], [124, 113], [113, 46], [46, 124], [106, 43], [43, 204], [204, 106], [96, 62], [62, 77], [77, 96], [227, 137], [137, 116], [116, 227], [73, 41], [41, 72], [72, 73],\n [36, 203], [203, 142], [142, 36], [235, 64], [64, 240], [240, 235], [48, 49], [49, 64], [64, 48], [42, 41], [41, 74], [74, 42], [214, 212], [212, 207], [207, 214], [183, 42], [42, 184], [184, 183],\n [210, 169], [169, 211], [211, 210], [140, 170], [170, 176], [176, 140], [104, 105], [105, 69], [69, 104], [193, 122], [122, 168], [168, 193], [50, 123], [123, 187], [187, 50], [89, 96], [96, 90], [90, 89],\n [66, 65], [65, 107], [107, 66], [179, 89], [89, 180], [180, 179], [119, 101], [101, 120], [120, 119], [68, 63], [63, 104], [104, 68], [234, 93], [93, 227], [227, 234], [16, 15], [15, 85], [85, 16],\n [209, 129], [129, 49], [49, 209], [15, 14], [14, 86], [86, 15], [107, 55], [55, 9], [9, 107], [120, 100], [100, 121], [121, 120], [153, 145], [145, 22], [22, 153], [178, 88], [88, 179], [179, 178],\n [197, 6], [6, 196], [196, 197], [89, 88], [88, 96], [96, 89], [135, 138], [138, 136], [136, 135], [138, 215], [215, 172], [172, 138], [218, 115], [115, 219], [219, 218], [41, 42], [42, 81], [81, 41],\n [5, 195], [195, 51], [51, 5], [57, 43], [43, 61], [61, 57], [208, 171], [171, 199], [199, 208], [41, 81], [81, 38], [38, 41], [224, 53], [53, 225], [225, 224], [24, 144], [144, 110], [110, 24],\n [105, 52], [52, 66], [66, 105], [118, 229], [229, 117], [117, 118], [227, 34], [34, 234], [234, 227], [66, 107], [107, 69], [69, 66], [10, 109], [109, 151], [151, 10], [219, 48], [48, 235], [235, 219],\n [183, 62], [62, 191], [191, 183], [142, 129], [129, 126], [126, 142], [116, 111], [111, 143], [143, 116], [118, 117], [117, 50], [50, 118], [223, 222], [222, 52], [52, 223], [94, 19], [19, 141], [141, 94],\n [222, 221], [221, 65], [65, 222], [196, 3], [3, 197], [197, 196], [45, 220], [220, 44], [44, 45], [156, 70], [70, 139], [139, 156], [188, 122], [122, 245], [245, 188], [139, 71], [71, 162], [162, 139],\n [149, 170], [170, 150], [150, 149], [122, 188], [188, 196], [196, 122], [206, 216], [216, 92], [92, 206], [164, 2], [2, 167], [167, 164], [242, 141], [141, 241], [241, 242], [0, 164], [164, 37], [37, 0],\n [11, 72], [72, 12], [12, 11], [12, 38], [38, 13], [13, 12], [70, 63], [63, 71], [71, 70], [31, 226], [226, 111], [111, 31], [36, 101], [101, 205], [205, 36], [203, 206], [206, 165], [165, 203],\n [126, 209], [209, 217], [217, 126], [98, 165], [165, 97], [97, 98], [237, 220], [220, 218], [218, 237], [237, 239], [239, 241], [241, 237], [210, 214], [214, 169], [169, 210], [140, 171], [171, 32], [32, 140],\n [241, 125], [125, 237], [237, 241], [179, 86], [86, 178], [178, 179], [180, 85], [85, 179], [179, 180], [181, 84], [84, 180], [180, 181], [182, 83], [83, 181], [181, 182], [194, 201], [201, 182], [182, 194],\n [177, 137], [137, 132], [132, 177], [184, 76], [76, 183], [183, 184], [185, 61], [61, 184], [184, 185], [186, 57], [57, 185], [185, 186], [216, 212], [212, 186], [186, 216], [192, 214], [214, 187], [187, 192],\n [139, 34], [34, 156], [156, 139], [218, 79], [79, 237], [237, 218], [147, 123], [123, 177], [177, 147], [45, 44], [44, 4], [4, 45], [208, 201], [201, 32], [32, 208], [98, 64], [64, 129], [129, 98],\n [192, 213], [213, 138], [138, 192], [235, 59], [59, 219], [219, 235], [141, 242], [242, 97], [97, 141], [97, 2], [2, 141], [141, 97], [240, 75], [75, 235], [235, 240], [229, 24], [24, 228], [228, 229],\n [31, 25], [25, 226], [226, 31], [230, 23], [23, 229], [229, 230], [231, 22], [22, 230], [230, 231], [232, 26], [26, 231], [231, 232], [233, 112], [112, 232], [232, 233], [244, 189], [189, 243], [243, 244],\n [189, 221], [221, 190], [190, 189], [222, 28], [28, 221], [221, 222], [223, 27], [27, 222], [222, 223], [224, 29], [29, 223], [223, 224], [225, 30], [30, 224], [224, 225], [113, 247], [247, 225], [225, 113],\n [99, 60], [60, 240], [240, 99], [213, 147], [147, 215], [215, 213], [60, 20], [20, 166], [166, 60], [192, 187], [187, 213], [213, 192], [243, 112], [112, 244], [244, 243], [244, 233], [233, 245], [245, 244],\n [245, 128], [128, 188], [188, 245], [188, 114], [114, 174], [174, 188], [134, 131], [131, 220], [220, 134], [174, 217], [217, 236], [236, 174], [236, 198], [198, 134], [134, 236], [215, 177], [177, 58], [58, 215],\n [156, 143], [143, 124], [124, 156], [25, 110], [110, 7], [7, 25], [31, 228], [228, 25], [25, 31], [264, 356], [356, 368], [368, 264], [0, 11], [11, 267], [267, 0], [451, 452], [452, 349], [349, 451],\n [267, 302], [302, 269], [269, 267], [350, 357], [357, 277], [277, 350], [350, 452], [452, 357], [357, 350], [299, 333], [333, 297], [297, 299], [396, 175], [175, 377], [377, 396], [280, 347], [347, 330], [330, 280],\n [269, 303], [303, 270], [270, 269], [151, 9], [9, 337], [337, 151], [344, 278], [278, 360], [360, 344], [424, 418], [418, 431], [431, 424], [270, 304], [304, 409], [409, 270], [272, 310], [310, 407], [407, 272],\n [322, 270], [270, 410], [410, 322], [449, 450], [450, 347], [347, 449], [432, 422], [422, 434], [434, 432], [18, 313], [313, 17], [17, 18], [291, 306], [306, 375], [375, 291], [259, 387], [387, 260], [260, 259],\n [424, 335], [335, 418], [418, 424], [434, 364], [364, 416], [416, 434], [391, 423], [423, 327], [327, 391], [301, 251], [251, 298], [298, 301], [275, 281], [281, 4], [4, 275], [254, 373], [373, 253], [253, 254],\n [375, 307], [307, 321], [321, 375], [280, 425], [425, 411], [411, 280], [200, 421], [421, 18], [18, 200], [335, 321], [321, 406], [406, 335], [321, 320], [320, 405], [405, 321], [314, 315], [315, 17], [17, 314],\n [423, 426], [426, 266], [266, 423], [396, 377], [377, 369], [369, 396], [270, 322], [322, 269], [269, 270], [413, 417], [417, 464], [464, 413], [385, 386], [386, 258], [258, 385], [248, 456], [456, 419], [419, 248],\n [298, 284], [284, 333], [333, 298], [168, 417], [417, 8], [8, 168], [448, 346], [346, 261], [261, 448], [417, 413], [413, 285], [285, 417], [326, 327], [327, 328], [328, 326], [277, 355], [355, 329], [329, 277],\n [309, 392], [392, 438], [438, 309], [381, 382], [382, 256], [256, 381], [279, 429], [429, 360], [360, 279], [365, 364], [364, 379], [379, 365], [355, 277], [277, 437], [437, 355], [282, 443], [443, 283], [283, 282],\n [281, 275], [275, 363], [363, 281], [395, 431], [431, 369], [369, 395], [299, 297], [297, 337], [337, 299], [335, 273], [273, 321], [321, 335], [348, 450], [450, 349], [349, 348], [359, 446], [446, 467], [467, 359],\n [283, 293], [293, 282], [282, 283], [250, 458], [458, 462], [462, 250], [300, 276], [276, 383], [383, 300], [292, 308], [308, 325], [325, 292], [283, 276], [276, 293], [293, 283], [264, 372], [372, 447], [447, 264],\n [346, 352], [352, 340], [340, 346], [354, 274], [274, 19], [19, 354], [363, 456], [456, 281], [281, 363], [426, 436], [436, 425], [425, 426], [380, 381], [381, 252], [252, 380], [267, 269], [269, 393], [393, 267],\n [421, 200], [200, 428], [428, 421], [371, 266], [266, 329], [329, 371], [432, 287], [287, 422], [422, 432], [290, 250], [250, 328], [328, 290], [385, 258], [258, 384], [384, 385], [446, 265], [265, 342], [342, 446],\n [386, 387], [387, 257], [257, 386], [422, 424], [424, 430], [430, 422], [445, 342], [342, 276], [276, 445], [422, 273], [273, 424], [424, 422], [306, 292], [292, 307], [307, 306], [352, 366], [366, 345], [345, 352],\n [268, 271], [271, 302], [302, 268], [358, 423], [423, 371], [371, 358], [327, 294], [294, 460], [460, 327], [331, 279], [279, 294], [294, 331], [303, 271], [271, 304], [304, 303], [436, 432], [432, 427], [427, 436],\n [304, 272], [272, 408], [408, 304], [395, 394], [394, 431], [431, 395], [378, 395], [395, 400], [400, 378], [296, 334], [334, 299], [299, 296], [6, 351], [351, 168], [168, 6], [376, 352], [352, 411], [411, 376],\n [307, 325], [325, 320], [320, 307], [285, 295], [295, 336], [336, 285], [320, 319], [319, 404], [404, 320], [329, 330], [330, 349], [349, 329], [334, 293], [293, 333], [333, 334], [366, 323], [323, 447], [447, 366],\n [316, 15], [15, 315], [315, 316], [331, 358], [358, 279], [279, 331], [317, 14], [14, 316], [316, 317], [8, 285], [285, 9], [9, 8], [277, 329], [329, 350], [350, 277], [253, 374], [374, 252], [252, 253],\n [319, 318], [318, 403], [403, 319], [351, 6], [6, 419], [419, 351], [324, 318], [318, 325], [325, 324], [397, 367], [367, 365], [365, 397], [288, 435], [435, 397], [397, 288], [278, 344], [344, 439], [439, 278],\n [310, 272], [272, 311], [311, 310], [248, 195], [195, 281], [281, 248], [375, 273], [273, 291], [291, 375], [175, 396], [396, 199], [199, 175], [312, 311], [311, 268], [268, 312], [276, 283], [283, 445], [445, 276],\n [390, 373], [373, 339], [339, 390], [295, 282], [282, 296], [296, 295], [448, 449], [449, 346], [346, 448], [356, 264], [264, 454], [454, 356], [337, 336], [336, 299], [299, 337], [337, 338], [338, 151], [151, 337],\n [294, 278], [278, 455], [455, 294], [308, 292], [292, 415], [415, 308], [429, 358], [358, 355], [355, 429], [265, 340], [340, 372], [372, 265], [352, 346], [346, 280], [280, 352], [295, 442], [442, 282], [282, 295],\n [354, 19], [19, 370], [370, 354], [285, 441], [441, 295], [295, 285], [195, 248], [248, 197], [197, 195], [457, 440], [440, 274], [274, 457], [301, 300], [300, 368], [368, 301], [417, 351], [351, 465], [465, 417],\n [251, 301], [301, 389], [389, 251], [394, 395], [395, 379], [379, 394], [399, 412], [412, 419], [419, 399], [410, 436], [436, 322], [322, 410], [326, 2], [2, 393], [393, 326], [354, 370], [370, 461], [461, 354],\n [393, 164], [164, 267], [267, 393], [268, 302], [302, 12], [12, 268], [312, 268], [268, 13], [13, 312], [298, 293], [293, 301], [301, 298], [265, 446], [446, 340], [340, 265], [280, 330], [330, 425], [425, 280],\n [322, 426], [426, 391], [391, 322], [420, 429], [429, 437], [437, 420], [393, 391], [391, 326], [326, 393], [344, 440], [440, 438], [438, 344], [458, 459], [459, 461], [461, 458], [364, 434], [434, 394], [394, 364],\n [428, 396], [396, 262], [262, 428], [274, 354], [354, 457], [457, 274], [317, 316], [316, 402], [402, 317], [316, 315], [315, 403], [403, 316], [315, 314], [314, 404], [404, 315], [314, 313], [313, 405], [405, 314],\n [313, 421], [421, 406], [406, 313], [323, 366], [366, 361], [361, 323], [292, 306], [306, 407], [407, 292], [306, 291], [291, 408], [408, 306], [291, 287], [287, 409], [409, 291], [287, 432], [432, 410], [410, 287],\n [427, 434], [434, 411], [411, 427], [372, 264], [264, 383], [383, 372], [459, 309], [309, 457], [457, 459], [366, 352], [352, 401], [401, 366], [1, 274], [274, 4], [4, 1], [418, 421], [421, 262], [262, 418],\n [331, 294], [294, 358], [358, 331], [435, 433], [433, 367], [367, 435], [392, 289], [289, 439], [439, 392], [328, 462], [462, 326], [326, 328], [94, 2], [2, 370], [370, 94], [289, 305], [305, 455], [455, 289],\n [339, 254], [254, 448], [448, 339], [359, 255], [255, 446], [446, 359], [254, 253], [253, 449], [449, 254], [253, 252], [252, 450], [450, 253], [252, 256], [256, 451], [451, 252], [256, 341], [341, 452], [452, 256],\n [414, 413], [413, 463], [463, 414], [286, 441], [441, 414], [414, 286], [286, 258], [258, 441], [441, 286], [258, 257], [257, 442], [442, 258], [257, 259], [259, 443], [443, 257], [259, 260], [260, 444], [444, 259],\n [260, 467], [467, 445], [445, 260], [309, 459], [459, 250], [250, 309], [305, 289], [289, 290], [290, 305], [305, 290], [290, 460], [460, 305], [401, 376], [376, 435], [435, 401], [309, 250], [250, 392], [392, 309],\n [376, 411], [411, 433], [433, 376], [453, 341], [341, 464], [464, 453], [357, 453], [453, 465], [465, 357], [343, 357], [357, 412], [412, 343], [437, 343], [343, 399], [399, 437], [344, 360], [360, 440], [440, 344],\n [420, 437], [437, 456], [456, 420], [360, 420], [420, 363], [363, 360], [361, 401], [401, 288], [288, 361], [265, 372], [372, 353], [353, 265], [390, 339], [339, 249], [249, 390], [339, 448], [448, 255], [255, 339],\n];\n\nfunction connectionsToIndices(connections: PairArray) {\n const indices = connections.map((connection) => connection[0]);\n indices.push(connections[connections.length - 1][1]);\n return indices;\n}\n\nexport const MEDIAPIPE_FACE_MESH_KEYPOINTS_BY_CONTOUR = {\n lips: connectionsToIndices(LIPS_CONNECTIONS),\n leftEye: connectionsToIndices(LEFT_EYE_CONNECTIONS),\n leftEyebrow: connectionsToIndices(LEFT_EYEBROW_CONNECTIONS),\n leftIris: connectionsToIndices(LEFT_IRIS_CONNECTIONS),\n rightEye: connectionsToIndices(RIGHT_EYE_CONNECTIONS),\n rightEyebrow: connectionsToIndices(RIGHT_EYEBROW_CONNECTIONS),\n rightIris: connectionsToIndices(RIGHT_IRIS_CONNECTIONS),\n faceOval: connectionsToIndices(FACE_OVAL_CONNECTIONS),\n};\n\nconst indexLabelPairs: Array<[number, string]> = Object.entries(MEDIAPIPE_FACE_MESH_KEYPOINTS_BY_CONTOUR)\n .map(([label, indices]) => indices.map((index) => [index, label] as [number, string]))\n .flat();\n\nexport const MEDIAPIPE_FACE_MESH_KEYPOINTS = new Map(indexLabelPairs);\n\ntype AssignAverage = number[];\nexport interface LandmarksRefinementConfig {\n indexesMapping: number[]; // Maps indexes of the given set of landmarks to indexes of the resulting set of landmarks. Should be non empty and contain the same amount of indexes as landmarks in the corresponding input\n zRefinement: 'none'|'copy'|AssignAverage; // Z refinement instructions.\n}\n\nexport const LANDMARKS_REFINEMENT_LIPS_CONFIG = [\n 61, 146, 91, 181, 84, 17, 314, 405, 321, 375, 291, // Lower outer.\n 185, 40, 39, 37, 0, 267, 269, 270, 409, // Upper outer(excluding corners).\n 78, 95, 88, 178, 87, 14, 317, 402, 318, 324, 308, // Lower inner.\n 191, 80, 81, 82, 13, 312, 311, 310, 415, // Upper inner(excluding corners).\n 76, 77, 90, 180, 85, 16, 315, 404, 320, 307, 306, // Lower semi - outer.\n 184, 74, 73, 72, 11, 302, 303, 304, 408, // Upper semi - outer(excluding corners).\n 62, 96, 89, 179, 86, 15, 316, 403, 319, 325, 292, // Lower semi - inner.\n 183, 42, 41, 38, 12, 268, 271, 272, 407, // Upper semi - inner(excluding corners).\n];\n\nexport const LANDMARKS_REFINEMENT_LEFT_EYE_CONFIG = [\n 33, 7, 163, 144, 145, 153, 154, 155, 133, // Lower contour.\n 246, 161, 160, 159, 158, 157, 173, // upper contour (excluding corners).\n 130, 25, 110, 24, 23, 22, 26, 112, 243, // Halo x2 lower contour.\n 247, 30, 29, 27, 28, 56, 190, // Halo x2 upper contour (excluding corners).\n 226, 31, 228, 229, 230, 231, 232, 233, 244, // Halo x3 lower contour.\n 113, 225, 224, 223, 222, 221, 189, // Halo x3 upper contour (excluding corners).\n 35, 124, 46, 53, 52, 65, // Halo x4 upper contour (no lower because of mesh structure) or eyebrow inner contour.\n 143, 111, 117, 118, 119, 120, 121, 128, 245, // Halo x5 lower contour.\n 156, 70, 63, 105, 66, 107, 55, 193, // Halo x5 upper contour (excluding corners) or eyebrow outer contour.\n];\n\nexport const LANDMARKS_REFINEMENT_RIGHT_EYE_CONFIG = [\n 263, 249, 390, 373, 374, 380, 381, 382, 362, // Lower contour.\n 466, 388, 387, 386, 385, 384, 398, // Upper contour (excluding corners).\n 359, 255, 339, 254, 253, 252, 256, 341, 463, // Halo x2 lower contour.\n 467, 260, 259, 257, 258, 286, 414, // Halo x2 upper contour (excluding corners).\n 446, 261, 448, 449, 450, 451, 452, 453, 464, // Halo x3 lower contour.\n 342, 445, 444, 443, 442, 441, 413, // Halo x3 upper contour (excluding corners).\n 265, 353, 276, 283, 282, 295, // Halo x4 upper contour (no lower because of mesh structure) or/ eyebrow inner contour.\n 372, 340, 346, 347, 348, 349, 350, 357, 465, // Halo x5 lower contour.\n 383, 300, 293, 334, 296, 336, 285, 417, // Halo x5 upper contour (excluding corners) or eyebrow outer contour.\n];\n\nexport const LANDMARKS_REFINEMENT_LEFT_IRIS_CONFIG = [\n 468, // Center.\n 469, // Iris right edge.\n 470, // Iris top edge.\n 471, // Iris left edge.\n 472, // Iris bottom edge.\n];\n/*\nzRefinement: [\n 33, 7, 163, 144, 145, 153, 154, 155, 133, // Lower contour.\n 246, 161, 160, 159, 158, 157, 173, // Upper contour (excluding corners).\n];\n*/\n\nexport const LANDMARKS_REFINEMENT_RIGHT_IRIS_CONFIG = [\n 473, // Center.\n 474, // Iris right edge.\n 475, // Iris top edge.\n 476, // Iris left edge.\n 477, // Iris bottom edge.\n];\n/*\nzRefinement: [\n 263, 249, 390, 373, 374, 380, 381, 382, 362, // Lower contour.\n 466, 388, 387, 386, 385, 384, 398, // Upper contour (excluding corners).\n];\n*/\n", "import * as constants from './constants';\nimport type { Tensor } from '../tfjs/types';\n\nexport async function augment(rawCoords, results: Tensor[]) {\n const t: Record = { // all attention models produce 2d results so it needs to be later augmented with correct z-coords\n // mesh: results[0], // already have it in rawCoords // output_mesh_identity\n // flag: results[1], // already processed in parent // conv_faceflag\n lips: results.filter((r) => r.size === 160)[0].dataSync() as Float32Array, // 80 x 2d = 160 // output_lips\n irisL: results.filter((r) => r.size === 10)[0].dataSync() as Float32Array, // 5 x 2d = 10 // output_right_iris\n eyeL: results.filter((r) => r.size === 142)[0].dataSync() as Float32Array, // 71 x 2d = 142 // output_right_eye\n irisR: results.filter((r) => r.size === 10)[1].dataSync() as Float32Array, // 5 x 2d = 10 // output_left_iris\n eyeR: results.filter((r) => r.size === 142)[1].dataSync() as Float32Array, // 71 x 2d = 142// output_left_eye\n };\n\n // augment iris: adds additional 5 keypoints per eye\n const irisLDepth = constants.LANDMARKS_REFINEMENT_LEFT_EYE_CONFIG.reduce((prev, curr) => prev += rawCoords[curr][2], 0) / constants.LANDMARKS_REFINEMENT_LEFT_EYE_CONFIG.length; // get average z-coord for iris\n for (let i = 0; i < t.irisL.length / 2; i++) rawCoords.push([t.irisL[2 * i + 0], t.irisL[2 * i + 1], irisLDepth]);\n const irisRDepth = constants.LANDMARKS_REFINEMENT_RIGHT_EYE_CONFIG.reduce((prev, curr) => prev += rawCoords[curr][2], 0) / constants.LANDMARKS_REFINEMENT_RIGHT_EYE_CONFIG.length; // get average z-coord for iris\n for (let i = 0; i < t.irisR.length / 2; i++) rawCoords.push([t.irisR[2 * i + 0], t.irisR[2 * i + 1], irisRDepth]);\n\n // augment eyes: replaces eye keypoints based on heuristic mapping\n for (let i = 0; i < t.eyeL.length / 2; i++) rawCoords[constants.LANDMARKS_REFINEMENT_LEFT_EYE_CONFIG[i]] = [t.eyeL[2 * i + 0], t.eyeL[2 * i + 1], rawCoords[constants.LANDMARKS_REFINEMENT_LEFT_EYE_CONFIG[i]][2]];\n for (let i = 0; i < t.eyeR.length / 2; i++) rawCoords[constants.LANDMARKS_REFINEMENT_RIGHT_EYE_CONFIG[i]] = [t.eyeR[2 * i + 0], t.eyeR[2 * i + 1], rawCoords[constants.LANDMARKS_REFINEMENT_RIGHT_EYE_CONFIG[i]][2]];\n\n // augment lips: replaces eye keypoints based on heuristic mapping\n for (let i = 0; i < t.lips.length / 2; i++) rawCoords[constants.LANDMARKS_REFINEMENT_LIPS_CONFIG[i]] = [t.lips[2 * i + 0], t.lips[2 * i + 1], rawCoords[constants.LANDMARKS_REFINEMENT_LIPS_CONFIG[i]][2]];\n\n return rawCoords;\n}\n", "/**\n * BlazeFace, FaceMesh & Iris model implementation\n *\n * Based on:\n * - [**MediaPipe BlazeFace**](https://drive.google.com/file/d/1f39lSzU5Oq-j_OXgS67KfN5wNsoeAZ4V/view)\n * - Facial Spacial Geometry: [**MediaPipe FaceMesh**](https://drive.google.com/file/d/1VFC_wIpw4O7xBOiTgUldl79d9LA-LsnA/view)\n * - Eye Iris Details: [**MediaPipe Iris**](https://drive.google.com/file/d/1bsWbokp9AklH2ANjCfmjqEzzxO1CNbMu/view)\n */\n\nimport { log, now } from '../util/util';\nimport { loadModel } from '../tfjs/load';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as blazeface from './blazeface';\nimport * as util from './facemeshutil';\nimport * as coords from './facemeshcoords';\nimport * as iris from './iris';\nimport * as attention from './attention';\nimport { histogramEqualization } from '../image/enhance';\nimport { env } from '../util/env';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport type { FaceResult, FaceLandmark, Point } from '../result';\nimport type { Config } from '../config';\n\ntype DetectBox = { startPoint: Point, endPoint: Point, landmarks: Array, confidence: number };\n\nconst cache = {\n boxes: [] as DetectBox[],\n skipped: Number.MAX_SAFE_INTEGER,\n timestamp: 0,\n};\n\nlet model: GraphModel | null = null;\nlet inputSize = 0;\n\nexport async function predict(input: Tensor, config: Config): Promise {\n // reset cached boxes\n const skipTime = (config.face.detector?.skipTime || 0) > (now() - cache.timestamp);\n const skipFrame = cache.skipped < (config.face.detector?.skipFrames || 0);\n if (!config.skipAllowed || !skipTime || !skipFrame || cache.boxes.length === 0) {\n cache.boxes = await blazeface.getBoxes(input, config); // get results from blazeface detector\n cache.timestamp = now();\n cache.skipped = 0;\n } else {\n cache.skipped++;\n }\n const faces: Array = [];\n const newCache: Array = [];\n let id = 0;\n for (let i = 0; i < cache.boxes.length; i++) {\n const box = cache.boxes[i];\n let angle = 0;\n let rotationMatrix;\n const face: FaceResult = { // init face result\n id: id++,\n mesh: [],\n meshRaw: [],\n box: [0, 0, 0, 0],\n boxRaw: [0, 0, 0, 0],\n score: 0,\n boxScore: 0,\n faceScore: 0,\n annotations: {} as Record,\n };\n\n // optional rotation correction based on detector data only if mesh is disabled otherwise perform it later when we have more accurate mesh data. if no rotation correction this function performs crop\n [angle, rotationMatrix, face.tensor] = util.correctFaceRotation(config.face.detector?.rotation, box, input, config.face.mesh?.enabled ? inputSize : blazeface.size());\n if (config?.filter?.equalization) {\n const equilized = await histogramEqualization(face.tensor as Tensor);\n tf.dispose(face.tensor);\n face.tensor = equilized;\n }\n face.boxScore = Math.round(100 * box.confidence) / 100;\n if (!config.face.mesh?.enabled) { // mesh not enabled, return resuts from detector only\n face.box = util.clampBox(box, input);\n face.boxRaw = util.getRawBox(box, input);\n face.score = face.boxScore;\n face.mesh = box.landmarks.map((pt) => [\n ((box.startPoint[0] + box.endPoint[0])) / 2 + ((box.endPoint[0] + box.startPoint[0]) * pt[0] / blazeface.size()),\n ((box.startPoint[1] + box.endPoint[1])) / 2 + ((box.endPoint[1] + box.startPoint[1]) * pt[1] / blazeface.size()),\n ]);\n face.meshRaw = face.mesh.map((pt) => [pt[0] / (input.shape[2] || 0), pt[1] / (input.shape[1] || 0), (pt[2] || 0) / inputSize]);\n for (const key of Object.keys(coords.blazeFaceLandmarks)) {\n face.annotations[key] = [face.mesh[coords.blazeFaceLandmarks[key] as number]]; // add annotations\n }\n } else if (!model) { // mesh enabled, but not loaded\n if (config.debug) log('face mesh detection requested, but model is not loaded');\n } else { // mesh enabled\n const results = model.execute(face.tensor as Tensor) as Array;\n const confidenceT = results.find((t) => t.shape[t.shape.length - 1] === 1) as Tensor;\n const meshT = results.find((t) => t.shape[t.shape.length - 1] === 1404) as Tensor;\n const faceConfidence = confidenceT.dataSync();\n face.faceScore = Math.round(100 * faceConfidence[0]) / 100;\n const coordsReshaped = tf.reshape(meshT, [-1, 3]);\n let rawCoords = await coordsReshaped.array();\n if (face.faceScore < (config.face.detector?.minConfidence || 1)) { // low confidence in detected mesh\n box.confidence = face.faceScore; // reset confidence of cached box\n if (config.face.mesh?.keepInvalid) {\n face.box = util.clampBox(box, input);\n face.boxRaw = util.getRawBox(box, input);\n face.score = face.boxScore;\n face.mesh = box.landmarks.map((pt) => [\n ((box.startPoint[0] + box.endPoint[0])) / 2 + ((box.endPoint[0] + box.startPoint[0]) * pt[0] / blazeface.size()),\n ((box.startPoint[1] + box.endPoint[1])) / 2 + ((box.endPoint[1] + box.startPoint[1]) * pt[1] / blazeface.size()),\n ]);\n face.meshRaw = face.mesh.map((pt) => [pt[0] / (input.shape[2] || 0), pt[1] / (input.shape[1] || 0), (pt[2] || 0) / inputSize]);\n for (const key of Object.keys(coords.blazeFaceLandmarks)) {\n face.annotations[key] = [face.mesh[coords.blazeFaceLandmarks[key] as number]]; // add annotations\n }\n }\n } else {\n if (config.face.attention?.enabled) {\n rawCoords = await attention.augment(rawCoords, results); // augment iris results using attention model results\n } else if (config.face.iris?.enabled) {\n rawCoords = await iris.augmentIris(rawCoords, face.tensor, config, inputSize); // run iris model and augment results\n }\n face.mesh = util.transformRawCoords(rawCoords, box, angle, rotationMatrix, inputSize); // get processed mesh\n face.meshRaw = face.mesh.map((pt) => [pt[0] / (input.shape[2] || 0), pt[1] / (input.shape[1] || 0), (pt[2] || 0) / inputSize]);\n for (const key of Object.keys(coords.meshAnnotations)) face.annotations[key] = coords.meshAnnotations[key].map((index) => face.mesh[index]); // add annotations\n face.score = face.faceScore;\n const calculatedBox = { ...util.calculateFaceBox(face.mesh, box), confidence: box.confidence, landmarks: box.landmarks };\n face.box = util.clampBox(calculatedBox, input);\n face.boxRaw = util.getRawBox(calculatedBox, input);\n newCache.push(calculatedBox);\n }\n tf.dispose([...results, coordsReshaped]);\n }\n if (face.score > (config.face.detector?.minConfidence || 1)) faces.push(face);\n else tf.dispose(face.tensor);\n }\n cache.boxes = newCache; // reset cache\n return faces;\n}\n\nexport async function load(config: Config): Promise {\n if (env.initial) model = null;\n // @ts-ignore private property\n if (config?.face?.attention?.enabled && model?.signature) {\n // @ts-ignore private property\n if (Object.keys(model?.signature?.outputs || {}).length < 6) model = null;\n }\n if (!model) {\n if (config.face.attention?.enabled) model = await loadModel(config.face.attention?.modelPath);\n else model = await loadModel(config.face.mesh?.modelPath);\n } else if (config.debug) {\n log('cached model:', model['modelUrl']);\n }\n inputSize = model.inputs[0].shape ? model.inputs[0].shape[2] : 0;\n return model;\n}\n\nexport const triangulation = coords.TRI468;\nexport const uvmap = coords.UV468;\n", "/**\n * FaceRes model implementation\n *\n * Returns Age, Gender, Descriptor\n * Implements Face simmilarity function\n *\n * Based on: [**HSE-FaceRes**](https://github.com/HSE-asavchenko/HSE_FaceRec_tf)\n */\n\nimport { log, now } from '../util/util';\nimport { env } from '../util/env';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport { constants } from '../tfjs/constants';\nimport type { Tensor, GraphModel } from '../tfjs/types';\nimport type { Config } from '../config';\nimport type { Gender, Race } from '../result';\n\nexport type FaceRes = { age: number, gender: Gender, genderScore: number, descriptor: number[], race?: { score: number, race: Race }[] };\n\nlet model: GraphModel | null;\nconst last: Array<{\n age: number,\n gender: Gender,\n genderScore: number,\n descriptor: number[],\n}> = [];\n\nlet lastTime = 0;\nlet lastCount = 0;\nlet skipped = Number.MAX_SAFE_INTEGER;\n\nexport async function load(config: Config): Promise {\n if (env.initial) model = null;\n if (!model) model = await loadModel(config.face.description?.modelPath);\n else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\nexport function enhance(input): Tensor {\n const tensor = (input.image || input.tensor || input) as Tensor; // input received from detector is already normalized to 0..1, input is also assumed to be straightened\n if (!model?.inputs[0].shape) return tensor; // model has no shape so no point continuing\n const crop = tf.image.resizeBilinear(tensor, [model.inputs[0].shape[2], model.inputs[0].shape[1]], false);\n const norm = tf.mul(crop, constants.tf255);\n tf.dispose(crop);\n return norm;\n /*\n // do a tight crop of image and resize it to fit the model\n const box = [[0.05, 0.15, 0.85, 0.85]]; // empyrical values for top, left, bottom, right\n const crop = (tensor.shape.length === 3)\n ? tf.image.cropAndResize(tf.expandDims(tensor, 0), box, [0], [model.inputs[0].shape[2], model.inputs[0].shape[1]]) // add batch dimension if missing\n : tf.image.cropAndResize(tensor, box, [0], [model.inputs[0].shape[2], model.inputs[0].shape[1]]);\n */\n /*\n // convert to black&white to avoid colorization impact\n const rgb = [0.2989, 0.5870, 0.1140]; // factors for red/green/blue colors when converting to grayscale: https://www.mathworks.com/help/matlab/ref/rgb2gray.html\n const [red, green, blue] = tf.split(crop, 3, 3);\n const redNorm = tf.mul(red, rgb[0]);\n const greenNorm = tf.mul(green, rgb[1]);\n const blueNorm = tf.mul(blue, rgb[2]);\n const grayscale = tf.addN([redNorm, greenNorm, blueNorm]);\n const merge = tf.stack([grayscale, grayscale, grayscale], 3).squeeze(4);\n */\n}\n\nexport async function predict(image: Tensor, config: Config, idx: number, count: number): Promise {\n if (!model) return { age: 0, gender: 'unknown', genderScore: 0, descriptor: [] };\n const skipFrame = skipped < (config.face.description?.skipFrames || 0);\n const skipTime = (config.face.description?.skipTime || 0) > (now() - lastTime);\n if (config.skipAllowed && skipFrame && skipTime && (lastCount === count) && last[idx]?.age && (last[idx]?.age > 0)) {\n skipped++;\n return last[idx];\n }\n skipped = 0;\n return new Promise(async (resolve) => {\n const obj = {\n age: 0,\n gender: 'unknown',\n genderScore: 0,\n descriptor: [],\n };\n\n if (config.face.description?.enabled) {\n const enhanced = enhance(image);\n const resT = model?.execute(enhanced) as Tensor[];\n lastTime = now();\n tf.dispose(enhanced);\n const genderT = await resT.find((t) => t.shape[1] === 1) as Tensor;\n const gender = await genderT.data();\n const confidence = Math.trunc(200 * Math.abs((gender[0] - 0.5))) / 100;\n if (confidence > (config.face.description?.minConfidence || 0)) {\n obj.gender = gender[0] <= 0.5 ? 'female' : 'male';\n obj.genderScore = Math.min(0.99, confidence);\n }\n const argmax = tf.argMax(resT.find((t) => t.shape[1] === 100), 1);\n const age = (await argmax.data())[0];\n tf.dispose(argmax);\n const ageT = resT.find((t) => t.shape[1] === 100) as Tensor;\n const all = await ageT.data();\n obj.age = Math.round(all[age - 1] > all[age + 1] ? 10 * age - 100 * all[age - 1] : 10 * age + 100 * all[age + 1]) / 10;\n\n const desc = resT.find((t) => t.shape[1] === 1024);\n // const reshape = desc.reshape([128, 8]); // reshape large 1024-element descriptor to 128 x 8\n // const reduce = reshape.logSumExp(1); // reduce 2nd dimension by calculating logSumExp on it which leaves us with 128-element descriptor\n const descriptor = desc ? await desc.data() : [];\n obj.descriptor = Array.from(descriptor);\n resT.forEach((t) => tf.dispose(t));\n }\n last[idx] = obj;\n lastCount = count;\n resolve(obj);\n });\n}\n", "import * as tf from '../../dist/tfjs.esm.js';\nimport type { Point } from '../result';\n\nexport function getBoxSize(box) {\n return [\n Math.abs(box.endPoint[0] - box.startPoint[0]),\n Math.abs(box.endPoint[1] - box.startPoint[1]),\n ];\n}\n\nexport function getBoxCenter(box) {\n return [\n box.startPoint[0] + (box.endPoint[0] - box.startPoint[0]) / 2,\n box.startPoint[1] + (box.endPoint[1] - box.startPoint[1]) / 2,\n ];\n}\n\nexport function cutBoxFromImageAndResize(box, image, cropSize) {\n const h = image.shape[1];\n const w = image.shape[2];\n const boxes = [[\n box.startPoint[1] / h,\n box.startPoint[0] / w,\n box.endPoint[1] / h,\n box.endPoint[0] / w,\n ]];\n return tf.image.cropAndResize(image, boxes, [0], cropSize);\n}\n\nexport function scaleBoxCoordinates(box, factor) {\n const startPoint = [box.startPoint[0] * factor[0], box.startPoint[1] * factor[1]] as Point;\n const endPoint = [box.endPoint[0] * factor[0], box.endPoint[1] * factor[1]] as Point;\n const palmLandmarks = box.palmLandmarks.map((coord) => {\n const scaledCoord = [coord[0] * factor[0], coord[1] * factor[1]];\n return scaledCoord;\n });\n return { startPoint, endPoint, palmLandmarks, confidence: box.confidence };\n}\n\nexport function enlargeBox(box, factor = 1.5) {\n const center = getBoxCenter(box);\n const size = getBoxSize(box);\n const newHalfSize = [factor * size[0] / 2, factor * size[1] / 2];\n const startPoint = [center[0] - newHalfSize[0], center[1] - newHalfSize[1]] as Point;\n const endPoint = [center[0] + newHalfSize[0], center[1] + newHalfSize[1]] as Point;\n return { startPoint, endPoint, palmLandmarks: box.palmLandmarks };\n}\n\nexport function squarifyBox(box) {\n const centers = getBoxCenter(box);\n const size = getBoxSize(box);\n const maxEdge = Math.max(...size);\n const halfSize = maxEdge / 2;\n const startPoint = [centers[0] - halfSize, centers[1] - halfSize] as Point;\n const endPoint = [centers[0] + halfSize, centers[1] + halfSize] as Point;\n return { startPoint, endPoint, palmLandmarks: box.palmLandmarks };\n}\n\nexport function shiftBox(box, shiftFactor) {\n const boxSize = [\n box.endPoint[0] - box.startPoint[0],\n box.endPoint[1] - box.startPoint[1],\n ];\n const shiftVector = [boxSize[0] * shiftFactor[0], boxSize[1] * shiftFactor[1]];\n const startPoint = [box.startPoint[0] + shiftVector[0], box.startPoint[1] + shiftVector[1]] as Point;\n const endPoint = [box.endPoint[0] + shiftVector[0], box.endPoint[1] + shiftVector[1]] as Point;\n return { startPoint, endPoint, palmLandmarks: box.palmLandmarks };\n}\n\nexport function normalizeRadians(angle) {\n return angle - 2 * Math.PI * Math.floor((angle + Math.PI) / (2 * Math.PI));\n}\n\nexport function computeRotation(point1, point2) {\n const radians = Math.PI / 2 - Math.atan2(-(point2[1] - point1[1]), point2[0] - point1[0]);\n return normalizeRadians(radians);\n}\n\nexport const buildTranslationMatrix = (x, y) => [[1, 0, x], [0, 1, y], [0, 0, 1]];\n\nexport function dot(v1, v2) {\n let product = 0;\n for (let i = 0; i < v1.length; i++) {\n product += v1[i] * v2[i];\n }\n return product;\n}\n\nexport function getColumnFrom2DArr(arr, columnIndex) {\n const column: Array = [];\n for (let i = 0; i < arr.length; i++) {\n column.push(arr[i][columnIndex]);\n }\n return column;\n}\n\nexport function multiplyTransformMatrices(mat1, mat2) {\n const product: Array = [];\n const size = mat1.length;\n for (let row = 0; row < size; row++) {\n product.push([]);\n for (let col = 0; col < size; col++) {\n product[row].push(dot(mat1[row], getColumnFrom2DArr(mat2, col)));\n }\n }\n return product;\n}\n\nexport function buildRotationMatrix(rotation, center) {\n const cosA = Math.cos(rotation);\n const sinA = Math.sin(rotation);\n const rotationMatrix = [[cosA, -sinA, 0], [sinA, cosA, 0], [0, 0, 1]];\n const translationMatrix = buildTranslationMatrix(center[0], center[1]);\n const translationTimesRotation = multiplyTransformMatrices(translationMatrix, rotationMatrix);\n const negativeTranslationMatrix = buildTranslationMatrix(-center[0], -center[1]);\n return multiplyTransformMatrices(translationTimesRotation, negativeTranslationMatrix);\n}\n\nexport function invertTransformMatrix(matrix) {\n const rotationComponent = [[matrix[0][0], matrix[1][0]], [matrix[0][1], matrix[1][1]]];\n const translationComponent = [matrix[0][2], matrix[1][2]];\n const invertedTranslation = [\n -dot(rotationComponent[0], translationComponent),\n -dot(rotationComponent[1], translationComponent),\n ];\n return [\n rotationComponent[0].concat(invertedTranslation[0]),\n rotationComponent[1].concat(invertedTranslation[1]),\n [0, 0, 1],\n ];\n}\n\nexport function rotatePoint(homogeneousCoordinate, rotationMatrix) {\n return [\n dot(homogeneousCoordinate, rotationMatrix[0]),\n dot(homogeneousCoordinate, rotationMatrix[1]),\n ];\n}\n", "/**\n * HandPose model implementation constants\n * See `handpose.ts` for entry point\n */\n\nexport const anchors = [\n { x: 0.015625, y: 0.015625 },\n { x: 0.015625, y: 0.015625 },\n { x: 0.046875, y: 0.015625 },\n { x: 0.046875, y: 0.015625 },\n { x: 0.078125, y: 0.015625 },\n { x: 0.078125, y: 0.015625 },\n { x: 0.109375, y: 0.015625 },\n { x: 0.109375, y: 0.015625 },\n { x: 0.140625, y: 0.015625 },\n { x: 0.140625, y: 0.015625 },\n { x: 0.171875, y: 0.015625 },\n { x: 0.171875, y: 0.015625 },\n { x: 0.203125, y: 0.015625 },\n { x: 0.203125, y: 0.015625 },\n { x: 0.234375, y: 0.015625 },\n { x: 0.234375, y: 0.015625 },\n { x: 0.265625, y: 0.015625 },\n { x: 0.265625, y: 0.015625 },\n { x: 0.296875, y: 0.015625 },\n { x: 0.296875, y: 0.015625 },\n { x: 0.328125, y: 0.015625 },\n { x: 0.328125, y: 0.015625 },\n { x: 0.359375, y: 0.015625 },\n { x: 0.359375, y: 0.015625 },\n { x: 0.390625, y: 0.015625 },\n { x: 0.390625, y: 0.015625 },\n { x: 0.421875, y: 0.015625 },\n { x: 0.421875, y: 0.015625 },\n { x: 0.453125, y: 0.015625 },\n { x: 0.453125, y: 0.015625 },\n { x: 0.484375, y: 0.015625 },\n { x: 0.484375, y: 0.015625 },\n { x: 0.515625, y: 0.015625 },\n { x: 0.515625, y: 0.015625 },\n { x: 0.546875, y: 0.015625 },\n { x: 0.546875, y: 0.015625 },\n { x: 0.578125, y: 0.015625 },\n { x: 0.578125, y: 0.015625 },\n { x: 0.609375, y: 0.015625 },\n { x: 0.609375, y: 0.015625 },\n { x: 0.640625, y: 0.015625 },\n { x: 0.640625, y: 0.015625 },\n { x: 0.671875, y: 0.015625 },\n { x: 0.671875, y: 0.015625 },\n { x: 0.703125, y: 0.015625 },\n { x: 0.703125, y: 0.015625 },\n { x: 0.734375, y: 0.015625 },\n { x: 0.734375, y: 0.015625 },\n { x: 0.765625, y: 0.015625 },\n { x: 0.765625, y: 0.015625 },\n { x: 0.796875, y: 0.015625 },\n { x: 0.796875, y: 0.015625 },\n { x: 0.828125, y: 0.015625 },\n { x: 0.828125, y: 0.015625 },\n { x: 0.859375, y: 0.015625 },\n { x: 0.859375, y: 0.015625 },\n { x: 0.890625, y: 0.015625 },\n { x: 0.890625, y: 0.015625 },\n { x: 0.921875, y: 0.015625 },\n { x: 0.921875, y: 0.015625 },\n { x: 0.953125, y: 0.015625 },\n { x: 0.953125, y: 0.015625 },\n { x: 0.984375, y: 0.015625 },\n { x: 0.984375, y: 0.015625 },\n { x: 0.015625, y: 0.046875 },\n { x: 0.015625, y: 0.046875 },\n { x: 0.046875, y: 0.046875 },\n { x: 0.046875, y: 0.046875 },\n { x: 0.078125, y: 0.046875 },\n { x: 0.078125, y: 0.046875 },\n { x: 0.109375, y: 0.046875 },\n { x: 0.109375, y: 0.046875 },\n { x: 0.140625, y: 0.046875 },\n { x: 0.140625, y: 0.046875 },\n { x: 0.171875, y: 0.046875 },\n { x: 0.171875, y: 0.046875 },\n { x: 0.203125, y: 0.046875 },\n { x: 0.203125, y: 0.046875 },\n { x: 0.234375, y: 0.046875 },\n { x: 0.234375, y: 0.046875 },\n { x: 0.265625, y: 0.046875 },\n { x: 0.265625, y: 0.046875 },\n { x: 0.296875, y: 0.046875 },\n { x: 0.296875, y: 0.046875 },\n { x: 0.328125, y: 0.046875 },\n { x: 0.328125, y: 0.046875 },\n { x: 0.359375, y: 0.046875 },\n { x: 0.359375, y: 0.046875 },\n { x: 0.390625, y: 0.046875 },\n { x: 0.390625, y: 0.046875 },\n { x: 0.421875, y: 0.046875 },\n { x: 0.421875, y: 0.046875 },\n { x: 0.453125, y: 0.046875 },\n { x: 0.453125, y: 0.046875 },\n { x: 0.484375, y: 0.046875 },\n { x: 0.484375, y: 0.046875 },\n { x: 0.515625, y: 0.046875 },\n { x: 0.515625, y: 0.046875 },\n { x: 0.546875, y: 0.046875 },\n { x: 0.546875, y: 0.046875 },\n { x: 0.578125, y: 0.046875 },\n { x: 0.578125, y: 0.046875 },\n { x: 0.609375, y: 0.046875 },\n { x: 0.609375, y: 0.046875 },\n { x: 0.640625, y: 0.046875 },\n { x: 0.640625, y: 0.046875 },\n { x: 0.671875, y: 0.046875 },\n { x: 0.671875, y: 0.046875 },\n { x: 0.703125, y: 0.046875 },\n { x: 0.703125, y: 0.046875 },\n { x: 0.734375, y: 0.046875 },\n { x: 0.734375, y: 0.046875 },\n { x: 0.765625, y: 0.046875 },\n { x: 0.765625, y: 0.046875 },\n { x: 0.796875, y: 0.046875 },\n { x: 0.796875, y: 0.046875 },\n { x: 0.828125, y: 0.046875 },\n { x: 0.828125, y: 0.046875 },\n { x: 0.859375, y: 0.046875 },\n { x: 0.859375, y: 0.046875 },\n { x: 0.890625, y: 0.046875 },\n { x: 0.890625, y: 0.046875 },\n { x: 0.921875, y: 0.046875 },\n { x: 0.921875, y: 0.046875 },\n { x: 0.953125, y: 0.046875 },\n { x: 0.953125, y: 0.046875 },\n { x: 0.984375, y: 0.046875 },\n { x: 0.984375, y: 0.046875 },\n { x: 0.015625, y: 0.078125 },\n { x: 0.015625, y: 0.078125 },\n { x: 0.046875, y: 0.078125 },\n { x: 0.046875, y: 0.078125 },\n { x: 0.078125, y: 0.078125 },\n { x: 0.078125, y: 0.078125 },\n { x: 0.109375, y: 0.078125 },\n { x: 0.109375, y: 0.078125 },\n { x: 0.140625, y: 0.078125 },\n { x: 0.140625, y: 0.078125 },\n { x: 0.171875, y: 0.078125 },\n { x: 0.171875, y: 0.078125 },\n { x: 0.203125, y: 0.078125 },\n { x: 0.203125, y: 0.078125 },\n { x: 0.234375, y: 0.078125 },\n { x: 0.234375, y: 0.078125 },\n { x: 0.265625, y: 0.078125 },\n { x: 0.265625, y: 0.078125 },\n { x: 0.296875, y: 0.078125 },\n { x: 0.296875, y: 0.078125 },\n { x: 0.328125, y: 0.078125 },\n { x: 0.328125, y: 0.078125 },\n { x: 0.359375, y: 0.078125 },\n { x: 0.359375, y: 0.078125 },\n { x: 0.390625, y: 0.078125 },\n { x: 0.390625, y: 0.078125 },\n { x: 0.421875, y: 0.078125 },\n { x: 0.421875, y: 0.078125 },\n { x: 0.453125, y: 0.078125 },\n { x: 0.453125, y: 0.078125 },\n { x: 0.484375, y: 0.078125 },\n { x: 0.484375, y: 0.078125 },\n { x: 0.515625, y: 0.078125 },\n { x: 0.515625, y: 0.078125 },\n { x: 0.546875, y: 0.078125 },\n { x: 0.546875, y: 0.078125 },\n { x: 0.578125, y: 0.078125 },\n { x: 0.578125, y: 0.078125 },\n { x: 0.609375, y: 0.078125 },\n { x: 0.609375, y: 0.078125 },\n { x: 0.640625, y: 0.078125 },\n { x: 0.640625, y: 0.078125 },\n { x: 0.671875, y: 0.078125 },\n { x: 0.671875, y: 0.078125 },\n { x: 0.703125, y: 0.078125 },\n { x: 0.703125, y: 0.078125 },\n { x: 0.734375, y: 0.078125 },\n { x: 0.734375, y: 0.078125 },\n { x: 0.765625, y: 0.078125 },\n { x: 0.765625, y: 0.078125 },\n { x: 0.796875, y: 0.078125 },\n { x: 0.796875, y: 0.078125 },\n { x: 0.828125, y: 0.078125 },\n { x: 0.828125, y: 0.078125 },\n { x: 0.859375, y: 0.078125 },\n { x: 0.859375, y: 0.078125 },\n { x: 0.890625, y: 0.078125 },\n { x: 0.890625, y: 0.078125 },\n { x: 0.921875, y: 0.078125 },\n { x: 0.921875, y: 0.078125 },\n { x: 0.953125, y: 0.078125 },\n { x: 0.953125, y: 0.078125 },\n { x: 0.984375, y: 0.078125 },\n { x: 0.984375, y: 0.078125 },\n { x: 0.015625, y: 0.109375 },\n { x: 0.015625, y: 0.109375 },\n { x: 0.046875, y: 0.109375 },\n { x: 0.046875, y: 0.109375 },\n { x: 0.078125, y: 0.109375 },\n { x: 0.078125, y: 0.109375 },\n { x: 0.109375, y: 0.109375 },\n { x: 0.109375, y: 0.109375 },\n { x: 0.140625, y: 0.109375 },\n { x: 0.140625, y: 0.109375 },\n { x: 0.171875, y: 0.109375 },\n { x: 0.171875, y: 0.109375 },\n { x: 0.203125, y: 0.109375 },\n { x: 0.203125, y: 0.109375 },\n { x: 0.234375, y: 0.109375 },\n { x: 0.234375, y: 0.109375 },\n { x: 0.265625, y: 0.109375 },\n { x: 0.265625, y: 0.109375 },\n { x: 0.296875, y: 0.109375 },\n { x: 0.296875, y: 0.109375 },\n { x: 0.328125, y: 0.109375 },\n { x: 0.328125, y: 0.109375 },\n { x: 0.359375, y: 0.109375 },\n { x: 0.359375, y: 0.109375 },\n { x: 0.390625, y: 0.109375 },\n { x: 0.390625, y: 0.109375 },\n { x: 0.421875, y: 0.109375 },\n { x: 0.421875, y: 0.109375 },\n { x: 0.453125, y: 0.109375 },\n { x: 0.453125, y: 0.109375 },\n { x: 0.484375, y: 0.109375 },\n { x: 0.484375, y: 0.109375 },\n { x: 0.515625, y: 0.109375 },\n { x: 0.515625, y: 0.109375 },\n { x: 0.546875, y: 0.109375 },\n { x: 0.546875, y: 0.109375 },\n { x: 0.578125, y: 0.109375 },\n { x: 0.578125, y: 0.109375 },\n { x: 0.609375, y: 0.109375 },\n { x: 0.609375, y: 0.109375 },\n { x: 0.640625, y: 0.109375 },\n { x: 0.640625, y: 0.109375 },\n { x: 0.671875, y: 0.109375 },\n { x: 0.671875, y: 0.109375 },\n { x: 0.703125, y: 0.109375 },\n { x: 0.703125, y: 0.109375 },\n { x: 0.734375, y: 0.109375 },\n { x: 0.734375, y: 0.109375 },\n { x: 0.765625, y: 0.109375 },\n { x: 0.765625, y: 0.109375 },\n { x: 0.796875, y: 0.109375 },\n { x: 0.796875, y: 0.109375 },\n { x: 0.828125, y: 0.109375 },\n { x: 0.828125, y: 0.109375 },\n { x: 0.859375, y: 0.109375 },\n { x: 0.859375, y: 0.109375 },\n { x: 0.890625, y: 0.109375 },\n { x: 0.890625, y: 0.109375 },\n { x: 0.921875, y: 0.109375 },\n { x: 0.921875, y: 0.109375 },\n { x: 0.953125, y: 0.109375 },\n { x: 0.953125, y: 0.109375 },\n { x: 0.984375, y: 0.109375 },\n { x: 0.984375, y: 0.109375 },\n { x: 0.015625, y: 0.140625 },\n { x: 0.015625, y: 0.140625 },\n { x: 0.046875, y: 0.140625 },\n { x: 0.046875, y: 0.140625 },\n { x: 0.078125, y: 0.140625 },\n { x: 0.078125, y: 0.140625 },\n { x: 0.109375, y: 0.140625 },\n { x: 0.109375, y: 0.140625 },\n { x: 0.140625, y: 0.140625 },\n { x: 0.140625, y: 0.140625 },\n { x: 0.171875, y: 0.140625 },\n { x: 0.171875, y: 0.140625 },\n { x: 0.203125, y: 0.140625 },\n { x: 0.203125, y: 0.140625 },\n { x: 0.234375, y: 0.140625 },\n { x: 0.234375, y: 0.140625 },\n { x: 0.265625, y: 0.140625 },\n { x: 0.265625, y: 0.140625 },\n { x: 0.296875, y: 0.140625 },\n { x: 0.296875, y: 0.140625 },\n { x: 0.328125, y: 0.140625 },\n { x: 0.328125, y: 0.140625 },\n { x: 0.359375, y: 0.140625 },\n { x: 0.359375, y: 0.140625 },\n { x: 0.390625, y: 0.140625 },\n { x: 0.390625, y: 0.140625 },\n { x: 0.421875, y: 0.140625 },\n { x: 0.421875, y: 0.140625 },\n { x: 0.453125, y: 0.140625 },\n { x: 0.453125, y: 0.140625 },\n { x: 0.484375, y: 0.140625 },\n { x: 0.484375, y: 0.140625 },\n { x: 0.515625, y: 0.140625 },\n { x: 0.515625, y: 0.140625 },\n { x: 0.546875, y: 0.140625 },\n { x: 0.546875, y: 0.140625 },\n { x: 0.578125, y: 0.140625 },\n { x: 0.578125, y: 0.140625 },\n { x: 0.609375, y: 0.140625 },\n { x: 0.609375, y: 0.140625 },\n { x: 0.640625, y: 0.140625 },\n { x: 0.640625, y: 0.140625 },\n { x: 0.671875, y: 0.140625 },\n { x: 0.671875, y: 0.140625 },\n { x: 0.703125, y: 0.140625 },\n { x: 0.703125, y: 0.140625 },\n { x: 0.734375, y: 0.140625 },\n { x: 0.734375, y: 0.140625 },\n { x: 0.765625, y: 0.140625 },\n { x: 0.765625, y: 0.140625 },\n { x: 0.796875, y: 0.140625 },\n { x: 0.796875, y: 0.140625 },\n { x: 0.828125, y: 0.140625 },\n { x: 0.828125, y: 0.140625 },\n { x: 0.859375, y: 0.140625 },\n { x: 0.859375, y: 0.140625 },\n { x: 0.890625, y: 0.140625 },\n { x: 0.890625, y: 0.140625 },\n { x: 0.921875, y: 0.140625 },\n { x: 0.921875, y: 0.140625 },\n { x: 0.953125, y: 0.140625 },\n { x: 0.953125, y: 0.140625 },\n { x: 0.984375, y: 0.140625 },\n { x: 0.984375, y: 0.140625 },\n { x: 0.015625, y: 0.171875 },\n { x: 0.015625, y: 0.171875 },\n { x: 0.046875, y: 0.171875 },\n { x: 0.046875, y: 0.171875 },\n { x: 0.078125, y: 0.171875 },\n { x: 0.078125, y: 0.171875 },\n { x: 0.109375, y: 0.171875 },\n { x: 0.109375, y: 0.171875 },\n { x: 0.140625, y: 0.171875 },\n { x: 0.140625, y: 0.171875 },\n { x: 0.171875, y: 0.171875 },\n { x: 0.171875, y: 0.171875 },\n { x: 0.203125, y: 0.171875 },\n { x: 0.203125, y: 0.171875 },\n { x: 0.234375, y: 0.171875 },\n { x: 0.234375, y: 0.171875 },\n { x: 0.265625, y: 0.171875 },\n { x: 0.265625, y: 0.171875 },\n { x: 0.296875, y: 0.171875 },\n { x: 0.296875, y: 0.171875 },\n { x: 0.328125, y: 0.171875 },\n { x: 0.328125, y: 0.171875 },\n { x: 0.359375, y: 0.171875 },\n { x: 0.359375, y: 0.171875 },\n { x: 0.390625, y: 0.171875 },\n { x: 0.390625, y: 0.171875 },\n { x: 0.421875, y: 0.171875 },\n { x: 0.421875, y: 0.171875 },\n { x: 0.453125, y: 0.171875 },\n { x: 0.453125, y: 0.171875 },\n { x: 0.484375, y: 0.171875 },\n { x: 0.484375, y: 0.171875 },\n { x: 0.515625, y: 0.171875 },\n { x: 0.515625, y: 0.171875 },\n { x: 0.546875, y: 0.171875 },\n { x: 0.546875, y: 0.171875 },\n { x: 0.578125, y: 0.171875 },\n { x: 0.578125, y: 0.171875 },\n { x: 0.609375, y: 0.171875 },\n { x: 0.609375, y: 0.171875 },\n { x: 0.640625, y: 0.171875 },\n { x: 0.640625, y: 0.171875 },\n { x: 0.671875, y: 0.171875 },\n { x: 0.671875, y: 0.171875 },\n { x: 0.703125, y: 0.171875 },\n { x: 0.703125, y: 0.171875 },\n { x: 0.734375, y: 0.171875 },\n { x: 0.734375, y: 0.171875 },\n { x: 0.765625, y: 0.171875 },\n { x: 0.765625, y: 0.171875 },\n { x: 0.796875, y: 0.171875 },\n { x: 0.796875, y: 0.171875 },\n { x: 0.828125, y: 0.171875 },\n { x: 0.828125, y: 0.171875 },\n { x: 0.859375, y: 0.171875 },\n { x: 0.859375, y: 0.171875 },\n { x: 0.890625, y: 0.171875 },\n { x: 0.890625, y: 0.171875 },\n { x: 0.921875, y: 0.171875 },\n { x: 0.921875, y: 0.171875 },\n { x: 0.953125, y: 0.171875 },\n { x: 0.953125, y: 0.171875 },\n { x: 0.984375, y: 0.171875 },\n { x: 0.984375, y: 0.171875 },\n { x: 0.015625, y: 0.203125 },\n { x: 0.015625, y: 0.203125 },\n { x: 0.046875, y: 0.203125 },\n { x: 0.046875, y: 0.203125 },\n { x: 0.078125, y: 0.203125 },\n { x: 0.078125, y: 0.203125 },\n { x: 0.109375, y: 0.203125 },\n { x: 0.109375, y: 0.203125 },\n { x: 0.140625, y: 0.203125 },\n { x: 0.140625, y: 0.203125 },\n { x: 0.171875, y: 0.203125 },\n { x: 0.171875, y: 0.203125 },\n { x: 0.203125, y: 0.203125 },\n { x: 0.203125, y: 0.203125 },\n { x: 0.234375, y: 0.203125 },\n { x: 0.234375, y: 0.203125 },\n { x: 0.265625, y: 0.203125 },\n { x: 0.265625, y: 0.203125 },\n { x: 0.296875, y: 0.203125 },\n { x: 0.296875, y: 0.203125 },\n { x: 0.328125, y: 0.203125 },\n { x: 0.328125, y: 0.203125 },\n { x: 0.359375, y: 0.203125 },\n { x: 0.359375, y: 0.203125 },\n { x: 0.390625, y: 0.203125 },\n { x: 0.390625, y: 0.203125 },\n { x: 0.421875, y: 0.203125 },\n { x: 0.421875, y: 0.203125 },\n { x: 0.453125, y: 0.203125 },\n { x: 0.453125, y: 0.203125 },\n { x: 0.484375, y: 0.203125 },\n { x: 0.484375, y: 0.203125 },\n { x: 0.515625, y: 0.203125 },\n { x: 0.515625, y: 0.203125 },\n { x: 0.546875, y: 0.203125 },\n { x: 0.546875, y: 0.203125 },\n { x: 0.578125, y: 0.203125 },\n { x: 0.578125, y: 0.203125 },\n { x: 0.609375, y: 0.203125 },\n { x: 0.609375, y: 0.203125 },\n { x: 0.640625, y: 0.203125 },\n { x: 0.640625, y: 0.203125 },\n { x: 0.671875, y: 0.203125 },\n { x: 0.671875, y: 0.203125 },\n { x: 0.703125, y: 0.203125 },\n { x: 0.703125, y: 0.203125 },\n { x: 0.734375, y: 0.203125 },\n { x: 0.734375, y: 0.203125 },\n { x: 0.765625, y: 0.203125 },\n { x: 0.765625, y: 0.203125 },\n { x: 0.796875, y: 0.203125 },\n { x: 0.796875, y: 0.203125 },\n { x: 0.828125, y: 0.203125 },\n { x: 0.828125, y: 0.203125 },\n { x: 0.859375, y: 0.203125 },\n { x: 0.859375, y: 0.203125 },\n { x: 0.890625, y: 0.203125 },\n { x: 0.890625, y: 0.203125 },\n { x: 0.921875, y: 0.203125 },\n { x: 0.921875, y: 0.203125 },\n { x: 0.953125, y: 0.203125 },\n { x: 0.953125, y: 0.203125 },\n { x: 0.984375, y: 0.203125 },\n { x: 0.984375, y: 0.203125 },\n { x: 0.015625, y: 0.234375 },\n { x: 0.015625, y: 0.234375 },\n { x: 0.046875, y: 0.234375 },\n { x: 0.046875, y: 0.234375 },\n { x: 0.078125, y: 0.234375 },\n { x: 0.078125, y: 0.234375 },\n { x: 0.109375, y: 0.234375 },\n { x: 0.109375, y: 0.234375 },\n { x: 0.140625, y: 0.234375 },\n { x: 0.140625, y: 0.234375 },\n { x: 0.171875, y: 0.234375 },\n { x: 0.171875, y: 0.234375 },\n { x: 0.203125, y: 0.234375 },\n { x: 0.203125, y: 0.234375 },\n { x: 0.234375, y: 0.234375 },\n { x: 0.234375, y: 0.234375 },\n { x: 0.265625, y: 0.234375 },\n { x: 0.265625, y: 0.234375 },\n { x: 0.296875, y: 0.234375 },\n { x: 0.296875, y: 0.234375 },\n { x: 0.328125, y: 0.234375 },\n { x: 0.328125, y: 0.234375 },\n { x: 0.359375, y: 0.234375 },\n { x: 0.359375, y: 0.234375 },\n { x: 0.390625, y: 0.234375 },\n { x: 0.390625, y: 0.234375 },\n { x: 0.421875, y: 0.234375 },\n { x: 0.421875, y: 0.234375 },\n { x: 0.453125, y: 0.234375 },\n { x: 0.453125, y: 0.234375 },\n { x: 0.484375, y: 0.234375 },\n { x: 0.484375, y: 0.234375 },\n { x: 0.515625, y: 0.234375 },\n { x: 0.515625, y: 0.234375 },\n { x: 0.546875, y: 0.234375 },\n { x: 0.546875, y: 0.234375 },\n { x: 0.578125, y: 0.234375 },\n { x: 0.578125, y: 0.234375 },\n { x: 0.609375, y: 0.234375 },\n { x: 0.609375, y: 0.234375 },\n { x: 0.640625, y: 0.234375 },\n { x: 0.640625, y: 0.234375 },\n { x: 0.671875, y: 0.234375 },\n { x: 0.671875, y: 0.234375 },\n { x: 0.703125, y: 0.234375 },\n { x: 0.703125, y: 0.234375 },\n { x: 0.734375, y: 0.234375 },\n { x: 0.734375, y: 0.234375 },\n { x: 0.765625, y: 0.234375 },\n { x: 0.765625, y: 0.234375 },\n { x: 0.796875, y: 0.234375 },\n { x: 0.796875, y: 0.234375 },\n { x: 0.828125, y: 0.234375 },\n { x: 0.828125, y: 0.234375 },\n { x: 0.859375, y: 0.234375 },\n { x: 0.859375, y: 0.234375 },\n { x: 0.890625, y: 0.234375 },\n { x: 0.890625, y: 0.234375 },\n { x: 0.921875, y: 0.234375 },\n { x: 0.921875, y: 0.234375 },\n { x: 0.953125, y: 0.234375 },\n { x: 0.953125, y: 0.234375 },\n { x: 0.984375, y: 0.234375 },\n { x: 0.984375, y: 0.234375 },\n { x: 0.015625, y: 0.265625 },\n { x: 0.015625, y: 0.265625 },\n { x: 0.046875, y: 0.265625 },\n { x: 0.046875, y: 0.265625 },\n { x: 0.078125, y: 0.265625 },\n { x: 0.078125, y: 0.265625 },\n { x: 0.109375, y: 0.265625 },\n { x: 0.109375, y: 0.265625 },\n { x: 0.140625, y: 0.265625 },\n { x: 0.140625, y: 0.265625 },\n { x: 0.171875, y: 0.265625 },\n { x: 0.171875, y: 0.265625 },\n { x: 0.203125, y: 0.265625 },\n { x: 0.203125, y: 0.265625 },\n { x: 0.234375, y: 0.265625 },\n { x: 0.234375, y: 0.265625 },\n { x: 0.265625, y: 0.265625 },\n { x: 0.265625, y: 0.265625 },\n { x: 0.296875, y: 0.265625 },\n { x: 0.296875, y: 0.265625 },\n { x: 0.328125, y: 0.265625 },\n { x: 0.328125, y: 0.265625 },\n { x: 0.359375, y: 0.265625 },\n { x: 0.359375, y: 0.265625 },\n { x: 0.390625, y: 0.265625 },\n { x: 0.390625, y: 0.265625 },\n { x: 0.421875, y: 0.265625 },\n { x: 0.421875, y: 0.265625 },\n { x: 0.453125, y: 0.265625 },\n { x: 0.453125, y: 0.265625 },\n { x: 0.484375, y: 0.265625 },\n { x: 0.484375, y: 0.265625 },\n { x: 0.515625, y: 0.265625 },\n { x: 0.515625, y: 0.265625 },\n { x: 0.546875, y: 0.265625 },\n { x: 0.546875, y: 0.265625 },\n { x: 0.578125, y: 0.265625 },\n { x: 0.578125, y: 0.265625 },\n { x: 0.609375, y: 0.265625 },\n { x: 0.609375, y: 0.265625 },\n { x: 0.640625, y: 0.265625 },\n { x: 0.640625, y: 0.265625 },\n { x: 0.671875, y: 0.265625 },\n { x: 0.671875, y: 0.265625 },\n { x: 0.703125, y: 0.265625 },\n { x: 0.703125, y: 0.265625 },\n { x: 0.734375, y: 0.265625 },\n { x: 0.734375, y: 0.265625 },\n { x: 0.765625, y: 0.265625 },\n { x: 0.765625, y: 0.265625 },\n { x: 0.796875, y: 0.265625 },\n { x: 0.796875, y: 0.265625 },\n { x: 0.828125, y: 0.265625 },\n { x: 0.828125, y: 0.265625 },\n { x: 0.859375, y: 0.265625 },\n { x: 0.859375, y: 0.265625 },\n { x: 0.890625, y: 0.265625 },\n { x: 0.890625, y: 0.265625 },\n { x: 0.921875, y: 0.265625 },\n { x: 0.921875, y: 0.265625 },\n { x: 0.953125, y: 0.265625 },\n { x: 0.953125, y: 0.265625 },\n { x: 0.984375, y: 0.265625 },\n { x: 0.984375, y: 0.265625 },\n { x: 0.015625, y: 0.296875 },\n { x: 0.015625, y: 0.296875 },\n { x: 0.046875, y: 0.296875 },\n { x: 0.046875, y: 0.296875 },\n { x: 0.078125, y: 0.296875 },\n { x: 0.078125, y: 0.296875 },\n { x: 0.109375, y: 0.296875 },\n { x: 0.109375, y: 0.296875 },\n { x: 0.140625, y: 0.296875 },\n { x: 0.140625, y: 0.296875 },\n { x: 0.171875, y: 0.296875 },\n { x: 0.171875, y: 0.296875 },\n { x: 0.203125, y: 0.296875 },\n { x: 0.203125, y: 0.296875 },\n { x: 0.234375, y: 0.296875 },\n { x: 0.234375, y: 0.296875 },\n { x: 0.265625, y: 0.296875 },\n { x: 0.265625, y: 0.296875 },\n { x: 0.296875, y: 0.296875 },\n { x: 0.296875, y: 0.296875 },\n { x: 0.328125, y: 0.296875 },\n { x: 0.328125, y: 0.296875 },\n { x: 0.359375, y: 0.296875 },\n { x: 0.359375, y: 0.296875 },\n { x: 0.390625, y: 0.296875 },\n { x: 0.390625, y: 0.296875 },\n { x: 0.421875, y: 0.296875 },\n { x: 0.421875, y: 0.296875 },\n { x: 0.453125, y: 0.296875 },\n { x: 0.453125, y: 0.296875 },\n { x: 0.484375, y: 0.296875 },\n { x: 0.484375, y: 0.296875 },\n { x: 0.515625, y: 0.296875 },\n { x: 0.515625, y: 0.296875 },\n { x: 0.546875, y: 0.296875 },\n { x: 0.546875, y: 0.296875 },\n { x: 0.578125, y: 0.296875 },\n { x: 0.578125, y: 0.296875 },\n { x: 0.609375, y: 0.296875 },\n { x: 0.609375, y: 0.296875 },\n { x: 0.640625, y: 0.296875 },\n { x: 0.640625, y: 0.296875 },\n { x: 0.671875, y: 0.296875 },\n { x: 0.671875, y: 0.296875 },\n { x: 0.703125, y: 0.296875 },\n { x: 0.703125, y: 0.296875 },\n { x: 0.734375, y: 0.296875 },\n { x: 0.734375, y: 0.296875 },\n { x: 0.765625, y: 0.296875 },\n { x: 0.765625, y: 0.296875 },\n { x: 0.796875, y: 0.296875 },\n { x: 0.796875, y: 0.296875 },\n { x: 0.828125, y: 0.296875 },\n { x: 0.828125, y: 0.296875 },\n { x: 0.859375, y: 0.296875 },\n { x: 0.859375, y: 0.296875 },\n { x: 0.890625, y: 0.296875 },\n { x: 0.890625, y: 0.296875 },\n { x: 0.921875, y: 0.296875 },\n { x: 0.921875, y: 0.296875 },\n { x: 0.953125, y: 0.296875 },\n { x: 0.953125, y: 0.296875 },\n { x: 0.984375, y: 0.296875 },\n { x: 0.984375, y: 0.296875 },\n { x: 0.015625, y: 0.328125 },\n { x: 0.015625, y: 0.328125 },\n { x: 0.046875, y: 0.328125 },\n { x: 0.046875, y: 0.328125 },\n { x: 0.078125, y: 0.328125 },\n { x: 0.078125, y: 0.328125 },\n { x: 0.109375, y: 0.328125 },\n { x: 0.109375, y: 0.328125 },\n { x: 0.140625, y: 0.328125 },\n { x: 0.140625, y: 0.328125 },\n { x: 0.171875, y: 0.328125 },\n { x: 0.171875, y: 0.328125 },\n { x: 0.203125, y: 0.328125 },\n { x: 0.203125, y: 0.328125 },\n { x: 0.234375, y: 0.328125 },\n { x: 0.234375, y: 0.328125 },\n { x: 0.265625, y: 0.328125 },\n { x: 0.265625, y: 0.328125 },\n { x: 0.296875, y: 0.328125 },\n { x: 0.296875, y: 0.328125 },\n { x: 0.328125, y: 0.328125 },\n { x: 0.328125, y: 0.328125 },\n { x: 0.359375, y: 0.328125 },\n { x: 0.359375, y: 0.328125 },\n { x: 0.390625, y: 0.328125 },\n { x: 0.390625, y: 0.328125 },\n { x: 0.421875, y: 0.328125 },\n { x: 0.421875, y: 0.328125 },\n { x: 0.453125, y: 0.328125 },\n { x: 0.453125, y: 0.328125 },\n { x: 0.484375, y: 0.328125 },\n { x: 0.484375, y: 0.328125 },\n { x: 0.515625, y: 0.328125 },\n { x: 0.515625, y: 0.328125 },\n { x: 0.546875, y: 0.328125 },\n { x: 0.546875, y: 0.328125 },\n { x: 0.578125, y: 0.328125 },\n { x: 0.578125, y: 0.328125 },\n { x: 0.609375, y: 0.328125 },\n { x: 0.609375, y: 0.328125 },\n { x: 0.640625, y: 0.328125 },\n { x: 0.640625, y: 0.328125 },\n { x: 0.671875, y: 0.328125 },\n { x: 0.671875, y: 0.328125 },\n { x: 0.703125, y: 0.328125 },\n { x: 0.703125, y: 0.328125 },\n { x: 0.734375, y: 0.328125 },\n { x: 0.734375, y: 0.328125 },\n { x: 0.765625, y: 0.328125 },\n { x: 0.765625, y: 0.328125 },\n { x: 0.796875, y: 0.328125 },\n { x: 0.796875, y: 0.328125 },\n { x: 0.828125, y: 0.328125 },\n { x: 0.828125, y: 0.328125 },\n { x: 0.859375, y: 0.328125 },\n { x: 0.859375, y: 0.328125 },\n { x: 0.890625, y: 0.328125 },\n { x: 0.890625, y: 0.328125 },\n { x: 0.921875, y: 0.328125 },\n { x: 0.921875, y: 0.328125 },\n { x: 0.953125, y: 0.328125 },\n { x: 0.953125, y: 0.328125 },\n { x: 0.984375, y: 0.328125 },\n { x: 0.984375, y: 0.328125 },\n { x: 0.015625, y: 0.359375 },\n { x: 0.015625, y: 0.359375 },\n { x: 0.046875, y: 0.359375 },\n { x: 0.046875, y: 0.359375 },\n { x: 0.078125, y: 0.359375 },\n { x: 0.078125, y: 0.359375 },\n { x: 0.109375, y: 0.359375 },\n { x: 0.109375, y: 0.359375 },\n { x: 0.140625, y: 0.359375 },\n { x: 0.140625, y: 0.359375 },\n { x: 0.171875, y: 0.359375 },\n { x: 0.171875, y: 0.359375 },\n { x: 0.203125, y: 0.359375 },\n { x: 0.203125, y: 0.359375 },\n { x: 0.234375, y: 0.359375 },\n { x: 0.234375, y: 0.359375 },\n { x: 0.265625, y: 0.359375 },\n { x: 0.265625, y: 0.359375 },\n { x: 0.296875, y: 0.359375 },\n { x: 0.296875, y: 0.359375 },\n { x: 0.328125, y: 0.359375 },\n { x: 0.328125, y: 0.359375 },\n { x: 0.359375, y: 0.359375 },\n { x: 0.359375, y: 0.359375 },\n { x: 0.390625, y: 0.359375 },\n { x: 0.390625, y: 0.359375 },\n { x: 0.421875, y: 0.359375 },\n { x: 0.421875, y: 0.359375 },\n { x: 0.453125, y: 0.359375 },\n { x: 0.453125, y: 0.359375 },\n { x: 0.484375, y: 0.359375 },\n { x: 0.484375, y: 0.359375 },\n { x: 0.515625, y: 0.359375 },\n { x: 0.515625, y: 0.359375 },\n { x: 0.546875, y: 0.359375 },\n { x: 0.546875, y: 0.359375 },\n { x: 0.578125, y: 0.359375 },\n { x: 0.578125, y: 0.359375 },\n { x: 0.609375, y: 0.359375 },\n { x: 0.609375, y: 0.359375 },\n { x: 0.640625, y: 0.359375 },\n { x: 0.640625, y: 0.359375 },\n { x: 0.671875, y: 0.359375 },\n { x: 0.671875, y: 0.359375 },\n { x: 0.703125, y: 0.359375 },\n { x: 0.703125, y: 0.359375 },\n { x: 0.734375, y: 0.359375 },\n { x: 0.734375, y: 0.359375 },\n { x: 0.765625, y: 0.359375 },\n { x: 0.765625, y: 0.359375 },\n { x: 0.796875, y: 0.359375 },\n { x: 0.796875, y: 0.359375 },\n { x: 0.828125, y: 0.359375 },\n { x: 0.828125, y: 0.359375 },\n { x: 0.859375, y: 0.359375 },\n { x: 0.859375, y: 0.359375 },\n { x: 0.890625, y: 0.359375 },\n { x: 0.890625, y: 0.359375 },\n { x: 0.921875, y: 0.359375 },\n { x: 0.921875, y: 0.359375 },\n { x: 0.953125, y: 0.359375 },\n { x: 0.953125, y: 0.359375 },\n { x: 0.984375, y: 0.359375 },\n { x: 0.984375, y: 0.359375 },\n { x: 0.015625, y: 0.390625 },\n { x: 0.015625, y: 0.390625 },\n { x: 0.046875, y: 0.390625 },\n { x: 0.046875, y: 0.390625 },\n { x: 0.078125, y: 0.390625 },\n { x: 0.078125, y: 0.390625 },\n { x: 0.109375, y: 0.390625 },\n { x: 0.109375, y: 0.390625 },\n { x: 0.140625, y: 0.390625 },\n { x: 0.140625, y: 0.390625 },\n { x: 0.171875, y: 0.390625 },\n { x: 0.171875, y: 0.390625 },\n { x: 0.203125, y: 0.390625 },\n { x: 0.203125, y: 0.390625 },\n { x: 0.234375, y: 0.390625 },\n { x: 0.234375, y: 0.390625 },\n { x: 0.265625, y: 0.390625 },\n { x: 0.265625, y: 0.390625 },\n { x: 0.296875, y: 0.390625 },\n { x: 0.296875, y: 0.390625 },\n { x: 0.328125, y: 0.390625 },\n { x: 0.328125, y: 0.390625 },\n { x: 0.359375, y: 0.390625 },\n { x: 0.359375, y: 0.390625 },\n { x: 0.390625, y: 0.390625 },\n { x: 0.390625, y: 0.390625 },\n { x: 0.421875, y: 0.390625 },\n { x: 0.421875, y: 0.390625 },\n { x: 0.453125, y: 0.390625 },\n { x: 0.453125, y: 0.390625 },\n { x: 0.484375, y: 0.390625 },\n { x: 0.484375, y: 0.390625 },\n { x: 0.515625, y: 0.390625 },\n { x: 0.515625, y: 0.390625 },\n { x: 0.546875, y: 0.390625 },\n { x: 0.546875, y: 0.390625 },\n { x: 0.578125, y: 0.390625 },\n { x: 0.578125, y: 0.390625 },\n { x: 0.609375, y: 0.390625 },\n { x: 0.609375, y: 0.390625 },\n { x: 0.640625, y: 0.390625 },\n { x: 0.640625, y: 0.390625 },\n { x: 0.671875, y: 0.390625 },\n { x: 0.671875, y: 0.390625 },\n { x: 0.703125, y: 0.390625 },\n { x: 0.703125, y: 0.390625 },\n { x: 0.734375, y: 0.390625 },\n { x: 0.734375, y: 0.390625 },\n { x: 0.765625, y: 0.390625 },\n { x: 0.765625, y: 0.390625 },\n { x: 0.796875, y: 0.390625 },\n { x: 0.796875, y: 0.390625 },\n { x: 0.828125, y: 0.390625 },\n { x: 0.828125, y: 0.390625 },\n { x: 0.859375, y: 0.390625 },\n { x: 0.859375, y: 0.390625 },\n { x: 0.890625, y: 0.390625 },\n { x: 0.890625, y: 0.390625 },\n { x: 0.921875, y: 0.390625 },\n { x: 0.921875, y: 0.390625 },\n { x: 0.953125, y: 0.390625 },\n { x: 0.953125, y: 0.390625 },\n { x: 0.984375, y: 0.390625 },\n { x: 0.984375, y: 0.390625 },\n { x: 0.015625, y: 0.421875 },\n { x: 0.015625, y: 0.421875 },\n { x: 0.046875, y: 0.421875 },\n { x: 0.046875, y: 0.421875 },\n { x: 0.078125, y: 0.421875 },\n { x: 0.078125, y: 0.421875 },\n { x: 0.109375, y: 0.421875 },\n { x: 0.109375, y: 0.421875 },\n { x: 0.140625, y: 0.421875 },\n { x: 0.140625, y: 0.421875 },\n { x: 0.171875, y: 0.421875 },\n { x: 0.171875, y: 0.421875 },\n { x: 0.203125, y: 0.421875 },\n { x: 0.203125, y: 0.421875 },\n { x: 0.234375, y: 0.421875 },\n { x: 0.234375, y: 0.421875 },\n { x: 0.265625, y: 0.421875 },\n { x: 0.265625, y: 0.421875 },\n { x: 0.296875, y: 0.421875 },\n { x: 0.296875, y: 0.421875 },\n { x: 0.328125, y: 0.421875 },\n { x: 0.328125, y: 0.421875 },\n { x: 0.359375, y: 0.421875 },\n { x: 0.359375, y: 0.421875 },\n { x: 0.390625, y: 0.421875 },\n { x: 0.390625, y: 0.421875 },\n { x: 0.421875, y: 0.421875 },\n { x: 0.421875, y: 0.421875 },\n { x: 0.453125, y: 0.421875 },\n { x: 0.453125, y: 0.421875 },\n { x: 0.484375, y: 0.421875 },\n { x: 0.484375, y: 0.421875 },\n { x: 0.515625, y: 0.421875 },\n { x: 0.515625, y: 0.421875 },\n { x: 0.546875, y: 0.421875 },\n { x: 0.546875, y: 0.421875 },\n { x: 0.578125, y: 0.421875 },\n { x: 0.578125, y: 0.421875 },\n { x: 0.609375, y: 0.421875 },\n { x: 0.609375, y: 0.421875 },\n { x: 0.640625, y: 0.421875 },\n { x: 0.640625, y: 0.421875 },\n { x: 0.671875, y: 0.421875 },\n { x: 0.671875, y: 0.421875 },\n { x: 0.703125, y: 0.421875 },\n { x: 0.703125, y: 0.421875 },\n { x: 0.734375, y: 0.421875 },\n { x: 0.734375, y: 0.421875 },\n { x: 0.765625, y: 0.421875 },\n { x: 0.765625, y: 0.421875 },\n { x: 0.796875, y: 0.421875 },\n { x: 0.796875, y: 0.421875 },\n { x: 0.828125, y: 0.421875 },\n { x: 0.828125, y: 0.421875 },\n { x: 0.859375, y: 0.421875 },\n { x: 0.859375, y: 0.421875 },\n { x: 0.890625, y: 0.421875 },\n { x: 0.890625, y: 0.421875 },\n { x: 0.921875, y: 0.421875 },\n { x: 0.921875, y: 0.421875 },\n { x: 0.953125, y: 0.421875 },\n { x: 0.953125, y: 0.421875 },\n { x: 0.984375, y: 0.421875 },\n { x: 0.984375, y: 0.421875 },\n { x: 0.015625, y: 0.453125 },\n { x: 0.015625, y: 0.453125 },\n { x: 0.046875, y: 0.453125 },\n { x: 0.046875, y: 0.453125 },\n { x: 0.078125, y: 0.453125 },\n { x: 0.078125, y: 0.453125 },\n { x: 0.109375, y: 0.453125 },\n { x: 0.109375, y: 0.453125 },\n { x: 0.140625, y: 0.453125 },\n { x: 0.140625, y: 0.453125 },\n { x: 0.171875, y: 0.453125 },\n { x: 0.171875, y: 0.453125 },\n { x: 0.203125, y: 0.453125 },\n { x: 0.203125, y: 0.453125 },\n { x: 0.234375, y: 0.453125 },\n { x: 0.234375, y: 0.453125 },\n { x: 0.265625, y: 0.453125 },\n { x: 0.265625, y: 0.453125 },\n { x: 0.296875, y: 0.453125 },\n { x: 0.296875, y: 0.453125 },\n { x: 0.328125, y: 0.453125 },\n { x: 0.328125, y: 0.453125 },\n { x: 0.359375, y: 0.453125 },\n { x: 0.359375, y: 0.453125 },\n { x: 0.390625, y: 0.453125 },\n { x: 0.390625, y: 0.453125 },\n { x: 0.421875, y: 0.453125 },\n { x: 0.421875, y: 0.453125 },\n { x: 0.453125, y: 0.453125 },\n { x: 0.453125, y: 0.453125 },\n { x: 0.484375, y: 0.453125 },\n { x: 0.484375, y: 0.453125 },\n { x: 0.515625, y: 0.453125 },\n { x: 0.515625, y: 0.453125 },\n { x: 0.546875, y: 0.453125 },\n { x: 0.546875, y: 0.453125 },\n { x: 0.578125, y: 0.453125 },\n { x: 0.578125, y: 0.453125 },\n { x: 0.609375, y: 0.453125 },\n { x: 0.609375, y: 0.453125 },\n { x: 0.640625, y: 0.453125 },\n { x: 0.640625, y: 0.453125 },\n { x: 0.671875, y: 0.453125 },\n { x: 0.671875, y: 0.453125 },\n { x: 0.703125, y: 0.453125 },\n { x: 0.703125, y: 0.453125 },\n { x: 0.734375, y: 0.453125 },\n { x: 0.734375, y: 0.453125 },\n { x: 0.765625, y: 0.453125 },\n { x: 0.765625, y: 0.453125 },\n { x: 0.796875, y: 0.453125 },\n { x: 0.796875, y: 0.453125 },\n { x: 0.828125, y: 0.453125 },\n { x: 0.828125, y: 0.453125 },\n { x: 0.859375, y: 0.453125 },\n { x: 0.859375, y: 0.453125 },\n { x: 0.890625, y: 0.453125 },\n { x: 0.890625, y: 0.453125 },\n { x: 0.921875, y: 0.453125 },\n { x: 0.921875, y: 0.453125 },\n { x: 0.953125, y: 0.453125 },\n { x: 0.953125, y: 0.453125 },\n { x: 0.984375, y: 0.453125 },\n { x: 0.984375, y: 0.453125 },\n { x: 0.015625, y: 0.484375 },\n { x: 0.015625, y: 0.484375 },\n { x: 0.046875, y: 0.484375 },\n { x: 0.046875, y: 0.484375 },\n { x: 0.078125, y: 0.484375 },\n { x: 0.078125, y: 0.484375 },\n { x: 0.109375, y: 0.484375 },\n { x: 0.109375, y: 0.484375 },\n { x: 0.140625, y: 0.484375 },\n { x: 0.140625, y: 0.484375 },\n { x: 0.171875, y: 0.484375 },\n { x: 0.171875, y: 0.484375 },\n { x: 0.203125, y: 0.484375 },\n { x: 0.203125, y: 0.484375 },\n { x: 0.234375, y: 0.484375 },\n { x: 0.234375, y: 0.484375 },\n { x: 0.265625, y: 0.484375 },\n { x: 0.265625, y: 0.484375 },\n { x: 0.296875, y: 0.484375 },\n { x: 0.296875, y: 0.484375 },\n { x: 0.328125, y: 0.484375 },\n { x: 0.328125, y: 0.484375 },\n { x: 0.359375, y: 0.484375 },\n { x: 0.359375, y: 0.484375 },\n { x: 0.390625, y: 0.484375 },\n { x: 0.390625, y: 0.484375 },\n { x: 0.421875, y: 0.484375 },\n { x: 0.421875, y: 0.484375 },\n { x: 0.453125, y: 0.484375 },\n { x: 0.453125, y: 0.484375 },\n { x: 0.484375, y: 0.484375 },\n { x: 0.484375, y: 0.484375 },\n { x: 0.515625, y: 0.484375 },\n { x: 0.515625, y: 0.484375 },\n { x: 0.546875, y: 0.484375 },\n { x: 0.546875, y: 0.484375 },\n { x: 0.578125, y: 0.484375 },\n { x: 0.578125, y: 0.484375 },\n { x: 0.609375, y: 0.484375 },\n { x: 0.609375, y: 0.484375 },\n { x: 0.640625, y: 0.484375 },\n { x: 0.640625, y: 0.484375 },\n { x: 0.671875, y: 0.484375 },\n { x: 0.671875, y: 0.484375 },\n { x: 0.703125, y: 0.484375 },\n { x: 0.703125, y: 0.484375 },\n { x: 0.734375, y: 0.484375 },\n { x: 0.734375, y: 0.484375 },\n { x: 0.765625, y: 0.484375 },\n { x: 0.765625, y: 0.484375 },\n { x: 0.796875, y: 0.484375 },\n { x: 0.796875, y: 0.484375 },\n { x: 0.828125, y: 0.484375 },\n { x: 0.828125, y: 0.484375 },\n { x: 0.859375, y: 0.484375 },\n { x: 0.859375, y: 0.484375 },\n { x: 0.890625, y: 0.484375 },\n { x: 0.890625, y: 0.484375 },\n { x: 0.921875, y: 0.484375 },\n { x: 0.921875, y: 0.484375 },\n { x: 0.953125, y: 0.484375 },\n { x: 0.953125, y: 0.484375 },\n { x: 0.984375, y: 0.484375 },\n { x: 0.984375, y: 0.484375 },\n { x: 0.015625, y: 0.515625 },\n { x: 0.015625, y: 0.515625 },\n { x: 0.046875, y: 0.515625 },\n { x: 0.046875, y: 0.515625 },\n { x: 0.078125, y: 0.515625 },\n { x: 0.078125, y: 0.515625 },\n { x: 0.109375, y: 0.515625 },\n { x: 0.109375, y: 0.515625 },\n { x: 0.140625, y: 0.515625 },\n { x: 0.140625, y: 0.515625 },\n { x: 0.171875, y: 0.515625 },\n { x: 0.171875, y: 0.515625 },\n { x: 0.203125, y: 0.515625 },\n { x: 0.203125, y: 0.515625 },\n { x: 0.234375, y: 0.515625 },\n { x: 0.234375, y: 0.515625 },\n { x: 0.265625, y: 0.515625 },\n { x: 0.265625, y: 0.515625 },\n { x: 0.296875, y: 0.515625 },\n { x: 0.296875, y: 0.515625 },\n { x: 0.328125, y: 0.515625 },\n { x: 0.328125, y: 0.515625 },\n { x: 0.359375, y: 0.515625 },\n { x: 0.359375, y: 0.515625 },\n { x: 0.390625, y: 0.515625 },\n { x: 0.390625, y: 0.515625 },\n { x: 0.421875, y: 0.515625 },\n { x: 0.421875, y: 0.515625 },\n { x: 0.453125, y: 0.515625 },\n { x: 0.453125, y: 0.515625 },\n { x: 0.484375, y: 0.515625 },\n { x: 0.484375, y: 0.515625 },\n { x: 0.515625, y: 0.515625 },\n { x: 0.515625, y: 0.515625 },\n { x: 0.546875, y: 0.515625 },\n { x: 0.546875, y: 0.515625 },\n { x: 0.578125, y: 0.515625 },\n { x: 0.578125, y: 0.515625 },\n { x: 0.609375, y: 0.515625 },\n { x: 0.609375, y: 0.515625 },\n { x: 0.640625, y: 0.515625 },\n { x: 0.640625, y: 0.515625 },\n { x: 0.671875, y: 0.515625 },\n { x: 0.671875, y: 0.515625 },\n { x: 0.703125, y: 0.515625 },\n { x: 0.703125, y: 0.515625 },\n { x: 0.734375, y: 0.515625 },\n { x: 0.734375, y: 0.515625 },\n { x: 0.765625, y: 0.515625 },\n { x: 0.765625, y: 0.515625 },\n { x: 0.796875, y: 0.515625 },\n { x: 0.796875, y: 0.515625 },\n { x: 0.828125, y: 0.515625 },\n { x: 0.828125, y: 0.515625 },\n { x: 0.859375, y: 0.515625 },\n { x: 0.859375, y: 0.515625 },\n { x: 0.890625, y: 0.515625 },\n { x: 0.890625, y: 0.515625 },\n { x: 0.921875, y: 0.515625 },\n { x: 0.921875, y: 0.515625 },\n { x: 0.953125, y: 0.515625 },\n { x: 0.953125, y: 0.515625 },\n { x: 0.984375, y: 0.515625 },\n { x: 0.984375, y: 0.515625 },\n { x: 0.015625, y: 0.546875 },\n { x: 0.015625, y: 0.546875 },\n { x: 0.046875, y: 0.546875 },\n { x: 0.046875, y: 0.546875 },\n { x: 0.078125, y: 0.546875 },\n { x: 0.078125, y: 0.546875 },\n { x: 0.109375, y: 0.546875 },\n { x: 0.109375, y: 0.546875 },\n { x: 0.140625, y: 0.546875 },\n { x: 0.140625, y: 0.546875 },\n { x: 0.171875, y: 0.546875 },\n { x: 0.171875, y: 0.546875 },\n { x: 0.203125, y: 0.546875 },\n { x: 0.203125, y: 0.546875 },\n { x: 0.234375, y: 0.546875 },\n { x: 0.234375, y: 0.546875 },\n { x: 0.265625, y: 0.546875 },\n { x: 0.265625, y: 0.546875 },\n { x: 0.296875, y: 0.546875 },\n { x: 0.296875, y: 0.546875 },\n { x: 0.328125, y: 0.546875 },\n { x: 0.328125, y: 0.546875 },\n { x: 0.359375, y: 0.546875 },\n { x: 0.359375, y: 0.546875 },\n { x: 0.390625, y: 0.546875 },\n { x: 0.390625, y: 0.546875 },\n { x: 0.421875, y: 0.546875 },\n { x: 0.421875, y: 0.546875 },\n { x: 0.453125, y: 0.546875 },\n { x: 0.453125, y: 0.546875 },\n { x: 0.484375, y: 0.546875 },\n { x: 0.484375, y: 0.546875 },\n { x: 0.515625, y: 0.546875 },\n { x: 0.515625, y: 0.546875 },\n { x: 0.546875, y: 0.546875 },\n { x: 0.546875, y: 0.546875 },\n { x: 0.578125, y: 0.546875 },\n { x: 0.578125, y: 0.546875 },\n { x: 0.609375, y: 0.546875 },\n { x: 0.609375, y: 0.546875 },\n { x: 0.640625, y: 0.546875 },\n { x: 0.640625, y: 0.546875 },\n { x: 0.671875, y: 0.546875 },\n { x: 0.671875, y: 0.546875 },\n { x: 0.703125, y: 0.546875 },\n { x: 0.703125, y: 0.546875 },\n { x: 0.734375, y: 0.546875 },\n { x: 0.734375, y: 0.546875 },\n { x: 0.765625, y: 0.546875 },\n { x: 0.765625, y: 0.546875 },\n { x: 0.796875, y: 0.546875 },\n { x: 0.796875, y: 0.546875 },\n { x: 0.828125, y: 0.546875 },\n { x: 0.828125, y: 0.546875 },\n { x: 0.859375, y: 0.546875 },\n { x: 0.859375, y: 0.546875 },\n { x: 0.890625, y: 0.546875 },\n { x: 0.890625, y: 0.546875 },\n { x: 0.921875, y: 0.546875 },\n { x: 0.921875, y: 0.546875 },\n { x: 0.953125, y: 0.546875 },\n { x: 0.953125, y: 0.546875 },\n { x: 0.984375, y: 0.546875 },\n { x: 0.984375, y: 0.546875 },\n { x: 0.015625, y: 0.578125 },\n { x: 0.015625, y: 0.578125 },\n { x: 0.046875, y: 0.578125 },\n { x: 0.046875, y: 0.578125 },\n { x: 0.078125, y: 0.578125 },\n { x: 0.078125, y: 0.578125 },\n { x: 0.109375, y: 0.578125 },\n { x: 0.109375, y: 0.578125 },\n { x: 0.140625, y: 0.578125 },\n { x: 0.140625, y: 0.578125 },\n { x: 0.171875, y: 0.578125 },\n { x: 0.171875, y: 0.578125 },\n { x: 0.203125, y: 0.578125 },\n { x: 0.203125, y: 0.578125 },\n { x: 0.234375, y: 0.578125 },\n { x: 0.234375, y: 0.578125 },\n { x: 0.265625, y: 0.578125 },\n { x: 0.265625, y: 0.578125 },\n { x: 0.296875, y: 0.578125 },\n { x: 0.296875, y: 0.578125 },\n { x: 0.328125, y: 0.578125 },\n { x: 0.328125, y: 0.578125 },\n { x: 0.359375, y: 0.578125 },\n { x: 0.359375, y: 0.578125 },\n { x: 0.390625, y: 0.578125 },\n { x: 0.390625, y: 0.578125 },\n { x: 0.421875, y: 0.578125 },\n { x: 0.421875, y: 0.578125 },\n { x: 0.453125, y: 0.578125 },\n { x: 0.453125, y: 0.578125 },\n { x: 0.484375, y: 0.578125 },\n { x: 0.484375, y: 0.578125 },\n { x: 0.515625, y: 0.578125 },\n { x: 0.515625, y: 0.578125 },\n { x: 0.546875, y: 0.578125 },\n { x: 0.546875, y: 0.578125 },\n { x: 0.578125, y: 0.578125 },\n { x: 0.578125, y: 0.578125 },\n { x: 0.609375, y: 0.578125 },\n { x: 0.609375, y: 0.578125 },\n { x: 0.640625, y: 0.578125 },\n { x: 0.640625, y: 0.578125 },\n { x: 0.671875, y: 0.578125 },\n { x: 0.671875, y: 0.578125 },\n { x: 0.703125, y: 0.578125 },\n { x: 0.703125, y: 0.578125 },\n { x: 0.734375, y: 0.578125 },\n { x: 0.734375, y: 0.578125 },\n { x: 0.765625, y: 0.578125 },\n { x: 0.765625, y: 0.578125 },\n { x: 0.796875, y: 0.578125 },\n { x: 0.796875, y: 0.578125 },\n { x: 0.828125, y: 0.578125 },\n { x: 0.828125, y: 0.578125 },\n { x: 0.859375, y: 0.578125 },\n { x: 0.859375, y: 0.578125 },\n { x: 0.890625, y: 0.578125 },\n { x: 0.890625, y: 0.578125 },\n { x: 0.921875, y: 0.578125 },\n { x: 0.921875, y: 0.578125 },\n { x: 0.953125, y: 0.578125 },\n { x: 0.953125, y: 0.578125 },\n { x: 0.984375, y: 0.578125 },\n { x: 0.984375, y: 0.578125 },\n { x: 0.015625, y: 0.609375 },\n { x: 0.015625, y: 0.609375 },\n { x: 0.046875, y: 0.609375 },\n { x: 0.046875, y: 0.609375 },\n { x: 0.078125, y: 0.609375 },\n { x: 0.078125, y: 0.609375 },\n { x: 0.109375, y: 0.609375 },\n { x: 0.109375, y: 0.609375 },\n { x: 0.140625, y: 0.609375 },\n { x: 0.140625, y: 0.609375 },\n { x: 0.171875, y: 0.609375 },\n { x: 0.171875, y: 0.609375 },\n { x: 0.203125, y: 0.609375 },\n { x: 0.203125, y: 0.609375 },\n { x: 0.234375, y: 0.609375 },\n { x: 0.234375, y: 0.609375 },\n { x: 0.265625, y: 0.609375 },\n { x: 0.265625, y: 0.609375 },\n { x: 0.296875, y: 0.609375 },\n { x: 0.296875, y: 0.609375 },\n { x: 0.328125, y: 0.609375 },\n { x: 0.328125, y: 0.609375 },\n { x: 0.359375, y: 0.609375 },\n { x: 0.359375, y: 0.609375 },\n { x: 0.390625, y: 0.609375 },\n { x: 0.390625, y: 0.609375 },\n { x: 0.421875, y: 0.609375 },\n { x: 0.421875, y: 0.609375 },\n { x: 0.453125, y: 0.609375 },\n { x: 0.453125, y: 0.609375 },\n { x: 0.484375, y: 0.609375 },\n { x: 0.484375, y: 0.609375 },\n { x: 0.515625, y: 0.609375 },\n { x: 0.515625, y: 0.609375 },\n { x: 0.546875, y: 0.609375 },\n { x: 0.546875, y: 0.609375 },\n { x: 0.578125, y: 0.609375 },\n { x: 0.578125, y: 0.609375 },\n { x: 0.609375, y: 0.609375 },\n { x: 0.609375, y: 0.609375 },\n { x: 0.640625, y: 0.609375 },\n { x: 0.640625, y: 0.609375 },\n { x: 0.671875, y: 0.609375 },\n { x: 0.671875, y: 0.609375 },\n { x: 0.703125, y: 0.609375 },\n { x: 0.703125, y: 0.609375 },\n { x: 0.734375, y: 0.609375 },\n { x: 0.734375, y: 0.609375 },\n { x: 0.765625, y: 0.609375 },\n { x: 0.765625, y: 0.609375 },\n { x: 0.796875, y: 0.609375 },\n { x: 0.796875, y: 0.609375 },\n { x: 0.828125, y: 0.609375 },\n { x: 0.828125, y: 0.609375 },\n { x: 0.859375, y: 0.609375 },\n { x: 0.859375, y: 0.609375 },\n { x: 0.890625, y: 0.609375 },\n { x: 0.890625, y: 0.609375 },\n { x: 0.921875, y: 0.609375 },\n { x: 0.921875, y: 0.609375 },\n { x: 0.953125, y: 0.609375 },\n { x: 0.953125, y: 0.609375 },\n { x: 0.984375, y: 0.609375 },\n { x: 0.984375, y: 0.609375 },\n { x: 0.015625, y: 0.640625 },\n { x: 0.015625, y: 0.640625 },\n { x: 0.046875, y: 0.640625 },\n { x: 0.046875, y: 0.640625 },\n { x: 0.078125, y: 0.640625 },\n { x: 0.078125, y: 0.640625 },\n { x: 0.109375, y: 0.640625 },\n { x: 0.109375, y: 0.640625 },\n { x: 0.140625, y: 0.640625 },\n { x: 0.140625, y: 0.640625 },\n { x: 0.171875, y: 0.640625 },\n { x: 0.171875, y: 0.640625 },\n { x: 0.203125, y: 0.640625 },\n { x: 0.203125, y: 0.640625 },\n { x: 0.234375, y: 0.640625 },\n { x: 0.234375, y: 0.640625 },\n { x: 0.265625, y: 0.640625 },\n { x: 0.265625, y: 0.640625 },\n { x: 0.296875, y: 0.640625 },\n { x: 0.296875, y: 0.640625 },\n { x: 0.328125, y: 0.640625 },\n { x: 0.328125, y: 0.640625 },\n { x: 0.359375, y: 0.640625 },\n { x: 0.359375, y: 0.640625 },\n { x: 0.390625, y: 0.640625 },\n { x: 0.390625, y: 0.640625 },\n { x: 0.421875, y: 0.640625 },\n { x: 0.421875, y: 0.640625 },\n { x: 0.453125, y: 0.640625 },\n { x: 0.453125, y: 0.640625 },\n { x: 0.484375, y: 0.640625 },\n { x: 0.484375, y: 0.640625 },\n { x: 0.515625, y: 0.640625 },\n { x: 0.515625, y: 0.640625 },\n { x: 0.546875, y: 0.640625 },\n { x: 0.546875, y: 0.640625 },\n { x: 0.578125, y: 0.640625 },\n { x: 0.578125, y: 0.640625 },\n { x: 0.609375, y: 0.640625 },\n { x: 0.609375, y: 0.640625 },\n { x: 0.640625, y: 0.640625 },\n { x: 0.640625, y: 0.640625 },\n { x: 0.671875, y: 0.640625 },\n { x: 0.671875, y: 0.640625 },\n { x: 0.703125, y: 0.640625 },\n { x: 0.703125, y: 0.640625 },\n { x: 0.734375, y: 0.640625 },\n { x: 0.734375, y: 0.640625 },\n { x: 0.765625, y: 0.640625 },\n { x: 0.765625, y: 0.640625 },\n { x: 0.796875, y: 0.640625 },\n { x: 0.796875, y: 0.640625 },\n { x: 0.828125, y: 0.640625 },\n { x: 0.828125, y: 0.640625 },\n { x: 0.859375, y: 0.640625 },\n { x: 0.859375, y: 0.640625 },\n { x: 0.890625, y: 0.640625 },\n { x: 0.890625, y: 0.640625 },\n { x: 0.921875, y: 0.640625 },\n { x: 0.921875, y: 0.640625 },\n { x: 0.953125, y: 0.640625 },\n { x: 0.953125, y: 0.640625 },\n { x: 0.984375, y: 0.640625 },\n { x: 0.984375, y: 0.640625 },\n { x: 0.015625, y: 0.671875 },\n { x: 0.015625, y: 0.671875 },\n { x: 0.046875, y: 0.671875 },\n { x: 0.046875, y: 0.671875 },\n { x: 0.078125, y: 0.671875 },\n { x: 0.078125, y: 0.671875 },\n { x: 0.109375, y: 0.671875 },\n { x: 0.109375, y: 0.671875 },\n { x: 0.140625, y: 0.671875 },\n { x: 0.140625, y: 0.671875 },\n { x: 0.171875, y: 0.671875 },\n { x: 0.171875, y: 0.671875 },\n { x: 0.203125, y: 0.671875 },\n { x: 0.203125, y: 0.671875 },\n { x: 0.234375, y: 0.671875 },\n { x: 0.234375, y: 0.671875 },\n { x: 0.265625, y: 0.671875 },\n { x: 0.265625, y: 0.671875 },\n { x: 0.296875, y: 0.671875 },\n { x: 0.296875, y: 0.671875 },\n { x: 0.328125, y: 0.671875 },\n { x: 0.328125, y: 0.671875 },\n { x: 0.359375, y: 0.671875 },\n { x: 0.359375, y: 0.671875 },\n { x: 0.390625, y: 0.671875 },\n { x: 0.390625, y: 0.671875 },\n { x: 0.421875, y: 0.671875 },\n { x: 0.421875, y: 0.671875 },\n { x: 0.453125, y: 0.671875 },\n { x: 0.453125, y: 0.671875 },\n { x: 0.484375, y: 0.671875 },\n { x: 0.484375, y: 0.671875 },\n { x: 0.515625, y: 0.671875 },\n { x: 0.515625, y: 0.671875 },\n { x: 0.546875, y: 0.671875 },\n { x: 0.546875, y: 0.671875 },\n { x: 0.578125, y: 0.671875 },\n { x: 0.578125, y: 0.671875 },\n { x: 0.609375, y: 0.671875 },\n { x: 0.609375, y: 0.671875 },\n { x: 0.640625, y: 0.671875 },\n { x: 0.640625, y: 0.671875 },\n { x: 0.671875, y: 0.671875 },\n { x: 0.671875, y: 0.671875 },\n { x: 0.703125, y: 0.671875 },\n { x: 0.703125, y: 0.671875 },\n { x: 0.734375, y: 0.671875 },\n { x: 0.734375, y: 0.671875 },\n { x: 0.765625, y: 0.671875 },\n { x: 0.765625, y: 0.671875 },\n { x: 0.796875, y: 0.671875 },\n { x: 0.796875, y: 0.671875 },\n { x: 0.828125, y: 0.671875 },\n { x: 0.828125, y: 0.671875 },\n { x: 0.859375, y: 0.671875 },\n { x: 0.859375, y: 0.671875 },\n { x: 0.890625, y: 0.671875 },\n { x: 0.890625, y: 0.671875 },\n { x: 0.921875, y: 0.671875 },\n { x: 0.921875, y: 0.671875 },\n { x: 0.953125, y: 0.671875 },\n { x: 0.953125, y: 0.671875 },\n { x: 0.984375, y: 0.671875 },\n { x: 0.984375, y: 0.671875 },\n { x: 0.015625, y: 0.703125 },\n { x: 0.015625, y: 0.703125 },\n { x: 0.046875, y: 0.703125 },\n { x: 0.046875, y: 0.703125 },\n { x: 0.078125, y: 0.703125 },\n { x: 0.078125, y: 0.703125 },\n { x: 0.109375, y: 0.703125 },\n { x: 0.109375, y: 0.703125 },\n { x: 0.140625, y: 0.703125 },\n { x: 0.140625, y: 0.703125 },\n { x: 0.171875, y: 0.703125 },\n { x: 0.171875, y: 0.703125 },\n { x: 0.203125, y: 0.703125 },\n { x: 0.203125, y: 0.703125 },\n { x: 0.234375, y: 0.703125 },\n { x: 0.234375, y: 0.703125 },\n { x: 0.265625, y: 0.703125 },\n { x: 0.265625, y: 0.703125 },\n { x: 0.296875, y: 0.703125 },\n { x: 0.296875, y: 0.703125 },\n { x: 0.328125, y: 0.703125 },\n { x: 0.328125, y: 0.703125 },\n { x: 0.359375, y: 0.703125 },\n { x: 0.359375, y: 0.703125 },\n { x: 0.390625, y: 0.703125 },\n { x: 0.390625, y: 0.703125 },\n { x: 0.421875, y: 0.703125 },\n { x: 0.421875, y: 0.703125 },\n { x: 0.453125, y: 0.703125 },\n { x: 0.453125, y: 0.703125 },\n { x: 0.484375, y: 0.703125 },\n { x: 0.484375, y: 0.703125 },\n { x: 0.515625, y: 0.703125 },\n { x: 0.515625, y: 0.703125 },\n { x: 0.546875, y: 0.703125 },\n { x: 0.546875, y: 0.703125 },\n { x: 0.578125, y: 0.703125 },\n { x: 0.578125, y: 0.703125 },\n { x: 0.609375, y: 0.703125 },\n { x: 0.609375, y: 0.703125 },\n { x: 0.640625, y: 0.703125 },\n { x: 0.640625, y: 0.703125 },\n { x: 0.671875, y: 0.703125 },\n { x: 0.671875, y: 0.703125 },\n { x: 0.703125, y: 0.703125 },\n { x: 0.703125, y: 0.703125 },\n { x: 0.734375, y: 0.703125 },\n { x: 0.734375, y: 0.703125 },\n { x: 0.765625, y: 0.703125 },\n { x: 0.765625, y: 0.703125 },\n { x: 0.796875, y: 0.703125 },\n { x: 0.796875, y: 0.703125 },\n { x: 0.828125, y: 0.703125 },\n { x: 0.828125, y: 0.703125 },\n { x: 0.859375, y: 0.703125 },\n { x: 0.859375, y: 0.703125 },\n { x: 0.890625, y: 0.703125 },\n { x: 0.890625, y: 0.703125 },\n { x: 0.921875, y: 0.703125 },\n { x: 0.921875, y: 0.703125 },\n { x: 0.953125, y: 0.703125 },\n { x: 0.953125, y: 0.703125 },\n { x: 0.984375, y: 0.703125 },\n { x: 0.984375, y: 0.703125 },\n { x: 0.015625, y: 0.734375 },\n { x: 0.015625, y: 0.734375 },\n { x: 0.046875, y: 0.734375 },\n { x: 0.046875, y: 0.734375 },\n { x: 0.078125, y: 0.734375 },\n { x: 0.078125, y: 0.734375 },\n { x: 0.109375, y: 0.734375 },\n { x: 0.109375, y: 0.734375 },\n { x: 0.140625, y: 0.734375 },\n { x: 0.140625, y: 0.734375 },\n { x: 0.171875, y: 0.734375 },\n { x: 0.171875, y: 0.734375 },\n { x: 0.203125, y: 0.734375 },\n { x: 0.203125, y: 0.734375 },\n { x: 0.234375, y: 0.734375 },\n { x: 0.234375, y: 0.734375 },\n { x: 0.265625, y: 0.734375 },\n { x: 0.265625, y: 0.734375 },\n { x: 0.296875, y: 0.734375 },\n { x: 0.296875, y: 0.734375 },\n { x: 0.328125, y: 0.734375 },\n { x: 0.328125, y: 0.734375 },\n { x: 0.359375, y: 0.734375 },\n { x: 0.359375, y: 0.734375 },\n { x: 0.390625, y: 0.734375 },\n { x: 0.390625, y: 0.734375 },\n { x: 0.421875, y: 0.734375 },\n { x: 0.421875, y: 0.734375 },\n { x: 0.453125, y: 0.734375 },\n { x: 0.453125, y: 0.734375 },\n { x: 0.484375, y: 0.734375 },\n { x: 0.484375, y: 0.734375 },\n { x: 0.515625, y: 0.734375 },\n { x: 0.515625, y: 0.734375 },\n { x: 0.546875, y: 0.734375 },\n { x: 0.546875, y: 0.734375 },\n { x: 0.578125, y: 0.734375 },\n { x: 0.578125, y: 0.734375 },\n { x: 0.609375, y: 0.734375 },\n { x: 0.609375, y: 0.734375 },\n { x: 0.640625, y: 0.734375 },\n { x: 0.640625, y: 0.734375 },\n { x: 0.671875, y: 0.734375 },\n { x: 0.671875, y: 0.734375 },\n { x: 0.703125, y: 0.734375 },\n { x: 0.703125, y: 0.734375 },\n { x: 0.734375, y: 0.734375 },\n { x: 0.734375, y: 0.734375 },\n { x: 0.765625, y: 0.734375 },\n { x: 0.765625, y: 0.734375 },\n { x: 0.796875, y: 0.734375 },\n { x: 0.796875, y: 0.734375 },\n { x: 0.828125, y: 0.734375 },\n { x: 0.828125, y: 0.734375 },\n { x: 0.859375, y: 0.734375 },\n { x: 0.859375, y: 0.734375 },\n { x: 0.890625, y: 0.734375 },\n { x: 0.890625, y: 0.734375 },\n { x: 0.921875, y: 0.734375 },\n { x: 0.921875, y: 0.734375 },\n { x: 0.953125, y: 0.734375 },\n { x: 0.953125, y: 0.734375 },\n { x: 0.984375, y: 0.734375 },\n { x: 0.984375, y: 0.734375 },\n { x: 0.015625, y: 0.765625 },\n { x: 0.015625, y: 0.765625 },\n { x: 0.046875, y: 0.765625 },\n { x: 0.046875, y: 0.765625 },\n { x: 0.078125, y: 0.765625 },\n { x: 0.078125, y: 0.765625 },\n { x: 0.109375, y: 0.765625 },\n { x: 0.109375, y: 0.765625 },\n { x: 0.140625, y: 0.765625 },\n { x: 0.140625, y: 0.765625 },\n { x: 0.171875, y: 0.765625 },\n { x: 0.171875, y: 0.765625 },\n { x: 0.203125, y: 0.765625 },\n { x: 0.203125, y: 0.765625 },\n { x: 0.234375, y: 0.765625 },\n { x: 0.234375, y: 0.765625 },\n { x: 0.265625, y: 0.765625 },\n { x: 0.265625, y: 0.765625 },\n { x: 0.296875, y: 0.765625 },\n { x: 0.296875, y: 0.765625 },\n { x: 0.328125, y: 0.765625 },\n { x: 0.328125, y: 0.765625 },\n { x: 0.359375, y: 0.765625 },\n { x: 0.359375, y: 0.765625 },\n { x: 0.390625, y: 0.765625 },\n { x: 0.390625, y: 0.765625 },\n { x: 0.421875, y: 0.765625 },\n { x: 0.421875, y: 0.765625 },\n { x: 0.453125, y: 0.765625 },\n { x: 0.453125, y: 0.765625 },\n { x: 0.484375, y: 0.765625 },\n { x: 0.484375, y: 0.765625 },\n { x: 0.515625, y: 0.765625 },\n { x: 0.515625, y: 0.765625 },\n { x: 0.546875, y: 0.765625 },\n { x: 0.546875, y: 0.765625 },\n { x: 0.578125, y: 0.765625 },\n { x: 0.578125, y: 0.765625 },\n { x: 0.609375, y: 0.765625 },\n { x: 0.609375, y: 0.765625 },\n { x: 0.640625, y: 0.765625 },\n { x: 0.640625, y: 0.765625 },\n { x: 0.671875, y: 0.765625 },\n { x: 0.671875, y: 0.765625 },\n { x: 0.703125, y: 0.765625 },\n { x: 0.703125, y: 0.765625 },\n { x: 0.734375, y: 0.765625 },\n { x: 0.734375, y: 0.765625 },\n { x: 0.765625, y: 0.765625 },\n { x: 0.765625, y: 0.765625 },\n { x: 0.796875, y: 0.765625 },\n { x: 0.796875, y: 0.765625 },\n { x: 0.828125, y: 0.765625 },\n { x: 0.828125, y: 0.765625 },\n { x: 0.859375, y: 0.765625 },\n { x: 0.859375, y: 0.765625 },\n { x: 0.890625, y: 0.765625 },\n { x: 0.890625, y: 0.765625 },\n { x: 0.921875, y: 0.765625 },\n { x: 0.921875, y: 0.765625 },\n { x: 0.953125, y: 0.765625 },\n { x: 0.953125, y: 0.765625 },\n { x: 0.984375, y: 0.765625 },\n { x: 0.984375, y: 0.765625 },\n { x: 0.015625, y: 0.796875 },\n { x: 0.015625, y: 0.796875 },\n { x: 0.046875, y: 0.796875 },\n { x: 0.046875, y: 0.796875 },\n { x: 0.078125, y: 0.796875 },\n { x: 0.078125, y: 0.796875 },\n { x: 0.109375, y: 0.796875 },\n { x: 0.109375, y: 0.796875 },\n { x: 0.140625, y: 0.796875 },\n { x: 0.140625, y: 0.796875 },\n { x: 0.171875, y: 0.796875 },\n { x: 0.171875, y: 0.796875 },\n { x: 0.203125, y: 0.796875 },\n { x: 0.203125, y: 0.796875 },\n { x: 0.234375, y: 0.796875 },\n { x: 0.234375, y: 0.796875 },\n { x: 0.265625, y: 0.796875 },\n { x: 0.265625, y: 0.796875 },\n { x: 0.296875, y: 0.796875 },\n { x: 0.296875, y: 0.796875 },\n { x: 0.328125, y: 0.796875 },\n { x: 0.328125, y: 0.796875 },\n { x: 0.359375, y: 0.796875 },\n { x: 0.359375, y: 0.796875 },\n { x: 0.390625, y: 0.796875 },\n { x: 0.390625, y: 0.796875 },\n { x: 0.421875, y: 0.796875 },\n { x: 0.421875, y: 0.796875 },\n { x: 0.453125, y: 0.796875 },\n { x: 0.453125, y: 0.796875 },\n { x: 0.484375, y: 0.796875 },\n { x: 0.484375, y: 0.796875 },\n { x: 0.515625, y: 0.796875 },\n { x: 0.515625, y: 0.796875 },\n { x: 0.546875, y: 0.796875 },\n { x: 0.546875, y: 0.796875 },\n { x: 0.578125, y: 0.796875 },\n { x: 0.578125, y: 0.796875 },\n { x: 0.609375, y: 0.796875 },\n { x: 0.609375, y: 0.796875 },\n { x: 0.640625, y: 0.796875 },\n { x: 0.640625, y: 0.796875 },\n { x: 0.671875, y: 0.796875 },\n { x: 0.671875, y: 0.796875 },\n { x: 0.703125, y: 0.796875 },\n { x: 0.703125, y: 0.796875 },\n { x: 0.734375, y: 0.796875 },\n { x: 0.734375, y: 0.796875 },\n { x: 0.765625, y: 0.796875 },\n { x: 0.765625, y: 0.796875 },\n { x: 0.796875, y: 0.796875 },\n { x: 0.796875, y: 0.796875 },\n { x: 0.828125, y: 0.796875 },\n { x: 0.828125, y: 0.796875 },\n { x: 0.859375, y: 0.796875 },\n { x: 0.859375, y: 0.796875 },\n { x: 0.890625, y: 0.796875 },\n { x: 0.890625, y: 0.796875 },\n { x: 0.921875, y: 0.796875 },\n { x: 0.921875, y: 0.796875 },\n { x: 0.953125, y: 0.796875 },\n { x: 0.953125, y: 0.796875 },\n { x: 0.984375, y: 0.796875 },\n { x: 0.984375, y: 0.796875 },\n { x: 0.015625, y: 0.828125 },\n { x: 0.015625, y: 0.828125 },\n { x: 0.046875, y: 0.828125 },\n { x: 0.046875, y: 0.828125 },\n { x: 0.078125, y: 0.828125 },\n { x: 0.078125, y: 0.828125 },\n { x: 0.109375, y: 0.828125 },\n { x: 0.109375, y: 0.828125 },\n { x: 0.140625, y: 0.828125 },\n { x: 0.140625, y: 0.828125 },\n { x: 0.171875, y: 0.828125 },\n { x: 0.171875, y: 0.828125 },\n { x: 0.203125, y: 0.828125 },\n { x: 0.203125, y: 0.828125 },\n { x: 0.234375, y: 0.828125 },\n { x: 0.234375, y: 0.828125 },\n { x: 0.265625, y: 0.828125 },\n { x: 0.265625, y: 0.828125 },\n { x: 0.296875, y: 0.828125 },\n { x: 0.296875, y: 0.828125 },\n { x: 0.328125, y: 0.828125 },\n { x: 0.328125, y: 0.828125 },\n { x: 0.359375, y: 0.828125 },\n { x: 0.359375, y: 0.828125 },\n { x: 0.390625, y: 0.828125 },\n { x: 0.390625, y: 0.828125 },\n { x: 0.421875, y: 0.828125 },\n { x: 0.421875, y: 0.828125 },\n { x: 0.453125, y: 0.828125 },\n { x: 0.453125, y: 0.828125 },\n { x: 0.484375, y: 0.828125 },\n { x: 0.484375, y: 0.828125 },\n { x: 0.515625, y: 0.828125 },\n { x: 0.515625, y: 0.828125 },\n { x: 0.546875, y: 0.828125 },\n { x: 0.546875, y: 0.828125 },\n { x: 0.578125, y: 0.828125 },\n { x: 0.578125, y: 0.828125 },\n { x: 0.609375, y: 0.828125 },\n { x: 0.609375, y: 0.828125 },\n { x: 0.640625, y: 0.828125 },\n { x: 0.640625, y: 0.828125 },\n { x: 0.671875, y: 0.828125 },\n { x: 0.671875, y: 0.828125 },\n { x: 0.703125, y: 0.828125 },\n { x: 0.703125, y: 0.828125 },\n { x: 0.734375, y: 0.828125 },\n { x: 0.734375, y: 0.828125 },\n { x: 0.765625, y: 0.828125 },\n { x: 0.765625, y: 0.828125 },\n { x: 0.796875, y: 0.828125 },\n { x: 0.796875, y: 0.828125 },\n { x: 0.828125, y: 0.828125 },\n { x: 0.828125, y: 0.828125 },\n { x: 0.859375, y: 0.828125 },\n { x: 0.859375, y: 0.828125 },\n { x: 0.890625, y: 0.828125 },\n { x: 0.890625, y: 0.828125 },\n { x: 0.921875, y: 0.828125 },\n { x: 0.921875, y: 0.828125 },\n { x: 0.953125, y: 0.828125 },\n { x: 0.953125, y: 0.828125 },\n { x: 0.984375, y: 0.828125 },\n { x: 0.984375, y: 0.828125 },\n { x: 0.015625, y: 0.859375 },\n { x: 0.015625, y: 0.859375 },\n { x: 0.046875, y: 0.859375 },\n { x: 0.046875, y: 0.859375 },\n { x: 0.078125, y: 0.859375 },\n { x: 0.078125, y: 0.859375 },\n { x: 0.109375, y: 0.859375 },\n { x: 0.109375, y: 0.859375 },\n { x: 0.140625, y: 0.859375 },\n { x: 0.140625, y: 0.859375 },\n { x: 0.171875, y: 0.859375 },\n { x: 0.171875, y: 0.859375 },\n { x: 0.203125, y: 0.859375 },\n { x: 0.203125, y: 0.859375 },\n { x: 0.234375, y: 0.859375 },\n { x: 0.234375, y: 0.859375 },\n { x: 0.265625, y: 0.859375 },\n { x: 0.265625, y: 0.859375 },\n { x: 0.296875, y: 0.859375 },\n { x: 0.296875, y: 0.859375 },\n { x: 0.328125, y: 0.859375 },\n { x: 0.328125, y: 0.859375 },\n { x: 0.359375, y: 0.859375 },\n { x: 0.359375, y: 0.859375 },\n { x: 0.390625, y: 0.859375 },\n { x: 0.390625, y: 0.859375 },\n { x: 0.421875, y: 0.859375 },\n { x: 0.421875, y: 0.859375 },\n { x: 0.453125, y: 0.859375 },\n { x: 0.453125, y: 0.859375 },\n { x: 0.484375, y: 0.859375 },\n { x: 0.484375, y: 0.859375 },\n { x: 0.515625, y: 0.859375 },\n { x: 0.515625, y: 0.859375 },\n { x: 0.546875, y: 0.859375 },\n { x: 0.546875, y: 0.859375 },\n { x: 0.578125, y: 0.859375 },\n { x: 0.578125, y: 0.859375 },\n { x: 0.609375, y: 0.859375 },\n { x: 0.609375, y: 0.859375 },\n { x: 0.640625, y: 0.859375 },\n { x: 0.640625, y: 0.859375 },\n { x: 0.671875, y: 0.859375 },\n { x: 0.671875, y: 0.859375 },\n { x: 0.703125, y: 0.859375 },\n { x: 0.703125, y: 0.859375 },\n { x: 0.734375, y: 0.859375 },\n { x: 0.734375, y: 0.859375 },\n { x: 0.765625, y: 0.859375 },\n { x: 0.765625, y: 0.859375 },\n { x: 0.796875, y: 0.859375 },\n { x: 0.796875, y: 0.859375 },\n { x: 0.828125, y: 0.859375 },\n { x: 0.828125, y: 0.859375 },\n { x: 0.859375, y: 0.859375 },\n { x: 0.859375, y: 0.859375 },\n { x: 0.890625, y: 0.859375 },\n { x: 0.890625, y: 0.859375 },\n { x: 0.921875, y: 0.859375 },\n { x: 0.921875, y: 0.859375 },\n { x: 0.953125, y: 0.859375 },\n { x: 0.953125, y: 0.859375 },\n { x: 0.984375, y: 0.859375 },\n { x: 0.984375, y: 0.859375 },\n { x: 0.015625, y: 0.890625 },\n { x: 0.015625, y: 0.890625 },\n { x: 0.046875, y: 0.890625 },\n { x: 0.046875, y: 0.890625 },\n { x: 0.078125, y: 0.890625 },\n { x: 0.078125, y: 0.890625 },\n { x: 0.109375, y: 0.890625 },\n { x: 0.109375, y: 0.890625 },\n { x: 0.140625, y: 0.890625 },\n { x: 0.140625, y: 0.890625 },\n { x: 0.171875, y: 0.890625 },\n { x: 0.171875, y: 0.890625 },\n { x: 0.203125, y: 0.890625 },\n { x: 0.203125, y: 0.890625 },\n { x: 0.234375, y: 0.890625 },\n { x: 0.234375, y: 0.890625 },\n { x: 0.265625, y: 0.890625 },\n { x: 0.265625, y: 0.890625 },\n { x: 0.296875, y: 0.890625 },\n { x: 0.296875, y: 0.890625 },\n { x: 0.328125, y: 0.890625 },\n { x: 0.328125, y: 0.890625 },\n { x: 0.359375, y: 0.890625 },\n { x: 0.359375, y: 0.890625 },\n { x: 0.390625, y: 0.890625 },\n { x: 0.390625, y: 0.890625 },\n { x: 0.421875, y: 0.890625 },\n { x: 0.421875, y: 0.890625 },\n { x: 0.453125, y: 0.890625 },\n { x: 0.453125, y: 0.890625 },\n { x: 0.484375, y: 0.890625 },\n { x: 0.484375, y: 0.890625 },\n { x: 0.515625, y: 0.890625 },\n { x: 0.515625, y: 0.890625 },\n { x: 0.546875, y: 0.890625 },\n { x: 0.546875, y: 0.890625 },\n { x: 0.578125, y: 0.890625 },\n { x: 0.578125, y: 0.890625 },\n { x: 0.609375, y: 0.890625 },\n { x: 0.609375, y: 0.890625 },\n { x: 0.640625, y: 0.890625 },\n { x: 0.640625, y: 0.890625 },\n { x: 0.671875, y: 0.890625 },\n { x: 0.671875, y: 0.890625 },\n { x: 0.703125, y: 0.890625 },\n { x: 0.703125, y: 0.890625 },\n { x: 0.734375, y: 0.890625 },\n { x: 0.734375, y: 0.890625 },\n { x: 0.765625, y: 0.890625 },\n { x: 0.765625, y: 0.890625 },\n { x: 0.796875, y: 0.890625 },\n { x: 0.796875, y: 0.890625 },\n { x: 0.828125, y: 0.890625 },\n { x: 0.828125, y: 0.890625 },\n { x: 0.859375, y: 0.890625 },\n { x: 0.859375, y: 0.890625 },\n { x: 0.890625, y: 0.890625 },\n { x: 0.890625, y: 0.890625 },\n { x: 0.921875, y: 0.890625 },\n { x: 0.921875, y: 0.890625 },\n { x: 0.953125, y: 0.890625 },\n { x: 0.953125, y: 0.890625 },\n { x: 0.984375, y: 0.890625 },\n { x: 0.984375, y: 0.890625 },\n { x: 0.015625, y: 0.921875 },\n { x: 0.015625, y: 0.921875 },\n { x: 0.046875, y: 0.921875 },\n { x: 0.046875, y: 0.921875 },\n { x: 0.078125, y: 0.921875 },\n { x: 0.078125, y: 0.921875 },\n { x: 0.109375, y: 0.921875 },\n { x: 0.109375, y: 0.921875 },\n { x: 0.140625, y: 0.921875 },\n { x: 0.140625, y: 0.921875 },\n { x: 0.171875, y: 0.921875 },\n { x: 0.171875, y: 0.921875 },\n { x: 0.203125, y: 0.921875 },\n { x: 0.203125, y: 0.921875 },\n { x: 0.234375, y: 0.921875 },\n { x: 0.234375, y: 0.921875 },\n { x: 0.265625, y: 0.921875 },\n { x: 0.265625, y: 0.921875 },\n { x: 0.296875, y: 0.921875 },\n { x: 0.296875, y: 0.921875 },\n { x: 0.328125, y: 0.921875 },\n { x: 0.328125, y: 0.921875 },\n { x: 0.359375, y: 0.921875 },\n { x: 0.359375, y: 0.921875 },\n { x: 0.390625, y: 0.921875 },\n { x: 0.390625, y: 0.921875 },\n { x: 0.421875, y: 0.921875 },\n { x: 0.421875, y: 0.921875 },\n { x: 0.453125, y: 0.921875 },\n { x: 0.453125, y: 0.921875 },\n { x: 0.484375, y: 0.921875 },\n { x: 0.484375, y: 0.921875 },\n { x: 0.515625, y: 0.921875 },\n { x: 0.515625, y: 0.921875 },\n { x: 0.546875, y: 0.921875 },\n { x: 0.546875, y: 0.921875 },\n { x: 0.578125, y: 0.921875 },\n { x: 0.578125, y: 0.921875 },\n { x: 0.609375, y: 0.921875 },\n { x: 0.609375, y: 0.921875 },\n { x: 0.640625, y: 0.921875 },\n { x: 0.640625, y: 0.921875 },\n { x: 0.671875, y: 0.921875 },\n { x: 0.671875, y: 0.921875 },\n { x: 0.703125, y: 0.921875 },\n { x: 0.703125, y: 0.921875 },\n { x: 0.734375, y: 0.921875 },\n { x: 0.734375, y: 0.921875 },\n { x: 0.765625, y: 0.921875 },\n { x: 0.765625, y: 0.921875 },\n { x: 0.796875, y: 0.921875 },\n { x: 0.796875, y: 0.921875 },\n { x: 0.828125, y: 0.921875 },\n { x: 0.828125, y: 0.921875 },\n { x: 0.859375, y: 0.921875 },\n { x: 0.859375, y: 0.921875 },\n { x: 0.890625, y: 0.921875 },\n { x: 0.890625, y: 0.921875 },\n { x: 0.921875, y: 0.921875 },\n { x: 0.921875, y: 0.921875 },\n { x: 0.953125, y: 0.921875 },\n { x: 0.953125, y: 0.921875 },\n { x: 0.984375, y: 0.921875 },\n { x: 0.984375, y: 0.921875 },\n { x: 0.015625, y: 0.953125 },\n { x: 0.015625, y: 0.953125 },\n { x: 0.046875, y: 0.953125 },\n { x: 0.046875, y: 0.953125 },\n { x: 0.078125, y: 0.953125 },\n { x: 0.078125, y: 0.953125 },\n { x: 0.109375, y: 0.953125 },\n { x: 0.109375, y: 0.953125 },\n { x: 0.140625, y: 0.953125 },\n { x: 0.140625, y: 0.953125 },\n { x: 0.171875, y: 0.953125 },\n { x: 0.171875, y: 0.953125 },\n { x: 0.203125, y: 0.953125 },\n { x: 0.203125, y: 0.953125 },\n { x: 0.234375, y: 0.953125 },\n { x: 0.234375, y: 0.953125 },\n { x: 0.265625, y: 0.953125 },\n { x: 0.265625, y: 0.953125 },\n { x: 0.296875, y: 0.953125 },\n { x: 0.296875, y: 0.953125 },\n { x: 0.328125, y: 0.953125 },\n { x: 0.328125, y: 0.953125 },\n { x: 0.359375, y: 0.953125 },\n { x: 0.359375, y: 0.953125 },\n { x: 0.390625, y: 0.953125 },\n { x: 0.390625, y: 0.953125 },\n { x: 0.421875, y: 0.953125 },\n { x: 0.421875, y: 0.953125 },\n { x: 0.453125, y: 0.953125 },\n { x: 0.453125, y: 0.953125 },\n { x: 0.484375, y: 0.953125 },\n { x: 0.484375, y: 0.953125 },\n { x: 0.515625, y: 0.953125 },\n { x: 0.515625, y: 0.953125 },\n { x: 0.546875, y: 0.953125 },\n { x: 0.546875, y: 0.953125 },\n { x: 0.578125, y: 0.953125 },\n { x: 0.578125, y: 0.953125 },\n { x: 0.609375, y: 0.953125 },\n { x: 0.609375, y: 0.953125 },\n { x: 0.640625, y: 0.953125 },\n { x: 0.640625, y: 0.953125 },\n { x: 0.671875, y: 0.953125 },\n { x: 0.671875, y: 0.953125 },\n { x: 0.703125, y: 0.953125 },\n { x: 0.703125, y: 0.953125 },\n { x: 0.734375, y: 0.953125 },\n { x: 0.734375, y: 0.953125 },\n { x: 0.765625, y: 0.953125 },\n { x: 0.765625, y: 0.953125 },\n { x: 0.796875, y: 0.953125 },\n { x: 0.796875, y: 0.953125 },\n { x: 0.828125, y: 0.953125 },\n { x: 0.828125, y: 0.953125 },\n { x: 0.859375, y: 0.953125 },\n { x: 0.859375, y: 0.953125 },\n { x: 0.890625, y: 0.953125 },\n { x: 0.890625, y: 0.953125 },\n { x: 0.921875, y: 0.953125 },\n { x: 0.921875, y: 0.953125 },\n { x: 0.953125, y: 0.953125 },\n { x: 0.953125, y: 0.953125 },\n { x: 0.984375, y: 0.953125 },\n { x: 0.984375, y: 0.953125 },\n { x: 0.015625, y: 0.984375 },\n { x: 0.015625, y: 0.984375 },\n { x: 0.046875, y: 0.984375 },\n { x: 0.046875, y: 0.984375 },\n { x: 0.078125, y: 0.984375 },\n { x: 0.078125, y: 0.984375 },\n { x: 0.109375, y: 0.984375 },\n { x: 0.109375, y: 0.984375 },\n { x: 0.140625, y: 0.984375 },\n { x: 0.140625, y: 0.984375 },\n { x: 0.171875, y: 0.984375 },\n { x: 0.171875, y: 0.984375 },\n { x: 0.203125, y: 0.984375 },\n { x: 0.203125, y: 0.984375 },\n { x: 0.234375, y: 0.984375 },\n { x: 0.234375, y: 0.984375 },\n { x: 0.265625, y: 0.984375 },\n { x: 0.265625, y: 0.984375 },\n { x: 0.296875, y: 0.984375 },\n { x: 0.296875, y: 0.984375 },\n { x: 0.328125, y: 0.984375 },\n { x: 0.328125, y: 0.984375 },\n { x: 0.359375, y: 0.984375 },\n { x: 0.359375, y: 0.984375 },\n { x: 0.390625, y: 0.984375 },\n { x: 0.390625, y: 0.984375 },\n { x: 0.421875, y: 0.984375 },\n { x: 0.421875, y: 0.984375 },\n { x: 0.453125, y: 0.984375 },\n { x: 0.453125, y: 0.984375 },\n { x: 0.484375, y: 0.984375 },\n { x: 0.484375, y: 0.984375 },\n { x: 0.515625, y: 0.984375 },\n { x: 0.515625, y: 0.984375 },\n { x: 0.546875, y: 0.984375 },\n { x: 0.546875, y: 0.984375 },\n { x: 0.578125, y: 0.984375 },\n { x: 0.578125, y: 0.984375 },\n { x: 0.609375, y: 0.984375 },\n { x: 0.609375, y: 0.984375 },\n { x: 0.640625, y: 0.984375 },\n { x: 0.640625, y: 0.984375 },\n { x: 0.671875, y: 0.984375 },\n { x: 0.671875, y: 0.984375 },\n { x: 0.703125, y: 0.984375 },\n { x: 0.703125, y: 0.984375 },\n { x: 0.734375, y: 0.984375 },\n { x: 0.734375, y: 0.984375 },\n { x: 0.765625, y: 0.984375 },\n { x: 0.765625, y: 0.984375 },\n { x: 0.796875, y: 0.984375 },\n { x: 0.796875, y: 0.984375 },\n { x: 0.828125, y: 0.984375 },\n { x: 0.828125, y: 0.984375 },\n { x: 0.859375, y: 0.984375 },\n { x: 0.859375, y: 0.984375 },\n { x: 0.890625, y: 0.984375 },\n { x: 0.890625, y: 0.984375 },\n { x: 0.921875, y: 0.984375 },\n { x: 0.921875, y: 0.984375 },\n { x: 0.953125, y: 0.984375 },\n { x: 0.953125, y: 0.984375 },\n { x: 0.984375, y: 0.984375 },\n { x: 0.984375, y: 0.984375 },\n { x: 0.03125, y: 0.03125 },\n { x: 0.03125, y: 0.03125 },\n { x: 0.09375, y: 0.03125 },\n { x: 0.09375, y: 0.03125 },\n { x: 0.15625, y: 0.03125 },\n { x: 0.15625, y: 0.03125 },\n { x: 0.21875, y: 0.03125 },\n { x: 0.21875, y: 0.03125 },\n { x: 0.28125, y: 0.03125 },\n { x: 0.28125, y: 0.03125 },\n { x: 0.34375, y: 0.03125 },\n { x: 0.34375, y: 0.03125 },\n { x: 0.40625, y: 0.03125 },\n { x: 0.40625, y: 0.03125 },\n { x: 0.46875, y: 0.03125 },\n { x: 0.46875, y: 0.03125 },\n { x: 0.53125, y: 0.03125 },\n { x: 0.53125, y: 0.03125 },\n { x: 0.59375, y: 0.03125 },\n { x: 0.59375, y: 0.03125 },\n { x: 0.65625, y: 0.03125 },\n { x: 0.65625, y: 0.03125 },\n { x: 0.71875, y: 0.03125 },\n { x: 0.71875, y: 0.03125 },\n { x: 0.78125, y: 0.03125 },\n { x: 0.78125, y: 0.03125 },\n { x: 0.84375, y: 0.03125 },\n { x: 0.84375, y: 0.03125 },\n { x: 0.90625, y: 0.03125 },\n { x: 0.90625, y: 0.03125 },\n { x: 0.96875, y: 0.03125 },\n { x: 0.96875, y: 0.03125 },\n { x: 0.03125, y: 0.09375 },\n { x: 0.03125, y: 0.09375 },\n { x: 0.09375, y: 0.09375 },\n { x: 0.09375, y: 0.09375 },\n { x: 0.15625, y: 0.09375 },\n { x: 0.15625, y: 0.09375 },\n { x: 0.21875, y: 0.09375 },\n { x: 0.21875, y: 0.09375 },\n { x: 0.28125, y: 0.09375 },\n { x: 0.28125, y: 0.09375 },\n { x: 0.34375, y: 0.09375 },\n { x: 0.34375, y: 0.09375 },\n { x: 0.40625, y: 0.09375 },\n { x: 0.40625, y: 0.09375 },\n { x: 0.46875, y: 0.09375 },\n { x: 0.46875, y: 0.09375 },\n { x: 0.53125, y: 0.09375 },\n { x: 0.53125, y: 0.09375 },\n { x: 0.59375, y: 0.09375 },\n { x: 0.59375, y: 0.09375 },\n { x: 0.65625, y: 0.09375 },\n { x: 0.65625, y: 0.09375 },\n { x: 0.71875, y: 0.09375 },\n { x: 0.71875, y: 0.09375 },\n { x: 0.78125, y: 0.09375 },\n { x: 0.78125, y: 0.09375 },\n { x: 0.84375, y: 0.09375 },\n { x: 0.84375, y: 0.09375 },\n { x: 0.90625, y: 0.09375 },\n { x: 0.90625, y: 0.09375 },\n { x: 0.96875, y: 0.09375 },\n { x: 0.96875, y: 0.09375 },\n { x: 0.03125, y: 0.15625 },\n { x: 0.03125, y: 0.15625 },\n { x: 0.09375, y: 0.15625 },\n { x: 0.09375, y: 0.15625 },\n { x: 0.15625, y: 0.15625 },\n { x: 0.15625, y: 0.15625 },\n { x: 0.21875, y: 0.15625 },\n { x: 0.21875, y: 0.15625 },\n { x: 0.28125, y: 0.15625 },\n { x: 0.28125, y: 0.15625 },\n { x: 0.34375, y: 0.15625 },\n { x: 0.34375, y: 0.15625 },\n { x: 0.40625, y: 0.15625 },\n { x: 0.40625, y: 0.15625 },\n { x: 0.46875, y: 0.15625 },\n { x: 0.46875, y: 0.15625 },\n { x: 0.53125, y: 0.15625 },\n { x: 0.53125, y: 0.15625 },\n { x: 0.59375, y: 0.15625 },\n { x: 0.59375, y: 0.15625 },\n { x: 0.65625, y: 0.15625 },\n { x: 0.65625, y: 0.15625 },\n { x: 0.71875, y: 0.15625 },\n { x: 0.71875, y: 0.15625 },\n { x: 0.78125, y: 0.15625 },\n { x: 0.78125, y: 0.15625 },\n { x: 0.84375, y: 0.15625 },\n { x: 0.84375, y: 0.15625 },\n { x: 0.90625, y: 0.15625 },\n { x: 0.90625, y: 0.15625 },\n { x: 0.96875, y: 0.15625 },\n { x: 0.96875, y: 0.15625 },\n { x: 0.03125, y: 0.21875 },\n { x: 0.03125, y: 0.21875 },\n { x: 0.09375, y: 0.21875 },\n { x: 0.09375, y: 0.21875 },\n { x: 0.15625, y: 0.21875 },\n { x: 0.15625, y: 0.21875 },\n { x: 0.21875, y: 0.21875 },\n { x: 0.21875, y: 0.21875 },\n { x: 0.28125, y: 0.21875 },\n { x: 0.28125, y: 0.21875 },\n { x: 0.34375, y: 0.21875 },\n { x: 0.34375, y: 0.21875 },\n { x: 0.40625, y: 0.21875 },\n { x: 0.40625, y: 0.21875 },\n { x: 0.46875, y: 0.21875 },\n { x: 0.46875, y: 0.21875 },\n { x: 0.53125, y: 0.21875 },\n { x: 0.53125, y: 0.21875 },\n { x: 0.59375, y: 0.21875 },\n { x: 0.59375, y: 0.21875 },\n { x: 0.65625, y: 0.21875 },\n { x: 0.65625, y: 0.21875 },\n { x: 0.71875, y: 0.21875 },\n { x: 0.71875, y: 0.21875 },\n { x: 0.78125, y: 0.21875 },\n { x: 0.78125, y: 0.21875 },\n { x: 0.84375, y: 0.21875 },\n { x: 0.84375, y: 0.21875 },\n { x: 0.90625, y: 0.21875 },\n { x: 0.90625, y: 0.21875 },\n { x: 0.96875, y: 0.21875 },\n { x: 0.96875, y: 0.21875 },\n { x: 0.03125, y: 0.28125 },\n { x: 0.03125, y: 0.28125 },\n { x: 0.09375, y: 0.28125 },\n { x: 0.09375, y: 0.28125 },\n { x: 0.15625, y: 0.28125 },\n { x: 0.15625, y: 0.28125 },\n { x: 0.21875, y: 0.28125 },\n { x: 0.21875, y: 0.28125 },\n { x: 0.28125, y: 0.28125 },\n { x: 0.28125, y: 0.28125 },\n { x: 0.34375, y: 0.28125 },\n { x: 0.34375, y: 0.28125 },\n { x: 0.40625, y: 0.28125 },\n { x: 0.40625, y: 0.28125 },\n { x: 0.46875, y: 0.28125 },\n { x: 0.46875, y: 0.28125 },\n { x: 0.53125, y: 0.28125 },\n { x: 0.53125, y: 0.28125 },\n { x: 0.59375, y: 0.28125 },\n { x: 0.59375, y: 0.28125 },\n { x: 0.65625, y: 0.28125 },\n { x: 0.65625, y: 0.28125 },\n { x: 0.71875, y: 0.28125 },\n { x: 0.71875, y: 0.28125 },\n { x: 0.78125, y: 0.28125 },\n { x: 0.78125, y: 0.28125 },\n { x: 0.84375, y: 0.28125 },\n { x: 0.84375, y: 0.28125 },\n { x: 0.90625, y: 0.28125 },\n { x: 0.90625, y: 0.28125 },\n { x: 0.96875, y: 0.28125 },\n { x: 0.96875, y: 0.28125 },\n { x: 0.03125, y: 0.34375 },\n { x: 0.03125, y: 0.34375 },\n { x: 0.09375, y: 0.34375 },\n { x: 0.09375, y: 0.34375 },\n { x: 0.15625, y: 0.34375 },\n { x: 0.15625, y: 0.34375 },\n { x: 0.21875, y: 0.34375 },\n { x: 0.21875, y: 0.34375 },\n { x: 0.28125, y: 0.34375 },\n { x: 0.28125, y: 0.34375 },\n { x: 0.34375, y: 0.34375 },\n { x: 0.34375, y: 0.34375 },\n { x: 0.40625, y: 0.34375 },\n { x: 0.40625, y: 0.34375 },\n { x: 0.46875, y: 0.34375 },\n { x: 0.46875, y: 0.34375 },\n { x: 0.53125, y: 0.34375 },\n { x: 0.53125, y: 0.34375 },\n { x: 0.59375, y: 0.34375 },\n { x: 0.59375, y: 0.34375 },\n { x: 0.65625, y: 0.34375 },\n { x: 0.65625, y: 0.34375 },\n { x: 0.71875, y: 0.34375 },\n { x: 0.71875, y: 0.34375 },\n { x: 0.78125, y: 0.34375 },\n { x: 0.78125, y: 0.34375 },\n { x: 0.84375, y: 0.34375 },\n { x: 0.84375, y: 0.34375 },\n { x: 0.90625, y: 0.34375 },\n { x: 0.90625, y: 0.34375 },\n { x: 0.96875, y: 0.34375 },\n { x: 0.96875, y: 0.34375 },\n { x: 0.03125, y: 0.40625 },\n { x: 0.03125, y: 0.40625 },\n { x: 0.09375, y: 0.40625 },\n { x: 0.09375, y: 0.40625 },\n { x: 0.15625, y: 0.40625 },\n { x: 0.15625, y: 0.40625 },\n { x: 0.21875, y: 0.40625 },\n { x: 0.21875, y: 0.40625 },\n { x: 0.28125, y: 0.40625 },\n { x: 0.28125, y: 0.40625 },\n { x: 0.34375, y: 0.40625 },\n { x: 0.34375, y: 0.40625 },\n { x: 0.40625, y: 0.40625 },\n { x: 0.40625, y: 0.40625 },\n { x: 0.46875, y: 0.40625 },\n { x: 0.46875, y: 0.40625 },\n { x: 0.53125, y: 0.40625 },\n { x: 0.53125, y: 0.40625 },\n { x: 0.59375, y: 0.40625 },\n { x: 0.59375, y: 0.40625 },\n { x: 0.65625, y: 0.40625 },\n { x: 0.65625, y: 0.40625 },\n { x: 0.71875, y: 0.40625 },\n { x: 0.71875, y: 0.40625 },\n { x: 0.78125, y: 0.40625 },\n { x: 0.78125, y: 0.40625 },\n { x: 0.84375, y: 0.40625 },\n { x: 0.84375, y: 0.40625 },\n { x: 0.90625, y: 0.40625 },\n { x: 0.90625, y: 0.40625 },\n { x: 0.96875, y: 0.40625 },\n { x: 0.96875, y: 0.40625 },\n { x: 0.03125, y: 0.46875 },\n { x: 0.03125, y: 0.46875 },\n { x: 0.09375, y: 0.46875 },\n { x: 0.09375, y: 0.46875 },\n { x: 0.15625, y: 0.46875 },\n { x: 0.15625, y: 0.46875 },\n { x: 0.21875, y: 0.46875 },\n { x: 0.21875, y: 0.46875 },\n { x: 0.28125, y: 0.46875 },\n { x: 0.28125, y: 0.46875 },\n { x: 0.34375, y: 0.46875 },\n { x: 0.34375, y: 0.46875 },\n { x: 0.40625, y: 0.46875 },\n { x: 0.40625, y: 0.46875 },\n { x: 0.46875, y: 0.46875 },\n { x: 0.46875, y: 0.46875 },\n { x: 0.53125, y: 0.46875 },\n { x: 0.53125, y: 0.46875 },\n { x: 0.59375, y: 0.46875 },\n { x: 0.59375, y: 0.46875 },\n { x: 0.65625, y: 0.46875 },\n { x: 0.65625, y: 0.46875 },\n { x: 0.71875, y: 0.46875 },\n { x: 0.71875, y: 0.46875 },\n { x: 0.78125, y: 0.46875 },\n { x: 0.78125, y: 0.46875 },\n { x: 0.84375, y: 0.46875 },\n { x: 0.84375, y: 0.46875 },\n { x: 0.90625, y: 0.46875 },\n { x: 0.90625, y: 0.46875 },\n { x: 0.96875, y: 0.46875 },\n { x: 0.96875, y: 0.46875 },\n { x: 0.03125, y: 0.53125 },\n { x: 0.03125, y: 0.53125 },\n { x: 0.09375, y: 0.53125 },\n { x: 0.09375, y: 0.53125 },\n { x: 0.15625, y: 0.53125 },\n { x: 0.15625, y: 0.53125 },\n { x: 0.21875, y: 0.53125 },\n { x: 0.21875, y: 0.53125 },\n { x: 0.28125, y: 0.53125 },\n { x: 0.28125, y: 0.53125 },\n { x: 0.34375, y: 0.53125 },\n { x: 0.34375, y: 0.53125 },\n { x: 0.40625, y: 0.53125 },\n { x: 0.40625, y: 0.53125 },\n { x: 0.46875, y: 0.53125 },\n { x: 0.46875, y: 0.53125 },\n { x: 0.53125, y: 0.53125 },\n { x: 0.53125, y: 0.53125 },\n { x: 0.59375, y: 0.53125 },\n { x: 0.59375, y: 0.53125 },\n { x: 0.65625, y: 0.53125 },\n { x: 0.65625, y: 0.53125 },\n { x: 0.71875, y: 0.53125 },\n { x: 0.71875, y: 0.53125 },\n { x: 0.78125, y: 0.53125 },\n { x: 0.78125, y: 0.53125 },\n { x: 0.84375, y: 0.53125 },\n { x: 0.84375, y: 0.53125 },\n { x: 0.90625, y: 0.53125 },\n { x: 0.90625, y: 0.53125 },\n { x: 0.96875, y: 0.53125 },\n { x: 0.96875, y: 0.53125 },\n { x: 0.03125, y: 0.59375 },\n { x: 0.03125, y: 0.59375 },\n { x: 0.09375, y: 0.59375 },\n { x: 0.09375, y: 0.59375 },\n { x: 0.15625, y: 0.59375 },\n { x: 0.15625, y: 0.59375 },\n { x: 0.21875, y: 0.59375 },\n { x: 0.21875, y: 0.59375 },\n { x: 0.28125, y: 0.59375 },\n { x: 0.28125, y: 0.59375 },\n { x: 0.34375, y: 0.59375 },\n { x: 0.34375, y: 0.59375 },\n { x: 0.40625, y: 0.59375 },\n { x: 0.40625, y: 0.59375 },\n { x: 0.46875, y: 0.59375 },\n { x: 0.46875, y: 0.59375 },\n { x: 0.53125, y: 0.59375 },\n { x: 0.53125, y: 0.59375 },\n { x: 0.59375, y: 0.59375 },\n { x: 0.59375, y: 0.59375 },\n { x: 0.65625, y: 0.59375 },\n { x: 0.65625, y: 0.59375 },\n { x: 0.71875, y: 0.59375 },\n { x: 0.71875, y: 0.59375 },\n { x: 0.78125, y: 0.59375 },\n { x: 0.78125, y: 0.59375 },\n { x: 0.84375, y: 0.59375 },\n { x: 0.84375, y: 0.59375 },\n { x: 0.90625, y: 0.59375 },\n { x: 0.90625, y: 0.59375 },\n { x: 0.96875, y: 0.59375 },\n { x: 0.96875, y: 0.59375 },\n { x: 0.03125, y: 0.65625 },\n { x: 0.03125, y: 0.65625 },\n { x: 0.09375, y: 0.65625 },\n { x: 0.09375, y: 0.65625 },\n { x: 0.15625, y: 0.65625 },\n { x: 0.15625, y: 0.65625 },\n { x: 0.21875, y: 0.65625 },\n { x: 0.21875, y: 0.65625 },\n { x: 0.28125, y: 0.65625 },\n { x: 0.28125, y: 0.65625 },\n { x: 0.34375, y: 0.65625 },\n { x: 0.34375, y: 0.65625 },\n { x: 0.40625, y: 0.65625 },\n { x: 0.40625, y: 0.65625 },\n { x: 0.46875, y: 0.65625 },\n { x: 0.46875, y: 0.65625 },\n { x: 0.53125, y: 0.65625 },\n { x: 0.53125, y: 0.65625 },\n { x: 0.59375, y: 0.65625 },\n { x: 0.59375, y: 0.65625 },\n { x: 0.65625, y: 0.65625 },\n { x: 0.65625, y: 0.65625 },\n { x: 0.71875, y: 0.65625 },\n { x: 0.71875, y: 0.65625 },\n { x: 0.78125, y: 0.65625 },\n { x: 0.78125, y: 0.65625 },\n { x: 0.84375, y: 0.65625 },\n { x: 0.84375, y: 0.65625 },\n { x: 0.90625, y: 0.65625 },\n { x: 0.90625, y: 0.65625 },\n { x: 0.96875, y: 0.65625 },\n { x: 0.96875, y: 0.65625 },\n { x: 0.03125, y: 0.71875 },\n { x: 0.03125, y: 0.71875 },\n { x: 0.09375, y: 0.71875 },\n { x: 0.09375, y: 0.71875 },\n { x: 0.15625, y: 0.71875 },\n { x: 0.15625, y: 0.71875 },\n { x: 0.21875, y: 0.71875 },\n { x: 0.21875, y: 0.71875 },\n { x: 0.28125, y: 0.71875 },\n { x: 0.28125, y: 0.71875 },\n { x: 0.34375, y: 0.71875 },\n { x: 0.34375, y: 0.71875 },\n { x: 0.40625, y: 0.71875 },\n { x: 0.40625, y: 0.71875 },\n { x: 0.46875, y: 0.71875 },\n { x: 0.46875, y: 0.71875 },\n { x: 0.53125, y: 0.71875 },\n { x: 0.53125, y: 0.71875 },\n { x: 0.59375, y: 0.71875 },\n { x: 0.59375, y: 0.71875 },\n { x: 0.65625, y: 0.71875 },\n { x: 0.65625, y: 0.71875 },\n { x: 0.71875, y: 0.71875 },\n { x: 0.71875, y: 0.71875 },\n { x: 0.78125, y: 0.71875 },\n { x: 0.78125, y: 0.71875 },\n { x: 0.84375, y: 0.71875 },\n { x: 0.84375, y: 0.71875 },\n { x: 0.90625, y: 0.71875 },\n { x: 0.90625, y: 0.71875 },\n { x: 0.96875, y: 0.71875 },\n { x: 0.96875, y: 0.71875 },\n { x: 0.03125, y: 0.78125 },\n { x: 0.03125, y: 0.78125 },\n { x: 0.09375, y: 0.78125 },\n { x: 0.09375, y: 0.78125 },\n { x: 0.15625, y: 0.78125 },\n { x: 0.15625, y: 0.78125 },\n { x: 0.21875, y: 0.78125 },\n { x: 0.21875, y: 0.78125 },\n { x: 0.28125, y: 0.78125 },\n { x: 0.28125, y: 0.78125 },\n { x: 0.34375, y: 0.78125 },\n { x: 0.34375, y: 0.78125 },\n { x: 0.40625, y: 0.78125 },\n { x: 0.40625, y: 0.78125 },\n { x: 0.46875, y: 0.78125 },\n { x: 0.46875, y: 0.78125 },\n { x: 0.53125, y: 0.78125 },\n { x: 0.53125, y: 0.78125 },\n { x: 0.59375, y: 0.78125 },\n { x: 0.59375, y: 0.78125 },\n { x: 0.65625, y: 0.78125 },\n { x: 0.65625, y: 0.78125 },\n { x: 0.71875, y: 0.78125 },\n { x: 0.71875, y: 0.78125 },\n { x: 0.78125, y: 0.78125 },\n { x: 0.78125, y: 0.78125 },\n { x: 0.84375, y: 0.78125 },\n { x: 0.84375, y: 0.78125 },\n { x: 0.90625, y: 0.78125 },\n { x: 0.90625, y: 0.78125 },\n { x: 0.96875, y: 0.78125 },\n { x: 0.96875, y: 0.78125 },\n { x: 0.03125, y: 0.84375 },\n { x: 0.03125, y: 0.84375 },\n { x: 0.09375, y: 0.84375 },\n { x: 0.09375, y: 0.84375 },\n { x: 0.15625, y: 0.84375 },\n { x: 0.15625, y: 0.84375 },\n { x: 0.21875, y: 0.84375 },\n { x: 0.21875, y: 0.84375 },\n { x: 0.28125, y: 0.84375 },\n { x: 0.28125, y: 0.84375 },\n { x: 0.34375, y: 0.84375 },\n { x: 0.34375, y: 0.84375 },\n { x: 0.40625, y: 0.84375 },\n { x: 0.40625, y: 0.84375 },\n { x: 0.46875, y: 0.84375 },\n { x: 0.46875, y: 0.84375 },\n { x: 0.53125, y: 0.84375 },\n { x: 0.53125, y: 0.84375 },\n { x: 0.59375, y: 0.84375 },\n { x: 0.59375, y: 0.84375 },\n { x: 0.65625, y: 0.84375 },\n { x: 0.65625, y: 0.84375 },\n { x: 0.71875, y: 0.84375 },\n { x: 0.71875, y: 0.84375 },\n { x: 0.78125, y: 0.84375 },\n { x: 0.78125, y: 0.84375 },\n { x: 0.84375, y: 0.84375 },\n { x: 0.84375, y: 0.84375 },\n { x: 0.90625, y: 0.84375 },\n { x: 0.90625, y: 0.84375 },\n { x: 0.96875, y: 0.84375 },\n { x: 0.96875, y: 0.84375 },\n { x: 0.03125, y: 0.90625 },\n { x: 0.03125, y: 0.90625 },\n { x: 0.09375, y: 0.90625 },\n { x: 0.09375, y: 0.90625 },\n { x: 0.15625, y: 0.90625 },\n { x: 0.15625, y: 0.90625 },\n { x: 0.21875, y: 0.90625 },\n { x: 0.21875, y: 0.90625 },\n { x: 0.28125, y: 0.90625 },\n { x: 0.28125, y: 0.90625 },\n { x: 0.34375, y: 0.90625 },\n { x: 0.34375, y: 0.90625 },\n { x: 0.40625, y: 0.90625 },\n { x: 0.40625, y: 0.90625 },\n { x: 0.46875, y: 0.90625 },\n { x: 0.46875, y: 0.90625 },\n { x: 0.53125, y: 0.90625 },\n { x: 0.53125, y: 0.90625 },\n { x: 0.59375, y: 0.90625 },\n { x: 0.59375, y: 0.90625 },\n { x: 0.65625, y: 0.90625 },\n { x: 0.65625, y: 0.90625 },\n { x: 0.71875, y: 0.90625 },\n { x: 0.71875, y: 0.90625 },\n { x: 0.78125, y: 0.90625 },\n { x: 0.78125, y: 0.90625 },\n { x: 0.84375, y: 0.90625 },\n { x: 0.84375, y: 0.90625 },\n { x: 0.90625, y: 0.90625 },\n { x: 0.90625, y: 0.90625 },\n { x: 0.96875, y: 0.90625 },\n { x: 0.96875, y: 0.90625 },\n { x: 0.03125, y: 0.96875 },\n { x: 0.03125, y: 0.96875 },\n { x: 0.09375, y: 0.96875 },\n { x: 0.09375, y: 0.96875 },\n { x: 0.15625, y: 0.96875 },\n { x: 0.15625, y: 0.96875 },\n { x: 0.21875, y: 0.96875 },\n { x: 0.21875, y: 0.96875 },\n { x: 0.28125, y: 0.96875 },\n { x: 0.28125, y: 0.96875 },\n { x: 0.34375, y: 0.96875 },\n { x: 0.34375, y: 0.96875 },\n { x: 0.40625, y: 0.96875 },\n { x: 0.40625, y: 0.96875 },\n { x: 0.46875, y: 0.96875 },\n { x: 0.46875, y: 0.96875 },\n { x: 0.53125, y: 0.96875 },\n { x: 0.53125, y: 0.96875 },\n { x: 0.59375, y: 0.96875 },\n { x: 0.59375, y: 0.96875 },\n { x: 0.65625, y: 0.96875 },\n { x: 0.65625, y: 0.96875 },\n { x: 0.71875, y: 0.96875 },\n { x: 0.71875, y: 0.96875 },\n { x: 0.78125, y: 0.96875 },\n { x: 0.78125, y: 0.96875 },\n { x: 0.84375, y: 0.96875 },\n { x: 0.84375, y: 0.96875 },\n { x: 0.90625, y: 0.96875 },\n { x: 0.90625, y: 0.96875 },\n { x: 0.96875, y: 0.96875 },\n { x: 0.96875, y: 0.96875 },\n { x: 0.0625, y: 0.0625 },\n { x: 0.0625, y: 0.0625 },\n { x: 0.0625, y: 0.0625 },\n { x: 0.0625, y: 0.0625 },\n { x: 0.0625, y: 0.0625 },\n { x: 0.0625, y: 0.0625 },\n { x: 0.1875, y: 0.0625 },\n { x: 0.1875, y: 0.0625 },\n { x: 0.1875, y: 0.0625 },\n { x: 0.1875, y: 0.0625 },\n { x: 0.1875, y: 0.0625 },\n { x: 0.1875, y: 0.0625 },\n { x: 0.3125, y: 0.0625 },\n { x: 0.3125, y: 0.0625 },\n { x: 0.3125, y: 0.0625 },\n { x: 0.3125, y: 0.0625 },\n { x: 0.3125, y: 0.0625 },\n { x: 0.3125, y: 0.0625 },\n { x: 0.4375, y: 0.0625 },\n { x: 0.4375, y: 0.0625 },\n { x: 0.4375, y: 0.0625 },\n { x: 0.4375, y: 0.0625 },\n { x: 0.4375, y: 0.0625 },\n { x: 0.4375, y: 0.0625 },\n { x: 0.5625, y: 0.0625 },\n { x: 0.5625, y: 0.0625 },\n { x: 0.5625, y: 0.0625 },\n { x: 0.5625, y: 0.0625 },\n { x: 0.5625, y: 0.0625 },\n { x: 0.5625, y: 0.0625 },\n { x: 0.6875, y: 0.0625 },\n { x: 0.6875, y: 0.0625 },\n { x: 0.6875, y: 0.0625 },\n { x: 0.6875, y: 0.0625 },\n { x: 0.6875, y: 0.0625 },\n { x: 0.6875, y: 0.0625 },\n { x: 0.8125, y: 0.0625 },\n { x: 0.8125, y: 0.0625 },\n { x: 0.8125, y: 0.0625 },\n { x: 0.8125, y: 0.0625 },\n { x: 0.8125, y: 0.0625 },\n { x: 0.8125, y: 0.0625 },\n { x: 0.9375, y: 0.0625 },\n { x: 0.9375, y: 0.0625 },\n { x: 0.9375, y: 0.0625 },\n { x: 0.9375, y: 0.0625 },\n { x: 0.9375, y: 0.0625 },\n { x: 0.9375, y: 0.0625 },\n { x: 0.0625, y: 0.1875 },\n { x: 0.0625, y: 0.1875 },\n { x: 0.0625, y: 0.1875 },\n { x: 0.0625, y: 0.1875 },\n { x: 0.0625, y: 0.1875 },\n { x: 0.0625, y: 0.1875 },\n { x: 0.1875, y: 0.1875 },\n { x: 0.1875, y: 0.1875 },\n { x: 0.1875, y: 0.1875 },\n { x: 0.1875, y: 0.1875 },\n { x: 0.1875, y: 0.1875 },\n { x: 0.1875, y: 0.1875 },\n { x: 0.3125, y: 0.1875 },\n { x: 0.3125, y: 0.1875 },\n { x: 0.3125, y: 0.1875 },\n { x: 0.3125, y: 0.1875 },\n { x: 0.3125, y: 0.1875 },\n { x: 0.3125, y: 0.1875 },\n { x: 0.4375, y: 0.1875 },\n { x: 0.4375, y: 0.1875 },\n { x: 0.4375, y: 0.1875 },\n { x: 0.4375, y: 0.1875 },\n { x: 0.4375, y: 0.1875 },\n { x: 0.4375, y: 0.1875 },\n { x: 0.5625, y: 0.1875 },\n { x: 0.5625, y: 0.1875 },\n { x: 0.5625, y: 0.1875 },\n { x: 0.5625, y: 0.1875 },\n { x: 0.5625, y: 0.1875 },\n { x: 0.5625, y: 0.1875 },\n { x: 0.6875, y: 0.1875 },\n { x: 0.6875, y: 0.1875 },\n { x: 0.6875, y: 0.1875 },\n { x: 0.6875, y: 0.1875 },\n { x: 0.6875, y: 0.1875 },\n { x: 0.6875, y: 0.1875 },\n { x: 0.8125, y: 0.1875 },\n { x: 0.8125, y: 0.1875 },\n { x: 0.8125, y: 0.1875 },\n { x: 0.8125, y: 0.1875 },\n { x: 0.8125, y: 0.1875 },\n { x: 0.8125, y: 0.1875 },\n { x: 0.9375, y: 0.1875 },\n { x: 0.9375, y: 0.1875 },\n { x: 0.9375, y: 0.1875 },\n { x: 0.9375, y: 0.1875 },\n { x: 0.9375, y: 0.1875 },\n { x: 0.9375, y: 0.1875 },\n { x: 0.0625, y: 0.3125 },\n { x: 0.0625, y: 0.3125 },\n { x: 0.0625, y: 0.3125 },\n { x: 0.0625, y: 0.3125 },\n { x: 0.0625, y: 0.3125 },\n { x: 0.0625, y: 0.3125 },\n { x: 0.1875, y: 0.3125 },\n { x: 0.1875, y: 0.3125 },\n { x: 0.1875, y: 0.3125 },\n { x: 0.1875, y: 0.3125 },\n { x: 0.1875, y: 0.3125 },\n { x: 0.1875, y: 0.3125 },\n { x: 0.3125, y: 0.3125 },\n { x: 0.3125, y: 0.3125 },\n { x: 0.3125, y: 0.3125 },\n { x: 0.3125, y: 0.3125 },\n { x: 0.3125, y: 0.3125 },\n { x: 0.3125, y: 0.3125 },\n { x: 0.4375, y: 0.3125 },\n { x: 0.4375, y: 0.3125 },\n { x: 0.4375, y: 0.3125 },\n { x: 0.4375, y: 0.3125 },\n { x: 0.4375, y: 0.3125 },\n { x: 0.4375, y: 0.3125 },\n { x: 0.5625, y: 0.3125 },\n { x: 0.5625, y: 0.3125 },\n { x: 0.5625, y: 0.3125 },\n { x: 0.5625, y: 0.3125 },\n { x: 0.5625, y: 0.3125 },\n { x: 0.5625, y: 0.3125 },\n { x: 0.6875, y: 0.3125 },\n { x: 0.6875, y: 0.3125 },\n { x: 0.6875, y: 0.3125 },\n { x: 0.6875, y: 0.3125 },\n { x: 0.6875, y: 0.3125 },\n { x: 0.6875, y: 0.3125 },\n { x: 0.8125, y: 0.3125 },\n { x: 0.8125, y: 0.3125 },\n { x: 0.8125, y: 0.3125 },\n { x: 0.8125, y: 0.3125 },\n { x: 0.8125, y: 0.3125 },\n { x: 0.8125, y: 0.3125 },\n { x: 0.9375, y: 0.3125 },\n { x: 0.9375, y: 0.3125 },\n { x: 0.9375, y: 0.3125 },\n { x: 0.9375, y: 0.3125 },\n { x: 0.9375, y: 0.3125 },\n { x: 0.9375, y: 0.3125 },\n { x: 0.0625, y: 0.4375 },\n { x: 0.0625, y: 0.4375 },\n { x: 0.0625, y: 0.4375 },\n { x: 0.0625, y: 0.4375 },\n { x: 0.0625, y: 0.4375 },\n { x: 0.0625, y: 0.4375 },\n { x: 0.1875, y: 0.4375 },\n { x: 0.1875, y: 0.4375 },\n { x: 0.1875, y: 0.4375 },\n { x: 0.1875, y: 0.4375 },\n { x: 0.1875, y: 0.4375 },\n { x: 0.1875, y: 0.4375 },\n { x: 0.3125, y: 0.4375 },\n { x: 0.3125, y: 0.4375 },\n { x: 0.3125, y: 0.4375 },\n { x: 0.3125, y: 0.4375 },\n { x: 0.3125, y: 0.4375 },\n { x: 0.3125, y: 0.4375 },\n { x: 0.4375, y: 0.4375 },\n { x: 0.4375, y: 0.4375 },\n { x: 0.4375, y: 0.4375 },\n { x: 0.4375, y: 0.4375 },\n { x: 0.4375, y: 0.4375 },\n { x: 0.4375, y: 0.4375 },\n { x: 0.5625, y: 0.4375 },\n { x: 0.5625, y: 0.4375 },\n { x: 0.5625, y: 0.4375 },\n { x: 0.5625, y: 0.4375 },\n { x: 0.5625, y: 0.4375 },\n { x: 0.5625, y: 0.4375 },\n { x: 0.6875, y: 0.4375 },\n { x: 0.6875, y: 0.4375 },\n { x: 0.6875, y: 0.4375 },\n { x: 0.6875, y: 0.4375 },\n { x: 0.6875, y: 0.4375 },\n { x: 0.6875, y: 0.4375 },\n { x: 0.8125, y: 0.4375 },\n { x: 0.8125, y: 0.4375 },\n { x: 0.8125, y: 0.4375 },\n { x: 0.8125, y: 0.4375 },\n { x: 0.8125, y: 0.4375 },\n { x: 0.8125, y: 0.4375 },\n { x: 0.9375, y: 0.4375 },\n { x: 0.9375, y: 0.4375 },\n { x: 0.9375, y: 0.4375 },\n { x: 0.9375, y: 0.4375 },\n { x: 0.9375, y: 0.4375 },\n { x: 0.9375, y: 0.4375 },\n { x: 0.0625, y: 0.5625 },\n { x: 0.0625, y: 0.5625 },\n { x: 0.0625, y: 0.5625 },\n { x: 0.0625, y: 0.5625 },\n { x: 0.0625, y: 0.5625 },\n { x: 0.0625, y: 0.5625 },\n { x: 0.1875, y: 0.5625 },\n { x: 0.1875, y: 0.5625 },\n { x: 0.1875, y: 0.5625 },\n { x: 0.1875, y: 0.5625 },\n { x: 0.1875, y: 0.5625 },\n { x: 0.1875, y: 0.5625 },\n { x: 0.3125, y: 0.5625 },\n { x: 0.3125, y: 0.5625 },\n { x: 0.3125, y: 0.5625 },\n { x: 0.3125, y: 0.5625 },\n { x: 0.3125, y: 0.5625 },\n { x: 0.3125, y: 0.5625 },\n { x: 0.4375, y: 0.5625 },\n { x: 0.4375, y: 0.5625 },\n { x: 0.4375, y: 0.5625 },\n { x: 0.4375, y: 0.5625 },\n { x: 0.4375, y: 0.5625 },\n { x: 0.4375, y: 0.5625 },\n { x: 0.5625, y: 0.5625 },\n { x: 0.5625, y: 0.5625 },\n { x: 0.5625, y: 0.5625 },\n { x: 0.5625, y: 0.5625 },\n { x: 0.5625, y: 0.5625 },\n { x: 0.5625, y: 0.5625 },\n { x: 0.6875, y: 0.5625 },\n { x: 0.6875, y: 0.5625 },\n { x: 0.6875, y: 0.5625 },\n { x: 0.6875, y: 0.5625 },\n { x: 0.6875, y: 0.5625 },\n { x: 0.6875, y: 0.5625 },\n { x: 0.8125, y: 0.5625 },\n { x: 0.8125, y: 0.5625 },\n { x: 0.8125, y: 0.5625 },\n { x: 0.8125, y: 0.5625 },\n { x: 0.8125, y: 0.5625 },\n { x: 0.8125, y: 0.5625 },\n { x: 0.9375, y: 0.5625 },\n { x: 0.9375, y: 0.5625 },\n { x: 0.9375, y: 0.5625 },\n { x: 0.9375, y: 0.5625 },\n { x: 0.9375, y: 0.5625 },\n { x: 0.9375, y: 0.5625 },\n { x: 0.0625, y: 0.6875 },\n { x: 0.0625, y: 0.6875 },\n { x: 0.0625, y: 0.6875 },\n { x: 0.0625, y: 0.6875 },\n { x: 0.0625, y: 0.6875 },\n { x: 0.0625, y: 0.6875 },\n { x: 0.1875, y: 0.6875 },\n { x: 0.1875, y: 0.6875 },\n { x: 0.1875, y: 0.6875 },\n { x: 0.1875, y: 0.6875 },\n { x: 0.1875, y: 0.6875 },\n { x: 0.1875, y: 0.6875 },\n { x: 0.3125, y: 0.6875 },\n { x: 0.3125, y: 0.6875 },\n { x: 0.3125, y: 0.6875 },\n { x: 0.3125, y: 0.6875 },\n { x: 0.3125, y: 0.6875 },\n { x: 0.3125, y: 0.6875 },\n { x: 0.4375, y: 0.6875 },\n { x: 0.4375, y: 0.6875 },\n { x: 0.4375, y: 0.6875 },\n { x: 0.4375, y: 0.6875 },\n { x: 0.4375, y: 0.6875 },\n { x: 0.4375, y: 0.6875 },\n { x: 0.5625, y: 0.6875 },\n { x: 0.5625, y: 0.6875 },\n { x: 0.5625, y: 0.6875 },\n { x: 0.5625, y: 0.6875 },\n { x: 0.5625, y: 0.6875 },\n { x: 0.5625, y: 0.6875 },\n { x: 0.6875, y: 0.6875 },\n { x: 0.6875, y: 0.6875 },\n { x: 0.6875, y: 0.6875 },\n { x: 0.6875, y: 0.6875 },\n { x: 0.6875, y: 0.6875 },\n { x: 0.6875, y: 0.6875 },\n { x: 0.8125, y: 0.6875 },\n { x: 0.8125, y: 0.6875 },\n { x: 0.8125, y: 0.6875 },\n { x: 0.8125, y: 0.6875 },\n { x: 0.8125, y: 0.6875 },\n { x: 0.8125, y: 0.6875 },\n { x: 0.9375, y: 0.6875 },\n { x: 0.9375, y: 0.6875 },\n { x: 0.9375, y: 0.6875 },\n { x: 0.9375, y: 0.6875 },\n { x: 0.9375, y: 0.6875 },\n { x: 0.9375, y: 0.6875 },\n { x: 0.0625, y: 0.8125 },\n { x: 0.0625, y: 0.8125 },\n { x: 0.0625, y: 0.8125 },\n { x: 0.0625, y: 0.8125 },\n { x: 0.0625, y: 0.8125 },\n { x: 0.0625, y: 0.8125 },\n { x: 0.1875, y: 0.8125 },\n { x: 0.1875, y: 0.8125 },\n { x: 0.1875, y: 0.8125 },\n { x: 0.1875, y: 0.8125 },\n { x: 0.1875, y: 0.8125 },\n { x: 0.1875, y: 0.8125 },\n { x: 0.3125, y: 0.8125 },\n { x: 0.3125, y: 0.8125 },\n { x: 0.3125, y: 0.8125 },\n { x: 0.3125, y: 0.8125 },\n { x: 0.3125, y: 0.8125 },\n { x: 0.3125, y: 0.8125 },\n { x: 0.4375, y: 0.8125 },\n { x: 0.4375, y: 0.8125 },\n { x: 0.4375, y: 0.8125 },\n { x: 0.4375, y: 0.8125 },\n { x: 0.4375, y: 0.8125 },\n { x: 0.4375, y: 0.8125 },\n { x: 0.5625, y: 0.8125 },\n { x: 0.5625, y: 0.8125 },\n { x: 0.5625, y: 0.8125 },\n { x: 0.5625, y: 0.8125 },\n { x: 0.5625, y: 0.8125 },\n { x: 0.5625, y: 0.8125 },\n { x: 0.6875, y: 0.8125 },\n { x: 0.6875, y: 0.8125 },\n { x: 0.6875, y: 0.8125 },\n { x: 0.6875, y: 0.8125 },\n { x: 0.6875, y: 0.8125 },\n { x: 0.6875, y: 0.8125 },\n { x: 0.8125, y: 0.8125 },\n { x: 0.8125, y: 0.8125 },\n { x: 0.8125, y: 0.8125 },\n { x: 0.8125, y: 0.8125 },\n { x: 0.8125, y: 0.8125 },\n { x: 0.8125, y: 0.8125 },\n { x: 0.9375, y: 0.8125 },\n { x: 0.9375, y: 0.8125 },\n { x: 0.9375, y: 0.8125 },\n { x: 0.9375, y: 0.8125 },\n { x: 0.9375, y: 0.8125 },\n { x: 0.9375, y: 0.8125 },\n { x: 0.0625, y: 0.9375 },\n { x: 0.0625, y: 0.9375 },\n { x: 0.0625, y: 0.9375 },\n { x: 0.0625, y: 0.9375 },\n { x: 0.0625, y: 0.9375 },\n { x: 0.0625, y: 0.9375 },\n { x: 0.1875, y: 0.9375 },\n { x: 0.1875, y: 0.9375 },\n { x: 0.1875, y: 0.9375 },\n { x: 0.1875, y: 0.9375 },\n { x: 0.1875, y: 0.9375 },\n { x: 0.1875, y: 0.9375 },\n { x: 0.3125, y: 0.9375 },\n { x: 0.3125, y: 0.9375 },\n { x: 0.3125, y: 0.9375 },\n { x: 0.3125, y: 0.9375 },\n { x: 0.3125, y: 0.9375 },\n { x: 0.3125, y: 0.9375 },\n { x: 0.4375, y: 0.9375 },\n { x: 0.4375, y: 0.9375 },\n { x: 0.4375, y: 0.9375 },\n { x: 0.4375, y: 0.9375 },\n { x: 0.4375, y: 0.9375 },\n { x: 0.4375, y: 0.9375 },\n { x: 0.5625, y: 0.9375 },\n { x: 0.5625, y: 0.9375 },\n { x: 0.5625, y: 0.9375 },\n { x: 0.5625, y: 0.9375 },\n { x: 0.5625, y: 0.9375 },\n { x: 0.5625, y: 0.9375 },\n { x: 0.6875, y: 0.9375 },\n { x: 0.6875, y: 0.9375 },\n { x: 0.6875, y: 0.9375 },\n { x: 0.6875, y: 0.9375 },\n { x: 0.6875, y: 0.9375 },\n { x: 0.6875, y: 0.9375 },\n { x: 0.8125, y: 0.9375 },\n { x: 0.8125, y: 0.9375 },\n { x: 0.8125, y: 0.9375 },\n { x: 0.8125, y: 0.9375 },\n { x: 0.8125, y: 0.9375 },\n { x: 0.8125, y: 0.9375 },\n { x: 0.9375, y: 0.9375 },\n { x: 0.9375, y: 0.9375 },\n { x: 0.9375, y: 0.9375 },\n { x: 0.9375, y: 0.9375 },\n { x: 0.9375, y: 0.9375 },\n { x: 0.9375, y: 0.9375 },\n];\n", "/**\n * HandPose model implementation\n * See `handpose.ts` for entry point\n */\n\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as util from './handposeutil';\nimport * as anchors from './handposeanchors';\nimport { constants } from '../tfjs/constants';\nimport type { Tensor, GraphModel } from '../tfjs/types';\nimport type { Point } from '../result';\n\nexport class HandDetector {\n model: GraphModel;\n anchors: number[][];\n anchorsTensor: Tensor;\n inputSize: number;\n inputSizeTensor: Tensor;\n doubleInputSizeTensor: Tensor;\n\n constructor(model) {\n this.model = model;\n this.anchors = anchors.anchors.map((anchor) => [anchor.x, anchor.y]);\n this.anchorsTensor = tf.tensor2d(this.anchors);\n this.inputSize = (this.model && this.model.inputs && this.model.inputs[0].shape) ? this.model.inputs[0].shape[2] : 0;\n this.inputSizeTensor = tf.tensor1d([this.inputSize, this.inputSize]);\n this.doubleInputSizeTensor = tf.tensor1d([this.inputSize * 2, this.inputSize * 2]);\n }\n\n normalizeBoxes(boxes) {\n const t: Record = {};\n t.boxOffsets = tf.slice(boxes, [0, 0], [-1, 2]);\n t.boxSizes = tf.slice(boxes, [0, 2], [-1, 2]);\n t.div = tf.div(t.boxOffsets, this.inputSizeTensor);\n t.boxCenterPoints = tf.add(t.div, this.anchorsTensor);\n t.halfBoxSizes = tf.div(t.boxSizes, this.doubleInputSizeTensor);\n t.sub = tf.sub(t.boxCenterPoints, t.halfBoxSizes);\n t.startPoints = tf.mul(t.sub, this.inputSizeTensor);\n t.add = tf.add(t.boxCenterPoints, t.halfBoxSizes);\n t.endPoints = tf.mul(t.add, this.inputSizeTensor);\n const res = tf.concat2d([t.startPoints, t.endPoints], 1);\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n return res;\n }\n\n normalizeLandmarks(rawPalmLandmarks, index) {\n const t: Record = {};\n t.reshape = tf.reshape(rawPalmLandmarks, [-1, 7, 2]);\n t.div = tf.div(t.reshape, this.inputSizeTensor);\n t.landmarks = tf.add(t.div, this.anchors[index]);\n const res = tf.mul(t.landmarks, this.inputSizeTensor);\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n return res;\n }\n\n async predict(input, config): Promise<{ startPoint: Point; endPoint: Point, palmLandmarks: Point[]; confidence: number }[]> {\n const t: Record = {};\n t.resize = tf.image.resizeBilinear(input, [this.inputSize, this.inputSize]);\n t.div = tf.div(t.resize, constants.tf127);\n t.image = tf.sub(t.div, constants.tf1);\n t.batched = this.model.execute(t.image) as Tensor;\n t.predictions = tf.squeeze(t.batched);\n t.slice = tf.slice(t.predictions, [0, 0], [-1, 1]);\n t.sigmoid = tf.sigmoid(t.slice);\n t.scores = tf.squeeze(t.sigmoid);\n const scores = await t.scores.data();\n t.boxes = tf.slice(t.predictions, [0, 1], [-1, 4]);\n t.norm = this.normalizeBoxes(t.boxes);\n // box detection is flaky so we look for 3x boxes than we need results\n t.nms = await tf.image.nonMaxSuppressionAsync(t.norm, t.scores, 3 * config.hand.maxDetected, config.hand.iouThreshold, config.hand.minConfidence);\n const nms = await t.nms.array() as Array;\n const hands: Array<{ startPoint: Point; endPoint: Point; palmLandmarks: Point[]; confidence: number }> = [];\n for (const index of nms) {\n const p: Record = {};\n p.box = tf.slice(t.norm, [index, 0], [1, -1]);\n p.slice = tf.slice(t.predictions, [index, 5], [1, 14]);\n p.norm = this.normalizeLandmarks(p.slice, index);\n p.palmLandmarks = tf.reshape(p.norm, [-1, 2]);\n const box = await p.box.data();\n const startPoint = box.slice(0, 2) as unknown as Point;\n const endPoint = box.slice(2, 4) as unknown as Point;\n const palmLandmarks = await p.palmLandmarks.array();\n const hand = { startPoint, endPoint, palmLandmarks, confidence: scores[index] };\n const scaled = util.scaleBoxCoordinates(hand, [input.shape[2] / this.inputSize, input.shape[1] / this.inputSize]);\n hands.push(scaled);\n Object.keys(p).forEach((tensor) => tf.dispose(p[tensor]));\n }\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n return hands;\n }\n}\n", "/**\n * HandPose model implementation\n * See `handpose.ts` for entry point\n */\n\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as util from './handposeutil';\nimport type * as detector from './handposedetector';\nimport { constants } from '../tfjs/constants';\nimport type { Tensor, GraphModel } from '../tfjs/types';\nimport { env } from '../util/env';\nimport { now } from '../util/util';\nimport type { Point } from '../result';\n\nconst palmBoxEnlargeFactor = 5; // default 3\nconst handBoxEnlargeFactor = 1.65; // default 1.65\nconst palmLandmarkIds = [0, 5, 9, 13, 17, 1, 2];\nconst palmLandmarksPalmBase = 0;\nconst palmLandmarksMiddleFingerBase = 2;\nlet lastTime = 0;\n\nexport class HandPipeline {\n handDetector: detector.HandDetector;\n handPoseModel: GraphModel;\n inputSize: number;\n storedBoxes: Array<{ startPoint: Point; endPoint: Point; palmLandmarks: Point[]; confidence: number } | null>;\n skipped: number;\n detectedHands: number;\n\n constructor(handDetector, handPoseModel) {\n this.handDetector = handDetector;\n this.handPoseModel = handPoseModel;\n this.inputSize = this.handPoseModel && this.handPoseModel.inputs[0].shape ? this.handPoseModel.inputs[0].shape[2] : 0;\n this.storedBoxes = [];\n this.skipped = Number.MAX_SAFE_INTEGER;\n this.detectedHands = 0;\n }\n\n // eslint-disable-next-line class-methods-use-this\n calculateLandmarksBoundingBox(landmarks) {\n const xs = landmarks.map((d) => d[0]);\n const ys = landmarks.map((d) => d[1]);\n const startPoint = [Math.min(...xs), Math.min(...ys)];\n const endPoint = [Math.max(...xs), Math.max(...ys)];\n return { startPoint, endPoint };\n }\n\n getBoxForPalmLandmarks(palmLandmarks, rotationMatrix) {\n const rotatedPalmLandmarks = palmLandmarks.map((coord) => util.rotatePoint([...coord, 1], rotationMatrix));\n const boxAroundPalm = this.calculateLandmarksBoundingBox(rotatedPalmLandmarks);\n return util.enlargeBox(util.squarifyBox(boxAroundPalm), palmBoxEnlargeFactor);\n }\n\n getBoxForHandLandmarks(landmarks) {\n const boundingBox = this.calculateLandmarksBoundingBox(landmarks);\n const boxAroundHand = util.enlargeBox(util.squarifyBox(boundingBox), handBoxEnlargeFactor);\n boxAroundHand.palmLandmarks = [];\n for (let i = 0; i < palmLandmarkIds.length; i++) {\n boxAroundHand.palmLandmarks.push(landmarks[palmLandmarkIds[i]].slice(0, 2));\n }\n return boxAroundHand;\n }\n\n transformRawCoords(rawCoords, box2, angle, rotationMatrix) {\n const boxSize = util.getBoxSize(box2);\n const scaleFactor = [boxSize[0] / this.inputSize, boxSize[1] / this.inputSize, (boxSize[0] + boxSize[1]) / this.inputSize / 2];\n const coordsScaled = rawCoords.map((coord) => [\n scaleFactor[0] * (coord[0] - this.inputSize / 2),\n scaleFactor[1] * (coord[1] - this.inputSize / 2),\n scaleFactor[2] * coord[2],\n ]);\n const coordsRotationMatrix = util.buildRotationMatrix(angle, [0, 0]);\n const coordsRotated = coordsScaled.map((coord) => {\n const rotated = util.rotatePoint(coord, coordsRotationMatrix);\n return [...rotated, coord[2]];\n });\n const inverseRotationMatrix = util.invertTransformMatrix(rotationMatrix);\n const boxCenter = [...util.getBoxCenter(box2), 1];\n const originalBoxCenter = [\n util.dot(boxCenter, inverseRotationMatrix[0]),\n util.dot(boxCenter, inverseRotationMatrix[1]),\n ];\n return coordsRotated.map((coord) => [\n Math.trunc(coord[0] + originalBoxCenter[0]),\n Math.trunc(coord[1] + originalBoxCenter[1]),\n Math.trunc(coord[2]),\n ]);\n }\n\n async estimateHands(image, config) {\n let useFreshBox = false;\n\n // run new detector every skipFrames\n let boxes;\n const skipTime = (config.hand.skipTime || 0) > (now() - lastTime);\n const skipFrame = this.skipped < (config.hand.skipFrames || 0);\n if (config.skipAllowed && skipTime && skipFrame) {\n boxes = await this.handDetector.predict(image, config);\n this.skipped = 0;\n }\n if (config.skipAllowed) this.skipped++;\n\n // if detector result count doesn't match current working set, use it to reset current working set\n if (boxes && (boxes.length > 0) && ((boxes.length !== this.detectedHands) && (this.detectedHands !== config.hand.maxDetected) || !config.hand.landmarks)) {\n this.detectedHands = 0;\n this.storedBoxes = [...boxes];\n // for (const possible of boxes) this.storedBoxes.push(possible);\n if (this.storedBoxes.length > 0) useFreshBox = true;\n }\n const hands: Array<{ landmarks: Point[], confidence: number, boxConfidence: number, fingerConfidence: number, box: { topLeft: Point, bottomRight: Point } }> = [];\n\n // go through working set of boxes\n for (let i = 0; i < this.storedBoxes.length; i++) {\n const currentBox = this.storedBoxes[i];\n if (!currentBox) continue;\n if (config.hand.landmarks) {\n const angle = config.hand.rotation ? util.computeRotation(currentBox.palmLandmarks[palmLandmarksPalmBase], currentBox.palmLandmarks[palmLandmarksMiddleFingerBase]) : 0;\n const palmCenter = util.getBoxCenter(currentBox);\n const palmCenterNormalized = [palmCenter[0] / image.shape[2], palmCenter[1] / image.shape[1]];\n const rotatedImage = config.hand.rotation && env.kernels.includes('rotatewithoffset') ? tf.image.rotateWithOffset(image, angle, 0, palmCenterNormalized) : image.clone();\n const rotationMatrix = util.buildRotationMatrix(-angle, palmCenter);\n const newBox = useFreshBox ? this.getBoxForPalmLandmarks(currentBox.palmLandmarks, rotationMatrix) : currentBox;\n const croppedInput = util.cutBoxFromImageAndResize(newBox, rotatedImage, [this.inputSize, this.inputSize]);\n const handImage = tf.div(croppedInput, constants.tf255);\n tf.dispose(croppedInput);\n tf.dispose(rotatedImage);\n const [confidenceT, keypoints] = this.handPoseModel.execute(handImage) as Array;\n lastTime = now();\n tf.dispose(handImage);\n const confidence = (await confidenceT.data())[0];\n tf.dispose(confidenceT);\n if (confidence >= config.hand.minConfidence / 4) {\n const keypointsReshaped = tf.reshape(keypoints, [-1, 3]);\n const rawCoords = await keypointsReshaped.array();\n tf.dispose(keypoints);\n tf.dispose(keypointsReshaped);\n const coords = this.transformRawCoords(rawCoords, newBox, angle, rotationMatrix);\n const nextBoundingBox = this.getBoxForHandLandmarks(coords);\n this.storedBoxes[i] = { ...nextBoundingBox, confidence };\n const result = {\n landmarks: coords,\n confidence,\n boxConfidence: currentBox.confidence,\n fingerConfidence: confidence,\n box: { topLeft: nextBoundingBox.startPoint, bottomRight: nextBoundingBox.endPoint },\n };\n hands.push(result);\n } else {\n this.storedBoxes[i] = null;\n }\n tf.dispose(keypoints);\n } else {\n // const enlarged = box.enlargeBox(box.squarifyBox(box.shiftBox(currentBox, HAND_BOX_SHIFT_VECTOR)), handBoxEnlargeFactor);\n const enlarged = util.enlargeBox(util.squarifyBox(currentBox), handBoxEnlargeFactor);\n const result = {\n confidence: currentBox.confidence,\n boxConfidence: currentBox.confidence,\n fingerConfidence: 0,\n box: { topLeft: enlarged.startPoint, bottomRight: enlarged.endPoint },\n landmarks: [],\n };\n hands.push(result);\n }\n }\n this.storedBoxes = this.storedBoxes.filter((a) => a !== null);\n this.detectedHands = hands.length;\n if (hands.length > config.hand.maxDetected) hands.length = config.hand.maxDetected;\n return hands;\n }\n}\n", "/**\n * FingerPose algorithm implementation\n * See `fingerpose.ts` for entry point\n */\n\nexport const Finger = {\n thumb: 0,\n index: 1,\n middle: 2,\n ring: 3,\n pinky: 4,\n all: [0, 1, 2, 3, 4], // just for convenience\n nameMapping: { 0: 'thumb', 1: 'index', 2: 'middle', 3: 'ring', 4: 'pinky' },\n // Describes mapping of joints based on the 21 points returned by handpose.\n // [0] Palm\n // [1-4] Thumb\n // [5-8] Index\n // [9-12] Middle\n // [13-16] Ring\n // [17-20] Pinky\n pointsMapping: {\n 0: [[0, 1], [1, 2], [2, 3], [3, 4]],\n 1: [[0, 5], [5, 6], [6, 7], [7, 8]],\n 2: [[0, 9], [9, 10], [10, 11], [11, 12]],\n 3: [[0, 13], [13, 14], [14, 15], [15, 16]],\n 4: [[0, 17], [17, 18], [18, 19], [19, 20]],\n },\n getName: (value) => Finger.nameMapping[value],\n getPoints: (value) => Finger.pointsMapping[value],\n};\n\nexport const FingerCurl = {\n none: 0,\n half: 1,\n full: 2,\n nameMapping: { 0: 'none', 1: 'half', 2: 'full' },\n getName: (value) => FingerCurl.nameMapping[value],\n};\n\nexport const FingerDirection = {\n verticalUp: 0,\n verticalDown: 1,\n horizontalLeft: 2,\n horizontalRight: 3,\n diagonalUpRight: 4,\n diagonalUpLeft: 5,\n diagonalDownRight: 6,\n diagonalDownLeft: 7,\n nameMapping: { 0: 'verticalUp', 1: 'verticalDown', 2: 'horizontalLeft', 3: 'horizontalRight', 4: 'diagonalUpRight', 5: 'diagonalUpLeft', 6: 'diagonalDownRight', 7: 'diagonalDownLeft' },\n getName: (value) => FingerDirection.nameMapping[value],\n};\n\nexport class FingerGesture {\n name;\n curls;\n directions;\n weights;\n weightsRelative;\n\n constructor(name) {\n // name (should be unique)\n this.name = name;\n this.curls = {};\n this.directions = {};\n this.weights = [1.0, 1.0, 1.0, 1.0, 1.0];\n this.weightsRelative = [1.0, 1.0, 1.0, 1.0, 1.0];\n }\n\n curl(finger, curl, confidence) {\n if (typeof this.curls[finger] === 'undefined') this.curls[finger] = [];\n this.curls[finger].push([curl, confidence]);\n }\n\n direction(finger, position, confidence) {\n if (!this.directions[finger]) this.directions[finger] = [];\n this.directions[finger].push([position, confidence]);\n }\n\n weight(finger, weight) {\n this.weights[finger] = weight;\n // recalculate relative weights\n const total = this.weights.reduce((a, b) => a + b, 0);\n this.weightsRelative = this.weights.map((el) => el * 5 / total);\n }\n\n matchAgainst(detectedCurls, detectedDirections) {\n let confidence = 0.0;\n // look at the detected curl of each finger and compare with\n // the expected curl of this finger inside current gesture\n for (const fingerIdx in detectedCurls) {\n const detectedCurl = detectedCurls[fingerIdx];\n const expectedCurls = this.curls[fingerIdx];\n if (typeof expectedCurls === 'undefined') {\n // no curl description available for this finger\n // add default confidence of \"1\"\n confidence += this.weightsRelative[fingerIdx];\n continue;\n }\n // compare to each possible curl of this specific finger\n for (const [expectedCurl, score] of expectedCurls) {\n if (detectedCurl === expectedCurl) {\n confidence += score * this.weightsRelative[fingerIdx];\n break;\n }\n }\n }\n // same for detected direction of each finger\n for (const fingerIdx in detectedDirections) {\n const detectedDirection = detectedDirections[fingerIdx];\n const expectedDirections = this.directions[fingerIdx];\n if (typeof expectedDirections === 'undefined') {\n // no direction description available for this finger\n // add default confidence of \"1\"\n confidence += this.weightsRelative[fingerIdx];\n continue;\n }\n // compare to each possible direction of this specific finger\n for (const [expectedDirection, score] of expectedDirections) {\n if (detectedDirection === expectedDirection) {\n confidence += score * this.weightsRelative[fingerIdx];\n break;\n }\n }\n }\n return confidence / 10;\n }\n}\n", "/**\n * FingerPose algorithm implementation\n * See `fingerpose.ts` for entry point\n */\n\nimport { Finger, FingerCurl, FingerDirection, FingerGesture } from './fingerdef';\n\n// eslint-disable-next-line no-unused-vars, @typescript-eslint/no-unused-vars\nexport const { thumb, index, middle, ring, pinky } = Finger;\n// eslint-disable-next-line no-unused-vars, @typescript-eslint/no-unused-vars\nexport const { none, half, full } = FingerCurl;\n// eslint-disable-next-line no-unused-vars, @typescript-eslint/no-unused-vars\nexport const { verticalUp, verticalDown, horizontalLeft, horizontalRight, diagonalUpRight, diagonalUpLeft, diagonalDownRight, diagonalDownLeft } = FingerDirection;\n\n// describe thumbs up gesture \uD83D\uDC4D\nconst ThumbsUp = new FingerGesture('thumbs up');\nThumbsUp.curl(thumb, none, 1.0);\nThumbsUp.direction(thumb, verticalUp, 1.0);\nThumbsUp.direction(thumb, diagonalUpLeft, 0.25);\nThumbsUp.direction(thumb, diagonalUpRight, 0.25);\nfor (const finger of [Finger.index, Finger.middle, Finger.ring, Finger.pinky]) {\n ThumbsUp.curl(finger, full, 1.0);\n ThumbsUp.direction(finger, horizontalLeft, 1.0);\n ThumbsUp.direction(finger, horizontalRight, 1.0);\n}\n\n// describe Victory gesture \u270C\uFE0F\nconst Victory = new FingerGesture('victory');\nVictory.curl(thumb, half, 0.5);\nVictory.curl(thumb, none, 0.5);\nVictory.direction(thumb, verticalUp, 1.0);\nVictory.direction(thumb, diagonalUpLeft, 1.0);\nVictory.curl(index, none, 1.0);\nVictory.direction(index, verticalUp, 0.75);\nVictory.direction(index, diagonalUpLeft, 1.0);\nVictory.curl(middle, none, 1.0);\nVictory.direction(middle, verticalUp, 1.0);\nVictory.direction(middle, diagonalUpLeft, 0.75);\nVictory.curl(ring, full, 1.0);\nVictory.direction(ring, verticalUp, 0.2);\nVictory.direction(ring, diagonalUpLeft, 1.0);\nVictory.direction(ring, horizontalLeft, 0.2);\nVictory.curl(pinky, full, 1.0);\nVictory.direction(pinky, verticalUp, 0.2);\nVictory.direction(pinky, diagonalUpLeft, 1.0);\nVictory.direction(pinky, horizontalLeft, 0.2);\nVictory.weight(index, 2);\nVictory.weight(middle, 2);\n\n// describe Point gesture \u270C\uFE0F\nconst Point = new FingerGesture('point');\nPoint.curl(thumb, full, 1.0);\nPoint.curl(index, none, 0.5);\nPoint.curl(middle, full, 0.5);\nPoint.curl(ring, full, 0.5);\nPoint.curl(pinky, full, 0.5);\nPoint.weight(index, 2);\nPoint.weight(middle, 2);\n\n// describe Point gesture \u270C\uFE0F\nconst MiddleFinger = new FingerGesture('middle finger');\nMiddleFinger.curl(thumb, none, 1.0);\nMiddleFinger.curl(index, full, 0.5);\nMiddleFinger.curl(middle, full, 0.5);\nMiddleFinger.curl(ring, full, 0.5);\nMiddleFinger.curl(pinky, full, 0.5);\nMiddleFinger.weight(index, 2);\nMiddleFinger.weight(middle, 2);\n\n// describe Open Palm gesture \u270C\uFE0F\nconst OpenPalm = new FingerGesture('open palm');\nOpenPalm.curl(thumb, none, 0.75);\nOpenPalm.curl(index, none, 0.75);\nOpenPalm.curl(middle, none, 0.75);\nOpenPalm.curl(ring, none, 0.75);\nOpenPalm.curl(pinky, none, 0.75);\n\nexport default [ThumbsUp, Victory, Point, MiddleFinger, OpenPalm];\n", "/**\n * FingerPose algorithm implementation constants\n *\n * Based on: [**FingerPose***](https://github.com/andypotato/fingerpose)\n */\n\nimport { Finger, FingerCurl, FingerDirection } from './fingerdef';\nimport Gestures from '../hand/fingergesture';\n\nconst minConfidence = 0.7;\nconst options = {\n // curl estimation\n HALF_CURL_START_LIMIT: 60.0,\n NO_CURL_START_LIMIT: 130.0,\n // direction estimation\n DISTANCE_VOTE_POWER: 1.1,\n SINGLE_ANGLE_VOTE_POWER: 0.9,\n TOTAL_ANGLE_VOTE_POWER: 1.6,\n};\n\nfunction calculateSlope(point1x, point1y, point2x, point2y) {\n const value = (point1y - point2y) / (point1x - point2x);\n let slope = Math.atan(value) * 180 / Math.PI;\n if (slope <= 0) slope = -slope;\n else if (slope > 0) slope = 180 - slope;\n return slope;\n}\n\n// point1, point2 are 2d or 3d point arrays (xy[z])\n// returns either a single scalar (2d) or array of two slopes (3d)\nfunction getSlopes(point1, point2) {\n if (!point1 || !point2) return [0, 0];\n const slopeXY = calculateSlope(point1[0], point1[1], point2[0], point2[1]);\n if (point1.length === 2) return slopeXY;\n const slopeYZ = calculateSlope(point1[1], point1[2], point2[1], point2[2]);\n return [slopeXY, slopeYZ];\n}\n\nfunction angleOrientationAt(angle, weightageAt = 1.0) {\n let isVertical = 0;\n let isDiagonal = 0;\n let isHorizontal = 0;\n if (angle >= 75.0 && angle <= 105.0) isVertical = 1 * weightageAt;\n else if (angle >= 25.0 && angle <= 155.0) isDiagonal = 1 * weightageAt;\n else isHorizontal = 1 * weightageAt;\n return [isVertical, isDiagonal, isHorizontal];\n}\n\nfunction estimateFingerCurl(startPoint, midPoint, endPoint) {\n const start_mid_x_dist = startPoint[0] - midPoint[0];\n const start_end_x_dist = startPoint[0] - endPoint[0];\n const mid_end_x_dist = midPoint[0] - endPoint[0];\n const start_mid_y_dist = startPoint[1] - midPoint[1];\n const start_end_y_dist = startPoint[1] - endPoint[1];\n const mid_end_y_dist = midPoint[1] - endPoint[1];\n const start_mid_z_dist = startPoint[2] - midPoint[2];\n const start_end_z_dist = startPoint[2] - endPoint[2];\n const mid_end_z_dist = midPoint[2] - endPoint[2];\n const start_mid_dist = Math.sqrt(start_mid_x_dist * start_mid_x_dist + start_mid_y_dist * start_mid_y_dist + start_mid_z_dist * start_mid_z_dist);\n const start_end_dist = Math.sqrt(start_end_x_dist * start_end_x_dist + start_end_y_dist * start_end_y_dist + start_end_z_dist * start_end_z_dist);\n const mid_end_dist = Math.sqrt(mid_end_x_dist * mid_end_x_dist + mid_end_y_dist * mid_end_y_dist + mid_end_z_dist * mid_end_z_dist);\n let cos_in = (mid_end_dist * mid_end_dist + start_mid_dist * start_mid_dist - start_end_dist * start_end_dist) / (2 * mid_end_dist * start_mid_dist);\n if (cos_in > 1.0) cos_in = 1.0;\n else if (cos_in < -1.0) cos_in = -1.0;\n let angleOfCurve = Math.acos(cos_in);\n angleOfCurve = (57.2958 * angleOfCurve) % 180;\n let fingerCurl;\n if (angleOfCurve > options.NO_CURL_START_LIMIT) fingerCurl = FingerCurl.none;\n else if (angleOfCurve > options.HALF_CURL_START_LIMIT) fingerCurl = FingerCurl.half;\n else fingerCurl = FingerCurl.full;\n return fingerCurl;\n}\n\nfunction estimateHorizontalDirection(start_end_x_dist, start_mid_x_dist, mid_end_x_dist, max_dist_x) {\n let estimatedDirection;\n if (max_dist_x === Math.abs(start_end_x_dist)) {\n if (start_end_x_dist > 0) estimatedDirection = FingerDirection.horizontalLeft;\n else estimatedDirection = FingerDirection.horizontalRight;\n } else if (max_dist_x === Math.abs(start_mid_x_dist)) {\n if (start_mid_x_dist > 0) estimatedDirection = FingerDirection.horizontalLeft;\n else estimatedDirection = FingerDirection.horizontalRight;\n } else {\n if (mid_end_x_dist > 0) estimatedDirection = FingerDirection.horizontalLeft;\n else estimatedDirection = FingerDirection.horizontalRight;\n }\n return estimatedDirection;\n}\n\nfunction estimateVerticalDirection(start_end_y_dist, start_mid_y_dist, mid_end_y_dist, max_dist_y) {\n let estimatedDirection;\n if (max_dist_y === Math.abs(start_end_y_dist)) {\n if (start_end_y_dist < 0) estimatedDirection = FingerDirection.verticalDown;\n else estimatedDirection = FingerDirection.verticalUp;\n } else if (max_dist_y === Math.abs(start_mid_y_dist)) {\n if (start_mid_y_dist < 0) estimatedDirection = FingerDirection.verticalDown;\n else estimatedDirection = FingerDirection.verticalUp;\n } else {\n if (mid_end_y_dist < 0) estimatedDirection = FingerDirection.verticalDown;\n else estimatedDirection = FingerDirection.verticalUp;\n }\n return estimatedDirection;\n}\n\nfunction estimateDiagonalDirection(start_end_y_dist, start_mid_y_dist, mid_end_y_dist, max_dist_y, start_end_x_dist, start_mid_x_dist, mid_end_x_dist, max_dist_x) {\n let estimatedDirection;\n const reqd_vertical_direction = estimateVerticalDirection(start_end_y_dist, start_mid_y_dist, mid_end_y_dist, max_dist_y);\n const reqd_horizontal_direction = estimateHorizontalDirection(start_end_x_dist, start_mid_x_dist, mid_end_x_dist, max_dist_x);\n if (reqd_vertical_direction === FingerDirection.verticalUp) {\n if (reqd_horizontal_direction === FingerDirection.horizontalLeft) estimatedDirection = FingerDirection.diagonalUpLeft;\n else estimatedDirection = FingerDirection.diagonalUpRight;\n } else {\n if (reqd_horizontal_direction === FingerDirection.horizontalLeft) estimatedDirection = FingerDirection.diagonalDownLeft;\n else estimatedDirection = FingerDirection.diagonalDownRight;\n }\n return estimatedDirection;\n}\n\nfunction calculateFingerDirection(startPoint, midPoint, endPoint, fingerSlopes) {\n const start_mid_x_dist = startPoint[0] - midPoint[0];\n const start_end_x_dist = startPoint[0] - endPoint[0];\n const mid_end_x_dist = midPoint[0] - endPoint[0];\n const start_mid_y_dist = startPoint[1] - midPoint[1];\n const start_end_y_dist = startPoint[1] - endPoint[1];\n const mid_end_y_dist = midPoint[1] - endPoint[1];\n const max_dist_x = Math.max(Math.abs(start_mid_x_dist), Math.abs(start_end_x_dist), Math.abs(mid_end_x_dist));\n const max_dist_y = Math.max(Math.abs(start_mid_y_dist), Math.abs(start_end_y_dist), Math.abs(mid_end_y_dist));\n let voteVertical = 0.0;\n let voteDiagonal = 0.0;\n let voteHorizontal = 0.0;\n const start_end_x_y_dist_ratio = max_dist_y / (max_dist_x + 0.00001);\n if (start_end_x_y_dist_ratio > 1.5) voteVertical += options.DISTANCE_VOTE_POWER;\n else if (start_end_x_y_dist_ratio > 0.66) voteDiagonal += options.DISTANCE_VOTE_POWER;\n else voteHorizontal += options.DISTANCE_VOTE_POWER;\n const start_mid_dist = Math.sqrt(start_mid_x_dist * start_mid_x_dist + start_mid_y_dist * start_mid_y_dist);\n const start_end_dist = Math.sqrt(start_end_x_dist * start_end_x_dist + start_end_y_dist * start_end_y_dist);\n const mid_end_dist = Math.sqrt(mid_end_x_dist * mid_end_x_dist + mid_end_y_dist * mid_end_y_dist);\n const max_dist = Math.max(start_mid_dist, start_end_dist, mid_end_dist);\n let calc_start_point_x = startPoint[0];\n let calc_start_point_y = startPoint[1];\n let calc_end_point_x = endPoint[0];\n let calc_end_point_y = endPoint[1];\n if (max_dist === start_mid_dist) {\n calc_end_point_x = endPoint[0];\n calc_end_point_y = endPoint[1];\n } else if (max_dist === mid_end_dist) {\n calc_start_point_x = midPoint[0];\n calc_start_point_y = midPoint[1];\n }\n const calcStartPoint = [calc_start_point_x, calc_start_point_y];\n const calcEndPoint = [calc_end_point_x, calc_end_point_y];\n const totalAngle = getSlopes(calcStartPoint, calcEndPoint);\n const votes = angleOrientationAt(totalAngle, options.TOTAL_ANGLE_VOTE_POWER);\n voteVertical += votes[0];\n voteDiagonal += votes[1];\n voteHorizontal += votes[2];\n for (const fingerSlope of fingerSlopes) {\n const fingerVotes = angleOrientationAt(fingerSlope, options.SINGLE_ANGLE_VOTE_POWER);\n voteVertical += fingerVotes[0];\n voteDiagonal += fingerVotes[1];\n voteHorizontal += fingerVotes[2];\n }\n // in case of tie, highest preference goes to Vertical,\n // followed by horizontal and then diagonal\n let estimatedDirection;\n if (voteVertical === Math.max(voteVertical, voteDiagonal, voteHorizontal)) {\n estimatedDirection = estimateVerticalDirection(start_end_y_dist, start_mid_y_dist, mid_end_y_dist, max_dist_y);\n } else if (voteHorizontal === Math.max(voteDiagonal, voteHorizontal)) {\n estimatedDirection = estimateHorizontalDirection(start_end_x_dist, start_mid_x_dist, mid_end_x_dist, max_dist_x);\n } else {\n estimatedDirection = estimateDiagonalDirection(start_end_y_dist, start_mid_y_dist, mid_end_y_dist, max_dist_y, start_end_x_dist, start_mid_x_dist, mid_end_x_dist, max_dist_x);\n }\n return estimatedDirection;\n}\n\nfunction estimate(landmarks) {\n // step 1: calculate slopes\n const slopesXY: Array = [];\n const slopesYZ: Array = [];\n const fingerCurls: Array = [];\n const fingerDirections: Array = [];\n if (!landmarks) return { curls: fingerCurls, directions: fingerDirections };\n\n // step 1: calculate slopes\n for (const finger of Finger.all) {\n const points = Finger.getPoints(finger);\n const slopeAtXY: Array = [];\n const slopeAtYZ: Array = [];\n for (const point of points) {\n const point1 = landmarks[point[0]];\n const point2 = landmarks[point[1]];\n // calculate single slope\n const slopes = getSlopes(point1, point2);\n const slopeXY = slopes[0];\n const slopeYZ = slopes[1];\n slopeAtXY.push(slopeXY);\n slopeAtYZ.push(slopeYZ);\n }\n slopesXY.push(slopeAtXY);\n slopesYZ.push(slopeAtYZ);\n }\n\n // step 2: calculate orientations\n for (const finger of Finger.all) {\n // start finger predictions from palm - except for thumb\n const pointIndexAt = (finger === Finger.thumb) ? 1 : 0;\n const fingerPointsAt = Finger.getPoints(finger);\n const startPoint = landmarks[fingerPointsAt[pointIndexAt][0]];\n const midPoint = landmarks[fingerPointsAt[pointIndexAt + 1][1]];\n const endPoint = landmarks[fingerPointsAt[3][1]];\n // check if finger is curled\n const fingerCurled = estimateFingerCurl(startPoint, midPoint, endPoint);\n const fingerPosition = calculateFingerDirection(startPoint, midPoint, endPoint, slopesXY[finger].slice(pointIndexAt));\n fingerCurls[finger] = fingerCurled;\n fingerDirections[finger] = fingerPosition;\n }\n return { curls: fingerCurls, directions: fingerDirections };\n}\n\nexport function analyze(keypoints) { // get estimations of curl / direction for each finger\n if (!keypoints || keypoints.length === 0) return null;\n const estimatorRes = estimate(keypoints);\n const landmarks = {};\n for (const fingerIdx of Finger.all) {\n landmarks[Finger.getName(fingerIdx)] = {\n curl: FingerCurl.getName(estimatorRes.curls[fingerIdx]),\n direction: FingerDirection.getName(estimatorRes.directions[fingerIdx]),\n };\n }\n return landmarks;\n}\n\nexport function match(keypoints) { // compare gesture description to each known gesture\n const poses: Array<{ name: string, confidence: number }> = [];\n if (!keypoints || keypoints.length === 0) return poses;\n const estimatorRes = estimate(keypoints);\n for (const gesture of Gestures) {\n const confidence = gesture.matchAgainst(estimatorRes.curls, estimatorRes.directions);\n if (confidence >= minConfidence) poses.push({ name: gesture.name, confidence });\n }\n return poses;\n}\n", "/**\n * HandPose model implementation\n *\n * Based on: [**MediaPipe HandPose**](https://drive.google.com/file/d/1sv4sSb9BSNVZhLzxXJ0jBv9DqD-4jnAz/view)\n */\n\nimport { log } from '../util/util';\nimport * as handdetector from './handposedetector';\nimport * as handpipeline from './handposepipeline';\nimport * as fingerPose from './fingerpose';\nimport { loadModel } from '../tfjs/load';\nimport type { HandResult, Box, Point } from '../result';\nimport type { Tensor, GraphModel } from '../tfjs/types';\nimport type { Config } from '../config';\nimport { env } from '../util/env';\n\nconst meshAnnotations = {\n thumb: [1, 2, 3, 4],\n index: [5, 6, 7, 8],\n middle: [9, 10, 11, 12],\n ring: [13, 14, 15, 16],\n pinky: [17, 18, 19, 20],\n palm: [0],\n};\n\nlet handDetectorModel: GraphModel | null;\nlet handPoseModel: GraphModel | null;\nlet handPipeline: handpipeline.HandPipeline;\n\nexport async function predict(input: Tensor, config: Config): Promise {\n const predictions = await handPipeline.estimateHands(input, config);\n if (!predictions) return [];\n const hands: Array = [];\n for (let i = 0; i < predictions.length; i++) {\n const annotations = {};\n if (predictions[i].landmarks) {\n for (const key of Object.keys(meshAnnotations)) {\n annotations[key] = meshAnnotations[key].map((index) => predictions[i].landmarks[index]);\n }\n }\n const keypoints = predictions[i].landmarks as unknown as Array;\n let box: Box = [Number.MAX_SAFE_INTEGER, Number.MAX_SAFE_INTEGER, 0, 0]; // maximums so conditionals work\n let boxRaw: Box = [0, 0, 0, 0];\n if (keypoints && keypoints.length > 0) { // if we have landmarks, calculate box based on landmarks\n for (const pt of keypoints) {\n if (pt[0] < box[0]) box[0] = pt[0];\n if (pt[1] < box[1]) box[1] = pt[1];\n if (pt[0] > box[2]) box[2] = pt[0];\n if (pt[1] > box[3]) box[3] = pt[1];\n }\n box[2] -= box[0];\n box[3] -= box[1];\n boxRaw = [box[0] / (input.shape[2] || 0), box[1] / (input.shape[1] || 0), box[2] / (input.shape[2] || 0), box[3] / (input.shape[1] || 0)];\n } else { // otherwise use box from prediction\n box = predictions[i].box ? [\n Math.trunc(Math.max(0, predictions[i].box.topLeft[0])),\n Math.trunc(Math.max(0, predictions[i].box.topLeft[1])),\n Math.trunc(Math.min((input.shape[2] || 0), predictions[i].box.bottomRight[0]) - Math.max(0, predictions[i].box.topLeft[0])),\n Math.trunc(Math.min((input.shape[1] || 0), predictions[i].box.bottomRight[1]) - Math.max(0, predictions[i].box.topLeft[1])),\n ] : [0, 0, 0, 0];\n boxRaw = [\n (predictions[i].box.topLeft[0]) / (input.shape[2] || 0),\n (predictions[i].box.topLeft[1]) / (input.shape[1] || 0),\n (predictions[i].box.bottomRight[0] - predictions[i].box.topLeft[0]) / (input.shape[2] || 0),\n (predictions[i].box.bottomRight[1] - predictions[i].box.topLeft[1]) / (input.shape[1] || 0),\n ];\n }\n const landmarks = fingerPose.analyze(keypoints);\n hands.push({\n id: i,\n score: Math.round(100 * predictions[i].confidence) / 100,\n boxScore: Math.round(100 * predictions[i].boxConfidence) / 100,\n fingerScore: Math.round(100 * predictions[i].fingerConfidence) / 100,\n label: 'hand',\n box,\n boxRaw,\n keypoints,\n annotations: annotations as HandResult['annotations'],\n landmarks: landmarks as HandResult['landmarks'],\n });\n }\n return hands;\n}\n\nexport async function load(config: Config): Promise<[GraphModel | null, GraphModel | null]> {\n if (env.initial) {\n handDetectorModel = null;\n handPoseModel = null;\n }\n if (!handDetectorModel || !handPoseModel) {\n [handDetectorModel, handPoseModel] = await Promise.all([\n config.hand.enabled ? loadModel(config.hand.detector?.modelPath) : null,\n config.hand.landmarks ? loadModel(config.hand.skeleton?.modelPath) : null,\n ]);\n } else {\n if (config.debug) log('cached model:', handDetectorModel['modelUrl']);\n if (config.debug) log('cached model:', handPoseModel['modelUrl']);\n }\n const handDetector = new handdetector.HandDetector(handDetectorModel);\n handPipeline = new handpipeline.HandPipeline(handDetector, handPoseModel);\n return [handDetectorModel, handPoseModel];\n}\n", "/**\n * HandTrack model implementation\n *\n * Based on:\n * - Hand Detection & Skeleton: [**MediaPipe HandPose**](https://drive.google.com/file/d/1sv4sSb9BSNVZhLzxXJ0jBv9DqD-4jnAz/view)\n * - Hand Tracking: [**HandTracking**](https://github.com/victordibia/handtracking)\n */\n\nimport { log, now } from '../util/util';\nimport * as box from '../util/box';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport type { HandResult, HandType, Box, Point } from '../result';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport type { Config } from '../config';\nimport { env } from '../util/env';\nimport * as fingerPose from './fingerpose';\nimport { fakeOps } from '../tfjs/backend';\nimport { constants } from '../tfjs/constants';\n\nconst models: [GraphModel | null, GraphModel | null] = [null, null];\nconst modelOutputNodes = ['StatefulPartitionedCall/Postprocessor/Slice', 'StatefulPartitionedCall/Postprocessor/ExpandDims_1'];\n\nconst inputSize = [[0, 0], [0, 0]];\n\nconst classes = ['hand', 'fist', 'pinch', 'point', 'face', 'tip', 'pinchtip'];\nconst faceIndex = 4;\n\nconst boxExpandFact = 1.6;\nconst maxDetectorResolution = 512;\nconst detectorExpandFact = 1.4;\n\nlet skipped = Number.MAX_SAFE_INTEGER;\nlet lastTime = 0;\nlet outputSize: [number, number] = [0, 0];\n\ntype HandDetectResult = {\n id: number,\n score: number,\n box: Box,\n boxRaw: Box,\n label: HandType,\n}\n\nconst cache: {\n boxes: Array,\n hands: Array;\n} = {\n boxes: [],\n hands: [],\n};\n\nconst fingerMap = {\n /*\n thumb: [0, 1, 2, 3, 4],\n index: [0, 5, 6, 7, 8],\n middle: [0, 9, 10, 11, 12],\n ring: [0, 13, 14, 15, 16],\n pinky: [0, 17, 18, 19, 20],\n palm: [0],\n */\n thumb: [1, 2, 3, 4],\n index: [5, 6, 7, 8],\n middle: [9, 10, 11, 12],\n ring: [13, 14, 15, 16],\n pinky: [17, 18, 19, 20],\n base: [0],\n palm: [0, 17, 13, 9, 5, 1, 0],\n};\n\nexport async function loadDetect(config: Config): Promise {\n // HandTrack Model: Original: TFJS Port: \n if (env.initial) models[0] = null;\n if (!models[0]) {\n // handtrack model has some kernel ops defined in model but those are never referenced and non-existent in tfjs\n // ideally need to prune the model itself\n fakeOps(['tensorlistreserve', 'enter', 'tensorlistfromtensor', 'merge', 'loopcond', 'switch', 'exit', 'tensorliststack', 'nextiteration', 'tensorlistsetitem', 'tensorlistgetitem', 'reciprocal', 'shape', 'split', 'where'], config);\n models[0] = await loadModel(config.hand.detector?.modelPath);\n const inputs = Object.values(models[0].modelSignature['inputs']);\n inputSize[0][0] = Array.isArray(inputs) ? parseInt(inputs[0].tensorShape.dim[1].size) : 0;\n inputSize[0][1] = Array.isArray(inputs) ? parseInt(inputs[0].tensorShape.dim[2].size) : 0;\n } else if (config.debug) log('cached model:', models[0]['modelUrl']);\n return models[0];\n}\n\nexport async function loadSkeleton(config: Config): Promise {\n if (env.initial) models[1] = null;\n if (!models[1]) {\n models[1] = await loadModel(config.hand.skeleton?.modelPath);\n const inputs = Object.values(models[1].modelSignature['inputs']);\n inputSize[1][0] = Array.isArray(inputs) ? parseInt(inputs[0].tensorShape.dim[1].size) : 0;\n inputSize[1][1] = Array.isArray(inputs) ? parseInt(inputs[0].tensorShape.dim[2].size) : 0;\n } else if (config.debug) log('cached model:', models[1]['modelUrl']);\n return models[1];\n}\n\nexport async function load(config: Config): Promise<[GraphModel | null, GraphModel | null]> {\n if (!models[0]) await loadDetect(config);\n if (!models[1]) await loadSkeleton(config);\n return models;\n}\n\nasync function detectHands(input: Tensor, config: Config): Promise {\n const hands: HandDetectResult[] = [];\n if (!input || !models[0]) return hands;\n const t: Record = {};\n const ratio = (input.shape[2] || 1) / (input.shape[1] || 1);\n const height = Math.min(Math.round((input.shape[1] || 0) / 8) * 8, maxDetectorResolution); // use dynamic input size but cap at 512\n const width = Math.round(height * ratio / 8) * 8;\n t.resize = tf.image.resizeBilinear(input, [height, width]); // todo: resize with padding\n t.cast = tf.cast(t.resize, 'int32');\n [t.rawScores, t.rawBoxes] = await models[0].executeAsync(t.cast, modelOutputNodes) as Tensor[];\n t.boxes = tf.squeeze(t.rawBoxes, [0, 2]);\n t.scores = tf.squeeze(t.rawScores, [0]);\n const classScores: Array = tf.unstack(t.scores, 1); // unstack scores based on classes\n tf.dispose(classScores[faceIndex]);\n classScores.splice(faceIndex, 1); // remove faces\n t.filtered = tf.stack(classScores, 1); // restack\n tf.dispose(classScores);\n // t.filtered = t.scores;\n t.max = tf.max(t.filtered, 1); // max overall score\n t.argmax = tf.argMax(t.filtered, 1); // class index of max overall score\n let id = 0;\n t.nms = await tf.image.nonMaxSuppressionAsync(t.boxes, t.max, (config.hand.maxDetected || 0) + 1, config.hand.iouThreshold || 0, config.hand.minConfidence || 1);\n const nms = await t.nms.data();\n const scores = await t.max.data();\n const classNum = await t.argmax.data();\n for (const nmsIndex of Array.from(nms)) { // generates results for each class\n const boxSlice = tf.slice(t.boxes, nmsIndex, 1);\n const boxYX = await boxSlice.data();\n tf.dispose(boxSlice);\n const boxData: Box = [boxYX[1], boxYX[0], boxYX[3] - boxYX[1], boxYX[2] - boxYX[0]]; // yx box reshaped to standard box\n const boxRaw: Box = box.scale(boxData, detectorExpandFact);\n const boxFull: Box = [Math.trunc(boxData[0] * outputSize[0]), Math.trunc(boxData[1] * outputSize[1]), Math.trunc(boxData[2] * outputSize[0]), Math.trunc(boxData[3] * outputSize[1])];\n const score = scores[nmsIndex];\n const label = classes[classNum[nmsIndex]] as HandType;\n const hand: HandDetectResult = { id: id++, score, box: boxFull, boxRaw, label };\n hands.push(hand);\n }\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n hands.sort((a, b) => b.score - a.score);\n if (hands.length > (config.hand.maxDetected || 1)) hands.length = (config.hand.maxDetected || 1);\n return hands;\n}\n\nasync function detectFingers(input: Tensor, h: HandDetectResult, config: Config): Promise {\n const hand: HandResult = { // initial values inherited from hand detect\n id: h.id,\n score: Math.round(100 * h.score) / 100,\n boxScore: Math.round(100 * h.score) / 100,\n fingerScore: 0,\n box: h.box,\n boxRaw: h.boxRaw,\n label: h.label,\n keypoints: [],\n landmarks: {} as HandResult['landmarks'],\n annotations: {} as HandResult['annotations'],\n };\n if (input && models[1] && config.hand.landmarks && h.score > (config.hand.minConfidence || 0)) {\n const t: Record = {};\n const boxCrop = [h.boxRaw[1], h.boxRaw[0], h.boxRaw[3] + h.boxRaw[1], h.boxRaw[2] + h.boxRaw[0]] as Box;\n t.crop = tf.image.cropAndResize(input, [boxCrop], [0], [inputSize[1][0], inputSize[1][1]], 'bilinear');\n t.div = tf.div(t.crop, constants.tf255);\n [t.score, t.keypoints] = models[1].execute(t.div, ['Identity_1', 'Identity']) as Tensor[];\n const rawScore = (await t.score.data())[0];\n const score = (100 - Math.trunc(100 / (1 + Math.exp(rawScore)))) / 100; // reverse sigmoid value\n if (score >= (config.hand.minConfidence || 0)) {\n hand.fingerScore = score;\n t.reshaped = tf.reshape(t.keypoints, [-1, 3]);\n const coordsData: Point[] = await t.reshaped.array() as Point[];\n const coordsRaw: Point[] = coordsData.map((kpt) => [kpt[0] / inputSize[1][1], kpt[1] / inputSize[1][0], (kpt[2] || 0)]);\n const coordsNorm: Point[] = coordsRaw.map((kpt) => [kpt[0] * h.boxRaw[2], kpt[1] * h.boxRaw[3], (kpt[2] || 0)]);\n hand.keypoints = (coordsNorm).map((kpt) => [outputSize[0] * (kpt[0] + h.boxRaw[0]), outputSize[1] * (kpt[1] + h.boxRaw[1]), (kpt[2] || 0)]);\n hand.landmarks = fingerPose.analyze(hand.keypoints) as HandResult['landmarks']; // calculate finger gestures\n for (const key of Object.keys(fingerMap)) { // map keypoints to per-finger annotations\n hand.annotations[key] = fingerMap[key].map((index: number) => (hand.landmarks && hand.keypoints[index] ? hand.keypoints[index] : null));\n }\n }\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n }\n return hand;\n}\n\nexport async function predict(input: Tensor, config: Config): Promise {\n if (!models[0] || !models[1] || !models[0]?.inputs[0].shape || !models[1]?.inputs[0].shape) return []; // something is wrong with the model\n outputSize = [input.shape[2] || 0, input.shape[1] || 0];\n skipped++; // increment skip frames\n const skipTime = (config.hand.skipTime || 0) > (now() - lastTime);\n const skipFrame = skipped < (config.hand.skipFrames || 0);\n if (config.skipAllowed && skipTime && skipFrame) {\n return cache.hands; // return cached results without running anything\n }\n return new Promise(async (resolve) => {\n const skipTimeExtended = 3 * (config.hand.skipTime || 0) > (now() - lastTime);\n const skipFrameExtended = skipped < 3 * (config.hand.skipFrames || 0);\n if (config.skipAllowed && cache.hands.length === config.hand.maxDetected) { // we have all detected hands so we're definitely skipping\n cache.hands = await Promise.all(cache.boxes.map((handBox) => detectFingers(input, handBox, config)));\n } else if (config.skipAllowed && skipTimeExtended && skipFrameExtended && cache.hands.length > 0) { // we have some cached results: maybe not enough but anyhow continue for bit longer\n cache.hands = await Promise.all(cache.boxes.map((handBox) => detectFingers(input, handBox, config)));\n } else { // finally rerun detector\n cache.boxes = await detectHands(input, config);\n lastTime = now();\n cache.hands = await Promise.all(cache.boxes.map((handBox) => detectFingers(input, handBox, config)));\n skipped = 0;\n }\n\n const oldCache = [...cache.boxes];\n cache.boxes.length = 0; // reset cache\n if (config.cacheSensitivity > 0) {\n for (let i = 0; i < cache.hands.length; i++) {\n const boxKpt = box.square(cache.hands[i].keypoints, outputSize);\n if (boxKpt.box[2] / (input.shape[2] || 1) > 0.05 && boxKpt.box[3] / (input.shape[1] || 1) > 0.05 && cache.hands[i].fingerScore && cache.hands[i].fingerScore > (config.hand.minConfidence || 0)) {\n const boxScale = box.scale(boxKpt.box, boxExpandFact);\n const boxScaleRaw = box.scale(boxKpt.boxRaw, boxExpandFact);\n // const boxCrop = box.crop(boxScaleRaw);\n cache.boxes.push({ ...oldCache[i], box: boxScale, boxRaw: boxScaleRaw });\n }\n }\n }\n for (let i = 0; i < cache.hands.length; i++) { // replace detected boxes with calculated boxes in final output\n const bbox = box.calc(cache.hands[i].keypoints, outputSize);\n cache.hands[i].box = bbox.box;\n cache.hands[i].boxRaw = bbox.boxRaw;\n }\n resolve(cache.hands);\n });\n}\n", "/**\n * Anti-spoofing model implementation\n */\n\nimport { log, now } from '../util/util';\nimport { loadModel } from '../tfjs/load';\nimport type { Config } from '../config';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { env } from '../util/env';\n\nlet model: GraphModel | null;\nconst cached: Array = [];\nlet skipped = Number.MAX_SAFE_INTEGER;\nlet lastCount = 0;\nlet lastTime = 0;\n\nexport async function load(config: Config): Promise {\n if (env.initial) model = null;\n if (!model) model = await loadModel(config.face.liveness?.modelPath);\n else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\nexport async function predict(image: Tensor, config: Config, idx: number, count: number): Promise {\n if (!model) return 0;\n const skipTime = (config.face.liveness?.skipTime || 0) > (now() - lastTime);\n const skipFrame = skipped < (config.face.liveness?.skipFrames || 0);\n if (config.skipAllowed && skipTime && skipFrame && (lastCount === count) && cached[idx]) {\n skipped++;\n return cached[idx];\n }\n skipped = 0;\n return new Promise(async (resolve) => {\n const resize = tf.image.resizeBilinear(image, [model?.inputs[0].shape ? model.inputs[0].shape[2] : 0, model?.inputs[0].shape ? model.inputs[0].shape[1] : 0], false);\n const res = model?.execute(resize) as Tensor;\n const num = (await res.data())[0];\n cached[idx] = Math.round(100 * num) / 100;\n lastCount = count;\n lastTime = now();\n tf.dispose([resize, res]);\n resolve(cached[idx]);\n });\n}\n", "export const kpt: Array = [ // used to create part labels\n 'nose',\n 'leftEye',\n 'rightEye',\n 'leftEar',\n 'rightEar',\n 'leftShoulder',\n 'rightShoulder',\n 'leftElbow',\n 'rightElbow',\n 'leftWrist',\n 'rightWrist',\n 'leftHip',\n 'rightHip',\n 'leftKnee',\n 'rightKnee',\n 'leftAnkle',\n 'rightAnkle',\n];\n\nexport const horizontal: Array = [ // used to fix left vs right\n ['leftEye', 'rightEye'],\n ['leftEar', 'rightEar'],\n ['leftShoulder', 'rightShoulder'],\n ['leftElbow', 'rightElbow'],\n ['leftWrist', 'rightWrist'],\n ['leftHip', 'rightHip'],\n ['leftKnee', 'rightKnee'],\n ['leftAnkle', 'rightAnkle'],\n];\n\nexport const vertical: Array = [ // used to remove unlikely keypoint positions\n ['leftKnee', 'leftShoulder'],\n ['rightKnee', 'rightShoulder'],\n ['leftAnkle', 'leftKnee'],\n ['rightAnkle', 'rightKnee'],\n];\n\nexport const relative: Array = [ // used to match relative body parts\n [['leftHip', 'rightHip'], ['leftShoulder', 'rightShoulder']],\n [['leftElbow', 'rightElbow'], ['leftShoulder', 'rightShoulder']],\n];\n\nexport const connected: Record = { // used to create body outline in annotations\n leftLeg: ['leftHip', 'leftKnee', 'leftAnkle'],\n rightLeg: ['rightHip', 'rightKnee', 'rightAnkle'],\n torso: ['leftShoulder', 'rightShoulder', 'rightHip', 'leftHip', 'leftShoulder'],\n leftArm: ['leftShoulder', 'leftElbow', 'leftWrist'],\n rightArm: ['rightShoulder', 'rightElbow', 'rightWrist'],\n head: [],\n};\n", "import type { BodyKeypoint, BodyResult } from '../result';\nimport * as box from '../util/box';\nimport * as coords from './movenetcoords';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport type { Tensor } from '../tfjs/types';\n\nconst maxJitter = 0.005; // default allowed jitter is within 0.5%\n\nconst cache: {\n keypoints: Array,\n padding: [number, number][];\n} = {\n keypoints: [],\n padding: [[0, 0], [0, 0], [0, 0], [0, 0]],\n};\n\nexport function bodyParts(body: BodyResult) { // model sometimes mixes up left vs right keypoints so we fix them\n for (const pair of coords.horizontal) { // fix body parts left vs right\n const left = body.keypoints.findIndex((kp) => kp.part === pair[0]);\n const right = body.keypoints.findIndex((kp) => kp.part === pair[1]);\n if (body.keypoints[left] && body.keypoints[right]) {\n if (body.keypoints[left].position[0] < body.keypoints[right].position[0]) {\n const tmp = body.keypoints[left];\n body.keypoints[left] = body.keypoints[right];\n body.keypoints[right] = tmp;\n }\n }\n }\n for (const pair of coords.vertical) { // remove body parts with improbable vertical position\n const lower = body.keypoints.findIndex((kp) => (kp && kp.part === pair[0]));\n const higher = body.keypoints.findIndex((kp) => (kp && kp.part === pair[1]));\n if (body.keypoints[lower] && body.keypoints[higher]) {\n if (body.keypoints[lower].position[1] < body.keypoints[higher].position[1]) {\n body.keypoints.splice(lower, 1);\n }\n }\n }\n for (const [pair, compare] of coords.relative) { // rearrange body parts according to their relative position\n const left = body.keypoints.findIndex((kp) => (kp && kp.part === pair[0]));\n const right = body.keypoints.findIndex((kp) => (kp && kp.part === pair[1]));\n const leftTo = body.keypoints.findIndex((kp) => (kp && kp.part === compare[0]));\n const rightTo = body.keypoints.findIndex((kp) => (kp && kp.part === compare[1]));\n if (!body.keypoints[leftTo] || !body.keypoints[rightTo]) continue; // only if we have both compare points\n const distanceLeft = body.keypoints[left] ? [\n Math.abs(body.keypoints[leftTo].position[0] - body.keypoints[left].position[0]),\n Math.abs(body.keypoints[rightTo].position[0] - body.keypoints[left].position[0]),\n ] : [0, 0];\n const distanceRight = body.keypoints[right] ? [\n Math.abs(body.keypoints[rightTo].position[0] - body.keypoints[right].position[0]),\n Math.abs(body.keypoints[leftTo].position[0] - body.keypoints[right].position[0]),\n ] : [0, 0];\n if (distanceLeft[0] > distanceLeft[1] || distanceRight[0] > distanceRight[1]) { // should flip keypoints\n const tmp = body.keypoints[left];\n body.keypoints[left] = body.keypoints[right];\n body.keypoints[right] = tmp;\n }\n }\n}\n\nexport function jitter(keypoints: Array): Array {\n for (let i = 0; i < keypoints.length; i++) {\n if (keypoints[i] && cache.keypoints[i]) {\n const diff = [Math.abs(keypoints[i].positionRaw[0] - cache.keypoints[i].positionRaw[0]), Math.abs(keypoints[i].positionRaw[1] - cache.keypoints[i].positionRaw[1])];\n if (diff[0] < maxJitter && diff[1] < maxJitter) {\n keypoints[i] = cache.keypoints[i]; // below jitter so replace keypoint\n } else {\n cache.keypoints[i] = keypoints[i]; // above jitter so update cache\n }\n } else {\n cache.keypoints[i] = keypoints[i]; // cache for keypoint doesnt exist so create it here\n }\n }\n return keypoints;\n}\n\nexport function padInput(input: Tensor, inputSize: number): Tensor {\n const t: Record = {};\n if (!input.shape || !input.shape[1] || !input.shape[2]) return input;\n cache.padding = [\n [0, 0], // dont touch batch\n [input.shape[2] > input.shape[1] ? Math.trunc((input.shape[2] - input.shape[1]) / 2) : 0, input.shape[2] > input.shape[1] ? Math.trunc((input.shape[2] - input.shape[1]) / 2) : 0], // height before&after\n [input.shape[1] > input.shape[2] ? Math.trunc((input.shape[1] - input.shape[2]) / 2) : 0, input.shape[1] > input.shape[2] ? Math.trunc((input.shape[1] - input.shape[2]) / 2) : 0], // width before&after\n [0, 0], // dont touch rbg\n ];\n t.pad = tf.pad(input, cache.padding);\n t.resize = tf.image.resizeBilinear(t.pad, [inputSize, inputSize]);\n const final = tf.cast(t.resize, 'int32');\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n return final;\n}\n\nexport function rescaleBody(body: BodyResult, outputSize: [number, number]): BodyResult {\n body.keypoints = body.keypoints.filter((kpt) => kpt && kpt.position); // filter invalid keypoints\n for (const kpt of body.keypoints) {\n kpt.position = [\n kpt.position[0] * (outputSize[0] + cache.padding[2][0] + cache.padding[2][1]) / outputSize[0] - cache.padding[2][0],\n kpt.position[1] * (outputSize[1] + cache.padding[1][0] + cache.padding[1][1]) / outputSize[1] - cache.padding[1][0],\n ];\n kpt.positionRaw = [\n kpt.position[0] / outputSize[0], kpt.position[1] / outputSize[1],\n ];\n }\n const rescaledBoxes = box.calc(body.keypoints.map((pt) => pt.position), outputSize);\n body.box = rescaledBoxes.box;\n body.boxRaw = rescaledBoxes.boxRaw;\n return body;\n}\n", "/**\n * MoveNet model implementation\n *\n * Based on: [**MoveNet**](https://blog.tensorflow.org/2021/05/next-generation-pose-detection-with-movenet-and-tensorflowjs.html)\n */\n\nimport { log, now } from '../util/util';\nimport * as box from '../util/box';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as coords from './movenetcoords';\nimport * as fix from './movenetfix';\nimport { loadModel } from '../tfjs/load';\nimport type { BodyKeypoint, BodyResult, BodyLandmark, BodyAnnotation, Box, Point } from '../result';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport type { Config } from '../config';\nimport { fakeOps } from '../tfjs/backend';\nimport { env } from '../util/env';\n\nlet model: GraphModel | null;\nlet inputSize = 0;\nlet skipped = Number.MAX_SAFE_INTEGER;\n// const boxExpandFact = 1.5; // increase to 150%\n\nconst cache: {\n boxes: Array, // unused\n bodies: Array;\n last: number,\n} = {\n boxes: [],\n bodies: [],\n last: 0,\n};\n\nexport async function load(config: Config): Promise {\n if (env.initial) model = null;\n if (!model) {\n fakeOps(['size'], config);\n model = await loadModel(config.body.modelPath);\n } else if (config.debug) log('cached model:', model['modelUrl']);\n inputSize = model.inputs[0].shape ? model.inputs[0].shape[2] : 0;\n if (inputSize < 64) inputSize = 256;\n return model;\n}\n\nasync function parseSinglePose(res, config, image) {\n const kpt = res[0][0];\n const keypoints: Array = [];\n let score = 0;\n for (let id = 0; id < kpt.length; id++) {\n score = kpt[id][2];\n if (score > config.body.minConfidence) {\n const positionRaw: Point = [kpt[id][1], kpt[id][0]];\n keypoints.push({\n score: Math.round(100 * score) / 100,\n part: coords.kpt[id] as BodyLandmark,\n positionRaw,\n position: [ // normalized to input image size\n Math.round((image.shape[2] || 0) * positionRaw[0]),\n Math.round((image.shape[1] || 0) * positionRaw[1]),\n ],\n });\n }\n }\n score = keypoints.reduce((prev, curr) => (curr.score > prev ? curr.score : prev), 0);\n const bodies: Array = [];\n const newBox = box.calc(keypoints.map((pt) => pt.position), [image.shape[2], image.shape[1]]);\n const annotations: Record = {};\n for (const [name, indexes] of Object.entries(coords.connected)) {\n const pt: Array = [];\n for (let i = 0; i < indexes.length - 1; i++) {\n const pt0 = keypoints.find((kp) => kp.part === indexes[i]);\n const pt1 = keypoints.find((kp) => kp.part === indexes[i + 1]);\n if (pt0 && pt1 && pt0.score > (config.body.minConfidence || 0) && pt1.score > (config.body.minConfidence || 0)) pt.push([pt0.position, pt1.position]);\n }\n annotations[name] = pt;\n }\n const body: BodyResult = { id: 0, score, box: newBox.box, boxRaw: newBox.boxRaw, keypoints, annotations };\n fix.bodyParts(body);\n bodies.push(body);\n return bodies;\n}\n\nasync function parseMultiPose(res, config, image) {\n const bodies: Array = [];\n for (let id = 0; id < res[0].length; id++) {\n const kpt = res[0][id];\n const totalScore = Math.round(100 * kpt[51 + 4]) / 100;\n if (totalScore > config.body.minConfidence) {\n const keypoints: Array = [];\n for (let i = 0; i < 17; i++) {\n const score = kpt[3 * i + 2];\n if (score > config.body.minConfidence) {\n const positionRaw: Point = [kpt[3 * i + 1], kpt[3 * i + 0]];\n keypoints.push({\n part: coords.kpt[i] as BodyLandmark,\n score: Math.round(100 * score) / 100,\n positionRaw,\n position: [Math.round((image.shape[2] || 0) * positionRaw[0]), Math.round((image.shape[1] || 0) * positionRaw[1])],\n });\n }\n }\n const newBox = box.calc(keypoints.map((pt) => pt.position), [image.shape[2], image.shape[1]]);\n // movenet-multipose has built-in box details\n // const boxRaw: Box = [kpt[51 + 1], kpt[51 + 0], kpt[51 + 3] - kpt[51 + 1], kpt[51 + 2] - kpt[51 + 0]];\n // const box: Box = [Math.trunc(boxRaw[0] * (image.shape[2] || 0)), Math.trunc(boxRaw[1] * (image.shape[1] || 0)), Math.trunc(boxRaw[2] * (image.shape[2] || 0)), Math.trunc(boxRaw[3] * (image.shape[1] || 0))];\n const annotations: Record = {} as Record;\n for (const [name, indexes] of Object.entries(coords.connected)) {\n const pt: Array = [];\n for (let i = 0; i < indexes.length - 1; i++) {\n const pt0 = keypoints.find((kp) => kp.part === indexes[i]);\n const pt1 = keypoints.find((kp) => kp.part === indexes[i + 1]);\n if (pt0 && pt1 && pt0.score > (config.body.minConfidence || 0) && pt1.score > (config.body.minConfidence || 0)) pt.push([pt0.position, pt1.position]);\n }\n annotations[name] = pt;\n }\n const body: BodyResult = { id, score: totalScore, box: newBox.box, boxRaw: newBox.boxRaw, keypoints: [...keypoints], annotations };\n fix.bodyParts(body);\n bodies.push(body);\n }\n }\n bodies.sort((a, b) => b.score - a.score);\n if (bodies.length > config.body.maxDetected) bodies.length = config.body.maxDetected;\n return bodies;\n}\n\nexport async function predict(input: Tensor, config: Config): Promise {\n if (!model || !model?.inputs[0].shape) return []; // something is wrong with the model\n if (!config.skipAllowed) cache.boxes.length = 0; // allowed to use cache or not\n skipped++; // increment skip frames\n const skipTime = (config.body.skipTime || 0) > (now() - cache.last);\n const skipFrame = skipped < (config.body.skipFrames || 0);\n if (config.skipAllowed && skipTime && skipFrame) {\n return cache.bodies; // return cached results without running anything\n }\n return new Promise(async (resolve) => {\n const t: Record = {};\n skipped = 0;\n // run detection on squared input and cached boxes\n /*\n cache.bodies = []; // reset bodies result\n if (cache.boxes.length >= (config.body.maxDetected || 0)) { // if we have enough cached boxes run detection using cache\n for (let i = 0; i < cache.boxes.length; i++) { // run detection based on cached boxes\n t.crop = tf.image.cropAndResize(input, [cache.boxes[i]], [0], [inputSize, inputSize], 'bilinear');\n t.cast = tf.cast(t.crop, 'int32');\n // t.input = prepareImage(input);\n t.res = model?.execute(t.cast) as Tensor;\n const res = await t.res.array();\n const newBodies = (t.res.shape[2] === 17) ? await parseSinglePose(res, config, input, cache.boxes[i]) : await parseMultiPose(res, config, input, cache.boxes[i]);\n cache.bodies = cache.bodies.concat(newBodies);\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n }\n }\n if (cache.bodies.length !== config.body.maxDetected) { // did not find enough bodies based on cached boxes so run detection on full frame\n t.input = prepareImage(input);\n t.res = model?.execute(t.input) as Tensor;\n const res = await t.res.array();\n cache.bodies = (t.res.shape[2] === 17) ? await parseSinglePose(res, config, input, [0, 0, 1, 1]) : await parseMultiPose(res, config, input, [0, 0, 1, 1]);\n for (const body of cache.bodies) rescaleBody(body, [input.shape[2] || 1, input.shape[1] || 1]);\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n }\n cache.boxes.length = 0; // reset cache\n for (let i = 0; i < cache.bodies.length; i++) {\n if (cache.bodies[i].keypoints.length > (coords.kpt.length / 2)) { // only update cache if we detected at least half keypoints\n const scaledBox = box.scale(cache.bodies[i].boxRaw, boxExpandFact);\n const cropBox = box.crop(scaledBox);\n cache.boxes.push(cropBox);\n }\n }\n */\n\n // run detection on squared input and no cached boxes\n t.input = fix.padInput(input, inputSize);\n t.res = model?.execute(t.input) as Tensor;\n cache.last = now();\n const res = await t.res.array();\n cache.bodies = (t.res.shape[2] === 17)\n ? await parseSinglePose(res, config, input)\n : await parseMultiPose(res, config, input);\n for (const body of cache.bodies) {\n fix.rescaleBody(body, [input.shape[2] || 1, input.shape[1] || 1]);\n fix.jitter(body.keypoints);\n }\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n\n resolve(cache.bodies);\n });\n}\n", "/**\n * NanoDet object detection model implementation\n *\n * Based on: [**MB3-CenterNet**](https://github.com/610265158/mobilenetv3_centernet)\n */\n\nimport { log, now } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport { constants } from '../tfjs/constants';\nimport { labels } from './labels';\nimport type { ObjectResult, ObjectType, Box } from '../result';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport type { Config } from '../config';\nimport { env } from '../util/env';\n\nlet model: GraphModel;\nlet last: Array = [];\nlet lastTime = 0;\nlet skipped = Number.MAX_SAFE_INTEGER;\nlet inputSize = 0;\n\nconst scaleBox = 2.5; // increase box size\n\nexport async function load(config: Config): Promise {\n if (!model || env.initial) {\n model = await loadModel(config.object.modelPath);\n const inputs = Object.values(model.modelSignature['inputs']);\n inputSize = Array.isArray(inputs) ? parseInt(inputs[0].tensorShape.dim[2].size) : 0;\n } else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\nasync function process(res: Tensor[], outputShape: [number, number], config: Config) {\n let id = 0;\n let results: Array = [];\n for (const strideSize of [1, 2, 4]) { // try each stride size as it detects large/medium/small objects\n // find scores, boxes, classes\n tf.tidy(async () => { // wrap in tidy to automatically deallocate temp tensors\n const baseSize = strideSize * 13; // 13x13=169, 26x26=676, 52x52=2704\n // find boxes and scores output depending on stride\n const scoresT = tf.squeeze(res.find((a: Tensor) => (a.shape[1] === (baseSize ** 2) && (a.shape[2] || 0) === labels.length)));\n const featuresT = tf.squeeze(res.find((a: Tensor) => (a.shape[1] === (baseSize ** 2) && (a.shape[2] || 0) < labels.length)));\n const boxesMax = featuresT.reshape([-1, 4, featuresT.shape[1] / 4]); // reshape [output] to [4, output / 4] where number is number of different features inside each stride\n const boxIdx = await boxesMax.argMax(2).array(); // what we need is indexes of features with highest scores, not values itself\n const scores = await scoresT.array(); // optionally use exponential scores or just as-is\n for (let i = 0; i < scoresT.shape[0]; i++) { // total strides (x * y matrix)\n for (let j = 0; j < scoresT.shape[1]; j++) { // one score for each class\n const score = scores[i][j]; // get score for current position\n if (score > (config.object.minConfidence || 0) && j !== 61) {\n const cx = (0.5 + Math.trunc(i % baseSize)) / baseSize; // center.x normalized to range 0..1\n const cy = (0.5 + Math.trunc(i / baseSize)) / baseSize; // center.y normalized to range 0..1\n const boxOffset = boxIdx[i].map((a: number) => a * (baseSize / strideSize / inputSize)); // just grab indexes of features with highest scores\n const [x, y] = [\n cx - (scaleBox / strideSize * boxOffset[0]),\n cy - (scaleBox / strideSize * boxOffset[1]),\n ];\n const [w, h] = [\n cx + (scaleBox / strideSize * boxOffset[2]) - x,\n cy + (scaleBox / strideSize * boxOffset[3]) - y,\n ];\n let boxRaw: Box = [x, y, w, h]; // results normalized to range 0..1\n boxRaw = boxRaw.map((a) => Math.max(0, Math.min(a, 1))) as Box; // fix out-of-bounds coords\n const box = [ // results normalized to input image pixels\n boxRaw[0] * outputShape[0],\n boxRaw[1] * outputShape[1],\n boxRaw[2] * outputShape[0],\n boxRaw[3] * outputShape[1],\n ];\n const result = {\n id: id++,\n // strideSize,\n score: Math.round(100 * score) / 100,\n class: j + 1,\n label: labels[j].label as ObjectType,\n // center: [Math.trunc(outputShape[0] * cx), Math.trunc(outputShape[1] * cy)],\n // centerRaw: [cx, cy],\n box: box.map((a) => Math.trunc(a)) as Box,\n boxRaw,\n };\n results.push(result);\n }\n }\n }\n });\n }\n // deallocate tensors\n res.forEach((t) => tf.dispose(t));\n\n // normally nms is run on raw results, but since boxes need to be calculated this way we skip calulcation of\n // unnecessary boxes and run nms only on good candidates (basically it just does IOU analysis as scores are already filtered)\n const nmsBoxes = results.map((a) => [a.boxRaw[1], a.boxRaw[0], a.boxRaw[3], a.boxRaw[2]]); // switches coordinates from x,y to y,x as expected by tf.nms\n const nmsScores = results.map((a) => a.score);\n let nmsIdx: Array = [];\n if (nmsBoxes && nmsBoxes.length > 0) {\n const nms = await tf.image.nonMaxSuppressionAsync(nmsBoxes, nmsScores, config.object.maxDetected, config.object.iouThreshold, config.object.minConfidence);\n nmsIdx = await nms.data();\n tf.dispose(nms);\n }\n\n // filter & sort results\n results = results\n .filter((_val, idx) => nmsIdx.includes(idx))\n .sort((a, b) => (b.score - a.score));\n\n return results;\n}\n\nexport async function predict(image: Tensor, config: Config): Promise {\n const skipTime = (config.object.skipTime || 0) > (now() - lastTime);\n const skipFrame = skipped < (config.object.skipFrames || 0);\n if (config.skipAllowed && skipTime && skipFrame && (last.length > 0)) {\n skipped++;\n return last;\n }\n skipped = 0;\n if (!env.kernels.includes('mod') || !env.kernels.includes('sparsetodense')) return last;\n return new Promise(async (resolve) => {\n const outputSize = [image.shape[2] || 0, image.shape[1] || 0];\n const resize = tf.image.resizeBilinear(image, [inputSize, inputSize], false);\n const norm = tf.div(resize, constants.tf255);\n const transpose = norm.transpose([0, 3, 1, 2]);\n tf.dispose(norm);\n tf.dispose(resize);\n\n let objectT;\n if (config.object.enabled) objectT = model.execute(transpose);\n lastTime = now();\n tf.dispose(transpose);\n\n const obj = await process(objectT as Tensor[], outputSize as [number, number], config);\n last = obj;\n resolve(obj);\n });\n}\n", "/**\n * PoseNet body detection model implementation constants\n * See `posenet.ts` for entry point\n */\n\nimport type { Point, BodyResult, BodyAnnotation, BodyLandmark } from '../result';\n\nexport const partNames = [\n 'nose', 'leftEye', 'rightEye', 'leftEar', 'rightEar', 'leftShoulder',\n 'rightShoulder', 'leftElbow', 'rightElbow', 'leftWrist', 'rightWrist',\n 'leftHip', 'rightHip', 'leftKnee', 'rightKnee', 'leftAnkle', 'rightAnkle',\n];\n\nexport const count = partNames.length; // 17 keypoints\n\nexport const partIds = partNames.reduce((result, jointName, i) => {\n result[jointName] = i;\n return result;\n}, {});\n\nconst connectedPartNames = [\n ['leftHip', 'leftShoulder'], ['leftElbow', 'leftShoulder'],\n ['leftElbow', 'leftWrist'], ['leftHip', 'leftKnee'],\n ['leftKnee', 'leftAnkle'], ['rightHip', 'rightShoulder'],\n ['rightElbow', 'rightShoulder'], ['rightElbow', 'rightWrist'],\n ['rightHip', 'rightKnee'], ['rightKnee', 'rightAnkle'],\n ['leftShoulder', 'rightShoulder'], ['leftHip', 'rightHip'],\n];\nexport const connectedPartIndices = connectedPartNames.map(([jointNameA, jointNameB]) => ([partIds[jointNameA], partIds[jointNameB]]));\n\nexport const poseChain = [\n ['nose', 'leftEye'], ['leftEye', 'leftEar'], ['nose', 'rightEye'],\n ['rightEye', 'rightEar'], ['nose', 'leftShoulder'],\n ['leftShoulder', 'leftElbow'], ['leftElbow', 'leftWrist'],\n ['leftShoulder', 'leftHip'], ['leftHip', 'leftKnee'],\n ['leftKnee', 'leftAnkle'], ['nose', 'rightShoulder'],\n ['rightShoulder', 'rightElbow'], ['rightElbow', 'rightWrist'],\n ['rightShoulder', 'rightHip'], ['rightHip', 'rightKnee'],\n ['rightKnee', 'rightAnkle'],\n];\n\nexport function eitherPointDoesntMeetConfidence(a: number, b: number, minConfidence: number) {\n return (a < minConfidence || b < minConfidence);\n}\n\nexport function getAdjacentKeyPoints(keypoints, minConfidence: number) {\n return connectedPartIndices.reduce((result, [leftJoint, rightJoint]) => {\n if (eitherPointDoesntMeetConfidence(keypoints[leftJoint].score, keypoints[rightJoint].score, minConfidence)) {\n return result;\n }\n result.push([keypoints[leftJoint], keypoints[rightJoint]]);\n return result;\n }, []);\n}\n\nexport function getBoundingBox(keypoints): [number, number, number, number] {\n const coord = keypoints.reduce(({ maxX, maxY, minX, minY }, { position: { x, y } }) => ({\n maxX: Math.max(maxX, x),\n maxY: Math.max(maxY, y),\n minX: Math.min(minX, x),\n minY: Math.min(minY, y),\n }), {\n maxX: Number.NEGATIVE_INFINITY,\n maxY: Number.NEGATIVE_INFINITY,\n minX: Number.POSITIVE_INFINITY,\n minY: Number.POSITIVE_INFINITY,\n });\n return [coord.minX, coord.minY, coord.maxX - coord.minX, coord.maxY - coord.minY];\n}\n\nexport function scalePoses(poses, [height, width], [inputResolutionHeight, inputResolutionWidth]): Array {\n const scaleY = height / inputResolutionHeight;\n const scaleX = width / inputResolutionWidth;\n const scalePose = (pose, i): BodyResult => ({\n id: i,\n score: pose.score,\n boxRaw: [pose.box[0] / inputResolutionWidth, pose.box[1] / inputResolutionHeight, pose.box[2] / inputResolutionWidth, pose.box[3] / inputResolutionHeight],\n box: [Math.trunc(pose.box[0] * scaleX), Math.trunc(pose.box[1] * scaleY), Math.trunc(pose.box[2] * scaleX), Math.trunc(pose.box[3] * scaleY)],\n keypoints: pose.keypoints.map(({ score, part, position }) => ({\n score: score as number,\n part: part as BodyLandmark,\n position: [Math.trunc(position.x * scaleX), Math.trunc(position.y * scaleY)] as Point,\n positionRaw: [position.x / inputResolutionHeight, position.y / inputResolutionHeight] as Point,\n })),\n annotations: {} as Record,\n });\n const scaledPoses = poses.map((pose, i) => scalePose(pose, i));\n return scaledPoses;\n}\n\n// algorithm based on Coursera Lecture from Algorithms, Part 1: https://www.coursera.org/learn/algorithms-part1/lecture/ZjoSM/heapsort\nexport class MaxHeap {\n priorityQueue: Array; // don't touch\n numberOfElements: number;\n getElementValue: unknown; // function call\n\n constructor(maxSize, getElementValue) {\n this.priorityQueue = new Array(maxSize);\n this.numberOfElements = -1;\n this.getElementValue = getElementValue;\n }\n\n enqueue(x) {\n this.priorityQueue[++this.numberOfElements] = x;\n this.swim(this.numberOfElements);\n }\n\n dequeue() {\n const max = this.priorityQueue[0];\n this.exchange(0, this.numberOfElements--);\n this.sink(0);\n this.priorityQueue[this.numberOfElements + 1] = null;\n return max;\n }\n\n empty() { return this.numberOfElements === -1; }\n\n size() { return this.numberOfElements + 1; }\n\n all() { return this.priorityQueue.slice(0, this.numberOfElements + 1); }\n\n max() { return this.priorityQueue[0]; }\n\n swim(k) {\n while (k > 0 && this.less(Math.floor(k / 2), k)) {\n this.exchange(k, Math.floor(k / 2));\n k = Math.floor(k / 2);\n }\n }\n\n sink(k) {\n while (2 * k <= this.numberOfElements) {\n let j = 2 * k;\n if (j < this.numberOfElements && this.less(j, j + 1)) j++;\n if (!this.less(k, j)) break;\n this.exchange(k, j);\n k = j;\n }\n }\n\n getValueAt(i) {\n // @ts-ignore getter is of unknown type\n return this.getElementValue(this.priorityQueue[i]);\n }\n\n less(i, j) {\n return this.getValueAt(i) < this.getValueAt(j);\n }\n\n exchange(i, j) {\n const t = this.priorityQueue[i];\n this.priorityQueue[i] = this.priorityQueue[j];\n this.priorityQueue[j] = t;\n }\n}\n\nexport function getOffsetPoint(y, x, keypoint, offsets) {\n return {\n y: offsets.get(y, x, keypoint),\n x: offsets.get(y, x, keypoint + count),\n };\n}\n\nexport function getImageCoords(part, outputStride, offsets) {\n const { heatmapY, heatmapX, id: keypoint } = part;\n const { y, x } = getOffsetPoint(heatmapY, heatmapX, keypoint, offsets);\n return {\n x: part.heatmapX * outputStride + x,\n y: part.heatmapY * outputStride + y,\n };\n}\n\nexport function fillArray(element, size) {\n const result = new Array(size);\n for (let i = 0; i < size; i++) {\n result[i] = element;\n }\n return result;\n}\n\nexport function clamp(a, min, max) {\n if (a < min) return min;\n if (a > max) return max;\n return a;\n}\n\nexport function squaredDistance(y1, x1, y2, x2) {\n const dy = y2 - y1;\n const dx = x2 - x1;\n return dy * dy + dx * dx;\n}\n\nexport function addVectors(a, b) {\n return { x: a.x + b.x, y: a.y + b.y };\n}\n\nexport function clampVector(a, min, max) {\n return { y: clamp(a.y, min, max), x: clamp(a.x, min, max) };\n}\n", "/**\n * PoseNet body detection model implementation\n *\n * Based on: [**PoseNet**](https://medium.com/tensorflow/real-time-human-pose-estimation-in-the-browser-with-tensorflow-js-7dd0bc881cd5)\n */\n\nimport { log } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport type { BodyResult, BodyLandmark, Box } from '../result';\nimport type { Tensor, GraphModel } from '../tfjs/types';\nimport type { Config } from '../config';\nimport { env } from '../util/env';\nimport * as utils from './posenetutils';\n\nlet model: GraphModel;\nconst poseNetOutputs = ['MobilenetV1/offset_2/BiasAdd'/* offsets */, 'MobilenetV1/heatmap_2/BiasAdd'/* heatmapScores */, 'MobilenetV1/displacement_fwd_2/BiasAdd'/* displacementFwd */, 'MobilenetV1/displacement_bwd_2/BiasAdd'/* displacementBwd */];\nconst localMaximumRadius = 1;\nconst outputStride = 16;\nconst squaredNmsRadius = 50 ** 2;\n\nfunction traverse(edgeId, sourceKeypoint, targetId, scores, offsets, displacements, offsetRefineStep = 2) {\n const getDisplacement = (point) => ({\n y: displacements.get(point.y, point.x, edgeId),\n x: displacements.get(point.y, point.x, (displacements.shape[2] / 2) + edgeId),\n });\n const getStridedIndexNearPoint = (point, height, width) => ({\n y: utils.clamp(Math.round(point.y / outputStride), 0, height - 1),\n x: utils.clamp(Math.round(point.x / outputStride), 0, width - 1),\n });\n\n const [height, width] = scores.shape;\n // Nearest neighbor interpolation for the source->target displacements.\n const sourceKeypointIndices = getStridedIndexNearPoint(sourceKeypoint.position, height, width);\n const displacement = getDisplacement(sourceKeypointIndices);\n const displacedPoint = utils.addVectors(sourceKeypoint.position, displacement);\n let targetKeypoint = displacedPoint;\n for (let i = 0; i < offsetRefineStep; i++) {\n const targetKeypointIndices = getStridedIndexNearPoint(targetKeypoint, height, width);\n const offsetPoint = utils.getOffsetPoint(targetKeypointIndices.y, targetKeypointIndices.x, targetId, offsets);\n targetKeypoint = utils.addVectors(\n { x: targetKeypointIndices.x * outputStride, y: targetKeypointIndices.y * outputStride },\n { x: offsetPoint.x, y: offsetPoint.y },\n );\n }\n const targetKeyPointIndices = getStridedIndexNearPoint(targetKeypoint, height, width);\n const score = scores.get(targetKeyPointIndices.y, targetKeyPointIndices.x, targetId);\n return { position: targetKeypoint, part: utils.partNames[targetId], score };\n}\n\nexport function decodePose(root, scores, offsets, displacementsFwd, displacementsBwd) {\n const tuples = utils.poseChain.map(([parentJoinName, childJoinName]) => ([utils.partIds[parentJoinName], utils.partIds[childJoinName]]));\n const edgesFwd = tuples.map(([, childJointId]) => childJointId);\n const edgesBwd = tuples.map(([parentJointId]) => parentJointId);\n const numParts = scores.shape[2]; // [21,21,17]\n const numEdges = edgesFwd.length;\n const keypoints = new Array(numParts);\n // Start a new detection instance at the position of the root.\n const rootPoint = utils.getImageCoords(root.part, outputStride, offsets);\n keypoints[root.part.id] = {\n score: root.score,\n part: utils.partNames[root.part.id] as BodyLandmark,\n position: rootPoint,\n };\n // Decode the part positions upwards in the tree, following the backward displacements.\n for (let edge = numEdges - 1; edge >= 0; --edge) {\n const sourceId = edgesFwd[edge];\n const targetId = edgesBwd[edge];\n if (keypoints[sourceId] && !keypoints[targetId]) {\n keypoints[targetId] = traverse(edge, keypoints[sourceId], targetId, scores, offsets, displacementsBwd);\n }\n }\n // Decode the part positions downwards in the tree, following the forward displacements.\n for (let edge = 0; edge < numEdges; ++edge) {\n const sourceId = edgesBwd[edge];\n const targetId = edgesFwd[edge];\n if (keypoints[sourceId] && !keypoints[targetId]) {\n keypoints[targetId] = traverse(edge, keypoints[sourceId], targetId, scores, offsets, displacementsFwd);\n }\n }\n return keypoints;\n}\n\nfunction scoreIsMaximumInLocalWindow(keypointId, score, heatmapY, heatmapX, scores) {\n const [height, width] = scores.shape;\n let localMaximum = true;\n const yStart = Math.max(heatmapY - localMaximumRadius, 0);\n const yEnd = Math.min(heatmapY + localMaximumRadius + 1, height);\n for (let yCurrent = yStart; yCurrent < yEnd; ++yCurrent) {\n const xStart = Math.max(heatmapX - localMaximumRadius, 0);\n const xEnd = Math.min(heatmapX + localMaximumRadius + 1, width);\n for (let xCurrent = xStart; xCurrent < xEnd; ++xCurrent) {\n if (scores.get(yCurrent, xCurrent, keypointId) > score) {\n localMaximum = false;\n break;\n }\n }\n if (!localMaximum) break;\n }\n return localMaximum;\n}\n\nexport function buildPartWithScoreQueue(minConfidence, scores) {\n const [height, width, numKeypoints] = scores.shape;\n const queue = new utils.MaxHeap(height * width * numKeypoints, ({ score }) => score);\n for (let heatmapY = 0; heatmapY < height; ++heatmapY) {\n for (let heatmapX = 0; heatmapX < width; ++heatmapX) {\n for (let keypointId = 0; keypointId < numKeypoints; ++keypointId) {\n const score = scores.get(heatmapY, heatmapX, keypointId);\n // Only consider parts with score greater or equal to threshold as root candidates.\n if (score < minConfidence) continue;\n // Only consider keypoints whose score is maximum in a local window.\n if (scoreIsMaximumInLocalWindow(keypointId, score, heatmapY, heatmapX, scores)) queue.enqueue({ score, part: { heatmapY, heatmapX, id: keypointId } });\n }\n }\n }\n return queue;\n}\n\nfunction withinRadius(poses, { x, y }, keypointId) {\n return poses.some(({ keypoints }) => {\n const correspondingKeypoint = keypoints[keypointId]?.position;\n if (!correspondingKeypoint) return false;\n return utils.squaredDistance(y, x, correspondingKeypoint.y, correspondingKeypoint.x) <= squaredNmsRadius;\n });\n}\n\nfunction getInstanceScore(existingPoses, keypoints) {\n const notOverlappedKeypointScores = keypoints.reduce((result, { position, score }, keypointId) => {\n if (!withinRadius(existingPoses, position, keypointId)) result += score;\n return result;\n }, 0.0);\n return notOverlappedKeypointScores / keypoints.length;\n}\n\nexport function decode(offsets, scores, displacementsFwd, displacementsBwd, maxDetected, minConfidence) {\n const poses: Array<{ keypoints, box: Box, score: number }> = [];\n const queue = buildPartWithScoreQueue(minConfidence, scores);\n // Generate at most maxDetected object instances per image in decreasing root part score order.\n while (poses.length < maxDetected && !queue.empty()) {\n // The top element in the queue is the next root candidate.\n const root = queue.dequeue();\n // Part-based non-maximum suppression: We reject a root candidate if it is within a disk of `nmsRadius` pixels from the corresponding part of a previously detected instance.\n // @ts-ignore this one is tree walk\n const rootImageCoords = utils.getImageCoords(root.part, outputStride, offsets);\n // @ts-ignore this one is tree walk\n if (withinRadius(poses, rootImageCoords, root.part.id)) continue;\n // Else start a new detection instance at the position of the root.\n let keypoints = decodePose(root, scores, offsets, displacementsFwd, displacementsBwd);\n keypoints = keypoints.filter((a) => a.score > minConfidence);\n const score = getInstanceScore(poses, keypoints);\n const box = utils.getBoundingBox(keypoints);\n if (score > minConfidence) poses.push({ keypoints, box, score: Math.round(100 * score) / 100 });\n }\n return poses;\n}\n\nexport async function predict(input: Tensor, config: Config): Promise {\n /** posenet is mostly obsolete\n * caching is not implemented\n */\n const res = tf.tidy(() => {\n if (!model.inputs[0].shape) return [];\n const resized = tf.image.resizeBilinear(input, [model.inputs[0].shape[2], model.inputs[0].shape[1]]);\n const normalized = tf.sub(tf.div(tf.cast(resized, 'float32'), 127.5), 1.0);\n const results: Array = model.execute(normalized, poseNetOutputs) as Array;\n const results3d = results.map((y) => tf.squeeze(y, [0]));\n results3d[1] = tf.sigmoid(results3d[1]); // apply sigmoid on scores\n return results3d;\n });\n\n const buffers = await Promise.all(res.map((tensor: Tensor) => tensor.buffer()));\n for (const t of res) tf.dispose(t);\n\n const decoded = await decode(buffers[0], buffers[1], buffers[2], buffers[3], config.body.maxDetected, config.body.minConfidence);\n if (!model.inputs[0].shape) return [];\n const scaled = utils.scalePoses(decoded, [input.shape[1], input.shape[2]], [model.inputs[0].shape[2], model.inputs[0].shape[1]]) as BodyResult[];\n return scaled;\n}\n\nexport async function load(config: Config): Promise {\n if (!model || env.initial) model = await loadModel(config.body.modelPath);\n else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n", "/**\n * Image segmentation for body detection model\n *\n * Based on:\n * - [**MediaPipe Meet**](https://drive.google.com/file/d/1lnP1bRi9CSqQQXUHa13159vLELYDgDu0/preview)\n * - [**MediaPipe Selfie**](https://drive.google.com/file/d/1dCfozqknMa068vVsO2j_1FgZkW_e3VWv/preview)\n */\n\nimport { log } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { loadModel } from '../tfjs/load';\nimport * as image from '../image/image';\nimport { constants } from '../tfjs/constants';\nimport type { GraphModel, Tensor } from '../tfjs/types';\nimport type { Config } from '../config';\nimport { env } from '../util/env';\nimport type { Input, AnyCanvas } from '../exports';\n\nlet model: GraphModel;\nlet busy = false;\n\nexport async function load(config: Config): Promise {\n if (!model || env.initial) model = await loadModel(config.segmentation.modelPath);\n else if (config.debug) log('cached model:', model['modelUrl']);\n return model;\n}\n\nexport async function process(input: Input, background: Input | undefined, config: Config)\n: Promise<{ data: Array | Tensor, canvas: AnyCanvas | null, alpha: AnyCanvas | null }> {\n if (busy) return { data: [], canvas: null, alpha: null };\n busy = true;\n if (!model) await load(config);\n const inputImage = await image.process(input, config);\n const width = inputImage.tensor?.shape[2] || 0;\n const height = inputImage.tensor?.shape[1] || 0;\n if (!inputImage.tensor) return { data: [], canvas: null, alpha: null };\n const t: Record = {};\n\n t.resize = tf.image.resizeBilinear(inputImage.tensor, [model.inputs[0].shape ? model.inputs[0].shape[1] : 0, model.inputs[0].shape ? model.inputs[0].shape[2] : 0], false);\n tf.dispose(inputImage.tensor);\n t.norm = tf.div(t.resize, constants.tf255);\n t.res = model.execute(t.norm) as Tensor;\n\n t.squeeze = tf.squeeze(t.res, 0); // meet.shape:[1,256,256,1], selfie.shape:[1,144,256,2]\n if (t.squeeze.shape[2] === 2) {\n t.softmax = tf.softmax(t.squeeze); // model meet has two channels for fg and bg\n [t.bg, t.fg] = tf.unstack(t.softmax, 2);\n t.expand = tf.expandDims(t.fg, 2);\n t.pad = tf.expandDims(t.expand, 0);\n t.crop = tf.image.cropAndResize(t.pad, [[0, 0, 0.5, 0.5]], [0], [width, height]);\n // running sofmax before unstack creates 2x2 matrix so we only take upper-left quadrant\n // otherwise run softmax after unstack and use standard resize\n // resizeOutput = tf.image.resizeBilinear(expand, [input.tensor?.shape[1], input.tensor?.shape[2]]);\n t.data = tf.squeeze(t.crop, 0);\n } else {\n t.data = tf.image.resizeBilinear(t.squeeze, [height, width]); // model selfie has a single channel that we can use directly\n }\n const data = Array.from(await t.data.data()) as number[];\n\n if (env.node && !env.Canvas && (typeof ImageData === 'undefined')) {\n if (config.debug) log('canvas support missing');\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n return { data, canvas: null, alpha: null }; // running in nodejs so return alpha array as-is\n }\n\n const alphaCanvas = image.canvas(width, height);\n // @ts-ignore browser is not defined in tfjs-node\n if (tf.browser) await tf.browser.toPixels(t.data, alphaCanvas);\n const alphaCtx = alphaCanvas.getContext('2d') as CanvasRenderingContext2D;\n if (config.segmentation.blur && config.segmentation.blur > 0) alphaCtx.filter = `blur(${config.segmentation.blur}px)`; // use css filter for bluring, can be done with gaussian blur manually instead\n const alphaData = alphaCtx.getImageData(0, 0, width, height);\n\n const compositeCanvas = image.canvas(width, height);\n const compositeCtx = compositeCanvas.getContext('2d') as CanvasRenderingContext2D;\n if (inputImage.canvas) compositeCtx.drawImage(inputImage.canvas, 0, 0);\n compositeCtx.globalCompositeOperation = 'darken'; // https://developer.mozilla.org/en-US/docs/Web/API/CanvasRenderingContext2D/globalCompositeOperation // best options are: darken, color-burn, multiply\n if (config.segmentation.blur && config.segmentation.blur > 0) compositeCtx.filter = `blur(${config.segmentation.blur}px)`; // use css filter for bluring, can be done with gaussian blur manually instead\n compositeCtx.drawImage(alphaCanvas, 0, 0);\n compositeCtx.globalCompositeOperation = 'source-over'; // reset composite operation\n compositeCtx.filter = 'none'; // reset css filter\n const compositeData = compositeCtx.getImageData(0, 0, width, height);\n for (let i = 0; i < width * height; i++) compositeData.data[4 * i + 3] = alphaData.data[4 * i + 0]; // copy original alpha value to new composite canvas\n compositeCtx.putImageData(compositeData, 0, 0);\n\n let mergedCanvas: AnyCanvas | null = null;\n if (background && compositeCanvas) { // draw background with segmentation as overlay if background is present\n mergedCanvas = image.canvas(width, height);\n const bgImage = await image.process(background, config);\n tf.dispose(bgImage.tensor);\n const ctxMerge = mergedCanvas.getContext('2d') as CanvasRenderingContext2D;\n ctxMerge.drawImage(bgImage.canvas as HTMLCanvasElement, 0, 0, mergedCanvas.width, mergedCanvas.height);\n ctxMerge.drawImage(compositeCanvas, 0, 0);\n }\n\n Object.keys(t).forEach((tensor) => tf.dispose(t[tensor]));\n busy = false;\n // return { data, canvas: mergedCanvas || compositeCanvas, alpha: alphaCanvas };\n return { data, canvas: compositeCanvas, alpha: alphaCanvas };\n}\n", "/** TFJS custom backend registration */\n\nimport type { Human } from '../human';\nimport { log } from '../util/util';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as image from '../image/image';\nimport * as models from '../models';\nimport type { AnyCanvas } from '../exports';\n// import { env } from '../env';\n\nexport const config = {\n name: 'humangl',\n priority: 999,\n canvas: null,\n gl: null,\n extensions: [],\n webGLattr: { // https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.2\n alpha: false,\n antialias: false,\n premultipliedAlpha: false,\n preserveDrawingBuffer: false,\n depth: false,\n stencil: false,\n failIfMajorPerformanceCaveat: false,\n desynchronized: true,\n },\n};\n\nfunction extensions(): void {\n /*\n https://www.khronos.org/registry/webgl/extensions/\n https://webglreport.com/?v=2\n */\n const gl = config.gl;\n if (!gl) return;\n config.extensions = gl.getSupportedExtensions() as string[];\n // gl.getExtension('KHR_parallel_shader_compile');\n}\n\n/**\n * Registers custom WebGL2 backend to be used by Human library\n *\n * @returns void\n */\nexport async function register(instance: Human): Promise {\n // force backend reload if gl context is not valid\n if (instance.config.backend !== 'humangl') return;\n if ((config.name in tf.engine().registry) && (!config.gl || !config.gl.getParameter(config.gl.VERSION))) {\n log('error: humangl backend invalid context');\n models.reset(instance);\n /*\n log('resetting humangl backend');\n await tf.removeBackend(config.name);\n await register(instance); // re-register\n */\n }\n if (!tf.findBackend(config.name)) {\n try {\n config.canvas = await image.canvas(100, 100);\n } catch (err) {\n log('error: cannot create canvas:', err);\n return;\n }\n try {\n config.gl = config.canvas?.getContext('webgl2', config.webGLattr) as WebGL2RenderingContext;\n const glv2 = config.gl.getParameter(config.gl.VERSION).includes('2.0');\n if (!glv2) {\n log('override: using fallback webgl backend as webgl 2.0 is not detected');\n instance.config.backend = 'webgl';\n return;\n }\n if (config.canvas) {\n config.canvas.addEventListener('webglcontextlost', async (e) => {\n log('error: humangl:', e.type);\n log('possible browser memory leak using webgl or conflict with multiple backend registrations');\n instance.emit('error');\n throw new Error('backend error: webgl context lost');\n // log('resetting humangl backend');\n // env.initial = true;\n // models.reset(instance);\n // await tf.removeBackend(config.name);\n // await register(instance); // re-register\n });\n config.canvas.addEventListener('webglcontextrestored', (e) => {\n log('error: humangl context restored:', e);\n });\n config.canvas.addEventListener('webglcontextcreationerror', (e) => {\n log('error: humangl context create:', e);\n });\n }\n } catch (err) {\n log('error: cannot get WebGL context:', err);\n return;\n }\n try {\n tf.setWebGLContext(2, config.gl);\n } catch (err) {\n log('error: cannot set WebGL context:', err);\n return;\n }\n try {\n const ctx = new tf.GPGPUContext(config.gl);\n tf.registerBackend(config.name, () => new tf.MathBackendWebGL(ctx), config.priority);\n } catch (err) {\n log('error: cannot register WebGL backend:', err);\n return;\n }\n try {\n const kernels = tf.getKernelsForBackend('webgl');\n kernels.forEach((kernelConfig) => {\n const newKernelConfig = { ...kernelConfig, backendName: config.name };\n tf.registerKernel(newKernelConfig);\n });\n } catch (err) {\n log('error: cannot update WebGL backend registration:', err);\n return;\n }\n const current = tf.backend().getGPGPUContext ? tf.backend().getGPGPUContext().gl : null;\n if (current) {\n log(`humangl webgl version:${current.getParameter(current.VERSION)} renderer:${current.getParameter(current.RENDERER)}`);\n } else {\n log('error: no current gl context:', current, config.gl);\n return;\n }\n try {\n tf.ENV.set('WEBGL_VERSION', 2);\n } catch (err) {\n log('error: cannot set WebGL backend flags:', err);\n return;\n }\n extensions();\n log('backend registered:', config.name);\n }\n}\n", "/** TFJS backend initialization and customization */\n\nimport type { Human } from '../human';\nimport { log, now } from '../util/util';\nimport { env } from '../util/env';\nimport * as humangl from './humangl';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as constants from './constants';\n\nfunction registerCustomOps() {\n if (!env.kernels.includes('mod')) {\n const kernelMod = {\n kernelName: 'Mod',\n backendName: tf.getBackend(),\n kernelFunc: (op) => tf.tidy(() => tf.sub(op.inputs.a, tf.mul(tf.div(op.inputs.a, op.inputs.b), op.inputs.b))),\n };\n tf.registerKernel(kernelMod);\n env.kernels.push('mod');\n }\n if (!env.kernels.includes('floormod')) {\n const kernelMod = {\n kernelName: 'FloorMod',\n backendName: tf.getBackend(),\n kernelFunc: (op) => tf.tidy(() => tf.floorDiv(op.inputs.a / op.inputs.b) * op.inputs.b + tf.mod(op.inputs.a, op.inputs.b)),\n };\n tf.registerKernel(kernelMod);\n env.kernels.push('floormod');\n }\n}\n\nexport async function check(instance: Human, force = false) {\n instance.state = 'backend';\n if (force || env.initial || (instance.config.backend && (instance.config.backend.length > 0) && (tf.getBackend() !== instance.config.backend))) {\n const timeStamp = now();\n\n if (instance.config.backend && instance.config.backend.length > 0) {\n // detect web worker\n // @ts-ignore ignore missing type for WorkerGlobalScope as that is the point\n if (typeof window === 'undefined' && typeof WorkerGlobalScope !== 'undefined' && instance.config.debug) {\n if (instance.config.debug) log('running inside web worker');\n }\n\n // force browser vs node backend\n if (env.browser && instance.config.backend === 'tensorflow') {\n if (instance.config.debug) log('override: backend set to tensorflow while running in browser');\n instance.config.backend = 'humangl';\n }\n if (env.node && (instance.config.backend === 'webgl' || instance.config.backend === 'humangl')) {\n if (instance.config.debug) log(`override: backend set to ${instance.config.backend} while running in nodejs`);\n instance.config.backend = 'tensorflow';\n }\n\n // handle webgpu\n if (env.browser && instance.config.backend === 'webgpu') {\n if (typeof navigator === 'undefined' || typeof navigator['gpu'] === 'undefined') {\n log('override: backend set to webgpu but browser does not support webgpu');\n instance.config.backend = 'humangl';\n } else {\n const adapter = await navigator['gpu'].requestAdapter();\n if (instance.config.debug) log('enumerated webgpu adapter:', adapter);\n }\n }\n\n // check available backends\n if (instance.config.backend === 'humangl') await humangl.register(instance);\n const available = Object.keys(tf.engine().registryFactory);\n if (instance.config.debug) log('available backends:', available);\n\n if (!available.includes(instance.config.backend)) {\n log(`error: backend ${instance.config.backend} not found in registry`);\n instance.config.backend = env.node ? 'tensorflow' : 'webgl';\n if (instance.config.debug) log(`override: setting backend ${instance.config.backend}`);\n }\n\n if (instance.config.debug) log('setting backend:', instance.config.backend);\n\n // customize wasm\n if (instance.config.backend === 'wasm') {\n if (instance.config.debug) log('wasm path:', instance.config.wasmPath);\n if (typeof tf?.setWasmPaths !== 'undefined') await tf.setWasmPaths(instance.config.wasmPath, instance.config.wasmPlatformFetch);\n else throw new Error('backend error: attempting to use wasm backend but wasm path is not set');\n const simd = await tf.env().getAsync('WASM_HAS_SIMD_SUPPORT');\n const mt = await tf.env().getAsync('WASM_HAS_MULTITHREAD_SUPPORT');\n if (instance.config.debug) log(`wasm execution: ${simd ? 'SIMD' : 'no SIMD'} ${mt ? 'multithreaded' : 'singlethreaded'}`);\n if (instance.config.debug && !simd) log('warning: wasm simd support is not enabled');\n }\n\n try {\n await tf.setBackend(instance.config.backend);\n await tf.ready();\n constants.init();\n } catch (err) {\n log('error: cannot set backend:', instance.config.backend, err);\n return false;\n }\n }\n\n // customize humangl\n if (tf.getBackend() === 'humangl') {\n tf.ENV.set('CHECK_COMPUTATION_FOR_ERRORS', false);\n tf.ENV.set('WEBGL_CPU_FORWARD', true);\n // tf.ENV.set('WEBGL_PACK_DEPTHWISECONV', false);\n tf.ENV.set('WEBGL_USE_SHAPES_UNIFORMS', true);\n tf.ENV.set('CPU_HANDOFF_SIZE_THRESHOLD', 256);\n // if (!instance.config.object.enabled) tf.ENV.set('WEBGL_FORCE_F16_TEXTURES', true); // safe to use 16bit precision\n if (typeof instance.config['deallocate'] !== 'undefined' && instance.config['deallocate']) { // hidden param\n log('changing webgl: WEBGL_DELETE_TEXTURE_THRESHOLD:', true);\n tf.ENV.set('WEBGL_DELETE_TEXTURE_THRESHOLD', 0);\n }\n if (tf.backend().getGPGPUContext) {\n const gl = await tf.backend().getGPGPUContext().gl;\n if (instance.config.debug) log(`gl version:${gl.getParameter(gl.VERSION)} renderer:${gl.getParameter(gl.RENDERER)}`);\n }\n }\n\n // customize webgpu\n if (tf.getBackend() === 'webgpu') {\n // tf.ENV.set('WEBGPU_CPU_HANDOFF_SIZE_THRESHOLD', 512);\n // tf.ENV.set('WEBGPU_DEFERRED_SUBMIT_BATCH_SIZE', 0);\n // tf.ENV.set('WEBGPU_CPU_FORWARD', true);\n }\n\n // wait for ready\n tf.enableProdMode();\n await tf.ready();\n\n instance.performance.initBackend = Math.trunc(now() - timeStamp);\n instance.config.backend = tf.getBackend();\n\n await env.updateBackend(); // update env on backend init\n registerCustomOps();\n // await env.updateBackend(); // update env on backend init\n }\n return true;\n}\n\n// register fake missing tfjs ops\nexport function fakeOps(kernelNames: Array, config) {\n // if (config.debug) log('registerKernel:', kernelNames);\n for (const kernelName of kernelNames) {\n const kernelConfig = {\n kernelName,\n backendName: config.backend,\n kernelFunc: () => { if (config.debug) log('kernelFunc', kernelName, config.backend); },\n // setupFunc: () => { if (config.debug) log('kernelFunc', kernelName, config.backend); },\n // disposeFunc: () => { if (config.debug) log('kernelFunc', kernelName, config.backend); },\n };\n tf.registerKernel(kernelConfig);\n }\n env.kernels = tf.getKernelsForBackend(tf.getBackend()).map((kernel) => kernel.kernelName.toLowerCase()); // re-scan registered ops\n}\n", "/**\n * Module that implements helper draw functions, exposed as human.draw\n */\n\nimport { mergeDeep, now } from '../util/util';\nimport { env } from '../util/env';\nimport { getCanvasContext, rect } from './primitives';\nimport { options } from './options';\nimport { face } from './face';\nimport { body } from './body';\nimport { hand } from './hand';\nimport { object } from './object';\nimport { gesture } from './gesture';\nimport type { Result, PersonResult } from '../result';\nimport type { AnyCanvas, DrawOptions } from '../exports';\n\nlet drawTime = 0;\n\nexport { options } from './options';\nexport { face } from './face';\nexport { body } from './body';\nexport { hand } from './hand';\nexport { object } from './object';\nexport { gesture } from './gesture';\n\n/** draw combined person results instead of individual detection result objects */\nexport async function person(inCanvas: AnyCanvas, result: Array, drawOptions?: Partial) {\n const localOptions = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n const ctx = getCanvasContext(inCanvas);\n if (!ctx) return;\n ctx.lineJoin = 'round';\n ctx.font = localOptions.font;\n\n for (let i = 0; i < result.length; i++) {\n if (localOptions.drawBoxes) {\n ctx.strokeStyle = localOptions.color;\n ctx.fillStyle = localOptions.color;\n rect(ctx, result[i].box[0], result[i].box[1], result[i].box[2], result[i].box[3], localOptions);\n if (localOptions.drawLabels) {\n const label = `person #${i}`;\n if (localOptions.shadowColor && localOptions.shadowColor !== '') {\n ctx.fillStyle = localOptions.shadowColor;\n ctx.fillText(label, result[i].box[0] + 3, 1 + result[i].box[1] + localOptions.lineHeight, result[i].box[2]);\n }\n ctx.fillStyle = localOptions.labelColor;\n ctx.fillText(label, result[i].box[0] + 2, 0 + result[i].box[1] + localOptions.lineHeight, result[i].box[2]);\n }\n ctx.stroke();\n }\n }\n}\n\n/** draw processed canvas */\nexport async function canvas(input: AnyCanvas | HTMLImageElement | HTMLVideoElement, output: AnyCanvas) {\n if (!input || !output) return;\n const ctx = getCanvasContext(output);\n if (!ctx) return;\n ctx.drawImage(input, 0, 0);\n}\n\n/** meta-function that performs draw for: canvas, face, body, hand */\nexport async function all(inCanvas: AnyCanvas, result: Result, drawOptions?: Partial) {\n if (!result || !result.performance || !result || !inCanvas) return null;\n const timeStamp = now();\n const localOptions = mergeDeep(options, drawOptions);\n const promise = Promise.all([\n face(inCanvas, result.face, localOptions),\n body(inCanvas, result.body, localOptions),\n hand(inCanvas, result.hand, localOptions),\n object(inCanvas, result.object, localOptions),\n gesture(inCanvas, result.gesture, localOptions), // gestures do not have buffering\n // person(inCanvas, result.persons, localOptions); // already included above\n ]);\n drawTime = env.perfadd ? drawTime + Math.round(now() - timeStamp) : Math.round(now() - timeStamp);\n result.performance.draw = drawTime;\n return promise;\n}\n", "import { log } from '../util/util';\nimport type { AnyCanvas } from '../exports';\nimport type { Point } from '../result';\nimport type { DrawOptions } from './options';\n\nexport const getCanvasContext = (input: AnyCanvas) => {\n if (!input) log('draw error: invalid canvas');\n else if (!input.getContext) log('draw error: canvas context not defined');\n else {\n const ctx = input.getContext('2d');\n if (!ctx) log('draw error: cannot get canvas context');\n else return ctx;\n }\n return null;\n};\n\nexport const rad2deg = (theta: number) => Math.round((theta * 180) / Math.PI);\n\nexport const colorDepth = (z: number | undefined, opt: DrawOptions): string => {\n if (!opt.useDepth || typeof z === 'undefined') return opt.color;\n const rgb = Uint8ClampedArray.from([127 + (2 * z), 127 - (2 * z), 255]);\n const color = `rgba(${rgb[0]}, ${rgb[1]}, ${rgb[2]}, ${opt.alpha})`;\n return color;\n};\n\nexport function point(ctx: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D, x: number, y: number, z: number | undefined, localOptions: DrawOptions) {\n ctx.fillStyle = colorDepth(z, localOptions);\n ctx.beginPath();\n ctx.arc(x, y, localOptions.pointSize, 0, 2 * Math.PI);\n ctx.fill();\n}\n\nexport function rect(ctx: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D, x: number, y: number, width: number, height: number, localOptions: DrawOptions) {\n ctx.beginPath();\n ctx.lineWidth = localOptions.lineWidth;\n if (localOptions.useCurves) {\n const cx = (x + x + width) / 2;\n const cy = (y + y + height) / 2;\n ctx.ellipse(cx, cy, width / 2, height / 2, 0, 0, 2 * Math.PI);\n } else {\n ctx.moveTo(x + localOptions.roundRect, y);\n ctx.lineTo(x + width - localOptions.roundRect, y);\n ctx.quadraticCurveTo(x + width, y, x + width, y + localOptions.roundRect);\n ctx.lineTo(x + width, y + height - localOptions.roundRect);\n ctx.quadraticCurveTo(x + width, y + height, x + width - localOptions.roundRect, y + height);\n ctx.lineTo(x + localOptions.roundRect, y + height);\n ctx.quadraticCurveTo(x, y + height, x, y + height - localOptions.roundRect);\n ctx.lineTo(x, y + localOptions.roundRect);\n ctx.quadraticCurveTo(x, y, x + localOptions.roundRect, y);\n ctx.closePath();\n }\n ctx.stroke();\n}\n\nexport function lines(ctx: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D, points: Point[], localOptions: DrawOptions) {\n if (points.length < 2) return;\n ctx.beginPath();\n ctx.moveTo(points[0][0], points[0][1]);\n for (const pt of points) {\n ctx.strokeStyle = colorDepth(pt[2], localOptions);\n ctx.lineTo(Math.trunc(pt[0]), Math.trunc(pt[1]));\n }\n ctx.stroke();\n if (localOptions.fillPolygons) {\n ctx.closePath();\n ctx.fill();\n }\n}\n\nexport function curves(ctx: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D, points: Point[], localOptions: DrawOptions) {\n if (points.length < 2) return;\n ctx.lineWidth = localOptions.lineWidth;\n if (!localOptions.useCurves || points.length <= 2) {\n lines(ctx, points, localOptions);\n return;\n }\n ctx.moveTo(points[0][0], points[0][1]);\n for (let i = 0; i < points.length - 2; i++) {\n const xc = (points[i][0] + points[i + 1][0]) / 2;\n const yc = (points[i][1] + points[i + 1][1]) / 2;\n ctx.quadraticCurveTo(points[i][0], points[i][1], xc, yc);\n }\n ctx.quadraticCurveTo(points[points.length - 2][0], points[points.length - 2][1], points[points.length - 1][0], points[points.length - 1][1]);\n ctx.stroke();\n if (localOptions.fillPolygons) {\n ctx.closePath();\n ctx.fill();\n }\n}\n\nexport function arrow(ctx: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D, from: Point, to: Point, radius = 5) {\n let angle;\n let x;\n let y;\n ctx.beginPath();\n ctx.moveTo(from[0], from[1]);\n ctx.lineTo(to[0], to[1]);\n angle = Math.atan2(to[1] - from[1], to[0] - from[0]);\n x = radius * Math.cos(angle) + to[0];\n y = radius * Math.sin(angle) + to[1];\n ctx.moveTo(x, y);\n angle += (1.0 / 3.0) * (2 * Math.PI);\n x = radius * Math.cos(angle) + to[0];\n y = radius * Math.sin(angle) + to[1];\n ctx.lineTo(x, y);\n angle += (1.0 / 3.0) * (2 * Math.PI);\n x = radius * Math.cos(angle) + to[0];\n y = radius * Math.sin(angle) + to[1];\n ctx.lineTo(x, y);\n ctx.closePath();\n ctx.stroke();\n ctx.fill();\n}\n", "/** Draw Options\n * - Accessed via `human.draw.options` or provided per each draw method as the drawOptions optional parameter\n */\nexport type DrawOptions = {\n /** draw line color */\n color: string,\n /** alpha value used for lines */\n alpha: number,\n /** label color */\n labelColor: string,\n /** label shadow color */\n shadowColor: string,\n /** label font */\n font: string,\n /** line spacing between labels */\n lineHeight: number,\n /** line width for drawn lines */\n lineWidth: number,\n /** size of drawn points */\n pointSize: number,\n /** draw rounded boxes by n pixels */\n roundRect: number,\n /** should points be drawn? */\n drawPoints: boolean,\n /** should labels be drawn? */\n drawLabels: boolean,\n /** should face attention keypoints be highlighted */\n drawAttention: boolean;\n /** should detected gestures be drawn? */\n drawGestures: boolean,\n /** should draw boxes around detection results? */\n drawBoxes: boolean,\n /** should draw polygons from detection points? */\n drawPolygons: boolean,\n /** should draw gaze arrows? */\n drawGaze: boolean,\n /** should fill polygons? */\n fillPolygons: boolean,\n /** use z-coordinate when available */\n useDepth: boolean,\n /** should lines be curved? */\n useCurves: boolean,\n}\n\n/** currently set draw options {@link DrawOptions} */\nexport const options: DrawOptions = {\n color: 'rgba(173, 216, 230, 0.6)', // 'lightblue' with light alpha channel\n labelColor: 'rgba(173, 216, 230, 1)', // 'lightblue' with dark alpha channel\n shadowColor: 'black',\n alpha: 0.5,\n font: 'small-caps 16px \"Segoe UI\"',\n lineHeight: 18,\n lineWidth: 4,\n pointSize: 2,\n roundRect: 8,\n drawPoints: false,\n drawLabels: true,\n drawBoxes: true,\n drawAttention: true,\n drawGestures: true,\n drawPolygons: true,\n drawGaze: true,\n fillPolygons: false,\n useDepth: true,\n useCurves: false,\n};\n", "import { TRI468 as triangulation } from '../face/facemeshcoords';\nimport { mergeDeep } from '../util/util';\nimport { getCanvasContext, rad2deg, rect, point, lines, arrow } from './primitives';\nimport { options } from './options';\nimport * as facemeshConstants from '../face/constants';\nimport type { FaceResult } from '../result';\nimport type { AnyCanvas, DrawOptions } from '../exports';\n\nlet opt: DrawOptions;\n\nfunction drawLabels(f: FaceResult, ctx: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D) {\n if (opt.drawLabels) {\n // silly hack since fillText does not suport new line\n const labels:string[] = [];\n labels.push(`face: ${Math.trunc(100 * f.score)}%`);\n if (f.genderScore) labels.push(`${f.gender || ''} ${Math.trunc(100 * f.genderScore)}%`);\n if (f.age) labels.push(`age: ${f.age || ''}`);\n if (f.iris) labels.push(`distance: ${f.iris}`);\n if (f.real) labels.push(`real: ${Math.trunc(100 * f.real)}%`);\n if (f.live) labels.push(`live: ${Math.trunc(100 * f.live)}%`);\n if (f.emotion && f.emotion.length > 0) {\n const emotion = f.emotion.map((a) => `${Math.trunc(100 * a.score)}% ${a.emotion}`);\n if (emotion.length > 3) emotion.length = 3;\n labels.push(emotion.join(' '));\n }\n if (f.rotation && f.rotation.angle && f.rotation.gaze) {\n if (f.rotation.angle.roll) labels.push(`roll: ${rad2deg(f.rotation.angle.roll)}\u00B0 yaw:${rad2deg(f.rotation.angle.yaw)}\u00B0 pitch:${rad2deg(f.rotation.angle.pitch)}\u00B0`);\n if (f.rotation.gaze.bearing) labels.push(`gaze: ${rad2deg(f.rotation.gaze.bearing)}\u00B0`);\n }\n if (labels.length === 0) labels.push('face');\n ctx.fillStyle = opt.color;\n for (let i = labels.length - 1; i >= 0; i--) {\n const x = Math.max(f.box[0], 0);\n const y = i * opt.lineHeight + f.box[1];\n if (opt.shadowColor && opt.shadowColor !== '') {\n ctx.fillStyle = opt.shadowColor;\n ctx.fillText(labels[i], x + 5, y + 16);\n }\n ctx.fillStyle = opt.labelColor;\n ctx.fillText(labels[i], x + 4, y + 15);\n }\n }\n}\n\nfunction drawIrisElipse(f: FaceResult, ctx: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D) {\n // iris: array[center, left, top, right, bottom]\n if (f.annotations && f.annotations['leftEyeIris'] && f.annotations['leftEyeIris'][0]) {\n ctx.strokeStyle = opt.useDepth ? 'rgba(255, 200, 255, 0.3)' : opt.color;\n ctx.beginPath();\n const sizeX = Math.abs(f.annotations['leftEyeIris'][3][0] - f.annotations['leftEyeIris'][1][0]) / 2;\n const sizeY = Math.abs(f.annotations['leftEyeIris'][4][1] - f.annotations['leftEyeIris'][2][1]) / 2;\n ctx.ellipse(f.annotations['leftEyeIris'][0][0], f.annotations['leftEyeIris'][0][1], sizeX, sizeY, 0, 0, 2 * Math.PI);\n ctx.stroke();\n if (opt.fillPolygons) {\n ctx.fillStyle = opt.useDepth ? 'rgba(255, 255, 200, 0.3)' : opt.color;\n ctx.fill();\n }\n }\n if (f.annotations && f.annotations['rightEyeIris'] && f.annotations['rightEyeIris'][0]) {\n ctx.strokeStyle = opt.useDepth ? 'rgba(255, 200, 255, 0.3)' : opt.color;\n ctx.beginPath();\n const sizeX = Math.abs(f.annotations['rightEyeIris'][3][0] - f.annotations['rightEyeIris'][1][0]) / 2;\n const sizeY = Math.abs(f.annotations['rightEyeIris'][4][1] - f.annotations['rightEyeIris'][2][1]) / 2;\n ctx.ellipse(f.annotations['rightEyeIris'][0][0], f.annotations['rightEyeIris'][0][1], sizeX, sizeY, 0, 0, 2 * Math.PI);\n ctx.stroke();\n if (opt.fillPolygons) {\n ctx.fillStyle = opt.useDepth ? 'rgba(255, 255, 200, 0.3)' : opt.color;\n ctx.fill();\n }\n }\n}\n\nfunction drawGazeSpheres(f: FaceResult, ctx: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D) {\n if (opt.drawGaze && f.rotation?.angle && typeof Path2D !== 'undefined') {\n ctx.strokeStyle = 'pink';\n const valX = (f.box[0] + f.box[2] / 2) - (f.box[3] * rad2deg(f.rotation.angle.yaw) / 90);\n const valY = (f.box[1] + f.box[3] / 2) + (f.box[2] * rad2deg(f.rotation.angle.pitch) / 90);\n const pathV = new Path2D(`\n M ${f.box[0] + f.box[2] / 2} ${f.box[1]}\n C\n ${valX} ${f.box[1]},\n ${valX} ${f.box[1] + f.box[3]},\n ${f.box[0] + f.box[2] / 2} ${f.box[1] + f.box[3]}\n `);\n const pathH = new Path2D(`\n M ${f.box[0]} ${f.box[1] + f.box[3] / 2}\n C \n ${f.box[0]} ${valY},\n ${f.box[0] + f.box[2]} ${valY},\n ${f.box[0] + f.box[2]} ${f.box[1] + f.box[3] / 2}\n `);\n ctx.stroke(pathH);\n ctx.stroke(pathV);\n }\n}\n\nfunction drawGazeArrows(f: FaceResult, ctx: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D) {\n if (opt.drawGaze && f.rotation?.gaze?.strength && f.rotation?.gaze?.bearing && f.annotations['leftEyeIris'] && f.annotations['rightEyeIris'] && f.annotations['leftEyeIris'][0] && f.annotations['rightEyeIris'][0]) {\n ctx.strokeStyle = 'pink';\n ctx.fillStyle = 'pink';\n const leftGaze = [\n f.annotations['leftEyeIris'][0][0] + (Math.sin(f.rotation.gaze.bearing) * f.rotation.gaze.strength * f.box[3]),\n f.annotations['leftEyeIris'][0][1] + (Math.cos(f.rotation.gaze.bearing) * f.rotation.gaze.strength * f.box[2]),\n ];\n arrow(ctx, [f.annotations['leftEyeIris'][0][0], f.annotations['leftEyeIris'][0][1]], [leftGaze[0], leftGaze[1]], 4);\n const rightGaze = [\n f.annotations['rightEyeIris'][0][0] + (Math.sin(f.rotation.gaze.bearing) * f.rotation.gaze.strength * f.box[3]),\n f.annotations['rightEyeIris'][0][1] + (Math.cos(f.rotation.gaze.bearing) * f.rotation.gaze.strength * f.box[2]),\n ];\n arrow(ctx, [f.annotations['rightEyeIris'][0][0], f.annotations['rightEyeIris'][0][1]], [rightGaze[0], rightGaze[1]], 4);\n }\n}\n\nfunction drawFacePolygons(f: FaceResult, ctx: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D) {\n if (opt.drawPolygons && f.mesh.length >= 468) {\n ctx.lineWidth = 1;\n for (let i = 0; i < triangulation.length / 3; i++) {\n const points = [triangulation[i * 3 + 0], triangulation[i * 3 + 1], triangulation[i * 3 + 2]].map((index) => f.mesh[index]);\n lines(ctx, points, opt);\n }\n drawIrisElipse(f, ctx);\n }\n}\n\nfunction drawFacePoints(f: FaceResult, ctx: CanvasRenderingContext2D | OffscreenCanvasRenderingContext2D) {\n if (opt.drawPoints && f.mesh.length >= 468) {\n for (let i = 0; i < f.mesh.length; i++) {\n point(ctx, f.mesh[i][0], f.mesh[i][1], f.mesh[i][2], opt);\n if (opt.drawAttention) {\n if (facemeshConstants.LANDMARKS_REFINEMENT_LIPS_CONFIG.includes(i)) point(ctx, f.mesh[i][0], f.mesh[i][1], (f.mesh[i][2] as number) + 127, opt);\n if (facemeshConstants.LANDMARKS_REFINEMENT_LEFT_EYE_CONFIG.includes(i)) point(ctx, f.mesh[i][0], f.mesh[i][1], (f.mesh[i][2] as number) - 127, opt);\n if (facemeshConstants.LANDMARKS_REFINEMENT_RIGHT_EYE_CONFIG.includes(i)) point(ctx, f.mesh[i][0], f.mesh[i][1], (f.mesh[i][2] as number) - 127, opt);\n }\n }\n }\n}\n\nfunction drawFaceBoxes(f: FaceResult, ctx) {\n if (opt.drawBoxes) {\n rect(ctx, f.box[0], f.box[1], f.box[2], f.box[3], opt);\n }\n}\n\n/** draw detected faces */\nexport async function face(inCanvas: AnyCanvas, result: Array, drawOptions?: Partial) {\n opt = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n const ctx = getCanvasContext(inCanvas);\n if (!ctx) return;\n ctx.font = opt.font;\n ctx.strokeStyle = opt.color;\n ctx.fillStyle = opt.color;\n for (const f of result) {\n drawFaceBoxes(f, ctx);\n drawLabels(f, ctx);\n if (f.mesh && f.mesh.length > 0) {\n drawFacePoints(f, ctx);\n drawFacePolygons(f, ctx);\n drawGazeSpheres(f, ctx);\n drawGazeArrows(f, ctx);\n }\n }\n}\n", "import { mergeDeep } from '../util/util';\nimport { getCanvasContext, rect, point, curves, colorDepth } from './primitives';\nimport { options } from './options';\nimport type { BodyResult } from '../result';\nimport type { AnyCanvas, DrawOptions } from '../exports';\n\n/** draw detected bodies */\nexport async function body(inCanvas: AnyCanvas, result: Array, drawOptions?: Partial) {\n const localOptions = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n const ctx = getCanvasContext(inCanvas);\n if (!ctx) return;\n ctx.lineJoin = 'round';\n for (let i = 0; i < result.length; i++) {\n ctx.strokeStyle = localOptions.color;\n ctx.fillStyle = localOptions.color;\n ctx.lineWidth = localOptions.lineWidth;\n ctx.font = localOptions.font;\n if (localOptions.drawBoxes && result[i].box && result[i].box?.length === 4) {\n rect(ctx, result[i].box[0], result[i].box[1], result[i].box[2], result[i].box[3], localOptions);\n if (localOptions.drawLabels) {\n if (localOptions.shadowColor && localOptions.shadowColor !== '') {\n ctx.fillStyle = localOptions.shadowColor;\n ctx.fillText(`body ${100 * result[i].score}%`, result[i].box[0] + 3, 1 + result[i].box[1] + localOptions.lineHeight, result[i].box[2]);\n }\n ctx.fillStyle = localOptions.labelColor;\n ctx.fillText(`body ${100 * result[i].score}%`, result[i].box[0] + 2, 0 + result[i].box[1] + localOptions.lineHeight, result[i].box[2]);\n }\n }\n if (localOptions.drawPoints && result[i].keypoints) {\n for (let pt = 0; pt < result[i].keypoints.length; pt++) {\n if (!result[i].keypoints[pt].score || (result[i].keypoints[pt].score === 0)) continue;\n ctx.fillStyle = colorDepth(result[i].keypoints[pt].position[2], localOptions);\n point(ctx, result[i].keypoints[pt].position[0], result[i].keypoints[pt].position[1], 0, localOptions);\n }\n }\n if (localOptions.drawLabels && result[i].keypoints) {\n ctx.font = localOptions.font;\n for (const pt of result[i].keypoints) {\n if (!pt.score || (pt.score === 0)) continue;\n ctx.fillStyle = colorDepth(pt.position[2], localOptions);\n ctx.fillText(`${pt.part} ${Math.trunc(100 * pt.score)}%`, pt.position[0] + 4, pt.position[1] + 4);\n }\n }\n if (localOptions.drawPolygons && result[i].keypoints && result[i].annotations) {\n for (const part of Object.values(result[i].annotations)) {\n for (const connected of part) curves(ctx, connected, localOptions);\n }\n }\n }\n}\n", "import { mergeDeep } from '../util/util';\nimport { getCanvasContext, rect, point, colorDepth } from './primitives';\nimport { options } from './options';\nimport type { HandResult } from '../result';\nimport type { AnyCanvas, DrawOptions, Point } from '../exports';\n\n/** draw detected hands */\nexport async function hand(inCanvas: AnyCanvas, result: Array, drawOptions?: Partial) {\n const localOptions = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n const ctx = getCanvasContext(inCanvas);\n if (!ctx) return;\n ctx.lineJoin = 'round';\n ctx.font = localOptions.font;\n for (const h of result) {\n if (localOptions.drawBoxes) {\n ctx.strokeStyle = localOptions.color;\n ctx.fillStyle = localOptions.color;\n rect(ctx, h.box[0], h.box[1], h.box[2], h.box[3], localOptions);\n if (localOptions.drawLabels) {\n if (localOptions.shadowColor && localOptions.shadowColor !== '') {\n ctx.fillStyle = localOptions.shadowColor;\n ctx.fillText(`hand:${Math.trunc(100 * h.score)}%`, h.box[0] + 3, 1 + h.box[1] + localOptions.lineHeight, h.box[2]); // can use h.label\n }\n ctx.fillStyle = localOptions.labelColor;\n ctx.fillText(`hand:${Math.trunc(100 * h.score)}%`, h.box[0] + 2, 0 + h.box[1] + localOptions.lineHeight, h.box[2]); // can use h.label\n }\n ctx.stroke();\n }\n if (localOptions.drawPoints) {\n if (h.keypoints && h.keypoints.length > 0) {\n for (const pt of h.keypoints) {\n ctx.fillStyle = colorDepth(pt[2], localOptions);\n point(ctx, pt[0], pt[1], 0, localOptions);\n }\n }\n }\n if (localOptions.drawLabels && h.annotations) {\n const addHandLabel = (part: Array, title: string) => {\n if (!part || part.length === 0 || !part[0]) return;\n const z = part[part.length - 1][2] || -256;\n ctx.fillStyle = colorDepth(z, localOptions);\n ctx.fillText(title, part[part.length - 1][0] + 4, part[part.length - 1][1] + 4);\n };\n ctx.font = localOptions.font;\n addHandLabel(h.annotations['index'], 'index');\n addHandLabel(h.annotations['middle'], 'middle');\n addHandLabel(h.annotations['ring'], 'ring');\n addHandLabel(h.annotations['pinky'], 'pinky');\n addHandLabel(h.annotations['thumb'], 'thumb');\n addHandLabel(h.annotations['palm'], 'palm');\n }\n if (localOptions.drawPolygons && h.annotations) {\n const addHandLine = (part: Array) => {\n if (!part || part.length === 0 || !part[0]) return;\n for (let i = 0; i < part.length; i++) {\n ctx.beginPath();\n const z = part[i][2] || 0;\n ctx.strokeStyle = colorDepth(i * z, localOptions);\n ctx.moveTo(part[i > 0 ? i - 1 : 0][0], part[i > 0 ? i - 1 : 0][1]);\n ctx.lineTo(part[i][0], part[i][1]);\n ctx.stroke();\n }\n };\n ctx.lineWidth = localOptions.lineWidth;\n addHandLine(h.annotations['index']);\n addHandLine(h.annotations['middle']);\n addHandLine(h.annotations['ring']);\n addHandLine(h.annotations['pinky']);\n addHandLine(h.annotations['thumb']);\n // addPart(h.annotations.palm);\n }\n }\n}\n", "import { mergeDeep } from '../util/util';\nimport { getCanvasContext, rect } from './primitives';\nimport { options } from './options';\nimport type { ObjectResult } from '../result';\nimport type { AnyCanvas, DrawOptions } from '../exports';\n\n/** draw detected objects */\nexport async function object(inCanvas: AnyCanvas, result: Array, drawOptions?: Partial) {\n const localOptions = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n const ctx = getCanvasContext(inCanvas);\n if (!ctx) return;\n ctx.lineJoin = 'round';\n ctx.font = localOptions.font;\n for (const h of result) {\n if (localOptions.drawBoxes) {\n ctx.strokeStyle = localOptions.color;\n ctx.fillStyle = localOptions.color;\n rect(ctx, h.box[0], h.box[1], h.box[2], h.box[3], localOptions);\n if (localOptions.drawLabels) {\n const label = `${h.label} ${Math.round(100 * h.score)}%`;\n if (localOptions.shadowColor && localOptions.shadowColor !== '') {\n ctx.fillStyle = localOptions.shadowColor;\n ctx.fillText(label, h.box[0] + 3, 1 + h.box[1] + localOptions.lineHeight, h.box[2]);\n }\n ctx.fillStyle = localOptions.labelColor;\n ctx.fillText(label, h.box[0] + 2, 0 + h.box[1] + localOptions.lineHeight, h.box[2]);\n }\n ctx.stroke();\n }\n }\n}\n", "import { mergeDeep } from '../util/util';\nimport { getCanvasContext } from './primitives';\nimport { options } from './options';\nimport type { GestureResult } from '../result';\nimport type { AnyCanvas, DrawOptions } from '../exports';\n\n/** draw detected gestures */\nexport async function gesture(inCanvas: AnyCanvas, result: Array, drawOptions?: Partial) {\n const localOptions = mergeDeep(options, drawOptions);\n if (!result || !inCanvas) return;\n if (localOptions.drawGestures) {\n const ctx = getCanvasContext(inCanvas);\n if (!ctx) return;\n ctx.font = localOptions.font;\n ctx.fillStyle = localOptions.color;\n let i = 1;\n for (let j = 0; j < result.length; j++) {\n let where: unknown[] = []; // what&where is a record\n let what: unknown[] = []; // what&where is a record\n [where, what] = Object.entries(result[j]);\n if ((what.length > 1) && ((what[1] as string).length > 0)) {\n const who = where[1] as number > 0 ? `#${where[1]}` : '';\n const label = `${where[0]} ${who}: ${what[1]}`;\n if (localOptions.shadowColor && localOptions.shadowColor !== '') {\n ctx.fillStyle = localOptions.shadowColor;\n ctx.fillText(label, 8, 2 + (i * localOptions.lineHeight));\n }\n ctx.fillStyle = localOptions.labelColor;\n ctx.fillText(label, 6, 0 + (i * localOptions.lineHeight));\n i += 1;\n }\n }\n }\n}\n", "import type { Tensor } from '../tfjs/types';\nimport type { FaceResult } from '../result';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport { meshAnnotations } from './facemeshcoords';\n\nconst expandFact = 0.1;\nconst alpha = 0.5;\n\n// point inclusion in polygon based on https://wrf.ecse.rpi.edu/Research/Short_Notes/pnpoly.html\nfunction insidePoly(x: number, y: number, polygon: Array<{ x: number, y: number }>): boolean {\n let inside = false;\n let j = polygon.length - 1;\n for (let i = 0; i < polygon.length; j = i++) {\n if (((polygon[i].y > y) !== (polygon[j].y > y)) && (x < (polygon[j].x - polygon[i].x) * (y - polygon[i].y) / (polygon[j].y - polygon[i].y) + polygon[i].x)) inside = !inside;\n }\n return inside;\n}\n\nexport async function mask(face: FaceResult): Promise {\n if (!face.tensor) return face.tensor;\n if (!face.mesh || face.mesh.length < 100) return face.tensor;\n const width = face.tensor.shape[2] || 0;\n const height = face.tensor.shape[1] || 0;\n const buffer = await face.tensor.buffer();\n let silhouette: Array<{ x: number, y: number }> = [];\n for (const pt of meshAnnotations.silhouette) silhouette.push({ x: (face.mesh[pt][0] - face.box[0]) / face.box[2], y: (face.mesh[pt][1] - face.box[1]) / face.box[3] }); // add all silhouette points scaled to local box\n if (expandFact && expandFact > 0) silhouette = silhouette.map((pt) => ({ x: pt.x > 0.5 ? pt.x + expandFact : pt.x - expandFact, y: pt.y > 0.5 ? pt.y + expandFact : pt.y - expandFact })); // expand silhouette\n for (let x = 0; x < width; x++) {\n for (let y = 0; y < height; y++) {\n const inside = insidePoly(x / width, y / width, silhouette);\n if (!inside) {\n buffer.set(alpha * buffer.get(0, y, x, 0), 0, y, x, 0);\n buffer.set(alpha * buffer.get(0, y, x, 1), 0, y, x, 1);\n buffer.set(alpha * buffer.get(0, y, x, 2), 0, y, x, 2);\n }\n }\n }\n const output = buffer.toTensor();\n tf.dispose(buffer);\n return output;\n}\n", "import type { Point, FaceResult } from '../result';\n\ntype Vector = [number, number, number];\n\nconst calculateGaze = (face: FaceResult): { bearing: number, strength: number } => {\n const radians = (pt1: Point, pt2: Point) => Math.atan2(pt1[1] - pt2[1], pt1[0] - pt2[0]); // function to calculate angle between any two points\n if (!face.annotations['rightEyeIris'] || !face.annotations['leftEyeIris']) return { bearing: 0, strength: 0 };\n\n const offsetIris = [0, -0.1]; // iris center may not align with average of eye extremes\n const eyeRatio = 1; // factor to normalize changes x vs y\n\n const left = (face.mesh[33][2] || 0) > (face.mesh[263][2] || 0); // pick left or right eye depending which one is closer bazed on outsize point z axis\n const irisCenter = left ? face.mesh[473] : face.mesh[468];\n const eyeCenter = left // eye center is average of extreme points on x axis for both x and y, ignoring y extreme points as eyelids naturally open/close more when gazing up/down so relative point is less precise\n ? [(face.mesh[133][0] + face.mesh[33][0]) / 2, (face.mesh[133][1] + face.mesh[33][1]) / 2]\n : [(face.mesh[263][0] + face.mesh[362][0]) / 2, (face.mesh[263][1] + face.mesh[362][1]) / 2];\n const eyeSize = left // eye size is difference between extreme points for both x and y, used to normalize & squarify eye dimensions\n ? [face.mesh[133][0] - face.mesh[33][0], face.mesh[23][1] - face.mesh[27][1]]\n : [face.mesh[263][0] - face.mesh[362][0], face.mesh[253][1] - face.mesh[257][1]];\n const eyeDiff: Point = [ // x distance between extreme point and center point normalized with eye size\n (eyeCenter[0] - irisCenter[0]) / eyeSize[0] - offsetIris[0],\n eyeRatio * (irisCenter[1] - eyeCenter[1]) / eyeSize[1] - offsetIris[1],\n ];\n let strength = Math.sqrt((eyeDiff[0] * eyeDiff[0]) + (eyeDiff[1] * eyeDiff[1])); // vector length is a diagonal between two differences\n strength = Math.min(strength, face.boxRaw[2] / 2, face.boxRaw[3] / 2); // limit strength to half of box size to avoid clipping due to low precision\n const bearing = (radians([0, 0], eyeDiff) + (Math.PI / 2)) % Math.PI; // using eyeDiff instead eyeCenter/irisCenter combo due to manual adjustments and rotate clockwise 90degrees\n return { bearing, strength };\n};\n\nexport const calculateFaceAngle = (face: FaceResult, imageSize: [number, number]): {\n angle: { pitch: number, yaw: number, roll: number },\n matrix: [number, number, number, number, number, number, number, number, number],\n gaze: { bearing: number, strength: number },\n} => {\n // const degrees = (theta) => Math.abs(((theta * 180) / Math.PI) % 360);\n const normalize = (v: Vector): Vector => { // normalize vector\n const length = Math.sqrt(v[0] * v[0] + v[1] * v[1] + v[2] * v[2]);\n v[0] /= length;\n v[1] /= length;\n v[2] /= length;\n return v;\n };\n const subVectors = (a: Vector, b: Vector): Vector => { // vector subtraction (a - b)\n const x = a[0] - b[0];\n const y = a[1] - b[1];\n const z = a[2] - b[2];\n return [x, y, z];\n };\n const crossVectors = (a: Vector, b: Vector): Vector => { // vector cross product (a x b)\n const x = a[1] * b[2] - a[2] * b[1];\n const y = a[2] * b[0] - a[0] * b[2];\n const z = a[0] * b[1] - a[1] * b[0];\n return [x, y, z];\n };\n // 3x3 rotation matrix to Euler angles based on https://www.geometrictools.com/Documentation/EulerAngles.pdf\n const rotationMatrixToEulerAngle = (r: number[]): { pitch: number, yaw: number, roll: number } => {\n // eslint-disable-next-line no-unused-vars, @typescript-eslint/no-unused-vars\n const [r00, _r01, _r02, r10, r11, r12, r20, r21, r22] = r;\n let thetaX: number;\n let thetaY: number;\n let thetaZ: number;\n if (r10 < 1) { // YZX calculation\n if (r10 > -1) {\n thetaZ = Math.asin(r10);\n thetaY = Math.atan2(-r20, r00);\n thetaX = Math.atan2(-r12, r11);\n } else {\n thetaZ = -Math.PI / 2;\n thetaY = -Math.atan2(r21, r22);\n thetaX = 0;\n }\n } else {\n thetaZ = Math.PI / 2;\n thetaY = Math.atan2(r21, r22);\n thetaX = 0;\n }\n if (isNaN(thetaX)) thetaX = 0;\n if (isNaN(thetaY)) thetaY = 0;\n if (isNaN(thetaZ)) thetaZ = 0;\n return { pitch: 2 * -thetaX, yaw: 2 * -thetaY, roll: 2 * -thetaZ };\n };\n\n /*\n const meshToEulerAngle = (mesh) => { // simple Euler angle calculation based existing 3D mesh\n const radians = (a1, a2, b1, b2) => Math.atan2(b2 - a2, b1 - a1);\n return { // values are in radians in range of -pi/2 to pi/2 which is -90 to +90 degrees, value of 0 means center\n pitch: radians(mesh[10][1], mesh[10][2], mesh[152][1], mesh[152][2]), // looking at y,z of top and bottom points of the face // pitch is face move up/down\n yaw: radians(mesh[33][0], mesh[33][2], mesh[263][0], mesh[263][2]), // looking at x,z of outside corners of leftEye and rightEye // yaw is face turn left/right\n roll: radians(mesh[33][0], mesh[33][1], mesh[263][0], mesh[263][1]), // looking at x,y of outside corners of leftEye and rightEye // roll is face lean left/right\n };\n };\n */\n\n // initialize gaze and mesh\n const mesh = face.meshRaw;\n if (!mesh || mesh.length < 300) return { angle: { pitch: 0, yaw: 0, roll: 0 }, matrix: [1, 0, 0, 0, 1, 0, 0, 0, 1], gaze: { bearing: 0, strength: 0 } };\n\n const size = Math.max(face.boxRaw[2] * imageSize[0], face.boxRaw[3] * imageSize[1]) / 1.5;\n // top, bottom, left, right\n const pts: Point[] = [mesh[10], mesh[152], mesh[234], mesh[454]].map((pt) => [pt[0] * imageSize[0] / size, pt[1] * imageSize[1] / size, pt[2]] as Point); // make the xyz coordinates proportional, independent of the image/box size\n\n const y_axis = normalize(subVectors(pts[1] as Vector, pts[0] as Vector));\n let x_axis = normalize(subVectors(pts[3] as Vector, pts[2] as Vector));\n const z_axis = normalize(crossVectors(x_axis, y_axis));\n // adjust x_axis to make sure that all axes are perpendicular to each other\n x_axis = crossVectors(y_axis, z_axis);\n\n // Rotation Matrix from Axis Vectors - http://renderdan.blogspot.com/2006/05/rotation-matrix-from-axis-vectors.html\n // 3x3 rotation matrix is flatten to array in row-major order. Note that the rotation represented by this matrix is inverted.\n const matrix: [number, number, number, number, number, number, number, number, number] = [\n x_axis[0], x_axis[1], x_axis[2],\n y_axis[0], y_axis[1], y_axis[2],\n z_axis[0], z_axis[1], z_axis[2],\n ];\n const angle = rotationMatrixToEulerAngle(matrix);\n // const angle = meshToEulerAngle(mesh);\n\n // we have iris keypoints so we can calculate gaze direction\n const gaze = mesh.length === 478 ? calculateGaze(face) : { bearing: 0, strength: 0 };\n\n return { angle, matrix, gaze };\n};\n", "/**\n * Face algorithm implementation\n * Uses FaceMesh, Emotion and FaceRes models to create a unified pipeline\n */\n\nimport { log, now } from '../util/util';\nimport { env } from '../util/env';\nimport * as tf from '../../dist/tfjs.esm.js';\nimport * as facemesh from './facemesh';\nimport * as emotion from '../gear/emotion';\nimport * as faceres from './faceres';\nimport * as mask from './mask';\nimport * as antispoof from './antispoof';\nimport * as liveness from './liveness';\nimport * as gear from '../gear/gear';\nimport * as ssrnetAge from '../gear/ssrnet-age';\nimport * as ssrnetGender from '../gear/ssrnet-gender';\nimport * as mobilefacenet from './mobilefacenet';\nimport type { FaceResult, Emotion, Gender, Race } from '../result';\nimport type { Tensor } from '../tfjs/types';\nimport type { Human } from '../human';\nimport { calculateFaceAngle } from './angles';\n\ntype DescRes = { age: number, gender: Gender, genderScore: number, descriptor: number[], race?: { score: number, race: Race }[] };\n\nexport const detectFace = async (instance: Human /* instance of human */, input: Tensor): Promise => {\n // run facemesh, includes blazeface and iris\n // eslint-disable-next-line no-async-promise-executor\n let timeStamp: number = now();\n let ageRes: { age: number } | Promise<{ age: number }> | null;\n let gearRes: gear.GearType | Promise | null;\n let genderRes: { gender: string, genderScore: number } | Promise<{ gender: string, genderScore: number }> | null;\n let emotionRes: { score: number, emotion: Emotion }[] | Promise<{ score: number, emotion: Emotion }[]>;\n let mobilefacenetRes: number[] | Promise | null;\n let antispoofRes: number | Promise | null;\n let livenessRes: number | Promise | null;\n let descRes: DescRes | Promise | null;\n\n const faceRes: Array = [];\n instance.state = 'run:face';\n\n const faces = await facemesh.predict(input, instance.config);\n instance.performance.face = env.perfadd ? (instance.performance.face || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n if (!input.shape || input.shape.length !== 4) return [];\n if (!faces) return [];\n // for (const face of faces) {\n for (let i = 0; i < faces.length; i++) {\n instance.analyze('Get Face');\n\n // is something went wrong, skip the face\n // @ts-ignore possibly undefied\n if (!faces[i].tensor || faces[i].tensor['isDisposedInternal']) {\n log('Face object is disposed:', faces[i].tensor);\n continue;\n }\n\n // optional face mask\n if (instance.config.face.detector?.mask) {\n const masked = await mask.mask(faces[i]);\n tf.dispose(faces[i].tensor);\n faces[i].tensor = masked as Tensor;\n }\n\n // calculate face angles\n const rotation = faces[i].mesh && (faces[i].mesh.length > 200) ? calculateFaceAngle(faces[i], [input.shape[2], input.shape[1]]) : null;\n\n // run emotion, inherits face from blazeface\n instance.analyze('Start Emotion:');\n if (instance.config.async) {\n emotionRes = instance.config.face.emotion?.enabled ? emotion.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : [];\n } else {\n instance.state = 'run:emotion';\n timeStamp = now();\n emotionRes = instance.config.face.emotion?.enabled ? await emotion.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : [];\n instance.performance.emotion = env.perfadd ? (instance.performance.emotion || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n }\n instance.analyze('End Emotion:');\n\n // run antispoof, inherits face from blazeface\n instance.analyze('Start AntiSpoof:');\n if (instance.config.async) {\n antispoofRes = instance.config.face.antispoof?.enabled ? antispoof.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : 0;\n } else {\n instance.state = 'run:antispoof';\n timeStamp = now();\n antispoofRes = instance.config.face.antispoof?.enabled ? await antispoof.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : 0;\n instance.performance.antispoof = env.perfadd ? (instance.performance.antispoof || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n }\n instance.analyze('End AntiSpoof:');\n\n // run liveness, inherits face from blazeface\n instance.analyze('Start Liveness:');\n if (instance.config.async) {\n livenessRes = instance.config.face.liveness?.enabled ? liveness.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : 0;\n } else {\n instance.state = 'run:liveness';\n timeStamp = now();\n livenessRes = instance.config.face.liveness?.enabled ? await liveness.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : 0;\n instance.performance.liveness = env.perfadd ? (instance.performance.antispoof || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n }\n instance.analyze('End Liveness:');\n\n // run gear, inherits face from blazeface\n instance.analyze('Start GEAR:');\n if (instance.config.async) {\n gearRes = instance.config.face['gear']?.enabled ? gear.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : null;\n } else {\n instance.state = 'run:gear';\n timeStamp = now();\n gearRes = instance.config.face['gear']?.enabled ? await gear.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : null;\n instance.performance.gear = Math.trunc(now() - timeStamp);\n }\n instance.analyze('End GEAR:');\n\n // run gear, inherits face from blazeface\n instance.analyze('Start SSRNet:');\n if (instance.config.async) {\n ageRes = instance.config.face['ssrnet']?.enabled ? ssrnetAge.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : null;\n genderRes = instance.config.face['ssrnet']?.enabled ? ssrnetGender.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : null;\n } else {\n instance.state = 'run:ssrnet';\n timeStamp = now();\n ageRes = instance.config.face['ssrnet']?.enabled ? await ssrnetAge.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : null;\n genderRes = instance.config.face['ssrnet']?.enabled ? await ssrnetGender.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : null;\n instance.performance.ssrnet = Math.trunc(now() - timeStamp);\n }\n instance.analyze('End SSRNet:');\n\n // run gear, inherits face from blazeface\n instance.analyze('Start MobileFaceNet:');\n if (instance.config.async) {\n mobilefacenetRes = instance.config.face['mobilefacenet']?.enabled ? mobilefacenet.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : null;\n } else {\n instance.state = 'run:mobilefacenet';\n timeStamp = now();\n mobilefacenetRes = instance.config.face['mobilefacenet']?.enabled ? await mobilefacenet.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : null;\n instance.performance.mobilefacenet = Math.trunc(now() - timeStamp);\n }\n instance.analyze('End MobileFaceNet:');\n\n // run emotion, inherits face from blazeface\n instance.analyze('Start Description:');\n if (instance.config.async) {\n descRes = instance.config.face.description?.enabled ? faceres.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : null;\n } else {\n instance.state = 'run:description';\n timeStamp = now();\n descRes = instance.config.face.description?.enabled ? await faceres.predict(faces[i].tensor || tf.tensor([]), instance.config, i, faces.length) : null;\n instance.performance.description = env.perfadd ? (instance.performance.description || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n }\n instance.analyze('End Description:');\n\n // if async wait for results\n if (instance.config.async) {\n [ageRes, genderRes, emotionRes, mobilefacenetRes, descRes, gearRes, antispoofRes, livenessRes] = await Promise.all([ageRes, genderRes, emotionRes, mobilefacenetRes, descRes, gearRes, antispoofRes, livenessRes]);\n }\n instance.analyze('Finish Face:');\n\n if (instance.config.face['ssrnet']?.enabled && ageRes && genderRes) { // override age/gender if ssrnet model is used\n descRes = {\n ...(descRes as DescRes),\n age: (ageRes as { age: number}).age,\n gender: (genderRes as { gender: Gender, genderScore: number }).gender,\n genderScore: (genderRes as { gender: Gender, genderScore: number }).genderScore,\n };\n }\n if (instance.config.face['gear']?.enabled && gearRes) { // override age/gender/race if gear model is used\n descRes = {\n ...(descRes as DescRes),\n age: (gearRes as gear.GearType).age,\n gender: (gearRes as gear.GearType).gender,\n genderScore: (gearRes as gear.GearType).genderScore,\n race: (gearRes as gear.GearType).race,\n };\n }\n if (instance.config.face['mobilefacenet']?.enabled && mobilefacenetRes) { // override descriptor if embedding model is used\n (descRes as DescRes).descriptor = mobilefacenetRes as number[];\n }\n\n // calculate iris distance\n // iris: array[ center, left, top, right, bottom]\n if (!instance.config.face.iris?.enabled) {\n // if (faces[i]?.annotations?.leftEyeIris) delete faces[i].annotations.leftEyeIris;\n // if (faces[i]?.annotations?.rightEyeIris) delete faces[i].annotations.rightEyeIris;\n }\n const irisSize = (faces[i].annotations && faces[i].annotations.leftEyeIris && faces[i].annotations.leftEyeIris[0] && faces[i].annotations.rightEyeIris && faces[i].annotations.rightEyeIris[0]\n && (faces[i].annotations.leftEyeIris.length > 0) && (faces[i].annotations.rightEyeIris.length > 0)\n && (faces[i].annotations.leftEyeIris[0] !== null) && (faces[i].annotations.rightEyeIris[0] !== null))\n ? Math.max(Math.abs(faces[i].annotations.leftEyeIris[3][0] - faces[i].annotations.leftEyeIris[1][0]), Math.abs(faces[i].annotations.rightEyeIris[4][1] - faces[i].annotations.rightEyeIris[2][1])) / input.shape[2]\n : 0; // note: average human iris size is 11.7mm\n\n // optionally return tensor\n const tensor = instance.config.face.detector?.return ? tf.squeeze(faces[i].tensor) : null;\n // dispose original face tensor\n tf.dispose(faces[i].tensor);\n // delete temp face image\n if (faces[i].tensor) delete faces[i].tensor;\n // combine results\n const res: FaceResult = {\n ...faces[i],\n id: i,\n };\n if ((descRes as DescRes)?.age) res.age = (descRes as DescRes).age as number;\n if ((descRes as DescRes)?.gender) res.gender = (descRes as DescRes).gender as Gender;\n if ((descRes as DescRes)?.genderScore) res.genderScore = (descRes as DescRes)?.genderScore as number;\n if ((descRes as DescRes)?.descriptor) res.embedding = (descRes as DescRes)?.descriptor as Array;\n if ((descRes as DescRes)?.race) res.race = (descRes as DescRes)?.race as { score: number, race: Race }[];\n if (emotionRes) res.emotion = emotionRes as Array<{ score: number, emotion: Emotion }>;\n if (antispoofRes) res.real = antispoofRes as number;\n if (livenessRes) res.live = livenessRes as number;\n if (irisSize && irisSize !== 0) res.iris = Math.trunc(500 / irisSize / 11.7) / 100;\n if (rotation) res.rotation = rotation;\n if (tensor) res.tensor = tensor;\n faceRes.push(res);\n instance.analyze('End Face');\n }\n instance.analyze('End FaceMesh:');\n if (instance.config.async) {\n if (instance.performance.face) delete instance.performance.face;\n if (instance.performance.age) delete instance.performance.age;\n if (instance.performance.gender) delete instance.performance.gender;\n if (instance.performance.emotion) delete instance.performance.emotion;\n }\n return faceRes;\n};\n", "/**\n * Gesture detection algorithm\n */\n\nimport type { GestureResult, BodyResult, FaceResult, HandResult, Point } from '../result';\nimport * as fingerPose from '../hand/fingerpose';\n\n/** face gesture type */\nexport type FaceGesture =\n `facing ${'left' | 'center' | 'right'}`\n | `blink ${'left' | 'right'} eye`\n | `mouth ${number}% open`\n | `head ${'up' | 'down'}`;\n\n/** iris gesture type */\nexport type IrisGesture =\n 'facing center'\n | `looking ${'left' | 'right' | 'up' | 'down'}`\n | 'looking center';\n\n/** body gesture type */\nexport type BodyGesture =\n `leaning ${'left' | 'right'}`\n | `raise ${'left' | 'right'} hand`\n | 'i give up';\n\n/** hand gesture type */\nexport type HandGesture =\n `${'thumb' | 'index' | 'middle' | 'ring' | 'pinky'} forward`\n | `${'thumb' | 'index' | 'middle' | 'ring' | 'pinky'} up`\n | 'victory'\n | 'thumbs up';\n\nexport const body = (res: BodyResult[]): GestureResult[] => {\n if (!res) return [];\n const gestures: Array<{ body: number, gesture: BodyGesture }> = [];\n for (let i = 0; i < res.length; i++) {\n // raising hands\n const leftWrist = res[i].keypoints.find((a) => (a.part === 'leftWrist'));\n const rightWrist = res[i].keypoints.find((a) => (a.part === 'rightWrist'));\n const nose = res[i].keypoints.find((a) => (a.part === 'nose'));\n if (nose && leftWrist && rightWrist && (leftWrist.position[1] < nose.position[1]) && (rightWrist.position[1] < nose.position[1])) gestures.push({ body: i, gesture: 'i give up' });\n else if (nose && leftWrist && (leftWrist.position[1] < nose.position[1])) gestures.push({ body: i, gesture: 'raise left hand' });\n else if (nose && rightWrist && (rightWrist.position[1] < nose.position[1])) gestures.push({ body: i, gesture: 'raise right hand' });\n\n // leaning\n const leftShoulder = res[i].keypoints.find((a) => (a.part === 'leftShoulder'));\n const rightShoulder = res[i].keypoints.find((a) => (a.part === 'rightShoulder'));\n if (leftShoulder && rightShoulder && Math.abs(leftShoulder.positionRaw[1] - rightShoulder.positionRaw[1]) > 0.1) {\n gestures.push({ body: i, gesture: `leaning ${(leftShoulder.position[1] > rightShoulder.position[1]) ? 'left' : 'right'}` });\n }\n }\n return gestures;\n};\n\nexport const face = (res: FaceResult[]): GestureResult[] => {\n if (!res) return [];\n const gestures: Array<{ face: number, gesture: FaceGesture }> = [];\n for (let i = 0; i < res.length; i++) {\n if (res[i].mesh && res[i].mesh.length > 450) {\n const zDiff = (res[i].mesh[33][2] || 0) - (res[i].mesh[263][2] || 0);\n const xDiff = res[i].mesh[33][0] - res[i].mesh[263][0];\n if (Math.abs(zDiff / xDiff) <= 0.15) gestures.push({ face: i, gesture: 'facing center' });\n else gestures.push({ face: i, gesture: `facing ${zDiff < 0 ? 'left' : 'right'}` });\n const openLeft = Math.abs(res[i].mesh[374][1] - res[i].mesh[386][1]) / Math.abs(res[i].mesh[443][1] - res[i].mesh[450][1]); // center of eye inner lid y coord div center of wider eye border y coord\n if (openLeft < 0.2) gestures.push({ face: i, gesture: 'blink left eye' });\n const openRight = Math.abs(res[i].mesh[145][1] - res[i].mesh[159][1]) / Math.abs(res[i].mesh[223][1] - res[i].mesh[230][1]); // center of eye inner lid y coord div center of wider eye border y coord\n if (openRight < 0.2) gestures.push({ face: i, gesture: 'blink right eye' });\n const mouthOpen = Math.min(100, 500 * Math.abs(res[i].mesh[13][1] - res[i].mesh[14][1]) / Math.abs(res[i].mesh[10][1] - res[i].mesh[152][1]));\n if (mouthOpen > 10) gestures.push({ face: i, gesture: `mouth ${Math.trunc(mouthOpen)}% open` });\n const chinDepth = res[i].mesh[152][2] || 0;\n if (Math.abs(chinDepth) > 10) gestures.push({ face: i, gesture: `head ${chinDepth < 0 ? 'up' : 'down'}` });\n }\n }\n return gestures;\n};\n\nexport const iris = (res: FaceResult[]): GestureResult[] => {\n if (!res) return [];\n const gestures: Array<{ iris: number, gesture: IrisGesture }> = [];\n for (let i = 0; i < res.length; i++) {\n if (!res[i].annotations || !res[i].annotations.leftEyeIris || !res[i].annotations.leftEyeIris[0] || !res[i].annotations.rightEyeIris || !res[i].annotations.rightEyeIris[0]) continue;\n const sizeXLeft = res[i].annotations.leftEyeIris[3][0] - res[i].annotations.leftEyeIris[1][0];\n const sizeYLeft = res[i].annotations.leftEyeIris[4][1] - res[i].annotations.leftEyeIris[2][1];\n const areaLeft = Math.abs(sizeXLeft * sizeYLeft);\n\n const sizeXRight = res[i].annotations.rightEyeIris[3][0] - res[i].annotations.rightEyeIris[1][0];\n const sizeYRight = res[i].annotations.rightEyeIris[4][1] - res[i].annotations.rightEyeIris[2][1];\n const areaRight = Math.abs(sizeXRight * sizeYRight);\n\n let center = false;\n const difference = Math.abs(areaLeft - areaRight) / Math.max(areaLeft, areaRight);\n if (difference < 0.25) {\n center = true;\n gestures.push({ iris: i, gesture: 'facing center' });\n }\n\n const leftIrisCenterX = Math.abs(res[i].mesh[263][0] - res[i].annotations.leftEyeIris[0][0]) / res[i].box[2];\n const rightIrisCenterX = Math.abs(res[i].mesh[33][0] - res[i].annotations.rightEyeIris[0][0]) / res[i].box[2];\n if (leftIrisCenterX > 0.06 || rightIrisCenterX > 0.06) center = false;\n if (leftIrisCenterX > rightIrisCenterX) { // check eye with bigger offset\n if (leftIrisCenterX > 0.05) gestures.push({ iris: i, gesture: 'looking right' });\n } else {\n if (rightIrisCenterX > 0.05) gestures.push({ iris: i, gesture: 'looking left' });\n }\n\n const rightIrisCenterY = Math.abs(res[i].mesh[145][1] - res[i].annotations.rightEyeIris[0][1]) / res[i].box[3];\n const leftIrisCenterY = Math.abs(res[i].mesh[374][1] - res[i].annotations.leftEyeIris[0][1]) / res[i].box[3];\n if (leftIrisCenterY < 0.01 || rightIrisCenterY < 0.01 || leftIrisCenterY > 0.022 || rightIrisCenterY > 0.022) center = false;\n if (leftIrisCenterY < 0.01 || rightIrisCenterY < 0.01) gestures.push({ iris: i, gesture: 'looking down' });\n if (leftIrisCenterY > 0.022 || rightIrisCenterY > 0.022) gestures.push({ iris: i, gesture: 'looking up' });\n\n // still center;\n if (center) gestures.push({ iris: i, gesture: 'looking center' });\n }\n return gestures;\n};\n\nexport const hand = (res: HandResult[]): GestureResult[] => {\n if (!res) return [];\n const gestures: Array<{ hand: number, gesture: HandGesture }> = [];\n for (let i = 0; i < res.length; i++) {\n const fingers: Array<{ name: string, position: Point }> = [];\n if (res[i]['annotations']) {\n for (const [finger, pos] of Object.entries(res[i]['annotations'])) {\n if (finger !== 'palmBase' && Array.isArray(pos) && pos[0]) fingers.push({ name: finger.toLowerCase(), position: pos[0] }); // get tip of each finger\n }\n }\n if (fingers && fingers.length > 0) {\n const closest = fingers.reduce((best, a) => ((best.position[2] || 0) < (a.position[2] || 0) ? best : a));\n gestures.push({ hand: i, gesture: `${closest.name} forward` as HandGesture });\n const highest = fingers.reduce((best, a) => (best.position[1] < a.position[1] ? best : a));\n gestures.push({ hand: i, gesture: `${highest.name} up` as HandGesture });\n }\n if (res[i]['keypoints']) {\n const poses = fingerPose.match(res[i]['keypoints']);\n for (const pose of poses) gestures.push({ hand: i, gesture: pose.name as HandGesture });\n }\n }\n return gestures;\n};\n", "/**\n * Results interpolation for smoothening of video detection results inbetween detected frames\n */\n\nimport type { Result, FaceResult, BodyResult, HandResult, ObjectResult, GestureResult, PersonResult, Box, Point, BodyLandmark, BodyAnnotation } from '../result';\nimport type { Config } from '../config';\n\nimport * as moveNetCoords from '../body/movenetcoords';\nimport * as blazePoseCoords from '../body/blazeposecoords';\nimport * as efficientPoseCoords from '../body/efficientposecoords';\nimport { now } from './util';\nimport { env } from './env';\n\nconst bufferedResult: Result = { face: [], body: [], hand: [], gesture: [], object: [], persons: [], performance: {}, timestamp: 0, error: null };\nlet interpolateTime = 0;\n\nexport function calc(newResult: Result, config: Config): Result {\n const t0 = now();\n if (!newResult) return { face: [], body: [], hand: [], gesture: [], object: [], persons: [], performance: {}, timestamp: 0, error: null };\n // each record is only updated using deep clone when number of detected record changes, otherwise it will converge by itself\n // otherwise bufferedResult is a shallow clone of result plus updated local calculated values\n // thus mixing by-reference and by-value assignments to minimize memory operations\n\n const elapsed = Date.now() - newResult.timestamp;\n // curve fitted: buffer = 8 - ln(delay)\n // interpolation formula: current = ((buffer - 1) * previous + live) / buffer\n // - at 50ms delay buffer = ~4.1 => 28% towards live data\n // - at 250ms delay buffer = ~2.5 => 40% towards live data\n // - at 500ms delay buffer = ~1.8 => 55% towards live data\n // - at 750ms delay buffer = ~1.4 => 71% towards live data\n // - at 1sec delay buffer = 1 which means live data is used\n const bufferedFactor = elapsed < 1000 ? 8 - Math.log(elapsed + 1) : 1;\n\n if (newResult.canvas) bufferedResult.canvas = newResult.canvas;\n if (newResult.error) bufferedResult.error = newResult.error;\n\n // interpolate body results\n if (!bufferedResult.body || (newResult.body.length !== bufferedResult.body.length)) {\n bufferedResult.body = JSON.parse(JSON.stringify(newResult.body as BodyResult[])); // deep clone once\n } else {\n for (let i = 0; i < newResult.body.length; i++) {\n const box = newResult.body[i].box // update box\n .map((newBoxCoord, j) => ((bufferedFactor - 1) * bufferedResult.body[i].box[j] + newBoxCoord) / bufferedFactor) as Box;\n const boxRaw = newResult.body[i].boxRaw // update boxRaw\n .map((newBoxCoord, j) => ((bufferedFactor - 1) * bufferedResult.body[i].boxRaw[j] + newBoxCoord) / bufferedFactor) as Box;\n const keypoints = (newResult.body[i].keypoints // update keypoints\n .map((newKpt, j) => ({\n score: newKpt.score,\n part: newKpt.part as BodyLandmark,\n position: [\n bufferedResult.body[i].keypoints[j] ? ((bufferedFactor - 1) * (bufferedResult.body[i].keypoints[j].position[0] || 0) + (newKpt.position[0] || 0)) / bufferedFactor : newKpt.position[0],\n bufferedResult.body[i].keypoints[j] ? ((bufferedFactor - 1) * (bufferedResult.body[i].keypoints[j].position[1] || 0) + (newKpt.position[1] || 0)) / bufferedFactor : newKpt.position[1],\n bufferedResult.body[i].keypoints[j] ? ((bufferedFactor - 1) * (bufferedResult.body[i].keypoints[j].position[2] || 0) + (newKpt.position[2] || 0)) / bufferedFactor : newKpt.position[2],\n ],\n positionRaw: [\n bufferedResult.body[i].keypoints[j] ? ((bufferedFactor - 1) * (bufferedResult.body[i].keypoints[j].positionRaw[0] || 0) + (newKpt.positionRaw[0] || 0)) / bufferedFactor : newKpt.positionRaw[0],\n bufferedResult.body[i].keypoints[j] ? ((bufferedFactor - 1) * (bufferedResult.body[i].keypoints[j].positionRaw[1] || 0) + (newKpt.positionRaw[1] || 0)) / bufferedFactor : newKpt.positionRaw[1],\n bufferedResult.body[i].keypoints[j] ? ((bufferedFactor - 1) * (bufferedResult.body[i].keypoints[j].positionRaw[2] || 0) + (newKpt.positionRaw[2] || 0)) / bufferedFactor : newKpt.positionRaw[2],\n ],\n distance: [\n bufferedResult.body[i].keypoints[j] ? ((bufferedFactor - 1) * (bufferedResult.body[i].keypoints[j].distance?.[0] || 0) + (newKpt.distance?.[0] || 0)) / bufferedFactor : newKpt.distance?.[0],\n bufferedResult.body[i].keypoints[j] ? ((bufferedFactor - 1) * (bufferedResult.body[i].keypoints[j].distance?.[1] || 0) + (newKpt.distance?.[1] || 0)) / bufferedFactor : newKpt.distance?.[1],\n bufferedResult.body[i].keypoints[j] ? ((bufferedFactor - 1) * (bufferedResult.body[i].keypoints[j].distance?.[2] || 0) + (newKpt.distance?.[2] || 0)) / bufferedFactor : newKpt.distance?.[2],\n ],\n }))) as Array<{ score: number, part: BodyLandmark, position: [number, number, number?], positionRaw: [number, number, number?] }>;\n\n const annotations: Record = {} as Record; // recreate annotations\n let coords = { connected: {} };\n if (config.body?.modelPath?.includes('efficientpose')) coords = efficientPoseCoords;\n else if (config.body?.modelPath?.includes('blazepose')) coords = blazePoseCoords;\n else if (config.body?.modelPath?.includes('movenet')) coords = moveNetCoords;\n for (const [name, indexes] of Object.entries(coords.connected as Record)) {\n const pt: Array = [];\n for (let j = 0; j < indexes.length - 1; j++) {\n const pt0 = keypoints.find((kp) => kp.part === indexes[j]);\n const pt1 = keypoints.find((kp) => kp.part === indexes[j + 1]);\n // if (pt0 && pt1 && pt0.score > (config.body.minConfidence || 0) && pt1.score > (config.body.minConfidence || 0)) pt.push([pt0.position, pt1.position]);\n if (pt0 && pt1) pt.push([pt0.position, pt1.position]);\n }\n annotations[name] = pt;\n }\n bufferedResult.body[i] = { ...newResult.body[i], box, boxRaw, keypoints, annotations: annotations as BodyResult['annotations'] }; // shallow clone plus updated values\n }\n }\n\n // interpolate hand results\n if (!bufferedResult.hand || (newResult.hand.length !== bufferedResult.hand.length)) {\n bufferedResult.hand = JSON.parse(JSON.stringify(newResult.hand as HandResult[])); // deep clone once\n } else {\n for (let i = 0; i < newResult.hand.length; i++) {\n const box = (newResult.hand[i].box// update box\n .map((b, j) => ((bufferedFactor - 1) * bufferedResult.hand[i].box[j] + b) / bufferedFactor)) as Box;\n const boxRaw = (newResult.hand[i].boxRaw // update boxRaw\n .map((b, j) => ((bufferedFactor - 1) * bufferedResult.hand[i].boxRaw[j] + b) / bufferedFactor)) as Box;\n if (bufferedResult.hand[i].keypoints.length !== newResult.hand[i].keypoints.length) bufferedResult.hand[i].keypoints = newResult.hand[i].keypoints; // reset keypoints as previous frame did not have them\n const keypoints = newResult.hand[i].keypoints && newResult.hand[i].keypoints.length > 0 ? newResult.hand[i].keypoints // update landmarks\n .map((landmark, j) => landmark\n .map((coord, k) => (((bufferedFactor - 1) * (bufferedResult.hand[i].keypoints[j][k] || 1) + (coord || 0)) / bufferedFactor)) as Point)\n : [];\n let annotations = {};\n if (Object.keys(bufferedResult.hand[i].annotations).length !== Object.keys(newResult.hand[i].annotations).length) {\n bufferedResult.hand[i].annotations = newResult.hand[i].annotations; // reset annotations as previous frame did not have them\n annotations = bufferedResult.hand[i].annotations;\n } else if (newResult.hand[i].annotations) {\n for (const key of Object.keys(newResult.hand[i].annotations)) { // update annotations\n annotations[key] = newResult.hand[i].annotations[key] && newResult.hand[i].annotations[key][0]\n ? newResult.hand[i].annotations[key]\n .map((val, j: number) => val\n .map((coord: number, k: number) => ((bufferedFactor - 1) * bufferedResult.hand[i].annotations[key][j][k] + coord) / bufferedFactor))\n : null;\n }\n }\n bufferedResult.hand[i] = { ...newResult.hand[i], box, boxRaw, keypoints, annotations: annotations as HandResult['annotations'] }; // shallow clone plus updated values\n }\n }\n\n // interpolate face results\n if (!bufferedResult.face || (newResult.face.length !== bufferedResult.face.length)) {\n bufferedResult.face = JSON.parse(JSON.stringify(newResult.face as FaceResult[])); // deep clone once\n } else {\n for (let i = 0; i < newResult.face.length; i++) {\n const box = (newResult.face[i].box // update box\n .map((b, j) => ((bufferedFactor - 1) * bufferedResult.face[i].box[j] + b) / bufferedFactor)) as Box;\n const boxRaw = (newResult.face[i].boxRaw // update boxRaw\n .map((b, j) => ((bufferedFactor - 1) * bufferedResult.face[i].boxRaw[j] + b) / bufferedFactor)) as Box;\n if (newResult.face[i].rotation) {\n const rotation: {\n matrix: [number, number, number, number, number, number, number, number, number],\n angle: { roll: number, yaw: number, pitch: number },\n gaze: { bearing: number, strength: number }\n } = { matrix: [0, 0, 0, 0, 0, 0, 0, 0, 0], angle: { roll: 0, yaw: 0, pitch: 0 }, gaze: { bearing: 0, strength: 0 } };\n rotation.matrix = newResult.face[i].rotation?.matrix as [number, number, number, number, number, number, number, number, number];\n rotation.angle = {\n roll: ((bufferedFactor - 1) * (bufferedResult.face[i].rotation?.angle?.roll || 0) + (newResult.face[i].rotation?.angle?.roll || 0)) / bufferedFactor,\n yaw: ((bufferedFactor - 1) * (bufferedResult.face[i].rotation?.angle?.yaw || 0) + (newResult.face[i].rotation?.angle?.yaw || 0)) / bufferedFactor,\n pitch: ((bufferedFactor - 1) * (bufferedResult.face[i].rotation?.angle?.pitch || 0) + (newResult.face[i].rotation?.angle?.pitch || 0)) / bufferedFactor,\n };\n rotation.gaze = {\n // not fully correct due projection on circle, also causes wrap-around draw on jump from negative to positive\n bearing: ((bufferedFactor - 1) * (bufferedResult.face[i].rotation?.gaze?.bearing || 0) + (newResult.face[i].rotation?.gaze?.bearing || 0)) / bufferedFactor,\n strength: ((bufferedFactor - 1) * (bufferedResult.face[i].rotation?.gaze?.strength || 0) + (newResult.face[i].rotation?.gaze?.strength || 0)) / bufferedFactor,\n };\n bufferedResult.face[i] = { ...newResult.face[i], rotation, box, boxRaw }; // shallow clone plus updated values\n }\n bufferedResult.face[i] = { ...newResult.face[i], box, boxRaw }; // shallow clone plus updated values\n }\n }\n\n // interpolate object detection results\n if (!bufferedResult.object || (newResult.object.length !== bufferedResult.object.length)) {\n bufferedResult.object = JSON.parse(JSON.stringify(newResult.object as ObjectResult[])); // deep clone once\n } else {\n for (let i = 0; i < newResult.object.length; i++) {\n const box = (newResult.object[i].box // update box\n .map((b, j) => ((bufferedFactor - 1) * bufferedResult.object[i].box[j] + b) / bufferedFactor)) as Box;\n const boxRaw = (newResult.object[i].boxRaw // update boxRaw\n .map((b, j) => ((bufferedFactor - 1) * bufferedResult.object[i].boxRaw[j] + b) / bufferedFactor)) as Box;\n bufferedResult.object[i] = { ...newResult.object[i], box, boxRaw }; // shallow clone plus updated values\n }\n }\n\n // interpolate person results\n if (newResult.persons) {\n const newPersons = newResult.persons; // trigger getter function\n if (!bufferedResult.persons || (newPersons.length !== bufferedResult.persons.length)) {\n bufferedResult.persons = JSON.parse(JSON.stringify(newPersons as PersonResult[]));\n } else {\n for (let i = 0; i < newPersons.length; i++) { // update person box, we don't update the rest as it's updated as reference anyhow\n bufferedResult.persons[i].box = (newPersons[i].box\n .map((box, j) => ((bufferedFactor - 1) * bufferedResult.persons[i].box[j] + box) / bufferedFactor)) as Box;\n }\n }\n }\n\n // just copy latest gestures without interpolation\n if (newResult.gesture) bufferedResult.gesture = newResult.gesture as GestureResult[];\n\n // append interpolation performance data\n const t1 = now();\n interpolateTime = env.perfadd ? interpolateTime + Math.round(t1 - t0) : Math.round(t1 - t0);\n if (newResult.performance) bufferedResult.performance = { ...newResult.performance, interpolate: interpolateTime };\n\n return bufferedResult;\n}\n", "/** Face descriptor type as number array */\nexport type Descriptor = Array\nexport type MatchOptions = { order?: number, threshold?: number, multiplier?: number, min?: number, max?: number } | undefined;\n\n/** Calculates distance between two descriptors\n * @param options - calculation options\n * - order - algorithm to use\n * Euclidean distance if `order` is 2 (default), Minkowski distance algorithm of nth order if `order` is higher than 2\n * - multiplier - by how much to enhance difference analysis in range of 1..100\n * default is 20 which normalizes results to similarity above 0.5 can be considered a match\n */\nexport function distance(descriptor1: Descriptor, descriptor2: Descriptor, options: MatchOptions = { order: 2, multiplier: 25 }) {\n // general minkowski distance, euclidean distance is limited case where order is 2\n let sum = 0;\n for (let i = 0; i < descriptor1.length; i++) {\n const diff = (!options.order || options.order === 2) ? (descriptor1[i] - descriptor2[i]) : (Math.abs(descriptor1[i] - descriptor2[i]));\n sum += (!options.order || options.order === 2) ? (diff * diff) : (diff ** options.order);\n }\n return (options.multiplier || 20) * sum;\n}\n\n// invert distance to similarity, normalize to given range and clamp\nconst normalizeDistance = (dist, order, min, max) => {\n if (dist === 0) return 1; // short circuit for identical inputs\n const root = order === 2 ? Math.sqrt(dist) : dist ** (1 / order); // take root of distance\n const norm = (1 - (root / 100) - min) / (max - min); // normalize to range\n const clamp = Math.max(Math.min(norm, 1), 0); // clamp to 0..1\n return clamp;\n};\n\n/** Calculates normalized similarity between two face descriptors based on their `distance`\n * @param options - calculation options\n * - order - algorithm to use\n * Euclidean distance if `order` is 2 (default), Minkowski distance algorithm of nth order if `order` is higher than 2\n * - multiplier - by how much to enhance difference analysis in range of 1..100\n * default is 20 which normalizes results to similarity above 0.5 can be considered a match\n * - min - normalize similarity result to a given range\n * - max - normalzie similarity resutl to a given range\n * default is 0.2...0.8\n * Returns similarity between two face descriptors normalized to 0..1 range where 0 is no similarity and 1 is perfect similarity\n */\nexport function similarity(descriptor1: Descriptor, descriptor2: Descriptor, options: MatchOptions = { order: 2, multiplier: 25, min: 0.2, max: 0.8 }) {\n const dist = distance(descriptor1, descriptor2, options);\n return normalizeDistance(dist, options.order || 2, options.min || 0, options.max || 1);\n}\n\n/** Matches given descriptor to a closest entry in array of descriptors\n * @param descriptor - face descriptor\n * @param descriptors - array of face descriptors to commpare given descriptor to\n * @param options - see `similarity` method for options description\n * Returns\n * - `index` index array index where best match was found or -1 if no matches\n * - `distance` calculated `distance` of given descriptor to the best match\n * - `similarity` calculated normalized `similarity` of given descriptor to the best match\n*/\nexport function match(descriptor: Descriptor, descriptors: Array, options: MatchOptions = { order: 2, multiplier: 25, threshold: 0, min: 0.2, max: 0.8 }) {\n if (!Array.isArray(descriptor) || !Array.isArray(descriptors) || descriptor.length < 64 || descriptors.length === 0 || descriptor.length !== descriptors[0].length) { // validate input\n return { index: -1, distance: Number.POSITIVE_INFINITY, similarity: 0 };\n }\n let lowestDistance = Number.MAX_SAFE_INTEGER;\n let index = -1;\n for (let i = 0; i < descriptors.length; i++) {\n const res = distance(descriptor, descriptors[i], options);\n if (res < lowestDistance) {\n lowestDistance = res;\n index = i;\n }\n if (lowestDistance < (options.threshold || 0)) break;\n }\n const normalizedSimilarity = normalizeDistance(lowestDistance, options.order || 2, options.min || 0, options.max || 1);\n return { index, distance: lowestDistance, similarity: normalizedSimilarity };\n}\n", "/**\n * Analyze detection Results and sort&combine them into per-person view\n */\n\nimport type { FaceResult, BodyResult, HandResult, GestureResult, PersonResult, Box } from '../result';\n\nexport function join(faces: Array, bodies: Array, hands: Array, gestures: Array, shape: Array | undefined): Array {\n let id = 0;\n const persons: Array = [];\n for (const face of faces) { // person is defined primarily by face and then we append other objects as found\n const person: PersonResult = { id: id++, face, body: null, hands: { left: null, right: null }, gestures: [], box: [0, 0, 0, 0] };\n for (const body of bodies) {\n if (face.box[0] > body.box[0] // x within body\n && face.box[0] < body.box[0] + body.box[2]\n && face.box[1] + face.box[3] > body.box[1] // y within body\n && face.box[1] + face.box[3] < body.box[1] + body.box[3]) {\n person.body = body;\n }\n }\n if (person.body) { // only try to join hands if body is found\n for (const hand of hands) {\n if (hand.box[0] + hand.box[2] > person.body.box[0] // x within body for left hand\n && hand.box[0] + hand.box[2] < person.body.box[0] + person.body.box[2]\n && hand.box[1] + hand.box[3] > person.body.box[1] // x within body for left hand\n && hand.box[1] + hand.box[3] < person.body.box[1] + person.body.box[3]) {\n if (person.hands) person.hands.left = hand;\n }\n if (hand.box[0] < person.body.box[0] + person.body.box[2] // x within body for right hand\n && hand.box[0] > person.body.box[0]\n && hand.box[1] + hand.box[3] > person.body.box[1] // x within body for right hand\n && hand.box[1] + hand.box[3] < person.body.box[1] + person.body.box[3]) {\n if (person.hands) person.hands.right = hand;\n }\n }\n }\n for (const gesture of gestures) { // append all gestures according to ids\n if (gesture['face'] !== undefined && gesture['face'] === face.id) person.gestures?.push(gesture);\n else if (gesture['iris'] !== undefined && gesture['iris'] === face.id) person.gestures?.push(gesture);\n else if (gesture['body'] !== undefined && gesture['body'] === person.body?.id) person.gestures?.push(gesture);\n else if (gesture['hand'] !== undefined && gesture['hand'] === person.hands?.left?.id) person.gestures?.push(gesture);\n else if (gesture['hand'] !== undefined && gesture['hand'] === person.hands?.right?.id) person.gestures?.push(gesture);\n }\n\n // create new overarching box from all boxes belonging to person\n const x: number[] = [];\n const y: number[] = [];\n const extractXY = (box: Box | undefined) => { // extract all [x, y] coordinates from boxes [x, y, width, height]\n if (box && box.length === 4) {\n x.push(box[0], box[0] + box[2]);\n y.push(box[1], box[1] + box[3]);\n }\n };\n extractXY(person.face?.box);\n extractXY(person.body?.box);\n extractXY(person.hands?.left?.box);\n extractXY(person.hands?.right?.box);\n const minX = Math.min(...x);\n const minY = Math.min(...y);\n person.box = [minX, minY, Math.max(...x) - minX, Math.max(...y) - minY]; // create new overarching box\n\n // shape is known so we calculate boxRaw as well\n if (shape && shape[1] && shape[2]) person.boxRaw = [person.box[0] / shape[2], person.box[1] / shape[1], person.box[2] / shape[2], person.box[3] / shape[1]];\n\n persons.push(person);\n }\n return persons;\n}\n", "/**\n * Embedded sample images used during warmup in dataURL format\n */\n\n// data:image/jpeg;base64,\nexport const face = `\n/9j/4AAQSkZJRgABAQEAYABgAAD/4QBoRXhpZgAATU0AKgAAAAgABAEaAAUAAAABAAAAPgEbAAUA\nAAABAAAARgEoAAMAAAABAAIAAAExAAIAAAARAAAATgAAAAAAAABgAAAAAQAAAGAAAAABcGFpbnQu\nbmV0IDQuMi4xMwAA/9sAQwAGBAUGBQQGBgUGBwcGCAoQCgoJCQoUDg8MEBcUGBgXFBYWGh0lHxob\nIxwWFiAsICMmJykqKRkfLTAtKDAlKCko/9sAQwEHBwcKCAoTCgoTKBoWGigoKCgoKCgoKCgoKCgo\nKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgo/8AAEQgBAAEAAwEhAAIRAQMRAf/E\nAB8AAAEFAQEBAQEBAAAAAAAAAAABAgMEBQYHCAkKC//EALUQAAIBAwMCBAMFBQQEAAABfQECAwAE\nEQUSITFBBhNRYQcicRQygZGhCCNCscEVUtHwJDNicoIJChYXGBkaJSYnKCkqNDU2Nzg5OkNERUZH\nSElKU1RVVldYWVpjZGVmZ2hpanN0dXZ3eHl6g4SFhoeIiYqSk5SVlpeYmZqio6Slpqeoqaqys7S1\ntre4ubrCw8TFxsfIycrS09TV1tfY2drh4uPk5ebn6Onq8fLz9PX29/j5+v/EAB8BAAMBAQEBAQEB\nAQEAAAAAAAABAgMEBQYHCAkKC//EALURAAIBAgQEAwQHBQQEAAECdwABAgMRBAUhMQYSQVEHYXET\nIjKBCBRCkaGxwQkjM1LwFWJy0QoWJDThJfEXGBkaJicoKSo1Njc4OTpDREVGR0hJSlNUVVZXWFla\nY2RlZmdoaWpzdHV2d3h5eoKDhIWGh4iJipKTlJWWl5iZmqKjpKWmp6ipqrKztLW2t7i5usLDxMXG\nx8jJytLT1NXW19jZ2uLj5OXm5+jp6vLz9PX29/j5+v/aAAwDAQACEQMRAD8A+qaKACigApGOKAML\nXp8xlF5A7V4X8RtYs7PzfNImnx8sa8Kp9z3q2tEgp6angWs62ZZ5CTGoJ6DArGNz5p+UrID6EUrF\nPUlW1EuN0XNW7PQ2L5j3JnoKXN0KijqNP0eYoqXBdgPuuo+ZPeupisWn2Jd4+0r924XgsQOCff3/\nAJ1FzRKxDqGii6m3siiQ8F1XGfXI6YNWLfRbiRQMkcZI9fpTDluT2/h6Qy8gDPbtmtG38JeY480Z\n5zSLUTZg8M28YwYxjAArXtdPt402qgHbpSaLWhma3o0Uqk7Nx9DWLaaVblgPs6qRyds2M/gRSQp9\nzZOni2iWS2hlQ+kjYz9OMGrdjq89vIPPVhj+8M/lQyDq9P1WOYBlMZz1AOD+VdDaTiReOKulK0jO\ntHmi0WDTlr0TyxRVhT8tJjIX+9SUxHXUV553BRQAVBcPhSBTSuxPY86+IGti0s5I7dsORy9fM3i6\n8e8mfDO5P90ZrWWiJicNPpZZtxV/xrW0jQt4DOv6Vk2dEEdTY6BHuB25rpbPSo0QARjP0qTRI17W\nwA/hFaMWmoQMgflQXYsDS142rU9tpqqenfNA7GgtihxkdKuRW6qMY/GkDZY8sY4Ap4hXbyB+VArk\nEtuH4wPyrk/EGkOm+a3jw3suRQLc5i38SX9hJ9nnY+XnBUdPyNdFY6pa3KkkAE9l6f8AfJ/pSJT6\nGhDmI+Zb4ZRycdv6ium0nUhKFydrelTsNnS2829RnrVgV6NKXNG55lWPLIM81Op+WrZkRMfmNNzT\nA7GivPO4KKAEY4XNYWt3vkwPg4OK0giJdjw/xrqhm87Zs8tc7pX5A+leSajf6aHYJ50kn4AZpTep\nrBWRm2Vobm4BXfyehPFdnpmnBFUY5rI2SN63tlToK0YI+KZpFF+3QdavwoKTLtoW0Toaswpk5pCb\nLCxipAhoIuP2dKevHXoaYDylRyxhlwRQI4nxVoCXWZI1GfpXGtbSWjYPGP73+NIGupt6TqMsLruZ\nih4xnP5V09mQ+JLd8gn0xSYJnVaVdkook69K34zuUGunDS3Rx4qOzHVIp4rrOMY3NJQI7GivPO8K\nKAILt9kZrz3xlebYiu8KCCWb0XvW0NFch6ysfO3jLVjfXLIn+pQkKorl7WxNxIPl71g2dUUdpo+l\npBGvHPet23iC8ihFosrxirkHQUFo0IF4FXI1O726CpKLacCrMJoJLYHAPpTwucHpSRJJ5e4AZI9x\nUqpxzVpCuOC8cUpQUMRnXttuB4rjNdsYyeVwfXpmpGmcvcQyafMCFJjPY10eg34BUg4DcZP8jUO4\nHaRq3lLNF+IHet7R7jz7c56rwa2wz9+xhiVeFy/T1PFegeaNPWigDsc0ZrzzvDNIaAM7VpNqdegr\nxL4l6kywyRhseZ19lrdfAZL4jxYg3Fw20d63tJsdrDI5rm3Z3R0R0Mce1eKnQYAplIkWrMJ45oZS\nNO3PHbNXIyfpSGWowSOasxLUiZdjFSqtNEMkUemKlAGKsRJjAppFAiORMjmsTVrNZEO4cfSoZSOD\n1eJ7WXBUzQZ+7nkfSo7e2Ei+ZaMzxntjBX2NSU1Y6/wxqojiEFzkA8KTXYaUoWRyv3W5rSjpNHPX\n+BmpSg8V6J5gUUAdhRXnneFFAGHrTfu5PpXzj8S70/aZtxzztXFbv4DKHxHI+H4GZiz9zxXXW8G3\nGBXMjvLRXAx0oPGPSmMVeOnWrMTYpFI0bcg1fh54xmgovRcD3qxETSIZcRvzp+/BpEkqsBUqsM9K\nq4Em4Gkxk0yRGXrVW6i8yFhkg+tJjRxGsWrxllkUMh9eK5uMz6bcebbnfG33kPcVkay2OntPKuo0\nnhXI67c8qa7Lw3c+adjcEDGK1paSRhVV4s6A0or0jyRRQ1AHX0V553hRQBz+vNtt5z3xXzX8Qbdm\nuic5YnOMdK3l8JnTXvlbwpYl+WySOgrp5YfLOOB9O1c62O7qQkc+9RsKChFPWp4DluOlSykaNruH\nArUgHShFNF2NT1qxGO3NBmyxGcE1N2560CFzjrUysO9JAPDDjFOVuKoQuSRTWouBkazbCa3cd8cV\nwF7IISQccHBzUSWpV9C3o1x5b5GAjdQD1rs9DjC3kckbEhqKfxIzn8LOupRXqnkPccBSkUAzraK8\n87wooA5rxMSI3HqK8B8bQl9Q8sffY5b/AAraXwkUviNrw9pH2W1ViMMRTdRjw4HpWNtDti9TPc4P\nFQs2M5qdyyMHLcfjV63HTAoBGtap0wK0YxigpsuRDtVhVYd6GQydVwwIqdRnqKCR23I5pCMUW6gD\nYNKuetAEise9KTxQBWuFyhrznxNZkXjFeN3I+tTIZg2OqmzmxNF0PO3vXp/g2+hukVl4zyPanTXv\nJmVR+60dpThXpnlPceopWFAbnV0V553hSGgRynjC5FujOey14Ssp1HxNmTnc+a3kvcIpv37HoEYQ\nQmMdVHSsnVbYJF5jVk0dsNzlruVIsl2wKxbjWrVHILjg1CRbZJb+ILHPzyhfStODWLQgFJFYd+el\nUJM27HUIXxhga1Y5lLVLKLkMnoauxnPPrSEx7ShF+Y/n2qrc6xBbhizDAqkK1zJuvG9nbg8ZA681\nly/Ei052RO3uKAsZlx8QGd8xxvt9Aa1NH8dK7AXMcip64zigdkdrZX8F7EJLdwwNXMkrz1qRMRly\nCK4TxmpidWI49felPYSOMmi80NIoOV6qRzXYeA5SskYPfirpfEjGr8LPWVHyD6U4CvQPL3ZItOYc\nUDOoNFeed4Uhpks4H4iE/Z5MeleMeGULeLgjds10S+BGdL+Jc9OSBU2Huc5Nc74yvUtrcDBrJnZF\n63PJdXvLy/lKWw46bvQVz82jXhkLO5Y+9ZlsYthcRnbIjY9R3q3awTRkEM3WmJI6C0ea3dGRsr1x\nXY6TqW9FLHnjrUs0izpLK5DDjofSta3ckH09KRUkZuuTvFGdvPauE1Y3U6Mqbssf/rUxHPTaJPK2\nZmJPbBqzY6DCZh5xJC9s9aBJHU6dpemJjfEmfetJtI0+VPkUr/unFOxdiextHs33W07YHQHk11mk\nXb3KbZ1xIvcd6LEyWho4Nct41sTPYb16ipexCPPZN+wYGCvH1rrPAEJmvkPoc1VL4kZVvgZ6yFwK\ncBXoHkkqinFaVyzo80GuE7WJRQSziPiGdthK5HQV4x4J/wBI8WPIewNdEvgRNL42emO/yj1UHNef\neNpRczbC+I17DvWT2OqJxc0sMK4TCisy41q0hfEkqj8aixdwTXNOlwvmqD9anS9tXH7uVG+hosO4\n/wC0oOhrR0+6G4YNIEzsNEuCxAPNdjZruA4xxUmjINSjURksOlcbqFykbnjFA1sYGoassaknCqO5\nrl7rxhGm7yBnBxuJq0rkSlYpw+NLlsfd5P8AerVsvHEqSBHwPVgcgVpyMyVXU3rXxcHYETAk+hru\n/DWti6ZSTyOKzZqndHaxvvUGq2rQ+dYyqR24qWI8dvbr7LqDxyDAzXpvw6FvIxePGSM06Xxoyr/A\nzviKFHNegeX1J41zUhXioGbuaSuM6wpCaBHG/EcA6HN/exxXjXw2jL67cv8A3Qa6H8CFR+NnoWpO\nI4XI44rxLxrqjQzSEsQM1gdSPM9U1uR1YbmWIdXHf2rmpIb67YS28UrRlsLI3c/jW0VZGUpO5pW1\njfLNOjahawzwReYI5cjzMkDavHJ5/SrVv9uhtPtVxCPLBwzxnlT9KGghLU3tKvvPjHzbl7EGuisJ\nGRxWLOg7nRXJEbDjmvSNK+aFSfSoZr0KutRkphc4NcRrdkVjL9aVio7Hk3iqS8ubhrWzUlsZY9kG\ncZNc5D4aee5MclzJIFTzHAO0MfatqSOWu7bFS1srDUZEis0vIZoUxPvfcC+4/dx2xjr712XiTwXb\nWmlQ6hol3cRhoFd4rlg3zY5wR0GelavQwjq7GD4etdVvSnk2wAB+9v8A8mvcfA2kXiRo0/UdcDis\nZnTTulqeoWqbUAJqWUb42X1FZlnjfjSwlGrr5S/eNdD4RkvLAAQ4yRyaUZcruVKl7TQ9I0G+mnzH\nckFwM8VuIK7ac3KF2eXiKapz5UWYxipNtMyNejNch0jSar3cjR27uoyQCRVRWom9DxTx54gu5fMi\nlbKdMVjfCZPNlv5v9rFbVHpYqjGzbOn8SzFI9o715L4u0r7arYzk+lYdTqSujy7U/C0u4vHk+WwO\nxuh9q3J9dgvbdVukMV1EwbDDgn04rZMwlHoZ+orZ6hfQ3RWVnQYCgZAq+8U0ln5NtBsV2yxYcfgK\nJtW0CnB31LlroVwJ1nQLGDjeP7w+lb0dsFxjrWB0tHS6NuWPJ6A16ToUm63T3Gallr4S7cxiTjrX\nPaxaF7dlVeSMUhxZ5jd+H7qCa4eF3DSE5x3zXN3Wk6jbyeaiFWUY6ZyPStYS5SalPmVipFbX0E4c\nW0alvmPHJrag0rVvEE6LdljGpG2NRtQD+tW5XMI0uU9M8NeFo9PiQhecDIIrtrOMIoG3H4VlJm9t\nC6CB06VPGM1IHLeItGS6uw+ORT7e3jsbQvj7gzUNam0JaWE+HN7NqOqX80n3FO1RXo8YzXdS+BHk\n4z+KyzGPapcU2YIv7qQtiuaxvcaWqG4O6FwfSrS1JbPnrxoxkv7qIfejcitj4V2f2exumI+8+aKn\nxHTT+G5d8Txlm4rjLxMsQwzWT3OiK0Mm6sEkVsAcjFc1d+FEmlGwEDPQVopaEuOpr6f4ZWNAu3tW\nvHpAj5ZQcUFIWaDjGMVUMQ3cVDBmvbhY7QAV2nh+T/R1yeKhlrY31+b61FcQK6nIoJMi401WblRi\nqr6PCw5UYq9y+YgOgWzNkRrx3xWjp+nx2v3FQcelAbmko9anQ4GBUNisPHWr1qMrQhS2K11HvmYV\nhamcxSRZ5xRIqluS/DKAQQXZxyXrvo2FdlL4EeZjH+/ZbjNSZpswLNBrE1Gt7VE4ODVIlnh/j61F\nj4lmeTGyUbq6LwdEqWbeX0YbhSqfEddP4Bddj4JIrhL5d8h7VjI6oLQqKNzelWre3yc4/ClFjaL6\nwqBxxUUxwCKu5BmXRA6c+9ZjP83FSBoQuPs4BrsNBlUW659KmRrDY6G1lyQtW3Hy0lqQ1qVJnAbm\noy3b9KYJCqRj3o4zRctIlhjLHmpSuOBRbQOpLGpPFaES7UqkZzKN1KsEc87/AHUUmvPLTVGv72aQ\nk7WJwKmRrQ3ud74Ltilgz4++2a6iNDXdS0gjyMU71my7GpqTbxSbMki3SViajTTHqkSeR/GeyZmg\nnQHkEE1S+F+oPPavBL96I4/Cia1udVF+4dVrkW+Fq8+v4tjMDWUkdVJ6WM0cNV+F+MVmjUcZgqnP\n1qpNNnkcVRLiZtxIS1UzzIF7mghlxUZpVQdq6nTVdAoAOKzkbQWhvwM6gMM1twOJYx3NOJE11Kt1\nH1/pVVlwBkk+9NocXoOQ45FPj+fkUJFF2NSB700v/hTEty5ZpkjvVyUgcCq6GM9zC14/8Se6GcZQ\n1574Xs5WkI2HBPHFQ1dm1KSSZ7Rotn9l0+KPHIHNacae1dy0Vjxaj5ptlhVp+2s2CJ9ppCKzuWNx\nzSFc1SYrHNeNdIGpaYw25ZeRXmvheyk0jVpEdcLJ0q3ZxNKTa0O3vQHg/DNcHrsJDmsmjspnNzNt\nfFIJ24GazOhC+azDmgZIOOKBsp3J2qSaZodubq58yQ4QAnmhGT3NO18pb7BORmu205LfYpyKVkWp\nOxr5gKYWoIZWgfGfloFq1qTPLubnGO1RPtxg4P0oBAkY/hBz6VNDDkZ6AU0W2WSdqkdKr9ZOaGSj\nVtcLHmnOcgmmYvcz7mBLy3MbdD1q9ouiRK6bUAVeelOC1InPlidSsWMDFOCEdq3uefykqrinYqGy\nrFvApMVka2DAowKAsMkRXQqwyDXn/iWyitNQ3qPl6itIvRoF8RXinW4tQ6HI6GuW8SIVBPalc6qe\n5x9x97r3qruwTjrWZ0ksZ9TUmcDNAmZ9/wAoao63rR0+w22MLPtAzt6mghmfofiB76LdJBJBIp5D\nd/oa7bSdWLIPnpDi9TM8TeKdas51XTbIyxd3J/pXS+E/EFxqNoFu7do5OmD60maHWrnZyDRkn/69\nMlEyOR0xntVoNx+FUgYjPxg4FLCuWDZyKQr2RoRnP0qO+nEFpJITgAUzLqZnhu6+0rknOTXpOmwJ\nFbrt5yMmnHYyr6Oxb2ijaKLnPYMClwKQWK3n0hn+lachHOJ9pNNN0apQFzsY10a4v4hXQh0xpieQ\nMA1XLZNjhK80cT8OdV+3Wl3A7ZZJCw+hrR1qLcjZ/CsbnfHRnFXseHJArOYYbrUs1uPhYbuatqFP\nByfSkMq3UIINYkto+87Tx6GkSxfsDbflGD7CtTw/pk4nzITtPIFMFudsukh4Rxz71paTpKwP5jcn\n0qTRy0NORMDgVCqewoJTJgAoxjntTiTu7fWmFxAcnn1q3EPl+X8KZMi4gKqB1Peob/Tv7Us5bfeU\nyOoq4R5nYxqT5I8xieH9J1DTbvyJELRg8ODwa9Ms5mSFV9BWiptbnNVrKdmif7Q1KLg96XIZc5Is\npNL5pqeUrmMtZs0jzV08phchaY00zH1p2ZNxjS1g+LdJOt6U9ssmxjyGp2urDjLlaZzng/wUPDqz\nTSTmWeTrjpVjVk3Rvjr2rnqQ5dDvo1XUd2cTqSNk9OKxXGCeKxZ1DAxHTr2q5C/y8GokUhsz54qu\nuCxzSQjQ0+FZblR2ro4bZYiMVQ0dBb7Qi5x0qzuG5QOh71LYErDufpSeWrHnimIXbjkUjLkH1Hem\ngGxryc+tXI19KYmWegq9YLiLJ7mtqS945cS7QsWehqxA9dEjz4krPSxyZqbFFhGxUm6smjRM55Lk\nHvSvNxXTY57kLT+9MNwKdhXGm5FIbkU7Bca1wMEVhaiuQcVhXWiZ14R6tHGanGBI2OtYkqEHjgVy\ns9ErEeo6UBsHipKEZs5qpPdRxcbhx70NCSuybTNWihc5brW9Fq6vjMnFSdEIdDRi8RRKygZbHFbu\nm6nb3RA3gMegNJhOm0jbXGOoxTuCc1Rz3FyoGKawz9KaAVcZqeMgCmIkB4FaUTbYwB6V00Fuzixb\n0SFMuDU8Mlbs4UPeXHeiOXkUrDuXYnyKk3cVk0ap6HMxxketSMhrcwRC0dMMZFMQ3yzSeVQAeUaz\n9Vj8uPd271nVV4m+GdpnHX67pCeKyLtBtNcR6xlk9RVeWTb3qRnO6trgttyIfm71z7ai8j7/AJmN\nDNqUVa5Yi1AnjynHuBV+11YJhWWXcP8AZNSzqgmaEerSsf3NtIQP4mGKtRavdRgMIpVI9KjU0a7n\nR6T43uYQI7qN2Tpkqciu503VVuQGAYZHQjFVc4alPlZrpKGAznpTwxOc9+lWjIlUACnM4XApiLNk\nnmvnsK0NvpXZRVonmYqV52GsmanhXitTmFkSiJTSAvwrxUxXIrJ7miOfjf1pzNWxkRlqYWpgJupu\n6gQbuahvIxPA6eo4pNXVioS5WmefakGhndH4INZs5DJXA10PaTurmLO21uKpSZqGMoXGnRzBiyjd\n9Kx5rcQS428fSkjanLoaOliHGZFB56VswW+mtPufcBsGOAfmxz+tFkd8HpoaUx09FAtFY8DO71qb\nSms/Nb7RbecG6AEjFLS5c78t+p0djpVs9wsyQiJAdyr1rW+zqjErzSe559Sbk9S3C+MA1bjbgE1S\nMSXzMVG0vNUI2tPKrAuCMnrVzNd0PhR49W/O2xrHmp4TxVMzQshpIzzQBehqesnuaI5VGzT2bitz\nFEbNTC1ADS1JupgG6l3UAc14s04yR/aYRll+8BXCtLncDXFWjys9TCz5oW7GddH5qqNzWDOgQnC8\nVSuo1kHzAGkPYopEY2+RWxV23Vzj5G/Kg3jWaNazhZuqNXS6TaKhB2c0jR1nJWOlhOxRxU4YkCgx\nY0OQatQyDbyaaFYe8uF4NY3iC9ltbVGj43NTIL3h7WzMihjzXVQXYYDdW9Cf2WcOJpfaRZ3g9KsQ\nmupnCLIabGeaAL0LcVY3cVmzRHIxtUhetzEjZqjLUAIWpN1ArhupwagAfDKQ3Q1594v0c2bm6tx+\n5Y8j+6ayrR5onThp8s7dzkZjuqAAmuBnqC7c0iwgtzSA0rWzjfGRW3ZadDu4AoNYo2rfS4v7orSh\n05UA2r0pDbsTm29KRottBNyJ0wpJ9KhD7f6U0ikNWffIFBz60zVUW52ow4UcUN6EPcx44WsbgOmd\nua7TT5Bd24KHnFKnLlZFSN4koluLdueRWvp14swweG9DXoxldHlTjYtzGoo25qzEvwtUxas2jRPQ\n5CNqkLVsYoYzUzdQA3dSFqBBmnqaBhuqhriCXTpVIzxUz+Fl03aSPI9QTypW2/dz0qKNw3SvOPZR\nMqin8VLKRcs3O4Cuk0w/MDjt1NBtHY6O2IIHY1pxgFaETIRwMkjtVSUEk4570MlFW5bap6dKzWm8\n1tqH8aY+hp2FvGoGayNevVt7/ap4xzUvYjqTLtvLPcvJxSaVcyWsxTnFZlnT2t15xHmCtOBYwQy4\nB9q7cPO+jPPxFO2qLEj5HWo42+aus4HpoX4W4FTF+KlotbHII9SFuK0MUNZqiLUDE3UbqBBupwag\nBc1DefPbyD/ZND2KjujyPWlKzuPesRZjHJXms9lMuw3StjnmphKDSLTJ7OfE3JrpbO4GQc9qlnRA\n3LO82k5NbFvdADkjBoCSHyXIIIzgVQvdRigT7wzjgUzO1jHknlvG7qnp61etYFQDIpCZoqVijzXn\n3iC8EmsOuaCGb/heR/s0ijkVv6fbxy3QMg5xmsnuX0Ldzut3+UYTPWk+2GJSe+M1pFtamcldalmx\n1eO4XaThhWnC+TXqR2PHqL3maUJ4qRjxSEjj42qXdxVmaGs1MJoATfSbqBAG5p6mgAzTJTmNvpQU\ntzzHXY83D/U1zF5FhjgV5r3Pa6FMsV5HWnLe7RhqBRdmTwagN2d2K2rPU1C5LAnPrUs6Iysbdrq6\nf3gK0BrUKj/WClY05iM6xLOcQAj3NT29uznfKSzHuadzNu7NSBFjHNSm5VO9IRnajqoWMhTzXFtA\nbvUfMduSeg702Qz0rS7FbTToQFwzjJqaGTFyfK5PQViyzUuFmuIdgGABya5u/vTaN5cnUHFUmLoZ\nzyskwlgJweSK6zQdUEwVJeGr0aUrxPLxEfe0OrhPAqVjxWhznGRtUwatDK4jNxURbmkAm6jNABup\n6tQAFqhupNtu59qUnZFwV5JHnWsHdIx96w5lz15rzT2uhRmt85xWbcxMnUGmZlB0bdxmrNvFIcfM\n350mWjbs7YkDJY/jW5ZWW4jikWkdNp9mqYJFaJdEHHakUULu/VB1rLn1Ld/FgetMGYd/qWSQmSa0\n/AemS32pfa7piLeLkg9z6UmQtz0W7uQ2cZx0A9BVzR7cAea6j2rPqX0L99KRat5A6Dk1wOoKZ52a\nYfMORTYRLujiGWEq6/NWza2yKQVHNdOHerRy4laJo6TTnbbtb8KuM3Fdh5z3OJjbmpt3FaMxAtUZ\nagBN1GaQBzTwaAAms3VbjERUGsa07RsdeFpuUuY4jUjljWTKK4j02RE4IpJYFk6imQkVl0xWarsO\nmAEcUi0bNnZBR0rWtoguMCkUi21wI161mXuocEKaYXMS4u+pY/hVCSWSY4HT0pEmlouiSahdpEBl\nmOceleiwWcNjClvHgJH97Hc1EmVFFi3Czy7mwIl/WtJbjP7uLgd/apQ2VNVvtsBhiPzdK5S4nAuR\nnqOCaTGi9pcytPlU+XpmumtWII44rah8ZjiNIXRuWeNvvViQ/LXpJWPJbu7nCRvVkNxVsxBmqJmo\nEPiXca0YLMuOlJsuKuPlsSi5IrNuG8s4HWs5VEkbwoOTKsk+FJY4rC1K53k1xTk5O7PSpwVNWRzt\n4cms+WpKICtSLTETQj5q0YeBSGiys23pUguGxQMq3E59ayrm4x3yaAKiRtO2WPHcmhruKFxFajzZ\nScA44qRHoXhuMaLpxaUg6hcDLMf4F9KlhuDeXGASIl+8azZslYma68y48m1+7nFW5rtbRNhb5z1p\niMKbUg0zuW4A4rPgb7VdKXOMmpA7HRbMS7nUYiUda0lkQOBngVrS+JGdbWLRt2bAx5BqeQ/LXpnj\nPQ4GJ+ashuK0MhWaoWcA0AaOmASMK7jRNPWYBmHyiuepO2x10qfcv6vYxCzYqoGK4HVYVTJrmb5l\nc6oaM5TUJ8EgGsG4kLNUHT0M64OaqMMikSRsuKbnFMRLG3zVehOaGNE445NNlnVFpDMu6uie9Vo1\n8z5mOAOST2pDK91cNN+5tsrH3PrW54a06KxT7fdrlh/q1Pc+tJ6IUdZGvHPLezMcnBOWbsPap5r3\nylFtbdT1xUWNWzU0/Zbwlgfmx8zGsHWtRHmMqE59aAMyNifvHPc1f0gtPdqkY5JosJHeNci2tktY\neuPnNY+oXWZEVJNrZ9aun8SIq/CzodHuriIokhDIR1ronbKZr0o6o8ipoz//2Q==`;\n\n// data:image/jpeg;base64,\nexport const body = `\n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\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAa2p1UYo5adbz+xbxMlvqJ1OqjDHLXree0ejmzNrWm953tPmTPWbWneZ7yoy5YhjrXXTjH8s75N\nmtkyxt0VZM2/m175N1V03yTKubMLXVXybeYLLX2VXy7eam+b0bOg4VquJW+rry4/O9uyZOq3UjVm\n9r25axMzPaIdvhns1kzbZddM0p5Y47z8/R2+HcF03Doi1a8+Xzvbv+TotJnjDXkt+K8ODHp8cY8N\nIpSO0RCwF2YAAAAAAAAACvUZYw6fJkntWN3k8dfHz2vLucdz8mkjFE9bz1+UOZosX1UzPm0nqI/W\nMYo9FlcPNklfFGeH/NshLGun+Cz6PtHZtVZWlRLS+jxPkRpIn7rdoupHTdA5s6SI+7H6Mfo+32Y2\n+To3neSIiZ7A0IjPXpXLePlMotGW3272t85datKzHZjbTVnsDj+FG/2Y/RlGP4R+jo20u7H6N1Ql\no+H8I/REY957R+jpfReiK6eOYHLtj2tttH6KrY/6Y/R2c+kjeJiFVtLG24hxpw7/AHY/RRkw9O37\nO99Hrt1YX0tfOBLjcGp4XF8c+u8fs9c4dcVcGemSI61nd3IneN1orQAAAAAAAAAAAAABFqxes1tE\nTE9JiUgPKcX4RbRXnNgiZwWnrH4XPi28PdXpW9JraImsxtMS8pxXhF9DecuGJtgmf+1TWW2N/la1\nL7N7T5e3Vy6W3hsYcvLbqzbO9jvvCzvDR0+XeO7crO6FmGSvRThy/RtVXJ92elvk2rRvDUzU7pl4\nizsd2J3jeBpcNz+Lg5LT7+Pp+Xk3W7js5eAAgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADs0NTrN96Yp6edkW8Wzm6+LNTq4pvTHO9vOfRoWtt\n1mes95YWvs1s2fZldddOczLPLn2ju0MmebT3YZc2/mpm3qqllN1drsbZIhr3yzvtHf4AsvlYYseb\nV5Yx4KTe0+UQ6nDvZ3UazbJqd8OKeu33peq0eh0+hxcmnxxWPOfOfm0mP+steT/ji8N9mKY9suum\nL37+HHaPm9DSlaVitKxWsdohI0Y22gAgAAAAAAAAAABXnyRhw3yT92Nwef4xm8bVzET0rPJH5d12\n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\nAOZE/OsPS29nuH27YrV+VpeV9pdPXhOtw49NG9Mld55+vXcTPd42I47qo7xSfyWV9oM8d8VJ/VxM\nd8l46xWF9cV7en6o/qLfxp2I9ob+eCv/AHMo9op89P8A/wBORGmyT5R+qfo2X8P7n9Q/jTsx7RR5\n6ef+4/8AuHftg/8A6cWcOSO9J/WEbWr3pY7Efzp2Lcfv5YK/9zWy8d1E/ZpSv5Oba1/+Hb9lc+LP\nbFt87I7E/wAabWbiurvEx4nL/pjZzc2bJkn372t85ZXx55/BX85lucC0vPxnTxlnnjm32mOiZqUu\nLJ2p4TwnVavNWaYbRTfre0bQ99pcH0bT0xb78vmtiIiNojaErMwAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAHnfarF7umzRHaZrLjYrdIen9ocPi8JyTt1xzF4eUw23rCm3R4r6bMy\nwt6kdTaWLdjswmNoZontsCm0K5XWjopnuDC0dGpqG5bs08/daKV672MjbSaif6oh6Z5f2LtvptRX\n0tEvUN3Jfo8f7cYve0eX4zV7B5z20xc/C8eSPuZIRficfXlcPaG7ino08HWIbePpLF2NuiyOyrHK\n3fZFSwuovHVfaVF4QK5YWTM9UT0EKry6Ps1Tn4zjn8NZn9nOtLseydObiWW34cf918fWfk+PYANn\nKAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\nAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAq1WKM+ly4p+/WYeBxTNd6zG0xO0\nvobw3FcP0bi2em20Tbmj5Srr418V9sa2Z7qKyzi07MXUylhaU7yjqhLCeiq3ddaFNxFYW7NLNG8t\nzya+WO6Va9J7FW66mvwidnrXiPY3Ny8RyUn71Jj9Ht3RPjk19HK9pMHj8D1ER3rHN+jqqtTjjNps\nuOe16zAifXzfTz7kNyndpYazS9qT0mszDdoxrsi6m8LazMq6zDOsq1ZEyrt1WWlXaUCqyq0rbKbi\nFdp6PReyFd8uqv8ACsfy83aXrPZHHto89/xX2/SP/dpj6y8vx6EBq5gAAAAAAAAAAAAAAAAAAAAA\n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\nNO67NbkhzNVnmInqzaOZrL93JyZeV0M1++7S02jvxDWxhxx033tPpC8Z6rrezWjmZyazJG2/u03h\n2vFibTHoqvamiwVwY+nLGzV0+SZ1Mx8G0/45tOhzJ5lXMc3UVXRdlF1HP+iYsDPLPPy49/tz1+Te\npSIr0ho6ak5Ms5J8o2q6NImOrHV7XX488ypzTtHXo0s9t6zG7c1G1qz6ubeZiZ3UatXJG3yauSO7\ncvMTEx5tPLb3prPRMVr0HB8vicNxf0+7+kt+LOJwTJyY/Bnz3tH93X36N58cWvq6LSyiyndMSlC7\nmZcymLJiwLosmJVRLKLAtiU7q4lMSCzc3YxJuDMRuAlKAEgAAAlAkAAAAAABKAEgAAAAAJAAAAAA\nAAAAAAAEgAAAAAAAAAAAAAkAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAhIAAACAAAASgAAAAAAEAAAA\nhGzJAImGMwzQDDZjNVuyNgUTVhNGxysZqDVmiu1G5NN2M4waM0+DCaN2cbGcQNGaMZq3JxMJxA1J\nqx2bU4kU09slorWNwa20z02RXHbJbl26QvtFovbHWkxEdJt5y2MOHlr2U1W3jx+1hiw8vSO63lmI\nXRTaEWmtY6snRHO1VpmJ+DjavpSZl2s8b7y4HFcnh0n0gha5ebJN55KRM2mdoiPN6fh+kpwXh0Wy\nRHj5Otp/s5Ps1p62y31+em9aTMYt/OfVfxTiPjZ52naI7fBrI5t66xz5+a1rW7yx0eSL6iZjtEOX\nqNbSletom3lENjh2fbHzbbWt3iVozruc+5ztWubf4M4ybpQ2Oboyrva0Vjza8WdDR4OkXt3n9ldX\nkaePP9VtYqctYhdvt5oivTeCZ2YOxXk6ubqMfV0b9mrljfqlFcq88k7z2U5axeItDa1OPessuC8P\nya7XRWYnwqdbT/ZMilvIu4dpslNdixXja8Y5tt85djZdbDWnGOesRtXFtuw6T27No5Kx2OrKYQlC\nExKJgBnEpiyvdlEgsizKLKollFgWxLKJVRLKJBbEp3VxLKJBnuMWQJEbpBIAAAJAAAABIAAAAAAA\nlAJAAAAAAAAAAAAAASAAAAAAAAAAAAAJAAAABAJABAlAAAAAAAAAAAAAAAAAAAAAAAAIAAAAAAAA\nAAABAJQAAAAgAABAAI2EoBGyJhkgGPKxmqxAKpownHC+YRMdN5BrTj67R3bOn01o7p01Iv71u89o\n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\n2Q==`;\n", "/**\n * Warmup algorithm that uses embedded images to exercise loaded models for faster future inference\n */\n\nimport { log, now, mergeDeep } from './util/util';\nimport * as sample from './sample';\nimport * as tf from '../dist/tfjs.esm.js';\nimport * as image from './image/image';\nimport { env } from './util/env';\nimport type { Config } from './config';\nimport type { Result } from './result';\nimport type { Human, Models } from './human';\nimport type { Tensor } from './tfjs/types';\n\nasync function warmupBitmap(instance: Human): Promise {\n const b64toBlob = (base64: string, type = 'application/octet-stream') => fetch(`data:${type};base64,${base64}`).then((res) => res.blob());\n let blob;\n let res;\n switch (instance.config.warmup) {\n case 'face': blob = await b64toBlob(sample.face); break;\n case 'body':\n case 'full': blob = await b64toBlob(sample.body); break;\n default: blob = null;\n }\n if (blob) {\n const bitmap = await createImageBitmap(blob);\n res = await instance.detect(bitmap, instance.config);\n bitmap.close();\n }\n return res;\n}\n\nasync function warmupCanvas(instance: Human): Promise {\n return new Promise((resolve) => {\n let src;\n // let size = 0;\n switch (instance.config.warmup) {\n case 'face':\n // size = 256;\n src = 'data:image/jpeg;base64,' + sample.face;\n break;\n case 'full':\n case 'body':\n // size = 1200;\n src = 'data:image/jpeg;base64,' + sample.body;\n break;\n default:\n src = null;\n }\n // src = encodeURI('../assets/human-sample-upper.jpg');\n let img: HTMLImageElement;\n if (typeof Image !== 'undefined') img = new Image();\n // @ts-ignore env.image is an external monkey-patch\n else if (env.Image) img = new env.Image();\n else return;\n img.onload = async () => {\n const canvas = image.canvas(img.naturalWidth, img.naturalHeight);\n if (!canvas) {\n log('Warmup: Canvas not found');\n resolve(undefined);\n } else {\n const ctx = canvas.getContext('2d');\n if (ctx) ctx.drawImage(img, 0, 0);\n // const data = ctx?.getImageData(0, 0, canvas.height, canvas.width);\n const tensor = await instance.image(canvas);\n const res = await instance.detect(tensor.tensor as Tensor, instance.config);\n resolve(res);\n }\n };\n if (src) img.src = src;\n else resolve(undefined);\n });\n}\n\nasync function warmupNode(instance: Human): Promise {\n const atob = (str: string) => Buffer.from(str, 'base64');\n let img;\n if (instance.config.warmup === 'face') img = atob(sample.face);\n else img = atob(sample.body);\n let res;\n if ('node' in tf) {\n // @ts-ignore tf.node may be undefined\n const data = tf['node'].decodeJpeg(img);\n const expanded = data.expandDims(0);\n instance.tf.dispose(data);\n // log('Input:', expanded);\n res = await instance.detect(expanded, instance.config);\n instance.tf.dispose(expanded);\n } else {\n if (instance.config.debug) log('Warmup tfjs-node not loaded');\n /*\n const input = await canvasJS.loadImage(img);\n const canvas = canvasJS.createCanvas(input.width, input.height);\n const ctx = canvas.getContext('2d');\n ctx.drawImage(img, 0, 0, input.width, input.height);\n res = await instance.detect(input, instance.config);\n */\n }\n return res;\n}\n\nasync function runInference(instance: Human) {\n let res: Result | undefined;\n if (typeof createImageBitmap === 'function') res = await warmupBitmap(instance);\n else if (typeof Image !== 'undefined' || env.Canvas !== undefined) res = await warmupCanvas(instance);\n else res = await warmupNode(instance);\n return res;\n}\n\n/** Runs pre-compile on all loaded models */\nexport async function runCompile(allModels: Models) {\n const backendType = tf.getBackend();\n const webGLBackend = tf.backend();\n if ((backendType !== 'webgl' && backendType !== 'humangl') || (!webGLBackend || !webGLBackend.checkCompileCompletion)) {\n // log('compile pass: skip');\n return;\n }\n tf.env().set('ENGINE_COMPILE_ONLY', true);\n const numTensorsStart = tf.engine().state.numTensors;\n const compiledModels: string[] = [];\n for (const [modelName, model] of Object.entries(allModels).filter(([key, val]) => (key !== null && val !== null))) {\n const shape = (model.inputs && model.inputs[0] && model.inputs[0].shape) ? [...model.inputs[0].shape] : [1, 64, 64, 3];\n const dtype = (model.inputs && model.inputs[0] && model.inputs[0].dtype) ? model.inputs[0].dtype : 'float32';\n for (let dim = 0; dim < shape.length; dim++) {\n if (shape[dim] === -1) shape[dim] = dim === 0 ? 1 : 64; // override batch number and any dynamic dimensions\n }\n const tensor = tf.zeros(shape, dtype);\n // const res = await model.executeAsync(tensor); // fails with current tfjs\n try {\n const res = model.execute(tensor);\n compiledModels.push(modelName);\n if (Array.isArray(res)) res.forEach((t) => tf.dispose(t));\n else tf.dispose(res);\n } catch {\n log('compile fail model:', modelName);\n }\n tf.dispose(tensor);\n }\n const kernels = await webGLBackend.checkCompileCompletionAsync();\n webGLBackend.getUniformLocations();\n log('compile pass models:', compiledModels);\n log('compile pass kernels:', kernels.length);\n tf.env().set('ENGINE_COMPILE_ONLY', false);\n const numTensorsEnd = tf.engine().state.numTensors;\n if ((numTensorsEnd - numTensorsStart) > 0) log('tensor leak:', numTensorsEnd - numTensorsStart);\n}\n\n/** Warmup method pre-initializes all configured models for faster inference\n * - can take significant time on startup\n * - only used in browser environments for `webgl` and `humangl` backends\n * @param userConfig?: Config\n*/\nexport async function warmup(instance: Human, userConfig?: Partial): Promise {\n const t0 = now();\n instance.state = 'warmup';\n if (userConfig) instance.config = mergeDeep(instance.config, userConfig) as Config;\n if (!instance.config.warmup || instance.config.warmup.length === 0 || instance.config.warmup === 'none') {\n return { face: [], body: [], hand: [], gesture: [], object: [], performance: instance.performance, timestamp: now(), persons: [], error: null };\n }\n return new Promise(async (resolve) => {\n await runCompile(instance.models);\n const res = await runInference(instance);\n const t1 = now();\n if (instance.config.debug) log('warmup', instance.config.warmup, Math.round(t1 - t0), 'ms');\n instance.emit('warmup');\n resolve(res);\n });\n}\n", "/**\n * Human main module\n * @default Human Library\n * @summary \n * @author \n * @copyright \n * @license MIT\n */\n\n// module imports\nimport { log, now, mergeDeep, validate } from './util/util';\nimport { defaults } from './config';\nimport { env, Env } from './util/env';\nimport { setModelLoadOptions } from './tfjs/load';\nimport * as tf from '../dist/tfjs.esm.js';\nimport * as app from '../package.json';\nimport * as backend from './tfjs/backend';\nimport * as blazepose from './body/blazepose';\nimport * as centernet from './object/centernet';\nimport * as draw from './draw/draw';\nimport * as efficientpose from './body/efficientpose';\nimport * as face from './face/face';\nimport * as facemesh from './face/facemesh';\nimport * as faceres from './face/faceres';\nimport * as gesture from './gesture/gesture';\nimport * as handpose from './hand/handpose';\nimport * as handtrack from './hand/handtrack';\nimport * as humangl from './tfjs/humangl';\nimport * as image from './image/image';\nimport * as interpolate from './util/interpolate';\nimport * as match from './face/match';\nimport * as models from './models';\nimport * as movenet from './body/movenet';\nimport * as nanodet from './object/nanodet';\nimport * as persons from './util/persons';\nimport * as posenet from './body/posenet';\nimport * as segmentation from './segmentation/segmentation';\nimport * as warmups from './warmup';\n// type definitions\nimport type { Input, Tensor, DrawOptions, Config, Result, FaceResult, HandResult, BodyResult, ObjectResult, GestureResult, PersonResult, AnyCanvas } from './exports';\n// type exports\nexport * from './exports';\n\n/** **Human** library main class\n *\n * All methods and properties are available only as members of Human class\n *\n * - Configuration object definition: {@link Config}\n * - Results object definition: {@link Result}\n * - Possible inputs: {@link Input}\n *\n * @param userConfig - {@link Config}\n * @returns instance of {@link Human}\n */\nexport class Human {\n /** Current version of Human library in *semver* format */\n version: string;\n\n /** Current configuration\n * - Defaults: [config](https://github.com/vladmandic/human/blob/main/src/config.ts#L262)\n */\n config: Config;\n\n /** Last known result of detect run\n * - Can be accessed anytime after initial detection\n */\n result: Result;\n\n /** Current state of Human library\n * - Can be polled to determine operations that are currently executed\n * - Progresses through: 'config', 'check', 'backend', 'load', 'run:', 'idle'\n */\n state: string;\n\n /** currenty processed image tensor and canvas */\n process: { tensor: Tensor | null, canvas: AnyCanvas | null };\n\n /** Instance of TensorFlow/JS used by Human\n * - Can be embedded or externally provided\n * [TFJS API]: {@link https://js.tensorflow.org/api/latest/}\n */\n tf;\n\n /** Object containing environment information used for diagnostics */\n env: Env;\n\n /** Draw helper classes that can draw detected objects on canvas using specified draw\n * - canvas: draws input to canvas\n * - options: are global settings for all draw operations, can be overriden for each draw method {@link DrawOptions}\n * - face, body, hand, gesture, object, person: draws detected results as overlays on canvas\n */\n draw: { canvas: typeof draw.canvas, face: typeof draw.face, body: typeof draw.body, hand: typeof draw.hand, gesture: typeof draw.gesture, object: typeof draw.object, person: typeof draw.person, all: typeof draw.all, options: DrawOptions };\n\n /** Currently loaded models\n * @internal\n * {@link Models}\n */\n models: models.Models;\n\n /** Container for events dispatched by Human\n * Possible events:\n * - `create`: triggered when Human object is instantiated\n * - `load`: triggered when models are loaded (explicitly or on-demand)\n * - `image`: triggered when input image is processed\n * - `result`: triggered when detection is complete\n * - `warmup`: triggered when warmup is complete\n * - `error`: triggered on some errors\n */\n events: EventTarget | undefined;\n /** Reference face triangualtion array of 468 points, used for triangle references between points */\n faceTriangulation: number[];\n /** Refernce UV map of 468 values, used for 3D mapping of the face mesh */\n faceUVMap: [number, number][];\n /** Performance object that contains values for all recently performed operations */\n performance: Record; // perf members are dynamically defined as needed\n #numTensors: number;\n #analyzeMemoryLeaks: boolean;\n #checkSanity: boolean;\n /** WebGL debug info */\n gl: Record;\n // definition end\n\n /** Constructor for **Human** library that is futher used for all operations\n * @param userConfig - user configuration object {@link Config}\n */\n constructor(userConfig?: Partial) {\n this.env = env;\n defaults.wasmPath = tf.version['tfjs-core'].includes('-') // custom build or official build\n ? 'https://vladmandic.github.io/tfjs/dist/'\n : `https://cdn.jsdelivr.net/npm/@tensorflow/tfjs-backend-wasm@${tf.version_core}/dist/`;\n defaults.modelBasePath = env.browser ? '../models/' : 'file://models/';\n defaults.backend = env.browser ? 'humangl' : 'tensorflow';\n this.version = app.version; // expose version property on instance of class\n Object.defineProperty(this, 'version', { value: app.version }); // expose version property directly on class itself\n this.config = JSON.parse(JSON.stringify(defaults));\n Object.seal(this.config);\n this.config.cacheModels = typeof indexedDB !== 'undefined';\n if (userConfig) this.config = mergeDeep(this.config, userConfig);\n setModelLoadOptions(this.config);\n this.tf = tf;\n this.state = 'idle';\n this.#numTensors = 0;\n this.#analyzeMemoryLeaks = false;\n this.#checkSanity = false;\n this.performance = {};\n this.events = (typeof EventTarget !== 'undefined') ? new EventTarget() : undefined;\n // object that contains all initialized models\n this.models = new models.Models();\n // reexport draw methods\n this.draw = {\n options: draw.options as DrawOptions,\n canvas: (input: AnyCanvas | HTMLImageElement | HTMLVideoElement, output: AnyCanvas) => draw.canvas(input, output),\n face: (output: AnyCanvas, result: FaceResult[], options?: Partial) => draw.face(output, result, options),\n body: (output: AnyCanvas, result: BodyResult[], options?: Partial) => draw.body(output, result, options),\n hand: (output: AnyCanvas, result: HandResult[], options?: Partial) => draw.hand(output, result, options),\n gesture: (output: AnyCanvas, result: GestureResult[], options?: Partial) => draw.gesture(output, result, options),\n object: (output: AnyCanvas, result: ObjectResult[], options?: Partial) => draw.object(output, result, options),\n person: (output: AnyCanvas, result: PersonResult[], options?: Partial) => draw.person(output, result, options),\n all: (output: AnyCanvas, result: Result, options?: Partial) => draw.all(output, result, options),\n };\n this.result = { face: [], body: [], hand: [], gesture: [], object: [], performance: {}, timestamp: 0, persons: [], error: null };\n // export access to image processing\n // @ts-ignore eslint-typescript cannot correctly infer type in anonymous function\n this.process = { tensor: null, canvas: null };\n // export raw access to underlying models\n this.faceTriangulation = facemesh.triangulation;\n this.faceUVMap = facemesh.uvmap;\n // set gl info\n this.gl = humangl.config;\n // include platform info\n this.emit('create');\n }\n\n /** internal function to measure tensor leaks */\n analyze = (...msg: string[]) => {\n if (!this.#analyzeMemoryLeaks) return;\n const currentTensors = this.tf.engine().state.numTensors;\n const previousTensors = this.#numTensors;\n this.#numTensors = currentTensors;\n const leaked = currentTensors - previousTensors;\n if (leaked !== 0) log(...msg, leaked);\n };\n\n /** internal function for quick sanity check on inputs @hidden */\n #sanity = (input: Input): null | string => {\n if (!this.#checkSanity) return null;\n if (!input) return 'input is not defined';\n if (this.env.node && !(input instanceof tf.Tensor)) return 'input must be a tensor';\n try {\n this.tf.getBackend();\n } catch {\n return 'backend not loaded';\n }\n return null;\n };\n\n /** Reset configuration to default values */\n reset(): void {\n const currentBackend = this.config.backend; // save backend;\n this.config = JSON.parse(JSON.stringify(defaults));\n this.config.backend = currentBackend;\n }\n\n /** Validate current configuration schema */\n validate(userConfig?: Partial) {\n return validate(defaults, userConfig || this.config);\n }\n\n /** Exports face matching methods {@link match#similarity} */\n public similarity = match.similarity;\n /** Exports face matching methods {@link match#distance} */\n public distance = match.distance;\n /** Exports face matching methods {@link match#match} */\n public match = match.match;\n\n /** Utility wrapper for performance.now() */\n now(): number {\n return now();\n }\n\n /** Process input as return canvas and tensor\n *\n * @param input - any input {@link Input}\n * @param getTensor - should image processing also return tensor or just canvas\n * Returns object with `tensor` and `canvas`\n */\n image(input: Input, getTensor: boolean = true) {\n return image.process(input, this.config, getTensor);\n }\n\n /** Segmentation method takes any input and returns processed canvas with body segmentation\n * - Segmentation is not triggered as part of detect process\n * @param input - {@link Input}\n * @param background - {@link Input}\n * - Optional parameter background is used to fill the background with specific input\n * Returns:\n * - `data` as raw data array with per-pixel segmentation values\n * - `canvas` as canvas which is input image filtered with segementation data and optionally merged with background image. canvas alpha values are set to segmentation values for easy merging\n * - `alpha` as grayscale canvas that represents segmentation alpha values\n */\n async segmentation(input: Input, background?: Input): Promise<{ data: number[] | Tensor, canvas: AnyCanvas | null, alpha: AnyCanvas | null }> {\n return segmentation.process(input, background, this.config);\n }\n\n /** Enhance method performs additional enhacements to face image previously detected for futher processing\n *\n * @param input - Tensor as provided in human.result.face[n].tensor\n * @returns Tensor\n */\n // eslint-disable-next-line class-methods-use-this\n enhance(input: Tensor): Tensor | null {\n return faceres.enhance(input);\n }\n\n /** Compare two input tensors for pixel simmilarity\n * - use `human.image` to process any valid input and get a tensor that can be used for compare\n * - when passing manually generated tensors:\n * - both input tensors must be in format [1, height, width, 3]\n * - if resolution of tensors does not match, second tensor will be resized to match resolution of the first tensor\n * - return value is pixel similarity score normalized by input resolution and rgb channels\n */\n compare(firstImageTensor: Tensor, secondImageTensor: Tensor): Promise {\n return image.compare(this.config, firstImageTensor, secondImageTensor);\n }\n\n /** Explicit backend initialization\n * - Normally done implicitly during initial load phase\n * - Call to explictly register and initialize TFJS backend without any other operations\n * - Use when changing backend during runtime\n */\n async init(): Promise {\n await backend.check(this, true);\n await this.tf.ready();\n }\n\n /** Load method preloads all configured models on-demand\n * - Not explicitly required as any required model is load implicitly on it's first run\n *\n * @param userConfig - {@link Config}\n */\n async load(userConfig?: Partial): Promise {\n this.state = 'load';\n const timeStamp = now();\n const count = Object.values(this.models).filter((model) => model).length;\n if (userConfig) this.config = mergeDeep(this.config, userConfig) as Config;\n\n if (this.env.initial) { // print version info on first run and check for correct backend setup\n if (this.config.debug) log(`version: ${this.version}`);\n if (this.config.debug) log(`tfjs version: ${this.tf.version['tfjs-core']}`);\n if (!await backend.check(this)) log('error: backend check failed');\n await tf.ready();\n if (this.env.browser) {\n if (this.config.debug) log('configuration:', this.config);\n if (this.config.debug) log('environment:', this.env);\n if (this.config.debug) log('tf flags:', this.tf.ENV['flags']);\n }\n }\n\n await models.load(this); // actually loads models\n if (this.env.initial && this.config.debug) log('tf engine state:', this.tf.engine().state.numBytes, 'bytes', this.tf.engine().state.numTensors, 'tensors'); // print memory stats on first run\n this.env.initial = false;\n\n const loaded = Object.values(this.models).filter((model) => model).length;\n if (loaded !== count) { // number of loaded models changed\n await models.validate(this); // validate kernel ops used by model against current backend\n this.emit('load');\n }\n\n const current = Math.trunc(now() - timeStamp);\n if (current > (this.performance.loadModels as number || 0)) this.performance.loadModels = this.env.perfadd ? (this.performance.loadModels || 0) + current : current;\n }\n\n /** emit event */\n emit = (event: string) => {\n if (this.events && this.events.dispatchEvent) this.events?.dispatchEvent(new Event(event));\n };\n\n /** Runs interpolation using last known result and returns smoothened result\n * Interpolation is based on time since last known result so can be called independently\n *\n * @param result - {@link Result} optional use specific result set to run interpolation on\n * @returns result - {@link Result}\n */\n next(result: Result = this.result): Result {\n return interpolate.calc(result, this.config) as Result;\n }\n\n /** Warmup method pre-initializes all configured models for faster inference\n * - can take significant time on startup\n * - only used for `webgl` and `humangl` backends\n * @param userConfig - {@link Config}\n * @returns result - {@link Result}\n */\n async warmup(userConfig?: Partial) {\n const t0 = now();\n const res = await warmups.warmup(this, userConfig);\n const t1 = now();\n this.performance.warmup = Math.trunc(t1 - t0);\n return res;\n }\n\n /** Run detect with tensorflow profiling\n * - result object will contain total exeuction time information for top-20 kernels\n * - actual detection object can be accessed via `human.result`\n */\n async profile(input: Input, userConfig?: Partial): Promise> {\n const profile = await this.tf.profile(() => this.detect(input, userConfig));\n const kernels: Record = {};\n for (const kernel of profile.kernels) { // sum kernel time values per kernel\n if (kernels[kernel.name]) kernels[kernel.name] += kernel.kernelTimeMs;\n else kernels[kernel.name] = kernel.kernelTimeMs;\n }\n const kernelArr: Array<{ name: string, ms: number }> = [];\n Object.entries(kernels).forEach((key) => kernelArr.push({ name: key[0], ms: key[1] as unknown as number })); // convert to array\n kernelArr.sort((a, b) => b.ms - a.ms); // sort\n kernelArr.length = 20; // crop\n const res: Record = {};\n for (const kernel of kernelArr) res[kernel.name] = kernel.ms; // create perf objects\n return res;\n }\n\n /** Main detection method\n * - Analyze configuration: {@link Config}\n * - Pre-process input: {@link Input}\n * - Run inference for all configured models\n * - Process and return result: {@link Result}\n *\n * @param input - {@link Input}\n * @param userConfig - {@link Config}\n * @returns result - {@link Result}\n */\n async detect(input: Input, userConfig?: Partial): Promise {\n // detection happens inside a promise\n this.state = 'detect';\n return new Promise(async (resolve) => {\n this.state = 'config';\n let timeStamp;\n\n // update configuration\n this.config = mergeDeep(this.config, userConfig) as Config;\n\n // sanity checks\n this.state = 'check';\n const error = this.#sanity(input);\n if (error) {\n log(error, input);\n this.emit('error');\n resolve({ face: [], body: [], hand: [], gesture: [], object: [], performance: this.performance, timestamp: now(), persons: [], error });\n }\n\n const timeStart = now();\n\n // configure backend if needed\n await backend.check(this);\n\n // load models if enabled\n await this.load();\n\n timeStamp = now();\n this.state = 'image';\n const img = await image.process(input, this.config) as { canvas: AnyCanvas, tensor: Tensor };\n this.process = img;\n this.performance.inputProcess = this.env.perfadd ? (this.performance.inputProcess || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n this.analyze('Get Image:');\n\n if (!img.tensor) {\n if (this.config.debug) log('could not convert input to tensor');\n this.emit('error');\n resolve({ face: [], body: [], hand: [], gesture: [], object: [], performance: this.performance, timestamp: now(), persons: [], error: 'could not convert input to tensor' });\n return;\n }\n this.emit('image');\n\n timeStamp = now();\n this.config.skipAllowed = await image.skip(this.config, img.tensor);\n if (!this.performance.totalFrames) this.performance.totalFrames = 0;\n if (!this.performance.cachedFrames) this.performance.cachedFrames = 0;\n (this.performance.totalFrames as number)++;\n if (this.config.skipAllowed) this.performance.cachedFrames++;\n this.performance.cacheCheck = this.env.perfadd ? (this.performance.cacheCheck || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n this.analyze('Check Changed:');\n\n // prepare where to store model results\n // keep them with weak typing as it can be promise or not\n let faceRes: FaceResult[] | Promise | never[] = [];\n let bodyRes: BodyResult[] | Promise | never[] = [];\n let handRes: HandResult[] | Promise | never[] = [];\n let objectRes: ObjectResult[] | Promise | never[] = [];\n\n // run face detection followed by all models that rely on face bounding box: face mesh, age, gender, emotion\n this.state = 'detect:face';\n if (this.config.async) {\n faceRes = this.config.face.enabled ? face.detectFace(this, img.tensor) : [];\n if (this.performance.face) delete this.performance.face;\n } else {\n timeStamp = now();\n faceRes = this.config.face.enabled ? await face.detectFace(this, img.tensor) : [];\n this.performance.face = this.env.perfadd ? (this.performance.face || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n }\n\n if (this.config.async && (this.config.body.maxDetected === -1 || this.config.hand.maxDetected === -1)) faceRes = await faceRes; // need face result for auto-detect number of hands or bodies\n\n // run body: can be posenet, blazepose, efficientpose, movenet\n this.analyze('Start Body:');\n this.state = 'detect:body';\n const bodyConfig = this.config.body.maxDetected === -1 ? mergeDeep(this.config, { body: { maxDetected: this.config.face.enabled ? 1 * (faceRes as FaceResult[]).length : 1 } }) : this.config; // autodetect number of bodies\n if (this.config.async) {\n if (this.config.body.modelPath?.includes('posenet')) bodyRes = this.config.body.enabled ? posenet.predict(img.tensor, bodyConfig) : [];\n else if (this.config.body.modelPath?.includes('blazepose')) bodyRes = this.config.body.enabled ? blazepose.predict(img.tensor, bodyConfig) : [];\n else if (this.config.body.modelPath?.includes('efficientpose')) bodyRes = this.config.body.enabled ? efficientpose.predict(img.tensor, bodyConfig) : [];\n else if (this.config.body.modelPath?.includes('movenet')) bodyRes = this.config.body.enabled ? movenet.predict(img.tensor, bodyConfig) : [];\n if (this.performance.body) delete this.performance.body;\n } else {\n timeStamp = now();\n if (this.config.body.modelPath?.includes('posenet')) bodyRes = this.config.body.enabled ? await posenet.predict(img.tensor, bodyConfig) : [];\n else if (this.config.body.modelPath?.includes('blazepose')) bodyRes = this.config.body.enabled ? await blazepose.predict(img.tensor, bodyConfig) : [];\n else if (this.config.body.modelPath?.includes('efficientpose')) bodyRes = this.config.body.enabled ? await efficientpose.predict(img.tensor, bodyConfig) : [];\n else if (this.config.body.modelPath?.includes('movenet')) bodyRes = this.config.body.enabled ? await movenet.predict(img.tensor, bodyConfig) : [];\n this.performance.body = this.env.perfadd ? (this.performance.body || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n }\n this.analyze('End Body:');\n\n // run handpose\n this.analyze('Start Hand:');\n this.state = 'detect:hand';\n const handConfig = this.config.hand.maxDetected === -1 ? mergeDeep(this.config, { hand: { maxDetected: this.config.face.enabled ? 2 * (faceRes as FaceResult[]).length : 1 } }) : this.config; // autodetect number of hands\n if (this.config.async) {\n if (this.config.hand.detector?.modelPath?.includes('handdetect')) handRes = this.config.hand.enabled ? handpose.predict(img.tensor, handConfig) : [];\n else if (this.config.hand.detector?.modelPath?.includes('handtrack')) handRes = this.config.hand.enabled ? handtrack.predict(img.tensor, handConfig) : [];\n if (this.performance.hand) delete this.performance.hand;\n } else {\n timeStamp = now();\n if (this.config.hand.detector?.modelPath?.includes('handdetect')) handRes = this.config.hand.enabled ? await handpose.predict(img.tensor, handConfig) : [];\n else if (this.config.hand.detector?.modelPath?.includes('handtrack')) handRes = this.config.hand.enabled ? await handtrack.predict(img.tensor, handConfig) : [];\n this.performance.hand = this.env.perfadd ? (this.performance.hand || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n }\n this.analyze('End Hand:');\n\n // run object detection\n this.analyze('Start Object:');\n this.state = 'detect:object';\n if (this.config.async) {\n if (this.config.object.modelPath?.includes('nanodet')) objectRes = this.config.object.enabled ? nanodet.predict(img.tensor, this.config) : [];\n else if (this.config.object.modelPath?.includes('centernet')) objectRes = this.config.object.enabled ? centernet.predict(img.tensor, this.config) : [];\n if (this.performance.object) delete this.performance.object;\n } else {\n timeStamp = now();\n if (this.config.object.modelPath?.includes('nanodet')) objectRes = this.config.object.enabled ? await nanodet.predict(img.tensor, this.config) : [];\n else if (this.config.object.modelPath?.includes('centernet')) objectRes = this.config.object.enabled ? await centernet.predict(img.tensor, this.config) : [];\n this.performance.object = this.env.perfadd ? (this.performance.object || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n }\n this.analyze('End Object:');\n\n // if async wait for results\n this.state = 'detect:await';\n if (this.config.async) [faceRes, bodyRes, handRes, objectRes] = await Promise.all([faceRes, bodyRes, handRes, objectRes]);\n\n // run gesture analysis last\n this.state = 'detect:gesture';\n let gestureRes: GestureResult[] = [];\n if (this.config.gesture.enabled) {\n timeStamp = now();\n gestureRes = [...gesture.face(faceRes as FaceResult[]), ...gesture.body(bodyRes as BodyResult[]), ...gesture.hand(handRes as HandResult[]), ...gesture.iris(faceRes as FaceResult[])];\n if (!this.config.async) this.performance.gesture = this.env.perfadd ? (this.performance.gesture || 0) + Math.trunc(now() - timeStamp) : Math.trunc(now() - timeStamp);\n else if (this.performance.gesture) delete this.performance.gesture;\n }\n\n this.performance.total = this.env.perfadd ? (this.performance.total || 0) + Math.trunc(now() - timeStart) : Math.trunc(now() - timeStart);\n const shape = this.process?.tensor?.shape || [];\n this.result = {\n face: faceRes as FaceResult[],\n body: bodyRes as BodyResult[],\n hand: handRes as HandResult[],\n gesture: gestureRes,\n object: objectRes as ObjectResult[],\n performance: this.performance,\n canvas: this.process.canvas,\n timestamp: Date.now(),\n error: null,\n get persons() { return persons.join(faceRes as FaceResult[], bodyRes as BodyResult[], handRes as HandResult[], gestureRes, shape); },\n };\n\n // finally dispose input tensor\n tf.dispose(img.tensor);\n\n // log('Result:', result);\n this.emit('detect');\n this.state = 'idle';\n resolve(this.result);\n });\n }\n}\n\n/** Class Human as default export */\n/* eslint no-restricted-exports: [\"off\", { \"restrictedNamedExports\": [\"default\"] }] */\nexport { Human as default, match, draw, models };\n"], + "mappings": "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AAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,eAAiB,gBAAiB,EACnC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,eAAiB,gBAAiB,EACnC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,eAAgB,EACnC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,eAAiB,gBAAiB,EACnC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,eAAiB,gBAAiB,EACnC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,eAAiB,gBAAiB,EACnC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,eAAiB,eAAgB,EAClC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,eAAiB,gBAAiB,EACnC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,eAAgB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,cAAgB,gBAAiB,EAClC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,gBAAkB,gBAAiB,EACpC,CAAC,eAAiB,gBAAiB,EACnC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,EACrC,CAAC,iBAAmB,gBAAiB,CACvC,EAEa,GAAwB,CACnC,IAAK,GAAI,IAAK,GAAI,EAAG,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,EACtJ,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,GAAI,GAClJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,EAAG,IAAK,GAAI,GAAI,GAAI,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,GACrJ,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,EAAG,IAC7I,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAClJ,IAAK,IAAK,GAAI,GAAI,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,GAAI,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,GACrJ,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,GACpJ,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,GACjJ,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,EAAG,EAAG,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,EAAG,IAC/I,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,IAAK,EAAG,GAAI,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IACnJ,IAAK,GAAI,EAAG,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IACnJ,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,EAAG,IAAK,IAAK,GAAI,EAAG,GAAI,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAC9I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,EAAG,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GACtJ,GAAI,GAAI,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,GAClJ,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,EAAG,EAAG,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GACnJ,IAAK,IAAK,IAAK,GAAI,GAAI,EAAG,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GACrJ,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IACpJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,EAAG,IAClJ,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,EAAG,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACnJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,GAAI,IAAK,IAAK,IAAK,IACnJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IACnJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAChJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,EAAG,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAChJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAC7I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAClJ,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAC7I,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,IAAK,EAAG,IAAK,GAAI,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GACnJ,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,EAAG,GAAI,EAAG,IAAK,IAAK,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,GACpJ,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,GAAI,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,GAAI,IAAK,GAAI,IAAK,EAAG,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAClJ,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAClJ,GAAI,GAAI,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,GAAI,GAAI,EAA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K,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAC9I,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAChJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAChJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAC9I,IAAK,GAAI,IAAK,EAAG,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAC/I,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAChJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,EAAG,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAClJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IACjJ,IAAK,IA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AAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,QAAU,EAAG,OAAS,EAC3B,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,OAAS,EAAG,MAAQ,EACzB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAAG,KAAO,EACvB,CAAE,EAAG,MAAQ,EAA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AAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;MCjJpB,kBAA4B,EAA8C,CACxE,GAAM,GAAY,CAAC,EAAgB,EAAO,6BAA+B,MAAM,QAAQ,YAAe,GAAQ,EAAE,KAAK,AAAC,GAAQ,EAAI,KAAK,CAAC,EACpI,EACA,EACJ,OAAQ,EAAS,OAAO,YACjB,OAAQ,EAAO,KAAM,GAAiB,EAAI,EAAG,UAC7C,WACA,OAAQ,EAAO,KAAM,GAAiB,EAAI,EAAG,cACzC,EAAO,KAElB,GAAI,EAAM,CACR,GAAM,GAAS,KAAM,mBAAkB,CAAI,EAC3C,EAAM,KAAM,GAAS,OAAO,EAAQ,EAAS,MAAM,EACnD,EAAO,MAAM,CACf,CACA,MAAO,EACT,CAEA,kBAA4B,EAA8C,CACxE,MAAO,IAAI,SAAQ,AAAC,GAAY,CAC9B,GAAI,GAEJ,OAAQ,EAAS,OAAO,YACjB,OAEH,EAAM,0BAAmC,GACzC,UACG,WACA,OAEH,EAAM,0BAAmC,GACzC,cAEA,EAAM,KAGV,GAAI,GACJ,GAAI,MAAO,QAAU,YAAa,EAAM,GAAI,eAEnC,EAAI,MAAO,EAAM,GAAI,GAAI,UAC7B,QACL,EAAI,OAAS,SAAY,CACvB,GAAM,GAAS,AAAM,GAAO,EAAI,aAAc,EAAI,aAAa,EAC/D,GAAI,CAAC,EACH,EAAI,0BAA0B,EAC9B,EAAQ,MAAS,MACZ,CACL,GAAM,GAAM,EAAO,WAAW,IAAI,EAClC,AAAI,GAAK,EAAI,UAAU,EAAK,EAAG,CAAC,EAEhC,GAAM,GAAS,KAAM,GAAS,MAAM,CAAM,EACpC,EAAM,KAAM,GAAS,OAAO,EAAO,OAAkB,EAAS,MAAM,EAC1E,EAAQ,CAAG,CACb,CACF,EACA,AAAI,EAAK,EAAI,IAAM,EACd,EAAQ,MAAS,CACxB,CAAC,CACH,CAEA,kBAA0B,EAA8C,CACtE,GAAM,GAAO,AAAC,GAAgB,OAAO,KAAK,EAAK,QAAQ,EACnD,EACJ,AAAI,EAAS,OAAO,SAAW,OAAQ,EAAM,EAAY,EAAI,EACxD,EAAM,EAAY,EAAI,EAC3B,GAAI,GACJ,GAAI,QAAU,GAAI,CAEhB,GAAM,GAAO,AAAG,OAAQ,WAAW,CAAG,EAChC,EAAW,EAAK,WAAW,CAAC,EAClC,EAAS,GAAG,QAAQ,CAAI,EAExB,EAAM,KAAM,GAAS,OAAO,EAAU,EAAS,MAAM,EACrD,EAAS,GAAG,QAAQ,CAAQ,CAC9B,KACE,AAAI,GAAS,OAAO,OAAO,EAAI,6BAA6B,EAS9D,MAAO,EACT,CAEA,kBAA4B,EAAiB,CAC3C,GAAI,GACJ,MAAI,OAAO,oBAAsB,WAAY,EAAM,KAAM,IAAa,CAAQ,EACzE,AAAI,MAAO,QAAU,aAAe,EAAI,SAAW,OAAW,EAAM,KAAM,IAAa,CAAQ,EAC/F,EAAM,KAAM,IAAW,CAAQ,EAC7B,CACT,CAGA,kBAAiC,EAAmB,CAClD,GAAM,GAAc,AAAG,aAAW,EAC5B,EAAe,AAAG,UAAQ,EAChC,GAAK,IAAgB,SAAW,IAAgB,WAAe,CAAC,GAAgB,CAAC,EAAa,uBAE5F,OAEF,AAAG,MAAI,EAAE,IAAI,sBAAuB,EAAI,EACxC,GAAM,GAAkB,AAAG,SAAO,EAAE,MAAM,WACpC,EAA2B,CAAC,EAClC,OAAW,CAAC,EAAW,IAAU,QAAO,QAAQ,CAAS,EAAE,OAAO,CAAC,CAAC,EAAK,KAAU,IAAQ,MAAQ,IAAQ,IAAK,EAAG,CACjH,GAAM,GAAS,EAAM,QAAU,EAAM,OAAO,IAAM,EAAM,OAAO,GAAG,MAAS,CAAC,GAAG,EAAM,OAAO,GAAG,KAAK,EAAI,CAAC,EAAG,GAAI,GAAI,CAAC,EAC/G,EAAS,EAAM,QAAU,EAAM,OAAO,IAAM,EAAM,OAAO,GAAG,MAAS,EAAM,OAAO,GAAG,MAAQ,UACnG,OAAS,GAAM,EAAG,EAAM,EAAM,OAAQ,IACpC,AAAI,EAAM,KAAS,IAAI,GAAM,GAAO,IAAQ,EAAI,EAAI,IAEtD,GAAM,GAAS,AAAG,QAAM,EAAO,CAAK,EAEpC,GAAI,CACF,GAAM,GAAM,EAAM,QAAQ,CAAM,EAChC,EAAe,KAAK,CAAS,EAC7B,AAAI,MAAM,QAAQ,CAAG,EAAG,EAAI,QAAQ,AAAC,GAAM,AAAG,UAAQ,CAAC,CAAC,EACnD,AAAG,UAAQ,CAAG,CACrB,OAAQ,EAAN,CACA,EAAI,sBAAuB,CAAS,CACtC,CACA,AAAG,UAAQ,CAAM,CACnB,CACA,GAAM,GAAU,KAAM,GAAa,4BAA4B,EAC/D,EAAa,oBAAoB,EACjC,EAAI,uBAAwB,CAAc,EAC1C,EAAI,wBAAyB,EAAQ,MAAM,EAC3C,AAAG,MAAI,EAAE,IAAI,sBAAuB,EAAK,EACzC,GAAM,GAAgB,AAAG,SAAO,EAAE,MAAM,WACxC,AAAK,EAAgB,EAAmB,GAAG,EAAI,eAAgB,EAAgB,CAAe,CAChG,CAOA,kBAA6B,EAAiB,EAA2D,CACvG,GAAM,GAAK,EAAI,EAGf,MAFA,GAAS,MAAQ,SACb,GAAY,GAAS,OAAS,EAAU,EAAS,OAAQ,CAAU,GACnE,CAAC,EAAS,OAAO,QAAU,EAAS,OAAO,OAAO,SAAW,GAAK,EAAS,OAAO,SAAW,OACxF,CAAE,KAAM,CAAC,EAAG,KAAM,CAAC,EAAG,KAAM,CAAC,EAAG,QAAS,CAAC,EAAG,OAAQ,CAAC,EAAG,YAAa,EAAS,YAAa,UAAW,EAAI,EAAG,QAAS,CAAC,EAAG,MAAO,IAAK,EAEzI,GAAI,SAAQ,KAAO,IAAY,CACpC,KAAM,IAAW,EAAS,MAAM,EAChC,GAAM,GAAM,KAAM,IAAa,CAAQ,EACjC,EAAK,EAAI,EACf,AAAI,EAAS,OAAO,OAAO,EAAI,SAAU,EAAS,OAAO,OAAQ,KAAK,MAAM,EAAK,CAAE,EAAG,IAAI,EAC1F,EAAS,KAAK,QAAQ,EACtB,EAAQ,CAAG,CACb,CAAC,CACH,CCvKA,gBAsDa,GAAN,KAAY,CAuEjB,YAAY,EAA8B,CArE1C,kBAKA,iBAKA,iBAMA,gBAGA,kBAMA,aAGA,cAOA,eAMA,iBAWA,iBAEA,4BAEA,oBAEA,sBACA,mBACA,mBACA,mBAEA,aAuDA,iBAAU,IAAI,IAAkB,CAC9B,GAAI,CAAC,QAAK,IAAqB,OAC/B,GAAM,GAAiB,KAAK,GAAG,OAAO,EAAE,MAAM,WACxC,EAAkB,QAAK,IAC7B,QAAK,GAAc,GACnB,GAAM,GAAS,EAAiB,EAChC,AAAI,IAAW,GAAG,EAAI,GAAG,EAAK,CAAM,CACtC,GAGA,WAAU,AAAC,GAAgC,CACzC,GAAI,CAAC,QAAK,IAAc,MAAO,MAC/B,GAAI,CAAC,EAAO,MAAO,uBACnB,GAAI,KAAK,IAAI,MAAQ,CAAE,aAAoB,KAAS,MAAO,yBAC3D,GAAI,CACF,KAAK,GAAG,WAAW,CACrB,OAAQ,EAAN,CACA,MAAO,oBACT,CACA,MAAO,KACT,GAeA,OAAO,aAAmB,IAE1B,OAAO,WAAiB,IAExB,OAAO,QAAc,IAoGrB,cAAO,AAAC,GAAkB,CAzT5B,MA0TI,AAAI,KAAK,QAAU,KAAK,OAAO,eAAe,SAAK,SAAL,QAAa,cAAc,GAAI,OAAM,CAAK,GAC1F,GA7LE,KAAK,IAAM,EACX,GAAS,SAAW,AAAG,GAAQ,aAAa,SAAS,GAAG,EACpD,0CACA,8DAAiE,uBACrE,GAAS,cAAgB,EAAI,QAAU,aAAe,iBACtD,GAAS,QAAU,EAAI,QAAU,UAAY,aAC7C,KAAK,QAAc,GACnB,OAAO,eAAe,KAAM,UAAW,CAAE,MAAW,EAAQ,CAAC,EAC7D,KAAK,OAAS,KAAK,MAAM,KAAK,UAAU,EAAQ,CAAC,EACjD,OAAO,KAAK,KAAK,MAAM,EACvB,KAAK,OAAO,YAAc,MAAO,YAAc,YAC3C,GAAY,MAAK,OAAS,EAAU,KAAK,OAAQ,CAAU,GAC/D,GAAoB,KAAK,MAAM,EAC/B,KAAK,GAAK,EACV,KAAK,MAAQ,OACb,QAAK,GAAc,GACnB,QAAK,GAAsB,IAC3B,QAAK,GAAe,IACpB,KAAK,YAAc,CAAC,EACpB,KAAK,OAAU,MAAO,cAAgB,YAAe,GAAI,aAAgB,OAEzE,KAAK,OAAS,GAAW,IAEzB,KAAK,KAAO,CACV,QAAc,GACd,OAAQ,CAAC,EAAwD,IAAsB,AAAK,GAAO,EAAO,CAAM,EAChH,KAAM,CAAC,EAAmB,EAAsB,IAAmC,AAAK,GAAK,EAAQ,EAAQ,CAAO,EACpH,KAAM,CAAC,EAAmB,EAAsB,IAAmC,AAAK,GAAK,EAAQ,EAAQ,CAAO,EACpH,KAAM,CAAC,EAAmB,EAAsB,IAAmC,AAAK,GAAK,EAAQ,EAAQ,CAAO,EACpH,QAAS,CAAC,EAAmB,EAAyB,IAAmC,AAAK,GAAQ,EAAQ,EAAQ,CAAO,EAC7H,OAAQ,CAAC,EAAmB,EAAwB,IAAmC,AAAK,GAAO,EAAQ,EAAQ,CAAO,EAC1H,OAAQ,CAAC,EAAmB,EAAwB,IAAmC,AAAK,GAAO,EAAQ,EAAQ,CAAO,EAC1H,IAAK,CAAC,EAAmB,EAAgB,IAAmC,AAAK,GAAI,EAAQ,EAAQ,CAAO,CAC9G,EACA,KAAK,OAAS,CAAE,KAAM,CAAC,EAAG,KAAM,CAAC,EAAG,KAAM,CAAC,EAAG,QAAS,CAAC,EAAG,OAAQ,CAAC,EAAG,YAAa,CAAC,EAAG,UAAW,EAAG,QAAS,CAAC,EAAG,MAAO,IAAK,EAG/H,KAAK,QAAU,CAAE,OAAQ,KAAM,OAAQ,IAAK,EAE5C,KAAK,kBAA6B,GAClC,KAAK,UAAqB,GAE1B,KAAK,GAAa,EAElB,KAAK,KAAK,QAAQ,CACpB,CA0BA,OAAc,CACZ,GAAM,GAAiB,KAAK,OAAO,QACnC,KAAK,OAAS,KAAK,MAAM,KAAK,UAAU,EAAQ,CAAC,EACjD,KAAK,OAAO,QAAU,CACxB,CAGA,SAAS,EAA8B,CACrC,MAAO,IAAS,GAAU,GAAc,KAAK,MAAM,CACrD,CAUA,KAAc,CACZ,MAAO,GAAI,CACb,CAQA,MAAM,EAAc,EAAqB,GAAM,CAC7C,MAAO,AAAM,IAAQ,EAAO,KAAK,OAAQ,CAAS,CACpD,CAYA,KAAM,cAAa,EAAc,EAA6G,CAC5I,MAAO,AAAa,IAAQ,EAAO,EAAY,KAAK,MAAM,CAC5D,CAQA,QAAQ,EAA8B,CACpC,MAAO,AAAQ,IAAQ,CAAK,CAC9B,CASA,QAAQ,EAA0B,EAA4C,CAC5E,MAAO,AAAM,IAAQ,KAAK,OAAQ,EAAkB,CAAiB,CACvE,CAOA,KAAM,OAAsB,CAC1B,KAAM,AAAQ,IAAM,KAAM,EAAI,EAC9B,KAAM,MAAK,GAAG,MAAM,CACtB,CAOA,KAAM,MAAK,EAA6C,CACtD,KAAK,MAAQ,OACb,GAAM,GAAY,EAAI,EAChB,EAAQ,OAAO,OAAO,KAAK,MAAM,EAAE,OAAO,AAAC,GAAU,CAAK,EAAE,OAClE,AAAI,GAAY,MAAK,OAAS,EAAU,KAAK,OAAQ,CAAU,GAE3D,KAAK,IAAI,SACP,MAAK,OAAO,OAAO,EAAI,YAAY,KAAK,SAAS,EACjD,KAAK,OAAO,OAAO,EAAI,iBAAiB,KAAK,GAAG,QAAQ,cAAc,EACrE,KAAM,AAAQ,IAAM,IAAI,GAAG,EAAI,6BAA6B,EACjE,KAAM,AAAG,SAAM,EACX,KAAK,IAAI,SACP,MAAK,OAAO,OAAO,EAAI,iBAAkB,KAAK,MAAM,EACpD,KAAK,OAAO,OAAO,EAAI,eAAgB,KAAK,GAAG,EAC/C,KAAK,OAAO,OAAO,EAAI,YAAa,KAAK,GAAG,IAAI,KAAQ,IAIhE,KAAM,AAAO,IAAK,IAAI,EAClB,KAAK,IAAI,SAAW,KAAK,OAAO,OAAO,EAAI,mBAAoB,KAAK,GAAG,OAAO,EAAE,MAAM,SAAU,QAAS,KAAK,GAAG,OAAO,EAAE,MAAM,WAAY,SAAS,EACzJ,KAAK,IAAI,QAAU,GAGf,AADW,OAAO,OAAO,KAAK,MAAM,EAAE,OAAO,AAAC,GAAU,CAAK,EAAE,SACpD,GACb,MAAM,AAAO,IAAS,IAAI,EAC1B,KAAK,KAAK,MAAM,GAGlB,GAAM,GAAU,KAAK,MAAM,EAAI,EAAI,CAAS,EAC5C,AAAI,EAAW,MAAK,YAAY,YAAwB,IAAI,MAAK,YAAY,WAAa,KAAK,IAAI,QAAW,MAAK,YAAY,YAAc,GAAK,EAAU,EAC9J,CAaA,KAAK,EAAiB,KAAK,OAAgB,CACzC,MAAO,AAAY,IAAK,EAAQ,KAAK,MAAM,CAC7C,CAQA,KAAM,QAAO,EAA8B,CACzC,GAAM,GAAK,EAAI,EACT,EAAM,KAAM,AAAQ,IAAO,KAAM,CAAU,EAC3C,EAAK,EAAI,EACf,YAAK,YAAY,OAAS,KAAK,MAAM,EAAK,CAAE,EACrC,CACT,CAMA,KAAM,SAAQ,EAAc,EAA+D,CACzF,GAAM,GAAU,KAAM,MAAK,GAAG,QAAQ,IAAM,KAAK,OAAO,EAAO,CAAU,CAAC,EACpE,EAAkC,CAAC,EACzC,OAAW,KAAU,GAAQ,QAC3B,AAAI,EAAQ,EAAO,MAAO,EAAQ,EAAO,OAAS,EAAO,aACpD,EAAQ,EAAO,MAAQ,EAAO,aAErC,GAAM,GAAiD,CAAC,EACxD,OAAO,QAAQ,CAAO,EAAE,QAAQ,AAAC,GAAQ,EAAU,KAAK,CAAE,KAAM,EAAI,GAAI,GAAI,EAAI,EAAwB,CAAC,CAAC,EAC1G,EAAU,KAAK,CAAC,EAAG,IAAM,EAAE,GAAK,EAAE,EAAE,EACpC,EAAU,OAAS,GACnB,GAAM,GAA8B,CAAC,EACrC,OAAW,KAAU,GAAW,EAAI,EAAO,MAAQ,EAAO,GAC1D,MAAO,EACT,CAYA,KAAM,QAAO,EAAc,EAA+C,CAExE,YAAK,MAAQ,SACN,GAAI,SAAQ,KAAO,IAAY,CAtX1C,mDAuXM,KAAK,MAAQ,SACb,GAAI,GAGJ,KAAK,OAAS,EAAU,KAAK,OAAQ,CAAU,EAG/C,KAAK,MAAQ,QACb,GAAM,GAAQ,QAAK,IAAL,UAAa,GAC3B,AAAI,GACF,GAAI,EAAO,CAAK,EAChB,KAAK,KAAK,OAAO,EACjB,EAAQ,CAAE,KAAM,CAAC,EAAG,KAAM,CAAC,EAAG,KAAM,CAAC,EAAG,QAAS,CAAC,EAAG,OAAQ,CAAC,EAAG,YAAa,KAAK,YAAa,UAAW,EAAI,EAAG,QAAS,CAAC,EAAG,OAAM,CAAC,GAGxI,GAAM,GAAY,EAAI,EAGtB,KAAM,AAAQ,IAAM,IAAI,EAGxB,KAAM,MAAK,KAAK,EAEhB,EAAY,EAAI,EAChB,KAAK,MAAQ,QACb,GAAM,GAAM,KAAM,AAAM,IAAQ,EAAO,KAAK,MAAM,EAKlD,GAJA,KAAK,QAAU,EACf,KAAK,YAAY,aAAe,KAAK,IAAI,QAAW,MAAK,YAAY,cAAgB,GAAK,KAAK,MAAM,EAAI,EAAI,CAAS,EAAI,KAAK,MAAM,EAAI,EAAI,CAAS,EACtJ,KAAK,QAAQ,YAAY,EAErB,CAAC,EAAI,OAAQ,CACf,AAAI,KAAK,OAAO,OAAO,EAAI,mCAAmC,EAC9D,KAAK,KAAK,OAAO,EACjB,EAAQ,CAAE,KAAM,CAAC,EAAG,KAAM,CAAC,EAAG,KAAM,CAAC,EAAG,QAAS,CAAC,EAAG,OAAQ,CAAC,EAAG,YAAa,KAAK,YAAa,UAAW,EAAI,EAAG,QAAS,CAAC,EAAG,MAAO,mCAAoC,CAAC,EAC3K,MACF,CACA,KAAK,KAAK,OAAO,EAEjB,EAAY,EAAI,EAChB,KAAK,OAAO,YAAc,KAAM,AAAM,IAAK,KAAK,OAAQ,EAAI,MAAM,EAC7D,KAAK,YAAY,aAAa,MAAK,YAAY,YAAc,GAC7D,KAAK,YAAY,cAAc,MAAK,YAAY,aAAe,GACnE,KAAK,YAAY,cACd,KAAK,OAAO,aAAa,KAAK,YAAY,eAC9C,KAAK,YAAY,WAAa,KAAK,IAAI,QAAW,MAAK,YAAY,YAAc,GAAK,KAAK,MAAM,EAAI,EAAI,CAAS,EAAI,KAAK,MAAM,EAAI,EAAI,CAAS,EAClJ,KAAK,QAAQ,gBAAgB,EAI7B,GAAI,GAA0D,CAAC,EAC3D,EAA0D,CAAC,EAC3D,EAA0D,CAAC,EAC3D,EAAgE,CAAC,EAGrE,KAAK,MAAQ,cACb,AAAI,KAAK,OAAO,MACd,GAAU,KAAK,OAAO,KAAK,QAAU,AAAK,GAAW,KAAM,EAAI,MAAM,EAAI,CAAC,EACtE,KAAK,YAAY,MAAM,MAAO,MAAK,YAAY,MAEnD,GAAY,EAAI,EAChB,EAAU,KAAK,OAAO,KAAK,QAAU,KAAM,AAAK,IAAW,KAAM,EAAI,MAAM,EAAI,CAAC,EAChF,KAAK,YAAY,KAAO,KAAK,IAAI,QAAW,MAAK,YAAY,MAAQ,GAAK,KAAK,MAAM,EAAI,EAAI,CAAS,EAAI,KAAK,MAAM,EAAI,EAAI,CAAS,GAGpI,KAAK,OAAO,OAAU,MAAK,OAAO,KAAK,cAAgB,IAAM,KAAK,OAAO,KAAK,cAAgB,KAAK,GAAU,KAAM,IAGvH,KAAK,QAAQ,aAAa,EAC1B,KAAK,MAAQ,cACb,GAAM,GAAa,KAAK,OAAO,KAAK,cAAgB,GAAK,EAAU,KAAK,OAAQ,CAAE,KAAM,CAAE,YAAa,KAAK,OAAO,KAAK,QAAU,EAAK,EAAyB,OAAS,CAAE,CAAE,CAAC,EAAI,KAAK,OACvL,AAAI,KAAK,OAAO,MACd,CAAI,QAAK,OAAO,KAAK,YAAjB,QAA4B,SAAS,WAAY,EAAU,KAAK,OAAO,KAAK,QAAU,AAAQ,GAAQ,EAAI,OAAQ,CAAU,EAAI,CAAC,EAChI,AAAI,QAAK,OAAO,KAAK,YAAjB,QAA4B,SAAS,aAAc,EAAU,KAAK,OAAO,KAAK,QAAU,AAAU,GAAQ,EAAI,OAAQ,CAAU,EAAI,CAAC,EACzI,AAAI,QAAK,OAAO,KAAK,YAAjB,QAA4B,SAAS,iBAAkB,EAAU,KAAK,OAAO,KAAK,QAAU,AAAc,GAAQ,EAAI,OAAQ,CAAU,EAAI,CAAC,EAC7I,QAAK,OAAO,KAAK,YAAjB,QAA4B,SAAS,YAAY,GAAU,KAAK,OAAO,KAAK,QAAU,AAAQ,GAAQ,EAAI,OAAQ,CAAU,EAAI,CAAC,GACtI,KAAK,YAAY,MAAM,MAAO,MAAK,YAAY,MAEnD,GAAY,EAAI,EAChB,AAAI,QAAK,OAAO,KAAK,YAAjB,QAA4B,SAAS,WAAY,EAAU,KAAK,OAAO,KAAK,QAAU,KAAM,AAAQ,IAAQ,EAAI,OAAQ,CAAU,EAAI,CAAC,EACtI,AAAI,QAAK,OAAO,KAAK,YAAjB,QAA4B,SAAS,aAAc,EAAU,KAAK,OAAO,KAAK,QAAU,KAAM,AAAU,IAAQ,EAAI,OAAQ,CAAU,EAAI,CAAC,EAC/I,AAAI,QAAK,OAAO,KAAK,YAAjB,QAA4B,SAAS,iBAAkB,EAAU,KAAK,OAAO,KAAK,QAAU,KAAM,AAAc,IAAQ,EAAI,OAAQ,CAAU,EAAI,CAAC,EACnJ,QAAK,OAAO,KAAK,YAAjB,QAA4B,SAAS,YAAY,GAAU,KAAK,OAAO,KAAK,QAAU,KAAM,AAAQ,IAAQ,EAAI,OAAQ,CAAU,EAAI,CAAC,GAChJ,KAAK,YAAY,KAAO,KAAK,IAAI,QAAW,MAAK,YAAY,MAAQ,GAAK,KAAK,MAAM,EAAI,EAAI,CAAS,EAAI,KAAK,MAAM,EAAI,EAAI,CAAS,GAExI,KAAK,QAAQ,WAAW,EAGxB,KAAK,QAAQ,aAAa,EAC1B,KAAK,MAAQ,cACb,GAAM,GAAa,KAAK,OAAO,KAAK,cAAgB,GAAK,EAAU,KAAK,OAAQ,CAAE,KAAM,CAAE,YAAa,KAAK,OAAO,KAAK,QAAU,EAAK,EAAyB,OAAS,CAAE,CAAE,CAAC,EAAI,KAAK,OACvL,AAAI,KAAK,OAAO,MACd,CAAI,WAAK,OAAO,KAAK,WAAjB,cAA2B,YAA3B,QAAsC,SAAS,cAAe,EAAU,KAAK,OAAO,KAAK,QAAU,AAAS,GAAQ,EAAI,OAAQ,CAAU,EAAI,CAAC,EAC1I,WAAK,OAAO,KAAK,WAAjB,cAA2B,YAA3B,QAAsC,SAAS,cAAc,GAAU,KAAK,OAAO,KAAK,QAAU,AAAU,GAAQ,EAAI,OAAQ,CAAU,EAAI,CAAC,GACpJ,KAAK,YAAY,MAAM,MAAO,MAAK,YAAY,MAEnD,GAAY,EAAI,EAChB,AAAI,WAAK,OAAO,KAAK,WAAjB,cAA2B,YAA3B,QAAsC,SAAS,cAAe,EAAU,KAAK,OAAO,KAAK,QAAU,KAAM,AAAS,IAAQ,EAAI,OAAQ,CAAU,EAAI,CAAC,EAChJ,YAAK,OAAO,KAAK,WAAjB,cAA2B,YAA3B,SAAsC,SAAS,cAAc,GAAU,KAAK,OAAO,KAAK,QAAU,KAAM,AAAU,IAAQ,EAAI,OAAQ,CAAU,EAAI,CAAC,GAC9J,KAAK,YAAY,KAAO,KAAK,IAAI,QAAW,MAAK,YAAY,MAAQ,GAAK,KAAK,MAAM,EAAI,EAAI,CAAS,EAAI,KAAK,MAAM,EAAI,EAAI,CAAS,GAExI,KAAK,QAAQ,WAAW,EAGxB,KAAK,QAAQ,eAAe,EAC5B,KAAK,MAAQ,gBACb,AAAI,KAAK,OAAO,MACd,CAAI,SAAK,OAAO,OAAO,YAAnB,SAA8B,SAAS,WAAY,EAAY,KAAK,OAAO,OAAO,QAAU,AAAQ,GAAQ,EAAI,OAAQ,KAAK,MAAM,EAAI,CAAC,EACnI,QAAK,OAAO,OAAO,YAAnB,QAA8B,SAAS,cAAc,GAAY,KAAK,OAAO,OAAO,QAAU,AAAU,GAAQ,EAAI,OAAQ,KAAK,MAAM,EAAI,CAAC,GACjJ,KAAK,YAAY,QAAQ,MAAO,MAAK,YAAY,QAErD,GAAY,EAAI,EAChB,AAAI,SAAK,OAAO,OAAO,YAAnB,SAA8B,SAAS,WAAY,EAAY,KAAK,OAAO,OAAO,QAAU,KAAM,AAAQ,IAAQ,EAAI,OAAQ,KAAK,MAAM,EAAI,CAAC,EACzI,QAAK,OAAO,OAAO,YAAnB,QAA8B,SAAS,cAAc,GAAY,KAAK,OAAO,OAAO,QAAU,KAAM,AAAU,IAAQ,EAAI,OAAQ,KAAK,MAAM,EAAI,CAAC,GAC3J,KAAK,YAAY,OAAS,KAAK,IAAI,QAAW,MAAK,YAAY,QAAU,GAAK,KAAK,MAAM,EAAI,EAAI,CAAS,EAAI,KAAK,MAAM,EAAI,EAAI,CAAS,GAE5I,KAAK,QAAQ,aAAa,EAG1B,KAAK,MAAQ,eACT,KAAK,OAAO,OAAO,EAAC,EAAS,EAAS,EAAS,CAAS,EAAI,KAAM,SAAQ,IAAI,CAAC,EAAS,EAAS,EAAS,CAAS,CAAC,GAGxH,KAAK,MAAQ,iBACb,GAAI,GAA8B,CAAC,EACnC,AAAI,KAAK,OAAO,QAAQ,SACtB,GAAY,EAAI,EAChB,EAAa,CAAC,GAAG,AAAQ,GAAK,CAAuB,EAAG,GAAG,AAAQ,GAAK,CAAuB,EAAG,GAAG,AAAQ,GAAK,CAAuB,EAAG,GAAG,AAAQ,GAAK,CAAuB,CAAC,EACpL,AAAK,KAAK,OAAO,MACR,KAAK,YAAY,SAAS,MAAO,MAAK,YAAY,QADnC,KAAK,YAAY,QAAU,KAAK,IAAI,QAAW,MAAK,YAAY,SAAW,GAAK,KAAK,MAAM,EAAI,EAAI,CAAS,EAAI,KAAK,MAAM,EAAI,EAAI,CAAS,GAItK,KAAK,YAAY,MAAQ,KAAK,IAAI,QAAW,MAAK,YAAY,OAAS,GAAK,KAAK,MAAM,EAAI,EAAI,CAAS,EAAI,KAAK,MAAM,EAAI,EAAI,CAAS,EACxI,GAAM,GAAQ,YAAK,UAAL,cAAc,SAAd,cAAsB,QAAS,CAAC,EAC9C,KAAK,OAAS,CACZ,KAAM,EACN,KAAM,EACN,KAAM,EACN,QAAS,EACT,OAAQ,EACR,YAAa,KAAK,YAClB,OAAQ,KAAK,QAAQ,OACrB,UAAW,KAAK,IAAI,EACpB,MAAO,KACP,GAAI,UAAU,CAAE,MAAO,AAAQ,IAAK,EAAyB,EAAyB,EAAyB,EAAY,CAAK,CAAG,CACrI,EAGA,AAAG,UAAQ,EAAI,MAAM,EAGrB,KAAK,KAAK,QAAQ,EAClB,KAAK,MAAQ,OACb,EAAQ,KAAK,MAAM,CACrB,CAAC,CACH,CACF,EAhaE,eACA,eACA,eAmEA", "names": [] } diff --git a/dist/human.esm.js b/dist/human.esm.js index 6fef0139..be789cd1 100644 --- a/dist/human.esm.js +++ b/dist/human.esm.js @@ -223,10 +223,10 @@ __export(tfjs_esm_exports, { Abs: () => lo, Acos: () => ul, Acosh: () => ll, - AdadeltaOptimizer: () => kb, - AdagradOptimizer: () => Sb, - AdamOptimizer: () => Ib, - AdamaxOptimizer: () => Cb, + AdadeltaOptimizer: () => Sb, + AdagradOptimizer: () => Ib, + AdamOptimizer: () => Cb, + AdamaxOptimizer: () => Nb, Add: () => Ir, AddN: () => Sa, All: () => cl, @@ -239,57 +239,57 @@ __export(tfjs_esm_exports, { Atan2: () => bl, Atanh: () => gl, AvgPool: () => Ca, - AvgPool3D: () => Jd, - AvgPool3DGrad: () => fg, - AvgPoolGrad: () => hg, - BackendWasm: () => ape, + AvgPool3D: () => ep, + AvgPool3DGrad: () => mg, + AvgPoolGrad: () => fg, + BackendWasm: () => ope, BatchMatMul: () => Na, BatchToSpaceND: () => co, - Bincount: () => mg, - BroadcastArgs: () => gg, - BroadcastTo: () => V$, - Callback: () => qW, - CallbackList: () => uB, + Bincount: () => gg, + BroadcastArgs: () => bg, + BroadcastTo: () => U$, + Callback: () => KW, + CallbackList: () => cB, Cast: () => Ta, Ceil: () => $a, ClipByValue: () => Cr, - Complex: () => ep, - ComplexAbs: () => tp, + Complex: () => tp, + ComplexAbs: () => np, Concat: () => po, Conv2D: () => _a, - Conv2DBackpropFilter: () => bg, + Conv2DBackpropFilter: () => yg, Conv2DBackpropInput: () => Aa, - Conv3D: () => np, - Conv3DBackpropFilterV2: () => yg, - Conv3DBackpropInputV2: () => vg, + Conv3D: () => sp, + Conv3DBackpropFilterV2: () => vg, + Conv3DBackpropInputV2: () => xg, Cos: () => Ea, Cosh: () => Ra, CropAndResize: () => fo, Cumprod: () => ho, Cumsum: () => Da, - CustomCallback: () => dB, - DataStorage: () => Yd, - DenseBincount: () => xg, + CustomCallback: () => hB, + DataStorage: () => Qd, + DenseBincount: () => wg, DepthToSpace: () => mo, DepthwiseConv2dNative: () => Fa, - DepthwiseConv2dNativeBackpropFilter: () => wg, - DepthwiseConv2dNativeBackpropInput: () => kg, - Diag: () => Sg, - Dilation2D: () => sp, - Dilation2DBackpropFilter: () => rm, - Dilation2DBackpropInput: () => sm, - ENV: () => lk, - EarlyStopping: () => jW, - Einsum: () => rp, + DepthwiseConv2dNativeBackpropFilter: () => kg, + DepthwiseConv2dNativeBackpropInput: () => Sg, + Diag: () => Ig, + Dilation2D: () => rp, + Dilation2DBackpropFilter: () => am, + Dilation2DBackpropInput: () => rm, + ENV: () => dk, + EarlyStopping: () => XW, + Einsum: () => ap, Elu: () => Pa, - EluGrad: () => Ig, - Environment: () => O$, + EluGrad: () => Cg, + Environment: () => z$, Equal: () => go, Erf: () => yl, Exp: () => za, ExpandDims: () => bo, Expm1: () => yo, - FFT: () => Cg, + FFT: () => Ng, Fill: () => vl, FlipLeftRight: () => vo, Floor: () => Ma, @@ -298,94 +298,94 @@ __export(tfjs_esm_exports, { FusedBatchNorm: () => Ba, FusedConv2D: () => oa, FusedDepthwiseConv2D: () => ua, - GPGPUContext: () => tm, + GPGPUContext: () => nm, GatherNd: () => wo, GatherV2: () => xo, - GraphModel: () => E0, + GraphModel: () => D0, Greater: () => ko, GreaterEqual: () => Va, - History: () => cB, - IFFT: () => Ng, + History: () => pB, + IFFT: () => Tg, Identity: () => Wa, - Imag: () => ap, - InputSpec: () => Ft, + Imag: () => ip, + InputSpec: () => Dt, IsFinite: () => xl, IsInf: () => wl, IsNan: () => kl, KernelBackend: () => ol, - LRN: () => op, - LRNGrad: () => $g, - LayerVariable: () => Sz, + LRN: () => up, + LRNGrad: () => _g, + LayerVariable: () => Cz, LayersModel: () => dr, LeakyRelu: () => Ua, Less: () => So, LessEqual: () => Io, - LinSpace: () => Tg, + LinSpace: () => $g, Log: () => Ga, Log1p: () => Sl, - LogSoftmax: () => W$, + LogSoftmax: () => G$, LogicalAnd: () => Co, LogicalNot: () => Il, - LogicalOr: () => ip, - LowerBound: () => dpe, - MathBackendCPU: () => J0, - MathBackendWebGL: () => Q1, + LogicalOr: () => op, + LowerBound: () => hpe, + MathBackendCPU: () => tC, + MathBackendWebGL: () => J1, Max: () => Ha, MaxPool: () => ja, - MaxPool3D: () => up, - MaxPool3DGrad: () => Ag, - MaxPoolGrad: () => _g, - MaxPoolWithArgmax: () => Eg, + MaxPool3D: () => lp, + MaxPool3DGrad: () => Eg, + MaxPoolGrad: () => Ag, + MaxPoolWithArgmax: () => Rg, Maximum: () => qa, Mean: () => Ka, Min: () => Xa, Minimum: () => Ya, MirrorPad: () => Qa, Mod: () => Cl, - MomentumOptimizer: () => Nb, - Multinomial: () => Rg, + MomentumOptimizer: () => Tb, + Multinomial: () => Dg, Multiply: () => Za, Neg: () => No, NonMaxSuppressionV3: () => $o, NonMaxSuppressionV4: () => Nl, NonMaxSuppressionV5: () => _o, NotEqual: () => To, - OP_SCOPE_SUFFIX: () => x_, + OP_SCOPE_SUFFIX: () => k_, OneHot: () => Eo, OnesLike: () => Ao, Optimizer: () => Ar, OptimizerConstructors: () => Gr, Pack: () => Ro, PadV2: () => Ja, - Pool: () => ppe, + Pool: () => fpe, Pow: () => ei, Prelu: () => ti, Prod: () => ni, - RMSPropOptimizer: () => Tb, + RMSPropOptimizer: () => $b, RNN: () => Er, Range: () => Tl, - Rank: () => d_, - Real: () => lp, + Rank: () => h_, + Real: () => cp, RealDiv: () => Oa, Reciprocal: () => $l, - Reduction: () => SO, + Reduction: () => CO, Relu: () => si, Relu6: () => ai, Reshape: () => Do, ResizeBilinear: () => ri, - ResizeBilinearGrad: () => Fg, + ResizeBilinearGrad: () => Og, ResizeNearestNeighbor: () => _l, - ResizeNearestNeighborGrad: () => Dg, + ResizeNearestNeighborGrad: () => Fg, Reverse: () => Fo, RotateWithOffset: () => Ko, Round: () => Oo, Rsqrt: () => ii, - SGDOptimizer: () => Ep, + SGDOptimizer: () => Rp, ScatterNd: () => Po, - SearchSorted: () => Og, + SearchSorted: () => Pg, Select: () => zo, Selu: () => Al, - Sequential: () => Qb, + Sequential: () => Zb, Sigmoid: () => ui, Sign: () => El, Sin: () => oi, @@ -394,358 +394,358 @@ __export(tfjs_esm_exports, { Softmax: () => di, Softplus: () => Rl, SpaceToBatchND: () => Bo, - SparseFillEmptyRows: () => cp, + SparseFillEmptyRows: () => dp, SparseReshape: () => Dl, - SparseSegmentMean: () => dp, - SparseSegmentSum: () => pp, - SparseToDense: () => hp, + SparseSegmentMean: () => pp, + SparseSegmentSum: () => hp, + SparseToDense: () => fp, SplitV: () => Vo, Sqrt: () => li, Square: () => Fl, SquaredDifference: () => pi, Step: () => mi, StridedSlice: () => Wo, - StringNGrams: () => fp, - StringSplit: () => Pg, - StringToHashBucketFast: () => zg, + StringNGrams: () => mp, + StringSplit: () => zg, + StringToHashBucketFast: () => Mg, Sub: () => hi, Sum: () => ci, SymbolicTensor: () => $s, Tan: () => Uo, Tanh: () => fi, Tensor: () => et, - TensorBuffer: () => Wt, + TensorBuffer: () => Vt, Tile: () => Nr, TopK: () => Go, Transform: () => Ho, Transpose: () => Hs, - Unique: () => Mg, + Unique: () => Lg, Unpack: () => qo, - UnsortedSegmentSum: () => mp, - UpperBound: () => hpe, + UnsortedSegmentSum: () => gp, + UpperBound: () => mpe, Variable: () => wd, ZerosLike: () => jo, _FusedMatMul: () => ia, - abs: () => Lt, - acos: () => aE, - acosh: () => oE, + abs: () => Mt, + acos: () => oE, + acosh: () => lE, add: () => ie, - addN: () => lE, - all: () => rS, - any: () => vm, + addN: () => dE, + all: () => iS, + any: () => xm, argMax: () => Xu, - argMin: () => fE, - asin: () => gE, - asinh: () => yE, - atan: () => xE, - atan2: () => kE, - atanh: () => IE, - avgPool: () => Zg, - avgPool3d: () => uS, - backend: () => wA, + argMin: () => gE, + asin: () => yE, + asinh: () => xE, + atan: () => kE, + atan2: () => IE, + atanh: () => NE, + avgPool: () => Jg, + avgPool3d: () => cS, + backend: () => SA, backend_util: () => C, - basicLSTMCell: () => Epe, + basicLSTMCell: () => Dpe, batchNorm: () => Qu, - batchNorm2d: () => UE, - batchNorm3d: () => HE, - batchNorm4d: () => jE, - batchToSpaceND: () => Jg, - bincount: () => lS, - booleanMaskAsync: () => ahe, - broadcastArgs: () => YE, + batchNorm2d: () => HE, + batchNorm3d: () => jE, + batchNorm4d: () => XE, + batchToSpaceND: () => eb, + bincount: () => dS, + booleanMaskAsync: () => ohe, + broadcastArgs: () => ZE, broadcastTo: () => id, broadcast_util: () => Xo, - browser: () => Lk, + browser: () => Vk, buffer: () => Ae, - callbacks: () => mhe, + callbacks: () => bhe, cast: () => le, - ceil: () => JE, + ceil: () => tR, clipByValue: () => Vn, clone: () => ur, complex: () => fr, - concat: () => Ot, - concat1d: () => nR, - concat2d: () => rR, - concat3d: () => iR, - concat4d: () => uR, - constraints: () => LL, - conv1d: () => cS, + concat: () => Ft, + concat1d: () => rR, + concat2d: () => iR, + concat3d: () => uR, + concat4d: () => cR, + constraints: () => VL, + conv1d: () => pS, conv2d: () => da, - conv2dTranspose: () => dS, - conv3d: () => pS, - conv3dTranspose: () => gR, - copyRegisteredKernels: () => gpe, - cos: () => tb, - cosh: () => fS, - cosineWindow: () => LS, - cumprod: () => wm, - cumsum: () => mS, + conv2dTranspose: () => hS, + conv3d: () => fS, + conv3dTranspose: () => yR, + copyRegisteredKernels: () => ype, + cos: () => nb, + cosh: () => gS, + cosineWindow: () => VS, + cumprod: () => km, + cumsum: () => bS, customGrad: () => js, - data: () => J4, - denseBincount: () => kR, - deprecationWarn: () => zk, - depthToSpace: () => IR, - depthwiseConv2d: () => wp, - deregisterOp: () => bhe, - device_util: () => yp, - diag: () => Rpe, - dilation2d: () => $R, - disableDeprecationWarnings: () => vpe, + data: () => tU, + denseBincount: () => IR, + deprecationWarn: () => Lk, + depthToSpace: () => NR, + depthwiseConv2d: () => kp, + deregisterOp: () => vhe, + device_util: () => vp, + diag: () => Fpe, + dilation2d: () => AR, + disableDeprecationWarnings: () => wpe, dispose: () => De, - disposeVariables: () => xpe, + disposeVariables: () => kpe, div: () => xe, - divNoNan: () => DR, - dot: () => Dpe, - dropout: () => yF, - einsum: () => PR, - elu: () => kp, - enableDebugMode: () => ype, - enableProdMode: () => bpe, - enclosingPowerOfTwo: () => vF, + divNoNan: () => OR, + dot: () => Ope, + dropout: () => xF, + einsum: () => MR, + elu: () => Sp, + enableDebugMode: () => xpe, + enableProdMode: () => vpe, + enclosingPowerOfTwo: () => wF, engine: () => ds, env: () => K, equal: () => Xn, - erf: () => LR, - euclideanNorm: () => YR, + erf: () => VR, + euclideanNorm: () => ZR, exp: () => Yn, expandDims: () => Pn, - expm1: () => eD, - eye: () => xS, - fft: () => bb, + expm1: () => nD, + eye: () => kS, + fft: () => yb, fill: () => Bl, - findBackend: () => Tpe, - findBackendFactory: () => $pe, - floor: () => Sp, - floorDiv: () => sS, - forceHalfFloat: () => b8, + findBackend: () => _pe, + findBackendFactory: () => Ape, + floor: () => Ip, + floorDiv: () => aS, + forceHalfFloat: () => v8, fused: () => fa, gather: () => Zu, - gatherND: () => mF, - gather_util: () => Vk, - getBackend: () => Cpe, - getGradient: () => lx, - getKernel: () => am, - getKernelsForBackend: () => im, - getThreadsCount: () => $he, - gpgpu_util: () => rX, - grad: () => Ppe, - grads: () => zpe, + gatherND: () => bF, + gather_util: () => Uk, + getBackend: () => Tpe, + getGradient: () => cx, + getKernel: () => im, + getKernelsForBackend: () => om, + getThreadsCount: () => Ahe, + gpgpu_util: () => iX, + grad: () => Mpe, + grads: () => Lpe, greater: () => Un, greaterEqual: () => Yo, ifft: () => Td, - imag: () => xp, + imag: () => wp, image: () => jn, - inTopKAsync: () => ohe, - initializers: () => GL, - input: () => nV, + inTopKAsync: () => lhe, + initializers: () => qL, + input: () => rV, io: () => An, - irfft: () => FS, - isFinite: () => Fpe, - isInf: () => Ope, - isNaN: () => cD, - keep: () => qt, + irfft: () => PS, + isFinite: () => Ppe, + isInf: () => zpe, + isNaN: () => pD, + keep: () => Ht, kernel_impls: () => ws, - layers: () => iB, - leakyRelu: () => ab, - less: () => wS, + layers: () => uB, + leakyRelu: () => ib, + less: () => SS, lessEqual: () => Qo, - linalg: () => sP, - linspace: () => fD, - loadGraphModel: () => yhe, - loadGraphModelSync: () => vhe, - loadLayersModel: () => hhe, - localResponseNormalization: () => gD, + linalg: () => aP, + linspace: () => gD, + loadGraphModel: () => xhe, + loadGraphModelSync: () => whe, + loadLayersModel: () => mhe, + localResponseNormalization: () => yD, log: () => Qn, - log1p: () => ib, - logSigmoid: () => Bpe, - logSoftmax: () => kS, - logSumExp: () => CD, + log1p: () => ob, + logSigmoid: () => Wpe, + logSoftmax: () => IS, + logSumExp: () => TD, logicalAnd: () => Ds, - logicalNot: () => ob, - logicalOr: () => SS, - logicalXor: () => Vpe, - losses: () => che, - lowerBound: () => ED, - matMul: () => Ve, - math: () => yA, + logicalNot: () => ub, + logicalOr: () => CS, + logicalXor: () => Upe, + losses: () => phe, + lowerBound: () => DD, + matMul: () => We, + math: () => xA, max: () => As, - maxPool: () => ub, - maxPool3d: () => CS, - maxPoolWithArgmax: () => OD, + maxPool: () => lb, + maxPool3d: () => TS, + maxPoolWithArgmax: () => zD, maximum: () => _r, mean: () => It, - memory: () => gm, - meshgrid: () => Wpe, - metrics: () => CW, - min: () => km, - minimum: () => Cp, - mirrorPad: () => BD, - mod: () => WD, - model: () => dhe, - models: () => VW, - moments: () => lb, - movingAverage: () => ihe, + memory: () => bm, + meshgrid: () => Gpe, + metrics: () => TW, + min: () => Sm, + minimum: () => Np, + mirrorPad: () => WD, + mod: () => GD, + model: () => hhe, + models: () => UW, + moments: () => cb, + movingAverage: () => uhe, mul: () => V, - multiRNNCell: () => Upe, - multinomial: () => qD, + multiRNNCell: () => Hpe, + multinomial: () => KD, neg: () => vt, - nextFrame: () => jS, - norm: () => rb, + nextFrame: () => XS, + norm: () => ab, notEqual: () => Ju, oneHot: () => Id, ones: () => Mn, onesLike: () => Zn, op: () => L, - outerProduct: () => Gpe, + outerProduct: () => qpe, pad: () => gi, - pad1d: () => Hpe, - pad2d: () => qpe, - pad3d: () => jpe, - pad4d: () => Kpe, - pool: () => Xpe, + pad1d: () => jpe, + pad2d: () => Kpe, + pad3d: () => Xpe, + pad4d: () => Ype, + pool: () => Qpe, pow: () => ha, - prelu: () => db, - print: () => eA, - prod: () => NS, - profile: () => wpe, - rand: () => Ype, - randomGamma: () => Qpe, - randomNormal: () => p3, + prelu: () => pb, + print: () => nA, + prod: () => $S, + profile: () => Spe, + rand: () => Zpe, + randomGamma: () => Jpe, + randomNormal: () => f3, randomUniform: () => Wl, range: () => el, - ready: () => Ipe, + ready: () => Npe, real: () => Ku, - reciprocal: () => m3, - registerBackend: () => vp, - registerCallbackConstructor: () => fhe, - registerGradient: () => G$, + reciprocal: () => b3, + registerBackend: () => xp, + registerCallbackConstructor: () => ghe, + registerGradient: () => q$, registerKernel: () => Ol, - registerOp: () => ghe, - regularizers: () => WW, + registerOp: () => yhe, + regularizers: () => GW, relu: () => Xs, - relu6: () => TS, - removeBackend: () => Npe, + relu6: () => _S, + removeBackend: () => $pe, reshape: () => U, reverse: () => Jn, - reverse1d: () => Zpe, - reverse2d: () => Jpe, - reverse3d: () => ehe, - reverse4d: () => the, - rfft: () => yb, - round: () => $S, - rsqrt: () => _S, + reverse1d: () => ehe, + reverse2d: () => the, + reverse3d: () => nhe, + reverse4d: () => she, + rfft: () => vb, + round: () => AS, + rsqrt: () => ES, scalar: () => we, - scatterND: () => dF, - scatter_util: () => Uk, - searchSorted: () => IS, - selu: () => AS, - separableConv2d: () => T3, - sequential: () => phe, + scatterND: () => hF, + scatter_util: () => Hk, + searchSorted: () => NS, + selu: () => RS, + separableConv2d: () => _3, + sequential: () => fhe, serialization: () => re, - setBackend: () => Spe, - setPlatform: () => _pe, - setThreadsCount: () => The, - setWasmPath: () => Che, - setWasmPaths: () => Nhe, - setWebGLContext: () => Y5, - setdiff1dAsync: () => _3, - shared: () => iv, + setBackend: () => Cpe, + setPlatform: () => Epe, + setThreadsCount: () => _he, + setWasmPath: () => The, + setWasmPaths: () => $he, + setWebGLContext: () => Z5, + setdiff1dAsync: () => E3, + shared: () => ov, sigmoid: () => qs, - sign: () => E3, - signal: () => lhe, - sin: () => ES, - sinh: () => RS, + sign: () => D3, + signal: () => dhe, + sin: () => DS, + sinh: () => FS, slice: () => qe, - slice1d: () => fb, - slice2d: () => DS, - slice3d: () => mb, + slice1d: () => mb, + slice2d: () => OS, + slice3d: () => gb, slice4d: () => Nd, slice_util: () => kt, - softmax: () => gb, + softmax: () => bb, softplus: () => Vl, - spaceToBatchND: () => cb, + spaceToBatchND: () => db, sparse: () => qc, - sparseToDense: () => MS, - spectral: () => uhe, + sparseToDense: () => BS, + spectral: () => che, split: () => Bn, - sqrt: () => dn, + sqrt: () => cn, square: () => ct, - squaredDifference: () => OS, + squaredDifference: () => zS, squeeze: () => gr, stack: () => es, - step: () => Np, - stridedSlice: () => X3, - string: () => qf, + step: () => Tp, + stridedSlice: () => Q3, + string: () => jf, sub: () => ge, sum: () => ve, - sumOutType: () => bp, - tan: () => Q3, + sumOutType: () => yp, + tan: () => J3, tanh: () => Yu, tensor: () => ms, - tensor1d: () => Zt, + tensor1d: () => Qt, tensor2d: () => Yi, - tensor3d: () => $A, - tensor4d: () => nhe, - tensor5d: () => she, - tensor6d: () => rhe, + tensor3d: () => AA, + tensor4d: () => rhe, + tensor5d: () => ahe, + tensor6d: () => ihe, tensor_util: () => _s, - test_util: () => HA, + test_util: () => jA, tidy: () => q, tile: () => hs, - time: () => kpe, - topk: () => J3, + time: () => Ipe, + topk: () => tF, train: () => zi, transpose: () => Ge, - truncatedNormal: () => vb, - unique: () => xx, - unregisterGradient: () => mpe, - unregisterKernel: () => fpe, - unsortedSegmentSum: () => sF, + truncatedNormal: () => xb, + unique: () => wx, + unregisterGradient: () => bpe, + unregisterKernel: () => gpe, + unsortedSegmentSum: () => aF, unstack: () => Fs, - upcastType: () => cn, - upperBound: () => aF, + upcastType: () => ln, + upperBound: () => oF, util: () => w, - valueAndGrad: () => Mpe, - valueAndGrads: () => Lpe, - variable: () => iF, - variableGrads: () => vD, - version: () => Ahe, - version_converter: () => xhe, - version_core: () => Ape, - version_cpu: () => whe, - version_layers: () => wI, - version_wasm: () => _he, - version_webgl: () => khe, - webgl: () => She, - webgl_util: () => X5, - webgpu: () => Voe, + valueAndGrad: () => Bpe, + valueAndGrads: () => Vpe, + variable: () => uF, + variableGrads: () => wD, + version: () => Rhe, + version_converter: () => khe, + version_core: () => Rpe, + version_cpu: () => She, + version_layers: () => SI, + version_wasm: () => Ehe, + version_webgl: () => Ihe, + webgl: () => Che, + webgl_util: () => Q5, + webgpu: () => Uoe, where: () => vn, - whereAsync: () => zS, + whereAsync: () => LS, zeros: () => $t, zerosLike: () => je }); -var YT = Object.create; -var Kd = Object.defineProperty; -var QT = Object.getOwnPropertyDescriptor; -var Qw = Object.getOwnPropertyNames; -var ZT = Object.getPrototypeOf; -var JT = Object.prototype.hasOwnProperty; -var e$ = (e) => Kd(e, "__esModule", { value: true }); -var Mt = (e, t) => function() { - return t || (0, e[Qw(e)[0]])((t = { exports: {} }).exports, t), t.exports; +var ZT = Object.create; +var Xd = Object.defineProperty; +var JT = Object.getOwnPropertyDescriptor; +var Jw = Object.getOwnPropertyNames; +var e$ = Object.getPrototypeOf; +var t$ = Object.prototype.hasOwnProperty; +var n$ = (e) => Xd(e, "__esModule", { value: true }); +var zt = (e, t) => function() { + return t || (0, e[Jw(e)[0]])((t = { exports: {} }).exports, t), t.exports; }; var Ee = (e, t) => { for (var n in t) - Kd(e, n, { get: t[n], enumerable: true }); + Xd(e, n, { get: t[n], enumerable: true }); }; -var t$ = (e, t, n, s) => { +var s$ = (e, t, n, s) => { if (t && typeof t == "object" || typeof t == "function") - for (let r of Qw(t)) - !JT.call(e, r) && (n || r !== "default") && Kd(e, r, { get: () => t[r], enumerable: !(s = QT(t, r)) || s.enumerable }); + for (let r of Jw(t)) + !t$.call(e, r) && (n || r !== "default") && Xd(e, r, { get: () => t[r], enumerable: !(s = JT(t, r)) || s.enumerable }); return e; }; -var wa = (e, t) => t$(e$(Kd(e != null ? YT(ZT(e)) : {}, "default", !t && e && e.__esModule ? { get: () => e.default, enumerable: true } : { value: e, enumerable: true })), e); -var n$ = Mt({ "src/node_modules/long/src/long.js"(e, t) { +var wa = (e, t) => s$(n$(Xd(e != null ? ZT(e$(e)) : {}, "default", !t && e && e.__esModule ? { get: () => e.default, enumerable: true } : { value: e, enumerable: true })), e); +var r$ = zt({ "src/node_modules/long/src/long.js"(e, t) { t.exports = s; var n = null; try { @@ -800,15 +800,15 @@ var n$ = Mt({ "src/node_modules/long/src/long.js"(e, t) { throw Error("interior hyphen"); if (W === 0) return p(O.substring(1), T, M).neg(); - for (var j = u(c(M, 8)), X = v, Y = 0; Y < O.length; Y += 8) { - var Z = Math.min(8, O.length - Y), te = parseInt(O.substring(Y, Y + Z), M); + for (var j = u(c(M, 8)), Y = v, X = 0; X < O.length; X += 8) { + var Z = Math.min(8, O.length - X), ne = parseInt(O.substring(X, X + Z), M); if (Z < 8) { - var J = u(c(M, Z)); - X = X.mul(J).add(u(te)); + var ee = u(c(M, Z)); + Y = Y.mul(ee).add(u(ne)); } else - X = X.mul(j), X = X.add(u(te)); + Y = Y.mul(j), Y = Y.add(u(ne)); } - return X.unsigned = T, X; + return Y.unsigned = T, Y; } s.fromString = p; function d(O, T) { @@ -847,9 +847,9 @@ var n$ = Mt({ "src/node_modules/long/src/long.js"(e, t) { return W.toString(T) + j.toInt().toString(T); } else return "-" + this.neg().toString(T); - for (var X = u(c(T, 6), this.unsigned), Y = this, Z = ""; ; ) { - var te = Y.div(X), J = Y.sub(te.mul(X)).toInt() >>> 0, se = J.toString(T); - if (Y = te, Y.isZero()) + for (var Y = u(c(T, 6), this.unsigned), X = this, Z = ""; ; ) { + var ne = X.div(Y), ee = X.sub(ne.mul(Y)).toInt() >>> 0, se = ee.toString(T); + if (X = ne, X.isZero()) return se + Z; for (; se.length < 6; ) se = "0" + se; @@ -900,8 +900,8 @@ var n$ = Mt({ "src/node_modules/long/src/long.js"(e, t) { return !this.unsigned && this.eq(P) ? P : this.not().add(k); }, A.neg = A.negate, A.add = function(T) { r(T) || (T = d(T)); - var M = this.high >>> 16, W = this.high & 65535, j = this.low >>> 16, X = this.low & 65535, Y = T.high >>> 16, Z = T.high & 65535, te = T.low >>> 16, J = T.low & 65535, se = 0, ne = 0, oe = 0, ae = 0; - return ae += X + J, oe += ae >>> 16, ae &= 65535, oe += j + te, ne += oe >>> 16, oe &= 65535, ne += W + Z, se += ne >>> 16, ne &= 65535, se += M + Y, se &= 65535, l(oe << 16 | ae, se << 16 | ne, this.unsigned); + var M = this.high >>> 16, W = this.high & 65535, j = this.low >>> 16, Y = this.low & 65535, X = T.high >>> 16, Z = T.high & 65535, ne = T.low >>> 16, ee = T.low & 65535, se = 0, te = 0, oe = 0, ae = 0; + return ae += Y + ee, oe += ae >>> 16, ae &= 65535, oe += j + ne, te += oe >>> 16, oe &= 65535, te += W + Z, se += te >>> 16, te &= 65535, se += M + X, se &= 65535, l(oe << 16 | ae, se << 16 | te, this.unsigned); }, A.subtract = function(T) { return r(T) || (T = d(T)), this.add(T.neg()); }, A.sub = A.subtract, A.multiply = function(T) { @@ -923,8 +923,8 @@ var n$ = Mt({ "src/node_modules/long/src/long.js"(e, t) { return this.mul(T.neg()).neg(); if (this.lt(y) && T.lt(y)) return u(this.toNumber() * T.toNumber(), this.unsigned); - var W = this.high >>> 16, j = this.high & 65535, X = this.low >>> 16, Y = this.low & 65535, Z = T.high >>> 16, te = T.high & 65535, J = T.low >>> 16, se = T.low & 65535, ne = 0, oe = 0, ae = 0, de = 0; - return de += Y * se, ae += de >>> 16, de &= 65535, ae += X * se, oe += ae >>> 16, ae &= 65535, ae += Y * J, oe += ae >>> 16, ae &= 65535, oe += j * se, ne += oe >>> 16, oe &= 65535, oe += X * J, ne += oe >>> 16, oe &= 65535, oe += Y * te, ne += oe >>> 16, oe &= 65535, ne += W * se + j * J + X * te + Y * Z, ne &= 65535, l(ae << 16 | de, ne << 16 | oe, this.unsigned); + var W = this.high >>> 16, j = this.high & 65535, Y = this.low >>> 16, X = this.low & 65535, Z = T.high >>> 16, ne = T.high & 65535, ee = T.low >>> 16, se = T.low & 65535, te = 0, oe = 0, ae = 0, de = 0; + return de += X * se, ae += de >>> 16, de &= 65535, ae += Y * se, oe += ae >>> 16, ae &= 65535, ae += X * ee, oe += ae >>> 16, ae &= 65535, oe += j * se, te += oe >>> 16, oe &= 65535, oe += Y * ee, te += oe >>> 16, oe &= 65535, oe += X * ne, te += oe >>> 16, oe &= 65535, te += W * se + j * ee + Y * ne + X * Z, te &= 65535, l(ae << 16 | de, te << 16 | oe, this.unsigned); }, A.mul = A.multiply, A.divide = function(T) { if (r(T) || (T = d(T)), T.isZero()) throw Error("division by zero"); @@ -936,36 +936,36 @@ var n$ = Mt({ "src/node_modules/long/src/long.js"(e, t) { } if (this.isZero()) return this.unsigned ? x : v; - var W, j, X; + var W, j, Y; if (this.unsigned) { if (T.unsigned || (T = T.toUnsigned()), T.gt(this)) return x; if (T.gt(this.shru(1))) return I; - X = x; + Y = x; } else { if (this.eq(P)) { if (T.eq(k) || T.eq($)) return P; if (T.eq(P)) return k; - var Y = this.shr(1); - return W = Y.div(T).shl(1), W.eq(v) ? T.isNegative() ? k : $ : (j = this.sub(T.mul(W)), X = W.add(j.div(T)), X); + var X = this.shr(1); + return W = X.div(T).shl(1), W.eq(v) ? T.isNegative() ? k : $ : (j = this.sub(T.mul(W)), Y = W.add(j.div(T)), Y); } else if (T.eq(P)) return this.unsigned ? x : v; if (this.isNegative()) return T.isNegative() ? this.neg().div(T.neg()) : this.neg().div(T).neg(); if (T.isNegative()) return this.div(T.neg()).neg(); - X = v; + Y = v; } for (j = this; j.gte(T); ) { W = Math.max(1, Math.floor(j.toNumber() / T.toNumber())); - for (var Z = Math.ceil(Math.log(W) / Math.LN2), te = Z <= 48 ? 1 : c(2, Z - 48), J = u(W), se = J.mul(T); se.isNegative() || se.gt(j); ) - W -= te, J = u(W, this.unsigned), se = J.mul(T); - J.isZero() && (J = k), X = X.add(J), j = j.sub(se); + for (var Z = Math.ceil(Math.log(W) / Math.LN2), ne = Z <= 48 ? 1 : c(2, Z - 48), ee = u(W), se = ee.mul(T); se.isNegative() || se.gt(j); ) + W -= ne, ee = u(W, this.unsigned), se = ee.mul(T); + ee.isZero() && (ee = k), Y = Y.add(ee), j = j.sub(se); } - return X; + return Y; }, A.div = A.divide, A.modulo = function(T) { if (r(T) || (T = d(T)), n) { var M = (this.unsigned ? n.rem_u : n.rem_s)(this.low, this.high, T.low, T.high); @@ -1013,11 +1013,11 @@ var n$ = Mt({ "src/node_modules/long/src/long.js"(e, t) { return new s(T[4] << 24 | T[5] << 16 | T[6] << 8 | T[7], T[0] << 24 | T[1] << 16 | T[2] << 8 | T[3], M); }; } }); -var s$ = Mt({ "(disabled):src/node_modules/node-fetch/browser.js"() { +var a$ = zt({ "(disabled):src/node_modules/node-fetch/browser.js"() { } }); -var r$ = Mt({ "(disabled):util"() { +var i$ = zt({ "(disabled):util"() { } }); -var a$ = Mt({ "src/node_modules/seedrandom/lib/alea.js"(e, t) { +var o$ = zt({ "src/node_modules/seedrandom/lib/alea.js"(e, t) { (function(n, s, r) { function a(l) { var c = this, p = u(); @@ -1056,7 +1056,7 @@ var a$ = Mt({ "src/node_modules/seedrandom/lib/alea.js"(e, t) { }) : this.alea = o; })(e, typeof t == "object" && t, typeof define == "function" && define); } }); -var i$ = Mt({ "src/node_modules/seedrandom/lib/xor128.js"(e, t) { +var u$ = zt({ "src/node_modules/seedrandom/lib/xor128.js"(e, t) { (function(n, s, r) { function a(u) { var l = this, c = ""; @@ -1088,7 +1088,7 @@ var i$ = Mt({ "src/node_modules/seedrandom/lib/xor128.js"(e, t) { }) : this.xor128 = o; })(e, typeof t == "object" && t, typeof define == "function" && define); } }); -var o$ = Mt({ "src/node_modules/seedrandom/lib/xorwow.js"(e, t) { +var l$ = zt({ "src/node_modules/seedrandom/lib/xorwow.js"(e, t) { (function(n, s, r) { function a(u) { var l = this, c = ""; @@ -1120,7 +1120,7 @@ var o$ = Mt({ "src/node_modules/seedrandom/lib/xorwow.js"(e, t) { }) : this.xorwow = o; })(e, typeof t == "object" && t, typeof define == "function" && define); } }); -var u$ = Mt({ "src/node_modules/seedrandom/lib/xorshift7.js"(e, t) { +var c$ = zt({ "src/node_modules/seedrandom/lib/xorshift7.js"(e, t) { (function(n, s, r) { function a(u) { var l = this; @@ -1166,7 +1166,7 @@ var u$ = Mt({ "src/node_modules/seedrandom/lib/xorshift7.js"(e, t) { }) : this.xorshift7 = o; })(e, typeof t == "object" && t, typeof define == "function" && define); } }); -var l$ = Mt({ "src/node_modules/seedrandom/lib/xor4096.js"(e, t) { +var d$ = zt({ "src/node_modules/seedrandom/lib/xor4096.js"(e, t) { (function(n, s, r) { function a(u) { var l = this; @@ -1206,7 +1206,7 @@ var l$ = Mt({ "src/node_modules/seedrandom/lib/xor4096.js"(e, t) { }) : this.xor4096 = o; })(e, typeof t == "object" && t, typeof define == "function" && define); } }); -var c$ = Mt({ "src/node_modules/seedrandom/lib/tychei.js"(e, t) { +var p$ = zt({ "src/node_modules/seedrandom/lib/tychei.js"(e, t) { (function(n, s, r) { function a(u) { var l = this, c = ""; @@ -1238,9 +1238,9 @@ var c$ = Mt({ "src/node_modules/seedrandom/lib/tychei.js"(e, t) { }) : this.tychei = o; })(e, typeof t == "object" && t, typeof define == "function" && define); } }); -var d$ = Mt({ "(disabled):crypto"() { +var h$ = zt({ "(disabled):crypto"() { } }); -var p$ = Mt({ "src/node_modules/seedrandom/seedrandom.js"(e, t) { +var f$ = zt({ "src/node_modules/seedrandom/seedrandom.js"(e, t) { (function(n, s, r) { var a = 256, i = 6, o = 52, u = "random", l = r.pow(a, i), c = r.pow(2, o), p = c * 2, d = a - 1, h; function f(k, I, $) { @@ -1270,8 +1270,8 @@ var p$ = Mt({ "src/node_modules/seedrandom/seedrandom.js"(e, t) { for (E = 0; E < a; E++) A[E] = A[P = d & P + k[E % $] + (I = A[E])], A[P] = I; (R.g = function(O) { - for (var T, M = 0, W = R.i, j = R.j, X = R.S; O--; ) - T = X[W = d & W + 1], M = M * a + X[d & (X[W] = X[j = d & j + T]) + (X[j] = T)]; + for (var T, M = 0, W = R.i, j = R.j, Y = R.S; O--; ) + T = Y[W = d & W + 1], M = M * a + Y[d & (Y[W] = Y[j = d & j + T]) + (Y[j] = T)]; return R.i = W, R.j = j, M; })(a); } @@ -1308,7 +1308,7 @@ var p$ = Mt({ "src/node_modules/seedrandom/seedrandom.js"(e, t) { if (y(r.random(), s), typeof t == "object" && t.exports) { t.exports = f; try { - h = d$(); + h = h$(); } catch (k) { } } else @@ -1317,47 +1317,47 @@ var p$ = Mt({ "src/node_modules/seedrandom/seedrandom.js"(e, t) { }) : r["seed" + u] = f; })(typeof self != "undefined" ? self : e, [], Math); } }); -var Xd = Mt({ "src/node_modules/seedrandom/index.js"(e, t) { - var n = a$(), s = i$(), r = o$(), a = u$(), i = l$(), o = c$(), u = p$(); +var Yd = zt({ "src/node_modules/seedrandom/index.js"(e, t) { + var n = o$(), s = u$(), r = l$(), a = c$(), i = d$(), o = p$(), u = f$(); u.alea = n, u.xor128 = s, u.xorwow = r, u.xorshift7 = a, u.xor4096 = i, u.tychei = o, t.exports = u; } }); -var Zw = Mt({ "(disabled):src/node_modules/string_decoder/index.js"() { +var ek = zt({ "(disabled):src/node_modules/string_decoder/index.js"() { } }); -var ug = Mt({ "(disabled):fs"() { +var lg = zt({ "(disabled):fs"() { } }); -var gd = Mt({ "(disabled):path"() { +var gd = zt({ "(disabled):path"() { } }); -var h$ = Mt({ "(disabled):worker_threads"() { +var m$ = zt({ "(disabled):worker_threads"() { } }); -var f$ = Mt({ "(disabled):perf_hooks"() { +var g$ = zt({ "(disabled):perf_hooks"() { } }); -var m$ = Mt({ "(disabled):os"() { +var b$ = zt({ "(disabled):os"() { } }); -var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js"(e, t) { +var y$ = zt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js"(e, t) { var n = (() => { var s = typeof document != "undefined" && document.currentScript ? document.currentScript.src : void 0; return typeof __filename != "undefined" && (s = s || __filename), function(r) { r = r || {}; function a() { - return Ce.buffer != nn && rs(Ce.buffer), lc; + return Ce.buffer != tn && rs(Ce.buffer), lc; } function i() { - return Ce.buffer != nn && rs(Ce.buffer), cc; + return Ce.buffer != tn && rs(Ce.buffer), cc; } function o() { - return Ce.buffer != nn && rs(Ce.buffer), gu; + return Ce.buffer != tn && rs(Ce.buffer), gu; } function u() { - return Ce.buffer != nn && rs(Ce.buffer), dc; + return Ce.buffer != tn && rs(Ce.buffer), dc; } function l() { - return Ce.buffer != nn && rs(Ce.buffer), pc; + return Ce.buffer != tn && rs(Ce.buffer), pc; } function c() { - return Ce.buffer != nn && rs(Ce.buffer), hc; + return Ce.buffer != tn && rs(Ce.buffer), hc; } function p() { - return Ce.buffer != nn && rs(Ce.buffer), fc; + return Ce.buffer != tn && rs(Ce.buffer), fc; } var d = typeof r != "undefined" ? r : {}, h, f; d.ready = new Promise(function(N, D) { @@ -1375,20 +1375,20 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js function M(N) { if (N instanceof Cu) return; - J("exiting due to exception: " + N); + ee("exiting due to exception: " + N); } - var W, j, X; + var W, j, Y; if (I) { - k ? R = gd().dirname(R) + "/" : R = __dirname + "/", X = () => { - j || (W = ug(), j = gd()); + k ? R = gd().dirname(R) + "/" : R = __dirname + "/", Y = () => { + j || (W = lg(), j = gd()); }, P = function(B, Q) { - return X(), B = j.normalize(B), W.readFileSync(B, Q ? void 0 : "utf8"); + return Y(), B = j.normalize(B), W.readFileSync(B, Q ? void 0 : "utf8"); }, O = (D) => { var B = P(D, true); return B.buffer || (B = new Uint8Array(B)), B; }, A = (D, B, Q) => { - X(), D = j.normalize(D), W.readFile(D, function(ue, pe) { - ue ? Q(ue) : B(pe.buffer); + Y(), D = j.normalize(D), W.readFile(D, function(ue, he) { + ue ? Q(ue) : B(he.buffer); }); }, process.argv.length > 1 && (y = process.argv[1].replace(/\\/g, "/")), b = process.argv.slice(2), process.on("uncaughtException", function(D) { if (!(D instanceof Cu)) @@ -1404,7 +1404,7 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js }; let N; try { - N = h$(); + N = m$(); } catch (D) { throw console.error('The "worker_threads" module is not supported in this node.js build - perhaps a newer version is needed?'), D; } @@ -1426,16 +1426,16 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js B(); }, Q.onerror = B, Q.send(null); }), T = (N) => document.title = N); - I && typeof performance == "undefined" && (global.performance = f$().performance); - var Y = console.log.bind(console), Z = console.warn.bind(console); - I && (X(), Y = (N) => W.writeSync(1, N + ` + I && typeof performance == "undefined" && (global.performance = g$().performance); + var X = console.log.bind(console), Z = console.warn.bind(console); + I && (Y(), X = (N) => W.writeSync(1, N + ` `), Z = (N) => W.writeSync(2, N + ` `)); - var te = d.print || Y, J = d.printErr || Z; + var ne = d.print || X, ee = d.printErr || Z; Object.assign(d, g), g = null, d.arguments && (b = d.arguments), d.thisProgram && (y = d.thisProgram), d.quit && (v = d.quit); var se = 4; - function ne(N) { - ne.shown || (ne.shown = {}), ne.shown[N] || (ne.shown[N] = 1, J(N)); + function te(N) { + te.shown || (te.shown = {}), te.shown[N] || (te.shown[N] = 1, ee(N)); } function oe(N, D) { if (typeof WebAssembly.Function == "function") { @@ -1443,12 +1443,12 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js Q.parameters.push(B[D[ue]]); return new WebAssembly.Function(Q, N); } - var pe = [1, 0, 1, 96], ye = D.slice(0, 1), Te = D.slice(1), bt = { i: 127, j: 126, f: 125, d: 124 }; - pe.push(Te.length); + var he = [1, 0, 1, 96], ye = D.slice(0, 1), Te = D.slice(1), bt = { i: 127, j: 126, f: 125, d: 124 }; + he.push(Te.length); for (var ue = 0; ue < Te.length; ++ue) - pe.push(bt[Te[ue]]); - ye == "v" ? pe.push(0) : pe = pe.concat([1, bt[ye]]), pe[1] = pe.length - 2; - var us = new Uint8Array([0, 97, 115, 109, 1, 0, 0, 0].concat(pe, [2, 7, 1, 1, 101, 1, 102, 0, 0, 7, 5, 1, 1, 102, 0, 0])), ls = new WebAssembly.Module(us), Uc = new WebAssembly.Instance(ls, { e: { f: N } }), Nu = Uc.exports.f; + he.push(bt[Te[ue]]); + ye == "v" ? he.push(0) : he = he.concat([1, bt[ye]]), he[1] = he.length - 2; + var us = new Uint8Array([0, 97, 115, 109, 1, 0, 0, 0].concat(he, [2, 7, 1, 1, 101, 1, 102, 0, 0, 7, 5, 1, 1, 102, 0, 0])), ls = new WebAssembly.Module(us), Uc = new WebAssembly.Instance(ls, { e: { f: N } }), Nu = Uc.exports.f; return Nu; } var ae = [], de; @@ -1474,7 +1474,7 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js d.wasmBinary && (Ye = d.wasmBinary); var tt = d.noExitRuntime || true; typeof WebAssembly != "object" && Ni("no native wasm support detected"); - var Ce, ut, at = false, Jt; + var Ce, ut, at = false, Zt; function Nt(N, D) { N || Ni(D); } @@ -1482,12 +1482,12 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js var D = d["_" + N]; return D; } - function Rt(N, D, B, Q, ue) { - var pe = { string: function(Tn) { + function Et(N, D, B, Q, ue) { + var he = { string: function(Tn) { var Pi = 0; if (Tn != null && Tn !== 0) { - var ox = (Tn.length << 2) + 1; - Pi = Oi(ox), Ms(Tn, Pi, ox); + var ux = (Tn.length << 2) + 1; + Pi = Oi(ux), Ms(Tn, Pi, ux); } return Pi; }, array: function(Tn) { @@ -1495,27 +1495,27 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js return Ls(Tn, Pi), Pi; } }; function ye(Tn) { - return D === "string" ? tn(Tn) : D === "boolean" ? Boolean(Tn) : Tn; + return D === "string" ? en(Tn) : D === "boolean" ? Boolean(Tn) : Tn; } var Te = In(N), bt = [], us = 0; if (Q) for (var ls = 0; ls < Q.length; ls++) { - var Uc = pe[B[ls]]; - Uc ? (us === 0 && (us = Lf()), bt[ls] = Uc(Q[ls])) : bt[ls] = Q[ls]; + var Uc = he[B[ls]]; + Uc ? (us === 0 && (us = Bf()), bt[ls] = Uc(Q[ls])) : bt[ls] = Q[ls]; } var Nu = Te.apply(null, bt); - function XT(Tn) { + function QT(Tn) { return us !== 0 && Lc(us), ye(Tn); } - return Nu = XT(Nu), Nu; + return Nu = QT(Nu), Nu; } - function en(N, D, B, Q) { + function Jt(N, D, B, Q) { B = B || []; var ue = B.every(function(ye) { return ye === "number"; - }), pe = D !== "string"; - return pe && ue && !Q ? In(N) : function() { - return Rt(N, D, B, arguments, Q); + }), he = D !== "string"; + return he && ue && !Q ? In(N) : function() { + return Et(N, D, B, arguments, Q); }; } var Cn = 1; @@ -1523,59 +1523,59 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js var D = new TextDecoder(N); this.decode = (B) => (B.buffer instanceof SharedArrayBuffer && (B = new Uint8Array(B)), D.decode.call(D, B)); } - var Yt = typeof TextDecoder != "undefined" ? new Nn("utf8") : void 0; + var Xt = typeof TextDecoder != "undefined" ? new Nn("utf8") : void 0; function Dn(N, D, B) { for (var Q = D + B, ue = D; N[ue] && !(ue >= Q); ) ++ue; - if (ue - D > 16 && N.subarray && Yt) - return Yt.decode(N.subarray(D, ue)); - for (var pe = ""; D < ue; ) { + if (ue - D > 16 && N.subarray && Xt) + return Xt.decode(N.subarray(D, ue)); + for (var he = ""; D < ue; ) { var ye = N[D++]; if (!(ye & 128)) { - pe += String.fromCharCode(ye); + he += String.fromCharCode(ye); continue; } var Te = N[D++] & 63; if ((ye & 224) == 192) { - pe += String.fromCharCode((ye & 31) << 6 | Te); + he += String.fromCharCode((ye & 31) << 6 | Te); continue; } var bt = N[D++] & 63; if ((ye & 240) == 224 ? ye = (ye & 15) << 12 | Te << 6 | bt : ye = (ye & 7) << 18 | Te << 12 | bt << 6 | N[D++] & 63, ye < 65536) - pe += String.fromCharCode(ye); + he += String.fromCharCode(ye); else { var us = ye - 65536; - pe += String.fromCharCode(55296 | us >> 10, 56320 | us & 1023); + he += String.fromCharCode(55296 | us >> 10, 56320 | us & 1023); } } - return pe; + return he; } - function tn(N, D) { + function en(N, D) { return N ? Dn(i(), N, D) : ""; } function zs(N, D, B, Q) { if (!(Q > 0)) return 0; - for (var ue = B, pe = B + Q - 1, ye = 0; ye < N.length; ++ye) { + for (var ue = B, he = B + Q - 1, ye = 0; ye < N.length; ++ye) { var Te = N.charCodeAt(ye); if (Te >= 55296 && Te <= 57343) { var bt = N.charCodeAt(++ye); Te = 65536 + ((Te & 1023) << 10) | bt & 1023; } if (Te <= 127) { - if (B >= pe) + if (B >= he) break; D[B++] = Te; } else if (Te <= 2047) { - if (B + 1 >= pe) + if (B + 1 >= he) break; D[B++] = 192 | Te >> 6, D[B++] = 128 | Te & 63; } else if (Te <= 65535) { - if (B + 2 >= pe) + if (B + 2 >= he) break; D[B++] = 224 | Te >> 12, D[B++] = 128 | Te >> 6 & 63, D[B++] = 128 | Te & 63; } else { - if (B + 3 >= pe) + if (B + 3 >= he) break; D[B++] = 240 | Te >> 18, D[B++] = 128 | Te >> 12 & 63, D[B++] = 128 | Te >> 6 & 63, D[B++] = 128 | Te & 63; } @@ -1604,36 +1604,36 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js function Ii(N, D) { return N % D > 0 && (N += D - N % D), N; } - var nn, lc, cc, gu, dc, pc, Vv, hc, fc; - $ && (nn = d.buffer); + var tn, lc, cc, gu, dc, pc, Wv, hc, fc; + $ && (tn = d.buffer); function rs(N) { - nn = N, d.HEAP8 = lc = new Int8Array(N), d.HEAP16 = gu = new Int16Array(N), d.HEAP32 = pc = new Int32Array(N), d.HEAPU8 = cc = new Uint8Array(N), d.HEAPU16 = dc = new Uint16Array(N), d.HEAPU32 = Vv = new Uint32Array(N), d.HEAPF32 = hc = new Float32Array(N), d.HEAPF64 = fc = new Float64Array(N); + tn = N, d.HEAP8 = lc = new Int8Array(N), d.HEAP16 = gu = new Int16Array(N), d.HEAP32 = pc = new Int32Array(N), d.HEAPU8 = cc = new Uint8Array(N), d.HEAPU16 = dc = new Uint16Array(N), d.HEAPU32 = Wv = new Uint32Array(N), d.HEAPF32 = hc = new Float32Array(N), d.HEAPF64 = fc = new Float64Array(N); } var mc = d.INITIAL_MEMORY || 16777216; if ($) - Ce = d.wasmMemory, nn = d.buffer; + Ce = d.wasmMemory, tn = d.buffer; else if (d.wasmMemory) Ce = d.wasmMemory; else if (Ce = new WebAssembly.Memory({ initial: mc / 65536, maximum: 32768, shared: true }), !(Ce.buffer instanceof SharedArrayBuffer)) - throw J("requested a shared WebAssembly.Memory but the returned buffer is not a SharedArrayBuffer, indicating that while the browser has SharedArrayBuffer it does not have WebAssembly threads support - you may need to set a flag"), I && console.log("(on node you may need: --experimental-wasm-threads --experimental-wasm-bulk-memory and also use a recent version)"), Error("bad memory"); - Ce && (nn = Ce.buffer), mc = nn.byteLength, rs(nn); - var Fn, Ci = [], Js = [], lh = [], gc = [], zr = false, ch = false, bc = 0; + throw ee("requested a shared WebAssembly.Memory but the returned buffer is not a SharedArrayBuffer, indicating that while the browser has SharedArrayBuffer it does not have WebAssembly threads support - you may need to set a flag"), I && console.log("(on node you may need: --experimental-wasm-threads --experimental-wasm-bulk-memory and also use a recent version)"), Error("bad memory"); + Ce && (tn = Ce.buffer), mc = tn.byteLength, rs(tn); + var Fn, Ci = [], Js = [], ch = [], gc = [], zr = false, dh = false, bc = 0; function Mr() { return tt || bc > 0; } - function sn() { + function nn() { if (d.preRun) for (typeof d.preRun == "function" && (d.preRun = [d.preRun]); d.preRun.length; ) - Wv(d.preRun.shift()); + Uv(d.preRun.shift()); kc(Ci); } function bu() { zr = true, !$ && kc(Js); } - function dh() { - $ || ($e.terminateAllThreads(), ch = true); - } function ph() { + $ || ($e.terminateAllThreads(), dh = true); + } + function hh() { if (!$) { if (d.postRun) for (typeof d.postRun == "function" && (d.postRun = [d.postRun]); d.postRun.length; ) @@ -1641,10 +1641,10 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js kc(gc); } } - function Wv(N) { + function Uv(N) { Ci.unshift(N); } - function Uv(N) { + function Gv(N) { Js.unshift(N); } function yu(N) { @@ -1654,7 +1654,7 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js function vu(N) { er++, d.monitorRunDependencies && d.monitorRunDependencies(er); } - function Gv(N) { + function Hv(N) { if (er--, d.monitorRunDependencies && d.monitorRunDependencies(er), er == 0 && (yc !== null && (clearInterval(yc), yc = null), as)) { var D = as; as = null, D(); @@ -1662,22 +1662,22 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js } d.preloadedImages = {}, d.preloadedAudios = {}; function Ni(N) { - $ ? postMessage({ cmd: "onAbort", arg: N }) : d.onAbort && d.onAbort(N), N = "Aborted(" + N + ")", J(N), at = true, Jt = 1, N += ". Build with -s ASSERTIONS=1 for more info."; + $ ? postMessage({ cmd: "onAbort", arg: N }) : d.onAbort && d.onAbort(N), N = "Aborted(" + N + ")", ee(N), at = true, Zt = 1, N += ". Build with -s ASSERTIONS=1 for more info."; var D = new WebAssembly.RuntimeError(N); throw f(D), D; } - var hh = "data:application/octet-stream;base64,"; + var fh = "data:application/octet-stream;base64,"; function vc(N) { - return N.startsWith(hh); + return N.startsWith(fh); } function xc(N) { return N.startsWith("file://"); } - var rn; - rn = "tfjs-backend-wasm-threaded-simd.wasm", vc(rn) || (rn = E(rn)); + var sn; + sn = "tfjs-backend-wasm-threaded-simd.wasm", vc(sn) || (sn = E(sn)); function wc(N) { try { - if (N == rn && Ye) + if (N == sn && Ye) return new Uint8Array(Ye); if (O) return O(N); @@ -1688,34 +1688,34 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js } function Ti() { if (!Ye && (x || k)) { - if (typeof fetch == "function" && !xc(rn)) - return fetch(rn, { credentials: "same-origin" }).then(function(N) { + if (typeof fetch == "function" && !xc(sn)) + return fetch(sn, { credentials: "same-origin" }).then(function(N) { if (!N.ok) - throw "failed to load wasm binary file at '" + rn + "'"; + throw "failed to load wasm binary file at '" + sn + "'"; return N.arrayBuffer(); }).catch(function() { - return wc(rn); + return wc(sn); }); if (A) return new Promise(function(N, D) { - A(rn, function(B) { + A(sn, function(B) { N(new Uint8Array(B)); }, D); }); } return Promise.resolve().then(function() { - return wc(rn); + return wc(sn); }); } - function fh() { + function mh() { var N = { env: Fc, wasi_snapshot_preview1: Fc }; function D(ye, Te) { var bt = ye.exports; - if (d.asm = bt, wh(d.asm.emscripten_tls_init), Fn = d.asm.__indirect_function_table, Uv(d.asm.__wasm_call_ctors), ut = Te, !$) { + if (d.asm = bt, kh(d.asm.emscripten_tls_init), Fn = d.asm.__indirect_function_table, Gv(d.asm.__wasm_call_ctors), ut = Te, !$) { var us = $e.unusedWorkers.length; $e.unusedWorkers.forEach(function(ls) { $e.loadWasmModuleToWorker(ls, function() { - --us || Gv("wasm-instantiate"); + --us || Hv("wasm-instantiate"); }); }); } @@ -1730,27 +1730,27 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js }).then(function(Te) { return Te; }).then(ye, function(Te) { - J("failed to asynchronously prepare wasm: " + Te), Ni(Te); + ee("failed to asynchronously prepare wasm: " + Te), Ni(Te); }); } function ue() { - return !Ye && typeof WebAssembly.instantiateStreaming == "function" && !vc(rn) && !xc(rn) && typeof fetch == "function" ? fetch(rn, { credentials: "same-origin" }).then(function(ye) { + return !Ye && typeof WebAssembly.instantiateStreaming == "function" && !vc(sn) && !xc(sn) && typeof fetch == "function" ? fetch(sn, { credentials: "same-origin" }).then(function(ye) { var Te = WebAssembly.instantiateStreaming(ye, N); return Te.then(B, function(bt) { - return J("wasm streaming compile failed: " + bt), J("falling back to ArrayBuffer instantiation"), Q(B); + return ee("wasm streaming compile failed: " + bt), ee("falling back to ArrayBuffer instantiation"), Q(B); }); }) : Q(B); } if (d.instantiateWasm) try { - var pe = d.instantiateWasm(N, D); - return pe; + var he = d.instantiateWasm(N, D); + return he; } catch (ye) { - return J("Module.instantiateWasm callback failed with error: " + ye), false; + return ee("Module.instantiateWasm callback failed with error: " + ye), false; } return ue().catch(f), {}; } - var Hv, qv, mh = {}; + var qv, jv, gh = {}; function kc(N) { for (; N.length > 0; ) { var D = N.shift(); @@ -1763,25 +1763,25 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js } } function $i(N) { - var D = Lf(), B = N(); + var D = Bf(), B = N(); return Lc(D), B; } - function sT(N) { + function aT(N) { return N; } - function jv(N) { + function Kv(N) { var D = /\b_Z[\w\d_]+/g; return N.replace(D, function(B) { var Q = B; return B === Q ? B : Q + " [" + B + "]"; }); } - function gh(N) { + function bh(N) { l()[N >> 2] = 0; var D = $e.pthreads[N]; - delete $e.pthreads[N], D.worker.terminate(), Mf(N), $e.runningWorkers.splice($e.runningWorkers.indexOf(D.worker), 1), D.worker.pthread = void 0; + delete $e.pthreads[N], D.worker.terminate(), Lf(N), $e.runningWorkers.splice($e.runningWorkers.indexOf(D.worker), 1), D.worker.pthread = void 0; } - function bh(N) { + function yh(N) { var D = $e.pthreads[N]; D.worker.postMessage({ cmd: "cancel" }); } @@ -1794,11 +1794,11 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js } } function Ic(N) { - qT(N); + KT(N); } - function yh(N) { + function vh(N) { if (N instanceof Cu || N == "unwind") - return Jt; + return Zt; v(1, N); } var $e = { unusedWorkers: [], runningWorkers: [], tlsInitFunctions: [], init: function() { @@ -1809,7 +1809,7 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js }, initWorker: function() { tt = false; }, pthreads: {}, setExitStatus: function(N) { - Jt = N; + Zt = N; }, terminateAllThreads: function() { for (var N in $e.pthreads) { var D = $e.pthreads[N]; @@ -1822,14 +1822,14 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js $e.unusedWorkers = []; }, returnWorkerToPool: function(N) { $e.runWithoutMainThreadQueuedCalls(function() { - delete $e.pthreads[N.pthread.threadInfoStruct], $e.unusedWorkers.push(N), $e.runningWorkers.splice($e.runningWorkers.indexOf(N), 1), Mf(N.pthread.threadInfoStruct), N.pthread = void 0; + delete $e.pthreads[N.pthread.threadInfoStruct], $e.unusedWorkers.push(N), $e.runningWorkers.splice($e.runningWorkers.indexOf(N), 1), Lf(N.pthread.threadInfoStruct), N.pthread = void 0; }); }, runWithoutMainThreadQueuedCalls: function(N) { - l()[ix >> 2] = 0; + l()[ox >> 2] = 0; try { N(); } finally { - l()[ix >> 2] = 1; + l()[ox >> 2] = 1; } }, receiveObjectTransfer: function(N) { }, threadInit: function() { @@ -1839,14 +1839,14 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js N.onmessage = (B) => { var Q = B.data, ue = Q.cmd; if (N.pthread && ($e.currentProxiedOperationCallerThread = N.pthread.threadInfoStruct), Q.targetThread && Q.targetThread != Mc()) { - var pe = $e.pthreads[Q.targetThread]; - pe ? pe.worker.postMessage(Q, Q.transferList) : J('Internal error! Worker sent a message "' + ue + '" to target pthread ' + Q.targetThread + ", but that thread no longer exists!"), $e.currentProxiedOperationCallerThread = void 0; + var he = $e.pthreads[Q.targetThread]; + he ? he.worker.postMessage(Q, Q.transferList) : ee('Internal error! Worker sent a message "' + ue + '" to target pthread ' + Q.targetThread + ", but that thread no longer exists!"), $e.currentProxiedOperationCallerThread = void 0; return; } - ue === "processQueuedMainThreadWork" ? tx() : ue === "spawnThread" ? Nc(Q) : ue === "cleanupThread" ? Sc(Q.thread) : ue === "killThread" ? gh(Q.thread) : ue === "cancelThread" ? bh(Q.thread) : ue === "loaded" ? (N.loaded = true, D && D(N), N.runPthread && (N.runPthread(), delete N.runPthread)) : ue === "print" ? te("Thread " + Q.threadId + ": " + Q.text) : ue === "printErr" ? J("Thread " + Q.threadId + ": " + Q.text) : ue === "alert" ? alert("Thread " + Q.threadId + ": " + Q.text) : Q.target === "setimmediate" ? N.postMessage(Q) : ue === "onAbort" ? d.onAbort && d.onAbort(Q.arg) : J("worker sent an unknown command " + ue), $e.currentProxiedOperationCallerThread = void 0; + ue === "processQueuedMainThreadWork" ? nx() : ue === "spawnThread" ? Nc(Q) : ue === "cleanupThread" ? Sc(Q.thread) : ue === "killThread" ? bh(Q.thread) : ue === "cancelThread" ? yh(Q.thread) : ue === "loaded" ? (N.loaded = true, D && D(N), N.runPthread && (N.runPthread(), delete N.runPthread)) : ue === "print" ? ne("Thread " + Q.threadId + ": " + Q.text) : ue === "printErr" ? ee("Thread " + Q.threadId + ": " + Q.text) : ue === "alert" ? alert("Thread " + Q.threadId + ": " + Q.text) : Q.target === "setimmediate" ? N.postMessage(Q) : ue === "onAbort" ? d.onAbort && d.onAbort(Q.arg) : ee("worker sent an unknown command " + ue), $e.currentProxiedOperationCallerThread = void 0; }, N.onerror = (B) => { var Q = "worker sent an error!"; - throw J(Q + " " + B.filename + ":" + B.lineno + ": " + B.message), B; + throw ee(Q + " " + B.filename + ":" + B.lineno + ": " + B.message), B; }, I && (N.on("message", function(B) { N.onmessage({ data: B }); }), N.on("error", function(B) { @@ -1859,18 +1859,18 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js }, getNewWorker: function() { return $e.unusedWorkers.length == 0 && ($e.allocateUnusedWorker(), $e.loadWasmModuleToWorker($e.unusedWorkers[0])), $e.unusedWorkers.pop(); } }; - function vh() { + function xh() { var N = Mc(), D = l()[N + 44 >> 2], B = l()[N + 48 >> 2], Q = D - B; - ax(D, Q), Lc(D); + ix(D, Q), Lc(D); } - d.establishStackSpace = vh; + d.establishStackSpace = xh; function Cc(N) { if ($) return Vr(1, 0, N); try { Ic(N); } catch (D) { - yh(D); + vh(D); } } var Lr = []; @@ -1878,11 +1878,11 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js var D = Lr[N]; return D || (N >= Lr.length && (Lr.length = N + 1), Lr[N] = D = Fn.get(N)), D; } - function xh(N, D) { + function wh(N, D) { return _i(N)(D); } - d.invokeEntryPoint = xh; - function Kv() { + d.invokeEntryPoint = wh; + function Xv() { var N = new Error(); if (!N.stack) { try { @@ -1895,10 +1895,10 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js } return N.stack.toString(); } - function wh(N, D, B) { + function kh(N, D, B) { $e.tlsInitFunctions.push(N); } - function Xv(N, D) { + function Yv(N, D) { Fn.set(N, D), Lr[N] = D; } var Br; @@ -1906,27 +1906,27 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js var N = process.hrtime(); return N[0] * 1e3 + N[1] / 1e6; } : $ ? Br = () => performance.now() - d.__performance_now_clock_drift : Br = () => performance.now(); - var kh = true; - function Sh(N) { - return l()[ex() >> 2] = N, N; + var Sh = true; + function Ih(N) { + return l()[tx() >> 2] = N, N; } - function Ih(N, D) { + function Ch(N, D) { var B; if (N === 0) B = Date.now(); - else if ((N === 1 || N === 4) && kh) + else if ((N === 1 || N === 4) && Sh) B = Br(); else - return Sh(28), -1; + return Ih(28), -1; return l()[D >> 2] = B / 1e3 | 0, l()[D + 4 >> 2] = B % 1e3 * 1e3 * 1e3 | 0, 0; } - function Ch(N, D) { - return Ih(N, D); - } - function Nh(N) { - nx(N, !k, 1, !x), $e.threadInit(); + function Nh(N, D) { + return Ch(N, D); } function Th(N) { + sx(N, !k, 1, !x), $e.threadInit(); + } + function $h(N) { $ ? postMessage({ cmd: "cleanupThread", thread: N }) : Sc(N); } function Nc(N) { @@ -1941,21 +1941,21 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js Q.time = performance.now(), D.postMessage(Q, N.transferList); }, D.loaded && (D.runPthread(), delete D.runPthread), 0; } - function $h(N, D, B, Q) { + function _h(N, D, B, Q) { if (typeof SharedArrayBuffer == "undefined") - return J("Current environment does not support SharedArrayBuffer, pthreads are not available!"), 6; - var ue = [], pe = 0; - if ($ && (ue.length === 0 || pe)) - return sx(687865856, N, D, B, Q); - if (pe) - return pe; + return ee("Current environment does not support SharedArrayBuffer, pthreads are not available!"), 6; + var ue = [], he = 0; + if ($ && (ue.length === 0 || he)) + return rx(687865856, N, D, B, Q); + if (he) + return he; var ye = { startRoutine: B, pthread_ptr: N, arg: Q, transferList: ue }; return $ ? (ye.cmd = "spawnThread", postMessage(ye, ue), 0) : Nc(ye); } - function _h() { + function Ah() { return 2097152; } - function Ah(N, D) { + function Eh(N, D) { if (N == D) postMessage({ cmd: "processQueuedMainThreadWork" }); else if ($) @@ -1968,46 +1968,46 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js } return 1; } - function Eh() { + function Rh() { Ni(""); } - function Rh() { - I || k || ne("Blocking on the main thread is very dangerous, see https://emscripten.org/docs/porting/pthreads.html#blocking-on-the-main-browser-thread"); + function Dh() { + I || k || te("Blocking on the main thread is very dangerous, see https://emscripten.org/docs/porting/pthreads.html#blocking-on-the-main-browser-thread"); } function Tc() { return 2147483648; } - function Dh(N, D, B) { + function Fh(N, D, B) { i().copyWithin(N, D, D + B); } - function Fh() { - return I ? m$().cpus().length : navigator.hardwareConcurrency; + function Oh() { + return I ? b$().cpus().length : navigator.hardwareConcurrency; } function Vr(N, D) { var B = arguments.length - 2, Q = arguments; return $i(function() { - for (var ue = B, pe = Oi(ue * 8), ye = pe >> 3, Te = 0; Te < B; Te++) { + for (var ue = B, he = Oi(ue * 8), ye = he >> 3, Te = 0; Te < B; Te++) { var bt = Q[2 + Te]; p()[ye + Te] = bt; } - return rx(N, ue, pe, D); + return ax(N, ue, he, D); }); } var xu = []; - function Oh(N, D, B) { + function Ph(N, D, B) { xu.length = D; for (var Q = B >> 3, ue = 0; ue < D; ue++) xu[ue] = p()[Q + ue]; - var pe = N < 0, ye = pe ? mh[-N - 1] : ef[N]; + var he = N < 0, ye = he ? gh[-N - 1] : tf[N]; return ye.apply(null, xu); } - function Ph(N) { + function zh(N) { try { - return Ce.grow(N - nn.byteLength + 65535 >>> 16), rs(Ce.buffer), 1; + return Ce.grow(N - tn.byteLength + 65535 >>> 16), rs(Ce.buffer), 1; } catch (D) { } } - function zh(N) { + function Mh(N) { var D = i().length; if (N = N >>> 0, N <= D) return false; @@ -2017,18 +2017,18 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js for (var Q = 1; Q <= 4; Q *= 2) { var ue = D * (1 + 0.2 / Q); ue = Math.min(ue, N + 100663296); - var pe = Math.min(B, Ii(Math.max(N, ue), 65536)), ye = Ph(pe); + var he = Math.min(B, Ii(Math.max(N, ue), 65536)), ye = zh(he); if (ye) return true; } return false; } - var Me = { inEventHandler: 0, removeAllEventListeners: function() { - for (var N = Me.eventHandlers.length - 1; N >= 0; --N) - Me._removeHandler(N); - Me.eventHandlers = [], Me.deferredCalls = []; + var Le = { inEventHandler: 0, removeAllEventListeners: function() { + for (var N = Le.eventHandlers.length - 1; N >= 0; --N) + Le._removeHandler(N); + Le.eventHandlers = [], Le.deferredCalls = []; }, registerRemoveEventListeners: function() { - Me.removeEventListenersRegistered || (lh.push(Me.removeAllEventListeners), Me.removeEventListenersRegistered = true); + Le.removeEventListenersRegistered || (ch.push(Le.removeAllEventListeners), Le.removeEventListenersRegistered = true); }, deferredCalls: [], deferCall: function(N, D, B) { function Q(ye, Te) { if (ye.length != Te.length) @@ -2038,44 +2038,44 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js return false; return true; } - for (var ue in Me.deferredCalls) { - var pe = Me.deferredCalls[ue]; - if (pe.targetFunction == N && Q(pe.argsList, B)) + for (var ue in Le.deferredCalls) { + var he = Le.deferredCalls[ue]; + if (he.targetFunction == N && Q(he.argsList, B)) return; } - Me.deferredCalls.push({ targetFunction: N, precedence: D, argsList: B }), Me.deferredCalls.sort(function(ye, Te) { + Le.deferredCalls.push({ targetFunction: N, precedence: D, argsList: B }), Le.deferredCalls.sort(function(ye, Te) { return ye.precedence < Te.precedence; }); }, removeDeferredCalls: function(N) { - for (var D = 0; D < Me.deferredCalls.length; ++D) - Me.deferredCalls[D].targetFunction == N && (Me.deferredCalls.splice(D, 1), --D); + for (var D = 0; D < Le.deferredCalls.length; ++D) + Le.deferredCalls[D].targetFunction == N && (Le.deferredCalls.splice(D, 1), --D); }, canPerformEventHandlerRequests: function() { - return Me.inEventHandler && Me.currentEventHandler.allowsDeferredCalls; + return Le.inEventHandler && Le.currentEventHandler.allowsDeferredCalls; }, runDeferredCalls: function() { - if (!!Me.canPerformEventHandlerRequests()) - for (var N = 0; N < Me.deferredCalls.length; ++N) { - var D = Me.deferredCalls[N]; - Me.deferredCalls.splice(N, 1), --N, D.targetFunction.apply(null, D.argsList); + if (!!Le.canPerformEventHandlerRequests()) + for (var N = 0; N < Le.deferredCalls.length; ++N) { + var D = Le.deferredCalls[N]; + Le.deferredCalls.splice(N, 1), --N, D.targetFunction.apply(null, D.argsList); } }, eventHandlers: [], removeAllHandlersOnTarget: function(N, D) { - for (var B = 0; B < Me.eventHandlers.length; ++B) - Me.eventHandlers[B].target == N && (!D || D == Me.eventHandlers[B].eventTypeString) && Me._removeHandler(B--); + for (var B = 0; B < Le.eventHandlers.length; ++B) + Le.eventHandlers[B].target == N && (!D || D == Le.eventHandlers[B].eventTypeString) && Le._removeHandler(B--); }, _removeHandler: function(N) { - var D = Me.eventHandlers[N]; - D.target.removeEventListener(D.eventTypeString, D.eventListenerFunc, D.useCapture), Me.eventHandlers.splice(N, 1); + var D = Le.eventHandlers[N]; + D.target.removeEventListener(D.eventTypeString, D.eventListenerFunc, D.useCapture), Le.eventHandlers.splice(N, 1); }, registerOrRemoveHandler: function(N) { var D = function(ue) { - ++Me.inEventHandler, Me.currentEventHandler = N, Me.runDeferredCalls(), N.handlerFunc(ue), Me.runDeferredCalls(), --Me.inEventHandler; + ++Le.inEventHandler, Le.currentEventHandler = N, Le.runDeferredCalls(), N.handlerFunc(ue), Le.runDeferredCalls(), --Le.inEventHandler; }; if (N.callbackfunc) - N.eventListenerFunc = D, N.target.addEventListener(N.eventTypeString, D, N.useCapture), Me.eventHandlers.push(N), Me.registerRemoveEventListeners(); + N.eventListenerFunc = D, N.target.addEventListener(N.eventTypeString, D, N.useCapture), Le.eventHandlers.push(N), Le.registerRemoveEventListeners(); else - for (var B = 0; B < Me.eventHandlers.length; ++B) - Me.eventHandlers[B].target == N.target && Me.eventHandlers[B].eventTypeString == N.eventTypeString && Me._removeHandler(B--); + for (var B = 0; B < Le.eventHandlers.length; ++B) + Le.eventHandlers[B].target == N.target && Le.eventHandlers[B].eventTypeString == N.eventTypeString && Le._removeHandler(B--); }, queueEventHandlerOnThread_iiii: function(N, D, B, Q, ue) { $i(function() { - var pe = Oi(12); - l()[pe >> 2] = B, l()[pe + 4 >> 2] = Q, l()[pe + 8 >> 2] = ue, zf(N, 637534208, D, Q, pe); + var he = Oi(12); + l()[he >> 2] = B, l()[he + 4 >> 2] = Q, l()[he + 8 >> 2] = ue, Mf(N, 637534208, D, Q, he); }); }, getTargetThreadForEventCallback: function(N) { switch (N) { @@ -2091,30 +2091,30 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js }, fullscreenEnabled: function() { return document.fullscreenEnabled || document.webkitFullscreenEnabled; } }; - function Mh(N) { - var D = Si(N) + 1, B = Pf(D); + function Lh(N) { + var D = Si(N) + 1, B = zf(D); return Ms(N, B, D), B; } - function Lh(N, D, B, Q) { + function Bh(N, D, B, Q) { $i(function() { - var ue = Oi(12), pe = 0; - D && (pe = Mh(D)), l()[ue >> 2] = pe, l()[ue + 4 >> 2] = B, l()[ue + 8 >> 2] = Q, zf(N, 657457152, 0, pe, ue); + var ue = Oi(12), he = 0; + D && (he = Lh(D)), l()[ue >> 2] = he, l()[ue + 4 >> 2] = B, l()[ue + 8 >> 2] = Q, Mf(N, 657457152, 0, he, ue); }); } - function Bh(N, D, B, Q) { - D = D ? tn(D) : "", Lh(N, D, B, Q); + function Vh(N, D, B, Q) { + D = D ? en(D) : "", Bh(N, D, B, Q); } - function Vh(N) { - return N > 2 ? tn(N) : N; + function Wh(N) { + return N > 2 ? en(N) : N; } - var Wh = [0, typeof document != "undefined" ? document : 0, typeof window != "undefined" ? window : 0]; - function Uh(N) { - N = Vh(N); - var D = Wh[N] || (typeof document != "undefined" ? document.querySelector(N) : void 0); + var Uh = [0, typeof document != "undefined" ? document : 0, typeof window != "undefined" ? window : 0]; + function Gh(N) { + N = Wh(N); + var D = Uh[N] || (typeof document != "undefined" ? document.querySelector(N) : void 0); return D; } function wu(N) { - return Uh(N); + return Gh(N); } function $c(N, D, B) { var Q = wu(N); @@ -2124,13 +2124,13 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js Q.offscreenCanvas && (Q = Q.offscreenCanvas); var ue = false; if (Q.GLctxObject && Q.GLctxObject.GLctx) { - var pe = Q.GLctxObject.GLctx.getParameter(2978); - ue = pe[0] === 0 && pe[1] === 0 && pe[2] === Q.width && pe[3] === Q.height; + var he = Q.GLctxObject.GLctx.getParameter(2978); + ue = he[0] === 0 && he[1] === 0 && he[2] === Q.width && he[3] === Q.height; } Q.width = D, Q.height = B, ue && Q.GLctxObject.GLctx.viewport(0, 0, D, B); } else if (Q.canvasSharedPtr) { var ye = l()[Q.canvasSharedPtr + 8 >> 2]; - return Bh(ye, N, D, B), 1; + return Vh(ye, N, D, B), 1; } else return -4; return 0; @@ -2138,25 +2138,25 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js function _c(N, D, B) { return $ ? Vr(2, 1, N, D, B) : $c(N, D, B); } - function Gh(N, D, B) { + function Hh(N, D, B) { var Q = wu(N); return Q ? $c(N, D, B) : _c(N, D, B); } - function Hh() { + function qh() { throw "unwind"; } - function qh(N) { + function jh(N) { var D = N.getExtension("ANGLE_instanced_arrays"); if (D) return N.vertexAttribDivisor = function(B, Q) { D.vertexAttribDivisorANGLE(B, Q); - }, N.drawArraysInstanced = function(B, Q, ue, pe) { - D.drawArraysInstancedANGLE(B, Q, ue, pe); - }, N.drawElementsInstanced = function(B, Q, ue, pe, ye) { - D.drawElementsInstancedANGLE(B, Q, ue, pe, ye); + }, N.drawArraysInstanced = function(B, Q, ue, he) { + D.drawArraysInstancedANGLE(B, Q, ue, he); + }, N.drawElementsInstanced = function(B, Q, ue, he, ye) { + D.drawElementsInstancedANGLE(B, Q, ue, he, ye); }, 1; } - function jh(N) { + function Kh(N) { var D = N.getExtension("OES_vertex_array_object"); if (D) return N.createVertexArray = function() { @@ -2169,14 +2169,14 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js return D.isVertexArrayOES(B); }, 1; } - function Kh(N) { + function Xh(N) { var D = N.getExtension("WEBGL_draw_buffers"); if (D) return N.drawBuffers = function(B, Q) { D.drawBuffersWEBGL(B, Q); }, 1; } - function Xh(N) { + function Yh(N) { return !!(N.multiDrawWebgl = N.getExtension("WEBGL_multi_draw")); } var gt = { counter: 1, buffers: [], programs: [], framebuffers: [], renderbuffers: [], textures: [], shaders: [], vaos: [], contexts: {}, offscreenCanvases: {}, queries: [], stringCache: {}, unpackAlignment: 4, recordError: function(D) { @@ -2186,14 +2186,14 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js N[B] = null; return D; }, getSource: function(N, D, B, Q) { - for (var ue = "", pe = 0; pe < D; ++pe) { - var ye = Q ? l()[Q + pe * 4 >> 2] : -1; - ue += tn(l()[B + pe * 4 >> 2], ye < 0 ? void 0 : ye); + for (var ue = "", he = 0; he < D; ++he) { + var ye = Q ? l()[Q + he * 4 >> 2] : -1; + ue += en(l()[B + he * 4 >> 2], ye < 0 ? void 0 : ye); } return ue; }, createContext: function(N, D) { - N.getContextSafariWebGL2Fixed || (N.getContextSafariWebGL2Fixed = N.getContext, N.getContext = function(ue, pe) { - var ye = N.getContextSafariWebGL2Fixed(ue, pe); + N.getContextSafariWebGL2Fixed || (N.getContextSafariWebGL2Fixed = N.getContext, N.getContext = function(ue, he) { + var ye = N.getContextSafariWebGL2Fixed(ue, he); return ue == "webgl" == ye instanceof WebGLRenderingContext ? ye : null; }); var B = N.getContext("webgl", D); @@ -2202,7 +2202,7 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js var Q = gt.registerContext(B, D); return Q; }, registerContext: function(N, D) { - var B = Pf(8); + var B = zf(8); l()[B + 4 >> 2] = Mc(); var Q = { handle: B, attributes: D, version: D.majorVersion, GLctx: N }; return N.canvas && (N.canvas.GLctxObject = Q), gt.contexts[B] = Q, (typeof D.enableExtensionsByDefault == "undefined" || D.enableExtensionsByDefault) && gt.initExtensions(Q), B; @@ -2211,37 +2211,37 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js }, getContext: function(N) { return gt.contexts[N]; }, deleteContext: function(N) { - gt.currentContext === gt.contexts[N] && (gt.currentContext = null), typeof Me == "object" && Me.removeAllHandlersOnTarget(gt.contexts[N].GLctx.canvas), gt.contexts[N] && gt.contexts[N].GLctx.canvas && (gt.contexts[N].GLctx.canvas.GLctxObject = void 0), Jv(gt.contexts[N].handle), gt.contexts[N] = null; + gt.currentContext === gt.contexts[N] && (gt.currentContext = null), typeof Le == "object" && Le.removeAllHandlersOnTarget(gt.contexts[N].GLctx.canvas), gt.contexts[N] && gt.contexts[N].GLctx.canvas && (gt.contexts[N].GLctx.canvas.GLctxObject = void 0), ex(gt.contexts[N].handle), gt.contexts[N] = null; }, initExtensions: function(N) { if (N || (N = gt.currentContext), !N.initExtensionsDone) { N.initExtensionsDone = true; var D = N.GLctx; - qh(D), jh(D), Kh(D), D.disjointTimerQueryExt = D.getExtension("EXT_disjoint_timer_query"), Xh(D); + jh(D), Kh(D), Xh(D), D.disjointTimerQueryExt = D.getExtension("EXT_disjoint_timer_query"), Yh(D); var B = D.getSupportedExtensions() || []; B.forEach(function(Q) { !Q.includes("lose_context") && !Q.includes("debug") && D.getExtension(Q); }); } - } }, Yh = ["default", "low-power", "high-performance"]; - function Qh(N, D) { - var B = D >> 2, Q = l()[B + 6], ue = { alpha: !!l()[B + 0], depth: !!l()[B + 1], stencil: !!l()[B + 2], antialias: !!l()[B + 3], premultipliedAlpha: !!l()[B + 4], preserveDrawingBuffer: !!l()[B + 5], powerPreference: Yh[Q], failIfMajorPerformanceCaveat: !!l()[B + 7], majorVersion: l()[B + 8], minorVersion: l()[B + 9], enableExtensionsByDefault: l()[B + 10], explicitSwapControl: l()[B + 11], proxyContextToMainThread: l()[B + 12], renderViaOffscreenBackBuffer: l()[B + 13] }, pe = wu(N); - if (!pe || ue.explicitSwapControl) + } }, Qh = ["default", "low-power", "high-performance"]; + function Zh(N, D) { + var B = D >> 2, Q = l()[B + 6], ue = { alpha: !!l()[B + 0], depth: !!l()[B + 1], stencil: !!l()[B + 2], antialias: !!l()[B + 3], premultipliedAlpha: !!l()[B + 4], preserveDrawingBuffer: !!l()[B + 5], powerPreference: Qh[Q], failIfMajorPerformanceCaveat: !!l()[B + 7], majorVersion: l()[B + 8], minorVersion: l()[B + 9], enableExtensionsByDefault: l()[B + 10], explicitSwapControl: l()[B + 11], proxyContextToMainThread: l()[B + 12], renderViaOffscreenBackBuffer: l()[B + 13] }, he = wu(N); + if (!he || ue.explicitSwapControl) return 0; - var ye = gt.createContext(pe, ue); + var ye = gt.createContext(he, ue); return ye; } - function Zh(N, D) { - return Qh(N, D); + function Jh(N, D) { + return Zh(N, D); } var Ai = { mappings: {}, buffers: [null, [], []], printChar: function(N, D) { var B = Ai.buffers[N]; - D === 0 || D === 10 ? ((N === 1 ? te : J)(Dn(B, 0)), B.length = 0) : B.push(D); + D === 0 || D === 10 ? ((N === 1 ? ne : ee)(Dn(B, 0)), B.length = 0) : B.push(D); }, varargs: void 0, get: function() { Ai.varargs += 4; var N = l()[Ai.varargs - 4 >> 2]; return N; }, getStr: function(N) { - var D = tn(N); + var D = en(N); return D; }, get64: function(N, D) { return N; @@ -2256,7 +2256,7 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js function Rc(N, D, B, Q) { if ($) return Vr(5, 1, N, D, B, Q); - for (var ue = 0, pe = 0; pe < B; pe++) { + for (var ue = 0, he = 0; he < B; he++) { var ye = l()[D >> 2], Te = l()[D + 4 >> 2]; D += 8; for (var bt = 0; bt < Te; bt++) @@ -2265,98 +2265,98 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js } return l()[Q >> 2] = ue, 0; } - function Jh(N) { + function ef(N) { Re(N); } $e.init(); - var Dc, ef = [null, Cc, _c, Ac, Ec, Rc], Yv = false, Fc = { __clock_gettime: Ch, __emscripten_init_main_thread_js: Nh, __emscripten_thread_cleanup: Th, __pthread_create_js: $h, _emscripten_default_pthread_stack_size: _h, _emscripten_notify_thread_queue: Ah, abort: Eh, emscripten_check_blocking_allowed: Rh, emscripten_get_heap_max: Tc, emscripten_get_now: Br, emscripten_memcpy_big: Dh, emscripten_num_logical_cores: Fh, emscripten_receive_on_main_thread_js: Oh, emscripten_resize_heap: zh, emscripten_set_canvas_element_size: Gh, emscripten_unwind_to_js_event_loop: Hh, emscripten_webgl_create_context: Zh, exit: Ic, fd_close: Ac, fd_seek: Ec, fd_write: Rc, memory: Ce || d.wasmMemory, setTempRet0: Jh }, Qv = fh(), tf = d.___wasm_call_ctors = function() { - return (tf = d.___wasm_call_ctors = d.asm.__wasm_call_ctors).apply(null, arguments); - }, nf = d._init = function() { - return (nf = d._init = d.asm.init).apply(null, arguments); - }, sf = d._init_with_threads_count = function() { - return (sf = d._init_with_threads_count = d.asm.init_with_threads_count).apply(null, arguments); - }, rf = d._get_threads_count = function() { - return (rf = d._get_threads_count = d.asm.get_threads_count).apply(null, arguments); - }, af = d._register_tensor = function() { - return (af = d._register_tensor = d.asm.register_tensor).apply(null, arguments); - }, of = d._dispose_data = function() { - return (of = d._dispose_data = d.asm.dispose_data).apply(null, arguments); - }, uf = d._dispose = function() { - return (uf = d._dispose = d.asm.dispose).apply(null, arguments); - }, lf = d._Abs = function() { - return (lf = d._Abs = d.asm.Abs).apply(null, arguments); - }, cf = d._Add = function() { - return (cf = d._Add = d.asm.Add).apply(null, arguments); - }, df = d._AddN = function() { - return (df = d._AddN = d.asm.AddN).apply(null, arguments); - }, pf = d._All = function() { - return (pf = d._All = d.asm.All).apply(null, arguments); - }, hf = d._Any = function() { - return (hf = d._Any = d.asm.Any).apply(null, arguments); - }, ff = d._ArgMax = function() { - return (ff = d._ArgMax = d.asm.ArgMax).apply(null, arguments); - }, mf = d._AvgPool = function() { - return (mf = d._AvgPool = d.asm.AvgPool).apply(null, arguments); - }, gf = d._BatchMatMul = function() { - return (gf = d._BatchMatMul = d.asm.BatchMatMul).apply(null, arguments); - }, bf = d._Ceil = function() { - return (bf = d._Ceil = d.asm.Ceil).apply(null, arguments); - }, yf = d._ClipByValue = function() { - return (yf = d._ClipByValue = d.asm.ClipByValue).apply(null, arguments); - }, vf = d._Conv2D = function() { - return (vf = d._Conv2D = d.asm.Conv2D).apply(null, arguments); - }, xf = d._Conv2DBackpropInput = function() { - return (xf = d._Conv2DBackpropInput = d.asm.Conv2DBackpropInput).apply(null, arguments); - }, wf = d._Cos = function() { - return (wf = d._Cos = d.asm.Cos).apply(null, arguments); - }, kf = d._Cosh = function() { - return (kf = d._Cosh = d.asm.Cosh).apply(null, arguments); - }, Sf = d._CropAndResize = function() { - return (Sf = d._CropAndResize = d.asm.CropAndResize).apply(null, arguments); - }, If = d._Cumprod = function() { - return (If = d._Cumprod = d.asm.Cumprod).apply(null, arguments); - }, Cf = d._Cumsum = function() { - return (Cf = d._Cumsum = d.asm.Cumsum).apply(null, arguments); - }, Nf = d._DepthToSpace = function() { - return (Nf = d._DepthToSpace = d.asm.DepthToSpace).apply(null, arguments); - }, Tf = d._DepthwiseConv2dNative = function() { - return (Tf = d._DepthwiseConv2dNative = d.asm.DepthwiseConv2dNative).apply(null, arguments); - }, $f = d._Elu = function() { - return ($f = d._Elu = d.asm.Elu).apply(null, arguments); - }, _f = d._Equal = function() { - return (_f = d._Equal = d.asm.Equal).apply(null, arguments); - }, Af = d._Exp = function() { - return (Af = d._Exp = d.asm.Exp).apply(null, arguments); - }, Ef = d._FlipLeftRight = function() { - return (Ef = d._FlipLeftRight = d.asm.FlipLeftRight).apply(null, arguments); + var Dc, tf = [null, Cc, _c, Ac, Ec, Rc], Qv = false, Fc = { __clock_gettime: Nh, __emscripten_init_main_thread_js: Th, __emscripten_thread_cleanup: $h, __pthread_create_js: _h, _emscripten_default_pthread_stack_size: Ah, _emscripten_notify_thread_queue: Eh, abort: Rh, emscripten_check_blocking_allowed: Dh, emscripten_get_heap_max: Tc, emscripten_get_now: Br, emscripten_memcpy_big: Fh, emscripten_num_logical_cores: Oh, emscripten_receive_on_main_thread_js: Ph, emscripten_resize_heap: Mh, emscripten_set_canvas_element_size: Hh, emscripten_unwind_to_js_event_loop: qh, emscripten_webgl_create_context: Jh, exit: Ic, fd_close: Ac, fd_seek: Ec, fd_write: Rc, memory: Ce || d.wasmMemory, setTempRet0: ef }, Zv = mh(), nf = d.___wasm_call_ctors = function() { + return (nf = d.___wasm_call_ctors = d.asm.__wasm_call_ctors).apply(null, arguments); + }, sf = d._init = function() { + return (sf = d._init = d.asm.init).apply(null, arguments); + }, rf = d._init_with_threads_count = function() { + return (rf = d._init_with_threads_count = d.asm.init_with_threads_count).apply(null, arguments); + }, af = d._get_threads_count = function() { + return (af = d._get_threads_count = d.asm.get_threads_count).apply(null, arguments); + }, of = d._register_tensor = function() { + return (of = d._register_tensor = d.asm.register_tensor).apply(null, arguments); + }, uf = d._dispose_data = function() { + return (uf = d._dispose_data = d.asm.dispose_data).apply(null, arguments); + }, lf = d._dispose = function() { + return (lf = d._dispose = d.asm.dispose).apply(null, arguments); + }, cf = d._Abs = function() { + return (cf = d._Abs = d.asm.Abs).apply(null, arguments); + }, df = d._Add = function() { + return (df = d._Add = d.asm.Add).apply(null, arguments); + }, pf = d._AddN = function() { + return (pf = d._AddN = d.asm.AddN).apply(null, arguments); + }, hf = d._All = function() { + return (hf = d._All = d.asm.All).apply(null, arguments); + }, ff = d._Any = function() { + return (ff = d._Any = d.asm.Any).apply(null, arguments); + }, mf = d._ArgMax = function() { + return (mf = d._ArgMax = d.asm.ArgMax).apply(null, arguments); + }, gf = d._AvgPool = function() { + return (gf = d._AvgPool = d.asm.AvgPool).apply(null, arguments); + }, bf = d._BatchMatMul = function() { + return (bf = d._BatchMatMul = d.asm.BatchMatMul).apply(null, arguments); + }, yf = d._Ceil = function() { + return (yf = d._Ceil = d.asm.Ceil).apply(null, arguments); + }, vf = d._ClipByValue = function() { + return (vf = d._ClipByValue = d.asm.ClipByValue).apply(null, arguments); + }, xf = d._Conv2D = function() { + return (xf = d._Conv2D = d.asm.Conv2D).apply(null, arguments); + }, wf = d._Conv2DBackpropInput = function() { + return (wf = d._Conv2DBackpropInput = d.asm.Conv2DBackpropInput).apply(null, arguments); + }, kf = d._Cos = function() { + return (kf = d._Cos = d.asm.Cos).apply(null, arguments); + }, Sf = d._Cosh = function() { + return (Sf = d._Cosh = d.asm.Cosh).apply(null, arguments); + }, If = d._CropAndResize = function() { + return (If = d._CropAndResize = d.asm.CropAndResize).apply(null, arguments); + }, Cf = d._Cumprod = function() { + return (Cf = d._Cumprod = d.asm.Cumprod).apply(null, arguments); + }, Nf = d._Cumsum = function() { + return (Nf = d._Cumsum = d.asm.Cumsum).apply(null, arguments); + }, Tf = d._DepthToSpace = function() { + return (Tf = d._DepthToSpace = d.asm.DepthToSpace).apply(null, arguments); + }, $f = d._DepthwiseConv2dNative = function() { + return ($f = d._DepthwiseConv2dNative = d.asm.DepthwiseConv2dNative).apply(null, arguments); + }, _f = d._Elu = function() { + return (_f = d._Elu = d.asm.Elu).apply(null, arguments); + }, Af = d._Equal = function() { + return (Af = d._Equal = d.asm.Equal).apply(null, arguments); + }, Ef = d._Exp = function() { + return (Ef = d._Exp = d.asm.Exp).apply(null, arguments); + }, Rf = d._FlipLeftRight = function() { + return (Rf = d._FlipLeftRight = d.asm.FlipLeftRight).apply(null, arguments); }, Oc = d._Floor = function() { return (Oc = d._Floor = d.asm.Floor).apply(null, arguments); }, Pc = d._FloorDiv = function() { return (Pc = d._FloorDiv = d.asm.FloorDiv).apply(null, arguments); }, ku = d._FusedBatchNorm = function() { return (ku = d._FusedBatchNorm = d.asm.FusedBatchNorm).apply(null, arguments); - }, Rf = d._FusedConv2D = function() { - return (Rf = d._FusedConv2D = d.asm.FusedConv2D).apply(null, arguments); - }, Df = d._FusedDepthwiseConv2D = function() { - return (Df = d._FusedDepthwiseConv2D = d.asm.FusedDepthwiseConv2D).apply(null, arguments); + }, Df = d._FusedConv2D = function() { + return (Df = d._FusedConv2D = d.asm.FusedConv2D).apply(null, arguments); + }, Ff = d._FusedDepthwiseConv2D = function() { + return (Ff = d._FusedDepthwiseConv2D = d.asm.FusedDepthwiseConv2D).apply(null, arguments); }, Ei = d._Gather = function() { return (Ei = d._Gather = d.asm.Gather).apply(null, arguments); }, Su = d._GatherNd = function() { return (Su = d._GatherNd = d.asm.GatherNd).apply(null, arguments); }, Iu = d._Greater = function() { return (Iu = d._Greater = d.asm.Greater).apply(null, arguments); - }, Zv = d._GreaterEqual = function() { - return (Zv = d._GreaterEqual = d.asm.GreaterEqual).apply(null, arguments); + }, Jv = d._GreaterEqual = function() { + return (Jv = d._GreaterEqual = d.asm.GreaterEqual).apply(null, arguments); }, Ri = d._LeakyRelu = function() { return (Ri = d._LeakyRelu = d.asm.LeakyRelu).apply(null, arguments); }, Di = d._Less = function() { return (Di = d._Less = d.asm.Less).apply(null, arguments); - }, Ff = d._LessEqual = function() { - return (Ff = d._LessEqual = d.asm.LessEqual).apply(null, arguments); + }, Of = d._LessEqual = function() { + return (Of = d._LessEqual = d.asm.LessEqual).apply(null, arguments); }, H = d._Log = function() { return (H = d._Log = d.asm.Log).apply(null, arguments); - }, ee = d._LogicalAnd = function() { - return (ee = d._LogicalAnd = d.asm.LogicalAnd).apply(null, arguments); + }, J = d._LogicalAnd = function() { + return (J = d._LogicalAnd = d.asm.LogicalAnd).apply(null, arguments); }, ce = d._Max = function() { return (ce = d._Max = d.asm.Max).apply(null, arguments); }, Se = d._MaxPool = function() { @@ -2365,8 +2365,8 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js return (Qe = d._Maximum = d.asm.Maximum).apply(null, arguments); }, Ze = d._Mean = function() { return (Ze = d._Mean = d.asm.Mean).apply(null, arguments); - }, Le = d._Min = function() { - return (Le = d._Min = d.asm.Min).apply(null, arguments); + }, Be = d._Min = function() { + return (Be = d._Min = d.asm.Min).apply(null, arguments); }, ze = d._Minimum = function() { return (ze = d._Minimum = d.asm.Minimum).apply(null, arguments); }, Tt = d._MirrorPad = function() { @@ -2379,146 +2379,146 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js return (Fi = d._NonMaxSuppressionV3 = d.asm.NonMaxSuppressionV3).apply(null, arguments); }, Wr = d._NonMaxSuppressionV4 = function() { return (Wr = d._NonMaxSuppressionV4 = d.asm.NonMaxSuppressionV4).apply(null, arguments); - }, Of = d._NonMaxSuppressionV5 = function() { - return (Of = d._NonMaxSuppressionV5 = d.asm.NonMaxSuppressionV5).apply(null, arguments); - }, an = d._NotEqual = function() { - return (an = d._NotEqual = d.asm.NotEqual).apply(null, arguments); + }, Pf = d._NonMaxSuppressionV5 = function() { + return (Pf = d._NonMaxSuppressionV5 = d.asm.NonMaxSuppressionV5).apply(null, arguments); + }, rn = d._NotEqual = function() { + return (rn = d._NotEqual = d.asm.NotEqual).apply(null, arguments); }, tr = d._OneHot = function() { return (tr = d._OneHot = d.asm.OneHot).apply(null, arguments); }, zc = d._PadV2 = function() { return (zc = d._PadV2 = d.asm.PadV2).apply(null, arguments); - }, rT = d._Pow = function() { - return (rT = d._Pow = d.asm.Pow).apply(null, arguments); - }, aT = d._Prelu = function() { - return (aT = d._Prelu = d.asm.Prelu).apply(null, arguments); - }, iT = d._Prod = function() { - return (iT = d._Prod = d.asm.Prod).apply(null, arguments); - }, oT = d._RealDiv = function() { - return (oT = d._RealDiv = d.asm.RealDiv).apply(null, arguments); - }, uT = d._Relu = function() { - return (uT = d._Relu = d.asm.Relu).apply(null, arguments); - }, lT = d._Relu6 = function() { - return (lT = d._Relu6 = d.asm.Relu6).apply(null, arguments); - }, cT = d._ResizeBilinear = function() { - return (cT = d._ResizeBilinear = d.asm.ResizeBilinear).apply(null, arguments); - }, dT = d._Reverse = function() { - return (dT = d._Reverse = d.asm.Reverse).apply(null, arguments); - }, pT = d._RotateWithOffset = function() { - return (pT = d._RotateWithOffset = d.asm.RotateWithOffset).apply(null, arguments); - }, hT = d._Round = function() { - return (hT = d._Round = d.asm.Round).apply(null, arguments); - }, fT = d._Rsqrt = function() { - return (fT = d._Rsqrt = d.asm.Rsqrt).apply(null, arguments); - }, mT = d._ScatterNd = function() { - return (mT = d._ScatterNd = d.asm.ScatterNd).apply(null, arguments); - }, gT = d._SelectV2 = function() { - return (gT = d._SelectV2 = d.asm.SelectV2).apply(null, arguments); - }, bT = d._Sigmoid = function() { - return (bT = d._Sigmoid = d.asm.Sigmoid).apply(null, arguments); - }, yT = d._Sin = function() { - return (yT = d._Sin = d.asm.Sin).apply(null, arguments); - }, vT = d._Softmax = function() { - return (vT = d._Softmax = d.asm.Softmax).apply(null, arguments); - }, xT = d._SparseFillEmptyRows = function() { - return (xT = d._SparseFillEmptyRows = d.asm.SparseFillEmptyRows).apply(null, arguments); - }, wT = d._SparseReshape = function() { - return (wT = d._SparseReshape = d.asm.SparseReshape).apply(null, arguments); - }, kT = d._SparseSegmentReduction = function() { - return (kT = d._SparseSegmentReduction = d.asm.SparseSegmentReduction).apply(null, arguments); - }, ST = d._Sqrt = function() { - return (ST = d._Sqrt = d.asm.Sqrt).apply(null, arguments); - }, IT = d._Square = function() { - return (IT = d._Square = d.asm.Square).apply(null, arguments); - }, CT = d._SquaredDifference = function() { - return (CT = d._SquaredDifference = d.asm.SquaredDifference).apply(null, arguments); - }, NT = d._Step = function() { - return (NT = d._Step = d.asm.Step).apply(null, arguments); - }, TT = d._StridedSlice = function() { - return (TT = d._StridedSlice = d.asm.StridedSlice).apply(null, arguments); - }, $T = d._Sub = function() { - return ($T = d._Sub = d.asm.Sub).apply(null, arguments); - }, _T = d._Sum = function() { - return (_T = d._Sum = d.asm.Sum).apply(null, arguments); - }, AT = d._Tan = function() { - return (AT = d._Tan = d.asm.Tan).apply(null, arguments); - }, ET = d._Tanh = function() { - return (ET = d._Tanh = d.asm.Tanh).apply(null, arguments); - }, RT = d._Tile = function() { - return (RT = d._Tile = d.asm.Tile).apply(null, arguments); - }, DT = d._TopK = function() { - return (DT = d._TopK = d.asm.TopK).apply(null, arguments); - }, FT = d._Transform = function() { - return (FT = d._Transform = d.asm.Transform).apply(null, arguments); - }, OT = d._Transpose = function() { - return (OT = d._Transpose = d.asm.Transpose).apply(null, arguments); - }, PT = d.__FusedMatMul = function() { - return (PT = d.__FusedMatMul = d.asm._FusedMatMul).apply(null, arguments); - }, Pf = d._malloc = function() { - return (Pf = d._malloc = d.asm.malloc).apply(null, arguments); - }, Jv = d._free = function() { - return (Jv = d._free = d.asm.free).apply(null, arguments); - }, zT = d._emscripten_tls_init = function() { - return (zT = d._emscripten_tls_init = d.asm.emscripten_tls_init).apply(null, arguments); - }, ex = d.___errno_location = function() { - return (ex = d.___errno_location = d.asm.__errno_location).apply(null, arguments); + }, iT = d._Pow = function() { + return (iT = d._Pow = d.asm.Pow).apply(null, arguments); + }, oT = d._Prelu = function() { + return (oT = d._Prelu = d.asm.Prelu).apply(null, arguments); + }, uT = d._Prod = function() { + return (uT = d._Prod = d.asm.Prod).apply(null, arguments); + }, lT = d._RealDiv = function() { + return (lT = d._RealDiv = d.asm.RealDiv).apply(null, arguments); + }, cT = d._Relu = function() { + return (cT = d._Relu = d.asm.Relu).apply(null, arguments); + }, dT = d._Relu6 = function() { + return (dT = d._Relu6 = d.asm.Relu6).apply(null, arguments); + }, pT = d._ResizeBilinear = function() { + return (pT = d._ResizeBilinear = d.asm.ResizeBilinear).apply(null, arguments); + }, hT = d._Reverse = function() { + return (hT = d._Reverse = d.asm.Reverse).apply(null, arguments); + }, fT = d._RotateWithOffset = function() { + return (fT = d._RotateWithOffset = d.asm.RotateWithOffset).apply(null, arguments); + }, mT = d._Round = function() { + return (mT = d._Round = d.asm.Round).apply(null, arguments); + }, gT = d._Rsqrt = function() { + return (gT = d._Rsqrt = d.asm.Rsqrt).apply(null, arguments); + }, bT = d._ScatterNd = function() { + return (bT = d._ScatterNd = d.asm.ScatterNd).apply(null, arguments); + }, yT = d._SelectV2 = function() { + return (yT = d._SelectV2 = d.asm.SelectV2).apply(null, arguments); + }, vT = d._Sigmoid = function() { + return (vT = d._Sigmoid = d.asm.Sigmoid).apply(null, arguments); + }, xT = d._Sin = function() { + return (xT = d._Sin = d.asm.Sin).apply(null, arguments); + }, wT = d._Softmax = function() { + return (wT = d._Softmax = d.asm.Softmax).apply(null, arguments); + }, kT = d._SparseFillEmptyRows = function() { + return (kT = d._SparseFillEmptyRows = d.asm.SparseFillEmptyRows).apply(null, arguments); + }, ST = d._SparseReshape = function() { + return (ST = d._SparseReshape = d.asm.SparseReshape).apply(null, arguments); + }, IT = d._SparseSegmentReduction = function() { + return (IT = d._SparseSegmentReduction = d.asm.SparseSegmentReduction).apply(null, arguments); + }, CT = d._Sqrt = function() { + return (CT = d._Sqrt = d.asm.Sqrt).apply(null, arguments); + }, NT = d._Square = function() { + return (NT = d._Square = d.asm.Square).apply(null, arguments); + }, TT = d._SquaredDifference = function() { + return (TT = d._SquaredDifference = d.asm.SquaredDifference).apply(null, arguments); + }, $T = d._Step = function() { + return ($T = d._Step = d.asm.Step).apply(null, arguments); + }, _T = d._StridedSlice = function() { + return (_T = d._StridedSlice = d.asm.StridedSlice).apply(null, arguments); + }, AT = d._Sub = function() { + return (AT = d._Sub = d.asm.Sub).apply(null, arguments); + }, ET = d._Sum = function() { + return (ET = d._Sum = d.asm.Sum).apply(null, arguments); + }, RT = d._Tan = function() { + return (RT = d._Tan = d.asm.Tan).apply(null, arguments); + }, DT = d._Tanh = function() { + return (DT = d._Tanh = d.asm.Tanh).apply(null, arguments); + }, FT = d._Tile = function() { + return (FT = d._Tile = d.asm.Tile).apply(null, arguments); + }, OT = d._TopK = function() { + return (OT = d._TopK = d.asm.TopK).apply(null, arguments); + }, PT = d._Transform = function() { + return (PT = d._Transform = d.asm.Transform).apply(null, arguments); + }, zT = d._Transpose = function() { + return (zT = d._Transpose = d.asm.Transpose).apply(null, arguments); + }, MT = d.__FusedMatMul = function() { + return (MT = d.__FusedMatMul = d.asm._FusedMatMul).apply(null, arguments); + }, zf = d._malloc = function() { + return (zf = d._malloc = d.asm.malloc).apply(null, arguments); + }, ex = d._free = function() { + return (ex = d._free = d.asm.free).apply(null, arguments); + }, LT = d._emscripten_tls_init = function() { + return (LT = d._emscripten_tls_init = d.asm.emscripten_tls_init).apply(null, arguments); + }, tx = d.___errno_location = function() { + return (tx = d.___errno_location = d.asm.__errno_location).apply(null, arguments); }, Mc = d._pthread_self = function() { return (Mc = d._pthread_self = d.asm.pthread_self).apply(null, arguments); - }, tx = d._emscripten_main_thread_process_queued_calls = function() { - return (tx = d._emscripten_main_thread_process_queued_calls = d.asm.emscripten_main_thread_process_queued_calls).apply(null, arguments); - }, MT = d.__emscripten_thread_crashed = function() { - return (MT = d.__emscripten_thread_crashed = d.asm._emscripten_thread_crashed).apply(null, arguments); - }, nx = d.__emscripten_thread_init = function() { - return (nx = d.__emscripten_thread_init = d.asm._emscripten_thread_init).apply(null, arguments); - }, LT = d._emscripten_current_thread_process_queued_calls = function() { - return (LT = d._emscripten_current_thread_process_queued_calls = d.asm.emscripten_current_thread_process_queued_calls).apply(null, arguments); - }, BT = d._emscripten_main_browser_thread_id = function() { - return (BT = d._emscripten_main_browser_thread_id = d.asm.emscripten_main_browser_thread_id).apply(null, arguments); - }, VT = d._emscripten_sync_run_in_main_thread_2 = function() { - return (VT = d._emscripten_sync_run_in_main_thread_2 = d.asm.emscripten_sync_run_in_main_thread_2).apply(null, arguments); - }, sx = d._emscripten_sync_run_in_main_thread_4 = function() { - return (sx = d._emscripten_sync_run_in_main_thread_4 = d.asm.emscripten_sync_run_in_main_thread_4).apply(null, arguments); - }, rx = d._emscripten_run_in_main_runtime_thread_js = function() { - return (rx = d._emscripten_run_in_main_runtime_thread_js = d.asm.emscripten_run_in_main_runtime_thread_js).apply(null, arguments); - }, zf = d._emscripten_dispatch_to_thread_ = function() { - return (zf = d._emscripten_dispatch_to_thread_ = d.asm.emscripten_dispatch_to_thread_).apply(null, arguments); - }, Mf = d.__emscripten_thread_free_data = function() { - return (Mf = d.__emscripten_thread_free_data = d.asm._emscripten_thread_free_data).apply(null, arguments); - }, WT = d.__emscripten_thread_exit = function() { - return (WT = d.__emscripten_thread_exit = d.asm._emscripten_thread_exit).apply(null, arguments); - }, UT = d._memalign = function() { - return (UT = d._memalign = d.asm.memalign).apply(null, arguments); - }, ax = d._emscripten_stack_set_limits = function() { - return (ax = d._emscripten_stack_set_limits = d.asm.emscripten_stack_set_limits).apply(null, arguments); - }, Lf = d.stackSave = function() { - return (Lf = d.stackSave = d.asm.stackSave).apply(null, arguments); + }, nx = d._emscripten_main_thread_process_queued_calls = function() { + return (nx = d._emscripten_main_thread_process_queued_calls = d.asm.emscripten_main_thread_process_queued_calls).apply(null, arguments); + }, BT = d.__emscripten_thread_crashed = function() { + return (BT = d.__emscripten_thread_crashed = d.asm._emscripten_thread_crashed).apply(null, arguments); + }, sx = d.__emscripten_thread_init = function() { + return (sx = d.__emscripten_thread_init = d.asm._emscripten_thread_init).apply(null, arguments); + }, VT = d._emscripten_current_thread_process_queued_calls = function() { + return (VT = d._emscripten_current_thread_process_queued_calls = d.asm.emscripten_current_thread_process_queued_calls).apply(null, arguments); + }, WT = d._emscripten_main_browser_thread_id = function() { + return (WT = d._emscripten_main_browser_thread_id = d.asm.emscripten_main_browser_thread_id).apply(null, arguments); + }, UT = d._emscripten_sync_run_in_main_thread_2 = function() { + return (UT = d._emscripten_sync_run_in_main_thread_2 = d.asm.emscripten_sync_run_in_main_thread_2).apply(null, arguments); + }, rx = d._emscripten_sync_run_in_main_thread_4 = function() { + return (rx = d._emscripten_sync_run_in_main_thread_4 = d.asm.emscripten_sync_run_in_main_thread_4).apply(null, arguments); + }, ax = d._emscripten_run_in_main_runtime_thread_js = function() { + return (ax = d._emscripten_run_in_main_runtime_thread_js = d.asm.emscripten_run_in_main_runtime_thread_js).apply(null, arguments); + }, Mf = d._emscripten_dispatch_to_thread_ = function() { + return (Mf = d._emscripten_dispatch_to_thread_ = d.asm.emscripten_dispatch_to_thread_).apply(null, arguments); + }, Lf = d.__emscripten_thread_free_data = function() { + return (Lf = d.__emscripten_thread_free_data = d.asm._emscripten_thread_free_data).apply(null, arguments); + }, GT = d.__emscripten_thread_exit = function() { + return (GT = d.__emscripten_thread_exit = d.asm._emscripten_thread_exit).apply(null, arguments); + }, HT = d._memalign = function() { + return (HT = d._memalign = d.asm.memalign).apply(null, arguments); + }, ix = d._emscripten_stack_set_limits = function() { + return (ix = d._emscripten_stack_set_limits = d.asm.emscripten_stack_set_limits).apply(null, arguments); + }, Bf = d.stackSave = function() { + return (Bf = d.stackSave = d.asm.stackSave).apply(null, arguments); }, Lc = d.stackRestore = function() { return (Lc = d.stackRestore = d.asm.stackRestore).apply(null, arguments); }, Oi = d.stackAlloc = function() { return (Oi = d.stackAlloc = d.asm.stackAlloc).apply(null, arguments); - }, GT = d.dynCall_iijjiiii = function() { - return (GT = d.dynCall_iijjiiii = d.asm.dynCall_iijjiiii).apply(null, arguments); - }, HT = d.dynCall_jiji = function() { - return (HT = d.dynCall_jiji = d.asm.dynCall_jiji).apply(null, arguments); - }, ix = d.__emscripten_allow_main_runtime_queued_calls = 21456; - d.cwrap = en, d.keepRuntimeAlive = Mr, d.PThread = $e, d.PThread = $e, d.wasmMemory = Ce, d.ExitStatus = Cu; + }, qT = d.dynCall_iijjiiii = function() { + return (qT = d.dynCall_iijjiiii = d.asm.dynCall_iijjiiii).apply(null, arguments); + }, jT = d.dynCall_jiji = function() { + return (jT = d.dynCall_jiji = d.asm.dynCall_jiji).apply(null, arguments); + }, ox = d.__emscripten_allow_main_runtime_queued_calls = 21456; + d.cwrap = Jt, d.keepRuntimeAlive = Mr, d.PThread = $e, d.PThread = $e, d.wasmMemory = Ce, d.ExitStatus = Cu; var Bc; function Cu(N) { this.name = "ExitStatus", this.message = "Program terminated with exit(" + N + ")", this.status = N; } as = function N() { - Bc || Bf(), Bc || (as = N); + Bc || Vf(), Bc || (as = N); }; - function Bf(N) { + function Vf(N) { if (N = N || b, er > 0) return; if ($) { h(d), bu(), postMessage({ cmd: "loaded" }); return; } - if (sn(), er > 0) + if (nn(), er > 0) return; function D() { - Bc || (Bc = true, d.calledRun = true, !at && (bu(), h(d), d.onRuntimeInitialized && d.onRuntimeInitialized(), ph())); + Bc || (Bc = true, d.calledRun = true, !at && (bu(), h(d), d.onRuntimeInitialized && d.onRuntimeInitialized(), hh())); } d.setStatus ? (d.setStatus("Running..."), setTimeout(function() { setTimeout(function() { @@ -2526,19 +2526,19 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js }, 1), D(); }, 1)) : D(); } - d.run = Bf; - function qT(N, D) { - if (Jt = N, !D && $) + d.run = Vf; + function KT(N, D) { + if (Zt = N, !D && $) throw Cc(N), "unwind"; - Mr() || dh(), jT(N); + Mr() || ph(), XT(N); } - function jT(N) { - Jt = N, Mr() || ($e.terminateAllThreads(), d.onExit && d.onExit(N), at = true), v(N, new Cu(N)); + function XT(N) { + Zt = N, Mr() || ($e.terminateAllThreads(), d.onExit && d.onExit(N), at = true), v(N, new Cu(N)); } if (d.preInit) for (typeof d.preInit == "function" && (d.preInit = [d.preInit]); d.preInit.length > 0; ) d.preInit.pop()(); - Bf(); + Vf(); var Vc; m && (Vc = { uncaughtException: process.listeners("uncaughtException").filter(function(N) { return !m.uncaughtException.indexOf(N) > -1; @@ -2553,9 +2553,9 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js else throw new Error("Could not find wasm module in post.js"); if (Vc) { - var KT = Wc._dispose; + var YT = Wc._dispose; Wc._dispose = function() { - KT(), Vc.uncaughtException.forEach(function(N) { + YT(), Vc.uncaughtException.forEach(function(N) { process.removeListener("uncaughtException", N); }), Vc.unhandledRejection.forEach(function(N) { process.removeListener("unhandledRejection", N); @@ -2569,19 +2569,19 @@ var g$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm-threaded-simd.js return n; }) : typeof e == "object" && (e.WasmBackendModuleThreadedSimd = n); } }); -var b$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm.js"(e, t) { +var v$ = zt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm.js"(e, t) { var n = (() => { var s = typeof document != "undefined" && document.currentScript ? document.currentScript.src : void 0; return typeof __filename != "undefined" && (s = s || __filename), function(r) { r = r || {}; var a = typeof r != "undefined" ? r : {}, i, o; - a.ready = new Promise(function(H, ee) { - i = H, o = ee; + a.ready = new Promise(function(H, J) { + i = H, o = J; }); var u; typeof process != "undefined" && process.listeners && (u = { uncaughtException: process.listeners("uncaughtException"), unhandledRejection: process.listeners("unhandledRejection") }); - var l = Object.assign({}, a), c = [], p = "./this.program", d = (H, ee) => { - throw ee; + var l = Object.assign({}, a), c = [], p = "./this.program", d = (H, J) => { + throw J; }, h = typeof window == "object", f = typeof importScripts == "function", m = typeof process == "object" && typeof process.versions == "object" && typeof process.versions.node == "string", g = ""; function b(H) { return a.locateFile ? a.locateFile(H, g) : g + H; @@ -2594,38 +2594,38 @@ var b$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm.js"(e, t) { } var $, R, E; m ? (f ? g = gd().dirname(g) + "/" : g = __dirname + "/", E = () => { - R || ($ = ug(), R = gd()); - }, y = function(ee, ce) { - return E(), ee = R.normalize(ee), $.readFileSync(ee, ce ? void 0 : "utf8"); + R || ($ = lg(), R = gd()); + }, y = function(J, ce) { + return E(), J = R.normalize(J), $.readFileSync(J, ce ? void 0 : "utf8"); }, x = (H) => { - var ee = y(H, true); - return ee.buffer || (ee = new Uint8Array(ee)), ee; - }, v = (H, ee, ce) => { + var J = y(H, true); + return J.buffer || (J = new Uint8Array(J)), J; + }, v = (H, J, ce) => { E(), H = R.normalize(H), $.readFile(H, function(Se, Qe) { - Se ? ce(Se) : ee(Qe.buffer); + Se ? ce(Se) : J(Qe.buffer); }); }, process.argv.length > 1 && (p = process.argv[1].replace(/\\/g, "/")), c = process.argv.slice(2), process.on("uncaughtException", function(H) { if (!(H instanceof Su)) throw H; }), process.on("unhandledRejection", function(H) { throw H; - }), d = (H, ee) => { + }), d = (H, J) => { if (gu()) - throw process.exitCode = H, ee; - I(ee), process.exit(H); + throw process.exitCode = H, J; + I(J), process.exit(H); }, a.inspect = function() { return "[Emscripten Module object]"; }) : (h || f) && (f ? g = self.location.href : typeof document != "undefined" && document.currentScript && (g = document.currentScript.src), s && (g = s), g.indexOf("blob:") !== 0 ? g = g.substr(0, g.replace(/[?#].*/, "").lastIndexOf("/") + 1) : g = "", y = (H) => { - var ee = new XMLHttpRequest(); - return ee.open("GET", H, false), ee.send(null), ee.responseText; + var J = new XMLHttpRequest(); + return J.open("GET", H, false), J.send(null), J.responseText; }, f && (x = (H) => { - var ee = new XMLHttpRequest(); - return ee.open("GET", H, false), ee.responseType = "arraybuffer", ee.send(null), new Uint8Array(ee.response); - }), v = (H, ee, ce) => { + var J = new XMLHttpRequest(); + return J.open("GET", H, false), J.responseType = "arraybuffer", J.send(null), new Uint8Array(J.response); + }), v = (H, J, ce) => { var Se = new XMLHttpRequest(); Se.open("GET", H, true), Se.responseType = "arraybuffer", Se.onload = () => { if (Se.status == 200 || Se.status == 0 && Se.response) { - ee(Se.response); + J(Se.response); return; } ce(); @@ -2637,22 +2637,22 @@ var b$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm.js"(e, t) { function T(H) { T.shown || (T.shown = {}), T.shown[H] || (T.shown[H] = 1, A(H)); } - function M(H, ee) { + function M(H, J) { if (typeof WebAssembly.Function == "function") { - for (var ce = { i: "i32", j: "i64", f: "f32", d: "f64" }, Se = { parameters: [], results: ee[0] == "v" ? [] : [ce[ee[0]]] }, Qe = 1; Qe < ee.length; ++Qe) - Se.parameters.push(ce[ee[Qe]]); + for (var ce = { i: "i32", j: "i64", f: "f32", d: "f64" }, Se = { parameters: [], results: J[0] == "v" ? [] : [ce[J[0]]] }, Qe = 1; Qe < J.length; ++Qe) + Se.parameters.push(ce[J[Qe]]); return new WebAssembly.Function(Se, H); } - var Ze = [1, 0, 1, 96], Le = ee.slice(0, 1), ze = ee.slice(1), Tt = { i: 127, j: 126, f: 125, d: 124 }; + var Ze = [1, 0, 1, 96], Be = J.slice(0, 1), ze = J.slice(1), Tt = { i: 127, j: 126, f: 125, d: 124 }; Ze.push(ze.length); for (var Qe = 0; Qe < ze.length; ++Qe) Ze.push(Tt[ze[Qe]]); - Le == "v" ? Ze.push(0) : Ze = Ze.concat([1, Tt[Le]]), Ze[1] = Ze.length - 2; + Be == "v" ? Ze.push(0) : Ze = Ze.concat([1, Tt[Be]]), Ze[1] = Ze.length - 2; var is = new Uint8Array([0, 97, 115, 109, 1, 0, 0, 0].concat(Ze, [2, 7, 1, 1, 101, 1, 102, 0, 0, 7, 5, 1, 1, 102, 0, 0])), os = new WebAssembly.Module(is), Fi = new WebAssembly.Instance(os, { e: { f: H } }), Wr = Fi.exports.f; return Wr; } var W = [], j; - function X() { + function Y() { if (W.length) return W.pop(); try { @@ -2662,40 +2662,40 @@ var b$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm.js"(e, t) { } return Zs.length - 1; } - function Y(H, ee) { - for (var ce = H; ce < H + ee; ce++) { + function X(H, J) { + for (var ce = H; ce < H + J; ce++) { var Se = vu(ce); Se && j.set(Se, ce); } } - var Z = 0, te = (H) => { + var Z = 0, ne = (H) => { Z = H; - }, J; - a.wasmBinary && (J = a.wasmBinary); + }, ee; + a.wasmBinary && (ee = a.wasmBinary); var se = a.noExitRuntime || true; typeof WebAssembly != "object" && zr("no native wasm support detected"); - var ne, oe = false, ae; - function de(H, ee) { - H || zr(ee); + var te, oe = false, ae; + function de(H, J) { + H || zr(J); } function me(H) { - var ee = a["_" + H]; - return ee; + var J = a["_" + H]; + return J; } - function ke(H, ee, ce, Se, Qe) { - var Ze = { string: function(an) { + function ke(H, J, ce, Se, Qe) { + var Ze = { string: function(rn) { var tr = 0; - if (an != null && an !== 0) { - var zc = (an.length << 2) + 1; - tr = ku(zc), tt(an, tr, zc); + if (rn != null && rn !== 0) { + var zc = (rn.length << 2) + 1; + tr = ku(zc), tt(rn, tr, zc); } return tr; - }, array: function(an) { - var tr = ku(an.length); - return at(an, tr), tr; + }, array: function(rn) { + var tr = ku(rn.length); + return at(rn, tr), tr; } }; - function Le(an) { - return ee === "string" ? Je(an) : ee === "boolean" ? Boolean(an) : an; + function Be(rn) { + return J === "string" ? Je(rn) : J === "boolean" ? Boolean(rn) : rn; } var ze = me(H), Tt = [], is = 0; if (Se) @@ -2704,106 +2704,106 @@ var b$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm.js"(e, t) { Fi ? (is === 0 && (is = Oc()), Tt[os] = Fi(Se[os])) : Tt[os] = Se[os]; } var Wr = ze.apply(null, Tt); - function Of(an) { - return is !== 0 && Pc(is), Le(an); + function Pf(rn) { + return is !== 0 && Pc(is), Be(rn); } - return Wr = Of(Wr), Wr; + return Wr = Pf(Wr), Wr; } - function Ie(H, ee, ce, Se) { + function Ie(H, J, ce, Se) { ce = ce || []; - var Qe = ce.every(function(Le) { - return Le === "number"; - }), Ze = ee !== "string"; + var Qe = ce.every(function(Be) { + return Be === "number"; + }), Ze = J !== "string"; return Ze && Qe && !Se ? me(H) : function() { - return ke(H, ee, ce, arguments, Se); + return ke(H, J, ce, arguments, Se); }; } var Re = 1, Pe = typeof TextDecoder != "undefined" ? new TextDecoder("utf8") : void 0; - function Xe(H, ee, ce) { - for (var Se = ee + ce, Qe = ee; H[Qe] && !(Qe >= Se); ) + function Xe(H, J, ce) { + for (var Se = J + ce, Qe = J; H[Qe] && !(Qe >= Se); ) ++Qe; - if (Qe - ee > 16 && H.subarray && Pe) - return Pe.decode(H.subarray(ee, Qe)); - for (var Ze = ""; ee < Qe; ) { - var Le = H[ee++]; - if (!(Le & 128)) { - Ze += String.fromCharCode(Le); + if (Qe - J > 16 && H.subarray && Pe) + return Pe.decode(H.subarray(J, Qe)); + for (var Ze = ""; J < Qe; ) { + var Be = H[J++]; + if (!(Be & 128)) { + Ze += String.fromCharCode(Be); continue; } - var ze = H[ee++] & 63; - if ((Le & 224) == 192) { - Ze += String.fromCharCode((Le & 31) << 6 | ze); + var ze = H[J++] & 63; + if ((Be & 224) == 192) { + Ze += String.fromCharCode((Be & 31) << 6 | ze); continue; } - var Tt = H[ee++] & 63; - if ((Le & 240) == 224 ? Le = (Le & 15) << 12 | ze << 6 | Tt : Le = (Le & 7) << 18 | ze << 12 | Tt << 6 | H[ee++] & 63, Le < 65536) - Ze += String.fromCharCode(Le); + var Tt = H[J++] & 63; + if ((Be & 240) == 224 ? Be = (Be & 15) << 12 | ze << 6 | Tt : Be = (Be & 7) << 18 | ze << 12 | Tt << 6 | H[J++] & 63, Be < 65536) + Ze += String.fromCharCode(Be); else { - var is = Le - 65536; + var is = Be - 65536; Ze += String.fromCharCode(55296 | is >> 10, 56320 | is & 1023); } } return Ze; } - function Je(H, ee) { - return H ? Xe(en, H, ee) : ""; + function Je(H, J) { + return H ? Xe(Jt, H, J) : ""; } - function Ye(H, ee, ce, Se) { + function Ye(H, J, ce, Se) { if (!(Se > 0)) return 0; - for (var Qe = ce, Ze = ce + Se - 1, Le = 0; Le < H.length; ++Le) { - var ze = H.charCodeAt(Le); + for (var Qe = ce, Ze = ce + Se - 1, Be = 0; Be < H.length; ++Be) { + var ze = H.charCodeAt(Be); if (ze >= 55296 && ze <= 57343) { - var Tt = H.charCodeAt(++Le); + var Tt = H.charCodeAt(++Be); ze = 65536 + ((ze & 1023) << 10) | Tt & 1023; } if (ze <= 127) { if (ce >= Ze) break; - ee[ce++] = ze; + J[ce++] = ze; } else if (ze <= 2047) { if (ce + 1 >= Ze) break; - ee[ce++] = 192 | ze >> 6, ee[ce++] = 128 | ze & 63; + J[ce++] = 192 | ze >> 6, J[ce++] = 128 | ze & 63; } else if (ze <= 65535) { if (ce + 2 >= Ze) break; - ee[ce++] = 224 | ze >> 12, ee[ce++] = 128 | ze >> 6 & 63, ee[ce++] = 128 | ze & 63; + J[ce++] = 224 | ze >> 12, J[ce++] = 128 | ze >> 6 & 63, J[ce++] = 128 | ze & 63; } else { if (ce + 3 >= Ze) break; - ee[ce++] = 240 | ze >> 18, ee[ce++] = 128 | ze >> 12 & 63, ee[ce++] = 128 | ze >> 6 & 63, ee[ce++] = 128 | ze & 63; + J[ce++] = 240 | ze >> 18, J[ce++] = 128 | ze >> 12 & 63, J[ce++] = 128 | ze >> 6 & 63, J[ce++] = 128 | ze & 63; } } - return ee[ce] = 0, ce - Qe; + return J[ce] = 0, ce - Qe; } - function tt(H, ee, ce) { - return Ye(H, en, ee, ce); + function tt(H, J, ce) { + return Ye(H, Jt, J, ce); } function Ce(H) { - for (var ee = 0, ce = 0; ce < H.length; ++ce) { + for (var J = 0, ce = 0; ce < H.length; ++ce) { var Se = H.charCodeAt(ce); - Se >= 55296 && Se <= 57343 && (Se = 65536 + ((Se & 1023) << 10) | H.charCodeAt(++ce) & 1023), Se <= 127 ? ++ee : Se <= 2047 ? ee += 2 : Se <= 65535 ? ee += 3 : ee += 4; + Se >= 55296 && Se <= 57343 && (Se = 65536 + ((Se & 1023) << 10) | H.charCodeAt(++ce) & 1023), Se <= 127 ? ++J : Se <= 2047 ? J += 2 : Se <= 65535 ? J += 3 : J += 4; } - return ee; + return J; } var ut = typeof TextDecoder != "undefined" ? new TextDecoder("utf-16le") : void 0; - function at(H, ee) { - Rt.set(H, ee); + function at(H, J) { + Et.set(H, J); } - function Jt(H, ee, ce) { + function Zt(H, J, ce) { for (var Se = 0; Se < H.length; ++Se) - Rt[ee++ >> 0] = H.charCodeAt(Se); - ce || (Rt[ee >> 0] = 0); + Et[J++ >> 0] = H.charCodeAt(Se); + ce || (Et[J >> 0] = 0); } - function Nt(H, ee) { - return H % ee > 0 && (H += ee - H % ee), H; + function Nt(H, J) { + return H % J > 0 && (H += J - H % J), H; } - var In, Rt, en, Cn, Nn, Yt, Dn, tn, zs; + var In, Et, Jt, Cn, Nn, Xt, Dn, en, zs; function Ms(H) { - In = H, a.HEAP8 = Rt = new Int8Array(H), a.HEAP16 = Cn = new Int16Array(H), a.HEAP32 = Yt = new Int32Array(H), a.HEAPU8 = en = new Uint8Array(H), a.HEAPU16 = Nn = new Uint16Array(H), a.HEAPU32 = Dn = new Uint32Array(H), a.HEAPF32 = tn = new Float32Array(H), a.HEAPF64 = zs = new Float64Array(H); + In = H, a.HEAP8 = Et = new Int8Array(H), a.HEAP16 = Cn = new Int16Array(H), a.HEAP32 = Xt = new Int32Array(H), a.HEAPU8 = Jt = new Uint8Array(H), a.HEAPU16 = Nn = new Uint16Array(H), a.HEAPU32 = Dn = new Uint32Array(H), a.HEAPF32 = en = new Float32Array(H), a.HEAPF64 = zs = new Float64Array(H); } - var Si = a.INITIAL_MEMORY || 16777216, Zs, Ls = [], mu = [], Ii = [], nn = false, lc = false, cc = 0; + var Si = a.INITIAL_MEMORY || 16777216, Zs, Ls = [], mu = [], Ii = [], tn = false, lc = false, cc = 0; function gu() { return se || cc > 0; } @@ -2814,9 +2814,9 @@ var b$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm.js"(e, t) { yu(Ls); } function pc() { - nn = true, yu(mu); + tn = true, yu(mu); } - function Vv() { + function Wv() { lc = true; } function hc() { @@ -2835,84 +2835,84 @@ var b$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm.js"(e, t) { Ii.unshift(H); } var Fn = 0, Ci = null, Js = null; - function lh(H) { + function ch(H) { Fn++, a.monitorRunDependencies && a.monitorRunDependencies(Fn); } function gc(H) { if (Fn--, a.monitorRunDependencies && a.monitorRunDependencies(Fn), Fn == 0 && (Ci !== null && (clearInterval(Ci), Ci = null), Js)) { - var ee = Js; - Js = null, ee(); + var J = Js; + Js = null, J(); } } a.preloadedImages = {}, a.preloadedAudios = {}; function zr(H) { a.onAbort && a.onAbort(H), H = "Aborted(" + H + ")", A(H), oe = true, ae = 1, H += ". Build with -s ASSERTIONS=1 for more info."; - var ee = new WebAssembly.RuntimeError(H); - throw o(ee), ee; + var J = new WebAssembly.RuntimeError(H); + throw o(J), J; } - var ch = "data:application/octet-stream;base64,"; + var dh = "data:application/octet-stream;base64,"; function bc(H) { - return H.startsWith(ch); + return H.startsWith(dh); } function Mr(H) { return H.startsWith("file://"); } - var sn; - sn = "tfjs-backend-wasm.wasm", bc(sn) || (sn = b(sn)); + var nn; + nn = "tfjs-backend-wasm.wasm", bc(nn) || (nn = b(nn)); function bu(H) { try { - if (H == sn && J) - return new Uint8Array(J); + if (H == nn && ee) + return new Uint8Array(ee); if (x) return x(H); throw "both async and sync fetching of the wasm failed"; - } catch (ee) { - zr(ee); + } catch (J) { + zr(J); } } - function dh() { - if (!J && (h || f)) { - if (typeof fetch == "function" && !Mr(sn)) - return fetch(sn, { credentials: "same-origin" }).then(function(H) { + function ph() { + if (!ee && (h || f)) { + if (typeof fetch == "function" && !Mr(nn)) + return fetch(nn, { credentials: "same-origin" }).then(function(H) { if (!H.ok) - throw "failed to load wasm binary file at '" + sn + "'"; + throw "failed to load wasm binary file at '" + nn + "'"; return H.arrayBuffer(); }).catch(function() { - return bu(sn); + return bu(nn); }); if (v) - return new Promise(function(H, ee) { - v(sn, function(ce) { + return new Promise(function(H, J) { + v(nn, function(ce) { H(new Uint8Array(ce)); - }, ee); + }, J); }); } return Promise.resolve().then(function() { - return bu(sn); + return bu(nn); }); } - function ph() { + function hh() { var H = { env: $i, wasi_snapshot_preview1: $i }; - function ee(Le, ze) { - var Tt = Le.exports; - a.asm = Tt, ne = a.asm.memory, Ms(ne.buffer), Zs = a.asm.__indirect_function_table, rs(a.asm.__wasm_call_ctors), gc("wasm-instantiate"); + function J(Be, ze) { + var Tt = Be.exports; + a.asm = Tt, te = a.asm.memory, Ms(te.buffer), Zs = a.asm.__indirect_function_table, rs(a.asm.__wasm_call_ctors), gc("wasm-instantiate"); } - lh("wasm-instantiate"); - function ce(Le) { - ee(Le.instance); + ch("wasm-instantiate"); + function ce(Be) { + J(Be.instance); } - function Se(Le) { - return dh().then(function(ze) { + function Se(Be) { + return ph().then(function(ze) { return WebAssembly.instantiate(ze, H); }).then(function(ze) { return ze; - }).then(Le, function(ze) { + }).then(Be, function(ze) { A("failed to asynchronously prepare wasm: " + ze), zr(ze); }); } function Qe() { - return !J && typeof WebAssembly.instantiateStreaming == "function" && !bc(sn) && !Mr(sn) && typeof fetch == "function" ? fetch(sn, { credentials: "same-origin" }).then(function(Le) { - var ze = WebAssembly.instantiateStreaming(Le, H); + return !ee && typeof WebAssembly.instantiateStreaming == "function" && !bc(nn) && !Mr(nn) && typeof fetch == "function" ? fetch(nn, { credentials: "same-origin" }).then(function(Be) { + var ze = WebAssembly.instantiateStreaming(Be, H); return ze.then(ce, function(Tt) { return A("wasm streaming compile failed: " + Tt), A("falling back to ArrayBuffer instantiation"), Se(ce); }); @@ -2920,229 +2920,229 @@ var b$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm.js"(e, t) { } if (a.instantiateWasm) try { - var Ze = a.instantiateWasm(H, ee); + var Ze = a.instantiateWasm(H, J); return Ze; - } catch (Le) { - return A("Module.instantiateWasm callback failed with error: " + Le), false; + } catch (Be) { + return A("Module.instantiateWasm callback failed with error: " + Be), false; } return Qe().catch(o), {}; } - var Wv, Uv; + var Uv, Gv; function yu(H) { for (; H.length > 0; ) { - var ee = H.shift(); - if (typeof ee == "function") { - ee(a); + var J = H.shift(); + if (typeof J == "function") { + J(a); continue; } - var ce = ee.func; - typeof ce == "number" ? ee.arg === void 0 ? vu(ce)() : vu(ce)(ee.arg) : ce(ee.arg === void 0 ? null : ee.arg); + var ce = J.func; + typeof ce == "number" ? J.arg === void 0 ? vu(ce)() : vu(ce)(J.arg) : ce(J.arg === void 0 ? null : J.arg); } } function er(H) { return H; } function yc(H) { - var ee = /\b_Z[\w\d_]+/g; - return H.replace(ee, function(ce) { + var J = /\b_Z[\w\d_]+/g; + return H.replace(J, function(ce) { var Se = ce; return ce === Se ? ce : Se + " [" + ce + "]"; }); } var as = []; function vu(H) { - var ee = as[H]; - return ee || (H >= as.length && (as.length = H + 1), as[H] = ee = Zs.get(H)), ee; + var J = as[H]; + return J || (H >= as.length && (as.length = H + 1), as[H] = J = Zs.get(H)), J; } - function Gv() { + function Hv() { var H = new Error(); if (!H.stack) { try { throw new Error(); - } catch (ee) { - H = ee; + } catch (J) { + H = J; } if (!H.stack) return "(no stack trace available)"; } return H.stack.toString(); } - function Ni(H, ee) { - Zs.set(H, ee), as[H] = ee; + function Ni(H, J) { + Zs.set(H, J), as[H] = J; } - function hh() { + function fh() { zr(""); } - function vc(H, ee, ce) { - en.copyWithin(H, ee, ee + ce); + function vc(H, J, ce) { + Jt.copyWithin(H, J, J + ce); } function xc() { return 2147483648; } - function rn(H) { + function sn(H) { try { - return ne.grow(H - In.byteLength + 65535 >>> 16), Ms(ne.buffer), 1; - } catch (ee) { + return te.grow(H - In.byteLength + 65535 >>> 16), Ms(te.buffer), 1; + } catch (J) { } } function wc(H) { - var ee = en.length; + var J = Jt.length; H = H >>> 0; var ce = xc(); if (H > ce) return false; for (var Se = 1; Se <= 4; Se *= 2) { - var Qe = ee * (1 + 0.2 / Se); + var Qe = J * (1 + 0.2 / Se); Qe = Math.min(Qe, H + 100663296); - var Ze = Math.min(ce, Nt(Math.max(H, Qe), 65536)), Le = rn(Ze); - if (Le) + var Ze = Math.min(ce, Nt(Math.max(H, Qe), 65536)), Be = sn(Ze); + if (Be) return true; } return false; } - var Ti = { mappings: {}, buffers: [null, [], []], printChar: function(H, ee) { + var Ti = { mappings: {}, buffers: [null, [], []], printChar: function(H, J) { var ce = Ti.buffers[H]; - ee === 0 || ee === 10 ? ((H === 1 ? P : A)(Xe(ce, 0)), ce.length = 0) : ce.push(ee); + J === 0 || J === 10 ? ((H === 1 ? P : A)(Xe(ce, 0)), ce.length = 0) : ce.push(J); }, varargs: void 0, get: function() { Ti.varargs += 4; - var H = Yt[Ti.varargs - 4 >> 2]; + var H = Xt[Ti.varargs - 4 >> 2]; return H; }, getStr: function(H) { - var ee = Je(H); - return ee; - }, get64: function(H, ee) { + var J = Je(H); + return J; + }, get64: function(H, J) { return H; } }; - function fh(H) { + function mh(H) { return 0; } - function Hv(H, ee, ce, Se, Qe) { + function qv(H, J, ce, Se, Qe) { } - function qv(H, ee, ce, Se) { + function jv(H, J, ce, Se) { for (var Qe = 0, Ze = 0; Ze < ce; Ze++) { - var Le = Yt[ee >> 2], ze = Yt[ee + 4 >> 2]; - ee += 8; + var Be = Xt[J >> 2], ze = Xt[J + 4 >> 2]; + J += 8; for (var Tt = 0; Tt < ze; Tt++) - Ti.printChar(H, en[Le + Tt]); + Ti.printChar(H, Jt[Be + Tt]); Qe += ze; } - return Yt[Se >> 2] = Qe, 0; + return Xt[Se >> 2] = Qe, 0; } - function mh(H) { - te(H); + function gh(H) { + ne(H); } - var kc = false, $i = { abort: hh, emscripten_memcpy_big: vc, emscripten_resize_heap: wc, fd_close: fh, fd_seek: Hv, fd_write: qv, setTempRet0: mh }, sT = ph(), jv = a.___wasm_call_ctors = function() { - return (jv = a.___wasm_call_ctors = a.asm.__wasm_call_ctors).apply(null, arguments); - }, gh = a._init = function() { - return (gh = a._init = a.asm.init).apply(null, arguments); - }, bh = a._init_with_threads_count = function() { - return (bh = a._init_with_threads_count = a.asm.init_with_threads_count).apply(null, arguments); + var kc = false, $i = { abort: fh, emscripten_memcpy_big: vc, emscripten_resize_heap: wc, fd_close: mh, fd_seek: qv, fd_write: jv, setTempRet0: gh }, aT = hh(), Kv = a.___wasm_call_ctors = function() { + return (Kv = a.___wasm_call_ctors = a.asm.__wasm_call_ctors).apply(null, arguments); + }, bh = a._init = function() { + return (bh = a._init = a.asm.init).apply(null, arguments); + }, yh = a._init_with_threads_count = function() { + return (yh = a._init_with_threads_count = a.asm.init_with_threads_count).apply(null, arguments); }, Sc = a._get_threads_count = function() { return (Sc = a._get_threads_count = a.asm.get_threads_count).apply(null, arguments); }, Ic = a._register_tensor = function() { return (Ic = a._register_tensor = a.asm.register_tensor).apply(null, arguments); - }, yh = a._dispose_data = function() { - return (yh = a._dispose_data = a.asm.dispose_data).apply(null, arguments); + }, vh = a._dispose_data = function() { + return (vh = a._dispose_data = a.asm.dispose_data).apply(null, arguments); }, $e = a._dispose = function() { return ($e = a._dispose = a.asm.dispose).apply(null, arguments); - }, vh = a._Abs = function() { - return (vh = a._Abs = a.asm.Abs).apply(null, arguments); + }, xh = a._Abs = function() { + return (xh = a._Abs = a.asm.Abs).apply(null, arguments); }, Cc = a._Add = function() { return (Cc = a._Add = a.asm.Add).apply(null, arguments); }, Lr = a._AddN = function() { return (Lr = a._AddN = a.asm.AddN).apply(null, arguments); }, _i = a._All = function() { return (_i = a._All = a.asm.All).apply(null, arguments); - }, xh = a._Any = function() { - return (xh = a._Any = a.asm.Any).apply(null, arguments); - }, Kv = a._ArgMax = function() { - return (Kv = a._ArgMax = a.asm.ArgMax).apply(null, arguments); - }, wh = a._AvgPool = function() { - return (wh = a._AvgPool = a.asm.AvgPool).apply(null, arguments); - }, Xv = a._BatchMatMul = function() { - return (Xv = a._BatchMatMul = a.asm.BatchMatMul).apply(null, arguments); + }, wh = a._Any = function() { + return (wh = a._Any = a.asm.Any).apply(null, arguments); + }, Xv = a._ArgMax = function() { + return (Xv = a._ArgMax = a.asm.ArgMax).apply(null, arguments); + }, kh = a._AvgPool = function() { + return (kh = a._AvgPool = a.asm.AvgPool).apply(null, arguments); + }, Yv = a._BatchMatMul = function() { + return (Yv = a._BatchMatMul = a.asm.BatchMatMul).apply(null, arguments); }, Br = a._Ceil = function() { return (Br = a._Ceil = a.asm.Ceil).apply(null, arguments); - }, kh = a._ClipByValue = function() { - return (kh = a._ClipByValue = a.asm.ClipByValue).apply(null, arguments); - }, Sh = a._Conv2D = function() { - return (Sh = a._Conv2D = a.asm.Conv2D).apply(null, arguments); - }, Ih = a._Conv2DBackpropInput = function() { - return (Ih = a._Conv2DBackpropInput = a.asm.Conv2DBackpropInput).apply(null, arguments); - }, Ch = a._Cos = function() { - return (Ch = a._Cos = a.asm.Cos).apply(null, arguments); - }, Nh = a._Cosh = function() { - return (Nh = a._Cosh = a.asm.Cosh).apply(null, arguments); - }, Th = a._CropAndResize = function() { - return (Th = a._CropAndResize = a.asm.CropAndResize).apply(null, arguments); + }, Sh = a._ClipByValue = function() { + return (Sh = a._ClipByValue = a.asm.ClipByValue).apply(null, arguments); + }, Ih = a._Conv2D = function() { + return (Ih = a._Conv2D = a.asm.Conv2D).apply(null, arguments); + }, Ch = a._Conv2DBackpropInput = function() { + return (Ch = a._Conv2DBackpropInput = a.asm.Conv2DBackpropInput).apply(null, arguments); + }, Nh = a._Cos = function() { + return (Nh = a._Cos = a.asm.Cos).apply(null, arguments); + }, Th = a._Cosh = function() { + return (Th = a._Cosh = a.asm.Cosh).apply(null, arguments); + }, $h = a._CropAndResize = function() { + return ($h = a._CropAndResize = a.asm.CropAndResize).apply(null, arguments); }, Nc = a._Cumprod = function() { return (Nc = a._Cumprod = a.asm.Cumprod).apply(null, arguments); - }, $h = a._Cumsum = function() { - return ($h = a._Cumsum = a.asm.Cumsum).apply(null, arguments); - }, _h = a._DepthToSpace = function() { - return (_h = a._DepthToSpace = a.asm.DepthToSpace).apply(null, arguments); - }, Ah = a._DepthwiseConv2dNative = function() { - return (Ah = a._DepthwiseConv2dNative = a.asm.DepthwiseConv2dNative).apply(null, arguments); - }, Eh = a._Elu = function() { - return (Eh = a._Elu = a.asm.Elu).apply(null, arguments); - }, Rh = a._Equal = function() { - return (Rh = a._Equal = a.asm.Equal).apply(null, arguments); + }, _h = a._Cumsum = function() { + return (_h = a._Cumsum = a.asm.Cumsum).apply(null, arguments); + }, Ah = a._DepthToSpace = function() { + return (Ah = a._DepthToSpace = a.asm.DepthToSpace).apply(null, arguments); + }, Eh = a._DepthwiseConv2dNative = function() { + return (Eh = a._DepthwiseConv2dNative = a.asm.DepthwiseConv2dNative).apply(null, arguments); + }, Rh = a._Elu = function() { + return (Rh = a._Elu = a.asm.Elu).apply(null, arguments); + }, Dh = a._Equal = function() { + return (Dh = a._Equal = a.asm.Equal).apply(null, arguments); }, Tc = a._Exp = function() { return (Tc = a._Exp = a.asm.Exp).apply(null, arguments); - }, Dh = a._FlipLeftRight = function() { - return (Dh = a._FlipLeftRight = a.asm.FlipLeftRight).apply(null, arguments); - }, Fh = a._Floor = function() { - return (Fh = a._Floor = a.asm.Floor).apply(null, arguments); + }, Fh = a._FlipLeftRight = function() { + return (Fh = a._FlipLeftRight = a.asm.FlipLeftRight).apply(null, arguments); + }, Oh = a._Floor = function() { + return (Oh = a._Floor = a.asm.Floor).apply(null, arguments); }, Vr = a._FloorDiv = function() { return (Vr = a._FloorDiv = a.asm.FloorDiv).apply(null, arguments); }, xu = a._FusedBatchNorm = function() { return (xu = a._FusedBatchNorm = a.asm.FusedBatchNorm).apply(null, arguments); - }, Oh = a._FusedConv2D = function() { - return (Oh = a._FusedConv2D = a.asm.FusedConv2D).apply(null, arguments); - }, Ph = a._FusedDepthwiseConv2D = function() { - return (Ph = a._FusedDepthwiseConv2D = a.asm.FusedDepthwiseConv2D).apply(null, arguments); - }, zh = a._Gather = function() { - return (zh = a._Gather = a.asm.Gather).apply(null, arguments); - }, Me = a._GatherNd = function() { - return (Me = a._GatherNd = a.asm.GatherNd).apply(null, arguments); - }, Mh = a._Greater = function() { - return (Mh = a._Greater = a.asm.Greater).apply(null, arguments); - }, Lh = a._GreaterEqual = function() { - return (Lh = a._GreaterEqual = a.asm.GreaterEqual).apply(null, arguments); - }, Bh = a._LeakyRelu = function() { - return (Bh = a._LeakyRelu = a.asm.LeakyRelu).apply(null, arguments); - }, Vh = a._Less = function() { - return (Vh = a._Less = a.asm.Less).apply(null, arguments); - }, Wh = a._LessEqual = function() { - return (Wh = a._LessEqual = a.asm.LessEqual).apply(null, arguments); - }, Uh = a._Log = function() { - return (Uh = a._Log = a.asm.Log).apply(null, arguments); + }, Ph = a._FusedConv2D = function() { + return (Ph = a._FusedConv2D = a.asm.FusedConv2D).apply(null, arguments); + }, zh = a._FusedDepthwiseConv2D = function() { + return (zh = a._FusedDepthwiseConv2D = a.asm.FusedDepthwiseConv2D).apply(null, arguments); + }, Mh = a._Gather = function() { + return (Mh = a._Gather = a.asm.Gather).apply(null, arguments); + }, Le = a._GatherNd = function() { + return (Le = a._GatherNd = a.asm.GatherNd).apply(null, arguments); + }, Lh = a._Greater = function() { + return (Lh = a._Greater = a.asm.Greater).apply(null, arguments); + }, Bh = a._GreaterEqual = function() { + return (Bh = a._GreaterEqual = a.asm.GreaterEqual).apply(null, arguments); + }, Vh = a._LeakyRelu = function() { + return (Vh = a._LeakyRelu = a.asm.LeakyRelu).apply(null, arguments); + }, Wh = a._Less = function() { + return (Wh = a._Less = a.asm.Less).apply(null, arguments); + }, Uh = a._LessEqual = function() { + return (Uh = a._LessEqual = a.asm.LessEqual).apply(null, arguments); + }, Gh = a._Log = function() { + return (Gh = a._Log = a.asm.Log).apply(null, arguments); }, wu = a._LogicalAnd = function() { return (wu = a._LogicalAnd = a.asm.LogicalAnd).apply(null, arguments); }, $c = a._Max = function() { return ($c = a._Max = a.asm.Max).apply(null, arguments); }, _c = a._MaxPool = function() { return (_c = a._MaxPool = a.asm.MaxPool).apply(null, arguments); - }, Gh = a._Maximum = function() { - return (Gh = a._Maximum = a.asm.Maximum).apply(null, arguments); - }, Hh = a._Mean = function() { - return (Hh = a._Mean = a.asm.Mean).apply(null, arguments); - }, qh = a._Min = function() { - return (qh = a._Min = a.asm.Min).apply(null, arguments); - }, jh = a._Minimum = function() { - return (jh = a._Minimum = a.asm.Minimum).apply(null, arguments); - }, Kh = a._MirrorPad = function() { - return (Kh = a._MirrorPad = a.asm.MirrorPad).apply(null, arguments); - }, Xh = a._Multiply = function() { - return (Xh = a._Multiply = a.asm.Multiply).apply(null, arguments); + }, Hh = a._Maximum = function() { + return (Hh = a._Maximum = a.asm.Maximum).apply(null, arguments); + }, qh = a._Mean = function() { + return (qh = a._Mean = a.asm.Mean).apply(null, arguments); + }, jh = a._Min = function() { + return (jh = a._Min = a.asm.Min).apply(null, arguments); + }, Kh = a._Minimum = function() { + return (Kh = a._Minimum = a.asm.Minimum).apply(null, arguments); + }, Xh = a._MirrorPad = function() { + return (Xh = a._MirrorPad = a.asm.MirrorPad).apply(null, arguments); + }, Yh = a._Multiply = function() { + return (Yh = a._Multiply = a.asm.Multiply).apply(null, arguments); }, gt = a._Neg = function() { return (gt = a._Neg = a.asm.Neg).apply(null, arguments); - }, Yh = a._NonMaxSuppressionV3 = function() { - return (Yh = a._NonMaxSuppressionV3 = a.asm.NonMaxSuppressionV3).apply(null, arguments); - }, Qh = a._NonMaxSuppressionV4 = function() { - return (Qh = a._NonMaxSuppressionV4 = a.asm.NonMaxSuppressionV4).apply(null, arguments); - }, Zh = a._NonMaxSuppressionV5 = function() { - return (Zh = a._NonMaxSuppressionV5 = a.asm.NonMaxSuppressionV5).apply(null, arguments); + }, Qh = a._NonMaxSuppressionV3 = function() { + return (Qh = a._NonMaxSuppressionV3 = a.asm.NonMaxSuppressionV3).apply(null, arguments); + }, Zh = a._NonMaxSuppressionV4 = function() { + return (Zh = a._NonMaxSuppressionV4 = a.asm.NonMaxSuppressionV4).apply(null, arguments); + }, Jh = a._NonMaxSuppressionV5 = function() { + return (Jh = a._NonMaxSuppressionV5 = a.asm.NonMaxSuppressionV5).apply(null, arguments); }, Ai = a._NotEqual = function() { return (Ai = a._NotEqual = a.asm.NotEqual).apply(null, arguments); }, Ac = a._OneHot = function() { @@ -3151,88 +3151,88 @@ var b$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm.js"(e, t) { return (Ec = a._PadV2 = a.asm.PadV2).apply(null, arguments); }, Rc = a._Pow = function() { return (Rc = a._Pow = a.asm.Pow).apply(null, arguments); - }, Jh = a._Prelu = function() { - return (Jh = a._Prelu = a.asm.Prelu).apply(null, arguments); + }, ef = a._Prelu = function() { + return (ef = a._Prelu = a.asm.Prelu).apply(null, arguments); }, Dc = a._Prod = function() { return (Dc = a._Prod = a.asm.Prod).apply(null, arguments); - }, ef = a._RealDiv = function() { - return (ef = a._RealDiv = a.asm.RealDiv).apply(null, arguments); - }, Yv = a._Relu = function() { - return (Yv = a._Relu = a.asm.Relu).apply(null, arguments); + }, tf = a._RealDiv = function() { + return (tf = a._RealDiv = a.asm.RealDiv).apply(null, arguments); + }, Qv = a._Relu = function() { + return (Qv = a._Relu = a.asm.Relu).apply(null, arguments); }, Fc = a._Relu6 = function() { return (Fc = a._Relu6 = a.asm.Relu6).apply(null, arguments); - }, Qv = a._ResizeBilinear = function() { - return (Qv = a._ResizeBilinear = a.asm.ResizeBilinear).apply(null, arguments); - }, tf = a._Reverse = function() { - return (tf = a._Reverse = a.asm.Reverse).apply(null, arguments); - }, nf = a._RotateWithOffset = function() { - return (nf = a._RotateWithOffset = a.asm.RotateWithOffset).apply(null, arguments); - }, sf = a._Round = function() { - return (sf = a._Round = a.asm.Round).apply(null, arguments); - }, rf = a._Rsqrt = function() { - return (rf = a._Rsqrt = a.asm.Rsqrt).apply(null, arguments); - }, af = a._ScatterNd = function() { - return (af = a._ScatterNd = a.asm.ScatterNd).apply(null, arguments); - }, of = a._SelectV2 = function() { - return (of = a._SelectV2 = a.asm.SelectV2).apply(null, arguments); - }, uf = a._Sigmoid = function() { - return (uf = a._Sigmoid = a.asm.Sigmoid).apply(null, arguments); - }, lf = a._Sin = function() { - return (lf = a._Sin = a.asm.Sin).apply(null, arguments); - }, cf = a._Softmax = function() { - return (cf = a._Softmax = a.asm.Softmax).apply(null, arguments); - }, df = a._SparseFillEmptyRows = function() { - return (df = a._SparseFillEmptyRows = a.asm.SparseFillEmptyRows).apply(null, arguments); - }, pf = a._SparseReshape = function() { - return (pf = a._SparseReshape = a.asm.SparseReshape).apply(null, arguments); - }, hf = a._SparseSegmentReduction = function() { - return (hf = a._SparseSegmentReduction = a.asm.SparseSegmentReduction).apply(null, arguments); - }, ff = a._Sqrt = function() { - return (ff = a._Sqrt = a.asm.Sqrt).apply(null, arguments); - }, mf = a._Square = function() { - return (mf = a._Square = a.asm.Square).apply(null, arguments); - }, gf = a._SquaredDifference = function() { - return (gf = a._SquaredDifference = a.asm.SquaredDifference).apply(null, arguments); - }, bf = a._Step = function() { - return (bf = a._Step = a.asm.Step).apply(null, arguments); - }, yf = a._StridedSlice = function() { - return (yf = a._StridedSlice = a.asm.StridedSlice).apply(null, arguments); - }, vf = a._Sub = function() { - return (vf = a._Sub = a.asm.Sub).apply(null, arguments); - }, xf = a._Sum = function() { - return (xf = a._Sum = a.asm.Sum).apply(null, arguments); - }, wf = a._Tan = function() { - return (wf = a._Tan = a.asm.Tan).apply(null, arguments); - }, kf = a._Tanh = function() { - return (kf = a._Tanh = a.asm.Tanh).apply(null, arguments); - }, Sf = a._Tile = function() { - return (Sf = a._Tile = a.asm.Tile).apply(null, arguments); - }, If = a._TopK = function() { - return (If = a._TopK = a.asm.TopK).apply(null, arguments); - }, Cf = a._Transform = function() { - return (Cf = a._Transform = a.asm.Transform).apply(null, arguments); - }, Nf = a._Transpose = function() { - return (Nf = a._Transpose = a.asm.Transpose).apply(null, arguments); - }, Tf = a.__FusedMatMul = function() { - return (Tf = a.__FusedMatMul = a.asm._FusedMatMul).apply(null, arguments); - }, $f = a._malloc = function() { - return ($f = a._malloc = a.asm.malloc).apply(null, arguments); - }, _f = a._free = function() { - return (_f = a._free = a.asm.free).apply(null, arguments); - }, Af = a.___errno_location = function() { - return (Af = a.___errno_location = a.asm.__errno_location).apply(null, arguments); - }, Ef = a._emscripten_main_thread_process_queued_calls = function() { - return (Ef = a._emscripten_main_thread_process_queued_calls = a.asm.emscripten_main_thread_process_queued_calls).apply(null, arguments); + }, Zv = a._ResizeBilinear = function() { + return (Zv = a._ResizeBilinear = a.asm.ResizeBilinear).apply(null, arguments); + }, nf = a._Reverse = function() { + return (nf = a._Reverse = a.asm.Reverse).apply(null, arguments); + }, sf = a._RotateWithOffset = function() { + return (sf = a._RotateWithOffset = a.asm.RotateWithOffset).apply(null, arguments); + }, rf = a._Round = function() { + return (rf = a._Round = a.asm.Round).apply(null, arguments); + }, af = a._Rsqrt = function() { + return (af = a._Rsqrt = a.asm.Rsqrt).apply(null, arguments); + }, of = a._ScatterNd = function() { + return (of = a._ScatterNd = a.asm.ScatterNd).apply(null, arguments); + }, uf = a._SelectV2 = function() { + return (uf = a._SelectV2 = a.asm.SelectV2).apply(null, arguments); + }, lf = a._Sigmoid = function() { + return (lf = a._Sigmoid = a.asm.Sigmoid).apply(null, arguments); + }, cf = a._Sin = function() { + return (cf = a._Sin = a.asm.Sin).apply(null, arguments); + }, df = a._Softmax = function() { + return (df = a._Softmax = a.asm.Softmax).apply(null, arguments); + }, pf = a._SparseFillEmptyRows = function() { + return (pf = a._SparseFillEmptyRows = a.asm.SparseFillEmptyRows).apply(null, arguments); + }, hf = a._SparseReshape = function() { + return (hf = a._SparseReshape = a.asm.SparseReshape).apply(null, arguments); + }, ff = a._SparseSegmentReduction = function() { + return (ff = a._SparseSegmentReduction = a.asm.SparseSegmentReduction).apply(null, arguments); + }, mf = a._Sqrt = function() { + return (mf = a._Sqrt = a.asm.Sqrt).apply(null, arguments); + }, gf = a._Square = function() { + return (gf = a._Square = a.asm.Square).apply(null, arguments); + }, bf = a._SquaredDifference = function() { + return (bf = a._SquaredDifference = a.asm.SquaredDifference).apply(null, arguments); + }, yf = a._Step = function() { + return (yf = a._Step = a.asm.Step).apply(null, arguments); + }, vf = a._StridedSlice = function() { + return (vf = a._StridedSlice = a.asm.StridedSlice).apply(null, arguments); + }, xf = a._Sub = function() { + return (xf = a._Sub = a.asm.Sub).apply(null, arguments); + }, wf = a._Sum = function() { + return (wf = a._Sum = a.asm.Sum).apply(null, arguments); + }, kf = a._Tan = function() { + return (kf = a._Tan = a.asm.Tan).apply(null, arguments); + }, Sf = a._Tanh = function() { + return (Sf = a._Tanh = a.asm.Tanh).apply(null, arguments); + }, If = a._Tile = function() { + return (If = a._Tile = a.asm.Tile).apply(null, arguments); + }, Cf = a._TopK = function() { + return (Cf = a._TopK = a.asm.TopK).apply(null, arguments); + }, Nf = a._Transform = function() { + return (Nf = a._Transform = a.asm.Transform).apply(null, arguments); + }, Tf = a._Transpose = function() { + return (Tf = a._Transpose = a.asm.Transpose).apply(null, arguments); + }, $f = a.__FusedMatMul = function() { + return ($f = a.__FusedMatMul = a.asm._FusedMatMul).apply(null, arguments); + }, _f = a._malloc = function() { + return (_f = a._malloc = a.asm.malloc).apply(null, arguments); + }, Af = a._free = function() { + return (Af = a._free = a.asm.free).apply(null, arguments); + }, Ef = a.___errno_location = function() { + return (Ef = a.___errno_location = a.asm.__errno_location).apply(null, arguments); + }, Rf = a._emscripten_main_thread_process_queued_calls = function() { + return (Rf = a._emscripten_main_thread_process_queued_calls = a.asm.emscripten_main_thread_process_queued_calls).apply(null, arguments); }, Oc = a.stackSave = function() { return (Oc = a.stackSave = a.asm.stackSave).apply(null, arguments); }, Pc = a.stackRestore = function() { return (Pc = a.stackRestore = a.asm.stackRestore).apply(null, arguments); }, ku = a.stackAlloc = function() { return (ku = a.stackAlloc = a.asm.stackAlloc).apply(null, arguments); - }, Rf = a.dynCall_iijjiiii = function() { - return (Rf = a.dynCall_iijjiiii = a.asm.dynCall_iijjiiii).apply(null, arguments); - }, Df = a.dynCall_jiji = function() { - return (Df = a.dynCall_jiji = a.asm.dynCall_jiji).apply(null, arguments); + }, Df = a.dynCall_iijjiiii = function() { + return (Df = a.dynCall_iijjiiii = a.asm.dynCall_iijjiiii).apply(null, arguments); + }, Ff = a.dynCall_jiji = function() { + return (Ff = a.dynCall_jiji = a.asm.dynCall_jiji).apply(null, arguments); }; a.cwrap = Ie; var Ei; @@ -3245,17 +3245,17 @@ var b$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm.js"(e, t) { function Iu(H) { if (H = H || c, Fn > 0 || (dc(), Fn > 0)) return; - function ee() { + function J() { Ei || (Ei = true, a.calledRun = true, !oe && (pc(), i(a), a.onRuntimeInitialized && a.onRuntimeInitialized(), hc())); } a.setStatus ? (a.setStatus("Running..."), setTimeout(function() { setTimeout(function() { a.setStatus(""); - }, 1), ee(); - }, 1)) : ee(); + }, 1), J(); + }, 1)) : J(); } a.run = Iu; - function Zv(H) { + function Jv(H) { ae = H, gu() || (a.onExit && a.onExit(H), oe = true), d(H, new Su(H)); } if (a.preInit) @@ -3276,9 +3276,9 @@ var b$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm.js"(e, t) { else throw new Error("Could not find wasm module in post.js"); if (Ri) { - var Ff = Di._dispose; + var Of = Di._dispose; Di._dispose = function() { - Ff(), Ri.uncaughtException.forEach(function(H) { + Of(), Ri.uncaughtException.forEach(function(H) { process.removeListener("uncaughtException", H); }), Ri.unhandledRejection.forEach(function(H) { process.removeListener("unhandledRejection", H); @@ -3292,9 +3292,9 @@ var b$ = Mt({ "src/tfjs-backend-wasm/wasm-out/tfjs-backend-wasm.js"(e, t) { return n; }) : typeof e == "object" && (e.WasmBackendModule = n); } }); -var y$ = 1e-7; -var v$ = 1e-4; -var Yd = class { +var x$ = 1e-7; +var w$ = 1e-4; +var Qd = class { constructor(e, t) { this.backend = e, this.dataMover = t, this.data = /* @__PURE__ */ new WeakMap(), this.dataIdsCount = 0; } @@ -3355,7 +3355,7 @@ var ol = class { return On("floatPrecision"); } epsilon() { - return this.floatPrecision() === 32 ? y$ : v$; + return this.floatPrecision() === 32 ? x$ : w$; } dispose() { return On("dispose"); @@ -3364,12 +3364,12 @@ var ol = class { function On(e) { throw new Error(`'${e}' not yet implemented or not found in the registry. This kernel may not be supported by the tfjs backend you have chosen`); } -function Jw(e) { +function tk(e) { let t = e.length, n = 0; for (; t > 0; ) n = Math.random() * t | 0, t--, bd(e, t, n); } -function x$(e, t) { +function k$(e, t) { if (e.length !== t.length) throw new Error(`Array sizes must match to be shuffled together First array length was ${e.length}Second array length was ${t.length}`); let n = e.length, s = 0; @@ -3379,24 +3379,24 @@ function x$(e, t) { function Gu(e, t, n) { return Math.max(e, Math.min(t, n)); } -function w$(e) { +function S$(e) { return e % 2 === 0 ? e : e + 1; } function bd(e, t, n) { let s = e[t]; e[t] = e[n], e[n] = s; } -function k$(e) { +function I$(e) { let t = 0; for (let n = 0; n < e.length; n++) t += e[n]; return t; } -function S$(e, t) { +function C$(e, t) { let n = Math.random(); return t * n + (1 - n) * e; } -function I$(e, t) { +function N$(e, t) { let n = 0; for (let s = 0; s < e.length; s++) { let r = Number(e[s]) - Number(t[s]); @@ -3415,7 +3415,7 @@ function ka(e) { F(e != null, () => "The input to the tensor constructor must be a non-null value."); } function aa(e, t = [], n = false) { - if (t == null && (t = []), Array.isArray(e) || Qt(e) && !n) + if (t == null && (t = []), Array.isArray(e) || Yt(e) && !n) for (let s = 0; s < e.length; ++s) aa(e[s], t, n); else @@ -3430,7 +3430,7 @@ function dt(e) { t *= e[n]; return t; } -function C$(e) { +function T$(e) { return e.length === 0; } function Sr(e, t) { @@ -3446,7 +3446,7 @@ function Sr(e, t) { function Zi(e) { return e % 1 === 0; } -function N$(e) { +function $$(e) { if (Math.tanh != null) return Math.tanh(e); if (e === 1 / 0) @@ -3458,20 +3458,20 @@ function N$(e) { return (t - 1) / (t + 1); } } -function T$(e) { +function _$(e) { let t = Math.ceil(Math.sqrt(e)); return [t, Math.ceil(e / t)]; } -function $$(e) { +function A$(e) { let t = new Uint32Array(e); for (let n = 0; n < e; ++n) t[n] = n; - return Jw(t), t; + return tk(t), t; } function Bu(e, t) { return t <= e.length ? e : e + " ".repeat(t - e.length); } -function _$(e, t = (s) => 0, n) { +function E$(e, t = (s) => 0, n) { return new Promise((s, r) => { let a = 0, i = () => { if (e()) { @@ -3489,7 +3489,7 @@ function _$(e, t = (s) => 0, n) { i(); }); } -function A$(e, t) { +function R$(e, t) { let n = 1, s = -1; for (let a = 0; a < e.length; ++a) if (e[a] >= 0) @@ -3516,7 +3516,7 @@ function ts(e, t) { let n = t.length; return e = e == null ? t.map((s, r) => r) : [].concat(e), F(e.every((s) => s >= -n && s < n), () => `All values in axis param must be in range [-${n}, ${n}) but got axis ${e}`), F(e.every((s) => Zi(s)), () => `All values in axis param must be integers but got axis ${e}`), e.map((s) => s < 0 ? n + s : s); } -function ek(e, t) { +function nk(e, t) { let n = [], s = [], r = t != null && Array.isArray(t) && t.length === 0, a = t == null || r ? null : ts(t, e).sort(), i = 0; for (let o = 0; o < e.length; ++o) { if (a != null) { @@ -3528,7 +3528,7 @@ function ek(e, t) { } return { newShape: n, keptDims: s }; } -function tk(e, t) { +function sk(e, t) { let n = null; if (e == null || e === "float32") n = new Float32Array(t); @@ -3540,7 +3540,7 @@ function tk(e, t) { throw new Error(`Unknown data type ${e}`); return n; } -function nk(e, t) { +function rk(e, t) { let n = null; if (e == null || e === "float32") n = new Float32Array(t); @@ -3554,23 +3554,23 @@ function nk(e, t) { throw new Error(`Unknown data type ${e}`); return n; } -function sk(e, t) { +function ak(e, t) { for (let n = 0; n < e.length; n++) { let s = e[n]; if (isNaN(s) || !isFinite(s)) throw Error(`A tensor of type ${t} being uploaded contains ${s}.`); } } -function rk(e) { +function ik(e) { return e === "bool" || e === "complex64" || e === "float32" || e === "int32" || e === "string"; } -function E$(e, t) { +function D$(e, t) { return !(t === "complex64" || t === "float32" && e !== "complex64" || t === "int32" && e !== "float32" && e !== "complex64" || t === "bool" && e === "bool"); } -function Qt(e) { +function Yt(e) { return e instanceof Float32Array || e instanceof Int32Array || e instanceof Uint8Array || e instanceof Uint8ClampedArray; } -function nm(e) { +function sm(e) { if (e === "float32" || e === "int32") return 4; if (e === "complex64") @@ -3579,7 +3579,7 @@ function nm(e) { return 1; throw new Error(`Unknown dtype ${e}`); } -function ak(e) { +function ok(e) { if (e == null) return 0; let t = 0; @@ -3588,14 +3588,14 @@ function ak(e) { function ar(e) { return typeof e == "string" || e instanceof String; } -function ik(e) { +function uk(e) { return typeof e == "boolean"; } -function ok(e) { +function lk(e) { return typeof e == "number"; } -function Qd(e) { - return Array.isArray(e) ? Qd(e[0]) : e instanceof Float32Array ? "float32" : e instanceof Int32Array || e instanceof Uint8Array || e instanceof Uint8ClampedArray ? "int32" : ok(e) ? "float32" : ar(e) ? "string" : ik(e) ? "bool" : "float32"; +function Zd(e) { + return Array.isArray(e) ? Zd(e[0]) : e instanceof Float32Array ? "float32" : e instanceof Int32Array || e instanceof Uint8Array || e instanceof Uint8ClampedArray ? "int32" : lk(e) ? "float32" : ar(e) ? "string" : uk(e) ? "bool" : "float32"; } function hr(e) { return !!(e && e.constructor && e.call && e.apply); @@ -3616,7 +3616,7 @@ function uo(e) { n[s] = n[s + 1] * e[s + 1]; return n; } -function uk(e, t, n, s = false) { +function ck(e, t, n, s = false) { let r = new Array(); if (t.length === 1) { let a = t[0] * (s ? 2 : 1); @@ -3625,7 +3625,7 @@ function uk(e, t, n, s = false) { } else { let a = t[0], i = t.slice(1), o = i.reduce((u, l) => u * l) * (s ? 2 : 1); for (let u = 0; u < a; u++) - r[u] = uk(e + u * o, i, n, s); + r[u] = ck(e + u * o, i, n, s); } return r; } @@ -3637,15 +3637,15 @@ function ji(e, t, n = false) { return []; if (s !== t.length) throw new Error(`[${e}] does not match the input size ${t.length}${n ? " for a complex tensor" : ""}.`); - return uk(0, e, t, n); + return ck(0, e, t, n); } -function lg(e, t) { - let n = Zd(e, t); +function cg(e, t) { + let n = Jd(e, t); for (let s = 0; s < n.length; s++) n[s] = 1; return n; } -function Zd(e, t) { +function Jd(e, t) { if (t == null || t === "float32" || t === "complex64") return new Float32Array(e); if (t === "int32") @@ -3654,7 +3654,7 @@ function Zd(e, t) { return new Uint8Array(e); throw new Error(`Unknown data type ${t}`); } -function R$(e, t) { +function F$(e, t) { let n = e.reduce((s, r) => s * r, 1); if (t == null || t === "float32") return ji(e, new Float32Array(n)); @@ -3664,12 +3664,12 @@ function R$(e, t) { return ji(e, new Uint8Array(n)); throw new Error(`Unknown data type ${t}`); } -function cg(e) { +function dg(e) { e.forEach((t) => { F(Number.isInteger(t) && t >= 0, () => `Tensor must have a shape comprised of positive integers but got shape [${e}].`); }); } -function D$(e, t, n) { +function O$(e, t, n) { if (t === 0) return 0; if (t === 1) @@ -3679,7 +3679,7 @@ function D$(e, t, n) { s += n[r] * e[r]; return s; } -function F$(e, t, n) { +function P$(e, t, n) { if (t === 0) return []; if (t === 1) @@ -3689,13 +3689,13 @@ function F$(e, t, n) { s[r] = Math.floor(e / n[r]), e -= s[r] * n[r]; return s[s.length - 1] = e, s; } -function dg(e) { +function pg(e) { return e && e.then && typeof e.then == "function"; } -var ux = "tfjsflags"; -var O$ = class { +var lx = "tfjsflags"; +var z$ = class { constructor(e) { - this.global = e, this.flags = {}, this.flagRegistry = {}, this.urlFlags = {}, this.getQueryParams = P$, this.populateURLFlags(); + this.global = e, this.flags = {}, this.flagRegistry = {}, this.urlFlags = {}, this.getQueryParams = M$, this.populateURLFlags(); } setPlatform(e, t) { this.platform != null && (K().getBool("IS_TEST") || K().getBool("PROD") || console.warn(`Platform ${this.platformName} has already been set. Overwriting the platform with ${e}.`)), this.platformName = e, this.platform = t; @@ -3713,7 +3713,7 @@ var O$ = class { if (e in this.flags) return this.flags[e]; let t = this.evaluateFlag(e); - if (dg(t)) + if (pg(t)) throw new Error(`Flag ${e} cannot be synchronously evaluated. Please use getAsync() instead.`); return this.flags[e] = t, this.flags[e]; } @@ -3749,20 +3749,20 @@ var O$ = class { if (typeof this.global == "undefined" || typeof this.global.location == "undefined" || typeof this.global.location.search == "undefined") return; let e = this.getQueryParams(this.global.location.search); - ux in e && e[ux].split(",").forEach((n) => { + lx in e && e[lx].split(",").forEach((n) => { let [s, r] = n.split(":"); - this.urlFlags[s] = M$(s, r); + this.urlFlags[s] = B$(s, r); }); } }; -function P$(e) { +function M$(e) { let t = {}; - return e.replace(/[?&]([^=?&]+)(?:=([^&]*))?/g, (n, ...s) => (z$(t, s[0], s[1]), s.join("="))), t; + return e.replace(/[?&]([^=?&]+)(?:=([^&]*))?/g, (n, ...s) => (L$(t, s[0], s[1]), s.join("="))), t; } -function z$(e, t, n) { +function L$(e, t, n) { e[decodeURIComponent(t)] = decodeURIComponent(n || ""); } -function M$(e, t) { +function B$(e, t) { if (t = t.toLowerCase(), t === "true" || t === "false") return t === "true"; if (`${+t}` === t) @@ -3770,15 +3770,15 @@ function M$(e, t) { throw new Error(`Could not parse value flag value ${t} for flag ${e}.`); } function K() { - return lk; + return dk; } -var lk = null; -function L$(e) { - lk = e; +var dk = null; +function V$(e) { + dk = e; } -var Vf; -function ck() { - if (Vf == null) { +var Wf; +function pk() { + if (Wf == null) { let e; if (typeof window != "undefined") e = window; @@ -3790,16 +3790,16 @@ function ck() { e = self; else throw new Error("Could not find a global object"); - Vf = e; + Wf = e; } - return Vf; + return Wf; } -function B$() { - let e = ck(); +function W$() { + let e = pk(); return e._tfGlobals == null && (e._tfGlobals = /* @__PURE__ */ new Map()), e._tfGlobals; } -function pg(e, t) { - let n = B$(); +function hg(e, t) { + let n = W$(); if (n.has(e)) return n.get(e); { @@ -3822,50 +3822,50 @@ var ml = "Atan"; var gl = "Atanh"; var bl = "Atan2"; var Ca = "AvgPool"; -var hg = "AvgPoolGrad"; -var Jd = "AvgPool3D"; -var fg = "AvgPool3DGrad"; +var fg = "AvgPoolGrad"; +var ep = "AvgPool3D"; +var mg = "AvgPool3DGrad"; var Na = "BatchMatMul"; var co = "BatchToSpaceND"; -var mg = "Bincount"; -var V$ = "BroadcastTo"; -var gg = "BroadcastArgs"; +var gg = "Bincount"; +var U$ = "BroadcastTo"; +var bg = "BroadcastArgs"; var Ta = "Cast"; var $a = "Ceil"; var Cr = "ClipByValue"; -var ep = "Complex"; -var tp = "ComplexAbs"; +var tp = "Complex"; +var np = "ComplexAbs"; var po = "Concat"; var _a = "Conv2D"; -var bg = "Conv2DBackpropFilter"; +var yg = "Conv2DBackpropFilter"; var Aa = "Conv2DBackpropInput"; -var np = "Conv3D"; -var yg = "Conv3DBackpropFilterV2"; -var vg = "Conv3DBackpropInputV2"; +var sp = "Conv3D"; +var vg = "Conv3DBackpropFilterV2"; +var xg = "Conv3DBackpropInputV2"; var Ea = "Cos"; var Ra = "Cosh"; var ho = "Cumprod"; var Da = "Cumsum"; var fo = "CropAndResize"; -var xg = "DenseBincount"; +var wg = "DenseBincount"; var mo = "DepthToSpace"; var Fa = "DepthwiseConv2dNative"; -var wg = "DepthwiseConv2dNativeBackpropFilter"; -var kg = "DepthwiseConv2dNativeBackpropInput"; -var Sg = "Diag"; -var sp = "Dilation2D"; -var sm = "Dilation2DBackpropInput"; -var rm = "Dilation2DBackpropFilter"; +var kg = "DepthwiseConv2dNativeBackpropFilter"; +var Sg = "DepthwiseConv2dNativeBackpropInput"; +var Ig = "Diag"; +var rp = "Dilation2D"; +var rm = "Dilation2DBackpropInput"; +var am = "Dilation2DBackpropFilter"; var Oa = "RealDiv"; -var rp = "Einsum"; +var ap = "Einsum"; var Pa = "Elu"; -var Ig = "EluGrad"; +var Cg = "EluGrad"; var yl = "Erf"; var go = "Equal"; var za = "Exp"; var bo = "ExpandDims"; var yo = "Expm1"; -var Cg = "FFT"; +var Ng = "FFT"; var vl = "Fill"; var vo = "FlipLeftRight"; var Ma = "Floor"; @@ -3876,37 +3876,37 @@ var wo = "GatherNd"; var ko = "Greater"; var Va = "GreaterEqual"; var Wa = "Identity"; -var Ng = "IFFT"; -var ap = "Imag"; +var Tg = "IFFT"; +var ip = "Imag"; var xl = "IsFinite"; var wl = "IsInf"; var kl = "IsNan"; var Ua = "LeakyRelu"; var So = "Less"; var Io = "LessEqual"; -var Tg = "LinSpace"; +var $g = "LinSpace"; var Ga = "Log"; var Sl = "Log1p"; var Co = "LogicalAnd"; var Il = "LogicalNot"; -var ip = "LogicalOr"; -var W$ = "LogSoftmax"; -var dpe = "LowerBound"; -var op = "LRN"; -var $g = "LRNGrad"; +var op = "LogicalOr"; +var G$ = "LogSoftmax"; +var hpe = "LowerBound"; +var up = "LRN"; +var _g = "LRNGrad"; var Ha = "Max"; var qa = "Maximum"; var ja = "MaxPool"; -var _g = "MaxPoolGrad"; -var up = "MaxPool3D"; -var Ag = "MaxPool3DGrad"; -var Eg = "MaxPoolWithArgmax"; +var Ag = "MaxPoolGrad"; +var lp = "MaxPool3D"; +var Eg = "MaxPool3DGrad"; +var Rg = "MaxPoolWithArgmax"; var Ka = "Mean"; var Xa = "Min"; var Ya = "Minimum"; var Qa = "MirrorPad"; var Cl = "Mod"; -var Rg = "Multinomial"; +var Dg = "Multinomial"; var Za = "Multiply"; var No = "Neg"; var To = "NotEqual"; @@ -3917,25 +3917,25 @@ var Ao = "OnesLike"; var Eo = "OneHot"; var Ro = "Pack"; var Ja = "PadV2"; -var ppe = "Pool"; +var fpe = "Pool"; var ei = "Pow"; var ti = "Prelu"; var ni = "Prod"; var Tl = "Range"; -var lp = "Real"; +var cp = "Real"; var $l = "Reciprocal"; var si = "Relu"; var Do = "Reshape"; var _l = "ResizeNearestNeighbor"; -var Dg = "ResizeNearestNeighborGrad"; +var Fg = "ResizeNearestNeighborGrad"; var ri = "ResizeBilinear"; -var Fg = "ResizeBilinearGrad"; +var Og = "ResizeBilinearGrad"; var ai = "Relu6"; var Fo = "Reverse"; var Oo = "Round"; var ii = "Rsqrt"; var Po = "ScatterNd"; -var Og = "SearchSorted"; +var Pg = "SearchSorted"; var zo = "Select"; var Al = "Selu"; var Mo = "Slice"; @@ -3949,17 +3949,17 @@ var ci = "Sum"; var Bo = "SpaceToBatchND"; var Vo = "SplitV"; var di = "Softmax"; -var cp = "SparseFillEmptyRows"; +var dp = "SparseFillEmptyRows"; var Dl = "SparseReshape"; -var dp = "SparseSegmentMean"; -var pp = "SparseSegmentSum"; -var hp = "SparseToDense"; +var pp = "SparseSegmentMean"; +var hp = "SparseSegmentSum"; +var fp = "SparseToDense"; var pi = "SquaredDifference"; var Fl = "Square"; var Wo = "StridedSlice"; -var fp = "StringNGrams"; -var Pg = "StringSplit"; -var zg = "StringToHashBucketFast"; +var mp = "StringNGrams"; +var zg = "StringSplit"; +var Mg = "StringToHashBucketFast"; var hi = "Sub"; var Uo = "Tan"; var fi = "Tanh"; @@ -3967,10 +3967,10 @@ var Nr = "Tile"; var Go = "TopK"; var Ho = "Transform"; var Hs = "Transpose"; -var Mg = "Unique"; +var Lg = "Unique"; var qo = "Unpack"; -var mp = "UnsortedSegmentSum"; -var hpe = "UpperBound"; +var gp = "UnsortedSegmentSum"; +var mpe = "UpperBound"; var jo = "ZerosLike"; var mi = "Step"; var vd = "FromPixels"; @@ -3981,19 +3981,19 @@ var ua = "FusedDepthwiseConv2D"; function rr(...e) { K().getBool("IS_TEST") || K().getBool("PROD") || console.warn(...e); } -function U$(...e) { +function H$(...e) { K().getBool("IS_TEST") || K().getBool("PROD") || console.log(...e); } -var Ji = pg("kernelRegistry", () => /* @__PURE__ */ new Map()); -var Hu = pg("gradRegistry", () => /* @__PURE__ */ new Map()); -function am(e, t) { - let n = Lg(e, t); +var Ji = hg("kernelRegistry", () => /* @__PURE__ */ new Map()); +var Hu = hg("gradRegistry", () => /* @__PURE__ */ new Map()); +function im(e, t) { + let n = Bg(e, t); return Ji.get(n); } -function lx(e) { +function cx(e) { return Hu.get(e); } -function im(e) { +function om(e) { let t = Ji.entries(), n = []; for (; ; ) { let { done: s, value: r } = t.next(); @@ -4005,57 +4005,57 @@ function im(e) { return n; } function Ol(e) { - let { kernelName: t, backendName: n } = e, s = Lg(t, n); + let { kernelName: t, backendName: n } = e, s = Bg(t, n); Ji.has(s) && rr(`The kernel '${t}' for backend '${n}' is already registered`), Ji.set(s, e); } -function G$(e) { +function q$(e) { let { kernelName: t } = e; Hu.has(t) && K().getBool("DEBUG") && rr(`Overriding the gradient for '${t}'`), Hu.set(t, e); } -function fpe(e, t) { - let n = Lg(e, t); +function gpe(e, t) { + let n = Bg(e, t); if (!Ji.has(n)) throw new Error(`The kernel '${e}' for backend '${t}' is not registered`); Ji.delete(n); } -function mpe(e) { +function bpe(e) { if (!Hu.has(e)) throw new Error(`The gradient '${e}' for backend is not registered`); Hu.delete(e); } -function gpe(e, t) { - im(e).forEach((s) => { +function ype(e, t) { + om(e).forEach((s) => { let r = Object.assign({}, s, { backendName: t }); Ol(r); }); } -function Lg(e, t) { +function Bg(e, t) { return `${t}_${e}`; } var w = {}; -Ee(w, { arraysEqual: () => Sr, assert: () => F, assertNonNegativeIntegerDimensions: () => cg, assertNonNull: () => ka, assertShapesMatch: () => pn, bytesFromStringArray: () => ak, bytesPerElement: () => nm, checkConversionForErrors: () => sk, clamp: () => Gu, computeStrides: () => uo, createScalarValue: () => Y$, createShuffledIndices: () => $$, decodeString: () => xd, distSquared: () => I$, encodeString: () => zl, fetch: () => Z$, fingerPrint64: () => X$, flatten: () => aa, getArrayFromDType: () => nk, getTypedArrayFromDType: () => tk, hasEncodingLoss: () => E$, hexToLong: () => Pl, indexToLoc: () => F$, inferDtype: () => Qd, inferFromImplicitShape: () => A$, isBoolean: () => ik, isFunction: () => hr, isInt: () => Zi, isNumber: () => ok, isPromise: () => dg, isScalarShape: () => C$, isString: () => ar, isTypedArray: () => Qt, isValidDtype: () => rk, locToIndex: () => D$, makeOnesTypedArray: () => lg, makeZerosNestedTypedArray: () => R$, makeZerosTypedArray: () => Zd, nearestDivisor: () => yd, nearestLargerEven: () => w$, now: () => qu, parseAxisParam: () => ts, randUniform: () => S$, repeatedTry: () => _$, rightPad: () => Bu, shuffle: () => Jw, shuffleCombo: () => x$, sizeFromShape: () => dt, sizeToSquarishShape: () => T$, squeezeShape: () => ek, sum: () => k$, swap: () => bd, tanh: () => N$, toNestedArray: () => ji, toTypedArray: () => gp }); -var cx = wa(n$()); -var Kr = cx.default || cx; +Ee(w, { arraysEqual: () => Sr, assert: () => F, assertNonNegativeIntegerDimensions: () => dg, assertNonNull: () => ka, assertShapesMatch: () => pn, bytesFromStringArray: () => ok, bytesPerElement: () => sm, checkConversionForErrors: () => ak, clamp: () => Gu, computeStrides: () => uo, createScalarValue: () => Z$, createShuffledIndices: () => A$, decodeString: () => xd, distSquared: () => N$, encodeString: () => zl, fetch: () => e_, fingerPrint64: () => Q$, flatten: () => aa, getArrayFromDType: () => rk, getTypedArrayFromDType: () => sk, hasEncodingLoss: () => D$, hexToLong: () => Pl, indexToLoc: () => P$, inferDtype: () => Zd, inferFromImplicitShape: () => R$, isBoolean: () => uk, isFunction: () => hr, isInt: () => Zi, isNumber: () => lk, isPromise: () => pg, isScalarShape: () => T$, isString: () => ar, isTypedArray: () => Yt, isValidDtype: () => ik, locToIndex: () => O$, makeOnesTypedArray: () => cg, makeZerosNestedTypedArray: () => F$, makeZerosTypedArray: () => Jd, nearestDivisor: () => yd, nearestLargerEven: () => S$, now: () => qu, parseAxisParam: () => ts, randUniform: () => C$, repeatedTry: () => E$, rightPad: () => Bu, shuffle: () => tk, shuffleCombo: () => k$, sizeFromShape: () => dt, sizeToSquarishShape: () => _$, squeezeShape: () => nk, sum: () => I$, swap: () => bd, tanh: () => $$, toNestedArray: () => ji, toTypedArray: () => bp }); +var dx = wa(r$()); +var Kr = dx.default || dx; function Pl(e) { return Kr.fromString(e, true, 16); } -var dk = Pl("c3a5c85c97cb3127"); +var hk = Pl("c3a5c85c97cb3127"); var qr = Pl("b492b66fbe98f273"); -var on = Pl("9ae16a3b2f90404f"); -function om(e) { +var an = Pl("9ae16a3b2f90404f"); +function um(e) { return e.xor(e.shru(47)); } -function pk(e, t, n) { +function fk(e, t, n) { let s = e.slice(t, t + n); return Kr.fromBytes(Array.from(s), true, true); } function lt(e, t) { - return pk(e, t, 8); + return fk(e, t, 8); } -function dx(e, t) { - return pk(e, t, 4); +function px(e, t) { + return fk(e, t, 4); } -function Bt(e, t) { +function Lt(e, t) { return t === 0 ? e : e.shru(t).or(e.shl(64 - t)); } function or(e, t, n = Pl("9ddfea08eb382d69")) { @@ -4064,62 +4064,62 @@ function or(e, t, n = Pl("9ddfea08eb382d69")) { let r = t.xor(s).mul(n); return r = r.xor(r.shru(47)), r = r.mul(n), r; } -function H$(e, t, n, s, r, a) { - r = r.add(e), a = Bt(a.add(r).add(s), 21); +function j$(e, t, n, s, r, a) { + r = r.add(e), a = Lt(a.add(r).add(s), 21); let i = r; - return r = r.add(t), r = r.add(n), a = a.add(Bt(r, 44)), [r.add(s), a.add(i)]; + return r = r.add(t), r = r.add(n), a = a.add(Lt(r, 44)), [r.add(s), a.add(i)]; } function Gc(e, t, n, s) { - return H$(lt(e, t), lt(e, t + 8), lt(e, t + 16), lt(e, t + 24), n, s); + return j$(lt(e, t), lt(e, t + 8), lt(e, t + 16), lt(e, t + 24), n, s); } -function q$(e, t = e.length) { +function K$(e, t = e.length) { if (t >= 8) { - let n = on.add(t * 2), s = lt(e, 0).add(on), r = lt(e, t - 8), a = Bt(r, 37).mul(n).add(s), i = Bt(s, 25).add(r).mul(n); + let n = an.add(t * 2), s = lt(e, 0).add(an), r = lt(e, t - 8), a = Lt(r, 37).mul(n).add(s), i = Lt(s, 25).add(r).mul(n); return or(a, i, n); } if (t >= 4) { - let n = on.add(t * 2), s = dx(e, 0); - return or(s.shl(3).add(t), dx(e, t - 4), n); + let n = an.add(t * 2), s = px(e, 0); + return or(s.shl(3).add(t), px(e, t - 4), n); } if (t > 0) { let n = e[0], s = e[t >> 1], r = e[t - 1], a = n + (s << 8), i = t + (r << 2); - return om(on.mul(a).xor(dk.mul(i))).mul(on); + return um(an.mul(a).xor(hk.mul(i))).mul(an); } - return on; -} -function j$(e, t = e.length) { - let n = on.add(t * 2), s = lt(e, 0).mul(qr), r = lt(e, 8), a = lt(e, t - 8).mul(n), i = lt(e, t - 16).mul(on); - return or(Bt(s.add(r), 43).add(Bt(a, 30)).add(i), s.add(Bt(r.add(on), 18)).add(a), n); -} -function K$(e, t = e.length) { - let n = on.add(t * 2), s = lt(e, 0).mul(on), r = lt(e, 8), a = lt(e, t - 8).mul(n), i = lt(e, t - 16).mul(on), o = Bt(s.add(r), 43).add(Bt(a, 30)).add(i), u = or(o, s.add(Bt(r.add(on), 18)).add(a), n), l = lt(e, 16).mul(n), c = lt(e, 24), p = o.add(lt(e, t - 32)).mul(n), d = u.add(lt(e, t - 24)).mul(n); - return or(Bt(l.add(c), 43).add(Bt(p, 30)).add(d), l.add(Bt(c.add(s), 18)).add(p), n); + return an; } function X$(e, t = e.length) { + let n = an.add(t * 2), s = lt(e, 0).mul(qr), r = lt(e, 8), a = lt(e, t - 8).mul(n), i = lt(e, t - 16).mul(an); + return or(Lt(s.add(r), 43).add(Lt(a, 30)).add(i), s.add(Lt(r.add(an), 18)).add(a), n); +} +function Y$(e, t = e.length) { + let n = an.add(t * 2), s = lt(e, 0).mul(an), r = lt(e, 8), a = lt(e, t - 8).mul(n), i = lt(e, t - 16).mul(an), o = Lt(s.add(r), 43).add(Lt(a, 30)).add(i), u = or(o, s.add(Lt(r.add(an), 18)).add(a), n), l = lt(e, 16).mul(n), c = lt(e, 24), p = o.add(lt(e, t - 32)).mul(n), d = u.add(lt(e, t - 24)).mul(n); + return or(Lt(l.add(c), 43).add(Lt(p, 30)).add(d), l.add(Lt(c.add(s), 18)).add(p), n); +} +function Q$(e, t = e.length) { let n = Kr.fromNumber(81, true); if (t <= 32) - return t <= 16 ? q$(e, t) : j$(e, t); + return t <= 16 ? K$(e, t) : X$(e, t); if (t <= 64) - return K$(e, t); - let s = n, r = n.mul(qr).add(113), a = om(r.mul(on).add(113)).mul(on), i = [Kr.UZERO, Kr.UZERO], o = [Kr.UZERO, Kr.UZERO]; - s = s.mul(on).add(lt(e, 0)); + return Y$(e, t); + let s = n, r = n.mul(qr).add(113), a = um(r.mul(an).add(113)).mul(an), i = [Kr.UZERO, Kr.UZERO], o = [Kr.UZERO, Kr.UZERO]; + s = s.mul(an).add(lt(e, 0)); let u = 0, l = (t - 1 >> 6) * 64, c = l + (t - 1 & 63) - 63; do - s = Bt(s.add(r).add(i[0]).add(lt(e, u + 8)), 37).mul(qr), r = Bt(r.add(i[1]).add(lt(e, u + 48)), 42).mul(qr), s = s.xor(o[1]), r = r.add(i[0]).add(lt(e, u + 40)), a = Bt(a.add(o[0]), 33).mul(qr), i = Gc(e, u, i[1].mul(qr), s.add(o[0])), o = Gc(e, u + 32, a.add(o[1]), r.add(lt(e, u + 16))), [a, s] = [s, a], u += 64; + s = Lt(s.add(r).add(i[0]).add(lt(e, u + 8)), 37).mul(qr), r = Lt(r.add(i[1]).add(lt(e, u + 48)), 42).mul(qr), s = s.xor(o[1]), r = r.add(i[0]).add(lt(e, u + 40)), a = Lt(a.add(o[0]), 33).mul(qr), i = Gc(e, u, i[1].mul(qr), s.add(o[0])), o = Gc(e, u + 32, a.add(o[1]), r.add(lt(e, u + 16))), [a, s] = [s, a], u += 64; while (u !== l); let p = qr.add(a.and(255).shl(1)); - return u = c, o[0] = o[0].add(t - 1 & 63), i[0] = i[0].add(o[0]), o[0] = o[0].add(i[0]), s = Bt(s.add(r).add(i[0]).add(lt(e, u + 8)), 37).mul(p), r = Bt(r.add(i[1]).add(lt(e, u + 48)), 42).mul(p), s = s.xor(o[1].mul(9)), r = r.add(i[0].mul(9).add(lt(e, u + 40))), a = Bt(a.add(o[0]), 33).mul(p), i = Gc(e, u, i[1].mul(p), s.add(o[0])), o = Gc(e, u + 32, a.add(o[1]), r.add(lt(e, u + 16))), [a, s] = [s, a], or(or(i[0], o[0], p).add(om(r).mul(dk)).add(a), or(i[1], o[1], p).add(s), p); + return u = c, o[0] = o[0].add(t - 1 & 63), i[0] = i[0].add(o[0]), o[0] = o[0].add(i[0]), s = Lt(s.add(r).add(i[0]).add(lt(e, u + 8)), 37).mul(p), r = Lt(r.add(i[1]).add(lt(e, u + 48)), 42).mul(p), s = s.xor(o[1].mul(9)), r = r.add(i[0].mul(9).add(lt(e, u + 40))), a = Lt(a.add(o[0]), 33).mul(p), i = Gc(e, u, i[1].mul(p), s.add(o[0])), o = Gc(e, u + 32, a.add(o[1]), r.add(lt(e, u + 16))), [a, s] = [s, a], or(or(i[0], o[0], p).add(um(r).mul(hk)).add(a), or(i[1], o[1], p).add(s), p); } -function Y$(e, t) { - return t === "string" ? zl(e) : gp([e], t); +function Z$(e, t) { + return t === "string" ? zl(e) : bp([e], t); } -function Q$(e, t) { +function J$(e, t) { return e instanceof Float32Array && t === "float32" || e instanceof Int32Array && t === "int32" || e instanceof Uint8Array && t === "bool"; } -function gp(e, t) { +function bp(e, t) { if (t === "string") throw new Error("Cannot convert a string[] to a TypedArray"); - if (Array.isArray(e) && (e = aa(e)), K().getBool("DEBUG") && sk(e, t), Q$(e, t)) + if (Array.isArray(e) && (e = aa(e)), K().getBool("DEBUG") && ak(e, t), J$(e, t)) return e; if (t == null || t === "float32" || t === "complex64") return new Float32Array(e); @@ -4136,7 +4136,7 @@ function gp(e, t) { function qu() { return K().platform.now(); } -function Z$(e, t) { +function e_(e, t) { return K().platform.fetch(e, t); } function zl(e, t = "utf-8") { @@ -4145,9 +4145,9 @@ function zl(e, t = "utf-8") { function xd(e, t = "utf-8") { return t = t || "utf-8", K().platform.decode(e, t); } -var J$ = class { +var t_ = class { constructor(e, t) { - this.backendTimer = e, this.logger = t, t == null && (this.logger = new t_()); + this.backendTimer = e, this.logger = t, t == null && (this.logger = new s_()); } profileKernel(e, t, n) { let s, r = () => { @@ -4165,7 +4165,7 @@ var J$ = class { for (let u = 0; u < s.length; u++) { let l = s[u]; l.data().then((c) => { - e_(c, l.dtype, e); + n_(c, l.dtype, e); }); } return { kernelName: e, outputs: s, inputs: t, timeMs: a.then((u) => u.kernelMs), extraInfo: a.then((u) => u.getExtraProfileInfo != null ? u.getExtraProfileInfo() : "") }; @@ -4179,7 +4179,7 @@ var J$ = class { }); } }; -function e_(e, t, n) { +function n_(e, t, n) { if (t !== "float32") return false; for (let s = 0; s < e.length; s++) { @@ -4189,7 +4189,7 @@ function e_(e, t, n) { } return false; } -var t_ = class { +var s_ = class { logKernelProfile(e, t, n, s, r, a) { let i = typeof s == "number" ? Bu(`${s}ms`, 9) : s.error, o = Bu(e, 25), u = t.rank, l = t.size, c = Bu(t.shape.toString(), 14), p = ""; for (let d in r) { @@ -4202,7 +4202,7 @@ var t_ = class { console.log(`%c${o} %c${i} %c${u}D ${c} %c${l} %c${p} %c${a}`, "font-weight:bold", "color:red", "color:blue", "color: orange", "color: green", "color: steelblue"); } }; -function n_(e, t, n) { +function r_(e, t, n) { let s = {}, r = {}; for (let u = 0; u < t.length; u++) s[t[u].id] = true; @@ -4246,7 +4246,7 @@ function n_(e, t, n) { } return o; } -function s_(e, t, n, s) { +function a_(e, t, n, s) { for (let r = t.length - 1; r >= 0; r--) { let a = t[r], i = []; if (a.outputs.forEach((u) => { @@ -4273,16 +4273,16 @@ function s_(e, t, n, s) { } } } -var px = 20; +var hx = 20; var Tu = 3; -var Wf = 7; -function r_(e, t, n, s) { - let r = uo(t), a = a_(e, t, n, r), i = t.length, o = rd(e, t, n, r, a), u = ["Tensor"]; +var Uf = 7; +function i_(e, t, n, s) { + let r = uo(t), a = o_(e, t, n, r), i = t.length, o = rd(e, t, n, r, a), u = ["Tensor"]; return s && (u.push(` dtype: ${n}`), u.push(` rank: ${i}`), u.push(` shape: [${t}]`), u.push(" values:")), u.push(o.map((l) => " " + l).join(` `)), u.join(` `); } -function a_(e, t, n, s) { +function o_(e, t, n, s) { let r = dt(t), a = s[s.length - 1], i = new Array(a).fill(0), o = t.length, u = n === "complex64" ? Ru(e) : e; if (o > 1) for (let l = 0; l < r / a; l++) { @@ -4294,9 +4294,9 @@ function a_(e, t, n, s) { } function Eu(e, t, n) { let s; - return Array.isArray(e) ? s = `${parseFloat(e[0].toFixed(Wf))} + ${parseFloat(e[1].toFixed(Wf))}j` : ar(e) ? s = `'${e}'` : n === "bool" ? s = hk(e) : s = parseFloat(e.toFixed(Wf)).toString(), Bu(s, t); + return Array.isArray(e) ? s = `${parseFloat(e[0].toFixed(Uf))} + ${parseFloat(e[1].toFixed(Uf))}j` : ar(e) ? s = `'${e}'` : n === "bool" ? s = mk(e) : s = parseFloat(e.toFixed(Uf)).toString(), Bu(s, t); } -function hk(e) { +function mk(e) { return e === 0 ? "false" : "true"; } function rd(e, t, n, s, r, a = true) { @@ -4306,10 +4306,10 @@ function rd(e, t, n, s, r, a = true) { let m = Ru(e); return [Eu(m[0], 0, n)]; } - return n === "bool" ? [hk(e[0])] : [e[0].toString()]; + return n === "bool" ? [mk(e[0])] : [e[0].toString()]; } if (u === 1) { - if (o > px) { + if (o > hx) { let g = Tu * i, b = Array.from(e.slice(0, g)), y = Array.from(e.slice((o - Tu) * i, o * i)); return n === "complex64" && (b = Ru(b), y = Ru(y)), ["[" + b.map((v, x) => Eu(v, r[x], n)).join(", ") + ", ..., " + y.map((v, x) => Eu(v, r[o - Tu + x], n)).join(", ") + "]"]; } @@ -4317,7 +4317,7 @@ function rd(e, t, n, s, r, a = true) { return ["[" + m.map((g, b) => Eu(g, r[b], n)).join(", ") + "]"]; } let l = t.slice(1), c = s.slice(1), p = s[0] * i, d = []; - if (o > px) { + if (o > hx) { for (let m = 0; m < Tu; m++) { let g = m * p, b = g + p; d.push(...rd(e.slice(g, b), l, n, c, r, false)); @@ -4349,7 +4349,7 @@ function Ru(e) { t.push([e[n], e[n + 1]]); return t; } -var Wt = class { +var Vt = class { constructor(e, t, n) { if (this.dtype = t, this.shape = e.slice(), this.size = dt(e), n != null) { let s = n.length; @@ -4357,7 +4357,7 @@ var Wt = class { } if (t === "complex64") throw new Error("complex64 dtype TensorBuffers are not supported. Please create a TensorBuffer for the real and imaginary parts separately and call tf.complex(real, imag)."); - this.values = n || nk(t, this.size), this.strides = uo(e); + this.values = n || rk(t, this.size), this.strides = uo(e); } set(e, ...t) { t.length === 0 && (t = [0]), F(t.length === this.rank, () => `The number of provided coordinates (${t.length}) must match the rank (${this.rank})`); @@ -4408,15 +4408,15 @@ var Wt = class { }; var cs = null; var Ui = null; -var i_ = null; -function o_(e) { +var u_ = null; +function l_(e) { cs = e; } -function u_(e) { +function c_(e) { Ui = e; } -function l_(e) { - i_ = e; +function d_(e) { + u_ = e; } var et = class { constructor(e, t, n, s) { @@ -4489,7 +4489,7 @@ var et = class { } toString(e = false) { let t = this.dataSync(); - return r_(t, this.shape, this.dtype, e); + return i_(t, this.shape, this.dtype, e); } cast(e) { return this.throwIfDisposed(), Ui.cast(this, e); @@ -4499,10 +4499,10 @@ var et = class { } }; Object.defineProperty(et, Symbol.hasInstance, { value: (e) => !!e && e.data != null && e.dataSync != null && e.throwIfDisposed != null }); -function c_() { - return pg("Tensor", () => et); +function p_() { + return hg("Tensor", () => et); } -c_(); +p_(); var wd = class extends et { constructor(e, t, n, s) { super(e.shape, e.dtype, e.dataId, s), this.trainable = t, this.name = n; @@ -4520,62 +4520,62 @@ var wd = class extends et { }; Object.defineProperty(wd, Symbol.hasInstance, { value: (e) => e instanceof et && e.assign != null && e.assign instanceof Function }); var _s = {}; -Ee(_s, { assertTypesMatch: () => yk, getTensorsInContainer: () => Bg, isTensorInList: () => h_, makeTypesMatch: () => xt }); -var d_ = ((e) => (e.R0 = "R0", e.R1 = "R1", e.R2 = "R2", e.R3 = "R3", e.R4 = "R4", e.R5 = "R5", e.R6 = "R6", e))(d_ || {}); -var fk = ((e) => (e.float32 = "float32", e.int32 = "int32", e.bool = "int32", e.complex64 = "complex64", e))(fk || {}); -var mk = ((e) => (e.float32 = "float32", e.int32 = "int32", e.bool = "bool", e.complex64 = "complex64", e))(mk || {}); -var gk = ((e) => (e.float32 = "float32", e.int32 = "float32", e.bool = "float32", e.complex64 = "complex64", e))(gk || {}); -var bk = ((e) => (e.float32 = "complex64", e.int32 = "complex64", e.bool = "complex64", e.complex64 = "complex64", e))(bk || {}); -var p_ = { float32: gk, int32: fk, bool: mk, complex64: bk }; -function cn(e, t) { +Ee(_s, { assertTypesMatch: () => xk, getTensorsInContainer: () => Vg, isTensorInList: () => m_, makeTypesMatch: () => xt }); +var h_ = ((e) => (e.R0 = "R0", e.R1 = "R1", e.R2 = "R2", e.R3 = "R3", e.R4 = "R4", e.R5 = "R5", e.R6 = "R6", e))(h_ || {}); +var gk = ((e) => (e.float32 = "float32", e.int32 = "int32", e.bool = "int32", e.complex64 = "complex64", e))(gk || {}); +var bk = ((e) => (e.float32 = "float32", e.int32 = "int32", e.bool = "bool", e.complex64 = "complex64", e))(bk || {}); +var yk = ((e) => (e.float32 = "float32", e.int32 = "float32", e.bool = "float32", e.complex64 = "complex64", e))(yk || {}); +var vk = ((e) => (e.float32 = "complex64", e.int32 = "complex64", e.bool = "complex64", e.complex64 = "complex64", e))(vk || {}); +var f_ = { float32: yk, int32: gk, bool: bk, complex64: vk }; +function ln(e, t) { if (e === "string" || t === "string") { if (e === "string" && t === "string") return "string"; throw new Error(`Can not upcast ${e} with ${t}`); } - return p_[e][t]; + return f_[e][t]; } -function bp(e) { - return cn(e, "int32"); +function yp(e) { + return ln(e, "int32"); } function xt(e, t) { if (e.dtype === t.dtype) return [e, t]; - let n = cn(e.dtype, t.dtype); + let n = ln(e.dtype, t.dtype); return [e.cast(n), t.cast(n)]; } -function yk(e, t) { +function xk(e, t) { F(e.dtype === t.dtype, () => `The dtypes of the first(${e.dtype}) and second(${t.dtype}) input must match`); } -function h_(e, t) { +function m_(e, t) { return t.some((n) => n.id === e.id); } -function Bg(e) { +function Vg(e) { let t = []; - return vk(e, t, /* @__PURE__ */ new Set()), t; + return wk(e, t, /* @__PURE__ */ new Set()), t; } -function vk(e, t, n) { +function wk(e, t, n) { if (e == null) return; if (e instanceof et) { t.push(e); return; } - if (!f_(e)) + if (!g_(e)) return; let s = e; for (let r in s) { let a = s[r]; - n.has(a) || (n.add(a), vk(a, t, n)); + n.has(a) || (n.add(a), wk(a, t, n)); } } -function f_(e) { +function g_(e) { return Array.isArray(e) || typeof e == "object"; } -function Uf(e) { +function Gf(e) { return e.kernelName != null; } -var hx = class { +var fx = class { constructor() { this.registeredVariables = {}, this.nextTapeNodeId = 0, this.numBytes = 0, this.numTensors = 0, this.numStringTensors = 0, this.numDataBuffers = 0, this.gradientDepth = 0, this.kernelDepth = 0, this.scopeStack = [], this.numDataMovesStack = [], this.nextScopeId = 0, this.tensorInfo = /* @__PURE__ */ new WeakMap(), this.profiling = false, this.activeProfile = { newBytes: 0, newTensors: 0, peakBytes: 0, kernels: [], result: null, get kernelNames() { return Array.from(new Set(this.kernels.map((e) => e.name))); @@ -4586,9 +4586,9 @@ var hx = class { this.registeredVariables[e].dispose(); } }; -var um = class { +var lm = class { constructor(e) { - this.ENV = e, this.registry = {}, this.registryFactory = {}, this.pendingBackendInitId = 0, this.state = new hx(); + this.ENV = e, this.registry = {}, this.registryFactory = {}, this.pendingBackendInitId = 0, this.state = new fx(); } async ready() { if (this.pendingBackendInit != null) @@ -4645,15 +4645,15 @@ var um = class { if (!(n ? await t : t)) return false; } - return this.backendInstance = this.registry[e], this.setupRegisteredKernels(), this.profiler = new J$(this.backendInstance), true; + return this.backendInstance = this.registry[e], this.setupRegisteredKernels(), this.profiler = new t_(this.backendInstance), true; } setupRegisteredKernels() { - im(this.backendName).forEach((t) => { + om(this.backendName).forEach((t) => { t.setupFunc != null && t.setupFunc(this.backendInstance); }); } disposeRegisteredKernels(e) { - im(e).forEach((n) => { + om(e).forEach((n) => { n.disposeFunc != null && n.disposeFunc(this.registry[e]); }); } @@ -4721,10 +4721,10 @@ var um = class { } } nextTensorId() { - return um.nextTensorId++; + return lm.nextTensorId++; } nextVariableId() { - return um.nextVariableId++; + return lm.nextVariableId++; } clone(e) { let t = z.runKernel(Wa, { x: e }), n = { x: e }, s = (a) => ({ x: () => { @@ -4734,7 +4734,7 @@ var um = class { return this.addTapeNode(this.state.activeScope.name, n, [t], s, r, {}), t; } runKernel(e, t, n) { - if (this.backendName == null && this.backend, !(am(e, this.backendName) != null)) + if (this.backendName == null && this.backend, !(im(e, this.backendName) != null)) throw new Error(`Kernel '${e}' not registered for backend '${this.backendName}'`); return this.runKernelFunc({ kernelName: e, inputs: t, attrs: n }); } @@ -4755,11 +4755,11 @@ var um = class { this.shouldCheckForMemLeaks() && this.state.numDataMovesStack.push(0); let i; this.backendName == null && this.backend; - let o, u = Uf(e) ? e.kernelName : this.state.activeScope != null ? this.state.activeScope.name : ""; - if (Uf(e)) { + let o, u = Gf(e) ? e.kernelName : this.state.activeScope != null ? this.state.activeScope.name : ""; + if (Gf(e)) { let { kernelName: h, inputs: f, attrs: m } = e; this.backendName == null && this.backend; - let g = am(h, this.backendName); + let g = im(h, this.backendName); F(g != null, () => `Cannot find registered kernel '${h}' for backend '${this.backendName}'`), i = () => { let b = this.backend.numDataIds(); o = g.kernelFunc({ inputs: f, attrs: m, backend: this.backend }); @@ -4783,7 +4783,7 @@ var um = class { return this.shouldCheckForMemLeaks() && this.checkKernelForMemLeak(u, m, g), g; }; } - let { inputs: l, attrs: c } = e, p = Uf(e) ? null : e.backwardsFunc, d; + let { inputs: l, attrs: c } = e, p = Gf(e) ? null : e.backwardsFunc, d; return this.scopedRun(() => this.state.kernelDepth++, () => this.state.kernelDepth--, () => { !this.ENV.getBool("DEBUG") && !this.state.profiling ? t = i() : (d = this.profiler.profileKernel(u, l, () => i()), this.ENV.getBool("DEBUG") && this.profiler.logKernelProfile(d), t = d.outputs); }), s && this.addTapeNode(u, l, t, p, n, c), this.state.profiling && this.state.activeProfile.kernels.push({ name: u, bytesAdded: this.state.numBytes - r, totalBytesSnapshot: this.state.numBytes, tensorsAdded: this.state.numTensors - a, totalTensorsSnapshot: this.state.numTensors, inputShapes: Object.keys(l).map((h) => l[h] != null ? l[h].shape : null), outputShapes: t.map((h) => h.shape), kernelTimeMs: d.timeMs, extraInfo: d.extraInfo }), Array.isArray(o) ? t : t[0]; @@ -4792,7 +4792,7 @@ var um = class { return e.map((n) => this.keep(this.clone(n))); } getTensorsForGradient(e, t, n) { - let s = lx(e); + let s = cx(e); if (s != null) { let r = s.inputsToSave || [], a = s.outputsToSave || [], i; s.saveAllInputs ? (F(Array.isArray(t), () => "saveAllInputs is true, expected inputs to be an array."), i = Object.keys(t).map((u) => t[u])) : i = r.map((u) => t[u]); @@ -4809,7 +4809,7 @@ var um = class { n === "string" && ar(e[0]) && (r = e.map((o) => zl(o))); let a = s.write(r, t, n), i = new et(t, n, a, this.nextTensorId()); if (this.trackTensor(i, s), n === "string") { - let o = this.state.tensorInfo.get(a), u = ak(r); + let o = this.state.tensorInfo.get(a), u = ok(r); this.state.numBytes += u - o.bytes, o.bytes = u; } return i; @@ -4833,7 +4833,7 @@ var um = class { trackTensor(e, t) { this.state.numTensors++, e.dtype === "string" && this.state.numStringTensors++; let n = 0; - e.dtype !== "complex64" && e.dtype !== "string" && (n = e.size * nm(e.dtype)), this.state.numBytes += n, this.state.tensorInfo.has(e.dataId) || (this.state.numDataBuffers++, this.state.tensorInfo.set(e.dataId, { backend: t || this.backend, dtype: e.dtype, shape: e.shape, bytes: n })), e instanceof wd || this.track(e); + e.dtype !== "complex64" && e.dtype !== "string" && (n = e.size * sm(e.dtype)), this.state.numBytes += n, this.state.tensorInfo.has(e.dataId) || (this.state.numDataBuffers++, this.state.tensorInfo.set(e.dataId, { backend: t || this.backend, dtype: e.dtype, shape: e.shape, bytes: n })), e instanceof wd || this.track(e); } incRef(e, t) { this.trackTensor(e, t), this.backend.incRef(e.dataId); @@ -4846,7 +4846,7 @@ var um = class { return; let t = this.state.tensorInfo.get(e.dataId); if (this.state.numTensors--, e.dtype === "string" && (this.state.numStringTensors--, this.state.numBytes -= t.bytes), e.dtype !== "complex64" && e.dtype !== "string") { - let n = e.size * nm(e.dtype); + let n = e.size * sm(e.dtype); this.state.numBytes -= n; } t.backend.disposeData(e.dataId) && this.removeDataId(e.dataId, t.backend); @@ -4876,10 +4876,10 @@ var um = class { return this.state.gradientDepth > 0 && this.state.kernelDepth === 0; } addTapeNode(e, t, n, s, r, a) { - let i = { id: this.state.nextTapeNodeId++, kernelName: e, inputs: t, outputs: n, saved: r }, o = lx(e); + let i = { id: this.state.nextTapeNodeId++, kernelName: e, inputs: t, outputs: n, saved: r }, o = cx(e); o != null && (s = o.gradFunc), s != null && (i.gradient = (u) => (u = u.map((l, c) => { if (l == null) { - let p = n[c], d = Zd(p.size, p.dtype); + let p = n[c], d = Jd(p.size, p.dtype); return this.makeTensor(d, p.shape, p.dtype); } return l; @@ -4899,7 +4899,7 @@ var um = class { e && (t.name = e), this.state.scopeStack.push(t), this.state.activeScope = t; } endScope(e) { - let t = Bg(e), n = new Set(t.map((r) => r.id)); + let t = Vg(e), n = new Set(t.map((r) => r.id)); for (let r = 0; r < this.state.activeScope.track.length; r++) { let a = this.state.activeScope.track[r]; !a.kept && !n.has(a.id) && a.dispose(); @@ -4914,12 +4914,12 @@ var um = class { throw new Error(`dy must have 'float32' dtype, but has '${n.dtype}'`); let r = this.scopedRun(() => this.startTape(), () => this.endTape(), () => this.tidy("forward", e)); F(r instanceof et, () => "The result y returned by f() must be a tensor."); - let a = n_(this.state.activeTape, t, r); + let a = r_(this.state.activeTape, t, r); if (!s && a.length === 0 && t.length > 0) throw new Error("Cannot compute gradient of y=f(x) with respect to x. Make sure that the f you passed encloses all operations that lead from x to y."); return this.tidy("backward", () => { let i = {}; - i[r.id] = n == null ? m_(r.shape) : n, s_(i, a, (u) => this.tidy(u), g_); + i[r.id] = n == null ? b_(r.shape) : n, a_(i, a, (u) => this.tidy(u), y_); let o = t.map((u) => i[u.id]); return this.state.gradientDepth === 0 && (this.state.activeTape.forEach((u) => { for (let l of u.saved) @@ -4965,45 +4965,45 @@ var um = class { return this.state.registeredVariables; } reset() { - this.pendingBackendInitId++, this.state.dispose(), this.ENV.reset(), this.state = new hx(); + this.pendingBackendInitId++, this.state.dispose(), this.ENV.reset(), this.state = new fx(); for (let e in this.registry) this.disposeRegisteredKernels(e), this.registry[e].dispose(), delete this.registry[e]; this.backendName = null, this.backendInstance = null, this.pendingBackendInit = null; } }; -var Vg = um; -Vg.nextTensorId = 0; -Vg.nextVariableId = 0; -function m_(e) { - let t = lg(dt(e), "float32"); +var Wg = lm; +Wg.nextTensorId = 0; +Wg.nextVariableId = 0; +function b_(e) { + let t = cg(dt(e), "float32"); return z.makeTensor(t, e, "float32"); } -function xk() { - let e = ck(); +function kk() { + let e = pk(); if (e._tfengine == null) { - let t = new O$(e); - e._tfengine = new Vg(t); + let t = new z$(e); + e._tfengine = new Wg(t); } - return L$(e._tfengine.ENV), o_(() => e._tfengine), e._tfengine; + return V$(e._tfengine.ENV), l_(() => e._tfengine), e._tfengine; } -var z = xk(); -function g_(e, t) { +var z = kk(); +function y_(e, t) { let n = { a: e, b: t }; return z.runKernel(Ir, n); } -var yp = {}; -Ee(yp, { isBrowser: () => wk, isMobile: () => v_, mockIsMobile: () => y_ }); -function b_() { +var vp = {}; +Ee(vp, { isBrowser: () => Sk, isMobile: () => w_, mockIsMobile: () => x_ }); +function v_() { return typeof navigator != "undefined" && navigator != null; } -var lm; -function y_(e) { - lm = e; +var cm; +function x_(e) { + cm = e; } -function v_(e) { - if (lm !== void 0) - return lm; - if (e || b_()) { +function w_(e) { + if (cm !== void 0) + return cm; + if (e || v_()) { if (e || (e = navigator), e.product === "ReactNative") return true; let t = e.userAgent || e.vendor || (typeof window != "undefined" ? window.opera : ""); @@ -5015,14 +5015,14 @@ function v_(e) { } return false; } -function wk() { +function Sk() { return typeof window != "undefined" && window.document != null || typeof WorkerGlobalScope != "undefined"; } var Kn = K(); Kn.registerFlag("DEBUG", () => false, (e) => { e && console.warn("Debugging mode is ON. The output of every math call will be downloaded to CPU and checked for NaNs. This significantly impacts performance."); }); -Kn.registerFlag("IS_BROWSER", () => wk()); +Kn.registerFlag("IS_BROWSER", () => Sk()); Kn.registerFlag("IS_NODE", () => typeof process != "undefined" && typeof process.versions != "undefined" && typeof process.versions.node != "undefined"); Kn.registerFlag("IS_CHROME", () => typeof navigator != "undefined" && navigator != null && navigator.userAgent != null && /Chrome/.test(navigator.userAgent) && /Google Inc/.test(navigator.vendor)); Kn.registerFlag("PROD", () => false); @@ -5034,26 +5034,26 @@ Kn.registerFlag("WRAP_TO_IMAGEBITMAP", () => false); Kn.registerFlag("ENGINE_COMPILE_ONLY", () => false); function Rs(e, t) { let n = e; - if (Qt(e)) + if (Yt(e)) return t === "string" ? [] : [e.length]; if (!Array.isArray(e)) return []; let s = []; - for (; Array.isArray(n) || Qt(n) && t !== "string"; ) + for (; Array.isArray(n) || Yt(n) && t !== "string"; ) s.push(n.length), n = n[0]; - return Array.isArray(e) && K().getBool("TENSORLIKE_CHECK_SHAPE_CONSISTENCY") && kk(e, s, []), s; + return Array.isArray(e) && K().getBool("TENSORLIKE_CHECK_SHAPE_CONSISTENCY") && Ik(e, s, []), s; } -function kk(e, t, n) { - if (n = n || [], !Array.isArray(e) && !Qt(e)) { +function Ik(e, t, n) { + if (n = n || [], !Array.isArray(e) && !Yt(e)) { F(t.length === 0, () => `Element arr[${n.join("][")}] is a primitive, but should be an array/TypedArray of ${t[0]} elements`); return; } F(t.length > 0, () => `Element arr[${n.join("][")}] should be a primitive, but is an array of ${e.length} elements`), F(e.length === t[0], () => `Element arr[${n.join("][")}] should have ${t[0]} elements, but has ${e.length} elements`); let s = t.slice(1); for (let r = 0; r < e.length; ++r) - kk(e[r], s, n.concat(r)); + Ik(e[r], s, n.concat(r)); } -function fx(e, t, n, s) { +function mx(e, t, n, s) { if (e !== "string_or_numeric") { if (e == null) throw new Error("Expected dtype cannot be null."); @@ -5063,15 +5063,15 @@ function fx(e, t, n, s) { } function _(e, t, n, s = "numeric") { if (e instanceof et) - return fx(s, e.dtype, t, n), e; - let r = Qd(e); - if (r !== "string" && ["bool", "int32", "float32"].indexOf(s) >= 0 && (r = s), fx(s, r, t, n), e == null || !Qt(e) && !Array.isArray(e) && typeof e != "number" && typeof e != "boolean" && typeof e != "string") { + return mx(s, e.dtype, t, n), e; + let r = Zd(e); + if (r !== "string" && ["bool", "int32", "float32"].indexOf(s) >= 0 && (r = s), mx(s, r, t, n), e == null || !Yt(e) && !Array.isArray(e) && typeof e != "number" && typeof e != "boolean" && typeof e != "string") { let u = e == null ? "null" : e.constructor.name; throw new Error(`Argument '${t}' passed to '${n}' must be a Tensor or TensorLike, but got '${u}'`); } let a = Rs(e, r); - !Qt(e) && !Array.isArray(e) && (e = [e]); - let o = r !== "string" ? gp(e, r) : aa(e, [], true); + !Yt(e) && !Array.isArray(e) && (e = [e]); + let o = r !== "string" ? bp(e, r) : aa(e, [], true); return z.makeTensor(o, a, r); } function ju(e, t, n, s = "numeric") { @@ -5079,38 +5079,38 @@ function ju(e, t, n, s = "numeric") { throw new Error(`Argument ${t} passed to ${n} must be a \`Tensor[]\` or \`TensorLike[]\``); return e.map((a, i) => _(a, `${t}[${i}]`, n, s)); } -var x_ = "__op"; +var k_ = "__op"; function L(e) { let t = Object.keys(e); if (t.length !== 1) throw new Error(`Please provide an object with a single key (operation name) mapping to a function. Got an object with ${t.length} keys.`); let n = t[0], s = e[n]; - n.endsWith("_") && (n = n.substring(0, n.length - 1)), n = n + x_; + n.endsWith("_") && (n = n.substring(0, n.length - 1)), n = n + k_; let r = (...a) => { z.startScope(n); try { let i = s(...a); - return dg(i) && console.error("Cannot return a Promise inside of tidy."), z.endScope(i), i; + return pg(i) && console.error("Cannot return a Promise inside of tidy."), z.endScope(i), i; } catch (i) { throw z.endScope(null), i; } }; return Object.defineProperty(r, "name", { value: n, configurable: true }), r; } -function w_(e, t) { +function S_(e, t) { let n = _(e, "real", "complex"), s = _(t, "imag", "complex"); pn(n.shape, s.shape, `real and imag shapes, ${n.shape} and ${s.shape}, must match in call to tf.complex().`); let r = { real: n, imag: s }; - return z.runKernel(ep, r); + return z.runKernel(tp, r); } -var fr = L({ complex_: w_ }); +var fr = L({ complex_: S_ }); function Tr(e, t, n, s) { - if (s == null && (s = Qd(e)), s === "complex64") + if (s == null && (s = Zd(e)), s === "complex64") throw new Error("Cannot construct a complex64 tensor directly. Please use tf.complex(real, imag)."); - if (!Qt(e) && !Array.isArray(e) && typeof e != "number" && typeof e != "boolean" && typeof e != "string") + if (!Yt(e) && !Array.isArray(e) && typeof e != "number" && typeof e != "boolean" && typeof e != "string") throw new Error("values passed to tensor(values) must be a number/boolean/string or an array of numbers/booleans/strings, or a TypedArray"); if (t != null) { - cg(t); + dg(t); let r = dt(t), a = dt(n); F(r === a, () => `Based on the provided shape, [${t}], the tensor should have ${r} values but has ${a}`); for (let i = 0; i < n.length; ++i) { @@ -5118,15 +5118,15 @@ function Tr(e, t, n, s) { F(n[i] === t[i] || !u, () => `Error creating a new Tensor. Inferred shape (${n}) does not match the provided shape (${t}). `); } } - return !Qt(e) && !Array.isArray(e) && (e = [e]), t = t || n, e = s !== "string" ? gp(e, s) : aa(e, [], true), z.makeTensor(e, t, s); + return !Yt(e) && !Array.isArray(e) && (e = [e]), t = t || n, e = s !== "string" ? bp(e, s) : aa(e, [], true), z.makeTensor(e, t, s); } function ms(e, t, n) { let s = Rs(e, n); return Tr(e, t, s, n); } -var cm = { float32: 4, float16: 2, int32: 4, uint16: 2, uint8: 1, bool: 1, complex64: 8 }; +var dm = { float32: 4, float16: 2, int32: 4, uint16: 2, uint8: 1, bool: 1, complex64: 8 }; var kd = 4; -async function k_(e, t) { +async function I_(e, t) { let n = [], s = [], r = Array.isArray(e) ? e.map((i) => i.name) : Object.keys(e); for (let i = 0; i < r.length; ++i) { let o = r[i], u = Array.isArray(e) ? e[i].tensor : e[o]; @@ -5148,9 +5148,9 @@ async function k_(e, t) { t != null && (l.group = t), n.push(l); } let a = await Promise.all(s); - return { data: S_(a), specs: n }; + return { data: C_(a), specs: n }; } -function Sk(e, t) { +function Ck(e, t) { let n = {}, s, r = 0; for (let a of t) { let i = a.name, o = a.dtype, u = a.shape, l = dt(u), c; @@ -5164,7 +5164,7 @@ function Sk(e, t) { throw new Error(`Weight ${a.name} is quantized with ${p.dtype} which only supports weights of type float32 not ${o}.`); } else throw new Error(`Weight ${a.name} has unknown quantization dtype ${p.dtype}. Supported quantization dtypes are: 'uint8', 'uint16', and 'float16'.`); - let d = cm[p.dtype], h = e.slice(r, r + l * d), f = p.dtype === "uint8" ? new Uint8Array(h) : new Uint16Array(h); + let d = dm[p.dtype], h = e.slice(r, r + l * d), f = p.dtype === "uint8" ? new Uint8Array(h) : new Uint16Array(h); if (o === "float32") if (p.dtype === "uint8" || p.dtype === "uint16") { c = new Float32Array(f.length); @@ -5173,7 +5173,7 @@ function Sk(e, t) { c[m] = g * p.scale + p.min; } } else if (p.dtype === "float16") - s === void 0 && (s = __()), c = s(f); + s === void 0 && (s = E_()), c = s(f); else throw new Error(`Unsupported quantization type ${p.dtype} for weight type float32.`); else if (o === "int32") { @@ -5197,7 +5197,7 @@ function Sk(e, t) { c.push(f), r += h; } } else { - let p = cm[o], d = e.slice(r, r + l * p); + let p = dm[o], d = e.slice(r, r + l * p); if (o === "float32") c = new Float32Array(d); else if (o === "int32") @@ -5219,7 +5219,7 @@ function Sk(e, t) { } return n; } -function S_(e) { +function C_(e) { if (e === null) throw new Error(`Invalid input value: ${JSON.stringify(e)}`); let t = 0, n = []; @@ -5232,20 +5232,20 @@ function S_(e) { s.set(new Uint8Array(a.buffer), r), r += a.byteLength; }), s.buffer; } -var Wg = typeof Buffer != "undefined" && (typeof Blob == "undefined" || typeof atob == "undefined" || typeof btoa == "undefined"); -function mx(e) { - return Wg ? Buffer.byteLength(e) : new Blob([e]).size; +var Ug = typeof Buffer != "undefined" && (typeof Blob == "undefined" || typeof atob == "undefined" || typeof btoa == "undefined"); +function gx(e) { + return Ug ? Buffer.byteLength(e) : new Blob([e]).size; } -function I_(e) { - if (Wg) +function N_(e) { + if (Ug) return Buffer.from(e).toString("base64"); let t = new Uint8Array(e), n = ""; for (let s = 0, r = t.length; s < r; s++) n += String.fromCharCode(t[s]); return btoa(n); } -function C_(e) { - if (Wg) { +function T_(e) { + if (Ug) { let s = Buffer.from(e, "base64"); return s.buffer.slice(s.byteOffset, s.byteOffset + s.byteLength); } @@ -5254,7 +5254,7 @@ function C_(e) { n.set([t.charCodeAt(s)], s); return n.buffer; } -function Ug(e) { +function Gg(e) { if (e.length === 1) return e[0]; let t = 0; @@ -5266,18 +5266,18 @@ function Ug(e) { n.set(new Uint8Array(r), s), s += r.byteLength; }), n.buffer; } -function gx(e) { +function bx(e) { let t = "/"; for (e = e.trim(); e.endsWith(t); ) e = e.slice(0, e.length - 1); let n = e.split(t); return n[n.length - 1]; } -function Ik(e, t) { +function Nk(e, t) { let n = { modelTopology: e.modelTopology, format: e.format, generatedBy: e.generatedBy, convertedBy: e.convertedBy, weightsManifest: t }; return e.signature != null && (n.signature = e.signature), e.userDefinedMetadata != null && (n.userDefinedMetadata = e.userDefinedMetadata), e.modelInitializer != null && (n.modelInitializer = e.modelInitializer), e.trainingConfig != null && (n.trainingConfig = e.trainingConfig), n; } -async function Gg(e, t) { +async function Hg(e, t) { let n = { modelTopology: e.modelTopology, format: e.format, generatedBy: e.generatedBy, convertedBy: e.convertedBy }; if (e.trainingConfig != null && (n.trainingConfig = e.trainingConfig), e.weightsManifest != null) { let [s, r] = await t(e.weightsManifest); @@ -5288,9 +5288,9 @@ async function Gg(e, t) { function Ml(e) { if (e.modelTopology instanceof ArrayBuffer) throw new Error("Expected JSON model topology, received ArrayBuffer."); - return { dateSaved: new Date(), modelTopologyType: "JSON", modelTopologyBytes: e.modelTopology == null ? 0 : mx(JSON.stringify(e.modelTopology)), weightSpecsBytes: e.weightSpecs == null ? 0 : mx(JSON.stringify(e.weightSpecs)), weightDataBytes: e.weightData == null ? 0 : e.weightData.byteLength }; + return { dateSaved: new Date(), modelTopologyType: "JSON", modelTopologyBytes: e.modelTopology == null ? 0 : gx(JSON.stringify(e.modelTopology)), weightSpecsBytes: e.weightSpecs == null ? 0 : gx(JSON.stringify(e.weightSpecs)), weightDataBytes: e.weightData == null ? 0 : e.weightData.byteLength }; } -function N_() { +function $_() { let e = (n) => { let s = n << 13, r = 0; for (; (s & 8388608) === 0; ) @@ -5304,7 +5304,7 @@ function N_() { t[n] = 939524096 + (n - 1024 << 13); return t; } -function T_() { +function __() { let e = new Uint32Array(64); e[0] = 0, e[31] = 1199570944, e[32] = 2147483648, e[63] = 3347054592; for (let t = 1; t < 31; t++) @@ -5313,14 +5313,14 @@ function T_() { e[t] = 2147483648 + (t - 32 << 23); return e; } -function $_() { +function A_() { let e = new Uint32Array(64); for (let t = 0; t < 64; t++) e[t] = 1024; return e[0] = e[32] = 0, e; } -function __() { - let e = N_(), t = T_(), n = $_(); +function E_() { + let e = $_(), t = __(), n = A_(); return (s) => { let r = new ArrayBuffer(4 * s.length), a = new Uint32Array(r); for (let i = 0; i < s.length; i++) { @@ -5357,15 +5357,15 @@ var wt = class { }), s; } }; -var A_ = (e) => wt.registerSaveRouter(e); -var E_ = (e) => wt.registerLoadRouter(e); -var R_ = (e) => wt.getSaveHandlers(e); -var D_ = (e, t) => wt.getLoadHandlers(e, t); -var dm = "tensorflowjs"; -var pm = 1; +var R_ = (e) => wt.registerSaveRouter(e); +var D_ = (e) => wt.registerLoadRouter(e); +var F_ = (e) => wt.getSaveHandlers(e); +var O_ = (e, t) => wt.getLoadHandlers(e, t); +var pm = "tensorflowjs"; +var hm = 1; var Zr = "models_store"; var ir = "model_info_store"; -function Ck() { +function Tk() { if (!K().getBool("IS_BROWSER")) throw new Error("Failed to obtain IndexedDB factory because the current environmentis not a web browser."); let e = typeof window == "undefined" ? self : window, t = e.indexedDB || e.mozIndexedDB || e.webkitIndexedDB || e.msIndexedDB || e.shimIndexedDB; @@ -5373,13 +5373,13 @@ function Ck() { throw new Error("The current browser does not appear to support IndexedDB."); return t; } -function hm(e) { +function fm(e) { let t = e.result; t.createObjectStore(Zr, { keyPath: "modelPath" }), t.createObjectStore(ir, { keyPath: "modelPath" }); } var la = class { constructor(e) { - if (this.indexedDB = Ck(), e == null || !e) + if (this.indexedDB = Tk(), e == null || !e) throw new Error("For IndexedDB, modelPath must not be null, undefined or empty."); this.modelPath = e; } @@ -5393,8 +5393,8 @@ var la = class { } databaseAction(e, t) { return new Promise((n, s) => { - let r = this.indexedDB.open(dm, pm); - r.onupgradeneeded = () => hm(r), r.onsuccess = () => { + let r = this.indexedDB.open(pm, hm); + r.onupgradeneeded = () => fm(r), r.onsuccess = () => { let a = r.result; if (t == null) { let i = a.transaction(Zr, "readonly"), u = i.objectStore(Zr).get(this.modelPath); @@ -5422,23 +5422,23 @@ var la = class { } }; la.URL_SCHEME = "indexeddb://"; -var Nk = (e) => K().getBool("IS_BROWSER") && !Array.isArray(e) && e.startsWith(la.URL_SCHEME) ? F_(e.slice(la.URL_SCHEME.length)) : null; -wt.registerSaveRouter(Nk); -wt.registerLoadRouter(Nk); -function F_(e) { +var $k = (e) => K().getBool("IS_BROWSER") && !Array.isArray(e) && e.startsWith(la.URL_SCHEME) ? P_(e.slice(la.URL_SCHEME.length)) : null; +wt.registerSaveRouter($k); +wt.registerLoadRouter($k); +function P_(e) { return new la(e); } -function O_(e) { +function z_(e) { return e.startsWith(la.URL_SCHEME) ? e.slice(la.URL_SCHEME.length) : e; } -var P_ = class { +var M_ = class { constructor() { - this.indexedDB = Ck(); + this.indexedDB = Tk(); } async listModels() { return new Promise((e, t) => { - let n = this.indexedDB.open(dm, pm); - n.onupgradeneeded = () => hm(n), n.onsuccess = () => { + let n = this.indexedDB.open(pm, hm); + n.onupgradeneeded = () => fm(n), n.onsuccess = () => { let s = n.result, r = s.transaction(ir, "readonly"), i = r.objectStore(ir).getAll(); i.onsuccess = () => { let o = {}; @@ -5450,9 +5450,9 @@ var P_ = class { }); } async removeModel(e) { - return e = O_(e), new Promise((t, n) => { - let s = this.indexedDB.open(dm, pm); - s.onupgradeneeded = () => hm(s), s.onsuccess = () => { + return e = z_(e), new Promise((t, n) => { + let s = this.indexedDB.open(pm, hm); + s.onupgradeneeded = () => fm(s), s.onsuccess = () => { let r = s.result, a = r.transaction(ir, "readwrite"), i = a.objectStore(ir), o = i.get(e), u; o.onsuccess = () => { if (o.result == null) @@ -5474,25 +5474,25 @@ var P_ = class { }; var Us = "/"; var Gi = "tensorflowjs_models"; -var Tk = "info"; -var z_ = "model_topology"; -var M_ = "weight_specs"; -var L_ = "weight_data"; -var B_ = "model_metadata"; -function $k(e) { - return { info: [Gi, e, Tk].join(Us), topology: [Gi, e, z_].join(Us), weightSpecs: [Gi, e, M_].join(Us), weightData: [Gi, e, L_].join(Us), modelMetadata: [Gi, e, B_].join(Us) }; +var _k = "info"; +var L_ = "model_topology"; +var B_ = "weight_specs"; +var V_ = "weight_data"; +var W_ = "model_metadata"; +function Ak(e) { + return { info: [Gi, e, _k].join(Us), topology: [Gi, e, L_].join(Us), weightSpecs: [Gi, e, B_].join(Us), weightData: [Gi, e, V_].join(Us), modelMetadata: [Gi, e, W_].join(Us) }; } -function _k(e) { +function Ek(e) { for (let t of Object.values(e)) window.localStorage.removeItem(t); } -function V_(e) { +function U_(e) { let t = e.split(Us); if (t.length < 3) throw new Error(`Invalid key format: ${e}`); return t.slice(1, t.length - 1).join(Us); } -function W_(e) { +function G_(e) { return e.startsWith(ca.URL_SCHEME) ? e.slice(ca.URL_SCHEME.length) : e; } var ca = class { @@ -5501,7 +5501,7 @@ var ca = class { throw new Error("The current environment does not support local storage."); if (this.LS = window.localStorage, e == null || !e) throw new Error("For local storage, modelPath must not be null, undefined or empty."); - this.modelPath = e, this.keys = $k(this.modelPath); + this.modelPath = e, this.keys = Ak(this.modelPath); } async save(e) { if (e.modelTopology instanceof ArrayBuffer) @@ -5509,11 +5509,11 @@ var ca = class { { let t = JSON.stringify(e.modelTopology), n = JSON.stringify(e.weightSpecs), s = Ml(e); try { - this.LS.setItem(this.keys.info, JSON.stringify(s)), this.LS.setItem(this.keys.topology, t), this.LS.setItem(this.keys.weightSpecs, n), this.LS.setItem(this.keys.weightData, I_(e.weightData)); + this.LS.setItem(this.keys.info, JSON.stringify(s)), this.LS.setItem(this.keys.topology, t), this.LS.setItem(this.keys.weightSpecs, n), this.LS.setItem(this.keys.weightData, N_(e.weightData)); let r = { format: e.format, generatedBy: e.generatedBy, convertedBy: e.convertedBy, signature: e.signature != null ? e.signature : void 0, userDefinedMetadata: e.userDefinedMetadata != null ? e.userDefinedMetadata : void 0, modelInitializer: e.modelInitializer != null ? e.modelInitializer : void 0, trainingConfig: e.trainingConfig != null ? e.trainingConfig : void 0 }; return this.LS.setItem(this.keys.modelMetadata, JSON.stringify(r)), { modelArtifactsInfo: s }; } catch (r) { - throw _k(this.keys), new Error(`Failed to save model '${this.modelPath}' to local storage: size quota being exceeded is a possible cause of this failure: modelTopologyBytes=${s.modelTopologyBytes}, weightSpecsBytes=${s.weightSpecsBytes}, weightDataBytes=${s.weightDataBytes}.`); + throw Ek(this.keys), new Error(`Failed to save model '${this.modelPath}' to local storage: size quota being exceeded is a possible cause of this failure: modelTopologyBytes=${s.modelTopologyBytes}, weightSpecsBytes=${s.weightSpecsBytes}, weightDataBytes=${s.weightDataBytes}.`); } } } @@ -5539,38 +5539,38 @@ var ca = class { let a = this.LS.getItem(this.keys.weightData); if (a == null) throw new Error(`In local storage, the binary weight values of model '${this.modelPath}' are missing.`); - return t.weightData = C_(a), t; + return t.weightData = T_(a), t; } }; ca.URL_SCHEME = "localstorage://"; -var Ak = (e) => K().getBool("IS_BROWSER") && !Array.isArray(e) && e.startsWith(ca.URL_SCHEME) ? U_(e.slice(ca.URL_SCHEME.length)) : null; -wt.registerSaveRouter(Ak); -wt.registerLoadRouter(Ak); -function U_(e) { +var Rk = (e) => K().getBool("IS_BROWSER") && !Array.isArray(e) && e.startsWith(ca.URL_SCHEME) ? H_(e.slice(ca.URL_SCHEME.length)) : null; +wt.registerSaveRouter(Rk); +wt.registerLoadRouter(Rk); +function H_(e) { return new ca(e); } -var G_ = class { +var q_ = class { constructor() { F(K().getBool("IS_BROWSER"), () => "Current environment is not a web browser"), F(typeof window == "undefined" || typeof window.localStorage != "undefined", () => "Current browser does not appear to support localStorage"), this.LS = window.localStorage; } async listModels() { - let e = {}, t = Gi + Us, n = Us + Tk; + let e = {}, t = Gi + Us, n = Us + _k; for (let s = 0; s < this.LS.length; ++s) { let r = this.LS.key(s); if (r.startsWith(t) && r.endsWith(n)) { - let a = V_(r); + let a = U_(r); e[a] = JSON.parse(this.LS.getItem(r)); } } return e; } async removeModel(e) { - e = W_(e); - let t = $k(e); + e = G_(e); + let t = Ak(e); if (this.LS.getItem(t.info) == null) throw new Error(`Cannot find model at path '${e}'`); let n = JSON.parse(this.LS.getItem(t.info)); - return _k(t), n; + return Ek(t), n; } }; var Ki = "://"; @@ -5601,7 +5601,7 @@ function ad(e) { throw new Error(`The url string provided does not contain a scheme. Supported schemes are: ${zn.getSchemes().join(",")}`); return { scheme: e.split(Ki)[0], path: e.split(Ki)[1] }; } -async function Ek(e, t, n = false) { +async function Dk(e, t, n = false) { F(e !== t, () => `Old path and new path are the same: '${e}'`); let s = wt.getLoadHandlers(e); F(s.length > 0, () => `Copying failed because no load handler is found for source URL ${e}.`), F(s.length < 2, () => `Copying failed because more than one (${s.length}) load handlers for source URL ${e}.`); @@ -5612,7 +5612,7 @@ async function Ek(e, t, n = false) { let p = await i.save(c); return n && !l && await zn.getManager(o).removeModel(u), p.modelArtifactsInfo; } -async function H_() { +async function j_() { let e = zn.getSchemes(), t = {}; for (let n of e) { let s = await zn.getManager(n).listModels(); @@ -5623,17 +5623,17 @@ async function H_() { } return t; } -async function q_(e) { +async function K_(e) { let t = ad(e); return zn.getManager(t.scheme).removeModel(t.path); } -async function j_(e, t) { - return Ek(e, t, false); +async function X_(e, t) { + return Dk(e, t, false); } -async function K_(e, t) { - return Ek(e, t, true); +async function Y_(e, t) { + return Dk(e, t, true); } -var X_ = class { +var Q_ = class { fetch(e, t) { return fetch(e, t); } @@ -5650,24 +5650,24 @@ var X_ = class { } }; if (K().get("IS_BROWSER")) { - K().setPlatform("browser", new X_()); + K().setPlatform("browser", new Q_()); try { - zn.registerManager(ca.URL_SCHEME, new G_()); + zn.registerManager(ca.URL_SCHEME, new q_()); } catch (e) { } try { - zn.registerManager(la.URL_SCHEME, new P_()); + zn.registerManager(la.URL_SCHEME, new M_()); } catch (e) { } } -var Y_ = { importFetch: () => s$() }; -var Gf; -var Q_ = class { +var Z_ = { importFetch: () => a$() }; +var Hf; +var J_ = class { constructor() { - this.util = r$(), this.textEncoder = new this.util.TextEncoder(); + this.util = i$(), this.textEncoder = new this.util.TextEncoder(); } fetch(e, t) { - return K().global.fetch != null ? K().global.fetch(e, t) : (Gf == null && (Gf = Y_.importFetch()), Gf(e, t)); + return K().global.fetch != null ? K().global.fetch(e, t) : (Hf == null && (Hf = Z_.importFetch()), Hf(e, t)); } now() { let e = process.hrtime(); @@ -5682,44 +5682,44 @@ var Q_ = class { return e.length === 0 ? "" : new this.util.TextDecoder(t).decode(e); } }; -K().get("IS_NODE") && !K().get("IS_BROWSER") && K().setPlatform("node", new Q_()); +K().get("IS_NODE") && !K().get("IS_BROWSER") && K().setPlatform("node", new J_()); function Ae(e, t = "float32", n) { - return t = t || "float32", cg(e), new Wt(e, t, n); + return t = t || "float32", dg(e), new Vt(e, t, n); } -function Z_(e, t) { +function eA(e, t) { let n = _(e, "x", "cast"); - if (!rk(t)) + if (!ik(t)) throw new Error(`Failed to cast to unknown dtype ${t}`); if (t === "string" && n.dtype !== "string" || t !== "string" && n.dtype === "string") throw new Error("Only strings can be casted to strings"); let s = { x: n }, r = { dtype: t }; return z.runKernel(Ta, s, r); } -var le = L({ cast_: Z_ }); -function J_(e) { +var le = L({ cast_: eA }); +function tA(e) { let n = { x: _(e, "x", "clone", "string_or_numeric") }; return z.runKernel(Wa, n); } -var ur = L({ clone_: J_ }); -function eA(e, t = false) { +var ur = L({ clone_: tA }); +function nA(e, t = false) { console.log(e.toString(t)); } -xk(); -var tA = { buffer: Ae, cast: le, clone: ur, print: eA }; -u_(tA); +kk(); +var sA = { buffer: Ae, cast: le, clone: ur, print: nA }; +c_(sA); var An = {}; -Ee(An, { browserFiles: () => uA, browserHTTPRequest: () => hA, concatenateArrayBuffers: () => Ug, copyModel: () => j_, decodeWeights: () => Sk, encodeWeights: () => k_, fromMemory: () => mA, fromMemorySync: () => Pk, getLoadHandlers: () => D_, getModelArtifactsForJSON: () => Gg, getModelArtifactsInfoForJSON: () => Ml, getSaveHandlers: () => R_, http: () => qg, isHTTPScheme: () => mm, listModels: () => H_, loadWeights: () => lA, moveModel: () => K_, registerLoadRouter: () => E_, registerSaveRouter: () => A_, removeModel: () => q_, weightsLoaderFactory: () => Dk, withSaveHandler: () => gA, withSaveHandlerSync: () => bA }); -var nA = "model"; -var sA = ".json"; -var rA = ".weights.bin"; -function bx(e) { +Ee(An, { browserFiles: () => cA, browserHTTPRequest: () => mA, concatenateArrayBuffers: () => Gg, copyModel: () => X_, decodeWeights: () => Ck, encodeWeights: () => I_, fromMemory: () => bA, fromMemorySync: () => Mk, getLoadHandlers: () => O_, getModelArtifactsForJSON: () => Hg, getModelArtifactsInfoForJSON: () => Ml, getSaveHandlers: () => F_, http: () => jg, isHTTPScheme: () => gm, listModels: () => j_, loadWeights: () => dA, moveModel: () => Y_, registerLoadRouter: () => D_, registerSaveRouter: () => R_, removeModel: () => K_, weightsLoaderFactory: () => Ok, withSaveHandler: () => yA, withSaveHandlerSync: () => vA }); +var rA = "model"; +var aA = ".json"; +var iA = ".weights.bin"; +function yx(e) { return new Promise((t) => setTimeout(t)).then(e); } -var fm = class { +var mm = class { constructor(e) { if (!K().getBool("IS_BROWSER")) throw new Error("browserDownloads() cannot proceed because the current environment is not a browser."); - e.startsWith(fm.URL_SCHEME) && (e = e.slice(fm.URL_SCHEME.length)), (e == null || e.length === 0) && (e = nA), this.modelJsonFileName = e + sA, this.weightDataFileName = e + rA; + e.startsWith(mm.URL_SCHEME) && (e = e.slice(mm.URL_SCHEME.length)), (e == null || e.length === 0) && (e = rA), this.modelJsonFileName = e + aA, this.weightDataFileName = e + iA; } async save(e) { if (typeof document == "undefined") @@ -5728,18 +5728,18 @@ var fm = class { if (e.modelTopology instanceof ArrayBuffer) throw new Error("BrowserDownloads.save() does not support saving model topology in binary formats yet."); { - let n = [{ paths: ["./" + this.weightDataFileName], weights: e.weightSpecs }], s = Ik(e, n), r = window.URL.createObjectURL(new Blob([JSON.stringify(s)], { type: "application/json" })), a = this.modelJsonAnchor == null ? document.createElement("a") : this.modelJsonAnchor; - if (a.download = this.modelJsonFileName, a.href = r, await bx(() => a.dispatchEvent(new MouseEvent("click"))), e.weightData != null) { + let n = [{ paths: ["./" + this.weightDataFileName], weights: e.weightSpecs }], s = Nk(e, n), r = window.URL.createObjectURL(new Blob([JSON.stringify(s)], { type: "application/json" })), a = this.modelJsonAnchor == null ? document.createElement("a") : this.modelJsonAnchor; + if (a.download = this.modelJsonFileName, a.href = r, await yx(() => a.dispatchEvent(new MouseEvent("click"))), e.weightData != null) { let i = this.weightDataAnchor == null ? document.createElement("a") : this.weightDataAnchor; - i.download = this.weightDataFileName, i.href = t, await bx(() => i.dispatchEvent(new MouseEvent("click"))); + i.download = this.weightDataFileName, i.href = t, await yx(() => i.dispatchEvent(new MouseEvent("click"))); } return { modelArtifactsInfo: Ml(e) }; } } }; -var Sd = fm; +var Sd = mm; Sd.URL_SCHEME = "downloads://"; -var aA = class { +var oA = class { constructor(e) { if (e == null || e.length < 1) throw new Error(`When calling browserFiles, at least 1 file is required, but received ${e}`); @@ -5762,7 +5762,7 @@ var aA = class { e({ modelTopology: a }); return; } - let o = Gg(r, (u) => this.loadWeights(u)); + let o = Hg(r, (u) => this.loadWeights(u)); e(o); }, n.onerror = (s) => t(`Failed to read model topology and weights manifest JSON from file '${this.jsonFile.name}'. BrowserFiles supports loading Keras-style tf.Model artifacts only.`), n.readAsText(this.jsonFile); }); @@ -5772,7 +5772,7 @@ var aA = class { for (let a of e) t.push(...a.weights), n.push(...a.paths); let s = this.checkManifestAndWeightFiles(e), r = n.map((a) => this.loadWeightsFile(a, s[a])); - return Promise.all(r).then((a) => [t, Ug(a)]); + return Promise.all(r).then((a) => [t, Gg(a)]); } loadWeightsFile(e, t) { return new Promise((n, s) => { @@ -5784,10 +5784,10 @@ var aA = class { }); } checkManifestAndWeightFiles(e) { - let t = [], n = this.weightsFiles.map((r) => gx(r.name)), s = {}; + let t = [], n = this.weightsFiles.map((r) => bx(r.name)), s = {}; for (let r of e) r.paths.forEach((a) => { - let i = gx(a); + let i = bx(a); if (t.indexOf(i) !== -1) throw new Error(`Duplicate file basename found in weights manifest: '${i}'`); if (t.push(i), n.indexOf(i) === -1) @@ -5799,15 +5799,15 @@ var aA = class { return s; } }; -var iA = (e) => K().getBool("IS_BROWSER") && !Array.isArray(e) && e.startsWith(Sd.URL_SCHEME) ? oA(e.slice(Sd.URL_SCHEME.length)) : null; -wt.registerSaveRouter(iA); -function oA(e = "model") { +var uA = (e) => K().getBool("IS_BROWSER") && !Array.isArray(e) && e.startsWith(Sd.URL_SCHEME) ? lA(e.slice(Sd.URL_SCHEME.length)) : null; +wt.registerSaveRouter(uA); +function lA(e = "model") { return new Sd(e); } -function uA(e) { - return new aA(e); +function cA(e) { + return new oA(e); } -function yx(e, t, n, s) { +function vx(e, t, n, s) { i(e), n = n == null ? 0 : n, s = s == null ? 1 : s, o(n, s); let r = 0, a = (u) => (u.then((l) => { let c = n + ++r / e.length * (s - n); @@ -5821,21 +5821,21 @@ function yx(e, t, n, s) { } return Promise.all(e.map(a)); } -async function Rk(e, t) { +async function Fk(e, t) { t == null && (t = {}); - let n = t.fetchFunc == null ? K().platform.fetch : t.fetchFunc, s = e.map((p) => n(p, t.requestInit, { isBinary: true })), r = 0, a = 0.5, o = (t.onProgress == null ? await Promise.all(s) : await yx(s, t.onProgress, r, a)).map((p) => p.arrayBuffer()), u = 0.5, l = 1; - return t.onProgress == null ? await Promise.all(o) : await yx(o, t.onProgress, u, l); + let n = t.fetchFunc == null ? K().platform.fetch : t.fetchFunc, s = e.map((p) => n(p, t.requestInit, { isBinary: true })), r = 0, a = 0.5, o = (t.onProgress == null ? await Promise.all(s) : await vx(s, t.onProgress, r, a)).map((p) => p.arrayBuffer()), u = 0.5, l = 1; + return t.onProgress == null ? await Promise.all(o) : await vx(o, t.onProgress, u, l); } -async function lA(e, t = "", n, s) { - return Dk((i) => Rk(i, { requestInit: s }))(e, t, n); +async function dA(e, t = "", n, s) { + return Ok((i) => Fk(i, { requestInit: s }))(e, t, n); } -function Dk(e) { +function Ok(e) { return async (t, n = "", s) => { let r = t.map(() => false), a = {}, i = s != null ? s.map(() => false) : [], o = []; if (t.forEach((h, f) => { let m = 0; h.weights.forEach((g) => { - let b = "quantization" in g ? g.quantization.dtype : g.dtype, y = cm[b] * dt(g.shape), v = () => { + let b = "quantization" in g ? g.quantization.dtype : g.dtype, y = dm[b] * dt(g.shape), v = () => { r[f] = true, a[f] == null && (a[f] = []), a[f].push({ manifestEntry: g, groupOffset: m, sizeBytes: y }); }; s != null ? s.forEach((x, k) => { @@ -5865,16 +5865,16 @@ Manifest JSON has weights with names: ${o.join(", ")}.`); b.set(k, y), y += k.byteLength; } a[h].forEach((x) => { - let k = g.slice(x.groupOffset, x.groupOffset + x.sizeBytes), I = Sk(k, [x.manifestEntry]); + let k = g.slice(x.groupOffset, x.groupOffset + x.sizeBytes), I = Ck(k, [x.manifestEntry]); for (let $ in I) p[$] = I[$]; }), d += f; }), p; }; } -var cA = "application/octet-stream"; -var dA = "application/json"; -var Hg = class { +var pA = "application/octet-stream"; +var hA = "application/json"; +var qg = class { constructor(e, t) { if (this.DEFAULT_METHOD = "POST", t == null && (t = {}), this.weightPathPrefix = t.weightPathPrefix, this.onProgress = t.onProgress, this.weightUrlConverter = t.weightUrlConverter, t.fetchFunc != null ? (F(typeof t.fetchFunc == "function", () => "Must pass a function that matches the signature of `fetch` (see https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API)"), this.fetch = t.fetchFunc) : this.fetch = K().platform.fetch, F(e != null && e.length > 0, () => "URL path for http must not be null, undefined or empty."), Array.isArray(e) && F(e.length === 2, () => `URL paths for http must have a length of 2, (actual length is ${e.length}).`), this.path = e, t.requestInit != null && t.requestInit.body != null) throw new Error("requestInit is expected to have no pre-existing body, but has one."); @@ -5885,8 +5885,8 @@ var Hg = class { throw new Error("BrowserHTTPRequest.save() does not support saving model topology in binary formats yet."); let t = Object.assign({ method: this.DEFAULT_METHOD }, this.requestInit); t.body = new FormData(); - let n = [{ paths: ["./model.weights.bin"], weights: e.weightSpecs }], s = Ik(e, n); - t.body.append("model.json", new Blob([JSON.stringify(s)], { type: dA }), "model.json"), e.weightData != null && t.body.append("model.weights.bin", new Blob([e.weightData], { type: cA }), "model.weights.bin"); + let n = [{ paths: ["./model.weights.bin"], weights: e.weightSpecs }], s = Nk(e, n); + t.body.append("model.json", new Blob([JSON.stringify(s)], { type: hA }), "model.json"), e.weightData != null && t.body.append("model.weights.bin", new Blob([e.weightData], { type: pA }), "model.weights.bin"); let r = await this.fetch(this.path, t); if (r.ok) return { modelArtifactsInfo: Ml(e), responses: [r] }; @@ -5906,10 +5906,10 @@ var Hg = class { let n = t.modelTopology, s = t.weightsManifest; if (n == null && s == null) throw new Error(`The JSON from HTTP path ${this.path} contains neither model topology or manifest for weights.`); - return Gg(t, (r) => this.loadWeights(r)); + return Hg(t, (r) => this.loadWeights(r)); } async loadWeights(e) { - let t = Array.isArray(this.path) ? this.path[1] : this.path, [n, s] = pA(t), r = this.weightPathPrefix || n, a = []; + let t = Array.isArray(this.path) ? this.path[1] : this.path, [n, s] = fA(t), r = this.weightPathPrefix || n, a = []; for (let l of e) a.push(...l.weights); let i = [], o = []; @@ -5917,37 +5917,37 @@ var Hg = class { for (let c of l.paths) this.weightUrlConverter != null ? o.push(this.weightUrlConverter(c)) : i.push(r + c + s); this.weightUrlConverter && i.push(...await Promise.all(o)); - let u = await Rk(i, { requestInit: this.requestInit, fetchFunc: this.fetch, onProgress: this.onProgress }); - return [a, Ug(u)]; + let u = await Fk(i, { requestInit: this.requestInit, fetchFunc: this.fetch, onProgress: this.onProgress }); + return [a, Gg(u)]; } }; -Hg.URL_SCHEME_REGEX = /^https?:\/\//; -function pA(e) { +qg.URL_SCHEME_REGEX = /^https?:\/\//; +function fA(e) { let t = e.lastIndexOf("/"), n = e.lastIndexOf("?"), s = e.substring(0, t), r = n > t ? e.substring(n) : ""; return [s + "/", r]; } -function mm(e) { - return e.match(Hg.URL_SCHEME_REGEX) != null; +function gm(e) { + return e.match(qg.URL_SCHEME_REGEX) != null; } -var Fk = (e, t) => { +var Pk = (e, t) => { if (typeof fetch == "undefined" && (t == null || t.fetchFunc == null)) return null; { let n = true; - if (Array.isArray(e) ? n = e.every((s) => mm(s)) : n = mm(e), n) - return qg(e, t); + if (Array.isArray(e) ? n = e.every((s) => gm(s)) : n = gm(e), n) + return jg(e, t); } return null; }; -wt.registerSaveRouter(Fk); -wt.registerLoadRouter(Fk); -function qg(e, t) { - return new Hg(e, t); +wt.registerSaveRouter(Pk); +wt.registerLoadRouter(Pk); +function jg(e, t) { + return new qg(e, t); } -function hA(e, t) { - return qg(e, t); +function mA(e, t) { + return jg(e, t); } -var Hf = class { +var qf = class { constructor(e) { this.modelArtifacts = e; } @@ -5955,7 +5955,7 @@ var Hf = class { return this.modelArtifacts; } }; -var Ok = class { +var zk = class { constructor(e) { this.saveHandler = e; } @@ -5963,120 +5963,120 @@ var Ok = class { return this.saveHandler(e); } }; -var fA = class { +var gA = class { constructor(e) { e.load && (this.load = () => Promise.resolve(e.load())), e.save && (this.save = (t) => Promise.resolve(e.save(t))); } }; -function mA(e, t, n, s) { +function bA(e, t, n, s) { let r = arguments; - return new fA(Pk(...r)); + return new gA(Mk(...r)); } -function Pk(e, t, n, s) { - return arguments.length === 1 ? e.modelTopology != null || e.weightSpecs != null ? new Hf(e) : (console.warn("Please call tf.io.fromMemory() with only one argument. The argument should be of type ModelArtifacts. The multi-argument signature of tf.io.fromMemory() has been deprecated and will be removed in a future release."), new Hf({ modelTopology: e })) : (console.warn("Please call tf.io.fromMemory() with only one argument. The argument should be of type ModelArtifacts. The multi-argument signature of tf.io.fromMemory() has been deprecated and will be removed in a future release."), new Hf({ modelTopology: e, weightSpecs: t, weightData: n, trainingConfig: s })); +function Mk(e, t, n, s) { + return arguments.length === 1 ? e.modelTopology != null || e.weightSpecs != null ? new qf(e) : (console.warn("Please call tf.io.fromMemory() with only one argument. The argument should be of type ModelArtifacts. The multi-argument signature of tf.io.fromMemory() has been deprecated and will be removed in a future release."), new qf({ modelTopology: e })) : (console.warn("Please call tf.io.fromMemory() with only one argument. The argument should be of type ModelArtifacts. The multi-argument signature of tf.io.fromMemory() has been deprecated and will be removed in a future release."), new qf({ modelTopology: e, weightSpecs: t, weightData: n, trainingConfig: s })); } -function gA(e) { - return new Ok(e); +function yA(e) { + return new zk(e); } -function bA(e) { - return new Ok(e); +function vA(e) { + return new zk(e); } -var yA = {}; -Ee(yA, { confusionMatrix: () => TA }); -function vA(e, t, n = false, s = false) { +var xA = {}; +Ee(xA, { confusionMatrix: () => _A }); +function wA(e, t, n = false, s = false) { let r = _(e, "a", "matMul"), a = _(t, "b", "matMul"); [r, a] = xt(r, a); let i = { a: r, b: a }, o = { transposeA: n, transposeB: s }; return z.runKernel(Na, i, o); } -var Ve = L({ matMul_: vA }); -function xA(e, t, n = 1, s = 0) { +var We = L({ matMul_: wA }); +function kA(e, t, n = 1, s = 0) { if (t < 2) throw new Error(`Error in oneHot: depth must be >=2, but it is ${t}`); let a = { indices: _(e, "indices", "oneHot", "int32") }, i = { depth: t, onValue: n, offValue: s }; return z.runKernel(Eo, a, i); } -var Id = L({ oneHot_: xA }); -function bpe() { +var Id = L({ oneHot_: kA }); +function vpe() { K().set("PROD", true); } -function ype() { +function xpe() { K().set("DEBUG", true); } -function vpe() { +function wpe() { K().set("DEPRECATION_WARNINGS_ENABLED", false), console.warn("TensorFlow.js deprecation warnings have been disabled."); } -function zk(e) { +function Lk(e) { K().getBool("DEPRECATION_WARNINGS_ENABLED") && console.warn(e + " You can disable deprecation warnings with tf.disableDeprecationWarnings()."); } -l_(zk); -function xpe() { +d_(Lk); +function kpe() { z.disposeVariables(); } function ds() { return z; } -function gm() { +function bm() { return z.memory(); } -function wpe(e) { +function Spe(e) { return z.profile(e); } function q(e, t) { return z.tidy(e, t); } function De(e) { - Bg(e).forEach((n) => n.dispose()); + Vg(e).forEach((n) => n.dispose()); } -function qt(e) { +function Ht(e) { return z.keep(e); } -function kpe(e) { +function Ipe(e) { return z.time(e); } -function Spe(e) { +function Cpe(e) { return z.setBackend(e); } -function Ipe() { +function Npe() { return z.ready(); } -function Cpe() { +function Tpe() { return z.backendName; } -function Npe(e) { +function $pe(e) { z.removeBackend(e); } -function Tpe(e) { +function _pe(e) { return z.findBackend(e); } -function $pe(e) { +function Ape(e) { return z.findBackendFactory(e); } -function vp(e, t, n = 1) { +function xp(e, t, n = 1) { return z.registerBackend(e, t, n); } -function wA() { +function SA() { return z.backend; } -function _pe(e, t) { +function Epe(e, t) { K().setPlatform(e, t); } -function kA(e) { +function IA(e) { let n = { input: _(e, "input", "imag") }; - return z.runKernel(ap, n); + return z.runKernel(ip, n); } -var xp = L({ imag_: kA }); -function SA(e) { +var wp = L({ imag_: IA }); +function CA(e) { let n = { x: _(e, "x", "neg") }; return z.runKernel(No, n); } -var vt = L({ neg_: SA }); -function IA(e) { +var vt = L({ neg_: CA }); +function NA(e) { let n = { input: _(e, "input", "real") }; - return z.runKernel(lp, n); + return z.runKernel(cp, n); } -var Ku = L({ real_: IA }); -function CA(e, t, n) { +var Ku = L({ real_: NA }); +function TA(e, t, n) { let s = _(e, "x", "transpose"); if (t == null && (t = s.shape.map((i, o) => o).reverse()), F(s.rank === t.length, () => `Error in transpose: rank of input ${s.rank} must match length of perm ${t}.`), t.forEach((i) => { F(i >= 0 && i < s.rank, () => `All entries in 'perm' must be between 0 and ${s.rank - 1} but got ${t}`); @@ -6084,21 +6084,21 @@ function CA(e, t, n) { return s.clone(); let r = { x: s }, a = { perm: t }; return s.dtype === "complex64" ? q(() => { - let i = Ku(s), o = xp(s); + let i = Ku(s), o = wp(s); return i = z.runKernel(Hs, { x: i }, a), o = z.runKernel(Hs, { x: o }, a), n && (o = vt(o)), fr(i, o); }) : z.runKernel(Hs, r, a); } -var Ge = L({ transpose_: CA }); -function NA(e, t, n) { +var Ge = L({ transpose_: TA }); +function $A(e, t, n) { let s = _(e, "labels", "confusionMatrix"), r = _(t, "predictions", "confusionMatrix"); F(n == null || n > 0 && Number.isInteger(n), () => `If provided, numClasses must be a positive integer, but got ${n}`), F(s.rank === 1, () => `Expected the rank of labels to be 1, but got ${s.rank}`), F(r.rank === 1, () => `Expected the rank of predictions to be 1, but got ${r.rank}`), F(s.shape[0] === r.shape[0], () => `Mismatch in the number of examples: ${s.shape[0]} vs. ${r.shape[0]}. Labels and predictions should have the same number of elements.`), F(n > 0 && Number.isInteger(n), () => `numClasses is required to be a positive integer, but got ${n}`); - let a = Id(le(s, "int32"), n), i = Id(le(r, "int32"), n), o = Ge(a), u = Ve(o, i); + let a = Id(le(s, "int32"), n), i = Id(le(r, "int32"), n), o = Ge(a), u = We(o, i); return le(u, "int32"); } -var TA = L({ confusionMatrix_: NA }); +var _A = L({ confusionMatrix_: $A }); var Xo = {}; -Ee(Xo, { assertAndGetBroadcastShape: () => rt, getBroadcastDims: () => Mk, getReductionAxes: () => At }); -function Mk(e, t) { +Ee(Xo, { assertAndGetBroadcastShape: () => rt, getBroadcastDims: () => Bk, getReductionAxes: () => _t }); +function Bk(e, t) { let n = e.length, s = []; for (let r = 0; r < n; r++) { let a = n - 1 - r, i = e[a] || 1; @@ -6106,7 +6106,7 @@ function Mk(e, t) { } return s; } -function At(e, t) { +function _t(e, t) { let n = []; for (let s = 0; s < t.length; s++) { let r = e[e.length - s - 1], a = t.length - s - 1, i = t[a]; @@ -6132,9 +6132,9 @@ function rt(e, t) { } return n; } -var Lk = {}; -Ee(Lk, { fromPixels: () => OA, fromPixelsAsync: () => DA, toPixels: () => FA }); -function $A(e, t, n) { +var Vk = {}; +Ee(Vk, { fromPixels: () => zA, fromPixelsAsync: () => OA, toPixels: () => PA }); +function AA(e, t, n) { if (ka(e), t != null && t.length !== 3) throw new Error("tensor3d() requires shape to have three numbers"); let s = Rs(e, n); @@ -6145,7 +6145,7 @@ function $A(e, t, n) { return Tr(e, t, s, n); } var Ur; -function Bk(e, t = 3) { +function Wk(e, t = 3) { if (t > 4) throw new Error("Cannot construct Tensor with more than 4 channels from pixels."); if (e == null) @@ -6167,7 +6167,7 @@ function Bk(e, t = 3) { throw new Error(`pixels passed to tf.browser.fromPixels() must be either an HTMLVideoElement, HTMLImageElement, HTMLCanvasElement, ImageData in browser, or OffscreenCanvas, ImageData in webworker or {data: Uint32Array, width: number, height: number}, but was ${e.constructor.name}`); if (r && r && e.readyState < 2) throw new Error("The video element has not loaded data yet. Please wait for `loadeddata` event on the