@vonage/ml-transformers 4.3.5 → 4.3.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -21530,7 +21530,7 @@ class b1 {
|
|
|
21530
21530
|
};
|
|
21531
21531
|
}
|
|
21532
21532
|
}
|
|
21533
|
-
const y1 = "4.3.
|
|
21533
|
+
const y1 = "4.3.6";
|
|
21534
21534
|
async function Ss(i) {
|
|
21535
21535
|
return new Promise((n) => {
|
|
21536
21536
|
setTimeout(() => {
|
|
@@ -23840,6 +23840,8 @@ class t3 {
|
|
|
23840
23840
|
case "VirtualBackground":
|
|
23841
23841
|
this.activePipeline = this.backgroundImage;
|
|
23842
23842
|
break;
|
|
23843
|
+
default:
|
|
23844
|
+
throw `Unknown transformer type [${n.transformerType}]`;
|
|
23843
23845
|
}
|
|
23844
23846
|
this.options = n;
|
|
23845
23847
|
}
|
|
@@ -24014,7 +24016,7 @@ let ho = jo;
|
|
|
24014
24016
|
(() => {
|
|
24015
24017
|
A2("ProcessorWorker", jo);
|
|
24016
24018
|
})();
|
|
24017
|
-
const Ll = "var il=Object.defineProperty;var ol=(q,X,z)=>X in q?il(q,X,{enumerable:!0,configurable:!0,writable:!0,value:z}):q[X]=z;var p=(q,X,z)=>(ol(q,typeof X!="symbol"?X+"":X,z),z);(function(){"use strict";function q(r,e){return globalThis[r]||(globalThis[r]=e),globalThis[r]}const X=q("globals",{});var z=(r=>(r.INIT="INIT",r.FORWARD="FORWARD",r.TERMINATE="TERMINATE",r.GLOBALS_SYNC="GLOBALS_SYNC",r))(z||{});function pi(r){return[ImageBitmap,ReadableStream,WritableStream].some(e=>r instanceof e)}function ze(r,e){const{id:t,type:n}=r,i=Array.isArray(e)?e:[e];postMessage({id:t,type:n,result:e},i.filter(o=>pi(o)))}q("workerized",{});function Sr(){return typeof WorkerGlobalScope<"u"&&self instanceof WorkerGlobalScope}function We(r,e){if(Array.isArray(e))e.splice(0,e.length);else if(typeof e=="object")for(const t in e)delete e[t];for(const t in r)Array.isArray(r[t])?(e[t]=[],We(r[t],e[t])):typeof r[t]=="object"?(e[t]={},We(r[t],e[t])):e[t]=r[t]}async function yi(r,e){const{functionName:t,args:n}=r;if(!e.instance)throw"instance not initialized";if(!t)throw"missing function name to call";if(!e.instance[t])throw`undefined function [${t}] in class ${e.instance.constructor.workerId}`;ze(r,await e.instance[t](...n!=null?n:[]))}const Rr=q("registeredWorkers",{});function _i(r,e){e.workerId=r,Sr()&&(Rr[e.workerId]=e)}function xi(r,e){if(!r.args)throw"Missing className while initializing worker";const[t,n]=r.args,i=Rr[t];if(i)e.instance=new i(r.args.slice(1));else throw`unknown worker class ${t}`;We(n,X),ze(r,typeof e.instance!==void 0)}async function gi(r,e){const{args:t}=r;if(!e.instance)throw"instance not initialized";let n;e.instance.terminate&&(n=await e.instance.terminate(...t!=null?t:[])),ze(r,n)}function bi(r){if(!r.args)throw"Missing globals while syncing";We(r.args[0],X),ze(r,{})}function vi(){const r={};onmessage=async e=>{const t=e.data;switch(t.type){case z.INIT:xi(t,r);break;case z.FORWARD:yi(t,r);break;case z.TERMINATE:gi(t,r);break;case z.GLOBALS_SYNC:bi(t);break}}}Sr()&&vi();var Ei=Object.defineProperty,Ti=(r,e,t)=>e in r?Ei(r,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):r[e]=t,A=(r,e,t)=>(Ti(r,typeof e!="symbol"?e+"":e,t),t);class J{}A(J,"updates",{transformer_new:"New transformer",transformer_null:"Null transformer"}),A(J,"errors",{transformer_none:"No transformers provided",transformer_start:"Cannot start transformer",transformer_transform:"Cannot transform frame",transformer_flush:"Cannot flush transformer",readable_null:"Readable is null",writable_null:"Writable is null"});const ee=new WeakMap,Ve=new WeakMap,Re=new WeakMap,Rt=Symbol("anyProducer"),Ir=Promise.resolve(),He=Symbol("listenerAdded"),Ye=Symbol("listenerRemoved");let It=!1;function be(r){if(typeof r!="string"&&typeof r!="symbol")throw new TypeError("eventName must be a string or a symbol")}function je(r){if(typeof r!="function")throw new TypeError("listener must be a function")}function ve(r,e){const t=Ve.get(r);return t.has(e)||t.set(e,new Set),t.get(e)}function Ie(r,e){const t=typeof e=="string"||typeof e=="symbol"?e:Rt,n=Re.get(r);return n.has(t)||n.set(t,new Set),n.get(t)}function Ai(r,e,t){const n=Re.get(r);if(n.has(e))for(const i of n.get(e))i.enqueue(t);if(n.has(Rt)){const i=Promise.all([e,t]);for(const o of n.get(Rt))o.enqueue(i)}}function Fr(r,e){e=Array.isArray(e)?e:[e];let t=!1,n=()=>{},i=[];const o={enqueue(s){i.push(s),n()},finish(){t=!0,n()}};for(const s of e)Ie(r,s).add(o);return{async next(){return i?i.length===0?t?(i=void 0,this.next()):(await new Promise(s=>{n=s}),this.next()):{done:!1,value:await i.shift()}:{done:!0}},async return(s){i=void 0;for(const a of e)Ie(r,a).delete(o);return n(),arguments.length>0?{done:!0,value:await s}:{done:!0}},[Symbol.asyncIterator](){return this}}}function Pr(r){if(r===void 0)return Dr;if(!Array.isArray(r))throw new TypeError("`methodNames` must be an array of strings");for(const e of r)if(!Dr.includes(e))throw typeof e!="string"?new TypeError("`methodNames` element must be a string"):new Error(`${e} is not Emittery method`);return r}const Ft=r=>r===He||r===Ye;class fe{static mixin(e,t){return t=Pr(t),n=>{if(typeof n!="function")throw new TypeError("`target` must be function");for(const s of t)if(n.prototype[s]!==void 0)throw new Error(`The property \`${s}\` already exists on \`target\``);function i(){return Object.defineProperty(this,e,{enumerable:!1,value:new fe}),this[e]}Object.defineProperty(n.prototype,e,{enumerable:!1,get:i});const o=s=>function(...a){return this[e][s](...a)};for(const s of t)Object.defineProperty(n.prototype,s,{enumerable:!1,value:o(s)});return n}}static get isDebugEnabled(){if(typeof process!="object")return It;const{env:e}=process||{env:{}};return e.DEBUG==="emittery"||e.DEBUG==="*"||It}static set isDebugEnabled(e){It=e}constructor(e={}){ee.set(this,new Set),Ve.set(this,new Map),Re.set(this,new Map),this.debug=e.debug||{},this.debug.enabled===void 0&&(this.debug.enabled=!1),this.debug.logger||(this.debug.logger=(t,n,i,o)=>{try{o=JSON.stringify(o)}catch{o=`Object with the following keys failed to stringify: ${Object.keys(o).join(",")}`}typeof i=="symbol"&&(i=i.toString());const s=new Date,a=`${s.getHours()}:${s.getMinutes()}:${s.getSeconds()}.${s.getMilliseconds()}`;console.log(`[${a}][emittery:${t}][${n}] Event Name: ${i}
	data: ${o}`)})}logIfDebugEnabled(e,t,n){(fe.isDebugEnabled||this.debug.enabled)&&this.debug.logger(e,this.debug.name,t,n)}on(e,t){je(t),e=Array.isArray(e)?e:[e];for(const n of e)be(n),ve(this,n).add(t),this.logIfDebugEnabled("subscribe",n,void 0),Ft(n)||this.emit(He,{eventName:n,listener:t});return this.off.bind(this,e,t)}off(e,t){je(t),e=Array.isArray(e)?e:[e];for(const n of e)be(n),ve(this,n).delete(t),this.logIfDebugEnabled("unsubscribe",n,void 0),Ft(n)||this.emit(Ye,{eventName:n,listener:t})}once(e){return new Promise(t=>{const n=this.on(e,i=>{n(),t(i)})})}events(e){e=Array.isArray(e)?e:[e];for(const t of e)be(t);return Fr(this,e)}async emit(e,t){be(e),this.logIfDebugEnabled("emit",e,t),Ai(this,e,t);const n=ve(this,e),i=ee.get(this),o=[...n],s=Ft(e)?[]:[...i];await Ir,await Promise.all([...o.map(async a=>{if(n.has(a))return a(t)}),...s.map(async a=>{if(i.has(a))return a(e,t)})])}async emitSerial(e,t){be(e),this.logIfDebugEnabled("emitSerial",e,t);const n=ve(this,e),i=ee.get(this),o=[...n],s=[...i];await Ir;for(const a of o)n.has(a)&&await a(t);for(const a of s)i.has(a)&&await a(e,t)}onAny(e){return je(e),this.logIfDebugEnabled("subscribeAny",void 0,void 0),ee.get(this).add(e),this.emit(He,{listener:e}),this.offAny.bind(this,e)}anyEvent(){return Fr(this)}offAny(e){je(e),this.logIfDebugEnabled("unsubscribeAny",void 0,void 0),this.emit(Ye,{listener:e}),ee.get(this).delete(e)}clearListeners(e){e=Array.isArray(e)?e:[e];for(const t of e)if(this.logIfDebugEnabled("clear",t,void 0),typeof t=="string"||typeof t=="symbol"){ve(this,t).clear();const n=Ie(this,t);for(const i of n)i.finish();n.clear()}else{ee.get(this).clear();for(const n of Ve.get(this).values())n.clear();for(const n of Re.get(this).values()){for(const i of n)i.finish();n.clear()}}}listenerCount(e){e=Array.isArray(e)?e:[e];let t=0;for(const n of e){if(typeof n=="string"){t+=ee.get(this).size+ve(this,n).size+Ie(this,n).size+Ie(this).size;continue}typeof n<"u"&&be(n),t+=ee.get(this).size;for(const i of Ve.get(this).values())t+=i.size;for(const i of Re.get(this).values())t+=i.size}return t}bindMethods(e,t){if(typeof e!="object"||e===null)throw new TypeError("`target` must be an object");t=Pr(t);for(const n of t){if(e[n]!==void 0)throw new Error(`The property \`${n}\` already exists on \`target\``);Object.defineProperty(e,n,{enumerable:!1,value:this[n].bind(this)})}}}const Dr=Object.getOwnPropertyNames(fe.prototype).filter(r=>r!=="constructor");Object.defineProperty(fe,"listenerAdded",{value:He,writable:!1,enumerable:!0,configurable:!1}),Object.defineProperty(fe,"listenerRemoved",{value:Ye,writable:!1,enumerable:!0,configurable:!1});var Pt=fe;function wi(r){return typeof r=="object"&&r!==null&&"message"in r&&typeof r.message=="string"}function Si(r){if(wi(r))return r;try{return new Error(JSON.stringify(r))}catch{return new Error(String(r))}}function Dt(r){return Si(r).message}var Ri=Object.defineProperty,Ii=(r,e,t)=>e in r?Ri(r,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):r[e]=t,Fi=(r,e,t)=>(Ii(r,typeof e!="symbol"?e+"":e,t),t);const Pi="hlg.tokbox.com/prod/logging/vcp_webrtc",Di="https://",Ni=1e4;let Xe;const Mi=new Uint8Array(16);function Ui(){if(!Xe&&(Xe=typeof crypto<"u"&&crypto.getRandomValues&&crypto.getRandomValues.bind(crypto),!Xe))throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");return Xe(Mi)}const M=[];for(let r=0;r<256;++r)M.push((r+256).toString(16).slice(1));function ki(r,e=0){return(M[r[e+0]]+M[r[e+1]]+M[r[e+2]]+M[r[e+3]]+"-"+M[r[e+4]]+M[r[e+5]]+"-"+M[r[e+6]]+M[r[e+7]]+"-"+M[r[e+8]]+M[r[e+9]]+"-"+M[r[e+10]]+M[r[e+11]]+M[r[e+12]]+M[r[e+13]]+M[r[e+14]]+M[r[e+15]]).toLowerCase()}const Ci=typeof crypto<"u"&&crypto.randomUUID&&crypto.randomUUID.bind(crypto),Nr={randomUUID:Ci};function Oi(r,e,t){if(Nr.randomUUID&&!e&&!r)return Nr.randomUUID();r=r||{};const n=r.random||(r.rng||Ui)();if(n[6]=n[6]&15|64,n[8]=n[8]&63|128,e){t=t||0;for(let i=0;i<16;++i)e[t+i]=n[i];return e}return ki(n)}function Nt(r,e){return globalThis[r]||(globalThis[r]=e),globalThis[r]}const te=Nt("globals",{});var le=(r=>(r.INIT="INIT",r.FORWARD="FORWARD",r.TERMINATE="TERMINATE",r.GLOBALS_SYNC="GLOBALS_SYNC",r))(le||{});function Mr(r){return[ImageBitmap,ReadableStream,WritableStream].some(e=>r instanceof e)}let Bi=0;function Li(r,e,t,n,i){const o=Bi++;return r.postMessage({id:o,type:e,functionName:t,args:n},n.filter(s=>Mr(s))),new Promise(s=>{i==null||i.set(o,s)})}function Fe(r,e){const{id:t,type:n}=r,i=Array.isArray(e)?e:[e];postMessage({id:t,type:n,result:e},i.filter(o=>Mr(o)))}const Ur=Nt("workerized",{});function kr(){return typeof WorkerGlobalScope<"u"&&self instanceof WorkerGlobalScope}async function Gi(){if(kr())Fe({type:le.GLOBALS_SYNC},te);else{const r=[];for(const e in Ur){const{worker:t,resolvers:n}=Ur[e].workerContext;t&&r.push(Li(t,le.GLOBALS_SYNC,"",[te],n))}await Promise.all(r)}}function Qe(r,e){if(Array.isArray(e))e.splice(0,e.length);else if(typeof e=="object")for(const t in e)delete e[t];for(const t in r)Array.isArray(r[t])?(e[t]=[],Qe(r[t],e[t])):typeof r[t]=="object"?(e[t]={},Qe(r[t],e[t])):e[t]=r[t]}async function $i(r,e){const{functionName:t,args:n}=r;if(!e.instance)throw"instance not initialized";if(!t)throw"missing function name to call";if(!e.instance[t])throw`undefined function [${t}] in class ${e.instance.constructor.workerId}`;Fe(r,await e.instance[t](...n!=null?n:[]))}const zi=Nt("registeredWorkers",{});function Wi(r,e){if(!r.args)throw"Missing className while initializing worker";const[t,n]=r.args,i=zi[t];if(i)e.instance=new i(r.args.slice(1));else throw`unknown worker class ${t}`;Qe(n,te),Fe(r,typeof e.instance!==void 0)}async function Vi(r,e){const{args:t}=r;if(!e.instance)throw"instance not initialized";let n;e.instance.terminate&&(n=await e.instance.terminate(...t!=null?t:[])),Fe(r,n)}function Hi(r){if(!r.args)throw"Missing globals while syncing";Qe(r.args[0],te),Fe(r,{})}function Yi(){const r={};onmessage=async e=>{const t=e.data;switch(t.type){case le.INIT:Wi(t,r);break;case le.FORWARD:$i(t,r);break;case le.TERMINATE:Vi(t,r);break;case le.GLOBALS_SYNC:Hi(t);break}}}kr()&&Yi();function ji(r,e){return te[r]||(te[r]=e),[()=>te[r],async t=>{te[r]=t,await Gi()}]}function Xi(r,e){return ji(r,e)}const[Qi,Ki]=Xi("metadata");function qi(r){Ki(r)}function Mt(){return Qi()}class Ut{constructor(e){Fi(this,"uuid",Oi()),this.config=e}async send(e){var t,n,i;const{appId:o,sourceType:s}=(t=Mt())!=null?t:{};if(!o||!s)return"metadata missing";const a=new AbortController,u=setTimeout(()=>a.abort(),Ni);return await((i=(n=this.config)==null?void 0:n.fetch)!=null?i:fetch)(this.getUrl(),{method:"POST",headers:this.getHeaders(),body:JSON.stringify(this.buildReport(e)),signal:a.signal}),clearTimeout(u),"success"}getUrl(){var e;let t=(e=Mt().proxyUrl)!=null?e:Di;return t+=(t.at(-1)==="/"?"":"/")+Pi,t}getHeaders(){return{"Content-Type":"application/json"}}buildReport(e){const t=Mt();return{guid:this.uuid,...e,applicationId:t.appId,timestamp:Date.now(),proxyUrl:t.proxyUrl,source:t.sourceType}}}const Ke="2.0.2";class Ji{constructor(e){A(this,"frameTransformedCount",0),A(this,"frameFromSourceCount",0),A(this,"startAt",0),A(this,"reporter"),this.config=e,this.reporter=new Ut(e)}async onFrameFromSource(){this.frameFromSourceCount++}get fps(){const{startAt:e,frameFromSourceCount:t}=this,n=(Date.now()-e)/1e3;return t/n}async onFrameTransformed(e={},t=!1){this.startAt===0&&(this.startAt=Date.now()),this.frameTransformedCount++;const{startAt:n,frameTransformedCount:i,frameFromSourceCount:o}=this,s=Date.now(),a=(s-n)/1e3,u=i/a,f=o/a;return t||this.frameTransformedCount>=this.config.loggingIntervalFrameCount?(this.frameFromSourceCount=0,this.frameTransformedCount=0,this.startAt=s,this.reporter.config=this.config,this.reporter.send({...this.config.report,variation:"QoS",fps:f,transformedFps:u,framesTransformed:i,...e})):"success"}}var kt=(r=>(r.pipeline_ended="pipeline_ended",r.pipeline_ended_with_error="pipeline_ended_with_error",r.pipeline_started="pipeline_started",r.pipeline_started_with_error="pipeline_started_with_error",r.pipeline_restarted="pipeline_restarted",r.pipeline_restarted_with_error="pipeline_restarted_with_error",r))(kt||{});const Zi=500,eo=.8;class to extends Pt{constructor(e,t){super(),A(this,"reporter_",new Ut),A(this,"reporterQos_",new Ji({loggingIntervalFrameCount:Zi,report:{version:Ke}})),A(this,"transformerType_"),A(this,"transformer_"),A(this,"shouldStop_"),A(this,"isFlashed_"),A(this,"mediaTransformerQosReportStartTimestamp_"),A(this,"videoHeight_"),A(this,"videoWidth_"),A(this,"trackExpectedRate_"),A(this,"index_"),A(this,"controller_"),this.index_=t,this.transformer_=e,this.shouldStop_=!1,this.isFlashed_=!1,this.mediaTransformerQosReportStartTimestamp_=0,this.videoHeight_=0,this.videoWidth_=0,this.trackExpectedRate_=-1,this.transformerType_="Custom","getTransformerType"in e&&(this.transformerType_=e.getTransformerType()),this.report({variation:"Create"})}setTrackExpectedRate(e){this.trackExpectedRate_=e}async start(e){if(this.controller_=e,this.transformer_&&typeof this.transformer_.start=="function")try{await this.transformer_.start(e)}catch(t){this.report({message:J.errors.transformer_start,variation:"Error",error:Dt(t)});const n={eventMetaData:{transformerIndex:this.index_},error:t,function:"start"};this.emit("error",n)}}async transform(e,t){var n,i,o,s;if(this.mediaTransformerQosReportStartTimestamp_===0&&(this.mediaTransformerQosReportStartTimestamp_=Date.now()),e instanceof VideoFrame&&(this.videoHeight_=(n=e==null?void 0:e.displayHeight)!=null?n:0,this.videoWidth_=(i=e==null?void 0:e.displayWidth)!=null?i:0),this.reporterQos_.onFrameFromSource(),this.transformer_)if(this.shouldStop_)console.warn("[Pipeline] flush from transform"),e.close(),this.flush(t),t.terminate();else{try{await((s=(o=this.transformer_).transform)==null?void 0:s.call(o,e,t)),this.reportQos()}catch(a){this.report({message:J.errors.transformer_transform,variation:"Error",error:Dt(a)});const u={eventMetaData:{transformerIndex:this.index_},error:a,function:"transform"};this.emit("error",u)}if(this.trackExpectedRate_!=-1&&this.trackExpectedRate_*eo>this.reporterQos_.fps){const a={eventMetaData:{transformerIndex:this.index_},warningType:"fps_drop",dropInfo:{requested:this.trackExpectedRate_,current:this.reporterQos_.fps}};this.emit("warn",a)}}}async flush(e){if(this.transformer_&&typeof this.transformer_.flush=="function"&&!this.isFlashed_){this.isFlashed_=!0;try{await this.transformer_.flush(e)}catch(t){this.report({message:J.errors.transformer_flush,variation:"Error",error:Dt(t)});const n={eventMetaData:{transformerIndex:this.index_},error:t,function:"flush"};this.emit("error",n)}}this.reportQos(!0),this.report({variation:"Delete"})}stop(){console.log("[Pipeline] Stop stream."),this.controller_&&(this.flush(this.controller_),this.controller_.terminate()),this.shouldStop_=!0}report(e){this.reporter_.send({version:Ke,action:"MediaTransformer",transformerType:this.transformerType_,...e})}reportQos(e=!1){this.reporterQos_.config={...this.reporterQos_.config},this.reporterQos_.onFrameTransformed({version:Ke,action:"MediaTransformer",transformerType:this.transformerType_,videoWidth:this.videoWidth_,videoHeight:this.videoHeight_},e)}}class ro extends Pt{constructor(e){super(),A(this,"transformers_"),A(this,"trackExpectedRate_"),this.transformers_=[],this.trackExpectedRate_=-1;for(let t=0;t<e.length;t++){let n=new to(e[t],t);n.on("error",i=>{this.emit("error",i)}),n.on("warn",i=>{this.emit("warn",i)}),this.transformers_.push(n)}}setTrackExpectedRate(e){this.trackExpectedRate_=e;for(let t of this.transformers_)t.setTrackExpectedRate(this.trackExpectedRate_)}async start(e,t){if(!this.transformers_||this.transformers_.length===0){console.log("[Pipeline] No transformers.");return}try{let n=e;for(let i of this.transformers_)e=e.pipeThrough(new TransformStream(i));e.pipeTo(t).then(async()=>{console.log("[Pipeline] Setup."),await t.abort(),await n.cancel(),this.emit("pipelineInfo","pipeline_ended")}).catch(async i=>{e.cancel().then(()=>{console.log("[Pipeline] Shutting down streams after abort.")}).catch(o=>{console.error("[Pipeline] Error from stream transform:",o)}),await t.abort(i),await n.cancel(i),this.emit("pipelineInfo","pipeline_ended_with_error")})}catch{this.emit("pipelineInfo","pipeline_started_with_error"),this.destroy();return}this.emit("pipelineInfo","pipeline_started"),console.log("[Pipeline] Pipeline started.")}async destroy(){console.log("[Pipeline] Destroying Pipeline.");for(let e of this.transformers_)e.stop()}}class no extends Pt{constructor(){super(),A(this,"reporter_"),A(this,"pipeline_"),A(this,"transformers_"),A(this,"readable_"),A(this,"writable_"),A(this,"trackExpectedRate_"),this.reporter_=new Ut,this.trackExpectedRate_=-1,this.report({variation:"Create"})}setTrackExpectedRate(e){this.trackExpectedRate_=e,this.pipeline_&&this.pipeline_.setTrackExpectedRate(this.trackExpectedRate_)}transform(e,t){return this.readable_=e,this.writable_=t,this.transformInternal()}transformInternal(){return new Promise(async(e,t)=>{if(!this.transformers_||this.transformers_.length===0){this.report({message:J.errors.transformer_none,variation:"Error"}),t("[MediaProcessor] Need to set transformers.");return}if(!this.readable_){this.report({variation:"Error",message:J.errors.readable_null}),t("[MediaProcessor] Readable is null.");return}if(!this.writable_){this.report({variation:"Error",message:J.errors.writable_null}),t("[MediaProcessor] Writable is null.");return}let n=!1;this.pipeline_&&(n=!0,this.pipeline_.clearListeners(),this.pipeline_.destroy()),this.pipeline_=new ro(this.transformers_),this.pipeline_.on("warn",i=>{this.emit("warn",i)}),this.pipeline_.on("error",i=>{this.emit("error",i)}),this.pipeline_.on("pipelineInfo",i=>{n&&(i==="pipeline_started"?i=kt.pipeline_restarted:i==="pipeline_started_with_error"&&(i=kt.pipeline_restarted_with_error)),this.emit("pipelineInfo",i)}),this.trackExpectedRate_!=-1&&this.pipeline_.setTrackExpectedRate(this.trackExpectedRate_),this.pipeline_.start(this.readable_,this.writable_).then(()=>{e()}).catch(i=>{t(i)})})}setTransformers(e){return this.report({variation:"Update",message:J.updates.transformer_new}),this.transformers_=e,this.readable_&&this.writable_?this.transformInternal():Promise.resolve()}destroy(){return new Promise(async e=>{this.pipeline_&&this.pipeline_.destroy(),this.report({variation:"Delete"}),e()})}report(e){this.reporter_.send({version:Ke,action:"MediaProcessor",...e})}}var io=Object.defineProperty,oo=(r,e,t)=>e in r?io(r,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):r[e]=t,so=(r,e,t)=>(oo(r,typeof e!="symbol"?e+"":e,t),t);const ao="hlg.tokbox.com/prod/logging/vcp_webrtc",uo="https://",co=1e4;let qe;const fo=new Uint8Array(16);function lo(){if(!qe&&(qe=typeof crypto<"u"&&crypto.getRandomValues&&crypto.getRandomValues.bind(crypto),!qe))throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");return qe(fo)}const U=[];for(let r=0;r<256;++r)U.push((r+256).toString(16).slice(1));function mo(r,e=0){return(U[r[e+0]]+U[r[e+1]]+U[r[e+2]]+U[r[e+3]]+"-"+U[r[e+4]]+U[r[e+5]]+"-"+U[r[e+6]]+U[r[e+7]]+"-"+U[r[e+8]]+U[r[e+9]]+"-"+U[r[e+10]]+U[r[e+11]]+U[r[e+12]]+U[r[e+13]]+U[r[e+14]]+U[r[e+15]]).toLowerCase()}const ho=typeof crypto<"u"&&crypto.randomUUID&&crypto.randomUUID.bind(crypto),Cr={randomUUID:ho};function po(r,e,t){if(Cr.randomUUID&&!e&&!r)return Cr.randomUUID();r=r||{};const n=r.random||(r.rng||lo)();if(n[6]=n[6]&15|64,n[8]=n[8]&63|128,e){t=t||0;for(let i=0;i<16;++i)e[t+i]=n[i];return e}return mo(n)}function Ct(r,e){return globalThis[r]||(globalThis[r]=e),globalThis[r]}const re=Ct("globals",{});var de=(r=>(r.INIT="INIT",r.FORWARD="FORWARD",r.TERMINATE="TERMINATE",r.GLOBALS_SYNC="GLOBALS_SYNC",r))(de||{});function Or(r){return[ImageBitmap,ReadableStream,WritableStream].some(e=>r instanceof e)}let yo=0;function _o(r,e,t,n,i){const o=yo++;return r.postMessage({id:o,type:e,functionName:t,args:n},n.filter(s=>Or(s))),new Promise(s=>{i==null||i.set(o,s)})}function Pe(r,e){const{id:t,type:n}=r,i=Array.isArray(e)?e:[e];postMessage({id:t,type:n,result:e},i.filter(o=>Or(o)))}const Br=Ct("workerized",{});function Lr(){return typeof WorkerGlobalScope<"u"&&self instanceof WorkerGlobalScope}async function xo(){if(Lr())Pe({type:de.GLOBALS_SYNC},re);else{const r=[];for(const e in Br){const{worker:t,resolvers:n}=Br[e].workerContext;t&&r.push(_o(t,de.GLOBALS_SYNC,"",[re],n))}await Promise.all(r)}}function Je(r,e){if(Array.isArray(e))e.splice(0,e.length);else if(typeof e=="object")for(const t in e)delete e[t];for(const t in r)Array.isArray(r[t])?(e[t]=[],Je(r[t],e[t])):typeof r[t]=="object"?(e[t]={},Je(r[t],e[t])):e[t]=r[t]}async function go(r,e){const{functionName:t,args:n}=r;if(!e.instance)throw"instance not initialized";if(!t)throw"missing function name to call";if(!e.instance[t])throw`undefined function [${t}] in class ${e.instance.constructor.workerId}`;Pe(r,await e.instance[t](...n!=null?n:[]))}const bo=Ct("registeredWorkers",{});function vo(r,e){if(!r.args)throw"Missing className while initializing worker";const[t,n]=r.args,i=bo[t];if(i)e.instance=new i(r.args.slice(1));else throw`unknown worker class ${t}`;Je(n,re),Pe(r,typeof e.instance!==void 0)}async function Eo(r,e){const{args:t}=r;if(!e.instance)throw"instance not initialized";let n;e.instance.terminate&&(n=await e.instance.terminate(...t!=null?t:[])),Pe(r,n)}function To(r){if(!r.args)throw"Missing globals while syncing";Je(r.args[0],re),Pe(r,{})}function Ao(){const r={};onmessage=async e=>{const t=e.data;switch(t.type){case de.INIT:vo(t,r);break;case de.FORWARD:go(t,r);break;case de.TERMINATE:Eo(t,r);break;case de.GLOBALS_SYNC:To(t);break}}}Lr()&&Ao();function wo(r,e){return re[r]||(re[r]=e),[()=>re[r],async t=>{re[r]=t,await xo()}]}function So(r,e){return wo(r,e)}const[Ro,sl]=So("metadata");function Ot(){return Ro()}class Io{constructor(e){so(this,"uuid",po()),this.config=e}async send(e){var t,n,i;const{appId:o,sourceType:s}=(t=Ot())!=null?t:{};if(!o||!s)return"metadata missing";const a=new AbortController,u=setTimeout(()=>a.abort(),co);return await((i=(n=this.config)==null?void 0:n.fetch)!=null?i:fetch)(this.getUrl(),{method:"POST",headers:this.getHeaders(),body:JSON.stringify(this.buildReport(e)),signal:a.signal}),clearTimeout(u),"success"}getUrl(){var e;let t=(e=Ot().proxyUrl)!=null?e:uo;return t+=(t.at(-1)==="/"?"":"/")+ao,t}getHeaders(){return{"Content-Type":"application/json"}}buildReport(e){const t=Ot();return{guid:this.uuid,...e,applicationId:t.appId,timestamp:Date.now(),proxyUrl:t.proxyUrl,source:t.sourceType}}}const Fo="4.3.5";var Ze=(r=>(r.Low="Low",r.High="High",r))(Ze||{});async function Gr(r){return new Promise(e=>{setTimeout(()=>{e()},r)})}class Po{constructor(e){p(this,"context");p(this,"extension");p(this,"queries",[]);p(this,"activeQuery");this.context=e,this.extension=e.getExtension("EXT_disjoint_timer_query_webgl2")}start(){}stop(){this.activeQuery&&this.context.endQuery(this.extension.TIME_ELAPSED_EXT)}pushContext(e){this.createQuery("PUSH",e)}popContext(e){this.createQuery("POP",e)}createQuery(e,t){this.activeQuery&&this.context.endQuery(this.extension.TIME_ELAPSED_EXT),this.activeQuery=this.context.createQuery(),this.context.beginQuery(this.extension.TIME_ELAPSED_EXT,this.activeQuery),this.queries.push({name:t,action:e,query:this.activeQuery})}async getResolvedQueries(){const e=(await Promise.all([...this.queries].map(t=>this.resolveQuery(t)))).filter(t=>t);for(let t=1;t<e.length;++t)e[t].timestamp+=e[t-1].duration+e[t-1].timestamp;return e}async resolveQuery(e){if(!await this.awaitQueryAvailable(e)){console.log("Unawaitable query",e);return}if(this.context.getParameter(this.extension.GPU_DISJOINT_EXT)){console.log("Disjointed query",e);return}return{...e,duration:this.context.getQueryParameter(e.query,this.context.QUERY_RESULT),timestamp:0}}async awaitQueryAvailable(e){for(let t=0;t<10;++t){if(this.context.getQueryParameter(e.query,this.context.QUERY_RESULT_AVAILABLE))return e;await Gr(200)}}}/* @license twgl.js 5.3.0 Copyright (c) 2015, Gregg Tavares All Rights Reserved.
Available via the MIT license.
see: http://github.com/greggman/twgl.js for details */const Bt=5120,De=5121,Lt=5122,Gt=5123,$t=5124,zt=5125,Wt=5126,Do=32819,No=32820,Mo=33635,Uo=5131,ko=33640,Co=35899,Oo=35902,Bo=36269,Lo=34042,$r={};{const r=$r;r[Bt]=Int8Array,r[De]=Uint8Array,r[Lt]=Int16Array,r[Gt]=Uint16Array,r[$t]=Int32Array,r[zt]=Uint32Array,r[Wt]=Float32Array,r[Do]=Uint16Array,r[No]=Uint16Array,r[Mo]=Uint16Array,r[Uo]=Uint16Array,r[ko]=Uint32Array,r[Co]=Uint32Array,r[Oo]=Uint32Array,r[Bo]=Uint32Array,r[Lo]=Uint32Array}function Vt(r){if(r instanceof Int8Array)return Bt;if(r instanceof Uint8Array||r instanceof Uint8ClampedArray)return De;if(r instanceof Int16Array)return Lt;if(r instanceof Uint16Array)return Gt;if(r instanceof Int32Array)return $t;if(r instanceof Uint32Array)return zt;if(r instanceof Float32Array)return Wt;throw new Error("unsupported typed array type")}function zr(r){if(r===Int8Array)return Bt;if(r===Uint8Array||r===Uint8ClampedArray)return De;if(r===Int16Array)return Lt;if(r===Uint16Array)return Gt;if(r===Int32Array)return $t;if(r===Uint32Array)return zt;if(r===Float32Array)return Wt;throw new Error("unsupported typed array type")}function Wr(r){const e=$r[r];if(!e)throw new Error("unknown gl type");return e}const et=typeof SharedArrayBuffer<"u"?function(e){return e&&e.buffer&&(e.buffer instanceof ArrayBuffer||e.buffer instanceof SharedArrayBuffer)}:function(e){return e&&e.buffer&&e.buffer instanceof ArrayBuffer};function Vr(...r){console.error(...r)}const Hr=new Map;function tt(r,e){if(!r||typeof r!="object")return!1;let t=Hr.get(e);t||(t=new WeakMap,Hr.set(e,t));let n=t.get(r);if(n===void 0){const i=Object.prototype.toString.call(r);n=i.substring(8,i.length-1)===e,t.set(r,n)}return n}function Go(r,e){return typeof WebGLBuffer<"u"&&tt(e,"WebGLBuffer")}function $o(r,e){return typeof WebGLRenderbuffer<"u"&&tt(e,"WebGLRenderbuffer")}function Ht(r,e){return typeof WebGLTexture<"u"&&tt(e,"WebGLTexture")}function zo(r,e){return typeof WebGLSampler<"u"&&tt(e,"WebGLSampler")}const Yr=35044,me=34962,Wo=34963,Vo=34660,Ho=5120,Yo=5121,jo=5122,Xo=5123,Qo=5124,Ko=5125,jr=5126,Xr={attribPrefix:""};function qo(r,e,t,n,i){r.bindBuffer(e,t),r.bufferData(e,n,i||Yr)}function Qr(r,e,t,n){if(Go(r,e))return e;t=t||me;const i=r.createBuffer();return qo(r,t,i,e,n),i}function Kr(r){return r==="indices"}function Jo(r){return r===Int8Array||r===Uint8Array}function Zo(r){return r.length?r:r.data}const es=/coord|texture/i,ts=/color|colour/i;function rs(r,e){let t;if(es.test(r)?t=2:ts.test(r)?t=4:t=3,e%t>0)throw new Error(`Can not guess numComponents for attribute '${r}'. Tried ${t} but ${e} values is not evenly divisible by ${t}. You should specify it.`);return t}function ns(r,e,t){return r.numComponents||r.size||rs(e,t||Zo(r).length)}function qr(r,e){if(et(r))return r;if(et(r.data))return r.data;Array.isArray(r)&&(r={data:r});let t=r.type?Yt(r.type):void 0;return t||(Kr(e)?t=Uint16Array:t=Float32Array),new t(r.data)}function is(r){return typeof r=="number"?r:r?zr(r):jr}function Yt(r){return typeof r=="number"?Wr(r):r||Float32Array}function os(r,e){return{buffer:e.buffer,numValues:2*3*4,type:is(e.type),arrayType:Yt(e.type)}}function ss(r,e){const t=e.data||e,n=Yt(e.type),i=t*n.BYTES_PER_ELEMENT,o=r.createBuffer();return r.bindBuffer(me,o),r.bufferData(me,i,e.drawType||Yr),{buffer:o,numValues:t,type:zr(n),arrayType:n}}function as(r,e,t){const n=qr(e,t);return{arrayType:n.constructor,buffer:Qr(r,n,void 0,e.drawType),type:Vt(n),numValues:0}}function us(r,e){const t={};return Object.keys(e).forEach(function(n){if(!Kr(n)){const i=e[n],o=i.attrib||i.name||i.attribName||Xr.attribPrefix+n;if(i.value){if(!Array.isArray(i.value)&&!et(i.value))throw new Error("array.value is not array or typedarray");t[o]={value:i.value}}else{let s;i.buffer&&i.buffer instanceof WebGLBuffer?s=os:typeof i=="number"||typeof i.data=="number"?s=ss:s=as;const{buffer:a,type:u,numValues:f,arrayType:d}=s(r,i,n),h=i.normalize!==void 0?i.normalize:Jo(d),y=ns(i,n,f);t[o]={buffer:a,numComponents:y,type:u,normalize:h,stride:i.stride||0,offset:i.offset||0,divisor:i.divisor===void 0?void 0:i.divisor,drawType:i.drawType}}}}),r.bindBuffer(me,null),t}function cs(r,e){return e===Ho||e===Yo?1:e===jo||e===Xo?2:e===Qo||e===Ko||e===jr?4:0}const jt=["position","positions","a_position"];function fs(r,e){let t,n;for(n=0;n<jt.length&&(t=jt[n],!(t in e||(t=Xr.attribPrefix+t,t in e)));++n);n===jt.length&&(t=Object.keys(e)[0]);const i=e[t];if(!i.buffer)return 1;r.bindBuffer(me,i.buffer);const o=r.getBufferParameter(me,Vo);r.bindBuffer(me,null);const s=cs(r,i.type),a=o/s,u=i.numComponents||i.size,f=a/u;if(f%1!==0)throw new Error(`numComponents ${u} not correct for length ${length}`);return f}function ls(r,e,t){const n=us(r,e),i=Object.assign({},t||{});i.attribs=Object.assign({},t?t.attribs:{},n);const o=e.indices;if(o){const s=qr(o,"indices");i.indices=Qr(r,s,Wo),i.numElements=s.length,i.elementType=Vt(s)}else i.numElements||(i.numElements=fs(r,i.attribs));return i}function Ne(r){return!!r.texStorage2D}const Jr=function(){const r={},e={};function t(n){const i=n.constructor.name;if(!r[i]){for(const o in n)if(typeof n[o]=="number"){const s=e[n[o]];e[n[o]]=s?`${s} | ${o}`:o}r[i]=!0}}return function(i,o){return t(i),e[o]||(typeof o=="number"?`0x${o.toString(16)}`:o)}}(),ne={textureColor:new Uint8Array([128,192,255,255]),textureOptions:{},crossOrigin:void 0},Me=et,Zr=function(){let r;return function(){return r=r||(typeof document<"u"&&document.createElement?document.createElement("canvas").getContext("2d"):null),r}}(),en=6406,Q=6407,F=6408,tn=6409,rn=6410,Ue=6402,nn=34041,rt=33071,ds=9728,ms=9729,ie=3553,oe=34067,he=32879,pe=35866,Xt=34069,hs=34070,ps=34071,ys=34072,_s=34073,xs=34074,Qt=10241,Kt=10240,nt=10242,it=10243,on=32882,gs=33082,bs=33083,vs=33084,Es=33085,qt=3317,sn=3314,an=32878,un=3316,cn=3315,fn=32877,Ts=37443,As=37441,ws=37440,Ss=33321,Rs=36756,Is=33325,Fs=33326,Ps=33330,Ds=33329,Ns=33338,Ms=33337,Us=33340,ks=33339,Cs=33323,Os=36757,Bs=33327,Ls=33328,Gs=33336,$s=33335,zs=33332,Ws=33331,Vs=33334,Hs=33333,Ys=32849,js=35905,Xs=36194,Qs=36758,Ks=35898,qs=35901,Js=34843,Zs=34837,ea=36221,ta=36239,ra=36215,na=36233,ia=36209,oa=36227,sa=32856,aa=35907,ua=36759,ca=32855,fa=32854,la=32857,da=34842,ma=34836,ha=36220,pa=36238,ya=36975,_a=36214,xa=36232,ga=36226,ba=36208,va=33189,Ea=33190,Ta=36012,Aa=36013,wa=35056,se=5120,R=5121,ot=5122,Ee=5123,st=5124,ye=5125,C=5126,ln=32819,dn=32820,mn=33635,W=5131,ke=36193,Jt=33640,Sa=35899,Ra=35902,Ia=36269,Fa=34042,at=33319,Te=33320,ut=6403,Ae=36244,we=36248,_e=36249;let Zt;function ct(r){if(!Zt){const e={};e[en]={textureFormat:en,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[1,2,2,4],type:[R,W,ke,C]},e[tn]={textureFormat:tn,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[1,2,2,4],type:[R,W,ke,C]},e[rn]={textureFormat:rn,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[2,4,4,8],type:[R,W,ke,C]},e[Q]={textureFormat:Q,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[3,6,6,12,2],type:[R,W,ke,C,mn]},e[F]={textureFormat:F,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[4,8,8,16,2,2],type:[R,W,ke,C,ln,dn]},e[Ue]={textureFormat:Ue,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[2,4],type:[ye,Ee]},e[Ss]={textureFormat:ut,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[1],type:[R]},e[Rs]={textureFormat:ut,colorRenderable:!1,textureFilterable:!0,bytesPerElement:[1],type:[se]},e[Is]={textureFormat:ut,colorRenderable:!1,textureFilterable:!0,bytesPerElement:[4,2],type:[C,W]},e[Fs]={textureFormat:ut,colorRenderable:!1,textureFilterable:!1,bytesPerElement:[4],type:[C]},e[Ps]={textureFormat:Ae,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[1],type:[R]},e[Ds]={textureFormat:Ae,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[1],type:[se]},e[zs]={textureFormat:Ae,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[2],type:[Ee]},e[Ws]={textureFormat:Ae,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[2],type:[ot]},e[Vs]={textureFormat:Ae,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[4],type:[ye]},e[Hs]={textureFormat:Ae,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[4],type:[st]},e[Cs]={textureFormat:at,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[2],type:[R]},e[Os]={textureFormat:at,colorRenderable:!1,textureFilterable:!0,bytesPerElement:[2],type:[se]},e[Bs]={textureFormat:at,colorRenderable:!1,textureFilterable:!0,bytesPerElement:[8,4],type:[C,W]},e[Ls]={textureFormat:at,colorRenderable:!1,textureFilterable:!1,bytesPerElement:[8],type:[C]},e[Gs]={textureFormat:Te,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[2],type:[R]},e[$s]={textureFormat:Te,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[2],type:[se]},e[Ns]={textureFormat:Te,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[4],type:[Ee]},e[Ms]={textureFormat:Te,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[4],type:[ot]},e[Us]={textureFormat:Te,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[8],type:[ye]},e[ks]={textureFormat:Te,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[8],type:[st]},e[Ys]={textureFormat:Q,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[3],type:[R]},e[js]={textureFormat:Q,colorRenderable:!1,textureFilterable:!0,bytesPerElement:[3],type:[R]},e[Xs]={textureFormat:Q,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[3,2],type:[R,mn]},e[Qs]={textureFormat:Q,colorRenderable:!1,textureFilterable:!0,bytesPerElement:[3],type:[se]},e[Ks]={textureFormat:Q,colorRenderable:!1,textureFilterable:!0,bytesPerElement:[12,6,4],type:[C,W,Sa]},e[qs]={textureFormat:Q,colorRenderable:!1,textureFilterable:!0,bytesPerElement:[12,6,4],type:[C,W,Ra]},e[Js]={textureFormat:Q,colorRenderable:!1,textureFilterable:!0,bytesPerElement:[12,6],type:[C,W]},e[Zs]={textureFormat:Q,colorRenderable:!1,textureFilterable:!1,bytesPerElement:[12],type:[C]},e[ea]={textureFormat:we,colorRenderable:!1,textureFilterable:!1,bytesPerElement:[3],type:[R]},e[ta]={textureFormat:we,colorRenderable:!1,textureFilterable:!1,bytesPerElement:[3],type:[se]},e[ra]={textureFormat:we,colorRenderable:!1,textureFilterable:!1,bytesPerElement:[6],type:[Ee]},e[na]={textureFormat:we,colorRenderable:!1,textureFilterable:!1,bytesPerElement:[6],type:[ot]},e[ia]={textureFormat:we,colorRenderable:!1,textureFilterable:!1,bytesPerElement:[12],type:[ye]},e[oa]={textureFormat:we,colorRenderable:!1,textureFilterable:!1,bytesPerElement:[12],type:[st]},e[sa]={textureFormat:F,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[4],type:[R]},e[aa]={textureFormat:F,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[4],type:[R]},e[ua]={textureFormat:F,colorRenderable:!1,textureFilterable:!0,bytesPerElement:[4],type:[se]},e[ca]={textureFormat:F,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[4,2,4],type:[R,dn,Jt]},e[fa]={textureFormat:F,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[4,2],type:[R,ln]},e[la]={textureFormat:F,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[4],type:[Jt]},e[da]={textureFormat:F,colorRenderable:!1,textureFilterable:!0,bytesPerElement:[16,8],type:[C,W]},e[ma]={textureFormat:F,colorRenderable:!1,textureFilterable:!1,bytesPerElement:[16],type:[C]},e[ha]={textureFormat:_e,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[4],type:[R]},e[pa]={textureFormat:_e,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[4],type:[se]},e[ya]={textureFormat:_e,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[4],type:[Jt]},e[_a]={textureFormat:_e,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[8],type:[Ee]},e[xa]={textureFormat:_e,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[8],type:[ot]},e[ga]={textureFormat:_e,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[16],type:[st]},e[ba]={textureFormat:_e,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[16],type:[ye]},e[va]={textureFormat:Ue,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[2,4],type:[Ee,ye]},e[Ea]={textureFormat:Ue,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[4],type:[ye]},e[Ta]={textureFormat:Ue,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[4],type:[C]},e[wa]={textureFormat:nn,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[4],type:[Fa]},e[Aa]={textureFormat:nn,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[4],type:[Ia]},Object.keys(e).forEach(function(t){const n=e[t];n.bytesPerElementMap={},n.bytesPerElement.forEach(function(i,o){const s=n.type[o];n.bytesPerElementMap[s]=i})}),Zt=e}return Zt[r]}function Pa(r,e){const t=ct(r);if(!t)throw"unknown internal format";const n=t.bytesPerElementMap[e];if(n===void 0)throw"unknown internal format";return n}function Ce(r){const e=ct(r);if(!e)throw"unknown internal format";return{format:e.textureFormat,type:e.type[0]}}function hn(r){return(r&r-1)===0}function Da(r,e,t,n){if(!Ne(r))return hn(e)&&hn(t);const i=ct(n);if(!i)throw"unknown internal format";return i.colorRenderable&&i.textureFilterable}function Na(r){const e=ct(r);if(!e)throw"unknown internal format";return e.textureFilterable}function Ma(r,e,t){return Me(e)?Vt(e):t||R}function ft(r,e,t,n,i){if(i%1!==0)throw"can't guess dimensions";if(!t&&!n){const o=Math.sqrt(i/(e===oe?6:1));o%1===0?(t=o,n=o):(t=i,n=1)}else if(n){if(!t&&(t=i/n,t%1))throw"can't guess dimensions"}else if(n=i/t,n%1)throw"can't guess dimensions";return{width:t,height:n}}function Se(r,e){e.colorspaceConversion!==void 0&&r.pixelStorei(Ts,e.colorspaceConversion),e.premultiplyAlpha!==void 0&&r.pixelStorei(As,e.premultiplyAlpha),e.flipY!==void 0&&r.pixelStorei(ws,e.flipY)}function pn(r){r.pixelStorei(qt,4),Ne(r)&&(r.pixelStorei(sn,0),r.pixelStorei(an,0),r.pixelStorei(un,0),r.pixelStorei(cn,0),r.pixelStorei(fn,0))}function Ua(r,e,t,n){n.minMag&&(t.call(r,e,Qt,n.minMag),t.call(r,e,Kt,n.minMag)),n.min&&t.call(r,e,Qt,n.min),n.mag&&t.call(r,e,Kt,n.mag),n.wrap&&(t.call(r,e,nt,n.wrap),t.call(r,e,it,n.wrap),(e===he||zo(r,e))&&t.call(r,e,on,n.wrap)),n.wrapR&&t.call(r,e,on,n.wrapR),n.wrapS&&t.call(r,e,nt,n.wrapS),n.wrapT&&t.call(r,e,it,n.wrapT),n.minLod&&t.call(r,e,gs,n.minLod),n.maxLod&&t.call(r,e,bs,n.maxLod),n.baseLevel&&t.call(r,e,vs,n.baseLevel),n.maxLevel&&t.call(r,e,Es,n.maxLevel)}function yn(r,e,t){const n=t.target||ie;r.bindTexture(n,e),Ua(r,n,r.texParameteri,t)}function ka(r){return r=r||ne.textureColor,Me(r)?r:new Uint8Array([r[0]*255,r[1]*255,r[2]*255,r[3]*255])}function er(r,e,t,n,i,o){t=t||ne.textureOptions,o=o||F;const s=t.target||ie;if(n=n||t.width,i=i||t.height,r.bindTexture(s,e),Da(r,n,i,o))r.generateMipmap(s);else{const a=Na(o)?ms:ds;r.texParameteri(s,Qt,a),r.texParameteri(s,Kt,a),r.texParameteri(s,nt,rt),r.texParameteri(s,it,rt)}}function Oe(r){return r.auto===!0||r.auto===void 0&&r.level===void 0}function tr(r,e){return e=e||{},e.cubeFaceOrder||[Xt,hs,ps,ys,_s,xs]}function rr(r,e){const n=tr(r,e).map(function(i,o){return{face:i,ndx:o}});return n.sort(function(i,o){return i.face-o.face}),n}function _n(r,e,t,n){n=n||ne.textureOptions;const i=n.target||ie,o=n.level||0;let s=t.width,a=t.height;const u=n.internalFormat||n.format||F,f=Ce(u),d=n.format||f.format,h=n.type||f.type;if(Se(r,n),r.bindTexture(i,e),i===oe){const y=t.width,x=t.height;let l,g;if(y/6===x)l=x,g=[0,0,1,0,2,0,3,0,4,0,5,0];else if(x/6===y)l=y,g=[0,0,0,1,0,2,0,3,0,4,0,5];else if(y/3===x/2)l=y/3,g=[0,0,1,0,2,0,0,1,1,1,2,1];else if(y/2===x/3)l=y/2,g=[0,0,1,0,0,1,1,1,0,2,1,2];else throw"can't figure out cube map from element: "+(t.src?t.src:t.nodeName);const E=Zr();E?(E.canvas.width=l,E.canvas.height=l,s=l,a=l,rr(r,n).forEach(function(v){const I=g[v.ndx*2+0]*l,D=g[v.ndx*2+1]*l;E.drawImage(t,I,D,l,l,0,0,l,l),r.texImage2D(v.face,o,u,d,h,E.canvas)}),E.canvas.width=1,E.canvas.height=1):typeof createImageBitmap<"u"&&(s=l,a=l,rr(r,n).forEach(function(v){const I=g[v.ndx*2+0]*l,D=g[v.ndx*2+1]*l;r.texImage2D(v.face,o,u,l,l,0,d,h,null),createImageBitmap(t,I,D,l,l,{premultiplyAlpha:"none",colorSpaceConversion:"none"}).then(function(G){Se(r,n),r.bindTexture(i,e),r.texImage2D(v.face,o,u,d,h,G),Oe(n)&&er(r,e,n,s,a,u)})}))}else if(i===he||i===pe){const y=Math.min(t.width,t.height),x=Math.max(t.width,t.height),l=x/y;if(l%1!==0)throw"can not compute 3D dimensions of element";const g=t.width===x?1:0,E=t.height===x?1:0;r.pixelStorei(qt,1),r.pixelStorei(sn,t.width),r.pixelStorei(an,0),r.pixelStorei(fn,0),r.texImage3D(i,o,u,y,y,y,0,d,h,null);for(let v=0;v<l;++v){const I=v*y*g,D=v*y*E;r.pixelStorei(un,I),r.pixelStorei(cn,D),r.texSubImage3D(i,o,0,0,v,y,y,1,d,h,t)}pn(r)}else r.texImage2D(i,o,u,d,h,t);Oe(n)&&er(r,e,n,s,a,u),yn(r,e,n)}function Be(){}function Ca(r){if(typeof document<"u"){const e=document.createElement("a");return e.href=r,e.hostname===location.hostname&&e.port===location.port&&e.protocol===location.protocol}else{const e=new URL(location.href).origin;return new URL(r,location.href).origin===e}}function Oa(r,e){return e===void 0&&!Ca(r)?"anonymous":e}function Ba(r,e,t){t=t||Be;let n;if(e=e!==void 0?e:ne.crossOrigin,e=Oa(r,e),typeof Image<"u"){n=new Image,e!==void 0&&(n.crossOrigin=e);const i=function(){n.removeEventListener("error",o),n.removeEventListener("load",s),n=null},o=function(){const u="couldn't load image: "+r;Vr(u),t(u,n),i()},s=function(){t(null,n),i()};return n.addEventListener("error",o),n.addEventListener("load",s),n.src=r,n}else if(typeof ImageBitmap<"u"){let i,o;const s=function(){t(i,o)},a={};e&&(a.mode="cors"),fetch(r,a).then(function(u){if(!u.ok)throw u;return u.blob()}).then(function(u){return createImageBitmap(u,{premultiplyAlpha:"none",colorSpaceConversion:"none"})}).then(function(u){o=u,setTimeout(s)}).catch(function(u){i=u,setTimeout(s)}),n=null}return n}function xn(r){return typeof ImageBitmap<"u"&&r instanceof ImageBitmap||typeof ImageData<"u"&&r instanceof ImageData||typeof HTMLElement<"u"&&r instanceof HTMLElement}function nr(r,e,t){return xn(r)?(setTimeout(function(){t(null,r)}),r):Ba(r,e,t)}function ir(r,e,t){t=t||ne.textureOptions;const n=t.target||ie;if(r.bindTexture(n,e),t.color===!1)return;const i=ka(t.color);if(n===oe)for(let o=0;o<6;++o)r.texImage2D(Xt+o,0,F,1,1,0,F,R,i);else n===he||n===pe?r.texImage3D(n,0,F,1,1,1,0,F,R,i):r.texImage2D(n,0,F,1,1,0,F,R,i)}function La(r,e,t,n){return n=n||Be,t=t||ne.textureOptions,ir(r,e,t),t=Object.assign({},t),nr(t.src,t.crossOrigin,function(o,s){o?n(o,e,s):(_n(r,e,s,t),n(null,e,s))})}function Ga(r,e,t,n){n=n||Be;const i=t.src;if(i.length!==6)throw"there must be 6 urls for a cubemap";const o=t.level||0,s=t.internalFormat||t.format||F,a=Ce(s),u=t.format||a.format,f=t.type||R,d=t.target||ie;if(d!==oe)throw"target must be TEXTURE_CUBE_MAP";ir(r,e,t),t=Object.assign({},t);let h=6;const y=[],x=tr(r,t);let l;function g(E){return function(v,I){--h,v?y.push(v):I.width!==I.height?y.push("cubemap face img is not a square: "+I.src):(Se(r,t),r.bindTexture(d,e),h===5?tr().forEach(function(D){r.texImage2D(D,o,s,u,f,I)}):r.texImage2D(E,o,s,u,f,I),Oe(t)&&r.generateMipmap(d)),h===0&&n(y.length?y:void 0,e,l)}}l=i.map(function(E,v){return nr(E,t.crossOrigin,g(x[v]))})}function $a(r,e,t,n){n=n||Be;const i=t.src,o=t.internalFormat||t.format||F,s=Ce(o),a=t.format||s.format,u=t.type||R,f=t.target||pe;if(f!==he&&f!==pe)throw"target must be TEXTURE_3D or TEXTURE_2D_ARRAY";ir(r,e,t),t=Object.assign({},t);let d=i.length;const h=[];let y;const x=t.level||0;let l=t.width,g=t.height;const E=i.length;let v=!0;function I(D){return function(G,$){if(--d,G)h.push(G);else{if(Se(r,t),r.bindTexture(f,e),v){v=!1,l=t.width||$.width,g=t.height||$.height,r.texImage3D(f,x,o,l,g,E,0,a,u,null);for(let Z=0;Z<E;++Z)r.texSubImage3D(f,x,0,0,Z,l,g,1,a,u,$)}else{let Z=$,H;($.width!==l||$.height!==g)&&(H=Zr(),Z=H.canvas,H.canvas.width=l,H.canvas.height=g,H.drawImage($,0,0,l,g)),r.texSubImage3D(f,x,0,0,D,l,g,1,a,u,Z),H&&Z===H.canvas&&(H.canvas.width=0,H.canvas.height=0)}Oe(t)&&r.generateMipmap(f)}d===0&&n(h.length?h:void 0,e,y)}}y=i.map(function(D,G){return nr(D,t.crossOrigin,I(G))})}function za(r,e,t,n){n=n||ne.textureOptions;const i=n.target||ie;r.bindTexture(i,e);let o=n.width,s=n.height,a=n.depth;const u=n.level||0,f=n.internalFormat||n.format||F,d=Ce(f),h=n.format||d.format,y=n.type||Ma(r,t,d.type);if(Me(t))t instanceof Uint8ClampedArray&&(t=new Uint8Array(t.buffer));else{const E=Wr(y);t=new E(t)}const x=Pa(f,y),l=t.byteLength/x;if(l%1)throw"length wrong size for format: "+Jr(r,h);let g;if(i===he||i===pe)if(!o&&!s&&!a){const E=Math.cbrt(l);if(E%1!==0)throw"can't guess cube size of array of numElements: "+l;o=E,s=E,a=E}else o&&(!s||!a)?(g=ft(r,i,s,a,l/o),s=g.width,a=g.height):s&&(!o||!a)?(g=ft(r,i,o,a,l/s),o=g.width,a=g.height):(g=ft(r,i,o,s,l/a),o=g.width,s=g.height);else g=ft(r,i,o,s,l),o=g.width,s=g.height;if(pn(r),r.pixelStorei(qt,n.unpackAlignment||1),Se(r,n),i===oe){const E=x/t.BYTES_PER_ELEMENT,v=l/6*E;rr(r,n).forEach(I=>{const D=v*I.ndx,G=t.subarray(D,D+v);r.texImage2D(I.face,u,f,o,s,0,h,y,G)})}else i===he||i===pe?r.texImage3D(i,u,f,o,s,a,0,h,y,t):r.texImage2D(i,u,f,o,s,0,h,y,t);return{width:o,height:s,depth:a,type:y}}function Wa(r,e,t){const n=t.target||ie;r.bindTexture(n,e);const i=t.level||0,o=t.internalFormat||t.format||F,s=Ce(o),a=t.format||s.format,u=t.type||s.type;if(Se(r,t),n===oe)for(let f=0;f<6;++f)r.texImage2D(Xt+f,i,o,t.width,t.height,0,a,u,null);else n===he||n===pe?r.texImage3D(n,i,o,t.width,t.height,t.depth,0,a,u,null):r.texImage2D(n,i,o,t.width,t.height,0,a,u,null)}function gn(r,e,t){t=t||Be,e=e||ne.textureOptions;const n=r.createTexture(),i=e.target||ie;let o=e.width||1,s=e.height||1;const a=e.internalFormat||F;r.bindTexture(i,n),i===oe&&(r.texParameteri(i,nt,rt),r.texParameteri(i,it,rt));let u=e.src;if(u)if(typeof u=="function"&&(u=u(r,e)),typeof u=="string")La(r,n,e,t);else if(Me(u)||Array.isArray(u)&&(typeof u[0]=="number"||Array.isArray(u[0])||Me(u[0]))){const f=za(r,n,u,e);o=f.width,s=f.height}else Array.isArray(u)&&(typeof u[0]=="string"||xn(u[0]))?i===oe?Ga(r,n,e,t):$a(r,n,e,t):(_n(r,n,u,e),o=u.width,s=u.height);else Wa(r,n,e);return Oe(e)&&er(r,n,e,o,s,a),yn(r,n,e),n}const or=Vr;function bn(r){return typeof document<"u"&&document.getElementById?document.getElementById(r):null}const lt=33984,dt=34962,Va=34963,Ha=35713,Ya=35714,ja=35632,Xa=35633,Qa=35981,vn=35718,Ka=35721,qa=35971,Ja=35382,Za=35396,eu=35398,tu=35392,ru=35395,mt=5126,En=35664,Tn=35665,An=35666,sr=5124,wn=35667,Sn=35668,Rn=35669,In=35670,Fn=35671,Pn=35672,Dn=35673,Nn=35674,Mn=35675,Un=35676,nu=35678,iu=35680,ou=35679,su=35682,au=35685,uu=35686,cu=35687,fu=35688,lu=35689,du=35690,mu=36289,hu=36292,pu=36293,ar=5125,kn=36294,Cn=36295,On=36296,yu=36298,_u=36299,xu=36300,gu=36303,bu=36306,vu=36307,Eu=36308,Tu=36311,ht=3553,pt=34067,ur=32879,yt=35866,b={};function Bn(r,e){return b[e].bindPoint}function Au(r,e){return function(t){r.uniform1f(e,t)}}function wu(r,e){return function(t){r.uniform1fv(e,t)}}function Su(r,e){return function(t){r.uniform2fv(e,t)}}function Ru(r,e){return function(t){r.uniform3fv(e,t)}}function Iu(r,e){return function(t){r.uniform4fv(e,t)}}function Ln(r,e){return function(t){r.uniform1i(e,t)}}function Gn(r,e){return function(t){r.uniform1iv(e,t)}}function $n(r,e){return function(t){r.uniform2iv(e,t)}}function zn(r,e){return function(t){r.uniform3iv(e,t)}}function Wn(r,e){return function(t){r.uniform4iv(e,t)}}function Fu(r,e){return function(t){r.uniform1ui(e,t)}}function Pu(r,e){return function(t){r.uniform1uiv(e,t)}}function Du(r,e){return function(t){r.uniform2uiv(e,t)}}function Nu(r,e){return function(t){r.uniform3uiv(e,t)}}function Mu(r,e){return function(t){r.uniform4uiv(e,t)}}function Uu(r,e){return function(t){r.uniformMatrix2fv(e,!1,t)}}function ku(r,e){return function(t){r.uniformMatrix3fv(e,!1,t)}}function Cu(r,e){return function(t){r.uniformMatrix4fv(e,!1,t)}}function Ou(r,e){return function(t){r.uniformMatrix2x3fv(e,!1,t)}}function Bu(r,e){return function(t){r.uniformMatrix3x2fv(e,!1,t)}}function Lu(r,e){return function(t){r.uniformMatrix2x4fv(e,!1,t)}}function Gu(r,e){return function(t){r.uniformMatrix4x2fv(e,!1,t)}}function $u(r,e){return function(t){r.uniformMatrix3x4fv(e,!1,t)}}function zu(r,e){return function(t){r.uniformMatrix4x3fv(e,!1,t)}}function B(r,e,t,n){const i=Bn(r,e);return Ne(r)?function(o){let s,a;!o||Ht(r,o)?(s=o,a=null):(s=o.texture,a=o.sampler),r.uniform1i(n,t),r.activeTexture(lt+t),r.bindTexture(i,s),r.bindSampler(t,a)}:function(o){r.uniform1i(n,t),r.activeTexture(lt+t),r.bindTexture(i,o)}}function L(r,e,t,n,i){const o=Bn(r,e),s=new Int32Array(i);for(let a=0;a<i;++a)s[a]=t+a;return Ne(r)?function(a){r.uniform1iv(n,s),a.forEach(function(u,f){r.activeTexture(lt+s[f]);let d,h;Ht(r,u)?(d=u,h=null):(d=u.texture,h=u.sampler),r.bindSampler(t,h),r.bindTexture(o,d)})}:function(a){r.uniform1iv(n,s),a.forEach(function(u,f){r.activeTexture(lt+s[f]),r.bindTexture(o,u)})}}b[mt]={Type:Float32Array,size:4,setter:Au,arraySetter:wu},b[En]={Type:Float32Array,size:8,setter:Su,cols:2},b[Tn]={Type:Float32Array,size:12,setter:Ru,cols:3},b[An]={Type:Float32Array,size:16,setter:Iu,cols:4},b[sr]={Type:Int32Array,size:4,setter:Ln,arraySetter:Gn},b[wn]={Type:Int32Array,size:8,setter:$n,cols:2},b[Sn]={Type:Int32Array,size:12,setter:zn,cols:3},b[Rn]={Type:Int32Array,size:16,setter:Wn,cols:4},b[ar]={Type:Uint32Array,size:4,setter:Fu,arraySetter:Pu},b[kn]={Type:Uint32Array,size:8,setter:Du,cols:2},b[Cn]={Type:Uint32Array,size:12,setter:Nu,cols:3},b[On]={Type:Uint32Array,size:16,setter:Mu,cols:4},b[In]={Type:Uint32Array,size:4,setter:Ln,arraySetter:Gn},b[Fn]={Type:Uint32Array,size:8,setter:$n,cols:2},b[Pn]={Type:Uint32Array,size:12,setter:zn,cols:3},b[Dn]={Type:Uint32Array,size:16,setter:Wn,cols:4},b[Nn]={Type:Float32Array,size:32,setter:Uu,rows:2,cols:2},b[Mn]={Type:Float32Array,size:48,setter:ku,rows:3,cols:3},b[Un]={Type:Float32Array,size:64,setter:Cu,rows:4,cols:4},b[au]={Type:Float32Array,size:32,setter:Ou,rows:2,cols:3},b[uu]={Type:Float32Array,size:32,setter:Lu,rows:2,cols:4},b[cu]={Type:Float32Array,size:48,setter:Bu,rows:3,cols:2},b[fu]={Type:Float32Array,size:48,setter:$u,rows:3,cols:4},b[lu]={Type:Float32Array,size:64,setter:Gu,rows:4,cols:2},b[du]={Type:Float32Array,size:64,setter:zu,rows:4,cols:3},b[nu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:ht},b[iu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:pt},b[ou]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:ur},b[su]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:ht},b[mu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:yt},b[hu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:yt},b[pu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:pt},b[yu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:ht},b[_u]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:ur},b[xu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:pt},b[gu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:yt},b[bu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:ht},b[vu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:ur},b[Eu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:pt},b[Tu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:yt};function _t(r,e){return function(t){if(t.value)switch(r.disableVertexAttribArray(e),t.value.length){case 4:r.vertexAttrib4fv(e,t.value);break;case 3:r.vertexAttrib3fv(e,t.value);break;case 2:r.vertexAttrib2fv(e,t.value);break;case 1:r.vertexAttrib1fv(e,t.value);break;default:throw new Error("the length of a float constant value must be between 1 and 4!")}else r.bindBuffer(dt,t.buffer),r.enableVertexAttribArray(e),r.vertexAttribPointer(e,t.numComponents||t.size,t.type||mt,t.normalize||!1,t.stride||0,t.offset||0),r.vertexAttribDivisor&&r.vertexAttribDivisor(e,t.divisor||0)}}function ae(r,e){return function(t){if(t.value)if(r.disableVertexAttribArray(e),t.value.length===4)r.vertexAttrib4iv(e,t.value);else throw new Error("The length of an integer constant value must be 4!");else r.bindBuffer(dt,t.buffer),r.enableVertexAttribArray(e),r.vertexAttribIPointer(e,t.numComponents||t.size,t.type||sr,t.stride||0,t.offset||0),r.vertexAttribDivisor&&r.vertexAttribDivisor(e,t.divisor||0)}}function xt(r,e){return function(t){if(t.value)if(r.disableVertexAttribArray(e),t.value.length===4)r.vertexAttrib4uiv(e,t.value);else throw new Error("The length of an unsigned integer constant value must be 4!");else r.bindBuffer(dt,t.buffer),r.enableVertexAttribArray(e),r.vertexAttribIPointer(e,t.numComponents||t.size,t.type||ar,t.stride||0,t.offset||0),r.vertexAttribDivisor&&r.vertexAttribDivisor(e,t.divisor||0)}}function cr(r,e,t){const n=t.size,i=t.count;return function(o){r.bindBuffer(dt,o.buffer);const s=o.size||o.numComponents||n,a=s/i,u=o.type||mt,d=b[u].size*s,h=o.normalize||!1,y=o.offset||0,x=d/i;for(let l=0;l<i;++l)r.enableVertexAttribArray(e+l),r.vertexAttribPointer(e+l,a,u,h,d,y+x*l),r.vertexAttribDivisor&&r.vertexAttribDivisor(e+l,o.divisor||0)}}const P={};P[mt]={size:4,setter:_t},P[En]={size:8,setter:_t},P[Tn]={size:12,setter:_t},P[An]={size:16,setter:_t},P[sr]={size:4,setter:ae},P[wn]={size:8,setter:ae},P[Sn]={size:12,setter:ae},P[Rn]={size:16,setter:ae},P[ar]={size:4,setter:xt},P[kn]={size:8,setter:xt},P[Cn]={size:12,setter:xt},P[On]={size:16,setter:xt},P[In]={size:4,setter:ae},P[Fn]={size:8,setter:ae},P[Pn]={size:12,setter:ae},P[Dn]={size:16,setter:ae},P[Nn]={size:4,setter:cr,count:2},P[Mn]={size:9,setter:cr,count:3},P[Un]={size:16,setter:cr,count:4};const Wu=/ERROR:\s*\d+:(\d+)/gi;function Vu(r,e="",t=0){const n=[...e.matchAll(Wu)],i=new Map(n.map((o,s)=>{const a=parseInt(o[1]),u=n[s+1],f=u?u.index:e.length,d=e.substring(o.index,f);return[a-1,d]}));return r.split(`
`).map((o,s)=>{const a=i.get(s);return`${s+1+t}: ${o}${a?`

^^^ ${a}`:""}`}).join(`
`)}const Vn=/^[ \t]*\n/;function Hn(r){let e=0;return Vn.test(r)&&(e=1,r=r.replace(Vn,"")),{lineOffset:e,shaderSource:r}}function Hu(r,e){return r.errorCallback(e),r.callback&&setTimeout(()=>{r.callback(`${e}
${r.errors.join(`
`)}`)}),null}function Yu(r,e,t,n){if(n=n||or,!r.getShaderParameter(t,Ha)){const o=r.getShaderInfoLog(t),{lineOffset:s,shaderSource:a}=Hn(r.getShaderSource(t)),u=`${Vu(a,o,s)}
Error compiling ${Jr(r,e)}: ${o}`;return n(u),u}return""}function fr(r,e,t){let n,i,o;if(typeof e=="function"&&(t=e,e=void 0),typeof r=="function")t=r,r=void 0;else if(r&&!Array.isArray(r)){const f=r;t=f.errorCallback,r=f.attribLocations,n=f.transformFeedbackVaryings,i=f.transformFeedbackMode,o=f.callback}const s=t||or,a=[],u={errorCallback(f,...d){a.push(f),s(f,...d)},transformFeedbackVaryings:n,transformFeedbackMode:i,callback:o,errors:a};{let f={};Array.isArray(r)?r.forEach(function(d,h){f[d]=e?e[h]:h}):f=r||{},u.attribLocations=f}return u}const ju=["VERTEX_SHADER","FRAGMENT_SHADER"];function Xu(r,e){if(e.indexOf("frag")>=0)return ja;if(e.indexOf("vert")>=0)return Xa}function Qu(r,e,t){const n=r.getAttachedShaders(e);for(const i of n)t.has(i)&&r.deleteShader(i);r.deleteProgram(e)}const Ku=(r=0)=>new Promise(e=>setTimeout(e,r));function qu(r,e,t){const n=r.createProgram(),{attribLocations:i,transformFeedbackVaryings:o,transformFeedbackMode:s}=fr(t);for(let a=0;a<e.length;++a){let u=e[a];if(typeof u=="string"){const f=bn(u),d=f?f.text:u;let h=r[ju[a]];f&&f.type&&(h=Xu(r,f.type)||h),u=r.createShader(h),r.shaderSource(u,Hn(d).shaderSource),r.compileShader(u),r.attachShader(n,u)}}Object.entries(i).forEach(([a,u])=>r.bindAttribLocation(n,u,a));{let a=o;a&&(a.attribs&&(a=a.attribs),Array.isArray(a)||(a=Object.keys(a)),r.transformFeedbackVaryings(n,a,s||Qa))}return r.linkProgram(n),n}function Ju(r,e,t,n,i){const o=fr(t,n,i),s=new Set(e),a=qu(r,e,o);function u(f,d){const h=ec(f,d,o.errorCallback);return h&&Qu(f,d,s),h}if(o.callback){Zu(r,a).then(()=>{const f=u(r,a);o.callback(f,f?void 0:a)});return}return u(r,a)?void 0:a}async function Zu(r,e){const t=r.getExtension("KHR_parallel_shader_compile"),n=t?(o,s)=>o.getProgramParameter(s,t.COMPLETION_STATUS_KHR):()=>!0;let i=0;do await Ku(i),i=1e3/60;while(!n(r,e))}function ec(r,e,t){if(t=t||or,!r.getProgramParameter(e,Ya)){const i=r.getProgramInfoLog(e);t(`Error in program linking: ${i}`);const s=r.getAttachedShaders(e).map(a=>Yu(r,r.getShaderParameter(a,r.SHADER_TYPE),a,t));return`${i}
${s.filter(a=>a).join(`
`)}`}}function tc(r,e,t,n,i){return Ju(r,e,t,n,i)}function Yn(r){const e=r.name;return e.startsWith("gl_")||e.startsWith("webgl_")}const rc=/(\.|\[|]|\w+)/g,nc=r=>r>="0"&&r<="9";function ic(r,e,t,n){const i=r.split(rc).filter(a=>a!=="");let o=0,s="";for(;;){const a=i[o++];s+=a;const u=nc(a[0]),f=u?parseInt(a):a;if(u&&(s+=i[o++]),o===i.length){t[f]=e;break}else{const h=i[o++],y=h==="[",x=t[f]||(y?[]:{});t[f]=x,t=x,n[s]=n[s]||function(l){return function(g){jn(l,g)}}(x),s+=h}}}function oc(r,e){let t=0;function n(a,u,f){const d=u.name.endsWith("[0]"),h=u.type,y=b[h];if(!y)throw new Error(`unknown type: 0x${h.toString(16)}`);let x;if(y.bindPoint){const l=t;t+=u.size,d?x=y.arraySetter(r,h,l,f,u.size):x=y.setter(r,h,l,f,u.size)}else y.arraySetter&&d?x=y.arraySetter(r,f):x=y.setter(r,f);return x.location=f,x}const i={},o={},s=r.getProgramParameter(e,vn);for(let a=0;a<s;++a){const u=r.getActiveUniform(e,a);if(Yn(u))continue;let f=u.name;f.endsWith("[0]")&&(f=f.substr(0,f.length-3));const d=r.getUniformLocation(e,u.name);if(d){const h=n(e,u,d);i[f]=h,ic(f,h,o,i)}}return i}function sc(r,e){const t={},n=r.getProgramParameter(e,qa);for(let i=0;i<n;++i){const o=r.getTransformFeedbackVarying(e,i);t[o.name]={index:i,type:o.type,size:o.size}}return t}function ac(r,e){const t=r.getProgramParameter(e,vn),n=[],i=[];for(let a=0;a<t;++a){i.push(a),n.push({});const u=r.getActiveUniform(e,a);n[a].name=u.name}[["UNIFORM_TYPE","type"],["UNIFORM_SIZE","size"],["UNIFORM_BLOCK_INDEX","blockNdx"],["UNIFORM_OFFSET","offset"]].forEach(function(a){const u=a[0],f=a[1];r.getActiveUniforms(e,i,r[u]).forEach(function(d,h){n[h][f]=d})});const o={},s=r.getProgramParameter(e,Ja);for(let a=0;a<s;++a){const u=r.getActiveUniformBlockName(e,a),f={index:r.getUniformBlockIndex(e,u),usedByVertexShader:r.getActiveUniformBlockParameter(e,a,Za),usedByFragmentShader:r.getActiveUniformBlockParameter(e,a,eu),size:r.getActiveUniformBlockParameter(e,a,tu),uniformIndices:r.getActiveUniformBlockParameter(e,a,ru)};f.used=f.usedByVertexShader||f.usedByFragmentShader,o[u]=f}return{blockSpecs:o,uniformData:n}}function jn(r,e){for(const t in e){const n=r[t];typeof n=="function"?n(e[t]):jn(r[t],e[t])}}function Xn(r,...e){const t=r.uniformSetters||r,n=e.length;for(let i=0;i<n;++i){const o=e[i];if(Array.isArray(o)){const s=o.length;for(let a=0;a<s;++a)Xn(t,o[a])}else for(const s in o){const a=t[s];a&&a(o[s])}}}function uc(r,e){const t={},n=r.getProgramParameter(e,Ka);for(let i=0;i<n;++i){const o=r.getActiveAttrib(e,i);if(Yn(o))continue;const s=r.getAttribLocation(e,o.name),a=P[o.type],u=a.setter(r,s,a);u.location=s,t[o.name]=u}return t}function cc(r,e){for(const t in e){const n=r[t];n&&n(e[t])}}function fc(r,e,t){t.vertexArrayObject?r.bindVertexArray(t.vertexArrayObject):(cc(e.attribSetters||e,t.attribs),t.indices&&r.bindBuffer(Va,t.indices))}function Qn(r,e){const t=oc(r,e),n=uc(r,e),i={program:e,uniformSetters:t,attribSetters:n};return Ne(r)&&(i.uniformBlockSpec=ac(r,e),i.transformFeedbackInfo=sc(r,e)),i}const lc=/\s|{|}|;/;function dc(r,e,t,n,i){const o=fr(t,n,i),s=[];if(e=e.map(function(f){if(!lc.test(f)){const d=bn(f);if(d)f=d.text;else{const h=`no element with id: ${f}`;o.errorCallback(h),s.push(h)}}return f}),s.length)return Hu(o,"");const a=o.callback;a&&(o.callback=(f,d)=>{a(f,f?void 0:Qn(r,d))});const u=tc(r,e,o);return u?Qn(r,u):null}const mc=4,Kn=5123;function hc(r,e,t,n,i,o){t=t===void 0?mc:t;const s=e.indices,a=e.elementType,u=n===void 0?e.numElements:n;i=i===void 0?0:i,a||s?o!==void 0?r.drawElementsInstanced(t,u,a===void 0?Kn:e.elementType,i,o):r.drawElements(t,u,a===void 0?Kn:e.elementType,i):o!==void 0?r.drawArraysInstanced(t,i,u,o):r.drawArrays(t,i,u)}const qn=36160,gt=36161,pc=3553,yc=5121,_c=6402,xc=6408,gc=33190,bc=36012,vc=35056,Ec=36013,Tc=32854,Ac=32855,wc=36194,Jn=33189,Zn=6401,ei=36168,lr=34041,dr=36064,bt=36096,ti=36128,mr=33306,hr=33071,pr=9729,Sc=[{format:xc,type:yc,min:pr,wrap:hr},{format:lr}],V={};V[lr]=mr,V[Zn]=ti,V[ei]=ti,V[_c]=bt,V[Jn]=bt,V[gc]=bt,V[bc]=bt,V[vc]=mr,V[Ec]=mr;function Rc(r,e){return V[r]||V[e]}const ue={};ue[Tc]=!0,ue[Ac]=!0,ue[wc]=!0,ue[lr]=!0,ue[Jn]=!0,ue[Zn]=!0,ue[ei]=!0;function Ic(r){return ue[r]}const Fc=32;function Pc(r){return r>=dr&&r<dr+Fc}function vt(r,e,t,n){const i=qn,o=r.createFramebuffer();r.bindFramebuffer(i,o),t=t||r.drawingBufferWidth,n=n||r.drawingBufferHeight,e=e||Sc;const s=[],a={framebuffer:o,attachments:[],width:t,height:n};return e.forEach(function(u,f){let d=u.attachment;const h=u.samples,y=u.format;let x=u.attachmentPoint||Rc(y,u.internalFormat);if(x||(x=dr+f),Pc(x)&&s.push(x),!d)if(h!==void 0||Ic(y))d=r.createRenderbuffer(),r.bindRenderbuffer(gt,d),h>1?r.renderbufferStorageMultisample(gt,h,y,t,n):r.renderbufferStorage(gt,y,t,n);else{const l=Object.assign({},u);l.width=t,l.height=n,l.auto===void 0&&(l.auto=!1,l.min=l.min||l.minMag||pr,l.mag=l.mag||l.minMag||pr,l.wrapS=l.wrapS||l.wrap||hr,l.wrapT=l.wrapT||l.wrap||hr),d=gn(r,l)}if($o(r,d))r.framebufferRenderbuffer(i,x,gt,d);else if(Ht(r,d))u.layer!==void 0?r.framebufferTextureLayer(i,x,d,u.level||0,u.layer):r.framebufferTexture2D(i,x,u.target||pc,d,u.level||0);else throw new Error("unknown attachment type");a.attachments.push(d)}),r.drawBuffers&&r.drawBuffers(s),a}function Dc(r,e,t){t=t||qn,e?(r.bindFramebuffer(t,e.framebuffer),r.viewport(0,0,e.width,e.height)):(r.bindFramebuffer(t,null),r.viewport(0,0,r.drawingBufferWidth,r.drawingBufferHeight))}function S(r,e){return()=>e instanceof WebGLTexture?e:gn(r,{src:e,wrap:r.CLAMP_TO_EDGE})}const ri=2;class xe{constructor(e){p(this,"id","_");p(this,"context");p(this,"output");p(this,"fbi");p(this,"options");p(this,"programInfo");p(this,"bufferInfo");p(this,"profiler");p(this,"lastRun");const{context:t,width:n,height:i}=e;this.context=t,this.options=e;const o=this.buildDefines();this.programInfo=dc(this.context,[o+this.getVertexShader(),o+this.getFragmentShader()]),this.bufferInfo=ls(this.context,this.getBuffers()),this.fbi=vt(this.context,[{format:this.context.RGBA,type:this.context.UNSIGNED_BYTE,min:this.context.LINEAR,wrap:this.context.CLAMP_TO_EDGE}],n,i),this.output=this.fbi.attachments[0]}resizeOutput(e,t){this.fbi=vt(this.context,[{format:this.context.RGBA,type:this.context.UNSIGNED_BYTE,min:this.context.LINEAR,wrap:this.context.CLAMP_TO_EDGE}],e,t),this.options.width=e,this.options.height=t,this.output=this.fbi.attachments[0]}getDefines(){return{}}getBuffers(){return{position:{numComponents:2,data:[-1,-1,-1,1,1,-1,1,1,-1,1,1,-1]},texture_coord:{numComponents:2,data:[0,0,0,1,1,0,1,1,0,1,1,0]}}}buildDefines(){let e="";const t=this.getDefines();for(let n in t)e+=`#define ${n} ${t[n].toFixed(1)}
`;return e}run(e){var i,o,s,a,u,f;(i=this.profiler)==null||i.pushContext(`[${this.id}] PROG : ${this.constructor.name}`),(o=this.profiler)==null||o.pushContext(`[${this.id}] UNIFORMS`);for(const d in e)typeof e[d]=="function"&&((s=this.profiler)==null||s.pushContext(`[${this.id}] UNI : ${d}`),e[d]=e[d](),(a=this.profiler)==null||a.popContext(`[${this.id}] UNI : ${d}`));(u=this.profiler)==null||u.popContext(`[${this.id}] UNIFORMS`);const t=Date.now();let n=0;this.lastRun&&(n=(t-this.lastRun)/1e3),this.lastRun=t,this.context.viewport(0,0,this.context.canvas.width,this.context.canvas.height),this.context.useProgram(this.programInfo.program),fc(this.context,this.programInfo,this.bufferInfo),Xn(this.programInfo,{delta:n,canvas:[this.context.canvas.width,this.context.canvas.height],...e}),Dc(this.context,this.options.disableFramebuffer?null:this.fbi),hc(this.context,this.bufferInfo),(f=this.profiler)==null||f.popContext(`[${this.id}] PROG : ${this.constructor.name}`)}setProfiler(e){this.profiler=e}}var Nc=`precision mediump float;

varying vec2 _texture_coord;

uniform vec2 canvas;
uniform sampler2D texture;
uniform sampler2D mask;

vec4 loop();

void main() { gl_FragColor = loop(); }
`,Mc=`varying vec2 _texture_coord;

attribute vec2 position;
attribute vec2 texture_coord;

void main() {
  gl_Position = vec4(position, 0., 1.);
  _texture_coord = texture_coord;
}
`;class Uc extends xe{getDefines(){var e;return{RADIUS:(e=this.options.radius)!=null?e:1}}getFragmentShader(){return Nc+this.createLoopFunction()}getVertexShader(){return Mc}createLoopFunction(){var t;let e=(t=this.options.radius)!=null?t:1;return`

        vec4 loop() { 
            vec4 result = vec4(0,0,0,0);
            float factorSum = 0.;

            vec2 normalizedRadius = vec2(-${e}.) / canvas;
            vec2 normalizedIncrement = vec2(1.) / canvas;
            vec2 diff = normalizedRadius;
            float maxLength = length(normalizedRadius);

            for(int y=-${e}; y<${e+1}; ++y) {
                for(int x=-${e}; x<${e+1}; ++x) {
                    float factor = (1.- texture2D(mask, _texture_coord + diff).a) * (maxLength - length(diff)) / maxLength;
                    result += factor * texture2D(texture, _texture_coord + diff);
                    factorSum += factor;
                    diff.x += normalizedIncrement.x;
                }
                diff.y += normalizedIncrement.y;
                diff.x = normalizedRadius.x;
            }
            return result / factorSum;
        }`}}var kc=`precision mediump float;

varying vec2 _texture_coord;

uniform sampler2D background;
uniform sampler2D foreground;
uniform sampler2D threshold;

void main() {
  vec4 backgroundColor = texture2D(background, _texture_coord);
  vec4 foregroundColor = texture2D(foreground, _texture_coord);
  vec4 tresholdColor = texture2D(threshold, _texture_coord);
  gl_FragColor = foregroundColor * tresholdColor.a +
                 backgroundColor * (1. - tresholdColor.a);
}
`,Cc=`varying vec2 _texture_coord;

attribute vec2 position;
attribute vec2 texture_coord;

void main() {
  gl_Position = vec4(position, 0., 1.);
  _texture_coord = texture_coord;
  _texture_coord.y = 1. - texture_coord.y;
}
`;class yr extends xe{getFragmentShader(){return kc}getVertexShader(){return Cc}}class _r{constructor(){p(this,"steps",[]);p(this,"profiler")}addStep(e){this.steps.push(e)}async run(){for(const e of this.steps)e.program.run(e.getUniforms())}resizeOutput(e,t){var n,i;(n=this.profiler)==null||n.pushContext(`PIP [${this.constructor.name}]`);for(const o of this.steps)o.preventResize||o.program.resizeOutput(e,t);(i=this.profiler)==null||i.popContext(`PIP [${this.constructor.name}]`)}setProfiler(e){this.profiler=e;for(const t of this.steps)t.program.setProfiler(e)}setId(e){for(const t of this.steps)t.program.id=e}}class xr extends _r{constructor(){super(...arguments);p(this,"preciseMaskEnabled",!1)}}const Oc=10,Bc=2,Lc=8;class Gc extends xr{constructor(t,n){super();p(this,"inputImage");p(this,"inputMask");p(this,"blur");this.context=t,this.radius=n;const i={context:t,height:t.canvas.height,width:t.canvas.width};this.blur=new Uc({...i,radius:n,...this.getBlurTextureSize(t.canvas.width,t.canvas.height)});const o=new yr({...i,disableFramebuffer:!0});this.addStep({program:this.blur,preventResize:!0,getUniforms:()=>({texture:S(t,this.inputImage),mask:S(t,this.inputMask)})}),this.addStep({program:o,getUniforms:()=>({background:S(t,this.blur.output),foreground:S(t,this.inputImage),threshold:S(t,this.inputMask)})})}getBlurTextureSize(t,n){const i=this.radius>Oc?Lc:Bc;return{width:Math.max(ri,t/i),height:Math.max(ri,n/i)}}setData(t,n){this.inputImage=t,this.inputMask=n}resizeOutput(t,n){super.resizeOutput(t,n);const i=this.getBlurTextureSize(t,n);this.blur.resizeOutput(i.width,i.height)}}class ni extends xr{constructor(t){super();p(this,"inputImage");p(this,"inputBackgroundImage");p(this,"inputMask");p(this,"preciseMaskEnabled",!0);this.context=t;const n={context:t,height:t.canvas.height,width:t.canvas.width},i=new yr({...n,disableFramebuffer:!0});this.addStep({program:i,getUniforms:()=>({background:S(t,this.inputBackgroundImage),foreground:S(t,this.inputImage),threshold:S(t,this.inputMask)})})}setData(t,n){this.inputImage=t,this.inputMask=n}}class $c extends ni{constructor(){super(...arguments);p(this,"frameReader");p(this,"preciseMaskEnabled",!0)}set inputVideo(t){this.frameReader=t.getReader(),this.readNextVideoFrame()}async run(){this.frameReader&&(await super.run(),this.readNextVideoFrame())}async readNextVideoFrame(){var n;const t=await((n=this.frameReader)==null?void 0:n.read());t!=null&&t.value&&(this.inputBackgroundImage=await createImageBitmap(t.value),t.value.close())}}var zc=`precision mediump float;

varying vec2 _texture_coord;

uniform vec2 canvas;
uniform sampler2D texture;

vec4 loop();

void main() { gl_FragColor = loop(); }
`,Wc=`varying vec2 _texture_coord;

attribute vec2 position;
attribute vec2 texture_coord;

void main() {
  gl_Position = vec4(position, 0., 1.);
  _texture_coord = texture_coord;
}
`,gr=(r=>(r[r.LINEAR=0]="LINEAR",r[r.GAUSSIAN=1]="GAUSSIAN",r))(gr||{});class ii extends xe{getDefines(){var e;return{RADIUS:(e=this.options.radius)!=null?e:1}}getFragmentShader(){return zc+this.createLoopFunction()}getVertexShader(){return Wc}createLoopFunction(){var t;let e=(t=this.options.radius)!=null?t:1;return`

        vec4 loop() { 
            vec4 result = vec4(0,0,0,0);
            float factorSum = 0.;

            vec2 normalizedRadius = vec2(-${e}.) / canvas;
            vec2 normalizedIncrement = vec2(1.) / canvas;
            vec2 diff = normalizedRadius;

            for(int y=-${e}; y<${e+1}; ++y) {
                for(int x=-${e}; x<${e+1}; ++x) {
                    float factor = 1.;
                    result += factor * texture2D(texture, _texture_coord + diff);
                    factorSum += factor;
                    diff.x += normalizedIncrement.x;
                }
                diff.y += normalizedIncrement.y;
                diff.x = normalizedRadius.x;
            }
            return result / factorSum;
        }`}getFactor(e,t){switch(this.options.type){case 1:return this.getLinearFactor(e,t);case 0:default:return this.getLinearFactor(e,t)}}getLinearFactor(e,t){return 1}getGaussianFactor(e,t){var u;const n=Math.PI*2,i=Math.max((u=this.options.radius)!=null?u:1,1),o=1/(n*i**2),s=-(e**2+t**2),a=o*s;return o*Math.E**a}}class Vc extends xr{constructor(t,n){super();p(this,"inputImage");p(this,"inputMask");this.context=t;const i={context:t,height:t.canvas.height,width:t.canvas.width},o=new ii({...i,radius:n,type:gr.GAUSSIAN}),s=new yr({...i,disableFramebuffer:!0});this.addStep({program:o,getUniforms:()=>({texture:S(t,this.inputImage)})}),this.addStep({program:s,getUniforms:()=>({background:S(t,this.inputImage),foreground:S(t,o.output),threshold:S(t,this.inputMask)})})}setData(t,n){this.inputImage=t,this.inputMask=n}}class br extends xe{constructor(t){super(t);p(this,"fbi2");this.fbi2=vt(t.context,[{format:t.context.RGBA,type:t.context.UNSIGNED_BYTE,min:t.context.LINEAR,mag:t.context.LINEAR,wrap:t.context.CLAMP_TO_EDGE}],t.width,t.height)}run(t){const n=this.fbi;this.fbi=this.fbi2,this.fbi2=n,this.output=this.fbi.attachments[0],super.run({...t,previous_rendering:this.fbi2.attachments[0]})}resizeOutput(t,n){super.resizeOutput(t,n),this.fbi2=vt(this.context,[{format:this.context.RGBA,type:this.context.UNSIGNED_BYTE,min:this.context.LINEAR,wrap:this.context.CLAMP_TO_EDGE}],t,n)}}var Hc=`precision mediump float;

varying vec2 _texture_coord;

// uniform float treshold;
uniform sampler2D image_now;
uniform sampler2D image_before;
uniform sampler2D mask_now;
uniform sampler2D mask_before;
uniform sampler2D previous_rendering;
uniform vec2 canvas;

uniform float delta;

float current_factor = 0.69;
float previous_factor = 0.74;
float threshold_activation = 0.54;

float map(float value, float min1, float max1, float min2, float max2) {
  return min2 + (value - min1) * (max2 - min2) / (max1 - min1);
}

float getThreshold() {
  vec4 color = vec4(0.);
  for (float y = -6.; y < 7.; y += 1.) {
    for (float x = -6.; x < 7.; x += 1.) {
      vec4 image_now_color =
          texture2D(image_now, _texture_coord + vec2(x, y) / canvas);
      vec4 image_before_color =
          texture2D(image_before, _texture_coord + vec2(x, y) / canvas);
      color += abs(image_before_color - image_now_color);
    }
  }
  return (color.x + color.y + color.z) / (3. * 9.);
}

void main() {
  float treshold_input = .4;
  float treshold_previous_rendering = .98;

  vec4 mask_now_color = texture2D(mask_now, _texture_coord);
  vec4 mask_before_color = texture2D(mask_before, _texture_coord);
  vec4 previous_rendering_color = texture2D(previous_rendering, _texture_coord);

  vec3 mask_diff = abs(mask_before_color.xyz - mask_now_color.xyz);
  float flickering = mask_diff.x;
  float threshold = getThreshold();
  if (threshold < threshold_activation) {
    gl_FragColor = vec4(flickering, 0., 0., 1.) * current_factor +
                   previous_rendering_color * previous_factor;
    gl_FragColor *= (1. - threshold);
  }
}
`,Yc=`varying vec2 _texture_coord;

attribute vec2 position;
attribute vec2 texture_coord;

void main() {
  gl_Position = vec4(position, 0., 1.);
  _texture_coord = texture_coord;
}
`;class jc extends br{getFragmentShader(){return Hc}getVertexShader(){return Yc}}var Xc=`#version 300 es
// https://github.com/Volcomix/virtual-background/blob/main/src/pipelines/webgl2/jointBilateralFilterStage.ts

precision highp float;
uniform sampler2D input_frame;
uniform sampler2D segmentation_mask;
uniform sampler2D threshold;
uniform vec2 texel_size;
uniform float step;
uniform float radius;
uniform float offset;
uniform float sigma_texel;
uniform float sigma_color;

in vec2 _texture_coord;
out vec4 outColor;

float gaussian(float x, float sigma) {
  float coeff = -0.5 / (sigma * sigma * 4.0 + 1.0e-6);
  return exp((x * x) * coeff);
}

void main() {
  vec2 centerCoord = _texture_coord;
  vec3 centerColor = texture(input_frame, centerCoord).rgb;
  float newVal = 0.0;
  float spaceWeight = 0.0;
  float colorWeight = 0.0;
  float totalWeight = 0.0;
  // Subsample kernel space.
  for (float i = -radius + offset; i <= radius; i += step) {
    for (float j = -radius + offset; j <= radius; j += step) {
      vec2 shift = vec2(j, i) * texel_size;
      vec2 coord = vec2(centerCoord + shift);
      vec3 frameColor = texture(input_frame, coord).rgb;
      float threshold = texture(threshold, coord).a;
      float outVal = texture(segmentation_mask, coord).a;

      spaceWeight = gaussian(distance(centerCoord, coord), sigma_texel);
      colorWeight = gaussian(distance(centerColor, frameColor), sigma_color);
      totalWeight += spaceWeight * colorWeight;
      newVal += spaceWeight * colorWeight * outVal * threshold;
    }
  }
  newVal /= totalWeight;
  outColor = vec4(vec3(0.), newVal);
}`,Qc=`#version 300 es
in vec2 position;
in vec2 texture_coord;
out vec2 _texture_coord;
void main() {
  gl_Position = vec4(position, 0.0, 1.0);
  _texture_coord = texture_coord;
}`;class Kc extends xe{getFragmentShader(){return Xc}getVertexShader(){return Qc}}var qc=`precision mediump float;

varying vec2 _texture_coord;

uniform vec2 canvas;
uniform sampler2D texture;

void main() {
  int count = 0;
  for (float y = -1.; y < 2.; y += 1.) {
    for (float x = -1.; x < 2.; x += 1.) {
      vec2 coord = _texture_coord + vec2(y, x) / canvas;
      vec4 color = texture2D(texture, coord);
      if (color.r > .1) {
        count++;
      }
    }
  }
  if (count > 5) {
    gl_FragColor = texture2D(texture, _texture_coord);
  }
}
`,Jc=`varying vec2 _texture_coord;

attribute vec2 position;
attribute vec2 texture_coord;

void main() {
  gl_Position = vec4(position, 0., 1.);
  _texture_coord = texture_coord;
}
`;class Zc extends xe{getFragmentShader(){return qc}getVertexShader(){return Jc}}var ef=`precision mediump float;

varying vec2 _texture_coord;

uniform vec2 canvas;
uniform sampler2D texture;

void main() {
  vec4 color = texture2D(texture, _texture_coord);
  for (float y = -2.; y < 3.; y += 1.) {
    for (float x = -2.; x < 3.; x += 1.) {
      vec2 coord = _texture_coord;
      coord += vec2(y, x) / canvas;
      color += texture2D(texture, coord) * (1. / 4.);
    }
  }

  gl_FragColor = color;
}
`,tf=`varying vec2 _texture_coord;

attribute vec2 position;
attribute vec2 texture_coord;

void main() {
  gl_Position = vec4(position, 0., 1.);
  _texture_coord = texture_coord;
}
`;class rf extends br{getFragmentShader(){return ef}getVertexShader(){return tf}}var nf=`precision mediump float;

varying vec2 _texture_coord;

uniform sampler2D threshold;
uniform sampler2D inputs;

void main() {
  vec4 inputs_color = texture2D(inputs, _texture_coord);
  vec4 threshold_color = texture2D(threshold, _texture_coord);
  if (threshold_color.r < .1 && inputs_color.r > .5) {
    gl_FragColor = inputs_color;
  }
}
`,of=`varying vec2 _texture_coord;

attribute vec2 position;
attribute vec2 texture_coord;

void main() {
  gl_Position = vec4(position, 0., 1.);
  _texture_coord = texture_coord;
}
`;class sf extends br{getFragmentShader(){return nf}getVertexShader(){return of}}class af extends _r{constructor(t,n,i){super();p(this,"inputImage");p(this,"inputMask");p(this,"previousInputImage");p(this,"previousInputMask");p(this,"output");p(this,"options",{currentThresholdMinimum:0,currentThresholdMaximum:1,previousThresholdMinimum:0,previousThresholdMaximum:1,thresholdMinimum:0,thresholdMaximum:1,thresholdFactor:1});this.context=t;const o={context:t,height:i,width:n},s=new jc(o),a=new ii({...o,radius:1,type:gr.GAUSSIAN}),u=new sf(o),f=new rf(o),d=new Zc(o),h=new Kc({...o}),y=.66,x=640,l=480,g=256,E=144;let v=1;v*=Math.max(x/g,l/E);const I=Math.max(1,Math.sqrt(v)*y),D=1/x,G=1/l;this.addStep({program:s,getUniforms:()=>({image_now:S(t,this.inputImage),image_before:S(t,this.previousInputImage),mask_now:S(t,this.inputMask),mask_before:S(t,this.previousInputMask),current_threshold_minimum:this.options.currentThresholdMinimum,current_threshold_maximum:this.options.currentThresholdMaximum,previous_threshold_minimum:this.options.previousThresholdMinimum,previous_threshold_maximum:this.options.previousThresholdMaximum,threshold_minimum:this.options.thresholdMinimum,threshold_maximum:this.options.thresholdMaximum,threshold_factor:this.options.thresholdFactor})}),this.addStep({program:u,getUniforms:()=>({inputs:S(t,this.inputMask),threshold:S(t,s.output)})}),this.addStep({program:d,getUniforms:()=>({texture:S(t,u.output)})}),this.addStep({program:f,getUniforms:()=>({texture:S(t,d.output)})}),this.addStep({program:a,getUniforms:()=>({texture:S(t,f.output)})}),this.addStep({program:h,getUniforms:()=>({input_frame:S(t,this.inputImage),segmentation_mask:S(t,this.inputMask),threshold:S(t,a.output),texel_size:[D,G],step:I,radius:v,offset:I>1?I*.5:0,sigma_texel:Math.max(D,G)*v,sigma_color:.1})}),this.output=h.output}setData(t,n){this.previousInputImage=this.inputImage?this.inputImage:t,this.previousInputMask=this.inputMask?this.inputMask:n,this.inputImage=t,this.inputMask=n}setOptions(t){this.options=t}}var uf=`precision mediump float;

varying vec2 _texture_coord;
uniform sampler2D texture;

void main() { gl_FragColor = texture2D(texture, _texture_coord); }
`,cf=`varying vec2 _texture_coord;

attribute vec2 position;
attribute vec2 texture_coord;
uniform bool invert_y;

void main() {
  gl_Position = vec4(position, 0., 1.);
  _texture_coord = texture_coord;
  if (invert_y) {
    _texture_coord.y = 1. - texture_coord.y;
  }
}
`;class ff extends xe{getFragmentShader(){return uf}getVertexShader(){return cf}}class lf extends _r{constructor(t,n,i){super();p(this,"inputImage");this.context=t;const o={context:t,height:i,width:n};this.addStep({program:new ff({...o,disableFramebuffer:!0}),getUniforms:()=>({texture:S(t,this.inputImage),invert_y:!0})})}setData(t){this.inputImage=t}}class df{constructor(e){p(this,"resize");p(this,"canvas");p(this,"context");this.canvas=new OffscreenCanvas(0,0),this.context=this.canvas.getContext("webgl2"),this.canvas.width=e.width,this.canvas.height=e.height,this.resize=new lf(this.context,e.width,e.height)}resizeForeground(e,t){this.canvas.width=e,this.canvas.height=t,this.resize.resizeOutput(e,t)}async process(e){var t,n;return this.canvas.width=this.canvas.width,(t=this.resize)==null||t.setData(e),(n=this.resize)==null||n.run(),this.canvas}}class mf{constructor(e,t){p(this,"improveMaskSegmentation");p(this,"backgroundResizer");p(this,"backgroundImage");p(this,"backgroundVideo");p(this,"profiler");p(this,"activePipeline");p(this,"canvas");p(this,"options");p(this,"context");p(this,"virtualBGImage");this.id=e,this.canvas=new OffscreenCanvas(0,0),this.context=this.canvas.getContext("webgl2"),this.canvas.width=t.foregroundWidth,this.canvas.height=t.foregroundHeight,this.improveMaskSegmentation=new af(this.context,t.maskWidth,t.maskHeight),this.backgroundImage=new ni(this.context),this.backgroundVideo=new $c(this.context),this.backgroundResizer=new df({width:t.foregroundWidth,height:t.foregroundHeight})}setBackgroundOptions(e){switch(e.transformerType){case"BackgroundBlur":this.activePipeline=new Gc(this.context,this.getBlurSize(e.radius));break;case"SilhouetteBlur":this.activePipeline=new Vc(this.context,this.getBlurSize(e.radius));break;case"VideoBackground":this.activePipeline=this.backgroundVideo;break;case"VirtualBackground":this.activePipeline=this.backgroundImage;break}this.options=e}setFlickeringOptions(e){var t;(t=this.improveMaskSegmentation)==null||t.setOptions(e)}setVideoBGReadable(e){this.backgroundVideo.inputVideo=e}async setVirtualBGImage(e){this.virtualBGImage=e,this.backgroundImage.inputBackgroundImage=await this.backgroundResizer.process(e)}async process(e,t){var n,i,o,s,a,u,f;if(this.activePipeline&&e.width&&(t==null?void 0:t.width)){const d=`[${this.id}] background-filter`;(n=this.profiler)==null||n.pushContext(d);let h=t;(((i=this.options)==null?void 0:i.selfieSegmentationType)&&((o=this.options)==null?void 0:o.selfieSegmentationType)==="PRECISE"||!((s=this.options)!=null&&s.selfieSegmentationType)&&this.activePipeline.preciseMaskEnabled)&&(this.improveMaskSegmentation.setId(this.id),this.improveMaskSegmentation.setProfiler(this.profiler),this.improveMaskSegmentation.setData(e,t),this.improveMaskSegmentation.run(),h=this.improveMaskSegmentation.output),this.activePipeline.setId(this.id),this.activePipeline.setProfiler(this.profiler),(a=this.activePipeline)==null||a.setData(e,h),(u=this.activePipeline)==null||u.run(),(f=this.profiler)==null||f.popContext(d)}}async resizeForeground(e,t){var n;this.canvas.width=e,this.canvas.height=t,this.backgroundImage.resizeOutput(e,t),this.backgroundVideo.resizeOutput(e,t),this.backgroundResizer.resizeForeground(e,t),(n=this.activePipeline)==null||n.resizeOutput(e,t),this.virtualBGImage&&(this.backgroundImage.inputBackgroundImage=await this.backgroundResizer.process(this.virtualBGImage))}async profile(e){const t=new Po(this.context);return this.profiler=t,t.start(),await Gr(e),this.profiler=void 0,t.stop(),t.getResolvedQueries()}getBlurSize(e=Ze.Low){switch(e){case Ze.Low:return 5;case Ze.High:return 12}return e}}var hf=function(){var r=typeof document<"u"&&document.currentScript?document.currentScript.src:void 0;return function(e){e=e||{};var t=typeof e<"u"?e:{},n,i;t.ready=new Promise(function(c,m){n=c,i=m});var o={},s;for(s in t)t.hasOwnProperty(s)&&(o[s]=t[s]);var a="./this.program",u=function(c,m){throw m},f=!0,d="";function h(c){return t.locateFile?t.locateFile(c,d):d+c}var y;typeof document<"u"&&document.currentScript&&(d=document.currentScript.src),r&&(d=r),d.indexOf("blob:")!==0?d=d.substr(0,d.replace(/[?#].*/,"").lastIndexOf("/")+1):d="";var x=t.print||console.log.bind(console),l=t.printErr||console.warn.bind(console);for(s in o)o.hasOwnProperty(s)&&(t[s]=o[s]);o=null,t.arguments&&t.arguments,t.thisProgram&&(a=t.thisProgram),t.quit&&(u=t.quit);var g;t.wasmBinary&&(g=t.wasmBinary);var E=t.noExitRuntime||!0;typeof WebAssembly!="object"&&ce("no native wasm support detected");var v,I=!1,D=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0;function G(c,m,_){for(var T=m+_,N=m;c[N]&&!(N>=T);)++N;if(N-m>16&&c.subarray&&D)return D.decode(c.subarray(m,N));for(var k="";m<N;){var w=c[m++];if(!(w&128)){k+=String.fromCharCode(w);continue}var O=c[m++]&63;if((w&224)==192){k+=String.fromCharCode((w&31)<<6|O);continue}var K=c[m++]&63;if((w&240)==224?w=(w&15)<<12|O<<6|K:w=(w&7)<<18|O<<12|K<<6|c[m++]&63,w<65536)k+=String.fromCharCode(w);else{var hi=w-65536;k+=String.fromCharCode(55296|hi>>10,56320|hi&1023)}}return k}function $(c,m){return c?G(Le,c,m):""}function Z(c,m,_){for(var T=0;T<c.length;++T)Et[m++>>0]=c.charCodeAt(T);_||(Et[m>>0]=0)}function H(c,m){return c%m>0&&(c+=m-c%m),c}var si,Et,Le,Y;function ai(c){si=c,t.HEAP8=Et=new Int8Array(c),t.HEAP16=new Int16Array(c),t.HEAP32=Y=new Int32Array(c),t.HEAPU8=Le=new Uint8Array(c),t.HEAPU16=new Uint16Array(c),t.HEAPU32=new Uint32Array(c),t.HEAPF32=new Float32Array(c),t.HEAPF64=new Float64Array(c)}t.INITIAL_MEMORY;var Er,ui=[],ci=[],fi=[],vf=0;function Ef(){return E||vf>0}function Tf(){if(t.preRun)for(typeof t.preRun=="function"&&(t.preRun=[t.preRun]);t.preRun.length;)Sf(t.preRun.shift());Tr(ui)}function Af(){Tr(ci)}function wf(){if(t.postRun)for(typeof t.postRun=="function"&&(t.postRun=[t.postRun]);t.postRun.length;)If(t.postRun.shift());Tr(fi)}function Sf(c){ui.unshift(c)}function Rf(c){ci.unshift(c)}function If(c){fi.unshift(c)}var ge=0,Ge=null;function Ff(c){ge++,t.monitorRunDependencies&&t.monitorRunDependencies(ge)}function Pf(c){if(ge--,t.monitorRunDependencies&&t.monitorRunDependencies(ge),ge==0&&Ge){var m=Ge;Ge=null,m()}}t.preloadedImages={},t.preloadedAudios={};function ce(c){t.onAbort&&t.onAbort(c),c="Aborted("+c+")",l(c),I=!0,c+=". Build with -s ASSERTIONS=1 for more info.";var m=new WebAssembly.RuntimeError(c);throw i(m),m}var Df="data:application/octet-stream;base64,";function li(c){return c.startsWith(Df)}var j;j="tflite-simd.wasm",li(j)||(j=h(j));function di(c){try{if(c==j&&g)return new Uint8Array(g);if(!y)throw"both async and sync fetching of the wasm failed"}catch(m){ce(m)}}function Nf(){return!g&&f&&typeof fetch=="function"?fetch(j,{credentials:"same-origin"}).then(function(c){if(!c.ok)throw"failed to load wasm binary file at '"+j+"'";return c.arrayBuffer()}).catch(function(){return di(j)}):Promise.resolve().then(function(){return di(j)})}function Mf(){var c={a:el};function m(w,O){var K=w.exports;t.asm=K,v=t.asm.q,ai(v.buffer),Er=t.asm.E,Rf(t.asm.r),Pf()}Ff();function _(w){m(w.instance)}function T(w){return Nf().then(function(O){return WebAssembly.instantiate(O,c)}).then(function(O){return O}).then(w,function(O){l("failed to asynchronously prepare wasm: "+O),ce(O)})}function N(){return!g&&typeof WebAssembly.instantiateStreaming=="function"&&!li(j)&&typeof fetch=="function"?fetch(j,{credentials:"same-origin"}).then(function(w){var O=WebAssembly.instantiateStreaming(w,c);return O.then(_,function(K){return l("wasm streaming compile failed: "+K),l("falling back to ArrayBuffer instantiation"),T(_)})}):T(_)}if(t.instantiateWasm)try{var k=t.instantiateWasm(c,m);return k}catch(w){return l("Module.instantiateWasm callback failed with error: "+w),!1}return N().catch(i),{}}function Tr(c){for(;c.length>0;){var m=c.shift();if(typeof m=="function"){m(t);continue}var _=m.func;typeof _=="number"?m.arg===void 0?Er.get(_)():Er.get(_)(m.arg):_(m.arg===void 0?null:m.arg)}}function Uf(c,m,_,T){ce("Assertion failed: "+$(c)+", at: "+[m?$(m):"unknown filename",_,T?$(T):"unknown function"])}function kf(c,m){ce("To use dlopen, you need to use Emscripten's linking support, see https://github.com/emscripten-core/emscripten/wiki/Linking")}function Cf(c,m){ce("To use dlopen, you need to use Emscripten's linking support, see https://github.com/emscripten-core/emscripten/wiki/Linking")}function Of(){ce("")}var Tt;Tt=function(){return performance.now()};var Bf=!0;function Lf(c){return Y[mi()>>2]=c,c}function Gf(c,m){var _;if(c===0)_=Date.now();else if((c===1||c===4)&&Bf)_=Tt();else return Lf(28),-1;return Y[m>>2]=_/1e3|0,Y[m+4>>2]=_%1e3*1e3*1e3|0,0}function $f(){return 2147483648}function zf(c,m,_){Le.copyWithin(c,m,m+_)}function Wf(c){try{return v.grow(c-si.byteLength+65535>>>16),ai(v.buffer),1}catch{}}function Vf(c){var m=Le.length;c=c>>>0;var _=2147483648;if(c>_)return!1;for(var T=1;T<=4;T*=2){var N=m*(1+.2/T);N=Math.min(N,c+100663296);var k=Math.min(_,H(Math.max(c,N),65536)),w=Wf(k);if(w)return!0}return!1}function Hf(c){for(var m=Tt();Tt()-m<c;);}var Ar={};function Yf(){return a||"./this.program"}function $e(){if(!$e.strings){var c=(typeof navigator=="object"&&navigator.languages&&navigator.languages[0]||"C").replace("-","_")+".UTF-8",m={USER:"web_user",LOGNAME:"web_user",PATH:"/",PWD:"/",HOME:"/home/web_user",LANG:c,_:Yf()};for(var _ in Ar)Ar[_]===void 0?delete m[_]:m[_]=Ar[_];var T=[];for(var _ in m)T.push(_+"="+m[_]);$e.strings=T}return $e.strings}var At={mappings:{},buffers:[null,[],[]],printChar:function(c,m){var _=At.buffers[c];m===0||m===10?((c===1?x:l)(G(_,0)),_.length=0):_.push(m)},varargs:void 0,get:function(){At.varargs+=4;var c=Y[At.varargs-4>>2];return c},getStr:function(c){var m=$(c);return m},get64:function(c,m){return c}};function jf(c,m){var _=0;return $e().forEach(function(T,N){var k=m+_;Y[c+N*4>>2]=k,Z(T,k),_+=T.length+1}),0}function Xf(c,m){var _=$e();Y[c>>2]=_.length;var T=0;return _.forEach(function(N){T+=N.length+1}),Y[m>>2]=T,0}function Qf(c){rl(c)}function Kf(c){return 0}function qf(c,m,_,T,N){}function Jf(c,m,_,T){for(var N=0,k=0;k<_;k++){for(var w=Y[m+k*8>>2],O=Y[m+(k*8+4)>>2],K=0;K<O;K++)At.printChar(c,Le[w+K]);N+=O}return Y[T>>2]=N,0}function Zf(){if(typeof crypto=="object"&&typeof crypto.getRandomValues=="function"){var c=new Uint8Array(1);return function(){return crypto.getRandomValues(c),c[0]}}else return function(){ce("randomDevice")}}function wt(c,m){wt.randomDevice||(wt.randomDevice=Zf());for(var _=0;_<m;_++)Et[c+_>>0]=wt.randomDevice();return 0}var el={a:Uf,e:kf,d:Cf,b:Of,n:Gf,h:$f,l:zf,m:Vf,p:Hf,f:jf,g:Xf,j:Qf,i:Kf,k:qf,c:Jf,o:wt};Mf(),t.___wasm_call_ctors=function(){return(t.___wasm_call_ctors=t.asm.r).apply(null,arguments)},t._getModelBufferMemoryOffset=function(){return(t._getModelBufferMemoryOffset=t.asm.s).apply(null,arguments)},t._getInputMemoryOffset=function(){return(t._getInputMemoryOffset=t.asm.t).apply(null,arguments)},t._getInputHeight=function(){return(t._getInputHeight=t.asm.u).apply(null,arguments)},t._getInputWidth=function(){return(t._getInputWidth=t.asm.v).apply(null,arguments)},t._getInputChannelCount=function(){return(t._getInputChannelCount=t.asm.w).apply(null,arguments)},t._getOutputMemoryOffset=function(){return(t._getOutputMemoryOffset=t.asm.x).apply(null,arguments)},t._getOutputHeight=function(){return(t._getOutputHeight=t.asm.y).apply(null,arguments)},t._getOutputWidth=function(){return(t._getOutputWidth=t.asm.z).apply(null,arguments)},t._getOutputChannelCount=function(){return(t._getOutputChannelCount=t.asm.A).apply(null,arguments)},t._loadModel=function(){return(t._loadModel=t.asm.B).apply(null,arguments)},t._runInference=function(){return(t._runInference=t.asm.C).apply(null,arguments)},t._isGPUEnabled=function(){return(t._isGPUEnabled=t.asm.D).apply(null,arguments)};var mi=t.___errno_location=function(){return(mi=t.___errno_location=t.asm.F).apply(null,arguments)},St;function tl(c){this.name="ExitStatus",this.message="Program terminated with exit("+c+")",this.status=c}Ge=function c(){St||wr(),St||(Ge=c)};function wr(c){if(ge>0||(Tf(),ge>0))return;function m(){St||(St=!0,t.calledRun=!0,!I&&(Af(),n(t),t.onRuntimeInitialized&&t.onRuntimeInitialized(),wf()))}t.setStatus?(t.setStatus("Running..."),setTimeout(function(){setTimeout(function(){t.setStatus("")},1),m()},1)):m()}t.run=wr;function rl(c,m){nl(c)}function nl(c){Ef()||(t.onExit&&t.onExit(c),I=!0),u(c,new tl(c))}if(t.preInit)for(typeof t.preInit=="function"&&(t.preInit=[t.preInit]);t.preInit.length>0;)t.preInit.pop()();return wr(),e.ready}}();class pf{constructor(){p(this,"selectedTFLite");p(this,"isSIMDSupported",!1);p(this,"isThreadsSupported",!1);p(this,"inputWidth",0);p(this,"inputHeight",0);p(this,"inputChannelCount",0);p(this,"inputMemoryOffset",0);p(this,"outputWidth",0);p(this,"outputHeight",0);p(this,"outputChannelCount",0);p(this,"outputMemoryOffset",0)}}const yf="https://d3opqjmqzxf057.cloudfront.net/vonage-tensorflow-wasm/tflite-simd-wasm/1.1.3/",_f="https://d3opqjmqzxf057.cloudfront.net/ml/selfie_segmentation/4.0.0/";async function xf(r=yf,e=_f){let t=new pf;var n=new Promise(function(i,o){async function s(){return hf({locateFile:function(f){return r+f}})}async function a(u){return new Promise(async(f,d)=>{const h=u;if(typeof h>"u")return d("TFLite backend unavailable: wasmSimd");const y="selfie_segmentation_landscape";console.log("Loading tflite model:",y);let x=e+`${y}.tflite`;console.log("TFLite modelUrl: "+x);try{const g=await(await fetch(x)).arrayBuffer();console.log("Model buffer size:",g.byteLength);const E=h._getModelBufferMemoryOffset();console.log("Model buffer memory offset:",E),console.log("Loading model buffer..."),h.HEAPU8.set(new Uint8Array(g),E);const v=h._loadModel(g.byteLength);if(console.log("Load model result:",v),v!==0){d("Cannot load model");return}t.inputWidth=h._getInputWidth(),t.inputHeight=h._getInputHeight(),t.inputChannelCount=h._getInputChannelCount(),t.inputMemoryOffset=h._getInputMemoryOffset(),console.log("Input memory offset:",t.inputMemoryOffset),console.log("Input height:",t.inputHeight),console.log("Input width:",t.inputWidth),console.log("Input channels:",t.inputChannelCount),t.outputMemoryOffset=h._getOutputMemoryOffset(),t.outputWidth=h._getOutputWidth(),t.outputHeight=h._getOutputHeight(),t.outputChannelCount=h._getOutputChannelCount(),console.log("Output memory offset:",t.outputMemoryOffset),console.log("Output height:",t.outputHeight),console.log("Output width:",t.outputWidth),console.log("Output channels:",t.outputChannelCount),t.selectedTFLite=h}catch(l){d(l);return}f()})}s().then(u=>{if(u===null)throw console.error("loadTFLite null"),"loadTFLite null";a(u).then(f=>{i(t)}).catch(f=>{console.error("loadTFLiteModel error"),o("loadTFLiteModel error")})}).catch(u=>{console.error("loadTFLite error:",u),o("loadTFLite error:"+u)})});return n}class gf{constructor(){p(this,"canvas",new OffscreenCanvas(0,0));p(this,"context",this.canvas.getContext("2d",{willReadFrequently:!0}));p(this,"pixelCount",0);p(this,"inputOffset",0);p(this,"outputOffset",0);p(this,"infos");p(this,"mask")}async init(e,t){await this.initWasm(e,t),this.infos&&(this.canvas.width=this.infos.inputWidth,this.canvas.height=this.infos.inputHeight,this.pixelCount=this.infos.inputWidth*this.infos.inputHeight,this.mask=new ImageData(this.infos.inputWidth,this.infos.inputHeight),this.inputOffset=this.infos.inputMemoryOffset/4,this.outputOffset=this.infos.outputMemoryOffset/4)}async initWasm(e,t){this.infos=await xf(e,t)}getOutputDimensions(){var e,t,n,i;return{width:(t=(e=this.infos)==null?void 0:e.outputWidth)!=null?t:0,height:(i=(n=this.infos)==null?void 0:n.outputHeight)!=null?i:0}}async process(e){if(!this.mask||!this.infos)return;const t=this.infos.inputWidth,n=this.infos.inputHeight;this.context.drawImage(e,0,0,e.width,e.height,0,0,t,n);const i=this.context.getImageData(0,0,t,n),o=this.infos.selectedTFLite.HEAPF32;for(let s=0;s<this.pixelCount;s++){const a=this.inputOffset+s*3;o[a]=i.data[s*4]/255,o[a+1]=i.data[s*4+1]/255,o[a+2]=i.data[s*4+2]/255}this.infos.selectedTFLite._runInference();for(let s=0;s<this.pixelCount;s++){const a=this.infos.selectedTFLite.HEAPF32[this.outputOffset+s];this.mask.data[s*4]=this.mask.data[s*4+3]=255*a}return createImageBitmap(this.mask)}isGpuSupported(){var e,t,n;return(n=(t=(e=this.infos)==null?void 0:e.selectedTFLite)==null?void 0:t._isGPUEnabled())!=null?n:!1}}class bf{constructor(){p(this,"selfieSegmentation",new gf);p(this,"backgroundFilter");p(this,"reporter",new Io);p(this,"previousDimensions",{width:0,height:0});p(this,"backgroundOptions")}async init(e,t){await this.selfieSegmentation.init(t.wasmAssetUriPath,t.tfliteAssetUriPath);const{width:n,height:i}=this.selfieSegmentation.getOutputDimensions();this.backgroundFilter=new mf(e,{foregroundWidth:1,foregroundHeight:1,maskWidth:n,maskHeight:i}),this.report({variation:"Create"})}async transform(e,t){var s,a,u,f;const n=(s=e.timestamp)!=null?s:0,i=await createImageBitmap(e),o=await this.selfieSegmentation.process(i);o?((i.width!==this.previousDimensions.width||i.height!==this.previousDimensions.height)&&(this.previousDimensions.width=i.width,this.previousDimensions.height=i.height,await((a=this.backgroundFilter)==null?void 0:a.resizeForeground(i.width,i.height))),await((u=this.backgroundFilter)==null?void 0:u.process(i,o)),e.close(),t.enqueue(new VideoFrame((f=this.backgroundFilter)==null?void 0:f.canvas,{timestamp:n,alpha:"discard"}))):t.enqueue(e)}async setBackgroundOptions(e){var t;this.backgroundOptions=e,await((t=this.backgroundFilter)==null?void 0:t.setBackgroundOptions(e)),this.report({variation:"Update"})}async setVideoBGReadable(e){var t;await((t=this.backgroundFilter)==null?void 0:t.setVideoBGReadable(e))}async setVirtualBGImage(e){var t;await((t=this.backgroundFilter)==null?void 0:t.setVirtualBGImage(e))}setFlickeringOptions(e){var t;(t=this.backgroundFilter)==null||t.setFlickeringOptions(e),this.report({variation:"Update"})}async profile(e){var t,n;return(n=(t=this.backgroundFilter)==null?void 0:t.profile(e))!=null?n:[]}getTransformerType(){var e,t;return(t=(e=this.backgroundOptions)==null?void 0:e.transformerType)!=null?t:"Undefined"}report(e){var t;this.reporter.send({version:Fo,action:"MlTransformers",transformerType:(t=this.backgroundOptions)==null?void 0:t.transformerType,config:JSON.stringify(this.backgroundOptions),...e})}}const vr=class{constructor(){p(this,"backgroundTransformer",new bf);p(this,"mediaProcessor",new no);p(this,"rate",30);p(this,"resolveOnMediaProcessor");p(this,"eventsQueue",[])}async init(e,t){await this.backgroundTransformer.init(e,t),await this.mediaProcessor.setTransformers([this.backgroundTransformer]),this.mediaProcessor.setTrackExpectedRate(this.rate),this.mediaProcessor.onAny((n,i)=>{this.resolveOnMediaProcessor?(this.resolveOnMediaProcessor({name:n,data:i}),this.resolveOnMediaProcessor=void 0):this.eventsQueue.push({name:n,data:i})})}async onMediaProcessorEvent(){return await new Promise(e=>{this.eventsQueue.length>0?e(this.eventsQueue.shift()):this.resolveOnMediaProcessor=e})}async setTrackExpectedRate(e){this.rate=e,this.mediaProcessor.setTrackExpectedRate(e)}async transform(e,t){this.mediaProcessor.transform(e,t)}async setBackgroundOptions(e){var t;await((t=this.backgroundTransformer)==null?void 0:t.setBackgroundOptions(e))}setVideoBGReadable(e){this.backgroundTransformer.setVideoBGReadable(e)}async setVirtualBGImage(e){await this.backgroundTransformer.setVirtualBGImage(e)}async terminate(){await this.mediaProcessor.destroy()}setFlickeringOptions(e){this.backgroundTransformer.setFlickeringOptions(e)}setVonageMetadata(e){qi(e)}async profile(e){return JSON.stringify(await this.backgroundTransformer.profile(e))}};let oi=vr;(()=>{_i("ProcessorWorker",vr)})()})();
", vs = typeof window < "u" && window.Blob && new Blob([atob(Ll)], { type: "text/javascript;charset=utf-8" });
|
|
24019
|
+
const Ll = "var il=Object.defineProperty;var ol=(q,X,z)=>X in q?il(q,X,{enumerable:!0,configurable:!0,writable:!0,value:z}):q[X]=z;var p=(q,X,z)=>(ol(q,typeof X!="symbol"?X+"":X,z),z);(function(){"use strict";function q(r,e){return globalThis[r]||(globalThis[r]=e),globalThis[r]}const X=q("globals",{});var z=(r=>(r.INIT="INIT",r.FORWARD="FORWARD",r.TERMINATE="TERMINATE",r.GLOBALS_SYNC="GLOBALS_SYNC",r))(z||{});function pi(r){return[ImageBitmap,ReadableStream,WritableStream].some(e=>r instanceof e)}function ze(r,e){const{id:t,type:n}=r,i=Array.isArray(e)?e:[e];postMessage({id:t,type:n,result:e},i.filter(o=>pi(o)))}q("workerized",{});function Sr(){return typeof WorkerGlobalScope<"u"&&self instanceof WorkerGlobalScope}function We(r,e){if(Array.isArray(e))e.splice(0,e.length);else if(typeof e=="object")for(const t in e)delete e[t];for(const t in r)Array.isArray(r[t])?(e[t]=[],We(r[t],e[t])):typeof r[t]=="object"?(e[t]={},We(r[t],e[t])):e[t]=r[t]}async function yi(r,e){const{functionName:t,args:n}=r;if(!e.instance)throw"instance not initialized";if(!t)throw"missing function name to call";if(!e.instance[t])throw`undefined function [${t}] in class ${e.instance.constructor.workerId}`;ze(r,await e.instance[t](...n!=null?n:[]))}const Rr=q("registeredWorkers",{});function _i(r,e){e.workerId=r,Sr()&&(Rr[e.workerId]=e)}function xi(r,e){if(!r.args)throw"Missing className while initializing worker";const[t,n]=r.args,i=Rr[t];if(i)e.instance=new i(r.args.slice(1));else throw`unknown worker class ${t}`;We(n,X),ze(r,typeof e.instance!==void 0)}async function gi(r,e){const{args:t}=r;if(!e.instance)throw"instance not initialized";let n;e.instance.terminate&&(n=await e.instance.terminate(...t!=null?t:[])),ze(r,n)}function bi(r){if(!r.args)throw"Missing globals while syncing";We(r.args[0],X),ze(r,{})}function vi(){const r={};onmessage=async e=>{const t=e.data;switch(t.type){case z.INIT:xi(t,r);break;case z.FORWARD:yi(t,r);break;case z.TERMINATE:gi(t,r);break;case z.GLOBALS_SYNC:bi(t);break}}}Sr()&&vi();var Ei=Object.defineProperty,Ti=(r,e,t)=>e in r?Ei(r,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):r[e]=t,A=(r,e,t)=>(Ti(r,typeof e!="symbol"?e+"":e,t),t);class J{}A(J,"updates",{transformer_new:"New transformer",transformer_null:"Null transformer"}),A(J,"errors",{transformer_none:"No transformers provided",transformer_start:"Cannot start transformer",transformer_transform:"Cannot transform frame",transformer_flush:"Cannot flush transformer",readable_null:"Readable is null",writable_null:"Writable is null"});const ee=new WeakMap,Ve=new WeakMap,Re=new WeakMap,Rt=Symbol("anyProducer"),Ir=Promise.resolve(),He=Symbol("listenerAdded"),Ye=Symbol("listenerRemoved");let It=!1;function be(r){if(typeof r!="string"&&typeof r!="symbol")throw new TypeError("eventName must be a string or a symbol")}function je(r){if(typeof r!="function")throw new TypeError("listener must be a function")}function ve(r,e){const t=Ve.get(r);return t.has(e)||t.set(e,new Set),t.get(e)}function Ie(r,e){const t=typeof e=="string"||typeof e=="symbol"?e:Rt,n=Re.get(r);return n.has(t)||n.set(t,new Set),n.get(t)}function Ai(r,e,t){const n=Re.get(r);if(n.has(e))for(const i of n.get(e))i.enqueue(t);if(n.has(Rt)){const i=Promise.all([e,t]);for(const o of n.get(Rt))o.enqueue(i)}}function Fr(r,e){e=Array.isArray(e)?e:[e];let t=!1,n=()=>{},i=[];const o={enqueue(s){i.push(s),n()},finish(){t=!0,n()}};for(const s of e)Ie(r,s).add(o);return{async next(){return i?i.length===0?t?(i=void 0,this.next()):(await new Promise(s=>{n=s}),this.next()):{done:!1,value:await i.shift()}:{done:!0}},async return(s){i=void 0;for(const a of e)Ie(r,a).delete(o);return n(),arguments.length>0?{done:!0,value:await s}:{done:!0}},[Symbol.asyncIterator](){return this}}}function Pr(r){if(r===void 0)return Dr;if(!Array.isArray(r))throw new TypeError("`methodNames` must be an array of strings");for(const e of r)if(!Dr.includes(e))throw typeof e!="string"?new TypeError("`methodNames` element must be a string"):new Error(`${e} is not Emittery method`);return r}const Ft=r=>r===He||r===Ye;class fe{static mixin(e,t){return t=Pr(t),n=>{if(typeof n!="function")throw new TypeError("`target` must be function");for(const s of t)if(n.prototype[s]!==void 0)throw new Error(`The property \`${s}\` already exists on \`target\``);function i(){return Object.defineProperty(this,e,{enumerable:!1,value:new fe}),this[e]}Object.defineProperty(n.prototype,e,{enumerable:!1,get:i});const o=s=>function(...a){return this[e][s](...a)};for(const s of t)Object.defineProperty(n.prototype,s,{enumerable:!1,value:o(s)});return n}}static get isDebugEnabled(){if(typeof process!="object")return It;const{env:e}=process||{env:{}};return e.DEBUG==="emittery"||e.DEBUG==="*"||It}static set isDebugEnabled(e){It=e}constructor(e={}){ee.set(this,new Set),Ve.set(this,new Map),Re.set(this,new Map),this.debug=e.debug||{},this.debug.enabled===void 0&&(this.debug.enabled=!1),this.debug.logger||(this.debug.logger=(t,n,i,o)=>{try{o=JSON.stringify(o)}catch{o=`Object with the following keys failed to stringify: ${Object.keys(o).join(",")}`}typeof i=="symbol"&&(i=i.toString());const s=new Date,a=`${s.getHours()}:${s.getMinutes()}:${s.getSeconds()}.${s.getMilliseconds()}`;console.log(`[${a}][emittery:${t}][${n}] Event Name: ${i}
	data: ${o}`)})}logIfDebugEnabled(e,t,n){(fe.isDebugEnabled||this.debug.enabled)&&this.debug.logger(e,this.debug.name,t,n)}on(e,t){je(t),e=Array.isArray(e)?e:[e];for(const n of e)be(n),ve(this,n).add(t),this.logIfDebugEnabled("subscribe",n,void 0),Ft(n)||this.emit(He,{eventName:n,listener:t});return this.off.bind(this,e,t)}off(e,t){je(t),e=Array.isArray(e)?e:[e];for(const n of e)be(n),ve(this,n).delete(t),this.logIfDebugEnabled("unsubscribe",n,void 0),Ft(n)||this.emit(Ye,{eventName:n,listener:t})}once(e){return new Promise(t=>{const n=this.on(e,i=>{n(),t(i)})})}events(e){e=Array.isArray(e)?e:[e];for(const t of e)be(t);return Fr(this,e)}async emit(e,t){be(e),this.logIfDebugEnabled("emit",e,t),Ai(this,e,t);const n=ve(this,e),i=ee.get(this),o=[...n],s=Ft(e)?[]:[...i];await Ir,await Promise.all([...o.map(async a=>{if(n.has(a))return a(t)}),...s.map(async a=>{if(i.has(a))return a(e,t)})])}async emitSerial(e,t){be(e),this.logIfDebugEnabled("emitSerial",e,t);const n=ve(this,e),i=ee.get(this),o=[...n],s=[...i];await Ir;for(const a of o)n.has(a)&&await a(t);for(const a of s)i.has(a)&&await a(e,t)}onAny(e){return je(e),this.logIfDebugEnabled("subscribeAny",void 0,void 0),ee.get(this).add(e),this.emit(He,{listener:e}),this.offAny.bind(this,e)}anyEvent(){return Fr(this)}offAny(e){je(e),this.logIfDebugEnabled("unsubscribeAny",void 0,void 0),this.emit(Ye,{listener:e}),ee.get(this).delete(e)}clearListeners(e){e=Array.isArray(e)?e:[e];for(const t of e)if(this.logIfDebugEnabled("clear",t,void 0),typeof t=="string"||typeof t=="symbol"){ve(this,t).clear();const n=Ie(this,t);for(const i of n)i.finish();n.clear()}else{ee.get(this).clear();for(const n of Ve.get(this).values())n.clear();for(const n of Re.get(this).values()){for(const i of n)i.finish();n.clear()}}}listenerCount(e){e=Array.isArray(e)?e:[e];let t=0;for(const n of e){if(typeof n=="string"){t+=ee.get(this).size+ve(this,n).size+Ie(this,n).size+Ie(this).size;continue}typeof n<"u"&&be(n),t+=ee.get(this).size;for(const i of Ve.get(this).values())t+=i.size;for(const i of Re.get(this).values())t+=i.size}return t}bindMethods(e,t){if(typeof e!="object"||e===null)throw new TypeError("`target` must be an object");t=Pr(t);for(const n of t){if(e[n]!==void 0)throw new Error(`The property \`${n}\` already exists on \`target\``);Object.defineProperty(e,n,{enumerable:!1,value:this[n].bind(this)})}}}const Dr=Object.getOwnPropertyNames(fe.prototype).filter(r=>r!=="constructor");Object.defineProperty(fe,"listenerAdded",{value:He,writable:!1,enumerable:!0,configurable:!1}),Object.defineProperty(fe,"listenerRemoved",{value:Ye,writable:!1,enumerable:!0,configurable:!1});var Pt=fe;function wi(r){return typeof r=="object"&&r!==null&&"message"in r&&typeof r.message=="string"}function Si(r){if(wi(r))return r;try{return new Error(JSON.stringify(r))}catch{return new Error(String(r))}}function Dt(r){return Si(r).message}var Ri=Object.defineProperty,Ii=(r,e,t)=>e in r?Ri(r,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):r[e]=t,Fi=(r,e,t)=>(Ii(r,typeof e!="symbol"?e+"":e,t),t);const Pi="hlg.tokbox.com/prod/logging/vcp_webrtc",Di="https://",Ni=1e4;let Xe;const Mi=new Uint8Array(16);function Ui(){if(!Xe&&(Xe=typeof crypto<"u"&&crypto.getRandomValues&&crypto.getRandomValues.bind(crypto),!Xe))throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");return Xe(Mi)}const M=[];for(let r=0;r<256;++r)M.push((r+256).toString(16).slice(1));function ki(r,e=0){return(M[r[e+0]]+M[r[e+1]]+M[r[e+2]]+M[r[e+3]]+"-"+M[r[e+4]]+M[r[e+5]]+"-"+M[r[e+6]]+M[r[e+7]]+"-"+M[r[e+8]]+M[r[e+9]]+"-"+M[r[e+10]]+M[r[e+11]]+M[r[e+12]]+M[r[e+13]]+M[r[e+14]]+M[r[e+15]]).toLowerCase()}const Ci=typeof crypto<"u"&&crypto.randomUUID&&crypto.randomUUID.bind(crypto),Nr={randomUUID:Ci};function Oi(r,e,t){if(Nr.randomUUID&&!e&&!r)return Nr.randomUUID();r=r||{};const n=r.random||(r.rng||Ui)();if(n[6]=n[6]&15|64,n[8]=n[8]&63|128,e){t=t||0;for(let i=0;i<16;++i)e[t+i]=n[i];return e}return ki(n)}function Nt(r,e){return globalThis[r]||(globalThis[r]=e),globalThis[r]}const te=Nt("globals",{});var le=(r=>(r.INIT="INIT",r.FORWARD="FORWARD",r.TERMINATE="TERMINATE",r.GLOBALS_SYNC="GLOBALS_SYNC",r))(le||{});function Mr(r){return[ImageBitmap,ReadableStream,WritableStream].some(e=>r instanceof e)}let Bi=0;function Li(r,e,t,n,i){const o=Bi++;return r.postMessage({id:o,type:e,functionName:t,args:n},n.filter(s=>Mr(s))),new Promise(s=>{i==null||i.set(o,s)})}function Fe(r,e){const{id:t,type:n}=r,i=Array.isArray(e)?e:[e];postMessage({id:t,type:n,result:e},i.filter(o=>Mr(o)))}const Ur=Nt("workerized",{});function kr(){return typeof WorkerGlobalScope<"u"&&self instanceof WorkerGlobalScope}async function Gi(){if(kr())Fe({type:le.GLOBALS_SYNC},te);else{const r=[];for(const e in Ur){const{worker:t,resolvers:n}=Ur[e].workerContext;t&&r.push(Li(t,le.GLOBALS_SYNC,"",[te],n))}await Promise.all(r)}}function Qe(r,e){if(Array.isArray(e))e.splice(0,e.length);else if(typeof e=="object")for(const t in e)delete e[t];for(const t in r)Array.isArray(r[t])?(e[t]=[],Qe(r[t],e[t])):typeof r[t]=="object"?(e[t]={},Qe(r[t],e[t])):e[t]=r[t]}async function $i(r,e){const{functionName:t,args:n}=r;if(!e.instance)throw"instance not initialized";if(!t)throw"missing function name to call";if(!e.instance[t])throw`undefined function [${t}] in class ${e.instance.constructor.workerId}`;Fe(r,await e.instance[t](...n!=null?n:[]))}const zi=Nt("registeredWorkers",{});function Wi(r,e){if(!r.args)throw"Missing className while initializing worker";const[t,n]=r.args,i=zi[t];if(i)e.instance=new i(r.args.slice(1));else throw`unknown worker class ${t}`;Qe(n,te),Fe(r,typeof e.instance!==void 0)}async function Vi(r,e){const{args:t}=r;if(!e.instance)throw"instance not initialized";let n;e.instance.terminate&&(n=await e.instance.terminate(...t!=null?t:[])),Fe(r,n)}function Hi(r){if(!r.args)throw"Missing globals while syncing";Qe(r.args[0],te),Fe(r,{})}function Yi(){const r={};onmessage=async e=>{const t=e.data;switch(t.type){case le.INIT:Wi(t,r);break;case le.FORWARD:$i(t,r);break;case le.TERMINATE:Vi(t,r);break;case le.GLOBALS_SYNC:Hi(t);break}}}kr()&&Yi();function ji(r,e){return te[r]||(te[r]=e),[()=>te[r],async t=>{te[r]=t,await Gi()}]}function Xi(r,e){return ji(r,e)}const[Qi,Ki]=Xi("metadata");function qi(r){Ki(r)}function Mt(){return Qi()}class Ut{constructor(e){Fi(this,"uuid",Oi()),this.config=e}async send(e){var t,n,i;const{appId:o,sourceType:s}=(t=Mt())!=null?t:{};if(!o||!s)return"metadata missing";const a=new AbortController,u=setTimeout(()=>a.abort(),Ni);return await((i=(n=this.config)==null?void 0:n.fetch)!=null?i:fetch)(this.getUrl(),{method:"POST",headers:this.getHeaders(),body:JSON.stringify(this.buildReport(e)),signal:a.signal}),clearTimeout(u),"success"}getUrl(){var e;let t=(e=Mt().proxyUrl)!=null?e:Di;return t+=(t.at(-1)==="/"?"":"/")+Pi,t}getHeaders(){return{"Content-Type":"application/json"}}buildReport(e){const t=Mt();return{guid:this.uuid,...e,applicationId:t.appId,timestamp:Date.now(),proxyUrl:t.proxyUrl,source:t.sourceType}}}const Ke="2.0.2";class Ji{constructor(e){A(this,"frameTransformedCount",0),A(this,"frameFromSourceCount",0),A(this,"startAt",0),A(this,"reporter"),this.config=e,this.reporter=new Ut(e)}async onFrameFromSource(){this.frameFromSourceCount++}get fps(){const{startAt:e,frameFromSourceCount:t}=this,n=(Date.now()-e)/1e3;return t/n}async onFrameTransformed(e={},t=!1){this.startAt===0&&(this.startAt=Date.now()),this.frameTransformedCount++;const{startAt:n,frameTransformedCount:i,frameFromSourceCount:o}=this,s=Date.now(),a=(s-n)/1e3,u=i/a,f=o/a;return t||this.frameTransformedCount>=this.config.loggingIntervalFrameCount?(this.frameFromSourceCount=0,this.frameTransformedCount=0,this.startAt=s,this.reporter.config=this.config,this.reporter.send({...this.config.report,variation:"QoS",fps:f,transformedFps:u,framesTransformed:i,...e})):"success"}}var kt=(r=>(r.pipeline_ended="pipeline_ended",r.pipeline_ended_with_error="pipeline_ended_with_error",r.pipeline_started="pipeline_started",r.pipeline_started_with_error="pipeline_started_with_error",r.pipeline_restarted="pipeline_restarted",r.pipeline_restarted_with_error="pipeline_restarted_with_error",r))(kt||{});const Zi=500,eo=.8;class to extends Pt{constructor(e,t){super(),A(this,"reporter_",new Ut),A(this,"reporterQos_",new Ji({loggingIntervalFrameCount:Zi,report:{version:Ke}})),A(this,"transformerType_"),A(this,"transformer_"),A(this,"shouldStop_"),A(this,"isFlashed_"),A(this,"mediaTransformerQosReportStartTimestamp_"),A(this,"videoHeight_"),A(this,"videoWidth_"),A(this,"trackExpectedRate_"),A(this,"index_"),A(this,"controller_"),this.index_=t,this.transformer_=e,this.shouldStop_=!1,this.isFlashed_=!1,this.mediaTransformerQosReportStartTimestamp_=0,this.videoHeight_=0,this.videoWidth_=0,this.trackExpectedRate_=-1,this.transformerType_="Custom","getTransformerType"in e&&(this.transformerType_=e.getTransformerType()),this.report({variation:"Create"})}setTrackExpectedRate(e){this.trackExpectedRate_=e}async start(e){if(this.controller_=e,this.transformer_&&typeof this.transformer_.start=="function")try{await this.transformer_.start(e)}catch(t){this.report({message:J.errors.transformer_start,variation:"Error",error:Dt(t)});const n={eventMetaData:{transformerIndex:this.index_},error:t,function:"start"};this.emit("error",n)}}async transform(e,t){var n,i,o,s;if(this.mediaTransformerQosReportStartTimestamp_===0&&(this.mediaTransformerQosReportStartTimestamp_=Date.now()),e instanceof VideoFrame&&(this.videoHeight_=(n=e==null?void 0:e.displayHeight)!=null?n:0,this.videoWidth_=(i=e==null?void 0:e.displayWidth)!=null?i:0),this.reporterQos_.onFrameFromSource(),this.transformer_)if(this.shouldStop_)console.warn("[Pipeline] flush from transform"),e.close(),this.flush(t),t.terminate();else{try{await((s=(o=this.transformer_).transform)==null?void 0:s.call(o,e,t)),this.reportQos()}catch(a){this.report({message:J.errors.transformer_transform,variation:"Error",error:Dt(a)});const u={eventMetaData:{transformerIndex:this.index_},error:a,function:"transform"};this.emit("error",u)}if(this.trackExpectedRate_!=-1&&this.trackExpectedRate_*eo>this.reporterQos_.fps){const a={eventMetaData:{transformerIndex:this.index_},warningType:"fps_drop",dropInfo:{requested:this.trackExpectedRate_,current:this.reporterQos_.fps}};this.emit("warn",a)}}}async flush(e){if(this.transformer_&&typeof this.transformer_.flush=="function"&&!this.isFlashed_){this.isFlashed_=!0;try{await this.transformer_.flush(e)}catch(t){this.report({message:J.errors.transformer_flush,variation:"Error",error:Dt(t)});const n={eventMetaData:{transformerIndex:this.index_},error:t,function:"flush"};this.emit("error",n)}}this.reportQos(!0),this.report({variation:"Delete"})}stop(){console.log("[Pipeline] Stop stream."),this.controller_&&(this.flush(this.controller_),this.controller_.terminate()),this.shouldStop_=!0}report(e){this.reporter_.send({version:Ke,action:"MediaTransformer",transformerType:this.transformerType_,...e})}reportQos(e=!1){this.reporterQos_.config={...this.reporterQos_.config},this.reporterQos_.onFrameTransformed({version:Ke,action:"MediaTransformer",transformerType:this.transformerType_,videoWidth:this.videoWidth_,videoHeight:this.videoHeight_},e)}}class ro extends Pt{constructor(e){super(),A(this,"transformers_"),A(this,"trackExpectedRate_"),this.transformers_=[],this.trackExpectedRate_=-1;for(let t=0;t<e.length;t++){let n=new to(e[t],t);n.on("error",i=>{this.emit("error",i)}),n.on("warn",i=>{this.emit("warn",i)}),this.transformers_.push(n)}}setTrackExpectedRate(e){this.trackExpectedRate_=e;for(let t of this.transformers_)t.setTrackExpectedRate(this.trackExpectedRate_)}async start(e,t){if(!this.transformers_||this.transformers_.length===0){console.log("[Pipeline] No transformers.");return}try{let n=e;for(let i of this.transformers_)e=e.pipeThrough(new TransformStream(i));e.pipeTo(t).then(async()=>{console.log("[Pipeline] Setup."),await t.abort(),await n.cancel(),this.emit("pipelineInfo","pipeline_ended")}).catch(async i=>{e.cancel().then(()=>{console.log("[Pipeline] Shutting down streams after abort.")}).catch(o=>{console.error("[Pipeline] Error from stream transform:",o)}),await t.abort(i),await n.cancel(i),this.emit("pipelineInfo","pipeline_ended_with_error")})}catch{this.emit("pipelineInfo","pipeline_started_with_error"),this.destroy();return}this.emit("pipelineInfo","pipeline_started"),console.log("[Pipeline] Pipeline started.")}async destroy(){console.log("[Pipeline] Destroying Pipeline.");for(let e of this.transformers_)e.stop()}}class no extends Pt{constructor(){super(),A(this,"reporter_"),A(this,"pipeline_"),A(this,"transformers_"),A(this,"readable_"),A(this,"writable_"),A(this,"trackExpectedRate_"),this.reporter_=new Ut,this.trackExpectedRate_=-1,this.report({variation:"Create"})}setTrackExpectedRate(e){this.trackExpectedRate_=e,this.pipeline_&&this.pipeline_.setTrackExpectedRate(this.trackExpectedRate_)}transform(e,t){return this.readable_=e,this.writable_=t,this.transformInternal()}transformInternal(){return new Promise(async(e,t)=>{if(!this.transformers_||this.transformers_.length===0){this.report({message:J.errors.transformer_none,variation:"Error"}),t("[MediaProcessor] Need to set transformers.");return}if(!this.readable_){this.report({variation:"Error",message:J.errors.readable_null}),t("[MediaProcessor] Readable is null.");return}if(!this.writable_){this.report({variation:"Error",message:J.errors.writable_null}),t("[MediaProcessor] Writable is null.");return}let n=!1;this.pipeline_&&(n=!0,this.pipeline_.clearListeners(),this.pipeline_.destroy()),this.pipeline_=new ro(this.transformers_),this.pipeline_.on("warn",i=>{this.emit("warn",i)}),this.pipeline_.on("error",i=>{this.emit("error",i)}),this.pipeline_.on("pipelineInfo",i=>{n&&(i==="pipeline_started"?i=kt.pipeline_restarted:i==="pipeline_started_with_error"&&(i=kt.pipeline_restarted_with_error)),this.emit("pipelineInfo",i)}),this.trackExpectedRate_!=-1&&this.pipeline_.setTrackExpectedRate(this.trackExpectedRate_),this.pipeline_.start(this.readable_,this.writable_).then(()=>{e()}).catch(i=>{t(i)})})}setTransformers(e){return this.report({variation:"Update",message:J.updates.transformer_new}),this.transformers_=e,this.readable_&&this.writable_?this.transformInternal():Promise.resolve()}destroy(){return new Promise(async e=>{this.pipeline_&&this.pipeline_.destroy(),this.report({variation:"Delete"}),e()})}report(e){this.reporter_.send({version:Ke,action:"MediaProcessor",...e})}}var io=Object.defineProperty,oo=(r,e,t)=>e in r?io(r,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):r[e]=t,so=(r,e,t)=>(oo(r,typeof e!="symbol"?e+"":e,t),t);const ao="hlg.tokbox.com/prod/logging/vcp_webrtc",uo="https://",co=1e4;let qe;const fo=new Uint8Array(16);function lo(){if(!qe&&(qe=typeof crypto<"u"&&crypto.getRandomValues&&crypto.getRandomValues.bind(crypto),!qe))throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");return qe(fo)}const U=[];for(let r=0;r<256;++r)U.push((r+256).toString(16).slice(1));function mo(r,e=0){return(U[r[e+0]]+U[r[e+1]]+U[r[e+2]]+U[r[e+3]]+"-"+U[r[e+4]]+U[r[e+5]]+"-"+U[r[e+6]]+U[r[e+7]]+"-"+U[r[e+8]]+U[r[e+9]]+"-"+U[r[e+10]]+U[r[e+11]]+U[r[e+12]]+U[r[e+13]]+U[r[e+14]]+U[r[e+15]]).toLowerCase()}const ho=typeof crypto<"u"&&crypto.randomUUID&&crypto.randomUUID.bind(crypto),Cr={randomUUID:ho};function po(r,e,t){if(Cr.randomUUID&&!e&&!r)return Cr.randomUUID();r=r||{};const n=r.random||(r.rng||lo)();if(n[6]=n[6]&15|64,n[8]=n[8]&63|128,e){t=t||0;for(let i=0;i<16;++i)e[t+i]=n[i];return e}return mo(n)}function Ct(r,e){return globalThis[r]||(globalThis[r]=e),globalThis[r]}const re=Ct("globals",{});var de=(r=>(r.INIT="INIT",r.FORWARD="FORWARD",r.TERMINATE="TERMINATE",r.GLOBALS_SYNC="GLOBALS_SYNC",r))(de||{});function Or(r){return[ImageBitmap,ReadableStream,WritableStream].some(e=>r instanceof e)}let yo=0;function _o(r,e,t,n,i){const o=yo++;return r.postMessage({id:o,type:e,functionName:t,args:n},n.filter(s=>Or(s))),new Promise(s=>{i==null||i.set(o,s)})}function Pe(r,e){const{id:t,type:n}=r,i=Array.isArray(e)?e:[e];postMessage({id:t,type:n,result:e},i.filter(o=>Or(o)))}const Br=Ct("workerized",{});function Lr(){return typeof WorkerGlobalScope<"u"&&self instanceof WorkerGlobalScope}async function xo(){if(Lr())Pe({type:de.GLOBALS_SYNC},re);else{const r=[];for(const e in Br){const{worker:t,resolvers:n}=Br[e].workerContext;t&&r.push(_o(t,de.GLOBALS_SYNC,"",[re],n))}await Promise.all(r)}}function Je(r,e){if(Array.isArray(e))e.splice(0,e.length);else if(typeof e=="object")for(const t in e)delete e[t];for(const t in r)Array.isArray(r[t])?(e[t]=[],Je(r[t],e[t])):typeof r[t]=="object"?(e[t]={},Je(r[t],e[t])):e[t]=r[t]}async function go(r,e){const{functionName:t,args:n}=r;if(!e.instance)throw"instance not initialized";if(!t)throw"missing function name to call";if(!e.instance[t])throw`undefined function [${t}] in class ${e.instance.constructor.workerId}`;Pe(r,await e.instance[t](...n!=null?n:[]))}const bo=Ct("registeredWorkers",{});function vo(r,e){if(!r.args)throw"Missing className while initializing worker";const[t,n]=r.args,i=bo[t];if(i)e.instance=new i(r.args.slice(1));else throw`unknown worker class ${t}`;Je(n,re),Pe(r,typeof e.instance!==void 0)}async function Eo(r,e){const{args:t}=r;if(!e.instance)throw"instance not initialized";let n;e.instance.terminate&&(n=await e.instance.terminate(...t!=null?t:[])),Pe(r,n)}function To(r){if(!r.args)throw"Missing globals while syncing";Je(r.args[0],re),Pe(r,{})}function Ao(){const r={};onmessage=async e=>{const t=e.data;switch(t.type){case de.INIT:vo(t,r);break;case de.FORWARD:go(t,r);break;case de.TERMINATE:Eo(t,r);break;case de.GLOBALS_SYNC:To(t);break}}}Lr()&&Ao();function wo(r,e){return re[r]||(re[r]=e),[()=>re[r],async t=>{re[r]=t,await xo()}]}function So(r,e){return wo(r,e)}const[Ro,sl]=So("metadata");function Ot(){return Ro()}class Io{constructor(e){so(this,"uuid",po()),this.config=e}async send(e){var t,n,i;const{appId:o,sourceType:s}=(t=Ot())!=null?t:{};if(!o||!s)return"metadata missing";const a=new AbortController,u=setTimeout(()=>a.abort(),co);return await((i=(n=this.config)==null?void 0:n.fetch)!=null?i:fetch)(this.getUrl(),{method:"POST",headers:this.getHeaders(),body:JSON.stringify(this.buildReport(e)),signal:a.signal}),clearTimeout(u),"success"}getUrl(){var e;let t=(e=Ot().proxyUrl)!=null?e:uo;return t+=(t.at(-1)==="/"?"":"/")+ao,t}getHeaders(){return{"Content-Type":"application/json"}}buildReport(e){const t=Ot();return{guid:this.uuid,...e,applicationId:t.appId,timestamp:Date.now(),proxyUrl:t.proxyUrl,source:t.sourceType}}}const Fo="4.3.6";var Ze=(r=>(r.Low="Low",r.High="High",r))(Ze||{});async function Gr(r){return new Promise(e=>{setTimeout(()=>{e()},r)})}class Po{constructor(e){p(this,"context");p(this,"extension");p(this,"queries",[]);p(this,"activeQuery");this.context=e,this.extension=e.getExtension("EXT_disjoint_timer_query_webgl2")}start(){}stop(){this.activeQuery&&this.context.endQuery(this.extension.TIME_ELAPSED_EXT)}pushContext(e){this.createQuery("PUSH",e)}popContext(e){this.createQuery("POP",e)}createQuery(e,t){this.activeQuery&&this.context.endQuery(this.extension.TIME_ELAPSED_EXT),this.activeQuery=this.context.createQuery(),this.context.beginQuery(this.extension.TIME_ELAPSED_EXT,this.activeQuery),this.queries.push({name:t,action:e,query:this.activeQuery})}async getResolvedQueries(){const e=(await Promise.all([...this.queries].map(t=>this.resolveQuery(t)))).filter(t=>t);for(let t=1;t<e.length;++t)e[t].timestamp+=e[t-1].duration+e[t-1].timestamp;return e}async resolveQuery(e){if(!await this.awaitQueryAvailable(e)){console.log("Unawaitable query",e);return}if(this.context.getParameter(this.extension.GPU_DISJOINT_EXT)){console.log("Disjointed query",e);return}return{...e,duration:this.context.getQueryParameter(e.query,this.context.QUERY_RESULT),timestamp:0}}async awaitQueryAvailable(e){for(let t=0;t<10;++t){if(this.context.getQueryParameter(e.query,this.context.QUERY_RESULT_AVAILABLE))return e;await Gr(200)}}}/* @license twgl.js 5.3.0 Copyright (c) 2015, Gregg Tavares All Rights Reserved.
Available via the MIT license.
see: http://github.com/greggman/twgl.js for details */const Bt=5120,De=5121,Lt=5122,Gt=5123,$t=5124,zt=5125,Wt=5126,Do=32819,No=32820,Mo=33635,Uo=5131,ko=33640,Co=35899,Oo=35902,Bo=36269,Lo=34042,$r={};{const r=$r;r[Bt]=Int8Array,r[De]=Uint8Array,r[Lt]=Int16Array,r[Gt]=Uint16Array,r[$t]=Int32Array,r[zt]=Uint32Array,r[Wt]=Float32Array,r[Do]=Uint16Array,r[No]=Uint16Array,r[Mo]=Uint16Array,r[Uo]=Uint16Array,r[ko]=Uint32Array,r[Co]=Uint32Array,r[Oo]=Uint32Array,r[Bo]=Uint32Array,r[Lo]=Uint32Array}function Vt(r){if(r instanceof Int8Array)return Bt;if(r instanceof Uint8Array||r instanceof Uint8ClampedArray)return De;if(r instanceof Int16Array)return Lt;if(r instanceof Uint16Array)return Gt;if(r instanceof Int32Array)return $t;if(r instanceof Uint32Array)return zt;if(r instanceof Float32Array)return Wt;throw new Error("unsupported typed array type")}function zr(r){if(r===Int8Array)return Bt;if(r===Uint8Array||r===Uint8ClampedArray)return De;if(r===Int16Array)return Lt;if(r===Uint16Array)return Gt;if(r===Int32Array)return $t;if(r===Uint32Array)return zt;if(r===Float32Array)return Wt;throw new Error("unsupported typed array type")}function Wr(r){const e=$r[r];if(!e)throw new Error("unknown gl type");return e}const et=typeof SharedArrayBuffer<"u"?function(e){return e&&e.buffer&&(e.buffer instanceof ArrayBuffer||e.buffer instanceof SharedArrayBuffer)}:function(e){return e&&e.buffer&&e.buffer instanceof ArrayBuffer};function Vr(...r){console.error(...r)}const Hr=new Map;function tt(r,e){if(!r||typeof r!="object")return!1;let t=Hr.get(e);t||(t=new WeakMap,Hr.set(e,t));let n=t.get(r);if(n===void 0){const i=Object.prototype.toString.call(r);n=i.substring(8,i.length-1)===e,t.set(r,n)}return n}function Go(r,e){return typeof WebGLBuffer<"u"&&tt(e,"WebGLBuffer")}function $o(r,e){return typeof WebGLRenderbuffer<"u"&&tt(e,"WebGLRenderbuffer")}function Ht(r,e){return typeof WebGLTexture<"u"&&tt(e,"WebGLTexture")}function zo(r,e){return typeof WebGLSampler<"u"&&tt(e,"WebGLSampler")}const Yr=35044,me=34962,Wo=34963,Vo=34660,Ho=5120,Yo=5121,jo=5122,Xo=5123,Qo=5124,Ko=5125,jr=5126,Xr={attribPrefix:""};function qo(r,e,t,n,i){r.bindBuffer(e,t),r.bufferData(e,n,i||Yr)}function Qr(r,e,t,n){if(Go(r,e))return e;t=t||me;const i=r.createBuffer();return qo(r,t,i,e,n),i}function Kr(r){return r==="indices"}function Jo(r){return r===Int8Array||r===Uint8Array}function Zo(r){return r.length?r:r.data}const es=/coord|texture/i,ts=/color|colour/i;function rs(r,e){let t;if(es.test(r)?t=2:ts.test(r)?t=4:t=3,e%t>0)throw new Error(`Can not guess numComponents for attribute '${r}'. Tried ${t} but ${e} values is not evenly divisible by ${t}. You should specify it.`);return t}function ns(r,e,t){return r.numComponents||r.size||rs(e,t||Zo(r).length)}function qr(r,e){if(et(r))return r;if(et(r.data))return r.data;Array.isArray(r)&&(r={data:r});let t=r.type?Yt(r.type):void 0;return t||(Kr(e)?t=Uint16Array:t=Float32Array),new t(r.data)}function is(r){return typeof r=="number"?r:r?zr(r):jr}function Yt(r){return typeof r=="number"?Wr(r):r||Float32Array}function os(r,e){return{buffer:e.buffer,numValues:2*3*4,type:is(e.type),arrayType:Yt(e.type)}}function ss(r,e){const t=e.data||e,n=Yt(e.type),i=t*n.BYTES_PER_ELEMENT,o=r.createBuffer();return r.bindBuffer(me,o),r.bufferData(me,i,e.drawType||Yr),{buffer:o,numValues:t,type:zr(n),arrayType:n}}function as(r,e,t){const n=qr(e,t);return{arrayType:n.constructor,buffer:Qr(r,n,void 0,e.drawType),type:Vt(n),numValues:0}}function us(r,e){const t={};return Object.keys(e).forEach(function(n){if(!Kr(n)){const i=e[n],o=i.attrib||i.name||i.attribName||Xr.attribPrefix+n;if(i.value){if(!Array.isArray(i.value)&&!et(i.value))throw new Error("array.value is not array or typedarray");t[o]={value:i.value}}else{let s;i.buffer&&i.buffer instanceof WebGLBuffer?s=os:typeof i=="number"||typeof i.data=="number"?s=ss:s=as;const{buffer:a,type:u,numValues:f,arrayType:d}=s(r,i,n),h=i.normalize!==void 0?i.normalize:Jo(d),y=ns(i,n,f);t[o]={buffer:a,numComponents:y,type:u,normalize:h,stride:i.stride||0,offset:i.offset||0,divisor:i.divisor===void 0?void 0:i.divisor,drawType:i.drawType}}}}),r.bindBuffer(me,null),t}function cs(r,e){return e===Ho||e===Yo?1:e===jo||e===Xo?2:e===Qo||e===Ko||e===jr?4:0}const jt=["position","positions","a_position"];function fs(r,e){let t,n;for(n=0;n<jt.length&&(t=jt[n],!(t in e||(t=Xr.attribPrefix+t,t in e)));++n);n===jt.length&&(t=Object.keys(e)[0]);const i=e[t];if(!i.buffer)return 1;r.bindBuffer(me,i.buffer);const o=r.getBufferParameter(me,Vo);r.bindBuffer(me,null);const s=cs(r,i.type),a=o/s,u=i.numComponents||i.size,f=a/u;if(f%1!==0)throw new Error(`numComponents ${u} not correct for length ${length}`);return f}function ls(r,e,t){const n=us(r,e),i=Object.assign({},t||{});i.attribs=Object.assign({},t?t.attribs:{},n);const o=e.indices;if(o){const s=qr(o,"indices");i.indices=Qr(r,s,Wo),i.numElements=s.length,i.elementType=Vt(s)}else i.numElements||(i.numElements=fs(r,i.attribs));return i}function Ne(r){return!!r.texStorage2D}const Jr=function(){const r={},e={};function t(n){const i=n.constructor.name;if(!r[i]){for(const o in n)if(typeof n[o]=="number"){const s=e[n[o]];e[n[o]]=s?`${s} | ${o}`:o}r[i]=!0}}return function(i,o){return t(i),e[o]||(typeof o=="number"?`0x${o.toString(16)}`:o)}}(),ne={textureColor:new Uint8Array([128,192,255,255]),textureOptions:{},crossOrigin:void 0},Me=et,Zr=function(){let r;return function(){return r=r||(typeof document<"u"&&document.createElement?document.createElement("canvas").getContext("2d"):null),r}}(),en=6406,Q=6407,F=6408,tn=6409,rn=6410,Ue=6402,nn=34041,rt=33071,ds=9728,ms=9729,ie=3553,oe=34067,he=32879,pe=35866,Xt=34069,hs=34070,ps=34071,ys=34072,_s=34073,xs=34074,Qt=10241,Kt=10240,nt=10242,it=10243,on=32882,gs=33082,bs=33083,vs=33084,Es=33085,qt=3317,sn=3314,an=32878,un=3316,cn=3315,fn=32877,Ts=37443,As=37441,ws=37440,Ss=33321,Rs=36756,Is=33325,Fs=33326,Ps=33330,Ds=33329,Ns=33338,Ms=33337,Us=33340,ks=33339,Cs=33323,Os=36757,Bs=33327,Ls=33328,Gs=33336,$s=33335,zs=33332,Ws=33331,Vs=33334,Hs=33333,Ys=32849,js=35905,Xs=36194,Qs=36758,Ks=35898,qs=35901,Js=34843,Zs=34837,ea=36221,ta=36239,ra=36215,na=36233,ia=36209,oa=36227,sa=32856,aa=35907,ua=36759,ca=32855,fa=32854,la=32857,da=34842,ma=34836,ha=36220,pa=36238,ya=36975,_a=36214,xa=36232,ga=36226,ba=36208,va=33189,Ea=33190,Ta=36012,Aa=36013,wa=35056,se=5120,R=5121,ot=5122,Ee=5123,st=5124,ye=5125,C=5126,ln=32819,dn=32820,mn=33635,W=5131,ke=36193,Jt=33640,Sa=35899,Ra=35902,Ia=36269,Fa=34042,at=33319,Te=33320,ut=6403,Ae=36244,we=36248,_e=36249;let Zt;function ct(r){if(!Zt){const e={};e[en]={textureFormat:en,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[1,2,2,4],type:[R,W,ke,C]},e[tn]={textureFormat:tn,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[1,2,2,4],type:[R,W,ke,C]},e[rn]={textureFormat:rn,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[2,4,4,8],type:[R,W,ke,C]},e[Q]={textureFormat:Q,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[3,6,6,12,2],type:[R,W,ke,C,mn]},e[F]={textureFormat:F,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[4,8,8,16,2,2],type:[R,W,ke,C,ln,dn]},e[Ue]={textureFormat:Ue,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[2,4],type:[ye,Ee]},e[Ss]={textureFormat:ut,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[1],type:[R]},e[Rs]={textureFormat:ut,colorRenderable:!1,textureFilterable:!0,bytesPerElement:[1],type:[se]},e[Is]={textureFormat:ut,colorRenderable:!1,textureFilterable:!0,bytesPerElement:[4,2],type:[C,W]},e[Fs]={textureFormat:ut,colorRenderable:!1,textureFilterable:!1,bytesPerElement:[4],type:[C]},e[Ps]={textureFormat:Ae,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[1],type:[R]},e[Ds]={textureFormat:Ae,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[1],type:[se]},e[zs]={textureFormat:Ae,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[2],type:[Ee]},e[Ws]={textureFormat:Ae,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[2],type:[ot]},e[Vs]={textureFormat:Ae,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[4],type:[ye]},e[Hs]={textureFormat:Ae,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[4],type:[st]},e[Cs]={textureFormat:at,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[2],type:[R]},e[Os]={textureFormat:at,colorRenderable:!1,textureFilterable:!0,bytesPerElement:[2],type:[se]},e[Bs]={textureFormat:at,colorRenderable:!1,textureFilterable:!0,bytesPerElement:[8,4],type:[C,W]},e[Ls]={textureFormat:at,colorRenderable:!1,textureFilterable:!1,bytesPerElement:[8],type:[C]},e[Gs]={textureFormat:Te,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[2],type:[R]},e[$s]={textureFormat:Te,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[2],type:[se]},e[Ns]={textureFormat:Te,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[4],type:[Ee]},e[Ms]={textureFormat:Te,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[4],type:[ot]},e[Us]={textureFormat:Te,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[8],type:[ye]},e[ks]={textureFormat:Te,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[8],type:[st]},e[Ys]={textureFormat:Q,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[3],type:[R]},e[js]={textureFormat:Q,colorRenderable:!1,textureFilterable:!0,bytesPerElement:[3],type:[R]},e[Xs]={textureFormat:Q,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[3,2],type:[R,mn]},e[Qs]={textureFormat:Q,colorRenderable:!1,textureFilterable:!0,bytesPerElement:[3],type:[se]},e[Ks]={textureFormat:Q,colorRenderable:!1,textureFilterable:!0,bytesPerElement:[12,6,4],type:[C,W,Sa]},e[qs]={textureFormat:Q,colorRenderable:!1,textureFilterable:!0,bytesPerElement:[12,6,4],type:[C,W,Ra]},e[Js]={textureFormat:Q,colorRenderable:!1,textureFilterable:!0,bytesPerElement:[12,6],type:[C,W]},e[Zs]={textureFormat:Q,colorRenderable:!1,textureFilterable:!1,bytesPerElement:[12],type:[C]},e[ea]={textureFormat:we,colorRenderable:!1,textureFilterable:!1,bytesPerElement:[3],type:[R]},e[ta]={textureFormat:we,colorRenderable:!1,textureFilterable:!1,bytesPerElement:[3],type:[se]},e[ra]={textureFormat:we,colorRenderable:!1,textureFilterable:!1,bytesPerElement:[6],type:[Ee]},e[na]={textureFormat:we,colorRenderable:!1,textureFilterable:!1,bytesPerElement:[6],type:[ot]},e[ia]={textureFormat:we,colorRenderable:!1,textureFilterable:!1,bytesPerElement:[12],type:[ye]},e[oa]={textureFormat:we,colorRenderable:!1,textureFilterable:!1,bytesPerElement:[12],type:[st]},e[sa]={textureFormat:F,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[4],type:[R]},e[aa]={textureFormat:F,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[4],type:[R]},e[ua]={textureFormat:F,colorRenderable:!1,textureFilterable:!0,bytesPerElement:[4],type:[se]},e[ca]={textureFormat:F,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[4,2,4],type:[R,dn,Jt]},e[fa]={textureFormat:F,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[4,2],type:[R,ln]},e[la]={textureFormat:F,colorRenderable:!0,textureFilterable:!0,bytesPerElement:[4],type:[Jt]},e[da]={textureFormat:F,colorRenderable:!1,textureFilterable:!0,bytesPerElement:[16,8],type:[C,W]},e[ma]={textureFormat:F,colorRenderable:!1,textureFilterable:!1,bytesPerElement:[16],type:[C]},e[ha]={textureFormat:_e,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[4],type:[R]},e[pa]={textureFormat:_e,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[4],type:[se]},e[ya]={textureFormat:_e,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[4],type:[Jt]},e[_a]={textureFormat:_e,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[8],type:[Ee]},e[xa]={textureFormat:_e,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[8],type:[ot]},e[ga]={textureFormat:_e,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[16],type:[st]},e[ba]={textureFormat:_e,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[16],type:[ye]},e[va]={textureFormat:Ue,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[2,4],type:[Ee,ye]},e[Ea]={textureFormat:Ue,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[4],type:[ye]},e[Ta]={textureFormat:Ue,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[4],type:[C]},e[wa]={textureFormat:nn,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[4],type:[Fa]},e[Aa]={textureFormat:nn,colorRenderable:!0,textureFilterable:!1,bytesPerElement:[4],type:[Ia]},Object.keys(e).forEach(function(t){const n=e[t];n.bytesPerElementMap={},n.bytesPerElement.forEach(function(i,o){const s=n.type[o];n.bytesPerElementMap[s]=i})}),Zt=e}return Zt[r]}function Pa(r,e){const t=ct(r);if(!t)throw"unknown internal format";const n=t.bytesPerElementMap[e];if(n===void 0)throw"unknown internal format";return n}function Ce(r){const e=ct(r);if(!e)throw"unknown internal format";return{format:e.textureFormat,type:e.type[0]}}function hn(r){return(r&r-1)===0}function Da(r,e,t,n){if(!Ne(r))return hn(e)&&hn(t);const i=ct(n);if(!i)throw"unknown internal format";return i.colorRenderable&&i.textureFilterable}function Na(r){const e=ct(r);if(!e)throw"unknown internal format";return e.textureFilterable}function Ma(r,e,t){return Me(e)?Vt(e):t||R}function ft(r,e,t,n,i){if(i%1!==0)throw"can't guess dimensions";if(!t&&!n){const o=Math.sqrt(i/(e===oe?6:1));o%1===0?(t=o,n=o):(t=i,n=1)}else if(n){if(!t&&(t=i/n,t%1))throw"can't guess dimensions"}else if(n=i/t,n%1)throw"can't guess dimensions";return{width:t,height:n}}function Se(r,e){e.colorspaceConversion!==void 0&&r.pixelStorei(Ts,e.colorspaceConversion),e.premultiplyAlpha!==void 0&&r.pixelStorei(As,e.premultiplyAlpha),e.flipY!==void 0&&r.pixelStorei(ws,e.flipY)}function pn(r){r.pixelStorei(qt,4),Ne(r)&&(r.pixelStorei(sn,0),r.pixelStorei(an,0),r.pixelStorei(un,0),r.pixelStorei(cn,0),r.pixelStorei(fn,0))}function Ua(r,e,t,n){n.minMag&&(t.call(r,e,Qt,n.minMag),t.call(r,e,Kt,n.minMag)),n.min&&t.call(r,e,Qt,n.min),n.mag&&t.call(r,e,Kt,n.mag),n.wrap&&(t.call(r,e,nt,n.wrap),t.call(r,e,it,n.wrap),(e===he||zo(r,e))&&t.call(r,e,on,n.wrap)),n.wrapR&&t.call(r,e,on,n.wrapR),n.wrapS&&t.call(r,e,nt,n.wrapS),n.wrapT&&t.call(r,e,it,n.wrapT),n.minLod&&t.call(r,e,gs,n.minLod),n.maxLod&&t.call(r,e,bs,n.maxLod),n.baseLevel&&t.call(r,e,vs,n.baseLevel),n.maxLevel&&t.call(r,e,Es,n.maxLevel)}function yn(r,e,t){const n=t.target||ie;r.bindTexture(n,e),Ua(r,n,r.texParameteri,t)}function ka(r){return r=r||ne.textureColor,Me(r)?r:new Uint8Array([r[0]*255,r[1]*255,r[2]*255,r[3]*255])}function er(r,e,t,n,i,o){t=t||ne.textureOptions,o=o||F;const s=t.target||ie;if(n=n||t.width,i=i||t.height,r.bindTexture(s,e),Da(r,n,i,o))r.generateMipmap(s);else{const a=Na(o)?ms:ds;r.texParameteri(s,Qt,a),r.texParameteri(s,Kt,a),r.texParameteri(s,nt,rt),r.texParameteri(s,it,rt)}}function Oe(r){return r.auto===!0||r.auto===void 0&&r.level===void 0}function tr(r,e){return e=e||{},e.cubeFaceOrder||[Xt,hs,ps,ys,_s,xs]}function rr(r,e){const n=tr(r,e).map(function(i,o){return{face:i,ndx:o}});return n.sort(function(i,o){return i.face-o.face}),n}function _n(r,e,t,n){n=n||ne.textureOptions;const i=n.target||ie,o=n.level||0;let s=t.width,a=t.height;const u=n.internalFormat||n.format||F,f=Ce(u),d=n.format||f.format,h=n.type||f.type;if(Se(r,n),r.bindTexture(i,e),i===oe){const y=t.width,x=t.height;let l,g;if(y/6===x)l=x,g=[0,0,1,0,2,0,3,0,4,0,5,0];else if(x/6===y)l=y,g=[0,0,0,1,0,2,0,3,0,4,0,5];else if(y/3===x/2)l=y/3,g=[0,0,1,0,2,0,0,1,1,1,2,1];else if(y/2===x/3)l=y/2,g=[0,0,1,0,0,1,1,1,0,2,1,2];else throw"can't figure out cube map from element: "+(t.src?t.src:t.nodeName);const E=Zr();E?(E.canvas.width=l,E.canvas.height=l,s=l,a=l,rr(r,n).forEach(function(v){const I=g[v.ndx*2+0]*l,D=g[v.ndx*2+1]*l;E.drawImage(t,I,D,l,l,0,0,l,l),r.texImage2D(v.face,o,u,d,h,E.canvas)}),E.canvas.width=1,E.canvas.height=1):typeof createImageBitmap<"u"&&(s=l,a=l,rr(r,n).forEach(function(v){const I=g[v.ndx*2+0]*l,D=g[v.ndx*2+1]*l;r.texImage2D(v.face,o,u,l,l,0,d,h,null),createImageBitmap(t,I,D,l,l,{premultiplyAlpha:"none",colorSpaceConversion:"none"}).then(function(G){Se(r,n),r.bindTexture(i,e),r.texImage2D(v.face,o,u,d,h,G),Oe(n)&&er(r,e,n,s,a,u)})}))}else if(i===he||i===pe){const y=Math.min(t.width,t.height),x=Math.max(t.width,t.height),l=x/y;if(l%1!==0)throw"can not compute 3D dimensions of element";const g=t.width===x?1:0,E=t.height===x?1:0;r.pixelStorei(qt,1),r.pixelStorei(sn,t.width),r.pixelStorei(an,0),r.pixelStorei(fn,0),r.texImage3D(i,o,u,y,y,y,0,d,h,null);for(let v=0;v<l;++v){const I=v*y*g,D=v*y*E;r.pixelStorei(un,I),r.pixelStorei(cn,D),r.texSubImage3D(i,o,0,0,v,y,y,1,d,h,t)}pn(r)}else r.texImage2D(i,o,u,d,h,t);Oe(n)&&er(r,e,n,s,a,u),yn(r,e,n)}function Be(){}function Ca(r){if(typeof document<"u"){const e=document.createElement("a");return e.href=r,e.hostname===location.hostname&&e.port===location.port&&e.protocol===location.protocol}else{const e=new URL(location.href).origin;return new URL(r,location.href).origin===e}}function Oa(r,e){return e===void 0&&!Ca(r)?"anonymous":e}function Ba(r,e,t){t=t||Be;let n;if(e=e!==void 0?e:ne.crossOrigin,e=Oa(r,e),typeof Image<"u"){n=new Image,e!==void 0&&(n.crossOrigin=e);const i=function(){n.removeEventListener("error",o),n.removeEventListener("load",s),n=null},o=function(){const u="couldn't load image: "+r;Vr(u),t(u,n),i()},s=function(){t(null,n),i()};return n.addEventListener("error",o),n.addEventListener("load",s),n.src=r,n}else if(typeof ImageBitmap<"u"){let i,o;const s=function(){t(i,o)},a={};e&&(a.mode="cors"),fetch(r,a).then(function(u){if(!u.ok)throw u;return u.blob()}).then(function(u){return createImageBitmap(u,{premultiplyAlpha:"none",colorSpaceConversion:"none"})}).then(function(u){o=u,setTimeout(s)}).catch(function(u){i=u,setTimeout(s)}),n=null}return n}function xn(r){return typeof ImageBitmap<"u"&&r instanceof ImageBitmap||typeof ImageData<"u"&&r instanceof ImageData||typeof HTMLElement<"u"&&r instanceof HTMLElement}function nr(r,e,t){return xn(r)?(setTimeout(function(){t(null,r)}),r):Ba(r,e,t)}function ir(r,e,t){t=t||ne.textureOptions;const n=t.target||ie;if(r.bindTexture(n,e),t.color===!1)return;const i=ka(t.color);if(n===oe)for(let o=0;o<6;++o)r.texImage2D(Xt+o,0,F,1,1,0,F,R,i);else n===he||n===pe?r.texImage3D(n,0,F,1,1,1,0,F,R,i):r.texImage2D(n,0,F,1,1,0,F,R,i)}function La(r,e,t,n){return n=n||Be,t=t||ne.textureOptions,ir(r,e,t),t=Object.assign({},t),nr(t.src,t.crossOrigin,function(o,s){o?n(o,e,s):(_n(r,e,s,t),n(null,e,s))})}function Ga(r,e,t,n){n=n||Be;const i=t.src;if(i.length!==6)throw"there must be 6 urls for a cubemap";const o=t.level||0,s=t.internalFormat||t.format||F,a=Ce(s),u=t.format||a.format,f=t.type||R,d=t.target||ie;if(d!==oe)throw"target must be TEXTURE_CUBE_MAP";ir(r,e,t),t=Object.assign({},t);let h=6;const y=[],x=tr(r,t);let l;function g(E){return function(v,I){--h,v?y.push(v):I.width!==I.height?y.push("cubemap face img is not a square: "+I.src):(Se(r,t),r.bindTexture(d,e),h===5?tr().forEach(function(D){r.texImage2D(D,o,s,u,f,I)}):r.texImage2D(E,o,s,u,f,I),Oe(t)&&r.generateMipmap(d)),h===0&&n(y.length?y:void 0,e,l)}}l=i.map(function(E,v){return nr(E,t.crossOrigin,g(x[v]))})}function $a(r,e,t,n){n=n||Be;const i=t.src,o=t.internalFormat||t.format||F,s=Ce(o),a=t.format||s.format,u=t.type||R,f=t.target||pe;if(f!==he&&f!==pe)throw"target must be TEXTURE_3D or TEXTURE_2D_ARRAY";ir(r,e,t),t=Object.assign({},t);let d=i.length;const h=[];let y;const x=t.level||0;let l=t.width,g=t.height;const E=i.length;let v=!0;function I(D){return function(G,$){if(--d,G)h.push(G);else{if(Se(r,t),r.bindTexture(f,e),v){v=!1,l=t.width||$.width,g=t.height||$.height,r.texImage3D(f,x,o,l,g,E,0,a,u,null);for(let Z=0;Z<E;++Z)r.texSubImage3D(f,x,0,0,Z,l,g,1,a,u,$)}else{let Z=$,H;($.width!==l||$.height!==g)&&(H=Zr(),Z=H.canvas,H.canvas.width=l,H.canvas.height=g,H.drawImage($,0,0,l,g)),r.texSubImage3D(f,x,0,0,D,l,g,1,a,u,Z),H&&Z===H.canvas&&(H.canvas.width=0,H.canvas.height=0)}Oe(t)&&r.generateMipmap(f)}d===0&&n(h.length?h:void 0,e,y)}}y=i.map(function(D,G){return nr(D,t.crossOrigin,I(G))})}function za(r,e,t,n){n=n||ne.textureOptions;const i=n.target||ie;r.bindTexture(i,e);let o=n.width,s=n.height,a=n.depth;const u=n.level||0,f=n.internalFormat||n.format||F,d=Ce(f),h=n.format||d.format,y=n.type||Ma(r,t,d.type);if(Me(t))t instanceof Uint8ClampedArray&&(t=new Uint8Array(t.buffer));else{const E=Wr(y);t=new E(t)}const x=Pa(f,y),l=t.byteLength/x;if(l%1)throw"length wrong size for format: "+Jr(r,h);let g;if(i===he||i===pe)if(!o&&!s&&!a){const E=Math.cbrt(l);if(E%1!==0)throw"can't guess cube size of array of numElements: "+l;o=E,s=E,a=E}else o&&(!s||!a)?(g=ft(r,i,s,a,l/o),s=g.width,a=g.height):s&&(!o||!a)?(g=ft(r,i,o,a,l/s),o=g.width,a=g.height):(g=ft(r,i,o,s,l/a),o=g.width,s=g.height);else g=ft(r,i,o,s,l),o=g.width,s=g.height;if(pn(r),r.pixelStorei(qt,n.unpackAlignment||1),Se(r,n),i===oe){const E=x/t.BYTES_PER_ELEMENT,v=l/6*E;rr(r,n).forEach(I=>{const D=v*I.ndx,G=t.subarray(D,D+v);r.texImage2D(I.face,u,f,o,s,0,h,y,G)})}else i===he||i===pe?r.texImage3D(i,u,f,o,s,a,0,h,y,t):r.texImage2D(i,u,f,o,s,0,h,y,t);return{width:o,height:s,depth:a,type:y}}function Wa(r,e,t){const n=t.target||ie;r.bindTexture(n,e);const i=t.level||0,o=t.internalFormat||t.format||F,s=Ce(o),a=t.format||s.format,u=t.type||s.type;if(Se(r,t),n===oe)for(let f=0;f<6;++f)r.texImage2D(Xt+f,i,o,t.width,t.height,0,a,u,null);else n===he||n===pe?r.texImage3D(n,i,o,t.width,t.height,t.depth,0,a,u,null):r.texImage2D(n,i,o,t.width,t.height,0,a,u,null)}function gn(r,e,t){t=t||Be,e=e||ne.textureOptions;const n=r.createTexture(),i=e.target||ie;let o=e.width||1,s=e.height||1;const a=e.internalFormat||F;r.bindTexture(i,n),i===oe&&(r.texParameteri(i,nt,rt),r.texParameteri(i,it,rt));let u=e.src;if(u)if(typeof u=="function"&&(u=u(r,e)),typeof u=="string")La(r,n,e,t);else if(Me(u)||Array.isArray(u)&&(typeof u[0]=="number"||Array.isArray(u[0])||Me(u[0]))){const f=za(r,n,u,e);o=f.width,s=f.height}else Array.isArray(u)&&(typeof u[0]=="string"||xn(u[0]))?i===oe?Ga(r,n,e,t):$a(r,n,e,t):(_n(r,n,u,e),o=u.width,s=u.height);else Wa(r,n,e);return Oe(e)&&er(r,n,e,o,s,a),yn(r,n,e),n}const or=Vr;function bn(r){return typeof document<"u"&&document.getElementById?document.getElementById(r):null}const lt=33984,dt=34962,Va=34963,Ha=35713,Ya=35714,ja=35632,Xa=35633,Qa=35981,vn=35718,Ka=35721,qa=35971,Ja=35382,Za=35396,eu=35398,tu=35392,ru=35395,mt=5126,En=35664,Tn=35665,An=35666,sr=5124,wn=35667,Sn=35668,Rn=35669,In=35670,Fn=35671,Pn=35672,Dn=35673,Nn=35674,Mn=35675,Un=35676,nu=35678,iu=35680,ou=35679,su=35682,au=35685,uu=35686,cu=35687,fu=35688,lu=35689,du=35690,mu=36289,hu=36292,pu=36293,ar=5125,kn=36294,Cn=36295,On=36296,yu=36298,_u=36299,xu=36300,gu=36303,bu=36306,vu=36307,Eu=36308,Tu=36311,ht=3553,pt=34067,ur=32879,yt=35866,b={};function Bn(r,e){return b[e].bindPoint}function Au(r,e){return function(t){r.uniform1f(e,t)}}function wu(r,e){return function(t){r.uniform1fv(e,t)}}function Su(r,e){return function(t){r.uniform2fv(e,t)}}function Ru(r,e){return function(t){r.uniform3fv(e,t)}}function Iu(r,e){return function(t){r.uniform4fv(e,t)}}function Ln(r,e){return function(t){r.uniform1i(e,t)}}function Gn(r,e){return function(t){r.uniform1iv(e,t)}}function $n(r,e){return function(t){r.uniform2iv(e,t)}}function zn(r,e){return function(t){r.uniform3iv(e,t)}}function Wn(r,e){return function(t){r.uniform4iv(e,t)}}function Fu(r,e){return function(t){r.uniform1ui(e,t)}}function Pu(r,e){return function(t){r.uniform1uiv(e,t)}}function Du(r,e){return function(t){r.uniform2uiv(e,t)}}function Nu(r,e){return function(t){r.uniform3uiv(e,t)}}function Mu(r,e){return function(t){r.uniform4uiv(e,t)}}function Uu(r,e){return function(t){r.uniformMatrix2fv(e,!1,t)}}function ku(r,e){return function(t){r.uniformMatrix3fv(e,!1,t)}}function Cu(r,e){return function(t){r.uniformMatrix4fv(e,!1,t)}}function Ou(r,e){return function(t){r.uniformMatrix2x3fv(e,!1,t)}}function Bu(r,e){return function(t){r.uniformMatrix3x2fv(e,!1,t)}}function Lu(r,e){return function(t){r.uniformMatrix2x4fv(e,!1,t)}}function Gu(r,e){return function(t){r.uniformMatrix4x2fv(e,!1,t)}}function $u(r,e){return function(t){r.uniformMatrix3x4fv(e,!1,t)}}function zu(r,e){return function(t){r.uniformMatrix4x3fv(e,!1,t)}}function B(r,e,t,n){const i=Bn(r,e);return Ne(r)?function(o){let s,a;!o||Ht(r,o)?(s=o,a=null):(s=o.texture,a=o.sampler),r.uniform1i(n,t),r.activeTexture(lt+t),r.bindTexture(i,s),r.bindSampler(t,a)}:function(o){r.uniform1i(n,t),r.activeTexture(lt+t),r.bindTexture(i,o)}}function L(r,e,t,n,i){const o=Bn(r,e),s=new Int32Array(i);for(let a=0;a<i;++a)s[a]=t+a;return Ne(r)?function(a){r.uniform1iv(n,s),a.forEach(function(u,f){r.activeTexture(lt+s[f]);let d,h;Ht(r,u)?(d=u,h=null):(d=u.texture,h=u.sampler),r.bindSampler(t,h),r.bindTexture(o,d)})}:function(a){r.uniform1iv(n,s),a.forEach(function(u,f){r.activeTexture(lt+s[f]),r.bindTexture(o,u)})}}b[mt]={Type:Float32Array,size:4,setter:Au,arraySetter:wu},b[En]={Type:Float32Array,size:8,setter:Su,cols:2},b[Tn]={Type:Float32Array,size:12,setter:Ru,cols:3},b[An]={Type:Float32Array,size:16,setter:Iu,cols:4},b[sr]={Type:Int32Array,size:4,setter:Ln,arraySetter:Gn},b[wn]={Type:Int32Array,size:8,setter:$n,cols:2},b[Sn]={Type:Int32Array,size:12,setter:zn,cols:3},b[Rn]={Type:Int32Array,size:16,setter:Wn,cols:4},b[ar]={Type:Uint32Array,size:4,setter:Fu,arraySetter:Pu},b[kn]={Type:Uint32Array,size:8,setter:Du,cols:2},b[Cn]={Type:Uint32Array,size:12,setter:Nu,cols:3},b[On]={Type:Uint32Array,size:16,setter:Mu,cols:4},b[In]={Type:Uint32Array,size:4,setter:Ln,arraySetter:Gn},b[Fn]={Type:Uint32Array,size:8,setter:$n,cols:2},b[Pn]={Type:Uint32Array,size:12,setter:zn,cols:3},b[Dn]={Type:Uint32Array,size:16,setter:Wn,cols:4},b[Nn]={Type:Float32Array,size:32,setter:Uu,rows:2,cols:2},b[Mn]={Type:Float32Array,size:48,setter:ku,rows:3,cols:3},b[Un]={Type:Float32Array,size:64,setter:Cu,rows:4,cols:4},b[au]={Type:Float32Array,size:32,setter:Ou,rows:2,cols:3},b[uu]={Type:Float32Array,size:32,setter:Lu,rows:2,cols:4},b[cu]={Type:Float32Array,size:48,setter:Bu,rows:3,cols:2},b[fu]={Type:Float32Array,size:48,setter:$u,rows:3,cols:4},b[lu]={Type:Float32Array,size:64,setter:Gu,rows:4,cols:2},b[du]={Type:Float32Array,size:64,setter:zu,rows:4,cols:3},b[nu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:ht},b[iu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:pt},b[ou]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:ur},b[su]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:ht},b[mu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:yt},b[hu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:yt},b[pu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:pt},b[yu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:ht},b[_u]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:ur},b[xu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:pt},b[gu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:yt},b[bu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:ht},b[vu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:ur},b[Eu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:pt},b[Tu]={Type:null,size:0,setter:B,arraySetter:L,bindPoint:yt};function _t(r,e){return function(t){if(t.value)switch(r.disableVertexAttribArray(e),t.value.length){case 4:r.vertexAttrib4fv(e,t.value);break;case 3:r.vertexAttrib3fv(e,t.value);break;case 2:r.vertexAttrib2fv(e,t.value);break;case 1:r.vertexAttrib1fv(e,t.value);break;default:throw new Error("the length of a float constant value must be between 1 and 4!")}else r.bindBuffer(dt,t.buffer),r.enableVertexAttribArray(e),r.vertexAttribPointer(e,t.numComponents||t.size,t.type||mt,t.normalize||!1,t.stride||0,t.offset||0),r.vertexAttribDivisor&&r.vertexAttribDivisor(e,t.divisor||0)}}function ae(r,e){return function(t){if(t.value)if(r.disableVertexAttribArray(e),t.value.length===4)r.vertexAttrib4iv(e,t.value);else throw new Error("The length of an integer constant value must be 4!");else r.bindBuffer(dt,t.buffer),r.enableVertexAttribArray(e),r.vertexAttribIPointer(e,t.numComponents||t.size,t.type||sr,t.stride||0,t.offset||0),r.vertexAttribDivisor&&r.vertexAttribDivisor(e,t.divisor||0)}}function xt(r,e){return function(t){if(t.value)if(r.disableVertexAttribArray(e),t.value.length===4)r.vertexAttrib4uiv(e,t.value);else throw new Error("The length of an unsigned integer constant value must be 4!");else r.bindBuffer(dt,t.buffer),r.enableVertexAttribArray(e),r.vertexAttribIPointer(e,t.numComponents||t.size,t.type||ar,t.stride||0,t.offset||0),r.vertexAttribDivisor&&r.vertexAttribDivisor(e,t.divisor||0)}}function cr(r,e,t){const n=t.size,i=t.count;return function(o){r.bindBuffer(dt,o.buffer);const s=o.size||o.numComponents||n,a=s/i,u=o.type||mt,d=b[u].size*s,h=o.normalize||!1,y=o.offset||0,x=d/i;for(let l=0;l<i;++l)r.enableVertexAttribArray(e+l),r.vertexAttribPointer(e+l,a,u,h,d,y+x*l),r.vertexAttribDivisor&&r.vertexAttribDivisor(e+l,o.divisor||0)}}const P={};P[mt]={size:4,setter:_t},P[En]={size:8,setter:_t},P[Tn]={size:12,setter:_t},P[An]={size:16,setter:_t},P[sr]={size:4,setter:ae},P[wn]={size:8,setter:ae},P[Sn]={size:12,setter:ae},P[Rn]={size:16,setter:ae},P[ar]={size:4,setter:xt},P[kn]={size:8,setter:xt},P[Cn]={size:12,setter:xt},P[On]={size:16,setter:xt},P[In]={size:4,setter:ae},P[Fn]={size:8,setter:ae},P[Pn]={size:12,setter:ae},P[Dn]={size:16,setter:ae},P[Nn]={size:4,setter:cr,count:2},P[Mn]={size:9,setter:cr,count:3},P[Un]={size:16,setter:cr,count:4};const Wu=/ERROR:\s*\d+:(\d+)/gi;function Vu(r,e="",t=0){const n=[...e.matchAll(Wu)],i=new Map(n.map((o,s)=>{const a=parseInt(o[1]),u=n[s+1],f=u?u.index:e.length,d=e.substring(o.index,f);return[a-1,d]}));return r.split(`
`).map((o,s)=>{const a=i.get(s);return`${s+1+t}: ${o}${a?`

^^^ ${a}`:""}`}).join(`
`)}const Vn=/^[ \t]*\n/;function Hn(r){let e=0;return Vn.test(r)&&(e=1,r=r.replace(Vn,"")),{lineOffset:e,shaderSource:r}}function Hu(r,e){return r.errorCallback(e),r.callback&&setTimeout(()=>{r.callback(`${e}
${r.errors.join(`
`)}`)}),null}function Yu(r,e,t,n){if(n=n||or,!r.getShaderParameter(t,Ha)){const o=r.getShaderInfoLog(t),{lineOffset:s,shaderSource:a}=Hn(r.getShaderSource(t)),u=`${Vu(a,o,s)}
Error compiling ${Jr(r,e)}: ${o}`;return n(u),u}return""}function fr(r,e,t){let n,i,o;if(typeof e=="function"&&(t=e,e=void 0),typeof r=="function")t=r,r=void 0;else if(r&&!Array.isArray(r)){const f=r;t=f.errorCallback,r=f.attribLocations,n=f.transformFeedbackVaryings,i=f.transformFeedbackMode,o=f.callback}const s=t||or,a=[],u={errorCallback(f,...d){a.push(f),s(f,...d)},transformFeedbackVaryings:n,transformFeedbackMode:i,callback:o,errors:a};{let f={};Array.isArray(r)?r.forEach(function(d,h){f[d]=e?e[h]:h}):f=r||{},u.attribLocations=f}return u}const ju=["VERTEX_SHADER","FRAGMENT_SHADER"];function Xu(r,e){if(e.indexOf("frag")>=0)return ja;if(e.indexOf("vert")>=0)return Xa}function Qu(r,e,t){const n=r.getAttachedShaders(e);for(const i of n)t.has(i)&&r.deleteShader(i);r.deleteProgram(e)}const Ku=(r=0)=>new Promise(e=>setTimeout(e,r));function qu(r,e,t){const n=r.createProgram(),{attribLocations:i,transformFeedbackVaryings:o,transformFeedbackMode:s}=fr(t);for(let a=0;a<e.length;++a){let u=e[a];if(typeof u=="string"){const f=bn(u),d=f?f.text:u;let h=r[ju[a]];f&&f.type&&(h=Xu(r,f.type)||h),u=r.createShader(h),r.shaderSource(u,Hn(d).shaderSource),r.compileShader(u),r.attachShader(n,u)}}Object.entries(i).forEach(([a,u])=>r.bindAttribLocation(n,u,a));{let a=o;a&&(a.attribs&&(a=a.attribs),Array.isArray(a)||(a=Object.keys(a)),r.transformFeedbackVaryings(n,a,s||Qa))}return r.linkProgram(n),n}function Ju(r,e,t,n,i){const o=fr(t,n,i),s=new Set(e),a=qu(r,e,o);function u(f,d){const h=ec(f,d,o.errorCallback);return h&&Qu(f,d,s),h}if(o.callback){Zu(r,a).then(()=>{const f=u(r,a);o.callback(f,f?void 0:a)});return}return u(r,a)?void 0:a}async function Zu(r,e){const t=r.getExtension("KHR_parallel_shader_compile"),n=t?(o,s)=>o.getProgramParameter(s,t.COMPLETION_STATUS_KHR):()=>!0;let i=0;do await Ku(i),i=1e3/60;while(!n(r,e))}function ec(r,e,t){if(t=t||or,!r.getProgramParameter(e,Ya)){const i=r.getProgramInfoLog(e);t(`Error in program linking: ${i}`);const s=r.getAttachedShaders(e).map(a=>Yu(r,r.getShaderParameter(a,r.SHADER_TYPE),a,t));return`${i}
${s.filter(a=>a).join(`
`)}`}}function tc(r,e,t,n,i){return Ju(r,e,t,n,i)}function Yn(r){const e=r.name;return e.startsWith("gl_")||e.startsWith("webgl_")}const rc=/(\.|\[|]|\w+)/g,nc=r=>r>="0"&&r<="9";function ic(r,e,t,n){const i=r.split(rc).filter(a=>a!=="");let o=0,s="";for(;;){const a=i[o++];s+=a;const u=nc(a[0]),f=u?parseInt(a):a;if(u&&(s+=i[o++]),o===i.length){t[f]=e;break}else{const h=i[o++],y=h==="[",x=t[f]||(y?[]:{});t[f]=x,t=x,n[s]=n[s]||function(l){return function(g){jn(l,g)}}(x),s+=h}}}function oc(r,e){let t=0;function n(a,u,f){const d=u.name.endsWith("[0]"),h=u.type,y=b[h];if(!y)throw new Error(`unknown type: 0x${h.toString(16)}`);let x;if(y.bindPoint){const l=t;t+=u.size,d?x=y.arraySetter(r,h,l,f,u.size):x=y.setter(r,h,l,f,u.size)}else y.arraySetter&&d?x=y.arraySetter(r,f):x=y.setter(r,f);return x.location=f,x}const i={},o={},s=r.getProgramParameter(e,vn);for(let a=0;a<s;++a){const u=r.getActiveUniform(e,a);if(Yn(u))continue;let f=u.name;f.endsWith("[0]")&&(f=f.substr(0,f.length-3));const d=r.getUniformLocation(e,u.name);if(d){const h=n(e,u,d);i[f]=h,ic(f,h,o,i)}}return i}function sc(r,e){const t={},n=r.getProgramParameter(e,qa);for(let i=0;i<n;++i){const o=r.getTransformFeedbackVarying(e,i);t[o.name]={index:i,type:o.type,size:o.size}}return t}function ac(r,e){const t=r.getProgramParameter(e,vn),n=[],i=[];for(let a=0;a<t;++a){i.push(a),n.push({});const u=r.getActiveUniform(e,a);n[a].name=u.name}[["UNIFORM_TYPE","type"],["UNIFORM_SIZE","size"],["UNIFORM_BLOCK_INDEX","blockNdx"],["UNIFORM_OFFSET","offset"]].forEach(function(a){const u=a[0],f=a[1];r.getActiveUniforms(e,i,r[u]).forEach(function(d,h){n[h][f]=d})});const o={},s=r.getProgramParameter(e,Ja);for(let a=0;a<s;++a){const u=r.getActiveUniformBlockName(e,a),f={index:r.getUniformBlockIndex(e,u),usedByVertexShader:r.getActiveUniformBlockParameter(e,a,Za),usedByFragmentShader:r.getActiveUniformBlockParameter(e,a,eu),size:r.getActiveUniformBlockParameter(e,a,tu),uniformIndices:r.getActiveUniformBlockParameter(e,a,ru)};f.used=f.usedByVertexShader||f.usedByFragmentShader,o[u]=f}return{blockSpecs:o,uniformData:n}}function jn(r,e){for(const t in e){const n=r[t];typeof n=="function"?n(e[t]):jn(r[t],e[t])}}function Xn(r,...e){const t=r.uniformSetters||r,n=e.length;for(let i=0;i<n;++i){const o=e[i];if(Array.isArray(o)){const s=o.length;for(let a=0;a<s;++a)Xn(t,o[a])}else for(const s in o){const a=t[s];a&&a(o[s])}}}function uc(r,e){const t={},n=r.getProgramParameter(e,Ka);for(let i=0;i<n;++i){const o=r.getActiveAttrib(e,i);if(Yn(o))continue;const s=r.getAttribLocation(e,o.name),a=P[o.type],u=a.setter(r,s,a);u.location=s,t[o.name]=u}return t}function cc(r,e){for(const t in e){const n=r[t];n&&n(e[t])}}function fc(r,e,t){t.vertexArrayObject?r.bindVertexArray(t.vertexArrayObject):(cc(e.attribSetters||e,t.attribs),t.indices&&r.bindBuffer(Va,t.indices))}function Qn(r,e){const t=oc(r,e),n=uc(r,e),i={program:e,uniformSetters:t,attribSetters:n};return Ne(r)&&(i.uniformBlockSpec=ac(r,e),i.transformFeedbackInfo=sc(r,e)),i}const lc=/\s|{|}|;/;function dc(r,e,t,n,i){const o=fr(t,n,i),s=[];if(e=e.map(function(f){if(!lc.test(f)){const d=bn(f);if(d)f=d.text;else{const h=`no element with id: ${f}`;o.errorCallback(h),s.push(h)}}return f}),s.length)return Hu(o,"");const a=o.callback;a&&(o.callback=(f,d)=>{a(f,f?void 0:Qn(r,d))});const u=tc(r,e,o);return u?Qn(r,u):null}const mc=4,Kn=5123;function hc(r,e,t,n,i,o){t=t===void 0?mc:t;const s=e.indices,a=e.elementType,u=n===void 0?e.numElements:n;i=i===void 0?0:i,a||s?o!==void 0?r.drawElementsInstanced(t,u,a===void 0?Kn:e.elementType,i,o):r.drawElements(t,u,a===void 0?Kn:e.elementType,i):o!==void 0?r.drawArraysInstanced(t,i,u,o):r.drawArrays(t,i,u)}const qn=36160,gt=36161,pc=3553,yc=5121,_c=6402,xc=6408,gc=33190,bc=36012,vc=35056,Ec=36013,Tc=32854,Ac=32855,wc=36194,Jn=33189,Zn=6401,ei=36168,lr=34041,dr=36064,bt=36096,ti=36128,mr=33306,hr=33071,pr=9729,Sc=[{format:xc,type:yc,min:pr,wrap:hr},{format:lr}],V={};V[lr]=mr,V[Zn]=ti,V[ei]=ti,V[_c]=bt,V[Jn]=bt,V[gc]=bt,V[bc]=bt,V[vc]=mr,V[Ec]=mr;function Rc(r,e){return V[r]||V[e]}const ue={};ue[Tc]=!0,ue[Ac]=!0,ue[wc]=!0,ue[lr]=!0,ue[Jn]=!0,ue[Zn]=!0,ue[ei]=!0;function Ic(r){return ue[r]}const Fc=32;function Pc(r){return r>=dr&&r<dr+Fc}function vt(r,e,t,n){const i=qn,o=r.createFramebuffer();r.bindFramebuffer(i,o),t=t||r.drawingBufferWidth,n=n||r.drawingBufferHeight,e=e||Sc;const s=[],a={framebuffer:o,attachments:[],width:t,height:n};return e.forEach(function(u,f){let d=u.attachment;const h=u.samples,y=u.format;let x=u.attachmentPoint||Rc(y,u.internalFormat);if(x||(x=dr+f),Pc(x)&&s.push(x),!d)if(h!==void 0||Ic(y))d=r.createRenderbuffer(),r.bindRenderbuffer(gt,d),h>1?r.renderbufferStorageMultisample(gt,h,y,t,n):r.renderbufferStorage(gt,y,t,n);else{const l=Object.assign({},u);l.width=t,l.height=n,l.auto===void 0&&(l.auto=!1,l.min=l.min||l.minMag||pr,l.mag=l.mag||l.minMag||pr,l.wrapS=l.wrapS||l.wrap||hr,l.wrapT=l.wrapT||l.wrap||hr),d=gn(r,l)}if($o(r,d))r.framebufferRenderbuffer(i,x,gt,d);else if(Ht(r,d))u.layer!==void 0?r.framebufferTextureLayer(i,x,d,u.level||0,u.layer):r.framebufferTexture2D(i,x,u.target||pc,d,u.level||0);else throw new Error("unknown attachment type");a.attachments.push(d)}),r.drawBuffers&&r.drawBuffers(s),a}function Dc(r,e,t){t=t||qn,e?(r.bindFramebuffer(t,e.framebuffer),r.viewport(0,0,e.width,e.height)):(r.bindFramebuffer(t,null),r.viewport(0,0,r.drawingBufferWidth,r.drawingBufferHeight))}function S(r,e){return()=>e instanceof WebGLTexture?e:gn(r,{src:e,wrap:r.CLAMP_TO_EDGE})}const ri=2;class xe{constructor(e){p(this,"id","_");p(this,"context");p(this,"output");p(this,"fbi");p(this,"options");p(this,"programInfo");p(this,"bufferInfo");p(this,"profiler");p(this,"lastRun");const{context:t,width:n,height:i}=e;this.context=t,this.options=e;const o=this.buildDefines();this.programInfo=dc(this.context,[o+this.getVertexShader(),o+this.getFragmentShader()]),this.bufferInfo=ls(this.context,this.getBuffers()),this.fbi=vt(this.context,[{format:this.context.RGBA,type:this.context.UNSIGNED_BYTE,min:this.context.LINEAR,wrap:this.context.CLAMP_TO_EDGE}],n,i),this.output=this.fbi.attachments[0]}resizeOutput(e,t){this.fbi=vt(this.context,[{format:this.context.RGBA,type:this.context.UNSIGNED_BYTE,min:this.context.LINEAR,wrap:this.context.CLAMP_TO_EDGE}],e,t),this.options.width=e,this.options.height=t,this.output=this.fbi.attachments[0]}getDefines(){return{}}getBuffers(){return{position:{numComponents:2,data:[-1,-1,-1,1,1,-1,1,1,-1,1,1,-1]},texture_coord:{numComponents:2,data:[0,0,0,1,1,0,1,1,0,1,1,0]}}}buildDefines(){let e="";const t=this.getDefines();for(let n in t)e+=`#define ${n} ${t[n].toFixed(1)}
`;return e}run(e){var i,o,s,a,u,f;(i=this.profiler)==null||i.pushContext(`[${this.id}] PROG : ${this.constructor.name}`),(o=this.profiler)==null||o.pushContext(`[${this.id}] UNIFORMS`);for(const d in e)typeof e[d]=="function"&&((s=this.profiler)==null||s.pushContext(`[${this.id}] UNI : ${d}`),e[d]=e[d](),(a=this.profiler)==null||a.popContext(`[${this.id}] UNI : ${d}`));(u=this.profiler)==null||u.popContext(`[${this.id}] UNIFORMS`);const t=Date.now();let n=0;this.lastRun&&(n=(t-this.lastRun)/1e3),this.lastRun=t,this.context.viewport(0,0,this.context.canvas.width,this.context.canvas.height),this.context.useProgram(this.programInfo.program),fc(this.context,this.programInfo,this.bufferInfo),Xn(this.programInfo,{delta:n,canvas:[this.context.canvas.width,this.context.canvas.height],...e}),Dc(this.context,this.options.disableFramebuffer?null:this.fbi),hc(this.context,this.bufferInfo),(f=this.profiler)==null||f.popContext(`[${this.id}] PROG : ${this.constructor.name}`)}setProfiler(e){this.profiler=e}}var Nc=`precision mediump float;

varying vec2 _texture_coord;

uniform vec2 canvas;
uniform sampler2D texture;
uniform sampler2D mask;

vec4 loop();

void main() { gl_FragColor = loop(); }
`,Mc=`varying vec2 _texture_coord;

attribute vec2 position;
attribute vec2 texture_coord;

void main() {
  gl_Position = vec4(position, 0., 1.);
  _texture_coord = texture_coord;
}
`;class Uc extends xe{getDefines(){var e;return{RADIUS:(e=this.options.radius)!=null?e:1}}getFragmentShader(){return Nc+this.createLoopFunction()}getVertexShader(){return Mc}createLoopFunction(){var t;let e=(t=this.options.radius)!=null?t:1;return`

        vec4 loop() { 
            vec4 result = vec4(0,0,0,0);
            float factorSum = 0.;

            vec2 normalizedRadius = vec2(-${e}.) / canvas;
            vec2 normalizedIncrement = vec2(1.) / canvas;
            vec2 diff = normalizedRadius;
            float maxLength = length(normalizedRadius);

            for(int y=-${e}; y<${e+1}; ++y) {
                for(int x=-${e}; x<${e+1}; ++x) {
                    float factor = (1.- texture2D(mask, _texture_coord + diff).a) * (maxLength - length(diff)) / maxLength;
                    result += factor * texture2D(texture, _texture_coord + diff);
                    factorSum += factor;
                    diff.x += normalizedIncrement.x;
                }
                diff.y += normalizedIncrement.y;
                diff.x = normalizedRadius.x;
            }
            return result / factorSum;
        }`}}var kc=`precision mediump float;

varying vec2 _texture_coord;

uniform sampler2D background;
uniform sampler2D foreground;
uniform sampler2D threshold;

void main() {
  vec4 backgroundColor = texture2D(background, _texture_coord);
  vec4 foregroundColor = texture2D(foreground, _texture_coord);
  vec4 tresholdColor = texture2D(threshold, _texture_coord);
  gl_FragColor = foregroundColor * tresholdColor.a +
                 backgroundColor * (1. - tresholdColor.a);
}
`,Cc=`varying vec2 _texture_coord;

attribute vec2 position;
attribute vec2 texture_coord;

void main() {
  gl_Position = vec4(position, 0., 1.);
  _texture_coord = texture_coord;
  _texture_coord.y = 1. - texture_coord.y;
}
`;class yr extends xe{getFragmentShader(){return kc}getVertexShader(){return Cc}}class _r{constructor(){p(this,"steps",[]);p(this,"profiler")}addStep(e){this.steps.push(e)}async run(){for(const e of this.steps)e.program.run(e.getUniforms())}resizeOutput(e,t){var n,i;(n=this.profiler)==null||n.pushContext(`PIP [${this.constructor.name}]`);for(const o of this.steps)o.preventResize||o.program.resizeOutput(e,t);(i=this.profiler)==null||i.popContext(`PIP [${this.constructor.name}]`)}setProfiler(e){this.profiler=e;for(const t of this.steps)t.program.setProfiler(e)}setId(e){for(const t of this.steps)t.program.id=e}}class xr extends _r{constructor(){super(...arguments);p(this,"preciseMaskEnabled",!1)}}const Oc=10,Bc=2,Lc=8;class Gc extends xr{constructor(t,n){super();p(this,"inputImage");p(this,"inputMask");p(this,"blur");this.context=t,this.radius=n;const i={context:t,height:t.canvas.height,width:t.canvas.width};this.blur=new Uc({...i,radius:n,...this.getBlurTextureSize(t.canvas.width,t.canvas.height)});const o=new yr({...i,disableFramebuffer:!0});this.addStep({program:this.blur,preventResize:!0,getUniforms:()=>({texture:S(t,this.inputImage),mask:S(t,this.inputMask)})}),this.addStep({program:o,getUniforms:()=>({background:S(t,this.blur.output),foreground:S(t,this.inputImage),threshold:S(t,this.inputMask)})})}getBlurTextureSize(t,n){const i=this.radius>Oc?Lc:Bc;return{width:Math.max(ri,t/i),height:Math.max(ri,n/i)}}setData(t,n){this.inputImage=t,this.inputMask=n}resizeOutput(t,n){super.resizeOutput(t,n);const i=this.getBlurTextureSize(t,n);this.blur.resizeOutput(i.width,i.height)}}class ni extends xr{constructor(t){super();p(this,"inputImage");p(this,"inputBackgroundImage");p(this,"inputMask");p(this,"preciseMaskEnabled",!0);this.context=t;const n={context:t,height:t.canvas.height,width:t.canvas.width},i=new yr({...n,disableFramebuffer:!0});this.addStep({program:i,getUniforms:()=>({background:S(t,this.inputBackgroundImage),foreground:S(t,this.inputImage),threshold:S(t,this.inputMask)})})}setData(t,n){this.inputImage=t,this.inputMask=n}}class $c extends ni{constructor(){super(...arguments);p(this,"frameReader");p(this,"preciseMaskEnabled",!0)}set inputVideo(t){this.frameReader=t.getReader(),this.readNextVideoFrame()}async run(){this.frameReader&&(await super.run(),this.readNextVideoFrame())}async readNextVideoFrame(){var n;const t=await((n=this.frameReader)==null?void 0:n.read());t!=null&&t.value&&(this.inputBackgroundImage=await createImageBitmap(t.value),t.value.close())}}var zc=`precision mediump float;

varying vec2 _texture_coord;

uniform vec2 canvas;
uniform sampler2D texture;

vec4 loop();

void main() { gl_FragColor = loop(); }
`,Wc=`varying vec2 _texture_coord;

attribute vec2 position;
attribute vec2 texture_coord;

void main() {
  gl_Position = vec4(position, 0., 1.);
  _texture_coord = texture_coord;
}
`,gr=(r=>(r[r.LINEAR=0]="LINEAR",r[r.GAUSSIAN=1]="GAUSSIAN",r))(gr||{});class ii extends xe{getDefines(){var e;return{RADIUS:(e=this.options.radius)!=null?e:1}}getFragmentShader(){return zc+this.createLoopFunction()}getVertexShader(){return Wc}createLoopFunction(){var t;let e=(t=this.options.radius)!=null?t:1;return`

        vec4 loop() { 
            vec4 result = vec4(0,0,0,0);
            float factorSum = 0.;

            vec2 normalizedRadius = vec2(-${e}.) / canvas;
            vec2 normalizedIncrement = vec2(1.) / canvas;
            vec2 diff = normalizedRadius;

            for(int y=-${e}; y<${e+1}; ++y) {
                for(int x=-${e}; x<${e+1}; ++x) {
                    float factor = 1.;
                    result += factor * texture2D(texture, _texture_coord + diff);
                    factorSum += factor;
                    diff.x += normalizedIncrement.x;
                }
                diff.y += normalizedIncrement.y;
                diff.x = normalizedRadius.x;
            }
            return result / factorSum;
        }`}getFactor(e,t){switch(this.options.type){case 1:return this.getLinearFactor(e,t);case 0:default:return this.getLinearFactor(e,t)}}getLinearFactor(e,t){return 1}getGaussianFactor(e,t){var u;const n=Math.PI*2,i=Math.max((u=this.options.radius)!=null?u:1,1),o=1/(n*i**2),s=-(e**2+t**2),a=o*s;return o*Math.E**a}}class Vc extends xr{constructor(t,n){super();p(this,"inputImage");p(this,"inputMask");this.context=t;const i={context:t,height:t.canvas.height,width:t.canvas.width},o=new ii({...i,radius:n,type:gr.GAUSSIAN}),s=new yr({...i,disableFramebuffer:!0});this.addStep({program:o,getUniforms:()=>({texture:S(t,this.inputImage)})}),this.addStep({program:s,getUniforms:()=>({background:S(t,this.inputImage),foreground:S(t,o.output),threshold:S(t,this.inputMask)})})}setData(t,n){this.inputImage=t,this.inputMask=n}}class br extends xe{constructor(t){super(t);p(this,"fbi2");this.fbi2=vt(t.context,[{format:t.context.RGBA,type:t.context.UNSIGNED_BYTE,min:t.context.LINEAR,mag:t.context.LINEAR,wrap:t.context.CLAMP_TO_EDGE}],t.width,t.height)}run(t){const n=this.fbi;this.fbi=this.fbi2,this.fbi2=n,this.output=this.fbi.attachments[0],super.run({...t,previous_rendering:this.fbi2.attachments[0]})}resizeOutput(t,n){super.resizeOutput(t,n),this.fbi2=vt(this.context,[{format:this.context.RGBA,type:this.context.UNSIGNED_BYTE,min:this.context.LINEAR,wrap:this.context.CLAMP_TO_EDGE}],t,n)}}var Hc=`precision mediump float;

varying vec2 _texture_coord;

// uniform float treshold;
uniform sampler2D image_now;
uniform sampler2D image_before;
uniform sampler2D mask_now;
uniform sampler2D mask_before;
uniform sampler2D previous_rendering;
uniform vec2 canvas;

uniform float delta;

float current_factor = 0.69;
float previous_factor = 0.74;
float threshold_activation = 0.54;

float map(float value, float min1, float max1, float min2, float max2) {
  return min2 + (value - min1) * (max2 - min2) / (max1 - min1);
}

float getThreshold() {
  vec4 color = vec4(0.);
  for (float y = -6.; y < 7.; y += 1.) {
    for (float x = -6.; x < 7.; x += 1.) {
      vec4 image_now_color =
          texture2D(image_now, _texture_coord + vec2(x, y) / canvas);
      vec4 image_before_color =
          texture2D(image_before, _texture_coord + vec2(x, y) / canvas);
      color += abs(image_before_color - image_now_color);
    }
  }
  return (color.x + color.y + color.z) / (3. * 9.);
}

void main() {
  float treshold_input = .4;
  float treshold_previous_rendering = .98;

  vec4 mask_now_color = texture2D(mask_now, _texture_coord);
  vec4 mask_before_color = texture2D(mask_before, _texture_coord);
  vec4 previous_rendering_color = texture2D(previous_rendering, _texture_coord);

  vec3 mask_diff = abs(mask_before_color.xyz - mask_now_color.xyz);
  float flickering = mask_diff.x;
  float threshold = getThreshold();
  if (threshold < threshold_activation) {
    gl_FragColor = vec4(flickering, 0., 0., 1.) * current_factor +
                   previous_rendering_color * previous_factor;
    gl_FragColor *= (1. - threshold);
  }
}
`,Yc=`varying vec2 _texture_coord;

attribute vec2 position;
attribute vec2 texture_coord;

void main() {
  gl_Position = vec4(position, 0., 1.);
  _texture_coord = texture_coord;
}
`;class jc extends br{getFragmentShader(){return Hc}getVertexShader(){return Yc}}var Xc=`#version 300 es
// https://github.com/Volcomix/virtual-background/blob/main/src/pipelines/webgl2/jointBilateralFilterStage.ts

precision highp float;
uniform sampler2D input_frame;
uniform sampler2D segmentation_mask;
uniform sampler2D threshold;
uniform vec2 texel_size;
uniform float step;
uniform float radius;
uniform float offset;
uniform float sigma_texel;
uniform float sigma_color;

in vec2 _texture_coord;
out vec4 outColor;

float gaussian(float x, float sigma) {
  float coeff = -0.5 / (sigma * sigma * 4.0 + 1.0e-6);
  return exp((x * x) * coeff);
}

void main() {
  vec2 centerCoord = _texture_coord;
  vec3 centerColor = texture(input_frame, centerCoord).rgb;
  float newVal = 0.0;
  float spaceWeight = 0.0;
  float colorWeight = 0.0;
  float totalWeight = 0.0;
  // Subsample kernel space.
  for (float i = -radius + offset; i <= radius; i += step) {
    for (float j = -radius + offset; j <= radius; j += step) {
      vec2 shift = vec2(j, i) * texel_size;
      vec2 coord = vec2(centerCoord + shift);
      vec3 frameColor = texture(input_frame, coord).rgb;
      float threshold = texture(threshold, coord).a;
      float outVal = texture(segmentation_mask, coord).a;

      spaceWeight = gaussian(distance(centerCoord, coord), sigma_texel);
      colorWeight = gaussian(distance(centerColor, frameColor), sigma_color);
      totalWeight += spaceWeight * colorWeight;
      newVal += spaceWeight * colorWeight * outVal * threshold;
    }
  }
  newVal /= totalWeight;
  outColor = vec4(vec3(0.), newVal);
}`,Qc=`#version 300 es
in vec2 position;
in vec2 texture_coord;
out vec2 _texture_coord;
void main() {
  gl_Position = vec4(position, 0.0, 1.0);
  _texture_coord = texture_coord;
}`;class Kc extends xe{getFragmentShader(){return Xc}getVertexShader(){return Qc}}var qc=`precision mediump float;

varying vec2 _texture_coord;

uniform vec2 canvas;
uniform sampler2D texture;

void main() {
  int count = 0;
  for (float y = -1.; y < 2.; y += 1.) {
    for (float x = -1.; x < 2.; x += 1.) {
      vec2 coord = _texture_coord + vec2(y, x) / canvas;
      vec4 color = texture2D(texture, coord);
      if (color.r > .1) {
        count++;
      }
    }
  }
  if (count > 5) {
    gl_FragColor = texture2D(texture, _texture_coord);
  }
}
`,Jc=`varying vec2 _texture_coord;

attribute vec2 position;
attribute vec2 texture_coord;

void main() {
  gl_Position = vec4(position, 0., 1.);
  _texture_coord = texture_coord;
}
`;class Zc extends xe{getFragmentShader(){return qc}getVertexShader(){return Jc}}var ef=`precision mediump float;

varying vec2 _texture_coord;

uniform vec2 canvas;
uniform sampler2D texture;

void main() {
  vec4 color = texture2D(texture, _texture_coord);
  for (float y = -2.; y < 3.; y += 1.) {
    for (float x = -2.; x < 3.; x += 1.) {
      vec2 coord = _texture_coord;
      coord += vec2(y, x) / canvas;
      color += texture2D(texture, coord) * (1. / 4.);
    }
  }

  gl_FragColor = color;
}
`,tf=`varying vec2 _texture_coord;

attribute vec2 position;
attribute vec2 texture_coord;

void main() {
  gl_Position = vec4(position, 0., 1.);
  _texture_coord = texture_coord;
}
`;class rf extends br{getFragmentShader(){return ef}getVertexShader(){return tf}}var nf=`precision mediump float;

varying vec2 _texture_coord;

uniform sampler2D threshold;
uniform sampler2D inputs;

void main() {
  vec4 inputs_color = texture2D(inputs, _texture_coord);
  vec4 threshold_color = texture2D(threshold, _texture_coord);
  if (threshold_color.r < .1 && inputs_color.r > .5) {
    gl_FragColor = inputs_color;
  }
}
`,of=`varying vec2 _texture_coord;

attribute vec2 position;
attribute vec2 texture_coord;

void main() {
  gl_Position = vec4(position, 0., 1.);
  _texture_coord = texture_coord;
}
`;class sf extends br{getFragmentShader(){return nf}getVertexShader(){return of}}class af extends _r{constructor(t,n,i){super();p(this,"inputImage");p(this,"inputMask");p(this,"previousInputImage");p(this,"previousInputMask");p(this,"output");p(this,"options",{currentThresholdMinimum:0,currentThresholdMaximum:1,previousThresholdMinimum:0,previousThresholdMaximum:1,thresholdMinimum:0,thresholdMaximum:1,thresholdFactor:1});this.context=t;const o={context:t,height:i,width:n},s=new jc(o),a=new ii({...o,radius:1,type:gr.GAUSSIAN}),u=new sf(o),f=new rf(o),d=new Zc(o),h=new Kc({...o}),y=.66,x=640,l=480,g=256,E=144;let v=1;v*=Math.max(x/g,l/E);const I=Math.max(1,Math.sqrt(v)*y),D=1/x,G=1/l;this.addStep({program:s,getUniforms:()=>({image_now:S(t,this.inputImage),image_before:S(t,this.previousInputImage),mask_now:S(t,this.inputMask),mask_before:S(t,this.previousInputMask),current_threshold_minimum:this.options.currentThresholdMinimum,current_threshold_maximum:this.options.currentThresholdMaximum,previous_threshold_minimum:this.options.previousThresholdMinimum,previous_threshold_maximum:this.options.previousThresholdMaximum,threshold_minimum:this.options.thresholdMinimum,threshold_maximum:this.options.thresholdMaximum,threshold_factor:this.options.thresholdFactor})}),this.addStep({program:u,getUniforms:()=>({inputs:S(t,this.inputMask),threshold:S(t,s.output)})}),this.addStep({program:d,getUniforms:()=>({texture:S(t,u.output)})}),this.addStep({program:f,getUniforms:()=>({texture:S(t,d.output)})}),this.addStep({program:a,getUniforms:()=>({texture:S(t,f.output)})}),this.addStep({program:h,getUniforms:()=>({input_frame:S(t,this.inputImage),segmentation_mask:S(t,this.inputMask),threshold:S(t,a.output),texel_size:[D,G],step:I,radius:v,offset:I>1?I*.5:0,sigma_texel:Math.max(D,G)*v,sigma_color:.1})}),this.output=h.output}setData(t,n){this.previousInputImage=this.inputImage?this.inputImage:t,this.previousInputMask=this.inputMask?this.inputMask:n,this.inputImage=t,this.inputMask=n}setOptions(t){this.options=t}}var uf=`precision mediump float;

varying vec2 _texture_coord;
uniform sampler2D texture;

void main() { gl_FragColor = texture2D(texture, _texture_coord); }
`,cf=`varying vec2 _texture_coord;

attribute vec2 position;
attribute vec2 texture_coord;
uniform bool invert_y;

void main() {
  gl_Position = vec4(position, 0., 1.);
  _texture_coord = texture_coord;
  if (invert_y) {
    _texture_coord.y = 1. - texture_coord.y;
  }
}
`;class ff extends xe{getFragmentShader(){return uf}getVertexShader(){return cf}}class lf extends _r{constructor(t,n,i){super();p(this,"inputImage");this.context=t;const o={context:t,height:i,width:n};this.addStep({program:new ff({...o,disableFramebuffer:!0}),getUniforms:()=>({texture:S(t,this.inputImage),invert_y:!0})})}setData(t){this.inputImage=t}}class df{constructor(e){p(this,"resize");p(this,"canvas");p(this,"context");this.canvas=new OffscreenCanvas(0,0),this.context=this.canvas.getContext("webgl2"),this.canvas.width=e.width,this.canvas.height=e.height,this.resize=new lf(this.context,e.width,e.height)}resizeForeground(e,t){this.canvas.width=e,this.canvas.height=t,this.resize.resizeOutput(e,t)}async process(e){var t,n;return this.canvas.width=this.canvas.width,(t=this.resize)==null||t.setData(e),(n=this.resize)==null||n.run(),this.canvas}}class mf{constructor(e,t){p(this,"improveMaskSegmentation");p(this,"backgroundResizer");p(this,"backgroundImage");p(this,"backgroundVideo");p(this,"profiler");p(this,"activePipeline");p(this,"canvas");p(this,"options");p(this,"context");p(this,"virtualBGImage");this.id=e,this.canvas=new OffscreenCanvas(0,0),this.context=this.canvas.getContext("webgl2"),this.canvas.width=t.foregroundWidth,this.canvas.height=t.foregroundHeight,this.improveMaskSegmentation=new af(this.context,t.maskWidth,t.maskHeight),this.backgroundImage=new ni(this.context),this.backgroundVideo=new $c(this.context),this.backgroundResizer=new df({width:t.foregroundWidth,height:t.foregroundHeight})}setBackgroundOptions(e){switch(e.transformerType){case"BackgroundBlur":this.activePipeline=new Gc(this.context,this.getBlurSize(e.radius));break;case"SilhouetteBlur":this.activePipeline=new Vc(this.context,this.getBlurSize(e.radius));break;case"VideoBackground":this.activePipeline=this.backgroundVideo;break;case"VirtualBackground":this.activePipeline=this.backgroundImage;break;default:throw`Unknown transformer type [${e.transformerType}]`}this.options=e}setFlickeringOptions(e){var t;(t=this.improveMaskSegmentation)==null||t.setOptions(e)}setVideoBGReadable(e){this.backgroundVideo.inputVideo=e}async setVirtualBGImage(e){this.virtualBGImage=e,this.backgroundImage.inputBackgroundImage=await this.backgroundResizer.process(e)}async process(e,t){var n,i,o,s,a,u,f;if(this.activePipeline&&e.width&&(t==null?void 0:t.width)){const d=`[${this.id}] background-filter`;(n=this.profiler)==null||n.pushContext(d);let h=t;(((i=this.options)==null?void 0:i.selfieSegmentationType)&&((o=this.options)==null?void 0:o.selfieSegmentationType)==="PRECISE"||!((s=this.options)!=null&&s.selfieSegmentationType)&&this.activePipeline.preciseMaskEnabled)&&(this.improveMaskSegmentation.setId(this.id),this.improveMaskSegmentation.setProfiler(this.profiler),this.improveMaskSegmentation.setData(e,t),this.improveMaskSegmentation.run(),h=this.improveMaskSegmentation.output),this.activePipeline.setId(this.id),this.activePipeline.setProfiler(this.profiler),(a=this.activePipeline)==null||a.setData(e,h),(u=this.activePipeline)==null||u.run(),(f=this.profiler)==null||f.popContext(d)}}async resizeForeground(e,t){var n;this.canvas.width=e,this.canvas.height=t,this.backgroundImage.resizeOutput(e,t),this.backgroundVideo.resizeOutput(e,t),this.backgroundResizer.resizeForeground(e,t),(n=this.activePipeline)==null||n.resizeOutput(e,t),this.virtualBGImage&&(this.backgroundImage.inputBackgroundImage=await this.backgroundResizer.process(this.virtualBGImage))}async profile(e){const t=new Po(this.context);return this.profiler=t,t.start(),await Gr(e),this.profiler=void 0,t.stop(),t.getResolvedQueries()}getBlurSize(e=Ze.Low){switch(e){case Ze.Low:return 5;case Ze.High:return 12}return e}}var hf=function(){var r=typeof document<"u"&&document.currentScript?document.currentScript.src:void 0;return function(e){e=e||{};var t=typeof e<"u"?e:{},n,i;t.ready=new Promise(function(c,m){n=c,i=m});var o={},s;for(s in t)t.hasOwnProperty(s)&&(o[s]=t[s]);var a="./this.program",u=function(c,m){throw m},f=!0,d="";function h(c){return t.locateFile?t.locateFile(c,d):d+c}var y;typeof document<"u"&&document.currentScript&&(d=document.currentScript.src),r&&(d=r),d.indexOf("blob:")!==0?d=d.substr(0,d.replace(/[?#].*/,"").lastIndexOf("/")+1):d="";var x=t.print||console.log.bind(console),l=t.printErr||console.warn.bind(console);for(s in o)o.hasOwnProperty(s)&&(t[s]=o[s]);o=null,t.arguments&&t.arguments,t.thisProgram&&(a=t.thisProgram),t.quit&&(u=t.quit);var g;t.wasmBinary&&(g=t.wasmBinary);var E=t.noExitRuntime||!0;typeof WebAssembly!="object"&&ce("no native wasm support detected");var v,I=!1,D=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0;function G(c,m,_){for(var T=m+_,N=m;c[N]&&!(N>=T);)++N;if(N-m>16&&c.subarray&&D)return D.decode(c.subarray(m,N));for(var k="";m<N;){var w=c[m++];if(!(w&128)){k+=String.fromCharCode(w);continue}var O=c[m++]&63;if((w&224)==192){k+=String.fromCharCode((w&31)<<6|O);continue}var K=c[m++]&63;if((w&240)==224?w=(w&15)<<12|O<<6|K:w=(w&7)<<18|O<<12|K<<6|c[m++]&63,w<65536)k+=String.fromCharCode(w);else{var hi=w-65536;k+=String.fromCharCode(55296|hi>>10,56320|hi&1023)}}return k}function $(c,m){return c?G(Le,c,m):""}function Z(c,m,_){for(var T=0;T<c.length;++T)Et[m++>>0]=c.charCodeAt(T);_||(Et[m>>0]=0)}function H(c,m){return c%m>0&&(c+=m-c%m),c}var si,Et,Le,Y;function ai(c){si=c,t.HEAP8=Et=new Int8Array(c),t.HEAP16=new Int16Array(c),t.HEAP32=Y=new Int32Array(c),t.HEAPU8=Le=new Uint8Array(c),t.HEAPU16=new Uint16Array(c),t.HEAPU32=new Uint32Array(c),t.HEAPF32=new Float32Array(c),t.HEAPF64=new Float64Array(c)}t.INITIAL_MEMORY;var Er,ui=[],ci=[],fi=[],vf=0;function Ef(){return E||vf>0}function Tf(){if(t.preRun)for(typeof t.preRun=="function"&&(t.preRun=[t.preRun]);t.preRun.length;)Sf(t.preRun.shift());Tr(ui)}function Af(){Tr(ci)}function wf(){if(t.postRun)for(typeof t.postRun=="function"&&(t.postRun=[t.postRun]);t.postRun.length;)If(t.postRun.shift());Tr(fi)}function Sf(c){ui.unshift(c)}function Rf(c){ci.unshift(c)}function If(c){fi.unshift(c)}var ge=0,Ge=null;function Ff(c){ge++,t.monitorRunDependencies&&t.monitorRunDependencies(ge)}function Pf(c){if(ge--,t.monitorRunDependencies&&t.monitorRunDependencies(ge),ge==0&&Ge){var m=Ge;Ge=null,m()}}t.preloadedImages={},t.preloadedAudios={};function ce(c){t.onAbort&&t.onAbort(c),c="Aborted("+c+")",l(c),I=!0,c+=". Build with -s ASSERTIONS=1 for more info.";var m=new WebAssembly.RuntimeError(c);throw i(m),m}var Df="data:application/octet-stream;base64,";function li(c){return c.startsWith(Df)}var j;j="tflite-simd.wasm",li(j)||(j=h(j));function di(c){try{if(c==j&&g)return new Uint8Array(g);if(!y)throw"both async and sync fetching of the wasm failed"}catch(m){ce(m)}}function Nf(){return!g&&f&&typeof fetch=="function"?fetch(j,{credentials:"same-origin"}).then(function(c){if(!c.ok)throw"failed to load wasm binary file at '"+j+"'";return c.arrayBuffer()}).catch(function(){return di(j)}):Promise.resolve().then(function(){return di(j)})}function Mf(){var c={a:el};function m(w,O){var K=w.exports;t.asm=K,v=t.asm.q,ai(v.buffer),Er=t.asm.E,Rf(t.asm.r),Pf()}Ff();function _(w){m(w.instance)}function T(w){return Nf().then(function(O){return WebAssembly.instantiate(O,c)}).then(function(O){return O}).then(w,function(O){l("failed to asynchronously prepare wasm: "+O),ce(O)})}function N(){return!g&&typeof WebAssembly.instantiateStreaming=="function"&&!li(j)&&typeof fetch=="function"?fetch(j,{credentials:"same-origin"}).then(function(w){var O=WebAssembly.instantiateStreaming(w,c);return O.then(_,function(K){return l("wasm streaming compile failed: "+K),l("falling back to ArrayBuffer instantiation"),T(_)})}):T(_)}if(t.instantiateWasm)try{var k=t.instantiateWasm(c,m);return k}catch(w){return l("Module.instantiateWasm callback failed with error: "+w),!1}return N().catch(i),{}}function Tr(c){for(;c.length>0;){var m=c.shift();if(typeof m=="function"){m(t);continue}var _=m.func;typeof _=="number"?m.arg===void 0?Er.get(_)():Er.get(_)(m.arg):_(m.arg===void 0?null:m.arg)}}function Uf(c,m,_,T){ce("Assertion failed: "+$(c)+", at: "+[m?$(m):"unknown filename",_,T?$(T):"unknown function"])}function kf(c,m){ce("To use dlopen, you need to use Emscripten's linking support, see https://github.com/emscripten-core/emscripten/wiki/Linking")}function Cf(c,m){ce("To use dlopen, you need to use Emscripten's linking support, see https://github.com/emscripten-core/emscripten/wiki/Linking")}function Of(){ce("")}var Tt;Tt=function(){return performance.now()};var Bf=!0;function Lf(c){return Y[mi()>>2]=c,c}function Gf(c,m){var _;if(c===0)_=Date.now();else if((c===1||c===4)&&Bf)_=Tt();else return Lf(28),-1;return Y[m>>2]=_/1e3|0,Y[m+4>>2]=_%1e3*1e3*1e3|0,0}function $f(){return 2147483648}function zf(c,m,_){Le.copyWithin(c,m,m+_)}function Wf(c){try{return v.grow(c-si.byteLength+65535>>>16),ai(v.buffer),1}catch{}}function Vf(c){var m=Le.length;c=c>>>0;var _=2147483648;if(c>_)return!1;for(var T=1;T<=4;T*=2){var N=m*(1+.2/T);N=Math.min(N,c+100663296);var k=Math.min(_,H(Math.max(c,N),65536)),w=Wf(k);if(w)return!0}return!1}function Hf(c){for(var m=Tt();Tt()-m<c;);}var Ar={};function Yf(){return a||"./this.program"}function $e(){if(!$e.strings){var c=(typeof navigator=="object"&&navigator.languages&&navigator.languages[0]||"C").replace("-","_")+".UTF-8",m={USER:"web_user",LOGNAME:"web_user",PATH:"/",PWD:"/",HOME:"/home/web_user",LANG:c,_:Yf()};for(var _ in Ar)Ar[_]===void 0?delete m[_]:m[_]=Ar[_];var T=[];for(var _ in m)T.push(_+"="+m[_]);$e.strings=T}return $e.strings}var At={mappings:{},buffers:[null,[],[]],printChar:function(c,m){var _=At.buffers[c];m===0||m===10?((c===1?x:l)(G(_,0)),_.length=0):_.push(m)},varargs:void 0,get:function(){At.varargs+=4;var c=Y[At.varargs-4>>2];return c},getStr:function(c){var m=$(c);return m},get64:function(c,m){return c}};function jf(c,m){var _=0;return $e().forEach(function(T,N){var k=m+_;Y[c+N*4>>2]=k,Z(T,k),_+=T.length+1}),0}function Xf(c,m){var _=$e();Y[c>>2]=_.length;var T=0;return _.forEach(function(N){T+=N.length+1}),Y[m>>2]=T,0}function Qf(c){rl(c)}function Kf(c){return 0}function qf(c,m,_,T,N){}function Jf(c,m,_,T){for(var N=0,k=0;k<_;k++){for(var w=Y[m+k*8>>2],O=Y[m+(k*8+4)>>2],K=0;K<O;K++)At.printChar(c,Le[w+K]);N+=O}return Y[T>>2]=N,0}function Zf(){if(typeof crypto=="object"&&typeof crypto.getRandomValues=="function"){var c=new Uint8Array(1);return function(){return crypto.getRandomValues(c),c[0]}}else return function(){ce("randomDevice")}}function wt(c,m){wt.randomDevice||(wt.randomDevice=Zf());for(var _=0;_<m;_++)Et[c+_>>0]=wt.randomDevice();return 0}var el={a:Uf,e:kf,d:Cf,b:Of,n:Gf,h:$f,l:zf,m:Vf,p:Hf,f:jf,g:Xf,j:Qf,i:Kf,k:qf,c:Jf,o:wt};Mf(),t.___wasm_call_ctors=function(){return(t.___wasm_call_ctors=t.asm.r).apply(null,arguments)},t._getModelBufferMemoryOffset=function(){return(t._getModelBufferMemoryOffset=t.asm.s).apply(null,arguments)},t._getInputMemoryOffset=function(){return(t._getInputMemoryOffset=t.asm.t).apply(null,arguments)},t._getInputHeight=function(){return(t._getInputHeight=t.asm.u).apply(null,arguments)},t._getInputWidth=function(){return(t._getInputWidth=t.asm.v).apply(null,arguments)},t._getInputChannelCount=function(){return(t._getInputChannelCount=t.asm.w).apply(null,arguments)},t._getOutputMemoryOffset=function(){return(t._getOutputMemoryOffset=t.asm.x).apply(null,arguments)},t._getOutputHeight=function(){return(t._getOutputHeight=t.asm.y).apply(null,arguments)},t._getOutputWidth=function(){return(t._getOutputWidth=t.asm.z).apply(null,arguments)},t._getOutputChannelCount=function(){return(t._getOutputChannelCount=t.asm.A).apply(null,arguments)},t._loadModel=function(){return(t._loadModel=t.asm.B).apply(null,arguments)},t._runInference=function(){return(t._runInference=t.asm.C).apply(null,arguments)},t._isGPUEnabled=function(){return(t._isGPUEnabled=t.asm.D).apply(null,arguments)};var mi=t.___errno_location=function(){return(mi=t.___errno_location=t.asm.F).apply(null,arguments)},St;function tl(c){this.name="ExitStatus",this.message="Program terminated with exit("+c+")",this.status=c}Ge=function c(){St||wr(),St||(Ge=c)};function wr(c){if(ge>0||(Tf(),ge>0))return;function m(){St||(St=!0,t.calledRun=!0,!I&&(Af(),n(t),t.onRuntimeInitialized&&t.onRuntimeInitialized(),wf()))}t.setStatus?(t.setStatus("Running..."),setTimeout(function(){setTimeout(function(){t.setStatus("")},1),m()},1)):m()}t.run=wr;function rl(c,m){nl(c)}function nl(c){Ef()||(t.onExit&&t.onExit(c),I=!0),u(c,new tl(c))}if(t.preInit)for(typeof t.preInit=="function"&&(t.preInit=[t.preInit]);t.preInit.length>0;)t.preInit.pop()();return wr(),e.ready}}();class pf{constructor(){p(this,"selectedTFLite");p(this,"isSIMDSupported",!1);p(this,"isThreadsSupported",!1);p(this,"inputWidth",0);p(this,"inputHeight",0);p(this,"inputChannelCount",0);p(this,"inputMemoryOffset",0);p(this,"outputWidth",0);p(this,"outputHeight",0);p(this,"outputChannelCount",0);p(this,"outputMemoryOffset",0)}}const yf="https://d3opqjmqzxf057.cloudfront.net/vonage-tensorflow-wasm/tflite-simd-wasm/1.1.3/",_f="https://d3opqjmqzxf057.cloudfront.net/ml/selfie_segmentation/4.0.0/";async function xf(r=yf,e=_f){let t=new pf;var n=new Promise(function(i,o){async function s(){return hf({locateFile:function(f){return r+f}})}async function a(u){return new Promise(async(f,d)=>{const h=u;if(typeof h>"u")return d("TFLite backend unavailable: wasmSimd");const y="selfie_segmentation_landscape";console.log("Loading tflite model:",y);let x=e+`${y}.tflite`;console.log("TFLite modelUrl: "+x);try{const g=await(await fetch(x)).arrayBuffer();console.log("Model buffer size:",g.byteLength);const E=h._getModelBufferMemoryOffset();console.log("Model buffer memory offset:",E),console.log("Loading model buffer..."),h.HEAPU8.set(new Uint8Array(g),E);const v=h._loadModel(g.byteLength);if(console.log("Load model result:",v),v!==0){d("Cannot load model");return}t.inputWidth=h._getInputWidth(),t.inputHeight=h._getInputHeight(),t.inputChannelCount=h._getInputChannelCount(),t.inputMemoryOffset=h._getInputMemoryOffset(),console.log("Input memory offset:",t.inputMemoryOffset),console.log("Input height:",t.inputHeight),console.log("Input width:",t.inputWidth),console.log("Input channels:",t.inputChannelCount),t.outputMemoryOffset=h._getOutputMemoryOffset(),t.outputWidth=h._getOutputWidth(),t.outputHeight=h._getOutputHeight(),t.outputChannelCount=h._getOutputChannelCount(),console.log("Output memory offset:",t.outputMemoryOffset),console.log("Output height:",t.outputHeight),console.log("Output width:",t.outputWidth),console.log("Output channels:",t.outputChannelCount),t.selectedTFLite=h}catch(l){d(l);return}f()})}s().then(u=>{if(u===null)throw console.error("loadTFLite null"),"loadTFLite null";a(u).then(f=>{i(t)}).catch(f=>{console.error("loadTFLiteModel error"),o("loadTFLiteModel error")})}).catch(u=>{console.error("loadTFLite error:",u),o("loadTFLite error:"+u)})});return n}class gf{constructor(){p(this,"canvas",new OffscreenCanvas(0,0));p(this,"context",this.canvas.getContext("2d",{willReadFrequently:!0}));p(this,"pixelCount",0);p(this,"inputOffset",0);p(this,"outputOffset",0);p(this,"infos");p(this,"mask")}async init(e,t){await this.initWasm(e,t),this.infos&&(this.canvas.width=this.infos.inputWidth,this.canvas.height=this.infos.inputHeight,this.pixelCount=this.infos.inputWidth*this.infos.inputHeight,this.mask=new ImageData(this.infos.inputWidth,this.infos.inputHeight),this.inputOffset=this.infos.inputMemoryOffset/4,this.outputOffset=this.infos.outputMemoryOffset/4)}async initWasm(e,t){this.infos=await xf(e,t)}getOutputDimensions(){var e,t,n,i;return{width:(t=(e=this.infos)==null?void 0:e.outputWidth)!=null?t:0,height:(i=(n=this.infos)==null?void 0:n.outputHeight)!=null?i:0}}async process(e){if(!this.mask||!this.infos)return;const t=this.infos.inputWidth,n=this.infos.inputHeight;this.context.drawImage(e,0,0,e.width,e.height,0,0,t,n);const i=this.context.getImageData(0,0,t,n),o=this.infos.selectedTFLite.HEAPF32;for(let s=0;s<this.pixelCount;s++){const a=this.inputOffset+s*3;o[a]=i.data[s*4]/255,o[a+1]=i.data[s*4+1]/255,o[a+2]=i.data[s*4+2]/255}this.infos.selectedTFLite._runInference();for(let s=0;s<this.pixelCount;s++){const a=this.infos.selectedTFLite.HEAPF32[this.outputOffset+s];this.mask.data[s*4]=this.mask.data[s*4+3]=255*a}return createImageBitmap(this.mask)}isGpuSupported(){var e,t,n;return(n=(t=(e=this.infos)==null?void 0:e.selectedTFLite)==null?void 0:t._isGPUEnabled())!=null?n:!1}}class bf{constructor(){p(this,"selfieSegmentation",new gf);p(this,"backgroundFilter");p(this,"reporter",new Io);p(this,"previousDimensions",{width:0,height:0});p(this,"backgroundOptions")}async init(e,t){await this.selfieSegmentation.init(t.wasmAssetUriPath,t.tfliteAssetUriPath);const{width:n,height:i}=this.selfieSegmentation.getOutputDimensions();this.backgroundFilter=new mf(e,{foregroundWidth:1,foregroundHeight:1,maskWidth:n,maskHeight:i}),this.report({variation:"Create"})}async transform(e,t){var s,a,u,f;const n=(s=e.timestamp)!=null?s:0,i=await createImageBitmap(e),o=await this.selfieSegmentation.process(i);o?((i.width!==this.previousDimensions.width||i.height!==this.previousDimensions.height)&&(this.previousDimensions.width=i.width,this.previousDimensions.height=i.height,await((a=this.backgroundFilter)==null?void 0:a.resizeForeground(i.width,i.height))),await((u=this.backgroundFilter)==null?void 0:u.process(i,o)),e.close(),t.enqueue(new VideoFrame((f=this.backgroundFilter)==null?void 0:f.canvas,{timestamp:n,alpha:"discard"}))):t.enqueue(e)}async setBackgroundOptions(e){var t;this.backgroundOptions=e,await((t=this.backgroundFilter)==null?void 0:t.setBackgroundOptions(e)),this.report({variation:"Update"})}async setVideoBGReadable(e){var t;await((t=this.backgroundFilter)==null?void 0:t.setVideoBGReadable(e))}async setVirtualBGImage(e){var t;await((t=this.backgroundFilter)==null?void 0:t.setVirtualBGImage(e))}setFlickeringOptions(e){var t;(t=this.backgroundFilter)==null||t.setFlickeringOptions(e),this.report({variation:"Update"})}async profile(e){var t,n;return(n=(t=this.backgroundFilter)==null?void 0:t.profile(e))!=null?n:[]}getTransformerType(){var e,t;return(t=(e=this.backgroundOptions)==null?void 0:e.transformerType)!=null?t:"Undefined"}report(e){var t;this.reporter.send({version:Fo,action:"MlTransformers",transformerType:(t=this.backgroundOptions)==null?void 0:t.transformerType,config:JSON.stringify(this.backgroundOptions),...e})}}const vr=class{constructor(){p(this,"backgroundTransformer",new bf);p(this,"mediaProcessor",new no);p(this,"rate",30);p(this,"resolveOnMediaProcessor");p(this,"eventsQueue",[])}async init(e,t){await this.backgroundTransformer.init(e,t),await this.mediaProcessor.setTransformers([this.backgroundTransformer]),this.mediaProcessor.setTrackExpectedRate(this.rate),this.mediaProcessor.onAny((n,i)=>{this.resolveOnMediaProcessor?(this.resolveOnMediaProcessor({name:n,data:i}),this.resolveOnMediaProcessor=void 0):this.eventsQueue.push({name:n,data:i})})}async onMediaProcessorEvent(){return await new Promise(e=>{this.eventsQueue.length>0?e(this.eventsQueue.shift()):this.resolveOnMediaProcessor=e})}async setTrackExpectedRate(e){this.rate=e,this.mediaProcessor.setTrackExpectedRate(e)}async transform(e,t){this.mediaProcessor.transform(e,t)}async setBackgroundOptions(e){var t;await((t=this.backgroundTransformer)==null?void 0:t.setBackgroundOptions(e))}setVideoBGReadable(e){this.backgroundTransformer.setVideoBGReadable(e)}async setVirtualBGImage(e){await this.backgroundTransformer.setVirtualBGImage(e)}async terminate(){await this.mediaProcessor.destroy()}setFlickeringOptions(e){this.backgroundTransformer.setFlickeringOptions(e)}setVonageMetadata(e){qi(e)}async profile(e){return JSON.stringify(await this.backgroundTransformer.profile(e))}};let oi=vr;(()=>{_i("ProcessorWorker",vr)})()})();
", vs = typeof window < "u" && window.Blob && new Blob([atob(Ll)], { type: "text/javascript;charset=utf-8" });
|
|
24018
24020
|
function n3() {
|
|
24019
24021
|
const i = vs && (window.URL || window.webkitURL).createObjectURL(vs);
|
|
24020
24022
|
try {
|