From c7047db6c7541a25bf056de993d72e3748da4f1d Mon Sep 17 00:00:00 2001 From: gtanczyk Date: Sun, 13 Oct 2024 10:19:24 +0000 Subject: [PATCH] =?UTF-8?q?Deploying=20to=20gh-pages=20from=20=20@=20c18f9?= =?UTF-8?q?bcb859fba0704f4cfff930df55ab7e70911=20=F0=9F=9A=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../{index-qWKj2ADz.js => index-vv2o-AJ0.js} | 2577 ++++++++--------- games/masterplan/index.html | 2 +- 2 files changed, 1289 insertions(+), 1290 deletions(-) rename games/masterplan/assets/{index-qWKj2ADz.js => index-vv2o-AJ0.js} (78%) diff --git a/games/masterplan/assets/index-qWKj2ADz.js b/games/masterplan/assets/index-vv2o-AJ0.js similarity index 78% rename from games/masterplan/assets/index-qWKj2ADz.js rename to games/masterplan/assets/index-vv2o-AJ0.js index 90bc4f08..0bb18b5c 100644 --- a/games/masterplan/assets/index-qWKj2ADz.js +++ b/games/masterplan/assets/index-vv2o-AJ0.js @@ -1,4 +1,4 @@ -var jD=Object.defineProperty;var KD=(t,e,n)=>e in t?jD(t,e,{enumerable:!0,configurable:!0,writable:!0,value:n}):t[e]=n;var ne=(t,e,n)=>KD(t,typeof e!="symbol"?e+"":e,n);function XD(t,e){for(var n=0;ns[r]})}}}return Object.freeze(Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}))}(function(){const e=document.createElement("link").relList;if(e&&e.supports&&e.supports("modulepreload"))return;for(const r of document.querySelectorAll('link[rel="modulepreload"]'))s(r);new MutationObserver(r=>{for(const o of r)if(o.type==="childList")for(const i of o.addedNodes)i.tagName==="LINK"&&i.rel==="modulepreload"&&s(i)}).observe(document,{childList:!0,subtree:!0});function n(r){const o={};return r.integrity&&(o.integrity=r.integrity),r.referrerPolicy&&(o.referrerPolicy=r.referrerPolicy),r.crossOrigin==="use-credentials"?o.credentials="include":r.crossOrigin==="anonymous"?o.credentials="omit":o.credentials="same-origin",o}function s(r){if(r.ep)return;r.ep=!0;const o=n(r);fetch(r.href,o)}})();var Ui=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof global<"u"?global:typeof self<"u"?self:{};function rS(t){return t&&t.__esModule&&Object.prototype.hasOwnProperty.call(t,"default")?t.default:t}function qD(t){if(t.__esModule)return t;var e=t.default;if(typeof e=="function"){var n=function s(){return this instanceof s?Reflect.construct(e,arguments,this.constructor):e.apply(this,arguments)};n.prototype=e.prototype}else n={};return Object.defineProperty(n,"__esModule",{value:!0}),Object.keys(t).forEach(function(s){var r=Object.getOwnPropertyDescriptor(t,s);Object.defineProperty(n,s,r.get?r:{enumerable:!0,get:function(){return t[s]}})}),n}var oS={exports:{}},jf={},iS={exports:{}},_e={};/** +var KD=Object.defineProperty;var XD=(t,e,n)=>e in t?KD(t,e,{enumerable:!0,configurable:!0,writable:!0,value:n}):t[e]=n;var ee=(t,e,n)=>XD(t,typeof e!="symbol"?e+"":e,n);function qD(t,e){for(var n=0;ns[r]})}}}return Object.freeze(Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}))}(function(){const e=document.createElement("link").relList;if(e&&e.supports&&e.supports("modulepreload"))return;for(const r of document.querySelectorAll('link[rel="modulepreload"]'))s(r);new MutationObserver(r=>{for(const o of r)if(o.type==="childList")for(const i of o.addedNodes)i.tagName==="LINK"&&i.rel==="modulepreload"&&s(i)}).observe(document,{childList:!0,subtree:!0});function n(r){const o={};return r.integrity&&(o.integrity=r.integrity),r.referrerPolicy&&(o.referrerPolicy=r.referrerPolicy),r.crossOrigin==="use-credentials"?o.credentials="include":r.crossOrigin==="anonymous"?o.credentials="omit":o.credentials="same-origin",o}function s(r){if(r.ep)return;r.ep=!0;const o=n(r);fetch(r.href,o)}})();var Ui=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof global<"u"?global:typeof self<"u"?self:{};function oS(t){return t&&t.__esModule&&Object.prototype.hasOwnProperty.call(t,"default")?t.default:t}function YD(t){if(t.__esModule)return t;var e=t.default;if(typeof e=="function"){var n=function s(){return this instanceof s?Reflect.construct(e,arguments,this.constructor):e.apply(this,arguments)};n.prototype=e.prototype}else n={};return Object.defineProperty(n,"__esModule",{value:!0}),Object.keys(t).forEach(function(s){var r=Object.getOwnPropertyDescriptor(t,s);Object.defineProperty(n,s,r.get?r:{enumerable:!0,get:function(){return t[s]}})}),n}var iS={exports:{}},jf={},aS={exports:{}},_e={};/** * @license React * react.production.min.js * @@ -6,7 +6,7 @@ var jD=Object.defineProperty;var KD=(t,e,n)=>e in t?jD(t,e,{enumerable:!0,config * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. - */var iu=Symbol.for("react.element"),YD=Symbol.for("react.portal"),QD=Symbol.for("react.fragment"),ZD=Symbol.for("react.strict_mode"),JD=Symbol.for("react.profiler"),e_=Symbol.for("react.provider"),t_=Symbol.for("react.context"),n_=Symbol.for("react.forward_ref"),s_=Symbol.for("react.suspense"),r_=Symbol.for("react.memo"),o_=Symbol.for("react.lazy"),Dv=Symbol.iterator;function i_(t){return t===null||typeof t!="object"?null:(t=Dv&&t[Dv]||t["@@iterator"],typeof t=="function"?t:null)}var aS={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},lS=Object.assign,cS={};function ml(t,e,n){this.props=t,this.context=e,this.refs=cS,this.updater=n||aS}ml.prototype.isReactComponent={};ml.prototype.setState=function(t,e){if(typeof t!="object"&&typeof t!="function"&&t!=null)throw Error("setState(...): takes an object of state variables to update or a function which returns an object of state variables.");this.updater.enqueueSetState(this,t,e,"setState")};ml.prototype.forceUpdate=function(t){this.updater.enqueueForceUpdate(this,t,"forceUpdate")};function uS(){}uS.prototype=ml.prototype;function z1(t,e,n){this.props=t,this.context=e,this.refs=cS,this.updater=n||aS}var O1=z1.prototype=new uS;O1.constructor=z1;lS(O1,ml.prototype);O1.isPureReactComponent=!0;var _v=Array.isArray,dS=Object.prototype.hasOwnProperty,M1={current:null},hS={key:!0,ref:!0,__self:!0,__source:!0};function fS(t,e,n){var s,r={},o=null,i=null;if(e!=null)for(s in e.ref!==void 0&&(i=e.ref),e.key!==void 0&&(o=""+e.key),e)dS.call(e,s)&&!hS.hasOwnProperty(s)&&(r[s]=e[s]);var a=arguments.length-2;if(a===1)r.children=n;else if(1e in t?jD(t,e,{enumerable:!0,config * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. - */var d_=ye,h_=Symbol.for("react.element"),f_=Symbol.for("react.fragment"),p_=Object.prototype.hasOwnProperty,m_=d_.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,g_={key:!0,ref:!0,__self:!0,__source:!0};function mS(t,e,n){var s,r={},o=null,i=null;n!==void 0&&(o=""+n),e.key!==void 0&&(o=""+e.key),e.ref!==void 0&&(i=e.ref);for(s in e)p_.call(e,s)&&!g_.hasOwnProperty(s)&&(r[s]=e[s]);if(t&&t.defaultProps)for(s in e=t.defaultProps,e)r[s]===void 0&&(r[s]=e[s]);return{$$typeof:h_,type:t,key:o,ref:i,props:r,_owner:m_.current}}jf.Fragment=f_;jf.jsx=mS;jf.jsxs=mS;oS.exports=jf;var De=oS.exports,Gg={},gS={exports:{}},ls={},xS={exports:{}},yS={};/** + */var d_=ye,f_=Symbol.for("react.element"),p_=Symbol.for("react.fragment"),m_=Object.prototype.hasOwnProperty,g_=d_.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,x_={key:!0,ref:!0,__self:!0,__source:!0};function gS(t,e,n){var s,r={},o=null,i=null;n!==void 0&&(o=""+n),e.key!==void 0&&(o=""+e.key),e.ref!==void 0&&(i=e.ref);for(s in e)m_.call(e,s)&&!x_.hasOwnProperty(s)&&(r[s]=e[s]);if(t&&t.defaultProps)for(s in e=t.defaultProps,e)r[s]===void 0&&(r[s]=e[s]);return{$$typeof:f_,type:t,key:o,ref:i,props:r,_owner:g_.current}}jf.Fragment=p_;jf.jsx=gS;jf.jsxs=gS;iS.exports=jf;var De=iS.exports,Gg={},xS={exports:{}},ls={},yS={exports:{}},wS={};/** * @license React * scheduler.production.min.js * @@ -22,7 +22,7 @@ var jD=Object.defineProperty;var KD=(t,e,n)=>e in t?jD(t,e,{enumerable:!0,config * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. - */(function(t){function e(R,O){var G=R.length;R.push(O);e:for(;0>>1,q=R[X];if(0>>1;Xr(Z,G))ser(ie,Z)?(R[X]=ie,R[se]=G,X=se):(R[X]=Z,R[ee]=G,X=ee);else if(ser(ie,G))R[X]=ie,R[se]=G,X=se;else break e}}return O}function r(R,O){var G=R.sortIndex-O.sortIndex;return G!==0?G:R.id-O.id}if(typeof performance=="object"&&typeof performance.now=="function"){var o=performance;t.unstable_now=function(){return o.now()}}else{var i=Date,a=i.now();t.unstable_now=function(){return i.now()-a}}var l=[],c=[],u=1,d=null,h=3,f=!1,p=!1,g=!1,x=typeof setTimeout=="function"?setTimeout:null,m=typeof clearTimeout=="function"?clearTimeout:null,y=typeof setImmediate<"u"?setImmediate:null;typeof navigator<"u"&&navigator.scheduling!==void 0&&navigator.scheduling.isInputPending!==void 0&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function w(R){for(var O=n(c);O!==null;){if(O.callback===null)s(c);else if(O.startTime<=R)s(c),O.sortIndex=O.expirationTime,e(l,O);else break;O=n(c)}}function v(R){if(g=!1,w(R),!p)if(n(l)!==null)p=!0,U(b);else{var O=n(c);O!==null&&K(v,O.startTime-R)}}function b(R,O){p=!1,g&&(g=!1,m(S),S=-1),f=!0;var G=h;try{for(w(O),d=n(l);d!==null&&(!(d.expirationTime>O)||R&&!A());){var X=d.callback;if(typeof X=="function"){d.callback=null,h=d.priorityLevel;var q=X(d.expirationTime<=O);O=t.unstable_now(),typeof q=="function"?d.callback=q:d===n(l)&&s(l),w(O)}else s(l);d=n(l)}if(d!==null)var Q=!0;else{var ee=n(c);ee!==null&&K(v,ee.startTime-O),Q=!1}return Q}finally{d=null,h=G,f=!1}}var C=!1,k=null,S=-1,$=5,N=-1;function A(){return!(t.unstable_now()-N<$)}function M(){if(k!==null){var R=t.unstable_now();N=R;var O=!0;try{O=k(!0,R)}finally{O?L():(C=!1,k=null)}}else C=!1}var L;if(typeof y=="function")L=function(){y(M)};else if(typeof MessageChannel<"u"){var V=new MessageChannel,B=V.port2;V.port1.onmessage=M,L=function(){B.postMessage(null)}}else L=function(){x(M,0)};function U(R){k=R,C||(C=!0,L())}function K(R,O){S=x(function(){R(t.unstable_now())},O)}t.unstable_IdlePriority=5,t.unstable_ImmediatePriority=1,t.unstable_LowPriority=4,t.unstable_NormalPriority=3,t.unstable_Profiling=null,t.unstable_UserBlockingPriority=2,t.unstable_cancelCallback=function(R){R.callback=null},t.unstable_continueExecution=function(){p||f||(p=!0,U(b))},t.unstable_forceFrameRate=function(R){0>R||125X?(R.sortIndex=G,e(c,R),n(l)===null&&R===n(c)&&(g?(m(S),S=-1):g=!0,K(v,G-X))):(R.sortIndex=q,e(l,R),p||f||(p=!0,U(b))),R},t.unstable_shouldYield=A,t.unstable_wrapCallback=function(R){var O=h;return function(){var G=h;h=O;try{return R.apply(this,arguments)}finally{h=G}}}})(yS);xS.exports=yS;var x_=xS.exports;/** + */(function(t){function e(R,O){var G=R.length;R.push(O);e:for(;0>>1,q=R[X];if(0>>1;Xr(Z,G))ser(ie,Z)?(R[X]=ie,R[se]=G,X=se):(R[X]=Z,R[te]=G,X=te);else if(ser(ie,G))R[X]=ie,R[se]=G,X=se;else break e}}return O}function r(R,O){var G=R.sortIndex-O.sortIndex;return G!==0?G:R.id-O.id}if(typeof performance=="object"&&typeof performance.now=="function"){var o=performance;t.unstable_now=function(){return o.now()}}else{var i=Date,a=i.now();t.unstable_now=function(){return i.now()-a}}var l=[],c=[],u=1,h=null,d=3,f=!1,p=!1,g=!1,x=typeof setTimeout=="function"?setTimeout:null,m=typeof clearTimeout=="function"?clearTimeout:null,y=typeof setImmediate<"u"?setImmediate:null;typeof navigator<"u"&&navigator.scheduling!==void 0&&navigator.scheduling.isInputPending!==void 0&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function w(R){for(var O=n(c);O!==null;){if(O.callback===null)s(c);else if(O.startTime<=R)s(c),O.sortIndex=O.expirationTime,e(l,O);else break;O=n(c)}}function v(R){if(g=!1,w(R),!p)if(n(l)!==null)p=!0,U(b);else{var O=n(c);O!==null&&K(v,O.startTime-R)}}function b(R,O){p=!1,g&&(g=!1,m(S),S=-1),f=!0;var G=d;try{for(w(O),h=n(l);h!==null&&(!(h.expirationTime>O)||R&&!A());){var X=h.callback;if(typeof X=="function"){h.callback=null,d=h.priorityLevel;var q=X(h.expirationTime<=O);O=t.unstable_now(),typeof q=="function"?h.callback=q:h===n(l)&&s(l),w(O)}else s(l);h=n(l)}if(h!==null)var Q=!0;else{var te=n(c);te!==null&&K(v,te.startTime-O),Q=!1}return Q}finally{h=null,d=G,f=!1}}var C=!1,k=null,S=-1,$=5,N=-1;function A(){return!(t.unstable_now()-N<$)}function M(){if(k!==null){var R=t.unstable_now();N=R;var O=!0;try{O=k(!0,R)}finally{O?L():(C=!1,k=null)}}else C=!1}var L;if(typeof y=="function")L=function(){y(M)};else if(typeof MessageChannel<"u"){var V=new MessageChannel,B=V.port2;V.port1.onmessage=M,L=function(){B.postMessage(null)}}else L=function(){x(M,0)};function U(R){k=R,C||(C=!0,L())}function K(R,O){S=x(function(){R(t.unstable_now())},O)}t.unstable_IdlePriority=5,t.unstable_ImmediatePriority=1,t.unstable_LowPriority=4,t.unstable_NormalPriority=3,t.unstable_Profiling=null,t.unstable_UserBlockingPriority=2,t.unstable_cancelCallback=function(R){R.callback=null},t.unstable_continueExecution=function(){p||f||(p=!0,U(b))},t.unstable_forceFrameRate=function(R){0>R||125X?(R.sortIndex=G,e(c,R),n(l)===null&&R===n(c)&&(g?(m(S),S=-1):g=!0,K(v,G-X))):(R.sortIndex=q,e(l,R),p||f||(p=!0,U(b))),R},t.unstable_shouldYield=A,t.unstable_wrapCallback=function(R){var O=d;return function(){var G=d;d=O;try{return R.apply(this,arguments)}finally{d=G}}}})(wS);yS.exports=wS;var y_=yS.exports;/** * @license React * react-dom.production.min.js * @@ -30,15 +30,15 @@ var jD=Object.defineProperty;var KD=(t,e,n)=>e in t?jD(t,e,{enumerable:!0,config * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. - */var y_=ye,os=x_;function te(t){for(var e="https://reactjs.org/docs/error-decoder.html?invariant="+t,n=1;n"u"||typeof window.document>"u"||typeof window.document.createElement>"u"),Hg=Object.prototype.hasOwnProperty,w_=/^[:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD][:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD\-.0-9\u00B7\u0300-\u036F\u203F-\u2040]*$/,zv={},Ov={};function v_(t){return Hg.call(Ov,t)?!0:Hg.call(zv,t)?!1:w_.test(t)?Ov[t]=!0:(zv[t]=!0,!1)}function b_(t,e,n,s){if(n!==null&&n.type===0)return!1;switch(typeof e){case"function":case"symbol":return!0;case"boolean":return s?!1:n!==null?!n.acceptsBooleans:(t=t.toLowerCase().slice(0,5),t!=="data-"&&t!=="aria-");default:return!1}}function C_(t,e,n,s){if(e===null||typeof e>"u"||b_(t,e,n,s))return!0;if(s)return!1;if(n!==null)switch(n.type){case 3:return!e;case 4:return e===!1;case 5:return isNaN(e);case 6:return isNaN(e)||1>e}return!1}function On(t,e,n,s,r,o,i){this.acceptsBooleans=e===2||e===3||e===4,this.attributeName=s,this.attributeNamespace=r,this.mustUseProperty=n,this.propertyName=t,this.type=e,this.sanitizeURL=o,this.removeEmptyString=i}var ln={};"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style".split(" ").forEach(function(t){ln[t]=new On(t,0,!1,t,null,!1,!1)});[["acceptCharset","accept-charset"],["className","class"],["htmlFor","for"],["httpEquiv","http-equiv"]].forEach(function(t){var e=t[0];ln[e]=new On(e,1,!1,t[1],null,!1,!1)});["contentEditable","draggable","spellCheck","value"].forEach(function(t){ln[t]=new On(t,2,!1,t.toLowerCase(),null,!1,!1)});["autoReverse","externalResourcesRequired","focusable","preserveAlpha"].forEach(function(t){ln[t]=new On(t,2,!1,t,null,!1,!1)});"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture disableRemotePlayback formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope".split(" ").forEach(function(t){ln[t]=new On(t,3,!1,t.toLowerCase(),null,!1,!1)});["checked","multiple","muted","selected"].forEach(function(t){ln[t]=new On(t,3,!0,t,null,!1,!1)});["capture","download"].forEach(function(t){ln[t]=new On(t,4,!1,t,null,!1,!1)});["cols","rows","size","span"].forEach(function(t){ln[t]=new On(t,6,!1,t,null,!1,!1)});["rowSpan","start"].forEach(function(t){ln[t]=new On(t,5,!1,t.toLowerCase(),null,!1,!1)});var L1=/[\-:]([a-z])/g;function B1(t){return t[1].toUpperCase()}"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height".split(" ").forEach(function(t){var e=t.replace(L1,B1);ln[e]=new On(e,1,!1,t,null,!1,!1)});"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type".split(" ").forEach(function(t){var e=t.replace(L1,B1);ln[e]=new On(e,1,!1,t,"http://www.w3.org/1999/xlink",!1,!1)});["xml:base","xml:lang","xml:space"].forEach(function(t){var e=t.replace(L1,B1);ln[e]=new On(e,1,!1,t,"http://www.w3.org/XML/1998/namespace",!1,!1)});["tabIndex","crossOrigin"].forEach(function(t){ln[t]=new On(t,1,!1,t.toLowerCase(),null,!1,!1)});ln.xlinkHref=new On("xlinkHref",1,!1,"xlink:href","http://www.w3.org/1999/xlink",!0,!1);["src","href","action","formAction"].forEach(function(t){ln[t]=new On(t,1,!1,t.toLowerCase(),null,!0,!0)});function V1(t,e,n,s){var r=ln.hasOwnProperty(e)?ln[e]:null;(r!==null?r.type!==0:s||!(2"u"||typeof window.document>"u"||typeof window.document.createElement>"u"),Hg=Object.prototype.hasOwnProperty,v_=/^[:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD][:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD\-.0-9\u00B7\u0300-\u036F\u203F-\u2040]*$/,zv={},Ov={};function b_(t){return Hg.call(Ov,t)?!0:Hg.call(zv,t)?!1:v_.test(t)?Ov[t]=!0:(zv[t]=!0,!1)}function C_(t,e,n,s){if(n!==null&&n.type===0)return!1;switch(typeof e){case"function":case"symbol":return!0;case"boolean":return s?!1:n!==null?!n.acceptsBooleans:(t=t.toLowerCase().slice(0,5),t!=="data-"&&t!=="aria-");default:return!1}}function k_(t,e,n,s){if(e===null||typeof e>"u"||C_(t,e,n,s))return!0;if(s)return!1;if(n!==null)switch(n.type){case 3:return!e;case 4:return e===!1;case 5:return isNaN(e);case 6:return isNaN(e)||1>e}return!1}function On(t,e,n,s,r,o,i){this.acceptsBooleans=e===2||e===3||e===4,this.attributeName=s,this.attributeNamespace=r,this.mustUseProperty=n,this.propertyName=t,this.type=e,this.sanitizeURL=o,this.removeEmptyString=i}var ln={};"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style".split(" ").forEach(function(t){ln[t]=new On(t,0,!1,t,null,!1,!1)});[["acceptCharset","accept-charset"],["className","class"],["htmlFor","for"],["httpEquiv","http-equiv"]].forEach(function(t){var e=t[0];ln[e]=new On(e,1,!1,t[1],null,!1,!1)});["contentEditable","draggable","spellCheck","value"].forEach(function(t){ln[t]=new On(t,2,!1,t.toLowerCase(),null,!1,!1)});["autoReverse","externalResourcesRequired","focusable","preserveAlpha"].forEach(function(t){ln[t]=new On(t,2,!1,t,null,!1,!1)});"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture disableRemotePlayback formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope".split(" ").forEach(function(t){ln[t]=new On(t,3,!1,t.toLowerCase(),null,!1,!1)});["checked","multiple","muted","selected"].forEach(function(t){ln[t]=new On(t,3,!0,t,null,!1,!1)});["capture","download"].forEach(function(t){ln[t]=new On(t,4,!1,t,null,!1,!1)});["cols","rows","size","span"].forEach(function(t){ln[t]=new On(t,6,!1,t,null,!1,!1)});["rowSpan","start"].forEach(function(t){ln[t]=new On(t,5,!1,t.toLowerCase(),null,!1,!1)});var L1=/[\-:]([a-z])/g;function B1(t){return t[1].toUpperCase()}"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height".split(" ").forEach(function(t){var e=t.replace(L1,B1);ln[e]=new On(e,1,!1,t,null,!1,!1)});"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type".split(" ").forEach(function(t){var e=t.replace(L1,B1);ln[e]=new On(e,1,!1,t,"http://www.w3.org/1999/xlink",!1,!1)});["xml:base","xml:lang","xml:space"].forEach(function(t){var e=t.replace(L1,B1);ln[e]=new On(e,1,!1,t,"http://www.w3.org/XML/1998/namespace",!1,!1)});["tabIndex","crossOrigin"].forEach(function(t){ln[t]=new On(t,1,!1,t.toLowerCase(),null,!1,!1)});ln.xlinkHref=new On("xlinkHref",1,!1,"xlink:href","http://www.w3.org/1999/xlink",!0,!1);["src","href","action","formAction"].forEach(function(t){ln[t]=new On(t,1,!1,t.toLowerCase(),null,!0,!0)});function V1(t,e,n,s){var r=ln.hasOwnProperty(e)?ln[e]:null;(r!==null?r.type!==0:s||!(2a||r[i]!==o[a]){var l=` -`+r[i].replace(" at new "," at ");return t.displayName&&l.includes("")&&(l=l.replace("",t.displayName)),l}while(1<=i&&0<=a);break}}}finally{jm=!1,Error.prepareStackTrace=n}return(t=t?t.displayName||t.name:"")?Yl(t):""}function k_(t){switch(t.tag){case 5:return Yl(t.type);case 16:return Yl("Lazy");case 13:return Yl("Suspense");case 19:return Yl("SuspenseList");case 0:case 2:case 15:return t=Km(t.type,!1),t;case 11:return t=Km(t.type.render,!1),t;case 1:return t=Km(t.type,!0),t;default:return""}}function qg(t){if(t==null)return null;if(typeof t=="function")return t.displayName||t.name||null;if(typeof t=="string")return t;switch(t){case ga:return"Fragment";case ma:return"Portal";case jg:return"Profiler";case W1:return"StrictMode";case Kg:return"Suspense";case Xg:return"SuspenseList"}if(typeof t=="object")switch(t.$$typeof){case bS:return(t.displayName||"Context")+".Consumer";case vS:return(t._context.displayName||"Context")+".Provider";case U1:var e=t.render;return t=t.displayName,t||(t=e.displayName||e.name||"",t=t!==""?"ForwardRef("+t+")":"ForwardRef"),t;case G1:return e=t.displayName||null,e!==null?e:qg(t.type)||"Memo";case so:e=t._payload,t=t._init;try{return qg(t(e))}catch{}}return null}function S_(t){var e=t.type;switch(t.tag){case 24:return"Cache";case 9:return(e.displayName||"Context")+".Consumer";case 10:return(e._context.displayName||"Context")+".Provider";case 18:return"DehydratedFragment";case 11:return t=e.render,t=t.displayName||t.name||"",e.displayName||(t!==""?"ForwardRef("+t+")":"ForwardRef");case 7:return"Fragment";case 5:return e;case 4:return"Portal";case 3:return"Root";case 6:return"Text";case 16:return qg(e);case 8:return e===W1?"StrictMode":"Mode";case 22:return"Offscreen";case 12:return"Profiler";case 21:return"Scope";case 13:return"Suspense";case 19:return"SuspenseList";case 25:return"TracingMarker";case 1:case 0:case 17:case 2:case 14:case 15:if(typeof e=="function")return e.displayName||e.name||null;if(typeof e=="string")return e}return null}function Ro(t){switch(typeof t){case"boolean":case"number":case"string":case"undefined":return t;case"object":return t;default:return""}}function kS(t){var e=t.type;return(t=t.nodeName)&&t.toLowerCase()==="input"&&(e==="checkbox"||e==="radio")}function I_(t){var e=kS(t)?"checked":"value",n=Object.getOwnPropertyDescriptor(t.constructor.prototype,e),s=""+t[e];if(!t.hasOwnProperty(e)&&typeof n<"u"&&typeof n.get=="function"&&typeof n.set=="function"){var r=n.get,o=n.set;return Object.defineProperty(t,e,{configurable:!0,get:function(){return r.call(this)},set:function(i){s=""+i,o.call(this,i)}}),Object.defineProperty(t,e,{enumerable:n.enumerable}),{getValue:function(){return s},setValue:function(i){s=""+i},stopTracking:function(){t._valueTracker=null,delete t[e]}}}}function Od(t){t._valueTracker||(t._valueTracker=I_(t))}function SS(t){if(!t)return!1;var e=t._valueTracker;if(!e)return!0;var n=e.getValue(),s="";return t&&(s=kS(t)?t.checked?"true":"false":t.value),t=s,t!==n?(e.setValue(t),!0):!1}function Oh(t){if(t=t||(typeof document<"u"?document:void 0),typeof t>"u")return null;try{return t.activeElement||t.body}catch{return t.body}}function Yg(t,e){var n=e.checked;return bt({},e,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:n??t._wrapperState.initialChecked})}function Pv(t,e){var n=e.defaultValue==null?"":e.defaultValue,s=e.checked!=null?e.checked:e.defaultChecked;n=Ro(e.value!=null?e.value:n),t._wrapperState={initialChecked:s,initialValue:n,controlled:e.type==="checkbox"||e.type==="radio"?e.checked!=null:e.value!=null}}function IS(t,e){e=e.checked,e!=null&&V1(t,"checked",e,!1)}function Qg(t,e){IS(t,e);var n=Ro(e.value),s=e.type;if(n!=null)s==="number"?(n===0&&t.value===""||t.value!=n)&&(t.value=""+n):t.value!==""+n&&(t.value=""+n);else if(s==="submit"||s==="reset"){t.removeAttribute("value");return}e.hasOwnProperty("value")?Zg(t,e.type,n):e.hasOwnProperty("defaultValue")&&Zg(t,e.type,Ro(e.defaultValue)),e.checked==null&&e.defaultChecked!=null&&(t.defaultChecked=!!e.defaultChecked)}function Lv(t,e,n){if(e.hasOwnProperty("value")||e.hasOwnProperty("defaultValue")){var s=e.type;if(!(s!=="submit"&&s!=="reset"||e.value!==void 0&&e.value!==null))return;e=""+t._wrapperState.initialValue,n||e===t.value||(t.value=e),t.defaultValue=e}n=t.name,n!==""&&(t.name=""),t.defaultChecked=!!t._wrapperState.initialChecked,n!==""&&(t.name=n)}function Zg(t,e,n){(e!=="number"||Oh(t.ownerDocument)!==t)&&(n==null?t.defaultValue=""+t._wrapperState.initialValue:t.defaultValue!==""+n&&(t.defaultValue=""+n))}var Ql=Array.isArray;function Ea(t,e,n,s){if(t=t.options,e){e={};for(var r=0;r"+e.valueOf().toString()+"",e=Md.firstChild;t.firstChild;)t.removeChild(t.firstChild);for(;e.firstChild;)t.appendChild(e.firstChild)}});function Nc(t,e){if(e){var n=t.firstChild;if(n&&n===t.lastChild&&n.nodeType===3){n.nodeValue=e;return}}t.textContent=e}var dc={animationIterationCount:!0,aspectRatio:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,zoom:!0,fillOpacity:!0,floodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},$_=["Webkit","ms","Moz","O"];Object.keys(dc).forEach(function(t){$_.forEach(function(e){e=e+t.charAt(0).toUpperCase()+t.substring(1),dc[e]=dc[t]})});function ES(t,e,n){return e==null||typeof e=="boolean"||e===""?"":n||typeof e!="number"||e===0||dc.hasOwnProperty(t)&&dc[t]?(""+e).trim():e+"px"}function RS(t,e){t=t.style;for(var n in e)if(e.hasOwnProperty(n)){var s=n.indexOf("--")===0,r=ES(n,e[n],s);n==="float"&&(n="cssFloat"),s?t.setProperty(n,r):t[n]=r}}var N_=bt({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});function t0(t,e){if(e){if(N_[t]&&(e.children!=null||e.dangerouslySetInnerHTML!=null))throw Error(te(137,t));if(e.dangerouslySetInnerHTML!=null){if(e.children!=null)throw Error(te(60));if(typeof e.dangerouslySetInnerHTML!="object"||!("__html"in e.dangerouslySetInnerHTML))throw Error(te(61))}if(e.style!=null&&typeof e.style!="object")throw Error(te(62))}}function n0(t,e){if(t.indexOf("-")===-1)return typeof e.is=="string";switch(t){case"annotation-xml":case"color-profile":case"font-face":case"font-face-src":case"font-face-uri":case"font-face-format":case"font-face-name":case"missing-glyph":return!1;default:return!0}}var s0=null;function H1(t){return t=t.target||t.srcElement||window,t.correspondingUseElement&&(t=t.correspondingUseElement),t.nodeType===3?t.parentNode:t}var r0=null,Ra=null,Aa=null;function Wv(t){if(t=cu(t)){if(typeof r0!="function")throw Error(te(280));var e=t.stateNode;e&&(e=Qf(e),r0(t.stateNode,t.type,e))}}function AS(t){Ra?Aa?Aa.push(t):Aa=[t]:Ra=t}function DS(){if(Ra){var t=Ra,e=Aa;if(Aa=Ra=null,Wv(t),e)for(t=0;t>>=0,t===0?32:31-(P_(t)/L_|0)|0}var Pd=64,Ld=4194304;function Zl(t){switch(t&-t){case 1:return 1;case 2:return 2;case 4:return 4;case 8:return 8;case 16:return 16;case 32:return 32;case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:return t&4194240;case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:return t&130023424;case 134217728:return 134217728;case 268435456:return 268435456;case 536870912:return 536870912;case 1073741824:return 1073741824;default:return t}}function Bh(t,e){var n=t.pendingLanes;if(n===0)return 0;var s=0,r=t.suspendedLanes,o=t.pingedLanes,i=n&268435455;if(i!==0){var a=i&~r;a!==0?s=Zl(a):(o&=i,o!==0&&(s=Zl(o)))}else i=n&~r,i!==0?s=Zl(i):o!==0&&(s=Zl(o));if(s===0)return 0;if(e!==0&&e!==s&&!(e&r)&&(r=s&-s,o=e&-e,r>=o||r===16&&(o&4194240)!==0))return e;if(s&4&&(s|=n&16),e=t.entangledLanes,e!==0)for(t=t.entanglements,e&=s;0n;n++)e.push(t);return e}function au(t,e,n){t.pendingLanes|=e,e!==536870912&&(t.suspendedLanes=0,t.pingedLanes=0),t=t.eventTimes,e=31-Hs(e),t[e]=n}function U_(t,e){var n=t.pendingLanes&~e;t.pendingLanes=e,t.suspendedLanes=0,t.pingedLanes=0,t.expiredLanes&=e,t.mutableReadLanes&=e,t.entangledLanes&=e,e=t.entanglements;var s=t.eventTimes;for(t=t.expirationTimes;0=fc),Qv=" ",Zv=!1;function ZS(t,e){switch(t){case"keyup":return xF.indexOf(e.keyCode)!==-1;case"keydown":return e.keyCode!==229;case"keypress":case"mousedown":case"focusout":return!0;default:return!1}}function JS(t){return t=t.detail,typeof t=="object"&&"data"in t?t.data:null}var xa=!1;function wF(t,e){switch(t){case"compositionend":return JS(e);case"keypress":return e.which!==32?null:(Zv=!0,Qv);case"textInput":return t=e.data,t===Qv&&Zv?null:t;default:return null}}function vF(t,e){if(xa)return t==="compositionend"||!J1&&ZS(t,e)?(t=YS(),gh=Y1=lo=null,xa=!1,t):null;switch(t){case"paste":return null;case"keypress":if(!(e.ctrlKey||e.altKey||e.metaKey)||e.ctrlKey&&e.altKey){if(e.char&&1=e)return{node:n,offset:e-t};t=s}e:{for(;n;){if(n.nextSibling){n=n.nextSibling;break e}n=n.parentNode}n=void 0}n=nb(n)}}function sI(t,e){return t&&e?t===e?!0:t&&t.nodeType===3?!1:e&&e.nodeType===3?sI(t,e.parentNode):"contains"in t?t.contains(e):t.compareDocumentPosition?!!(t.compareDocumentPosition(e)&16):!1:!1}function rI(){for(var t=window,e=Oh();e instanceof t.HTMLIFrameElement;){try{var n=typeof e.contentWindow.location.href=="string"}catch{n=!1}if(n)t=e.contentWindow;else break;e=Oh(t.document)}return e}function ex(t){var e=t&&t.nodeName&&t.nodeName.toLowerCase();return e&&(e==="input"&&(t.type==="text"||t.type==="search"||t.type==="tel"||t.type==="url"||t.type==="password")||e==="textarea"||t.contentEditable==="true")}function EF(t){var e=rI(),n=t.focusedElem,s=t.selectionRange;if(e!==n&&n&&n.ownerDocument&&sI(n.ownerDocument.documentElement,n)){if(s!==null&&ex(n)){if(e=s.start,t=s.end,t===void 0&&(t=e),"selectionStart"in n)n.selectionStart=e,n.selectionEnd=Math.min(t,n.value.length);else if(t=(e=n.ownerDocument||document)&&e.defaultView||window,t.getSelection){t=t.getSelection();var r=n.textContent.length,o=Math.min(s.start,r);s=s.end===void 0?o:Math.min(s.end,r),!t.extend&&o>s&&(r=s,s=o,o=r),r=sb(n,o);var i=sb(n,s);r&&i&&(t.rangeCount!==1||t.anchorNode!==r.node||t.anchorOffset!==r.offset||t.focusNode!==i.node||t.focusOffset!==i.offset)&&(e=e.createRange(),e.setStart(r.node,r.offset),t.removeAllRanges(),o>s?(t.addRange(e),t.extend(i.node,i.offset)):(e.setEnd(i.node,i.offset),t.addRange(e)))}}for(e=[],t=n;t=t.parentNode;)t.nodeType===1&&e.push({element:t,left:t.scrollLeft,top:t.scrollTop});for(typeof n.focus=="function"&&n.focus(),n=0;n=document.documentMode,ya=null,u0=null,mc=null,d0=!1;function rb(t,e,n){var s=n.window===n?n.document:n.nodeType===9?n:n.ownerDocument;d0||ya==null||ya!==Oh(s)||(s=ya,"selectionStart"in s&&ex(s)?s={start:s.selectionStart,end:s.selectionEnd}:(s=(s.ownerDocument&&s.ownerDocument.defaultView||window).getSelection(),s={anchorNode:s.anchorNode,anchorOffset:s.anchorOffset,focusNode:s.focusNode,focusOffset:s.focusOffset}),mc&&_c(mc,s)||(mc=s,s=Uh(u0,"onSelect"),0ba||(t.current=x0[ba],x0[ba]=null,ba--)}function rt(t,e){ba++,x0[ba]=t.current,t.current=e}var Ao={},kn=Lo(Ao),Hn=Lo(!1),ki=Ao;function Ua(t,e){var n=t.type.contextTypes;if(!n)return Ao;var s=t.stateNode;if(s&&s.__reactInternalMemoizedUnmaskedChildContext===e)return s.__reactInternalMemoizedMaskedChildContext;var r={},o;for(o in n)r[o]=e[o];return s&&(t=t.stateNode,t.__reactInternalMemoizedUnmaskedChildContext=e,t.__reactInternalMemoizedMaskedChildContext=r),r}function jn(t){return t=t.childContextTypes,t!=null}function Hh(){ht(Hn),ht(kn)}function db(t,e,n){if(kn.current!==Ao)throw Error(te(168));rt(kn,e),rt(Hn,n)}function fI(t,e,n){var s=t.stateNode;if(e=e.childContextTypes,typeof s.getChildContext!="function")return n;s=s.getChildContext();for(var r in s)if(!(r in e))throw Error(te(108,S_(t)||"Unknown",r));return bt({},n,s)}function jh(t){return t=(t=t.stateNode)&&t.__reactInternalMemoizedMergedChildContext||Ao,ki=kn.current,rt(kn,t),rt(Hn,Hn.current),!0}function hb(t,e,n){var s=t.stateNode;if(!s)throw Error(te(169));n?(t=fI(t,e,ki),s.__reactInternalMemoizedMergedChildContext=t,ht(Hn),ht(kn),rt(kn,t)):ht(Hn),rt(Hn,n)}var Ar=null,Zf=!1,ag=!1;function pI(t){Ar===null?Ar=[t]:Ar.push(t)}function VF(t){Zf=!0,pI(t)}function Bo(){if(!ag&&Ar!==null){ag=!0;var t=0,e=Ye;try{var n=Ar;for(Ye=1;t>=i,r-=i,Fr=1<<32-Hs(e)+r|n<S?($=k,k=null):$=k.sibling;var N=h(m,k,w[S],v);if(N===null){k===null&&(k=$);break}t&&k&&N.alternate===null&&e(m,k),y=o(N,y,S),C===null?b=N:C.sibling=N,C=N,k=$}if(S===w.length)return n(m,k),gt&&ni(m,S),b;if(k===null){for(;SS?($=k,k=null):$=k.sibling;var A=h(m,k,N.value,v);if(A===null){k===null&&(k=$);break}t&&k&&A.alternate===null&&e(m,k),y=o(A,y,S),C===null?b=A:C.sibling=A,C=A,k=$}if(N.done)return n(m,k),gt&&ni(m,S),b;if(k===null){for(;!N.done;S++,N=w.next())N=d(m,N.value,v),N!==null&&(y=o(N,y,S),C===null?b=N:C.sibling=N,C=N);return gt&&ni(m,S),b}for(k=s(m,k);!N.done;S++,N=w.next())N=f(k,m,S,N.value,v),N!==null&&(t&&N.alternate!==null&&k.delete(N.key===null?S:N.key),y=o(N,y,S),C===null?b=N:C.sibling=N,C=N);return t&&k.forEach(function(M){return e(m,M)}),gt&&ni(m,S),b}function x(m,y,w,v){if(typeof w=="object"&&w!==null&&w.type===ga&&w.key===null&&(w=w.props.children),typeof w=="object"&&w!==null){switch(w.$$typeof){case zd:e:{for(var b=w.key,C=y;C!==null;){if(C.key===b){if(b=w.type,b===ga){if(C.tag===7){n(m,C.sibling),y=r(C,w.props.children),y.return=m,m=y;break e}}else if(C.elementType===b||typeof b=="object"&&b!==null&&b.$$typeof===so&&mb(b)===C.type){n(m,C.sibling),y=r(C,w.props),y.ref=Vl(m,C,w),y.return=m,m=y;break e}n(m,C);break}else e(m,C);C=C.sibling}w.type===ga?(y=gi(w.props.children,m.mode,v,w.key),y.return=m,m=y):(v=Sh(w.type,w.key,w.props,null,m.mode,v),v.ref=Vl(m,y,w),v.return=m,m=v)}return i(m);case ma:e:{for(C=w.key;y!==null;){if(y.key===C)if(y.tag===4&&y.stateNode.containerInfo===w.containerInfo&&y.stateNode.implementation===w.implementation){n(m,y.sibling),y=r(y,w.children||[]),y.return=m,m=y;break e}else{n(m,y);break}else e(m,y);y=y.sibling}y=mg(w,m.mode,v),y.return=m,m=y}return i(m);case so:return C=w._init,x(m,y,C(w._payload),v)}if(Ql(w))return p(m,y,w,v);if(Ol(w))return g(m,y,w,v);jd(m,w)}return typeof w=="string"&&w!==""||typeof w=="number"?(w=""+w,y!==null&&y.tag===6?(n(m,y.sibling),y=r(y,w),y.return=m,m=y):(n(m,y),y=pg(w,m.mode,v),y.return=m,m=y),i(m)):n(m,y)}return x}var Ha=yI(!0),wI=yI(!1),qh=Lo(null),Yh=null,Sa=null,rx=null;function ox(){rx=Sa=Yh=null}function ix(t){var e=qh.current;ht(qh),t._currentValue=e}function v0(t,e,n){for(;t!==null;){var s=t.alternate;if((t.childLanes&e)!==e?(t.childLanes|=e,s!==null&&(s.childLanes|=e)):s!==null&&(s.childLanes&e)!==e&&(s.childLanes|=e),t===n)break;t=t.return}}function _a(t,e){Yh=t,rx=Sa=null,t=t.dependencies,t!==null&&t.firstContext!==null&&(t.lanes&e&&(Wn=!0),t.firstContext=null)}function Is(t){var e=t._currentValue;if(rx!==t)if(t={context:t,memoizedValue:e,next:null},Sa===null){if(Yh===null)throw Error(te(308));Sa=t,Yh.dependencies={lanes:0,firstContext:t}}else Sa=Sa.next=t;return e}var ci=null;function ax(t){ci===null?ci=[t]:ci.push(t)}function vI(t,e,n,s){var r=e.interleaved;return r===null?(n.next=n,ax(e)):(n.next=r.next,r.next=n),e.interleaved=n,Br(t,s)}function Br(t,e){t.lanes|=e;var n=t.alternate;for(n!==null&&(n.lanes|=e),n=t,t=t.return;t!==null;)t.childLanes|=e,n=t.alternate,n!==null&&(n.childLanes|=e),n=t,t=t.return;return n.tag===3?n.stateNode:null}var ro=!1;function lx(t){t.updateQueue={baseState:t.memoizedState,firstBaseUpdate:null,lastBaseUpdate:null,shared:{pending:null,interleaved:null,lanes:0},effects:null}}function bI(t,e){t=t.updateQueue,e.updateQueue===t&&(e.updateQueue={baseState:t.baseState,firstBaseUpdate:t.firstBaseUpdate,lastBaseUpdate:t.lastBaseUpdate,shared:t.shared,effects:t.effects})}function Mr(t,e){return{eventTime:t,lane:e,tag:0,payload:null,callback:null,next:null}}function wo(t,e,n){var s=t.updateQueue;if(s===null)return null;if(s=s.shared,Le&2){var r=s.pending;return r===null?e.next=e:(e.next=r.next,r.next=e),s.pending=e,Br(t,n)}return r=s.interleaved,r===null?(e.next=e,ax(s)):(e.next=r.next,r.next=e),s.interleaved=e,Br(t,n)}function yh(t,e,n){if(e=e.updateQueue,e!==null&&(e=e.shared,(n&4194240)!==0)){var s=e.lanes;s&=t.pendingLanes,n|=s,e.lanes=n,K1(t,n)}}function gb(t,e){var n=t.updateQueue,s=t.alternate;if(s!==null&&(s=s.updateQueue,n===s)){var r=null,o=null;if(n=n.firstBaseUpdate,n!==null){do{var i={eventTime:n.eventTime,lane:n.lane,tag:n.tag,payload:n.payload,callback:n.callback,next:null};o===null?r=o=i:o=o.next=i,n=n.next}while(n!==null);o===null?r=o=e:o=o.next=e}else r=o=e;n={baseState:s.baseState,firstBaseUpdate:r,lastBaseUpdate:o,shared:s.shared,effects:s.effects},t.updateQueue=n;return}t=n.lastBaseUpdate,t===null?n.firstBaseUpdate=e:t.next=e,n.lastBaseUpdate=e}function Qh(t,e,n,s){var r=t.updateQueue;ro=!1;var o=r.firstBaseUpdate,i=r.lastBaseUpdate,a=r.shared.pending;if(a!==null){r.shared.pending=null;var l=a,c=l.next;l.next=null,i===null?o=c:i.next=c,i=l;var u=t.alternate;u!==null&&(u=u.updateQueue,a=u.lastBaseUpdate,a!==i&&(a===null?u.firstBaseUpdate=c:a.next=c,u.lastBaseUpdate=l))}if(o!==null){var d=r.baseState;i=0,u=c=l=null,a=o;do{var h=a.lane,f=a.eventTime;if((s&h)===h){u!==null&&(u=u.next={eventTime:f,lane:0,tag:a.tag,payload:a.payload,callback:a.callback,next:null});e:{var p=t,g=a;switch(h=e,f=n,g.tag){case 1:if(p=g.payload,typeof p=="function"){d=p.call(f,d,h);break e}d=p;break e;case 3:p.flags=p.flags&-65537|128;case 0:if(p=g.payload,h=typeof p=="function"?p.call(f,d,h):p,h==null)break e;d=bt({},d,h);break e;case 2:ro=!0}}a.callback!==null&&a.lane!==0&&(t.flags|=64,h=r.effects,h===null?r.effects=[a]:h.push(a))}else f={eventTime:f,lane:h,tag:a.tag,payload:a.payload,callback:a.callback,next:null},u===null?(c=u=f,l=d):u=u.next=f,i|=h;if(a=a.next,a===null){if(a=r.shared.pending,a===null)break;h=a,a=h.next,h.next=null,r.lastBaseUpdate=h,r.shared.pending=null}}while(!0);if(u===null&&(l=d),r.baseState=l,r.firstBaseUpdate=c,r.lastBaseUpdate=u,e=r.shared.interleaved,e!==null){r=e;do i|=r.lane,r=r.next;while(r!==e)}else o===null&&(r.shared.lanes=0);$i|=i,t.lanes=i,t.memoizedState=d}}function xb(t,e,n){if(t=e.effects,e.effects=null,t!==null)for(e=0;en?n:4,t(!0);var s=cg.transition;cg.transition={};try{t(!1),e()}finally{Ye=n,cg.transition=s}}function PI(){return $s().memoizedState}function HF(t,e,n){var s=bo(t);if(n={lane:s,action:n,hasEagerState:!1,eagerState:null,next:null},LI(t))BI(e,n);else if(n=vI(t,e,n,s),n!==null){var r=An();js(n,t,s,r),VI(n,e,s)}}function jF(t,e,n){var s=bo(t),r={lane:s,action:n,hasEagerState:!1,eagerState:null,next:null};if(LI(t))BI(e,r);else{var o=t.alternate;if(t.lanes===0&&(o===null||o.lanes===0)&&(o=e.lastRenderedReducer,o!==null))try{var i=e.lastRenderedState,a=o(i,n);if(r.hasEagerState=!0,r.eagerState=a,Qs(a,i)){var l=e.interleaved;l===null?(r.next=r,ax(e)):(r.next=l.next,l.next=r),e.interleaved=r;return}}catch{}finally{}n=vI(t,e,r,s),n!==null&&(r=An(),js(n,t,s,r),VI(n,e,s))}}function LI(t){var e=t.alternate;return t===vt||e!==null&&e===vt}function BI(t,e){gc=Jh=!0;var n=t.pending;n===null?e.next=e:(e.next=n.next,n.next=e),t.pending=e}function VI(t,e,n){if(n&4194240){var s=e.lanes;s&=t.pendingLanes,n|=s,e.lanes=n,K1(t,n)}}var ef={readContext:Is,useCallback:mn,useContext:mn,useEffect:mn,useImperativeHandle:mn,useInsertionEffect:mn,useLayoutEffect:mn,useMemo:mn,useReducer:mn,useRef:mn,useState:mn,useDebugValue:mn,useDeferredValue:mn,useTransition:mn,useMutableSource:mn,useSyncExternalStore:mn,useId:mn,unstable_isNewReconciler:!1},KF={readContext:Is,useCallback:function(t,e){return rr().memoizedState=[t,e===void 0?null:e],t},useContext:Is,useEffect:wb,useImperativeHandle:function(t,e,n){return n=n!=null?n.concat([t]):null,vh(4194308,4,_I.bind(null,e,t),n)},useLayoutEffect:function(t,e){return vh(4194308,4,t,e)},useInsertionEffect:function(t,e){return vh(4,2,t,e)},useMemo:function(t,e){var n=rr();return e=e===void 0?null:e,t=t(),n.memoizedState=[t,e],t},useReducer:function(t,e,n){var s=rr();return e=n!==void 0?n(e):e,s.memoizedState=s.baseState=e,t={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:t,lastRenderedState:e},s.queue=t,t=t.dispatch=HF.bind(null,vt,t),[s.memoizedState,t]},useRef:function(t){var e=rr();return t={current:t},e.memoizedState=t},useState:yb,useDebugValue:gx,useDeferredValue:function(t){return rr().memoizedState=t},useTransition:function(){var t=yb(!1),e=t[0];return t=GF.bind(null,t[1]),rr().memoizedState=t,[e,t]},useMutableSource:function(){},useSyncExternalStore:function(t,e,n){var s=vt,r=rr();if(gt){if(n===void 0)throw Error(te(407));n=n()}else{if(n=e(),en===null)throw Error(te(349));Ii&30||II(s,e,n)}r.memoizedState=n;var o={value:n,getSnapshot:e};return r.queue=o,wb(NI.bind(null,s,o,t),[t]),s.flags|=2048,Vc(9,$I.bind(null,s,o,n,e),void 0,null),n},useId:function(){var t=rr(),e=en.identifierPrefix;if(gt){var n=zr,s=Fr;n=(s&~(1<<32-Hs(s)-1)).toString(32)+n,e=":"+e+"R"+n,n=Lc++,0")&&(l=l.replace("",t.displayName)),l}while(1<=i&&0<=a);break}}}finally{jm=!1,Error.prepareStackTrace=n}return(t=t?t.displayName||t.name:"")?Yl(t):""}function S_(t){switch(t.tag){case 5:return Yl(t.type);case 16:return Yl("Lazy");case 13:return Yl("Suspense");case 19:return Yl("SuspenseList");case 0:case 2:case 15:return t=Km(t.type,!1),t;case 11:return t=Km(t.type.render,!1),t;case 1:return t=Km(t.type,!0),t;default:return""}}function qg(t){if(t==null)return null;if(typeof t=="function")return t.displayName||t.name||null;if(typeof t=="string")return t;switch(t){case ga:return"Fragment";case ma:return"Portal";case jg:return"Profiler";case W1:return"StrictMode";case Kg:return"Suspense";case Xg:return"SuspenseList"}if(typeof t=="object")switch(t.$$typeof){case CS:return(t.displayName||"Context")+".Consumer";case bS:return(t._context.displayName||"Context")+".Provider";case U1:var e=t.render;return t=t.displayName,t||(t=e.displayName||e.name||"",t=t!==""?"ForwardRef("+t+")":"ForwardRef"),t;case G1:return e=t.displayName||null,e!==null?e:qg(t.type)||"Memo";case ro:e=t._payload,t=t._init;try{return qg(t(e))}catch{}}return null}function I_(t){var e=t.type;switch(t.tag){case 24:return"Cache";case 9:return(e.displayName||"Context")+".Consumer";case 10:return(e._context.displayName||"Context")+".Provider";case 18:return"DehydratedFragment";case 11:return t=e.render,t=t.displayName||t.name||"",e.displayName||(t!==""?"ForwardRef("+t+")":"ForwardRef");case 7:return"Fragment";case 5:return e;case 4:return"Portal";case 3:return"Root";case 6:return"Text";case 16:return qg(e);case 8:return e===W1?"StrictMode":"Mode";case 22:return"Offscreen";case 12:return"Profiler";case 21:return"Scope";case 13:return"Suspense";case 19:return"SuspenseList";case 25:return"TracingMarker";case 1:case 0:case 17:case 2:case 14:case 15:if(typeof e=="function")return e.displayName||e.name||null;if(typeof e=="string")return e}return null}function Ro(t){switch(typeof t){case"boolean":case"number":case"string":case"undefined":return t;case"object":return t;default:return""}}function SS(t){var e=t.type;return(t=t.nodeName)&&t.toLowerCase()==="input"&&(e==="checkbox"||e==="radio")}function $_(t){var e=SS(t)?"checked":"value",n=Object.getOwnPropertyDescriptor(t.constructor.prototype,e),s=""+t[e];if(!t.hasOwnProperty(e)&&typeof n<"u"&&typeof n.get=="function"&&typeof n.set=="function"){var r=n.get,o=n.set;return Object.defineProperty(t,e,{configurable:!0,get:function(){return r.call(this)},set:function(i){s=""+i,o.call(this,i)}}),Object.defineProperty(t,e,{enumerable:n.enumerable}),{getValue:function(){return s},setValue:function(i){s=""+i},stopTracking:function(){t._valueTracker=null,delete t[e]}}}}function Oh(t){t._valueTracker||(t._valueTracker=$_(t))}function IS(t){if(!t)return!1;var e=t._valueTracker;if(!e)return!0;var n=e.getValue(),s="";return t&&(s=SS(t)?t.checked?"true":"false":t.value),t=s,t!==n?(e.setValue(t),!0):!1}function Od(t){if(t=t||(typeof document<"u"?document:void 0),typeof t>"u")return null;try{return t.activeElement||t.body}catch{return t.body}}function Yg(t,e){var n=e.checked;return bt({},e,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:n??t._wrapperState.initialChecked})}function Pv(t,e){var n=e.defaultValue==null?"":e.defaultValue,s=e.checked!=null?e.checked:e.defaultChecked;n=Ro(e.value!=null?e.value:n),t._wrapperState={initialChecked:s,initialValue:n,controlled:e.type==="checkbox"||e.type==="radio"?e.checked!=null:e.value!=null}}function $S(t,e){e=e.checked,e!=null&&V1(t,"checked",e,!1)}function Qg(t,e){$S(t,e);var n=Ro(e.value),s=e.type;if(n!=null)s==="number"?(n===0&&t.value===""||t.value!=n)&&(t.value=""+n):t.value!==""+n&&(t.value=""+n);else if(s==="submit"||s==="reset"){t.removeAttribute("value");return}e.hasOwnProperty("value")?Zg(t,e.type,n):e.hasOwnProperty("defaultValue")&&Zg(t,e.type,Ro(e.defaultValue)),e.checked==null&&e.defaultChecked!=null&&(t.defaultChecked=!!e.defaultChecked)}function Lv(t,e,n){if(e.hasOwnProperty("value")||e.hasOwnProperty("defaultValue")){var s=e.type;if(!(s!=="submit"&&s!=="reset"||e.value!==void 0&&e.value!==null))return;e=""+t._wrapperState.initialValue,n||e===t.value||(t.value=e),t.defaultValue=e}n=t.name,n!==""&&(t.name=""),t.defaultChecked=!!t._wrapperState.initialChecked,n!==""&&(t.name=n)}function Zg(t,e,n){(e!=="number"||Od(t.ownerDocument)!==t)&&(n==null?t.defaultValue=""+t._wrapperState.initialValue:t.defaultValue!==""+n&&(t.defaultValue=""+n))}var Ql=Array.isArray;function Ea(t,e,n,s){if(t=t.options,e){e={};for(var r=0;r"+e.valueOf().toString()+"",e=Mh.firstChild;t.firstChild;)t.removeChild(t.firstChild);for(;e.firstChild;)t.appendChild(e.firstChild)}});function Nc(t,e){if(e){var n=t.firstChild;if(n&&n===t.lastChild&&n.nodeType===3){n.nodeValue=e;return}}t.textContent=e}var hc={animationIterationCount:!0,aspectRatio:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,zoom:!0,fillOpacity:!0,floodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},N_=["Webkit","ms","Moz","O"];Object.keys(hc).forEach(function(t){N_.forEach(function(e){e=e+t.charAt(0).toUpperCase()+t.substring(1),hc[e]=hc[t]})});function RS(t,e,n){return e==null||typeof e=="boolean"||e===""?"":n||typeof e!="number"||e===0||hc.hasOwnProperty(t)&&hc[t]?(""+e).trim():e+"px"}function AS(t,e){t=t.style;for(var n in e)if(e.hasOwnProperty(n)){var s=n.indexOf("--")===0,r=RS(n,e[n],s);n==="float"&&(n="cssFloat"),s?t.setProperty(n,r):t[n]=r}}var T_=bt({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});function t0(t,e){if(e){if(T_[t]&&(e.children!=null||e.dangerouslySetInnerHTML!=null))throw Error(ne(137,t));if(e.dangerouslySetInnerHTML!=null){if(e.children!=null)throw Error(ne(60));if(typeof e.dangerouslySetInnerHTML!="object"||!("__html"in e.dangerouslySetInnerHTML))throw Error(ne(61))}if(e.style!=null&&typeof e.style!="object")throw Error(ne(62))}}function n0(t,e){if(t.indexOf("-")===-1)return typeof e.is=="string";switch(t){case"annotation-xml":case"color-profile":case"font-face":case"font-face-src":case"font-face-uri":case"font-face-format":case"font-face-name":case"missing-glyph":return!1;default:return!0}}var s0=null;function H1(t){return t=t.target||t.srcElement||window,t.correspondingUseElement&&(t=t.correspondingUseElement),t.nodeType===3?t.parentNode:t}var r0=null,Ra=null,Aa=null;function Wv(t){if(t=cu(t)){if(typeof r0!="function")throw Error(ne(280));var e=t.stateNode;e&&(e=Qf(e),r0(t.stateNode,t.type,e))}}function DS(t){Ra?Aa?Aa.push(t):Aa=[t]:Ra=t}function _S(){if(Ra){var t=Ra,e=Aa;if(Aa=Ra=null,Wv(t),e)for(t=0;t>>=0,t===0?32:31-(L_(t)/B_|0)|0}var Ph=64,Lh=4194304;function Zl(t){switch(t&-t){case 1:return 1;case 2:return 2;case 4:return 4;case 8:return 8;case 16:return 16;case 32:return 32;case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:return t&4194240;case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:return t&130023424;case 134217728:return 134217728;case 268435456:return 268435456;case 536870912:return 536870912;case 1073741824:return 1073741824;default:return t}}function Bd(t,e){var n=t.pendingLanes;if(n===0)return 0;var s=0,r=t.suspendedLanes,o=t.pingedLanes,i=n&268435455;if(i!==0){var a=i&~r;a!==0?s=Zl(a):(o&=i,o!==0&&(s=Zl(o)))}else i=n&~r,i!==0?s=Zl(i):o!==0&&(s=Zl(o));if(s===0)return 0;if(e!==0&&e!==s&&!(e&r)&&(r=s&-s,o=e&-e,r>=o||r===16&&(o&4194240)!==0))return e;if(s&4&&(s|=n&16),e=t.entangledLanes,e!==0)for(t=t.entanglements,e&=s;0n;n++)e.push(t);return e}function au(t,e,n){t.pendingLanes|=e,e!==536870912&&(t.suspendedLanes=0,t.pingedLanes=0),t=t.eventTimes,e=31-js(e),t[e]=n}function G_(t,e){var n=t.pendingLanes&~e;t.pendingLanes=e,t.suspendedLanes=0,t.pingedLanes=0,t.expiredLanes&=e,t.mutableReadLanes&=e,t.entangledLanes&=e,e=t.entanglements;var s=t.eventTimes;for(t=t.expirationTimes;0=fc),Qv=" ",Zv=!1;function JS(t,e){switch(t){case"keyup":return yF.indexOf(e.keyCode)!==-1;case"keydown":return e.keyCode!==229;case"keypress":case"mousedown":case"focusout":return!0;default:return!1}}function e2(t){return t=t.detail,typeof t=="object"&&"data"in t?t.data:null}var xa=!1;function vF(t,e){switch(t){case"compositionend":return e2(e);case"keypress":return e.which!==32?null:(Zv=!0,Qv);case"textInput":return t=e.data,t===Qv&&Zv?null:t;default:return null}}function bF(t,e){if(xa)return t==="compositionend"||!J1&&JS(t,e)?(t=QS(),gd=Y1=co=null,xa=!1,t):null;switch(t){case"paste":return null;case"keypress":if(!(e.ctrlKey||e.altKey||e.metaKey)||e.ctrlKey&&e.altKey){if(e.char&&1=e)return{node:n,offset:e-t};t=s}e:{for(;n;){if(n.nextSibling){n=n.nextSibling;break e}n=n.parentNode}n=void 0}n=nb(n)}}function r2(t,e){return t&&e?t===e?!0:t&&t.nodeType===3?!1:e&&e.nodeType===3?r2(t,e.parentNode):"contains"in t?t.contains(e):t.compareDocumentPosition?!!(t.compareDocumentPosition(e)&16):!1:!1}function o2(){for(var t=window,e=Od();e instanceof t.HTMLIFrameElement;){try{var n=typeof e.contentWindow.location.href=="string"}catch{n=!1}if(n)t=e.contentWindow;else break;e=Od(t.document)}return e}function ex(t){var e=t&&t.nodeName&&t.nodeName.toLowerCase();return e&&(e==="input"&&(t.type==="text"||t.type==="search"||t.type==="tel"||t.type==="url"||t.type==="password")||e==="textarea"||t.contentEditable==="true")}function RF(t){var e=o2(),n=t.focusedElem,s=t.selectionRange;if(e!==n&&n&&n.ownerDocument&&r2(n.ownerDocument.documentElement,n)){if(s!==null&&ex(n)){if(e=s.start,t=s.end,t===void 0&&(t=e),"selectionStart"in n)n.selectionStart=e,n.selectionEnd=Math.min(t,n.value.length);else if(t=(e=n.ownerDocument||document)&&e.defaultView||window,t.getSelection){t=t.getSelection();var r=n.textContent.length,o=Math.min(s.start,r);s=s.end===void 0?o:Math.min(s.end,r),!t.extend&&o>s&&(r=s,s=o,o=r),r=sb(n,o);var i=sb(n,s);r&&i&&(t.rangeCount!==1||t.anchorNode!==r.node||t.anchorOffset!==r.offset||t.focusNode!==i.node||t.focusOffset!==i.offset)&&(e=e.createRange(),e.setStart(r.node,r.offset),t.removeAllRanges(),o>s?(t.addRange(e),t.extend(i.node,i.offset)):(e.setEnd(i.node,i.offset),t.addRange(e)))}}for(e=[],t=n;t=t.parentNode;)t.nodeType===1&&e.push({element:t,left:t.scrollLeft,top:t.scrollTop});for(typeof n.focus=="function"&&n.focus(),n=0;n=document.documentMode,ya=null,u0=null,mc=null,h0=!1;function rb(t,e,n){var s=n.window===n?n.document:n.nodeType===9?n:n.ownerDocument;h0||ya==null||ya!==Od(s)||(s=ya,"selectionStart"in s&&ex(s)?s={start:s.selectionStart,end:s.selectionEnd}:(s=(s.ownerDocument&&s.ownerDocument.defaultView||window).getSelection(),s={anchorNode:s.anchorNode,anchorOffset:s.anchorOffset,focusNode:s.focusNode,focusOffset:s.focusOffset}),mc&&_c(mc,s)||(mc=s,s=Ud(u0,"onSelect"),0ba||(t.current=x0[ba],x0[ba]=null,ba--)}function rt(t,e){ba++,x0[ba]=t.current,t.current=e}var Ao={},kn=Lo(Ao),Hn=Lo(!1),ki=Ao;function Ua(t,e){var n=t.type.contextTypes;if(!n)return Ao;var s=t.stateNode;if(s&&s.__reactInternalMemoizedUnmaskedChildContext===e)return s.__reactInternalMemoizedMaskedChildContext;var r={},o;for(o in n)r[o]=e[o];return s&&(t=t.stateNode,t.__reactInternalMemoizedUnmaskedChildContext=e,t.__reactInternalMemoizedMaskedChildContext=r),r}function jn(t){return t=t.childContextTypes,t!=null}function Hd(){dt(Hn),dt(kn)}function hb(t,e,n){if(kn.current!==Ao)throw Error(ne(168));rt(kn,e),rt(Hn,n)}function p2(t,e,n){var s=t.stateNode;if(e=e.childContextTypes,typeof s.getChildContext!="function")return n;s=s.getChildContext();for(var r in s)if(!(r in e))throw Error(ne(108,I_(t)||"Unknown",r));return bt({},n,s)}function jd(t){return t=(t=t.stateNode)&&t.__reactInternalMemoizedMergedChildContext||Ao,ki=kn.current,rt(kn,t),rt(Hn,Hn.current),!0}function db(t,e,n){var s=t.stateNode;if(!s)throw Error(ne(169));n?(t=p2(t,e,ki),s.__reactInternalMemoizedMergedChildContext=t,dt(Hn),dt(kn),rt(kn,t)):dt(Hn),rt(Hn,n)}var Dr=null,Zf=!1,ag=!1;function m2(t){Dr===null?Dr=[t]:Dr.push(t)}function WF(t){Zf=!0,m2(t)}function Bo(){if(!ag&&Dr!==null){ag=!0;var t=0,e=Ye;try{var n=Dr;for(Ye=1;t>=i,r-=i,zr=1<<32-js(e)+r|n<S?($=k,k=null):$=k.sibling;var N=d(m,k,w[S],v);if(N===null){k===null&&(k=$);break}t&&k&&N.alternate===null&&e(m,k),y=o(N,y,S),C===null?b=N:C.sibling=N,C=N,k=$}if(S===w.length)return n(m,k),gt&&ni(m,S),b;if(k===null){for(;SS?($=k,k=null):$=k.sibling;var A=d(m,k,N.value,v);if(A===null){k===null&&(k=$);break}t&&k&&A.alternate===null&&e(m,k),y=o(A,y,S),C===null?b=A:C.sibling=A,C=A,k=$}if(N.done)return n(m,k),gt&&ni(m,S),b;if(k===null){for(;!N.done;S++,N=w.next())N=h(m,N.value,v),N!==null&&(y=o(N,y,S),C===null?b=N:C.sibling=N,C=N);return gt&&ni(m,S),b}for(k=s(m,k);!N.done;S++,N=w.next())N=f(k,m,S,N.value,v),N!==null&&(t&&N.alternate!==null&&k.delete(N.key===null?S:N.key),y=o(N,y,S),C===null?b=N:C.sibling=N,C=N);return t&&k.forEach(function(M){return e(m,M)}),gt&&ni(m,S),b}function x(m,y,w,v){if(typeof w=="object"&&w!==null&&w.type===ga&&w.key===null&&(w=w.props.children),typeof w=="object"&&w!==null){switch(w.$$typeof){case zh:e:{for(var b=w.key,C=y;C!==null;){if(C.key===b){if(b=w.type,b===ga){if(C.tag===7){n(m,C.sibling),y=r(C,w.props.children),y.return=m,m=y;break e}}else if(C.elementType===b||typeof b=="object"&&b!==null&&b.$$typeof===ro&&mb(b)===C.type){n(m,C.sibling),y=r(C,w.props),y.ref=Vl(m,C,w),y.return=m,m=y;break e}n(m,C);break}else e(m,C);C=C.sibling}w.type===ga?(y=gi(w.props.children,m.mode,v,w.key),y.return=m,m=y):(v=Sd(w.type,w.key,w.props,null,m.mode,v),v.ref=Vl(m,y,w),v.return=m,m=v)}return i(m);case ma:e:{for(C=w.key;y!==null;){if(y.key===C)if(y.tag===4&&y.stateNode.containerInfo===w.containerInfo&&y.stateNode.implementation===w.implementation){n(m,y.sibling),y=r(y,w.children||[]),y.return=m,m=y;break e}else{n(m,y);break}else e(m,y);y=y.sibling}y=mg(w,m.mode,v),y.return=m,m=y}return i(m);case ro:return C=w._init,x(m,y,C(w._payload),v)}if(Ql(w))return p(m,y,w,v);if(Ol(w))return g(m,y,w,v);jh(m,w)}return typeof w=="string"&&w!==""||typeof w=="number"?(w=""+w,y!==null&&y.tag===6?(n(m,y.sibling),y=r(y,w),y.return=m,m=y):(n(m,y),y=pg(w,m.mode,v),y.return=m,m=y),i(m)):n(m,y)}return x}var Ha=w2(!0),v2=w2(!1),qd=Lo(null),Yd=null,Sa=null,rx=null;function ox(){rx=Sa=Yd=null}function ix(t){var e=qd.current;dt(qd),t._currentValue=e}function v0(t,e,n){for(;t!==null;){var s=t.alternate;if((t.childLanes&e)!==e?(t.childLanes|=e,s!==null&&(s.childLanes|=e)):s!==null&&(s.childLanes&e)!==e&&(s.childLanes|=e),t===n)break;t=t.return}}function _a(t,e){Yd=t,rx=Sa=null,t=t.dependencies,t!==null&&t.firstContext!==null&&(t.lanes&e&&(Wn=!0),t.firstContext=null)}function $s(t){var e=t._currentValue;if(rx!==t)if(t={context:t,memoizedValue:e,next:null},Sa===null){if(Yd===null)throw Error(ne(308));Sa=t,Yd.dependencies={lanes:0,firstContext:t}}else Sa=Sa.next=t;return e}var ci=null;function ax(t){ci===null?ci=[t]:ci.push(t)}function b2(t,e,n,s){var r=e.interleaved;return r===null?(n.next=n,ax(e)):(n.next=r.next,r.next=n),e.interleaved=n,Vr(t,s)}function Vr(t,e){t.lanes|=e;var n=t.alternate;for(n!==null&&(n.lanes|=e),n=t,t=t.return;t!==null;)t.childLanes|=e,n=t.alternate,n!==null&&(n.childLanes|=e),n=t,t=t.return;return n.tag===3?n.stateNode:null}var oo=!1;function lx(t){t.updateQueue={baseState:t.memoizedState,firstBaseUpdate:null,lastBaseUpdate:null,shared:{pending:null,interleaved:null,lanes:0},effects:null}}function C2(t,e){t=t.updateQueue,e.updateQueue===t&&(e.updateQueue={baseState:t.baseState,firstBaseUpdate:t.firstBaseUpdate,lastBaseUpdate:t.lastBaseUpdate,shared:t.shared,effects:t.effects})}function Pr(t,e){return{eventTime:t,lane:e,tag:0,payload:null,callback:null,next:null}}function wo(t,e,n){var s=t.updateQueue;if(s===null)return null;if(s=s.shared,Le&2){var r=s.pending;return r===null?e.next=e:(e.next=r.next,r.next=e),s.pending=e,Vr(t,n)}return r=s.interleaved,r===null?(e.next=e,ax(s)):(e.next=r.next,r.next=e),s.interleaved=e,Vr(t,n)}function yd(t,e,n){if(e=e.updateQueue,e!==null&&(e=e.shared,(n&4194240)!==0)){var s=e.lanes;s&=t.pendingLanes,n|=s,e.lanes=n,K1(t,n)}}function gb(t,e){var n=t.updateQueue,s=t.alternate;if(s!==null&&(s=s.updateQueue,n===s)){var r=null,o=null;if(n=n.firstBaseUpdate,n!==null){do{var i={eventTime:n.eventTime,lane:n.lane,tag:n.tag,payload:n.payload,callback:n.callback,next:null};o===null?r=o=i:o=o.next=i,n=n.next}while(n!==null);o===null?r=o=e:o=o.next=e}else r=o=e;n={baseState:s.baseState,firstBaseUpdate:r,lastBaseUpdate:o,shared:s.shared,effects:s.effects},t.updateQueue=n;return}t=n.lastBaseUpdate,t===null?n.firstBaseUpdate=e:t.next=e,n.lastBaseUpdate=e}function Qd(t,e,n,s){var r=t.updateQueue;oo=!1;var o=r.firstBaseUpdate,i=r.lastBaseUpdate,a=r.shared.pending;if(a!==null){r.shared.pending=null;var l=a,c=l.next;l.next=null,i===null?o=c:i.next=c,i=l;var u=t.alternate;u!==null&&(u=u.updateQueue,a=u.lastBaseUpdate,a!==i&&(a===null?u.firstBaseUpdate=c:a.next=c,u.lastBaseUpdate=l))}if(o!==null){var h=r.baseState;i=0,u=c=l=null,a=o;do{var d=a.lane,f=a.eventTime;if((s&d)===d){u!==null&&(u=u.next={eventTime:f,lane:0,tag:a.tag,payload:a.payload,callback:a.callback,next:null});e:{var p=t,g=a;switch(d=e,f=n,g.tag){case 1:if(p=g.payload,typeof p=="function"){h=p.call(f,h,d);break e}h=p;break e;case 3:p.flags=p.flags&-65537|128;case 0:if(p=g.payload,d=typeof p=="function"?p.call(f,h,d):p,d==null)break e;h=bt({},h,d);break e;case 2:oo=!0}}a.callback!==null&&a.lane!==0&&(t.flags|=64,d=r.effects,d===null?r.effects=[a]:d.push(a))}else f={eventTime:f,lane:d,tag:a.tag,payload:a.payload,callback:a.callback,next:null},u===null?(c=u=f,l=h):u=u.next=f,i|=d;if(a=a.next,a===null){if(a=r.shared.pending,a===null)break;d=a,a=d.next,d.next=null,r.lastBaseUpdate=d,r.shared.pending=null}}while(!0);if(u===null&&(l=h),r.baseState=l,r.firstBaseUpdate=c,r.lastBaseUpdate=u,e=r.shared.interleaved,e!==null){r=e;do i|=r.lane,r=r.next;while(r!==e)}else o===null&&(r.shared.lanes=0);$i|=i,t.lanes=i,t.memoizedState=h}}function xb(t,e,n){if(t=e.effects,e.effects=null,t!==null)for(e=0;en?n:4,t(!0);var s=cg.transition;cg.transition={};try{t(!1),e()}finally{Ye=n,cg.transition=s}}function L2(){return Ns().memoizedState}function jF(t,e,n){var s=bo(t);if(n={lane:s,action:n,hasEagerState:!1,eagerState:null,next:null},B2(t))V2(e,n);else if(n=b2(t,e,n,s),n!==null){var r=An();Ks(n,t,s,r),W2(n,e,s)}}function KF(t,e,n){var s=bo(t),r={lane:s,action:n,hasEagerState:!1,eagerState:null,next:null};if(B2(t))V2(e,r);else{var o=t.alternate;if(t.lanes===0&&(o===null||o.lanes===0)&&(o=e.lastRenderedReducer,o!==null))try{var i=e.lastRenderedState,a=o(i,n);if(r.hasEagerState=!0,r.eagerState=a,Zs(a,i)){var l=e.interleaved;l===null?(r.next=r,ax(e)):(r.next=l.next,l.next=r),e.interleaved=r;return}}catch{}finally{}n=b2(t,e,r,s),n!==null&&(r=An(),Ks(n,t,s,r),W2(n,e,s))}}function B2(t){var e=t.alternate;return t===vt||e!==null&&e===vt}function V2(t,e){gc=Jd=!0;var n=t.pending;n===null?e.next=e:(e.next=n.next,n.next=e),t.pending=e}function W2(t,e,n){if(n&4194240){var s=e.lanes;s&=t.pendingLanes,n|=s,e.lanes=n,K1(t,n)}}var ef={readContext:$s,useCallback:mn,useContext:mn,useEffect:mn,useImperativeHandle:mn,useInsertionEffect:mn,useLayoutEffect:mn,useMemo:mn,useReducer:mn,useRef:mn,useState:mn,useDebugValue:mn,useDeferredValue:mn,useTransition:mn,useMutableSource:mn,useSyncExternalStore:mn,useId:mn,unstable_isNewReconciler:!1},XF={readContext:$s,useCallback:function(t,e){return or().memoizedState=[t,e===void 0?null:e],t},useContext:$s,useEffect:wb,useImperativeHandle:function(t,e,n){return n=n!=null?n.concat([t]):null,vd(4194308,4,F2.bind(null,e,t),n)},useLayoutEffect:function(t,e){return vd(4194308,4,t,e)},useInsertionEffect:function(t,e){return vd(4,2,t,e)},useMemo:function(t,e){var n=or();return e=e===void 0?null:e,t=t(),n.memoizedState=[t,e],t},useReducer:function(t,e,n){var s=or();return e=n!==void 0?n(e):e,s.memoizedState=s.baseState=e,t={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:t,lastRenderedState:e},s.queue=t,t=t.dispatch=jF.bind(null,vt,t),[s.memoizedState,t]},useRef:function(t){var e=or();return t={current:t},e.memoizedState=t},useState:yb,useDebugValue:gx,useDeferredValue:function(t){return or().memoizedState=t},useTransition:function(){var t=yb(!1),e=t[0];return t=HF.bind(null,t[1]),or().memoizedState=t,[e,t]},useMutableSource:function(){},useSyncExternalStore:function(t,e,n){var s=vt,r=or();if(gt){if(n===void 0)throw Error(ne(407));n=n()}else{if(n=e(),en===null)throw Error(ne(349));Ii&30||$2(s,e,n)}r.memoizedState=n;var o={value:n,getSnapshot:e};return r.queue=o,wb(T2.bind(null,s,o,t),[t]),s.flags|=2048,Vc(9,N2.bind(null,s,o,n,e),void 0,null),n},useId:function(){var t=or(),e=en.identifierPrefix;if(gt){var n=Or,s=zr;n=(s&~(1<<32-js(s)-1)).toString(32)+n,e=":"+e+"R"+n,n=Lc++,0<\/script>",t=t.removeChild(t.firstChild)):typeof s.is=="string"?t=i.createElement(n,{is:s.is}):(t=i.createElement(n),n==="select"&&(i=t,s.multiple?i.multiple=!0:s.size&&(i.size=s.size))):t=i.createElementNS(t,n),t[hr]=e,t[Oc]=s,QI(t,e,!1,!1),e.stateNode=t;e:{switch(i=n0(n,s),n){case"dialog":ct("cancel",t),ct("close",t),r=s;break;case"iframe":case"object":case"embed":ct("load",t),r=s;break;case"video":case"audio":for(r=0;rXa&&(e.flags|=128,s=!0,Wl(o,!1),e.lanes=4194304)}else{if(!s)if(t=Zh(i),t!==null){if(e.flags|=128,s=!0,n=t.updateQueue,n!==null&&(e.updateQueue=n,e.flags|=4),Wl(o,!0),o.tail===null&&o.tailMode==="hidden"&&!i.alternate&&!gt)return gn(e),null}else 2*Et()-o.renderingStartTime>Xa&&n!==1073741824&&(e.flags|=128,s=!0,Wl(o,!1),e.lanes=4194304);o.isBackwards?(i.sibling=e.child,e.child=i):(n=o.last,n!==null?n.sibling=i:e.child=i,o.last=i)}return o.tail!==null?(e=o.tail,o.rendering=e,o.tail=e.sibling,o.renderingStartTime=Et(),e.sibling=null,n=wt.current,rt(wt,s?n&1|2:n&1),e):(gn(e),null);case 22:case 23:return Cx(),s=e.memoizedState!==null,t!==null&&t.memoizedState!==null!==s&&(e.flags|=8192),s&&e.mode&1?Jn&1073741824&&(gn(e),e.subtreeFlags&6&&(e.flags|=8192)):gn(e),null;case 24:return null;case 25:return null}throw Error(te(156,e.tag))}function tz(t,e){switch(nx(e),e.tag){case 1:return jn(e.type)&&Hh(),t=e.flags,t&65536?(e.flags=t&-65537|128,e):null;case 3:return ja(),ht(Hn),ht(kn),dx(),t=e.flags,t&65536&&!(t&128)?(e.flags=t&-65537|128,e):null;case 5:return ux(e),null;case 13:if(ht(wt),t=e.memoizedState,t!==null&&t.dehydrated!==null){if(e.alternate===null)throw Error(te(340));Ga()}return t=e.flags,t&65536?(e.flags=t&-65537|128,e):null;case 19:return ht(wt),null;case 4:return ja(),null;case 10:return ix(e.type._context),null;case 22:case 23:return Cx(),null;case 24:return null;default:return null}}var Xd=!1,yn=!1,nz=typeof WeakSet=="function"?WeakSet:Set,de=null;function Ia(t,e){var n=t.ref;if(n!==null)if(typeof n=="function")try{n(null)}catch(s){Ct(t,e,s)}else n.current=null}function E0(t,e,n){try{n()}catch(s){Ct(t,e,s)}}var Rb=!1;function sz(t,e){if(h0=Vh,t=rI(),ex(t)){if("selectionStart"in t)var n={start:t.selectionStart,end:t.selectionEnd};else e:{n=(n=t.ownerDocument)&&n.defaultView||window;var s=n.getSelection&&n.getSelection();if(s&&s.rangeCount!==0){n=s.anchorNode;var r=s.anchorOffset,o=s.focusNode;s=s.focusOffset;try{n.nodeType,o.nodeType}catch{n=null;break e}var i=0,a=-1,l=-1,c=0,u=0,d=t,h=null;t:for(;;){for(var f;d!==n||r!==0&&d.nodeType!==3||(a=i+r),d!==o||s!==0&&d.nodeType!==3||(l=i+s),d.nodeType===3&&(i+=d.nodeValue.length),(f=d.firstChild)!==null;)h=d,d=f;for(;;){if(d===t)break t;if(h===n&&++c===r&&(a=i),h===o&&++u===s&&(l=i),(f=d.nextSibling)!==null)break;d=h,h=d.parentNode}d=f}n=a===-1||l===-1?null:{start:a,end:l}}else n=null}n=n||{start:0,end:0}}else n=null;for(f0={focusedElem:t,selectionRange:n},Vh=!1,de=e;de!==null;)if(e=de,t=e.child,(e.subtreeFlags&1028)!==0&&t!==null)t.return=e,de=t;else for(;de!==null;){e=de;try{var p=e.alternate;if(e.flags&1024)switch(e.tag){case 0:case 11:case 15:break;case 1:if(p!==null){var g=p.memoizedProps,x=p.memoizedState,m=e.stateNode,y=m.getSnapshotBeforeUpdate(e.elementType===e.type?g:Ps(e.type,g),x);m.__reactInternalSnapshotBeforeUpdate=y}break;case 3:var w=e.stateNode.containerInfo;w.nodeType===1?w.textContent="":w.nodeType===9&&w.documentElement&&w.removeChild(w.documentElement);break;case 5:case 6:case 4:case 17:break;default:throw Error(te(163))}}catch(v){Ct(e,e.return,v)}if(t=e.sibling,t!==null){t.return=e.return,de=t;break}de=e.return}return p=Rb,Rb=!1,p}function xc(t,e,n){var s=e.updateQueue;if(s=s!==null?s.lastEffect:null,s!==null){var r=s=s.next;do{if((r.tag&t)===t){var o=r.destroy;r.destroy=void 0,o!==void 0&&E0(e,n,o)}r=r.next}while(r!==s)}}function tp(t,e){if(e=e.updateQueue,e=e!==null?e.lastEffect:null,e!==null){var n=e=e.next;do{if((n.tag&t)===t){var s=n.create;n.destroy=s()}n=n.next}while(n!==e)}}function R0(t){var e=t.ref;if(e!==null){var n=t.stateNode;switch(t.tag){case 5:t=n;break;default:t=n}typeof e=="function"?e(t):e.current=t}}function e2(t){var e=t.alternate;e!==null&&(t.alternate=null,e2(e)),t.child=null,t.deletions=null,t.sibling=null,t.tag===5&&(e=t.stateNode,e!==null&&(delete e[hr],delete e[Oc],delete e[g0],delete e[LF],delete e[BF])),t.stateNode=null,t.return=null,t.dependencies=null,t.memoizedProps=null,t.memoizedState=null,t.pendingProps=null,t.stateNode=null,t.updateQueue=null}function t2(t){return t.tag===5||t.tag===3||t.tag===4}function Ab(t){e:for(;;){for(;t.sibling===null;){if(t.return===null||t2(t.return))return null;t=t.return}for(t.sibling.return=t.return,t=t.sibling;t.tag!==5&&t.tag!==6&&t.tag!==18;){if(t.flags&2||t.child===null||t.tag===4)continue e;t.child.return=t,t=t.child}if(!(t.flags&2))return t.stateNode}}function A0(t,e,n){var s=t.tag;if(s===5||s===6)t=t.stateNode,e?n.nodeType===8?n.parentNode.insertBefore(t,e):n.insertBefore(t,e):(n.nodeType===8?(e=n.parentNode,e.insertBefore(t,n)):(e=n,e.appendChild(t)),n=n._reactRootContainer,n!=null||e.onclick!==null||(e.onclick=Gh));else if(s!==4&&(t=t.child,t!==null))for(A0(t,e,n),t=t.sibling;t!==null;)A0(t,e,n),t=t.sibling}function D0(t,e,n){var s=t.tag;if(s===5||s===6)t=t.stateNode,e?n.insertBefore(t,e):n.appendChild(t);else if(s!==4&&(t=t.child,t!==null))for(D0(t,e,n),t=t.sibling;t!==null;)D0(t,e,n),t=t.sibling}var on=null,Ls=!1;function to(t,e,n){for(n=n.child;n!==null;)n2(t,e,n),n=n.sibling}function n2(t,e,n){if(pr&&typeof pr.onCommitFiberUnmount=="function")try{pr.onCommitFiberUnmount(Kf,n)}catch{}switch(n.tag){case 5:yn||Ia(n,e);case 6:var s=on,r=Ls;on=null,to(t,e,n),on=s,Ls=r,on!==null&&(Ls?(t=on,n=n.stateNode,t.nodeType===8?t.parentNode.removeChild(n):t.removeChild(n)):on.removeChild(n.stateNode));break;case 18:on!==null&&(Ls?(t=on,n=n.stateNode,t.nodeType===8?ig(t.parentNode,n):t.nodeType===1&&ig(t,n),Ac(t)):ig(on,n.stateNode));break;case 4:s=on,r=Ls,on=n.stateNode.containerInfo,Ls=!0,to(t,e,n),on=s,Ls=r;break;case 0:case 11:case 14:case 15:if(!yn&&(s=n.updateQueue,s!==null&&(s=s.lastEffect,s!==null))){r=s=s.next;do{var o=r,i=o.destroy;o=o.tag,i!==void 0&&(o&2||o&4)&&E0(n,e,i),r=r.next}while(r!==s)}to(t,e,n);break;case 1:if(!yn&&(Ia(n,e),s=n.stateNode,typeof s.componentWillUnmount=="function"))try{s.props=n.memoizedProps,s.state=n.memoizedState,s.componentWillUnmount()}catch(a){Ct(n,e,a)}to(t,e,n);break;case 21:to(t,e,n);break;case 22:n.mode&1?(yn=(s=yn)||n.memoizedState!==null,to(t,e,n),yn=s):to(t,e,n);break;default:to(t,e,n)}}function Db(t){var e=t.updateQueue;if(e!==null){t.updateQueue=null;var n=t.stateNode;n===null&&(n=t.stateNode=new nz),e.forEach(function(s){var r=hz.bind(null,t,s);n.has(s)||(n.add(s),s.then(r,r))})}}function zs(t,e){var n=e.deletions;if(n!==null)for(var s=0;sr&&(r=i),s&=~o}if(s=r,s=Et()-s,s=(120>s?120:480>s?480:1080>s?1080:1920>s?1920:3e3>s?3e3:4320>s?4320:1960*oz(s/1960))-s,10t?16:t,co===null)var s=!1;else{if(t=co,co=null,sf=0,Le&6)throw Error(te(331));var r=Le;for(Le|=4,de=t.current;de!==null;){var o=de,i=o.child;if(de.flags&16){var a=o.deletions;if(a!==null){for(var l=0;lEt()-vx?mi(t,0):wx|=n),Kn(t,e)}function u2(t,e){e===0&&(t.mode&1?(e=Ld,Ld<<=1,!(Ld&130023424)&&(Ld=4194304)):e=1);var n=An();t=Br(t,e),t!==null&&(au(t,e,n),Kn(t,n))}function dz(t){var e=t.memoizedState,n=0;e!==null&&(n=e.retryLane),u2(t,n)}function hz(t,e){var n=0;switch(t.tag){case 13:var s=t.stateNode,r=t.memoizedState;r!==null&&(n=r.retryLane);break;case 19:s=t.stateNode;break;default:throw Error(te(314))}s!==null&&s.delete(e),u2(t,n)}var d2;d2=function(t,e,n){if(t!==null)if(t.memoizedProps!==e.pendingProps||Hn.current)Wn=!0;else{if(!(t.lanes&n)&&!(e.flags&128))return Wn=!1,JF(t,e,n);Wn=!!(t.flags&131072)}else Wn=!1,gt&&e.flags&1048576&&mI(e,Xh,e.index);switch(e.lanes=0,e.tag){case 2:var s=e.type;bh(t,e),t=e.pendingProps;var r=Ua(e,kn.current);_a(e,n),r=fx(null,e,s,t,r,n);var o=px();return e.flags|=1,typeof r=="object"&&r!==null&&typeof r.render=="function"&&r.$$typeof===void 0?(e.tag=1,e.memoizedState=null,e.updateQueue=null,jn(s)?(o=!0,jh(e)):o=!1,e.memoizedState=r.state!==null&&r.state!==void 0?r.state:null,lx(e),r.updater=ep,e.stateNode=r,r._reactInternals=e,C0(e,s,t,n),e=I0(null,e,s,!0,o,n)):(e.tag=0,gt&&o&&tx(e),Nn(null,e,r,n),e=e.child),e;case 16:s=e.elementType;e:{switch(bh(t,e),t=e.pendingProps,r=s._init,s=r(s._payload),e.type=s,r=e.tag=pz(s),t=Ps(s,t),r){case 0:e=S0(null,e,s,t,n);break e;case 1:e=Nb(null,e,s,t,n);break e;case 11:e=Ib(null,e,s,t,n);break e;case 14:e=$b(null,e,s,Ps(s.type,t),n);break e}throw Error(te(306,s,""))}return e;case 0:return s=e.type,r=e.pendingProps,r=e.elementType===s?r:Ps(s,r),S0(t,e,s,r,n);case 1:return s=e.type,r=e.pendingProps,r=e.elementType===s?r:Ps(s,r),Nb(t,e,s,r,n);case 3:e:{if(XI(e),t===null)throw Error(te(387));s=e.pendingProps,o=e.memoizedState,r=o.element,bI(t,e),Qh(e,s,null,n);var i=e.memoizedState;if(s=i.element,o.isDehydrated)if(o={element:s,isDehydrated:!1,cache:i.cache,pendingSuspenseBoundaries:i.pendingSuspenseBoundaries,transitions:i.transitions},e.updateQueue.baseState=o,e.memoizedState=o,e.flags&256){r=Ka(Error(te(423)),e),e=Tb(t,e,s,n,r);break e}else if(s!==r){r=Ka(Error(te(424)),e),e=Tb(t,e,s,n,r);break e}else for(ts=yo(e.stateNode.containerInfo.firstChild),ss=e,gt=!0,Bs=null,n=wI(e,null,s,n),e.child=n;n;)n.flags=n.flags&-3|4096,n=n.sibling;else{if(Ga(),s===r){e=Vr(t,e,n);break e}Nn(t,e,s,n)}e=e.child}return e;case 5:return CI(e),t===null&&w0(e),s=e.type,r=e.pendingProps,o=t!==null?t.memoizedProps:null,i=r.children,p0(s,r)?i=null:o!==null&&p0(s,o)&&(e.flags|=32),KI(t,e),Nn(t,e,i,n),e.child;case 6:return t===null&&w0(e),null;case 13:return qI(t,e,n);case 4:return cx(e,e.stateNode.containerInfo),s=e.pendingProps,t===null?e.child=Ha(e,null,s,n):Nn(t,e,s,n),e.child;case 11:return s=e.type,r=e.pendingProps,r=e.elementType===s?r:Ps(s,r),Ib(t,e,s,r,n);case 7:return Nn(t,e,e.pendingProps,n),e.child;case 8:return Nn(t,e,e.pendingProps.children,n),e.child;case 12:return Nn(t,e,e.pendingProps.children,n),e.child;case 10:e:{if(s=e.type._context,r=e.pendingProps,o=e.memoizedProps,i=r.value,rt(qh,s._currentValue),s._currentValue=i,o!==null)if(Qs(o.value,i)){if(o.children===r.children&&!Hn.current){e=Vr(t,e,n);break e}}else for(o=e.child,o!==null&&(o.return=e);o!==null;){var a=o.dependencies;if(a!==null){i=o.child;for(var l=a.firstContext;l!==null;){if(l.context===s){if(o.tag===1){l=Mr(-1,n&-n),l.tag=2;var c=o.updateQueue;if(c!==null){c=c.shared;var u=c.pending;u===null?l.next=l:(l.next=u.next,u.next=l),c.pending=l}}o.lanes|=n,l=o.alternate,l!==null&&(l.lanes|=n),v0(o.return,n,e),a.lanes|=n;break}l=l.next}}else if(o.tag===10)i=o.type===e.type?null:o.child;else if(o.tag===18){if(i=o.return,i===null)throw Error(te(341));i.lanes|=n,a=i.alternate,a!==null&&(a.lanes|=n),v0(i,n,e),i=o.sibling}else i=o.child;if(i!==null)i.return=o;else for(i=o;i!==null;){if(i===e){i=null;break}if(o=i.sibling,o!==null){o.return=i.return,i=o;break}i=i.return}o=i}Nn(t,e,r.children,n),e=e.child}return e;case 9:return r=e.type,s=e.pendingProps.children,_a(e,n),r=Is(r),s=s(r),e.flags|=1,Nn(t,e,s,n),e.child;case 14:return s=e.type,r=Ps(s,e.pendingProps),r=Ps(s.type,r),$b(t,e,s,r,n);case 15:return HI(t,e,e.type,e.pendingProps,n);case 17:return s=e.type,r=e.pendingProps,r=e.elementType===s?r:Ps(s,r),bh(t,e),e.tag=1,jn(s)?(t=!0,jh(e)):t=!1,_a(e,n),WI(e,s,r),C0(e,s,r,n),I0(null,e,s,!0,t,n);case 19:return YI(t,e,n);case 22:return jI(t,e,n)}throw Error(te(156,e.tag))};function h2(t,e){return LS(t,e)}function fz(t,e,n,s){this.tag=t,this.key=n,this.sibling=this.child=this.return=this.stateNode=this.type=this.elementType=null,this.index=0,this.ref=null,this.pendingProps=e,this.dependencies=this.memoizedState=this.updateQueue=this.memoizedProps=null,this.mode=s,this.subtreeFlags=this.flags=0,this.deletions=null,this.childLanes=this.lanes=0,this.alternate=null}function ys(t,e,n,s){return new fz(t,e,n,s)}function Sx(t){return t=t.prototype,!(!t||!t.isReactComponent)}function pz(t){if(typeof t=="function")return Sx(t)?1:0;if(t!=null){if(t=t.$$typeof,t===U1)return 11;if(t===G1)return 14}return 2}function Co(t,e){var n=t.alternate;return n===null?(n=ys(t.tag,e,t.key,t.mode),n.elementType=t.elementType,n.type=t.type,n.stateNode=t.stateNode,n.alternate=t,t.alternate=n):(n.pendingProps=e,n.type=t.type,n.flags=0,n.subtreeFlags=0,n.deletions=null),n.flags=t.flags&14680064,n.childLanes=t.childLanes,n.lanes=t.lanes,n.child=t.child,n.memoizedProps=t.memoizedProps,n.memoizedState=t.memoizedState,n.updateQueue=t.updateQueue,e=t.dependencies,n.dependencies=e===null?null:{lanes:e.lanes,firstContext:e.firstContext},n.sibling=t.sibling,n.index=t.index,n.ref=t.ref,n}function Sh(t,e,n,s,r,o){var i=2;if(s=t,typeof t=="function")Sx(t)&&(i=1);else if(typeof t=="string")i=5;else e:switch(t){case ga:return gi(n.children,r,o,e);case W1:i=8,r|=8;break;case jg:return t=ys(12,n,e,r|2),t.elementType=jg,t.lanes=o,t;case Kg:return t=ys(13,n,e,r),t.elementType=Kg,t.lanes=o,t;case Xg:return t=ys(19,n,e,r),t.elementType=Xg,t.lanes=o,t;case CS:return sp(n,r,o,e);default:if(typeof t=="object"&&t!==null)switch(t.$$typeof){case vS:i=10;break e;case bS:i=9;break e;case U1:i=11;break e;case G1:i=14;break e;case so:i=16,s=null;break e}throw Error(te(130,t==null?t:typeof t,""))}return e=ys(i,n,e,r),e.elementType=t,e.type=s,e.lanes=o,e}function gi(t,e,n,s){return t=ys(7,t,s,e),t.lanes=n,t}function sp(t,e,n,s){return t=ys(22,t,s,e),t.elementType=CS,t.lanes=n,t.stateNode={isHidden:!1},t}function pg(t,e,n){return t=ys(6,t,null,e),t.lanes=n,t}function mg(t,e,n){return e=ys(4,t.children!==null?t.children:[],t.key,e),e.lanes=n,e.stateNode={containerInfo:t.containerInfo,pendingChildren:null,implementation:t.implementation},e}function mz(t,e,n,s,r){this.tag=e,this.containerInfo=t,this.finishedWork=this.pingCache=this.current=this.pendingChildren=null,this.timeoutHandle=-1,this.callbackNode=this.pendingContext=this.context=null,this.callbackPriority=0,this.eventTimes=qm(0),this.expirationTimes=qm(-1),this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0,this.entanglements=qm(0),this.identifierPrefix=s,this.onRecoverableError=r,this.mutableSourceEagerHydrationData=null}function Ix(t,e,n,s,r,o,i,a,l){return t=new mz(t,e,n,a,l),e===1?(e=1,o===!0&&(e|=8)):e=0,o=ys(3,null,null,e),t.current=o,o.stateNode=t,o.memoizedState={element:s,isDehydrated:n,cache:null,transitions:null,pendingSuspenseBoundaries:null},lx(o),t}function gz(t,e,n){var s=3"u"||typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE!="function"))try{__REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(g2)}catch(t){console.error(t)}}g2(),gS.exports=ls;var bz=gS.exports,Bb=bz;Gg.createRoot=Bb.createRoot,Gg.hydrateRoot=Bb.hydrateRoot;var bn=function(){return bn=Object.assign||function(e){for(var n,s=1,r=arguments.length;s0?Zt(yl,--Ns):0,Ya--,Ft===10&&(Ya=1,cp--),Ft}function Ks(){return Ft=Ns2||P0(Ft)>3?"":" "}function Az(t,e){for(;--e&&Ks()&&!(Ft<48||Ft>102||Ft>57&&Ft<65||Ft>70&&Ft<97););return dp(t,$h()+(e<6&&xi()==32&&Ks()==32))}function L0(t){for(;Ks();)switch(Ft){case t:return Ns;case 34:case 39:t!==34&&t!==39&&L0(Ft);break;case 40:t===41&&L0(t);break;case 92:Ks();break}return Ns}function Dz(t,e){for(;Ks()&&t+Ft!==57;)if(t+Ft===84&&xi()===47)break;return"/*"+dp(e,Ns-1)+"*"+Rx(t===47?t:Ks())}function _z(t){for(;!P0(xi());)Ks();return dp(t,Ns)}function Fz(t){return Ez(Nh("",null,null,null,[""],t=Tz(t),0,[0],t))}function Nh(t,e,n,s,r,o,i,a,l){for(var c=0,u=0,d=i,h=0,f=0,p=0,g=1,x=1,m=1,y=0,w="",v=r,b=o,C=s,k=w;x;)switch(p=y,y=Ks()){case 40:if(p!=108&&Zt(k,d-1)==58){Ih(k+=Te(gg(y),"&","&\f"),"&\f",w2(c?a[c-1]:0))!=-1&&(m=-1);break}case 34:case 39:case 91:k+=gg(y);break;case 9:case 10:case 13:case 32:k+=Rz(p);break;case 92:k+=Az($h()-1,7);continue;case 47:switch(xi()){case 42:case 47:ec(zz(Dz(Ks(),$h()),e,n,l),l);break;default:k+="/"}break;case 123*g:a[c++]=lr(k)*m;case 125*g:case 59:case 0:switch(y){case 0:case 125:x=0;case 59+u:m==-1&&(k=Te(k,/\f/g,"")),f>0&&lr(k)-d&&ec(f>32?Ub(k+";",s,n,d-1,l):Ub(Te(k," ","")+";",s,n,d-2,l),l);break;case 59:k+=";";default:if(ec(C=Wb(k,e,n,c,u,r,a,w,v=[],b=[],d,o),o),y===123)if(u===0)Nh(k,e,C,C,v,o,d,a,b);else switch(h===99&&Zt(k,3)===110?100:h){case 100:case 108:case 109:case 115:Nh(t,C,C,s&&ec(Wb(t,C,C,0,0,r,a,w,r,v=[],d,b),b),r,b,d,a,s?v:b);break;default:Nh(k,C,C,C,[""],b,0,a,b)}}c=u=f=0,g=m=1,w=k="",d=i;break;case 58:d=1+lr(k),f=p;default:if(g<1){if(y==123)--g;else if(y==125&&g++==0&&Nz()==125)continue}switch(k+=Rx(y),y*g){case 38:m=u>0?1:(k+="\f",-1);break;case 44:a[c++]=(lr(k)-1)*m,m=1;break;case 64:xi()===45&&(k+=gg(Ks())),h=xi(),u=d=lr(w=k+=_z($h())),y++;break;case 45:p===45&&lr(k)==2&&(g=0)}}return o}function Wb(t,e,n,s,r,o,i,a,l,c,u,d){for(var h=r-1,f=r===0?o:[""],p=b2(f),g=0,x=0,m=0;g0?f[y]+" "+w:Te(w,/&\f/g,f[y])))&&(l[m++]=v);return up(t,e,n,r===0?lp:a,l,c,u,d)}function zz(t,e,n,s){return up(t,e,n,x2,Rx($z()),qa(t,2,-2),0,s)}function Ub(t,e,n,s,r){return up(t,e,n,Ex,qa(t,0,s),qa(t,s+1,-1),s,r)}function k2(t,e,n){switch(Sz(t,e)){case 5103:return je+"print-"+t+t;case 5737:case 4201:case 3177:case 3433:case 1641:case 4457:case 2921:case 5572:case 6356:case 5844:case 3191:case 6645:case 3005:case 6391:case 5879:case 5623:case 6135:case 4599:case 4855:case 4215:case 6389:case 5109:case 5365:case 5621:case 3829:return je+t+t;case 4789:return vc+t+t;case 5349:case 4246:case 4810:case 6968:case 2756:return je+t+vc+t+ut+t+t;case 5936:switch(Zt(t,e+11)){case 114:return je+t+ut+Te(t,/[svh]\w+-[tblr]{2}/,"tb")+t;case 108:return je+t+ut+Te(t,/[svh]\w+-[tblr]{2}/,"tb-rl")+t;case 45:return je+t+ut+Te(t,/[svh]\w+-[tblr]{2}/,"lr")+t}case 6828:case 4268:case 2903:return je+t+ut+t+t;case 6165:return je+t+ut+"flex-"+t+t;case 5187:return je+t+Te(t,/(\w+).+(:[^]+)/,je+"box-$1$2"+ut+"flex-$1$2")+t;case 5443:return je+t+ut+"flex-item-"+Te(t,/flex-|-self/g,"")+(Rr(t,/flex-|baseline/)?"":ut+"grid-row-"+Te(t,/flex-|-self/g,""))+t;case 4675:return je+t+ut+"flex-line-pack"+Te(t,/align-content|flex-|-self/g,"")+t;case 5548:return je+t+ut+Te(t,"shrink","negative")+t;case 5292:return je+t+ut+Te(t,"basis","preferred-size")+t;case 6060:return je+"box-"+Te(t,"-grow","")+je+t+ut+Te(t,"grow","positive")+t;case 4554:return je+Te(t,/([^-])(transform)/g,"$1"+je+"$2")+t;case 6187:return Te(Te(Te(t,/(zoom-|grab)/,je+"$1"),/(image-set)/,je+"$1"),t,"")+t;case 5495:case 3959:return Te(t,/(image-set\([^]*)/,je+"$1$`$1");case 4968:return Te(Te(t,/(.+:)(flex-)?(.*)/,je+"box-pack:$3"+ut+"flex-pack:$3"),/s.+-b[^;]+/,"justify")+je+t+t;case 4200:if(!Rr(t,/flex-|baseline/))return ut+"grid-column-align"+qa(t,e)+t;break;case 2592:case 3360:return ut+Te(t,"template-","")+t;case 4384:case 3616:return n&&n.some(function(s,r){return e=r,Rr(s.props,/grid-\w+-end/)})?~Ih(t+(n=n[e].value),"span",0)?t:ut+Te(t,"-start","")+t+ut+"grid-row-span:"+(~Ih(n,"span",0)?Rr(n,/\d+/):+Rr(n,/\d+/)-+Rr(t,/\d+/))+";":ut+Te(t,"-start","")+t;case 4896:case 4128:return n&&n.some(function(s){return Rr(s.props,/grid-\w+-start/)})?t:ut+Te(Te(t,"-end","-span"),"span ","")+t;case 4095:case 3583:case 4068:case 2532:return Te(t,/(.+)-inline(.+)/,je+"$1$2")+t;case 8116:case 7059:case 5753:case 5535:case 5445:case 5701:case 4933:case 4677:case 5533:case 5789:case 5021:case 4765:if(lr(t)-1-e>6)switch(Zt(t,e+1)){case 109:if(Zt(t,e+4)!==45)break;case 102:return Te(t,/(.+:)(.+)-([^]+)/,"$1"+je+"$2-$3$1"+vc+(Zt(t,e+3)==108?"$3":"$2-$3"))+t;case 115:return~Ih(t,"stretch",0)?k2(Te(t,"stretch","fill-available"),e,n)+t:t}break;case 5152:case 5920:return Te(t,/(.+?):(\d+)(\s*\/\s*(span)?\s*(\d+))?(.*)/,function(s,r,o,i,a,l,c){return ut+r+":"+o+c+(i?ut+r+"-span:"+(a?l:+l-+o)+c:"")+t});case 4949:if(Zt(t,e+6)===121)return Te(t,":",":"+je)+t;break;case 6444:switch(Zt(t,Zt(t,14)===45?18:11)){case 120:return Te(t,/(.+:)([^;\s!]+)(;|(\s+)?!.+)?/,"$1"+je+(Zt(t,14)===45?"inline-":"")+"box$3$1"+je+"$2$3$1"+ut+"$2box$3")+t;case 100:return Te(t,":",":"+ut)+t}break;case 5719:case 2647:case 2135:case 3927:case 2391:return Te(t,"scroll-","scroll-snap-")+t}return t}function af(t,e){for(var n="",s=0;s-1&&!t.return)switch(t.type){case Ex:t.return=k2(t.value,t.length,n);return;case y2:return af([no(t,{value:Te(t.value,"@","@"+je)})],s);case lp:if(t.length)return Iz(n=t.props,function(r){switch(Rr(r,s=/(::plac\w+|:read-\w+)/)){case":read-only":case":read-write":oa(no(t,{props:[Te(r,/:(read-\w+)/,":"+vc+"$1")]})),oa(no(t,{props:[r]})),M0(t,{props:Vb(n,s)});break;case"::placeholder":oa(no(t,{props:[Te(r,/:(plac\w+)/,":"+je+"input-$1")]})),oa(no(t,{props:[Te(r,/:(plac\w+)/,":"+vc+"$1")]})),oa(no(t,{props:[Te(r,/:(plac\w+)/,ut+"input-$1")]})),oa(no(t,{props:[r]})),M0(t,{props:Vb(n,s)});break}return""})}}var Bz={animationIterationCount:1,aspectRatio:1,borderImageOutset:1,borderImageSlice:1,borderImageWidth:1,boxFlex:1,boxFlexGroup:1,boxOrdinalGroup:1,columnCount:1,columns:1,flex:1,flexGrow:1,flexPositive:1,flexShrink:1,flexNegative:1,flexOrder:1,gridRow:1,gridRowEnd:1,gridRowSpan:1,gridRowStart:1,gridColumn:1,gridColumnEnd:1,gridColumnSpan:1,gridColumnStart:1,msGridRow:1,msGridRowSpan:1,msGridColumn:1,msGridColumnSpan:1,fontWeight:1,lineHeight:1,opacity:1,order:1,orphans:1,tabSize:1,widows:1,zIndex:1,zoom:1,WebkitLineClamp:1,fillOpacity:1,floodOpacity:1,stopOpacity:1,strokeDasharray:1,strokeDashoffset:1,strokeMiterlimit:1,strokeOpacity:1,strokeWidth:1},Zn={},Qa=typeof process<"u"&&Zn!==void 0&&(Zn.REACT_APP_SC_ATTR||Zn.SC_ATTR)||"data-styled",S2="active",I2="data-styled-version",hp="6.1.13",Ax=`/*!sc*/ -`,lf=typeof window<"u"&&"HTMLElement"in window,Vz=!!(typeof SC_DISABLE_SPEEDY=="boolean"?SC_DISABLE_SPEEDY:typeof process<"u"&&Zn!==void 0&&Zn.REACT_APP_SC_DISABLE_SPEEDY!==void 0&&Zn.REACT_APP_SC_DISABLE_SPEEDY!==""?Zn.REACT_APP_SC_DISABLE_SPEEDY!=="false"&&Zn.REACT_APP_SC_DISABLE_SPEEDY:typeof process<"u"&&Zn!==void 0&&Zn.SC_DISABLE_SPEEDY!==void 0&&Zn.SC_DISABLE_SPEEDY!==""&&Zn.SC_DISABLE_SPEEDY!=="false"&&Zn.SC_DISABLE_SPEEDY),Wz={},fp=Object.freeze([]),Za=Object.freeze({});function $2(t,e,n){return n===void 0&&(n=Za),t.theme!==n.theme&&t.theme||e||n.theme}var N2=new Set(["a","abbr","address","area","article","aside","audio","b","base","bdi","bdo","big","blockquote","body","br","button","canvas","caption","cite","code","col","colgroup","data","datalist","dd","del","details","dfn","dialog","div","dl","dt","em","embed","fieldset","figcaption","figure","footer","form","h1","h2","h3","h4","h5","h6","header","hgroup","hr","html","i","iframe","img","input","ins","kbd","keygen","label","legend","li","link","main","map","mark","menu","menuitem","meta","meter","nav","noscript","object","ol","optgroup","option","output","p","param","picture","pre","progress","q","rp","rt","ruby","s","samp","script","section","select","small","source","span","strong","style","sub","summary","sup","table","tbody","td","textarea","tfoot","th","thead","time","tr","track","u","ul","use","var","video","wbr","circle","clipPath","defs","ellipse","foreignObject","g","image","line","linearGradient","marker","mask","path","pattern","polygon","polyline","radialGradient","rect","stop","svg","text","tspan"]),Uz=/[!"#$%&'()*+,./:;<=>?@[\\\]^`{|}~-]+/g,Gz=/(^-|-$)/g;function Gb(t){return t.replace(Uz,"-").replace(Gz,"")}var Hz=/(a)(d)/gi,Qd=52,Hb=function(t){return String.fromCharCode(t+(t>25?39:97))};function B0(t){var e,n="";for(e=Math.abs(t);e>Qd;e=e/Qd|0)n=Hb(e%Qd)+n;return(Hb(e%Qd)+n).replace(Hz,"$1-$2")}var xg,T2=5381,Na=function(t,e){for(var n=e.length;n;)t=33*t^e.charCodeAt(--n);return t},E2=function(t){return Na(T2,t)};function R2(t){return B0(E2(t)>>>0)}function jz(t){return t.displayName||t.name||"Component"}function yg(t){return typeof t=="string"&&!0}var A2=typeof Symbol=="function"&&Symbol.for,D2=A2?Symbol.for("react.memo"):60115,Kz=A2?Symbol.for("react.forward_ref"):60112,Xz={childContextTypes:!0,contextType:!0,contextTypes:!0,defaultProps:!0,displayName:!0,getDefaultProps:!0,getDerivedStateFromError:!0,getDerivedStateFromProps:!0,mixins:!0,propTypes:!0,type:!0},qz={name:!0,length:!0,prototype:!0,caller:!0,callee:!0,arguments:!0,arity:!0},_2={$$typeof:!0,compare:!0,defaultProps:!0,displayName:!0,propTypes:!0,type:!0},Yz=((xg={})[Kz]={$$typeof:!0,render:!0,defaultProps:!0,displayName:!0,propTypes:!0},xg[D2]=_2,xg);function jb(t){return("type"in(e=t)&&e.type.$$typeof)===D2?_2:"$$typeof"in t?Yz[t.$$typeof]:Xz;var e}var Qz=Object.defineProperty,Zz=Object.getOwnPropertyNames,Kb=Object.getOwnPropertySymbols,Jz=Object.getOwnPropertyDescriptor,eO=Object.getPrototypeOf,Xb=Object.prototype;function F2(t,e,n){if(typeof e!="string"){if(Xb){var s=eO(e);s&&s!==Xb&&F2(t,s,n)}var r=Zz(e);Kb&&(r=r.concat(Kb(e)));for(var o=jb(t),i=jb(e),a=0;a0?" Args: ".concat(e.join(", ")):""))}var tO=function(){function t(e){this.groupSizes=new Uint32Array(512),this.length=512,this.tag=e}return t.prototype.indexOfGroup=function(e){for(var n=0,s=0;s=this.groupSizes.length){for(var s=this.groupSizes,r=s.length,o=r;e>=o;)if((o<<=1)<0)throw du(16,"".concat(e));this.groupSizes=new Uint32Array(o),this.groupSizes.set(s),this.length=o;for(var i=r;i=this.length||this.groupSizes[e]===0)return n;for(var s=this.groupSizes[e],r=this.indexOfGroup(e),o=r+s,i=r;i=0){var s=document.createTextNode(n);return this.element.insertBefore(s,this.nodes[e]||null),this.length++,!0}return!1},t.prototype.deleteRule=function(e){this.element.removeChild(this.nodes[e]),this.length--},t.prototype.getRule=function(e){return e0&&(x+="".concat(m,","))}),l+="".concat(p).concat(g,'{content:"').concat(x,'"}').concat(Ax)},u=0;u0?".".concat(e):h},u=l.slice();u.push(function(h){h.type===lp&&h.value.includes("&")&&(h.props[0]=h.props[0].replace(hO,n).replace(s,c))}),i.prefix&&u.push(Lz),u.push(Oz);var d=function(h,f,p,g){f===void 0&&(f=""),p===void 0&&(p=""),g===void 0&&(g="&"),e=g,n=f,s=new RegExp("\\".concat(n,"\\b"),"g");var x=h.replace(fO,""),m=Fz(p||f?"".concat(p," ").concat(f," { ").concat(x," }"):x);i.namespace&&(m=O2(m,i.namespace));var y=[];return af(m,Mz(u.concat(Pz(function(w){return y.push(w)})))),y};return d.hash=l.length?l.reduce(function(h,f){return f.name||du(15),Na(h,f.name)},T2).toString():"",d}var mO=new uf,U0=pO(),M2=Us.createContext({shouldForwardProp:void 0,styleSheet:mO,stylis:U0});M2.Consumer;Us.createContext(void 0);function G0(){return ye.useContext(M2)}var gO=function(){function t(e,n){var s=this;this.inject=function(r,o){o===void 0&&(o=U0);var i=s.name+o.hash;r.hasNameForId(s.id,i)||r.insertRules(s.id,i,o(s.rules,i,"@keyframes"))},this.name=e,this.id="sc-keyframes-".concat(e),this.rules=n,_x(this,function(){throw du(12,String(s.name))})}return t.prototype.getName=function(e){return e===void 0&&(e=U0),this.name+e.hash},t}(),xO=function(t){return t>="A"&&t<="Z"};function Qb(t){for(var e="",n=0;n>>0);if(!n.hasNameForId(this.componentId,i)){var a=s(o,".".concat(i),void 0,this.componentId);n.insertRules(this.componentId,i,a)}r=di(r,i),this.staticRulesId=i}else{for(var l=Na(this.baseHash,s.hash),c="",u=0;u>>0);n.hasNameForId(this.componentId,f)||n.insertRules(this.componentId,f,s(c,".".concat(f),void 0,this.componentId)),r=di(r,f)}}return r},t}(),Fx=Us.createContext(void 0);Fx.Consumer;var wg={};function vO(t,e,n){var s=Dx(t),r=t,o=!yg(t),i=e.attrs,a=i===void 0?fp:i,l=e.componentId,c=l===void 0?function(v,b){var C=typeof v!="string"?"sc":Gb(v);wg[C]=(wg[C]||0)+1;var k="".concat(C,"-").concat(R2(hp+C+wg[C]));return b?"".concat(b,"-").concat(k):k}(e.displayName,e.parentComponentId):l,u=e.displayName,d=u===void 0?function(v){return yg(v)?"styled.".concat(v):"Styled(".concat(jz(v),")")}(t):u,h=e.displayName&&e.componentId?"".concat(Gb(e.displayName),"-").concat(e.componentId):e.componentId||c,f=s&&r.attrs?r.attrs.concat(a).filter(Boolean):a,p=e.shouldForwardProp;if(s&&r.shouldForwardProp){var g=r.shouldForwardProp;if(e.shouldForwardProp){var x=e.shouldForwardProp;p=function(v,b){return g(v,b)&&x(v,b)}}else p=g}var m=new wO(n,h,s?r.componentStyle:void 0);function y(v,b){return function(C,k,S){var $=C.attrs,N=C.componentStyle,A=C.defaultProps,M=C.foldedComponentIds,L=C.styledComponentId,V=C.target,B=Us.useContext(Fx),U=G0(),K=C.shouldForwardProp||U.shouldForwardProp,R=$2(k,B,A)||Za,O=function(Z,se,ie){for(var ce,ue=bn(bn({},se),{className:void 0,theme:ie}),xe=0;xe2&&uf.registerId(this.componentId+e),this.removeStyles(e,s),this.createStyles(e,n,s,r)},t}();function U2(t){for(var e=[],n=1;n<\/script>",t=t.removeChild(t.firstChild)):typeof s.is=="string"?t=i.createElement(n,{is:s.is}):(t=i.createElement(n),n==="select"&&(i=t,s.multiple?i.multiple=!0:s.size&&(i.size=s.size))):t=i.createElementNS(t,n),t[fr]=e,t[Oc]=s,Z2(t,e,!1,!1),e.stateNode=t;e:{switch(i=n0(n,s),n){case"dialog":ct("cancel",t),ct("close",t),r=s;break;case"iframe":case"object":case"embed":ct("load",t),r=s;break;case"video":case"audio":for(r=0;rXa&&(e.flags|=128,s=!0,Wl(o,!1),e.lanes=4194304)}else{if(!s)if(t=Zd(i),t!==null){if(e.flags|=128,s=!0,n=t.updateQueue,n!==null&&(e.updateQueue=n,e.flags|=4),Wl(o,!0),o.tail===null&&o.tailMode==="hidden"&&!i.alternate&&!gt)return gn(e),null}else 2*Et()-o.renderingStartTime>Xa&&n!==1073741824&&(e.flags|=128,s=!0,Wl(o,!1),e.lanes=4194304);o.isBackwards?(i.sibling=e.child,e.child=i):(n=o.last,n!==null?n.sibling=i:e.child=i,o.last=i)}return o.tail!==null?(e=o.tail,o.rendering=e,o.tail=e.sibling,o.renderingStartTime=Et(),e.sibling=null,n=wt.current,rt(wt,s?n&1|2:n&1),e):(gn(e),null);case 22:case 23:return Cx(),s=e.memoizedState!==null,t!==null&&t.memoizedState!==null!==s&&(e.flags|=8192),s&&e.mode&1?Jn&1073741824&&(gn(e),e.subtreeFlags&6&&(e.flags|=8192)):gn(e),null;case 24:return null;case 25:return null}throw Error(ne(156,e.tag))}function nz(t,e){switch(nx(e),e.tag){case 1:return jn(e.type)&&Hd(),t=e.flags,t&65536?(e.flags=t&-65537|128,e):null;case 3:return ja(),dt(Hn),dt(kn),hx(),t=e.flags,t&65536&&!(t&128)?(e.flags=t&-65537|128,e):null;case 5:return ux(e),null;case 13:if(dt(wt),t=e.memoizedState,t!==null&&t.dehydrated!==null){if(e.alternate===null)throw Error(ne(340));Ga()}return t=e.flags,t&65536?(e.flags=t&-65537|128,e):null;case 19:return dt(wt),null;case 4:return ja(),null;case 10:return ix(e.type._context),null;case 22:case 23:return Cx(),null;case 24:return null;default:return null}}var Xh=!1,yn=!1,sz=typeof WeakSet=="function"?WeakSet:Set,he=null;function Ia(t,e){var n=t.ref;if(n!==null)if(typeof n=="function")try{n(null)}catch(s){Ct(t,e,s)}else n.current=null}function E0(t,e,n){try{n()}catch(s){Ct(t,e,s)}}var Rb=!1;function rz(t,e){if(d0=Vd,t=o2(),ex(t)){if("selectionStart"in t)var n={start:t.selectionStart,end:t.selectionEnd};else e:{n=(n=t.ownerDocument)&&n.defaultView||window;var s=n.getSelection&&n.getSelection();if(s&&s.rangeCount!==0){n=s.anchorNode;var r=s.anchorOffset,o=s.focusNode;s=s.focusOffset;try{n.nodeType,o.nodeType}catch{n=null;break e}var i=0,a=-1,l=-1,c=0,u=0,h=t,d=null;t:for(;;){for(var f;h!==n||r!==0&&h.nodeType!==3||(a=i+r),h!==o||s!==0&&h.nodeType!==3||(l=i+s),h.nodeType===3&&(i+=h.nodeValue.length),(f=h.firstChild)!==null;)d=h,h=f;for(;;){if(h===t)break t;if(d===n&&++c===r&&(a=i),d===o&&++u===s&&(l=i),(f=h.nextSibling)!==null)break;h=d,d=h.parentNode}h=f}n=a===-1||l===-1?null:{start:a,end:l}}else n=null}n=n||{start:0,end:0}}else n=null;for(f0={focusedElem:t,selectionRange:n},Vd=!1,he=e;he!==null;)if(e=he,t=e.child,(e.subtreeFlags&1028)!==0&&t!==null)t.return=e,he=t;else for(;he!==null;){e=he;try{var p=e.alternate;if(e.flags&1024)switch(e.tag){case 0:case 11:case 15:break;case 1:if(p!==null){var g=p.memoizedProps,x=p.memoizedState,m=e.stateNode,y=m.getSnapshotBeforeUpdate(e.elementType===e.type?g:Ls(e.type,g),x);m.__reactInternalSnapshotBeforeUpdate=y}break;case 3:var w=e.stateNode.containerInfo;w.nodeType===1?w.textContent="":w.nodeType===9&&w.documentElement&&w.removeChild(w.documentElement);break;case 5:case 6:case 4:case 17:break;default:throw Error(ne(163))}}catch(v){Ct(e,e.return,v)}if(t=e.sibling,t!==null){t.return=e.return,he=t;break}he=e.return}return p=Rb,Rb=!1,p}function xc(t,e,n){var s=e.updateQueue;if(s=s!==null?s.lastEffect:null,s!==null){var r=s=s.next;do{if((r.tag&t)===t){var o=r.destroy;r.destroy=void 0,o!==void 0&&E0(e,n,o)}r=r.next}while(r!==s)}}function tp(t,e){if(e=e.updateQueue,e=e!==null?e.lastEffect:null,e!==null){var n=e=e.next;do{if((n.tag&t)===t){var s=n.create;n.destroy=s()}n=n.next}while(n!==e)}}function R0(t){var e=t.ref;if(e!==null){var n=t.stateNode;switch(t.tag){case 5:t=n;break;default:t=n}typeof e=="function"?e(t):e.current=t}}function tI(t){var e=t.alternate;e!==null&&(t.alternate=null,tI(e)),t.child=null,t.deletions=null,t.sibling=null,t.tag===5&&(e=t.stateNode,e!==null&&(delete e[fr],delete e[Oc],delete e[g0],delete e[BF],delete e[VF])),t.stateNode=null,t.return=null,t.dependencies=null,t.memoizedProps=null,t.memoizedState=null,t.pendingProps=null,t.stateNode=null,t.updateQueue=null}function nI(t){return t.tag===5||t.tag===3||t.tag===4}function Ab(t){e:for(;;){for(;t.sibling===null;){if(t.return===null||nI(t.return))return null;t=t.return}for(t.sibling.return=t.return,t=t.sibling;t.tag!==5&&t.tag!==6&&t.tag!==18;){if(t.flags&2||t.child===null||t.tag===4)continue e;t.child.return=t,t=t.child}if(!(t.flags&2))return t.stateNode}}function A0(t,e,n){var s=t.tag;if(s===5||s===6)t=t.stateNode,e?n.nodeType===8?n.parentNode.insertBefore(t,e):n.insertBefore(t,e):(n.nodeType===8?(e=n.parentNode,e.insertBefore(t,n)):(e=n,e.appendChild(t)),n=n._reactRootContainer,n!=null||e.onclick!==null||(e.onclick=Gd));else if(s!==4&&(t=t.child,t!==null))for(A0(t,e,n),t=t.sibling;t!==null;)A0(t,e,n),t=t.sibling}function D0(t,e,n){var s=t.tag;if(s===5||s===6)t=t.stateNode,e?n.insertBefore(t,e):n.appendChild(t);else if(s!==4&&(t=t.child,t!==null))for(D0(t,e,n),t=t.sibling;t!==null;)D0(t,e,n),t=t.sibling}var on=null,Bs=!1;function no(t,e,n){for(n=n.child;n!==null;)sI(t,e,n),n=n.sibling}function sI(t,e,n){if(mr&&typeof mr.onCommitFiberUnmount=="function")try{mr.onCommitFiberUnmount(Kf,n)}catch{}switch(n.tag){case 5:yn||Ia(n,e);case 6:var s=on,r=Bs;on=null,no(t,e,n),on=s,Bs=r,on!==null&&(Bs?(t=on,n=n.stateNode,t.nodeType===8?t.parentNode.removeChild(n):t.removeChild(n)):on.removeChild(n.stateNode));break;case 18:on!==null&&(Bs?(t=on,n=n.stateNode,t.nodeType===8?ig(t.parentNode,n):t.nodeType===1&&ig(t,n),Ac(t)):ig(on,n.stateNode));break;case 4:s=on,r=Bs,on=n.stateNode.containerInfo,Bs=!0,no(t,e,n),on=s,Bs=r;break;case 0:case 11:case 14:case 15:if(!yn&&(s=n.updateQueue,s!==null&&(s=s.lastEffect,s!==null))){r=s=s.next;do{var o=r,i=o.destroy;o=o.tag,i!==void 0&&(o&2||o&4)&&E0(n,e,i),r=r.next}while(r!==s)}no(t,e,n);break;case 1:if(!yn&&(Ia(n,e),s=n.stateNode,typeof s.componentWillUnmount=="function"))try{s.props=n.memoizedProps,s.state=n.memoizedState,s.componentWillUnmount()}catch(a){Ct(n,e,a)}no(t,e,n);break;case 21:no(t,e,n);break;case 22:n.mode&1?(yn=(s=yn)||n.memoizedState!==null,no(t,e,n),yn=s):no(t,e,n);break;default:no(t,e,n)}}function Db(t){var e=t.updateQueue;if(e!==null){t.updateQueue=null;var n=t.stateNode;n===null&&(n=t.stateNode=new sz),e.forEach(function(s){var r=fz.bind(null,t,s);n.has(s)||(n.add(s),s.then(r,r))})}}function Os(t,e){var n=e.deletions;if(n!==null)for(var s=0;sr&&(r=i),s&=~o}if(s=r,s=Et()-s,s=(120>s?120:480>s?480:1080>s?1080:1920>s?1920:3e3>s?3e3:4320>s?4320:1960*iz(s/1960))-s,10t?16:t,uo===null)var s=!1;else{if(t=uo,uo=null,sf=0,Le&6)throw Error(ne(331));var r=Le;for(Le|=4,he=t.current;he!==null;){var o=he,i=o.child;if(he.flags&16){var a=o.deletions;if(a!==null){for(var l=0;lEt()-vx?mi(t,0):wx|=n),Kn(t,e)}function hI(t,e){e===0&&(t.mode&1?(e=Lh,Lh<<=1,!(Lh&130023424)&&(Lh=4194304)):e=1);var n=An();t=Vr(t,e),t!==null&&(au(t,e,n),Kn(t,n))}function dz(t){var e=t.memoizedState,n=0;e!==null&&(n=e.retryLane),hI(t,n)}function fz(t,e){var n=0;switch(t.tag){case 13:var s=t.stateNode,r=t.memoizedState;r!==null&&(n=r.retryLane);break;case 19:s=t.stateNode;break;default:throw Error(ne(314))}s!==null&&s.delete(e),hI(t,n)}var dI;dI=function(t,e,n){if(t!==null)if(t.memoizedProps!==e.pendingProps||Hn.current)Wn=!0;else{if(!(t.lanes&n)&&!(e.flags&128))return Wn=!1,ez(t,e,n);Wn=!!(t.flags&131072)}else Wn=!1,gt&&e.flags&1048576&&g2(e,Xd,e.index);switch(e.lanes=0,e.tag){case 2:var s=e.type;bd(t,e),t=e.pendingProps;var r=Ua(e,kn.current);_a(e,n),r=fx(null,e,s,t,r,n);var o=px();return e.flags|=1,typeof r=="object"&&r!==null&&typeof r.render=="function"&&r.$$typeof===void 0?(e.tag=1,e.memoizedState=null,e.updateQueue=null,jn(s)?(o=!0,jd(e)):o=!1,e.memoizedState=r.state!==null&&r.state!==void 0?r.state:null,lx(e),r.updater=ep,e.stateNode=r,r._reactInternals=e,C0(e,s,t,n),e=I0(null,e,s,!0,o,n)):(e.tag=0,gt&&o&&tx(e),Nn(null,e,r,n),e=e.child),e;case 16:s=e.elementType;e:{switch(bd(t,e),t=e.pendingProps,r=s._init,s=r(s._payload),e.type=s,r=e.tag=mz(s),t=Ls(s,t),r){case 0:e=S0(null,e,s,t,n);break e;case 1:e=Nb(null,e,s,t,n);break e;case 11:e=Ib(null,e,s,t,n);break e;case 14:e=$b(null,e,s,Ls(s.type,t),n);break e}throw Error(ne(306,s,""))}return e;case 0:return s=e.type,r=e.pendingProps,r=e.elementType===s?r:Ls(s,r),S0(t,e,s,r,n);case 1:return s=e.type,r=e.pendingProps,r=e.elementType===s?r:Ls(s,r),Nb(t,e,s,r,n);case 3:e:{if(q2(e),t===null)throw Error(ne(387));s=e.pendingProps,o=e.memoizedState,r=o.element,C2(t,e),Qd(e,s,null,n);var i=e.memoizedState;if(s=i.element,o.isDehydrated)if(o={element:s,isDehydrated:!1,cache:i.cache,pendingSuspenseBoundaries:i.pendingSuspenseBoundaries,transitions:i.transitions},e.updateQueue.baseState=o,e.memoizedState=o,e.flags&256){r=Ka(Error(ne(423)),e),e=Tb(t,e,s,n,r);break e}else if(s!==r){r=Ka(Error(ne(424)),e),e=Tb(t,e,s,n,r);break e}else for(ts=yo(e.stateNode.containerInfo.firstChild),ss=e,gt=!0,Vs=null,n=v2(e,null,s,n),e.child=n;n;)n.flags=n.flags&-3|4096,n=n.sibling;else{if(Ga(),s===r){e=Wr(t,e,n);break e}Nn(t,e,s,n)}e=e.child}return e;case 5:return k2(e),t===null&&w0(e),s=e.type,r=e.pendingProps,o=t!==null?t.memoizedProps:null,i=r.children,p0(s,r)?i=null:o!==null&&p0(s,o)&&(e.flags|=32),X2(t,e),Nn(t,e,i,n),e.child;case 6:return t===null&&w0(e),null;case 13:return Y2(t,e,n);case 4:return cx(e,e.stateNode.containerInfo),s=e.pendingProps,t===null?e.child=Ha(e,null,s,n):Nn(t,e,s,n),e.child;case 11:return s=e.type,r=e.pendingProps,r=e.elementType===s?r:Ls(s,r),Ib(t,e,s,r,n);case 7:return Nn(t,e,e.pendingProps,n),e.child;case 8:return Nn(t,e,e.pendingProps.children,n),e.child;case 12:return Nn(t,e,e.pendingProps.children,n),e.child;case 10:e:{if(s=e.type._context,r=e.pendingProps,o=e.memoizedProps,i=r.value,rt(qd,s._currentValue),s._currentValue=i,o!==null)if(Zs(o.value,i)){if(o.children===r.children&&!Hn.current){e=Wr(t,e,n);break e}}else for(o=e.child,o!==null&&(o.return=e);o!==null;){var a=o.dependencies;if(a!==null){i=o.child;for(var l=a.firstContext;l!==null;){if(l.context===s){if(o.tag===1){l=Pr(-1,n&-n),l.tag=2;var c=o.updateQueue;if(c!==null){c=c.shared;var u=c.pending;u===null?l.next=l:(l.next=u.next,u.next=l),c.pending=l}}o.lanes|=n,l=o.alternate,l!==null&&(l.lanes|=n),v0(o.return,n,e),a.lanes|=n;break}l=l.next}}else if(o.tag===10)i=o.type===e.type?null:o.child;else if(o.tag===18){if(i=o.return,i===null)throw Error(ne(341));i.lanes|=n,a=i.alternate,a!==null&&(a.lanes|=n),v0(i,n,e),i=o.sibling}else i=o.child;if(i!==null)i.return=o;else for(i=o;i!==null;){if(i===e){i=null;break}if(o=i.sibling,o!==null){o.return=i.return,i=o;break}i=i.return}o=i}Nn(t,e,r.children,n),e=e.child}return e;case 9:return r=e.type,s=e.pendingProps.children,_a(e,n),r=$s(r),s=s(r),e.flags|=1,Nn(t,e,s,n),e.child;case 14:return s=e.type,r=Ls(s,e.pendingProps),r=Ls(s.type,r),$b(t,e,s,r,n);case 15:return j2(t,e,e.type,e.pendingProps,n);case 17:return s=e.type,r=e.pendingProps,r=e.elementType===s?r:Ls(s,r),bd(t,e),e.tag=1,jn(s)?(t=!0,jd(e)):t=!1,_a(e,n),U2(e,s,r),C0(e,s,r,n),I0(null,e,s,!0,t,n);case 19:return Q2(t,e,n);case 22:return K2(t,e,n)}throw Error(ne(156,e.tag))};function fI(t,e){return BS(t,e)}function pz(t,e,n,s){this.tag=t,this.key=n,this.sibling=this.child=this.return=this.stateNode=this.type=this.elementType=null,this.index=0,this.ref=null,this.pendingProps=e,this.dependencies=this.memoizedState=this.updateQueue=this.memoizedProps=null,this.mode=s,this.subtreeFlags=this.flags=0,this.deletions=null,this.childLanes=this.lanes=0,this.alternate=null}function ys(t,e,n,s){return new pz(t,e,n,s)}function Sx(t){return t=t.prototype,!(!t||!t.isReactComponent)}function mz(t){if(typeof t=="function")return Sx(t)?1:0;if(t!=null){if(t=t.$$typeof,t===U1)return 11;if(t===G1)return 14}return 2}function Co(t,e){var n=t.alternate;return n===null?(n=ys(t.tag,e,t.key,t.mode),n.elementType=t.elementType,n.type=t.type,n.stateNode=t.stateNode,n.alternate=t,t.alternate=n):(n.pendingProps=e,n.type=t.type,n.flags=0,n.subtreeFlags=0,n.deletions=null),n.flags=t.flags&14680064,n.childLanes=t.childLanes,n.lanes=t.lanes,n.child=t.child,n.memoizedProps=t.memoizedProps,n.memoizedState=t.memoizedState,n.updateQueue=t.updateQueue,e=t.dependencies,n.dependencies=e===null?null:{lanes:e.lanes,firstContext:e.firstContext},n.sibling=t.sibling,n.index=t.index,n.ref=t.ref,n}function Sd(t,e,n,s,r,o){var i=2;if(s=t,typeof t=="function")Sx(t)&&(i=1);else if(typeof t=="string")i=5;else e:switch(t){case ga:return gi(n.children,r,o,e);case W1:i=8,r|=8;break;case jg:return t=ys(12,n,e,r|2),t.elementType=jg,t.lanes=o,t;case Kg:return t=ys(13,n,e,r),t.elementType=Kg,t.lanes=o,t;case Xg:return t=ys(19,n,e,r),t.elementType=Xg,t.lanes=o,t;case kS:return sp(n,r,o,e);default:if(typeof t=="object"&&t!==null)switch(t.$$typeof){case bS:i=10;break e;case CS:i=9;break e;case U1:i=11;break e;case G1:i=14;break e;case ro:i=16,s=null;break e}throw Error(ne(130,t==null?t:typeof t,""))}return e=ys(i,n,e,r),e.elementType=t,e.type=s,e.lanes=o,e}function gi(t,e,n,s){return t=ys(7,t,s,e),t.lanes=n,t}function sp(t,e,n,s){return t=ys(22,t,s,e),t.elementType=kS,t.lanes=n,t.stateNode={isHidden:!1},t}function pg(t,e,n){return t=ys(6,t,null,e),t.lanes=n,t}function mg(t,e,n){return e=ys(4,t.children!==null?t.children:[],t.key,e),e.lanes=n,e.stateNode={containerInfo:t.containerInfo,pendingChildren:null,implementation:t.implementation},e}function gz(t,e,n,s,r){this.tag=e,this.containerInfo=t,this.finishedWork=this.pingCache=this.current=this.pendingChildren=null,this.timeoutHandle=-1,this.callbackNode=this.pendingContext=this.context=null,this.callbackPriority=0,this.eventTimes=qm(0),this.expirationTimes=qm(-1),this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0,this.entanglements=qm(0),this.identifierPrefix=s,this.onRecoverableError=r,this.mutableSourceEagerHydrationData=null}function Ix(t,e,n,s,r,o,i,a,l){return t=new gz(t,e,n,a,l),e===1?(e=1,o===!0&&(e|=8)):e=0,o=ys(3,null,null,e),t.current=o,o.stateNode=t,o.memoizedState={element:s,isDehydrated:n,cache:null,transitions:null,pendingSuspenseBoundaries:null},lx(o),t}function xz(t,e,n){var s=3"u"||typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE!="function"))try{__REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(xI)}catch(t){console.error(t)}}xI(),xS.exports=ls;var Cz=xS.exports,Bb=Cz;Gg.createRoot=Bb.createRoot,Gg.hydrateRoot=Bb.hydrateRoot;var bn=function(){return bn=Object.assign||function(e){for(var n,s=1,r=arguments.length;s0?Zt(yl,--Ts):0,Ya--,Ft===10&&(Ya=1,cp--),Ft}function Xs(){return Ft=Ts2||P0(Ft)>3?"":" "}function Dz(t,e){for(;--e&&Xs()&&!(Ft<48||Ft>102||Ft>57&&Ft<65||Ft>70&&Ft<97););return hp(t,$d()+(e<6&&xi()==32&&Xs()==32))}function L0(t){for(;Xs();)switch(Ft){case t:return Ts;case 34:case 39:t!==34&&t!==39&&L0(Ft);break;case 40:t===41&&L0(t);break;case 92:Xs();break}return Ts}function _z(t,e){for(;Xs()&&t+Ft!==57;)if(t+Ft===84&&xi()===47)break;return"/*"+hp(e,Ts-1)+"*"+Rx(t===47?t:Xs())}function Fz(t){for(;!P0(xi());)Xs();return hp(t,Ts)}function zz(t){return Rz(Nd("",null,null,null,[""],t=Ez(t),0,[0],t))}function Nd(t,e,n,s,r,o,i,a,l){for(var c=0,u=0,h=i,d=0,f=0,p=0,g=1,x=1,m=1,y=0,w="",v=r,b=o,C=s,k=w;x;)switch(p=y,y=Xs()){case 40:if(p!=108&&Zt(k,h-1)==58){Id(k+=Te(gg(y),"&","&\f"),"&\f",vI(c?a[c-1]:0))!=-1&&(m=-1);break}case 34:case 39:case 91:k+=gg(y);break;case 9:case 10:case 13:case 32:k+=Az(p);break;case 92:k+=Dz($d()-1,7);continue;case 47:switch(xi()){case 42:case 47:ec(Oz(_z(Xs(),$d()),e,n,l),l);break;default:k+="/"}break;case 123*g:a[c++]=cr(k)*m;case 125*g:case 59:case 0:switch(y){case 0:case 125:x=0;case 59+u:m==-1&&(k=Te(k,/\f/g,"")),f>0&&cr(k)-h&&ec(f>32?Ub(k+";",s,n,h-1,l):Ub(Te(k," ","")+";",s,n,h-2,l),l);break;case 59:k+=";";default:if(ec(C=Wb(k,e,n,c,u,r,a,w,v=[],b=[],h,o),o),y===123)if(u===0)Nd(k,e,C,C,v,o,h,a,b);else switch(d===99&&Zt(k,3)===110?100:d){case 100:case 108:case 109:case 115:Nd(t,C,C,s&&ec(Wb(t,C,C,0,0,r,a,w,r,v=[],h,b),b),r,b,h,a,s?v:b);break;default:Nd(k,C,C,C,[""],b,0,a,b)}}c=u=f=0,g=m=1,w=k="",h=i;break;case 58:h=1+cr(k),f=p;default:if(g<1){if(y==123)--g;else if(y==125&&g++==0&&Tz()==125)continue}switch(k+=Rx(y),y*g){case 38:m=u>0?1:(k+="\f",-1);break;case 44:a[c++]=(cr(k)-1)*m,m=1;break;case 64:xi()===45&&(k+=gg(Xs())),d=xi(),u=h=cr(w=k+=Fz($d())),y++;break;case 45:p===45&&cr(k)==2&&(g=0)}}return o}function Wb(t,e,n,s,r,o,i,a,l,c,u,h){for(var d=r-1,f=r===0?o:[""],p=CI(f),g=0,x=0,m=0;g0?f[y]+" "+w:Te(w,/&\f/g,f[y])))&&(l[m++]=v);return up(t,e,n,r===0?lp:a,l,c,u,h)}function Oz(t,e,n,s){return up(t,e,n,yI,Rx(Nz()),qa(t,2,-2),0,s)}function Ub(t,e,n,s,r){return up(t,e,n,Ex,qa(t,0,s),qa(t,s+1,-1),s,r)}function SI(t,e,n){switch(Iz(t,e)){case 5103:return je+"print-"+t+t;case 5737:case 4201:case 3177:case 3433:case 1641:case 4457:case 2921:case 5572:case 6356:case 5844:case 3191:case 6645:case 3005:case 6391:case 5879:case 5623:case 6135:case 4599:case 4855:case 4215:case 6389:case 5109:case 5365:case 5621:case 3829:return je+t+t;case 4789:return vc+t+t;case 5349:case 4246:case 4810:case 6968:case 2756:return je+t+vc+t+ut+t+t;case 5936:switch(Zt(t,e+11)){case 114:return je+t+ut+Te(t,/[svh]\w+-[tblr]{2}/,"tb")+t;case 108:return je+t+ut+Te(t,/[svh]\w+-[tblr]{2}/,"tb-rl")+t;case 45:return je+t+ut+Te(t,/[svh]\w+-[tblr]{2}/,"lr")+t}case 6828:case 4268:case 2903:return je+t+ut+t+t;case 6165:return je+t+ut+"flex-"+t+t;case 5187:return je+t+Te(t,/(\w+).+(:[^]+)/,je+"box-$1$2"+ut+"flex-$1$2")+t;case 5443:return je+t+ut+"flex-item-"+Te(t,/flex-|-self/g,"")+(Ar(t,/flex-|baseline/)?"":ut+"grid-row-"+Te(t,/flex-|-self/g,""))+t;case 4675:return je+t+ut+"flex-line-pack"+Te(t,/align-content|flex-|-self/g,"")+t;case 5548:return je+t+ut+Te(t,"shrink","negative")+t;case 5292:return je+t+ut+Te(t,"basis","preferred-size")+t;case 6060:return je+"box-"+Te(t,"-grow","")+je+t+ut+Te(t,"grow","positive")+t;case 4554:return je+Te(t,/([^-])(transform)/g,"$1"+je+"$2")+t;case 6187:return Te(Te(Te(t,/(zoom-|grab)/,je+"$1"),/(image-set)/,je+"$1"),t,"")+t;case 5495:case 3959:return Te(t,/(image-set\([^]*)/,je+"$1$`$1");case 4968:return Te(Te(t,/(.+:)(flex-)?(.*)/,je+"box-pack:$3"+ut+"flex-pack:$3"),/s.+-b[^;]+/,"justify")+je+t+t;case 4200:if(!Ar(t,/flex-|baseline/))return ut+"grid-column-align"+qa(t,e)+t;break;case 2592:case 3360:return ut+Te(t,"template-","")+t;case 4384:case 3616:return n&&n.some(function(s,r){return e=r,Ar(s.props,/grid-\w+-end/)})?~Id(t+(n=n[e].value),"span",0)?t:ut+Te(t,"-start","")+t+ut+"grid-row-span:"+(~Id(n,"span",0)?Ar(n,/\d+/):+Ar(n,/\d+/)-+Ar(t,/\d+/))+";":ut+Te(t,"-start","")+t;case 4896:case 4128:return n&&n.some(function(s){return Ar(s.props,/grid-\w+-start/)})?t:ut+Te(Te(t,"-end","-span"),"span ","")+t;case 4095:case 3583:case 4068:case 2532:return Te(t,/(.+)-inline(.+)/,je+"$1$2")+t;case 8116:case 7059:case 5753:case 5535:case 5445:case 5701:case 4933:case 4677:case 5533:case 5789:case 5021:case 4765:if(cr(t)-1-e>6)switch(Zt(t,e+1)){case 109:if(Zt(t,e+4)!==45)break;case 102:return Te(t,/(.+:)(.+)-([^]+)/,"$1"+je+"$2-$3$1"+vc+(Zt(t,e+3)==108?"$3":"$2-$3"))+t;case 115:return~Id(t,"stretch",0)?SI(Te(t,"stretch","fill-available"),e,n)+t:t}break;case 5152:case 5920:return Te(t,/(.+?):(\d+)(\s*\/\s*(span)?\s*(\d+))?(.*)/,function(s,r,o,i,a,l,c){return ut+r+":"+o+c+(i?ut+r+"-span:"+(a?l:+l-+o)+c:"")+t});case 4949:if(Zt(t,e+6)===121)return Te(t,":",":"+je)+t;break;case 6444:switch(Zt(t,Zt(t,14)===45?18:11)){case 120:return Te(t,/(.+:)([^;\s!]+)(;|(\s+)?!.+)?/,"$1"+je+(Zt(t,14)===45?"inline-":"")+"box$3$1"+je+"$2$3$1"+ut+"$2box$3")+t;case 100:return Te(t,":",":"+ut)+t}break;case 5719:case 2647:case 2135:case 3927:case 2391:return Te(t,"scroll-","scroll-snap-")+t}return t}function af(t,e){for(var n="",s=0;s-1&&!t.return)switch(t.type){case Ex:t.return=SI(t.value,t.length,n);return;case wI:return af([so(t,{value:Te(t.value,"@","@"+je)})],s);case lp:if(t.length)return $z(n=t.props,function(r){switch(Ar(r,s=/(::plac\w+|:read-\w+)/)){case":read-only":case":read-write":oa(so(t,{props:[Te(r,/:(read-\w+)/,":"+vc+"$1")]})),oa(so(t,{props:[r]})),M0(t,{props:Vb(n,s)});break;case"::placeholder":oa(so(t,{props:[Te(r,/:(plac\w+)/,":"+je+"input-$1")]})),oa(so(t,{props:[Te(r,/:(plac\w+)/,":"+vc+"$1")]})),oa(so(t,{props:[Te(r,/:(plac\w+)/,ut+"input-$1")]})),oa(so(t,{props:[r]})),M0(t,{props:Vb(n,s)});break}return""})}}var Vz={animationIterationCount:1,aspectRatio:1,borderImageOutset:1,borderImageSlice:1,borderImageWidth:1,boxFlex:1,boxFlexGroup:1,boxOrdinalGroup:1,columnCount:1,columns:1,flex:1,flexGrow:1,flexPositive:1,flexShrink:1,flexNegative:1,flexOrder:1,gridRow:1,gridRowEnd:1,gridRowSpan:1,gridRowStart:1,gridColumn:1,gridColumnEnd:1,gridColumnSpan:1,gridColumnStart:1,msGridRow:1,msGridRowSpan:1,msGridColumn:1,msGridColumnSpan:1,fontWeight:1,lineHeight:1,opacity:1,order:1,orphans:1,tabSize:1,widows:1,zIndex:1,zoom:1,WebkitLineClamp:1,fillOpacity:1,floodOpacity:1,stopOpacity:1,strokeDasharray:1,strokeDashoffset:1,strokeMiterlimit:1,strokeOpacity:1,strokeWidth:1},Zn={},Qa=typeof process<"u"&&Zn!==void 0&&(Zn.REACT_APP_SC_ATTR||Zn.SC_ATTR)||"data-styled",II="active",$I="data-styled-version",dp="6.1.13",Ax=`/*!sc*/ +`,lf=typeof window<"u"&&"HTMLElement"in window,Wz=!!(typeof SC_DISABLE_SPEEDY=="boolean"?SC_DISABLE_SPEEDY:typeof process<"u"&&Zn!==void 0&&Zn.REACT_APP_SC_DISABLE_SPEEDY!==void 0&&Zn.REACT_APP_SC_DISABLE_SPEEDY!==""?Zn.REACT_APP_SC_DISABLE_SPEEDY!=="false"&&Zn.REACT_APP_SC_DISABLE_SPEEDY:typeof process<"u"&&Zn!==void 0&&Zn.SC_DISABLE_SPEEDY!==void 0&&Zn.SC_DISABLE_SPEEDY!==""&&Zn.SC_DISABLE_SPEEDY!=="false"&&Zn.SC_DISABLE_SPEEDY),Uz={},fp=Object.freeze([]),Za=Object.freeze({});function NI(t,e,n){return n===void 0&&(n=Za),t.theme!==n.theme&&t.theme||e||n.theme}var TI=new Set(["a","abbr","address","area","article","aside","audio","b","base","bdi","bdo","big","blockquote","body","br","button","canvas","caption","cite","code","col","colgroup","data","datalist","dd","del","details","dfn","dialog","div","dl","dt","em","embed","fieldset","figcaption","figure","footer","form","h1","h2","h3","h4","h5","h6","header","hgroup","hr","html","i","iframe","img","input","ins","kbd","keygen","label","legend","li","link","main","map","mark","menu","menuitem","meta","meter","nav","noscript","object","ol","optgroup","option","output","p","param","picture","pre","progress","q","rp","rt","ruby","s","samp","script","section","select","small","source","span","strong","style","sub","summary","sup","table","tbody","td","textarea","tfoot","th","thead","time","tr","track","u","ul","use","var","video","wbr","circle","clipPath","defs","ellipse","foreignObject","g","image","line","linearGradient","marker","mask","path","pattern","polygon","polyline","radialGradient","rect","stop","svg","text","tspan"]),Gz=/[!"#$%&'()*+,./:;<=>?@[\\\]^`{|}~-]+/g,Hz=/(^-|-$)/g;function Gb(t){return t.replace(Gz,"-").replace(Hz,"")}var jz=/(a)(d)/gi,Qh=52,Hb=function(t){return String.fromCharCode(t+(t>25?39:97))};function B0(t){var e,n="";for(e=Math.abs(t);e>Qh;e=e/Qh|0)n=Hb(e%Qh)+n;return(Hb(e%Qh)+n).replace(jz,"$1-$2")}var xg,EI=5381,Na=function(t,e){for(var n=e.length;n;)t=33*t^e.charCodeAt(--n);return t},RI=function(t){return Na(EI,t)};function AI(t){return B0(RI(t)>>>0)}function Kz(t){return t.displayName||t.name||"Component"}function yg(t){return typeof t=="string"&&!0}var DI=typeof Symbol=="function"&&Symbol.for,_I=DI?Symbol.for("react.memo"):60115,Xz=DI?Symbol.for("react.forward_ref"):60112,qz={childContextTypes:!0,contextType:!0,contextTypes:!0,defaultProps:!0,displayName:!0,getDefaultProps:!0,getDerivedStateFromError:!0,getDerivedStateFromProps:!0,mixins:!0,propTypes:!0,type:!0},Yz={name:!0,length:!0,prototype:!0,caller:!0,callee:!0,arguments:!0,arity:!0},FI={$$typeof:!0,compare:!0,defaultProps:!0,displayName:!0,propTypes:!0,type:!0},Qz=((xg={})[Xz]={$$typeof:!0,render:!0,defaultProps:!0,displayName:!0,propTypes:!0},xg[_I]=FI,xg);function jb(t){return("type"in(e=t)&&e.type.$$typeof)===_I?FI:"$$typeof"in t?Qz[t.$$typeof]:qz;var e}var Zz=Object.defineProperty,Jz=Object.getOwnPropertyNames,Kb=Object.getOwnPropertySymbols,eO=Object.getOwnPropertyDescriptor,tO=Object.getPrototypeOf,Xb=Object.prototype;function zI(t,e,n){if(typeof e!="string"){if(Xb){var s=tO(e);s&&s!==Xb&&zI(t,s,n)}var r=Jz(e);Kb&&(r=r.concat(Kb(e)));for(var o=jb(t),i=jb(e),a=0;a0?" Args: ".concat(e.join(", ")):""))}var nO=function(){function t(e){this.groupSizes=new Uint32Array(512),this.length=512,this.tag=e}return t.prototype.indexOfGroup=function(e){for(var n=0,s=0;s=this.groupSizes.length){for(var s=this.groupSizes,r=s.length,o=r;e>=o;)if((o<<=1)<0)throw hu(16,"".concat(e));this.groupSizes=new Uint32Array(o),this.groupSizes.set(s),this.length=o;for(var i=r;i=this.length||this.groupSizes[e]===0)return n;for(var s=this.groupSizes[e],r=this.indexOfGroup(e),o=r+s,i=r;i=0){var s=document.createTextNode(n);return this.element.insertBefore(s,this.nodes[e]||null),this.length++,!0}return!1},t.prototype.deleteRule=function(e){this.element.removeChild(this.nodes[e]),this.length--},t.prototype.getRule=function(e){return e0&&(x+="".concat(m,","))}),l+="".concat(p).concat(g,'{content:"').concat(x,'"}').concat(Ax)},u=0;u0?".".concat(e):d},u=l.slice();u.push(function(d){d.type===lp&&d.value.includes("&")&&(d.props[0]=d.props[0].replace(fO,n).replace(s,c))}),i.prefix&&u.push(Bz),u.push(Mz);var h=function(d,f,p,g){f===void 0&&(f=""),p===void 0&&(p=""),g===void 0&&(g="&"),e=g,n=f,s=new RegExp("\\".concat(n,"\\b"),"g");var x=d.replace(pO,""),m=zz(p||f?"".concat(p," ").concat(f," { ").concat(x," }"):x);i.namespace&&(m=MI(m,i.namespace));var y=[];return af(m,Pz(u.concat(Lz(function(w){return y.push(w)})))),y};return h.hash=l.length?l.reduce(function(d,f){return f.name||hu(15),Na(d,f.name)},EI).toString():"",h}var gO=new uf,U0=mO(),PI=Gs.createContext({shouldForwardProp:void 0,styleSheet:gO,stylis:U0});PI.Consumer;Gs.createContext(void 0);function G0(){return ye.useContext(PI)}var xO=function(){function t(e,n){var s=this;this.inject=function(r,o){o===void 0&&(o=U0);var i=s.name+o.hash;r.hasNameForId(s.id,i)||r.insertRules(s.id,i,o(s.rules,i,"@keyframes"))},this.name=e,this.id="sc-keyframes-".concat(e),this.rules=n,_x(this,function(){throw hu(12,String(s.name))})}return t.prototype.getName=function(e){return e===void 0&&(e=U0),this.name+e.hash},t}(),yO=function(t){return t>="A"&&t<="Z"};function Qb(t){for(var e="",n=0;n>>0);if(!n.hasNameForId(this.componentId,i)){var a=s(o,".".concat(i),void 0,this.componentId);n.insertRules(this.componentId,i,a)}r=hi(r,i),this.staticRulesId=i}else{for(var l=Na(this.baseHash,s.hash),c="",u=0;u>>0);n.hasNameForId(this.componentId,f)||n.insertRules(this.componentId,f,s(c,".".concat(f),void 0,this.componentId)),r=hi(r,f)}}return r},t}(),Fx=Gs.createContext(void 0);Fx.Consumer;var wg={};function bO(t,e,n){var s=Dx(t),r=t,o=!yg(t),i=e.attrs,a=i===void 0?fp:i,l=e.componentId,c=l===void 0?function(v,b){var C=typeof v!="string"?"sc":Gb(v);wg[C]=(wg[C]||0)+1;var k="".concat(C,"-").concat(AI(dp+C+wg[C]));return b?"".concat(b,"-").concat(k):k}(e.displayName,e.parentComponentId):l,u=e.displayName,h=u===void 0?function(v){return yg(v)?"styled.".concat(v):"Styled(".concat(Kz(v),")")}(t):u,d=e.displayName&&e.componentId?"".concat(Gb(e.displayName),"-").concat(e.componentId):e.componentId||c,f=s&&r.attrs?r.attrs.concat(a).filter(Boolean):a,p=e.shouldForwardProp;if(s&&r.shouldForwardProp){var g=r.shouldForwardProp;if(e.shouldForwardProp){var x=e.shouldForwardProp;p=function(v,b){return g(v,b)&&x(v,b)}}else p=g}var m=new vO(n,d,s?r.componentStyle:void 0);function y(v,b){return function(C,k,S){var $=C.attrs,N=C.componentStyle,A=C.defaultProps,M=C.foldedComponentIds,L=C.styledComponentId,V=C.target,B=Gs.useContext(Fx),U=G0(),K=C.shouldForwardProp||U.shouldForwardProp,R=NI(k,B,A)||Za,O=function(Z,se,ie){for(var ce,ue=bn(bn({},se),{className:void 0,theme:ie}),xe=0;xe2&&uf.registerId(this.componentId+e),this.removeStyles(e,s),this.createStyles(e,n,s,r)},t}();function GI(t){for(var e=[],n=1;nDe.jsxs(kO,{children:[De.jsx(SO,{children:"MasterPlan"}),De.jsx(IO,{onClick:t,"aria-label":"Start the game",children:"Play"})]});function NO(t,e){var n=ye.useRef(!1),s=ye.useRef(),r=ye.useRef(t),o=ye.useCallback(function(){return n.current},[]),i=ye.useCallback(function(){n.current=!1,s.current&&clearTimeout(s.current),s.current=setTimeout(function(){n.current=!0,r.current()},e)},[e]),a=ye.useCallback(function(){n.current=null,s.current&&clearTimeout(s.current)},[]);return ye.useEffect(function(){r.current=t},[t]),ye.useEffect(function(){return i(),a},[e]),[o,a,i]}function TO(t,e,n){n===void 0&&(n=[]);var s=NO(t,e),r=s[0],o=s[1],i=s[2];return ye.useEffect(i,n),[r,o]}function EO(t,e){e===void 0&&(e=!0);var n=ye.useRef(null),s=ye.useRef(!1),r=ye.useRef(t);r.current=t;var o=ye.useCallback(function(a){s.current&&(r.current(a),n.current=requestAnimationFrame(o))},[]),i=ye.useMemo(function(){return[function(){s.current&&(s.current=!1,n.current&&cancelAnimationFrame(n.current))},function(){s.current||(s.current=!0,n.current=requestAnimationFrame(o))},function(){return s.current}]},[]);return ye.useEffect(function(){return e&&i[1](),i[0]},[]),i}const RO=10,eC=100,hu="layer-default",uo=800,df=100,is=32,Wr=32,yi=1600,wi=800,So=yi/is,Io=wi/Wr,AO=10,j0=is+AO,tC=600,DO=250,nC=300,sC=500,_O=is*5,rC=1e3,oC=is/3,za=is*4,G2=1500,FO=1e3,el=Math.floor(So/2),tl=Math.floor(Io/2),zO="",OO="",MO="",PO="",K0={warrior:zO,archer:OO,tank:MO,artillery:PO},LO=t=>new Promise((e,n)=>{const s=new Image;s.onload=()=>e(s),s.onerror=n,s.src=t}),zx=Us.memo(({width:t,height:e,cellWidth:n,cellHeight:s,units:r,selectedUnitId:o,onMouseDown:i,onMouseMove:a,onMouseUp:l,onTouchStart:c,onTouchMove:u,onTouchEnd:d,onCellClick:h,isPlayerArea:f})=>{const p=ye.useRef(null),[g,x]=ye.useState({});ye.useEffect(()=>{(async()=>{const b={};for(const[C,k]of Object.entries(K0))try{b[C]=await LO(k)}catch(S){console.error(`Failed to load image for ${C}:`,S)}x(b)})()},[]);const m=ye.useCallback(v=>{v.strokeStyle="#ccc",v.lineWidth=1;for(let b=0;b<=t;b+=n)v.beginPath(),v.moveTo(b,0),v.lineTo(b,e),v.stroke();for(let b=0;b<=e;b+=s)v.beginPath(),v.moveTo(0,b),v.lineTo(t,b),v.stroke()},[t,e,n,s]),y=ye.useCallback(v=>{r.forEach(b=>{const C=(b.col+el)*n,k=(b.row+tl)*s,S=b.sizeCol*n,$=b.sizeRow*s;if(g[b.type])for(let N=0;N{const v=p.current;if(!v)return;const b=v.getContext("2d");b&&(b.clearRect(0,0,t,e),m(b),y(b))},[t,e,n,s,r,o,g,m,y]);const w=ye.useCallback(v=>{if(!f)return;const b=p.current;if(!b)return;const C=b.getBoundingClientRect(),k=(v.clientX-C.left)*(b.width/C.width),S=(v.clientY-C.top)*(b.height/C.height),$=Math.floor(k/n)-el,N=Math.floor(S/s)-tl;h($,N)},[n,s,h,f]);return De.jsx(BO,{ref:p,"data-is-player-area":f,width:t,height:e,onClick:w,onMouseDown:i,onMouseMove:a,onMouseUp:l,onTouchStart:c,onTouchMove:u,onTouchEnd:d})});zx.displayName="CanvasGrid";const BO=In.canvas` +`,NO=({onPlayClick:t})=>De.jsxs(SO,{children:[De.jsx(IO,{children:"MasterPlan"}),De.jsx($O,{onClick:t,"aria-label":"Start the game",children:"Play"})]});function TO(t,e){var n=ye.useRef(!1),s=ye.useRef(),r=ye.useRef(t),o=ye.useCallback(function(){return n.current},[]),i=ye.useCallback(function(){n.current=!1,s.current&&clearTimeout(s.current),s.current=setTimeout(function(){n.current=!0,r.current()},e)},[e]),a=ye.useCallback(function(){n.current=null,s.current&&clearTimeout(s.current)},[]);return ye.useEffect(function(){r.current=t},[t]),ye.useEffect(function(){return i(),a},[e]),[o,a,i]}function EO(t,e,n){n===void 0&&(n=[]);var s=TO(t,e),r=s[0],o=s[1],i=s[2];return ye.useEffect(i,n),[r,o]}function RO(t,e){e===void 0&&(e=!0);var n=ye.useRef(null),s=ye.useRef(!1),r=ye.useRef(t);r.current=t;var o=ye.useCallback(function(a){s.current&&(r.current(a),n.current=requestAnimationFrame(o))},[]),i=ye.useMemo(function(){return[function(){s.current&&(s.current=!1,n.current&&cancelAnimationFrame(n.current))},function(){s.current||(s.current=!0,n.current=requestAnimationFrame(o))},function(){return s.current}]},[]);return ye.useEffect(function(){return e&&i[1](),i[0]},[]),i}const AO=10,eC=100,du="layer-default",ws=800,hf=100,is=32,Ur=32,yi=1600,wi=800,So=yi/is,Io=wi/Ur,DO=10,j0=is+DO,tC=600,_O=250,nC=300,sC=500,FO=is*5,rC=1e3,oC=is/3,za=is*4,HI=1500,zO=1e3,el=Math.floor(So/2),tl=Math.floor(Io/2),OO="",MO="",PO="",LO="",K0={warrior:OO,archer:MO,tank:PO,artillery:LO},BO=t=>new Promise((e,n)=>{const s=new Image;s.onload=()=>e(s),s.onerror=n,s.src=t}),zx=Gs.memo(({width:t,height:e,cellWidth:n,cellHeight:s,units:r,selectedUnitId:o,onMouseDown:i,onMouseMove:a,onMouseUp:l,onTouchStart:c,onTouchMove:u,onTouchEnd:h,onCellClick:d,isPlayerArea:f})=>{const p=ye.useRef(null),[g,x]=ye.useState({});ye.useEffect(()=>{(async()=>{const b={};for(const[C,k]of Object.entries(K0))try{b[C]=await BO(k)}catch(S){console.error(`Failed to load image for ${C}:`,S)}x(b)})()},[]);const m=ye.useCallback(v=>{v.strokeStyle="#ccc",v.lineWidth=1;for(let b=0;b<=t;b+=n)v.beginPath(),v.moveTo(b,0),v.lineTo(b,e),v.stroke();for(let b=0;b<=e;b+=s)v.beginPath(),v.moveTo(0,b),v.lineTo(t,b),v.stroke()},[t,e,n,s]),y=ye.useCallback(v=>{r.forEach(b=>{const C=(b.col+el)*n,k=(b.row+tl)*s,S=b.sizeCol*n,$=b.sizeRow*s;if(g[b.type])for(let N=0;N{const v=p.current;if(!v)return;const b=v.getContext("2d");b&&(b.clearRect(0,0,t,e),m(b),y(b))},[t,e,n,s,r,o,g,m,y]);const w=ye.useCallback(v=>{if(!f)return;const b=p.current;if(!b)return;const C=b.getBoundingClientRect(),k=(v.clientX-C.left)*(b.width/C.width),S=(v.clientY-C.top)*(b.height/C.height),$=Math.floor(k/n)-el,N=Math.floor(S/s)-tl;d($,N)},[n,s,d,f]);return De.jsx(VO,{ref:p,"data-is-player-area":f,width:t,height:e,onClick:w,onMouseDown:i,onMouseMove:a,onMouseUp:l,onTouchStart:c,onTouchMove:u,onTouchEnd:h})});zx.displayName="CanvasGrid";const VO=In.canvas` position: absolute; transform: translate(-50%, -50%); left: 50%; top: 50%; max-width: 90vw; max-height: 50vh; -`,iC=(t,e)=>({x:(t+el)*is,y:(e+tl)*Wr}),aC=(t,e)=>({col:Math.floor(t/is)-el,row:Math.floor(e/Wr)-tl}),VO=(t,e)=>{const[n,s]=ye.useState({isDragging:!1,draggedUnit:null,dragOffset:{x:0,y:0}}),r=ye.useCallback(l=>"touches"in l?{clientX:l.touches[0].clientX,clientY:l.touches[0].clientY}:{clientX:l.clientX,clientY:l.clientY},[]),o=ye.useCallback(l=>{const c=l.currentTarget,u=c.getBoundingClientRect(),{clientX:d,clientY:h}=r(l),{col:f,row:p}=aC((d-u.left)*(c.width/u.width),(h-u.top)*(c.height/u.height)),g=t.find(x=>f>=x.col&&f=x.row&&p{if(n.isDragging&&n.draggedUnit){const c=l.currentTarget,u=c.getBoundingClientRect(),{clientX:d,clientY:h}=r(l),{col:f,row:p}=aC((d-u.left)*(c.width/u.width)-n.dragOffset.x,(h-u.top)*(c.height/u.height)-n.dragOffset.y);e(g=>g.map(x=>x.id===n.draggedUnit.id?{...x,col:Math.max(-el,Math.min(f,So-el-x.sizeCol)),row:Math.max(-tl,Math.min(p,Io-tl-x.sizeRow))}:x))}},[n,e,r]),a=ye.useCallback(()=>{s({isDragging:!1,draggedUnit:null,dragOffset:{x:0,y:0}})},[]);return{isDragging:n.isDragging,handleDragStart:o,handleDragMove:i,handleDragEnd:a}},WO=t=>{const[e,n]=ye.useState(null),s=ye.useCallback((o,i)=>{const a=t.find(l=>o>=l.col&&o=l.row&&i{n(null)},[]);return{selectedUnit:e,handleUnitSelect:s,setSelectedUnit:n,clearSelection:r}};function lC(t,e){if(e.length===0)throw new Error("No AI plans available for selection");const n=e.map(r=>({plan:r,score:r.probabilityScore(t)}));n.sort((r,o)=>o.score-r.score);const s=n[0].plan;return console.log("Selected plan:",s.name,"with score:",n[0].score),console.log("All plan scores:"),n.forEach(({plan:r,score:o})=>{console.log(`${r.name}: ${o}`)}),s.units}function Qe(t){return t.reduce((e,n)=>(e[n.type]=(e[n.type]||0)+1,e),{tank:0,warrior:0,archer:0,artillery:0})}function nt(t){const e={left:0,center:0,right:0,front:0};t.forEach(s=>{s.col<-5?e.left++:s.col>5?e.right++:e.center++,s.row>-5&&e.front++});const n=t.length;return{left:e.left/n,center:e.center/n,right:e.right/n,front:e.front/n}}function lt(t){return t.length===0?0:t.reduce((n,s)=>n+s.sizeCol*s.sizeRow,0)/(t.length*16)}function At(t){const e=t.map(i=>({x:i.col,y:i.row})),n=e.reduce((i,a)=>i+a.x,0)/e.length,s=e.reduce((i,a)=>i+a.y,0)/e.length,r=Math.sqrt(32*32+18*18);return e.reduce((i,a)=>{const l=a.x-n,c=a.y-s;return i+Math.sqrt(l*l+c*c)},0)/e.length/r}const Ox=[{id:201,col:-12,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"advance-wait"},{id:202,col:0,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"advance-wait"},{id:203,col:12,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"advance-wait"},{id:204,col:-8,row:-4,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:205,col:8,row:-4,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:206,col:-16,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:207,col:16,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:208,col:2,row:-8,sizeCol:8,sizeRow:1,type:"artillery",command:"wait-advance"}],UO="Balanced Assault",GO=t=>{const e=Qe(t),n=nt(t),s=1-Math.abs(.25-e.warrior/t.length)-Math.abs(.25-e.archer/t.length)-Math.abs(.25-e.tank/t.length)-Math.abs(.25-e.artillery/t.length),r=(n.left+n.right+n.center)/3,o=1-Math.abs(.5-lt(t));return(s*.5+r*.3+o*.2)*100},HO=Object.freeze(Object.defineProperty({__proto__:null,name:UO,probabilityScore:GO,units:Ox},Symbol.toStringTag,{value:"Module"})),jO=[{id:301,col:-16,row:0,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:302,col:16,row:0,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:303,col:0,row:-4,sizeCol:8,sizeRow:3,type:"artillery",command:"advance-wait"},{id:304,col:-12,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:305,col:12,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:306,col:-8,row:-6,sizeCol:4,sizeRow:3,type:"tank",command:"advance"},{id:307,col:8,row:-6,sizeCol:4,sizeRow:3,type:"tank",command:"advance"}],KO="Anti-Tank Defense",XO=t=>{const e=Qe(t),n=nt(t),s=e.tank/t.length,r=Math.min(s*2,1),o=n.center,i=lt(t.filter(a=>a.type==="tank"));return(r*.5+o*.3+i*.2)*100},qO=Object.freeze(Object.defineProperty({__proto__:null,name:KO,probabilityScore:XO,units:jO},Symbol.toStringTag,{value:"Module"})),YO=[{id:401,col:-12,row:-2,sizeCol:4,sizeRow:2,type:"tank",command:"flank-left"},{id:402,col:12,row:-2,sizeCol:4,sizeRow:2,type:"tank",command:"flank-right"},{id:403,col:0,row:-6,sizeCol:6,sizeRow:3,type:"artillery",command:"wait-advance"},{id:404,col:-16,row:0,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:405,col:16,row:0,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:406,col:-8,row:-10,sizeCol:4,sizeRow:3,type:"tank",command:"advance"},{id:407,col:8,row:-10,sizeCol:4,sizeRow:3,type:"tank",command:"advance"},{id:408,col:-4,row:-4,sizeCol:4,sizeRow:2,type:"warrior",command:"advance"},{id:409,col:4,row:-4,sizeCol:4,sizeRow:2,type:"warrior",command:"advance"}],QO="Archer Counter",ZO=t=>{const e=Qe(t),n=nt(t),s=e.archer/t.length,r=Math.min(s*2,1),o=Math.max(n.left,n.right),i=1-lt(t.filter(a=>a.type==="archer"));return(r*.5+o*.3+i*.2)*100},JO=Object.freeze(Object.defineProperty({__proto__:null,name:QO,probabilityScore:ZO,units:YO},Symbol.toStringTag,{value:"Module"})),e3=[{id:501,col:-12,row:0,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:502,col:12,row:0,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:503,col:-8,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"flank-left"},{id:504,col:8,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"flank-right"},{id:505,col:-16,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:506,col:16,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:507,col:0,row:-6,sizeCol:6,sizeRow:3,type:"artillery",command:"wait-advance"},{id:508,col:-4,row:-2,sizeCol:4,sizeRow:2,type:"warrior",command:"advance"},{id:509,col:4,row:-2,sizeCol:4,sizeRow:2,type:"warrior",command:"advance"}],t3="Warrior Blitz",n3=t=>{const e=Qe(t),n=nt(t),s=e.tank/t.length,r=(e.warrior+e.archer)/t.length,o=(1-s)*.5+r*.5,i=n.center,a=1-lt(t);return(o*.4+i*.4+a*.2)*100},s3=Object.freeze(Object.defineProperty({__proto__:null,name:t3,probabilityScore:n3,units:e3},Symbol.toStringTag,{value:"Module"})),r3=[{id:601,col:-12,row:-4,sizeCol:4,sizeRow:4,type:"tank",command:"advance-wait"},{id:602,col:12,row:-4,sizeCol:4,sizeRow:4,type:"tank",command:"advance-wait"},{id:603,col:-16,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"advance"},{id:604,col:16,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"advance"},{id:605,col:0,row:-8,sizeCol:8,sizeRow:2,type:"artillery",command:"wait-advance"},{id:606,col:-8,row:-10,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:607,col:8,row:-10,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:608,col:0,row:-12,sizeCol:8,sizeRow:2,type:"artillery",command:"wait-advance"},{id:609,col:0,row:-2,sizeCol:8,sizeRow:2,type:"warrior",command:"advance"}],o3="Tank Formation",i3=t=>{const e=Qe(t),n=nt(t),s=(e.warrior+e.archer)/t.length,r=Math.min(s*1.5,1),o=1-n.center,i=1-lt(t);return(r*.4+o*.4+i*.2)*100},a3=Object.freeze(Object.defineProperty({__proto__:null,name:o3,probabilityScore:i3,units:r3},Symbol.toStringTag,{value:"Module"})),l3=[{id:701,col:-16,row:-4,sizeCol:6,sizeRow:3,type:"artillery",command:"advance"},{id:702,col:16,row:-4,sizeCol:6,sizeRow:3,type:"artillery",command:"advance"},{id:703,col:0,row:0,sizeCol:6,sizeRow:3,type:"tank",command:"advance-wait"},{id:704,col:-8,row:-10,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:705,col:8,row:-10,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:706,col:-12,row:-12,sizeCol:4,sizeRow:3,type:"tank",command:"advance"},{id:707,col:12,row:-12,sizeCol:4,sizeRow:3,type:"tank",command:"advance"},{id:708,col:0,row:-6,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"}],c3="Artillery Strike",u3=t=>{const e=Qe(t),n=nt(t),s=(e.tank+e.artillery)/t.length,r=Math.min(s*2,1),o=Math.max(n.left,n.center,n.right),i=lt(t);return(r*.4+o*.4+i*.2)*100},d3=Object.freeze(Object.defineProperty({__proto__:null,name:c3,probabilityScore:u3,units:l3},Symbol.toStringTag,{value:"Module"})),h3=[{id:801,col:-16,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:802,col:-8,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:803,col:0,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:804,col:8,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:805,col:16,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:806,col:-12,row:-10,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:807,col:12,row:-10,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:808,col:0,row:-14,sizeCol:8,sizeRow:2,type:"artillery",command:"wait-advance"},{id:809,col:-20,row:-6,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:810,col:20,row:-6,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:811,col:-4,row:-8,sizeCol:4,sizeRow:2,type:"warrior",command:"advance"},{id:812,col:4,row:-8,sizeCol:4,sizeRow:2,type:"warrior",command:"advance"}],f3="Archer Ambush",p3=t=>{const e=Qe(t),n=nt(t),s=(e.warrior+e.tank)/t.length,r=Math.min(s*1.5,1),o=n.center+n.front*.5,i=lt(t);return(r*.4+o*.4+i*.2)*100},m3=Object.freeze(Object.defineProperty({__proto__:null,name:f3,probabilityScore:p3,units:h3},Symbol.toStringTag,{value:"Module"})),g3=[{id:301,col:-16,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:302,col:-8,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:303,col:8,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:304,col:16,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:305,col:-12,row:-4,sizeCol:8,sizeRow:2,type:"artillery",command:"wait-advance"},{id:306,col:12,row:-4,sizeCol:8,sizeRow:2,type:"artillery",command:"wait-advance"},{id:307,col:-8,row:0,sizeCol:4,sizeRow:4,type:"tank",command:"wait-advance"},{id:308,col:8,row:0,sizeCol:4,sizeRow:4,type:"tank",command:"wait-advance"},{id:309,col:0,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:310,col:-16,row:-2,sizeCol:4,sizeRow:2,type:"warrior",command:"flank-left"},{id:311,col:16,row:-2,sizeCol:4,sizeRow:2,type:"warrior",command:"flank-right"}],x3="Warrior Counter",y3=t=>{const e=Qe(t),n=t.length,s=(e.warrior||0)/n,r=At(t),o=Math.min(s*2,1),i=1-r,a=1-lt(t.filter(l=>l.type==="warrior"));return(o*.5+i*.3+a*.2)*100},w3=Object.freeze(Object.defineProperty({__proto__:null,name:x3,probabilityScore:y3,units:g3},Symbol.toStringTag,{value:"Module"})),v3=[{id:301,col:-6,row:0,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:302,col:6,row:0,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:303,col:-10,row:-4,sizeCol:3,sizeRow:2,type:"warrior",command:"advance"},{id:304,col:-5,row:-4,sizeCol:3,sizeRow:2,type:"warrior",command:"advance"},{id:305,col:0,row:-4,sizeCol:3,sizeRow:2,type:"warrior",command:"advance"},{id:306,col:5,row:-4,sizeCol:3,sizeRow:2,type:"warrior",command:"advance"},{id:307,col:10,row:-4,sizeCol:3,sizeRow:2,type:"warrior",command:"advance"},{id:308,col:-12,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:309,col:0,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:310,col:12,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:311,col:-12,row:-12,sizeCol:8,sizeRow:2,type:"artillery",command:"wait-advance"},{id:312,col:12,row:-12,sizeCol:8,sizeRow:2,type:"artillery",command:"wait-advance"}],b3="Artillery Counter",C3=t=>{const e=Qe(t),n=nt(t),s=Math.min(e.artillery/t.length,.5)*2,r=n.center,o=lt(t);return(s*.6+r*.2+o*.2)*100},k3=Object.freeze(Object.defineProperty({__proto__:null,name:b3,probabilityScore:C3,units:v3},Symbol.toStringTag,{value:"Module"})),Rh=[...[...Array(10)].map((t,e)=>({id:e,type:"warrior",col:-2+e%5,row:-4+Math.floor(e/5),sizeCol:2,sizeRow:2,command:"advance"})),...[...Array(5)].map((t,e)=>({id:e+10,type:"archer",col:-2+e,row:-2,sizeCol:2,sizeRow:2,command:"advance"})),...[...Array(3)].map((t,e)=>({id:e+15,type:"artillery",col:-3+e*3,row:0,sizeCol:3,sizeRow:2,command:"advance"})),...[...Array(4)].map((t,e)=>({id:e+18,type:"warrior",col:e<2?-4:4,row:-5+e%2*2,sizeCol:2,sizeRow:2,command:"advance"})),...[...Array(4)].map((t,e)=>({id:e+22,type:"archer",col:e<2?-5:5,row:-4+e%2*2,sizeCol:2,sizeRow:2,command:"advance"}))],S3="Phalanx Formation";function I3(t){const e=Qe(Rh),n=Qe(t),s=nt(Rh),r=nt(t),o=At(Rh),i=At(t);let a=.5;return a+=(e.warrior-n.warrior)*.02,a+=(n.tank-e.tank)*.03,a+=(s.center-r.center)*.1,a+=(i-o)*.1,a-=Math.max(0,n.archer-e.archer)*.01,a-=Math.max(0,n.artillery-e.artillery)*.01,Math.max(0,Math.min(1,a))}const $3=Object.freeze(Object.defineProperty({__proto__:null,name:S3,probabilityScore:I3,units:Rh},Symbol.toStringTag,{value:"Module"})),tc=[...[...Array(5)].map((t,e)=>({id:e,type:"tank",col:Math.floor(e/2)-1,row:-6+e%2+Math.floor(e/2),sizeCol:3,sizeRow:3,command:"advance"})),...[...Array(3)].map((t,e)=>({id:e+5,type:"tank",col:(e-1)*2,row:-2,sizeCol:3,sizeRow:3,command:"advance"})),...[...Array(2)].map((t,e)=>({id:e+8,type:"artillery",col:e*4-2,row:2,sizeCol:3,sizeRow:2,command:"advance"})),...[...Array(4)].map((t,e)=>({id:e+10,type:"warrior",col:e<2?-6:6,row:-4+e%2*2,sizeCol:2,sizeRow:2,command:"advance"}))],N3="Cavalry Charge";function T3(t){const e=Qe(tc),n=Qe(t),s=nt(tc),r=nt(t),o=lt(tc),i=lt(t),a=At(tc),l=At(t);let c=.5;return c+=(e.tank-n.tank)*.03,c-=(n.warrior+n.artillery)*.02,c+=(s.front-r.front)*.1,c+=(l-a)*.1,c+=(o-i)*.2,c+=Math.max(0,n.archer-e.archer)*.01,Math.max(0,Math.min(1,c))}const E3=Object.freeze(Object.defineProperty({__proto__:null,name:N3,probabilityScore:T3,units:tc},Symbol.toStringTag,{value:"Module"})),nc=[...[...Array(7)].map((t,e)=>({id:e,type:"artillery",col:e*3-9,row:2,sizeCol:3,sizeRow:2,command:"advance"})),...[...Array(4)].map((t,e)=>({id:e+7,type:"artillery",col:e*4-6,row:0,sizeCol:3,sizeRow:2,command:"advance"})),...[...Array(3)].map((t,e)=>({id:e+11,type:"tank",col:e*6-6,row:-4,sizeCol:4,sizeRow:3,command:"wait-advance"})),...[...Array(5)].map((t,e)=>({id:e+14,type:"warrior",col:e*4-8,row:-6,sizeCol:3,sizeRow:2,command:"wait-advance"}))],R3="Artillery Barrage";function A3(t){const e=Qe(nc),n=Qe(t),s=nt(nc),r=nt(t),o=lt(nc),i=lt(t),a=At(nc),l=At(t);let c=.5;return c+=(e.artillery-n.artillery)*.04,c-=(n.tank+n.warrior)*.02,c+=(l-a)*.15,c+=(r.front-s.front)*.1,c+=(i-o)*.1,c+=Math.max(0,n.archer-e.archer)*.02,c-=Math.max(0,n.tank-e.tank)*.03,Math.max(0,Math.min(1,c))}const D3=Object.freeze(Object.defineProperty({__proto__:null,name:R3,probabilityScore:A3,units:nc},Symbol.toStringTag,{value:"Module"})),Jo=(t,e,n)=>[{id:t,type:"warrior",col:e-1,row:n-1,sizeCol:2,sizeRow:2,command:"advance"},{id:t+1,type:"archer",col:e,row:n,sizeCol:2,sizeRow:2,command:"advance"},{id:t+2,type:"tank",col:e+1,row:n+1,sizeCol:3,sizeRow:3,command:"advance"}],Ah=[...Jo(0,-10,-5),...Jo(3,0,-6),...Jo(6,10,-5),...Jo(9,-8,0),...Jo(12,8,0),...Jo(15,-5,5),...Jo(18,5,5),...[...Array(2)].map((t,e)=>({id:21+e,type:"artillery",col:e*10-5,row:8,sizeCol:3,sizeRow:2,command:"advance"}))],_3="Guerrilla Tactics";function F3(t){const e=Qe(Ah),n=Qe(t),s=nt(t),r=lt(Ah),o=lt(t),i=At(Ah),a=At(t);let l=.5;l+=(i-a)*.2,l+=(Math.abs(s.front-.5)+Math.abs(s.center-.5))*.15,l+=(o-r)*.15;const c=Math.min(e.warrior,e.archer,e.tank,e.artillery)/Math.max(e.warrior,e.archer,e.tank,e.artillery);l+=c*.1;const u=Math.max(n.warrior-e.warrior,n.archer-e.archer,n.tank-e.tank,n.artillery-e.artillery);return l-=Math.max(0,u)*.02,Math.max(0,Math.min(1,l))}const z3=Object.freeze(Object.defineProperty({__proto__:null,name:_3,probabilityScore:F3,units:Ah},Symbol.toStringTag,{value:"Module"})),sc=[...[...Array(12)].map((t,e)=>({id:e,type:"warrior",col:e<3?-6:e<6?e-7.5:e<9?6:7.5-e,row:e<3?e-7.5:e<6?-6:e<9?7.5-e:6,sizeCol:2,sizeRow:2,command:"advance"})),...[...Array(3)].map((t,e)=>({id:e+12,type:"tank",col:e===0?-3:e===1?3:0,row:e===0?-3:e===1?3:-3,sizeCol:3,sizeRow:3,command:"wait-advance"})),...[...Array(6)].map((t,e)=>({id:e+15,type:"archer",col:e<3?-2:2,row:e%3-1,sizeCol:2,sizeRow:2,command:"advance"})),...[...Array(2)].map((t,e)=>({id:e+21,type:"artillery",col:e*2-1,row:-1,sizeCol:2,sizeRow:2,command:"advance"})),...[...Array(3)].map((t,e)=>({id:e+23,type:"warrior",col:(e-1)*2,row:-5,sizeCol:2,sizeRow:2,command:"wait-advance"}))],O3="Fortress Defense";function M3(t){const e=Qe(sc),n=Qe(t),s=nt(sc),r=nt(t),o=lt(sc),i=lt(t),a=At(sc),l=At(t);let c=.5;c+=(l-a)*.2,c+=(e.warrior+e.tank-n.warrior-n.tank)*.02,c+=(e.artillery-n.artillery)*.03,c+=(r.front-s.front)*.15,c+=(s.center-r.center)*.1;const u=e.archer+e.artillery,d=n.archer+n.artillery;return c-=Math.max(0,d-u)*.02,c+=(i-o)*.1,Math.max(0,Math.min(1,c))}const P3=Object.freeze(Object.defineProperty({__proto__:null,name:O3,probabilityScore:M3,units:sc},Symbol.toStringTag,{value:"Module"})),L3=[{id:301,col:-14,row:-2,sizeCol:4,sizeRow:3,type:"tank",command:"flank-left"},{id:302,col:-18,row:-6,sizeCol:4,sizeRow:2,type:"archer",command:"flank-left"},{id:303,col:-16,row:2,sizeCol:6,sizeRow:2,type:"warrior",command:"flank-left"},{id:304,col:-4,row:0,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:305,col:4,row:0,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:306,col:0,row:-6,sizeCol:6,sizeRow:2,type:"artillery",command:"advance"},{id:307,col:14,row:-2,sizeCol:4,sizeRow:3,type:"tank",command:"flank-right"},{id:308,col:18,row:-6,sizeCol:4,sizeRow:2,type:"archer",command:"flank-right"},{id:309,col:16,row:2,sizeCol:6,sizeRow:2,type:"warrior",command:"flank-right"}],B3="Pincer Attack",V3=t=>{const e=Qe(t),n=nt(t),s=At(t),r=1-(n.left+n.right)/2,o=1-Math.max(Math.abs(e.warrior-e.archer),Math.abs(e.warrior-e.tank),Math.abs(e.warrior-e.artillery),Math.abs(e.archer-e.tank),Math.abs(e.archer-e.artillery),Math.abs(e.tank-e.artillery))/t.length,i=1-s;return(r*.4+o*.3+i*.3)*100},W3=Object.freeze(Object.defineProperty({__proto__:null,name:B3,probabilityScore:V3,units:L3},Symbol.toStringTag,{value:"Module"})),U3=[{id:401,col:-16,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"wait-advance"},{id:402,col:0,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"wait-advance"},{id:403,col:16,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"wait-advance"},{id:404,col:-12,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"advance"},{id:405,col:0,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"advance"},{id:406,col:12,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"advance"},{id:407,col:0,row:-8,sizeCol:8,sizeRow:2,type:"artillery",command:"advance"},{id:408,col:-16,row:-6,sizeCol:4,sizeRow:4,type:"tank",command:"wait-advance"},{id:409,col:16,row:-6,sizeCol:4,sizeRow:4,type:"tank",command:"wait-advance"}],G3="Shield Wall",H3=t=>{const e=Qe(t),n=nt(t),s=At(t),r=lt(t),o=(e.warrior+e.tank)/t.length,i=n.front,a=s,l=r;return(o*.35+i*.25+a*.2+l*.2)*100},j3=Object.freeze(Object.defineProperty({__proto__:null,name:G3,probabilityScore:H3,units:U3},Symbol.toStringTag,{value:"Module"})),K3=[{id:501,col:-4,row:2,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:502,col:4,row:2,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:503,col:0,row:0,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:504,col:-10,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:505,col:10,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:506,col:0,row:-6,sizeCol:8,sizeRow:2,type:"artillery",command:"advance"},{id:507,col:-16,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"advance"},{id:508,col:16,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"advance"}],X3="Blitzkrieg",q3=t=>{const e=Qe(t),n=nt(t),s=At(t),r=lt(t),o=1-e.tank/t.length,i=1-(n.left+n.right)/2,a=1-s,l=1-r,c=n.front;return(o*.25+i*.2+a*.2+l*.15+c*.2)*100},Y3=Object.freeze(Object.defineProperty({__proto__:null,name:X3,probabilityScore:q3,units:K3},Symbol.toStringTag,{value:"Module"})),Q3=[{id:601,col:-16,row:-8,sizeCol:6,sizeRow:2,type:"artillery",command:"advance"},{id:602,col:0,row:-8,sizeCol:6,sizeRow:2,type:"artillery",command:"advance"},{id:603,col:16,row:-8,sizeCol:6,sizeRow:2,type:"artillery",command:"advance"},{id:604,col:-12,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"advance"},{id:605,col:0,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"advance"},{id:606,col:12,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"advance"},{id:607,col:-16,row:0,sizeCol:6,sizeRow:2,type:"warrior",command:"wait-advance"},{id:608,col:0,row:0,sizeCol:6,sizeRow:2,type:"warrior",command:"wait-advance"},{id:609,col:16,row:0,sizeCol:6,sizeRow:2,type:"warrior",command:"wait-advance"},{id:610,col:-10,row:-6,sizeCol:4,sizeRow:4,type:"tank",command:"wait-advance"},{id:611,col:10,row:-6,sizeCol:4,sizeRow:4,type:"tank",command:"wait-advance"}],Z3="Scorched Earth",J3=t=>{const e=Qe(t),n=nt(t),s=At(t),r=lt(t),o=1-(e.artillery+e.archer)/t.length,i=s,a=n.front,l=r,c=(e.warrior+e.tank)/t.length;return(o*.25+i*.2+a*.2+l*.15+c*.2)*100},eM=Object.freeze(Object.defineProperty({__proto__:null,name:Z3,probabilityScore:J3,units:Q3},Symbol.toStringTag,{value:"Module"})),tM=[{id:701,col:-8,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"advance"},{id:702,col:8,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"advance"},{id:703,col:-8,row:-4,sizeCol:4,sizeRow:4,type:"tank",command:"wait-advance"},{id:704,col:0,row:-4,sizeCol:4,sizeRow:4,type:"tank",command:"wait-advance"},{id:705,col:8,row:-4,sizeCol:4,sizeRow:4,type:"tank",command:"wait-advance"},{id:706,col:-12,row:-8,sizeCol:6,sizeRow:2,type:"artillery",command:"advance-wait"},{id:707,col:12,row:-8,sizeCol:6,sizeRow:2,type:"artillery",command:"advance-wait"},{id:708,col:-16,row:-6,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:709,col:0,row:-6,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:710,col:16,row:-6,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"}],nM="Trojan Horse",sM=t=>{const e=Qe(t),n=nt(t),s=At(t),r=lt(t),o=(e.warrior+e.tank)/t.length,i=n.front,a=1-s,l=1-(e.artillery+e.archer)/t.length,c=r;return(o*.3+i*.25+a*.15+l*.2+c*.1)*100},rM=Object.freeze(Object.defineProperty({__proto__:null,name:nM,probabilityScore:sM,units:tM},Symbol.toStringTag,{value:"Module"})),oM=[{id:801,col:0,row:2,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:802,col:-4,row:0,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:803,col:-8,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:804,col:-12,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:805,col:-16,row:-6,sizeCol:6,sizeRow:2,type:"artillery",command:"advance"},{id:806,col:4,row:0,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:807,col:8,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:808,col:12,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:809,col:16,row:-6,sizeCol:6,sizeRow:2,type:"artillery",command:"advance"},{id:810,col:0,row:-4,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"}],iM="Flying V",aM=t=>{const e=Qe(t),n=nt(t),s=At(t),r=lt(t),o=1-(n.left+n.right)/2,i=1-Math.max(Math.abs(e.warrior-e.archer),Math.abs(e.warrior-e.tank),Math.abs(e.warrior-e.artillery),Math.abs(e.archer-e.tank),Math.abs(e.archer-e.artillery),Math.abs(e.tank-e.artillery))/t.length,a=s,l=n.front,c=1-r;return(o*.3+i*.2+a*.15+l*.25+c*.1)*100},lM=Object.freeze(Object.defineProperty({__proto__:null,name:iM,probabilityScore:aM,units:oM},Symbol.toStringTag,{value:"Module"})),cM=[{id:901,col:-8,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"wait-advance"},{id:902,col:8,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"wait-advance"},{id:903,col:-4,row:-2,sizeCol:4,sizeRow:4,type:"tank",command:"wait-advance"},{id:904,col:4,row:-2,sizeCol:4,sizeRow:4,type:"tank",command:"wait-advance"},{id:905,col:-16,row:-4,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:906,col:-20,row:-6,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:907,col:16,row:-4,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:908,col:20,row:-6,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:909,col:-12,row:-6,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:910,col:12,row:-6,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:911,col:0,row:-8,sizeCol:6,sizeRow:2,type:"artillery",command:"wait-advance"}],uM="Hammer and Anvil",dM=t=>{const e=Qe(t),n=nt(t),s=At(t),r=lt(t),o=1-(n.left+n.right)/2,i=(e.warrior+e.tank)/t.length,a=1-s,l=n.front,c=r,u=1-(e.artillery+e.archer)/t.length;return(o*.25+i*.2+a*.15+l*.2+c*.1+u*.1)*100},hM=Object.freeze(Object.defineProperty({__proto__:null,name:uM,probabilityScore:dM,units:cM},Symbol.toStringTag,{value:"Module"})),fM=[{id:1001,col:12,row:2,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:1002,col:8,row:0,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:1003,col:4,row:-2,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:1004,col:0,row:-4,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:1005,col:-4,row:-6,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:1006,col:-8,row:-8,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:1007,col:12,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:1008,col:0,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:1009,col:-16,row:-12,sizeCol:6,sizeRow:2,type:"artillery",command:"advance"}],pM="Echelon Formation",mM=t=>{const e=Qe(t),n=nt(t),s=At(t),r=lt(t),o=Math.abs(n.left-n.right),i=1-Math.max(Math.abs(e.warrior-e.archer),Math.abs(e.warrior-e.tank),Math.abs(e.warrior-e.artillery),Math.abs(e.archer-e.tank),Math.abs(e.archer-e.artillery),Math.abs(e.tank-e.artillery))/t.length,a=s,l=1-e.artillery/t.length,c=1-r;return(o*.25+i*.2+a*.2+l*.25+c*.1)*100},gM=Object.freeze(Object.defineProperty({__proto__:null,name:pM,probabilityScore:mM,units:fM},Symbol.toStringTag,{value:"Module"})),xM=[{id:1101,col:-6,row:2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:1102,col:6,row:2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:1103,col:-8,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:1104,col:8,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:1105,col:-6,row:-6,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:1106,col:6,row:-6,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:1107,col:-3,row:-2,sizeCol:3,sizeRow:3,type:"tank",command:"advance"},{id:1108,col:3,row:-2,sizeCol:3,sizeRow:3,type:"tank",command:"advance"},{id:1109,col:-4,row:-4,sizeCol:3,sizeRow:2,type:"archer",command:"advance"},{id:1110,col:4,row:-4,sizeCol:3,sizeRow:2,type:"archer",command:"advance"},{id:1111,col:0,row:-4,sizeCol:4,sizeRow:2,type:"artillery",command:"advance"}],yM="Turtle Formation",wM=t=>{const e=Qe(t),n=nt(t),s=At(t),r=lt(t),o=(e.warrior+e.tank)/t.length,i=1-s,a=r,l=1-e.artillery/t.length,c=1-(e.artillery+e.archer)/t.length,u=n.front;return(o*.25+i*.2+a*.15+l*.2+c*.1+u*.1)*100},vM=Object.freeze(Object.defineProperty({__proto__:null,name:yM,probabilityScore:wM,units:xM},Symbol.toStringTag,{value:"Module"})),bM=[{id:1201,col:-12,row:2,sizeCol:3,sizeRow:2,type:"archer",command:"wait-advance"},{id:1202,col:-4,row:2,sizeCol:3,sizeRow:2,type:"archer",command:"wait-advance"},{id:1203,col:4,row:2,sizeCol:3,sizeRow:2,type:"archer",command:"wait-advance"},{id:1204,col:12,row:2,sizeCol:3,sizeRow:2,type:"archer",command:"wait-advance"},{id:1205,col:-8,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:1206,col:8,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:1207,col:-6,row:-6,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:1208,col:6,row:-6,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:1209,col:-8,row:-10,sizeCol:6,sizeRow:2,type:"artillery",command:"advance"},{id:1210,col:8,row:-10,sizeCol:6,sizeRow:2,type:"artillery",command:"advance"}],CM="Skirmisher Screen",kM=t=>{const e=Qe(t),n=nt(t),s=At(t),r=lt(t),o=(e.tank+e.artillery)/t.length,i=s,a=r,l=1-e.archer/t.length,c=n.front,u=1-e.warrior/t.length;return(o*.25+i*.2+a*.15+l*.15+c*.15+u*.1)*100},SM=Object.freeze(Object.defineProperty({__proto__:null,name:CM,probabilityScore:kM,units:bM},Symbol.toStringTag,{value:"Module"})),cC=[HO,qO,JO,s3,a3,d3,m3,w3,k3,$3,E3,D3,z3,P3,W3,j3,Y3,eM,rM,lM,hM,gM,vM,SM];/** +`,iC=(t,e)=>({x:(t+el)*is,y:(e+tl)*Ur}),aC=(t,e)=>({col:Math.floor(t/is)-el,row:Math.floor(e/Ur)-tl}),WO=(t,e)=>{const[n,s]=ye.useState({isDragging:!1,draggedUnit:null,dragOffset:{x:0,y:0}}),r=ye.useCallback(l=>"touches"in l?{clientX:l.touches[0].clientX,clientY:l.touches[0].clientY}:{clientX:l.clientX,clientY:l.clientY},[]),o=ye.useCallback(l=>{const c=l.currentTarget,u=c.getBoundingClientRect(),{clientX:h,clientY:d}=r(l),{col:f,row:p}=aC((h-u.left)*(c.width/u.width),(d-u.top)*(c.height/u.height)),g=t.find(x=>f>=x.col&&f=x.row&&p{if(n.isDragging&&n.draggedUnit){const c=l.currentTarget,u=c.getBoundingClientRect(),{clientX:h,clientY:d}=r(l),{col:f,row:p}=aC((h-u.left)*(c.width/u.width)-n.dragOffset.x,(d-u.top)*(c.height/u.height)-n.dragOffset.y);e(g=>g.map(x=>x.id===n.draggedUnit.id?{...x,col:Math.max(-el,Math.min(f,So-el-x.sizeCol)),row:Math.max(-tl,Math.min(p,Io-tl-x.sizeRow))}:x))}},[n,e,r]),a=ye.useCallback(()=>{s({isDragging:!1,draggedUnit:null,dragOffset:{x:0,y:0}})},[]);return{isDragging:n.isDragging,handleDragStart:o,handleDragMove:i,handleDragEnd:a}},UO=t=>{const[e,n]=ye.useState(null),s=ye.useCallback((o,i)=>{const a=t.find(l=>o>=l.col&&o=l.row&&i{n(null)},[]);return{selectedUnit:e,handleUnitSelect:s,setSelectedUnit:n,clearSelection:r}};function lC(t,e){if(e.length===0)throw new Error("No AI plans available for selection");const n=e.map(r=>({plan:r,score:r.probabilityScore(t)}));n.sort((r,o)=>o.score-r.score);const s=n[0].plan;return console.log("Selected plan:",s.name,"with score:",n[0].score),console.log("All plan scores:"),n.forEach(({plan:r,score:o})=>{console.log(`${r.name}: ${o}`)}),s.units}function Qe(t){return t.reduce((e,n)=>(e[n.type]=(e[n.type]||0)+1,e),{tank:0,warrior:0,archer:0,artillery:0})}function nt(t){const e={left:0,center:0,right:0,front:0};t.forEach(s=>{s.col<-5?e.left++:s.col>5?e.right++:e.center++,s.row>-5&&e.front++});const n=t.length;return{left:e.left/n,center:e.center/n,right:e.right/n,front:e.front/n}}function lt(t){return t.length===0?0:t.reduce((n,s)=>n+s.sizeCol*s.sizeRow,0)/(t.length*16)}function At(t){const e=t.map(i=>({x:i.col,y:i.row})),n=e.reduce((i,a)=>i+a.x,0)/e.length,s=e.reduce((i,a)=>i+a.y,0)/e.length,r=Math.sqrt(32*32+18*18);return e.reduce((i,a)=>{const l=a.x-n,c=a.y-s;return i+Math.sqrt(l*l+c*c)},0)/e.length/r}const Ox=[{id:201,col:-12,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"advance-wait"},{id:202,col:0,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"advance-wait"},{id:203,col:12,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"advance-wait"},{id:204,col:-8,row:-4,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:205,col:8,row:-4,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:206,col:-16,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:207,col:16,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:208,col:2,row:-8,sizeCol:8,sizeRow:1,type:"artillery",command:"wait-advance"}],GO="Balanced Assault",HO=t=>{const e=Qe(t),n=nt(t),s=1-Math.abs(.25-e.warrior/t.length)-Math.abs(.25-e.archer/t.length)-Math.abs(.25-e.tank/t.length)-Math.abs(.25-e.artillery/t.length),r=(n.left+n.right+n.center)/3,o=1-Math.abs(.5-lt(t));return(s*.5+r*.3+o*.2)*100},jO=Object.freeze(Object.defineProperty({__proto__:null,name:GO,probabilityScore:HO,units:Ox},Symbol.toStringTag,{value:"Module"})),KO=[{id:301,col:-16,row:0,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:302,col:16,row:0,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:303,col:0,row:-4,sizeCol:8,sizeRow:3,type:"artillery",command:"advance-wait"},{id:304,col:-12,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:305,col:12,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:306,col:-8,row:-6,sizeCol:4,sizeRow:3,type:"tank",command:"advance"},{id:307,col:8,row:-6,sizeCol:4,sizeRow:3,type:"tank",command:"advance"}],XO="Anti-Tank Defense",qO=t=>{const e=Qe(t),n=nt(t),s=e.tank/t.length,r=Math.min(s*2,1),o=n.center,i=lt(t.filter(a=>a.type==="tank"));return(r*.5+o*.3+i*.2)*100},YO=Object.freeze(Object.defineProperty({__proto__:null,name:XO,probabilityScore:qO,units:KO},Symbol.toStringTag,{value:"Module"})),QO=[{id:401,col:-12,row:-2,sizeCol:4,sizeRow:2,type:"tank",command:"flank-left"},{id:402,col:12,row:-2,sizeCol:4,sizeRow:2,type:"tank",command:"flank-right"},{id:403,col:0,row:-6,sizeCol:6,sizeRow:3,type:"artillery",command:"wait-advance"},{id:404,col:-16,row:0,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:405,col:16,row:0,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:406,col:-8,row:-10,sizeCol:4,sizeRow:3,type:"tank",command:"advance"},{id:407,col:8,row:-10,sizeCol:4,sizeRow:3,type:"tank",command:"advance"},{id:408,col:-4,row:-4,sizeCol:4,sizeRow:2,type:"warrior",command:"advance"},{id:409,col:4,row:-4,sizeCol:4,sizeRow:2,type:"warrior",command:"advance"}],ZO="Archer Counter",JO=t=>{const e=Qe(t),n=nt(t),s=e.archer/t.length,r=Math.min(s*2,1),o=Math.max(n.left,n.right),i=1-lt(t.filter(a=>a.type==="archer"));return(r*.5+o*.3+i*.2)*100},e3=Object.freeze(Object.defineProperty({__proto__:null,name:ZO,probabilityScore:JO,units:QO},Symbol.toStringTag,{value:"Module"})),t3=[{id:501,col:-12,row:0,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:502,col:12,row:0,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:503,col:-8,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"flank-left"},{id:504,col:8,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"flank-right"},{id:505,col:-16,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:506,col:16,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:507,col:0,row:-6,sizeCol:6,sizeRow:3,type:"artillery",command:"wait-advance"},{id:508,col:-4,row:-2,sizeCol:4,sizeRow:2,type:"warrior",command:"advance"},{id:509,col:4,row:-2,sizeCol:4,sizeRow:2,type:"warrior",command:"advance"}],n3="Warrior Blitz",s3=t=>{const e=Qe(t),n=nt(t),s=e.tank/t.length,r=(e.warrior+e.archer)/t.length,o=(1-s)*.5+r*.5,i=n.center,a=1-lt(t);return(o*.4+i*.4+a*.2)*100},r3=Object.freeze(Object.defineProperty({__proto__:null,name:n3,probabilityScore:s3,units:t3},Symbol.toStringTag,{value:"Module"})),o3=[{id:601,col:-12,row:-4,sizeCol:4,sizeRow:4,type:"tank",command:"advance-wait"},{id:602,col:12,row:-4,sizeCol:4,sizeRow:4,type:"tank",command:"advance-wait"},{id:603,col:-16,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"advance"},{id:604,col:16,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"advance"},{id:605,col:0,row:-8,sizeCol:8,sizeRow:2,type:"artillery",command:"wait-advance"},{id:606,col:-8,row:-10,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:607,col:8,row:-10,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:608,col:0,row:-12,sizeCol:8,sizeRow:2,type:"artillery",command:"wait-advance"},{id:609,col:0,row:-2,sizeCol:8,sizeRow:2,type:"warrior",command:"advance"}],i3="Tank Formation",a3=t=>{const e=Qe(t),n=nt(t),s=(e.warrior+e.archer)/t.length,r=Math.min(s*1.5,1),o=1-n.center,i=1-lt(t);return(r*.4+o*.4+i*.2)*100},l3=Object.freeze(Object.defineProperty({__proto__:null,name:i3,probabilityScore:a3,units:o3},Symbol.toStringTag,{value:"Module"})),c3=[{id:701,col:-16,row:-4,sizeCol:6,sizeRow:3,type:"artillery",command:"advance"},{id:702,col:16,row:-4,sizeCol:6,sizeRow:3,type:"artillery",command:"advance"},{id:703,col:0,row:0,sizeCol:6,sizeRow:3,type:"tank",command:"advance-wait"},{id:704,col:-8,row:-10,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:705,col:8,row:-10,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:706,col:-12,row:-12,sizeCol:4,sizeRow:3,type:"tank",command:"advance"},{id:707,col:12,row:-12,sizeCol:4,sizeRow:3,type:"tank",command:"advance"},{id:708,col:0,row:-6,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"}],u3="Artillery Strike",h3=t=>{const e=Qe(t),n=nt(t),s=(e.tank+e.artillery)/t.length,r=Math.min(s*2,1),o=Math.max(n.left,n.center,n.right),i=lt(t);return(r*.4+o*.4+i*.2)*100},d3=Object.freeze(Object.defineProperty({__proto__:null,name:u3,probabilityScore:h3,units:c3},Symbol.toStringTag,{value:"Module"})),f3=[{id:801,col:-16,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:802,col:-8,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:803,col:0,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:804,col:8,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:805,col:16,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:806,col:-12,row:-10,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:807,col:12,row:-10,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:808,col:0,row:-14,sizeCol:8,sizeRow:2,type:"artillery",command:"wait-advance"},{id:809,col:-20,row:-6,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:810,col:20,row:-6,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:811,col:-4,row:-8,sizeCol:4,sizeRow:2,type:"warrior",command:"advance"},{id:812,col:4,row:-8,sizeCol:4,sizeRow:2,type:"warrior",command:"advance"}],p3="Archer Ambush",m3=t=>{const e=Qe(t),n=nt(t),s=(e.warrior+e.tank)/t.length,r=Math.min(s*1.5,1),o=n.center+n.front*.5,i=lt(t);return(r*.4+o*.4+i*.2)*100},g3=Object.freeze(Object.defineProperty({__proto__:null,name:p3,probabilityScore:m3,units:f3},Symbol.toStringTag,{value:"Module"})),x3=[{id:301,col:-16,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:302,col:-8,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:303,col:8,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:304,col:16,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:305,col:-12,row:-4,sizeCol:8,sizeRow:2,type:"artillery",command:"wait-advance"},{id:306,col:12,row:-4,sizeCol:8,sizeRow:2,type:"artillery",command:"wait-advance"},{id:307,col:-8,row:0,sizeCol:4,sizeRow:4,type:"tank",command:"wait-advance"},{id:308,col:8,row:0,sizeCol:4,sizeRow:4,type:"tank",command:"wait-advance"},{id:309,col:0,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:310,col:-16,row:-2,sizeCol:4,sizeRow:2,type:"warrior",command:"flank-left"},{id:311,col:16,row:-2,sizeCol:4,sizeRow:2,type:"warrior",command:"flank-right"}],y3="Warrior Counter",w3=t=>{const e=Qe(t),n=t.length,s=(e.warrior||0)/n,r=At(t),o=Math.min(s*2,1),i=1-r,a=1-lt(t.filter(l=>l.type==="warrior"));return(o*.5+i*.3+a*.2)*100},v3=Object.freeze(Object.defineProperty({__proto__:null,name:y3,probabilityScore:w3,units:x3},Symbol.toStringTag,{value:"Module"})),b3=[{id:301,col:-6,row:0,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:302,col:6,row:0,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:303,col:-10,row:-4,sizeCol:3,sizeRow:2,type:"warrior",command:"advance"},{id:304,col:-5,row:-4,sizeCol:3,sizeRow:2,type:"warrior",command:"advance"},{id:305,col:0,row:-4,sizeCol:3,sizeRow:2,type:"warrior",command:"advance"},{id:306,col:5,row:-4,sizeCol:3,sizeRow:2,type:"warrior",command:"advance"},{id:307,col:10,row:-4,sizeCol:3,sizeRow:2,type:"warrior",command:"advance"},{id:308,col:-12,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:309,col:0,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:310,col:12,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:311,col:-12,row:-12,sizeCol:8,sizeRow:2,type:"artillery",command:"wait-advance"},{id:312,col:12,row:-12,sizeCol:8,sizeRow:2,type:"artillery",command:"wait-advance"}],C3="Artillery Counter",k3=t=>{const e=Qe(t),n=nt(t),s=Math.min(e.artillery/t.length,.5)*2,r=n.center,o=lt(t);return(s*.6+r*.2+o*.2)*100},S3=Object.freeze(Object.defineProperty({__proto__:null,name:C3,probabilityScore:k3,units:b3},Symbol.toStringTag,{value:"Module"})),Rd=[...[...Array(10)].map((t,e)=>({id:e,type:"warrior",col:-2+e%5,row:-4+Math.floor(e/5),sizeCol:2,sizeRow:2,command:"advance"})),...[...Array(5)].map((t,e)=>({id:e+10,type:"archer",col:-2+e,row:-2,sizeCol:2,sizeRow:2,command:"advance"})),...[...Array(3)].map((t,e)=>({id:e+15,type:"artillery",col:-3+e*3,row:0,sizeCol:3,sizeRow:2,command:"advance"})),...[...Array(4)].map((t,e)=>({id:e+18,type:"warrior",col:e<2?-4:4,row:-5+e%2*2,sizeCol:2,sizeRow:2,command:"advance"})),...[...Array(4)].map((t,e)=>({id:e+22,type:"archer",col:e<2?-5:5,row:-4+e%2*2,sizeCol:2,sizeRow:2,command:"advance"}))],I3="Phalanx Formation";function $3(t){const e=Qe(Rd),n=Qe(t),s=nt(Rd),r=nt(t),o=At(Rd),i=At(t);let a=.5;return a+=(e.warrior-n.warrior)*.02,a+=(n.tank-e.tank)*.03,a+=(s.center-r.center)*.1,a+=(i-o)*.1,a-=Math.max(0,n.archer-e.archer)*.01,a-=Math.max(0,n.artillery-e.artillery)*.01,Math.max(0,Math.min(1,a))}const N3=Object.freeze(Object.defineProperty({__proto__:null,name:I3,probabilityScore:$3,units:Rd},Symbol.toStringTag,{value:"Module"})),tc=[...[...Array(5)].map((t,e)=>({id:e,type:"tank",col:Math.floor(e/2)-1,row:-6+e%2+Math.floor(e/2),sizeCol:3,sizeRow:3,command:"advance"})),...[...Array(3)].map((t,e)=>({id:e+5,type:"tank",col:(e-1)*2,row:-2,sizeCol:3,sizeRow:3,command:"advance"})),...[...Array(2)].map((t,e)=>({id:e+8,type:"artillery",col:e*4-2,row:2,sizeCol:3,sizeRow:2,command:"advance"})),...[...Array(4)].map((t,e)=>({id:e+10,type:"warrior",col:e<2?-6:6,row:-4+e%2*2,sizeCol:2,sizeRow:2,command:"advance"}))],T3="Cavalry Charge";function E3(t){const e=Qe(tc),n=Qe(t),s=nt(tc),r=nt(t),o=lt(tc),i=lt(t),a=At(tc),l=At(t);let c=.5;return c+=(e.tank-n.tank)*.03,c-=(n.warrior+n.artillery)*.02,c+=(s.front-r.front)*.1,c+=(l-a)*.1,c+=(o-i)*.2,c+=Math.max(0,n.archer-e.archer)*.01,Math.max(0,Math.min(1,c))}const R3=Object.freeze(Object.defineProperty({__proto__:null,name:T3,probabilityScore:E3,units:tc},Symbol.toStringTag,{value:"Module"})),nc=[...[...Array(7)].map((t,e)=>({id:e,type:"artillery",col:e*3-9,row:2,sizeCol:3,sizeRow:2,command:"advance"})),...[...Array(4)].map((t,e)=>({id:e+7,type:"artillery",col:e*4-6,row:0,sizeCol:3,sizeRow:2,command:"advance"})),...[...Array(3)].map((t,e)=>({id:e+11,type:"tank",col:e*6-6,row:-4,sizeCol:4,sizeRow:3,command:"wait-advance"})),...[...Array(5)].map((t,e)=>({id:e+14,type:"warrior",col:e*4-8,row:-6,sizeCol:3,sizeRow:2,command:"wait-advance"}))],A3="Artillery Barrage";function D3(t){const e=Qe(nc),n=Qe(t),s=nt(nc),r=nt(t),o=lt(nc),i=lt(t),a=At(nc),l=At(t);let c=.5;return c+=(e.artillery-n.artillery)*.04,c-=(n.tank+n.warrior)*.02,c+=(l-a)*.15,c+=(r.front-s.front)*.1,c+=(i-o)*.1,c+=Math.max(0,n.archer-e.archer)*.02,c-=Math.max(0,n.tank-e.tank)*.03,Math.max(0,Math.min(1,c))}const _3=Object.freeze(Object.defineProperty({__proto__:null,name:A3,probabilityScore:D3,units:nc},Symbol.toStringTag,{value:"Module"})),Jo=(t,e,n)=>[{id:t,type:"warrior",col:e-1,row:n-1,sizeCol:2,sizeRow:2,command:"advance"},{id:t+1,type:"archer",col:e,row:n,sizeCol:2,sizeRow:2,command:"advance"},{id:t+2,type:"tank",col:e+1,row:n+1,sizeCol:3,sizeRow:3,command:"advance"}],Ad=[...Jo(0,-10,-5),...Jo(3,0,-6),...Jo(6,10,-5),...Jo(9,-8,0),...Jo(12,8,0),...Jo(15,-5,5),...Jo(18,5,5),...[...Array(2)].map((t,e)=>({id:21+e,type:"artillery",col:e*10-5,row:8,sizeCol:3,sizeRow:2,command:"advance"}))],F3="Guerrilla Tactics";function z3(t){const e=Qe(Ad),n=Qe(t),s=nt(t),r=lt(Ad),o=lt(t),i=At(Ad),a=At(t);let l=.5;l+=(i-a)*.2,l+=(Math.abs(s.front-.5)+Math.abs(s.center-.5))*.15,l+=(o-r)*.15;const c=Math.min(e.warrior,e.archer,e.tank,e.artillery)/Math.max(e.warrior,e.archer,e.tank,e.artillery);l+=c*.1;const u=Math.max(n.warrior-e.warrior,n.archer-e.archer,n.tank-e.tank,n.artillery-e.artillery);return l-=Math.max(0,u)*.02,Math.max(0,Math.min(1,l))}const O3=Object.freeze(Object.defineProperty({__proto__:null,name:F3,probabilityScore:z3,units:Ad},Symbol.toStringTag,{value:"Module"})),sc=[...[...Array(12)].map((t,e)=>({id:e,type:"warrior",col:e<3?-6:e<6?e-7.5:e<9?6:7.5-e,row:e<3?e-7.5:e<6?-6:e<9?7.5-e:6,sizeCol:2,sizeRow:2,command:"advance"})),...[...Array(3)].map((t,e)=>({id:e+12,type:"tank",col:e===0?-3:e===1?3:0,row:e===0?-3:e===1?3:-3,sizeCol:3,sizeRow:3,command:"wait-advance"})),...[...Array(6)].map((t,e)=>({id:e+15,type:"archer",col:e<3?-2:2,row:e%3-1,sizeCol:2,sizeRow:2,command:"advance"})),...[...Array(2)].map((t,e)=>({id:e+21,type:"artillery",col:e*2-1,row:-1,sizeCol:2,sizeRow:2,command:"advance"})),...[...Array(3)].map((t,e)=>({id:e+23,type:"warrior",col:(e-1)*2,row:-5,sizeCol:2,sizeRow:2,command:"wait-advance"}))],M3="Fortress Defense";function P3(t){const e=Qe(sc),n=Qe(t),s=nt(sc),r=nt(t),o=lt(sc),i=lt(t),a=At(sc),l=At(t);let c=.5;c+=(l-a)*.2,c+=(e.warrior+e.tank-n.warrior-n.tank)*.02,c+=(e.artillery-n.artillery)*.03,c+=(r.front-s.front)*.15,c+=(s.center-r.center)*.1;const u=e.archer+e.artillery,h=n.archer+n.artillery;return c-=Math.max(0,h-u)*.02,c+=(i-o)*.1,Math.max(0,Math.min(1,c))}const L3=Object.freeze(Object.defineProperty({__proto__:null,name:M3,probabilityScore:P3,units:sc},Symbol.toStringTag,{value:"Module"})),B3=[{id:301,col:-14,row:-2,sizeCol:4,sizeRow:3,type:"tank",command:"flank-left"},{id:302,col:-18,row:-6,sizeCol:4,sizeRow:2,type:"archer",command:"flank-left"},{id:303,col:-16,row:2,sizeCol:6,sizeRow:2,type:"warrior",command:"flank-left"},{id:304,col:-4,row:0,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:305,col:4,row:0,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:306,col:0,row:-6,sizeCol:6,sizeRow:2,type:"artillery",command:"advance"},{id:307,col:14,row:-2,sizeCol:4,sizeRow:3,type:"tank",command:"flank-right"},{id:308,col:18,row:-6,sizeCol:4,sizeRow:2,type:"archer",command:"flank-right"},{id:309,col:16,row:2,sizeCol:6,sizeRow:2,type:"warrior",command:"flank-right"}],V3="Pincer Attack",W3=t=>{const e=Qe(t),n=nt(t),s=At(t),r=1-(n.left+n.right)/2,o=1-Math.max(Math.abs(e.warrior-e.archer),Math.abs(e.warrior-e.tank),Math.abs(e.warrior-e.artillery),Math.abs(e.archer-e.tank),Math.abs(e.archer-e.artillery),Math.abs(e.tank-e.artillery))/t.length,i=1-s;return(r*.4+o*.3+i*.3)*100},U3=Object.freeze(Object.defineProperty({__proto__:null,name:V3,probabilityScore:W3,units:B3},Symbol.toStringTag,{value:"Module"})),G3=[{id:401,col:-16,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"wait-advance"},{id:402,col:0,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"wait-advance"},{id:403,col:16,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"wait-advance"},{id:404,col:-12,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"advance"},{id:405,col:0,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"advance"},{id:406,col:12,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"advance"},{id:407,col:0,row:-8,sizeCol:8,sizeRow:2,type:"artillery",command:"advance"},{id:408,col:-16,row:-6,sizeCol:4,sizeRow:4,type:"tank",command:"wait-advance"},{id:409,col:16,row:-6,sizeCol:4,sizeRow:4,type:"tank",command:"wait-advance"}],H3="Shield Wall",j3=t=>{const e=Qe(t),n=nt(t),s=At(t),r=lt(t),o=(e.warrior+e.tank)/t.length,i=n.front,a=s,l=r;return(o*.35+i*.25+a*.2+l*.2)*100},K3=Object.freeze(Object.defineProperty({__proto__:null,name:H3,probabilityScore:j3,units:G3},Symbol.toStringTag,{value:"Module"})),X3=[{id:501,col:-4,row:2,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:502,col:4,row:2,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:503,col:0,row:0,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:504,col:-10,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:505,col:10,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:506,col:0,row:-6,sizeCol:8,sizeRow:2,type:"artillery",command:"advance"},{id:507,col:-16,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"advance"},{id:508,col:16,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"advance"}],q3="Blitzkrieg",Y3=t=>{const e=Qe(t),n=nt(t),s=At(t),r=lt(t),o=1-e.tank/t.length,i=1-(n.left+n.right)/2,a=1-s,l=1-r,c=n.front;return(o*.25+i*.2+a*.2+l*.15+c*.2)*100},Q3=Object.freeze(Object.defineProperty({__proto__:null,name:q3,probabilityScore:Y3,units:X3},Symbol.toStringTag,{value:"Module"})),Z3=[{id:601,col:-16,row:-8,sizeCol:6,sizeRow:2,type:"artillery",command:"advance"},{id:602,col:0,row:-8,sizeCol:6,sizeRow:2,type:"artillery",command:"advance"},{id:603,col:16,row:-8,sizeCol:6,sizeRow:2,type:"artillery",command:"advance"},{id:604,col:-12,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"advance"},{id:605,col:0,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"advance"},{id:606,col:12,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"advance"},{id:607,col:-16,row:0,sizeCol:6,sizeRow:2,type:"warrior",command:"wait-advance"},{id:608,col:0,row:0,sizeCol:6,sizeRow:2,type:"warrior",command:"wait-advance"},{id:609,col:16,row:0,sizeCol:6,sizeRow:2,type:"warrior",command:"wait-advance"},{id:610,col:-10,row:-6,sizeCol:4,sizeRow:4,type:"tank",command:"wait-advance"},{id:611,col:10,row:-6,sizeCol:4,sizeRow:4,type:"tank",command:"wait-advance"}],J3="Scorched Earth",eM=t=>{const e=Qe(t),n=nt(t),s=At(t),r=lt(t),o=1-(e.artillery+e.archer)/t.length,i=s,a=n.front,l=r,c=(e.warrior+e.tank)/t.length;return(o*.25+i*.2+a*.2+l*.15+c*.2)*100},tM=Object.freeze(Object.defineProperty({__proto__:null,name:J3,probabilityScore:eM,units:Z3},Symbol.toStringTag,{value:"Module"})),nM=[{id:701,col:-8,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"advance"},{id:702,col:8,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"advance"},{id:703,col:-8,row:-4,sizeCol:4,sizeRow:4,type:"tank",command:"wait-advance"},{id:704,col:0,row:-4,sizeCol:4,sizeRow:4,type:"tank",command:"wait-advance"},{id:705,col:8,row:-4,sizeCol:4,sizeRow:4,type:"tank",command:"wait-advance"},{id:706,col:-12,row:-8,sizeCol:6,sizeRow:2,type:"artillery",command:"advance-wait"},{id:707,col:12,row:-8,sizeCol:6,sizeRow:2,type:"artillery",command:"advance-wait"},{id:708,col:-16,row:-6,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:709,col:0,row:-6,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:710,col:16,row:-6,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"}],sM="Trojan Horse",rM=t=>{const e=Qe(t),n=nt(t),s=At(t),r=lt(t),o=(e.warrior+e.tank)/t.length,i=n.front,a=1-s,l=1-(e.artillery+e.archer)/t.length,c=r;return(o*.3+i*.25+a*.15+l*.2+c*.1)*100},oM=Object.freeze(Object.defineProperty({__proto__:null,name:sM,probabilityScore:rM,units:nM},Symbol.toStringTag,{value:"Module"})),iM=[{id:801,col:0,row:2,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:802,col:-4,row:0,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:803,col:-8,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:804,col:-12,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:805,col:-16,row:-6,sizeCol:6,sizeRow:2,type:"artillery",command:"advance"},{id:806,col:4,row:0,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:807,col:8,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:808,col:12,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:809,col:16,row:-6,sizeCol:6,sizeRow:2,type:"artillery",command:"advance"},{id:810,col:0,row:-4,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"}],aM="Flying V",lM=t=>{const e=Qe(t),n=nt(t),s=At(t),r=lt(t),o=1-(n.left+n.right)/2,i=1-Math.max(Math.abs(e.warrior-e.archer),Math.abs(e.warrior-e.tank),Math.abs(e.warrior-e.artillery),Math.abs(e.archer-e.tank),Math.abs(e.archer-e.artillery),Math.abs(e.tank-e.artillery))/t.length,a=s,l=n.front,c=1-r;return(o*.3+i*.2+a*.15+l*.25+c*.1)*100},cM=Object.freeze(Object.defineProperty({__proto__:null,name:aM,probabilityScore:lM,units:iM},Symbol.toStringTag,{value:"Module"})),uM=[{id:901,col:-8,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"wait-advance"},{id:902,col:8,row:0,sizeCol:8,sizeRow:2,type:"warrior",command:"wait-advance"},{id:903,col:-4,row:-2,sizeCol:4,sizeRow:4,type:"tank",command:"wait-advance"},{id:904,col:4,row:-2,sizeCol:4,sizeRow:4,type:"tank",command:"wait-advance"},{id:905,col:-16,row:-4,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:906,col:-20,row:-6,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:907,col:16,row:-4,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:908,col:20,row:-6,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:909,col:-12,row:-6,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:910,col:12,row:-6,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:911,col:0,row:-8,sizeCol:6,sizeRow:2,type:"artillery",command:"wait-advance"}],hM="Hammer and Anvil",dM=t=>{const e=Qe(t),n=nt(t),s=At(t),r=lt(t),o=1-(n.left+n.right)/2,i=(e.warrior+e.tank)/t.length,a=1-s,l=n.front,c=r,u=1-(e.artillery+e.archer)/t.length;return(o*.25+i*.2+a*.15+l*.2+c*.1+u*.1)*100},fM=Object.freeze(Object.defineProperty({__proto__:null,name:hM,probabilityScore:dM,units:uM},Symbol.toStringTag,{value:"Module"})),pM=[{id:1001,col:12,row:2,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:1002,col:8,row:0,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:1003,col:4,row:-2,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:1004,col:0,row:-4,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:1005,col:-4,row:-6,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:1006,col:-8,row:-8,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:1007,col:12,row:-4,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:1008,col:0,row:-8,sizeCol:4,sizeRow:2,type:"archer",command:"wait-advance"},{id:1009,col:-16,row:-12,sizeCol:6,sizeRow:2,type:"artillery",command:"advance"}],mM="Echelon Formation",gM=t=>{const e=Qe(t),n=nt(t),s=At(t),r=lt(t),o=Math.abs(n.left-n.right),i=1-Math.max(Math.abs(e.warrior-e.archer),Math.abs(e.warrior-e.tank),Math.abs(e.warrior-e.artillery),Math.abs(e.archer-e.tank),Math.abs(e.archer-e.artillery),Math.abs(e.tank-e.artillery))/t.length,a=s,l=1-e.artillery/t.length,c=1-r;return(o*.25+i*.2+a*.2+l*.25+c*.1)*100},xM=Object.freeze(Object.defineProperty({__proto__:null,name:mM,probabilityScore:gM,units:pM},Symbol.toStringTag,{value:"Module"})),yM=[{id:1101,col:-6,row:2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:1102,col:6,row:2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:1103,col:-8,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:1104,col:8,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:1105,col:-6,row:-6,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:1106,col:6,row:-6,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:1107,col:-3,row:-2,sizeCol:3,sizeRow:3,type:"tank",command:"advance"},{id:1108,col:3,row:-2,sizeCol:3,sizeRow:3,type:"tank",command:"advance"},{id:1109,col:-4,row:-4,sizeCol:3,sizeRow:2,type:"archer",command:"advance"},{id:1110,col:4,row:-4,sizeCol:3,sizeRow:2,type:"archer",command:"advance"},{id:1111,col:0,row:-4,sizeCol:4,sizeRow:2,type:"artillery",command:"advance"}],wM="Turtle Formation",vM=t=>{const e=Qe(t),n=nt(t),s=At(t),r=lt(t),o=(e.warrior+e.tank)/t.length,i=1-s,a=r,l=1-e.artillery/t.length,c=1-(e.artillery+e.archer)/t.length,u=n.front;return(o*.25+i*.2+a*.15+l*.2+c*.1+u*.1)*100},bM=Object.freeze(Object.defineProperty({__proto__:null,name:wM,probabilityScore:vM,units:yM},Symbol.toStringTag,{value:"Module"})),CM=[{id:1201,col:-12,row:2,sizeCol:3,sizeRow:2,type:"archer",command:"wait-advance"},{id:1202,col:-4,row:2,sizeCol:3,sizeRow:2,type:"archer",command:"wait-advance"},{id:1203,col:4,row:2,sizeCol:3,sizeRow:2,type:"archer",command:"wait-advance"},{id:1204,col:12,row:2,sizeCol:3,sizeRow:2,type:"archer",command:"wait-advance"},{id:1205,col:-8,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:1206,col:8,row:-2,sizeCol:6,sizeRow:2,type:"warrior",command:"advance"},{id:1207,col:-6,row:-6,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:1208,col:6,row:-6,sizeCol:4,sizeRow:4,type:"tank",command:"advance"},{id:1209,col:-8,row:-10,sizeCol:6,sizeRow:2,type:"artillery",command:"advance"},{id:1210,col:8,row:-10,sizeCol:6,sizeRow:2,type:"artillery",command:"advance"}],kM="Skirmisher Screen",SM=t=>{const e=Qe(t),n=nt(t),s=At(t),r=lt(t),o=(e.tank+e.artillery)/t.length,i=s,a=r,l=1-e.archer/t.length,c=n.front,u=1-e.warrior/t.length;return(o*.25+i*.2+a*.15+l*.15+c*.15+u*.1)*100},IM=Object.freeze(Object.defineProperty({__proto__:null,name:kM,probabilityScore:SM,units:CM},Symbol.toStringTag,{value:"Module"})),cC=[jO,YO,e3,r3,l3,d3,g3,v3,S3,N3,R3,_3,O3,L3,U3,K3,Q3,tM,oM,cM,fM,xM,bM,IM];/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -118,7 +118,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const IM=1e-7,$M=1e-4;class H2{constructor(e,n){this.backend=e,this.dataMover=n,this.data=new WeakMap,this.dataIdsCount=0}get(e){return this.data.has(e)||this.dataMover.moveData(this.backend,e),this.data.get(e)}set(e,n){this.dataIdsCount++,this.data.set(e,n)}has(e){return this.data.has(e)}delete(e){return this.dataIdsCount--,this.data.delete(e)}numDataIds(){return this.dataIdsCount}}class Mx{refCount(e){return Ln("refCount")}incRef(e){return Ln("incRef")}timerAvailable(){return!0}time(e){return Ln("time")}read(e){return Ln("read")}readSync(e){return Ln("readSync")}readToGPU(e,n){return Ln("readToGPU")}numDataIds(){return Ln("numDataIds")}disposeData(e,n){return Ln("disposeData")}write(e,n,s){return Ln("write")}move(e,n,s,r,o){return Ln("move")}createTensorFromGPUData(e,n,s){return Ln("createTensorFromGPUData")}memory(){return Ln("memory")}floatPrecision(){return Ln("floatPrecision")}epsilon(){return this.floatPrecision()===32?IM:$M}dispose(){return Ln("dispose")}}function Ln(t){throw new Error(`'${t}' not yet implemented or not found in the registry. This kernel may not be supported by the tfjs backend you have chosen`)}/** + */const $M=1e-7,NM=1e-4;class jI{constructor(e,n){this.backend=e,this.dataMover=n,this.data=new WeakMap,this.dataIdsCount=0}get(e){return this.data.has(e)||this.dataMover.moveData(this.backend,e),this.data.get(e)}set(e,n){this.dataIdsCount++,this.data.set(e,n)}has(e){return this.data.has(e)}delete(e){return this.dataIdsCount--,this.data.delete(e)}numDataIds(){return this.dataIdsCount}}class Mx{refCount(e){return Ln("refCount")}incRef(e){return Ln("incRef")}timerAvailable(){return!0}time(e){return Ln("time")}read(e){return Ln("read")}readSync(e){return Ln("readSync")}readToGPU(e,n){return Ln("readToGPU")}numDataIds(){return Ln("numDataIds")}disposeData(e,n){return Ln("disposeData")}write(e,n,s){return Ln("write")}move(e,n,s,r,o){return Ln("move")}createTensorFromGPUData(e,n,s){return Ln("createTensorFromGPUData")}memory(){return Ln("memory")}floatPrecision(){return Ln("floatPrecision")}epsilon(){return this.floatPrecision()===32?$M:NM}dispose(){return Ln("dispose")}}function Ln(t){throw new Error(`'${t}' not yet implemented or not found in the registry. This kernel may not be supported by the tfjs backend you have chosen`)}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -133,7 +133,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function NM(t){let e=t.length,n=0;for(;e>0;)n=Math.random()*e|0,e--,ha(t,e,n)}function Ti(t,e,n){return Math.max(t,Math.min(e,n))}function Px(t){return t%2===0?t:t+1}function ha(t,e,n){const s=t[e];t[e]=t[n],t[n]=s}function TM(t){let e=0;for(let n=0;nn+` Shapes ${t} and ${e} must match`)}function Bx(t){I(t!=null,()=>"The input to the tensor constructor must be a non-null value.")}function j(t){if(t.length===0)return 1;let e=t[0];for(let n=1;n0,n,s){return new Promise((r,o)=>{let i=0;const a=()=>{if(t()){r();return}i++;const l=e(i);if(n!=null&&i>=n){o();return}s!=null?s(a,l):setTimeout(a,l)};a()})}function j2(t,e){let n=1,s=-1;for(let o=0;o=0)n*=t[o];else if(t[o]===-1){if(s!==-1)throw Error(`Shapes can only have 1 implicit size. Found -1 at dim ${s} and dim ${o}`);s=o}else if(t[o]<0)throw Error(`Shapes can not be < 0. Found ${t[o]} at dim ${o}`);if(s===-1){if(e>0&&e!==n)throw Error(`Size(${e}) must match the product of shape ${t}`);return t}if(n===0)throw Error(`Cannot infer the missing size in [${t}] when there are 0 elements`);if(e%n!==0)throw Error(`The implicit shape can't be a fractional number. Got ${e} / ${n}`);const r=t.slice();return r[s]=e/n,r}function Re(t,e){const n=e.length;return t=t==null?e.map((s,r)=>r):[].concat(t),I(t.every(s=>s>=-n&&s`All values in axis param must be in range [-${n}, ${n}) but got axis ${t}`),I(t.every(s=>nl(s)),()=>`All values in axis param must be integers but got axis ${t}`),t.map(s=>s<0?n+s:s)}function Vo(t,e){const n=[],s=[],r=e!=null&&Array.isArray(e)&&e.length===0,o=e==null||r?null:Re(e,t).sort();let i=0;for(let a=0;aa)&&t[a]===1&&(n.push(t[a]),s.push(a)),o[i]<=a&&i++}t[a]!==1&&(n.push(t[a]),s.push(a))}return{newShape:n,keptDims:s}}function cn(t,e){return kt(t,e)}function kt(t,e){let n=null;if(t==null||t==="float32")n=new Float32Array(e);else if(t==="int32")n=new Int32Array(e);else if(t==="bool")n=new Uint8Array(e);else if(t==="string")n=new Array(e);else throw new Error(`Unknown data type ${t}`);return n}function EM(t,e){for(let n=0;ne+=n.length),e}function fu(t){return typeof t=="string"||t instanceof String}function DM(t){return typeof t=="boolean"}function q0(t){return typeof t=="number"}function wl(t){return Array.isArray(t)?wl(t[0]):t instanceof Float32Array?"float32":t instanceof Int32Array||t instanceof Uint8Array||t instanceof Uint8ClampedArray?"int32":q0(t)?"float32":fu(t)?"string":DM(t)?"bool":"float32"}function Y0(t){return!!(t&&t.constructor&&t.call&&t.apply)}function Q0(t,e){for(let n=e;n=0;--s)n[s]=n[s+1]*t[s+1];return n}function X2(t,e,n,s=!1){const r=new Array;if(e.length===1){const o=e[0]*(s?2:1);for(let i=0;il*c)*(s?2:1);for(let l=0;lr*o)*(n?2:1);if(s===0)return[];if(s!==e.length)throw new Error(`[${t}] does not match the input size ${e.length}${n?" for a complex tensor":""}.`);return X2(0,t,e,n)}function _M(t,e){if(Array.isArray(t))return t;if(e==="float32")return t instanceof Float32Array?t:new Float32Array(t);if(e==="int32")return t instanceof Int32Array?t:new Int32Array(t);if(e==="bool"||e==="string")return Uint8Array.from(new Int32Array(t));throw new Error(`Unknown dtype ${e}`)}function Vx(t,e){const n=un(t,e);for(let s=0;ss*r,1);if(e==null||e==="float32")return Xs(t,new Float32Array(n));if(e==="int32")return Xs(t,new Int32Array(n));if(e==="bool")return Xs(t,new Uint8Array(n));throw new Error(`Unknown data type ${e}`)}function Xr(t){t.forEach(e=>{I(Number.isInteger(e)&&e>=0,()=>`Tensor must have a shape comprised of positive integers but got shape [${t}].`)})}function gr(t,e,n){if(e===0)return 0;if(e===1)return t[0];let s=t[t.length-1];for(let r=0;r0;)n=Math.random()*e|0,e--,da(t,e,n)}function Ti(t,e,n){return Math.max(t,Math.min(e,n))}function Px(t){return t%2===0?t:t+1}function da(t,e,n){const s=t[e];t[e]=t[n],t[n]=s}function EM(t){let e=0;for(let n=0;nn+` Shapes ${t} and ${e} must match`)}function Bx(t){I(t!=null,()=>"The input to the tensor constructor must be a non-null value.")}function j(t){if(t.length===0)return 1;let e=t[0];for(let n=1;n0,n,s){return new Promise((r,o)=>{let i=0;const a=()=>{if(t()){r();return}i++;const l=e(i);if(n!=null&&i>=n){o();return}s!=null?s(a,l):setTimeout(a,l)};a()})}function KI(t,e){let n=1,s=-1;for(let o=0;o=0)n*=t[o];else if(t[o]===-1){if(s!==-1)throw Error(`Shapes can only have 1 implicit size. Found -1 at dim ${s} and dim ${o}`);s=o}else if(t[o]<0)throw Error(`Shapes can not be < 0. Found ${t[o]} at dim ${o}`);if(s===-1){if(e>0&&e!==n)throw Error(`Size(${e}) must match the product of shape ${t}`);return t}if(n===0)throw Error(`Cannot infer the missing size in [${t}] when there are 0 elements`);if(e%n!==0)throw Error(`The implicit shape can't be a fractional number. Got ${e} / ${n}`);const r=t.slice();return r[s]=e/n,r}function Re(t,e){const n=e.length;return t=t==null?e.map((s,r)=>r):[].concat(t),I(t.every(s=>s>=-n&&s`All values in axis param must be in range [-${n}, ${n}) but got axis ${t}`),I(t.every(s=>nl(s)),()=>`All values in axis param must be integers but got axis ${t}`),t.map(s=>s<0?n+s:s)}function Vo(t,e){const n=[],s=[],r=e!=null&&Array.isArray(e)&&e.length===0,o=e==null||r?null:Re(e,t).sort();let i=0;for(let a=0;aa)&&t[a]===1&&(n.push(t[a]),s.push(a)),o[i]<=a&&i++}t[a]!==1&&(n.push(t[a]),s.push(a))}return{newShape:n,keptDims:s}}function cn(t,e){return kt(t,e)}function kt(t,e){let n=null;if(t==null||t==="float32")n=new Float32Array(e);else if(t==="int32")n=new Int32Array(e);else if(t==="bool")n=new Uint8Array(e);else if(t==="string")n=new Array(e);else throw new Error(`Unknown data type ${t}`);return n}function RM(t,e){for(let n=0;ne+=n.length),e}function fu(t){return typeof t=="string"||t instanceof String}function _M(t){return typeof t=="boolean"}function q0(t){return typeof t=="number"}function wl(t){return Array.isArray(t)?wl(t[0]):t instanceof Float32Array?"float32":t instanceof Int32Array||t instanceof Uint8Array||t instanceof Uint8ClampedArray?"int32":q0(t)?"float32":fu(t)?"string":_M(t)?"bool":"float32"}function Y0(t){return!!(t&&t.constructor&&t.call&&t.apply)}function Q0(t,e){for(let n=e;n=0;--s)n[s]=n[s+1]*t[s+1];return n}function qI(t,e,n,s=!1){const r=new Array;if(e.length===1){const o=e[0]*(s?2:1);for(let i=0;il*c)*(s?2:1);for(let l=0;lr*o)*(n?2:1);if(s===0)return[];if(s!==e.length)throw new Error(`[${t}] does not match the input size ${e.length}${n?" for a complex tensor":""}.`);return qI(0,t,e,n)}function FM(t,e){if(Array.isArray(t))return t;if(e==="float32")return t instanceof Float32Array?t:new Float32Array(t);if(e==="int32")return t instanceof Int32Array?t:new Int32Array(t);if(e==="bool"||e==="string")return Uint8Array.from(new Int32Array(t));throw new Error(`Unknown dtype ${e}`)}function Vx(t,e){const n=un(t,e);for(let s=0;ss*r,1);if(e==null||e==="float32")return qs(t,new Float32Array(n));if(e==="int32")return qs(t,new Int32Array(n));if(e==="bool")return qs(t,new Uint8Array(n));throw new Error(`Unknown data type ${e}`)}function qr(t){t.forEach(e=>{I(Number.isInteger(e)&&e>=0,()=>`Tensor must have a shape comprised of positive integers but got shape [${t}].`)})}function xr(t,e,n){if(e===0)return 0;if(e===1)return t[0];let s=t[t.length-1];for(let r=0;r"u"||typeof this.global.location>"u"||typeof this.global.location.search>"u")return;const e=this.getQueryParams(this.global.location.search);dC in e&&e[dC].split(",").forEach(s=>{const[r,o]=s.split(":");this.urlFlags[r]=MM(r,o)})}}function zM(t){const e={};return t.replace(/[?&]([^=?&]+)(?:=([^&]*))?/g,(n,...s)=>(OM(e,s[0],s[1]),s.join("="))),e}function OM(t,e,n){t[decodeURIComponent(e)]=decodeURIComponent(n||"")}function MM(t,e){const n=e.toLowerCase();return n==="true"||n==="false"?n==="true":`${+n}`===n?+n:e}function W(){return Y2}let Y2=null;function PM(t){Y2=t}/** + */const hC="tfjsflags";class zM{constructor(e){this.global=e,this.flags={},this.flagRegistry={},this.urlFlags={},this.getQueryParams=OM,this.populateURLFlags()}setPlatform(e,n){this.platform!=null&&(W().getBool("IS_TEST")||W().getBool("PROD")||console.warn(`Platform ${this.platformName} has already been set. Overwriting the platform with ${e}.`)),this.platformName=e,this.platform=n}registerFlag(e,n,s){if(this.flagRegistry[e]={evaluationFn:n,setHook:s},this.urlFlags[e]!=null){const r=this.urlFlags[e];W().getBool("IS_TEST")||W().getBool("PROD")||console.warn(`Setting feature override from URL ${e}: ${r}.`),this.set(e,r)}}async getAsync(e){return e in this.flags?this.flags[e]:(this.flags[e]=await this.evaluateFlag(e),this.flags[e])}get(e){if(e in this.flags)return this.flags[e];const n=this.evaluateFlag(e);if(Wx(n))throw new Error(`Flag ${e} cannot be synchronously evaluated. Please use getAsync() instead.`);return this.flags[e]=n,this.flags[e]}getNumber(e){return this.get(e)}getBool(e){return this.get(e)}getString(e){return this.get(e)}getFlags(){return this.flags}get features(){return this.flags}set(e,n){if(this.flagRegistry[e]==null)throw new Error(`Cannot set flag ${e} as it has not been registered.`);this.flags[e]=n,this.flagRegistry[e].setHook!=null&&this.flagRegistry[e].setHook(n)}evaluateFlag(e){if(this.flagRegistry[e]==null)throw new Error(`Cannot evaluate flag '${e}': no evaluation function found.`);return this.flagRegistry[e].evaluationFn()}setFlags(e){this.flags=Object.assign({},e)}reset(){this.flags={},this.urlFlags={},this.populateURLFlags()}populateURLFlags(){if(typeof this.global>"u"||typeof this.global.location>"u"||typeof this.global.location.search>"u")return;const e=this.getQueryParams(this.global.location.search);hC in e&&e[hC].split(",").forEach(s=>{const[r,o]=s.split(":");this.urlFlags[r]=PM(r,o)})}}function OM(t){const e={};return t.replace(/[?&]([^=?&]+)(?:=([^&]*))?/g,(n,...s)=>(MM(e,s[0],s[1]),s.join("="))),e}function MM(t,e,n){t[decodeURIComponent(e)]=decodeURIComponent(n||"")}function PM(t,e){const n=e.toLowerCase();return n==="true"||n==="false"?n==="true":`${+n}`===n?+n:e}function W(){return QI}let QI=null;function LM(t){QI=t}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -163,7 +163,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */let vg;function Q2(){if(vg==null){let t;if(typeof window<"u")t=window;else if(typeof global<"u")t=global;else if(typeof process<"u")t=process;else if(typeof self<"u")t=self;else throw new Error("Could not find a global object");vg=t}return vg}function LM(){const t=Q2();return t._tfGlobals==null&&(t._tfGlobals=new Map),t._tfGlobals}function Ux(t,e){const n=LM();if(n.has(t))return n.get(t);{const s=e();return n.set(t,s),n.get(t)}}const pp="Abs",pu="Acos",mu="Acosh",bl="Add",Gx="AddN",Hx="All",jx="Any",mp="ArgMax",gp="ArgMin",gu="Asin",xu="Asinh",yu="Atan",wu="Atanh",vu="Atan2",xp="AvgPool",Kx="AvgPoolGrad",yp="AvgPool3D",Xx="AvgPool3DGrad",wp="BatchMatMul",vp="BatchToSpaceND",qx="Bincount",Yx="BitwiseAnd",BM="BroadcastTo",Z2="BroadcastArgs",bu="Cast",Cu="Ceil",ku="ClipByValue",Qx="Complex",bp="ComplexAbs",Cp="Concat",kp="Conv2D",Zx="Conv2DBackpropFilter",Sp="Conv2DBackpropInput",Ip="Conv3D",Jx="Conv3DBackpropFilterV2",ey="Conv3DBackpropInputV2",Su="Cos",Iu="Cosh",ty="Cumprod",$p="Cumsum",ny="CropAndResize",sy="DenseBincount",ry="DepthToSpace",Np="DepthwiseConv2dNative",oy="DepthwiseConv2dNativeBackpropFilter",iy="DepthwiseConv2dNativeBackpropInput",J2="Diag",Tp="Dilation2D",Z0="Dilation2DBackpropInput",J0="Dilation2DBackpropFilter",VM="Draw",$u="RealDiv",ay="Einsum",Nu="Elu",ly="EluGrad",Tu="Erf",Ep="Equal",Eu="Exp",Rp="ExpandDims",Ru="Expm1",cy="FFT",uy="Fill",dy="FlipLeftRight",Au="Floor",Du="FloorDiv",Ap="FusedBatchNorm",Dp="GatherV2",e$="GatherNd",_p="Greater",_u="GreaterEqual",Fu="Identity",hy="IFFT",fy="Imag",zu="IsFinite",Ou="IsInf",Mu="IsNan",Fp="LeakyRelu",zp="Less",Op="LessEqual",t$="LinSpace",Pu="Log",Lu="Log1p",Mp="LogicalAnd",Pp="LogicalNot",Lp="LogicalOr",WM="LogSoftmax",Bp="LRN",py="LRNGrad",Vp="Max",Bu="Maximum",Wp="MaxPool",my="MaxPoolGrad",Up="MaxPool3D",gy="MaxPool3DGrad",n$="MaxPoolWithArgmax",Gp="Mean",Hp="Min",Vu="Minimum",jp="MirrorPad",Wu="Mod",s$="Multinomial",Uu="Multiply",Kp="Neg",Xp="NotEqual",xy="NonMaxSuppressionV3",yy="NonMaxSuppressionV4",wy="NonMaxSuppressionV5",qp="OnesLike",Yp="OneHot",Qp="Pack",Zp="PadV2",Gu="Pow",Jp="Prelu",em="Prod",r$="RaggedGather",o$="RaggedRange",i$="RaggedTensorToTensor",vy="Range",by="Real",Hu="Reciprocal",ju="Relu",tm="Reshape",nm="ResizeNearestNeighbor",Cy="ResizeNearestNeighborGrad",sm="ResizeBilinear",ky="ResizeBilinearGrad",Ku="Relu6",rm="Reverse",Xu="Round",qu="Rsqrt",a$="ScatterNd",l$="TensorScatterUpdate",c$="SearchSorted",om="Select",Yu="Selu",im="Slice",Qu="Sin",Zu="Sinh",Ju="Sign",ed="Sigmoid",td="Softplus",nd="Sqrt",am="Sum",lm="SpaceToBatchND",cm="SplitV",um="Softmax",u$="SparseFillEmptyRows",d$="SparseReshape",h$="SparseSegmentMean",f$="SparseSegmentSum",p$="SparseToDense",sd="SquaredDifference",Sy="Square",Iy="StaticRegexReplace",$y="StridedSlice",m$="StringNGrams",g$="StringSplit",x$="StringToHashBucketFast",rd="Sub",od="Tan",id="Tanh",ad="Tile",Ny="TopK",Ty="Transform",Ma="Transpose",Ey="Unique",dm="Unpack",hm="UnsortedSegmentSum",fm="ZerosLike",ld="Step",UM="FromPixels",Ry="RotateWithOffset",ff="_FusedMatMul",pf="FusedConv2D",y$="FusedDepthwiseConv2D";/** + */let vg;function ZI(){if(vg==null){let t;if(typeof window<"u")t=window;else if(typeof global<"u")t=global;else if(typeof process<"u")t=process;else if(typeof self<"u")t=self;else throw new Error("Could not find a global object");vg=t}return vg}function BM(){const t=ZI();return t._tfGlobals==null&&(t._tfGlobals=new Map),t._tfGlobals}function Ux(t,e){const n=BM();if(n.has(t))return n.get(t);{const s=e();return n.set(t,s),n.get(t)}}const pp="Abs",pu="Acos",mu="Acosh",bl="Add",Gx="AddN",Hx="All",jx="Any",mp="ArgMax",gp="ArgMin",gu="Asin",xu="Asinh",yu="Atan",wu="Atanh",vu="Atan2",xp="AvgPool",Kx="AvgPoolGrad",yp="AvgPool3D",Xx="AvgPool3DGrad",wp="BatchMatMul",vp="BatchToSpaceND",qx="Bincount",Yx="BitwiseAnd",VM="BroadcastTo",JI="BroadcastArgs",bu="Cast",Cu="Ceil",ku="ClipByValue",Qx="Complex",bp="ComplexAbs",Cp="Concat",kp="Conv2D",Zx="Conv2DBackpropFilter",Sp="Conv2DBackpropInput",Ip="Conv3D",Jx="Conv3DBackpropFilterV2",ey="Conv3DBackpropInputV2",Su="Cos",Iu="Cosh",ty="Cumprod",$p="Cumsum",ny="CropAndResize",sy="DenseBincount",ry="DepthToSpace",Np="DepthwiseConv2dNative",oy="DepthwiseConv2dNativeBackpropFilter",iy="DepthwiseConv2dNativeBackpropInput",e$="Diag",Tp="Dilation2D",Z0="Dilation2DBackpropInput",J0="Dilation2DBackpropFilter",WM="Draw",$u="RealDiv",ay="Einsum",Nu="Elu",ly="EluGrad",Tu="Erf",Ep="Equal",Eu="Exp",Rp="ExpandDims",Ru="Expm1",cy="FFT",uy="Fill",hy="FlipLeftRight",Au="Floor",Du="FloorDiv",Ap="FusedBatchNorm",Dp="GatherV2",t$="GatherNd",_p="Greater",_u="GreaterEqual",Fu="Identity",dy="IFFT",fy="Imag",zu="IsFinite",Ou="IsInf",Mu="IsNan",Fp="LeakyRelu",zp="Less",Op="LessEqual",n$="LinSpace",Pu="Log",Lu="Log1p",Mp="LogicalAnd",Pp="LogicalNot",Lp="LogicalOr",UM="LogSoftmax",Bp="LRN",py="LRNGrad",Vp="Max",Bu="Maximum",Wp="MaxPool",my="MaxPoolGrad",Up="MaxPool3D",gy="MaxPool3DGrad",s$="MaxPoolWithArgmax",Gp="Mean",Hp="Min",Vu="Minimum",jp="MirrorPad",Wu="Mod",r$="Multinomial",Uu="Multiply",Kp="Neg",Xp="NotEqual",xy="NonMaxSuppressionV3",yy="NonMaxSuppressionV4",wy="NonMaxSuppressionV5",qp="OnesLike",Yp="OneHot",Qp="Pack",Zp="PadV2",Gu="Pow",Jp="Prelu",em="Prod",o$="RaggedGather",i$="RaggedRange",a$="RaggedTensorToTensor",vy="Range",by="Real",Hu="Reciprocal",ju="Relu",tm="Reshape",nm="ResizeNearestNeighbor",Cy="ResizeNearestNeighborGrad",sm="ResizeBilinear",ky="ResizeBilinearGrad",Ku="Relu6",rm="Reverse",Xu="Round",qu="Rsqrt",l$="ScatterNd",c$="TensorScatterUpdate",u$="SearchSorted",om="Select",Yu="Selu",im="Slice",Qu="Sin",Zu="Sinh",Ju="Sign",eh="Sigmoid",th="Softplus",nh="Sqrt",am="Sum",lm="SpaceToBatchND",cm="SplitV",um="Softmax",h$="SparseFillEmptyRows",d$="SparseReshape",f$="SparseSegmentMean",p$="SparseSegmentSum",m$="SparseToDense",sh="SquaredDifference",Sy="Square",Iy="StaticRegexReplace",$y="StridedSlice",g$="StringNGrams",x$="StringSplit",y$="StringToHashBucketFast",rh="Sub",oh="Tan",ih="Tanh",ah="Tile",Ny="TopK",Ty="Transform",Ma="Transpose",Ey="Unique",hm="Unpack",dm="UnsortedSegmentSum",fm="ZerosLike",lh="Step",GM="FromPixels",Ry="RotateWithOffset",ff="_FusedMatMul",pf="FusedConv2D",w$="FusedDepthwiseConv2D";/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -178,7 +178,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function es(...t){W().getBool("IS_TEST")||W().getBool("PROD")||console.warn(...t)}function GM(...t){W().getBool("IS_TEST")||W().getBool("PROD")||console.log(...t)}/** + */function es(...t){W().getBool("IS_TEST")||W().getBool("PROD")||console.warn(...t)}function HM(...t){W().getBool("IS_TEST")||W().getBool("PROD")||console.log(...t)}/** * @license * Copyright 2019 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -193,7 +193,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const mf=Ux("kernelRegistry",()=>new Map),e1=Ux("gradRegistry",()=>new Map);function hC(t,e){const n=v$(t,e);return mf.get(n)}function fC(t){return e1.get(t)}function pC(t){const e=mf.entries(),n=[];for(;;){const{done:s,value:r}=e.next();if(s)break;const[o,i]=r,[a]=o.split("_");a===t&&n.push(i)}return n}function w$(t){const{kernelName:e,backendName:n}=t,s=v$(e,n);mf.has(s)&&es(`The kernel '${e}' for backend '${n}' is already registered`),mf.set(s,t)}function HM(t){const{kernelName:e}=t;e1.has(e)&&W().getBool("DEBUG")&&es(`Overriding the gradient for '${e}'`),e1.set(e,t)}function v$(t,e){return`${e}_${t}`}/** + */const mf=Ux("kernelRegistry",()=>new Map),e1=Ux("gradRegistry",()=>new Map);function dC(t,e){const n=b$(t,e);return mf.get(n)}function fC(t){return e1.get(t)}function pC(t){const e=mf.entries(),n=[];for(;;){const{done:s,value:r}=e.next();if(s)break;const[o,i]=r,[a]=o.split("_");a===t&&n.push(i)}return n}function v$(t){const{kernelName:e,backendName:n}=t,s=b$(e,n);mf.has(s)&&es(`The kernel '${e}' for backend '${n}' is already registered`),mf.set(s,t)}function jM(t){const{kernelName:e}=t;e1.has(e)&&W().getBool("DEBUG")&&es(`Overriding the gradient for '${e}'`),e1.set(e,t)}function b$(t,e){return`${e}_${t}`}/** * @license * Copyright 2023 Google LLC. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -208,7 +208,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function b$(t){return t instanceof Float32Array||t instanceof Int32Array||t instanceof Uint8Array||t instanceof Uint8ClampedArray}var C$=it,ws=null;try{ws=new WebAssembly.Instance(new WebAssembly.Module(new Uint8Array([0,97,115,109,1,0,0,0,1,13,2,96,0,1,127,96,4,127,127,127,127,1,127,3,7,6,0,1,1,1,1,1,6,6,1,127,1,65,0,11,7,50,6,3,109,117,108,0,1,5,100,105,118,95,115,0,2,5,100,105,118,95,117,0,3,5,114,101,109,95,115,0,4,5,114,101,109,95,117,0,5,8,103,101,116,95,104,105,103,104,0,0,10,191,1,6,4,0,35,0,11,36,1,1,126,32,0,173,32,1,173,66,32,134,132,32,2,173,32,3,173,66,32,134,132,126,34,4,66,32,135,167,36,0,32,4,167,11,36,1,1,126,32,0,173,32,1,173,66,32,134,132,32,2,173,32,3,173,66,32,134,132,127,34,4,66,32,135,167,36,0,32,4,167,11,36,1,1,126,32,0,173,32,1,173,66,32,134,132,32,2,173,32,3,173,66,32,134,132,128,34,4,66,32,135,167,36,0,32,4,167,11,36,1,1,126,32,0,173,32,1,173,66,32,134,132,32,2,173,32,3,173,66,32,134,132,129,34,4,66,32,135,167,36,0,32,4,167,11,36,1,1,126,32,0,173,32,1,173,66,32,134,132,32,2,173,32,3,173,66,32,134,132,130,34,4,66,32,135,167,36,0,32,4,167,11])),{}).exports}catch{}function it(t,e,n){this.low=t|0,this.high=e|0,this.unsigned=!!n}it.prototype.__isLong__;Object.defineProperty(it.prototype,"__isLong__",{value:!0});function Qn(t){return(t&&t.__isLong__)===!0}it.isLong=Qn;var mC={},gC={};function ji(t,e){var n,s,r;return e?(t>>>=0,(r=0<=t&&t<256)&&(s=gC[t],s)?s:(n=at(t,(t|0)<0?-1:0,!0),r&&(gC[t]=n),n)):(t|=0,(r=-128<=t&&t<128)&&(s=mC[t],s)?s:(n=at(t,t<0?-1:0,!1),r&&(mC[t]=n),n))}it.fromInt=ji;function vs(t,e){if(isNaN(t))return e?hi:bs;if(e){if(t<0)return hi;if(t>=k$)return $$}else{if(t<=-yC)return Un;if(t+1>=yC)return I$}return t<0?vs(-t,e).neg():at(t%sl|0,t/sl|0,e)}it.fromNumber=vs;function at(t,e,n){return new it(t,e,n)}it.fromBits=at;var gf=Math.pow;function Ay(t,e,n){if(t.length===0)throw Error("empty string");if(t==="NaN"||t==="Infinity"||t==="+Infinity"||t==="-Infinity")return bs;if(typeof e=="number"?(n=e,e=!1):e=!!e,n=n||10,n<2||360)throw Error("interior hyphen");if(s===0)return Ay(t.substring(1),e,n).neg();for(var r=vs(gf(n,8)),o=bs,i=0;i>>0:this.low};oe.toNumber=function(){return this.unsigned?(this.high>>>0)*sl+(this.low>>>0):this.high*sl+(this.low>>>0)};oe.toString=function(e){if(e=e||10,e<2||36>>0,u=c.toString(e);if(i=l,i.isZero())return u+a;for(;u.length<6;)u="0"+u;a=""+u+a}};oe.getHighBits=function(){return this.high};oe.getHighBitsUnsigned=function(){return this.high>>>0};oe.getLowBits=function(){return this.low};oe.getLowBitsUnsigned=function(){return this.low>>>0};oe.getNumBitsAbs=function(){if(this.isNegative())return this.eq(Un)?64:this.neg().getNumBitsAbs();for(var e=this.high!=0?this.high:this.low,n=31;n>0&&!(e&1<=0};oe.isOdd=function(){return(this.low&1)===1};oe.isEven=function(){return(this.low&1)===0};oe.equals=function(e){return Qn(e)||(e=tr(e)),this.unsigned!==e.unsigned&&this.high>>>31===1&&e.high>>>31===1?!1:this.high===e.high&&this.low===e.low};oe.eq=oe.equals;oe.notEquals=function(e){return!this.eq(e)};oe.neq=oe.notEquals;oe.ne=oe.notEquals;oe.lessThan=function(e){return this.comp(e)<0};oe.lt=oe.lessThan;oe.lessThanOrEqual=function(e){return this.comp(e)<=0};oe.lte=oe.lessThanOrEqual;oe.le=oe.lessThanOrEqual;oe.greaterThan=function(e){return this.comp(e)>0};oe.gt=oe.greaterThan;oe.greaterThanOrEqual=function(e){return this.comp(e)>=0};oe.gte=oe.greaterThanOrEqual;oe.ge=oe.greaterThanOrEqual;oe.compare=function(e){if(Qn(e)||(e=tr(e)),this.eq(e))return 0;var n=this.isNegative(),s=e.isNegative();return n&&!s?-1:!n&&s?1:this.unsigned?e.high>>>0>this.high>>>0||e.high===this.high&&e.low>>>0>this.low>>>0?-1:1:this.sub(e).isNegative()?-1:1};oe.comp=oe.compare;oe.negate=function(){return!this.unsigned&&this.eq(Un)?Un:this.not().add(Ta)};oe.neg=oe.negate;oe.add=function(e){Qn(e)||(e=tr(e));var n=this.high>>>16,s=this.high&65535,r=this.low>>>16,o=this.low&65535,i=e.high>>>16,a=e.high&65535,l=e.low>>>16,c=e.low&65535,u=0,d=0,h=0,f=0;return f+=o+c,h+=f>>>16,f&=65535,h+=r+l,d+=h>>>16,h&=65535,d+=s+a,u+=d>>>16,d&=65535,u+=n+i,u&=65535,at(h<<16|f,u<<16|d,this.unsigned)};oe.subtract=function(e){return Qn(e)||(e=tr(e)),this.add(e.neg())};oe.sub=oe.subtract;oe.multiply=function(e){if(this.isZero())return bs;if(Qn(e)||(e=tr(e)),ws){var n=ws.mul(this.low,this.high,e.low,e.high);return at(n,ws.get_high(),this.unsigned)}if(e.isZero())return bs;if(this.eq(Un))return e.isOdd()?Un:bs;if(e.eq(Un))return this.isOdd()?Un:bs;if(this.isNegative())return e.isNegative()?this.neg().mul(e.neg()):this.neg().mul(e).neg();if(e.isNegative())return this.mul(e.neg()).neg();if(this.lt(wC)&&e.lt(wC))return vs(this.toNumber()*e.toNumber(),this.unsigned);var s=this.high>>>16,r=this.high&65535,o=this.low>>>16,i=this.low&65535,a=e.high>>>16,l=e.high&65535,c=e.low>>>16,u=e.low&65535,d=0,h=0,f=0,p=0;return p+=i*u,f+=p>>>16,p&=65535,f+=o*u,h+=f>>>16,f&=65535,f+=i*c,h+=f>>>16,f&=65535,h+=r*u,d+=h>>>16,h&=65535,h+=o*c,d+=h>>>16,h&=65535,h+=i*l,d+=h>>>16,h&=65535,d+=s*u+r*c+o*l+i*a,d&=65535,at(f<<16|p,d<<16|h,this.unsigned)};oe.mul=oe.multiply;oe.divide=function(e){if(Qn(e)||(e=tr(e)),e.isZero())throw Error("division by zero");if(ws){if(!this.unsigned&&this.high===-2147483648&&e.low===-1&&e.high===-1)return this;var n=(this.unsigned?ws.div_u:ws.div_s)(this.low,this.high,e.low,e.high);return at(n,ws.get_high(),this.unsigned)}if(this.isZero())return this.unsigned?hi:bs;var s,r,o;if(this.unsigned){if(e.unsigned||(e=e.toUnsigned()),e.gt(this))return hi;if(e.gt(this.shru(1)))return S$;o=hi}else{if(this.eq(Un)){if(e.eq(Ta)||e.eq(t1))return Un;if(e.eq(Un))return Ta;var i=this.shr(1);return s=i.div(e).shl(1),s.eq(bs)?e.isNegative()?Ta:t1:(r=this.sub(e.mul(s)),o=s.add(r.div(e)),o)}else if(e.eq(Un))return this.unsigned?hi:bs;if(this.isNegative())return e.isNegative()?this.neg().div(e.neg()):this.neg().div(e).neg();if(e.isNegative())return this.div(e.neg()).neg();o=bs}for(r=this;r.gte(e);){s=Math.max(1,Math.floor(r.toNumber()/e.toNumber()));for(var a=Math.ceil(Math.log(s)/Math.LN2),l=a<=48?1:gf(2,a-48),c=vs(s),u=c.mul(e);u.isNegative()||u.gt(r);)s-=l,c=vs(s,this.unsigned),u=c.mul(e);c.isZero()&&(c=Ta),o=o.add(c),r=r.sub(u)}return o};oe.div=oe.divide;oe.modulo=function(e){if(Qn(e)||(e=tr(e)),ws){var n=(this.unsigned?ws.rem_u:ws.rem_s)(this.low,this.high,e.low,e.high);return at(n,ws.get_high(),this.unsigned)}return this.sub(this.div(e).mul(e))};oe.mod=oe.modulo;oe.rem=oe.modulo;oe.not=function(){return at(~this.low,~this.high,this.unsigned)};oe.and=function(e){return Qn(e)||(e=tr(e)),at(this.low&e.low,this.high&e.high,this.unsigned)};oe.or=function(e){return Qn(e)||(e=tr(e)),at(this.low|e.low,this.high|e.high,this.unsigned)};oe.xor=function(e){return Qn(e)||(e=tr(e)),at(this.low^e.low,this.high^e.high,this.unsigned)};oe.shiftLeft=function(e){return Qn(e)&&(e=e.toInt()),(e&=63)===0?this:e<32?at(this.low<>>32-e,this.unsigned):at(0,this.low<>>e|this.high<<32-e,this.high>>e,this.unsigned):at(this.high>>e-32,this.high>=0?0:-1,this.unsigned)};oe.shr=oe.shiftRight;oe.shiftRightUnsigned=function(e){if(Qn(e)&&(e=e.toInt()),e&=63,e===0)return this;var n=this.high;if(e<32){var s=this.low;return at(s>>>e|n<<32-e,n>>>e,this.unsigned)}else return e===32?at(n,0,this.unsigned):at(n>>>e-32,0,this.unsigned)};oe.shru=oe.shiftRightUnsigned;oe.shr_u=oe.shiftRightUnsigned;oe.toSigned=function(){return this.unsigned?at(this.low,this.high,!1):this};oe.toUnsigned=function(){return this.unsigned?this:at(this.low,this.high,!0)};oe.toBytes=function(e){return e?this.toBytesLE():this.toBytesBE()};oe.toBytesLE=function(){var e=this.high,n=this.low;return[n&255,n>>>8&255,n>>>16&255,n>>>24,e&255,e>>>8&255,e>>>16&255,e>>>24]};oe.toBytesBE=function(){var e=this.high,n=this.low;return[e>>>24,e>>>16&255,e>>>8&255,e&255,n>>>24,n>>>16&255,n>>>8&255,n&255]};it.fromBytes=function(e,n,s){return s?it.fromBytesLE(e,n):it.fromBytesBE(e,n)};it.fromBytesLE=function(e,n){return new it(e[0]|e[1]<<8|e[2]<<16|e[3]<<24,e[4]|e[5]<<8|e[6]<<16|e[7]<<24,n)};it.fromBytesBE=function(e,n){return new it(e[4]<<24|e[5]<<16|e[6]<<8|e[7],e[0]<<24|e[1]<<16|e[2]<<8|e[3],n)};const N$=rS(C$),KM=XD({__proto__:null,default:N$},[C$]);/** + */function C$(t){return t instanceof Float32Array||t instanceof Int32Array||t instanceof Uint8Array||t instanceof Uint8ClampedArray}var k$=it,vs=null;try{vs=new WebAssembly.Instance(new WebAssembly.Module(new Uint8Array([0,97,115,109,1,0,0,0,1,13,2,96,0,1,127,96,4,127,127,127,127,1,127,3,7,6,0,1,1,1,1,1,6,6,1,127,1,65,0,11,7,50,6,3,109,117,108,0,1,5,100,105,118,95,115,0,2,5,100,105,118,95,117,0,3,5,114,101,109,95,115,0,4,5,114,101,109,95,117,0,5,8,103,101,116,95,104,105,103,104,0,0,10,191,1,6,4,0,35,0,11,36,1,1,126,32,0,173,32,1,173,66,32,134,132,32,2,173,32,3,173,66,32,134,132,126,34,4,66,32,135,167,36,0,32,4,167,11,36,1,1,126,32,0,173,32,1,173,66,32,134,132,32,2,173,32,3,173,66,32,134,132,127,34,4,66,32,135,167,36,0,32,4,167,11,36,1,1,126,32,0,173,32,1,173,66,32,134,132,32,2,173,32,3,173,66,32,134,132,128,34,4,66,32,135,167,36,0,32,4,167,11,36,1,1,126,32,0,173,32,1,173,66,32,134,132,32,2,173,32,3,173,66,32,134,132,129,34,4,66,32,135,167,36,0,32,4,167,11,36,1,1,126,32,0,173,32,1,173,66,32,134,132,32,2,173,32,3,173,66,32,134,132,130,34,4,66,32,135,167,36,0,32,4,167,11])),{}).exports}catch{}function it(t,e,n){this.low=t|0,this.high=e|0,this.unsigned=!!n}it.prototype.__isLong__;Object.defineProperty(it.prototype,"__isLong__",{value:!0});function Qn(t){return(t&&t.__isLong__)===!0}it.isLong=Qn;var mC={},gC={};function ji(t,e){var n,s,r;return e?(t>>>=0,(r=0<=t&&t<256)&&(s=gC[t],s)?s:(n=at(t,(t|0)<0?-1:0,!0),r&&(gC[t]=n),n)):(t|=0,(r=-128<=t&&t<128)&&(s=mC[t],s)?s:(n=at(t,t<0?-1:0,!1),r&&(mC[t]=n),n))}it.fromInt=ji;function bs(t,e){if(isNaN(t))return e?di:Cs;if(e){if(t<0)return di;if(t>=S$)return N$}else{if(t<=-yC)return Un;if(t+1>=yC)return $$}return t<0?bs(-t,e).neg():at(t%sl|0,t/sl|0,e)}it.fromNumber=bs;function at(t,e,n){return new it(t,e,n)}it.fromBits=at;var gf=Math.pow;function Ay(t,e,n){if(t.length===0)throw Error("empty string");if(t==="NaN"||t==="Infinity"||t==="+Infinity"||t==="-Infinity")return Cs;if(typeof e=="number"?(n=e,e=!1):e=!!e,n=n||10,n<2||360)throw Error("interior hyphen");if(s===0)return Ay(t.substring(1),e,n).neg();for(var r=bs(gf(n,8)),o=Cs,i=0;i>>0:this.low};oe.toNumber=function(){return this.unsigned?(this.high>>>0)*sl+(this.low>>>0):this.high*sl+(this.low>>>0)};oe.toString=function(e){if(e=e||10,e<2||36>>0,u=c.toString(e);if(i=l,i.isZero())return u+a;for(;u.length<6;)u="0"+u;a=""+u+a}};oe.getHighBits=function(){return this.high};oe.getHighBitsUnsigned=function(){return this.high>>>0};oe.getLowBits=function(){return this.low};oe.getLowBitsUnsigned=function(){return this.low>>>0};oe.getNumBitsAbs=function(){if(this.isNegative())return this.eq(Un)?64:this.neg().getNumBitsAbs();for(var e=this.high!=0?this.high:this.low,n=31;n>0&&!(e&1<=0};oe.isOdd=function(){return(this.low&1)===1};oe.isEven=function(){return(this.low&1)===0};oe.equals=function(e){return Qn(e)||(e=nr(e)),this.unsigned!==e.unsigned&&this.high>>>31===1&&e.high>>>31===1?!1:this.high===e.high&&this.low===e.low};oe.eq=oe.equals;oe.notEquals=function(e){return!this.eq(e)};oe.neq=oe.notEquals;oe.ne=oe.notEquals;oe.lessThan=function(e){return this.comp(e)<0};oe.lt=oe.lessThan;oe.lessThanOrEqual=function(e){return this.comp(e)<=0};oe.lte=oe.lessThanOrEqual;oe.le=oe.lessThanOrEqual;oe.greaterThan=function(e){return this.comp(e)>0};oe.gt=oe.greaterThan;oe.greaterThanOrEqual=function(e){return this.comp(e)>=0};oe.gte=oe.greaterThanOrEqual;oe.ge=oe.greaterThanOrEqual;oe.compare=function(e){if(Qn(e)||(e=nr(e)),this.eq(e))return 0;var n=this.isNegative(),s=e.isNegative();return n&&!s?-1:!n&&s?1:this.unsigned?e.high>>>0>this.high>>>0||e.high===this.high&&e.low>>>0>this.low>>>0?-1:1:this.sub(e).isNegative()?-1:1};oe.comp=oe.compare;oe.negate=function(){return!this.unsigned&&this.eq(Un)?Un:this.not().add(Ta)};oe.neg=oe.negate;oe.add=function(e){Qn(e)||(e=nr(e));var n=this.high>>>16,s=this.high&65535,r=this.low>>>16,o=this.low&65535,i=e.high>>>16,a=e.high&65535,l=e.low>>>16,c=e.low&65535,u=0,h=0,d=0,f=0;return f+=o+c,d+=f>>>16,f&=65535,d+=r+l,h+=d>>>16,d&=65535,h+=s+a,u+=h>>>16,h&=65535,u+=n+i,u&=65535,at(d<<16|f,u<<16|h,this.unsigned)};oe.subtract=function(e){return Qn(e)||(e=nr(e)),this.add(e.neg())};oe.sub=oe.subtract;oe.multiply=function(e){if(this.isZero())return Cs;if(Qn(e)||(e=nr(e)),vs){var n=vs.mul(this.low,this.high,e.low,e.high);return at(n,vs.get_high(),this.unsigned)}if(e.isZero())return Cs;if(this.eq(Un))return e.isOdd()?Un:Cs;if(e.eq(Un))return this.isOdd()?Un:Cs;if(this.isNegative())return e.isNegative()?this.neg().mul(e.neg()):this.neg().mul(e).neg();if(e.isNegative())return this.mul(e.neg()).neg();if(this.lt(wC)&&e.lt(wC))return bs(this.toNumber()*e.toNumber(),this.unsigned);var s=this.high>>>16,r=this.high&65535,o=this.low>>>16,i=this.low&65535,a=e.high>>>16,l=e.high&65535,c=e.low>>>16,u=e.low&65535,h=0,d=0,f=0,p=0;return p+=i*u,f+=p>>>16,p&=65535,f+=o*u,d+=f>>>16,f&=65535,f+=i*c,d+=f>>>16,f&=65535,d+=r*u,h+=d>>>16,d&=65535,d+=o*c,h+=d>>>16,d&=65535,d+=i*l,h+=d>>>16,d&=65535,h+=s*u+r*c+o*l+i*a,h&=65535,at(f<<16|p,h<<16|d,this.unsigned)};oe.mul=oe.multiply;oe.divide=function(e){if(Qn(e)||(e=nr(e)),e.isZero())throw Error("division by zero");if(vs){if(!this.unsigned&&this.high===-2147483648&&e.low===-1&&e.high===-1)return this;var n=(this.unsigned?vs.div_u:vs.div_s)(this.low,this.high,e.low,e.high);return at(n,vs.get_high(),this.unsigned)}if(this.isZero())return this.unsigned?di:Cs;var s,r,o;if(this.unsigned){if(e.unsigned||(e=e.toUnsigned()),e.gt(this))return di;if(e.gt(this.shru(1)))return I$;o=di}else{if(this.eq(Un)){if(e.eq(Ta)||e.eq(t1))return Un;if(e.eq(Un))return Ta;var i=this.shr(1);return s=i.div(e).shl(1),s.eq(Cs)?e.isNegative()?Ta:t1:(r=this.sub(e.mul(s)),o=s.add(r.div(e)),o)}else if(e.eq(Un))return this.unsigned?di:Cs;if(this.isNegative())return e.isNegative()?this.neg().div(e.neg()):this.neg().div(e).neg();if(e.isNegative())return this.div(e.neg()).neg();o=Cs}for(r=this;r.gte(e);){s=Math.max(1,Math.floor(r.toNumber()/e.toNumber()));for(var a=Math.ceil(Math.log(s)/Math.LN2),l=a<=48?1:gf(2,a-48),c=bs(s),u=c.mul(e);u.isNegative()||u.gt(r);)s-=l,c=bs(s,this.unsigned),u=c.mul(e);c.isZero()&&(c=Ta),o=o.add(c),r=r.sub(u)}return o};oe.div=oe.divide;oe.modulo=function(e){if(Qn(e)||(e=nr(e)),vs){var n=(this.unsigned?vs.rem_u:vs.rem_s)(this.low,this.high,e.low,e.high);return at(n,vs.get_high(),this.unsigned)}return this.sub(this.div(e).mul(e))};oe.mod=oe.modulo;oe.rem=oe.modulo;oe.not=function(){return at(~this.low,~this.high,this.unsigned)};oe.and=function(e){return Qn(e)||(e=nr(e)),at(this.low&e.low,this.high&e.high,this.unsigned)};oe.or=function(e){return Qn(e)||(e=nr(e)),at(this.low|e.low,this.high|e.high,this.unsigned)};oe.xor=function(e){return Qn(e)||(e=nr(e)),at(this.low^e.low,this.high^e.high,this.unsigned)};oe.shiftLeft=function(e){return Qn(e)&&(e=e.toInt()),(e&=63)===0?this:e<32?at(this.low<>>32-e,this.unsigned):at(0,this.low<>>e|this.high<<32-e,this.high>>e,this.unsigned):at(this.high>>e-32,this.high>=0?0:-1,this.unsigned)};oe.shr=oe.shiftRight;oe.shiftRightUnsigned=function(e){if(Qn(e)&&(e=e.toInt()),e&=63,e===0)return this;var n=this.high;if(e<32){var s=this.low;return at(s>>>e|n<<32-e,n>>>e,this.unsigned)}else return e===32?at(n,0,this.unsigned):at(n>>>e-32,0,this.unsigned)};oe.shru=oe.shiftRightUnsigned;oe.shr_u=oe.shiftRightUnsigned;oe.toSigned=function(){return this.unsigned?at(this.low,this.high,!1):this};oe.toUnsigned=function(){return this.unsigned?this:at(this.low,this.high,!0)};oe.toBytes=function(e){return e?this.toBytesLE():this.toBytesBE()};oe.toBytesLE=function(){var e=this.high,n=this.low;return[n&255,n>>>8&255,n>>>16&255,n>>>24,e&255,e>>>8&255,e>>>16&255,e>>>24]};oe.toBytesBE=function(){var e=this.high,n=this.low;return[e>>>24,e>>>16&255,e>>>8&255,e&255,n>>>24,n>>>16&255,n>>>8&255,n&255]};it.fromBytes=function(e,n,s){return s?it.fromBytesLE(e,n):it.fromBytesBE(e,n)};it.fromBytesLE=function(e,n){return new it(e[0]|e[1]<<8|e[2]<<16|e[3]<<24,e[4]|e[5]<<8|e[6]<<16|e[7]<<24,n)};it.fromBytesBE=function(e,n){return new it(e[4]<<24|e[5]<<16|e[6]<<8|e[7],e[0]<<24|e[1]<<16|e[2]<<8|e[3],n)};const T$=oS(k$),XM=qD({__proto__:null,default:T$},[k$]);/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -223,7 +223,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const oi=N$||KM;function pm(t){return oi.fromString(t,!0,16)}const T$=pm("c3a5c85c97cb3127"),ri=pm("b492b66fbe98f273"),wn=pm("9ae16a3b2f90404f");function n1(t){return t.xor(t.shru(47))}function E$(t,e,n){const s=t.slice(e,e+n);return oi.fromBytes(Array.from(s),!0,!0)}function et(t,e){return E$(t,e,8)}function vC(t,e){return E$(t,e,4)}function jt(t,e){return e===0?t:t.shru(e).or(t.shl(64-e))}function $o(t,e,n=pm("9ddfea08eb382d69")){let s=t.xor(e).mul(n);s=s.xor(s.shru(47));let r=e.xor(s).mul(n);return r=r.xor(r.shru(47)),r=r.mul(n),r}function XM(t,e,n,s,r,o){r=r.add(t),o=jt(o.add(r).add(s),21);const i=r;return r=r.add(e),r=r.add(n),o=o.add(jt(r,44)),[r.add(s),o.add(i)]}function Jd(t,e,n,s){return XM(et(t,e),et(t,e+8),et(t,e+16),et(t,e+24),n,s)}function qM(t,e=t.length){if(e>=8){const n=wn.add(e*2),s=et(t,0).add(wn),r=et(t,e-8),o=jt(r,37).mul(n).add(s),i=jt(s,25).add(r).mul(n);return $o(o,i,n)}if(e>=4){const n=wn.add(e*2),s=vC(t,0);return $o(s.shl(3).add(e),vC(t,e-4),n)}if(e>0){const n=t[0],s=t[e>>1],r=t[e-1],o=n+(s<<8),i=e+(r<<2);return n1(wn.mul(o).xor(T$.mul(i))).mul(wn)}return wn}function YM(t,e=t.length){const n=wn.add(e*2),s=et(t,0).mul(ri),r=et(t,8),o=et(t,e-8).mul(n),i=et(t,e-16).mul(wn);return $o(jt(s.add(r),43).add(jt(o,30)).add(i),s.add(jt(r.add(wn),18)).add(o),n)}function QM(t,e=t.length){const n=wn.add(e*2),s=et(t,0).mul(wn),r=et(t,8),o=et(t,e-8).mul(n),i=et(t,e-16).mul(wn),a=jt(s.add(r),43).add(jt(o,30)).add(i),l=$o(a,s.add(jt(r.add(wn),18)).add(o),n),c=et(t,16).mul(n),u=et(t,24),d=a.add(et(t,e-32)).mul(n),h=l.add(et(t,e-24)).mul(n);return $o(jt(c.add(u),43).add(jt(d,30)).add(h),c.add(jt(u.add(s),18)).add(d),n)}function ZM(t,e=t.length){const n=oi.fromNumber(81,!0);if(e<=32)return e<=16?qM(t,e):YM(t,e);if(e<=64)return QM(t,e);let s=n,r=n.mul(ri).add(113),o=n1(r.mul(wn).add(113)).mul(wn),i=[oi.UZERO,oi.UZERO],a=[oi.UZERO,oi.UZERO];s=s.mul(wn).add(et(t,0));let l=0;const c=(e-1>>6)*64,u=c+(e-1&63)-63;do s=jt(s.add(r).add(i[0]).add(et(t,l+8)),37).mul(ri),r=jt(r.add(i[1]).add(et(t,l+48)),42).mul(ri),s=s.xor(a[1]),r=r.add(i[0]).add(et(t,l+40)),o=jt(o.add(a[0]),33).mul(ri),i=Jd(t,l,i[1].mul(ri),s.add(a[0])),a=Jd(t,l+32,o.add(a[1]),r.add(et(t,l+16))),[o,s]=[s,o],l+=64;while(l!==c);const d=ri.add(o.and(255).shl(1));return l=u,a[0]=a[0].add(e-1&63),i[0]=i[0].add(a[0]),a[0]=a[0].add(i[0]),s=jt(s.add(r).add(i[0]).add(et(t,l+8)),37).mul(d),r=jt(r.add(i[1]).add(et(t,l+48)),42).mul(d),s=s.xor(a[1].mul(9)),r=r.add(i[0].mul(9).add(et(t,l+40))),o=jt(o.add(a[0]),33).mul(d),i=Jd(t,l,i[1].mul(d),s.add(a[0])),a=Jd(t,l+32,o.add(a[1]),r.add(et(t,l+16))),[o,s]=[s,o],$o($o(i[0],a[0],d).add(n1(r).mul(T$)).add(o),$o(i[1],a[1],d).add(s),d)}/** + */const oi=T$||XM;function pm(t){return oi.fromString(t,!0,16)}const E$=pm("c3a5c85c97cb3127"),ri=pm("b492b66fbe98f273"),wn=pm("9ae16a3b2f90404f");function n1(t){return t.xor(t.shru(47))}function R$(t,e,n){const s=t.slice(e,e+n);return oi.fromBytes(Array.from(s),!0,!0)}function et(t,e){return R$(t,e,8)}function vC(t,e){return R$(t,e,4)}function jt(t,e){return e===0?t:t.shru(e).or(t.shl(64-e))}function $o(t,e,n=pm("9ddfea08eb382d69")){let s=t.xor(e).mul(n);s=s.xor(s.shru(47));let r=e.xor(s).mul(n);return r=r.xor(r.shru(47)),r=r.mul(n),r}function qM(t,e,n,s,r,o){r=r.add(t),o=jt(o.add(r).add(s),21);const i=r;return r=r.add(e),r=r.add(n),o=o.add(jt(r,44)),[r.add(s),o.add(i)]}function Jh(t,e,n,s){return qM(et(t,e),et(t,e+8),et(t,e+16),et(t,e+24),n,s)}function YM(t,e=t.length){if(e>=8){const n=wn.add(e*2),s=et(t,0).add(wn),r=et(t,e-8),o=jt(r,37).mul(n).add(s),i=jt(s,25).add(r).mul(n);return $o(o,i,n)}if(e>=4){const n=wn.add(e*2),s=vC(t,0);return $o(s.shl(3).add(e),vC(t,e-4),n)}if(e>0){const n=t[0],s=t[e>>1],r=t[e-1],o=n+(s<<8),i=e+(r<<2);return n1(wn.mul(o).xor(E$.mul(i))).mul(wn)}return wn}function QM(t,e=t.length){const n=wn.add(e*2),s=et(t,0).mul(ri),r=et(t,8),o=et(t,e-8).mul(n),i=et(t,e-16).mul(wn);return $o(jt(s.add(r),43).add(jt(o,30)).add(i),s.add(jt(r.add(wn),18)).add(o),n)}function ZM(t,e=t.length){const n=wn.add(e*2),s=et(t,0).mul(wn),r=et(t,8),o=et(t,e-8).mul(n),i=et(t,e-16).mul(wn),a=jt(s.add(r),43).add(jt(o,30)).add(i),l=$o(a,s.add(jt(r.add(wn),18)).add(o),n),c=et(t,16).mul(n),u=et(t,24),h=a.add(et(t,e-32)).mul(n),d=l.add(et(t,e-24)).mul(n);return $o(jt(c.add(u),43).add(jt(h,30)).add(d),c.add(jt(u.add(s),18)).add(h),n)}function JM(t,e=t.length){const n=oi.fromNumber(81,!0);if(e<=32)return e<=16?YM(t,e):QM(t,e);if(e<=64)return ZM(t,e);let s=n,r=n.mul(ri).add(113),o=n1(r.mul(wn).add(113)).mul(wn),i=[oi.UZERO,oi.UZERO],a=[oi.UZERO,oi.UZERO];s=s.mul(wn).add(et(t,0));let l=0;const c=(e-1>>6)*64,u=c+(e-1&63)-63;do s=jt(s.add(r).add(i[0]).add(et(t,l+8)),37).mul(ri),r=jt(r.add(i[1]).add(et(t,l+48)),42).mul(ri),s=s.xor(a[1]),r=r.add(i[0]).add(et(t,l+40)),o=jt(o.add(a[0]),33).mul(ri),i=Jh(t,l,i[1].mul(ri),s.add(a[0])),a=Jh(t,l+32,o.add(a[1]),r.add(et(t,l+16))),[o,s]=[s,o],l+=64;while(l!==c);const h=ri.add(o.and(255).shl(1));return l=u,a[0]=a[0].add(e-1&63),i[0]=i[0].add(a[0]),a[0]=a[0].add(i[0]),s=jt(s.add(r).add(i[0]).add(et(t,l+8)),37).mul(h),r=jt(r.add(i[1]).add(et(t,l+48)),42).mul(h),s=s.xor(a[1].mul(9)),r=r.add(i[0].mul(9).add(et(t,l+40))),o=jt(o.add(a[0]),33).mul(h),i=Jh(t,l,i[1].mul(h),s.add(a[0])),a=Jh(t,l+32,o.add(a[1]),r.add(et(t,l+16))),[o,s]=[s,o],$o($o(i[0],a[0],h).add(n1(r).mul(E$)).add(o),$o(i[1],a[1],h).add(s),h)}/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -238,7 +238,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Wo(t,e){return e==="string"?No(t):Ki([t],e)}function JM(t,e){return t instanceof Float32Array&&e==="float32"||t instanceof Int32Array&&e==="int32"||t instanceof Uint8Array&&e==="bool"}function Ki(t,e){if(e==="string")throw new Error("Cannot convert a string[] to a TypedArray");if(Array.isArray(t)&&(t=Ei(t)),W().getBool("DEBUG")&&EM(t,e),JM(t,e))return t;if(e==null||e==="float32"||e==="complex64")return new Float32Array(t);if(e==="int32")return new Int32Array(t);if(e==="bool"){const n=new Uint8Array(t.length);for(let s=0;s{r=s()};let i;const a=Tn();if(this.backendTimer.timerAvailable())i=this.backendTimer.time(o);else{o();for(const c of r)c.dataSync();i=Promise.resolve({kernelMs:Tn()-a})}if(W().getBool("CHECK_COMPUTATION_FOR_ERRORS"))for(let c=0;c{tP(d,u.dtype,e)})}return{kernelName:e,outputs:r,inputs:n,timeMs:i.then(c=>c.kernelMs),extraInfo:i.then(c=>c.getExtraProfileInfo!=null?c.getExtraProfileInfo():"")}}logKernelProfile(e){const{kernelName:n,outputs:s,timeMs:r,inputs:o,extraInfo:i}=e;s.forEach(a=>{Promise.all([a.data(),r,i]).then(l=>{this.logger.logKernelProfile(n,a,l[0],l[1],o,l[2])})})}}function tP(t,e,n){if(e!=="float32")return!1;for(let s=0;s0?g:""} `}}console.log(`%c${l} %c${a} %c${c}D ${d} %c${u} %c${h} %c${i}`,"font-weight:bold","color:red","color:blue","color: orange","color: green","color: steelblue")}}/** + */class tP{constructor(e,n){this.backendTimer=e,this.logger=n,n==null&&(this.logger=new sP)}profileKernel(e,n,s){let r;const o=()=>{r=s()};let i;const a=Tn();if(this.backendTimer.timerAvailable())i=this.backendTimer.time(o);else{o();for(const c of r)c.dataSync();i=Promise.resolve({kernelMs:Tn()-a})}if(W().getBool("CHECK_COMPUTATION_FOR_ERRORS"))for(let c=0;c{nP(h,u.dtype,e)})}return{kernelName:e,outputs:r,inputs:n,timeMs:i.then(c=>c.kernelMs),extraInfo:i.then(c=>c.getExtraProfileInfo!=null?c.getExtraProfileInfo():"")}}logKernelProfile(e){const{kernelName:n,outputs:s,timeMs:r,inputs:o,extraInfo:i}=e;s.forEach(a=>{Promise.all([a.data(),r,i]).then(l=>{this.logger.logKernelProfile(n,a,l[0],l[1],o,l[2])})})}}function nP(t,e,n){if(e!=="float32")return!1;for(let s=0;s0?g:""} `}}console.log(`%c${l} %c${a} %c${c}D ${h} %c${u} %c${d} %c${i}`,"font-weight:bold","color:red","color:blue","color: orange","color: green","color: steelblue")}}/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -268,7 +268,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function sP(t,e,n){const s={},r={};for(let l=0;ls[g.id]=!0),f=!0,r[c.id]=!0;break}if(f)break}}const o={};o[n.id]=!0;const i={};for(let l=t.length-1;l>=0;l--){const c=t[l],u=c.inputs;for(let d=0;d=0;r--){const o=e[r],i=[];if(o.outputs.forEach(l=>{const c=t[l.id];c!=null?i.push(c):i.push(null)}),o.gradient==null)throw new Error(`Cannot compute gradient: gradient function not found for ${o.kernelName}.`);const a=o.gradient(i);for(const l in o.inputs){if(!(l in a))throw new Error(`Cannot backprop through input ${l}. Available gradients found: ${Object.keys(a)}.`);const c=n(()=>a[l]());if(c.dtype!=="float32")throw new Error(`Error in gradient for op ${o.kernelName}. The gradient of input ${l} must have 'float32' dtype, but has '${c.dtype}'`);const u=o.inputs[l];if(!Ue(c.shape,u.shape))throw new Error(`Error in gradient for op ${o.kernelName}. The gradient of input '${l}' has shape '${c.shape}', which does not match the shape of the input '${u.shape}'`);if(t[u.id]==null)t[u.id]=c;else{const d=t[u.id];t[u.id]=s(d,c),d.dispose()}}}}/** + */function rP(t,e,n){const s={},r={};for(let l=0;ls[g.id]=!0),f=!0,r[c.id]=!0;break}if(f)break}}const o={};o[n.id]=!0;const i={};for(let l=t.length-1;l>=0;l--){const c=t[l],u=c.inputs;for(let h=0;h=0;r--){const o=e[r],i=[];if(o.outputs.forEach(l=>{const c=t[l.id];c!=null?i.push(c):i.push(null)}),o.gradient==null)throw new Error(`Cannot compute gradient: gradient function not found for ${o.kernelName}.`);const a=o.gradient(i);for(const l in o.inputs){if(!(l in a))throw new Error(`Cannot backprop through input ${l}. Available gradients found: ${Object.keys(a)}.`);const c=n(()=>a[l]());if(c.dtype!=="float32")throw new Error(`Error in gradient for op ${o.kernelName}. The gradient of input ${l} must have 'float32' dtype, but has '${c.dtype}'`);const u=o.inputs[l];if(!Ue(c.shape,u.shape))throw new Error(`Error in gradient for op ${o.kernelName}. The gradient of input '${l}' has shape '${c.shape}', which does not match the shape of the input '${u.shape}'`);if(t[u.id]==null)t[u.id]=c;else{const h=t[u.id];t[u.id]=s(h,c),h.dispose()}}}}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -283,11 +283,11 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const bC=20,Gl=3,bg=7;function oP(t,e,n,s){const r=pe(e),o=iP(t,e,n,r),i=e.length,a=Dh(t,e,n,r,o),l=["Tensor"];return s&&(l.push(` dtype: ${n}`),l.push(` rank: ${i}`),l.push(` shape: [${e}]`),l.push(" values:")),l.push(a.map(c=>" "+c).join(` + */const bC=20,Gl=3,bg=7;function iP(t,e,n,s){const r=pe(e),o=aP(t,e,n,r),i=e.length,a=Dd(t,e,n,r,o),l=["Tensor"];return s&&(l.push(` dtype: ${n}`),l.push(` rank: ${i}`),l.push(` shape: [${e}]`),l.push(" values:")),l.push(a.map(c=>" "+c).join(` `)),l.join(` -`)}function iP(t,e,n,s){const r=j(e),o=s[s.length-1],i=new Array(o).fill(0),a=e.length,l=n==="complex64"?oc(t):t;if(a>1)for(let c=0;cbC){const x=Gl*i;let m=Array.from(t.slice(0,x)),y=Array.from(t.slice((a-Gl)*i,a*i));return n==="complex64"&&(m=oc(m),y=oc(y)),["["+m.map((w,v)=>rc(w,r[v],n)).join(", ")+", ..., "+y.map((w,v)=>rc(w,r[a-Gl+v],n)).join(", ")+"]"]}return["["+(n==="complex64"?oc(t):Array.from(t)).map((x,m)=>rc(x,r[m],n)).join(", ")+"]"]}const c=e.slice(1),u=s.slice(1),d=s[0]*i,h=[];if(a>bC){for(let g=0;g0?h[0]+f:"");for(let g=1;g1)for(let c=0;cbC){const x=Gl*i;let m=Array.from(t.slice(0,x)),y=Array.from(t.slice((a-Gl)*i,a*i));return n==="complex64"&&(m=oc(m),y=oc(y)),["["+m.map((w,v)=>rc(w,r[v],n)).join(", ")+", ..., "+y.map((w,v)=>rc(w,r[a-Gl+v],n)).join(", ")+"]"]}return["["+(n==="complex64"?oc(t):Array.from(t)).map((x,m)=>rc(x,r[m],n)).join(", ")+"]"]}const c=e.slice(1),u=s.slice(1),h=s[0]*i,d=[];if(a>bC){for(let g=0;g0?d[0]+f:"");for(let g=1;g`Length of values '${r}' does not match the size inferred by the shape '${this.size}'.`)}if(n==="complex64")throw new Error("complex64 dtype TensorBuffers are not supported. Please create a TensorBuffer for the real and imaginary parts separately and call tf.complex(real, imag).");this.values=s||kt(n,this.size),this.strides=pe(e)}set(e,...n){n.length===0&&(n=[0]),I(n.length===this.rank,()=>`The number of provided coordinates (${n.length}) must match the rank (${this.rank})`);const s=this.locToIndex(n);this.values[s]=e}get(...e){e.length===0&&(e=[0]);let n=0;for(const r of e){if(r<0||r>=this.shape[n]){const o=`Requested out of range element at ${e}. Buffer shape=${this.shape}`;throw new Error(o)}n++}let s=e[e.length-1];for(let r=0;rDo(s))}catch{throw new Error("Failed to decode the string bytes into utf-8. To get the original bytes, call tensor.bytes().")}}return e}dataToGPU(e){return this.throwIfDisposed(),Vs().readToGPU(this.dataId,e)}dataSync(){this.throwIfDisposed();const e=Vs().readSync(this.dataId);if(this.dtype==="string")try{return e.map(n=>Do(n))}catch{throw new Error("Failed to decode the string bytes into utf-8. To get the original bytes, call tensor.bytes().")}return e}async bytes(){this.throwIfDisposed();const e=await Vs().read(this.dataId);return this.dtype==="string"?e:new Uint8Array(e.buffer)}dispose(){this.isDisposed||(this.kerasMask&&this.kerasMask.dispose(),Vs().disposeTensor(this),this.isDisposedInternal=!0)}get isDisposed(){return this.isDisposedInternal}throwIfDisposed(){if(this.isDisposed)throw new Error("Tensor is disposed.")}print(e=!1){return fa.print(this,e)}clone(){return this.throwIfDisposed(),fa.clone(this)}toString(e=!1){const n=this.dataSync();return oP(n,this.shape,this.dtype,e)}cast(e){return this.throwIfDisposed(),fa.cast(this,e)}variable(e=!0,n,s){return this.throwIfDisposed(),Vs().makeVariable(this,e,n,s)}}Object.defineProperty(zt,Symbol.hasInstance,{value:t=>!!t&&t.data!=null&&t.dataSync!=null&&t.throwIfDisposed!=null});function H(){return Ux("Tensor",()=>zt)}H();class xf extends zt{constructor(e,n,s,r){super(e.shape,e.dtype,e.dataId,r),this.trainable=n,this.name=s}assign(e){if(e.dtype!==this.dtype)throw new Error(`dtype of the new value (${e.dtype}) and previous value (${this.dtype}) must match`);if(!Ue(e.shape,this.shape))throw new Error(`shape of the new value (${e.shape}) and previous value (${this.shape}) must match`);Vs().disposeTensor(this),this.dataId=e.dataId,Vs().incRef(this,null)}dispose(){Vs().disposeVariable(this),this.isDisposedInternal=!0}}Object.defineProperty(xf,Symbol.hasInstance,{value:t=>t instanceof zt&&t.assign!=null&&t.assign instanceof Function});/** + */class tn{constructor(e,n,s){if(this.dtype=n,this.shape=e.slice(),this.size=j(e),s!=null){const r=s.length;I(r===this.size,()=>`Length of values '${r}' does not match the size inferred by the shape '${this.size}'.`)}if(n==="complex64")throw new Error("complex64 dtype TensorBuffers are not supported. Please create a TensorBuffer for the real and imaginary parts separately and call tf.complex(real, imag).");this.values=s||kt(n,this.size),this.strides=pe(e)}set(e,...n){n.length===0&&(n=[0]),I(n.length===this.rank,()=>`The number of provided coordinates (${n.length}) must match the rank (${this.rank})`);const s=this.locToIndex(n);this.values[s]=e}get(...e){e.length===0&&(e=[0]);let n=0;for(const r of e){if(r<0||r>=this.shape[n]){const o=`Requested out of range element at ${e}. Buffer shape=${this.shape}`;throw new Error(o)}n++}let s=e[e.length-1];for(let r=0;rDo(s))}catch{throw new Error("Failed to decode the string bytes into utf-8. To get the original bytes, call tensor.bytes().")}}return e}dataToGPU(e){return this.throwIfDisposed(),Ws().readToGPU(this.dataId,e)}dataSync(){this.throwIfDisposed();const e=Ws().readSync(this.dataId);if(this.dtype==="string")try{return e.map(n=>Do(n))}catch{throw new Error("Failed to decode the string bytes into utf-8. To get the original bytes, call tensor.bytes().")}return e}async bytes(){this.throwIfDisposed();const e=await Ws().read(this.dataId);return this.dtype==="string"?e:new Uint8Array(e.buffer)}dispose(){this.isDisposed||(this.kerasMask&&this.kerasMask.dispose(),Ws().disposeTensor(this),this.isDisposedInternal=!0)}get isDisposed(){return this.isDisposedInternal}throwIfDisposed(){if(this.isDisposed)throw new Error("Tensor is disposed.")}print(e=!1){return fa.print(this,e)}clone(){return this.throwIfDisposed(),fa.clone(this)}toString(e=!1){const n=this.dataSync();return iP(n,this.shape,this.dtype,e)}cast(e){return this.throwIfDisposed(),fa.cast(this,e)}variable(e=!0,n,s){return this.throwIfDisposed(),Ws().makeVariable(this,e,n,s)}}Object.defineProperty(zt,Symbol.hasInstance,{value:t=>!!t&&t.data!=null&&t.dataSync!=null&&t.throwIfDisposed!=null});function H(){return Ux("Tensor",()=>zt)}H();class xf extends zt{constructor(e,n,s,r){super(e.shape,e.dtype,e.dataId,r),this.trainable=n,this.name=s}assign(e){if(e.dtype!==this.dtype)throw new Error(`dtype of the new value (${e.dtype}) and previous value (${this.dtype}) must match`);if(!Ue(e.shape,this.shape))throw new Error(`shape of the new value (${e.shape}) and previous value (${this.shape}) must match`);Ws().disposeTensor(this),this.dataId=e.dataId,Ws().incRef(this,null)}dispose(){Ws().disposeVariable(this),this.isDisposedInternal=!0}}Object.defineProperty(xf,Symbol.hasInstance,{value:t=>t instanceof zt&&t.assign!=null&&t.assign instanceof Function});/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -317,7 +317,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */var CC;(function(t){t.R0="R0",t.R1="R1",t.R2="R2",t.R3="R3",t.R4="R4",t.R5="R5",t.R6="R6"})(CC||(CC={}));var s1;(function(t){t.float32="float32",t.int32="int32",t.bool="int32",t.complex64="complex64"})(s1||(s1={}));var r1;(function(t){t.float32="float32",t.int32="int32",t.bool="bool",t.complex64="complex64"})(r1||(r1={}));var o1;(function(t){t.float32="float32",t.int32="float32",t.bool="float32",t.complex64="complex64"})(o1||(o1={}));var i1;(function(t){t.float32="complex64",t.int32="complex64",t.bool="complex64",t.complex64="complex64"})(i1||(i1={}));const cP={float32:o1,int32:s1,bool:r1,complex64:i1};function Xn(t,e){if(t==="string"||e==="string"){if(t==="string"&&e==="string")return"string";throw new Error(`Can not upcast ${t} with ${e}`)}return cP[t][e]}function Dy(t){return Xn(t,"int32")}function A$(t){return t!=null&&typeof t=="object"&&"texture"in t&&t.texture instanceof WebGLTexture}function D$(t){return typeof GPUBuffer<"u"&&t!=null&&typeof t=="object"&&"buffer"in t&&t.buffer instanceof GPUBuffer}/** + */var CC;(function(t){t.R0="R0",t.R1="R1",t.R2="R2",t.R3="R3",t.R4="R4",t.R5="R5",t.R6="R6"})(CC||(CC={}));var s1;(function(t){t.float32="float32",t.int32="int32",t.bool="int32",t.complex64="complex64"})(s1||(s1={}));var r1;(function(t){t.float32="float32",t.int32="int32",t.bool="bool",t.complex64="complex64"})(r1||(r1={}));var o1;(function(t){t.float32="float32",t.int32="float32",t.bool="float32",t.complex64="complex64"})(o1||(o1={}));var i1;(function(t){t.float32="complex64",t.int32="complex64",t.bool="complex64",t.complex64="complex64"})(i1||(i1={}));const uP={float32:o1,int32:s1,bool:r1,complex64:i1};function Xn(t,e){if(t==="string"||e==="string"){if(t==="string"&&e==="string")return"string";throw new Error(`Can not upcast ${t} with ${e}`)}return uP[t][e]}function Dy(t){return Xn(t,"int32")}function D$(t){return t!=null&&typeof t=="object"&&"texture"in t&&t.texture instanceof WebGLTexture}function _$(t){return typeof GPUBuffer<"u"&&t!=null&&typeof t=="object"&&"buffer"in t&&t.buffer instanceof GPUBuffer}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -332,7 +332,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function It(t,e){if(t.dtype===e.dtype)return[t,e];const n=Xn(t.dtype,e.dtype);return[t.cast(n),e.cast(n)]}function _$(t){const e=[];return F$(t,e,new Set),e}function F$(t,e,n){if(t==null)return;if(t instanceof zt){e.push(t);return}if(!uP(t))return;const s=t;for(const r in s){const o=s[r];n.has(o)||(n.add(o),F$(o,e,n))}}function uP(t){return Array.isArray(t)||typeof t=="object"}/** + */function It(t,e){if(t.dtype===e.dtype)return[t,e];const n=Xn(t.dtype,e.dtype);return[t.cast(n),e.cast(n)]}function F$(t){const e=[];return z$(t,e,new Set),e}function z$(t,e,n){if(t==null)return;if(t instanceof zt){e.push(t);return}if(!hP(t))return;const s=t;for(const r in s){const o=s[r];n.has(o)||(n.add(o),z$(o,e,n))}}function hP(t){return Array.isArray(t)||typeof t=="object"}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -347,7 +347,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Cg(t){return t.kernelName!=null}class kC{constructor(){this.registeredVariables={},this.nextTapeNodeId=0,this.numBytes=0,this.numTensors=0,this.numStringTensors=0,this.numDataBuffers=0,this.gradientDepth=0,this.kernelDepth=0,this.scopeStack=[],this.numDataMovesStack=[],this.nextScopeId=0,this.tensorInfo=new WeakMap,this.profiling=!1,this.activeProfile={newBytes:0,newTensors:0,peakBytes:0,kernels:[],result:null,get kernelNames(){return Array.from(new Set(this.kernels.map(e=>e.name)))}}}dispose(){for(const e in this.registeredVariables)this.registeredVariables[e].dispose()}}class rl{constructor(e){this.ENV=e,this.registry={},this.registryFactory={},this.pendingBackendInitId=0,this.state=new kC}async ready(){if(this.pendingBackendInit!=null)return this.pendingBackendInit.then(()=>{});if(this.backendInstance!=null)return;const e=this.getSortedBackends();for(let n=0;n{n.setupFunc!=null&&n.setupFunc(this.backendInstance)})}disposeRegisteredKernels(e){pC(e).forEach(s=>{s.disposeFunc!=null&&s.disposeFunc(this.registry[e])})}initializeBackend(e){const n=this.registryFactory[e];if(n==null)throw new Error(`Cannot initialize backend ${e}, no registration found.`);try{const s=n.factory();if(s&&!(s instanceof Mx)&&typeof s.then=="function"){const r=++this.pendingBackendInitId,o=s.then(i=>r(rthis.registryFactory[n].priority-this.registryFactory[e].priority)}initializeBackendsAndReturnBest(){const e=this.getSortedBackends();for(let n=0;nthis.startScope(s),()=>this.endScope(r),()=>(r=n(),r instanceof Promise&&console.error("Cannot return a Promise inside of tidy."),r))}scopedRun(e,n,s){e();try{const r=s();return n(),r}catch(r){throw n(),r}}nextTensorId(){return rl.nextTensorId++}nextVariableId(){return rl.nextVariableId++}clone(e){const n=_.runKernel(Fu,{x:e}),s={x:e},r=i=>({x:()=>{const a="float32",l={x:i},c={dtype:a};return _.runKernel(bu,l,c)}}),o=[];return this.addTapeNode(this.state.activeScope.name,s,[n],r,o,{}),n}runKernel(e,n,s){if(this.backendName==null&&this.backend,!(hC(e,this.backendName)!=null))throw new Error(`Kernel '${e}' not registered for backend '${this.backendName}'`);return this.runKernelFunc({kernelName:e,inputs:n,attrs:s})}shouldCheckForMemLeaks(){return this.ENV.getBool("IS_TEST")}checkKernelForMemLeak(e,n,s){const r=this.backend.numDataIds();let o=0;s.forEach(l=>{o+=l.dtype==="complex64"?3:1});const i=this.state.numDataMovesStack[this.state.numDataMovesStack.length-1],a=r-n-o-i;if(a>0)throw new Error(`Backend '${this.backendName}' has an internal memory leak (${a} data ids) after running '${e}'`)}runKernelFunc(e){let n,s=[];const r=this.isTapeOn(),o=this.state.numBytes,i=this.state.numTensors;this.shouldCheckForMemLeaks()&&this.state.numDataMovesStack.push(0);let a;this.backendName==null&&this.backend;let l;const c=Cg(e)?e.kernelName:this.state.activeScope!=null?this.state.activeScope.name:"";if(Cg(e)){const{kernelName:p,inputs:g,attrs:x}=e;this.backendName==null&&this.backend;const m=hC(p,this.backendName);I(m!=null,()=>`Cannot find registered kernel '${p}' for backend '${this.backendName}'`),a=()=>{const y=this.backend.numDataIds();l=m.kernelFunc({inputs:g,attrs:x,backend:this.backend});const w=Array.isArray(l)?l:[l];this.shouldCheckForMemLeaks()&&this.checkKernelForMemLeak(p,y,w);const v=w.map(b=>b.rank!=null?b:this.makeTensorFromTensorInfo(b));if(r){const b=this.getTensorsForGradient(p,g,v);s=this.saveTensorsForBackwardMode(b)}return v}}else{const{forwardFunc:p}=e,g=x=>{r&&(s=x.map(m=>this.keep(this.clone(m))))};a=()=>{const x=this.backend.numDataIds();l=this.tidy(()=>p(this.backend,g));const m=Array.isArray(l)?l:[l];return this.shouldCheckForMemLeaks()&&this.checkKernelForMemLeak(c,x,m),m}}const{inputs:u,attrs:d}=e,h=Cg(e)?null:e.backwardsFunc;let f;return this.scopedRun(()=>this.state.kernelDepth++,()=>this.state.kernelDepth--,()=>{!this.ENV.getBool("DEBUG")&&!this.state.profiling?n=a():(f=this.profiler.profileKernel(c,u,()=>a()),this.ENV.getBool("DEBUG")&&this.profiler.logKernelProfile(f),n=f.outputs)}),r&&this.addTapeNode(c,u,n,h,s,d),this.state.profiling&&this.state.activeProfile.kernels.push({name:c,bytesAdded:this.state.numBytes-o,totalBytesSnapshot:this.state.numBytes,tensorsAdded:this.state.numTensors-i,totalTensorsSnapshot:this.state.numTensors,inputShapes:Object.keys(u).map(p=>u[p]!=null?u[p].shape:null),outputShapes:n.map(p=>p.shape),kernelTimeMs:f.timeMs,extraInfo:f.extraInfo}),Array.isArray(l)?n:n[0]}saveTensorsForBackwardMode(e){return e.map(s=>this.keep(this.clone(s)))}getTensorsForGradient(e,n,s){const r=fC(e);if(r!=null){const o=r.inputsToSave||[],i=r.outputsToSave||[];let a;r.saveAllInputs?(I(Array.isArray(n),()=>"saveAllInputs is true, expected inputs to be an array."),a=Object.keys(n).map(c=>n[c])):a=o.map(c=>n[c]);const l=s.filter((c,u)=>i[u]);return a.concat(l)}return[]}makeTensor(e,n,s,r){if(e==null)throw new Error("Values passed to engine.makeTensor() are null");s=s||"float32",r=r||this.backend;let o=e;s==="string"&&fu(e[0])&&(o=e.map(l=>No(l)));const i=r.write(o,n,s),a=new zt(n,s,i,this.nextTensorId());if(this.trackTensor(a,r),s==="string"){const l=this.state.tensorInfo.get(i),c=AM(o);this.state.numBytes+=c-l.bytes,l.bytes=c}return a}makeTensorFromDataId(e,n,s,r){s=s||"float32";const o={dataId:e,shape:n,dtype:s};return this.makeTensorFromTensorInfo(o,r)}makeTensorFromTensorInfo(e,n){const{dataId:s,shape:r,dtype:o}=e,i=new zt(r,o,s,this.nextTensorId());return this.trackTensor(i,n),i}makeVariable(e,n=!0,s,r){s=s||this.nextVariableId().toString(),r!=null&&r!==e.dtype&&(e=e.cast(r));const o=new xf(e,n,s,this.nextTensorId());if(this.state.registeredVariables[o.name]!=null)throw new Error(`Variable with name ${o.name} was already registered`);return this.state.registeredVariables[o.name]=o,this.incRef(o,this.backend),o}trackTensor(e,n){this.state.numTensors++,e.dtype==="string"&&this.state.numStringTensors++;let s=0;e.dtype!=="complex64"&&e.dtype!=="string"&&(s=e.size*hf(e.dtype)),this.state.numBytes+=s,this.state.tensorInfo.has(e.dataId)||(this.state.numDataBuffers++,this.state.tensorInfo.set(e.dataId,{backend:n||this.backend,dtype:e.dtype,shape:e.shape,bytes:s})),e instanceof xf||this.track(e)}incRef(e,n){this.trackTensor(e,n),this.backend.incRef(e.dataId)}removeDataId(e,n){this.state.tensorInfo.has(e)&&this.state.tensorInfo.get(e).backend===n&&(this.state.tensorInfo.delete(e),this.state.numDataBuffers--)}disposeTensor(e){if(!this.state.tensorInfo.has(e.dataId))return;const n=this.state.tensorInfo.get(e.dataId);if(this.state.numTensors--,e.dtype==="string"&&(this.state.numStringTensors--,this.state.numBytes-=n.bytes),e.dtype!=="complex64"&&e.dtype!=="string"){const s=e.size*hf(e.dtype);this.state.numBytes-=s}n.backend.disposeData(e.dataId)&&this.removeDataId(e.dataId,n.backend)}disposeVariables(){for(const e in this.state.registeredVariables){const n=this.state.registeredVariables[e];this.disposeVariable(n)}}disposeVariable(e){this.disposeTensor(e),this.state.registeredVariables[e.name]!=null&&delete this.state.registeredVariables[e.name]}memory(){const e=this.backend.memory();return e.numTensors=this.state.numTensors,e.numDataBuffers=this.state.numDataBuffers,e.numBytes=this.state.numBytes,this.state.numStringTensors>0&&(e.unreliable=!0,e.reasons==null&&(e.reasons=[]),e.reasons.push("Memory usage by string tensors is approximate (2 bytes per character)")),e}async profile(e){this.state.profiling=!0;const n=this.state.numBytes,s=this.state.numTensors;this.state.activeProfile.kernels=[],this.state.activeProfile.result=await e(),this.state.profiling=!1,this.state.activeProfile.peakBytes=Math.max(...this.state.activeProfile.kernels.map(r=>r.totalBytesSnapshot)),this.state.activeProfile.newBytes=this.state.numBytes-n,this.state.activeProfile.newTensors=this.state.numTensors-s;for(const r of this.state.activeProfile.kernels)r.kernelTimeMs=await r.kernelTimeMs,r.extraInfo=await r.extraInfo;return this.state.activeProfile}isTapeOn(){return this.state.gradientDepth>0&&this.state.kernelDepth===0}addTapeNode(e,n,s,r,o,i){const a={id:this.state.nextTapeNodeId++,kernelName:e,inputs:n,outputs:s,saved:o},l=fC(e);l!=null&&(r=l.gradFunc),r!=null&&(a.gradient=c=>(c=c.map((u,d)=>{if(u==null){const h=s[d],f=un(h.size,h.dtype);return this.makeTensor(f,h.shape,h.dtype)}return u}),r(c.length>1?c:c[0],o,i))),this.state.activeTape.push(a)}keep(e){return e.kept=!0,e}startTape(){this.state.gradientDepth===0&&(this.state.activeTape=[]),this.state.gradientDepth++}endTape(){this.state.gradientDepth--}startScope(e){const n={track:[],name:"unnamed scope",id:this.state.nextScopeId++};e&&(n.name=e),this.state.scopeStack.push(n),this.state.activeScope=n}endScope(e){const n=_$(e),s=new Set(n.map(o=>o.id));for(let o=0;o{!o.kept&&o.scopeId===r.id&&this.track(o)})}gradients(e,n,s,r=!1){if(I(n.length>0,()=>"gradients() received an empty list of xs."),s!=null&&s.dtype!=="float32")throw new Error(`dy must have 'float32' dtype, but has '${s.dtype}'`);const o=this.scopedRun(()=>this.startTape(),()=>this.endTape(),()=>this.tidy("forward",e));I(o instanceof zt,()=>"The result y returned by f() must be a tensor.");const i=sP(this.state.activeTape,n,o);if(!r&&i.length===0&&n.length>0)throw new Error("Cannot compute gradient of y=f(x) with respect to x. Make sure that the f you passed encloses all operations that lead from x to y.");return this.tidy("backward",()=>{const a={};a[o.id]=s??dP(o.shape),rP(a,i,c=>this.tidy(c),hP);const l=n.map(c=>a[c.id]);return this.state.gradientDepth===0&&(this.state.activeTape.forEach(c=>{for(const u of c.saved)u.dispose()}),this.state.activeTape=null),{value:o,grads:l}})}customGrad(e){return I(Y0(e),()=>"The f passed in customGrad(f) must be a function."),(...n)=>{I(n.every(a=>a instanceof zt),()=>"The args passed in customGrad(f)(x1, x2,...) must all be tensors");let s;const r={};n.forEach((a,l)=>{r[l]=a});const o=(a,l)=>(s=e(...n,l),I(s.value instanceof zt,()=>"The function f passed in customGrad(f) must return an object where `obj.value` is a tensor"),I(Y0(s.gradFunc),()=>"The function f passed in customGrad(f) must return an object where `obj.gradFunc` is a function."),s.value),i=(a,l)=>{const c=s.gradFunc(a,l),u=Array.isArray(c)?c:[c];I(u.length===n.length,()=>"The function f passed in customGrad(f) must return an object where `obj.gradFunc` is a function that returns the same number of tensors as inputs passed to f(...)."),I(u.every(h=>h instanceof zt),()=>"The function f passed in customGrad(f) must return an object where `obj.gradFunc` is a function that returns a list of only tensors.");const d={};return u.forEach((h,f)=>{d[f]=()=>h}),d};return this.runKernelFunc({forwardFunc:o,backwardsFunc:i,inputs:r})}}readSync(e){return this.state.tensorInfo.get(e).backend.readSync(e)}read(e){return this.state.tensorInfo.get(e).backend.read(e)}readToGPU(e,n){return this.state.tensorInfo.get(e).backend.readToGPU(e,n)}async time(e){const n=Tn(),s=await this.backend.time(e);return s.wallMs=Tn()-n,s}track(e){return this.state.activeScope!=null&&(e.scopeId=this.state.activeScope.id,this.state.activeScope.track.push(e)),e}get registeredVariables(){return this.state.registeredVariables}reset(){this.pendingBackendInitId++,this.state.dispose(),this.ENV.reset(),this.state=new kC;for(const e in this.registry)this.disposeRegisteredKernels(e),this.registry[e].dispose(),delete this.registry[e];this.backendName=null,this.backendInstance=null,this.pendingBackendInit=null}}rl.nextTensorId=0;rl.nextVariableId=0;function dP(t){const e=Vx(j(t),"float32");return _.makeTensor(e,t,"float32")}function z$(){const t=Q2();if(t._tfengine==null){const e=new FM(t);t._tfengine=new rl(e)}return PM(t._tfengine.ENV),aP(()=>t._tfengine),t._tfengine}const _=z$();function hP(t,e){const n={a:t,b:e};return _.runKernel(bl,n)}/** + */function Cg(t){return t.kernelName!=null}class kC{constructor(){this.registeredVariables={},this.nextTapeNodeId=0,this.numBytes=0,this.numTensors=0,this.numStringTensors=0,this.numDataBuffers=0,this.gradientDepth=0,this.kernelDepth=0,this.scopeStack=[],this.numDataMovesStack=[],this.nextScopeId=0,this.tensorInfo=new WeakMap,this.profiling=!1,this.activeProfile={newBytes:0,newTensors:0,peakBytes:0,kernels:[],result:null,get kernelNames(){return Array.from(new Set(this.kernels.map(e=>e.name)))}}}dispose(){for(const e in this.registeredVariables)this.registeredVariables[e].dispose()}}class rl{constructor(e){this.ENV=e,this.registry={},this.registryFactory={},this.pendingBackendInitId=0,this.state=new kC}async ready(){if(this.pendingBackendInit!=null)return this.pendingBackendInit.then(()=>{});if(this.backendInstance!=null)return;const e=this.getSortedBackends();for(let n=0;n{n.setupFunc!=null&&n.setupFunc(this.backendInstance)})}disposeRegisteredKernels(e){pC(e).forEach(s=>{s.disposeFunc!=null&&s.disposeFunc(this.registry[e])})}initializeBackend(e){const n=this.registryFactory[e];if(n==null)throw new Error(`Cannot initialize backend ${e}, no registration found.`);try{const s=n.factory();if(s&&!(s instanceof Mx)&&typeof s.then=="function"){const r=++this.pendingBackendInitId,o=s.then(i=>r(rthis.registryFactory[n].priority-this.registryFactory[e].priority)}initializeBackendsAndReturnBest(){const e=this.getSortedBackends();for(let n=0;nthis.startScope(s),()=>this.endScope(r),()=>(r=n(),r instanceof Promise&&console.error("Cannot return a Promise inside of tidy."),r))}scopedRun(e,n,s){e();try{const r=s();return n(),r}catch(r){throw n(),r}}nextTensorId(){return rl.nextTensorId++}nextVariableId(){return rl.nextVariableId++}clone(e){const n=_.runKernel(Fu,{x:e}),s={x:e},r=i=>({x:()=>{const a="float32",l={x:i},c={dtype:a};return _.runKernel(bu,l,c)}}),o=[];return this.addTapeNode(this.state.activeScope.name,s,[n],r,o,{}),n}runKernel(e,n,s){if(this.backendName==null&&this.backend,!(dC(e,this.backendName)!=null))throw new Error(`Kernel '${e}' not registered for backend '${this.backendName}'`);return this.runKernelFunc({kernelName:e,inputs:n,attrs:s})}shouldCheckForMemLeaks(){return this.ENV.getBool("IS_TEST")}checkKernelForMemLeak(e,n,s){const r=this.backend.numDataIds();let o=0;s.forEach(l=>{o+=l.dtype==="complex64"?3:1});const i=this.state.numDataMovesStack[this.state.numDataMovesStack.length-1],a=r-n-o-i;if(a>0)throw new Error(`Backend '${this.backendName}' has an internal memory leak (${a} data ids) after running '${e}'`)}runKernelFunc(e){let n,s=[];const r=this.isTapeOn(),o=this.state.numBytes,i=this.state.numTensors;this.shouldCheckForMemLeaks()&&this.state.numDataMovesStack.push(0);let a;this.backendName==null&&this.backend;let l;const c=Cg(e)?e.kernelName:this.state.activeScope!=null?this.state.activeScope.name:"";if(Cg(e)){const{kernelName:p,inputs:g,attrs:x}=e;this.backendName==null&&this.backend;const m=dC(p,this.backendName);I(m!=null,()=>`Cannot find registered kernel '${p}' for backend '${this.backendName}'`),a=()=>{const y=this.backend.numDataIds();l=m.kernelFunc({inputs:g,attrs:x,backend:this.backend});const w=Array.isArray(l)?l:[l];this.shouldCheckForMemLeaks()&&this.checkKernelForMemLeak(p,y,w);const v=w.map(b=>b.rank!=null?b:this.makeTensorFromTensorInfo(b));if(r){const b=this.getTensorsForGradient(p,g,v);s=this.saveTensorsForBackwardMode(b)}return v}}else{const{forwardFunc:p}=e,g=x=>{r&&(s=x.map(m=>this.keep(this.clone(m))))};a=()=>{const x=this.backend.numDataIds();l=this.tidy(()=>p(this.backend,g));const m=Array.isArray(l)?l:[l];return this.shouldCheckForMemLeaks()&&this.checkKernelForMemLeak(c,x,m),m}}const{inputs:u,attrs:h}=e,d=Cg(e)?null:e.backwardsFunc;let f;return this.scopedRun(()=>this.state.kernelDepth++,()=>this.state.kernelDepth--,()=>{!this.ENV.getBool("DEBUG")&&!this.state.profiling?n=a():(f=this.profiler.profileKernel(c,u,()=>a()),this.ENV.getBool("DEBUG")&&this.profiler.logKernelProfile(f),n=f.outputs)}),r&&this.addTapeNode(c,u,n,d,s,h),this.state.profiling&&this.state.activeProfile.kernels.push({name:c,bytesAdded:this.state.numBytes-o,totalBytesSnapshot:this.state.numBytes,tensorsAdded:this.state.numTensors-i,totalTensorsSnapshot:this.state.numTensors,inputShapes:Object.keys(u).map(p=>u[p]!=null?u[p].shape:null),outputShapes:n.map(p=>p.shape),kernelTimeMs:f.timeMs,extraInfo:f.extraInfo}),Array.isArray(l)?n:n[0]}saveTensorsForBackwardMode(e){return e.map(s=>this.keep(this.clone(s)))}getTensorsForGradient(e,n,s){const r=fC(e);if(r!=null){const o=r.inputsToSave||[],i=r.outputsToSave||[];let a;r.saveAllInputs?(I(Array.isArray(n),()=>"saveAllInputs is true, expected inputs to be an array."),a=Object.keys(n).map(c=>n[c])):a=o.map(c=>n[c]);const l=s.filter((c,u)=>i[u]);return a.concat(l)}return[]}makeTensor(e,n,s,r){if(e==null)throw new Error("Values passed to engine.makeTensor() are null");s=s||"float32",r=r||this.backend;let o=e;s==="string"&&fu(e[0])&&(o=e.map(l=>No(l)));const i=r.write(o,n,s),a=new zt(n,s,i,this.nextTensorId());if(this.trackTensor(a,r),s==="string"){const l=this.state.tensorInfo.get(i),c=DM(o);this.state.numBytes+=c-l.bytes,l.bytes=c}return a}makeTensorFromDataId(e,n,s,r){s=s||"float32";const o={dataId:e,shape:n,dtype:s};return this.makeTensorFromTensorInfo(o,r)}makeTensorFromTensorInfo(e,n){const{dataId:s,shape:r,dtype:o}=e,i=new zt(r,o,s,this.nextTensorId());return this.trackTensor(i,n),i}makeVariable(e,n=!0,s,r){s=s||this.nextVariableId().toString(),r!=null&&r!==e.dtype&&(e=e.cast(r));const o=new xf(e,n,s,this.nextTensorId());if(this.state.registeredVariables[o.name]!=null)throw new Error(`Variable with name ${o.name} was already registered`);return this.state.registeredVariables[o.name]=o,this.incRef(o,this.backend),o}trackTensor(e,n){this.state.numTensors++,e.dtype==="string"&&this.state.numStringTensors++;let s=0;e.dtype!=="complex64"&&e.dtype!=="string"&&(s=e.size*df(e.dtype)),this.state.numBytes+=s,this.state.tensorInfo.has(e.dataId)||(this.state.numDataBuffers++,this.state.tensorInfo.set(e.dataId,{backend:n||this.backend,dtype:e.dtype,shape:e.shape,bytes:s})),e instanceof xf||this.track(e)}incRef(e,n){this.trackTensor(e,n),this.backend.incRef(e.dataId)}removeDataId(e,n){this.state.tensorInfo.has(e)&&this.state.tensorInfo.get(e).backend===n&&(this.state.tensorInfo.delete(e),this.state.numDataBuffers--)}disposeTensor(e){if(!this.state.tensorInfo.has(e.dataId))return;const n=this.state.tensorInfo.get(e.dataId);if(this.state.numTensors--,e.dtype==="string"&&(this.state.numStringTensors--,this.state.numBytes-=n.bytes),e.dtype!=="complex64"&&e.dtype!=="string"){const s=e.size*df(e.dtype);this.state.numBytes-=s}n.backend.disposeData(e.dataId)&&this.removeDataId(e.dataId,n.backend)}disposeVariables(){for(const e in this.state.registeredVariables){const n=this.state.registeredVariables[e];this.disposeVariable(n)}}disposeVariable(e){this.disposeTensor(e),this.state.registeredVariables[e.name]!=null&&delete this.state.registeredVariables[e.name]}memory(){const e=this.backend.memory();return e.numTensors=this.state.numTensors,e.numDataBuffers=this.state.numDataBuffers,e.numBytes=this.state.numBytes,this.state.numStringTensors>0&&(e.unreliable=!0,e.reasons==null&&(e.reasons=[]),e.reasons.push("Memory usage by string tensors is approximate (2 bytes per character)")),e}async profile(e){this.state.profiling=!0;const n=this.state.numBytes,s=this.state.numTensors;this.state.activeProfile.kernels=[],this.state.activeProfile.result=await e(),this.state.profiling=!1,this.state.activeProfile.peakBytes=Math.max(...this.state.activeProfile.kernels.map(r=>r.totalBytesSnapshot)),this.state.activeProfile.newBytes=this.state.numBytes-n,this.state.activeProfile.newTensors=this.state.numTensors-s;for(const r of this.state.activeProfile.kernels)r.kernelTimeMs=await r.kernelTimeMs,r.extraInfo=await r.extraInfo;return this.state.activeProfile}isTapeOn(){return this.state.gradientDepth>0&&this.state.kernelDepth===0}addTapeNode(e,n,s,r,o,i){const a={id:this.state.nextTapeNodeId++,kernelName:e,inputs:n,outputs:s,saved:o},l=fC(e);l!=null&&(r=l.gradFunc),r!=null&&(a.gradient=c=>(c=c.map((u,h)=>{if(u==null){const d=s[h],f=un(d.size,d.dtype);return this.makeTensor(f,d.shape,d.dtype)}return u}),r(c.length>1?c:c[0],o,i))),this.state.activeTape.push(a)}keep(e){return e.kept=!0,e}startTape(){this.state.gradientDepth===0&&(this.state.activeTape=[]),this.state.gradientDepth++}endTape(){this.state.gradientDepth--}startScope(e){const n={track:[],name:"unnamed scope",id:this.state.nextScopeId++};e&&(n.name=e),this.state.scopeStack.push(n),this.state.activeScope=n}endScope(e){const n=F$(e),s=new Set(n.map(o=>o.id));for(let o=0;o{!o.kept&&o.scopeId===r.id&&this.track(o)})}gradients(e,n,s,r=!1){if(I(n.length>0,()=>"gradients() received an empty list of xs."),s!=null&&s.dtype!=="float32")throw new Error(`dy must have 'float32' dtype, but has '${s.dtype}'`);const o=this.scopedRun(()=>this.startTape(),()=>this.endTape(),()=>this.tidy("forward",e));I(o instanceof zt,()=>"The result y returned by f() must be a tensor.");const i=rP(this.state.activeTape,n,o);if(!r&&i.length===0&&n.length>0)throw new Error("Cannot compute gradient of y=f(x) with respect to x. Make sure that the f you passed encloses all operations that lead from x to y.");return this.tidy("backward",()=>{const a={};a[o.id]=s??dP(o.shape),oP(a,i,c=>this.tidy(c),fP);const l=n.map(c=>a[c.id]);return this.state.gradientDepth===0&&(this.state.activeTape.forEach(c=>{for(const u of c.saved)u.dispose()}),this.state.activeTape=null),{value:o,grads:l}})}customGrad(e){return I(Y0(e),()=>"The f passed in customGrad(f) must be a function."),(...n)=>{I(n.every(a=>a instanceof zt),()=>"The args passed in customGrad(f)(x1, x2,...) must all be tensors");let s;const r={};n.forEach((a,l)=>{r[l]=a});const o=(a,l)=>(s=e(...n,l),I(s.value instanceof zt,()=>"The function f passed in customGrad(f) must return an object where `obj.value` is a tensor"),I(Y0(s.gradFunc),()=>"The function f passed in customGrad(f) must return an object where `obj.gradFunc` is a function."),s.value),i=(a,l)=>{const c=s.gradFunc(a,l),u=Array.isArray(c)?c:[c];I(u.length===n.length,()=>"The function f passed in customGrad(f) must return an object where `obj.gradFunc` is a function that returns the same number of tensors as inputs passed to f(...)."),I(u.every(d=>d instanceof zt),()=>"The function f passed in customGrad(f) must return an object where `obj.gradFunc` is a function that returns a list of only tensors.");const h={};return u.forEach((d,f)=>{h[f]=()=>d}),h};return this.runKernelFunc({forwardFunc:o,backwardsFunc:i,inputs:r})}}readSync(e){return this.state.tensorInfo.get(e).backend.readSync(e)}read(e){return this.state.tensorInfo.get(e).backend.read(e)}readToGPU(e,n){return this.state.tensorInfo.get(e).backend.readToGPU(e,n)}async time(e){const n=Tn(),s=await this.backend.time(e);return s.wallMs=Tn()-n,s}track(e){return this.state.activeScope!=null&&(e.scopeId=this.state.activeScope.id,this.state.activeScope.track.push(e)),e}get registeredVariables(){return this.state.registeredVariables}reset(){this.pendingBackendInitId++,this.state.dispose(),this.ENV.reset(),this.state=new kC;for(const e in this.registry)this.disposeRegisteredKernels(e),this.registry[e].dispose(),delete this.registry[e];this.backendName=null,this.backendInstance=null,this.pendingBackendInit=null}}rl.nextTensorId=0;rl.nextVariableId=0;function dP(t){const e=Vx(j(t),"float32");return _.makeTensor(e,t,"float32")}function O$(){const t=ZI();if(t._tfengine==null){const e=new zM(t);t._tfengine=new rl(e)}return LM(t._tfengine.ENV),lP(()=>t._tfengine),t._tfengine}const _=O$();function fP(t,e){const n={a:t,b:e};return _.runKernel(bl,n)}/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -362,7 +362,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function fP(){return typeof navigator<"u"&&navigator!=null}function O$(t){if(t||fP()){if(t||(t=navigator),t.product==="ReactNative")return!0;const e=t.userAgent||t.vendor||(typeof window<"u"?window.opera:"");if(!e){const n=t;return n.userAgentData&&n.userAgentData.mobile}return/(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows ce|xda|xiino/i.test(e)||/1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i.test(e.substr(0,4))}return!1}function M$(){return typeof window<"u"&&window.document!=null||typeof WorkerGlobalScope<"u"}/** + */function pP(){return typeof navigator<"u"&&navigator!=null}function M$(t){if(t||pP()){if(t||(t=navigator),t.product==="ReactNative")return!0;const e=t.userAgent||t.vendor||(typeof window<"u"?window.opera:"");if(!e){const n=t;return n.userAgentData&&n.userAgentData.mobile}return/(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows ce|xda|xiino/i.test(e)||/1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i.test(e.substr(0,4))}return!1}function P$(){return typeof window<"u"&&window.document!=null||typeof WorkerGlobalScope<"u"}/** * @license * Copyright 2019 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -377,7 +377,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const _n=W();_n.registerFlag("DEBUG",()=>!1,t=>{t&&console.warn("Debugging mode is ON. The output of every math call will be downloaded to CPU and checked for NaNs. This significantly impacts performance.")});_n.registerFlag("IS_BROWSER",()=>M$());_n.registerFlag("IS_NODE",()=>typeof process<"u"&&typeof process.versions<"u"&&typeof process.versions.node<"u");_n.registerFlag("IS_CHROME",()=>typeof navigator<"u"&&navigator!=null&&navigator.userAgent!=null&&/Chrome/.test(navigator.userAgent)&&/Google Inc/.test(navigator.vendor));_n.registerFlag("IS_SAFARI",()=>typeof navigator<"u"&&navigator!=null&&navigator.userAgent!=null&&/Safari/.test(navigator.userAgent)&&/Apple/.test(navigator.vendor));_n.registerFlag("PROD",()=>!1);_n.registerFlag("TENSORLIKE_CHECK_SHAPE_CONSISTENCY",()=>_n.getBool("DEBUG"));_n.registerFlag("DEPRECATION_WARNINGS_ENABLED",()=>!0);_n.registerFlag("IS_TEST",()=>!1);_n.registerFlag("CHECK_COMPUTATION_FOR_ERRORS",()=>_n.getBool("DEBUG"));_n.registerFlag("WRAP_TO_IMAGEBITMAP",()=>!1);_n.registerFlag("CANVAS2D_WILL_READ_FREQUENTLY_FOR_GPU",()=>!1);_n.registerFlag("USE_SETTIMEOUTCUSTOM",()=>!1);/** + */const _n=W();_n.registerFlag("DEBUG",()=>!1,t=>{t&&console.warn("Debugging mode is ON. The output of every math call will be downloaded to CPU and checked for NaNs. This significantly impacts performance.")});_n.registerFlag("IS_BROWSER",()=>P$());_n.registerFlag("IS_NODE",()=>typeof process<"u"&&typeof process.versions<"u"&&typeof process.versions.node<"u");_n.registerFlag("IS_CHROME",()=>typeof navigator<"u"&&navigator!=null&&navigator.userAgent!=null&&/Chrome/.test(navigator.userAgent)&&/Google Inc/.test(navigator.vendor));_n.registerFlag("IS_SAFARI",()=>typeof navigator<"u"&&navigator!=null&&navigator.userAgent!=null&&/Safari/.test(navigator.userAgent)&&/Apple/.test(navigator.vendor));_n.registerFlag("PROD",()=>!1);_n.registerFlag("TENSORLIKE_CHECK_SHAPE_CONSISTENCY",()=>_n.getBool("DEBUG"));_n.registerFlag("DEPRECATION_WARNINGS_ENABLED",()=>!0);_n.registerFlag("IS_TEST",()=>!1);_n.registerFlag("CHECK_COMPUTATION_FOR_ERRORS",()=>_n.getBool("DEBUG"));_n.registerFlag("WRAP_TO_IMAGEBITMAP",()=>!1);_n.registerFlag("CANVAS2D_WILL_READ_FREQUENTLY_FOR_GPU",()=>!1);_n.registerFlag("USE_SETTIMEOUTCUSTOM",()=>!1);/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -392,7 +392,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function cd(t,e){let n=t;if(Ts(t))return e==="string"?[]:[t.length];if(A$(t)){const r=t.channels||"RGBA";return[t.height,t.width*r.length]}else if(D$(t))return[t.buffer.size/(e==null?4:hf(e))];if(!Array.isArray(t))return[];const s=[];for(;Array.isArray(n)||Ts(n)&&e!=="string";)s.push(n.length),n=n[0];return Array.isArray(t)&&W().getBool("TENSORLIKE_CHECK_SHAPE_CONSISTENCY")&&P$(t,s,[]),s}function P$(t,e,n){if(n=n||[],!Array.isArray(t)&&!Ts(t)){I(e.length===0,()=>`Element arr[${n.join("][")}] is a primitive, but should be an array/TypedArray of ${e[0]} elements`);return}I(e.length>0,()=>`Element arr[${n.join("][")}] should be a primitive, but is an array of ${t.length} elements`),I(t.length===e[0],()=>`Element arr[${n.join("][")}] should have ${e[0]} elements, but has ${t.length} elements`);const s=e.slice(1);for(let r=0;r=0&&(r=s),SC(s,r,e,n),t==null||!Ts(t)&&!Array.isArray(t)&&typeof t!="number"&&typeof t!="boolean"&&typeof t!="string"){const l=t==null?"null":t.constructor.name;throw new Error(`Argument '${e}' passed to '${n}' must be a Tensor or TensorLike, but got '${l}'`)}const o=cd(t,r);!Ts(t)&&!Array.isArray(t)&&(t=[t]);const a=r!=="string"?Ki(t,r):Ei(t,[],!0);return _.makeTensor(a,o,r)}function L$(t,e,n,s="numeric"){if(!Array.isArray(t))throw new Error(`Argument ${e} passed to ${n} must be a \`Tensor[]\` or \`TensorLike[]\``);return t.map((o,i)=>T(o,`${e}[${i}]`,n,s))}/** + */function ch(t,e){let n=t;if(Es(t))return e==="string"?[]:[t.length];if(D$(t)){const r=t.channels||"RGBA";return[t.height,t.width*r.length]}else if(_$(t))return[t.buffer.size/(e==null?4:df(e))];if(!Array.isArray(t))return[];const s=[];for(;Array.isArray(n)||Es(n)&&e!=="string";)s.push(n.length),n=n[0];return Array.isArray(t)&&W().getBool("TENSORLIKE_CHECK_SHAPE_CONSISTENCY")&&L$(t,s,[]),s}function L$(t,e,n){if(n=n||[],!Array.isArray(t)&&!Es(t)){I(e.length===0,()=>`Element arr[${n.join("][")}] is a primitive, but should be an array/TypedArray of ${e[0]} elements`);return}I(e.length>0,()=>`Element arr[${n.join("][")}] should be a primitive, but is an array of ${t.length} elements`),I(t.length===e[0],()=>`Element arr[${n.join("][")}] should have ${e[0]} elements, but has ${t.length} elements`);const s=e.slice(1);for(let r=0;r=0&&(r=s),SC(s,r,e,n),t==null||!Es(t)&&!Array.isArray(t)&&typeof t!="number"&&typeof t!="boolean"&&typeof t!="string"){const l=t==null?"null":t.constructor.name;throw new Error(`Argument '${e}' passed to '${n}' must be a Tensor or TensorLike, but got '${l}'`)}const o=ch(t,r);!Es(t)&&!Array.isArray(t)&&(t=[t]);const a=r!=="string"?Ki(t,r):Ei(t,[],!0);return _.makeTensor(a,o,r)}function B$(t,e,n,s="numeric"){if(!Array.isArray(t))throw new Error(`Argument ${e} passed to ${n} must be a \`Tensor[]\` or \`TensorLike[]\``);return t.map((o,i)=>T(o,`${e}[${i}]`,n,s))}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -407,7 +407,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const pP="__op";function z(t){const e=Object.keys(t);if(e.length!==1)throw new Error(`Please provide an object with a single key (operation name) mapping to a function. Got an object with ${e.length} keys.`);let n=e[0];const s=t[n];n.endsWith("_")&&(n=n.substring(0,n.length-1)),n=n+pP;const r=(...o)=>{_.startScope(n);try{const i=s(...o);return Wx(i)&&console.error("Cannot return a Promise inside of tidy."),_.endScope(i),i}catch(i){throw _.endScope(null),i}};return Object.defineProperty(r,"name",{value:n,configurable:!0}),r}/** + */const mP="__op";function z(t){const e=Object.keys(t);if(e.length!==1)throw new Error(`Please provide an object with a single key (operation name) mapping to a function. Got an object with ${e.length} keys.`);let n=e[0];const s=t[n];n.endsWith("_")&&(n=n.substring(0,n.length-1)),n=n+mP;const r=(...o)=>{_.startScope(n);try{const i=s(...o);return Wx(i)&&console.error("Cannot return a Promise inside of tidy."),_.endScope(i),i}catch(i){throw _.endScope(null),i}};return Object.defineProperty(r,"name",{value:n,configurable:!0}),r}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -422,7 +422,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function mP(t,e){const n=T(t,"real","complex"),s=T(e,"imag","complex");Lx(n.shape,s.shape,`real and imag shapes, ${n.shape} and ${s.shape}, must match in call to tf.complex().`);const r={real:n,imag:s};return _.runKernel(Qx,r)}const Ri=z({complex_:mP});/** + */function gP(t,e){const n=T(t,"real","complex"),s=T(e,"imag","complex");Lx(n.shape,s.shape,`real and imag shapes, ${n.shape} and ${s.shape}, must match in call to tf.complex().`);const r={real:n,imag:s};return _.runKernel(Qx,r)}const Ri=z({complex_:gP});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -437,7 +437,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function ud(t,e,n,s){if(s==null)s=wl(t);else if(s==="complex64")throw new Error("Cannot construct a complex64 tensor directly. Please use tf.complex(real, imag).");if(D$(t)||A$(t)){if(s!=="float32"&&s!=="int32")throw new Error(`Creating tensor from GPU data only supports 'float32'|'int32' dtype, while the dtype is ${s}.`);return _.backend.createTensorFromGPUData(t,e||n,s)}if(!Ts(t)&&!Array.isArray(t)&&typeof t!="number"&&typeof t!="boolean"&&typeof t!="string")throw new Error("values passed to tensor(values) must be a number/boolean/string or an array of numbers/booleans/strings, or a TypedArray");if(e!=null){Xr(e);const r=j(e),o=j(n);I(r===o,()=>`Based on the provided shape, [${e}], the tensor should have ${r} values but has ${o}`);for(let i=0;i`Error creating a new Tensor. Inferred shape (${n}) does not match the provided shape (${e}). `)}}return!Ts(t)&&!Array.isArray(t)&&(t=[t]),e=e||n,t=s!=="string"?Ki(t,s):Ei(t,[],!0),_.makeTensor(t,e,s)}/** + */function uh(t,e,n,s){if(s==null)s=wl(t);else if(s==="complex64")throw new Error("Cannot construct a complex64 tensor directly. Please use tf.complex(real, imag).");if(_$(t)||D$(t)){if(s!=="float32"&&s!=="int32")throw new Error(`Creating tensor from GPU data only supports 'float32'|'int32' dtype, while the dtype is ${s}.`);return _.backend.createTensorFromGPUData(t,e||n,s)}if(!Es(t)&&!Array.isArray(t)&&typeof t!="number"&&typeof t!="boolean"&&typeof t!="string")throw new Error("values passed to tensor(values) must be a number/boolean/string or an array of numbers/booleans/strings, or a TypedArray");if(e!=null){qr(e);const r=j(e),o=j(n);I(r===o,()=>`Based on the provided shape, [${e}], the tensor should have ${r} values but has ${o}`);for(let i=0;i`Error creating a new Tensor. Inferred shape (${n}) does not match the provided shape (${e}). `)}}return!Es(t)&&!Array.isArray(t)&&(t=[t]),e=e||n,t=s!=="string"?Ki(t,s):Ei(t,[],!0),_.makeTensor(t,e,s)}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -452,7 +452,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function bc(t,e,n){const s=cd(t,n);return ud(t,e,s,n)}/** + */function bc(t,e,n){const s=ch(t,n);return uh(t,e,s,n)}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -467,7 +467,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const yf={float32:4,float16:2,int32:4,uint16:2,uint8:1,bool:1,complex64:8};class Uo{static join(e){return new Uo(e).slice()}constructor(e){if(this.shards=[],this.previousShardIndex=0,e==null||(e instanceof Array||(e=[e]),e=e.map(s=>Ts(s)?s.buffer:s),e.length===0))return;this.bufferUniformSize=e[0].byteLength;let n=0;for(let s=0;s=this.byteLength)return-1;if(this.bufferUniformSize!=null)return this.previousShardIndex=Math.floor(e/this.bufferUniformSize),this.previousShardIndex;function n(r){return e=r.end?1:0}if(n(this.shards[this.previousShardIndex])===0)return this.previousShardIndex;const s=gP(this.shards,n);return s===-1?-1:(this.previousShardIndex=s,this.previousShardIndex)}}function gP(t,e){let n=0,s=t.length;for(;n<=s;){const r=Math.floor((s-n)/2)+n,o=e(t[r]);if(o===0)return r;o<0?s=r:n=r+1}return-1}/** + */const yf={float32:4,float16:2,int32:4,uint16:2,uint8:1,bool:1,complex64:8};class Uo{static join(e){return new Uo(e).slice()}constructor(e){if(this.shards=[],this.previousShardIndex=0,e==null||(e instanceof Array||(e=[e]),e=e.map(s=>Es(s)?s.buffer:s),e.length===0))return;this.bufferUniformSize=e[0].byteLength;let n=0;for(let s=0;s=this.byteLength)return-1;if(this.bufferUniformSize!=null)return this.previousShardIndex=Math.floor(e/this.bufferUniformSize),this.previousShardIndex;function n(r){return e=r.end?1:0}if(n(this.shards[this.previousShardIndex])===0)return this.previousShardIndex;const s=xP(this.shards,n);return s===-1?-1:(this.previousShardIndex=s,this.previousShardIndex)}}function xP(t,e){let n=0,s=t.length;for(;n<=s;){const r=Math.floor((s-n)/2)+n,o=e(t[r]);if(o===0)return r;o<0?s=r:n=r+1}return-1}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -482,7 +482,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function or(){return _}function IC(){return _.memory()}function P(t,e){return _.tidy(t,e)}function $e(t){_$(t).forEach(n=>n.dispose())}function xr(t){return _.keep(t)}function B$(t,e,n=1){return _.registerBackend(t,e,n)}function xP(){return _.backend}/** + */function ir(){return _}function IC(){return _.memory()}function P(t,e){return _.tidy(t,e)}function $e(t){F$(t).forEach(n=>n.dispose())}function yr(t){return _.keep(t)}function V$(t,e,n=1){return _.registerBackend(t,e,n)}function yP(){return _.backend}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -497,7 +497,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const ol=4;async function $C(t,e){const n=[],s=[],r=Array.isArray(t)?t.map(i=>i.name):Object.keys(t);for(let i=0;i{const h=await l.bytes(),f=h.reduce((x,m)=>x+m.length,0)+ol*h.length,p=new Uint8Array(f);let g=0;for(let x=0;xn.slice(r+a,r+l));s[o.name]=vP(o,n.slice(r,r+i)),r+=i}return s}function wP(t,e){const n=j(t.shape);let s;if("quantization"in t){const r=t.quantization;s=yf[r.dtype]}else if(t.dtype==="string"){let r=0;for(let o=0;o{if(e+=o.byteLength,n.push(o.byteLength===o.buffer.byteLength?o:new o.constructor(o)),!(o instanceof Float32Array||o instanceof Int32Array||o instanceof Uint8Array))throw new Error(`Unsupported TypedArray subtype: ${o.constructor.name}`)});const s=new Uint8Array(e);let r=0;return n.forEach(o=>{s.set(new Uint8Array(o.buffer),r),r+=o.byteLength}),s.buffer}const _y=typeof Buffer<"u"&&(typeof Blob>"u"||typeof atob>"u"||typeof btoa>"u");function NC(t){return _y?Buffer.byteLength(t,"utf8"):new Blob([t]).size}function CP(t){if(_y)return Buffer.from(t).toString("base64");const e=new Uint8Array(t);let n="";for(let s=0,r=e.length;s{let s=n<<13,r=0;for(;!(s&8388608);)r-=8388608,s<<=1;return s&=-8388609,r+=947912704,s|r},e=new Uint32Array(2048);e[0]=0;for(let n=1;n<1024;n++)e[n]=t(n);for(let n=1024;n<2048;n++)e[n]=939524096+(n-1024<<13);return e}function EP(){const t=new Uint32Array(64);t[0]=0,t[31]=1199570944,t[32]=2147483648,t[63]=3347054592;for(let e=1;e<31;e++)t[e]=e<<23;for(let e=33;e<63;e++)t[e]=2147483648+(e-32<<23);return t}function RP(){const t=new Uint32Array(64);for(let e=0;e<64;e++)t[e]=1024;return t[0]=t[32]=0,t}function AP(){const t=TP(),e=EP(),n=RP();return s=>{const r=new ArrayBuffer(4*s.length),o=new Uint32Array(r);for(let i=0;i>10]+(a&1023)]+e[a>>10];o[i]=l}return new Float32Array(r)}}/** + */const ol=4;async function $C(t,e){const n=[],s=[],r=Array.isArray(t)?t.map(i=>i.name):Object.keys(t);for(let i=0;i{const d=await l.bytes(),f=d.reduce((x,m)=>x+m.length,0)+ol*d.length,p=new Uint8Array(f);let g=0;for(let x=0;xn.slice(r+a,r+l));s[o.name]=bP(o,n.slice(r,r+i)),r+=i}return s}function vP(t,e){const n=j(t.shape);let s;if("quantization"in t){const r=t.quantization;s=yf[r.dtype]}else if(t.dtype==="string"){let r=0;for(let o=0;o{if(e+=o.byteLength,n.push(o.byteLength===o.buffer.byteLength?o:new o.constructor(o)),!(o instanceof Float32Array||o instanceof Int32Array||o instanceof Uint8Array))throw new Error(`Unsupported TypedArray subtype: ${o.constructor.name}`)});const s=new Uint8Array(e);let r=0;return n.forEach(o=>{s.set(new Uint8Array(o.buffer),r),r+=o.byteLength}),s.buffer}const _y=typeof Buffer<"u"&&(typeof Blob>"u"||typeof atob>"u"||typeof btoa>"u");function NC(t){return _y?Buffer.byteLength(t,"utf8"):new Blob([t]).size}function kP(t){if(_y)return Buffer.from(t).toString("base64");const e=new Uint8Array(t);let n="";for(let s=0,r=e.length;s{let s=n<<13,r=0;for(;!(s&8388608);)r-=8388608,s<<=1;return s&=-8388609,r+=947912704,s|r},e=new Uint32Array(2048);e[0]=0;for(let n=1;n<1024;n++)e[n]=t(n);for(let n=1024;n<2048;n++)e[n]=939524096+(n-1024<<13);return e}function RP(){const t=new Uint32Array(64);t[0]=0,t[31]=1199570944,t[32]=2147483648,t[63]=3347054592;for(let e=1;e<31;e++)t[e]=e<<23;for(let e=33;e<63;e++)t[e]=2147483648+(e-32<<23);return t}function AP(){const t=new Uint32Array(64);for(let e=0;e<64;e++)t[e]=1024;return t[0]=t[32]=0,t}function DP(){const t=EP(),e=RP(),n=AP();return s=>{const r=new ArrayBuffer(4*s.length),o=new Uint32Array(r);for(let i=0;i>10]+(a&1023)]+e[a>>10];o[i]=l}return new Float32Array(r)}}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -512,7 +512,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class Gt{constructor(){this.saveRouters=[],this.loadRouters=[]}static getInstance(){return Gt.instance==null&&(Gt.instance=new Gt),Gt.instance}static registerSaveRouter(e){Gt.getInstance().saveRouters.push(e)}static registerLoadRouter(e){Gt.getInstance().loadRouters.push(e)}static getSaveHandlers(e){return Gt.getHandlers(e,"save")}static getLoadHandlers(e,n){return Gt.getHandlers(e,"load",n)}static getHandlers(e,n,s){const r=[];return(n==="load"?Gt.getInstance().loadRouters:Gt.getInstance().saveRouters).forEach(i=>{const a=i(e,s);a!==null&&r.push(a)}),r}}const DP=t=>Gt.getSaveHandlers(t),_P=(t,e)=>Gt.getLoadHandlers(t,e);/** + */class Gt{constructor(){this.saveRouters=[],this.loadRouters=[]}static getInstance(){return Gt.instance==null&&(Gt.instance=new Gt),Gt.instance}static registerSaveRouter(e){Gt.getInstance().saveRouters.push(e)}static registerLoadRouter(e){Gt.getInstance().loadRouters.push(e)}static getSaveHandlers(e){return Gt.getHandlers(e,"save")}static getLoadHandlers(e,n){return Gt.getHandlers(e,"load",n)}static getHandlers(e,n,s){const r=[];return(n==="load"?Gt.getInstance().loadRouters:Gt.getInstance().saveRouters).forEach(i=>{const a=i(e,s);a!==null&&r.push(a)}),r}}const _P=t=>Gt.getSaveHandlers(t),FP=(t,e)=>Gt.getLoadHandlers(t,e);/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -527,7 +527,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const a1="tensorflowjs",l1=1,fi="models_store",ho="model_info_store";function V$(){if(!W().getBool("IS_BROWSER"))throw new Error("Failed to obtain IndexedDB factory because the current environmentis not a web browser.");const t=typeof window>"u"?self:window,e=t.indexedDB||t.mozIndexedDB||t.webkitIndexedDB||t.msIndexedDB||t.shimIndexedDB;if(e==null)throw new Error("The current browser does not appear to support IndexedDB.");return e}function c1(t){const e=t.result;e.createObjectStore(fi,{keyPath:"modelPath"}),e.createObjectStore(ho,{keyPath:"modelPath"})}class Ai{constructor(e){if(this.indexedDB=V$(),e==null||!e)throw new Error("For IndexedDB, modelPath must not be null, undefined or empty.");this.modelPath=e}async save(e){if(e.modelTopology instanceof ArrayBuffer)throw new Error("BrowserLocalStorage.save() does not support saving model topology in binary formats yet.");return this.databaseAction(this.modelPath,e)}async load(){return this.databaseAction(this.modelPath)}databaseAction(e,n){return new Promise((s,r)=>{const o=this.indexedDB.open(a1,l1);o.onupgradeneeded=()=>c1(o),o.onsuccess=()=>{const i=o.result;if(n==null){const a=i.transaction(fi,"readonly"),c=a.objectStore(fi).get(this.modelPath);c.onsuccess=()=>{if(c.result==null)return i.close(),r(new Error(`Cannot find model with path '${this.modelPath}' in IndexedDB.`));s(c.result.modelArtifacts)},c.onerror=u=>(i.close(),r(c.error)),a.oncomplete=()=>i.close()}else{n.weightData=Uo.join(n.weightData);const a=Fy(n),l=i.transaction(ho,"readwrite");let c=l.objectStore(ho),u;try{u=c.put({modelPath:this.modelPath,modelArtifactsInfo:a})}catch(h){return r(h)}let d;u.onsuccess=()=>{d=i.transaction(fi,"readwrite");const h=d.objectStore(fi);let f;try{f=h.put({modelPath:this.modelPath,modelArtifacts:n,modelArtifactsInfo:a})}catch(p){return r(p)}f.onsuccess=()=>s({modelArtifactsInfo:a}),f.onerror=p=>{c=l.objectStore(ho);const g=c.delete(this.modelPath);g.onsuccess=()=>(i.close(),r(f.error)),g.onerror=x=>(i.close(),r(f.error))}},u.onerror=h=>(i.close(),r(u.error)),l.oncomplete=()=>{d==null?i.close():d.oncomplete=()=>i.close()}}},o.onerror=i=>r(o.error)})}}Ai.URL_SCHEME="indexeddb://";const W$=t=>W().getBool("IS_BROWSER")&&!Array.isArray(t)&&t.startsWith(Ai.URL_SCHEME)?FP(t.slice(Ai.URL_SCHEME.length)):null;Gt.registerSaveRouter(W$);Gt.registerLoadRouter(W$);function FP(t){return new Ai(t)}function zP(t){return t.startsWith(Ai.URL_SCHEME)?t.slice(Ai.URL_SCHEME.length):t}class OP{constructor(){this.indexedDB=V$()}async listModels(){return new Promise((e,n)=>{const s=this.indexedDB.open(a1,l1);s.onupgradeneeded=()=>c1(s),s.onsuccess=()=>{const r=s.result,o=r.transaction(ho,"readonly"),a=o.objectStore(ho).getAll();a.onsuccess=()=>{const l={};for(const c of a.result)l[c.modelPath]=c.modelArtifactsInfo;e(l)},a.onerror=l=>(r.close(),n(a.error)),o.oncomplete=()=>r.close()},s.onerror=r=>n(s.error)})}async removeModel(e){return e=zP(e),new Promise((n,s)=>{const r=this.indexedDB.open(a1,l1);r.onupgradeneeded=()=>c1(r),r.onsuccess=()=>{const o=r.result,i=o.transaction(ho,"readwrite"),a=i.objectStore(ho),l=a.get(e);let c;l.onsuccess=()=>{if(l.result==null)return o.close(),s(new Error(`Cannot find model with path '${e}' in IndexedDB.`));{const u=a.delete(e),d=()=>{c=o.transaction(fi,"readwrite");const f=c.objectStore(fi).delete(e);f.onsuccess=()=>n(l.result.modelArtifactsInfo),f.onerror=p=>s(l.error)};u.onsuccess=d,u.onerror=h=>(d(),o.close(),s(l.error))}},l.onerror=u=>(o.close(),s(l.error)),i.oncomplete=()=>{c==null?o.close():c.oncomplete=()=>o.close()}},r.onerror=o=>s(r.error)})}}/** + */const a1="tensorflowjs",l1=1,fi="models_store",ho="model_info_store";function W$(){if(!W().getBool("IS_BROWSER"))throw new Error("Failed to obtain IndexedDB factory because the current environmentis not a web browser.");const t=typeof window>"u"?self:window,e=t.indexedDB||t.mozIndexedDB||t.webkitIndexedDB||t.msIndexedDB||t.shimIndexedDB;if(e==null)throw new Error("The current browser does not appear to support IndexedDB.");return e}function c1(t){const e=t.result;e.createObjectStore(fi,{keyPath:"modelPath"}),e.createObjectStore(ho,{keyPath:"modelPath"})}class Ai{constructor(e){if(this.indexedDB=W$(),e==null||!e)throw new Error("For IndexedDB, modelPath must not be null, undefined or empty.");this.modelPath=e}async save(e){if(e.modelTopology instanceof ArrayBuffer)throw new Error("BrowserLocalStorage.save() does not support saving model topology in binary formats yet.");return this.databaseAction(this.modelPath,e)}async load(){return this.databaseAction(this.modelPath)}databaseAction(e,n){return new Promise((s,r)=>{const o=this.indexedDB.open(a1,l1);o.onupgradeneeded=()=>c1(o),o.onsuccess=()=>{const i=o.result;if(n==null){const a=i.transaction(fi,"readonly"),c=a.objectStore(fi).get(this.modelPath);c.onsuccess=()=>{if(c.result==null)return i.close(),r(new Error(`Cannot find model with path '${this.modelPath}' in IndexedDB.`));s(c.result.modelArtifacts)},c.onerror=u=>(i.close(),r(c.error)),a.oncomplete=()=>i.close()}else{n.weightData=Uo.join(n.weightData);const a=Fy(n),l=i.transaction(ho,"readwrite");let c=l.objectStore(ho),u;try{u=c.put({modelPath:this.modelPath,modelArtifactsInfo:a})}catch(d){return r(d)}let h;u.onsuccess=()=>{h=i.transaction(fi,"readwrite");const d=h.objectStore(fi);let f;try{f=d.put({modelPath:this.modelPath,modelArtifacts:n,modelArtifactsInfo:a})}catch(p){return r(p)}f.onsuccess=()=>s({modelArtifactsInfo:a}),f.onerror=p=>{c=l.objectStore(ho);const g=c.delete(this.modelPath);g.onsuccess=()=>(i.close(),r(f.error)),g.onerror=x=>(i.close(),r(f.error))}},u.onerror=d=>(i.close(),r(u.error)),l.oncomplete=()=>{h==null?i.close():h.oncomplete=()=>i.close()}}},o.onerror=i=>r(o.error)})}}Ai.URL_SCHEME="indexeddb://";const U$=t=>W().getBool("IS_BROWSER")&&!Array.isArray(t)&&t.startsWith(Ai.URL_SCHEME)?zP(t.slice(Ai.URL_SCHEME.length)):null;Gt.registerSaveRouter(U$);Gt.registerLoadRouter(U$);function zP(t){return new Ai(t)}function OP(t){return t.startsWith(Ai.URL_SCHEME)?t.slice(Ai.URL_SCHEME.length):t}class MP{constructor(){this.indexedDB=W$()}async listModels(){return new Promise((e,n)=>{const s=this.indexedDB.open(a1,l1);s.onupgradeneeded=()=>c1(s),s.onsuccess=()=>{const r=s.result,o=r.transaction(ho,"readonly"),a=o.objectStore(ho).getAll();a.onsuccess=()=>{const l={};for(const c of a.result)l[c.modelPath]=c.modelArtifactsInfo;e(l)},a.onerror=l=>(r.close(),n(a.error)),o.oncomplete=()=>r.close()},s.onerror=r=>n(s.error)})}async removeModel(e){return e=OP(e),new Promise((n,s)=>{const r=this.indexedDB.open(a1,l1);r.onupgradeneeded=()=>c1(r),r.onsuccess=()=>{const o=r.result,i=o.transaction(ho,"readwrite"),a=i.objectStore(ho),l=a.get(e);let c;l.onsuccess=()=>{if(l.result==null)return o.close(),s(new Error(`Cannot find model with path '${e}' in IndexedDB.`));{const u=a.delete(e),h=()=>{c=o.transaction(fi,"readwrite");const f=c.objectStore(fi).delete(e);f.onsuccess=()=>n(l.result.modelArtifactsInfo),f.onerror=p=>s(l.error)};u.onsuccess=h,u.onerror=d=>(h(),o.close(),s(l.error))}},l.onerror=u=>(o.close(),s(l.error)),i.oncomplete=()=>{c==null?o.close():c.oncomplete=()=>o.close()}},r.onerror=o=>s(r.error)})}}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -542,7 +542,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const _r="/",pa="tensorflowjs_models",U$="info",MP="model_topology",PP="weight_specs",LP="weight_data",BP="model_metadata";function G$(t){return{info:[pa,t,U$].join(_r),topology:[pa,t,MP].join(_r),weightSpecs:[pa,t,PP].join(_r),weightData:[pa,t,LP].join(_r),modelMetadata:[pa,t,BP].join(_r)}}function H$(t){for(const e of Object.values(t))window.localStorage.removeItem(e)}function VP(t){const e=t.split(_r);if(e.length<3)throw new Error(`Invalid key format: ${t}`);return e.slice(1,e.length-1).join(_r)}function WP(t){return t.startsWith(Di.URL_SCHEME)?t.slice(Di.URL_SCHEME.length):t}class Di{constructor(e){if(!W().getBool("IS_BROWSER")||typeof window>"u"||typeof window.localStorage>"u")throw new Error("The current environment does not support local storage.");if(this.LS=window.localStorage,e==null||!e)throw new Error("For local storage, modelPath must not be null, undefined or empty.");this.modelPath=e,this.keys=G$(this.modelPath)}async save(e){if(e.modelTopology instanceof ArrayBuffer)throw new Error("BrowserLocalStorage.save() does not support saving model topology in binary formats yet.");{const n=JSON.stringify(e.modelTopology),s=JSON.stringify(e.weightSpecs),r=Fy(e),o=Uo.join(e.weightData);try{this.LS.setItem(this.keys.info,JSON.stringify(r)),this.LS.setItem(this.keys.topology,n),this.LS.setItem(this.keys.weightSpecs,s),this.LS.setItem(this.keys.weightData,CP(o));const i={format:e.format,generatedBy:e.generatedBy,convertedBy:e.convertedBy,signature:e.signature!=null?e.signature:void 0,userDefinedMetadata:e.userDefinedMetadata!=null?e.userDefinedMetadata:void 0,modelInitializer:e.modelInitializer!=null?e.modelInitializer:void 0,initializerSignature:e.initializerSignature!=null?e.initializerSignature:void 0,trainingConfig:e.trainingConfig!=null?e.trainingConfig:void 0};return this.LS.setItem(this.keys.modelMetadata,JSON.stringify(i)),{modelArtifactsInfo:r}}catch{throw H$(this.keys),new Error(`Failed to save model '${this.modelPath}' to local storage: size quota being exceeded is a possible cause of this failure: modelTopologyBytes=${r.modelTopologyBytes}, weightSpecsBytes=${r.weightSpecsBytes}, weightDataBytes=${r.weightDataBytes}.`)}}}async load(){const e=JSON.parse(this.LS.getItem(this.keys.info));if(e==null)throw new Error(`In local storage, there is no model with name '${this.modelPath}'`);if(e.modelTopologyType!=="JSON")throw new Error("BrowserLocalStorage does not support loading non-JSON model topology yet.");const n={},s=JSON.parse(this.LS.getItem(this.keys.topology));if(s==null)throw new Error(`In local storage, the topology of model '${this.modelPath}' is missing.`);n.modelTopology=s;const r=JSON.parse(this.LS.getItem(this.keys.weightSpecs));if(r==null)throw new Error(`In local storage, the weight specs of model '${this.modelPath}' are missing.`);n.weightSpecs=r;const o=this.LS.getItem(this.keys.modelMetadata);if(o!=null){const a=JSON.parse(o);n.format=a.format,n.generatedBy=a.generatedBy,n.convertedBy=a.convertedBy,a.signature!=null&&(n.signature=a.signature),a.userDefinedMetadata!=null&&(n.userDefinedMetadata=a.userDefinedMetadata),a.modelInitializer!=null&&(n.modelInitializer=a.modelInitializer),a.initializerSignature!=null&&(n.initializerSignature=a.initializerSignature),a.trainingConfig!=null&&(n.trainingConfig=a.trainingConfig)}const i=this.LS.getItem(this.keys.weightData);if(i==null)throw new Error(`In local storage, the binary weight values of model '${this.modelPath}' are missing.`);return n.weightData=kP(i),n}}Di.URL_SCHEME="localstorage://";const j$=t=>W().getBool("IS_BROWSER")&&!Array.isArray(t)&&t.startsWith(Di.URL_SCHEME)?UP(t.slice(Di.URL_SCHEME.length)):null;Gt.registerSaveRouter(j$);Gt.registerLoadRouter(j$);function UP(t){return new Di(t)}class GP{constructor(){I(W().getBool("IS_BROWSER"),()=>"Current environment is not a web browser"),I(typeof window>"u"||typeof window.localStorage<"u",()=>"Current browser does not appear to support localStorage"),this.LS=window.localStorage}async listModels(){const e={},n=pa+_r,s=_r+U$;for(let r=0;r"u"||typeof window.localStorage>"u")throw new Error("The current environment does not support local storage.");if(this.LS=window.localStorage,e==null||!e)throw new Error("For local storage, modelPath must not be null, undefined or empty.");this.modelPath=e,this.keys=H$(this.modelPath)}async save(e){if(e.modelTopology instanceof ArrayBuffer)throw new Error("BrowserLocalStorage.save() does not support saving model topology in binary formats yet.");{const n=JSON.stringify(e.modelTopology),s=JSON.stringify(e.weightSpecs),r=Fy(e),o=Uo.join(e.weightData);try{this.LS.setItem(this.keys.info,JSON.stringify(r)),this.LS.setItem(this.keys.topology,n),this.LS.setItem(this.keys.weightSpecs,s),this.LS.setItem(this.keys.weightData,kP(o));const i={format:e.format,generatedBy:e.generatedBy,convertedBy:e.convertedBy,signature:e.signature!=null?e.signature:void 0,userDefinedMetadata:e.userDefinedMetadata!=null?e.userDefinedMetadata:void 0,modelInitializer:e.modelInitializer!=null?e.modelInitializer:void 0,initializerSignature:e.initializerSignature!=null?e.initializerSignature:void 0,trainingConfig:e.trainingConfig!=null?e.trainingConfig:void 0};return this.LS.setItem(this.keys.modelMetadata,JSON.stringify(i)),{modelArtifactsInfo:r}}catch{throw j$(this.keys),new Error(`Failed to save model '${this.modelPath}' to local storage: size quota being exceeded is a possible cause of this failure: modelTopologyBytes=${r.modelTopologyBytes}, weightSpecsBytes=${r.weightSpecsBytes}, weightDataBytes=${r.weightDataBytes}.`)}}}async load(){const e=JSON.parse(this.LS.getItem(this.keys.info));if(e==null)throw new Error(`In local storage, there is no model with name '${this.modelPath}'`);if(e.modelTopologyType!=="JSON")throw new Error("BrowserLocalStorage does not support loading non-JSON model topology yet.");const n={},s=JSON.parse(this.LS.getItem(this.keys.topology));if(s==null)throw new Error(`In local storage, the topology of model '${this.modelPath}' is missing.`);n.modelTopology=s;const r=JSON.parse(this.LS.getItem(this.keys.weightSpecs));if(r==null)throw new Error(`In local storage, the weight specs of model '${this.modelPath}' are missing.`);n.weightSpecs=r;const o=this.LS.getItem(this.keys.modelMetadata);if(o!=null){const a=JSON.parse(o);n.format=a.format,n.generatedBy=a.generatedBy,n.convertedBy=a.convertedBy,a.signature!=null&&(n.signature=a.signature),a.userDefinedMetadata!=null&&(n.userDefinedMetadata=a.userDefinedMetadata),a.modelInitializer!=null&&(n.modelInitializer=a.modelInitializer),a.initializerSignature!=null&&(n.initializerSignature=a.initializerSignature),a.trainingConfig!=null&&(n.trainingConfig=a.trainingConfig)}const i=this.LS.getItem(this.keys.weightData);if(i==null)throw new Error(`In local storage, the binary weight values of model '${this.modelPath}' are missing.`);return n.weightData=SP(i),n}}Di.URL_SCHEME="localstorage://";const K$=t=>W().getBool("IS_BROWSER")&&!Array.isArray(t)&&t.startsWith(Di.URL_SCHEME)?GP(t.slice(Di.URL_SCHEME.length)):null;Gt.registerSaveRouter(K$);Gt.registerLoadRouter(K$);function GP(t){return new Di(t)}class HP{constructor(){I(W().getBool("IS_BROWSER"),()=>"Current environment is not a web browser"),I(typeof window>"u"||typeof window.localStorage<"u",()=>"Current browser does not appear to support localStorage"),this.LS=window.localStorage}async listModels(){const e={},n=pa+Fr,s=Fr+G$;for(let r=0;r"scheme must not be undefined or null."),e.endsWith(EC)&&(e=e.slice(0,e.indexOf(EC))),I(e.length>0,()=>"scheme must not be an empty string.");const s=ir.getInstance();I(s.managers[e]==null,()=>`A model store manager is already registered for scheme '${e}'.`),s.managers[e]=n}static getManager(e){const n=ir.getInstance().managers[e];if(n==null)throw new Error(`Cannot find model manager for scheme '${e}'`);return n}static getSchemes(){return Object.keys(ir.getInstance().managers)}}/** + */const EC="://";class ar{constructor(){this.managers={}}static getInstance(){return ar.instance==null&&(ar.instance=new ar),ar.instance}static registerManager(e,n){I(e!=null,()=>"scheme must not be undefined or null."),e.endsWith(EC)&&(e=e.slice(0,e.indexOf(EC))),I(e.length>0,()=>"scheme must not be an empty string.");const s=ar.getInstance();I(s.managers[e]==null,()=>`A model store manager is already registered for scheme '${e}'.`),s.managers[e]=n}static getManager(e){const n=ar.getInstance().managers[e];if(n==null)throw new Error(`Cannot find model manager for scheme '${e}'`);return n}static getSchemes(){return Object.keys(ar.getInstance().managers)}}/** * @license * Copyright 2019 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -572,7 +572,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class HP{constructor(){this.messageName="setTimeoutCustom",this.functionRefs=[],this.handledMessageCount=0,this.hasEventListener=!1}fetch(e,n){return fetch(e,n)}now(){return performance.now()}encode(e,n){if(n!=="utf-8"&&n!=="utf8")throw new Error(`Browser's encoder only supports utf-8, but got ${n}`);return this.textEncoder==null&&(this.textEncoder=new TextEncoder),this.textEncoder.encode(e)}decode(e,n){return new TextDecoder(n).decode(e)}setTimeoutCustom(e,n){if(typeof window>"u"||!W().getBool("USE_SETTIMEOUTCUSTOM")){setTimeout(e,n);return}this.functionRefs.push(e),setTimeout(()=>{window.postMessage({name:this.messageName,index:this.functionRefs.length-1},"*")},n),this.hasEventListener||(this.hasEventListener=!0,window.addEventListener("message",s=>{if(s.source===window&&s.data.name===this.messageName){s.stopPropagation();const r=this.functionRefs[s.data.index];r(),this.handledMessageCount++,this.handledMessageCount===this.functionRefs.length&&(this.functionRefs=[],this.handledMessageCount=0)}},!0))}isTypedArray(e){return b$(e)}}if(W().get("IS_BROWSER")){W().setPlatform("browser",new HP);try{ir.registerManager(Di.URL_SCHEME,new GP)}catch{}try{ir.registerManager(Ai.URL_SCHEME,new OP)}catch{}}/** + */class jP{constructor(){this.messageName="setTimeoutCustom",this.functionRefs=[],this.handledMessageCount=0,this.hasEventListener=!1}fetch(e,n){return fetch(e,n)}now(){return performance.now()}encode(e,n){if(n!=="utf-8"&&n!=="utf8")throw new Error(`Browser's encoder only supports utf-8, but got ${n}`);return this.textEncoder==null&&(this.textEncoder=new TextEncoder),this.textEncoder.encode(e)}decode(e,n){return new TextDecoder(n).decode(e)}setTimeoutCustom(e,n){if(typeof window>"u"||!W().getBool("USE_SETTIMEOUTCUSTOM")){setTimeout(e,n);return}this.functionRefs.push(e),setTimeout(()=>{window.postMessage({name:this.messageName,index:this.functionRefs.length-1},"*")},n),this.hasEventListener||(this.hasEventListener=!0,window.addEventListener("message",s=>{if(s.source===window&&s.data.name===this.messageName){s.stopPropagation();const r=this.functionRefs[s.data.index];r(),this.handledMessageCount++,this.handledMessageCount===this.functionRefs.length&&(this.functionRefs=[],this.handledMessageCount=0)}},!0))}isTypedArray(e){return C$(e)}}if(W().get("IS_BROWSER")){W().setPlatform("browser",new jP);try{ar.registerManager(Di.URL_SCHEME,new HP)}catch{}try{ar.registerManager(Ai.URL_SCHEME,new MP)}catch{}}/** * @license * Copyright 2019 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -587,7 +587,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const jP={importFetch:()=>require("node-fetch")};let kg;class KP{constructor(){this.util=require("util"),this.textEncoder=new this.util.TextEncoder}fetch(e,n){return W().global.fetch!=null?W().global.fetch(e,n):(kg==null&&(kg=jP.importFetch()),kg(e,n))}now(){const e=process.hrtime();return e[0]*1e3+e[1]/1e6}encode(e,n){if(n!=="utf-8"&&n!=="utf8")throw new Error(`Node built-in encoder only supports utf-8, but got ${n}`);return this.textEncoder.encode(e)}decode(e,n){return e.length===0?"":new this.util.TextDecoder(n).decode(e)}isTypedArray(e){return this.util.types.isFloat32Array(e)||this.util.types.isInt32Array(e)||this.util.types.isUint8Array(e)||this.util.types.isUint8ClampedArray(e)}}W().get("IS_NODE")&&!W().get("IS_BROWSER")&&W().setPlatform("node",new KP);/** + */const KP={importFetch:()=>require("node-fetch")};let kg;class XP{constructor(){this.util=require("util"),this.textEncoder=new this.util.TextEncoder}fetch(e,n){return W().global.fetch!=null?W().global.fetch(e,n):(kg==null&&(kg=KP.importFetch()),kg(e,n))}now(){const e=process.hrtime();return e[0]*1e3+e[1]/1e6}encode(e,n){if(n!=="utf-8"&&n!=="utf8")throw new Error(`Node built-in encoder only supports utf-8, but got ${n}`);return this.textEncoder.encode(e)}decode(e,n){return e.length===0?"":new this.util.TextDecoder(n).decode(e)}isTypedArray(e){return this.util.types.isFloat32Array(e)||this.util.types.isInt32Array(e)||this.util.types.isUint8Array(e)||this.util.types.isUint8ClampedArray(e)}}W().get("IS_NODE")&&!W().get("IS_BROWSER")&&W().setPlatform("node",new XP);/** * @license * Copyright 2020 Google Inc. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -602,7 +602,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Ee(t,e="float32",n){return e=e||"float32",Xr(t),new tn(t,e,n)}/** + */function Ee(t,e="float32",n){return e=e||"float32",qr(t),new tn(t,e,n)}/** * @license * Copyright 2020 Google Inc. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -617,7 +617,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function XP(t,e){const n=T(t,"x","cast");if(!RM(e))throw new Error(`Failed to cast to unknown dtype ${e}`);if(e==="string"&&n.dtype!=="string"||e!=="string"&&n.dtype==="string")throw new Error("Only strings can be casted to strings");const s={x:n},r={dtype:e};return _.runKernel(bu,s,r)}const le=z({cast_:XP});/** + */function qP(t,e){const n=T(t,"x","cast");if(!AM(e))throw new Error(`Failed to cast to unknown dtype ${e}`);if(e==="string"&&n.dtype!=="string"||e!=="string"&&n.dtype==="string")throw new Error("Only strings can be casted to strings");const s={x:n},r={dtype:e};return _.runKernel(bu,s,r)}const le=z({cast_:qP});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -632,7 +632,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function qP(t){const n={x:T(t,"x","clone","string_or_numeric")};return _.runKernel(Fu,n)}const vi=z({clone_:qP});/** + */function YP(t){const n={x:T(t,"x","clone","string_or_numeric")};return _.runKernel(Fu,n)}const vi=z({clone_:YP});/** * @license * Copyright 2020 Google Inc. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -647,7 +647,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function YP(t,e=!1){console.log(t.toString(e))}/** + */function QP(t,e=!1){console.log(t.toString(e))}/** * @license * Copyright 2020 Google Inc. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -662,7 +662,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */z$();const QP={buffer:Ee,cast:le,clone:vi,print:YP};lP(QP);/** + */O$();const ZP={buffer:Ee,cast:le,clone:vi,print:QP};cP(ZP);/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -677,7 +677,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function ZP(t,e){let n=T(t,"a","add"),s=T(e,"b","add");[n,s]=It(n,s);const r={a:n,b:s};return _.runKernel(bl,r)}const J=z({add_:ZP});/** + */function JP(t,e){let n=T(t,"a","add"),s=T(e,"b","add");[n,s]=It(n,s);const r={a:n,b:s};return _.runKernel(bl,r)}const J=z({add_:JP});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -692,7 +692,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function JP(t,e){let n=T(t,"a","floorDiv"),s=T(e,"b","floorDiv");[n,s]=It(n,s);const r={a:n,b:s};return _.runKernel(Du,r)}const K$=z({floorDiv_:JP});/** + */function eL(t,e){let n=T(t,"a","floorDiv"),s=T(e,"b","floorDiv");[n,s]=It(n,s);const r={a:n,b:s};return _.runKernel(Du,r)}const X$=z({floorDiv_:eL});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -707,7 +707,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function eL(t,e){let n=T(t,"a","div"),s=T(e,"b","div");if([n,s]=It(n,s),n.dtype==="int32"&&s.dtype==="int32")return K$(n,s);const r={a:n,b:s},o={};return _.runKernel($u,r,o)}const ge=z({div_:eL});/** + */function tL(t,e){let n=T(t,"a","div"),s=T(e,"b","div");if([n,s]=It(n,s),n.dtype==="int32"&&s.dtype==="int32")return X$(n,s);const r={a:n,b:s},o={};return _.runKernel($u,r,o)}const ge=z({div_:tL});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -722,7 +722,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function tL(t,e){let n=T(t,"a","mul"),s=T(e,"b","mul");[n,s]=It(n,s);const r={a:n,b:s};return _.runKernel(Uu,r)}const D=z({mul_:tL});/** + */function nL(t,e){let n=T(t,"a","mul"),s=T(e,"b","mul");[n,s]=It(n,s);const r={a:n,b:s};return _.runKernel(Uu,r)}const D=z({mul_:nL});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -737,7 +737,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function nL(t){const e=T(t,"x","abs");if(e.dtype==="complex64"){const n={x:e};return _.runKernel(bp,n)}else{const n={x:e};return _.runKernel(pp,n)}}const xn=z({abs_:nL});/** + */function sL(t){const e=T(t,"x","abs");if(e.dtype==="complex64"){const n={x:e};return _.runKernel(bp,n)}else{const n={x:e};return _.runKernel(pp,n)}}const xn=z({abs_:sL});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -752,7 +752,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function sL(t){const n={x:T(t,"x","acos")};return _.runKernel(pu,n)}const rL=z({acos_:sL});/** + */function rL(t){const n={x:T(t,"x","acos")};return _.runKernel(pu,n)}const oL=z({acos_:rL});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -767,7 +767,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function oL(t){const n={x:T(t,"x","acosh")};return _.runKernel(mu,n)}const iL=z({acosh_:oL});/** + */function iL(t){const n={x:T(t,"x","acosh")};return _.runKernel(mu,n)}const aL=z({acosh_:iL});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -782,7 +782,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function aL(t,e=null,n=!1){const r={x:T(t,"x","all","bool")},o={axis:e,keepDims:n};return _.runKernel(Hx,r,o)}const X$=z({all_:aL});/** + */function lL(t,e=null,n=!1){const r={x:T(t,"x","all","bool")},o={axis:e,keepDims:n};return _.runKernel(Hx,r,o)}const q$=z({all_:lL});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -797,7 +797,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function lL(t,e=null,n=!1){const r={x:T(t,"x","any","bool")},o={axis:e,keepDims:n};return _.runKernel(jx,r,o)}const u1=z({any_:lL});/** + */function cL(t,e=null,n=!1){const r={x:T(t,"x","any","bool")},o={axis:e,keepDims:n};return _.runKernel(jx,r,o)}const u1=z({any_:cL});/** * @license * Copyright 2020 Google Inc. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -812,7 +812,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function cL(t,e=0){const s={x:T(t,"x","argMax")},r={axis:e};return _.runKernel(mp,s,r)}const Hc=z({argMax_:cL});/** + */function uL(t,e=0){const s={x:T(t,"x","argMax")},r={axis:e};return _.runKernel(mp,s,r)}const Hc=z({argMax_:uL});/** * @license * Copyright 2020 Google Inc. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -827,7 +827,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function uL(t,e=0){const s={x:T(t,"x","argMin")},r={axis:e};return _.runKernel(gp,s,r)}const dL=z({argMin_:uL});/** + */function hL(t,e=0){const s={x:T(t,"x","argMin")},r={axis:e};return _.runKernel(gp,s,r)}const dL=z({argMin_:hL});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -842,7 +842,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function hL(t){const n={x:T(t,"x","asin")};return _.runKernel(gu,n)}const fL=z({asin_:hL});/** + */function fL(t){const n={x:T(t,"x","asin")};return _.runKernel(gu,n)}const pL=z({asin_:fL});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -857,7 +857,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function pL(t){const n={x:T(t,"x","asinh")};return _.runKernel(xu,n)}const mL=z({asinh_:pL});/** + */function mL(t){const n={x:T(t,"x","asinh")};return _.runKernel(xu,n)}const gL=z({asinh_:mL});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -872,7 +872,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function gL(t){const n={x:T(t,"x","atan")};return _.runKernel(yu,n)}const xL=z({atan_:gL});/** + */function xL(t){const n={x:T(t,"x","atan")};return _.runKernel(yu,n)}const yL=z({atan_:xL});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -887,7 +887,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function yL(t,e){let n=T(t,"a","atan2"),s=T(e,"b","atan2");[n,s]=It(n,s);const r={a:n,b:s};return _.runKernel(vu,r)}const wL=z({atan2_:yL});/** + */function wL(t,e){let n=T(t,"a","atan2"),s=T(e,"b","atan2");[n,s]=It(n,s);const r={a:n,b:s};return _.runKernel(vu,r)}const vL=z({atan2_:wL});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -902,7 +902,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function vL(t){const n={x:T(t,"x","atanh")};return _.runKernel(wu,n)}const bL=z({atanh_:vL});/** + */function bL(t){const n={x:T(t,"x","atanh")};return _.runKernel(wu,n)}const CL=z({atanh_:bL});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -917,7 +917,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function dd(t,e,n,s,r="NHWC",o){const i=t[3],a=[...e,i],l=Yr(r);return nn(t,a,n,o,s,null,null,l)}function Rs(t,e,n,s,r,o,i="channelsLast"){const[a,l]=jc(e);let c;if(i==="channelsLast")c=[a,l,t[3],t[3]];else if(i==="channelsFirst")c=[a,l,t[1],t[1]];else throw new Error(`Unknown dataFormat ${i}`);return nn(t,c,n,s,r,o,!1,i)}function qr(t,e,n,s,r,o,i="NDHWC"){const[a,l,c]=d1(e);let u,d;if(i==="NDHWC")d="channelsLast",u=[a,l,c,t[4],t[4]];else if(i==="NCDHW")d="channelsFirst",u=[a,l,c,t[1],t[1]];else throw new Error(`Unknown dataFormat ${i}`);return Go(t,u,n,s,r,!1,d,o)}function nn(t,e,n,s,r,o,i=!1,a="channelsLast"){let[l,c,u,d]=[-1,-1,-1,-1];if(a==="channelsLast")[l,c,u,d]=t;else if(a==="channelsFirst")[l,d,c,u]=t;else throw new Error(`Unknown dataFormat ${a}`);const[h,f,,p]=e,[g,x]=jc(n),[m,y]=jc(s),w=Pa(h,m),v=Pa(f,y),{padInfo:b,outHeight:C,outWidth:k}=SL(r,c,u,g,x,w,v,o,a),S=i?p*d:p;let $;return a==="channelsFirst"?$=[l,S,C,k]:a==="channelsLast"&&($=[l,C,k,S]),{batchSize:l,dataFormat:a,inHeight:c,inWidth:u,inChannels:d,outHeight:C,outWidth:k,outChannels:S,padInfo:b,strideHeight:g,strideWidth:x,filterHeight:h,filterWidth:f,effectiveFilterHeight:w,effectiveFilterWidth:v,dilationHeight:m,dilationWidth:y,inShape:t,outShape:$,filterShape:e}}function Go(t,e,n,s,r,o=!1,i="channelsLast",a){let[l,c,u,d,h]=[-1,-1,-1,-1,-1];if(i==="channelsLast")[l,c,u,d,h]=t;else if(i==="channelsFirst")[l,h,c,u,d]=t;else throw new Error(`Unknown dataFormat ${i}`);const[f,p,g,,x]=e,[m,y,w]=d1(n),[v,b,C]=d1(s),k=Pa(f,v),S=Pa(p,b),$=Pa(g,C),{padInfo:N,outDepth:A,outHeight:M,outWidth:L}=IL(r,c,u,d,m,y,w,k,S,$,a),V=o?x*h:x;let B;return i==="channelsFirst"?B=[l,V,A,M,L]:i==="channelsLast"&&(B=[l,A,M,L,V]),{batchSize:l,dataFormat:i,inDepth:c,inHeight:u,inWidth:d,inChannels:h,outDepth:A,outHeight:M,outWidth:L,outChannels:V,padInfo:N,strideDepth:m,strideHeight:y,strideWidth:w,filterDepth:f,filterHeight:p,filterWidth:g,effectiveFilterDepth:k,effectiveFilterHeight:S,effectiveFilterWidth:$,dilationDepth:v,dilationHeight:b,dilationWidth:C,inShape:t,outShape:B,filterShape:e}}function CL(t,e,n,s,r){s==null&&(s=zy(t,e,n));const o=t[0],i=t[1],a=Kc((o-e+2*s)/n+1,r),l=Kc((i-e+2*s)/n+1,r);return[a,l]}function kL(t,e,n,s,r,o){r==null&&(r=zy(t,e[0],s[0]));const i=[0,0,0,n];for(let a=0;a<3;a++)t[a]+2*r>=e[a]&&(i[a]=Kc((t[a]-e[a]+2*r)/s[a]+1,o));return i}function zy(t,e,n,s=1){const r=Pa(e,s);return Math.floor((t[0]*(n-1)-n+r)/2)}function jc(t){return typeof t=="number"?[t,t,t]:t.length===2?[t[0],t[1],1]:t}function d1(t){return typeof t=="number"?[t,t,t]:t}function Pa(t,e){return e<=1?t:t+(t-1)*(e-1)}function SL(t,e,n,s,r,o,i,a,l){let c,u,d;if(typeof t=="number"){c={top:t,bottom:t,left:t,right:t,type:t===0?"VALID":"NUMBER"};const f=CL([e,n],o,s,t,a);u=f[0],d=f[1]}else if(t==="same"){u=Math.ceil(e/s),d=Math.ceil(n/r);const h=Math.max(0,(u-1)*s+o-e),f=Math.max(0,(d-1)*r+i-n),p=Math.floor(h/2),g=h-p,x=Math.floor(f/2),m=f-x;c={top:p,bottom:g,left:x,right:m,type:"SAME"}}else if(t==="valid")c={top:0,bottom:0,left:0,right:0,type:"VALID"},u=Math.ceil((e-o+1)/s),d=Math.ceil((n-i+1)/r);else if(typeof t=="object"){const h=l==="channelsLast"?t[1][0]:t[2][0],f=l==="channelsLast"?t[1][1]:t[2][1],p=l==="channelsLast"?t[2][0]:t[3][0],g=l==="channelsLast"?t[2][1]:t[3][1];c={top:h,bottom:f,left:p,right:g,type:h===0&&f===0&&p===0&&g===0?"VALID":"EXPLICIT"},u=Kc((e-o+h+f)/s+1,a),d=Kc((n-i+p+g)/r+1,a)}else throw Error(`Unknown padding parameter: ${t}`);return{padInfo:c,outHeight:u,outWidth:d}}function IL(t,e,n,s,r,o,i,a,l,c,u){let d,h,f,p;if(t==="valid"&&(t=0),typeof t=="number"){d={top:t,bottom:t,left:t,right:t,front:t,back:t,type:t===0?"VALID":"NUMBER"};const x=kL([e,n,s,1],[a,l,c],1,[r,o,i],t,u);h=x[0],f=x[1],p=x[2]}else if(t==="same"){h=Math.ceil(e/r),f=Math.ceil(n/o),p=Math.ceil(s/i);const g=(h-1)*r+a-e,x=(f-1)*o+l-n,m=(p-1)*i+c-s,y=Math.floor(g/2),w=g-y,v=Math.floor(x/2),b=x-v,C=Math.floor(m/2),k=m-C;d={top:v,bottom:b,left:C,right:k,front:y,back:w,type:"SAME"}}else throw Error(`Unknown padding parameter: ${t}`);return{padInfo:d,outDepth:h,outHeight:f,outWidth:p}}function Kc(t,e){if(!e)return Math.trunc(t);switch(e){case"round":return Math.round(t);case"ceil":return Math.ceil(t);case"floor":return Math.floor(t);default:throw new Error(`Unknown roundingMode ${e}`)}}function _i(t){const[e,n,s]=jc(t);return e===1&&n===1&&s===1}function hn(t,e){return _i(t)||_i(e)}function Fi(t){return jc(t).every(e=>e>0)}function Yr(t){if(t==="NHWC")return"channelsLast";if(t==="NCHW")return"channelsFirst";throw new Error(`Unknown dataFormat ${t}`)}function Mn(t,e,n){if(n!=null){if(typeof e=="string")throw Error(`Error in ${t}: pad must be an integer when using dimRoundingMode ${n} but got pad ${e}.`);if(typeof e=="number")I(nl(e),()=>`Error in ${t}: pad must be an integer when using dimRoundingMode ${n} but got pad ${e}.`);else if(typeof e=="object")e.forEach(s=>{s.forEach(r=>{I(nl(r),()=>`Error in ${t}: pad must be an integer when using dimRoundingMode ${n} but got pad ${r}.`)})});else throw Error(`Error in ${t}: Unknown padding parameter: ${e}`)}}/** + */function hh(t,e,n,s,r="NHWC",o){const i=t[3],a=[...e,i],l=Qr(r);return nn(t,a,n,o,s,null,null,l)}function As(t,e,n,s,r,o,i="channelsLast"){const[a,l]=jc(e);let c;if(i==="channelsLast")c=[a,l,t[3],t[3]];else if(i==="channelsFirst")c=[a,l,t[1],t[1]];else throw new Error(`Unknown dataFormat ${i}`);return nn(t,c,n,s,r,o,!1,i)}function Yr(t,e,n,s,r,o,i="NDHWC"){const[a,l,c]=h1(e);let u,h;if(i==="NDHWC")h="channelsLast",u=[a,l,c,t[4],t[4]];else if(i==="NCDHW")h="channelsFirst",u=[a,l,c,t[1],t[1]];else throw new Error(`Unknown dataFormat ${i}`);return Go(t,u,n,s,r,!1,h,o)}function nn(t,e,n,s,r,o,i=!1,a="channelsLast"){let[l,c,u,h]=[-1,-1,-1,-1];if(a==="channelsLast")[l,c,u,h]=t;else if(a==="channelsFirst")[l,h,c,u]=t;else throw new Error(`Unknown dataFormat ${a}`);const[d,f,,p]=e,[g,x]=jc(n),[m,y]=jc(s),w=Pa(d,m),v=Pa(f,y),{padInfo:b,outHeight:C,outWidth:k}=IL(r,c,u,g,x,w,v,o,a),S=i?p*h:p;let $;return a==="channelsFirst"?$=[l,S,C,k]:a==="channelsLast"&&($=[l,C,k,S]),{batchSize:l,dataFormat:a,inHeight:c,inWidth:u,inChannels:h,outHeight:C,outWidth:k,outChannels:S,padInfo:b,strideHeight:g,strideWidth:x,filterHeight:d,filterWidth:f,effectiveFilterHeight:w,effectiveFilterWidth:v,dilationHeight:m,dilationWidth:y,inShape:t,outShape:$,filterShape:e}}function Go(t,e,n,s,r,o=!1,i="channelsLast",a){let[l,c,u,h,d]=[-1,-1,-1,-1,-1];if(i==="channelsLast")[l,c,u,h,d]=t;else if(i==="channelsFirst")[l,d,c,u,h]=t;else throw new Error(`Unknown dataFormat ${i}`);const[f,p,g,,x]=e,[m,y,w]=h1(n),[v,b,C]=h1(s),k=Pa(f,v),S=Pa(p,b),$=Pa(g,C),{padInfo:N,outDepth:A,outHeight:M,outWidth:L}=$L(r,c,u,h,m,y,w,k,S,$,a),V=o?x*d:x;let B;return i==="channelsFirst"?B=[l,V,A,M,L]:i==="channelsLast"&&(B=[l,A,M,L,V]),{batchSize:l,dataFormat:i,inDepth:c,inHeight:u,inWidth:h,inChannels:d,outDepth:A,outHeight:M,outWidth:L,outChannels:V,padInfo:N,strideDepth:m,strideHeight:y,strideWidth:w,filterDepth:f,filterHeight:p,filterWidth:g,effectiveFilterDepth:k,effectiveFilterHeight:S,effectiveFilterWidth:$,dilationDepth:v,dilationHeight:b,dilationWidth:C,inShape:t,outShape:B,filterShape:e}}function kL(t,e,n,s,r){s==null&&(s=zy(t,e,n));const o=t[0],i=t[1],a=Kc((o-e+2*s)/n+1,r),l=Kc((i-e+2*s)/n+1,r);return[a,l]}function SL(t,e,n,s,r,o){r==null&&(r=zy(t,e[0],s[0]));const i=[0,0,0,n];for(let a=0;a<3;a++)t[a]+2*r>=e[a]&&(i[a]=Kc((t[a]-e[a]+2*r)/s[a]+1,o));return i}function zy(t,e,n,s=1){const r=Pa(e,s);return Math.floor((t[0]*(n-1)-n+r)/2)}function jc(t){return typeof t=="number"?[t,t,t]:t.length===2?[t[0],t[1],1]:t}function h1(t){return typeof t=="number"?[t,t,t]:t}function Pa(t,e){return e<=1?t:t+(t-1)*(e-1)}function IL(t,e,n,s,r,o,i,a,l){let c,u,h;if(typeof t=="number"){c={top:t,bottom:t,left:t,right:t,type:t===0?"VALID":"NUMBER"};const f=kL([e,n],o,s,t,a);u=f[0],h=f[1]}else if(t==="same"){u=Math.ceil(e/s),h=Math.ceil(n/r);const d=Math.max(0,(u-1)*s+o-e),f=Math.max(0,(h-1)*r+i-n),p=Math.floor(d/2),g=d-p,x=Math.floor(f/2),m=f-x;c={top:p,bottom:g,left:x,right:m,type:"SAME"}}else if(t==="valid")c={top:0,bottom:0,left:0,right:0,type:"VALID"},u=Math.ceil((e-o+1)/s),h=Math.ceil((n-i+1)/r);else if(typeof t=="object"){const d=l==="channelsLast"?t[1][0]:t[2][0],f=l==="channelsLast"?t[1][1]:t[2][1],p=l==="channelsLast"?t[2][0]:t[3][0],g=l==="channelsLast"?t[2][1]:t[3][1];c={top:d,bottom:f,left:p,right:g,type:d===0&&f===0&&p===0&&g===0?"VALID":"EXPLICIT"},u=Kc((e-o+d+f)/s+1,a),h=Kc((n-i+p+g)/r+1,a)}else throw Error(`Unknown padding parameter: ${t}`);return{padInfo:c,outHeight:u,outWidth:h}}function $L(t,e,n,s,r,o,i,a,l,c,u){let h,d,f,p;if(t==="valid"&&(t=0),typeof t=="number"){h={top:t,bottom:t,left:t,right:t,front:t,back:t,type:t===0?"VALID":"NUMBER"};const x=SL([e,n,s,1],[a,l,c],1,[r,o,i],t,u);d=x[0],f=x[1],p=x[2]}else if(t==="same"){d=Math.ceil(e/r),f=Math.ceil(n/o),p=Math.ceil(s/i);const g=(d-1)*r+a-e,x=(f-1)*o+l-n,m=(p-1)*i+c-s,y=Math.floor(g/2),w=g-y,v=Math.floor(x/2),b=x-v,C=Math.floor(m/2),k=m-C;h={top:v,bottom:b,left:C,right:k,front:y,back:w,type:"SAME"}}else throw Error(`Unknown padding parameter: ${t}`);return{padInfo:h,outDepth:d,outHeight:f,outWidth:p}}function Kc(t,e){if(!e)return Math.trunc(t);switch(e){case"round":return Math.round(t);case"ceil":return Math.ceil(t);case"floor":return Math.floor(t);default:throw new Error(`Unknown roundingMode ${e}`)}}function _i(t){const[e,n,s]=jc(t);return e===1&&n===1&&s===1}function dn(t,e){return _i(t)||_i(e)}function Fi(t){return jc(t).every(e=>e>0)}function Qr(t){if(t==="NHWC")return"channelsLast";if(t==="NCHW")return"channelsFirst";throw new Error(`Unknown dataFormat ${t}`)}function Mn(t,e,n){if(n!=null){if(typeof e=="string")throw Error(`Error in ${t}: pad must be an integer when using dimRoundingMode ${n} but got pad ${e}.`);if(typeof e=="number")I(nl(e),()=>`Error in ${t}: pad must be an integer when using dimRoundingMode ${n} but got pad ${e}.`);else if(typeof e=="object")e.forEach(s=>{s.forEach(r=>{I(nl(r),()=>`Error in ${t}: pad must be an integer when using dimRoundingMode ${n} but got pad ${r}.`)})});else throw Error(`Error in ${t}: Unknown padding parameter: ${e}`)}}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -932,7 +932,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function $L(t,e){const s={x:T(t,"x","reshape","string_or_numeric")},r={shape:e};return _.runKernel(tm,s,r)}const F=z({reshape_:$L});/** + */function NL(t,e){const s={x:T(t,"x","reshape","string_or_numeric")},r={shape:e};return _.runKernel(tm,s,r)}const F=z({reshape_:NL});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -947,7 +947,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function NL(t,e,n,s,r){const o=T(t,"x","avgPool","float32"),i=1;I(hn(n,i),()=>`Error in avgPool: Either strides or dilations must be 1. Got strides ${n} and dilations '${i}'`);let a=o,l=!1;o.rank===3&&(l=!0,a=F(o,[1,o.shape[0],o.shape[1],o.shape[2]])),I(a.rank===4,()=>`Error in avgPool: x must be rank 4 but got rank ${a.rank}.`),Mn("avgPool",s,r);const c={x:a},u={filterSize:e,strides:n,pad:s,dimRoundingMode:r};let d=_.runKernel(xp,c,u);return d=le(d,o.dtype),l?F(d,[d.shape[1],d.shape[2],d.shape[3]]):d}const Oy=z({avgPool_:NL});/** + */function TL(t,e,n,s,r){const o=T(t,"x","avgPool","float32"),i=1;I(dn(n,i),()=>`Error in avgPool: Either strides or dilations must be 1. Got strides ${n} and dilations '${i}'`);let a=o,l=!1;o.rank===3&&(l=!0,a=F(o,[1,o.shape[0],o.shape[1],o.shape[2]])),I(a.rank===4,()=>`Error in avgPool: x must be rank 4 but got rank ${a.rank}.`),Mn("avgPool",s,r);const c={x:a},u={filterSize:e,strides:n,pad:s,dimRoundingMode:r};let h=_.runKernel(xp,c,u);return h=le(h,o.dtype),l?F(h,[h.shape[1],h.shape[2],h.shape[3]]):h}const Oy=z({avgPool_:TL});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -962,7 +962,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function TL(t,e,n,s,r,o="NDHWC"){const i=T(t,"x","avgPool3d","float32");let a=i,l=!1;i.rank===4&&(l=!0,a=F(i,[1,i.shape[0],i.shape[1],i.shape[2],i.shape[3]])),I(a.rank===5,()=>`Error in avgPool3d: x must be rank 5 but got rank ${a.rank}.`),I(o==="NDHWC",()=>`Error in avgPool3d: Only NDHWC is currently supported, but got dataFormat of ${o}`),I(typeof n=="number"&&n>0||Array.isArray(n)&&n[0]>0&&n[1]>0&&n[2]>0,()=>`Error in avgPool3d: Stride must be > 0, but got '${n}'`),Mn("avgPool3d",s,r);const c={x:a},u={filterSize:e,strides:n,pad:s,dimRoundingMode:r,dataFormat:o};let d=_.runKernel(yp,c,u);return d=le(d,a.dtype),l?F(d,[d.shape[1],d.shape[2],d.shape[3],d.shape[4]]):d}const EL=z({avgPool3d_:TL});/** + */function EL(t,e,n,s,r,o="NDHWC"){const i=T(t,"x","avgPool3d","float32");let a=i,l=!1;i.rank===4&&(l=!0,a=F(i,[1,i.shape[0],i.shape[1],i.shape[2],i.shape[3]])),I(a.rank===5,()=>`Error in avgPool3d: x must be rank 5 but got rank ${a.rank}.`),I(o==="NDHWC",()=>`Error in avgPool3d: Only NDHWC is currently supported, but got dataFormat of ${o}`),I(typeof n=="number"&&n>0||Array.isArray(n)&&n[0]>0&&n[1]>0&&n[2]>0,()=>`Error in avgPool3d: Stride must be > 0, but got '${n}'`),Mn("avgPool3d",s,r);const c={x:a},u={filterSize:e,strides:n,pad:s,dimRoundingMode:r,dataFormat:o};let h=_.runKernel(yp,c,u);return h=le(h,a.dtype),l?F(h,[h.shape[1],h.shape[2],h.shape[3],h.shape[4]]):h}const RL=z({avgPool3d_:EL});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -977,8 +977,8 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function RL(t,e=0){I(t.length>=1,()=>"Pass at least one tensor to concat");const n=L$(t,"tensors","concat","string_or_numeric");if(n[0].dtype==="complex64"&&n.forEach(o=>{if(o.dtype!=="complex64")throw new Error(`Cannot concatenate complex64 tensors with a tensor - with dtype ${o.dtype}. `)}),n.length===1)return vi(n[0]);const s=n,r={axis:e};return _.runKernel(Cp,s,r)}const Dn=z({concat_:RL});/** + */function AL(t,e=0){I(t.length>=1,()=>"Pass at least one tensor to concat");const n=B$(t,"tensors","concat","string_or_numeric");if(n[0].dtype==="complex64"&&n.forEach(o=>{if(o.dtype!=="complex64")throw new Error(`Cannot concatenate complex64 tensors with a tensor + with dtype ${o.dtype}. `)}),n.length===1)return vi(n[0]);const s=n,r={axis:e};return _.runKernel(Cp,s,r)}const Dn=z({concat_:AL});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -993,7 +993,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function AL(t,e,n=!1,s=!1){let r=T(t,"a","matMul"),o=T(e,"b","matMul");[r,o]=It(r,o);const i={a:r,b:o},a={transposeA:n,transposeB:s};return _.runKernel(wp,i,a)}const Ve=z({matMul_:AL});/** + */function DL(t,e,n=!1,s=!1){let r=T(t,"a","matMul"),o=T(e,"b","matMul");[r,o]=It(r,o);const i={a:r,b:o},a={transposeA:n,transposeB:s};return _.runKernel(wp,i,a)}const Ve=z({matMul_:DL});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1008,7 +1008,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function DL(t){const n={x:T(t,"x","sigmoid","float32")};return _.runKernel(ed,n)}const Cl=z({sigmoid_:DL});/** + */function _L(t){const n={x:T(t,"x","sigmoid","float32")};return _.runKernel(eh,n)}const Cl=z({sigmoid_:_L});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1023,7 +1023,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function _L(t,e,n){const s=T(t,"x","slice","string_or_numeric");if(s.rank===0)throw new Error("Slicing scalar is not possible");const r={x:s},o={begin:e,size:n};return _.runKernel(im,r,o)}const tt=z({slice_:_L});/** + */function FL(t,e,n){const s=T(t,"x","slice","string_or_numeric");if(s.rank===0)throw new Error("Slicing scalar is not possible");const r={x:s},o={begin:e,size:n};return _.runKernel(im,r,o)}const tt=z({slice_:FL});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1038,7 +1038,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function FL(t){const n={x:T(t,"x","tanh","float32")};return _.runKernel(id,n)}const mm=z({tanh_:FL});/** + */function zL(t){const n={x:T(t,"x","tanh","float32")};return _.runKernel(ih,n)}const mm=z({tanh_:zL});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1053,7 +1053,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function zL(t,e,n){const s=T(t,"x","batchToSpaceND"),r=e.reduce((a,l)=>a*l);I(s.rank>=1+e.length,()=>`input rank is ${s.rank} but should be > than blockShape.length ${e.length}`),I(n.length===e.length,()=>`crops.length is ${n.length} but should be equal to blockShape.length ${e.length}`),I(s.shape[0]%r===0,()=>`input tensor batch is ${s.shape[0]} but is not divisible by the product of the elements of blockShape ${e.join(" * ")} === ${r}`);const o={x:s},i={blockShape:e,crops:n};return _.runKernel(vp,o,i)}const My=z({batchToSpaceND_:zL});function OL(t){let e;return t.rank===0||t.rank===1?e=F(t,[1,1,1,t.size]):t.rank===2?e=F(t,[1,1,t.shape[0],t.shape[1]]):t.rank===3?e=F(t,[1,t.shape[0],t.shape[1],t.shape[2]]):e=t,e}/** + */function OL(t,e,n){const s=T(t,"x","batchToSpaceND"),r=e.reduce((a,l)=>a*l);I(s.rank>=1+e.length,()=>`input rank is ${s.rank} but should be > than blockShape.length ${e.length}`),I(n.length===e.length,()=>`crops.length is ${n.length} but should be equal to blockShape.length ${e.length}`),I(s.shape[0]%r===0,()=>`input tensor batch is ${s.shape[0]} but is not divisible by the product of the elements of blockShape ${e.join(" * ")} === ${r}`);const o={x:s},i={blockShape:e,crops:n};return _.runKernel(vp,o,i)}const My=z({batchToSpaceND_:OL});function ML(t){let e;return t.rank===0||t.rank===1?e=F(t,[1,1,1,t.size]):t.rank===2?e=F(t,[1,1,t.shape[0],t.shape[1]]):t.rank===3?e=F(t,[1,t.shape[0],t.shape[1],t.shape[2]]):e=t,e}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1068,7 +1068,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function ML(t,e,n,s,r,o){o==null&&(o=.001);const i=T(t,"x","batchNorm"),a=T(e,"mean","batchNorm"),l=T(n,"variance","batchNorm");let c;r!=null&&(c=T(r,"scale","batchNorm"));let u;s!=null&&(u=T(s,"offset","batchNorm")),I(a.rank===l.rank,()=>"Batch normalization gradient requires mean and variance to have equal ranks."),I(u==null||a.rank===u.rank,()=>"Batch normalization gradient requires mean and offset to have equal ranks."),I(c==null||a.rank===c.rank,()=>"Batch normalization gradient requires mean and scale to have equal ranks.");const h={x:OL(i),scale:c,offset:u,mean:a,variance:l},f={varianceEpsilon:o},p=_.runKernel(Ap,h,f);return F(p,i.shape)}const gm=z({batchNorm_:ML});function PL(t,e,n,s,r,o){const i=T(t,"x","batchNorm"),a=T(e,"mean","batchNorm"),l=T(n,"variance","batchNorm");let c;r!=null&&(c=T(r,"scale","batchNorm"));let u;return s!=null&&(u=T(s,"offset","batchNorm")),I(i.rank===2,()=>`Error in batchNorm2D: x must be rank 2 but got rank ${i.rank}.`),I(a.rank===2||a.rank===1,()=>`Error in batchNorm2D: mean must be rank 2 or rank 1 but got rank ${a.rank}.`),I(l.rank===2||l.rank===1,()=>`Error in batchNorm2D: variance must be rank 2 or rank 1 but got rank ${l.rank}.`),c!=null&&I(c.rank===2||c.rank===1,()=>`Error in batchNorm2D: scale must be rank 2 or rank 1 but got rank ${c.rank}.`),u!=null&&I(u.rank===2||u.rank===1,()=>`Error in batchNorm2D: offset must be rank 2 or rank 1 but got rank ${u.rank}.`),gm(i,a,l,u,c,o)}const LL=z({batchNorm2d_:PL});function BL(t,e,n,s,r,o){const i=T(t,"x","batchNorm"),a=T(e,"mean","batchNorm"),l=T(n,"variance","batchNorm");let c;r!=null&&(c=T(r,"scale","batchNorm"));let u;return s!=null&&(u=T(s,"offset","batchNorm")),I(i.rank===3,()=>`Error in batchNorm3D: x must be rank 3 but got rank ${i.rank}.`),I(a.rank===3||a.rank===1,()=>`Error in batchNorm3D: mean must be rank 3 or rank 1 but got rank ${a.rank}.`),I(l.rank===3||l.rank===1,()=>`Error in batchNorm3D: variance must be rank 3 or rank 1 but got rank ${l.rank}.`),c!=null&&I(c.rank===3||c.rank===1,()=>`Error in batchNorm3D: scale must be rank 3 or rank 1 but got rank ${c.rank}.`),u!=null&&I(u.rank===3||u.rank===1,()=>`Error in batchNorm3D: offset must be rank 3 or rank 1 but got rank ${u.rank}.`),gm(i,a,l,u,c,o)}const VL=z({batchNorm3d_:BL});function WL(t,e,n,s,r,o){const i=T(t,"x","batchNorm"),a=T(e,"mean","batchNorm"),l=T(n,"variance","batchNorm");let c;r!=null&&(c=T(r,"scale","batchNorm"));let u;return s!=null&&(u=T(s,"offset","batchNorm")),I(i.rank===4,()=>`Error in batchNorm4D: x must be rank 4 but got rank ${i.rank}.`),I(a.rank===4||a.rank===1,()=>`Error in batchNorm4D: mean must be rank 4 or rank 1 but got rank ${a.rank}.`),I(l.rank===4||l.rank===1,()=>`Error in batchNorm4D: variance must be rank 4 or rank 1 but got rank ${l.rank}.`),c!=null&&I(c.rank===4||c.rank===1,()=>`Error in batchNorm4D: scale must be rank 4 or rank 1 but got rank ${c.rank}.`),u!=null&&I(u.rank===4||u.rank===1,()=>`Error in batchNorm4D: offset must be rank 4 or rank 1 but got rank ${u.rank}.`),gm(i,a,l,u,c,o)}const UL=z({batchNorm4d_:WL});/** + */function PL(t,e,n,s,r,o){o==null&&(o=.001);const i=T(t,"x","batchNorm"),a=T(e,"mean","batchNorm"),l=T(n,"variance","batchNorm");let c;r!=null&&(c=T(r,"scale","batchNorm"));let u;s!=null&&(u=T(s,"offset","batchNorm")),I(a.rank===l.rank,()=>"Batch normalization gradient requires mean and variance to have equal ranks."),I(u==null||a.rank===u.rank,()=>"Batch normalization gradient requires mean and offset to have equal ranks."),I(c==null||a.rank===c.rank,()=>"Batch normalization gradient requires mean and scale to have equal ranks.");const d={x:ML(i),scale:c,offset:u,mean:a,variance:l},f={varianceEpsilon:o},p=_.runKernel(Ap,d,f);return F(p,i.shape)}const gm=z({batchNorm_:PL});function LL(t,e,n,s,r,o){const i=T(t,"x","batchNorm"),a=T(e,"mean","batchNorm"),l=T(n,"variance","batchNorm");let c;r!=null&&(c=T(r,"scale","batchNorm"));let u;return s!=null&&(u=T(s,"offset","batchNorm")),I(i.rank===2,()=>`Error in batchNorm2D: x must be rank 2 but got rank ${i.rank}.`),I(a.rank===2||a.rank===1,()=>`Error in batchNorm2D: mean must be rank 2 or rank 1 but got rank ${a.rank}.`),I(l.rank===2||l.rank===1,()=>`Error in batchNorm2D: variance must be rank 2 or rank 1 but got rank ${l.rank}.`),c!=null&&I(c.rank===2||c.rank===1,()=>`Error in batchNorm2D: scale must be rank 2 or rank 1 but got rank ${c.rank}.`),u!=null&&I(u.rank===2||u.rank===1,()=>`Error in batchNorm2D: offset must be rank 2 or rank 1 but got rank ${u.rank}.`),gm(i,a,l,u,c,o)}const BL=z({batchNorm2d_:LL});function VL(t,e,n,s,r,o){const i=T(t,"x","batchNorm"),a=T(e,"mean","batchNorm"),l=T(n,"variance","batchNorm");let c;r!=null&&(c=T(r,"scale","batchNorm"));let u;return s!=null&&(u=T(s,"offset","batchNorm")),I(i.rank===3,()=>`Error in batchNorm3D: x must be rank 3 but got rank ${i.rank}.`),I(a.rank===3||a.rank===1,()=>`Error in batchNorm3D: mean must be rank 3 or rank 1 but got rank ${a.rank}.`),I(l.rank===3||l.rank===1,()=>`Error in batchNorm3D: variance must be rank 3 or rank 1 but got rank ${l.rank}.`),c!=null&&I(c.rank===3||c.rank===1,()=>`Error in batchNorm3D: scale must be rank 3 or rank 1 but got rank ${c.rank}.`),u!=null&&I(u.rank===3||u.rank===1,()=>`Error in batchNorm3D: offset must be rank 3 or rank 1 but got rank ${u.rank}.`),gm(i,a,l,u,c,o)}const WL=z({batchNorm3d_:VL});function UL(t,e,n,s,r,o){const i=T(t,"x","batchNorm"),a=T(e,"mean","batchNorm"),l=T(n,"variance","batchNorm");let c;r!=null&&(c=T(r,"scale","batchNorm"));let u;return s!=null&&(u=T(s,"offset","batchNorm")),I(i.rank===4,()=>`Error in batchNorm4D: x must be rank 4 but got rank ${i.rank}.`),I(a.rank===4||a.rank===1,()=>`Error in batchNorm4D: mean must be rank 4 or rank 1 but got rank ${a.rank}.`),I(l.rank===4||l.rank===1,()=>`Error in batchNorm4D: variance must be rank 4 or rank 1 but got rank ${l.rank}.`),c!=null&&I(c.rank===4||c.rank===1,()=>`Error in batchNorm4D: scale must be rank 4 or rank 1 but got rank ${c.rank}.`),u!=null&&I(u.rank===4||u.rank===1,()=>`Error in batchNorm4D: offset must be rank 4 or rank 1 but got rank ${u.rank}.`),gm(i,a,l,u,c,o)}const GL=z({batchNorm4d_:UL});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1083,7 +1083,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function GL(t,e,n){const s=T(t,"x","bincount"),r=T(e,"weights","bincount");I(s.dtype==="int32",()=>`Error in bincount: input dtype must be int32, but got ${s.dtype}`),I(n>=0,()=>`size must be non-negative, but got ${n}.`),I(r.size===s.size||r.size===0,()=>`Error in bincount: weights must have the same size as input or0-length, but got input shape: ${s.shape}, weights shape: ${r.shape}.`);const o={x:s,weights:r},i={size:n};return _.runKernel(qx,o,i)}const HL=z({bincount_:GL});/** + */function HL(t,e,n){const s=T(t,"x","bincount"),r=T(e,"weights","bincount");I(s.dtype==="int32",()=>`Error in bincount: input dtype must be int32, but got ${s.dtype}`),I(n>=0,()=>`size must be non-negative, but got ${n}.`),I(r.size===s.size||r.size===0,()=>`Error in bincount: weights must have the same size as input or0-length, but got input shape: ${s.shape}, weights shape: ${r.shape}.`);const o={x:s,weights:r},i={size:n};return _.runKernel(qx,o,i)}const jL=z({bincount_:HL});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1098,7 +1098,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function jL(t,e){let n=T(t,"broadcastTo","x");const s=n.shape;if(Xr(e),e.lengthn.rank){const c=n.shape.slice();for(;c.length=0;c--)if(r[c]===e[c])o[c]=1;else if(n.shape[c]!==1)throw new Error(`broadcastTo(): [${s}] cannot be broadcast to [${e}].`);if(o.map((c,u)=>c>1?u:-1).filter(c=>c>=0).length===0)return vi(n);const a={x:n},l={reps:o};return _.runKernel(ad,a,l)}const Cc=z({broadcastTo_:jL});/** + */function KL(t,e){let n=T(t,"broadcastTo","x");const s=n.shape;if(qr(e),e.lengthn.rank){const c=n.shape.slice();for(;c.length=0;c--)if(r[c]===e[c])o[c]=1;else if(n.shape[c]!==1)throw new Error(`broadcastTo(): [${s}] cannot be broadcast to [${e}].`);if(o.map((c,u)=>c>1?u:-1).filter(c=>c>=0).length===0)return vi(n);const a={x:n},l={reps:o};return _.runKernel(ah,a,l)}const Cc=z({broadcastTo_:KL});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1113,7 +1113,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function KL(t){const n={x:T(t,"x","ceil","float32")};return _.runKernel(Cu,n)}const XL=z({ceil_:KL});/** + */function XL(t){const n={x:T(t,"x","ceil","float32")};return _.runKernel(Cu,n)}const qL=z({ceil_:XL});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1128,7 +1128,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function xm(t,e,n){Xr(t),n=n||wl(e);const s={shape:t,value:e,dtype:n};return _.runKernel(uy,{},s)}/** + */function xm(t,e,n){qr(t),n=n||wl(e);const s={shape:t,value:e,dtype:n};return _.runKernel(uy,{},s)}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1143,7 +1143,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function qL(t,e,n){const s=T(t,"x","clipByValue");if(I(e<=n,()=>`Error in clip: min (${e}) must be less than or equal to max (${n}).`),e===n)return xm(s.shape,e,s.dtype);const r={x:s},o={clipValueMin:e,clipValueMax:n};return _.runKernel(ku,r,o)}const as=z({clipByValue_:qL});function YL(t){return Dn(t,0)}const QL=z({concat1d_:YL});function ZL(t,e){return Dn(t,e)}const JL=z({concat2d_:ZL});function e4(t,e){return Dn(t,e)}const t4=z({concat3d_:e4});function n4(t,e){return Dn(t,e)}const s4=z({concat4d_:n4});/** + */function YL(t,e,n){const s=T(t,"x","clipByValue");if(I(e<=n,()=>`Error in clip: min (${e}) must be less than or equal to max (${n}).`),e===n)return xm(s.shape,e,s.dtype);const r={x:s},o={clipValueMin:e,clipValueMax:n};return _.runKernel(ku,r,o)}const as=z({clipByValue_:YL});function QL(t){return Dn(t,0)}const ZL=z({concat1d_:QL});function JL(t,e){return Dn(t,e)}const e4=z({concat2d_:JL});function t4(t,e){return Dn(t,e)}const n4=z({concat3d_:t4});function s4(t,e){return Dn(t,e)}const r4=z({concat4d_:s4});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1158,7 +1158,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function r4(t,e,n,s,r="NHWC",o=[1,1],i){const a=T(t,"x","conv2d","float32"),l=T(e,"filter","conv2d","float32");let c=a,u=!1;a.rank===3&&(u=!0,c=F(a,[1,a.shape[0],a.shape[1],a.shape[2]])),I(c.rank===4,()=>`Error in conv2d: input must be rank 4, but got rank ${c.rank}.`),I(l.rank===4,()=>`Error in conv2d: filter must be rank 4, but got rank ${l.rank}.`),Mn("conv2d",s,i);const d=r==="NHWC"?c.shape[3]:c.shape[1];I(d===l.shape[2],()=>`Error in conv2d: depth of input (${d}) must match input depth for filter ${l.shape[2]}.`),I(hn(n,o),()=>`Error in conv2D: Either strides or dilations must be 1. Got strides ${n} and dilations '${o}'`),I(Fi(o),()=>"Error in conv2D: Dilated rates should be larger than 0."),I(Fi(n),()=>"Error in conv2D: Strides should be larger than 0.");const h={x:c,filter:l},f={strides:n,pad:s,dataFormat:r,dilations:o,dimRoundingMode:i},p=_.runKernel(kp,h,f);return u?F(p,[p.shape[1],p.shape[2],p.shape[3]]):p}const zi=z({conv2d_:r4});function o4(t,e,n,s,r="NWC",o=1,i){const a=T(t,"x","conv1d"),l=T(e,"filter","conv1d");let c=a,u=!1;a.rank===2&&(u=!0,c=F(a,[1,a.shape[0],a.shape[1]])),I(c.rank===3,()=>`Error in conv1d: input must be rank 3, but got rank ${c.rank}.`),I(l.rank===3,()=>`Error in conv1d: filter must be rank 3, but got rank ${l.rank}.`),Mn("conv1d",s,i),I(c.shape[2]===l.shape[1],()=>`Error in conv1d: depth of input (${c.shape[2]}) must match input depth for filter ${l.shape[1]}.`),I(hn(n,o),()=>`Error in conv1D: Either stride or dilation must be 1. Got stride ${n} and dilation '${o}'`),I(Fi(o),()=>"Error in conv1D: Dilated rates should be larger than 0."),I(Fi(n),()=>"Error in conv1D: Stride should be larger than 0."),I(r==="NWC",()=>`Error in conv1d: got dataFormat of ${r} but only NWC is currently supported.`);const d=F(l,[1,l.shape[0],l.shape[1],l.shape[2]]),h=F(c,[c.shape[0],1,c.shape[1],c.shape[2]]),x=zi(h,d,[1,n],s,"NHWC",[1,o],i);return u?F(x,[x.shape[2],x.shape[3]]):F(x,[x.shape[0],x.shape[2],x.shape[3]])}const q$=z({conv1d_:o4});/** + */function o4(t,e,n,s,r="NHWC",o=[1,1],i){const a=T(t,"x","conv2d","float32"),l=T(e,"filter","conv2d","float32");let c=a,u=!1;a.rank===3&&(u=!0,c=F(a,[1,a.shape[0],a.shape[1],a.shape[2]])),I(c.rank===4,()=>`Error in conv2d: input must be rank 4, but got rank ${c.rank}.`),I(l.rank===4,()=>`Error in conv2d: filter must be rank 4, but got rank ${l.rank}.`),Mn("conv2d",s,i);const h=r==="NHWC"?c.shape[3]:c.shape[1];I(h===l.shape[2],()=>`Error in conv2d: depth of input (${h}) must match input depth for filter ${l.shape[2]}.`),I(dn(n,o),()=>`Error in conv2D: Either strides or dilations must be 1. Got strides ${n} and dilations '${o}'`),I(Fi(o),()=>"Error in conv2D: Dilated rates should be larger than 0."),I(Fi(n),()=>"Error in conv2D: Strides should be larger than 0.");const d={x:c,filter:l},f={strides:n,pad:s,dataFormat:r,dilations:o,dimRoundingMode:i},p=_.runKernel(kp,d,f);return u?F(p,[p.shape[1],p.shape[2],p.shape[3]]):p}const zi=z({conv2d_:o4});function i4(t,e,n,s,r="NWC",o=1,i){const a=T(t,"x","conv1d"),l=T(e,"filter","conv1d");let c=a,u=!1;a.rank===2&&(u=!0,c=F(a,[1,a.shape[0],a.shape[1]])),I(c.rank===3,()=>`Error in conv1d: input must be rank 3, but got rank ${c.rank}.`),I(l.rank===3,()=>`Error in conv1d: filter must be rank 3, but got rank ${l.rank}.`),Mn("conv1d",s,i),I(c.shape[2]===l.shape[1],()=>`Error in conv1d: depth of input (${c.shape[2]}) must match input depth for filter ${l.shape[1]}.`),I(dn(n,o),()=>`Error in conv1D: Either stride or dilation must be 1. Got stride ${n} and dilation '${o}'`),I(Fi(o),()=>"Error in conv1D: Dilated rates should be larger than 0."),I(Fi(n),()=>"Error in conv1D: Stride should be larger than 0."),I(r==="NWC",()=>`Error in conv1d: got dataFormat of ${r} but only NWC is currently supported.`);const h=F(l,[1,l.shape[0],l.shape[1],l.shape[2]]),d=F(c,[c.shape[0],1,c.shape[1],c.shape[2]]),x=zi(d,h,[1,n],s,"NHWC",[1,o],i);return u?F(x,[x.shape[2],x.shape[3]]):F(x,[x.shape[0],x.shape[2],x.shape[3]])}const Y$=z({conv1d_:i4});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1173,7 +1173,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function i4(t,e,n,s,r,o="NHWC",i){I(t.length===e.rank,()=>`Length of inShape (${t.length}) and rank of dy (${e.rank}) must match`);let a=t,l=e,c=!1;e.rank===3&&(c=!0,l=F(e,[1,e.shape[0],e.shape[1],e.shape[2]]),a=[1,t[0],t[1],t[2]]),I(a.length===4,()=>`Error in conv2dDerInput: inShape must be length 4, but got length ${a.length}.`),I(l.rank===4,()=>`Error in conv2dDerInput: dy must be rank 4, but got rank ${l.rank}`),I(n.rank===4,()=>`Error in conv2dDerInput: filter must be rank 4, but got rank ${n.rank}`);const u=o==="NHWC"?a[3]:a[1],d=o==="NHWC"?l.shape[3]:l.shape[1];I(u===n.shape[2],()=>`Error in conv2dDerInput: depth of input (${u}) must match input depth for filter ${n.shape[2]}.`),I(d===n.shape[3],()=>`Error in conv2dDerInput: depth of output (${d}) must match output depth for filter ${n.shape[3]}.`),Mn("conv2dDerInput",r,i);const h={dy:l,filter:n},f={strides:s,pad:r,dataFormat:o,dimRoundingMode:i,inputShape:a},p=_.runKernel(Sp,h,f);return c?F(p,[p.shape[1],p.shape[2],p.shape[3]]):p}const Py=z({conv2DBackpropInput_:i4});function a4(t,e,n,s,r,o){const i=T(t,"x","conv2dTranspose"),a=T(e,"filter","conv2dTranspose");return Py(n,i,a,s,r,"NHWC",o)}const Y$=z({conv2dTranspose_:a4});/** + */function a4(t,e,n,s,r,o="NHWC",i){I(t.length===e.rank,()=>`Length of inShape (${t.length}) and rank of dy (${e.rank}) must match`);let a=t,l=e,c=!1;e.rank===3&&(c=!0,l=F(e,[1,e.shape[0],e.shape[1],e.shape[2]]),a=[1,t[0],t[1],t[2]]),I(a.length===4,()=>`Error in conv2dDerInput: inShape must be length 4, but got length ${a.length}.`),I(l.rank===4,()=>`Error in conv2dDerInput: dy must be rank 4, but got rank ${l.rank}`),I(n.rank===4,()=>`Error in conv2dDerInput: filter must be rank 4, but got rank ${n.rank}`);const u=o==="NHWC"?a[3]:a[1],h=o==="NHWC"?l.shape[3]:l.shape[1];I(u===n.shape[2],()=>`Error in conv2dDerInput: depth of input (${u}) must match input depth for filter ${n.shape[2]}.`),I(h===n.shape[3],()=>`Error in conv2dDerInput: depth of output (${h}) must match output depth for filter ${n.shape[3]}.`),Mn("conv2dDerInput",r,i);const d={dy:l,filter:n},f={strides:s,pad:r,dataFormat:o,dimRoundingMode:i,inputShape:a},p=_.runKernel(Sp,d,f);return c?F(p,[p.shape[1],p.shape[2],p.shape[3]]):p}const Py=z({conv2DBackpropInput_:a4});function l4(t,e,n,s,r,o){const i=T(t,"x","conv2dTranspose"),a=T(e,"filter","conv2dTranspose");return Py(n,i,a,s,r,"NHWC",o)}const Q$=z({conv2dTranspose_:l4});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1188,7 +1188,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function l4(t,e,n,s,r="NDHWC",o=[1,1,1]){const i=T(t,"x","conv3d"),a=T(e,"filter","conv3d");let l=i,c=!1;i.rank===4&&(c=!0,l=F(i,[1,i.shape[0],i.shape[1],i.shape[2],i.shape[3]])),I(l.rank===5,()=>`Error in conv3d: input must be rank 5, but got rank ${l.rank}.`),I(a.rank===5,()=>`Error in conv3d: filter must be rank 5, but got rank ${a.rank}.`),I(l.shape[4]===a.shape[3],()=>`Error in conv3d: depth of input (${l.shape[4]}) must match input depth for filter ${a.shape[3]}.`),I(hn(n,o),()=>`Error in conv3D: Either strides or dilations must be 1. Got strides ${n} and dilations '${o}'`),I(r==="NDHWC",()=>`Error in conv3d: got dataFormat of ${r} but only NDHWC is currently supported.`),I(Fi(o),()=>"Error in conv3D: Dilated rates should be larger than 0."),I(Fi(n),()=>"Error in conv3D: Strides should be larger than 0.");const u={x:l,filter:a},d={strides:n,pad:s,dataFormat:r,dilations:o},h=_.runKernel(Ip,u,d);return c?F(h,[h.shape[1],h.shape[2],h.shape[3],h.shape[4]]):h}const c4=z({conv3d_:l4});/** + */function c4(t,e,n,s,r="NDHWC",o=[1,1,1]){const i=T(t,"x","conv3d"),a=T(e,"filter","conv3d");let l=i,c=!1;i.rank===4&&(c=!0,l=F(i,[1,i.shape[0],i.shape[1],i.shape[2],i.shape[3]])),I(l.rank===5,()=>`Error in conv3d: input must be rank 5, but got rank ${l.rank}.`),I(a.rank===5,()=>`Error in conv3d: filter must be rank 5, but got rank ${a.rank}.`),I(l.shape[4]===a.shape[3],()=>`Error in conv3d: depth of input (${l.shape[4]}) must match input depth for filter ${a.shape[3]}.`),I(dn(n,o),()=>`Error in conv3D: Either strides or dilations must be 1. Got strides ${n} and dilations '${o}'`),I(r==="NDHWC",()=>`Error in conv3d: got dataFormat of ${r} but only NDHWC is currently supported.`),I(Fi(o),()=>"Error in conv3D: Dilated rates should be larger than 0."),I(Fi(n),()=>"Error in conv3D: Strides should be larger than 0.");const u={x:l,filter:a},h={strides:n,pad:s,dataFormat:r,dilations:o},d=_.runKernel(Ip,u,h);return c?F(d,[d.shape[1],d.shape[2],d.shape[3],d.shape[4]]):d}const u4=z({conv3d_:c4});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1203,7 +1203,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function u4(t,e,n,s,r){I(t.length===e.rank,()=>`Length of inShape (${t.length}) and rank of dy (${e.rank}) must match`);let o=t,i=e,a=!1;e.rank===4&&(a=!0,i=F(e,[1,e.shape[0],e.shape[1],e.shape[2],e.shape[3]]),o=[1,t[0],t[1],t[2],t[3]]);const l=o[4],c=i.shape[4];I(o.length===5,()=>`Error in conv3dDerInput: inShape must be length 5, but got length ${o.length}.`),I(i.rank===5,()=>`Error in conv3dDerInput: dy must be rank 5, but got rank ${i.rank}`),I(n.rank===5,()=>`Error in conv3dDerInput: filter must be rank 5, but got rank ${n.rank}`),I(l===n.shape[3],()=>`Error in conv3dDerInput: depth of input (${l}) must match input depth for filter ${n.shape[3]}.`),I(c===n.shape[4],()=>`Error in conv3dDerInput: depth of output (${c}) must match output depth for filter ${n.shape[4]}.`);const u={dy:i,filter:n},d={pad:r,strides:s,inputShape:o},h=_.runKernel(ey,u,d);return a?F(h,[h.shape[1],h.shape[2],h.shape[3],h.shape[4]]):h}const Q$=z({conv3DBackpropInput_:u4});function d4(t,e,n,s,r){const o=T(t,"x","conv3dTranspose"),i=T(e,"filter","conv3dTranspose");return Q$(n,o,i,s,r)}const h4=z({conv3dTranspose_:d4});/** + */function h4(t,e,n,s,r){I(t.length===e.rank,()=>`Length of inShape (${t.length}) and rank of dy (${e.rank}) must match`);let o=t,i=e,a=!1;e.rank===4&&(a=!0,i=F(e,[1,e.shape[0],e.shape[1],e.shape[2],e.shape[3]]),o=[1,t[0],t[1],t[2],t[3]]);const l=o[4],c=i.shape[4];I(o.length===5,()=>`Error in conv3dDerInput: inShape must be length 5, but got length ${o.length}.`),I(i.rank===5,()=>`Error in conv3dDerInput: dy must be rank 5, but got rank ${i.rank}`),I(n.rank===5,()=>`Error in conv3dDerInput: filter must be rank 5, but got rank ${n.rank}`),I(l===n.shape[3],()=>`Error in conv3dDerInput: depth of input (${l}) must match input depth for filter ${n.shape[3]}.`),I(c===n.shape[4],()=>`Error in conv3dDerInput: depth of output (${c}) must match output depth for filter ${n.shape[4]}.`);const u={dy:i,filter:n},h={pad:r,strides:s,inputShape:o},d=_.runKernel(ey,u,h);return a?F(d,[d.shape[1],d.shape[2],d.shape[3],d.shape[4]]):d}const Z$=z({conv3DBackpropInput_:h4});function d4(t,e,n,s,r){const o=T(t,"x","conv3dTranspose"),i=T(e,"filter","conv3dTranspose");return Z$(n,o,i,s,r)}const f4=z({conv3dTranspose_:d4});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1218,7 +1218,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function f4(t){const n={x:T(t,"x","cos","float32")};return _.runKernel(Su,n)}const Ly=z({cos_:f4});/** + */function p4(t){const n={x:T(t,"x","cos","float32")};return _.runKernel(Su,n)}const Ly=z({cos_:p4});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1233,7 +1233,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function p4(t){const n={x:T(t,"x","cosh","float32")};return _.runKernel(Iu,n)}const Z$=z({cosh_:p4});/** + */function m4(t){const n={x:T(t,"x","cosh","float32")};return _.runKernel(Iu,n)}const J$=z({cosh_:m4});/** * @license * Copyright 2022 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the 'License'); @@ -1248,7 +1248,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function m4(t,e=0,n=!1,s=!1){const o={x:T(t,"x","cumprod")},i={axis:e,exclusive:n,reverse:s};return _.runKernel(ty,o,i)}const h1=z({cumprod_:m4});/** + */function g4(t,e=0,n=!1,s=!1){const o={x:T(t,"x","cumprod")},i={axis:e,exclusive:n,reverse:s};return _.runKernel(ty,o,i)}const d1=z({cumprod_:g4});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1263,7 +1263,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function g4(t,e=0,n=!1,s=!1){const o={x:T(t,"x","cumsum")},i={axis:e,exclusive:n,reverse:s};return _.runKernel($p,o,i)}const J$=z({cumsum_:g4});/** + */function x4(t,e=0,n=!1,s=!1){const o={x:T(t,"x","cumsum")},i={axis:e,exclusive:n,reverse:s};return _.runKernel($p,o,i)}const eN=z({cumsum_:x4});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1278,7 +1278,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function x4(t,e,n,s=!1){const r=T(t,"x","denseBincount"),o=T(e,"weights","denseBincount");I(r.dtype==="int32",()=>`Error in denseBincount: input dtype must be int32, but got ${r.dtype}`),I(r.rank<=2,()=>`Error in denseBincount: input must be at most rank 2, but got rank ${r.rank}.`),I(n>=0,()=>`size must be non-negative, but got ${n}.`),I(o.size===r.size||o.size===0,()=>`Error in denseBincount: weights must have the same shape as x or 0-length, but got x shape: ${r.shape}, weights shape: ${o.shape}.`);const i={x:r,weights:o},a={size:n,binaryOutput:s};return _.runKernel(sy,i,a)}const RC=z({denseBincount_:x4});/** + */function y4(t,e,n,s=!1){const r=T(t,"x","denseBincount"),o=T(e,"weights","denseBincount");I(r.dtype==="int32",()=>`Error in denseBincount: input dtype must be int32, but got ${r.dtype}`),I(r.rank<=2,()=>`Error in denseBincount: input must be at most rank 2, but got rank ${r.rank}.`),I(n>=0,()=>`size must be non-negative, but got ${n}.`),I(o.size===r.size||o.size===0,()=>`Error in denseBincount: weights must have the same shape as x or 0-length, but got x shape: ${r.shape}, weights shape: ${o.shape}.`);const i={x:r,weights:o},a={size:n,binaryOutput:s};return _.runKernel(sy,i,a)}const RC=z({denseBincount_:y4});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1293,11 +1293,11 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function y4(t,e,n="NHWC"){const s=T(t,"x","depthToSpace","float32"),r=n==="NHWC"?s.shape[1]:s.shape[2],o=n==="NHWC"?s.shape[2]:s.shape[3],i=n==="NHWC"?s.shape[3]:s.shape[1];I(e>1,()=>`blockSize should be > 1 for depthToSpace, but was: ${e}`),I(r*e>=0,()=>`Negative dimension size caused by overflow when multiplying + */function w4(t,e,n="NHWC"){const s=T(t,"x","depthToSpace","float32"),r=n==="NHWC"?s.shape[1]:s.shape[2],o=n==="NHWC"?s.shape[2]:s.shape[3],i=n==="NHWC"?s.shape[3]:s.shape[1];I(e>1,()=>`blockSize should be > 1 for depthToSpace, but was: ${e}`),I(r*e>=0,()=>`Negative dimension size caused by overflow when multiplying ${r} and ${e} for depthToSpace with input shape ${s.shape}`),I(o*e>=0,()=>`Negative dimension size caused by overflow when multiplying ${o} and ${e} for depthToSpace with input shape - ${s.shape}`),I(i%(e*e)===0,()=>`Dimension size must be evenly divisible by ${e*e} but is ${i} for depthToSpace with input shape ${s.shape}`);const a={x:s},l={blockSize:e,dataFormat:n};return _.runKernel(ry,a,l)}const w4=z({depthToSpace_:y4});/** + ${s.shape}`),I(i%(e*e)===0,()=>`Dimension size must be evenly divisible by ${e*e} but is ${i} for depthToSpace with input shape ${s.shape}`);const a={x:s},l={blockSize:e,dataFormat:n};return _.runKernel(ry,a,l)}const v4=z({depthToSpace_:w4});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1312,7 +1312,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function v4(t,e,n,s,r="NHWC",o=[1,1],i){const a=T(t,"x","depthwiseConv2d","float32"),l=T(e,"filter","depthwiseConv2d","float32");let c=a,u=!1;a.rank===3&&(u=!0,c=F(a,[1,a.shape[0],a.shape[1],a.shape[2]])),I(c.rank===4,()=>`Error in depthwiseConv2d: input must be rank 4, but got rank ${c.rank}.`),I(l.rank===4,()=>`Error in depthwiseConv2d: filter must be rank 4, but got rank ${l.rank}.`);const d=r==="NHWC"?c.shape[3]:c.shape[1];I(d===l.shape[2],()=>`Error in depthwiseConv2d: number of input channels (${d}) must match the inChannels dimension in filter ${l.shape[2]}.`),Mn("depthwiseConv2d",s,i);const h={x:c,filter:l},f={strides:n,pad:s,dataFormat:r,dilations:o,dimRoundingMode:i},p=_.runKernel(Np,h,f);return u?F(p,[p.shape[1],p.shape[2],p.shape[3]]):p}const By=z({depthwiseConv2d_:v4});/** + */function b4(t,e,n,s,r="NHWC",o=[1,1],i){const a=T(t,"x","depthwiseConv2d","float32"),l=T(e,"filter","depthwiseConv2d","float32");let c=a,u=!1;a.rank===3&&(u=!0,c=F(a,[1,a.shape[0],a.shape[1],a.shape[2]])),I(c.rank===4,()=>`Error in depthwiseConv2d: input must be rank 4, but got rank ${c.rank}.`),I(l.rank===4,()=>`Error in depthwiseConv2d: filter must be rank 4, but got rank ${l.rank}.`);const h=r==="NHWC"?c.shape[3]:c.shape[1];I(h===l.shape[2],()=>`Error in depthwiseConv2d: number of input channels (${h}) must match the inChannels dimension in filter ${l.shape[2]}.`),Mn("depthwiseConv2d",s,i);const d={x:c,filter:l},f={strides:n,pad:s,dataFormat:r,dilations:o,dimRoundingMode:i},p=_.runKernel(Np,d,f);return u?F(p,[p.shape[1],p.shape[2],p.shape[3]]):p}const By=z({depthwiseConv2d_:b4});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1327,7 +1327,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function b4(t,e,n,s,r=[1,1],o="NHWC"){const i=T(t,"x","dilation2d"),a=T(e,"filter","dilation2d");I(i.rank===3||i.rank===4,()=>`Error in dilation2d: input must be rank 3 or 4, but got rank ${i.rank}.`),I(a.rank===3,()=>`Error in dilation2d: filter must be rank 3, but got rank ${a.rank}.`),I(o==="NHWC",()=>`Error in dilation2d: Only NHWC is currently supported, but got dataFormat of ${o}`);let l=i,c=!1;i.rank===3&&(l=F(i,[1,i.shape[0],i.shape[1],i.shape[2]]),c=!0),I(l.shape[3]===a.shape[2],()=>`Error in dilation2d: input and filter must have the same depth: ${l.shape[3]} vs ${a.shape[2]}`);const u={x:l,filter:a},d={strides:n,pad:s,dilations:r},h=_.runKernel(Tp,u,d);return c?F(h,[h.shape[1],h.shape[2],h.shape[3]]):h}const C4=z({dilation2d_:b4});/** + */function C4(t,e,n,s,r=[1,1],o="NHWC"){const i=T(t,"x","dilation2d"),a=T(e,"filter","dilation2d");I(i.rank===3||i.rank===4,()=>`Error in dilation2d: input must be rank 3 or 4, but got rank ${i.rank}.`),I(a.rank===3,()=>`Error in dilation2d: filter must be rank 3, but got rank ${a.rank}.`),I(o==="NHWC",()=>`Error in dilation2d: Only NHWC is currently supported, but got dataFormat of ${o}`);let l=i,c=!1;i.rank===3&&(l=F(i,[1,i.shape[0],i.shape[1],i.shape[2]]),c=!0),I(l.shape[3]===a.shape[2],()=>`Error in dilation2d: input and filter must have the same depth: ${l.shape[3]} vs ${a.shape[2]}`);const u={x:l,filter:a},h={strides:n,pad:s,dilations:r},d=_.runKernel(Tp,u,h);return c?F(d,[d.shape[1],d.shape[2],d.shape[3]]):d}const k4=z({dilation2d_:C4});/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1357,7 +1357,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function k4(t,e){let n=T(t,"a","equal","string_or_numeric"),s=T(e,"b","equal","string_or_numeric");[n,s]=It(n,s),Se(n.shape,s.shape);const r={a:n,b:s};return _.runKernel(Ep,r)}const Cr=z({equal_:k4});/** + */function S4(t,e){let n=T(t,"a","equal","string_or_numeric"),s=T(e,"b","equal","string_or_numeric");[n,s]=It(n,s),Se(n.shape,s.shape);const r={a:n,b:s};return _.runKernel(Ep,r)}const kr=z({equal_:S4});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1372,7 +1372,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function S4(t,e,n){const s=T(e,"a","where"),r=T(n,"b","where"),o=T(t,"condition","where","bool"),i=Se(Se(o.shape,s.shape),r.shape),a=Cc(o,i),l=Cc(s,i),c=Cc(r,i),u={condition:a,t:l,e:c};return _.runKernel(om,u)}const Cn=z({where_:S4});/** + */function I4(t,e,n){const s=T(e,"a","where"),r=T(n,"b","where"),o=T(t,"condition","where","bool"),i=Se(Se(o.shape,s.shape),r.shape),a=Cc(o,i),l=Cc(s,i),c=Cc(r,i),u={condition:a,t:l,e:c};return _.runKernel(om,u)}const Cn=z({where_:I4});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1387,7 +1387,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function I4(t){const n={x:T(t,"x","zerosLike")};return _.runKernel(fm,n)}const ze=z({zerosLike_:I4});/** + */function $4(t){const n={x:T(t,"x","zerosLike")};return _.runKernel(fm,n)}const ze=z({zerosLike_:$4});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1402,7 +1402,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function $4(t,e){let n=T(t,"a","div"),s=T(e,"b","div");[n,s]=It(n,s);const r=ge(n,s),o=ze(r),i=Cr(s,o);return Cn(i,o,r)}const N4=z({divNoNan_:$4});/** + */function N4(t,e){let n=T(t,"a","div"),s=T(e,"b","div");[n,s]=It(n,s);const r=ge(n,s),o=ze(r),i=kr(s,o);return Cn(i,o,r)}const T4=z({divNoNan_:N4});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1417,7 +1417,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function T4(t,e){const n=T(t,"t1","dot"),s=T(e,"t2","dot");I((n.rank===1||n.rank===2)&&(s.rank===1||s.rank===2),()=>`Error in dot: inputs must all be rank 1 or 2, but got ranks ${n.rank} and ${s.rank}.`);const r=n.rank===1?n.size:n.shape[1],o=s.rank===1?s.size:s.shape[0];if(I(r===o,()=>`Error in dot: inner dimensions of inputs must match, but got ${r} and ${o}.`),n.rank===1&&s.rank===1){const i=F(n,[1,-1]),a=F(s,[-1,1]),l=Ve(i,a);return F(l,[])}else if(n.rank===1&&s.rank===2){const i=F(n,[1,-1]),a=F(s,[s.shape[0],s.shape[1]]),l=Ve(i,a);return F(l,[l.size])}else if(n.rank===2&&s.rank===1){const i=F(s,[-1,1]),a=Ve(n,i);return F(a,[a.size])}else{const i=F(s,[s.shape[0],s.shape[1]]);return Ve(n,i)}}const E4=z({dot_:T4});/** + */function E4(t,e){const n=T(t,"t1","dot"),s=T(e,"t2","dot");I((n.rank===1||n.rank===2)&&(s.rank===1||s.rank===2),()=>`Error in dot: inputs must all be rank 1 or 2, but got ranks ${n.rank} and ${s.rank}.`);const r=n.rank===1?n.size:n.shape[1],o=s.rank===1?s.size:s.shape[0];if(I(r===o,()=>`Error in dot: inner dimensions of inputs must match, but got ${r} and ${o}.`),n.rank===1&&s.rank===1){const i=F(n,[1,-1]),a=F(s,[-1,1]),l=Ve(i,a);return F(l,[])}else if(n.rank===1&&s.rank===2){const i=F(n,[1,-1]),a=F(s,[s.shape[0],s.shape[1]]),l=Ve(i,a);return F(l,[l.size])}else if(n.rank===2&&s.rank===1){const i=F(s,[-1,1]),a=Ve(n,i);return F(a,[a.size])}else{const i=F(s,[s.shape[0],s.shape[1]]);return Ve(n,i)}}const R4=z({dot_:E4});/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1432,7 +1432,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function R4(t,...e){const n=e.map((r,o)=>T(r,`tensors${o}`,"einsum")),s={equation:t};return _.runKernel(ay,n,s)}const Hl=z({einsum_:R4});/** + */function A4(t,...e){const n=e.map((r,o)=>T(r,`tensors${o}`,"einsum")),s={equation:t};return _.runKernel(ay,n,s)}const Hl=z({einsum_:A4});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1447,7 +1447,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function A4(t){const n={x:T(t,"x","elu","float32")};return _.runKernel(Nu,n)}const ym=z({elu_:A4});/** + */function D4(t){const n={x:T(t,"x","elu","float32")};return _.runKernel(Nu,n)}const ym=z({elu_:D4});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1462,7 +1462,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function D4(t){let e=T(t,"x","erf");I(e.dtype==="int32"||e.dtype==="float32",()=>"Input dtype must be `int32` or `float32`."),e.dtype==="int32"&&(e=le(e,"float32"));const n={x:e};return _.runKernel(Tu,n)}const eN=z({erf_:D4});/** + */function _4(t){let e=T(t,"x","erf");I(e.dtype==="int32"||e.dtype==="float32",()=>"Input dtype must be `int32` or `float32`."),e.dtype==="int32"&&(e=le(e,"float32"));const n={x:e};return _.runKernel(Tu,n)}const tN=z({erf_:_4});/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1477,7 +1477,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Vy(t,e){for(let n=0;nt[o]);return[n,r]}function Dt(t,e){const n=e.map(s=>1);return tN(t,n,e)}function sn(t,e,n){I(Vy(e,n),()=>`${t} supports only inner-most axes for now. Got axes ${e} and rank-${n} input.`)}function yt(t,e){if(Vy(t,e))return null;const n=[];for(let s=0;sn.push(s)),n}function Ho(t){return t.map((e,n)=>[n,e]).sort((e,n)=>e[1]-n[1]).map(e=>e[0])}function $t(t,e){const n=[];for(let s=e-t;st[o]);return[n,r]}function Dt(t,e){const n=e.map(s=>1);return nN(t,n,e)}function sn(t,e,n){I(Vy(e,n),()=>`${t} supports only inner-most axes for now. Got axes ${e} and rank-${n} input.`)}function yt(t,e){if(Vy(t,e))return null;const n=[];for(let s=0;sn.push(s)),n}function Ho(t){return t.map((e,n)=>[n,e]).sort((e,n)=>e[1]-n[1]).map(e=>e[0])}function $t(t,e){const n=[];for(let s=e-t;s"Axis must be <= rank of the tensor");const s={input:n},r={dim:e};return _.runKernel(Rp,s,r)}const En=z({expandDims_:U4});/** + */function G4(t,e=0){const n=T(t,"x","expandDims","string_or_numeric");I(e<=n.rank,()=>"Axis must be <= rank of the tensor");const s={input:n},r={dim:e};return _.runKernel(Rp,s,r)}const En=z({expandDims_:G4});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1657,7 +1657,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function G4(t){const n={x:T(t,"x","expm1")};return _.runKernel(Ru,n)}const H4=z({expm1_:G4});/** + */function H4(t){const n={x:T(t,"x","expm1")};return _.runKernel(Ru,n)}const j4=z({expm1_:H4});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1672,7 +1672,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function j4(t,e){const n=T(t,"x","tile","string_or_numeric");I(n.rank===e.length,()=>`Error in transpose: rank of input ${n.rank} must match length of reps ${e}.`);const s={x:n},r={reps:e};return _.runKernel(ad,s,r)}const Gs=z({tile_:j4});/** + */function K4(t,e){const n=T(t,"x","tile","string_or_numeric");I(n.rank===e.length,()=>`Error in transpose: rank of input ${n.rank} must match length of reps ${e}.`);const s={x:n},r={reps:e};return _.runKernel(ah,s,r)}const Hs=z({tile_:K4});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1687,7 +1687,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function K4(t,e,n,s="float32"){e==null&&(e=t);const r=Ee([t,e],s),o=t<=e?t:e;for(let a=0;a`Error in localResponseNormalization: x must be rank 3 or 4 but got - rank ${o.rank}.`),I(nl(e),()=>`Error in localResponseNormalization: depthRadius must be an integer but got depthRadius ${e}.`);let i=o,a=!1;o.rank===3&&(a=!0,i=F(o,[1,o.shape[0],o.shape[1],o.shape[2]]));const l={x:i},c={depthRadius:e,bias:n,alpha:s,beta:r},u=_.runKernel(Bp,l,c);return a?F(u,[u.shape[1],u.shape[2],u.shape[3]]):u}const cB=z({localResponseNormalization_:lB});/** + */function cB(t,e=5,n=1,s=1,r=.5){const o=T(t,"x","localResponseNormalization");I(o.rank===4||o.rank===3,()=>`Error in localResponseNormalization: x must be rank 3 or 4 but got + rank ${o.rank}.`),I(nl(e),()=>`Error in localResponseNormalization: depthRadius must be an integer but got depthRadius ${e}.`);let i=o,a=!1;o.rank===3&&(a=!0,i=F(o,[1,o.shape[0],o.shape[1],o.shape[2]]));const l={x:i},c={depthRadius:e,bias:n,alpha:s,beta:r},u=_.runKernel(Bp,l,c);return a?F(u,[u.shape[1],u.shape[2],u.shape[3]]):u}const uB=z({localResponseNormalization_:cB});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1883,7 +1883,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function uB(t){const n={x:T(t,"x","log","float32")};return _.runKernel(Pu,n)}const Sr=z({log_:uB});/** + */function hB(t){const n={x:T(t,"x","log","float32")};return _.runKernel(Pu,n)}const Ir=z({log_:hB});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1898,7 +1898,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function dB(t){const n={x:T(t,"x","log1p")};return _.runKernel(Lu,n)}const rN=z({log1p_:dB});/** + */function dB(t){const n={x:T(t,"x","log1p")};return _.runKernel(Lu,n)}const oN=z({log1p_:dB});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1913,7 +1913,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function hB(t,e){I(Y0(t),()=>"The f passed in variableGrads(f) must be a function"),I(e==null||Array.isArray(e)&&e.every(c=>c instanceof xf),()=>"The varList passed in variableGrads(f, varList) must be an array of variables");const n=e!=null;if(!n){e=[];for(const c in _.registeredVariables)e.push(_.registeredVariables[c])}const s=n?e.filter(c=>!c.trainable):null,r=e.length;e=e.filter(c=>c.trainable),I(e.length>0,()=>`variableGrads() expects at least one of the input variables to be trainable, but none of the ${r} variables is trainable.`);const o=!0,{value:i,grads:a}=_.gradients(t,e,null,o);I(a.some(c=>c!=null),()=>"Cannot find a connection between any variable and the result of the loss function y=f(x). Please make sure the operations that use variables are inside the function f passed to minimize()."),I(i.rank===0,()=>`The f passed in variableGrads(f) must return a scalar, but it returned a rank-${i.rank} tensor`);const l={};return e.forEach((c,u)=>{a[u]!=null&&(l[c.name]=a[u])}),s!=null&&s.forEach(c=>l[c.name]=null),{value:i,grads:l}}function al(t){return _.customGrad(t)}/** + */function fB(t,e){I(Y0(t),()=>"The f passed in variableGrads(f) must be a function"),I(e==null||Array.isArray(e)&&e.every(c=>c instanceof xf),()=>"The varList passed in variableGrads(f, varList) must be an array of variables");const n=e!=null;if(!n){e=[];for(const c in _.registeredVariables)e.push(_.registeredVariables[c])}const s=n?e.filter(c=>!c.trainable):null,r=e.length;e=e.filter(c=>c.trainable),I(e.length>0,()=>`variableGrads() expects at least one of the input variables to be trainable, but none of the ${r} variables is trainable.`);const o=!0,{value:i,grads:a}=_.gradients(t,e,null,o);I(a.some(c=>c!=null),()=>"Cannot find a connection between any variable and the result of the loss function y=f(x). Please make sure the operations that use variables are inside the function f passed to minimize()."),I(i.rank===0,()=>`The f passed in variableGrads(f) must return a scalar, but it returned a rank-${i.rank} tensor`);const l={};return e.forEach((c,u)=>{a[u]!=null&&(l[c.name]=a[u])}),s!=null&&s.forEach(c=>l[c.name]=null),{value:i,grads:l}}function al(t){return _.customGrad(t)}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1928,7 +1928,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function fB(t){const n={x:T(t,"x","neg")};return _.runKernel(Kp,n)}const St=z({neg_:fB});/** + */function pB(t){const n={x:T(t,"x","neg")};return _.runKernel(Kp,n)}const St=z({neg_:pB});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1943,7 +1943,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function pB(t){const n={x:T(t,"x","softplus")};return _.runKernel(td,n)}const hd=z({softplus_:pB});/** + */function mB(t){const n={x:T(t,"x","softplus")};return _.runKernel(th,n)}const dh=z({softplus_:mB});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1958,7 +1958,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function mB(t){const e=T(t,"x","logSigmoid");return al(s=>({value:St(hd(St(s))),gradFunc:i=>D(i,Cl(St(s)))}))(e)}const gB=z({logSigmoid_:mB});/** + */function gB(t){const e=T(t,"x","logSigmoid");return al(s=>({value:St(dh(St(s))),gradFunc:i=>D(i,Cl(St(s)))}))(e)}const xB=z({logSigmoid_:gB});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1973,7 +1973,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function xB(t,e){let n=T(t,"a","sub"),s=T(e,"b","sub");[n,s]=It(n,s);const r={a:n,b:s};return _.runKernel(rd,r)}const ve=z({sub_:xB});/** + */function yB(t,e){let n=T(t,"a","sub"),s=T(e,"b","sub");[n,s]=It(n,s);const r={a:n,b:s};return _.runKernel(rh,r)}const ve=z({sub_:yB});/** * @license * Copyright 2020 Google Inc. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -1988,7 +1988,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function yB(t,e=-1){const n=T(t,"logits","logSoftmax");if(e===-1&&(e=n.rank-1),e!==n.rank-1)throw Error(`Log Softmax along a non-last dimension is not yet supported. Logits was rank ${n.rank} and axis was ${e}`);return al((r,o)=>{const a=qs(r,e,!0),l=ve(r,a),c=ve(le(l,"float32"),Sr(me(kr(l),e,!0)));return o([c]),{value:c,gradFunc:(d,h)=>{const[f]=h,p=!0,g=kr(f);return ve(d,D(me(d,e,p),g))}}})(n)}const oN=z({logSoftmax_:yB});/** + */function wB(t,e=-1){const n=T(t,"logits","logSoftmax");if(e===-1&&(e=n.rank-1),e!==n.rank-1)throw Error(`Log Softmax along a non-last dimension is not yet supported. Logits was rank ${n.rank} and axis was ${e}`);return al((r,o)=>{const a=Ys(r,e,!0),l=ve(r,a),c=ve(le(l,"float32"),Ir(me(Sr(l),e,!0)));return o([c]),{value:c,gradFunc:(h,d)=>{const[f]=d,p=!0,g=Sr(f);return ve(h,D(me(h,e,p),g))}}})(n)}const iN=z({logSoftmax_:wB});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2003,7 +2003,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function wB(t,e=null,n=!1){const s=T(t,"x","logSumExp"),r=Re(e,s.shape),o=qs(s,r,!0),i=ve(s,o),a=kr(i),l=me(a,r),c=Sr(l),u=J(F(o,c.shape),c);if(n){const d=Dt(u.shape,r);return F(u,d)}return u}const iN=z({logSumExp_:wB});/** + */function vB(t,e=null,n=!1){const s=T(t,"x","logSumExp"),r=Re(e,s.shape),o=Ys(s,r,!0),i=ve(s,o),a=Sr(i),l=me(a,r),c=Ir(l),u=J(F(o,c.shape),c);if(n){const h=Dt(u.shape,r);return F(u,h)}return u}const aN=z({logSumExp_:vB});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2018,7 +2018,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function vB(t,e){const n=T(t,"a","logicalAnd","bool"),s=T(e,"b","logicalAnd","bool");Se(n.shape,s.shape);const r={a:n,b:s};return _.runKernel(Mp,r)}const Ur=z({logicalAnd_:vB});/** + */function bB(t,e){const n=T(t,"a","logicalAnd","bool"),s=T(e,"b","logicalAnd","bool");Se(n.shape,s.shape);const r={a:n,b:s};return _.runKernel(Mp,r)}const Gr=z({logicalAnd_:bB});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2033,7 +2033,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function bB(t){const n={x:T(t,"x","logicalNot","bool")};return _.runKernel(Pp,n)}const Hy=z({logicalNot_:bB});/** + */function CB(t){const n={x:T(t,"x","logicalNot","bool")};return _.runKernel(Pp,n)}const Hy=z({logicalNot_:CB});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2048,7 +2048,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function CB(t,e){const n=T(t,"a","logicalOr","bool"),s=T(e,"b","logicalOr","bool");Se(n.shape,s.shape);const r={a:n,b:s};return _.runKernel(Lp,r)}const aN=z({logicalOr_:CB});/** + */function kB(t,e){const n=T(t,"a","logicalOr","bool"),s=T(e,"b","logicalOr","bool");Se(n.shape,s.shape);const r={a:n,b:s};return _.runKernel(Lp,r)}const lN=z({logicalOr_:kB});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2063,7 +2063,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function kB(t,e){const n=T(t,"a","logicalXor","bool"),s=T(e,"b","logicalXor","bool");return Se(n.shape,s.shape),Ur(aN(t,e),Hy(Ur(t,e)))}const SB=z({logicalXor_:kB});/** + */function SB(t,e){const n=T(t,"a","logicalXor","bool"),s=T(e,"b","logicalXor","bool");return Se(n.shape,s.shape),Gr(lN(t,e),Hy(Gr(t,e)))}const IB=z({logicalXor_:SB});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2078,7 +2078,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function IB(t,e,n,s,r){const o=T(t,"x","maxPool"),i=1;let a=o,l=!1;o.rank===3&&(l=!0,a=F(o,[1,o.shape[0],o.shape[1],o.shape[2]])),I(a.rank===4,()=>`Error in maxPool: input must be rank 4 but got rank ${a.rank}.`),I(hn(n,i),()=>`Error in maxPool: Either strides or dilations must be 1. Got strides ${n} and dilations '${i}'`),Mn("maxPool",s,r);const c={x:a},u={filterSize:e,strides:n,pad:s,dimRoundingMode:r},d=_.runKernel(Wp,c,u);return l?F(d,[d.shape[1],d.shape[2],d.shape[3]]):d}const jy=z({maxPool_:IB});/** + */function $B(t,e,n,s,r){const o=T(t,"x","maxPool"),i=1;let a=o,l=!1;o.rank===3&&(l=!0,a=F(o,[1,o.shape[0],o.shape[1],o.shape[2]])),I(a.rank===4,()=>`Error in maxPool: input must be rank 4 but got rank ${a.rank}.`),I(dn(n,i),()=>`Error in maxPool: Either strides or dilations must be 1. Got strides ${n} and dilations '${i}'`),Mn("maxPool",s,r);const c={x:a},u={filterSize:e,strides:n,pad:s,dimRoundingMode:r},h=_.runKernel(Wp,c,u);return l?F(h,[h.shape[1],h.shape[2],h.shape[3]]):h}const jy=z({maxPool_:$B});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2093,7 +2093,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function $B(t,e=[1,1,1],n,s,r,o="NDHWC"){const i=T(t,"x","maxPool3d");let a=i,l=!1;i.rank===4&&(l=!0,a=F(i,[1,i.shape[0],i.shape[1],i.shape[2],i.shape[3]])),I(a.rank===5,()=>`Error in maxPool3d: x must be rank 5 but got rank ${a.rank}.`),I(o==="NDHWC",()=>`Error in maxPool3d: Only NDHWC is currently supported, but got dataFormat of ${o}`),Mn("maxPool3d",s,r);const c={x:a},u={filterSize:e,strides:n,pad:s,dimRoundingMode:r,dataFormat:o},d=_.runKernel(Up,c,u);return l?F(d,[d.shape[1],d.shape[2],d.shape[3],d.shape[4]]):d}const NB=z({maxPool3d_:$B});/** + */function NB(t,e=[1,1,1],n,s,r,o="NDHWC"){const i=T(t,"x","maxPool3d");let a=i,l=!1;i.rank===4&&(l=!0,a=F(i,[1,i.shape[0],i.shape[1],i.shape[2],i.shape[3]])),I(a.rank===5,()=>`Error in maxPool3d: x must be rank 5 but got rank ${a.rank}.`),I(o==="NDHWC",()=>`Error in maxPool3d: Only NDHWC is currently supported, but got dataFormat of ${o}`),Mn("maxPool3d",s,r);const c={x:a},u={filterSize:e,strides:n,pad:s,dimRoundingMode:r,dataFormat:o},h=_.runKernel(Up,c,u);return l?F(h,[h.shape[1],h.shape[2],h.shape[3],h.shape[4]]):h}const TB=z({maxPool3d_:NB});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2108,7 +2108,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function TB(t,e){let n=T(t,"a","maximum"),s=T(e,"b","maximum");[n,s]=It(n,s),n.dtype==="bool"&&(n=le(n,"int32"),s=le(s,"int32")),Se(n.shape,s.shape);const r={a:n,b:s};return _.runKernel(Bu,r)}const jo=z({maximum_:TB});/** + */function EB(t,e){let n=T(t,"a","maximum"),s=T(e,"b","maximum");[n,s]=It(n,s),n.dtype==="bool"&&(n=le(n,"int32"),s=le(s,"int32")),Se(n.shape,s.shape);const r={a:n,b:s};return _.runKernel(Bu,r)}const jo=z({maximum_:EB});/** * @license * Copyright 2020 Google Inc. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2123,7 +2123,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function EB(t,e=null,n=!1){const r={x:T(t,"x","mean")},o={axis:e,keepDims:n};return _.runKernel(Gp,r,o)}const Rt=z({mean_:EB});/** + */function RB(t,e=null,n=!1){const r={x:T(t,"x","mean")},o={axis:e,keepDims:n};return _.runKernel(Gp,r,o)}const Rt=z({mean_:RB});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2138,7 +2138,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Kt(t,e="float32"){if(Xr(t),e==="complex64"){const s=Kt(t,"float32"),r=Kt(t,"float32");return Ri(s,r)}const n=un(j(t),e);return _.makeTensor(n,t,e)}/** + */function Kt(t,e="float32"){if(qr(t),e==="complex64"){const s=Kt(t,"float32"),r=Kt(t,"float32");return Ri(s,r)}const n=un(j(t),e);return _.makeTensor(n,t,e)}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2153,7 +2153,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Ko(t,e="float32"){if(Xr(t),e==="complex64"){const s=Ko(t,"float32"),r=Kt(t,"float32");return Ri(s,r)}const n=Vx(j(t),e);return _.makeTensor(n,t,e)}/** + */function Ko(t,e="float32"){if(qr(t),e==="complex64"){const s=Ko(t,"float32"),r=Kt(t,"float32");return Ri(s,r)}const n=Vx(j(t),e);return _.makeTensor(n,t,e)}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2168,7 +2168,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function RB(t,e){let n=T(t,"a","minimum"),s=T(e,"b","minimum");[n,s]=It(n,s),n.dtype==="bool"&&(n=le(n,"int32"),s=le(s,"int32")),Se(n.shape,s.shape);const r={a:n,b:s};return _.runKernel(Vu,r)}const Xc=z({minimum_:RB});/** + */function AB(t,e){let n=T(t,"a","minimum"),s=T(e,"b","minimum");[n,s]=It(n,s),n.dtype==="bool"&&(n=le(n,"int32"),s=le(s,"int32")),Se(n.shape,s.shape);const r={a:n,b:s};return _.runKernel(Vu,r)}const Xc=z({minimum_:AB});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2183,7 +2183,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function AB(t,e,n){I(n==="reflect"||n==="symmetric",()=>`Invalid mode. Mode must be either reflect or symmetric. Got ${n}.`);const s=T(t,"x","mirrorPad");if(s.rank===0)throw new Error("mirrorPad(scalar) is not defined. Pass non-scalar to mirrorPad");I(e.length===s.rank,()=>`Padding doesn't match input. Must be ${s.rank}. Got ${e.length}.`);const r=n==="reflect"?1:0;for(let a=0;a"Invalid number of paddings. Must be length of 2 each."),I(e[a][0]>=0&&e[a][0]<=s.shape[a]-r&&e[a][1]>=0&&e[a][1]<=s.shape[a]-r,()=>`Padding in dimension ${a} cannot be greater than or equal to ${s.shape[a]-r} or less than 0 for input of shape ${s.shape}`);const o={paddings:e,mode:n},i={x:s};return _.runKernel(jp,i,o)}const DB=z({mirrorPad_:AB});/** + */function DB(t,e,n){I(n==="reflect"||n==="symmetric",()=>`Invalid mode. Mode must be either reflect or symmetric. Got ${n}.`);const s=T(t,"x","mirrorPad");if(s.rank===0)throw new Error("mirrorPad(scalar) is not defined. Pass non-scalar to mirrorPad");I(e.length===s.rank,()=>`Padding doesn't match input. Must be ${s.rank}. Got ${e.length}.`);const r=n==="reflect"?1:0;for(let a=0;a"Invalid number of paddings. Must be length of 2 each."),I(e[a][0]>=0&&e[a][0]<=s.shape[a]-r&&e[a][1]>=0&&e[a][1]<=s.shape[a]-r,()=>`Padding in dimension ${a} cannot be greater than or equal to ${s.shape[a]-r} or less than 0 for input of shape ${s.shape}`);const o={paddings:e,mode:n},i={x:s};return _.runKernel(jp,i,o)}const _B=z({mirrorPad_:DB});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2198,7 +2198,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function _B(t,e){let n=T(t,"a","mod"),s=T(e,"b","mod");[n,s]=It(n,s);const r={a:n,b:s};return _.runKernel(Wu,r)}const FB=z({mod_:_B});/** + */function FB(t,e){let n=T(t,"a","mod"),s=T(e,"b","mod");[n,s]=It(n,s);const r={a:n,b:s};return _.runKernel(Wu,r)}const zB=z({mod_:FB});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2213,7 +2213,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function zB(t,e=null,n=!1){t=T(t,"x","moments");const s=Re(e,t.shape),r=Rt(t,s,n);let o=r.shape;n||(o=Dt(r.shape,s));const i=ot(ve(le(t,"float32"),F(r,o))),a=Rt(i,s,n);return{mean:r,variance:a}}const Ky=z({moments_:zB});/** + */function OB(t,e=null,n=!1){t=T(t,"x","moments");const s=Re(e,t.shape),r=Rt(t,s,n);let o=r.shape;n||(o=Dt(r.shape,s));const i=ot(ve(le(t,"float32"),F(r,o))),a=Rt(i,s,n);return{mean:r,variance:a}}const Ky=z({moments_:OB});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2228,7 +2228,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function OB(t,e){let n=T(t,"a","notEqual","string_or_numeric"),s=T(e,"b","notEqual","string_or_numeric");[n,s]=It(n,s),Se(n.shape,s.shape);const r={a:n,b:s};return _.runKernel(Xp,r)}const bf=z({notEqual_:OB});/** + */function MB(t,e){let n=T(t,"a","notEqual","string_or_numeric"),s=T(e,"b","notEqual","string_or_numeric");[n,s]=It(n,s),Se(n.shape,s.shape);const r={a:n,b:s};return _.runKernel(Xp,r)}const bf=z({notEqual_:MB});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2243,7 +2243,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function MB(t,e,n=1,s=0,r="int32"){if(e<2)throw new Error(`Error in oneHot: depth must be >=2, but it is ${e}`);const i={indices:T(t,"indices","oneHot","int32")},a={dtype:r,depth:e,onValue:n,offValue:s};return _.runKernel(Yp,i,a)}const lN=z({oneHot_:MB});/** + */function PB(t,e,n=1,s=0,r="int32"){if(e<2)throw new Error(`Error in oneHot: depth must be >=2, but it is ${e}`);const i={indices:T(t,"indices","oneHot","int32")},a={dtype:r,depth:e,onValue:n,offValue:s};return _.runKernel(Yp,i,a)}const cN=z({oneHot_:PB});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2258,7 +2258,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function PB(t){const n={x:T(t,"x","onesLike")};return _.runKernel(qp,n)}const Es=z({onesLike_:PB});/** + */function LB(t){const n={x:T(t,"x","onesLike")};return _.runKernel(qp,n)}const Rs=z({onesLike_:LB});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2273,7 +2273,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function LB(t,e,n=0){const s=T(t,"x","pad");if(s.rank===0)throw new Error("pad(scalar) is not defined. Pass non-scalar to pad");const r={paddings:e,constantValue:n},o={x:s};return _.runKernel(Zp,o,r)}const Xy=z({pad_:LB});/** + */function BB(t,e,n=0){const s=T(t,"x","pad");if(s.rank===0)throw new Error("pad(scalar) is not defined. Pass non-scalar to pad");const r={paddings:e,constantValue:n},o={x:s};return _.runKernel(Zp,o,r)}const Xy=z({pad_:BB});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2288,7 +2288,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function BB(t,e,n){const s=T(t,"x","spaceToBatchND");I(s.rank>=1+e.length,()=>`input rank ${s.rank} should be > than [blockShape] ${e.length}`),I(n.length===e.length,()=>`paddings.shape[0] ${n.length} must be equal to [blockShape] ${e.length}`),I(s.shape.reduce((i,a,l)=>l>0&&l<=e.length?i&&(a+n[l-1][0]+n[l-1][1])%e[l-1]===0:i,!0),()=>`input spatial dimensions ${s.shape.slice(1)} with paddings ${n.toString()} must be divisible by blockShapes ${e.toString()}`);const r={x:s},o={blockShape:e,paddings:n};return _.runKernel(lm,r,o)}const qy=z({spaceToBatchND_:BB});/** + */function VB(t,e,n){const s=T(t,"x","spaceToBatchND");I(s.rank>=1+e.length,()=>`input rank ${s.rank} should be > than [blockShape] ${e.length}`),I(n.length===e.length,()=>`paddings.shape[0] ${n.length} must be equal to [blockShape] ${e.length}`),I(s.shape.reduce((i,a,l)=>l>0&&l<=e.length?i&&(a+n[l-1][0]+n[l-1][1])%e[l-1]===0:i,!0),()=>`input spatial dimensions ${s.shape.slice(1)} with paddings ${n.toString()} must be divisible by blockShapes ${e.toString()}`);const r={x:s},o={blockShape:e,paddings:n};return _.runKernel(lm,r,o)}const qy=z({spaceToBatchND_:VB});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2303,7 +2303,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function VB(t,e,n,s,r,o,i){r==null&&(r=[1,1]),o==null&&(o=1),s===0&&(s="valid");const a=T(t,"x","maxPool");let l=a,c=!1;a.rank===3&&(c=!0,l=F(a,[1,a.shape[0],a.shape[1],a.shape[2]])),I(hn(o,r),()=>`Error in pool: Either strides or dilations must be 1. Got strides ${o} and dilations '${r}'`);const u=Rs(l.shape,e,o,r,s),d=[u.dilationHeight,u.dilationWidth];let h;s==="same"?h=UB([u.filterHeight,u.filterWidth],d):h=[[0,0],[0,0]];const f=d[0]===1&&d[1]===1,[p,g]=WB([u.inHeight,u.inWidth],d,h),x=f?s:"valid",m=f?l:qy(l,d,p),w=(n==="avg"?()=>Oy(m,e,o,x,i):()=>jy(m,e,o,x,i))(),v=f?w:My(w,d,g);return c?F(v,[v.shape[1],v.shape[2],v.shape[3]]):v}function WB(t,e,n){const s=n.map(u=>u[0]),r=n.map(u=>u[1]),o=t.concat(s,r),i=e.map((u,d)=>(u-o[d]%u)%u),a=r.map((u,d)=>u+i[d]),l=e.map((u,d)=>[s[d],a[d]]),c=e.map((u,d)=>[0,i[d]]);return[l,c]}function UB(t,e){const s=t.map((i,a)=>i+(i-1)*(e[a]-1)).map(i=>i-1),r=s.map(i=>Math.floor(i/2)),o=s.map((i,a)=>i-r[a]);return s.map((i,a)=>[r[a],o[a]])}const GB=z({pool_:VB});/** + */function WB(t,e,n,s,r,o,i){r==null&&(r=[1,1]),o==null&&(o=1),s===0&&(s="valid");const a=T(t,"x","maxPool");let l=a,c=!1;a.rank===3&&(c=!0,l=F(a,[1,a.shape[0],a.shape[1],a.shape[2]])),I(dn(o,r),()=>`Error in pool: Either strides or dilations must be 1. Got strides ${o} and dilations '${r}'`);const u=As(l.shape,e,o,r,s),h=[u.dilationHeight,u.dilationWidth];let d;s==="same"?d=GB([u.filterHeight,u.filterWidth],h):d=[[0,0],[0,0]];const f=h[0]===1&&h[1]===1,[p,g]=UB([u.inHeight,u.inWidth],h,d),x=f?s:"valid",m=f?l:qy(l,h,p),w=(n==="avg"?()=>Oy(m,e,o,x,i):()=>jy(m,e,o,x,i))(),v=f?w:My(w,h,g);return c?F(v,[v.shape[1],v.shape[2],v.shape[3]]):v}function UB(t,e,n){const s=n.map(u=>u[0]),r=n.map(u=>u[1]),o=t.concat(s,r),i=e.map((u,h)=>(u-o[h]%u)%u),a=r.map((u,h)=>u+i[h]),l=e.map((u,h)=>[s[h],a[h]]),c=e.map((u,h)=>[0,i[h]]);return[l,c]}function GB(t,e){const s=t.map((i,a)=>i+(i-1)*(e[a]-1)).map(i=>i-1),r=s.map(i=>Math.floor(i/2)),o=s.map((i,a)=>i-r[a]);return s.map((i,a)=>[r[a],o[a]])}const HB=z({pool_:WB});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2318,7 +2318,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function HB(t,e){const n=T(t,"x","prelu"),s=T(e,"alpha","prelu"),r={x:n,alpha:s};return _.runKernel(Jp,r)}const Yy=z({prelu_:HB});/** + */function jB(t,e){const n=T(t,"x","prelu"),s=T(e,"alpha","prelu"),r={x:n,alpha:s};return _.runKernel(Jp,r)}const Yy=z({prelu_:jB});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2333,7 +2333,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function jB(t,e=null,n=!1){let s=T(t,"x","prod");s.dtype==="bool"&&(s=le(s,"int32"));const r={x:s},o={axis:e,keepDims:n};return _.runKernel(em,r,o)}const KB=z({prod_:jB});var Qy={exports:{}};Qy.exports;(function(t){(function(e,n,s){function r(l){var c=this,u=a();c.next=function(){var d=2091639*c.s0+c.c*23283064365386963e-26;return c.s0=c.s1,c.s1=c.s2,c.s2=d-(c.c=d|0)},c.c=1,c.s0=u(" "),c.s1=u(" "),c.s2=u(" "),c.s0-=u(l),c.s0<0&&(c.s0+=1),c.s1-=u(l),c.s1<0&&(c.s1+=1),c.s2-=u(l),c.s2<0&&(c.s2+=1),u=null}function o(l,c){return c.c=l.c,c.s0=l.s0,c.s1=l.s1,c.s2=l.s2,c}function i(l,c){var u=new r(l),d=c&&c.state,h=u.next;return h.int32=function(){return u.next()*4294967296|0},h.double=function(){return h()+(h()*2097152|0)*11102230246251565e-32},h.quick=h,d&&(typeof d=="object"&&o(d,u),h.state=function(){return o(u,{})}),h}function a(){var l=4022871197,c=function(u){u=String(u);for(var d=0;d>>0,h-=l,h*=l,l=h>>>0,h-=l,l+=h*4294967296}return(l>>>0)*23283064365386963e-26};return c}n&&n.exports?n.exports=i:this.alea=i})(Ui,t)})(Qy);var XB=Qy.exports,Zy={exports:{}};Zy.exports;(function(t){(function(e,n,s){function r(a){var l=this,c="";l.x=0,l.y=0,l.z=0,l.w=0,l.next=function(){var d=l.x^l.x<<11;return l.x=l.y,l.y=l.z,l.z=l.w,l.w^=l.w>>>19^d^d>>>8},a===(a|0)?l.x=a:c+=a;for(var u=0;u>>0)/4294967296};return d.double=function(){do var h=c.next()>>>11,f=(c.next()>>>0)/4294967296,p=(h+f)/(1<<21);while(p===0);return p},d.int32=c.next,d.quick=d,u&&(typeof u=="object"&&o(u,c),d.state=function(){return o(c,{})}),d}n&&n.exports?n.exports=i:this.xor128=i})(Ui,t)})(Zy);var qB=Zy.exports,Jy={exports:{}};Jy.exports;(function(t){(function(e,n,s){function r(a){var l=this,c="";l.next=function(){var d=l.x^l.x>>>2;return l.x=l.y,l.y=l.z,l.z=l.w,l.w=l.v,(l.d=l.d+362437|0)+(l.v=l.v^l.v<<4^(d^d<<1))|0},l.x=0,l.y=0,l.z=0,l.w=0,l.v=0,a===(a|0)?l.x=a:c+=a;for(var u=0;u>>4),l.next()}function o(a,l){return l.x=a.x,l.y=a.y,l.z=a.z,l.w=a.w,l.v=a.v,l.d=a.d,l}function i(a,l){var c=new r(a),u=l&&l.state,d=function(){return(c.next()>>>0)/4294967296};return d.double=function(){do var h=c.next()>>>11,f=(c.next()>>>0)/4294967296,p=(h+f)/(1<<21);while(p===0);return p},d.int32=c.next,d.quick=d,u&&(typeof u=="object"&&o(u,c),d.state=function(){return o(c,{})}),d}n&&n.exports?n.exports=i:this.xorwow=i})(Ui,t)})(Jy);var YB=Jy.exports,ew={exports:{}};ew.exports;(function(t){(function(e,n,s){function r(a){var l=this;l.next=function(){var u=l.x,d=l.i,h,f;return h=u[d],h^=h>>>7,f=h^h<<24,h=u[d+1&7],f^=h^h>>>10,h=u[d+3&7],f^=h^h>>>3,h=u[d+4&7],f^=h^h<<7,h=u[d+7&7],h=h^h<<13,f^=h^h<<9,u[d]=f,l.i=d+1&7,f};function c(u,d){var h,f=[];if(d===(d|0))f[0]=d;else for(d=""+d,h=0;h0;--h)u.next()}c(l,a)}function o(a,l){return l.x=a.x.slice(),l.i=a.i,l}function i(a,l){a==null&&(a=+new Date);var c=new r(a),u=l&&l.state,d=function(){return(c.next()>>>0)/4294967296};return d.double=function(){do var h=c.next()>>>11,f=(c.next()>>>0)/4294967296,p=(h+f)/(1<<21);while(p===0);return p},d.int32=c.next,d.quick=d,u&&(u.x&&o(u,c),d.state=function(){return o(c,{})}),d}n&&n.exports?n.exports=i:this.xorshift7=i})(Ui,t)})(ew);var QB=ew.exports,tw={exports:{}};tw.exports;(function(t){(function(e,n,s){function r(a){var l=this;l.next=function(){var u=l.w,d=l.X,h=l.i,f,p;return l.w=u=u+1640531527|0,p=d[h+34&127],f=d[h=h+1&127],p^=p<<13,f^=f<<17,p^=p>>>15,f^=f>>>12,p=d[h]=p^f,l.i=h,p+(u^u>>>16)|0};function c(u,d){var h,f,p,g,x,m=[],y=128;for(d===(d|0)?(f=d,d=null):(d=d+"\0",f=0,y=Math.max(y,d.length)),p=0,g=-32;g>>15,f^=f<<4,f^=f>>>13,g>=0&&(x=x+1640531527|0,h=m[g&127]^=f+x,p=h==0?p+1:0);for(p>=128&&(m[(d&&d.length||0)&127]=-1),p=127,g=4*128;g>0;--g)f=m[p+34&127],h=m[p=p+1&127],f^=f<<13,h^=h<<17,f^=f>>>15,h^=h>>>12,m[p]=f^h;u.w=x,u.X=m,u.i=p}c(l,a)}function o(a,l){return l.i=a.i,l.w=a.w,l.X=a.X.slice(),l}function i(a,l){a==null&&(a=+new Date);var c=new r(a),u=l&&l.state,d=function(){return(c.next()>>>0)/4294967296};return d.double=function(){do var h=c.next()>>>11,f=(c.next()>>>0)/4294967296,p=(h+f)/(1<<21);while(p===0);return p},d.int32=c.next,d.quick=d,u&&(u.X&&o(u,c),d.state=function(){return o(c,{})}),d}n&&n.exports?n.exports=i:this.xor4096=i})(Ui,t)})(tw);var ZB=tw.exports,nw={exports:{}};nw.exports;(function(t){(function(e,n,s){function r(a){var l=this,c="";l.next=function(){var d=l.b,h=l.c,f=l.d,p=l.a;return d=d<<25^d>>>7^h,h=h-f|0,f=f<<24^f>>>8^p,p=p-d|0,l.b=d=d<<20^d>>>12^h,l.c=h=h-f|0,l.d=f<<16^h>>>16^p,l.a=p-d|0},l.a=0,l.b=0,l.c=-1640531527,l.d=1367130551,a===Math.floor(a)?(l.a=a/4294967296|0,l.b=a|0):c+=a;for(var u=0;u>>0)/4294967296};return d.double=function(){do var h=c.next()>>>11,f=(c.next()>>>0)/4294967296,p=(h+f)/(1<<21);while(p===0);return p},d.int32=c.next,d.quick=d,u&&(typeof u=="object"&&o(u,c),d.state=function(){return o(c,{})}),d}n&&n.exports?n.exports=i:this.tychei=i})(Ui,t)})(nw);var JB=nw.exports,cN={exports:{}};const eV={},tV=Object.freeze(Object.defineProperty({__proto__:null,default:eV},Symbol.toStringTag,{value:"Module"})),nV=qD(tV);(function(t){(function(e,n,s){var r=256,o=6,i=52,a="random",l=s.pow(r,o),c=s.pow(2,i),u=c*2,d=r-1,h;function f(v,b,C){var k=[];b=b==!0?{entropy:!0}:b||{};var S=m(x(b.entropy?[v,w(n)]:v??y(),3),k),$=new p(k),N=function(){for(var A=$.g(o),M=l,L=0;A=u;)A/=2,M/=2,L>>>=1;return(A+L)/M};return N.int32=function(){return $.g(4)|0},N.quick=function(){return $.g(4)/4294967296},N.double=N,m(w($.S),n),(b.pass||C||function(A,M,L,V){return V&&(V.S&&g(V,$),A.state=function(){return g($,{})}),L?(s[a]=A,M):A})(N,S,"global"in b?b.global:this==s,b.state)}function p(v){var b,C=v.length,k=this,S=0,$=k.i=k.j=0,N=k.S=[];for(C||(v=[C++]);S>>0,d-=l,d*=l,l=d>>>0,d-=l,l+=d*4294967296}return(l>>>0)*23283064365386963e-26};return c}n&&n.exports?n.exports=i:this.alea=i})(Ui,t)})(Qy);var qB=Qy.exports,Zy={exports:{}};Zy.exports;(function(t){(function(e,n,s){function r(a){var l=this,c="";l.x=0,l.y=0,l.z=0,l.w=0,l.next=function(){var h=l.x^l.x<<11;return l.x=l.y,l.y=l.z,l.z=l.w,l.w^=l.w>>>19^h^h>>>8},a===(a|0)?l.x=a:c+=a;for(var u=0;u>>0)/4294967296};return h.double=function(){do var d=c.next()>>>11,f=(c.next()>>>0)/4294967296,p=(d+f)/(1<<21);while(p===0);return p},h.int32=c.next,h.quick=h,u&&(typeof u=="object"&&o(u,c),h.state=function(){return o(c,{})}),h}n&&n.exports?n.exports=i:this.xor128=i})(Ui,t)})(Zy);var YB=Zy.exports,Jy={exports:{}};Jy.exports;(function(t){(function(e,n,s){function r(a){var l=this,c="";l.next=function(){var h=l.x^l.x>>>2;return l.x=l.y,l.y=l.z,l.z=l.w,l.w=l.v,(l.d=l.d+362437|0)+(l.v=l.v^l.v<<4^(h^h<<1))|0},l.x=0,l.y=0,l.z=0,l.w=0,l.v=0,a===(a|0)?l.x=a:c+=a;for(var u=0;u>>4),l.next()}function o(a,l){return l.x=a.x,l.y=a.y,l.z=a.z,l.w=a.w,l.v=a.v,l.d=a.d,l}function i(a,l){var c=new r(a),u=l&&l.state,h=function(){return(c.next()>>>0)/4294967296};return h.double=function(){do var d=c.next()>>>11,f=(c.next()>>>0)/4294967296,p=(d+f)/(1<<21);while(p===0);return p},h.int32=c.next,h.quick=h,u&&(typeof u=="object"&&o(u,c),h.state=function(){return o(c,{})}),h}n&&n.exports?n.exports=i:this.xorwow=i})(Ui,t)})(Jy);var QB=Jy.exports,ew={exports:{}};ew.exports;(function(t){(function(e,n,s){function r(a){var l=this;l.next=function(){var u=l.x,h=l.i,d,f;return d=u[h],d^=d>>>7,f=d^d<<24,d=u[h+1&7],f^=d^d>>>10,d=u[h+3&7],f^=d^d>>>3,d=u[h+4&7],f^=d^d<<7,d=u[h+7&7],d=d^d<<13,f^=d^d<<9,u[h]=f,l.i=h+1&7,f};function c(u,h){var d,f=[];if(h===(h|0))f[0]=h;else for(h=""+h,d=0;d0;--d)u.next()}c(l,a)}function o(a,l){return l.x=a.x.slice(),l.i=a.i,l}function i(a,l){a==null&&(a=+new Date);var c=new r(a),u=l&&l.state,h=function(){return(c.next()>>>0)/4294967296};return h.double=function(){do var d=c.next()>>>11,f=(c.next()>>>0)/4294967296,p=(d+f)/(1<<21);while(p===0);return p},h.int32=c.next,h.quick=h,u&&(u.x&&o(u,c),h.state=function(){return o(c,{})}),h}n&&n.exports?n.exports=i:this.xorshift7=i})(Ui,t)})(ew);var ZB=ew.exports,tw={exports:{}};tw.exports;(function(t){(function(e,n,s){function r(a){var l=this;l.next=function(){var u=l.w,h=l.X,d=l.i,f,p;return l.w=u=u+1640531527|0,p=h[d+34&127],f=h[d=d+1&127],p^=p<<13,f^=f<<17,p^=p>>>15,f^=f>>>12,p=h[d]=p^f,l.i=d,p+(u^u>>>16)|0};function c(u,h){var d,f,p,g,x,m=[],y=128;for(h===(h|0)?(f=h,h=null):(h=h+"\0",f=0,y=Math.max(y,h.length)),p=0,g=-32;g>>15,f^=f<<4,f^=f>>>13,g>=0&&(x=x+1640531527|0,d=m[g&127]^=f+x,p=d==0?p+1:0);for(p>=128&&(m[(h&&h.length||0)&127]=-1),p=127,g=4*128;g>0;--g)f=m[p+34&127],d=m[p=p+1&127],f^=f<<13,d^=d<<17,f^=f>>>15,d^=d>>>12,m[p]=f^d;u.w=x,u.X=m,u.i=p}c(l,a)}function o(a,l){return l.i=a.i,l.w=a.w,l.X=a.X.slice(),l}function i(a,l){a==null&&(a=+new Date);var c=new r(a),u=l&&l.state,h=function(){return(c.next()>>>0)/4294967296};return h.double=function(){do var d=c.next()>>>11,f=(c.next()>>>0)/4294967296,p=(d+f)/(1<<21);while(p===0);return p},h.int32=c.next,h.quick=h,u&&(u.X&&o(u,c),h.state=function(){return o(c,{})}),h}n&&n.exports?n.exports=i:this.xor4096=i})(Ui,t)})(tw);var JB=tw.exports,nw={exports:{}};nw.exports;(function(t){(function(e,n,s){function r(a){var l=this,c="";l.next=function(){var h=l.b,d=l.c,f=l.d,p=l.a;return h=h<<25^h>>>7^d,d=d-f|0,f=f<<24^f>>>8^p,p=p-h|0,l.b=h=h<<20^h>>>12^d,l.c=d=d-f|0,l.d=f<<16^d>>>16^p,l.a=p-h|0},l.a=0,l.b=0,l.c=-1640531527,l.d=1367130551,a===Math.floor(a)?(l.a=a/4294967296|0,l.b=a|0):c+=a;for(var u=0;u>>0)/4294967296};return h.double=function(){do var d=c.next()>>>11,f=(c.next()>>>0)/4294967296,p=(d+f)/(1<<21);while(p===0);return p},h.int32=c.next,h.quick=h,u&&(typeof u=="object"&&o(u,c),h.state=function(){return o(c,{})}),h}n&&n.exports?n.exports=i:this.tychei=i})(Ui,t)})(nw);var eV=nw.exports,uN={exports:{}};const tV={},nV=Object.freeze(Object.defineProperty({__proto__:null,default:tV},Symbol.toStringTag,{value:"Module"})),sV=YD(nV);(function(t){(function(e,n,s){var r=256,o=6,i=52,a="random",l=s.pow(r,o),c=s.pow(2,i),u=c*2,h=r-1,d;function f(v,b,C){var k=[];b=b==!0?{entropy:!0}:b||{};var S=m(x(b.entropy?[v,w(n)]:v??y(),3),k),$=new p(k),N=function(){for(var A=$.g(o),M=l,L=0;A=u;)A/=2,M/=2,L>>>=1;return(A+L)/M};return N.int32=function(){return $.g(4)|0},N.quick=function(){return $.g(4)/4294967296},N.double=N,m(w($.S),n),(b.pass||C||function(A,M,L,V){return V&&(V.S&&g(V,$),A.state=function(){return g($,{})}),L?(s[a]=A,M):A})(N,S,"global"in b?b.global:this==s,b.state)}function p(v){var b,C=v.length,k=this,S=0,$=k.i=k.j=0,N=k.S=[];for(C||(v=[C++]);S=1||i===0);const a=Math.sqrt(-2*Math.log(i)/i);e=this.mean+this.stdDev*r*a,n=this.mean+this.stdDev*o*a,(!this.truncated||this.isValidTruncated(e))&&(s=!0)}return(!this.truncated||this.isValidTruncated(n))&&(this.nextVal=this.convertValue(n)),this.convertValue(e)}convertValue(e){return this.dtype==null||this.dtype==="float32"?e:Math.round(e)}isValidTruncated(e){return e<=this.upper&&e>=this.lower}}class uV{constructor(e=0,n=1,s,r){if(this.canReturnFloat=()=>this.dtype==null||this.dtype==="float32",this.min=e,this.range=n-e,this.dtype=s,r==null&&(r=Math.random()),typeof r=="number"&&(r=r.toString()),!this.canReturnFloat()&&this.range<=1)throw new Error(`The difference between ${e} - ${n} <= 1 and dtype is not float`);this.random=sw.alea(r)}convertValue(e){return this.canReturnFloat()?e:Math.round(e)}nextValue(){return this.convertValue(this.min+this.range*this.random())}}/** + */class hN{constructor(e,n,s,r,o){this.mean=e,this.stdDev=n,this.dtype=s,this.nextVal=NaN,this.truncated=r,this.truncated&&(this.upper=this.mean+this.stdDev*2,this.lower=this.mean-this.stdDev*2);const i=o||Math.random();this.random=sw.alea(i.toString())}nextValue(){if(!isNaN(this.nextVal)){const r=this.nextVal;return this.nextVal=NaN,r}let e,n,s=!1;for(;!s;){let r,o,i;do r=2*this.random()-1,o=2*this.random()-1,i=r*r+o*o;while(i>=1||i===0);const a=Math.sqrt(-2*Math.log(i)/i);e=this.mean+this.stdDev*r*a,n=this.mean+this.stdDev*o*a,(!this.truncated||this.isValidTruncated(e))&&(s=!0)}return(!this.truncated||this.isValidTruncated(n))&&(this.nextVal=this.convertValue(n)),this.convertValue(e)}convertValue(e){return this.dtype==null||this.dtype==="float32"?e:Math.round(e)}isValidTruncated(e){return e<=this.upper&&e>=this.lower}}class hV{constructor(e=0,n=1,s,r){if(this.canReturnFloat=()=>this.dtype==null||this.dtype==="float32",this.min=e,this.range=n-e,this.dtype=s,r==null&&(r=Math.random()),typeof r=="number"&&(r=r.toString()),!this.canReturnFloat()&&this.range<=1)throw new Error(`The difference between ${e} - ${n} <= 1 and dtype is not float`);this.random=sw.alea(r)}convertValue(e){return this.canReturnFloat()?e:Math.round(e)}nextValue(){return this.convertValue(this.min+this.range*this.random())}}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2363,7 +2363,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function dV(t,e=0,n=1,s,r){if(Xr(t),s!=null&&s==="bool")throw new Error(`Unsupported data type ${s}`);const o=new uN(e,n,s,!1,r),i=Ee(t,s);for(let a=0;a`Error in separableConv2d: input must be rank 4, but got rank ${u.rank}.`),I(l.rank===4,()=>`Error in separableConv2d: depthwise filter must be rank 4, but got rank ${l.rank}.`),I(c.rank===4,()=>`Error in separableConv2d: pointwise filter must be rank 4, but got rank ${l.rank}.`),I(c.shape[0]===1,()=>`Error in separableConv2d: the first dimension of pointwise filter must be 1, but got ${c.shape[0]}.`),I(c.shape[1]===1,()=>`Error in separableConv2d: the second dimension of pointwise filter must be 1, but got ${c.shape[1]}.`);const h=l.shape[2],f=l.shape[3];I(c.shape[2]===h*f,()=>`Error in separableConv2d: the third dimension of pointwise filter must be ${h*f}, but got ${c.shape[2]}.`);const p=By(u,l,s,r,i,o),x=zi(p,c,1,"valid",i);return d?F(x,[x.shape[1],x.shape[2],x.shape[3]]):x}const mN=z({separableConv2d_:kV});/** + */function kV(t){const n={x:T(t,"x","selu")};return _.runKernel(Yu,n)}const mN=z({selu_:kV});function SV(t,e,n,s,r,o=[1,1],i="NHWC"){const a=T(t,"x","separableConv2d"),l=T(e,"depthwiseFilter","separableConv2d"),c=T(n,"pointwiseFilter","separableConv2d");let u=a,h=!1;if(a.rank===3&&(h=!0,u=F(a,[1,a.shape[0],a.shape[1],a.shape[2]])),i==="NCHW")throw new Error("separableConv2d currently does not support dataFormat NCHW; only NHWC is supported");I(u.rank===4,()=>`Error in separableConv2d: input must be rank 4, but got rank ${u.rank}.`),I(l.rank===4,()=>`Error in separableConv2d: depthwise filter must be rank 4, but got rank ${l.rank}.`),I(c.rank===4,()=>`Error in separableConv2d: pointwise filter must be rank 4, but got rank ${l.rank}.`),I(c.shape[0]===1,()=>`Error in separableConv2d: the first dimension of pointwise filter must be 1, but got ${c.shape[0]}.`),I(c.shape[1]===1,()=>`Error in separableConv2d: the second dimension of pointwise filter must be 1, but got ${c.shape[1]}.`);const d=l.shape[2],f=l.shape[3];I(c.shape[2]===d*f,()=>`Error in separableConv2d: the third dimension of pointwise filter must be ${d*f}, but got ${c.shape[2]}.`);const p=By(u,l,s,r,i,o),x=zi(p,c,1,"valid",i);return h?F(x,[x.shape[1],x.shape[2],x.shape[3]]):x}const gN=z({separableConv2d_:SV});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2528,7 +2528,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function SV(t){const n={x:T(t,"x","sign")};return _.runKernel(Ju,n)}const IV=z({sign_:SV});/** + */function IV(t){const n={x:T(t,"x","sign")};return _.runKernel(Ju,n)}const $V=z({sign_:IV});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2543,7 +2543,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function $V(t){const n={x:T(t,"x","sin","float32")};return _.runKernel(Qu,n)}const gN=z({sin_:$V});/** + */function NV(t){const n={x:T(t,"x","sin","float32")};return _.runKernel(Qu,n)}const xN=z({sin_:NV});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2558,7 +2558,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function NV(t){const n={x:T(t,"x","sinh")};return _.runKernel(Zu,n)}const xN=z({sinh_:NV});/** + */function TV(t){const n={x:T(t,"x","sinh")};return _.runKernel(Zu,n)}const yN=z({sinh_:TV});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2573,7 +2573,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function TV(t,e,n){const s=T(t,"x","slice1d");return I(s.rank===1,()=>`slice1d expects a rank-1 tensor, but got a rank-${s.rank} tensor`),tt(s,[e],[n])}const rw=z({slice1d_:TV});/** + */function EV(t,e,n){const s=T(t,"x","slice1d");return I(s.rank===1,()=>`slice1d expects a rank-1 tensor, but got a rank-${s.rank} tensor`),tt(s,[e],[n])}const rw=z({slice1d_:EV});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2588,7 +2588,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function EV(t,e,n){const s=T(t,"x","slice2d");return I(s.rank===2,()=>`slice2d expects a rank-2 tensor, but got a rank-${s.rank} tensor`),tt(s,e,n)}const yN=z({slice2d_:EV});/** + */function RV(t,e,n){const s=T(t,"x","slice2d");return I(s.rank===2,()=>`slice2d expects a rank-2 tensor, but got a rank-${s.rank} tensor`),tt(s,e,n)}const wN=z({slice2d_:RV});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2603,7 +2603,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function RV(t,e,n){const s=T(t,"x","slice3d");return I(s.rank===3,()=>`slice3d expects a rank-3 tensor, but got a rank-${s.rank} tensor`),tt(s,e,n)}const ow=z({slice3d_:RV});/** + */function AV(t,e,n){const s=T(t,"x","slice3d");return I(s.rank===3,()=>`slice3d expects a rank-3 tensor, but got a rank-${s.rank} tensor`),tt(s,e,n)}const ow=z({slice3d_:AV});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2618,7 +2618,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function AV(t,e,n){const s=T(t,"x","slice4d");return I(s.rank===4,()=>`slice4d expects a rank-4 tensor, but got a rank-${s.rank} tensor`),tt(s,e,n)}const kf=z({slice4d_:AV});/** + */function DV(t,e,n){const s=T(t,"x","slice4d");return I(s.rank===4,()=>`slice4d expects a rank-4 tensor, but got a rank-${s.rank} tensor`),tt(s,e,n)}const kf=z({slice4d_:DV});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2633,7 +2633,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function DV(t,e=-1){const n=T(t,"logits","softmax","float32");if(e===-1&&(e=n.rank-1),e!==n.rank-1)throw Error(`Softmax along a non-last dimension is not yet supported. Logits was rank ${n.rank} and dim was ${e}`);const s={logits:n},r={dim:e};return _.runKernel(um,s,r)}const iw=z({softmax_:DV});/** + */function _V(t,e=-1){const n=T(t,"logits","softmax","float32");if(e===-1&&(e=n.rank-1),e!==n.rank-1)throw Error(`Softmax along a non-last dimension is not yet supported. Logits was rank ${n.rank} and dim was ${e}`);const s={logits:n},r={dim:e};return _.runKernel(um,s,r)}const iw=z({softmax_:_V});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2648,7 +2648,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function _V(t){I(t.dtype==="complex64",()=>`The dtype for tf.spectral.fft() must be complex64 but got ${t.dtype}.`);const e={input:t};return _.runKernel(cy,e)}const wN=z({fft_:_V});/** + */function FV(t){I(t.dtype==="complex64",()=>`The dtype for tf.spectral.fft() must be complex64 but got ${t.dtype}.`);const e={input:t};return _.runKernel(cy,e)}const vN=z({fft_:FV});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2663,7 +2663,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function FV(t){I(t.dtype==="complex64",()=>`The dtype for tf.spectral.ifft() must be complex64 but got ${t.dtype}.`);const e={input:t};return _.runKernel(hy,e)}const f1=z({ifft_:FV});/** + */function zV(t){I(t.dtype==="complex64",()=>`The dtype for tf.spectral.ifft() must be complex64 but got ${t.dtype}.`);const e={input:t};return _.runKernel(dy,e)}const f1=z({ifft_:zV});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2678,7 +2678,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function zV(t){const e=t.shape[t.shape.length-1],n=t.size/e;let s;if(e<=2){const r=F(t,[n,e]);s=f1(r)}else{const r=[n,2*(e-1)],o=F(Cf(t),[n,e]),i=F(Uy(t),[n,e]),a=Mi(tt(o,[0,1],[n,e-2]),1),l=D(Mi(tt(i,[0,1],[n,e-2]),1),We(-1)),c=Dn([o,a],1),u=Dn([i,l],1),d=F(Ri(c,u),[r[0],r[1]]);s=f1(d)}if(s=Cf(s),t.rank===3&&t.shape[0]!==0){const r=s,o=t.shape[0];s=F(s,[o,s.shape[0]/o,s.shape[1]]),r.dispose()}return s}const OV=z({irfft_:zV});/** + */function OV(t){const e=t.shape[t.shape.length-1],n=t.size/e;let s;if(e<=2){const r=F(t,[n,e]);s=f1(r)}else{const r=[n,2*(e-1)],o=F(Cf(t),[n,e]),i=F(Uy(t),[n,e]),a=Mi(tt(o,[0,1],[n,e-2]),1),l=D(Mi(tt(i,[0,1],[n,e-2]),1),We(-1)),c=Dn([o,a],1),u=Dn([i,l],1),h=F(Ri(c,u),[r[0],r[1]]);s=f1(h)}if(s=Cf(s),t.rank===3&&t.shape[0]!==0){const r=s,o=t.shape[0];s=F(s,[o,s.shape[0]/o,s.shape[1]]),r.dispose()}return s}const MV=z({irfft_:OV});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2693,7 +2693,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function MV(t,e,n=0){const r={x:T(t,"x","split")},o={numOrSizeSplits:e,axis:n};return _.runKernel(cm,r,o)}const rs=z({split_:MV});/** + */function PV(t,e,n=0){const r={x:T(t,"x","split")},o={numOrSizeSplits:e,axis:n};return _.runKernel(cm,r,o)}const rs=z({split_:PV});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2708,7 +2708,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function PV(t,e){I(t.dtype==="float32",()=>`The dtype for rfft() must be real value but got ${t.dtype}`);let n=t.shape[t.shape.length-1];const s=t.size/n;let r;if(e!=null&&e0),g=t.shape.map(x=>x);g[t.shape.length-1]=e,r=tt(t,p,g),n=e}else if(e!=null&&e>n){const p=t.shape.map(g=>g);p[t.shape.length-1]=e-n,r=Dn([t,Kt(p)],t.shape.length-1),n=e}else r=t;const o=ze(r),i=F(Ri(r,o),[s,n]),a=wN(i),l=Math.floor(n/2)+1,c=Cf(a),u=Uy(a),d=rs(c,[l,n-l],c.shape.length-1),h=rs(u,[l,n-l],u.shape.length-1),f=r.shape.slice();return f[r.shape.length-1]=l,F(Ri(d[0],h[0]),f)}const LV=z({rfft_:PV});/** + */function LV(t,e){I(t.dtype==="float32",()=>`The dtype for rfft() must be real value but got ${t.dtype}`);let n=t.shape[t.shape.length-1];const s=t.size/n;let r;if(e!=null&&e0),g=t.shape.map(x=>x);g[t.shape.length-1]=e,r=tt(t,p,g),n=e}else if(e!=null&&e>n){const p=t.shape.map(g=>g);p[t.shape.length-1]=e-n,r=Dn([t,Kt(p)],t.shape.length-1),n=e}else r=t;const o=ze(r),i=F(Ri(r,o),[s,n]),a=vN(i),l=Math.floor(n/2)+1,c=Cf(a),u=Uy(a),h=rs(c,[l,n-l],c.shape.length-1),d=rs(u,[l,n-l],u.shape.length-1),f=r.shape.slice();return f[r.shape.length-1]=l,F(Ri(h[0],d[0]),f)}const BV=z({rfft_:LV});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2723,7 +2723,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function BV(t,e){let n=T(t,"a","squaredDifference"),s=T(e,"b","squaredDifference");[n,s]=It(n,s),Se(n.shape,s.shape);const r={a:n,b:s},o={};return _.runKernel(sd,r,o)}const VV=z({squaredDifference_:BV});/** + */function VV(t,e){let n=T(t,"a","squaredDifference"),s=T(e,"b","squaredDifference");[n,s]=It(n,s),Se(n.shape,s.shape);const r={a:n,b:s},o={};return _.runKernel(sh,r,o)}const WV=z({squaredDifference_:VV});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2738,7 +2738,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function WV(t,e){const n=T(t,"x","squeeze","string_or_numeric");return F(n,Vo(n.shape,e).newShape)}const pd=z({squeeze_:WV});/** + */function UV(t,e){const n=T(t,"x","squeeze","string_or_numeric");return F(n,Vo(n.shape,e).newShape)}const ph=z({squeeze_:UV});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2753,7 +2753,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function UV(t,e=0){const n=L$(t,"tensors","stack","string_or_numeric");I(n.length>=1,()=>"Pass at least one tensor to tf.stack"),n.length>0&&I(e<=n[0].rank,()=>"Axis must be <= rank of the tensor");const s=n,r={axis:e};return _.runKernel(Qp,s,r)}const Gr=z({stack_:UV});/** + */function GV(t,e=0){const n=B$(t,"tensors","stack","string_or_numeric");I(n.length>=1,()=>"Pass at least one tensor to tf.stack"),n.length>0&&I(e<=n[0].rank,()=>"Axis must be <= rank of the tensor");const s=n,r={axis:e};return _.runKernel(Qp,s,r)}const Hr=z({stack_:GV});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2768,7 +2768,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function GV(t,e=0){const s={x:T(t,"x","step")},r={alpha:e};return _.runKernel(ld,s,r)}const md=z({step_:GV});/** + */function HV(t,e=0){const s={x:T(t,"x","step")},r={alpha:e};return _.runKernel(lh,s,r)}const mh=z({step_:HV});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2783,7 +2783,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function HV(t,e,n,s,r=0,o=0,i=0,a=0,l=0){const u={x:T(t,"x","stridedSlice","string_or_numeric")},d={begin:e,end:n,strides:s,beginMask:r,endMask:o,ellipsisMask:i,newAxisMask:a,shrinkAxisMask:l};return _.runKernel($y,u,d)}const jV=z({stridedSlice_:HV});/** + */function jV(t,e,n,s,r=0,o=0,i=0,a=0,l=0){const u={x:T(t,"x","stridedSlice","string_or_numeric")},h={begin:e,end:n,strides:s,beginMask:r,endMask:o,ellipsisMask:i,newAxisMask:a,shrinkAxisMask:l};return _.runKernel($y,u,h)}const KV=z({stridedSlice_:jV});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2798,7 +2798,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function KV(t){const n={x:T(t,"x","tan","float32")};return _.runKernel(od,n)}const XV=z({tan_:KV});/** + */function XV(t){const n={x:T(t,"x","tan","float32")};return _.runKernel(oh,n)}const qV=z({tan_:XV});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2813,7 +2813,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Gn(t,e){Bx(t);const n=cd(t,e);if(n.length!==1)throw new Error("tensor1d() requires values to be a flat/TypedArray");return ud(t,null,n,e)}/** + */function Gn(t,e){Bx(t);const n=ch(t,e);if(n.length!==1)throw new Error("tensor1d() requires values to be a flat/TypedArray");return uh(t,null,n,e)}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2828,7 +2828,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Sg(t,e,n){if(Bx(t),e!=null&&e.length!==2)throw new Error("tensor2d() requires shape to have two numbers");const s=cd(t,n);if(s.length!==2&&s.length!==1)throw new Error("tensor2d() requires values to be number[][] or flat/TypedArray");if(s.length===1&&e==null)throw new Error("tensor2d() requires shape to be provided when `values` are a flat/TypedArray");return ud(t,e,s,n)}/** + */function Sg(t,e,n){if(Bx(t),e!=null&&e.length!==2)throw new Error("tensor2d() requires shape to have two numbers");const s=ch(t,n);if(s.length!==2&&s.length!==1)throw new Error("tensor2d() requires values to be number[][] or flat/TypedArray");if(s.length===1&&e==null)throw new Error("tensor2d() requires shape to be provided when `values` are a flat/TypedArray");return uh(t,e,s,n)}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2843,7 +2843,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function qV(t,e,n){Bx(t);const s=cd(t,n);if(s.length!==3&&s.length!==1)throw new Error("tensor3d() requires values to be number[][][] or flat/TypedArray");if(s.length===1&&e==null)throw new Error("tensor3d() requires shape to be provided when `values` are a flat array");return ud(t,e,s,n)}function vN(t,e,n){const s=e.rank>1?e.shape[e.rank-1]:1,r=e.rank>1?e.rank-1:1,o=`Must have updates.shape = indices.shape[:batchDim] + shape[sliceDim:], got updates.shape: ${n.shape}, indices.shape: ${e.shape}, shape: ${t}, sliceDim: ${s}, and batchDim: ${r}.`;if(n.rank1?e.shape[s-1]:1,o=n.length;let i=1;for(let d=r;d1?e.shape[e.rank-1]:1,r=e.rank>1?e.rank-1:1,o=`Must have updates.shape = indices.shape[:batchDim] + shape[sliceDim:], got updates.shape: ${n.shape}, indices.shape: ${e.shape}, shape: ${t}, sliceDim: ${s}, and batchDim: ${r}.`;if(n.rank1?e.shape[s-1]:1,o=n.length;let i=1;for(let h=r;h= 0 but got ${e}`);if(e>r)throw new Error(`'k' passed to topk() must be <= the last dimension (${r}) but got ${e}`);const o={x:s},i={k:e,sorted:n},[a,l]=_.runKernel(Ny,o,i);return{values:a,indices:l}}const ZV=z({topk_:QV});/** + */function ZV(t,e=1,n=!0){const s=T(t,"x","topk");if(s.rank===0)throw new Error("topk() expects the input to be of rank 1 or higher");const r=s.shape[s.shape.length-1];if(e<0)throw new Error(`'k' passed to topk() must be >= 0 but got ${e}`);if(e>r)throw new Error(`'k' passed to topk() must be <= the last dimension (${r}) but got ${e}`);const o={x:s},i={k:e,sorted:n},[a,l]=_.runKernel(Ny,o,i);return{values:a,indices:l}}const JV=z({topk_:ZV});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2873,7 +2873,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function JV(t,e=0,n=1,s,r){if(Xr(t),s!=null&&s==="bool")throw new Error("Unsupported data type $ { dtype }");const o=new uN(e,n,s,!0,r),i=Ee(t,s);for(let a=0;a0,()=>"The input tensor must be at least 1D");const s={x:n},r={axis:e},[o,i]=_.runKernel(Ey,s,r);return{values:o,indices:i}}const tW=z({unique_:eW});/** + */function tW(t,e=0){const n=T(t,"x","unique","string_or_numeric");I(n.rank>0,()=>"The input tensor must be at least 1D");const s={x:n},r={axis:e},[o,i]=_.runKernel(Ey,s,r);return{values:o,indices:i}}const nW=z({unique_:tW});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2903,7 +2903,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function nW(t,e,n){const s=T(t,"x","unsortedSegmentSum"),r=T(e,"segmentIds","unsortedSegmentSum","int32");I(nl(n),()=>"numSegments must be of dtype int");const o={x:s,segmentIds:r},i={numSegments:n};return _.runKernel(hm,o,i)}const CN=z({unsortedSegmentSum_:nW});/** + */function sW(t,e,n){const s=T(t,"x","unsortedSegmentSum"),r=T(e,"segmentIds","unsortedSegmentSum","int32");I(nl(n),()=>"numSegments must be of dtype int");const o={x:s,segmentIds:r},i={numSegments:n};return _.runKernel(dm,o,i)}const kN=z({unsortedSegmentSum_:sW});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2918,7 +2918,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function sW(t,e=0){const n=T(t,"x","unstack","string_or_numeric");I(e>=-n.shape.length&&e`Axis = ${e} is not in [-${n.shape.length}, ${n.shape.length})`);const s={value:n},r={axis:e};return _.runKernel(dm,s,r)}const Pi=z({unstack_:sW});/** + */function rW(t,e=0){const n=T(t,"x","unstack","string_or_numeric");I(e>=-n.shape.length&&e`Axis = ${e} is not in [-${n.shape.length}, ${n.shape.length})`);const s={value:n},r={axis:e};return _.runKernel(hm,s,r)}const Pi=z({unstack_:rW});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2933,7 +2933,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function rW(t,e=!0,n,s){return _.makeVariable(t,e,n,s)}/** + */function oW(t,e=!0,n,s){return _.makeVariable(t,e,n,s)}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2948,7 +2948,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function kN(t,e){const n=[];for(let o=0;oa).reverse()),I(s.rank===e.length,()=>`Error in transpose: rank of input ${s.rank} must match length of perm ${e}.`),e.forEach(i=>{I(i>=0&&i`All entries in 'perm' must be between 0 and ${s.rank-1} but got ${e}`)}),s.rank<=1)return s.clone();const r={x:s},o={perm:e};return s.dtype==="complex64"?P(()=>{let i=Cf(s),a=Uy(s);return i=_.runKernel(Ma,{x:i},o),a=_.runKernel(Ma,{x:a},o),n&&(a=St(a)),Ri(i,a)}):_.runKernel(Ma,r,o)}const Fe=z({transpose_:oW});/** + */function iW(t,e,n){const s=T(t,"x","transpose");if(e==null&&(e=s.shape.map((i,a)=>a).reverse()),I(s.rank===e.length,()=>`Error in transpose: rank of input ${s.rank} must match length of perm ${e}.`),e.forEach(i=>{I(i>=0&&i`All entries in 'perm' must be between 0 and ${s.rank-1} but got ${e}`)}),s.rank<=1)return s.clone();const r={x:s},o={perm:e};return s.dtype==="complex64"?P(()=>{let i=Cf(s),a=Uy(s);return i=_.runKernel(Ma,{x:i},o),a=_.runKernel(Ma,{x:a},o),n&&(a=St(a)),Ri(i,a)}):_.runKernel(Ma,r,o)}const Fe=z({transpose_:iW});/** * @license * Copyright 2019 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -2978,7 +2978,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function iW(t,e){if(e==null)return t.shape.slice();if(Ue(t.shape,e))return e;if(t.shape.length===e.length){const n=[];for(let s=0;s`x has to be a floating point tensor since it's going to be scaled, but got a ${r.dtype} tensor instead.`),I(e>=0&&e<1,()=>`rate must be a float in the range [0, 1), but got ${e}.`),e===0)return t instanceof zt?r.clone():r;const o=iW(r,n),i=1-e,a=ge(vm(J(fd(o,0,1,"float32",s),i)),i);return D(r,a)}const lW=z({dropout_:aW});/** + */function lW(t,e,n,s){const r=T(t,"x","dropout");if(I(r.dtype==="float32",()=>`x has to be a floating point tensor since it's going to be scaled, but got a ${r.dtype} tensor instead.`),I(e>=0&&e<1,()=>`rate must be a float in the range [0, 1), but got ${e}.`),e===0)return t instanceof zt?r.clone():r;const o=aW(r,n),i=1-e,a=ge(vm(J(fh(o,0,1,"float32",s),i)),i);return D(r,a)}const cW=z({dropout_:lW});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3008,7 +3008,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function cW(t,e,n,s,r,o="NHWC",i){let a=t;t.rank===3&&(a=F(t,[1,t.shape[0],t.shape[1],t.shape[2]]));let l=e;l.rank===3&&(l=F(e,[1,e.shape[0],e.shape[1],e.shape[2]])),I(a.rank===4,()=>`Error in conv2dDerFilter: input must be rank 4, but got shape ${a.shape}.`),I(l.rank===4,()=>`Error in conv2dDerFilter: dy must be rank 4, but got shape ${l.shape}.`),I(n.length===4,()=>`Error in conv2dDerFilter: filterShape must be length 4, but got ${n}.`);const c=o==="NHWC"?a.shape[3]:a.shape[1],u=o==="NHWC"?l.shape[3]:l.shape[1];I(c===n[2],()=>`Error in conv2dDerFilter: depth of input ${c}) must match input depth in filter (${n[2]}.`),I(u===n[3],()=>`Error in conv2dDerFilter: depth of dy (${u}) must match output depth for filter (${n[3]}).`),Mn("conv2dDerFilter",r,i);const d={x:a,dy:l},h={strides:s,pad:r,dataFormat:o,dimRoundingMode:i,filterShape:n};return _.runKernel(Zx,d,h)}const aw=z({conv2DBackpropFilter_:cW});/** + */function uW(t,e,n,s,r,o="NHWC",i){let a=t;t.rank===3&&(a=F(t,[1,t.shape[0],t.shape[1],t.shape[2]]));let l=e;l.rank===3&&(l=F(e,[1,e.shape[0],e.shape[1],e.shape[2]])),I(a.rank===4,()=>`Error in conv2dDerFilter: input must be rank 4, but got shape ${a.shape}.`),I(l.rank===4,()=>`Error in conv2dDerFilter: dy must be rank 4, but got shape ${l.shape}.`),I(n.length===4,()=>`Error in conv2dDerFilter: filterShape must be length 4, but got ${n}.`);const c=o==="NHWC"?a.shape[3]:a.shape[1],u=o==="NHWC"?l.shape[3]:l.shape[1];I(c===n[2],()=>`Error in conv2dDerFilter: depth of input ${c}) must match input depth in filter (${n[2]}.`),I(u===n[3],()=>`Error in conv2dDerFilter: depth of dy (${u}) must match output depth for filter (${n[3]}).`),Mn("conv2dDerFilter",r,i);const h={x:a,dy:l},d={strides:s,pad:r,dataFormat:o,dimRoundingMode:i,filterShape:n};return _.runKernel(Zx,h,d)}const aw=z({conv2DBackpropFilter_:uW});/** * @license * Copyright 2019 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3023,7 +3023,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function lw(t,e,n){if(n==null||n==="linear")return t;if(n==="relu")return D(t,md(e));throw new Error(`Cannot compute gradient for fused activation ${n}.`)}function cw(t,e){let n=e;const s=Vt(t.shape,e.shape);return s.length>0&&(n=me(n,s)),F(n,t.shape)}function uw(t,e,n,s){if(e==="linear")return t;if(e==="relu")return Yi(t);if(e==="elu")return ym(t);if(e==="relu6")return dN(t);if(e==="prelu")return Yy(t,n);if(e==="leakyrelu")return Gy(t,s);if(e==="sigmoid")return Cl(t);throw new Error(`Unknown fused activation ${e}.`)}const dw=(t,e)=>!(t>0)||e==="linear";/** + */function lw(t,e,n){if(n==null||n==="linear")return t;if(n==="relu")return D(t,mh(e));throw new Error(`Cannot compute gradient for fused activation ${n}.`)}function cw(t,e){let n=e;const s=Vt(t.shape,e.shape);return s.length>0&&(n=me(n,s)),F(n,t.shape)}function uw(t,e,n,s){if(e==="linear")return t;if(e==="relu")return Yi(t);if(e==="elu")return ym(t);if(e==="relu6")return dN(t);if(e==="prelu")return Yy(t,n);if(e==="leakyrelu")return Gy(t,s);if(e==="sigmoid")return Cl(t);throw new Error(`Unknown fused activation ${e}.`)}const hw=(t,e)=>!(t>0)||e==="linear";/** * @license * Copyright 2019 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3038,7 +3038,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function uW({x:t,filter:e,strides:n,pad:s,dataFormat:r="NHWC",dilations:o=[1,1],dimRoundingMode:i,bias:a,activation:l="linear",preluActivationWeights:c,leakyreluAlpha:u}){if(l=l||"linear",dw(_.state.gradientDepth,l)===!1){I(r==="NHWC",()=>`Error in fused conv2d: got dataFormat of ${r} but only NHWC is currently supported for the case of gradient depth is 0 and the activation is not linear.`);let C=zi(t,e,n,s,r,o,i);return a!=null&&(C=J(C,a)),uw(C,l,c,u)}const d=T(t,"x","conv2d","float32"),h=T(e,"filter","conv2d","float32");let f=d,p=!1;d.rank===3&&(p=!0,f=F(d,[1,d.shape[0],d.shape[1],d.shape[2]])),I(f.rank===4,()=>`Error in fused conv2d: input must be rank 4, but got rank ${f.rank}.`),I(h.rank===4,()=>`Error in fused conv2d: filter must be rank 4, but got rank ${h.rank}.`),Mn("fused conv2d",s,i);const g=r==="NHWC"?f.shape[3]:f.shape[1];I(h.shape[2]===g,()=>`Error in conv2d: depth of input (${g}) must match input depth for filter ${h.shape[2]}.`),I(hn(n,o),()=>`Error in conv2D: Either strides or dilations must be 1. Got strides ${n} and dilations '${o}'`);const x=nn(f.shape,h.shape,n,o,s,i);let m;a!=null&&(m=T(a,"bias","fused conv2d"),[m]=It(m,d),r==="NHWC"?Se(x.outShape,m.shape):(I(m.shape.length<=1,()=>`Error in fused conv2d: only supports scalar or 1-D Tensor bias for NCHW format but got the bias of rank-${m.shape.length}.`),I(m.shape.length===0||m.shape[0]===x.outChannels||m.shape[0]===1,()=>`Error in fused conv2d: bias shape (${m.shape}) is not compatible with the number of output channels (${x.outChannels})`)));let y;if(c!=null){const C=c.shape;if(I(C.length<=1||C.length===3,()=>`Error in fused conv2d: only supports scalar, 1-D Tensor or 3-D Tensor PReLU activation weights but got a tensor of rank-${C.length}.`),C.length===1)I(C[0]===1||C[0]===x.outChannels,()=>`Error in fused conv2d: PReLU activation weights (${C}) is not compatible with the number of output channels (${x.outChannels}).`);else if(C.length===3)try{Se(C,x.outShape)}catch{const S=`Error in fused conv2d: PReLU activation weights (${C}) is not compatible with the output shape of the conv2d (${x.outShape}).`;throw Error(S)}y=T(c,"prelu weights","fused conv2d")}const w=(C,k)=>{I(r==="NHWC",()=>`Error in gradient of fused conv2D: got dataFormat of ${r} but only NHWC is currently supported.`);const[S,$,N,A]=k,M=lw(C,N,l);I(_i(o),()=>`Error in gradient of fused conv2D: dilation rates greater than 1 are not yet supported in gradients. Got dilations '${o}'`);const L=Py($.shape,M,S,n,s),V=aw($,M,S.shape,n,s),B=[L,V];if(A!=null){const U=cw(A,M);B.push(U)}return B},v={x:f,filter:h,bias:m,preluActivationWeights:y},b={strides:n,pad:s,dataFormat:r,dilations:o,dimRoundingMode:i,activation:l,leakyreluAlpha:u};return a==null?al((k,S,$)=>{let N=_.runKernel(pf,v,b);return $([S,k,N]),p&&(N=F(N,[N.shape[1],N.shape[2],N.shape[3]])),{value:N,gradFunc:w}})(f,h):al((k,S,$,N)=>{let A=_.runKernel(pf,v,b);return N([S,k,A,$]),p&&(A=F(A,[A.shape[1],A.shape[2],A.shape[3]])),{value:A,gradFunc:w}})(f,h,m)}const dW=z({fusedConv2d_:uW});/** + */function hW({x:t,filter:e,strides:n,pad:s,dataFormat:r="NHWC",dilations:o=[1,1],dimRoundingMode:i,bias:a,activation:l="linear",preluActivationWeights:c,leakyreluAlpha:u}){if(l=l||"linear",hw(_.state.gradientDepth,l)===!1){I(r==="NHWC",()=>`Error in fused conv2d: got dataFormat of ${r} but only NHWC is currently supported for the case of gradient depth is 0 and the activation is not linear.`);let C=zi(t,e,n,s,r,o,i);return a!=null&&(C=J(C,a)),uw(C,l,c,u)}const h=T(t,"x","conv2d","float32"),d=T(e,"filter","conv2d","float32");let f=h,p=!1;h.rank===3&&(p=!0,f=F(h,[1,h.shape[0],h.shape[1],h.shape[2]])),I(f.rank===4,()=>`Error in fused conv2d: input must be rank 4, but got rank ${f.rank}.`),I(d.rank===4,()=>`Error in fused conv2d: filter must be rank 4, but got rank ${d.rank}.`),Mn("fused conv2d",s,i);const g=r==="NHWC"?f.shape[3]:f.shape[1];I(d.shape[2]===g,()=>`Error in conv2d: depth of input (${g}) must match input depth for filter ${d.shape[2]}.`),I(dn(n,o),()=>`Error in conv2D: Either strides or dilations must be 1. Got strides ${n} and dilations '${o}'`);const x=nn(f.shape,d.shape,n,o,s,i);let m;a!=null&&(m=T(a,"bias","fused conv2d"),[m]=It(m,h),r==="NHWC"?Se(x.outShape,m.shape):(I(m.shape.length<=1,()=>`Error in fused conv2d: only supports scalar or 1-D Tensor bias for NCHW format but got the bias of rank-${m.shape.length}.`),I(m.shape.length===0||m.shape[0]===x.outChannels||m.shape[0]===1,()=>`Error in fused conv2d: bias shape (${m.shape}) is not compatible with the number of output channels (${x.outChannels})`)));let y;if(c!=null){const C=c.shape;if(I(C.length<=1||C.length===3,()=>`Error in fused conv2d: only supports scalar, 1-D Tensor or 3-D Tensor PReLU activation weights but got a tensor of rank-${C.length}.`),C.length===1)I(C[0]===1||C[0]===x.outChannels,()=>`Error in fused conv2d: PReLU activation weights (${C}) is not compatible with the number of output channels (${x.outChannels}).`);else if(C.length===3)try{Se(C,x.outShape)}catch{const S=`Error in fused conv2d: PReLU activation weights (${C}) is not compatible with the output shape of the conv2d (${x.outShape}).`;throw Error(S)}y=T(c,"prelu weights","fused conv2d")}const w=(C,k)=>{I(r==="NHWC",()=>`Error in gradient of fused conv2D: got dataFormat of ${r} but only NHWC is currently supported.`);const[S,$,N,A]=k,M=lw(C,N,l);I(_i(o),()=>`Error in gradient of fused conv2D: dilation rates greater than 1 are not yet supported in gradients. Got dilations '${o}'`);const L=Py($.shape,M,S,n,s),V=aw($,M,S.shape,n,s),B=[L,V];if(A!=null){const U=cw(A,M);B.push(U)}return B},v={x:f,filter:d,bias:m,preluActivationWeights:y},b={strides:n,pad:s,dataFormat:r,dilations:o,dimRoundingMode:i,activation:l,leakyreluAlpha:u};return a==null?al((k,S,$)=>{let N=_.runKernel(pf,v,b);return $([S,k,N]),p&&(N=F(N,[N.shape[1],N.shape[2],N.shape[3]])),{value:N,gradFunc:w}})(f,d):al((k,S,$,N)=>{let A=_.runKernel(pf,v,b);return N([S,k,A,$]),p&&(A=F(A,[A.shape[1],A.shape[2],A.shape[3]])),{value:A,gradFunc:w}})(f,d,m)}const dW=z({fusedConv2d_:hW});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3053,7 +3053,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function hW(t,e,n,s,r,o=[1,1],i){let a=t;t.rank===3&&(a=F(t,[1,t.shape[0],t.shape[1],t.shape[2]]));let l=e;l.rank===3&&(l=F(e,[1,e.shape[0],e.shape[1],e.shape[2]]));const c={x:a,dy:l},u={strides:s,pad:r,dimRoundingMode:i,dilations:o,filterShape:n};return _.runKernel(oy,c,u)}const fW=z({depthwiseConv2dNativeBackpropFilter_:hW});/** + */function fW(t,e,n,s,r,o=[1,1],i){let a=t;t.rank===3&&(a=F(t,[1,t.shape[0],t.shape[1],t.shape[2]]));let l=e;l.rank===3&&(l=F(e,[1,e.shape[0],e.shape[1],e.shape[2]]));const c={x:a,dy:l},u={strides:s,pad:r,dimRoundingMode:i,dilations:o,filterShape:n};return _.runKernel(oy,c,u)}const pW=z({depthwiseConv2dNativeBackpropFilter_:fW});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3068,7 +3068,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function pW(t,e,n,s,r,o=[1,1],i){let a=e,l=!1;e.rank===3&&(l=!0,a=F(e,[1,e.shape[0],e.shape[1],e.shape[2]]));const c={dy:a,filter:n},u={strides:s,pad:r,dimRoundingMode:i,dilations:o,inputShape:t},d=_.runKernel(iy,c,u);return l?F(d,[d.shape[1],d.shape[2],d.shape[3]]):d}const mW=z({depthwiseConv2dNativeBackpropInput_:pW});/** + */function mW(t,e,n,s,r,o=[1,1],i){let a=e,l=!1;e.rank===3&&(l=!0,a=F(e,[1,e.shape[0],e.shape[1],e.shape[2]]));const c={dy:a,filter:n},u={strides:s,pad:r,dimRoundingMode:i,dilations:o,inputShape:t},h=_.runKernel(iy,c,u);return l?F(h,[h.shape[1],h.shape[2],h.shape[3]]):h}const gW=z({depthwiseConv2dNativeBackpropInput_:mW});/** * @license * Copyright 2019 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3083,7 +3083,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function gW({a:t,b:e,transposeA:n=!1,transposeB:s=!1,bias:r,activation:o="linear",preluActivationWeights:i,leakyreluAlpha:a=.2}){if(dw(_.state.gradientDepth,o)===!1){let A=Ve(t,e,n,s);return r!=null&&(A=J(A,r)),uw(A,o,i,a)}let l=T(t,"a","fused matMul"),c=T(e,"b","fused matMul");[l,c]=It(l,c);const u=n?l.shape[l.rank-2]:l.shape[l.rank-1],d=s?c.shape[c.rank-1]:c.shape[c.rank-2],h=n?l.shape[l.rank-1]:l.shape[l.rank-2],f=s?c.shape[c.rank-2]:c.shape[c.rank-1],p=l.shape.slice(0,-2),g=c.shape.slice(0,-2),x=j(p),m=j(g);I(u===d,()=>`Error in fused matMul: inner shapes (${u}) and (${d}) of Tensors with shapes ${l.shape} and ${c.shape} and transposeA=${n} and transposeB=${s} must match.`);const w=Se(l.shape.slice(0,-2),c.shape.slice(0,-2)).concat([h,f]),v=n?F(l,[x,u,h]):F(l,[x,h,u]),b=s?F(c,[m,f,d]):F(c,[m,d,f]);let C;r!=null&&(C=T(r,"bias","fused matMul"),[C]=It(C,l),Se(w,C.shape));let k;i!=null&&(k=T(i,"prelu weights","fused matMul"));const S=(A,M)=>{const[L,V,B,U]=M,K=lw(F(A,B.shape),B,o);let R,O;if(!n&&!s?(R=Ve(K,V,!1,!0),O=Ve(L,K,!0,!1)):!n&&s?(R=Ve(K,V,!1,!1),O=Ve(K,L,!0,!1)):n&&!s?(R=Ve(V,K,!1,!0),O=Ve(L,K,!1,!1)):(R=Ve(V,K,!0,!0),O=Ve(K,L,!0,!0)),r!=null){const G=cw(U,K);return[R,O,G]}else return[R,O]},$={a:v,b,bias:C,preluActivationWeights:k},N={transposeA:n,transposeB:s,activation:o,leakyreluAlpha:a};return r==null?al((M,L,V)=>{const B=_.runKernel(ff,$,N);return V([M,L,B]),{value:F(B,w),gradFunc:S}})(v,b):al((M,L,V,B)=>{const U=_.runKernel(ff,$,N);return B([M,L,U,V]),{value:F(U,w),gradFunc:S}})(v,b,C)}const AC=z({fusedMatMul_:gW});/** + */function xW({a:t,b:e,transposeA:n=!1,transposeB:s=!1,bias:r,activation:o="linear",preluActivationWeights:i,leakyreluAlpha:a=.2}){if(hw(_.state.gradientDepth,o)===!1){let A=Ve(t,e,n,s);return r!=null&&(A=J(A,r)),uw(A,o,i,a)}let l=T(t,"a","fused matMul"),c=T(e,"b","fused matMul");[l,c]=It(l,c);const u=n?l.shape[l.rank-2]:l.shape[l.rank-1],h=s?c.shape[c.rank-1]:c.shape[c.rank-2],d=n?l.shape[l.rank-1]:l.shape[l.rank-2],f=s?c.shape[c.rank-2]:c.shape[c.rank-1],p=l.shape.slice(0,-2),g=c.shape.slice(0,-2),x=j(p),m=j(g);I(u===h,()=>`Error in fused matMul: inner shapes (${u}) and (${h}) of Tensors with shapes ${l.shape} and ${c.shape} and transposeA=${n} and transposeB=${s} must match.`);const w=Se(l.shape.slice(0,-2),c.shape.slice(0,-2)).concat([d,f]),v=n?F(l,[x,u,d]):F(l,[x,d,u]),b=s?F(c,[m,f,h]):F(c,[m,h,f]);let C;r!=null&&(C=T(r,"bias","fused matMul"),[C]=It(C,l),Se(w,C.shape));let k;i!=null&&(k=T(i,"prelu weights","fused matMul"));const S=(A,M)=>{const[L,V,B,U]=M,K=lw(F(A,B.shape),B,o);let R,O;if(!n&&!s?(R=Ve(K,V,!1,!0),O=Ve(L,K,!0,!1)):!n&&s?(R=Ve(K,V,!1,!1),O=Ve(K,L,!0,!1)):n&&!s?(R=Ve(V,K,!1,!0),O=Ve(L,K,!1,!1)):(R=Ve(V,K,!0,!0),O=Ve(K,L,!0,!0)),r!=null){const G=cw(U,K);return[R,O,G]}else return[R,O]},$={a:v,b,bias:C,preluActivationWeights:k},N={transposeA:n,transposeB:s,activation:o,leakyreluAlpha:a};return r==null?al((M,L,V)=>{const B=_.runKernel(ff,$,N);return V([M,L,B]),{value:F(B,w),gradFunc:S}})(v,b):al((M,L,V,B)=>{const U=_.runKernel(ff,$,N);return B([M,L,U,V]),{value:F(U,w),gradFunc:S}})(v,b,C)}const AC=z({fusedMatMul_:xW});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3098,7 +3098,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function xW(t,e,n,s,r="bilinear",o=0){const i=T(t,"image","cropAndResize"),a=T(e,"boxes","cropAndResize","float32"),l=T(n,"boxInd","cropAndResize","int32"),c=a.shape[0];I(i.rank===4,()=>`Error in cropAndResize: image must be rank 4,but got rank ${i.rank}.`),I(a.rank===2&&a.shape[1]===4,()=>`Error in cropAndResize: boxes must be have size [${c},4] but had shape ${a.shape}.`),I(l.rank===1&&l.shape[0]===c,()=>`Error in cropAndResize: boxInd must be have size [${c}] but had shape ${a.shape}.`),I(s.length===2,()=>`Error in cropAndResize: cropSize must be of length 2, but got length ${s.length}.`),I(s[0]>=1&&s[1]>=1,()=>`cropSize must be atleast [1,1], but was ${s}`),I(r==="bilinear"||r==="nearest",()=>`method must be bilinear or nearest, but was ${r}`);const u={image:i,boxes:a,boxInd:l},d={method:r,extrapolationValue:o,cropSize:s};return _.runKernel(ny,u,d)}const yW=z({cropAndResize_:xW});/** + */function yW(t,e,n,s,r="bilinear",o=0){const i=T(t,"image","cropAndResize"),a=T(e,"boxes","cropAndResize","float32"),l=T(n,"boxInd","cropAndResize","int32"),c=a.shape[0];I(i.rank===4,()=>`Error in cropAndResize: image must be rank 4,but got rank ${i.rank}.`),I(a.rank===2&&a.shape[1]===4,()=>`Error in cropAndResize: boxes must be have size [${c},4] but had shape ${a.shape}.`),I(l.rank===1&&l.shape[0]===c,()=>`Error in cropAndResize: boxInd must be have size [${c}] but had shape ${a.shape}.`),I(s.length===2,()=>`Error in cropAndResize: cropSize must be of length 2, but got length ${s.length}.`),I(s[0]>=1&&s[1]>=1,()=>`cropSize must be atleast [1,1], but was ${s}`),I(r==="bilinear"||r==="nearest",()=>`method must be bilinear or nearest, but was ${r}`);const u={image:i,boxes:a,boxInd:l},h={method:r,extrapolationValue:o,cropSize:s};return _.runKernel(ny,u,h)}const wW=z({cropAndResize_:yW});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3113,7 +3113,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function wW(t){const e=T(t,"image","flipLeftRight","float32");I(e.rank===4,()=>`Error in flipLeftRight: image must be rank 4,but got rank ${e.rank}.`);const n={image:e};return _.runKernel(dy,n,{})}const vW=z({flipLeftRight_:wW});/** + */function vW(t){const e=T(t,"image","flipLeftRight","float32");I(e.rank===4,()=>`Error in flipLeftRight: image must be rank 4,but got rank ${e.rank}.`);const n={image:e};return _.runKernel(hy,n,{})}const bW=z({flipLeftRight_:vW});/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3128,7 +3128,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function bW(t){const e=T(t,"image","grayscaleToRGB"),n=e.rank-1,s=e.shape[n];I(e.rank>=2,()=>`Error in grayscaleToRGB: images must be at least rank 2, but got rank ${e.rank}.`),I(s===1,()=>`Error in grayscaleToRGB: last dimension of a grayscale image should be size 1, but got size ${s}.`);const r=new Array(e.rank);return r.fill(1,0,n),r[n]=3,Gs(e,r)}const CW=z({grayscaleToRGB_:bW});/** + */function CW(t){const e=T(t,"image","grayscaleToRGB"),n=e.rank-1,s=e.shape[n];I(e.rank>=2,()=>`Error in grayscaleToRGB: images must be at least rank 2, but got rank ${e.rank}.`),I(s===1,()=>`Error in grayscaleToRGB: last dimension of a grayscale image should be size 1, but got size ${s}.`);const r=new Array(e.rank);return r.fill(1,0,n),r[n]=3,Hs(e,r)}const kW=z({grayscaleToRGB_:CW});/** * @license * Copyright 2023 Google LLC. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3143,7 +3143,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function kW(t){const e=T(t,"image","RGBToGrayscale"),n=e.rank-1,s=e.shape[n];I(e.rank>=2,()=>`Error in RGBToGrayscale: images must be at least rank 2, but got rank ${e.rank}.`),I(s===3,()=>`Error in RGBToGrayscale: last dimension of an RGB image should be size 3, but got size ${s}.`);const r=e.dtype,o=le(e,"float32"),i=Gn([.2989,.587,.114]);let a;switch(e.rank){case 2:a=Hl("ij,j->i",o,i);break;case 3:a=Hl("ijk,k->ij",o,i);break;case 4:a=Hl("ijkl,l->ijk",o,i);break;case 5:a=Hl("ijklm,m->ijkl",o,i);break;case 6:a=Hl("ijklmn,n->ijklm",o,i);break;default:throw new Error("Not a valid tensor rank.")}return a=En(a,-1),le(a,r)}const SW=z({rgbToGrayscale_:kW});/** + */function SW(t){const e=T(t,"image","RGBToGrayscale"),n=e.rank-1,s=e.shape[n];I(e.rank>=2,()=>`Error in RGBToGrayscale: images must be at least rank 2, but got rank ${e.rank}.`),I(s===3,()=>`Error in RGBToGrayscale: last dimension of an RGB image should be size 3, but got size ${s}.`);const r=e.dtype,o=le(e,"float32"),i=Gn([.2989,.587,.114]);let a;switch(e.rank){case 2:a=Hl("ij,j->i",o,i);break;case 3:a=Hl("ijk,k->ij",o,i);break;case 4:a=Hl("ijkl,l->ijk",o,i);break;case 5:a=Hl("ijklm,m->ijkl",o,i);break;case 6:a=Hl("ijklmn,n->ijklm",o,i);break;default:throw new Error("Not a valid tensor rank.")}return a=En(a,-1),le(a,r)}const IW=z({rgbToGrayscale_:SW});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3158,7 +3158,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function IW(t,e,n=0,s=.5){const r=T(t,"image","rotateWithOffset","float32");I(r.rank===4,()=>`Error in rotateWithOffset: image must be rank 4,but got rank ${r.rank}.`);const o={image:r},i={radians:e,fillValue:n,center:s};return _.runKernel(Ry,o,i)}const $W=z({rotateWithOffset_:IW});/** + */function $W(t,e,n=0,s=.5){const r=T(t,"image","rotateWithOffset","float32");I(r.rank===4,()=>`Error in rotateWithOffset: image must be rank 4,but got rank ${r.rank}.`);const o={image:r},i={radians:e,fillValue:n,center:s};return _.runKernel(Ry,o,i)}const NW=z({rotateWithOffset_:$W});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3188,7 +3188,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function NW(t,e,n,s=.5,r=Number.NEGATIVE_INFINITY){const o=T(t,"boxes","nonMaxSuppression","float32"),i=T(e,"scores","nonMaxSuppression","float32"),a=Sl(o,i,n,s,r);n=a.maxOutputSize,s=a.iouThreshold,r=a.scoreThreshold;const l={maxOutputSize:n,iouThreshold:s,scoreThreshold:r};return _.runKernel(xy,{boxes:o,scores:i},l)}const TW=z({nonMaxSuppression_:NW});/** + */function TW(t,e,n,s=.5,r=Number.NEGATIVE_INFINITY){const o=T(t,"boxes","nonMaxSuppression","float32"),i=T(e,"scores","nonMaxSuppression","float32"),a=Sl(o,i,n,s,r);n=a.maxOutputSize,s=a.iouThreshold,r=a.scoreThreshold;const l={maxOutputSize:n,iouThreshold:s,scoreThreshold:r};return _.runKernel(xy,{boxes:o,scores:i},l)}const EW=z({nonMaxSuppression_:TW});/** * @license * Copyright 2019 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3203,7 +3203,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function EW(t,e,n){const s=RW(t,e,n),r=s<0?-(s+1):s;t.splice(r,0,e)}function RW(t,e,n){return DW(t,e,n||AW)}function AW(t,e){return t>e?1:t>>1);const a=n(e,t[o]);a>0?s=o+1:(r=o,i=!a)}return i?s:-s-1}/** + */function RW(t,e,n){const s=AW(t,e,n),r=s<0?-(s+1):s;t.splice(r,0,e)}function AW(t,e,n){return _W(t,e,n||DW)}function DW(t,e){return t>e?1:t>>1);const a=n(e,t[o]);a>0?s=o+1:(r=o,i=!a)}return i?s:-s-1}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3218,7 +3218,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function hw(t,e,n,s,r){return mw(t,e,n,s,r,0)}function fw(t,e,n,s,r,o){return mw(t,e,n,s,r,0,!1,o,!0)}function pw(t,e,n,s,r,o){return mw(t,e,n,s,r,o,!0)}function mw(t,e,n,s,r,o,i=!1,a=!1,l=!1){const c=[];for(let x=0;xr&&c.push({score:e[x],boxIndex:x,suppressBeginIndex:0});c.sort(DC);const u=o>0?-.5/o:0,d=[],h=[];for(;d.length0;){const x=c.pop(),{score:m,boxIndex:y,suppressBeginIndex:w}=x;if(m=w;--b){const C=_W(t,y,d[b]);if(C>=s){v=!0;break}if(x.score=x.score*FW(s,u,C),x.score<=r)break}x.suppressBeginIndex=d.length,v||(x.score===m?(d.push(y),h.push(x.score)):x.score>r&&EW(c,x,DC))}const f=d.length,p=n-f;a&&p>0&&(d.push(...new Array(p).fill(0)),h.push(...new Array(p).fill(0)));const g={selectedIndices:d};return i&&(g.selectedScores=h),l&&(g.validOutputs=f),g}function _W(t,e,n){const s=t.subarray(e*4,e*4+4),r=t.subarray(n*4,n*4+4),o=Math.min(s[0],s[2]),i=Math.min(s[1],s[3]),a=Math.max(s[0],s[2]),l=Math.max(s[1],s[3]),c=Math.min(r[0],r[2]),u=Math.min(r[1],r[3]),d=Math.max(r[0],r[2]),h=Math.max(r[1],r[3]),f=(a-o)*(l-i),p=(d-c)*(h-u);if(f<=0||p<=0)return 0;const g=Math.max(o,c),x=Math.max(i,u),m=Math.min(a,d),y=Math.min(l,h),w=Math.max(m-g,0)*Math.max(y-x,0);return w/(f+p-w)}function FW(t,e,n){const s=Math.exp(e*n*n);return n<=t?s:0}function DC(t,e){return t.score-e.score||t.score===e.score&&e.boxIndex-t.boxIndex}/** + */function dw(t,e,n,s,r){return mw(t,e,n,s,r,0)}function fw(t,e,n,s,r,o){return mw(t,e,n,s,r,0,!1,o,!0)}function pw(t,e,n,s,r,o){return mw(t,e,n,s,r,o,!0)}function mw(t,e,n,s,r,o,i=!1,a=!1,l=!1){const c=[];for(let x=0;xr&&c.push({score:e[x],boxIndex:x,suppressBeginIndex:0});c.sort(DC);const u=o>0?-.5/o:0,h=[],d=[];for(;h.length0;){const x=c.pop(),{score:m,boxIndex:y,suppressBeginIndex:w}=x;if(m=w;--b){const C=FW(t,y,h[b]);if(C>=s){v=!0;break}if(x.score=x.score*zW(s,u,C),x.score<=r)break}x.suppressBeginIndex=h.length,v||(x.score===m?(h.push(y),d.push(x.score)):x.score>r&&RW(c,x,DC))}const f=h.length,p=n-f;a&&p>0&&(h.push(...new Array(p).fill(0)),d.push(...new Array(p).fill(0)));const g={selectedIndices:h};return i&&(g.selectedScores=d),l&&(g.validOutputs=f),g}function FW(t,e,n){const s=t.subarray(e*4,e*4+4),r=t.subarray(n*4,n*4+4),o=Math.min(s[0],s[2]),i=Math.min(s[1],s[3]),a=Math.max(s[0],s[2]),l=Math.max(s[1],s[3]),c=Math.min(r[0],r[2]),u=Math.min(r[1],r[3]),h=Math.max(r[0],r[2]),d=Math.max(r[1],r[3]),f=(a-o)*(l-i),p=(h-c)*(d-u);if(f<=0||p<=0)return 0;const g=Math.max(o,c),x=Math.max(i,u),m=Math.min(a,h),y=Math.min(l,d),w=Math.max(m-g,0)*Math.max(y-x,0);return w/(f+p-w)}function zW(t,e,n){const s=Math.exp(e*n*n);return n<=t?s:0}function DC(t,e){return t.score-e.score||t.score===e.score&&e.boxIndex-t.boxIndex}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3233,7 +3233,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */async function zW(t,e,n,s=.5,r=Number.NEGATIVE_INFINITY){const o=T(t,"boxes","nonMaxSuppressionAsync"),i=T(e,"scores","nonMaxSuppressionAsync"),a=Sl(o,i,n,s,r);n=a.maxOutputSize,s=a.iouThreshold,r=a.scoreThreshold;const l=await Promise.all([o.data(),i.data()]),c=l[0],u=l[1],{selectedIndices:d}=hw(c,u,n,s,r);return o!==t&&o.dispose(),i!==e&&i.dispose(),Gn(d,"int32")}const OW=zW;/** + */async function OW(t,e,n,s=.5,r=Number.NEGATIVE_INFINITY){const o=T(t,"boxes","nonMaxSuppressionAsync"),i=T(e,"scores","nonMaxSuppressionAsync"),a=Sl(o,i,n,s,r);n=a.maxOutputSize,s=a.iouThreshold,r=a.scoreThreshold;const l=await Promise.all([o.data(),i.data()]),c=l[0],u=l[1],{selectedIndices:h}=dw(c,u,n,s,r);return o!==t&&o.dispose(),i!==e&&i.dispose(),Gn(h,"int32")}const MW=OW;/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3248,7 +3248,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function MW(t,e,n,s=.5,r=Number.NEGATIVE_INFINITY,o=0){const i=T(t,"boxes","nonMaxSuppression"),a=T(e,"scores","nonMaxSuppression"),l=Sl(i,a,n,s,r,o);n=l.maxOutputSize,s=l.iouThreshold,r=l.scoreThreshold,o=l.softNmsSigma;const c={boxes:i,scores:a},u={maxOutputSize:n,iouThreshold:s,scoreThreshold:r,softNmsSigma:o},d=_.runKernel(wy,c,u);return{selectedIndices:d[0],selectedScores:d[1]}}const PW=z({nonMaxSuppressionWithScore_:MW});/** + */function PW(t,e,n,s=.5,r=Number.NEGATIVE_INFINITY,o=0){const i=T(t,"boxes","nonMaxSuppression"),a=T(e,"scores","nonMaxSuppression"),l=Sl(i,a,n,s,r,o);n=l.maxOutputSize,s=l.iouThreshold,r=l.scoreThreshold,o=l.softNmsSigma;const c={boxes:i,scores:a},u={maxOutputSize:n,iouThreshold:s,scoreThreshold:r,softNmsSigma:o},h=_.runKernel(wy,c,u);return{selectedIndices:h[0],selectedScores:h[1]}}const LW=z({nonMaxSuppressionWithScore_:PW});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3263,7 +3263,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */async function LW(t,e,n,s=.5,r=Number.NEGATIVE_INFINITY,o=0){const i=T(t,"boxes","nonMaxSuppressionAsync"),a=T(e,"scores","nonMaxSuppressionAsync"),l=Sl(i,a,n,s,r,o);n=l.maxOutputSize,s=l.iouThreshold,r=l.scoreThreshold,o=l.softNmsSigma;const c=await Promise.all([i.data(),a.data()]),u=c[0],d=c[1],{selectedIndices:h,selectedScores:f}=pw(u,d,n,s,r,o);return i!==t&&i.dispose(),a!==e&&a.dispose(),{selectedIndices:Gn(h,"int32"),selectedScores:Gn(f)}}const BW=LW;/** + */async function BW(t,e,n,s=.5,r=Number.NEGATIVE_INFINITY,o=0){const i=T(t,"boxes","nonMaxSuppressionAsync"),a=T(e,"scores","nonMaxSuppressionAsync"),l=Sl(i,a,n,s,r,o);n=l.maxOutputSize,s=l.iouThreshold,r=l.scoreThreshold,o=l.softNmsSigma;const c=await Promise.all([i.data(),a.data()]),u=c[0],h=c[1],{selectedIndices:d,selectedScores:f}=pw(u,h,n,s,r,o);return i!==t&&i.dispose(),a!==e&&a.dispose(),{selectedIndices:Gn(d,"int32"),selectedScores:Gn(f)}}const VW=BW;/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3278,7 +3278,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function VW(t,e,n,s=.5,r=Number.NEGATIVE_INFINITY,o=!1){const i=T(t,"boxes","nonMaxSuppression"),a=T(e,"scores","nonMaxSuppression"),l=Sl(i,a,n,s,r,null),c=l.maxOutputSize,u=l.iouThreshold,d=l.scoreThreshold,h={boxes:i,scores:a},f={maxOutputSize:c,iouThreshold:u,scoreThreshold:d,padToMaxOutputSize:o},p=_.runKernel(yy,h,f);return{selectedIndices:p[0],validOutputs:p[1]}}const WW=z({nonMaxSuppressionPadded_:VW});/** + */function WW(t,e,n,s=.5,r=Number.NEGATIVE_INFINITY,o=!1){const i=T(t,"boxes","nonMaxSuppression"),a=T(e,"scores","nonMaxSuppression"),l=Sl(i,a,n,s,r,null),c=l.maxOutputSize,u=l.iouThreshold,h=l.scoreThreshold,d={boxes:i,scores:a},f={maxOutputSize:c,iouThreshold:u,scoreThreshold:h,padToMaxOutputSize:o},p=_.runKernel(yy,d,f);return{selectedIndices:p[0],validOutputs:p[1]}}const UW=z({nonMaxSuppressionPadded_:WW});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3293,7 +3293,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */async function UW(t,e,n,s=.5,r=Number.NEGATIVE_INFINITY,o=!1){const i=T(t,"boxes","nonMaxSuppressionAsync"),a=T(e,"scores","nonMaxSuppressionAsync"),l=Sl(i,a,n,s,r,null),c=l.maxOutputSize,u=l.iouThreshold,d=l.scoreThreshold,[h,f]=await Promise.all([i.data(),a.data()]),{selectedIndices:p,validOutputs:g}=fw(h,f,c,u,d,o);return i!==t&&i.dispose(),a!==e&&a.dispose(),{selectedIndices:Gn(p,"int32"),validOutputs:We(g,"int32")}}const GW=UW;/** + */async function GW(t,e,n,s=.5,r=Number.NEGATIVE_INFINITY,o=!1){const i=T(t,"boxes","nonMaxSuppressionAsync"),a=T(e,"scores","nonMaxSuppressionAsync"),l=Sl(i,a,n,s,r,null),c=l.maxOutputSize,u=l.iouThreshold,h=l.scoreThreshold,[d,f]=await Promise.all([i.data(),a.data()]),{selectedIndices:p,validOutputs:g}=fw(d,f,c,u,h,o);return i!==t&&i.dispose(),a!==e&&a.dispose(),{selectedIndices:Gn(p,"int32"),validOutputs:We(g,"int32")}}const HW=GW;/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3308,7 +3308,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function HW(t,e,n=!1,s=!1){const r=T(t,"images","resizeBilinear");I(r.rank===3||r.rank===4,()=>`Error in resizeBilinear: x must be rank 3 or 4, but got rank ${r.rank}.`),I(e.length===2,()=>`Error in resizeBilinear: new shape must 2D, but got shape ${e}.`),I(s===!1||n===!1,()=>"Error in resizeBilinear: If halfPixelCenters is true, alignCorners must be false.");let o=r,i=!1;r.rank===3&&(i=!0,o=F(r,[1,r.shape[0],r.shape[1],r.shape[2]]));const a={images:o},l={alignCorners:n,halfPixelCenters:s,size:e},c=_.runKernel(sm,a,l);return i?F(c,[c.shape[1],c.shape[2],c.shape[3]]):c}const SN=z({resizeBilinear_:HW});/** + */function jW(t,e,n=!1,s=!1){const r=T(t,"images","resizeBilinear");I(r.rank===3||r.rank===4,()=>`Error in resizeBilinear: x must be rank 3 or 4, but got rank ${r.rank}.`),I(e.length===2,()=>`Error in resizeBilinear: new shape must 2D, but got shape ${e}.`),I(s===!1||n===!1,()=>"Error in resizeBilinear: If halfPixelCenters is true, alignCorners must be false.");let o=r,i=!1;r.rank===3&&(i=!0,o=F(r,[1,r.shape[0],r.shape[1],r.shape[2]]));const a={images:o},l={alignCorners:n,halfPixelCenters:s,size:e},c=_.runKernel(sm,a,l);return i?F(c,[c.shape[1],c.shape[2],c.shape[3]]):c}const IN=z({resizeBilinear_:jW});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3323,7 +3323,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function jW(t,e,n=!1,s=!1){const r=T(t,"images","resizeNearestNeighbor");I(r.rank===3||r.rank===4,()=>`Error in resizeNearestNeighbor: x must be rank 3 or 4, but got rank ${r.rank}.`),I(e.length===2,()=>`Error in resizeNearestNeighbor: new shape must 2D, but got shape ${e}.`),I(r.dtype==="float32"||r.dtype==="int32",()=>"`images` must have `int32` or `float32` as dtype"),I(s===!1||n===!1,()=>"Error in resizeNearestNeighbor: If halfPixelCenters is true, alignCorners must be false.");let o=r,i=!1;r.rank===3&&(i=!0,o=F(r,[1,r.shape[0],r.shape[1],r.shape[2]]));const a={images:o},l={alignCorners:n,halfPixelCenters:s,size:e},c=_.runKernel(nm,a,l);return i?F(c,[c.shape[1],c.shape[2],c.shape[3]]):c}const IN=z({resizeNearestNeighbor_:jW});/** + */function KW(t,e,n=!1,s=!1){const r=T(t,"images","resizeNearestNeighbor");I(r.rank===3||r.rank===4,()=>`Error in resizeNearestNeighbor: x must be rank 3 or 4, but got rank ${r.rank}.`),I(e.length===2,()=>`Error in resizeNearestNeighbor: new shape must 2D, but got shape ${e}.`),I(r.dtype==="float32"||r.dtype==="int32",()=>"`images` must have `int32` or `float32` as dtype"),I(s===!1||n===!1,()=>"Error in resizeNearestNeighbor: If halfPixelCenters is true, alignCorners must be false.");let o=r,i=!1;r.rank===3&&(i=!0,o=F(r,[1,r.shape[0],r.shape[1],r.shape[2]]));const a={images:o},l={alignCorners:n,halfPixelCenters:s,size:e},c=_.runKernel(nm,a,l);return i?F(c,[c.shape[1],c.shape[2],c.shape[3]]):c}const $N=z({resizeNearestNeighbor_:KW});/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3338,7 +3338,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function KW(t,e="binary",n=!1,s=.5){const r=T(t,"image","threshold"),o=.2989,i=.587,a=.114,l=r.shape[0]*r.shape[1];let c=D(Gn([s]),255),u,d,h,f;if(I(r.rank===3,()=>`Error in threshold: image must be rank 3,but got rank ${r.rank}.`),I(r.shape[2]===3||r.shape[2]===1,()=>`Error in threshold: image color channel must be equal to 3 or 1but got ${r.shape[2]}.`),I(r.dtype==="int32"||r.dtype==="float32",()=>`Error in dtype: image dtype must be int32 or float32,but got dtype ${r.dtype}.`),I(e==="otsu"||e==="binary",()=>`Method must be binary or otsu, but was ${e}`),r.shape[2]===3){[u,d,h]=rs(r,[1,1,1],-1);const x=D(u,o),m=D(d,i),y=D(h,a);f=J(J(x,m),y)}else f=t;if(e==="otsu"){const x=HL(le(hN(f),"int32"),bc([]),256);c=XW(x,l)}const p=n?kl(f,c):us(f,c);return le(D(p,255),"int32")}function XW(t,e){let n=Gn([-1]),s=Gn([0]),r=Gn([0]),o,i,a,l,c,u;for(let d=0;d`Error in threshold: image must be rank 3,but got rank ${r.rank}.`),I(r.shape[2]===3||r.shape[2]===1,()=>`Error in threshold: image color channel must be equal to 3 or 1but got ${r.shape[2]}.`),I(r.dtype==="int32"||r.dtype==="float32",()=>`Error in dtype: image dtype must be int32 or float32,but got dtype ${r.dtype}.`),I(e==="otsu"||e==="binary",()=>`Method must be binary or otsu, but was ${e}`),r.shape[2]===3){[u,h,d]=rs(r,[1,1,1],-1);const x=D(u,o),m=D(h,i),y=D(d,a);f=J(J(x,m),y)}else f=t;if(e==="otsu"){const x=jL(le(fN(f),"int32"),bc([]),256);c=qW(x,l)}const p=n?kl(f,c):us(f,c);return le(D(p,255),"int32")}function qW(t,e){let n=Gn([-1]),s=Gn([0]),r=Gn([0]),o,i,a,l,c,u;for(let h=0;h`Error in transform: image must be rank 4,but got rank ${i.rank}.`),I(a.rank===2&&(a.shape[0]===i.shape[0]||a.shape[0]===1)&&a.shape[1]===8,()=>"Error in transform: Input transform should be batch x 8 or 1 x 8"),I(o==null||o.length===2,()=>`Error in transform: outputShape must be [height, width] or null, but got ${o}.`);const l={image:i,transforms:a},c={interpolation:n,fillMode:s,fillValue:r,outputShape:o};return _.runKernel(Ty,l,c)}const QW=z({transform_:YW});/** + */function QW(t,e,n="nearest",s="constant",r=0,o){const i=T(t,"image","transform","float32"),a=T(e,"transforms","transform","float32");I(i.rank===4,()=>`Error in transform: image must be rank 4,but got rank ${i.rank}.`),I(a.rank===2&&(a.shape[0]===i.shape[0]||a.shape[0]===1)&&a.shape[1]===8,()=>"Error in transform: Input transform should be batch x 8 or 1 x 8"),I(o==null||o.length===2,()=>`Error in transform: outputShape must be [height, width] or null, but got ${o}.`);const l={image:i,transforms:a},c={interpolation:n,fillMode:s,fillValue:r,outputShape:o};return _.runKernel(Ty,l,c)}const ZW=z({transform_:QW});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3368,7 +3368,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function ZW(t,e,n){const s=T(t,"a","bandPart");I(s.rank>=2,()=>`bandPart(): Rank must be at least 2, got ${s.rank}.`);const r=s.shape,[o,i]=s.shape.slice(-2);let a,l;typeof e=="number"?(I(e%1===0,()=>`bandPart(): numLower must be an integer, got ${e}.`),I(e<=o,()=>`bandPart(): numLower (${e}) must not be greater than the number of rows (${o}).`),a=T(e<0?o:e,"numLower","bandPart")):(I(e.dtype==="int32",()=>"bandPart(): numLower's dtype must be an int32."),a=Cn(vf(e,0),o,Xc(e,o))),typeof n=="number"?(I(n%1===0,()=>`bandPart(): numUpper must be an integer, got ${n}.`),I(n<=i,()=>`bandPart(): numUpper (${n}) must not be greater than the number of columns (${i}).`),l=T(n<0?i:n,"numUpper","bandPart")):(I(n.dtype==="int32",()=>"bandPart(): numUpper's dtype must be an int32."),l=Cn(vf(n,0),i,Xc(n,i)));const c=F(qc(0,o,1,"int32"),[-1,1]),u=qc(0,i,1,"int32"),d=ve(c,u),h=Ur(kl(d,a),Xi(d,St(l))),f=Kt([o,i],s.dtype);return F(Gr(Pi(F(s,[-1,o,i])).map(p=>Cn(h,p,f))),r)}const JW=z({bandPart_:ZW});/** + */function JW(t,e,n){const s=T(t,"a","bandPart");I(s.rank>=2,()=>`bandPart(): Rank must be at least 2, got ${s.rank}.`);const r=s.shape,[o,i]=s.shape.slice(-2);let a,l;typeof e=="number"?(I(e%1===0,()=>`bandPart(): numLower must be an integer, got ${e}.`),I(e<=o,()=>`bandPart(): numLower (${e}) must not be greater than the number of rows (${o}).`),a=T(e<0?o:e,"numLower","bandPart")):(I(e.dtype==="int32",()=>"bandPart(): numLower's dtype must be an int32."),a=Cn(vf(e,0),o,Xc(e,o))),typeof n=="number"?(I(n%1===0,()=>`bandPart(): numUpper must be an integer, got ${n}.`),I(n<=i,()=>`bandPart(): numUpper (${n}) must not be greater than the number of columns (${i}).`),l=T(n<0?i:n,"numUpper","bandPart")):(I(n.dtype==="int32",()=>"bandPart(): numUpper's dtype must be an int32."),l=Cn(vf(n,0),i,Xc(n,i)));const c=F(qc(0,o,1,"int32"),[-1,1]),u=qc(0,i,1,"int32"),h=ve(c,u),d=Gr(kl(h,a),Xi(h,St(l))),f=Kt([o,i],s.dtype);return F(Hr(Pi(F(s,[-1,o,i])).map(p=>Cn(d,p,f))),r)}const eU=z({bandPart_:JW});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3383,7 +3383,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function eU(t){let e;if(Array.isArray(t)){e=!1,I(t!=null&&t.length>0,()=>"Gram-Schmidt process: input must not be null, undefined, or empty");const r=t[0].shape[0];for(let o=1;o`Gram-Schmidt: Non-unique lengths found in the input vectors: (${t[o].shape[0]} vs. ${r})`)}else e=!0,t=rs(t,t.shape[0],0).map(r=>pd(r,[0]));I(t.length<=t[0].shape[0],()=>`Gram-Schmidt: Number of vectors (${t.length}) exceeds number of dimensions (${t[0].shape[0]}).`);const n=[],s=t;for(let r=0;r{let o=s[r];if(r>0)for(let i=0;i0,()=>"Gram-Schmidt process: input must not be null, undefined, or empty");const r=t[0].shape[0];for(let o=1;o`Gram-Schmidt: Non-unique lengths found in the input vectors: (${t[o].shape[0]} vs. ${r})`)}else e=!0,t=rs(t,t.shape[0],0).map(r=>ph(r,[0]));I(t.length<=t[0].shape[0],()=>`Gram-Schmidt: Number of vectors (${t.length}) exceeds number of dimensions (${t[0].shape[0]}).`);const n=[],s=t;for(let r=0;r{let o=s[r];if(r>0)for(let i=0;i=2,()=>`qr() requires input tensor to have a rank >= 2, but got rank ${t.rank}`),t.rank===2)return _C(t,e);{const n=t.shape.slice(0,t.shape.length-2).reduce((l,c)=>l*c),s=Pi(F(t,[n,t.shape[t.shape.length-2],t.shape[t.shape.length-1]]),0),r=[],o=[];s.forEach(l=>{const[c,u]=_C(l,e);r.push(c),o.push(u)});const i=F(Gr(r,0),t.shape),a=F(Gr(o,0),t.shape);return[i,a]}}function _C(t,e=!1){return _.tidy(()=>{I(t.shape.length===2,()=>`qr2d() requires a 2D Tensor, but got a ${t.shape.length}D Tensor.`);const n=t.shape[0],s=t.shape[1];let r=sN(n),o=vi(t);const i=Sg([[1]],[1,1]);let a=vi(i);const l=n>=s?s:n;for(let c=0;c{const f=tt(o,[c,c],[n-c,1]),p=wm(f),g=tt(o,[c,c],[1,1]),x=Cn(us(g,0),Sg([[-1]]),Sg([[1]])),m=ve(g,D(x,p)),y=ge(f,m);y.shape[0]===1?a=vi(i):a=Dn([i,tt(y,[1,0],[y.shape[0]-1,y.shape[1]])],0);const w=St(ge(Ve(x,m),p)),v=tt(o,[c,0],[n-c,s]),b=D(w,a),C=Fe(a);if(c===0)o=ve(v,Ve(b,Ve(C,v)));else{const $=ve(v,Ve(b,Ve(C,v)));o=Dn([tt(o,[0,0],[c,s]),$],0)}const k=Fe(b),S=tt(r,[0,c],[n,r.shape[1]-c]);if(c===0)r=ve(S,Ve(Ve(S,a),k));else{const $=ve(S,Ve(Ve(S,a),k));r=Dn([tt(r,[0,0],[n,c]),$],1)}return[a,o,r]}),$e([u,d,h])}return!e&&n>s&&(r=tt(r,[0,0],[n,s]),o=tt(o,[0,0],[s,s])),[r,o]})}const sU=z({qr_:nU});/** + */function sU(t,e=!1){if(I(t.rank>=2,()=>`qr() requires input tensor to have a rank >= 2, but got rank ${t.rank}`),t.rank===2)return _C(t,e);{const n=t.shape.slice(0,t.shape.length-2).reduce((l,c)=>l*c),s=Pi(F(t,[n,t.shape[t.shape.length-2],t.shape[t.shape.length-1]]),0),r=[],o=[];s.forEach(l=>{const[c,u]=_C(l,e);r.push(c),o.push(u)});const i=F(Hr(r,0),t.shape),a=F(Hr(o,0),t.shape);return[i,a]}}function _C(t,e=!1){return _.tidy(()=>{I(t.shape.length===2,()=>`qr2d() requires a 2D Tensor, but got a ${t.shape.length}D Tensor.`);const n=t.shape[0],s=t.shape[1];let r=rN(n),o=vi(t);const i=Sg([[1]],[1,1]);let a=vi(i);const l=n>=s?s:n;for(let c=0;c{const f=tt(o,[c,c],[n-c,1]),p=wm(f),g=tt(o,[c,c],[1,1]),x=Cn(us(g,0),Sg([[-1]]),Sg([[1]])),m=ve(g,D(x,p)),y=ge(f,m);y.shape[0]===1?a=vi(i):a=Dn([i,tt(y,[1,0],[y.shape[0]-1,y.shape[1]])],0);const w=St(ge(Ve(x,m),p)),v=tt(o,[c,0],[n-c,s]),b=D(w,a),C=Fe(a);if(c===0)o=ve(v,Ve(b,Ve(C,v)));else{const $=ve(v,Ve(b,Ve(C,v)));o=Dn([tt(o,[0,0],[c,s]),$],0)}const k=Fe(b),S=tt(r,[0,c],[n,r.shape[1]-c]);if(c===0)r=ve(S,Ve(Ve(S,a),k));else{const $=ve(S,Ve(Ve(S,a),k));r=Dn([tt(r,[0,0],[n,c]),$],1)}return[a,o,r]}),$e([u,h,d])}return!e&&n>s&&(r=tt(r,[0,0],[n,s]),o=tt(o,[0,0],[s,s])),[r,o]})}const rU=z({qr_:sU});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3413,7 +3413,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Or={flipLeftRight:vW,grayscaleToRGB:CW,resizeNearestNeighbor:IN,resizeBilinear:SN,rgbToGrayscale:SW,rotateWithOffset:$W,cropAndResize:yW,nonMaxSuppression:TW,nonMaxSuppressionAsync:OW,nonMaxSuppressionWithScore:PW,nonMaxSuppressionWithScoreAsync:BW,nonMaxSuppressionPadded:WW,nonMaxSuppressionPaddedAsync:GW,threshold:qW,transform:QW},rU={bandPart:JW,gramSchmidt:tU,qr:sU};/** + */const Mr={flipLeftRight:bW,grayscaleToRGB:kW,resizeNearestNeighbor:$N,resizeBilinear:IN,rgbToGrayscale:IW,rotateWithOffset:NW,cropAndResize:wW,nonMaxSuppression:EW,nonMaxSuppressionAsync:MW,nonMaxSuppressionWithScore:LW,nonMaxSuppressionWithScoreAsync:VW,nonMaxSuppressionPadded:UW,nonMaxSuppressionPaddedAsync:HW,threshold:YW,transform:ZW},oU={bandPart:eU,gramSchmidt:nU,qr:rU};/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3428,7 +3428,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const oU=new Map,iU=new Map;class Il{getClassName(){return this.constructor.className}static fromConfig(e,n){return new e(n)}}class xs{constructor(){this.classNameMap={}}static getMap(){return xs.instance==null&&(xs.instance=new xs),xs.instance}static register(e){xs.getMap().classNameMap[e.className]=[e,e.fromConfig]}}function Y(t,e,n){I(t.className!=null,()=>"Class being registered does not have the static className property defined."),I(typeof t.className=="string",()=>"className is required to be a string, but got type "+typeof t.className),I(t.className.length>0,()=>"Class being registered has an empty-string as its className, which is disallowed."),typeof e>"u"&&(e="Custom"),typeof n>"u"&&(n=t.className);const s=n,r=e+">"+s;return xs.register(t),oU.set(r,t),iU.set(t,r),t}/** + */const iU=new Map,aU=new Map;class Il{getClassName(){return this.constructor.className}static fromConfig(e,n){return new e(n)}}class xs{constructor(){this.classNameMap={}}static getMap(){return xs.instance==null&&(xs.instance=new xs),xs.instance}static register(e){xs.getMap().classNameMap[e.className]=[e,e.fromConfig]}}function Y(t,e,n){I(t.className!=null,()=>"Class being registered does not have the static className property defined."),I(typeof t.className=="string",()=>"className is required to be a string, but got type "+typeof t.className),I(t.className.length>0,()=>"Class being registered has an empty-string as its className, which is disallowed."),typeof e>"u"&&(e="Custom"),typeof n>"u"&&(n=t.className);const s=n,r=e+">"+s;return xs.register(t),iU.set(r,t),aU.set(t,r),t}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3443,7 +3443,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class Xo extends Il{minimize(e,n=!1,s){const{value:r,grads:o}=this.computeGradients(e,s);if(s!=null){const i=s.map(a=>({name:a.name,tensor:o[a.name]}));this.applyGradients(i)}else this.applyGradients(o);return $e(o),n?r:(r.dispose(),null)}get iterations(){return this.iterations_==null&&(this.iterations_=0),this.iterations_}incrementIterations(){this.iterations_=this.iterations+1}computeGradients(e,n){return hB(e,n)}dispose(){this.iterations_!=null&&$e(this.iterations_)}async saveIterations(){return this.iterations_==null&&(this.iterations_=0),{name:"iter",tensor:We(this.iterations_,"int32")}}async getWeights(){throw new Error("getWeights() is not implemented for this optimizer yet.")}async setWeights(e){throw new Error(`setWeights() is not implemented for this optimizer class ${this.getClassName()}`)}async extractIterations(e){return this.iterations_=(await e[0].tensor.data())[0],e.slice(1)}}Object.defineProperty(Xo,Symbol.hasInstance,{value:t=>t.minimize!=null&&t.computeGradients!=null&&t.applyGradients!=null});/** + */class Xo extends Il{minimize(e,n=!1,s){const{value:r,grads:o}=this.computeGradients(e,s);if(s!=null){const i=s.map(a=>({name:a.name,tensor:o[a.name]}));this.applyGradients(i)}else this.applyGradients(o);return $e(o),n?r:(r.dispose(),null)}get iterations(){return this.iterations_==null&&(this.iterations_=0),this.iterations_}incrementIterations(){this.iterations_=this.iterations+1}computeGradients(e,n){return fB(e,n)}dispose(){this.iterations_!=null&&$e(this.iterations_)}async saveIterations(){return this.iterations_==null&&(this.iterations_=0),{name:"iter",tensor:We(this.iterations_,"int32")}}async getWeights(){throw new Error("getWeights() is not implemented for this optimizer yet.")}async setWeights(e){throw new Error(`setWeights() is not implemented for this optimizer class ${this.getClassName()}`)}async extractIterations(e){return this.iterations_=(await e[0].tensor.data())[0],e.slice(1)}}Object.defineProperty(Xo,Symbol.hasInstance,{value:t=>t.minimize!=null&&t.computeGradients!=null&&t.applyGradients!=null});/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3458,7 +3458,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class $N extends Xo{static get className(){return"Adadelta"}constructor(e,n,s=null){super(),this.learningRate=e,this.rho=n,this.epsilon=s,this.accumulatedGrads=[],this.accumulatedUpdates=[],s==null&&(this.epsilon=_.backend.epsilon())}applyGradients(e){(Array.isArray(e)?e.map(s=>s.name):Object.keys(e)).forEach((s,r)=>{const o=_.registeredVariables[s],i=!1;this.accumulatedGrads[r]==null&&(this.accumulatedGrads[r]={originalName:`${s}/accum_grad`,variable:P(()=>ze(o).variable(i))}),this.accumulatedUpdates[r]==null&&(this.accumulatedUpdates[r]={originalName:`${s}/accum_var`,variable:P(()=>ze(o).variable(i))});const a=Array.isArray(e)?e[r].tensor:e[s];if(a==null)return;const l=this.accumulatedGrads[r].variable,c=this.accumulatedUpdates[r].variable;P(()=>{const u=J(D(l,this.rho),D(ot(a),1-this.rho)),d=D(ge(dn(J(c,this.epsilon)),dn(J(l,this.epsilon))),a),h=J(D(c,this.rho),D(ot(d),1-this.rho));l.assign(u),c.assign(h);const f=J(D(d,-this.learningRate),o);o.assign(f)})}),this.incrementIterations()}dispose(){this.accumulatedUpdates!=null&&($e(this.accumulatedGrads.map(e=>e.variable)),$e(this.accumulatedUpdates.map(e=>e.variable)))}async getWeights(){const e=[...this.accumulatedGrads,...this.accumulatedUpdates];return[await this.saveIterations()].concat(e.map(n=>({name:n.originalName,tensor:n.variable})))}async setWeights(e){e=await this.extractIterations(e);const n=e.length/2,s=!1;this.accumulatedGrads=e.slice(0,n).map(r=>({originalName:r.name,variable:r.tensor.variable(s)})),this.accumulatedUpdates=e.slice(n,n*2).map(r=>({originalName:r.name,variable:r.tensor.variable(s)}))}getConfig(){return{learningRate:this.learningRate,rho:this.rho,epsilon:this.epsilon}}static fromConfig(e,n){return new e(n.learningRate,n.rho,n.epsilon)}}/** + */class NN extends Xo{static get className(){return"Adadelta"}constructor(e,n,s=null){super(),this.learningRate=e,this.rho=n,this.epsilon=s,this.accumulatedGrads=[],this.accumulatedUpdates=[],s==null&&(this.epsilon=_.backend.epsilon())}applyGradients(e){(Array.isArray(e)?e.map(s=>s.name):Object.keys(e)).forEach((s,r)=>{const o=_.registeredVariables[s],i=!1;this.accumulatedGrads[r]==null&&(this.accumulatedGrads[r]={originalName:`${s}/accum_grad`,variable:P(()=>ze(o).variable(i))}),this.accumulatedUpdates[r]==null&&(this.accumulatedUpdates[r]={originalName:`${s}/accum_var`,variable:P(()=>ze(o).variable(i))});const a=Array.isArray(e)?e[r].tensor:e[s];if(a==null)return;const l=this.accumulatedGrads[r].variable,c=this.accumulatedUpdates[r].variable;P(()=>{const u=J(D(l,this.rho),D(ot(a),1-this.rho)),h=D(ge(hn(J(c,this.epsilon)),hn(J(l,this.epsilon))),a),d=J(D(c,this.rho),D(ot(h),1-this.rho));l.assign(u),c.assign(d);const f=J(D(h,-this.learningRate),o);o.assign(f)})}),this.incrementIterations()}dispose(){this.accumulatedUpdates!=null&&($e(this.accumulatedGrads.map(e=>e.variable)),$e(this.accumulatedUpdates.map(e=>e.variable)))}async getWeights(){const e=[...this.accumulatedGrads,...this.accumulatedUpdates];return[await this.saveIterations()].concat(e.map(n=>({name:n.originalName,tensor:n.variable})))}async setWeights(e){e=await this.extractIterations(e);const n=e.length/2,s=!1;this.accumulatedGrads=e.slice(0,n).map(r=>({originalName:r.name,variable:r.tensor.variable(s)})),this.accumulatedUpdates=e.slice(n,n*2).map(r=>({originalName:r.name,variable:r.tensor.variable(s)}))}getConfig(){return{learningRate:this.learningRate,rho:this.rho,epsilon:this.epsilon}}static fromConfig(e,n){return new e(n.learningRate,n.rho,n.epsilon)}}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3473,7 +3473,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class NN extends Xo{static get className(){return"Adagrad"}constructor(e,n=.1){super(),this.learningRate=e,this.initialAccumulatorValue=n,this.accumulatedGrads=[]}applyGradients(e){(Array.isArray(e)?e.map(s=>s.name):Object.keys(e)).forEach((s,r)=>{const o=_.registeredVariables[s];this.accumulatedGrads[r]==null&&(this.accumulatedGrads[r]={originalName:`${s}/accumulator`,variable:P(()=>xm(o.shape,this.initialAccumulatorValue).variable(!1))});const i=Array.isArray(e)?e[r].tensor:e[s];if(i==null)return;const a=this.accumulatedGrads[r].variable;P(()=>{const l=J(a,ot(i));a.assign(l);const c=J(D(ge(i,dn(J(l,_.backend.epsilon()))),-this.learningRate),o);o.assign(c)})}),this.incrementIterations()}dispose(){this.accumulatedGrads!=null&&$e(this.accumulatedGrads.map(e=>e.variable))}async getWeights(){return[await this.saveIterations()].concat(this.accumulatedGrads.map(e=>({name:e.originalName,tensor:e.variable})))}async setWeights(e){e=await this.extractIterations(e);const n=!1;this.accumulatedGrads=e.map(s=>({originalName:s.name,variable:s.tensor.variable(n)}))}getConfig(){return{learningRate:this.learningRate,initialAccumulatorValue:this.initialAccumulatorValue}}static fromConfig(e,n){return new e(n.learningRate,n.initialAccumulatorValue)}}/** + */class TN extends Xo{static get className(){return"Adagrad"}constructor(e,n=.1){super(),this.learningRate=e,this.initialAccumulatorValue=n,this.accumulatedGrads=[]}applyGradients(e){(Array.isArray(e)?e.map(s=>s.name):Object.keys(e)).forEach((s,r)=>{const o=_.registeredVariables[s];this.accumulatedGrads[r]==null&&(this.accumulatedGrads[r]={originalName:`${s}/accumulator`,variable:P(()=>xm(o.shape,this.initialAccumulatorValue).variable(!1))});const i=Array.isArray(e)?e[r].tensor:e[s];if(i==null)return;const a=this.accumulatedGrads[r].variable;P(()=>{const l=J(a,ot(i));a.assign(l);const c=J(D(ge(i,hn(J(l,_.backend.epsilon()))),-this.learningRate),o);o.assign(c)})}),this.incrementIterations()}dispose(){this.accumulatedGrads!=null&&$e(this.accumulatedGrads.map(e=>e.variable))}async getWeights(){return[await this.saveIterations()].concat(this.accumulatedGrads.map(e=>({name:e.originalName,tensor:e.variable})))}async setWeights(e){e=await this.extractIterations(e);const n=!1;this.accumulatedGrads=e.map(s=>({originalName:s.name,variable:s.tensor.variable(n)}))}getConfig(){return{learningRate:this.learningRate,initialAccumulatorValue:this.initialAccumulatorValue}}static fromConfig(e,n){return new e(n.learningRate,n.initialAccumulatorValue)}}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3488,7 +3488,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class TN extends Xo{static get className(){return"Adam"}constructor(e,n,s,r=null){super(),this.learningRate=e,this.beta1=n,this.beta2=s,this.epsilon=r,this.accumulatedFirstMoment=[],this.accumulatedSecondMoment=[],P(()=>{this.accBeta1=We(n).variable(),this.accBeta2=We(s).variable()}),r==null&&(this.epsilon=_.backend.epsilon())}applyGradients(e){const n=Array.isArray(e)?e.map(s=>s.name):Object.keys(e);P(()=>{const s=ve(1,this.accBeta1),r=ve(1,this.accBeta2);n.forEach((o,i)=>{const a=_.registeredVariables[o],l=!1;this.accumulatedFirstMoment[i]==null&&(this.accumulatedFirstMoment[i]={originalName:`${o}/m`,variable:P(()=>ze(a).variable(l))}),this.accumulatedSecondMoment[i]==null&&(this.accumulatedSecondMoment[i]={originalName:`${o}/v`,variable:P(()=>ze(a).variable(l))});const c=Array.isArray(e)?e[i].tensor:e[o];if(c==null)return;const u=this.accumulatedFirstMoment[i].variable,d=this.accumulatedSecondMoment[i].variable,h=J(D(u,this.beta1),D(c,1-this.beta1)),f=J(D(d,this.beta2),D(ot(c),1-this.beta2)),p=ge(h,s),g=ge(f,r);u.assign(h),d.assign(f);const x=J(D(ge(p,J(dn(g),this.epsilon)),-this.learningRate),a);a.assign(x)}),this.accBeta1.assign(D(this.accBeta1,this.beta1)),this.accBeta2.assign(D(this.accBeta2,this.beta2))}),this.incrementIterations()}dispose(){this.accBeta1.dispose(),this.accBeta2.dispose(),this.accumulatedFirstMoment!=null&&$e(this.accumulatedFirstMoment.map(e=>e.variable)),this.accumulatedSecondMoment!=null&&$e(this.accumulatedSecondMoment.map(e=>e.variable))}async getWeights(){const e=[...this.accumulatedFirstMoment,...this.accumulatedSecondMoment];return[await this.saveIterations()].concat(e.map(n=>({name:n.originalName,tensor:n.variable})))}async setWeights(e){e=await this.extractIterations(e),P(()=>{this.accBeta1.assign(Oi(this.beta1,this.iterations_+1)),this.accBeta2.assign(Oi(this.beta2,this.iterations_+1))});const n=e.length/2,s=!1;this.accumulatedFirstMoment=e.slice(0,n).map(r=>({originalName:r.name,variable:r.tensor.variable(s)})),this.accumulatedSecondMoment=e.slice(n,n*2).map(r=>({originalName:r.name,variable:r.tensor.variable(s)}))}getConfig(){return{learningRate:this.learningRate,beta1:this.beta1,beta2:this.beta2,epsilon:this.epsilon}}static fromConfig(e,n){return new e(n.learningRate,n.beta1,n.beta2,n.epsilon)}}/** + */class EN extends Xo{static get className(){return"Adam"}constructor(e,n,s,r=null){super(),this.learningRate=e,this.beta1=n,this.beta2=s,this.epsilon=r,this.accumulatedFirstMoment=[],this.accumulatedSecondMoment=[],P(()=>{this.accBeta1=We(n).variable(),this.accBeta2=We(s).variable()}),r==null&&(this.epsilon=_.backend.epsilon())}applyGradients(e){const n=Array.isArray(e)?e.map(s=>s.name):Object.keys(e);P(()=>{const s=ve(1,this.accBeta1),r=ve(1,this.accBeta2);n.forEach((o,i)=>{const a=_.registeredVariables[o],l=!1;this.accumulatedFirstMoment[i]==null&&(this.accumulatedFirstMoment[i]={originalName:`${o}/m`,variable:P(()=>ze(a).variable(l))}),this.accumulatedSecondMoment[i]==null&&(this.accumulatedSecondMoment[i]={originalName:`${o}/v`,variable:P(()=>ze(a).variable(l))});const c=Array.isArray(e)?e[i].tensor:e[o];if(c==null)return;const u=this.accumulatedFirstMoment[i].variable,h=this.accumulatedSecondMoment[i].variable,d=J(D(u,this.beta1),D(c,1-this.beta1)),f=J(D(h,this.beta2),D(ot(c),1-this.beta2)),p=ge(d,s),g=ge(f,r);u.assign(d),h.assign(f);const x=J(D(ge(p,J(hn(g),this.epsilon)),-this.learningRate),a);a.assign(x)}),this.accBeta1.assign(D(this.accBeta1,this.beta1)),this.accBeta2.assign(D(this.accBeta2,this.beta2))}),this.incrementIterations()}dispose(){this.accBeta1.dispose(),this.accBeta2.dispose(),this.accumulatedFirstMoment!=null&&$e(this.accumulatedFirstMoment.map(e=>e.variable)),this.accumulatedSecondMoment!=null&&$e(this.accumulatedSecondMoment.map(e=>e.variable))}async getWeights(){const e=[...this.accumulatedFirstMoment,...this.accumulatedSecondMoment];return[await this.saveIterations()].concat(e.map(n=>({name:n.originalName,tensor:n.variable})))}async setWeights(e){e=await this.extractIterations(e),P(()=>{this.accBeta1.assign(Oi(this.beta1,this.iterations_+1)),this.accBeta2.assign(Oi(this.beta2,this.iterations_+1))});const n=e.length/2,s=!1;this.accumulatedFirstMoment=e.slice(0,n).map(r=>({originalName:r.name,variable:r.tensor.variable(s)})),this.accumulatedSecondMoment=e.slice(n,n*2).map(r=>({originalName:r.name,variable:r.tensor.variable(s)}))}getConfig(){return{learningRate:this.learningRate,beta1:this.beta1,beta2:this.beta2,epsilon:this.epsilon}}static fromConfig(e,n){return new e(n.learningRate,n.beta1,n.beta2,n.epsilon)}}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3503,7 +3503,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class EN extends Xo{static get className(){return"Adamax"}constructor(e,n,s,r=null,o=0){super(),this.learningRate=e,this.beta1=n,this.beta2=s,this.epsilon=r,this.decay=o,this.accumulatedFirstMoment=[],this.accumulatedWeightedInfNorm=[],P(()=>{this.iteration=We(0).variable(),this.accBeta1=We(n).variable()}),r==null&&(this.epsilon=_.backend.epsilon())}applyGradients(e){const n=Array.isArray(e)?e.map(s=>s.name):Object.keys(e);P(()=>{const s=ve(1,this.accBeta1),r=ge(-this.learningRate,J(D(this.iteration,this.decay),1));n.forEach((o,i)=>{const a=_.registeredVariables[o],l=!1;this.accumulatedFirstMoment[i]==null&&(this.accumulatedFirstMoment[i]={originalName:`${o}/m`,variable:ze(a).variable(l)}),this.accumulatedWeightedInfNorm[i]==null&&(this.accumulatedWeightedInfNorm[i]={originalName:`${o}/v`,variable:ze(a).variable(l)});const c=Array.isArray(e)?e[i].tensor:e[o];if(c==null)return;const u=this.accumulatedFirstMoment[i].variable,d=this.accumulatedWeightedInfNorm[i].variable,h=J(D(u,this.beta1),D(c,1-this.beta1)),f=D(d,this.beta2),p=xn(c),g=jo(f,p);u.assign(h),d.assign(g);const x=J(D(ge(r,s),ge(h,J(g,this.epsilon))),a);a.assign(x)}),this.iteration.assign(J(this.iteration,1)),this.accBeta1.assign(D(this.accBeta1,this.beta1))}),this.incrementIterations()}dispose(){this.accBeta1.dispose(),this.iteration.dispose(),this.accumulatedFirstMoment!=null&&$e(this.accumulatedFirstMoment.map(e=>e.variable)),this.accumulatedWeightedInfNorm!=null&&$e(this.accumulatedWeightedInfNorm.map(e=>e.variable))}async getWeights(){throw new Error("getWeights() is not implemented for Adamax yet.")}async setWeights(e){throw new Error("setWeights() is not implemented for Adamax yet.")}getConfig(){return{learningRate:this.learningRate,beta1:this.beta1,beta2:this.beta2,epsilon:this.epsilon,decay:this.decay}}static fromConfig(e,n){return new e(n.learningRate,n.beta1,n.beta2,n.epsilon,n.decay)}}/** + */class RN extends Xo{static get className(){return"Adamax"}constructor(e,n,s,r=null,o=0){super(),this.learningRate=e,this.beta1=n,this.beta2=s,this.epsilon=r,this.decay=o,this.accumulatedFirstMoment=[],this.accumulatedWeightedInfNorm=[],P(()=>{this.iteration=We(0).variable(),this.accBeta1=We(n).variable()}),r==null&&(this.epsilon=_.backend.epsilon())}applyGradients(e){const n=Array.isArray(e)?e.map(s=>s.name):Object.keys(e);P(()=>{const s=ve(1,this.accBeta1),r=ge(-this.learningRate,J(D(this.iteration,this.decay),1));n.forEach((o,i)=>{const a=_.registeredVariables[o],l=!1;this.accumulatedFirstMoment[i]==null&&(this.accumulatedFirstMoment[i]={originalName:`${o}/m`,variable:ze(a).variable(l)}),this.accumulatedWeightedInfNorm[i]==null&&(this.accumulatedWeightedInfNorm[i]={originalName:`${o}/v`,variable:ze(a).variable(l)});const c=Array.isArray(e)?e[i].tensor:e[o];if(c==null)return;const u=this.accumulatedFirstMoment[i].variable,h=this.accumulatedWeightedInfNorm[i].variable,d=J(D(u,this.beta1),D(c,1-this.beta1)),f=D(h,this.beta2),p=xn(c),g=jo(f,p);u.assign(d),h.assign(g);const x=J(D(ge(r,s),ge(d,J(g,this.epsilon))),a);a.assign(x)}),this.iteration.assign(J(this.iteration,1)),this.accBeta1.assign(D(this.accBeta1,this.beta1))}),this.incrementIterations()}dispose(){this.accBeta1.dispose(),this.iteration.dispose(),this.accumulatedFirstMoment!=null&&$e(this.accumulatedFirstMoment.map(e=>e.variable)),this.accumulatedWeightedInfNorm!=null&&$e(this.accumulatedWeightedInfNorm.map(e=>e.variable))}async getWeights(){throw new Error("getWeights() is not implemented for Adamax yet.")}async setWeights(e){throw new Error("setWeights() is not implemented for Adamax yet.")}getConfig(){return{learningRate:this.learningRate,beta1:this.beta1,beta2:this.beta2,epsilon:this.epsilon,decay:this.decay}}static fromConfig(e,n){return new e(n.learningRate,n.beta1,n.beta2,n.epsilon,n.decay)}}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3518,7 +3518,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class gw extends Xo{static get className(){return"SGD"}constructor(e){super(),this.learningRate=e,this.setLearningRate(e)}applyGradients(e){(Array.isArray(e)?e.map(s=>s.name):Object.keys(e)).forEach((s,r)=>{const o=Array.isArray(e)?e[r].tensor:e[s];if(o==null)return;const i=_.registeredVariables[s];P(()=>{const a=J(D(this.c,o),i);i.assign(a)})}),this.incrementIterations()}setLearningRate(e){this.learningRate=e,this.c!=null&&this.c.dispose(),this.c=xr(We(-e))}dispose(){this.c.dispose()}async getWeights(){return[await this.saveIterations()]}async setWeights(e){if(e=await this.extractIterations(e),e.length!==0)throw new Error("SGD optimizer does not have settable weights.")}getConfig(){return{learningRate:this.learningRate}}static fromConfig(e,n){return new e(n.learningRate)}}/** + */class gw extends Xo{static get className(){return"SGD"}constructor(e){super(),this.learningRate=e,this.setLearningRate(e)}applyGradients(e){(Array.isArray(e)?e.map(s=>s.name):Object.keys(e)).forEach((s,r)=>{const o=Array.isArray(e)?e[r].tensor:e[s];if(o==null)return;const i=_.registeredVariables[s];P(()=>{const a=J(D(this.c,o),i);i.assign(a)})}),this.incrementIterations()}setLearningRate(e){this.learningRate=e,this.c!=null&&this.c.dispose(),this.c=yr(We(-e))}dispose(){this.c.dispose()}async getWeights(){return[await this.saveIterations()]}async setWeights(e){if(e=await this.extractIterations(e),e.length!==0)throw new Error("SGD optimizer does not have settable weights.")}getConfig(){return{learningRate:this.learningRate}}static fromConfig(e,n){return new e(n.learningRate)}}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3533,7 +3533,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class RN extends gw{static get className(){return"Momentum"}constructor(e,n,s=!1){super(e),this.learningRate=e,this.momentum=n,this.useNesterov=s,this.accumulations=[],this.m=We(this.momentum)}applyGradients(e){(Array.isArray(e)?e.map(s=>s.name):Object.keys(e)).forEach((s,r)=>{const o=_.registeredVariables[s];this.accumulations[r]==null&&(this.accumulations[r]={originalName:`${s}/momentum`,variable:P(()=>ze(o).variable(!1))});const i=this.accumulations[r].variable,a=Array.isArray(e)?e[r].tensor:e[s];a!=null&&P(()=>{let l;const c=J(D(this.m,i),a);this.useNesterov?l=J(D(this.c,J(a,D(c,this.m))),o):l=J(D(this.c,c),o),i.assign(c),o.assign(l)})}),this.incrementIterations()}dispose(){this.m.dispose(),this.accumulations!=null&&$e(this.accumulations.map(e=>e.variable))}setMomentum(e){this.momentum=e}async getWeights(){return[await this.saveIterations()].concat(this.accumulations.map(e=>({name:e.originalName,tensor:e.variable})))}async setWeights(e){e=await this.extractIterations(e);const n=!1;this.accumulations=e.map(s=>({originalName:s.name,variable:s.tensor.variable(n)}))}getConfig(){return{learningRate:this.learningRate,momentum:this.momentum,useNesterov:this.useNesterov}}static fromConfig(e,n){return new e(n.learningRate,n.momentum,n.useNesterov)}}/** + */class AN extends gw{static get className(){return"Momentum"}constructor(e,n,s=!1){super(e),this.learningRate=e,this.momentum=n,this.useNesterov=s,this.accumulations=[],this.m=We(this.momentum)}applyGradients(e){(Array.isArray(e)?e.map(s=>s.name):Object.keys(e)).forEach((s,r)=>{const o=_.registeredVariables[s];this.accumulations[r]==null&&(this.accumulations[r]={originalName:`${s}/momentum`,variable:P(()=>ze(o).variable(!1))});const i=this.accumulations[r].variable,a=Array.isArray(e)?e[r].tensor:e[s];a!=null&&P(()=>{let l;const c=J(D(this.m,i),a);this.useNesterov?l=J(D(this.c,J(a,D(c,this.m))),o):l=J(D(this.c,c),o),i.assign(c),o.assign(l)})}),this.incrementIterations()}dispose(){this.m.dispose(),this.accumulations!=null&&$e(this.accumulations.map(e=>e.variable))}setMomentum(e){this.momentum=e}async getWeights(){return[await this.saveIterations()].concat(this.accumulations.map(e=>({name:e.originalName,tensor:e.variable})))}async setWeights(e){e=await this.extractIterations(e);const n=!1;this.accumulations=e.map(s=>({originalName:s.name,variable:s.tensor.variable(n)}))}getConfig(){return{learningRate:this.learningRate,momentum:this.momentum,useNesterov:this.useNesterov}}static fromConfig(e,n){return new e(n.learningRate,n.momentum,n.useNesterov)}}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3548,7 +3548,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class AN extends Xo{static get className(){return"RMSProp"}constructor(e,n=.9,s=0,r=null,o=!1){if(super(),this.learningRate=e,this.decay=n,this.momentum=s,this.epsilon=r,this.accumulatedMeanSquares=[],this.accumulatedMoments=[],this.accumulatedMeanGrads=[],this.centered=o,r==null&&(this.epsilon=_.backend.epsilon()),e==null)throw new Error("learningRate for RMSPropOptimizer must be defined.")}applyGradients(e){(Array.isArray(e)?e.map(s=>s.name):Object.keys(e)).forEach((s,r)=>{const o=_.registeredVariables[s],i=!1;this.accumulatedMeanSquares[r]==null&&(this.accumulatedMeanSquares[r]={originalName:`${s}/rms`,variable:P(()=>ze(o).variable(i))}),this.accumulatedMoments[r]==null&&(this.accumulatedMoments[r]={originalName:`${s}/momentum`,variable:P(()=>ze(o).variable(i))}),this.accumulatedMeanGrads[r]==null&&this.centered&&(this.accumulatedMeanGrads[r]={originalName:`${s}/mg`,variable:P(()=>ze(o).variable(i))});const a=Array.isArray(e)?e[r].tensor:e[s];if(a==null)return;const l=this.accumulatedMeanSquares[r].variable,c=this.accumulatedMoments[r].variable;P(()=>{const u=J(D(l,this.decay),D(ot(a),1-this.decay));if(this.centered){const d=this.accumulatedMeanGrads[r].variable,h=J(D(d,this.decay),D(a,1-this.decay)),f=ge(D(a,this.learningRate),dn(ve(u,J(ot(h),this.epsilon)))),p=J(D(c,this.momentum),f);l.assign(u),d.assign(h),c.assign(p);const g=ve(o,p);o.assign(g)}else{const d=J(D(l,this.decay),D(ot(a),1-this.decay)),h=J(D(c,this.momentum),ge(D(a,this.learningRate),dn(J(d,this.epsilon))));l.assign(d),c.assign(h);const f=ve(o,h);o.assign(f)}})}),this.incrementIterations()}dispose(){this.accumulatedMeanSquares!=null&&$e(this.accumulatedMeanSquares.map(e=>e.variable)),this.accumulatedMeanGrads!=null&&this.centered&&$e(this.accumulatedMeanGrads.map(e=>e.variable)),this.accumulatedMoments!=null&&$e(this.accumulatedMoments.map(e=>e.variable))}async getWeights(){const e=[...this.accumulatedMeanSquares,...this.accumulatedMoments];return this.centered&&e.push(...this.accumulatedMeanGrads),[await this.saveIterations()].concat(e.map(n=>({name:n.originalName,tensor:n.variable})))}async setWeights(e){e=await this.extractIterations(e);const n=this.centered?e.length/3:e.length/2,s=!1;this.accumulatedMeanSquares=e.slice(0,n).map(r=>({originalName:r.name,variable:r.tensor.variable(s)})),this.accumulatedMoments=e.slice(n,n*2).map(r=>({originalName:r.name,variable:r.tensor.variable(s)})),this.centered&&(this.accumulatedMeanGrads=e.slice(n*2,n*3).map(r=>({originalName:r.name,variable:r.tensor.variable(s)})))}getConfig(){return{learningRate:this.learningRate,decay:this.decay,momentum:this.momentum,epsilon:this.epsilon,centered:this.centered}}static fromConfig(e,n){return new e(n.learningRate,n.decay,n.momentum,n.epsilon,n.centered)}}/** + */class DN extends Xo{static get className(){return"RMSProp"}constructor(e,n=.9,s=0,r=null,o=!1){if(super(),this.learningRate=e,this.decay=n,this.momentum=s,this.epsilon=r,this.accumulatedMeanSquares=[],this.accumulatedMoments=[],this.accumulatedMeanGrads=[],this.centered=o,r==null&&(this.epsilon=_.backend.epsilon()),e==null)throw new Error("learningRate for RMSPropOptimizer must be defined.")}applyGradients(e){(Array.isArray(e)?e.map(s=>s.name):Object.keys(e)).forEach((s,r)=>{const o=_.registeredVariables[s],i=!1;this.accumulatedMeanSquares[r]==null&&(this.accumulatedMeanSquares[r]={originalName:`${s}/rms`,variable:P(()=>ze(o).variable(i))}),this.accumulatedMoments[r]==null&&(this.accumulatedMoments[r]={originalName:`${s}/momentum`,variable:P(()=>ze(o).variable(i))}),this.accumulatedMeanGrads[r]==null&&this.centered&&(this.accumulatedMeanGrads[r]={originalName:`${s}/mg`,variable:P(()=>ze(o).variable(i))});const a=Array.isArray(e)?e[r].tensor:e[s];if(a==null)return;const l=this.accumulatedMeanSquares[r].variable,c=this.accumulatedMoments[r].variable;P(()=>{const u=J(D(l,this.decay),D(ot(a),1-this.decay));if(this.centered){const h=this.accumulatedMeanGrads[r].variable,d=J(D(h,this.decay),D(a,1-this.decay)),f=ge(D(a,this.learningRate),hn(ve(u,J(ot(d),this.epsilon)))),p=J(D(c,this.momentum),f);l.assign(u),h.assign(d),c.assign(p);const g=ve(o,p);o.assign(g)}else{const h=J(D(l,this.decay),D(ot(a),1-this.decay)),d=J(D(c,this.momentum),ge(D(a,this.learningRate),hn(J(h,this.epsilon))));l.assign(h),c.assign(d);const f=ve(o,d);o.assign(f)}})}),this.incrementIterations()}dispose(){this.accumulatedMeanSquares!=null&&$e(this.accumulatedMeanSquares.map(e=>e.variable)),this.accumulatedMeanGrads!=null&&this.centered&&$e(this.accumulatedMeanGrads.map(e=>e.variable)),this.accumulatedMoments!=null&&$e(this.accumulatedMoments.map(e=>e.variable))}async getWeights(){const e=[...this.accumulatedMeanSquares,...this.accumulatedMoments];return this.centered&&e.push(...this.accumulatedMeanGrads),[await this.saveIterations()].concat(e.map(n=>({name:n.originalName,tensor:n.variable})))}async setWeights(e){e=await this.extractIterations(e);const n=this.centered?e.length/3:e.length/2,s=!1;this.accumulatedMeanSquares=e.slice(0,n).map(r=>({originalName:r.name,variable:r.tensor.variable(s)})),this.accumulatedMoments=e.slice(n,n*2).map(r=>({originalName:r.name,variable:r.tensor.variable(s)})),this.centered&&(this.accumulatedMeanGrads=e.slice(n*2,n*3).map(r=>({originalName:r.name,variable:r.tensor.variable(s)})))}getConfig(){return{learningRate:this.learningRate,decay:this.decay,momentum:this.momentum,epsilon:this.epsilon,centered:this.centered}}static fromConfig(e,n){return new e(n.learningRate,n.decay,n.momentum,n.epsilon,n.centered)}}/** * @license * Copyright 2022 Google LLC. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3563,7 +3563,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const aU=[$N,NN,TN,EN,RN,AN,gw];function lU(){for(const t of aU)Y(t)}/** + */const lU=[NN,TN,EN,RN,AN,DN,gw];function cU(){for(const t of lU)Y(t)}/** * @license * Copyright 2019 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3593,7 +3593,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */async function cU(t,e){e==null&&(e={});const n=e.fetchFunc==null?W().platform.fetch:e.fetchFunc,s=t.map(d=>n(d,e.requestInit,{isBinary:!0})),a=(e.onProgress==null?await Promise.all(s):await FC(s,e.onProgress,0,.5)).map(d=>d.arrayBuffer());return e.onProgress==null?await Promise.all(a):await FC(a,e.onProgress,.5,1)}function uU(t,e){var n;const s=e.fetchFunc==null?W().platform.fetch:e.fetchFunc;let r=0,o;return(n=e.onProgress)===null||n===void 0||n.call(e,0),new ReadableStream({pull:async i=>{for(var a;rn(h,e.requestInit,{isBinary:!0})),a=(e.onProgress==null?await Promise.all(s):await FC(s,e.onProgress,0,.5)).map(h=>h.arrayBuffer());return e.onProgress==null?await Promise.all(a):await FC(a,e.onProgress,.5,1)}function hU(t,e){var n;const s=e.fetchFunc==null?W().platform.fetch:e.fetchFunc;let r=0,o;return(n=e.onProgress)===null||n===void 0||n.call(e,0),new ReadableStream({pull:async i=>{for(var a;r"Must pass a function that matches the signature of `fetch` (see https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API)"),this.fetch=n.fetchFunc):this.fetch=W().platform.fetch,I(e!=null&&e.length>0,()=>"URL path for http must not be null, undefined or empty."),Array.isArray(e)&&I(e.length===2,()=>`URL paths for http must have a length of 2, (actual length is ${e.length}).`),this.path=e,n.requestInit!=null&&n.requestInit.body!=null)throw new Error("requestInit is expected to have no pre-existing body, but has one.");this.requestInit=n.requestInit||{},this.loadOptions=n}async save(e){if(e.modelTopology instanceof ArrayBuffer)throw new Error("BrowserHTTPRequest.save() does not support saving model topology in binary formats yet.");const n=Object.assign({method:this.DEFAULT_METHOD},this.requestInit);n.body=new FormData;const s=[{paths:["./model.weights.bin"],weights:e.weightSpecs}],r=IP(e,s);if(n.body.append("model.json",new Blob([JSON.stringify(r)],{type:hU}),"model.json"),e.weightData!=null){const i=Uo.join(e.weightData);n.body.append("model.weights.bin",new Blob([i],{type:dU}),"model.weights.bin")}const o=await this.fetch(this.path,n);if(o.ok)return{modelArtifactsInfo:Fy(e),responses:[o]};throw new Error(`BrowserHTTPRequest.save() failed due to HTTP response status ${o.status}.`)}async loadModelJSON(){const e=await this.fetch(this.path,this.requestInit);if(!e.ok)throw new Error(`Request to ${this.path} failed with status code ${e.status}. Please verify this URL points to the model JSON of the model to load.`);let n;try{n=await e.json()}catch{let i=`Failed to parse model JSON of response from ${this.path}.`;throw this.path.endsWith(".pb")?i+=" Your path contains a .pb file extension. Support for .pb models have been removed in TensorFlow.js 1.0 in favor of .json models. You can re-convert your Python TensorFlow model using the TensorFlow.js 1.0 conversion scripts or you can convert your.pb models with the 'pb2json'NPM script in the tensorflow/tfjs-converter repository.":i+=" Please make sure the server is serving valid JSON for this request.",new Error(i)}const s=n.modelTopology,r=n.weightsManifest;if(s==null&&r==null)throw new Error(`The JSON from HTTP path ${this.path} contains neither model topology or manifest for weights.`);return n}async load(){if(this.loadOptions.streamWeights)return this.loadStream();const e=await this.loadModelJSON();return NP(e,n=>this.loadWeights(n))}async loadStream(){const e=await this.loadModelJSON(),n=await this.getWeightUrls(e.weightsManifest),s=TC(e.weightsManifest),r=()=>uU(n,this.loadOptions);return Object.assign(Object.assign({},e),{weightSpecs:s,getWeightStream:r})}async getWeightUrls(e){const n=Array.isArray(this.path)?this.path[1]:this.path,[s,r]=fU(n),o=this.weightPathPrefix||s,i=[],a=[];for(const l of e)for(const c of l.paths)this.weightUrlConverter!=null?a.push(this.weightUrlConverter(c)):i.push(o+c+r);return this.weightUrlConverter&&i.push(...await Promise.all(a)),i}async loadWeights(e){const n=await this.getWeightUrls(e),s=TC(e),r=await cU(n,this.loadOptions);return[s,r]}}xw.URL_SCHEME_REGEX=/^https?:\/\//;function fU(t){const e=t.lastIndexOf("/"),n=t.lastIndexOf("?"),s=t.substring(0,e),r=n>e?t.substring(n):"";return[s+"/",r]}function zC(t){return t.match(xw.URL_SCHEME_REGEX)!=null}const DN=(t,e)=>{if(typeof fetch>"u"&&(e==null||e.fetchFunc==null))return null;{let n=!0;if(Array.isArray(t)?n=t.every(s=>zC(s)):n=zC(t),n)return _N(t,e)}return null};Gt.registerSaveRouter(DN);Gt.registerLoadRouter(DN);function _N(t,e){return new xw(t,e)}function pU(t,e){return _N(t,e)}function yw(t,e){const n=t.shape.length,s=e.shape.length;if(n<1)throw new Error(`tf.gatherND() expects the input to be rank 1 or higher, but the rank was ${n}.`);if(s<1)throw new Error(`tf.gatherND() expects the indices to be rank 1 or higher, but the rank was ${s}.`);if(e.dtype!=="int32")throw new Error(`tf.gatherND() expects the indices to be int32 type, but the dtype was ${e.dtype}.`);if(e.shape[s-1]>n)throw new Error(`index innermost dimension length must be <= tensor rank; saw: ${e.shape[s-1]} vs. ${n}`);if(j(t.shape)===0)throw new Error(`Requested more than 0 entries, but input is empty. Input shape: ${t.shape}.`);const r=e.shape,o=r[r.length-1];let i=1;for(let d=0;dd/c),1].slice(0,o);return[l,i,c,u]}/** + */const dU="application/octet-stream",fU="application/json";class xw{constructor(e,n){if(this.DEFAULT_METHOD="POST",n==null&&(n={}),this.weightPathPrefix=n.weightPathPrefix,this.weightUrlConverter=n.weightUrlConverter,n.fetchFunc!=null?(I(typeof n.fetchFunc=="function",()=>"Must pass a function that matches the signature of `fetch` (see https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API)"),this.fetch=n.fetchFunc):this.fetch=W().platform.fetch,I(e!=null&&e.length>0,()=>"URL path for http must not be null, undefined or empty."),Array.isArray(e)&&I(e.length===2,()=>`URL paths for http must have a length of 2, (actual length is ${e.length}).`),this.path=e,n.requestInit!=null&&n.requestInit.body!=null)throw new Error("requestInit is expected to have no pre-existing body, but has one.");this.requestInit=n.requestInit||{},this.loadOptions=n}async save(e){if(e.modelTopology instanceof ArrayBuffer)throw new Error("BrowserHTTPRequest.save() does not support saving model topology in binary formats yet.");const n=Object.assign({method:this.DEFAULT_METHOD},this.requestInit);n.body=new FormData;const s=[{paths:["./model.weights.bin"],weights:e.weightSpecs}],r=$P(e,s);if(n.body.append("model.json",new Blob([JSON.stringify(r)],{type:fU}),"model.json"),e.weightData!=null){const i=Uo.join(e.weightData);n.body.append("model.weights.bin",new Blob([i],{type:dU}),"model.weights.bin")}const o=await this.fetch(this.path,n);if(o.ok)return{modelArtifactsInfo:Fy(e),responses:[o]};throw new Error(`BrowserHTTPRequest.save() failed due to HTTP response status ${o.status}.`)}async loadModelJSON(){const e=await this.fetch(this.path,this.requestInit);if(!e.ok)throw new Error(`Request to ${this.path} failed with status code ${e.status}. Please verify this URL points to the model JSON of the model to load.`);let n;try{n=await e.json()}catch{let i=`Failed to parse model JSON of response from ${this.path}.`;throw this.path.endsWith(".pb")?i+=" Your path contains a .pb file extension. Support for .pb models have been removed in TensorFlow.js 1.0 in favor of .json models. You can re-convert your Python TensorFlow model using the TensorFlow.js 1.0 conversion scripts or you can convert your.pb models with the 'pb2json'NPM script in the tensorflow/tfjs-converter repository.":i+=" Please make sure the server is serving valid JSON for this request.",new Error(i)}const s=n.modelTopology,r=n.weightsManifest;if(s==null&&r==null)throw new Error(`The JSON from HTTP path ${this.path} contains neither model topology or manifest for weights.`);return n}async load(){if(this.loadOptions.streamWeights)return this.loadStream();const e=await this.loadModelJSON();return TP(e,n=>this.loadWeights(n))}async loadStream(){const e=await this.loadModelJSON(),n=await this.getWeightUrls(e.weightsManifest),s=TC(e.weightsManifest),r=()=>hU(n,this.loadOptions);return Object.assign(Object.assign({},e),{weightSpecs:s,getWeightStream:r})}async getWeightUrls(e){const n=Array.isArray(this.path)?this.path[1]:this.path,[s,r]=pU(n),o=this.weightPathPrefix||s,i=[],a=[];for(const l of e)for(const c of l.paths)this.weightUrlConverter!=null?a.push(this.weightUrlConverter(c)):i.push(o+c+r);return this.weightUrlConverter&&i.push(...await Promise.all(a)),i}async loadWeights(e){const n=await this.getWeightUrls(e),s=TC(e),r=await uU(n,this.loadOptions);return[s,r]}}xw.URL_SCHEME_REGEX=/^https?:\/\//;function pU(t){const e=t.lastIndexOf("/"),n=t.lastIndexOf("?"),s=t.substring(0,e),r=n>e?t.substring(n):"";return[s+"/",r]}function zC(t){return t.match(xw.URL_SCHEME_REGEX)!=null}const _N=(t,e)=>{if(typeof fetch>"u"&&(e==null||e.fetchFunc==null))return null;{let n=!0;if(Array.isArray(t)?n=t.every(s=>zC(s)):n=zC(t),n)return FN(t,e)}return null};Gt.registerSaveRouter(_N);Gt.registerLoadRouter(_N);function FN(t,e){return new xw(t,e)}function mU(t,e){return FN(t,e)}function yw(t,e){const n=t.shape.length,s=e.shape.length;if(n<1)throw new Error(`tf.gatherND() expects the input to be rank 1 or higher, but the rank was ${n}.`);if(s<1)throw new Error(`tf.gatherND() expects the indices to be rank 1 or higher, but the rank was ${s}.`);if(e.dtype!=="int32")throw new Error(`tf.gatherND() expects the indices to be int32 type, but the dtype was ${e.dtype}.`);if(e.shape[s-1]>n)throw new Error(`index innermost dimension length must be <= tensor rank; saw: ${e.shape[s-1]} vs. ${n}`);if(j(t.shape)===0)throw new Error(`Requested more than 0 entries, but input is empty. Input shape: ${t.shape}.`);const r=e.shape,o=r[r.length-1];let i=1;for(let h=0;hh/c),1].slice(0,o);return[l,i,c,u]}/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3623,7 +3623,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const p1=-2,mU=-1;function ww(t,e,n){const s=t.shape.length;I(s===e.length,()=>`Error in slice${s}D: Length of begin ${e} must match the rank of the array (${s}).`),I(s===n.length,()=>`Error in slice${s}D: Length of size ${n} must match the rank of the array (${s}).`);for(let r=0;r`Error in slice${s}D: begin[${r}] + size[${r}] (${e[r]+n[r]}) would overflow input.shape[${r}] (${t.shape[r]})`)}function gU(t){const e=[];let n=0;for(;t>0;)t&1&&e.push(n),t/=2,n++;return e}function vw(t,e,n){const s=[];for(let r=0;r0){const f=e[0],p=n+1;u=MN(i,f,p,s,t),d=PN(a,f,p,r,t),h=FN(o,f,p,t)}else for(let f=0;f-1)o[a]=0;else{const l=zN(e,n,a);let c=s[l];t&1<-1)o[a]=Number.MAX_SAFE_INTEGER;else{const l=zN(e,n,a);let c=s[l];t&1<0?i=Number.MIN_SAFE_INTEGER:i=Number.MAX_SAFE_INTEGER);const l=s[r];return i<0&&(i+=l),i=Ti(0,i,l-1),i}function VN(t,e,n,s,r,o){let i=e[r];const a=n[r]||1;(t&1<0?i=Number.MAX_SAFE_INTEGER:i=Number.MIN_SAFE_INTEGER);const l=s[r];return i<0&&(i+=l),a>0?i=Ti(0,i,l):i=Ti(-1,i,l-1),i}function bw(t,e,n){let s=n.length;for(let r=0;r1){s=r;break}for(let r=s+1;r0||n[r]!==t[r])return!1;return!0}function Cw(t,e){let n=t.length>0?t[t.length-1]:1;for(let s=0;s{I(i!==-1,()=>"slice() does not support negative begin indexing.")});let o;return n==null?o=new Array(r).fill(-1):typeof n=="number"?o=[n,...new Array(r-1).fill(-1)]:n.lengthi>=0?i:(I(i===-1,()=>`Negative size values should be exactly -1 but got ${i} for the slice() size at index ${a}.`),t.shape[a]-s[a])),[s,o]}function kw(t,e,n,s,r,o,i,a,l){let c;if(s==null?(c=new Array(e.length),c.fill(1)):c=s,i!=null&&i&i-1)throw new Error("Multiple ellipses in slice is not allowed.");let u=!1;const d={dims:c.length,numAddAxisAfterEllipsis:0,begin:e.slice(),end:n.slice(),strides:c.slice(),beginMask:r,endMask:o,ellipsisMask:i,newAxisMask:a,shrinkAxisMask:l};for(let w=0;w0?0:-1,h.strides[w]>0?b:b-1];if(v&&h.strides[w]<=0)throw Error("only stride 1 allowed on non-range indexing.");g=g&&h.strides[w]===1;const S=!!(h.beginMask&1<=b)throw Error(`slice index ${h.begin[w]} of dimension ${w} out of bounds.`)}else h.begin[w]=OC(h.begin[w],0,h.strides[w],b,C,k),h.end[w]=OC(h.end[w],1,h.strides[w],b,C,k);const A=h.strides[w]===1&&h.begin[w]===0&&h.end[w]===b;f=f&&A,p=p&&(w===0&&h.strides[w]===1||A)}else f=f&&h.strides[w]===1&&S,p=p&&(w===0&&h.strides[w]===1||S);let $,N=!1;if(h.beginValid&&h.endValid?($=h.end[w]-h.begin[w],N=!0):v?($=1,N=!0):S&&b>=0&&(h.strides[w]<0?$=-b:$=b,N=!0),N){let A;$===0||$<0!=h.strides[w]<0?A=0:A=Math.trunc($/h.strides[w])+($%h.strides[w]!==0?1:0),x.push(A)}else x.push(-1)}for(let w=0;w=0?m.push(x[v]):v===p1&&m.push(1)}return{finalShapeSparse:m.filter((w,v)=>h.finalShapeGatherIndices[v]!==p1),finalShape:m,isIdentity:f,sliceDim0:p,isSimpleSlice:g,begin:h.begin,end:h.end,strides:h.strides}}function yU(t,e){e.beginMask=0,e.endMask=0,e.shrinkAxisMask=0;let n=0;e.beginValid=t.begin!=null,e.endValid=t.end!=null,e.begin=new Array(e.dims),e.end=new Array(e.dims),e.strides=new Array(e.dims),e.finalShapeGatherIndices=[],e.finalShapeGatherIndicesSparse=[],e.inputShapeGatherIndicesSparse=new Array(e.dims);for(let s=0;s0?o[e]:o[e+1&1];{const i=t<0?s+t:t;return io[1]?o[1]:i}}const wU=Object.freeze(Object.defineProperty({__proto__:null,assertParamsValid:ww,computeFlatOffset:Cw,computeOutShape:vw,getNormalizedAxes:xU,isSliceContinous:bw,maskToAxes:gU,parseSliceParams:bm,sliceInfo:kw,startForAxis:BN,startIndicesWithElidedDims:MN,stopForAxis:VN,stopIndicesWithElidedDims:PN,stridesForAxis:LN,stridesWithElidedDims:FN},Symbol.toStringTag,{value:"Module"}));/** + */const p1=-2,gU=-1;function ww(t,e,n){const s=t.shape.length;I(s===e.length,()=>`Error in slice${s}D: Length of begin ${e} must match the rank of the array (${s}).`),I(s===n.length,()=>`Error in slice${s}D: Length of size ${n} must match the rank of the array (${s}).`);for(let r=0;r`Error in slice${s}D: begin[${r}] + size[${r}] (${e[r]+n[r]}) would overflow input.shape[${r}] (${t.shape[r]})`)}function xU(t){const e=[];let n=0;for(;t>0;)t&1&&e.push(n),t/=2,n++;return e}function vw(t,e,n){const s=[];for(let r=0;r0){const f=e[0],p=n+1;u=PN(i,f,p,s,t),h=LN(a,f,p,r,t),d=zN(o,f,p,t)}else for(let f=0;f-1)o[a]=0;else{const l=ON(e,n,a);let c=s[l];t&1<-1)o[a]=Number.MAX_SAFE_INTEGER;else{const l=ON(e,n,a);let c=s[l];t&1<0?i=Number.MIN_SAFE_INTEGER:i=Number.MAX_SAFE_INTEGER);const l=s[r];return i<0&&(i+=l),i=Ti(0,i,l-1),i}function WN(t,e,n,s,r,o){let i=e[r];const a=n[r]||1;(t&1<0?i=Number.MAX_SAFE_INTEGER:i=Number.MIN_SAFE_INTEGER);const l=s[r];return i<0&&(i+=l),a>0?i=Ti(0,i,l):i=Ti(-1,i,l-1),i}function bw(t,e,n){let s=n.length;for(let r=0;r1){s=r;break}for(let r=s+1;r0||n[r]!==t[r])return!1;return!0}function Cw(t,e){let n=t.length>0?t[t.length-1]:1;for(let s=0;s{I(i!==-1,()=>"slice() does not support negative begin indexing.")});let o;return n==null?o=new Array(r).fill(-1):typeof n=="number"?o=[n,...new Array(r-1).fill(-1)]:n.lengthi>=0?i:(I(i===-1,()=>`Negative size values should be exactly -1 but got ${i} for the slice() size at index ${a}.`),t.shape[a]-s[a])),[s,o]}function kw(t,e,n,s,r,o,i,a,l){let c;if(s==null?(c=new Array(e.length),c.fill(1)):c=s,i!=null&&i&i-1)throw new Error("Multiple ellipses in slice is not allowed.");let u=!1;const h={dims:c.length,numAddAxisAfterEllipsis:0,begin:e.slice(),end:n.slice(),strides:c.slice(),beginMask:r,endMask:o,ellipsisMask:i,newAxisMask:a,shrinkAxisMask:l};for(let w=0;w0?0:-1,d.strides[w]>0?b:b-1];if(v&&d.strides[w]<=0)throw Error("only stride 1 allowed on non-range indexing.");g=g&&d.strides[w]===1;const S=!!(d.beginMask&1<=b)throw Error(`slice index ${d.begin[w]} of dimension ${w} out of bounds.`)}else d.begin[w]=OC(d.begin[w],0,d.strides[w],b,C,k),d.end[w]=OC(d.end[w],1,d.strides[w],b,C,k);const A=d.strides[w]===1&&d.begin[w]===0&&d.end[w]===b;f=f&&A,p=p&&(w===0&&d.strides[w]===1||A)}else f=f&&d.strides[w]===1&&S,p=p&&(w===0&&d.strides[w]===1||S);let $,N=!1;if(d.beginValid&&d.endValid?($=d.end[w]-d.begin[w],N=!0):v?($=1,N=!0):S&&b>=0&&(d.strides[w]<0?$=-b:$=b,N=!0),N){let A;$===0||$<0!=d.strides[w]<0?A=0:A=Math.trunc($/d.strides[w])+($%d.strides[w]!==0?1:0),x.push(A)}else x.push(-1)}for(let w=0;w=0?m.push(x[v]):v===p1&&m.push(1)}return{finalShapeSparse:m.filter((w,v)=>d.finalShapeGatherIndices[v]!==p1),finalShape:m,isIdentity:f,sliceDim0:p,isSimpleSlice:g,begin:d.begin,end:d.end,strides:d.strides}}function wU(t,e){e.beginMask=0,e.endMask=0,e.shrinkAxisMask=0;let n=0;e.beginValid=t.begin!=null,e.endValid=t.end!=null,e.begin=new Array(e.dims),e.end=new Array(e.dims),e.strides=new Array(e.dims),e.finalShapeGatherIndices=[],e.finalShapeGatherIndicesSparse=[],e.inputShapeGatherIndicesSparse=new Array(e.dims);for(let s=0;s0?o[e]:o[e+1&1];{const i=t<0?s+t:t;return io[1]?o[1]:i}}const vU=Object.freeze(Object.defineProperty({__proto__:null,assertParamsValid:ww,computeFlatOffset:Cw,computeOutShape:vw,getNormalizedAxes:yU,isSliceContinous:bw,maskToAxes:xU,parseSliceParams:bm,sliceInfo:kw,startForAxis:VN,startIndicesWithElidedDims:PN,stopForAxis:WN,stopIndicesWithElidedDims:LN,stridesForAxis:BN,stridesWithElidedDims:zN},Symbol.toStringTag,{value:"Module"}));/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3638,7 +3638,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class vU{static sgd(e){return new gw(e)}static momentum(e,n,s=!1){return new RN(e,n,s)}static rmsprop(e,n=.9,s=0,r=null,o=!1){return new AN(e,n,s,r,o)}static adam(e=.001,n=.9,s=.999,r=null){return new TN(e,n,s,r)}static adadelta(e=.001,n=.95,s=null){return new $N(e,n,s)}static adamax(e=.002,n=.9,s=.999,r=null,o=0){return new EN(e,n,s,r,o)}static adagrad(e,n=.1){return new NN(e,n)}}/** + */class bU{static sgd(e){return new gw(e)}static momentum(e,n,s=!1){return new AN(e,n,s)}static rmsprop(e,n=.9,s=0,r=null,o=!1){return new DN(e,n,s,r,o)}static adam(e=.001,n=.9,s=.999,r=null){return new EN(e,n,s,r)}static adadelta(e=.001,n=.95,s=null){return new NN(e,n,s)}static adamax(e=.002,n=.9,s=.999,r=null,o=0){return new RN(e,n,s,r,o)}static adagrad(e,n=.1){return new TN(e,n)}}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3653,7 +3653,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const ia=vU;/** + */const ia=bU;/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3668,7 +3668,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const bU=typeof requestAnimationFrame<"u"?requestAnimationFrame:typeof setImmediate<"u"?setImmediate:t=>t();function WN(){return new Promise(t=>bU(()=>t()))}/** + */const CU=typeof requestAnimationFrame<"u"?requestAnimationFrame:typeof setImmediate<"u"?setImmediate:t=>t();function UN(){return new Promise(t=>CU(()=>t()))}/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3683,7 +3683,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Sw(t,e){const n=t[0].length;t.forEach((r,o)=>{I(r.length===n,()=>`Error in concat${n}D: rank of tensors[${o}] must be the same as the rank of the rest (${n})`)}),I(e>=0&&e`Error in concat${n}D: axis must be between 0 and ${n-1}.`);const s=t[0];t.forEach((r,o)=>{for(let i=0;i`Error in concat${n}D: Shape of tensors[${o}] (${r}) does not match the shape of the rest (${s}) along the non-concatenated axis ${o}.`)})}function yr(t,e){const n=t[0].slice();for(let s=1;s{I(r.length===n,()=>`Error in concat${n}D: rank of tensors[${o}] must be the same as the rank of the rest (${n})`)}),I(e>=0&&e`Error in concat${n}D: axis must be between 0 and ${n-1}.`);const s=t[0];t.forEach((r,o)=>{for(let i=0;i`Error in concat${n}D: Shape of tensors[${o}] (${r}) does not match the shape of the rest (${s}) along the non-concatenated axis ${o}.`)})}function wr(t,e){const n=t[0].slice();for(let s=1;s=0)if(a>=0){if(a!==o)throw new Error(`rt input.shape and shape=${e} are incompatible: rt input.shape[${r+t}] = ${o} but shape[${r+t}] = ${a}`)}else s[i]=o}return s}function GN(t){const e={FIRST_DIM_SIZE:Ws.FIRST_DIM_SIZE,VALUE_ROWIDS:Ws.VALUE_ROWIDS,ROW_LENGTHS:Ws.ROW_LENGTHS,ROW_SPLITS:Ws.ROW_SPLITS,ROW_LIMITS:Ws.ROW_LIMITS,ROW_STARTS:Ws.ROW_STARTS},n=[];for(const s of t)if(s in e)n.push(e[s]);else break;return n}function HN(t){return t.length===0?0:t[0]===Ws.FIRST_DIM_SIZE?t.length-1:t.length}function jN(t,e){if(t==null||e==null)return;const n=t.length,s=e.length;if(n>=s)throw new Error(`defaultValue.shape=${t} and ragged tensor flatValues.shape=${e}, are incompatible: defaultValue.rank = ${n} must be less than ragged tensor input flatValues.rank = ${s})`);for(let r=0;r=0&&i>=0&&o!==1&&o!==i)throw new Error(`defaultValue.shape=${t}, and ragged tensor input flatValues.shape=${e} are incompatible: defaultValue.shape[${r-t.length}] = ${o} but ragged tensor input.flatValues.shape[${r-t.length}] = ${i}`)}}/** + */var Us;(function(t){t[t.FIRST_DIM_SIZE=0]="FIRST_DIM_SIZE",t[t.VALUE_ROWIDS=1]="VALUE_ROWIDS",t[t.ROW_LENGTHS=2]="ROW_LENGTHS",t[t.ROW_SPLITS=3]="ROW_SPLITS",t[t.ROW_LIMITS=4]="ROW_LIMITS",t[t.ROW_STARTS=5]="ROW_STARTS"})(Us||(Us={}));function GN(t,e,n){let s=new Array;if(n==null&&e==null)return s;if(e==null)for(;s.length=0)if(a>=0){if(a!==o)throw new Error(`rt input.shape and shape=${e} are incompatible: rt input.shape[${r+t}] = ${o} but shape[${r+t}] = ${a}`)}else s[i]=o}return s}function HN(t){const e={FIRST_DIM_SIZE:Us.FIRST_DIM_SIZE,VALUE_ROWIDS:Us.VALUE_ROWIDS,ROW_LENGTHS:Us.ROW_LENGTHS,ROW_SPLITS:Us.ROW_SPLITS,ROW_LIMITS:Us.ROW_LIMITS,ROW_STARTS:Us.ROW_STARTS},n=[];for(const s of t)if(s in e)n.push(e[s]);else break;return n}function jN(t){return t.length===0?0:t[0]===Us.FIRST_DIM_SIZE?t.length-1:t.length}function KN(t,e){if(t==null||e==null)return;const n=t.length,s=e.length;if(n>=s)throw new Error(`defaultValue.shape=${t} and ragged tensor flatValues.shape=${e}, are incompatible: defaultValue.rank = ${n} must be less than ragged tensor input flatValues.rank = ${s})`);for(let r=0;r=0&&i>=0&&o!==1&&o!==i)throw new Error(`defaultValue.shape=${t}, and ragged tensor input flatValues.shape=${e} are incompatible: defaultValue.shape[${r-t.length}] = ${o} but ragged tensor input.flatValues.shape[${r-t.length}] = ${i}`)}}/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3743,7 +3743,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function gd(t,e,n,s=!0){let r=[];if(s)r=r.concat(e.slice(0)),r.push(t[0]/n),r=r.concat(t.slice(1));else{r=r.concat(t[0]);const o=e.length;for(let i=0;i=e*2+1||i%2===1?o.push(i):r.push(i);s.push(...r),s.push(0),s.push(...o)}return s}function yd(t,e,n,s=!0){const r=[];s?r.push(t[0]/n):r.push(t[0]*n);for(let o=1;o=e*2+1||i%2===1?o.push(i):r.push(i);s.push(...r),s.push(0),s.push(...o)}return s}function yh(t,e,n,s=!0){const r=[];s?r.push(t[0]/n):r.push(t[0]*n);for(let o=1;o/g,MC=",",PC="...";function Ow(t,e){t=t.replace(/\s/g,"");const n=(t.length-t.replace(CU,"").length)/Ig.length;if(n<1)throw new Error("Equations without an arrow are not supported.");if(n>1)throw new Error(`Equation must contain exactly one arrow ("${Ig}").`);const[s,r]=t.split(Ig);I(s.indexOf(PC)===-1,()=>`The ellipsis notation ("${PC}") is not supported yet.`);const o=s.split(MC),i=o.length;if(e!==i)throw new Error(`Expected ${i} input tensors, received ${e}`);if(i>2)throw new Error("Support for more than 2 input tensors is not implemented yet.");const a=[];for(let h=0;hp.indexOf(f)!==-1))throw new Error(`Output subscripts contain the label ${f} not present in the input subscripts.`);a.indexOf(f)===-1&&a.push(f)}for(let h=0;hr!==-1),{permutationIndices:n,expandDims:s}}function Pw(t,e,n){const s=new Array(t);for(let r=0;r`Expected dimension ${s[e[r][i]]} at axis ${i} of input shaped ${JSON.stringify(o)}, but got dimension ${o[i]}`)}}function Lw(t,e){const n=t,s=[];let r=0;t.length===0&&n.push(-1),r=t.length+1;for(let i=0;ie===n)}function kU(t,e){const n=[];for(let s=0;s"Number of splits must evenly divide the axis."),s=new Array(e).fill(t.shape[n]/e);else{const r=e.reduce((i,a)=>(a===-1&&(i+=1),i),0);I(r<=1,()=>"There should be only one negative value in split array.");const o=e.indexOf(-1);if(o!==-1){const i=e.reduce((a,l)=>l>0?a+l:a);e[o]=t.shape[n]-i}I(t.shape[n]===e.reduce((i,a)=>i+a),()=>"The sum of sizes must match the size of the axis dimension."),s=e}return s}/** + */const Ig="->",kU=/->/g,MC=",",PC="...";function Ow(t,e){t=t.replace(/\s/g,"");const n=(t.length-t.replace(kU,"").length)/Ig.length;if(n<1)throw new Error("Equations without an arrow are not supported.");if(n>1)throw new Error(`Equation must contain exactly one arrow ("${Ig}").`);const[s,r]=t.split(Ig);I(s.indexOf(PC)===-1,()=>`The ellipsis notation ("${PC}") is not supported yet.`);const o=s.split(MC),i=o.length;if(e!==i)throw new Error(`Expected ${i} input tensors, received ${e}`);if(i>2)throw new Error("Support for more than 2 input tensors is not implemented yet.");const a=[];for(let d=0;dp.indexOf(f)!==-1))throw new Error(`Output subscripts contain the label ${f} not present in the input subscripts.`);a.indexOf(f)===-1&&a.push(f)}for(let d=0;dr!==-1),{permutationIndices:n,expandDims:s}}function Pw(t,e,n){const s=new Array(t);for(let r=0;r`Expected dimension ${s[e[r][i]]} at axis ${i} of input shaped ${JSON.stringify(o)}, but got dimension ${o[i]}`)}}function Lw(t,e){const n=t,s=[];let r=0;t.length===0&&n.push(-1),r=t.length+1;for(let i=0;ie===n)}function SU(t,e){const n=[];for(let s=0;s"Number of splits must evenly divide the axis."),s=new Array(e).fill(t.shape[n]/e);else{const r=e.reduce((i,a)=>(a===-1&&(i+=1),i),0);I(r<=1,()=>"There should be only one negative value in split array.");const o=e.indexOf(-1);if(o!==-1){const i=e.reduce((a,l)=>l>0?a+l:a);e[o]=t.shape[n]-i}I(t.shape[n]===e.reduce((i,a)=>i+a),()=>"The sum of sizes must match the size of the axis dimension."),s=e}return s}/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3818,8 +3818,8 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function JN(t){return`Received SparseTensor with denseShape[0] = 0 but - indices.shape[0] = ${t}`}function eT(t,e){return`indices(${t}, 0) is invalid: ${e} < 0`}function tT(t,e,n){return`indices(${t}, 0) is invalid: ${e} >= ${n}`}/** + */function eT(t){return`Received SparseTensor with denseShape[0] = 0 but + indices.shape[0] = ${t}`}function tT(t,e){return`indices(${t}, 0) is invalid: ${e} < 0`}function nT(t,e,n){return`indices(${t}, 0) is invalid: ${e} >= ${n}`}/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3834,8 +3834,8 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function nT(t,e){return`only one output dimension may be -1, not both ${t} and ${e}`}function sT(t,e){return`size ${t} must be non-negative, not ${e}`}function rT(){return"reshape cannot infer the missing input size for an empty tensor unless all specified input sizes are non-zero"}function oT(t,e){const n=j(t),s=j(e);return`Input to reshape is a SparseTensor with ${n} - dense values, but the requested shape requires a multiple of ${s}. inputShape=${t} outputShape= ${e}`}function iT(t,e){const n=j(t),s=j(e);return`Input to reshape is a tensor with ${n} dense values, but the requested shape has ${s}. inputShape=${t} outputShape=${e}`}/** + */function sT(t,e){return`only one output dimension may be -1, not both ${t} and ${e}`}function rT(t,e){return`size ${t} must be non-negative, not ${e}`}function oT(){return"reshape cannot infer the missing input size for an empty tensor unless all specified input sizes are non-zero"}function iT(t,e){const n=j(t),s=j(e);return`Input to reshape is a SparseTensor with ${n} + dense values, but the requested shape requires a multiple of ${s}. inputShape=${t} outputShape= ${e}`}function aT(t,e){const n=j(t),s=j(e);return`Input to reshape is a tensor with ${n} dense values, but the requested shape has ${s}. inputShape=${t} outputShape=${e}`}/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3850,7 +3850,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function m1(){return"segment ids must be >= 0"}function aT(){return"segment ids are not increasing"}function lT(t,e){return`Segment id ${t} out of range [0, ${e}), possibly because segmentIds input is not sorted.`}function cT(t,e,n){return`Bad: indices[${t}] == ${e} out of range [0, ${n})`}/** + */function m1(){return"segment ids must be >= 0"}function lT(){return"segment ids are not increasing"}function cT(t,e){return`Segment id ${t} out of range [0, ${e}), possibly because segmentIds input is not sorted.`}function uT(t,e,n){return`Bad: indices[${t}] == ${e} out of range [0, ${n})`}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3865,8 +3865,8 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function uT(t,e){let n=!1,s;for(t<=Iw?(s=t,n=!0):s=Q0(t,Math.floor(Math.sqrt(t)));!n;)s>e||s===t?n=!0:s=Q0(t,s+1);return s}function dT(t,e,n){const s=[],r=t.length;for(let o=0;or))throw new Error(`Expect batchDims in the range of [-${r}, ${r}], but got ${s}`);if(s<0&&(s+=r),s>o)throw new Error(`batchDims (${s}) must be less than rank(x) ( - ${o}).`);if(ne||s===t?n=!0:s=Q0(t,s+1);return s}function dT(t,e,n){const s=[],r=t.length;for(let o=0;or))throw new Error(`Expect batchDims in the range of [-${r}, ${r}], but got ${s}`);if(s<0&&(s+=r),s>o)throw new Error(`batchDims (${s}) must be less than rank(x) ( + ${o}).`);if(nDo(e))}catch(e){throw new Error(`Failed to decode encoded string bytes into utf-8, error: ${e}`)}}function hT(t){return t.map(e=>No(e))}const IU=Object.freeze(Object.defineProperty({__proto__:null,ERF_A1:Rw,ERF_A2:Aw,ERF_A3:Dw,ERF_A4:_w,ERF_A5:Fw,ERF_P:Ew,PARALLELIZE_THRESHOLD:Iw,get RowPartitionType(){return Ws},SELU_SCALE:Sm,SELU_SCALEALPHA:km,applyActivation:uw,assertAndGetBroadcastShape:Se,assertAxesAreInnerMostDims:sn,assertParamsConsistent:Sw,assignToTypedArray:YN,axesAreInnerMostDims:Vy,calculateShapes:Qi,checkEinsumDimSizes:Pw,checkPadOnDimRoundingMode:Mn,combineLocations:tN,combineRaggedTensorToTensorShapes:UN,complexWithEvenIndex:XN,complexWithOddIndex:qN,computeConv2DInfo:nn,computeConv3DInfo:Go,computeDefaultPad:zy,computeDilation2DInfo:dd,computeOptimalWindowSize:Cm,computeOutAndReduceShapes:Yt,computeOutShape:yr,computePool2DInfo:Rs,computePool3DInfo:qr,convertConv2DDataFormat:Yr,decodeEinsumEquation:Ow,eitherStridesOrDilationsAreOne:hn,expandShapeToKeepDim:Dt,exponent:ZN,exponents:QN,fromStringArrayToUint8:hT,fromUint8ToStringArray:jr,getAxesPermutation:yt,getBroadcastDims:il,getComplexWithIndex:zw,getEinsumComputePath:Lw,getEinsumPermutation:Mw,getFusedBiasGradient:cw,getFusedDyActivation:lw,getImageCenter:$w,getInnerMostAxes:$t,getPermuted:xd,getRaggedRank:HN,getReductionAxes:Vt,getReshaped:gd,getReshapedPermuted:yd,getRowPartitionTypesHelper:GN,getSliceBeginCoords:Nw,getSliceSize:Tw,getSparseFillEmptyRowsIndicesDenseShapeMismatch:JN,getSparseFillEmptyRowsNegativeIndexErrorMessage:eT,getSparseFillEmptyRowsOutOfRangeIndexErrorMessage:tT,getSparseReshapeEmptyTensorZeroOutputDimErrorMessage:rT,getSparseReshapeInputOutputMismatchErrorMessage:iT,getSparseReshapeInputOutputMultipleErrorMessage:oT,getSparseReshapeMultipleNegativeOneOutputDimErrorMessage:nT,getSparseReshapeNegativeOutputDimErrorMessage:sT,getSparseSegmentReductionIndicesOutOfRangeErrorMessage:cT,getSparseSegmentReductionNegativeSegmentIdsErrorMessage:m1,getSparseSegmentReductionNonIncreasingSegmentIdsErrorMessage:aT,getSparseSegmentReductionSegmentIdOutOfRangeErrorMessage:lT,getUndoAxesPermutation:Ho,isIdentityPermutation:Bw,log:GM,mergeRealAndImagArrays:Hr,prepareAndValidate:yw,prepareSplitSize:Vw,segment_util:SU,shouldFuse:dw,slice_util:wU,splitRealAndImagArrays:KN,stridesOrDilationsArePositive:Fi,tupleValuesAreOne:_i,upcastType:Xn,validateDefaultValueShape:jN,validateInput:YV,validateUpdateShape:vN,warn:es},Symbol.toStringTag,{value:"Module"}));/** + */function Kr(t){try{return t.map(e=>Do(e))}catch(e){throw new Error(`Failed to decode encoded string bytes into utf-8, error: ${e}`)}}function fT(t){return t.map(e=>No(e))}const $U=Object.freeze(Object.defineProperty({__proto__:null,ERF_A1:Rw,ERF_A2:Aw,ERF_A3:Dw,ERF_A4:_w,ERF_A5:Fw,ERF_P:Ew,PARALLELIZE_THRESHOLD:Iw,get RowPartitionType(){return Us},SELU_SCALE:Sm,SELU_SCALEALPHA:km,applyActivation:uw,assertAndGetBroadcastShape:Se,assertAxesAreInnerMostDims:sn,assertParamsConsistent:Sw,assignToTypedArray:QN,axesAreInnerMostDims:Vy,calculateShapes:Qi,checkEinsumDimSizes:Pw,checkPadOnDimRoundingMode:Mn,combineLocations:nN,combineRaggedTensorToTensorShapes:GN,complexWithEvenIndex:qN,complexWithOddIndex:YN,computeConv2DInfo:nn,computeConv3DInfo:Go,computeDefaultPad:zy,computeDilation2DInfo:hh,computeOptimalWindowSize:Cm,computeOutAndReduceShapes:Yt,computeOutShape:wr,computePool2DInfo:As,computePool3DInfo:Yr,convertConv2DDataFormat:Qr,decodeEinsumEquation:Ow,eitherStridesOrDilationsAreOne:dn,expandShapeToKeepDim:Dt,exponent:JN,exponents:ZN,fromStringArrayToUint8:fT,fromUint8ToStringArray:Kr,getAxesPermutation:yt,getBroadcastDims:il,getComplexWithIndex:zw,getEinsumComputePath:Lw,getEinsumPermutation:Mw,getFusedBiasGradient:cw,getFusedDyActivation:lw,getImageCenter:$w,getInnerMostAxes:$t,getPermuted:xh,getRaggedRank:jN,getReductionAxes:Vt,getReshaped:gh,getReshapedPermuted:yh,getRowPartitionTypesHelper:HN,getSliceBeginCoords:Nw,getSliceSize:Tw,getSparseFillEmptyRowsIndicesDenseShapeMismatch:eT,getSparseFillEmptyRowsNegativeIndexErrorMessage:tT,getSparseFillEmptyRowsOutOfRangeIndexErrorMessage:nT,getSparseReshapeEmptyTensorZeroOutputDimErrorMessage:oT,getSparseReshapeInputOutputMismatchErrorMessage:aT,getSparseReshapeInputOutputMultipleErrorMessage:iT,getSparseReshapeMultipleNegativeOneOutputDimErrorMessage:sT,getSparseReshapeNegativeOutputDimErrorMessage:rT,getSparseSegmentReductionIndicesOutOfRangeErrorMessage:uT,getSparseSegmentReductionNegativeSegmentIdsErrorMessage:m1,getSparseSegmentReductionNonIncreasingSegmentIdsErrorMessage:lT,getSparseSegmentReductionSegmentIdOutOfRangeErrorMessage:cT,getUndoAxesPermutation:Ho,isIdentityPermutation:Bw,log:HM,mergeRealAndImagArrays:jr,prepareAndValidate:yw,prepareSplitSize:Vw,segment_util:IU,shouldFuse:hw,slice_util:vU,splitRealAndImagArrays:XN,stridesOrDilationsArePositive:Fi,tupleValuesAreOne:_i,upcastType:Xn,validateDefaultValueShape:KN,validateInput:QV,validateUpdateShape:bN,warn:es},Symbol.toStringTag,{value:"Module"}));/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3896,7 +3896,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */lU();/** + */cU();/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3911,7 +3911,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const fT={kernelName:pp,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(t,md(le(n,"float32"),-1))}}};/** + */const pT={kernelName:pp,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(t,mh(le(n,"float32"),-1))}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3926,7 +3926,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const $U={kernelName:pu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>{const s=ot(le(n,"float32")),r=dn(ve(We(1),s));return St(ge(t,r))}}}};/** + */const NU={kernelName:pu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>{const s=ot(le(n,"float32")),r=hn(ve(We(1),s));return St(ge(t,r))}}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3941,7 +3941,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const NU={kernelName:mu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>{const s=dn(ve(ot(le(n,"float32")),1));return ge(t,s)}}}};/** + */const TU={kernelName:mu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>{const s=hn(ve(ot(le(n,"float32")),1));return ge(t,s)}}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3956,7 +3956,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const TU={kernelName:bl,inputsToSave:["a","b"],gradFunc:(t,e)=>{const[n,s]=e,r=Se(n.shape,s.shape);return{a:()=>{let a=t;const l=Vt(n.shape,r);return l.length>0&&(a=me(a,l)),F(a,n.shape)},b:()=>{let a=t;const l=Vt(s.shape,r);return l.length>0&&(a=me(a,l)),F(a,s.shape)}}}};/** + */const EU={kernelName:bl,inputsToSave:["a","b"],gradFunc:(t,e)=>{const[n,s]=e,r=Se(n.shape,s.shape);return{a:()=>{let a=t;const l=Vt(n.shape,r);return l.length>0&&(a=me(a,l)),F(a,n.shape)},b:()=>{let a=t;const l=Vt(s.shape,r);return l.length>0&&(a=me(a,l)),F(a,s.shape)}}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3971,7 +3971,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const EU={kernelName:Gx,saveAllInputs:!0,gradFunc:(t,e)=>{const n={};return e.forEach((s,r)=>{n[r]=()=>t.clone()}),n}};/** + */const RU={kernelName:Gx,saveAllInputs:!0,gradFunc:(t,e)=>{const n={};return e.forEach((s,r)=>{n[r]=()=>t.clone()}),n}};/** * @license * Copyright 2020 Google Inc. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -3986,7 +3986,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const RU={kernelName:mp,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>ze(n)}}};/** + */const AU={kernelName:mp,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>ze(n)}}};/** * @license * Copyright 2020 Google Inc. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4001,7 +4001,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const AU={kernelName:gp,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>ze(n)}}};/** + */const DU={kernelName:gp,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>ze(n)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4016,7 +4016,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const DU={kernelName:gu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>ge(t,dn(ve(We(1),ot(le(n,"float32")))))}}};/** + */const _U={kernelName:gu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>ge(t,hn(ve(We(1),ot(le(n,"float32")))))}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4031,7 +4031,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const _U={kernelName:xu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>{const s=dn(J(We(1),ot(le(n,"float32"))));return ge(t,s)}}}};/** + */const FU={kernelName:xu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>{const s=hn(J(We(1),ot(le(n,"float32"))));return ge(t,s)}}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4046,7 +4046,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const FU={kernelName:vu,inputsToSave:["a","b"],gradFunc:(t,e)=>{const[n,s]=e,r=Se(n.shape,s.shape);return{a:()=>{const a=J(ot(n),ot(s));let l=D(t,ge(s,a));const c=Vt(n.shape,r);return c.length>0&&(l=me(l,c)),F(l,n.shape)},b:()=>{const a=J(ot(n),ot(s));let l=St(D(t,ge(n,a)));const c=Vt(s.shape,r);return c.length>0&&(l=me(l,c)),F(l,s.shape)}}}};/** + */const zU={kernelName:vu,inputsToSave:["a","b"],gradFunc:(t,e)=>{const[n,s]=e,r=Se(n.shape,s.shape);return{a:()=>{const a=J(ot(n),ot(s));let l=D(t,ge(s,a));const c=Vt(n.shape,r);return c.length>0&&(l=me(l,c)),F(l,n.shape)},b:()=>{const a=J(ot(n),ot(s));let l=St(D(t,ge(n,a)));const c=Vt(s.shape,r);return c.length>0&&(l=me(l,c)),F(l,s.shape)}}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4061,7 +4061,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const zU={kernelName:yu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>ge(t,J(ot(le(n,"float32")),1))}}};/** + */const OU={kernelName:yu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>ge(t,J(ot(le(n,"float32")),1))}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4076,7 +4076,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const OU={kernelName:wu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>ge(t,ve(We(1),ot(le(n,"float32"))))}}};/** + */const MU={kernelName:wu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>ge(t,ve(We(1),ot(le(n,"float32"))))}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4091,7 +4091,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function MU(t,e,n,s,r,o){const i=T(t,"dy","avgPool3dGrad"),a=T(e,"input","avgPool3dGrad");let l=i,c=a,u=!1;a.rank===4&&(u=!0,l=F(i,[1,i.shape[0],i.shape[1],i.shape[2],i.shape[3]]),c=F(a,[1,a.shape[0],a.shape[1],a.shape[2],a.shape[3]])),I(l.rank===5,()=>`Error in avgPool3dGrad: dy must be rank 5 but got rank ${l.rank}.`),I(c.rank===5,()=>`Error in avgPool3dGrad: input must be rank 5 but got rank ${c.rank}.`),Mn("avgPool3dGrad",r,o);const d={dy:l,input:c},h={filterSize:n,strides:s,pad:r,dimRoundingMode:o},f=_.runKernel(Xx,d,h);return u?F(f,[f.shape[1],f.shape[2],f.shape[3],f.shape[4]]):f}const PU=z({avgPool3dGrad_:MU});/** + */function PU(t,e,n,s,r,o){const i=T(t,"dy","avgPool3dGrad"),a=T(e,"input","avgPool3dGrad");let l=i,c=a,u=!1;a.rank===4&&(u=!0,l=F(i,[1,i.shape[0],i.shape[1],i.shape[2],i.shape[3]]),c=F(a,[1,a.shape[0],a.shape[1],a.shape[2],a.shape[3]])),I(l.rank===5,()=>`Error in avgPool3dGrad: dy must be rank 5 but got rank ${l.rank}.`),I(c.rank===5,()=>`Error in avgPool3dGrad: input must be rank 5 but got rank ${c.rank}.`),Mn("avgPool3dGrad",r,o);const h={dy:l,input:c},d={filterSize:n,strides:s,pad:r,dimRoundingMode:o},f=_.runKernel(Xx,h,d);return u?F(f,[f.shape[1],f.shape[2],f.shape[3],f.shape[4]]):f}const LU=z({avgPool3dGrad_:PU});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4106,7 +4106,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const LU={kernelName:yp,inputsToSave:["x"],gradFunc:(t,e,n)=>{const[s]=e,{filterSize:r,strides:o,pad:i,dimRoundingMode:a}=n;return{x:()=>PU(t,s,r,o,i,a)}}};/** + */const BU={kernelName:yp,inputsToSave:["x"],gradFunc:(t,e,n)=>{const[s]=e,{filterSize:r,strides:o,pad:i,dimRoundingMode:a}=n;return{x:()=>LU(t,s,r,o,i,a)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4121,7 +4121,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function BU(t,e,n,s,r){const o=T(t,"dy","avgPoolGrad"),i=T(e,"input","avgPoolGrad");I(i.rank===o.rank,()=>`Rank of input (${i.rank}) does not match rank of dy (${o.rank})`);let a=i,l=o,c=!1;i.rank===3&&(c=!0,a=F(i,[1,i.shape[0],i.shape[1],i.shape[2]]),l=F(o,[1,o.shape[0],o.shape[1],o.shape[2]])),I(l.rank===4,()=>`Error in avgPoolGrad: dy must be rank 4 but got rank ${l.rank}.`),I(a.rank===4,()=>`Error in avgPoolGrad: input must be rank 4 but got rank ${a.rank}.`);const u={dy:l,input:a},d={filterSize:n,strides:s,pad:r},h=_.runKernel(Kx,u,d);return c?F(h,[h.shape[1],h.shape[2],h.shape[3]]):h}const VU=z({avgPoolGrad_:BU});/** + */function VU(t,e,n,s,r){const o=T(t,"dy","avgPoolGrad"),i=T(e,"input","avgPoolGrad");I(i.rank===o.rank,()=>`Rank of input (${i.rank}) does not match rank of dy (${o.rank})`);let a=i,l=o,c=!1;i.rank===3&&(c=!0,a=F(i,[1,i.shape[0],i.shape[1],i.shape[2]]),l=F(o,[1,o.shape[0],o.shape[1],o.shape[2]])),I(l.rank===4,()=>`Error in avgPoolGrad: dy must be rank 4 but got rank ${l.rank}.`),I(a.rank===4,()=>`Error in avgPoolGrad: input must be rank 4 but got rank ${a.rank}.`);const u={dy:l,input:a},h={filterSize:n,strides:s,pad:r},d=_.runKernel(Kx,u,h);return c?F(d,[d.shape[1],d.shape[2],d.shape[3]]):d}const WU=z({avgPoolGrad_:VU});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4136,7 +4136,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const WU={kernelName:xp,inputsToSave:["x"],gradFunc:(t,e,n)=>{const[s]=e,{filterSize:r,strides:o,pad:i}=n;return{x:()=>VU(t,s,r,o,i)}}};/** + */const UU={kernelName:xp,inputsToSave:["x"],gradFunc:(t,e,n)=>{const[s]=e,{filterSize:r,strides:o,pad:i}=n;return{x:()=>WU(t,s,r,o,i)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4151,7 +4151,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const UU={kernelName:wp,inputsToSave:["a","b"],gradFunc:(t,e,n)=>{const[s,r]=e,{transposeA:o,transposeB:i}=n;return!o&&!i?{a:()=>Ve(t,r,!1,!0),b:()=>Ve(s,t,!0,!1)}:!o&&i?{a:()=>Ve(t,r,!1,!1),b:()=>Ve(t,s,!0,!1)}:o&&!i?{a:()=>Ve(r,t,!1,!0),b:()=>Ve(s,t,!1,!1)}:{a:()=>Ve(r,t,!0,!0),b:()=>Ve(t,s,!0,!0)}}};/** + */const GU={kernelName:wp,inputsToSave:["a","b"],gradFunc:(t,e,n)=>{const[s,r]=e,{transposeA:o,transposeB:i}=n;return!o&&!i?{a:()=>Ve(t,r,!1,!0),b:()=>Ve(s,t,!0,!1)}:!o&&i?{a:()=>Ve(t,r,!1,!1),b:()=>Ve(t,s,!0,!1)}:o&&!i?{a:()=>Ve(r,t,!1,!0),b:()=>Ve(s,t,!1,!1)}:{a:()=>Ve(r,t,!0,!0),b:()=>Ve(t,s,!0,!0)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4166,7 +4166,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const GU={kernelName:vp,gradFunc:(t,e,n)=>{const{blockShape:s,crops:r}=n;return{x:()=>qy(t,s,r)}}};/** + */const HU={kernelName:vp,gradFunc:(t,e,n)=>{const{blockShape:s,crops:r}=n;return{x:()=>qy(t,s,r)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4181,7 +4181,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const HU={kernelName:BM,gradFunc:(t,e,n)=>{const s=n,r=s.inputShape,o=s.shape,i=Array.from(o);for(let l=r.length-1;l>=0;l--)if(r[l]===o[l])i[l]=1;else if(r[l]!==1)throw new Error(`broadcastTo(): [${r}] cannot be broadcast to [${o}].`);const a=[];for(let l=0;l1&&a.push(l);return{x:()=>me(t,a,!0)}}};/** + */const jU={kernelName:VM,gradFunc:(t,e,n)=>{const s=n,r=s.inputShape,o=s.shape,i=Array.from(o);for(let l=r.length-1;l>=0;l--)if(r[l]===o[l])i[l]=1;else if(r[l]!==1)throw new Error(`broadcastTo(): [${r}] cannot be broadcast to [${o}].`);const a=[];for(let l=0;l1&&a.push(l);return{x:()=>me(t,a,!0)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4196,7 +4196,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const jU={kernelName:bu,gradFunc:t=>({x:()=>t.clone()})};/** + */const KU={kernelName:bu,gradFunc:t=>({x:()=>t.clone()})};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4211,7 +4211,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const KU={kernelName:Cu,gradFunc:t=>({x:()=>ze(t)})};/** + */const XU={kernelName:Cu,gradFunc:t=>({x:()=>ze(t)})};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4226,7 +4226,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const XU={kernelName:ku,inputsToSave:["x"],gradFunc:(t,e,n)=>{const[s]=e,{clipValueMin:r,clipValueMax:o}=n;return{x:()=>Cn(Ur(Xi(s,r),kl(s,o)),t,ze(t))}}};/** + */const qU={kernelName:ku,inputsToSave:["x"],gradFunc:(t,e,n)=>{const[s]=e,{clipValueMin:r,clipValueMax:o}=n;return{x:()=>Cn(Gr(Xi(s,r),kl(s,o)),t,ze(t))}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4241,7 +4241,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const qU={kernelName:bp,inputsToSave:["x"],gradFunc:fT.gradFunc};/** + */const YU={kernelName:bp,inputsToSave:["x"],gradFunc:pT.gradFunc};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4256,7 +4256,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const YU={kernelName:Cp,saveAllInputs:!0,gradFunc:(t,e,n)=>{const s=e.map(l=>l.shape),{axis:r}=n,o=Re(r,e[0].shape)[0],i=s.map(l=>l[o]);return rs(t,i,o).map(l=>()=>l)}};/** + */const QU={kernelName:Cp,saveAllInputs:!0,gradFunc:(t,e,n)=>{const s=e.map(l=>l.shape),{axis:r}=n,o=Re(r,e[0].shape)[0],i=s.map(l=>l[o]);return rs(t,i,o).map(l=>()=>l)}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4271,7 +4271,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const QU={kernelName:kp,inputsToSave:["x","filter"],gradFunc:(t,e,n)=>{const[s,r]=e,{dilations:o,strides:i,pad:a,dataFormat:l}=n;return I(_i(o),()=>`Error in gradient of conv2D: dilation rates greater than 1 are not yet supported in gradients. Got dilations '${o}'`),{x:()=>Py(s.shape,t,r,i,a,l),filter:()=>aw(s,t,r.shape,i,a,l)}}};/** + */const ZU={kernelName:kp,inputsToSave:["x","filter"],gradFunc:(t,e,n)=>{const[s,r]=e,{dilations:o,strides:i,pad:a,dataFormat:l}=n;return I(_i(o),()=>`Error in gradient of conv2D: dilation rates greater than 1 are not yet supported in gradients. Got dilations '${o}'`),{x:()=>Py(s.shape,t,r,i,a,l),filter:()=>aw(s,t,r.shape,i,a,l)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4286,7 +4286,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const ZU={kernelName:Sp,inputsToSave:["dy","filter"],gradFunc:(t,e,n)=>{const[s,r]=e,{strides:o,pad:i,dataFormat:a,dimRoundingMode:l}=n;return{dy:()=>zi(t,r,o,i,a,1,l),filter:()=>aw(t,s,r.shape,o,i,a,l)}}};/** + */const JU={kernelName:Sp,inputsToSave:["dy","filter"],gradFunc:(t,e,n)=>{const[s,r]=e,{strides:o,pad:i,dataFormat:a,dimRoundingMode:l}=n;return{dy:()=>zi(t,r,o,i,a,1,l),filter:()=>aw(t,s,r.shape,o,i,a,l)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4301,7 +4301,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function JU(t,e,n,s,r){let o=t;t.rank===4&&(o=F(t,[1,t.shape[0],t.shape[1],t.shape[2],t.shape[3]]));let i=e;i.rank===4&&(i=F(e,[1,e.shape[0],e.shape[1],e.shape[2],e.shape[3]])),I(o.rank===5,()=>`Error in conv3dDerFilter: input must be rank 5, but got shape ${o.shape}.`),I(i.rank===5,()=>`Error in conv3dDerFilter: dy must be rank 5, but got shape ${i.shape}.`),I(n.length===5,()=>`Error in conv3dDerFilter: filterShape must be length 5, but got ${n}.`),I(o.shape[4]===n[3],()=>`Error in conv3dDerFilter: depth of input ${o.shape[4]}) must match input depth in filter (${n[3]}.`),I(i.shape[4]===n[4],()=>`Error in conv3dDerFilter: depth of dy (${i.shape[4]}) must match output depth for filter (${n[4]}).`);const a={x:o,dy:i},l={strides:s,pad:r,filterShape:n};return _.runKernel(Jx,a,l)}const eG=z({conv3DBackpropFilter_:JU});/** + */function eG(t,e,n,s,r){let o=t;t.rank===4&&(o=F(t,[1,t.shape[0],t.shape[1],t.shape[2],t.shape[3]]));let i=e;i.rank===4&&(i=F(e,[1,e.shape[0],e.shape[1],e.shape[2],e.shape[3]])),I(o.rank===5,()=>`Error in conv3dDerFilter: input must be rank 5, but got shape ${o.shape}.`),I(i.rank===5,()=>`Error in conv3dDerFilter: dy must be rank 5, but got shape ${i.shape}.`),I(n.length===5,()=>`Error in conv3dDerFilter: filterShape must be length 5, but got ${n}.`),I(o.shape[4]===n[3],()=>`Error in conv3dDerFilter: depth of input ${o.shape[4]}) must match input depth in filter (${n[3]}.`),I(i.shape[4]===n[4],()=>`Error in conv3dDerFilter: depth of dy (${i.shape[4]}) must match output depth for filter (${n[4]}).`);const a={x:o,dy:i},l={strides:s,pad:r,filterShape:n};return _.runKernel(Jx,a,l)}const tG=z({conv3DBackpropFilter_:eG});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4316,7 +4316,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const tG={kernelName:Ip,inputsToSave:["x","filter"],gradFunc:(t,e,n)=>{const{dilations:s,strides:r,pad:o}=n;I(_i(s),()=>`Error in gradient of conv3D: dilation rates greater than 1 are not yet supported in gradients. Got dilations '${s}'`);const[i,a]=e;return{x:()=>Q$(i.shape,t,a,r,o),filter:()=>eG(i,t,a.shape,r,o)}}};/** + */const nG={kernelName:Ip,inputsToSave:["x","filter"],gradFunc:(t,e,n)=>{const{dilations:s,strides:r,pad:o}=n;I(_i(s),()=>`Error in gradient of conv3D: dilation rates greater than 1 are not yet supported in gradients. Got dilations '${s}'`);const[i,a]=e;return{x:()=>Z$(i.shape,t,a,r,o),filter:()=>tG(i,t,a.shape,r,o)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4331,7 +4331,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const nG={kernelName:Su,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(St(gN(le(n,"float32"))),t)}}};/** + */const sG={kernelName:Su,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(St(xN(le(n,"float32"))),t)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4346,7 +4346,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const sG={kernelName:Iu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(xN(le(n,"float32")),t)}}};/** + */const rG={kernelName:Iu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(yN(le(n,"float32")),t)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4361,7 +4361,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const rG={kernelName:$p,inputsToSave:["x"],gradFunc:(t,e,n)=>{const[s]=e,{axis:r,exclusive:o,reverse:i}=n;return{x:()=>{const a=yt([r],s.rank);let l=J$(t,r,o,!i);return a!=null&&(l=Fe(l,a)),l}}}};/** + */const oG={kernelName:$p,inputsToSave:["x"],gradFunc:(t,e,n)=>{const[s]=e,{axis:r,exclusive:o,reverse:i}=n;return{x:()=>{const a=yt([r],s.rank);let l=eN(t,r,o,!i);return a!=null&&(l=Fe(l,a)),l}}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4376,7 +4376,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const oG={kernelName:Np,inputsToSave:["x","filter"],gradFunc:(t,e,n)=>{const{dilations:s,strides:r,pad:o,dimRoundingMode:i}=n,a=s??[1,1];I(_i(a),()=>`Error in gradient of depthwiseConv2dNative: dilation rates greater than 1 are not yet supported. Got dilations '${a}'`);const[l,c]=e;return I(l.rank===4,()=>`Error in gradient of depthwiseConv2dNative: input must be rank 4, but got rank ${l.rank}.`),I(c.rank===4,()=>`Error in gradient of depthwiseConv2dNative: filter must be rank 4, but got rank ${c.rank}.`),I(l.shape[3]===c.shape[2],()=>`Error in gradient of depthwiseConv2d: number of input channels (${l.shape[3]}) must match the inChannels dimension in filter ${c.shape[2]}.`),I(hn(r,a),()=>`Error in gradient of depthwiseConv2d: Either strides or dilations must be 1. Got strides ${r} and dilations '${a}'.`),Mn("depthwiseConv2d",o,i),{x:()=>mW(l.shape,t,c,r,o,a,i),filter:()=>fW(l,t,c.shape,r,o,a,i)}}};/** + */const iG={kernelName:Np,inputsToSave:["x","filter"],gradFunc:(t,e,n)=>{const{dilations:s,strides:r,pad:o,dimRoundingMode:i}=n,a=s??[1,1];I(_i(a),()=>`Error in gradient of depthwiseConv2dNative: dilation rates greater than 1 are not yet supported. Got dilations '${a}'`);const[l,c]=e;return I(l.rank===4,()=>`Error in gradient of depthwiseConv2dNative: input must be rank 4, but got rank ${l.rank}.`),I(c.rank===4,()=>`Error in gradient of depthwiseConv2dNative: filter must be rank 4, but got rank ${c.rank}.`),I(l.shape[3]===c.shape[2],()=>`Error in gradient of depthwiseConv2d: number of input channels (${l.shape[3]}) must match the inChannels dimension in filter ${c.shape[2]}.`),I(dn(r,a),()=>`Error in gradient of depthwiseConv2d: Either strides or dilations must be 1. Got strides ${r} and dilations '${a}'.`),Mn("depthwiseConv2d",o,i),{x:()=>gW(l.shape,t,c,r,o,a,i),filter:()=>pW(l,t,c.shape,r,o,a,i)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4391,7 +4391,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const iG={kernelName:Tp,inputsToSave:["x","filter"],gradFunc:(t,e,n)=>{const[s,r]=e,o={x:s,filter:r,dy:t},i={x:s,filter:r,dy:t};return{x:()=>_.runKernel(Z0,o,n),filter:()=>_.runKernel(J0,i,n)}}};/** + */const aG={kernelName:Tp,inputsToSave:["x","filter"],gradFunc:(t,e,n)=>{const[s,r]=e,o={x:s,filter:r,dy:t},i={x:s,filter:r,dy:t};return{x:()=>_.runKernel(Z0,o,n),filter:()=>_.runKernel(J0,i,n)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4406,7 +4406,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const aG={kernelName:Nu,outputsToSave:[!0],gradFunc:(t,e)=>{const[n]=e,s={dy:t,y:n};return{x:()=>_.runKernel(ly,s)}}};/** + */const lG={kernelName:Nu,outputsToSave:[!0],gradFunc:(t,e)=>{const[n]=e,s={dy:t,y:n};return{x:()=>_.runKernel(ly,s)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4421,7 +4421,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const lG={kernelName:Tu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e,s=D(kr(St(ot(n))),2/Math.sqrt(Math.PI));return{x:()=>D(t,s)}}};/** + */const cG={kernelName:Tu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e,s=D(Sr(St(ot(n))),2/Math.sqrt(Math.PI));return{x:()=>D(t,s)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4436,7 +4436,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const cG={kernelName:Eu,outputsToSave:[!0],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(t,n)}}};/** + */const uG={kernelName:Eu,outputsToSave:[!0],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(t,n)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4451,7 +4451,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const uG={kernelName:Rp,inputsToSave:["input"],gradFunc:(t,e)=>{const[n]=e;return{input:()=>F(t,n.shape)}}};/** + */const hG={kernelName:Rp,inputsToSave:["input"],gradFunc:(t,e)=>{const[n]=e;return{input:()=>F(t,n.shape)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4466,7 +4466,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const dG={kernelName:Ru,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(t,kr(n))}}};/** + */const dG={kernelName:Ru,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(t,Sr(n))}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4481,7 +4481,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const hG={kernelName:Au,gradFunc:t=>({x:()=>ze(t)})};/** + */const fG={kernelName:Au,gradFunc:t=>({x:()=>ze(t)})};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4496,7 +4496,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const fG={kernelName:Du,inputsToSave:["a","b"],gradFunc:(t,e)=>{const[n,s]=e,r=Se(n.shape,s.shape);return{a:()=>{const a=ge(t,le(s,"float32")),l=Vt(n.shape,r);return l.length>0?F(me(a,l),n.shape):a},b:()=>{let a=D(t,le(n,"float32"));const l=Vt(s.shape,r);l.length>0&&(a=F(me(a,l),s.shape));const c=ot(s);return St(ge(a,le(c,"float32")))}}}};/** + */const pG={kernelName:Du,inputsToSave:["a","b"],gradFunc:(t,e)=>{const[n,s]=e,r=Se(n.shape,s.shape);return{a:()=>{const a=ge(t,le(s,"float32")),l=Vt(n.shape,r);return l.length>0?F(me(a,l),n.shape):a},b:()=>{let a=D(t,le(n,"float32"));const l=Vt(s.shape,r);l.length>0&&(a=F(me(a,l),s.shape));const c=ot(s);return St(ge(a,le(c,"float32")))}}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4511,7 +4511,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const pG={kernelName:Ap,inputsToSave:["x","mean","variance","scale"],gradFunc:(t,e,n)=>{const{varianceEpsilon:s}=n,[r,o,i,a]=e,l=a??We(1),c=Vt(o.shape,r.shape),u=[];if(o.rank===1){for(let v=0;vo.rank===1?F(D(D(t,Gs(F(f,[1,1,1,o.shape[0]]),u)),l),r.shape):F(D(D(t,f),l),r.shape),mean:()=>{let v=D(D(f,We(-1)),h);return o.rank===1&&(v=me(v,c)),F(v,o.shape)},variance:()=>{let v=D(D(p,d),h);return o.rank===1&&(v=me(v,c)),F(v,o.shape)},scale:()=>{const v=D(d,f);let b=D(t,v);return o.rank===1&&(b=me(b,c)),F(b,o.shape)},offset:()=>{let v=t;return o.rank===1&&(v=me(v,c)),F(v,o.shape)}}}};/** + */const mG={kernelName:Ap,inputsToSave:["x","mean","variance","scale"],gradFunc:(t,e,n)=>{const{varianceEpsilon:s}=n,[r,o,i,a]=e,l=a??We(1),c=Vt(o.shape,r.shape),u=[];if(o.rank===1){for(let v=0;vo.rank===1?F(D(D(t,Hs(F(f,[1,1,1,o.shape[0]]),u)),l),r.shape):F(D(D(t,f),l),r.shape),mean:()=>{let v=D(D(f,We(-1)),d);return o.rank===1&&(v=me(v,c)),F(v,o.shape)},variance:()=>{let v=D(D(p,h),d);return o.rank===1&&(v=me(v,c)),F(v,o.shape)},scale:()=>{const v=D(h,f);let b=D(t,v);return o.rank===1&&(b=me(b,c)),F(b,o.shape)},offset:()=>{let v=t;return o.rank===1&&(v=me(v,c)),F(v,o.shape)}}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4526,7 +4526,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const mG={kernelName:Dp,inputsToSave:["x","indices"],gradFunc:(t,e,n)=>{const[s,r]=e,{axis:o,batchDims:i}=n,a=Re(o,s.shape)[0],l=(c,u,d)=>()=>{const h=c.shape,f=u.size,p=h.slice(0,a),g=p.length,x=h.slice(o,h.length).slice(1),m=x.length,y=LC(0,g),w=LC(g+1,g+1+m),v=BC([p,[f],x]),b=F(d,v),C=F(u,[f]),k=BC([[g],y,w]),S=Fe(b,k);let $=CN(S,C,c.shape[a]);const N=Ho(k);return $=Fe($,N),$};if(i===1){const c=s.shape[0],u=s.split(c,0);return{x:()=>Gr(u.map((f,p)=>l(f,r.slice(p,1),t.slice(p,1))())).reshape(s.shape),indices:()=>r}}else return{x:l(s,r,t),indices:()=>r}}};function LC(t,e){const n=[];for(let s=t;s{const[s,r]=e,{axis:o,batchDims:i}=n,a=Re(o,s.shape)[0],l=(c,u,h)=>()=>{const d=c.shape,f=u.size,p=d.slice(0,a),g=p.length,x=d.slice(o,d.length).slice(1),m=x.length,y=LC(0,g),w=LC(g+1,g+1+m),v=BC([p,[f],x]),b=F(h,v),C=F(u,[f]),k=BC([[g],y,w]),S=Fe(b,k);let $=kN(S,C,c.shape[a]);const N=Ho(k);return $=Fe($,N),$};if(i===1){const c=s.shape[0],u=s.split(c,0);return{x:()=>Hr(u.map((f,p)=>l(f,r.slice(p,1),t.slice(p,1))())).reshape(s.shape),indices:()=>r}}else return{x:l(s,r,t),indices:()=>r}}};function LC(t,e){const n=[];for(let s=t;s{const[n,s]=e;return{a:()=>ze(n),b:()=>ze(s)}}};/** + */const xG={kernelName:_u,inputsToSave:["a","b"],gradFunc:(t,e)=>{const[n,s]=e;return{a:()=>ze(n),b:()=>ze(s)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4556,7 +4556,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const xG={kernelName:Fu,gradFunc:t=>({x:()=>le(t,"float32")})};/** + */const yG={kernelName:Fu,gradFunc:t=>({x:()=>le(t,"float32")})};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4571,7 +4571,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const yG={kernelName:zu,gradFunc:t=>({x:()=>ze(t)})};/** + */const wG={kernelName:zu,gradFunc:t=>({x:()=>ze(t)})};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4586,7 +4586,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const wG={kernelName:Ou,gradFunc:t=>({x:()=>ze(t)})};/** + */const vG={kernelName:Ou,gradFunc:t=>({x:()=>ze(t)})};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4601,7 +4601,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const vG={kernelName:Mu,gradFunc:t=>({x:()=>ze(t)})};/** + */const bG={kernelName:Mu,gradFunc:t=>({x:()=>ze(t)})};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4616,7 +4616,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const bG={kernelName:Fp,inputsToSave:["x"],gradFunc:(t,e,n)=>{const[s]=e,{alpha:r}=n,o=us(s,0);return{x:()=>Cn(o,t,D(t,r))}}};/** + */const CG={kernelName:Fp,inputsToSave:["x"],gradFunc:(t,e,n)=>{const[s]=e,{alpha:r}=n,o=us(s,0);return{x:()=>Cn(o,t,D(t,r))}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4631,7 +4631,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const CG={kernelName:Lu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>ge(t,J(n,1))}}};/** + */const kG={kernelName:Lu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>ge(t,J(n,1))}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4646,7 +4646,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const kG={kernelName:Pu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>ge(t,le(n,"float32"))}}};/** + */const SG={kernelName:Pu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>ge(t,le(n,"float32"))}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4661,7 +4661,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const SG={kernelName:WM,inputsToSave:[],outputsToSave:[!0],gradFunc:(t,e,n)=>{const[s]=e,{axis:r}=n;return{logits:()=>{const i=kr(s);return ve(t,D(me(t,r,!0),i))}}}};/** + */const IG={kernelName:UM,inputsToSave:[],outputsToSave:[!0],gradFunc:(t,e,n)=>{const[s]=e,{axis:r}=n;return{logits:()=>{const i=Sr(s);return ve(t,D(me(t,r,!0),i))}}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4676,7 +4676,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function IG(t,e,n,s=5,r=1,o=1,i=.5){const a={x:t,y:e,dy:n},l={depthRadius:s,bias:r,alpha:o,beta:i};return _.runKernel(py,a,l)}const $G=z({localResponseNormalizationBackprop_:IG});/** + */function $G(t,e,n,s=5,r=1,o=1,i=.5){const a={x:t,y:e,dy:n},l={depthRadius:s,bias:r,alpha:o,beta:i};return _.runKernel(py,a,l)}const NG=z({localResponseNormalizationBackprop_:$G});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4691,7 +4691,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const NG={kernelName:Bp,inputsToSave:["x"],outputsToSave:[!0],gradFunc:(t,e,n)=>{const[s,r]=e,{depthRadius:o,bias:i,alpha:a,beta:l}=n;return{x:()=>$G(s,r,t,o,i,a,l)}}};/** + */const TG={kernelName:Bp,inputsToSave:["x"],outputsToSave:[!0],gradFunc:(t,e,n)=>{const[s,r]=e,{depthRadius:o,bias:i,alpha:a,beta:l}=n;return{x:()=>NG(s,r,t,o,i,a,l)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4706,7 +4706,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function pT(t,e,n,s){return e.rankD(t,le(Cr(n,e),t.dtype))}}/** + */function mT(t,e,n,s){return e.rankD(t,le(kr(n,e),t.dtype))}}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4721,7 +4721,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const VC={kernelName:Vp,inputsToSave:["x"],outputsToSave:[!0],gradFunc:(t,e,n)=>{const s=n,{reductionIndices:r}=s,o=e[0],i=e[1],a=Re(r,o.shape),l=pT(t,i,o,a);return{x:()=>l.x()}}};/** + */const VC={kernelName:Vp,inputsToSave:["x"],outputsToSave:[!0],gradFunc:(t,e,n)=>{const s=n,{reductionIndices:r}=s,o=e[0],i=e[1],a=Re(r,o.shape),l=mT(t,i,o,a);return{x:()=>l.x()}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4736,7 +4736,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const TG={kernelName:Bu,inputsToSave:["a","b"],gradFunc:(t,e)=>{const[n,s]=e;return{a:()=>D(t,le(Xi(n,s),"float32")),b:()=>D(t,le(vf(n,s),"float32"))}}};/** + */const EG={kernelName:Bu,inputsToSave:["a","b"],gradFunc:(t,e)=>{const[n,s]=e;return{a:()=>D(t,le(Xi(n,s),"float32")),b:()=>D(t,le(vf(n,s),"float32"))}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4751,7 +4751,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function EG(t,e,n,s,r,o,i){const a=T(t,"dy","maxPool3dGrad"),l=T(e,"input","maxPool3dGrad"),c=T(n,"output","maxPool3dGrad");let u=a,d=l,h=c,f=!1;l.rank===4&&(f=!0,u=F(a,[1,a.shape[0],a.shape[1],a.shape[2],a.shape[3]]),d=F(l,[1,l.shape[0],l.shape[1],l.shape[2],l.shape[3]]),h=F(c,[1,c.shape[0],c.shape[1],c.shape[2],c.shape[3]])),I(u.rank===5,()=>`Error in maxPool3dGrad: dy must be rank 5 but got rank ${u.rank}.`),I(d.rank===5,()=>`Error in maxPool3dGrad: input must be rank 5 but got rank ${d.rank}.`),I(h.rank===5,()=>`Error in maxPool3dGrad: output must be rank 5 but got rank ${h.rank}.`),Mn("maxPool3dGrad",o,i);const p={dy:u,input:d,output:h},g={filterSize:s,strides:r,pad:o,dimRoundingMode:i},x=_.runKernel(gy,p,g);return f?F(x,[x.shape[1],x.shape[2],x.shape[3],x.shape[4]]):x}const RG=z({maxPool3dGrad_:EG});/** + */function RG(t,e,n,s,r,o,i){const a=T(t,"dy","maxPool3dGrad"),l=T(e,"input","maxPool3dGrad"),c=T(n,"output","maxPool3dGrad");let u=a,h=l,d=c,f=!1;l.rank===4&&(f=!0,u=F(a,[1,a.shape[0],a.shape[1],a.shape[2],a.shape[3]]),h=F(l,[1,l.shape[0],l.shape[1],l.shape[2],l.shape[3]]),d=F(c,[1,c.shape[0],c.shape[1],c.shape[2],c.shape[3]])),I(u.rank===5,()=>`Error in maxPool3dGrad: dy must be rank 5 but got rank ${u.rank}.`),I(h.rank===5,()=>`Error in maxPool3dGrad: input must be rank 5 but got rank ${h.rank}.`),I(d.rank===5,()=>`Error in maxPool3dGrad: output must be rank 5 but got rank ${d.rank}.`),Mn("maxPool3dGrad",o,i);const p={dy:u,input:h,output:d},g={filterSize:s,strides:r,pad:o,dimRoundingMode:i},x=_.runKernel(gy,p,g);return f?F(x,[x.shape[1],x.shape[2],x.shape[3],x.shape[4]]):x}const AG=z({maxPool3dGrad_:RG});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4766,7 +4766,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const AG={kernelName:Up,inputsToSave:["x"],outputsToSave:[!0],gradFunc:(t,e,n)=>{const[s,r]=e,{filterSize:o,strides:i,pad:a,dimRoundingMode:l}=n;return{x:()=>RG(t,s,r,o,i,a,l)}}};/** + */const DG={kernelName:Up,inputsToSave:["x"],outputsToSave:[!0],gradFunc:(t,e,n)=>{const[s,r]=e,{filterSize:o,strides:i,pad:a,dimRoundingMode:l}=n;return{x:()=>AG(t,s,r,o,i,a,l)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4781,7 +4781,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function DG(t,e,n,s,r,o,i){const a=T(t,"dy","maxPoolGrad"),l=T(e,"input","maxPoolGrad"),c=T(n,"output","maxPoolGrad");I(l.rank===a.rank,()=>`Rank of input (${l.rank}) does not match rank of dy (${a.rank})`),I(a.rank===4,()=>`Error in maxPoolGrad: dy must be rank 4 but got rank ${a.rank}.`),I(l.rank===4,()=>`Error in maxPoolGrad: input must be rank 4 but got rank ${l.rank}.`),Mn("maxPoolGrad",o,i);const u={dy:a,input:l,output:c},d={filterSize:s,strides:r,pad:o,dimRoundingMode:i};return _.runKernel(my,u,d)}const _G=z({maxPoolGrad_:DG});/** + */function _G(t,e,n,s,r,o,i){const a=T(t,"dy","maxPoolGrad"),l=T(e,"input","maxPoolGrad"),c=T(n,"output","maxPoolGrad");I(l.rank===a.rank,()=>`Rank of input (${l.rank}) does not match rank of dy (${a.rank})`),I(a.rank===4,()=>`Error in maxPoolGrad: dy must be rank 4 but got rank ${a.rank}.`),I(l.rank===4,()=>`Error in maxPoolGrad: input must be rank 4 but got rank ${l.rank}.`),Mn("maxPoolGrad",o,i);const u={dy:a,input:l,output:c},h={filterSize:s,strides:r,pad:o,dimRoundingMode:i};return _.runKernel(my,u,h)}const FG=z({maxPoolGrad_:_G});/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4796,7 +4796,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const FG={kernelName:Wp,inputsToSave:["x"],outputsToSave:[!0],gradFunc:(t,e,n)=>{const[s,r]=e,{filterSize:o,strides:i,pad:a}=n;return{x:()=>_G(t,s,r,o,i,a)}}};/** + */const zG={kernelName:Wp,inputsToSave:["x"],outputsToSave:[!0],gradFunc:(t,e,n)=>{const[s,r]=e,{filterSize:o,strides:i,pad:a}=n;return{x:()=>FG(t,s,r,o,i,a)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4811,7 +4811,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const zG={kernelName:Gp,inputsToSave:["x"],gradFunc:(t,e,n)=>{const[s]=e,{axis:r}=n,o=Re(r,s.shape),a=Yt(s.shape,o)[1],l=j(a);return{x:()=>{const u=s.shape.slice();o.forEach(f=>{u[f]=1});const d=F(t,u);return ge(D(d,Ko(s.shape,"float32")),l)}}}};/** + */const OG={kernelName:Gp,inputsToSave:["x"],gradFunc:(t,e,n)=>{const[s]=e,{axis:r}=n,o=Re(r,s.shape),a=Yt(s.shape,o)[1],l=j(a);return{x:()=>{const u=s.shape.slice();o.forEach(f=>{u[f]=1});const h=F(t,u);return ge(D(h,Ko(s.shape,"float32")),l)}}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4826,7 +4826,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const OG={kernelName:Hp,inputsToSave:["x"],outputsToSave:[!0],gradFunc:(t,e,n)=>{const s=n,{axis:r}=s,[o,i]=e,a=Re(r,o.shape),l=pT(t,i,o,a);return{x:()=>l.x()}}};/** + */const MG={kernelName:Hp,inputsToSave:["x"],outputsToSave:[!0],gradFunc:(t,e,n)=>{const s=n,{axis:r}=s,[o,i]=e,a=Re(r,o.shape),l=mT(t,i,o,a);return{x:()=>l.x()}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4841,7 +4841,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const MG={kernelName:Vu,inputsToSave:["a","b"],gradFunc:(t,e)=>{const[n,s]=e;return{a:()=>D(t,le(kl(n,s),"float32")),b:()=>D(t,le(us(n,s),"float32"))}}};/** + */const PG={kernelName:Vu,inputsToSave:["a","b"],gradFunc:(t,e)=>{const[n,s]=e;return{a:()=>D(t,le(kl(n,s),"float32")),b:()=>D(t,le(us(n,s),"float32"))}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4856,7 +4856,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const PG={kernelName:jp,inputsToSave:["x"],gradFunc:(t,e,n)=>{const s=e[0],{paddings:r}=n,o=r.map(i=>i[0]);return{x:()=>tt(t,o,s.shape)}}};/** + */const LG={kernelName:jp,inputsToSave:["x"],gradFunc:(t,e,n)=>{const s=e[0],{paddings:r}=n,o=r.map(i=>i[0]);return{x:()=>tt(t,o,s.shape)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4871,7 +4871,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const LG={kernelName:Wu,inputsToSave:["a","b"],gradFunc:(t,e)=>{const[n,s]=e,r=Se(n.shape,s.shape);return{a:()=>{const a=Vt(n.shape,r);return a.length>0?F(me(t,a),n.shape):t},b:()=>{const a=D(t,St(vm(ge(n,s)))),l=Vt(s.shape,r);return l.length>0?F(me(a,l),s.shape):a}}}};/** + */const BG={kernelName:Wu,inputsToSave:["a","b"],gradFunc:(t,e)=>{const[n,s]=e,r=Se(n.shape,s.shape);return{a:()=>{const a=Vt(n.shape,r);return a.length>0?F(me(t,a),n.shape):t},b:()=>{const a=D(t,St(vm(ge(n,s)))),l=Vt(s.shape,r);return l.length>0?F(me(a,l),s.shape):a}}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4886,7 +4886,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const BG={kernelName:Uu,inputsToSave:["a","b"],gradFunc:(t,e)=>{const[n,s]=e,r=Se(n.shape,s.shape);return{a:()=>{const a=D(t,le(s,"float32")),l=Vt(n.shape,r);return l.length>0?F(me(a,l),n.shape):a},b:()=>{const a=D(t,le(n,"float32")),l=Vt(s.shape,r);return l.length>0?F(me(a,l),s.shape):a}}}};/** + */const VG={kernelName:Uu,inputsToSave:["a","b"],gradFunc:(t,e)=>{const[n,s]=e,r=Se(n.shape,s.shape);return{a:()=>{const a=D(t,le(s,"float32")),l=Vt(n.shape,r);return l.length>0?F(me(a,l),n.shape):a},b:()=>{const a=D(t,le(n,"float32")),l=Vt(s.shape,r);return l.length>0?F(me(a,l),s.shape):a}}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4901,7 +4901,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const VG={kernelName:Kp,gradFunc:t=>({x:()=>St(t)})};/** + */const WG={kernelName:Kp,gradFunc:t=>({x:()=>St(t)})};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4916,7 +4916,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const WG={kernelName:Yp,inputsToSave:["indices"],gradFunc:(t,e)=>{const n=e[0];return{indices:()=>Kt(n.shape,"float32")}}};/** + */const UG={kernelName:Yp,inputsToSave:["indices"],gradFunc:(t,e)=>{const n=e[0];return{indices:()=>Kt(n.shape,"float32")}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4931,7 +4931,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const UG={kernelName:qp,gradFunc:t=>({x:()=>ze(t)})};/** + */const GG={kernelName:qp,gradFunc:t=>({x:()=>ze(t)})};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4946,7 +4946,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const GG={kernelName:Qp,saveAllInputs:!0,gradFunc:(t,e,n)=>{const{axis:s}=n;return Pi(t,s).map(o=>()=>o)}};/** + */const HG={kernelName:Qp,saveAllInputs:!0,gradFunc:(t,e,n)=>{const{axis:s}=n;return Pi(t,s).map(o=>()=>o)}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4976,7 +4976,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const HG={kernelName:Gu,inputsToSave:["a","b"],outputsToSave:[!0],gradFunc:(t,e)=>{const[n,s,r]=e,o=n,i=s,a=Se(o.shape,i.shape);return{a:()=>{const u=le(i,"float32");let d=D(t,D(u,Oi(o,ve(u,We(1)))));const h=Vt(o.shape,a);return h.length>0&&(d=me(d,h)),F(d,o.shape)},b:()=>{const u=us(o,0),d=Cn(u,Sr(o),ze(o));let h=D(t,D(r,d));const f=Vt(i.shape,a);return f.length>0&&(h=me(h,f)),F(h,i.shape)}}}};/** + */const jG={kernelName:Gu,inputsToSave:["a","b"],outputsToSave:[!0],gradFunc:(t,e)=>{const[n,s,r]=e,o=n,i=s,a=Se(o.shape,i.shape);return{a:()=>{const u=le(i,"float32");let h=D(t,D(u,Oi(o,ve(u,We(1)))));const d=Vt(o.shape,a);return d.length>0&&(h=me(h,d)),F(h,o.shape)},b:()=>{const u=us(o,0),h=Cn(u,Ir(o),ze(o));let d=D(t,D(r,h));const f=Vt(i.shape,a);return f.length>0&&(d=me(d,f)),F(d,i.shape)}}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -4991,7 +4991,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const jG={kernelName:Jp,inputsToSave:["x","alpha"],gradFunc:(t,e)=>{const[n,s]=e,r=us(n,0);return{x:()=>Cn(r,t,D(t,s)),alpha:()=>{let o=Cn(r,ze(t),D(t,n));const i=Vt(s.shape,t.shape);return i.length>0&&(o=me(o,i)),F(o,s.shape)}}}};/** + */const KG={kernelName:Jp,inputsToSave:["x","alpha"],gradFunc:(t,e)=>{const[n,s]=e,r=us(n,0);return{x:()=>Cn(r,t,D(t,s)),alpha:()=>{let o=Cn(r,ze(t),D(t,n));const i=Vt(s.shape,t.shape);return i.length>0&&(o=me(o,i)),F(o,s.shape)}}}};/** * @license * Copyright 2022 Google Inc. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5006,7 +5006,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function KG(t,e,n){const s=t.shape.slice();s[n]=1;const r=F(e,s),o=h1(t,n,!0,!1),i=h1(t,n,!0,!0),a=D(o,i);return D(r,a)}function XG(t,e,n){const s=t.shape.length,r=s-n.length,o=yt(n,s);let i=t;o!=null&&(i=Fe(t,o));const a=i.shape.slice(),c=a.splice(s-n.length,n.length).reduce((h,f)=>h*f,1);a.push(c);const u=i.reshape(a);let d=KG(u,e,r);if(d=d.reshape(i.shape),o!=null){const h=Ho(o);d=Fe(d,h)}return d}const qG={kernelName:em,inputsToSave:["x"],gradFunc:(t,e,n)=>{const[s]=e,{axis:r}=n;let o=[];return r==null?o=s.shape.map((i,a)=>a):typeof r=="number"?o=[r]:o=r,{x:()=>XG(s,t,o)}}};/** + */function XG(t,e,n){const s=t.shape.slice();s[n]=1;const r=F(e,s),o=d1(t,n,!0,!1),i=d1(t,n,!0,!0),a=D(o,i);return D(r,a)}function qG(t,e,n){const s=t.shape.length,r=s-n.length,o=yt(n,s);let i=t;o!=null&&(i=Fe(t,o));const a=i.shape.slice(),c=a.splice(s-n.length,n.length).reduce((d,f)=>d*f,1);a.push(c);const u=i.reshape(a);let h=XG(u,e,r);if(h=h.reshape(i.shape),o!=null){const d=Ho(o);h=Fe(h,d)}return h}const YG={kernelName:em,inputsToSave:["x"],gradFunc:(t,e,n)=>{const[s]=e,{axis:r}=n;let o=[];return r==null?o=s.shape.map((i,a)=>a):typeof r=="number"?o=[r]:o=r,{x:()=>qG(s,t,o)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5021,7 +5021,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const YG={kernelName:$u,inputsToSave:["a","b"],gradFunc:(t,e)=>{const[n,s]=e,r=Se(n.shape,s.shape);return{a:()=>{const a=ge(t,le(s,"float32")),l=Vt(n.shape,r);return l.length>0?F(me(a,l),n.shape):a},b:()=>{let a=D(t,le(n,"float32"));const l=Vt(s.shape,r);l.length>0&&(a=F(me(a,l),s.shape));const c=ot(s);return St(ge(a,le(c,"float32")))}}}};/** + */const QG={kernelName:$u,inputsToSave:["a","b"],gradFunc:(t,e)=>{const[n,s]=e,r=Se(n.shape,s.shape);return{a:()=>{const a=ge(t,le(s,"float32")),l=Vt(n.shape,r);return l.length>0?F(me(a,l),n.shape):a},b:()=>{let a=D(t,le(n,"float32"));const l=Vt(s.shape,r);l.length>0&&(a=F(me(a,l),s.shape));const c=ot(s);return St(ge(a,le(c,"float32")))}}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5036,7 +5036,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const QG={kernelName:Hu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>ge(t,St(ot(n)))}}};/** + */const ZG={kernelName:Hu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>ge(t,St(ot(n)))}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5051,7 +5051,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const ZG={kernelName:Ku,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e,s=D(kl(n,6),md(n));return{x:()=>D(t,le(s,"float32"))}}};/** + */const JG={kernelName:Ku,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e,s=D(kl(n,6),mh(n));return{x:()=>D(t,le(s,"float32"))}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5066,7 +5066,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const JG={kernelName:ju,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(t,le(md(n),"float32"))}}};/** + */const e6={kernelName:ju,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(t,le(mh(n),"float32"))}}};/** * @license * Copyright 2020 Google Inc. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5081,7 +5081,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const e6={kernelName:tm,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>F(t,n.shape)}}};/** + */const t6={kernelName:tm,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>F(t,n.shape)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5096,7 +5096,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const t6={kernelName:sm,inputsToSave:["images"],gradFunc:(t,e,n)=>{const[s]=e,r={dy:t,images:s};return{images:()=>_.runKernel(ky,r,n)}}};/** + */const n6={kernelName:sm,inputsToSave:["images"],gradFunc:(t,e,n)=>{const[s]=e,r={dy:t,images:s};return{images:()=>_.runKernel(ky,r,n)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5111,7 +5111,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const n6={kernelName:nm,inputsToSave:["images"],gradFunc:(t,e,n)=>{const[s]=e,r={dy:t,images:s};return{images:()=>_.runKernel(Cy,r,n)}}};/** + */const s6={kernelName:nm,inputsToSave:["images"],gradFunc:(t,e,n)=>{const[s]=e,r={dy:t,images:s};return{images:()=>_.runKernel(Cy,r,n)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5126,7 +5126,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const s6={kernelName:rm,gradFunc:(t,e,n)=>{const{dims:s}=n,r=Re(s,t.shape);return{x:()=>Mi(t,r)}}};/** + */const r6={kernelName:rm,gradFunc:(t,e,n)=>{const{dims:s}=n,r=Re(s,t.shape);return{x:()=>Mi(t,r)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5141,7 +5141,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const r6={kernelName:Xu,gradFunc:t=>({x:()=>ze(t)})};/** + */const o6={kernelName:Xu,gradFunc:t=>({x:()=>ze(t)})};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5156,7 +5156,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const o6={kernelName:qu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>St(ge(t,D(Oi(n,1.5),2)))}}};/** + */const i6={kernelName:qu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>St(ge(t,D(Oi(n,1.5),2)))}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5171,7 +5171,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const i6={kernelName:om,inputsToSave:["condition"],gradFunc:(t,e)=>{const[n]=e;return{condition:()=>le(ze(n),"float32"),t:()=>D(t,le(n,t.dtype)),e:()=>D(t,le(Hy(n),t.dtype))}}};/** + */const a6={kernelName:om,inputsToSave:["condition"],gradFunc:(t,e)=>{const[n]=e;return{condition:()=>le(ze(n),"float32"),t:()=>D(t,le(n,t.dtype)),e:()=>D(t,le(Hy(n),t.dtype))}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5186,7 +5186,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const a6={kernelName:Yu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>{const s=us(n,We(0)),r=We(km),o=We(Sm),i=D(t,o),a=D(D(t,r),kr(le(n,"float32")));return Cn(s,i,a)}}}};/** + */const l6={kernelName:Yu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>{const s=us(n,We(0)),r=We(km),o=We(Sm),i=D(t,o),a=D(D(t,r),Sr(le(n,"float32")));return Cn(s,i,a)}}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5201,7 +5201,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const l6={kernelName:ed,outputsToSave:[!0],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(t,D(n,ve(We(1),n)))}}};/** + */const c6={kernelName:eh,outputsToSave:[!0],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(t,D(n,ve(We(1),n)))}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5216,7 +5216,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const c6={kernelName:Ju,gradFunc:t=>({x:()=>ze(t)})};/** + */const u6={kernelName:Ju,gradFunc:t=>({x:()=>ze(t)})};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5231,7 +5231,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const u6={kernelName:Qu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(Ly(le(n,"float32")),t)}}};/** + */const h6={kernelName:Qu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(Ly(le(n,"float32")),t)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5246,7 +5246,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const d6={kernelName:Zu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(Z$(le(n,"float32")),t)}}};/** + */const d6={kernelName:Zu,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(J$(le(n,"float32")),t)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5261,7 +5261,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const h6={kernelName:im,inputsToSave:["x"],gradFunc:(t,e,n)=>{const[s]=e,{begin:r,size:o}=n,i=s.shape,[a,l]=bm(s,r,o),c=[];for(let u=0;uXy(t,c)}}};/** + */const f6={kernelName:im,inputsToSave:["x"],gradFunc:(t,e,n)=>{const[s]=e,{begin:r,size:o}=n,i=s.shape,[a,l]=bm(s,r,o),c=[];for(let u=0;uXy(t,c)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5276,7 +5276,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const f6={kernelName:um,outputsToSave:[!0],gradFunc:(t,e,n)=>{const[s]=e,{dim:r}=n,o=!0,i=D(t,s);return{logits:()=>ve(i,D(me(i,[r],o),s))}}};/** + */const p6={kernelName:um,outputsToSave:[!0],gradFunc:(t,e,n)=>{const[s]=e,{dim:r}=n,o=!0,i=D(t,s);return{logits:()=>ve(i,D(me(i,[r],o),s))}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5291,7 +5291,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const p6={kernelName:td,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(t,Cl(n))}}};/** + */const m6={kernelName:th,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(t,Cl(n))}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5336,7 +5336,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const m6={kernelName:nd,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>ge(t,D(dn(le(n,"float32")),2))}}};/** + */const g6={kernelName:nh,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>ge(t,D(hn(le(n,"float32")),2))}}};/** * @license * Copyright 2019 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5351,7 +5351,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const g6={kernelName:Sy,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(t,D(le(n,"float32"),2))}}};/** + */const x6={kernelName:Sy,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(t,D(le(n,"float32"),2))}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5366,7 +5366,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const x6={kernelName:sd,inputsToSave:["a","b"],gradFunc:(t,e)=>{const[n,s]=e,r=We(2);return{a:()=>D(t,D(r,ve(n,s))),b:()=>D(t,D(r,ve(s,n)))}}};/** + */const y6={kernelName:sh,inputsToSave:["a","b"],gradFunc:(t,e)=>{const[n,s]=e,r=We(2);return{a:()=>D(t,D(r,ve(n,s))),b:()=>D(t,D(r,ve(s,n)))}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5381,7 +5381,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const y6={kernelName:ld,gradFunc:t=>({x:()=>ze(t)})};/** + */const w6={kernelName:lh,gradFunc:t=>({x:()=>ze(t)})};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5396,7 +5396,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const w6={kernelName:rd,inputsToSave:["a","b"],gradFunc:(t,e)=>{const[n,s]=e,r=Se(n.shape,s.shape);return{a:()=>{let a=t;const l=Vt(n.shape,r);return l.length>0&&(a=me(a,l)),F(a,n.shape)},b:()=>{let a=t;const l=Vt(s.shape,r);return l.length>0&&(a=me(a,l)),F(St(a),s.shape)}}}};/** + */const v6={kernelName:rh,inputsToSave:["a","b"],gradFunc:(t,e)=>{const[n,s]=e,r=Se(n.shape,s.shape);return{a:()=>{let a=t;const l=Vt(n.shape,r);return l.length>0&&(a=me(a,l)),F(a,n.shape)},b:()=>{let a=t;const l=Vt(s.shape,r);return l.length>0&&(a=me(a,l)),F(St(a),s.shape)}}}};/** * @license * Copyright 2020 Google Inc. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5411,7 +5411,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const v6={kernelName:am,inputsToSave:["x"],gradFunc:(t,e,n)=>{const[s]=e,r=s.shape.slice(),{axis:o}=n;Re(o,s.shape).forEach(c=>{r[c]=1});const a=F(t,r),l=D(a,Ko(s.shape,"float32"));return{x:()=>l}}};/** + */const b6={kernelName:am,inputsToSave:["x"],gradFunc:(t,e,n)=>{const[s]=e,r=s.shape.slice(),{axis:o}=n;Re(o,s.shape).forEach(c=>{r[c]=1});const a=F(t,r),l=D(a,Ko(s.shape,"float32"));return{x:()=>l}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5426,7 +5426,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const b6={kernelName:od,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>ge(t,ot(Ly(n)))}}};/** + */const C6={kernelName:oh,inputsToSave:["x"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>ge(t,ot(Ly(n)))}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5441,7 +5441,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const C6={kernelName:id,outputsToSave:[!0],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(ve(We(1),ot(n)),t)}}};/** + */const k6={kernelName:ih,outputsToSave:[!0],gradFunc:(t,e)=>{const[n]=e;return{x:()=>D(ve(We(1),ot(n)),t)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5456,7 +5456,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const k6={kernelName:ad,inputsToSave:["x"],gradFunc:(t,e,n)=>{const[s]=e,{reps:r}=n;return{x:()=>{let i=ze(s);if(s.rank===1)for(let a=0;a{const[s]=e,{reps:r}=n;return{x:()=>{let i=ze(s);if(s.rank===1)for(let a=0;a{const s=n,{perm:r}=s,o=Ho(r);return{x:()=>Fe(t,o)}}};/** + */const I6={kernelName:Ma,gradFunc:(t,e,n)=>{const s=n,{perm:r}=s,o=Ho(r);return{x:()=>Fe(t,o)}}};/** * @license * Copyright 2020 Google Inc. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5486,7 +5486,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const I6={kernelName:dm,gradFunc:(t,e,n)=>{const s=n,{axis:r}=s;return{value:()=>Gr(t,r)}}};/** + */const $6={kernelName:hm,gradFunc:(t,e,n)=>{const s=n,{axis:r}=s;return{value:()=>Hr(t,r)}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5501,7 +5501,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const $6={kernelName:hm,inputsToSave:["segmentIds"],gradFunc:(t,e)=>{const[n]=e;return{x:()=>N6(t,n)}}};function N6(t,e){const n=jo(e,ze(e)),s=Wy(t,n);let r=Xi(e,We(0,"int32"));const o=s.rank-r.rank;for(let a=0;a{const[n]=e;return{x:()=>T6(t,n)}}};function T6(t,e){const n=jo(e,ze(e)),s=Wy(t,n);let r=Xi(e,We(0,"int32"));const o=s.rank-r.rank;for(let a=0;a({x:()=>ze(t)})};/** + */const E6={kernelName:fm,gradFunc:t=>({x:()=>ze(t)})};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5531,7 +5531,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const E6=[fT,$U,NU,TU,EU,RU,AU,DU,_U,FU,zU,OU,LU,WU,UU,GU,HU,jU,KU,XU,qU,YU,ZU,QU,tG,nG,sG,rG,oG,iG,YG,aG,lG,cG,uG,dG,fG,hG,pG,mG,gG,xG,yG,wG,vG,bG,CG,kG,SG,NG,VC,VC,TG,AG,FG,zG,OG,MG,PG,LG,BG,VG,WG,UG,GG,WC,WC,HG,jG,qG,QG,ZG,JG,e6,t6,n6,s6,r6,o6,i6,a6,l6,c6,u6,d6,h6,f6,p6,UC,UC,GC,GC,m6,x6,g6,y6,w6,v6,b6,C6,k6,S6,I6,$6,T6];for(const t of E6)HM(t);/** + */const R6=[pT,NU,TU,EU,RU,AU,DU,_U,FU,zU,OU,MU,BU,UU,GU,HU,jU,KU,XU,qU,YU,QU,JU,ZU,nG,sG,rG,oG,iG,aG,QG,lG,cG,uG,hG,dG,pG,fG,mG,gG,xG,yG,wG,vG,bG,CG,kG,SG,IG,TG,VC,VC,EG,DG,zG,OG,MG,PG,LG,BG,VG,WG,UG,GG,HG,WC,WC,jG,KG,YG,ZG,JG,e6,t6,n6,s6,r6,o6,i6,a6,l6,c6,u6,h6,d6,f6,p6,m6,UC,UC,GC,GC,g6,y6,x6,w6,v6,b6,C6,k6,S6,I6,$6,N6,E6];for(const t of R6)jM(t);/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5561,7 +5561,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.acos=function(){return this.throwIfDisposed(),rL(this)};/** + */H().prototype.acos=function(){return this.throwIfDisposed(),oL(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5576,7 +5576,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.acosh=function(){return this.throwIfDisposed(),iL(this)};/** + */H().prototype.acosh=function(){return this.throwIfDisposed(),aL(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5606,7 +5606,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.all=function(t,e){return this.throwIfDisposed(),X$(this,t,e)};/** + */H().prototype.all=function(t,e){return this.throwIfDisposed(),q$(this,t,e)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5771,7 +5771,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.asin=function(){return this.throwIfDisposed(),fL(this)};/** + */H().prototype.asin=function(){return this.throwIfDisposed(),pL(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5786,7 +5786,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.asinh=function(){return this.throwIfDisposed(),mL(this)};/** + */H().prototype.asinh=function(){return this.throwIfDisposed(),gL(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5801,7 +5801,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.atan=function(){return this.throwIfDisposed(),xL(this)};/** + */H().prototype.atan=function(){return this.throwIfDisposed(),yL(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5816,7 +5816,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.atan2=function(t){return this.throwIfDisposed(),wL(this,t)};/** + */H().prototype.atan2=function(t){return this.throwIfDisposed(),vL(this,t)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5831,7 +5831,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.atanh=function(){return this.throwIfDisposed(),bL(this)};H().prototype.avgPool=function(t,e,n,s){return this.throwIfDisposed(),Oy(this,t,e,n,s)};/** + */H().prototype.atanh=function(){return this.throwIfDisposed(),CL(this)};H().prototype.avgPool=function(t,e,n,s){return this.throwIfDisposed(),Oy(this,t,e,n,s)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5906,7 +5906,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.ceil=function(){return this.throwIfDisposed(),XL(this)};/** + */H().prototype.ceil=function(){return this.throwIfDisposed(),qL(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5951,7 +5951,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.conv1d=function(t,e,n,s,r,o){return this.throwIfDisposed(),q$(this,t,e,n,s,r,o)};/** + */H().prototype.conv1d=function(t,e,n,s,r,o){return this.throwIfDisposed(),Y$(this,t,e,n,s,r,o)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -5966,7 +5966,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.conv2dTranspose=function(t,e,n,s,r){return this.throwIfDisposed(),Y$(this,t,e,n,s,r)};/** + */H().prototype.conv2dTranspose=function(t,e,n,s,r){return this.throwIfDisposed(),Q$(this,t,e,n,s,r)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6011,7 +6011,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.cosh=function(){return this.throwIfDisposed(),Z$(this)};/** + */H().prototype.cosh=function(){return this.throwIfDisposed(),J$(this)};/** * @license * Copyright 2022 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the 'License'); @@ -6026,7 +6026,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.cumprod=function(t,e,n){return this.throwIfDisposed(),h1(this,t,e,n)};/** + */H().prototype.cumprod=function(t,e,n){return this.throwIfDisposed(),d1(this,t,e,n)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6041,7 +6041,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.cumsum=function(t,e,n){return this.throwIfDisposed(),J$(this,t,e,n)};/** + */H().prototype.cumsum=function(t,e,n){return this.throwIfDisposed(),eN(this,t,e,n)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6056,7 +6056,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.depthToSpace=function(t,e){return this.throwIfDisposed(),w4(this,t,e)};/** + */H().prototype.depthToSpace=function(t,e){return this.throwIfDisposed(),v4(this,t,e)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6086,7 +6086,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.dilation2d=function(t,e,n,s,r){return this.throwIfDisposed(),C4(this,t,e,n,s,r)};/** + */H().prototype.dilation2d=function(t,e,n,s,r){return this.throwIfDisposed(),k4(this,t,e,n,s,r)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6101,7 +6101,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.divNoNan=function(t){return this.throwIfDisposed(),N4(this,t)};/** + */H().prototype.divNoNan=function(t){return this.throwIfDisposed(),T4(this,t)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6131,7 +6131,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.dot=function(t){return this.throwIfDisposed(),E4(this,t)};/** + */H().prototype.dot=function(t){return this.throwIfDisposed(),R4(this,t)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6161,7 +6161,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.equal=function(t){return this.throwIfDisposed(),Cr(this,t)};/** + */H().prototype.equal=function(t){return this.throwIfDisposed(),kr(this,t)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6176,7 +6176,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.erf=function(){return this.throwIfDisposed(),eN(this)};/** + */H().prototype.erf=function(){return this.throwIfDisposed(),tN(this)};/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6191,7 +6191,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.euclideanNorm=function(t,e){return this.throwIfDisposed(),V4(this,t,e)};/** + */H().prototype.euclideanNorm=function(t,e){return this.throwIfDisposed(),W4(this,t,e)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6206,7 +6206,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.exp=function(){return this.throwIfDisposed(),kr(this)};/** + */H().prototype.exp=function(){return this.throwIfDisposed(),Sr(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6236,7 +6236,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.expm1=function(){return this.throwIfDisposed(),H4(this)};/** + */H().prototype.expm1=function(){return this.throwIfDisposed(),j4(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6251,7 +6251,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.fft=function(){return this.throwIfDisposed(),wN(this)};/** + */H().prototype.fft=function(){return this.throwIfDisposed(),vN(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6296,7 +6296,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.floorDiv=function(t){return this.throwIfDisposed(),K$(this,t)};/** + */H().prototype.floorDiv=function(t){return this.throwIfDisposed(),X$(this,t)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6371,7 +6371,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.irfft=function(){return this.throwIfDisposed(),OV(this)};/** + */H().prototype.irfft=function(){return this.throwIfDisposed(),MV(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6386,7 +6386,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.isFinite=function(){return this.throwIfDisposed(),eB(this)};/** + */H().prototype.isFinite=function(){return this.throwIfDisposed(),tB(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6401,7 +6401,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.isInf=function(){return this.throwIfDisposed(),nB(this)};/** + */H().prototype.isInf=function(){return this.throwIfDisposed(),sB(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6416,7 +6416,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.isNaN=function(){return this.throwIfDisposed(),rB(this)};/** + */H().prototype.isNaN=function(){return this.throwIfDisposed(),oB(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6476,7 +6476,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.localResponseNormalization=function(t,e,n,s){return this.throwIfDisposed(),cB(this,t,e,n,s)};/** + */H().prototype.localResponseNormalization=function(t,e,n,s){return this.throwIfDisposed(),uB(this,t,e,n,s)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6491,7 +6491,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.logSigmoid=function(){return this.throwIfDisposed(),gB(this)};/** + */H().prototype.logSigmoid=function(){return this.throwIfDisposed(),xB(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6506,7 +6506,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.logSoftmax=function(t){return this.throwIfDisposed(),oN(this,t)};/** + */H().prototype.logSoftmax=function(t){return this.throwIfDisposed(),iN(this,t)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6521,7 +6521,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.logSumExp=function(t,e){return this.throwIfDisposed(),iN(this,t,e)};/** + */H().prototype.logSumExp=function(t,e){return this.throwIfDisposed(),aN(this,t,e)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6536,7 +6536,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.log=function(){return this.throwIfDisposed(),Sr(this)};/** + */H().prototype.log=function(){return this.throwIfDisposed(),Ir(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6551,7 +6551,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.log1p=function(){return this.throwIfDisposed(),rN(this)};/** + */H().prototype.log1p=function(){return this.throwIfDisposed(),oN(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6566,7 +6566,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.logicalAnd=function(t){return this.throwIfDisposed(),Ur(this,t)};/** + */H().prototype.logicalAnd=function(t){return this.throwIfDisposed(),Gr(this,t)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6596,7 +6596,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.logicalOr=function(t){return this.throwIfDisposed(),aN(this,t)};/** + */H().prototype.logicalOr=function(t){return this.throwIfDisposed(),lN(this,t)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6611,7 +6611,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.logicalXor=function(t){return this.throwIfDisposed(),SB(this,t)};/** + */H().prototype.logicalXor=function(t){return this.throwIfDisposed(),IB(this,t)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6641,7 +6641,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.max=function(t,e){return this.throwIfDisposed(),qs(this,t,e)};/** + */H().prototype.max=function(t,e){return this.throwIfDisposed(),Ys(this,t,e)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6716,7 +6716,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.mirrorPad=function(t,e){return this.throwIfDisposed(),DB(this,t,e)};/** + */H().prototype.mirrorPad=function(t,e){return this.throwIfDisposed(),_B(this,t,e)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6731,7 +6731,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.mod=function(t){return this.throwIfDisposed(),FB(this,t)};/** + */H().prototype.mod=function(t){return this.throwIfDisposed(),zB(this,t)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6806,7 +6806,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.oneHot=function(t,e=1,n=0){return this.throwIfDisposed(),lN(this,t,e,n)};/** + */H().prototype.oneHot=function(t,e=1,n=0){return this.throwIfDisposed(),cN(this,t,e,n)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6821,7 +6821,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.onesLike=function(){return this.throwIfDisposed(),Es(this)};/** + */H().prototype.onesLike=function(){return this.throwIfDisposed(),Rs(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6836,7 +6836,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.pad=function(t,e){return this.throwIfDisposed(),Xy(this,t,e)};H().prototype.pool=function(t,e,n,s,r,o){return this.throwIfDisposed(),GB(this,t,e,n,s,r,o)};/** + */H().prototype.pad=function(t,e){return this.throwIfDisposed(),Xy(this,t,e)};H().prototype.pool=function(t,e,n,s,r,o){return this.throwIfDisposed(),HB(this,t,e,n,s,r,o)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6881,7 +6881,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.prod=function(t,e){return this.throwIfDisposed(),KB(this,t,e)};/** + */H().prototype.prod=function(t,e){return this.throwIfDisposed(),XB(this,t,e)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6896,7 +6896,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.reciprocal=function(){return this.throwIfDisposed(),gV(this)};/** + */H().prototype.reciprocal=function(){return this.throwIfDisposed(),xV(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6971,7 +6971,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.resizeBilinear=function(t,e,n){return this.throwIfDisposed(),SN(this,t,e,n)};/** + */H().prototype.resizeBilinear=function(t,e,n){return this.throwIfDisposed(),IN(this,t,e,n)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -6986,7 +6986,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.resizeNearestNeighbor=function(t,e,n){return this.throwIfDisposed(),IN(this,t,e,n)};/** + */H().prototype.resizeNearestNeighbor=function(t,e,n){return this.throwIfDisposed(),$N(this,t,e,n)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -7016,7 +7016,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.rfft=function(){return this.throwIfDisposed(),LV(this)};/** + */H().prototype.rfft=function(){return this.throwIfDisposed(),BV(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -7031,7 +7031,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.round=function(){return this.throwIfDisposed(),hN(this)};/** + */H().prototype.round=function(){return this.throwIfDisposed(),fN(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -7046,7 +7046,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.rsqrt=function(){return this.throwIfDisposed(),fN(this)};/** + */H().prototype.rsqrt=function(){return this.throwIfDisposed(),pN(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -7061,7 +7061,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.selu=function(){return this.throwIfDisposed(),pN(this)};/** + */H().prototype.selu=function(){return this.throwIfDisposed(),mN(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -7076,7 +7076,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.separableConv2d=function(t,e,n,s,r,o){return this.throwIfDisposed(),mN(this,t,e,n,s,r,o)};/** + */H().prototype.separableConv2d=function(t,e,n,s,r,o){return this.throwIfDisposed(),gN(this,t,e,n,s,r,o)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -7106,7 +7106,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.sign=function(){return this.throwIfDisposed(),IV(this)};/** + */H().prototype.sign=function(){return this.throwIfDisposed(),$V(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -7121,7 +7121,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.sin=function(){return this.throwIfDisposed(),gN(this)};/** + */H().prototype.sin=function(){return this.throwIfDisposed(),xN(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -7136,7 +7136,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.sinh=function(){return this.throwIfDisposed(),xN(this)};/** + */H().prototype.sinh=function(){return this.throwIfDisposed(),yN(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -7181,7 +7181,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.softplus=function(){return this.throwIfDisposed(),hd(this)};/** + */H().prototype.softplus=function(){return this.throwIfDisposed(),dh(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -7226,7 +7226,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.sqrt=function(){return this.throwIfDisposed(),dn(this)};/** + */H().prototype.sqrt=function(){return this.throwIfDisposed(),hn(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -7256,7 +7256,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.squaredDifference=function(t){return this.throwIfDisposed(),VV(this,t)};/** + */H().prototype.squaredDifference=function(t){return this.throwIfDisposed(),WV(this,t)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -7271,7 +7271,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.squeeze=function(t){return this.throwIfDisposed(),pd(this,t)};/** + */H().prototype.squeeze=function(t){return this.throwIfDisposed(),ph(this,t)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -7286,7 +7286,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.stack=function(t,e){this.throwIfDisposed();const n=t instanceof zt?[this,t]:[this,...t];return Gr(n,e)};/** + */H().prototype.stack=function(t,e){this.throwIfDisposed();const n=t instanceof zt?[this,t]:[this,...t];return Hr(n,e)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -7301,7 +7301,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.step=function(t){return this.throwIfDisposed(),md(this,t)};/** + */H().prototype.step=function(t){return this.throwIfDisposed(),mh(this,t)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -7316,7 +7316,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.stridedSlice=function(t,e,n,s,r,o,i,a){return this.throwIfDisposed(),jV(this,t,e,n,s,r,o,i,a)};/** + */H().prototype.stridedSlice=function(t,e,n,s,r,o,i,a){return this.throwIfDisposed(),KV(this,t,e,n,s,r,o,i,a)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -7361,7 +7361,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.tan=function(){return this.throwIfDisposed(),XV(this)};/** + */H().prototype.tan=function(){return this.throwIfDisposed(),qV(this)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -7391,7 +7391,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.tile=function(t){return this.throwIfDisposed(),Gs(this,t)};/** + */H().prototype.tile=function(t){return this.throwIfDisposed(),Hs(this,t)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -7451,7 +7451,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.topk=function(t,e){return this.throwIfDisposed(),ZV(this,t,e)};/** + */H().prototype.topk=function(t,e){return this.throwIfDisposed(),JV(this,t,e)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -7481,7 +7481,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.unique=function(t){return this.throwIfDisposed(),tW(this,t)};/** + */H().prototype.unique=function(t){return this.throwIfDisposed(),nW(this,t)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -7496,7 +7496,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */H().prototype.unsortedSegmentSum=function(t,e){return this.throwIfDisposed(),CN(this,t,e)};/** + */H().prototype.unsortedSegmentSum=function(t,e){return this.throwIfDisposed(),kN(this,t,e)};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -7549,7 +7549,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */class cr extends Error{constructor(e){super(e),Object.setPrototypeOf(this,cr.prototype)}}class Cs extends Error{constructor(e){super(e),Object.setPrototypeOf(this,Cs.prototype)}}class E extends Error{constructor(e){super(e),Object.setPrototypeOf(this,E.prototype)}}class Ie extends Error{constructor(e){super(e),Object.setPrototypeOf(this,Ie.prototype)}}class Uw extends Error{constructor(e){super(e),Object.setPrototypeOf(this,Uw.prototype)}}/** + */class ur extends Error{constructor(e){super(e),Object.setPrototypeOf(this,ur.prototype)}}class ks extends Error{constructor(e){super(e),Object.setPrototypeOf(this,ks.prototype)}}class E extends Error{constructor(e){super(e),Object.setPrototypeOf(this,E.prototype)}}class Ie extends Error{constructor(e){super(e),Object.setPrototypeOf(this,Ie.prototype)}}class Uw extends Error{constructor(e){super(e),Object.setPrototypeOf(this,Uw.prototype)}}/** * @license * Copyright 2022 Google LLC * @@ -7557,7 +7557,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */class mT{constructor(e){this.maxEntries=e||100,this.cache=new Map}get(e){let n;return this.cache.has(e)&&(n=this.cache.get(e),this.cache.delete(e),this.cache.set(e,n)),n}put(e,n){if(this.cache.has(e))this.cache.delete(e);else if(this.cache.size>=this.maxEntries){const s=this.cache.keys().next().value;this.cache.delete(s)}this.cache.set(e,n)}getMaxEntries(){return this.maxEntries}setMaxEntries(e){if(e<0)throw new Error(`The maxEntries of LRU caches must be at least 0, but got ${e}.`);if(this.maxEntries>e)for(let n=0;n=this.maxEntries){const s=this.cache.keys().next().value;this.cache.delete(s)}this.cache.set(e,n)}getMaxEntries(){return this.maxEntries}setMaxEntries(e){if(e<0)throw new Error(`The maxEntries of LRU caches must be at least 0, but got ${e}.`);if(this.maxEntries>e)for(let n=0;nn.toUpperCase())}let hs={};function Gw(t){if(t==null)return null;const e={};return e.className=t.getClassName(),e.config=t.getConfig(),e}function g1(t){if(!(t==null||typeof t!="object"))if(Array.isArray(t))t.forEach(e=>g1(e));else{const e=Object.keys(t);for(const n of e){const s=t[n];s!=null&&typeof s=="object"&&(!Array.isArray(s)&&s.type==="ndarray"&&typeof s.value=="number"?t[n]=s.value:g1(s))}}}function wd(t,e={},n={},s="object",r=!1){if(typeof t=="string"){const o=t;let i;if(o in n)i=n[o];else if(o in hs)i=hs[o];else if(i=e[o],i==null)throw new E(`Unknown ${s}: ${t}. This may be due to one of the following reasons: + */function Li(t,e){if(Array.isArray(t)){let n=[];for(let s=0;sn.toUpperCase())}let ds={};function Gw(t){if(t==null)return null;const e={};return e.className=t.getClassName(),e.config=t.getConfig(),e}function g1(t){if(!(t==null||typeof t!="object"))if(Array.isArray(t))t.forEach(e=>g1(e));else{const e=Object.keys(t);for(const n of e){const s=t[n];s!=null&&typeof s=="object"&&(!Array.isArray(s)&&s.type==="ndarray"&&typeof s.value=="number"?t[n]=s.value:g1(s))}}}function wh(t,e={},n={},s="object",r=!1){if(typeof t=="string"){const o=t;let i;if(o in n)i=n[o];else if(o in ds)i=ds[o];else if(i=e[o],i==null)throw new E(`Unknown ${s}: ${t}. This may be due to one of the following reasons: 1. The ${s} is defined in Python, in which case it needs to be ported to TensorFlow.js or your JavaScript code. 2. The custom ${s} is defined in JavaScript, but is not registered properly with tf.serialization.registerClass().`);return i}else{const o=t;if(o.className==null||o.config==null)throw new E(`${s}: Improper config format: ${JSON.stringify(o)}. -'className' and 'config' must set.`);const i=o.className;let a,l;if(i in n?[a,l]=n[i]:i in hs?[a,l]=hs.className:i in e&&([a,l]=e[i]),a==null)throw new E(`Unknown ${s}: ${i}. This may be due to one of the following reasons: +'className' and 'config' must set.`);const i=o.className;let a,l;if(i in n?[a,l]=n[i]:i in ds?[a,l]=ds.className:i in e&&([a,l]=e[i]),a==null)throw new E(`Unknown ${s}: ${i}. This may be due to one of the following reasons: 1. The ${s} is defined in Python, in which case it needs to be ported to TensorFlow.js or your JavaScript code. -2. The custom ${s} is defined in JavaScript, but is not registered properly with tf.serialization.registerClass().`);if(l!=null){const c={};for(const f of Object.keys(hs))c[f]=hs[f];for(const f of Object.keys(n))c[f]=n[f];const u=o.config;u.customObjects=c;const d=Object.assign({},hs);for(const f of Object.keys(n))hs[f]=n[f];g1(o.config);const h=l(a,o.config,n,r);return hs=Object.assign({},d),h}else{const c=Object.assign({},hs);for(const d of Object.keys(n))hs[d]=n[d];const u=new a(o.config);return hs=Object.assign({},c),u}}}function R6(t,e){return te?1:0}function eh(t,e){return-1*R6(t,e)}function To(t){if(t==null)return t;const e=[];for(const n of t)e.indexOf(n)===-1&&e.push(n);return e}function A6(t){if(t==null)throw new E(`Invalid value in obj: ${JSON.stringify(t)}`);for(const e in t)if(t.hasOwnProperty(e))return!1;return!0}function Zi(t,e,n){if(n!=null&&t.indexOf(n)<0)throw new E(`${n} is not a valid ${e}. Valid values are ${t} or null/undefined.`)}function Hw(t,e,n=0,s=1/0){return ur(n>=0),ur(s>=n),Array.isArray(t)&&t.length>=n&&t.length<=s&&t.every(r=>typeof r===e)}function qt(t,e){Array.isArray(t)?(I(t.length>0,()=>`${e} is unexpectedly an empty array.`),t.forEach((n,s)=>qt(n,`element ${s+1} of ${e}`))):I(Number.isInteger(t)&&t>0,()=>`Expected ${e} to be a positive integer, but got ${gT(t)}.`)}function gT(t){return t===null?"null":Array.isArray(t)?"["+t.map(e=>gT(e)).join(",")+"]":typeof t=="string"?`"${t}"`:`${t}`}function D6(t,e,n){let s=n!=null?n():Tn(),r;return(...i)=>{const a=n!=null?n():Tn();return a-se?1:0}function ed(t,e){return-1*A6(t,e)}function To(t){if(t==null)return t;const e=[];for(const n of t)e.indexOf(n)===-1&&e.push(n);return e}function D6(t){if(t==null)throw new E(`Invalid value in obj: ${JSON.stringify(t)}`);for(const e in t)if(t.hasOwnProperty(e))return!1;return!0}function Zi(t,e,n){if(n!=null&&t.indexOf(n)<0)throw new E(`${n} is not a valid ${e}. Valid values are ${t} or null/undefined.`)}function Hw(t,e,n=0,s=1/0){return hr(n>=0),hr(s>=n),Array.isArray(t)&&t.length>=n&&t.length<=s&&t.every(r=>typeof r===e)}function qt(t,e){Array.isArray(t)?(I(t.length>0,()=>`${e} is unexpectedly an empty array.`),t.forEach((n,s)=>qt(n,`element ${s+1} of ${e}`))):I(Number.isInteger(t)&&t>0,()=>`Expected ${e} to be a positive integer, but got ${xT(t)}.`)}function xT(t){return t===null?"null":Array.isArray(t)?"["+t.map(e=>xT(e)).join(",")+"]":typeof t=="string"?`"${t}"`:`${t}`}function _6(t,e,n){let s=n!=null?n():Tn(),r;return(...i)=>{const a=n!=null?n():Tn();return a-s0){const n=`${t}_${e}`;return aa.set(n,1),n}else return t}const V6=new RegExp(/^[A-Za-z0-9][-A-Za-z0-9\._\/]*$/);function CT(t){return!!t.match(V6)}/** + */const aa=new Map;function Nt(t){Zi(z6,"DataFormat",t)}function B6(t){Zi(O6,"InterpolationFormat",t)}function hs(t){Zi(M6,"PaddingMode",t)}function vT(t){Zi(P6,"PoolMode",t)}const kc=[],jC="/";function bi(t,e){kc.push(t);try{const n=e();return kc.pop(),n}catch(n){throw kc.pop(),n}}function V6(){return kc.length===0?"":kc.join(jC)+jC}function bT(t){if(!kT(t))throw new Error("Not a valid tensor name: '"+t+"'");return V6()+t}function CT(t){if(!kT(t))throw new Error("Not a valid tensor name: '"+t+"'");aa.has(t)||aa.set(t,0);const e=aa.get(t);if(aa.set(t,aa.get(t)+1),e>0){const n=`${t}_${e}`;return aa.set(n,1),n}else return t}const W6=new RegExp(/^[A-Za-z0-9][-A-Za-z0-9\._\/]*$/);function kT(t){return!!t.match(W6)}/** * @license * Copyright 2018 Google LLC * @@ -7602,7 +7602,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */function W6(t){return t===parseInt(t.toString(),10)}function Eo(t,e,n){e==null&&(e=0),n==null&&(n=t.length);let s=1;for(let r=e;re&&(e=s)}return e}function Zs(t,e){if(ee&&(e=s)}return e}function Js(t,e){if(e{if(t.shape.length!==2)throw new E(`repeat() expects a rank-2 tensor, but received a rank-${t.shape.length} tensor.`);const n=vd(t,1);return x1(n,[1,e,1])})}function G6(t){const e=[Eo(t.shape)];return F(t,e)}function H6(t){if(t.rank<=1)throw new E(`batchFlatten requires a minimum rank of 2. Got rank: ${t.rank}.`);const e=[t.shape[0],Eo(t.shape,1)];return F(t,e)}function Ci(t,e,n){return P(()=>{switch(t.rank){case 1:return rw(t,e,n);case 2:return yN(t,[e,0],[n,t.shape[1]]);case 3:return ow(t,[e,0,0],[n,t.shape[1],t.shape[2]]);case 4:return kf(t,[e,0,0,0],[n,t.shape[1],t.shape[2],t.shape[3]]);case 5:return tt(t,[e,0,0,0,0],[n,t.shape[1],t.shape[2],t.shape[3],t.shape[4]]);case 6:return tt(t,[e,0,0,0,0,0],[n,t.shape[1],t.shape[2],t.shape[3],t.shape[4],t.shape[5]]);default:throw new E(`sliceAlongFirstAxis() received an unsupported tensor rank: ${t.rank}`)}})}function Ng(t,e,n){return P(()=>{switch(t.rank){case 1:return rw(t,e,n);case 2:return yN(t,[0,e],[t.shape[0],n]);case 3:return ow(t,[0,0,e],[t.shape[0],t.shape[1],n]);case 4:return kf(t,[0,0,0,e],[t.shape[0],t.shape[1],t.shape[2],n]);default:throw new E(`sliceAlongLastAxis() received an unsupported tensor rank: ${t.rank}`)}})}function nh(t,e,n,s){return P(()=>{switch(t.rank){case 1:return rw(t,e,n);case 2:switch(s){case 1:return Ci(t,e,n);case 2:return Ng(t,e,n);default:throw new E(`The axis is not within the rank of the tensor ${s}`)}case 3:switch(s){case 1:return Ci(t,e,n);case 2:return ow(t,[0,e,0],[t.shape[0],n,t.shape[2]]);case 3:return Ng(t,e,n);default:throw new E(`The axis is not within the rank of the tensor ${s}`)}case 4:switch(s){case 1:return Ci(t,e,n);case 2:return kf(t,[0,e,0,0],[t.shape[0],n,t.shape[2],t.shape[3]]);case 3:return kf(t,[0,0,e,0],[t.shape[0],t.shape[1],n,t.shape[3]]);case 4:return Ng(t,e,n);default:throw new E(`The axis is not within the rank of the tensor ${s}`)}default:throw new E(`sliceAlongLastAxis() received an unsupported tensor rank: ${t.rank}`)}})}function jw(t,e=-1){let n;return e<0&&(n=t[0].rank,n!==0?e=n:e=0),e===t[0].rank&&(e=-1),Dn(t,e)}function KC(t,e){switch(t.rank){case 1:return QL([t,e]);case 2:return JL([t,e],0);case 3:return t4([t,e],0);case 4:return s4([t,e],0);default:throw new E(`concatAlongFirstAxis() received an unsupported tensor rank: ${t.rank}`)}}function x1(t,e){if(Array.isArray(e)||(e=[e]),t.rank!==e.length)throw new E(`The length of input n (${e.length}) does not match the number of dimensions in input x (${t.rank})`);return Gs(t,e)}function $m(t,e=0,n=1,s,r){return hV(t,e,n,s,r)}function vr(t,e,n,s){if(t.rank<2||e.rank<2)throw new Ie(`dot requires both inputs to be rank >= 2 but got x shape = ${t.shape} and y shape = ${e.shape}`);if(e.rank>=3){const r=t.shape.slice(-1)[0],o=e.shape.slice(-2)[0];if(r!==o)throw new Ie(`If rank y >= 3, then the second last dim of y must equal the last dim of x but got x shape = ${t.shape} and y shape = ${e.shape}`)}if(t.rank===2&&e.rank===2)return AC({a:t,b:e,transposeA:!1,transposeB:!1,bias:s?y1(t.rank,s,Js()):null,activation:n});{const r=t.shape.slice(),o=r.pop();t=F(t,[-1,o]);const i=e.shape.slice(),a=i.pop(),l=i.pop(),c=[...i,a],u=Array.from({length:e.rank},(p,g)=>g===0?e.rank-2:g<=e.rank-2?g-1:g);e=F(Fe(e,u),[l,-1]);const d=[...r,...c];return F(AC({a:t,b:e,transposeA:!1,transposeB:!1,bias:s?y1(t.rank,s,Js()):null,activation:n}),d)}}function kT(t,e,n){return P(()=>(Array.isArray(e)?e=Gn(e,"int32"):e=le(e,"int32"),Wy(t,e,n)))}function bd(t){return D(t,t)}function y1(t,e,n){const s=e.shape;if(e.rank!==1&&e.rank!==t)throw new E(`Unexpected bias dimensions: ${e.rank}; expected it to be 1 or ${t}`);if(t===5){if(n==="channelsFirst")return s.length===1?F(e,[1,s[0],1,1,1]):F(e,[1,s[3],s[0],s[1],s[2]]);if(n==="channelsLast")return s.length===1?F(e,[1,1,1,1,s[0]]):F(e,[1].concat(s))}else if(t===4){if(n==="channelsFirst")return s.length===1?F(e,[1,s[0],1,1]):F(e,[1,s[2],s[0],s[1]]);if(n==="channelsLast")return s.length===1?F(e,[1,1,1,s[0]]):F(e,[1].concat(s))}else if(t===3){if(n==="channelsFirst")return s.length===1?F(e,[1,s[0],1]):F(e,[1,s[1],s[0]]);if(n==="channelsLast")return s.length===1?F(e,[1,1,s[0]]):F(e,[1].concat(s))}else if(t<3)return e;throw new E(`Unsupported input rank by biasAdd: ${e.rank}`)}function nr(t,e,n){return P(()=>(n==null&&(n=Js()),Nt(n),J(t,y1(t.rank,e,n))))}function j6(t,e=1){if(e!==1)throw new Ie(`Support for alpha values other than 1 (${e}) is not implemented yet.`);return ym(t)}function K6(t){return P(()=>ge(t,J(xn(t),1)))}function ST(t,e,n,s){return P(()=>lW(t,e,n,s))}function X6(t){return P(()=>{const e=J(.5,D(.2,t));return as(e,0,1)})}function Cd(t,e,n=!1){return n?t():e()}/** + */function vr(t,e){return le(t,e)}function vh(t,e=-1){const n=t.shape.slice();return e<0&&(e=n.length+e+1),n.splice(e,0,1),F(t,n)}function G6(t,e){return P(()=>{if(t.shape.length!==2)throw new E(`repeat() expects a rank-2 tensor, but received a rank-${t.shape.length} tensor.`);const n=vh(t,1);return x1(n,[1,e,1])})}function H6(t){const e=[Eo(t.shape)];return F(t,e)}function j6(t){if(t.rank<=1)throw new E(`batchFlatten requires a minimum rank of 2. Got rank: ${t.rank}.`);const e=[t.shape[0],Eo(t.shape,1)];return F(t,e)}function Ci(t,e,n){return P(()=>{switch(t.rank){case 1:return rw(t,e,n);case 2:return wN(t,[e,0],[n,t.shape[1]]);case 3:return ow(t,[e,0,0],[n,t.shape[1],t.shape[2]]);case 4:return kf(t,[e,0,0,0],[n,t.shape[1],t.shape[2],t.shape[3]]);case 5:return tt(t,[e,0,0,0,0],[n,t.shape[1],t.shape[2],t.shape[3],t.shape[4]]);case 6:return tt(t,[e,0,0,0,0,0],[n,t.shape[1],t.shape[2],t.shape[3],t.shape[4],t.shape[5]]);default:throw new E(`sliceAlongFirstAxis() received an unsupported tensor rank: ${t.rank}`)}})}function Ng(t,e,n){return P(()=>{switch(t.rank){case 1:return rw(t,e,n);case 2:return wN(t,[0,e],[t.shape[0],n]);case 3:return ow(t,[0,0,e],[t.shape[0],t.shape[1],n]);case 4:return kf(t,[0,0,0,e],[t.shape[0],t.shape[1],t.shape[2],n]);default:throw new E(`sliceAlongLastAxis() received an unsupported tensor rank: ${t.rank}`)}})}function nd(t,e,n,s){return P(()=>{switch(t.rank){case 1:return rw(t,e,n);case 2:switch(s){case 1:return Ci(t,e,n);case 2:return Ng(t,e,n);default:throw new E(`The axis is not within the rank of the tensor ${s}`)}case 3:switch(s){case 1:return Ci(t,e,n);case 2:return ow(t,[0,e,0],[t.shape[0],n,t.shape[2]]);case 3:return Ng(t,e,n);default:throw new E(`The axis is not within the rank of the tensor ${s}`)}case 4:switch(s){case 1:return Ci(t,e,n);case 2:return kf(t,[0,e,0,0],[t.shape[0],n,t.shape[2],t.shape[3]]);case 3:return kf(t,[0,0,e,0],[t.shape[0],t.shape[1],n,t.shape[3]]);case 4:return Ng(t,e,n);default:throw new E(`The axis is not within the rank of the tensor ${s}`)}default:throw new E(`sliceAlongLastAxis() received an unsupported tensor rank: ${t.rank}`)}})}function jw(t,e=-1){let n;return e<0&&(n=t[0].rank,n!==0?e=n:e=0),e===t[0].rank&&(e=-1),Dn(t,e)}function KC(t,e){switch(t.rank){case 1:return ZL([t,e]);case 2:return e4([t,e],0);case 3:return n4([t,e],0);case 4:return r4([t,e],0);default:throw new E(`concatAlongFirstAxis() received an unsupported tensor rank: ${t.rank}`)}}function x1(t,e){if(Array.isArray(e)||(e=[e]),t.rank!==e.length)throw new E(`The length of input n (${e.length}) does not match the number of dimensions in input x (${t.rank})`);return Hs(t,e)}function $m(t,e=0,n=1,s,r){return fV(t,e,n,s,r)}function br(t,e,n,s){if(t.rank<2||e.rank<2)throw new Ie(`dot requires both inputs to be rank >= 2 but got x shape = ${t.shape} and y shape = ${e.shape}`);if(e.rank>=3){const r=t.shape.slice(-1)[0],o=e.shape.slice(-2)[0];if(r!==o)throw new Ie(`If rank y >= 3, then the second last dim of y must equal the last dim of x but got x shape = ${t.shape} and y shape = ${e.shape}`)}if(t.rank===2&&e.rank===2)return AC({a:t,b:e,transposeA:!1,transposeB:!1,bias:s?y1(t.rank,s,er()):null,activation:n});{const r=t.shape.slice(),o=r.pop();t=F(t,[-1,o]);const i=e.shape.slice(),a=i.pop(),l=i.pop(),c=[...i,a],u=Array.from({length:e.rank},(p,g)=>g===0?e.rank-2:g<=e.rank-2?g-1:g);e=F(Fe(e,u),[l,-1]);const h=[...r,...c];return F(AC({a:t,b:e,transposeA:!1,transposeB:!1,bias:s?y1(t.rank,s,er()):null,activation:n}),h)}}function ST(t,e,n){return P(()=>(Array.isArray(e)?e=Gn(e,"int32"):e=le(e,"int32"),Wy(t,e,n)))}function bh(t){return D(t,t)}function y1(t,e,n){const s=e.shape;if(e.rank!==1&&e.rank!==t)throw new E(`Unexpected bias dimensions: ${e.rank}; expected it to be 1 or ${t}`);if(t===5){if(n==="channelsFirst")return s.length===1?F(e,[1,s[0],1,1,1]):F(e,[1,s[3],s[0],s[1],s[2]]);if(n==="channelsLast")return s.length===1?F(e,[1,1,1,1,s[0]]):F(e,[1].concat(s))}else if(t===4){if(n==="channelsFirst")return s.length===1?F(e,[1,s[0],1,1]):F(e,[1,s[2],s[0],s[1]]);if(n==="channelsLast")return s.length===1?F(e,[1,1,1,s[0]]):F(e,[1].concat(s))}else if(t===3){if(n==="channelsFirst")return s.length===1?F(e,[1,s[0],1]):F(e,[1,s[1],s[0]]);if(n==="channelsLast")return s.length===1?F(e,[1,1,s[0]]):F(e,[1].concat(s))}else if(t<3)return e;throw new E(`Unsupported input rank by biasAdd: ${e.rank}`)}function sr(t,e,n){return P(()=>(n==null&&(n=er()),Nt(n),J(t,y1(t.rank,e,n))))}function K6(t,e=1){if(e!==1)throw new Ie(`Support for alpha values other than 1 (${e}) is not implemented yet.`);return ym(t)}function X6(t){return P(()=>ge(t,J(xn(t),1)))}function IT(t,e,n,s){return P(()=>cW(t,e,n,s))}function q6(t){return P(()=>{const e=J(.5,D(.2,t));return as(e,0,1)})}function Ch(t,e,n=!1){return n?t():e()}/** * @license * Copyright 2018 Google LLC * @@ -7626,7 +7626,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */const q6=["fanIn","fanOut","fanAvg"],Y6=["normal","uniform","truncatedNormal"];/** + */const Y6=["fanIn","fanOut","fanAvg"],Q6=["normal","uniform","truncatedNormal"];/** * @license * Copyright 2018 Google LLC * @@ -7634,7 +7634,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */function Q6(t){Zi(q6,"FanMode",t)}function Z6(t){Zi(Y6,"Distribution",t)}class As extends Il{fromConfigUsesCustomObjects(){return!1}getConfig(){return{}}}class IT extends As{apply(e,n){return Kt(e,n)}}IT.className="Zeros";Y(IT);class Kw extends As{apply(e,n){return Ko(e,n)}}Kw.className="Ones";Y(Kw);class $T extends As{constructor(e){if(super(),typeof e!="object")throw new E(`Expected argument of type ConstantConfig but got ${e}`);if(e.value===void 0)throw new E(`config must have value set but got ${e}`);this.value=e.value}apply(e,n){return P(()=>D(We(this.value),Ko(e,n)))}getConfig(){return{value:this.value}}}$T.className="Constant";Y($T);class NT extends As{constructor(e){super(),this.DEFAULT_MINVAL=-.05,this.DEFAULT_MAXVAL=.05,this.minval=e.minval||this.DEFAULT_MINVAL,this.maxval=e.maxval||this.DEFAULT_MAXVAL,this.seed=e.seed}apply(e,n){return fd(e,this.minval,this.maxval,n,this.seed)}getConfig(){return{minval:this.minval,maxval:this.maxval,seed:this.seed}}}NT.className="RandomUniform";Y(NT);class TT extends As{constructor(e){super(),this.DEFAULT_MEAN=0,this.DEFAULT_STDDEV=.05,this.mean=e.mean||this.DEFAULT_MEAN,this.stddev=e.stddev||this.DEFAULT_STDDEV,this.seed=e.seed}apply(e,n){if(n=n||"float32",n!=="float32"&&n!=="int32")throw new Ie(`randomNormal does not support dType ${n}.`);return $m(e,this.mean,this.stddev,n,this.seed)}getConfig(){return{mean:this.mean,stddev:this.stddev,seed:this.seed}}}TT.className="RandomNormal";Y(TT);class ET extends As{constructor(e){super(),this.DEFAULT_MEAN=0,this.DEFAULT_STDDEV=.05,this.mean=e.mean||this.DEFAULT_MEAN,this.stddev=e.stddev||this.DEFAULT_STDDEV,this.seed=e.seed}apply(e,n){if(n=n||"float32",n!=="float32"&&n!=="int32")throw new Ie(`truncatedNormal does not support dType ${n}.`);return bN(e,this.mean,this.stddev,n,this.seed)}getConfig(){return{mean:this.mean,stddev:this.stddev,seed:this.seed}}}ET.className="TruncatedNormal";Y(ET);class RT extends As{constructor(e){super(),this.gain=e.gain!=null?e.gain:1}apply(e,n){return P(()=>{if(e.length!==2||e[0]!==e[1])throw new E("Identity matrix initializer can only be used for 2D square matrices.");return D(this.gain,sN(e[0]))})}getConfig(){return{gain:this.gain}}}RT.className="Identity";Y(RT);function J6(t,e="channelsLast"){let n,s;if(Nt(e),t.length===2)n=t[0],s=t[1];else if([3,4,5].indexOf(t.length)!==-1){if(e==="channelsFirst"){const r=Eo(t,2);n=t[1]*r,s=t[0]*r}else if(e==="channelsLast"){const r=Eo(t,0,t.length-2);n=t[t.length-2]*r,s=t[t.length-1]*r}}else{const r=Eo(t);n=Math.sqrt(r),s=Math.sqrt(r)}return[n,s]}class qn extends As{constructor(e){if(super(),e.scale<0)throw new E(`scale must be a positive float. Got: ${e.scale}`);this.scale=e.scale==null?1:e.scale,this.mode=e.mode==null?"fanIn":e.mode,Q6(this.mode),this.distribution=e.distribution==null?"normal":e.distribution,Z6(this.distribution),this.seed=e.seed}apply(e,n){const s=J6(e),r=s[0],o=s[1];let i=this.scale;if(this.mode==="fanIn"?i/=Math.max(1,r):this.mode==="fanOut"?i/=Math.max(1,o):i/=Math.max(1,(r+o)/2),this.distribution==="normal"){const a=Math.sqrt(i);if(n=n||"float32",n!=="float32"&&n!=="int32")throw new Ie(`${this.getClassName()} does not support dType ${n}.`);return bN(e,0,a,n,this.seed)}else{const a=Math.sqrt(3*i);return fd(e,-a,a,n,this.seed)}}getConfig(){return{scale:this.scale,mode:this.mode,distribution:this.distribution,seed:this.seed}}}qn.className="VarianceScaling";Y(qn);class Xw extends qn{constructor(e){super({scale:1,mode:"fanAvg",distribution:"uniform",seed:e==null?null:e.seed})}getClassName(){return qn.className}}Xw.className="GlorotUniform";Y(Xw);class qw extends qn{constructor(e){super({scale:1,mode:"fanAvg",distribution:"normal",seed:e==null?null:e.seed})}getClassName(){return qn.className}}qw.className="GlorotNormal";Y(qw);class Yw extends qn{constructor(e){super({scale:2,mode:"fanIn",distribution:"normal",seed:e==null?null:e.seed})}getClassName(){return qn.className}}Yw.className="HeNormal";Y(Yw);class Qw extends qn{constructor(e){super({scale:2,mode:"fanIn",distribution:"uniform",seed:e==null?null:e.seed})}getClassName(){return qn.className}}Qw.className="HeUniform";Y(Qw);class Zw extends qn{constructor(e){super({scale:1,mode:"fanIn",distribution:"normal",seed:e==null?null:e.seed})}getClassName(){return qn.className}}Zw.className="LeCunNormal";Y(Zw);class Jw extends qn{constructor(e){super({scale:1,mode:"fanIn",distribution:"uniform",seed:e==null?null:e.seed})}getClassName(){return qn.className}}Jw.className="LeCunUniform";Y(Jw);class AT extends As{constructor(e){super(),this.DEFAULT_GAIN=1,this.ELEMENTS_WARN_SLOW=2e3,this.gain=e.gain==null?this.DEFAULT_GAIN:e.gain,this.seed=e.seed}apply(e,n){return P(()=>{if(e.length<2)throw new Ie("Shape must be at least 2D.");if(n!=="int32"&&n!=="float32"&&n!==void 0)throw new TypeError(`Unsupported data type ${n}.`);n=n;const s=j(e.slice(0,-1)),r=e[e.length-1],o=s*r;o>this.ELEMENTS_WARN_SLOW&&console.warn(`Orthogonal initializer is being called on a matrix with more than ${this.ELEMENTS_WARN_SLOW} (${o}) elements: Slowness may result.`);const i=[Math.max(r,s),Math.min(r,s)],a=$m(i,0,1,n,this.seed),l=rU.qr(a,!1);let c=l[0];const d=l[1].flatten().stridedSlice([0],[Math.min(r,s)*Math.min(r,s)],[Math.min(r,s)+1]);return c=D(c,d.sign()),sD(We(this.value),Ko(e,n)))}getConfig(){return{value:this.value}}}NT.className="Constant";Y(NT);class TT extends Ds{constructor(e){super(),this.DEFAULT_MINVAL=-.05,this.DEFAULT_MAXVAL=.05,this.minval=e.minval||this.DEFAULT_MINVAL,this.maxval=e.maxval||this.DEFAULT_MAXVAL,this.seed=e.seed}apply(e,n){return fh(e,this.minval,this.maxval,n,this.seed)}getConfig(){return{minval:this.minval,maxval:this.maxval,seed:this.seed}}}TT.className="RandomUniform";Y(TT);class ET extends Ds{constructor(e){super(),this.DEFAULT_MEAN=0,this.DEFAULT_STDDEV=.05,this.mean=e.mean||this.DEFAULT_MEAN,this.stddev=e.stddev||this.DEFAULT_STDDEV,this.seed=e.seed}apply(e,n){if(n=n||"float32",n!=="float32"&&n!=="int32")throw new Ie(`randomNormal does not support dType ${n}.`);return $m(e,this.mean,this.stddev,n,this.seed)}getConfig(){return{mean:this.mean,stddev:this.stddev,seed:this.seed}}}ET.className="RandomNormal";Y(ET);class RT extends Ds{constructor(e){super(),this.DEFAULT_MEAN=0,this.DEFAULT_STDDEV=.05,this.mean=e.mean||this.DEFAULT_MEAN,this.stddev=e.stddev||this.DEFAULT_STDDEV,this.seed=e.seed}apply(e,n){if(n=n||"float32",n!=="float32"&&n!=="int32")throw new Ie(`truncatedNormal does not support dType ${n}.`);return CN(e,this.mean,this.stddev,n,this.seed)}getConfig(){return{mean:this.mean,stddev:this.stddev,seed:this.seed}}}RT.className="TruncatedNormal";Y(RT);class AT extends Ds{constructor(e){super(),this.gain=e.gain!=null?e.gain:1}apply(e,n){return P(()=>{if(e.length!==2||e[0]!==e[1])throw new E("Identity matrix initializer can only be used for 2D square matrices.");return D(this.gain,rN(e[0]))})}getConfig(){return{gain:this.gain}}}AT.className="Identity";Y(AT);function e5(t,e="channelsLast"){let n,s;if(Nt(e),t.length===2)n=t[0],s=t[1];else if([3,4,5].indexOf(t.length)!==-1){if(e==="channelsFirst"){const r=Eo(t,2);n=t[1]*r,s=t[0]*r}else if(e==="channelsLast"){const r=Eo(t,0,t.length-2);n=t[t.length-2]*r,s=t[t.length-1]*r}}else{const r=Eo(t);n=Math.sqrt(r),s=Math.sqrt(r)}return[n,s]}class qn extends Ds{constructor(e){if(super(),e.scale<0)throw new E(`scale must be a positive float. Got: ${e.scale}`);this.scale=e.scale==null?1:e.scale,this.mode=e.mode==null?"fanIn":e.mode,Z6(this.mode),this.distribution=e.distribution==null?"normal":e.distribution,J6(this.distribution),this.seed=e.seed}apply(e,n){const s=e5(e),r=s[0],o=s[1];let i=this.scale;if(this.mode==="fanIn"?i/=Math.max(1,r):this.mode==="fanOut"?i/=Math.max(1,o):i/=Math.max(1,(r+o)/2),this.distribution==="normal"){const a=Math.sqrt(i);if(n=n||"float32",n!=="float32"&&n!=="int32")throw new Ie(`${this.getClassName()} does not support dType ${n}.`);return CN(e,0,a,n,this.seed)}else{const a=Math.sqrt(3*i);return fh(e,-a,a,n,this.seed)}}getConfig(){return{scale:this.scale,mode:this.mode,distribution:this.distribution,seed:this.seed}}}qn.className="VarianceScaling";Y(qn);class Xw extends qn{constructor(e){super({scale:1,mode:"fanAvg",distribution:"uniform",seed:e==null?null:e.seed})}getClassName(){return qn.className}}Xw.className="GlorotUniform";Y(Xw);class qw extends qn{constructor(e){super({scale:1,mode:"fanAvg",distribution:"normal",seed:e==null?null:e.seed})}getClassName(){return qn.className}}qw.className="GlorotNormal";Y(qw);class Yw extends qn{constructor(e){super({scale:2,mode:"fanIn",distribution:"normal",seed:e==null?null:e.seed})}getClassName(){return qn.className}}Yw.className="HeNormal";Y(Yw);class Qw extends qn{constructor(e){super({scale:2,mode:"fanIn",distribution:"uniform",seed:e==null?null:e.seed})}getClassName(){return qn.className}}Qw.className="HeUniform";Y(Qw);class Zw extends qn{constructor(e){super({scale:1,mode:"fanIn",distribution:"normal",seed:e==null?null:e.seed})}getClassName(){return qn.className}}Zw.className="LeCunNormal";Y(Zw);class Jw extends qn{constructor(e){super({scale:1,mode:"fanIn",distribution:"uniform",seed:e==null?null:e.seed})}getClassName(){return qn.className}}Jw.className="LeCunUniform";Y(Jw);class DT extends Ds{constructor(e){super(),this.DEFAULT_GAIN=1,this.ELEMENTS_WARN_SLOW=2e3,this.gain=e.gain==null?this.DEFAULT_GAIN:e.gain,this.seed=e.seed}apply(e,n){return P(()=>{if(e.length<2)throw new Ie("Shape must be at least 2D.");if(n!=="int32"&&n!=="float32"&&n!==void 0)throw new TypeError(`Unsupported data type ${n}.`);n=n;const s=j(e.slice(0,-1)),r=e[e.length-1],o=s*r;o>this.ELEMENTS_WARN_SLOW&&console.warn(`Orthogonal initializer is being called on a matrix with more than ${this.ELEMENTS_WARN_SLOW} (${o}) elements: Slowness may result.`);const i=[Math.max(r,s),Math.min(r,s)],a=$m(i,0,1,n,this.seed),l=oU.qr(a,!1);let c=l[0];const h=l[1].flatten().stridedSlice([0],[Math.min(r,s)*Math.min(r,s)],[Math.min(r,s)+1]);return c=D(c,h.sign()),se.read())}function ev(t){t.forEach(e=>{e[0].write(e[1])})}/** + */const YC="Variable";class t5{constructor(e,n="float32",s=YC,r=!0,o=null){this.dtype=n??"float32",this.shape=e.shape,this.id=wT(),s=s??YC,this.originalName=bT(s),this.name=CT(this.originalName),this.trainable_=r,this.constraint=o,this.val=oW(e,this.trainable_,this.name,this.dtype)}read(){return this.assertNotDisposed(),this.val}write(e){return this.assertNotDisposed(),n5(this.val,e),this.val.id!==e.id&&(this.val.assign(e),this.constraint!=null&&this.val.assign(this.constraint.apply(this.val))),this}dispose(){this.assertNotDisposed(),this.val.dispose()}assertNotDisposed(){if(this.val.isDisposed)throw new Error(`LayersVariable ${this.name} is already disposed.`)}get trainable(){return this.trainable_}set trainable(e){this.trainable_=e,this.val.trainable=e}}function n5(t,e){if(t.shape.toString()!==e.shape.toString())throw new Error("Shape mismatch: "+JSON.stringify(t.shape)+" vs. "+JSON.stringify(e.shape))}function v1(t){return t.map(e=>e.read())}function ev(t){t.forEach(e=>{e[0].write(e[1])})}/** * @license * Copyright 2018 Google LLC * @@ -7666,7 +7666,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */class Pt{constructor(e){this.dtype=e.dtype,this.shape=e.shape,e.shape!=null?this.ndim=e.shape.length:this.ndim=e.ndim,this.maxNDim=e.maxNDim,this.minNDim=e.minNDim,this.axes=e.axes||{}}}class Ir{constructor(e,n,s,r,o,i,a){this.dtype=e,this.shape=n,this.sourceLayer=s,this.inputs=r,this.callArgs=o,this.outputTensorIndex=a,this.id=yT(),i!=null&&(this.originalName=vT(i),this.name=bT(this.originalName)),this.rank=n.length}}let n5=0;class Nm{constructor(e,n){this.callArgs=n,this.id=n5++,this.outboundLayer=e.outboundLayer,this.inboundLayers=e.inboundLayers,this.nodeIndices=e.nodeIndices,this.tensorIndices=e.tensorIndices,this.inputTensors=e.inputTensors,this.outputTensors=e.outputTensors,this.inputMasks=e.inputMasks,this.outputMasks=e.outputMasks,this.inputShapes=e.inputShapes,this.outputShapes=e.outputShapes;for(const s of e.inboundLayers)s!=null&&s.outboundNodes.push(this);e.outboundLayer.inboundNodes.push(this)}getConfig(){const e=[];for(const n of this.inboundLayers)n!=null?e.push(n.name):e.push(null);return{outboundLayer:this.outboundLayer?this.outboundLayer.name:null,inboundLayers:e,nodeIndices:this.nodeIndices,tensorIndices:this.tensorIndices}}}let s5=0;class Ae extends Il{constructor(e={}){super(),this._callHook=null,this._addedWeightNames=[],this._stateful=!1,this.id=s5++,this.activityRegularizer=null,this.inputSpec=null,this.supportsMasking=!1,this._trainableWeights=[],this._nonTrainableWeights=[],this._losses=[],this._updates=[],this._built=!1,this.inboundNodes=[],this.outboundNodes=[];let n=e.name;if(!n){const s=this.getClassName();n=Dr(s)+"_"+Im(s)}if(this.name=n,this.trainable_=e.trainable==null?!0:e.trainable,e.inputShape!=null||e.batchInputShape!=null){let s;if(e.batchInputShape!=null)s=e.batchInputShape;else if(e.inputShape!=null){let o=null;e.batchSize!=null&&(o=e.batchSize),s=[o].concat(e.inputShape)}this.batchInputShape=s;let r=e.dtype;r==null&&(r=e.inputDType),r==null&&(r="float32"),this.dtype=r}e.weights!=null?this.initialWeights=e.weights:this.initialWeights=null,this._refCount=null,this.fastWeightInitDuringBuild=!1}static nodeKey(e,n){return e.name+"_ib-"+n.toString()}getNodeAtIndex(e,n){if(this.inboundNodes.length===0)throw new Cs(`The layer has never been called and thus has no defined ${n}.`);if(this.inboundNodes.length<=e)throw new E(`Asked to get ${n} at node ${e}, but the layer has only ${this.inboundNodes.length} inbound nodes.`);return this.inboundNodes[e]}getInputAt(e){return Rn(this.getNodeAtIndex(e,"input").inputTensors)}getOutputAt(e){return Rn(this.getNodeAtIndex(e,"output").outputTensors)}get input(){if(this.inboundNodes.length>1)throw new cr(`Layer ${this.name} has multiple inbound nodes, hence the notion of "layer input" is ill-defined. Use \`getInputAt(nodeIndex)\` instead.`);if(this.inboundNodes.length===0)throw new cr(`Layer ${this.name} is not connected, no input to return.`);return Rn(this.getNodeAtIndex(0,"input").inputTensors)}get output(){if(this.inboundNodes.length===0)throw new cr(`Layer ${this.name} has no inbound nodes.`);if(this.inboundNodes.length>1)throw new cr(`Layer ${this.name} has multiple inbound nodes, hence the notion of "layer output" is ill-defined. Use \`getOutputAt(nodeIndex)\` instead.`);return Rn(this.getNodeAtIndex(0,"output").outputTensors)}get losses(){return this._losses}calculateLosses(){return this.losses.map(e=>e())}get updates(){return this._updates}get built(){return this._built}set built(e){this._built=e}get trainable(){return this.trainable_}set trainable(e){this._trainableWeights.forEach(n=>n.trainable=e),this.trainable_=e}get trainableWeights(){return this.trainable_?this._trainableWeights.filter(e=>e.trainable):[]}set trainableWeights(e){this._trainableWeights=e}get nonTrainableWeights(){return this.trainable?this._trainableWeights.filter(e=>!e.trainable).concat(this._nonTrainableWeights):this._trainableWeights.concat(this._nonTrainableWeights)}set nonTrainableWeights(e){this._nonTrainableWeights=e}get weights(){return this.trainableWeights.concat(this.nonTrainableWeights)}get stateful(){return this._stateful}resetStates(){if(!this.stateful)throw new Error("Cannot call the resetStates() method of a non-stateful Layer object.")}assertInputCompatibility(e){const n=Ke(e);if(this.inputSpec==null||this.inputSpec.length===0)return;const s=Ke(this.inputSpec);if(n.length!==s.length)throw new E(`Layer ${this.name} expects ${s.length} inputs, but it received ${n.length} input tensors. Input received: ${e}`);for(let r=0;ri.maxNDim)throw new E(`Input ${r} is incompatible with layer ${this.name}: expected max_ndim=${i.maxNDim}, found ndim=${a}`);if(i.minNDim!=null&&a=0?l[u]:l[l.length+u];if(d!=null&&[d,null].indexOf(h)===-1)throw new E(`Input ${r} is incompatible with layer ${this.name}: expected axis ${u} of input shape to have value ${d} but got shape ${l}.`)}}if(i.shape!=null)for(let l=0;l{if(!this.built){this.assertInputCompatibility(e);const i=[];for(const a of Ke(e))i.push(a.shape);this.build(Rn(i)),this.built=!0,this.initialWeights&&this.setWeights(this.initialWeights),this._refCount===null&&o&&(this._refCount=1)}if(this.assertInputCompatibility(e),o){let i=this.call(e,n);this.supportsMasking&&this.setMaskMetadata(e,i);const a=Ke(i),l=[];for(let c of a)s.indexOf(c)!==-1&&(c=c.clone()),l.push(c);if(i=Rn(l),this.activityRegularizer!=null)throw new Ie("Layer invocation in the presence of activity regularizer(s) is not supported yet.");return i}else{const i=r5(e),a=this.computeOutputShape(i);let l;const c=o5(e);if(this.warnOnIncompatibleInputShape(Array.isArray(e)?i[0]:i),a!=null&&a.length>0&&Array.isArray(a[0])?l=a.map((u,d)=>new Ir(c,u,this,Ke(e),n,this.name,d)):l=new Ir(c,a,this,Ke(e),n,this.name),this.addInboundNode(e,l,null,null,i,a,n),this._refCount++,this.activityRegularizer!=null)throw new Ie("Layer invocation in the presence of activity regularizer(s) is not supported yet.");return l}})}warnOnIncompatibleInputShape(e){if(this.batchInputShape!=null)if(e.length!==this.batchInputShape.length)console.warn(`The rank of the input tensor provided (shape: ${JSON.stringify(e)}) does not match that of the batchInputShape (${JSON.stringify(this.batchInputShape)}) of the layer ${this.name}`);else{let n=!1;this.batchInputShape.forEach((s,r)=>{s!=null&&e[r]!=null&&e[r]!==s&&(n=!0)}),n&&console.warn(`The shape of the input tensor (${JSON.stringify(e)}) does not match the expectation of layer ${this.name}: ${JSON.stringify(this.batchInputShape)}`)}}get outputShape(){if(this.inboundNodes==null||this.inboundNodes.length===0)throw new cr(`The layer ${this.name} has never been called and thus has no defined output shape.`);const e=[];for(const n of this.inboundNodes){const s=JSON.stringify(n.outputShapes);e.indexOf(s)===-1&&e.push(s)}if(e.length===1){const n=this.inboundNodes[0].outputShapes;return Array.isArray(n)&&Array.isArray(n[0])&&n.length===1?n[0]:n}else throw new cr(`The layer ${this.name} has multiple inbound nodes with different output shapes. Hence the notion of "output shape" is ill-defined for the layer.`)}countParams(){if(!this.built)throw new Cs(`You tried to call countParams() on ${this.name}, but the layer is not built yet. Build it first by calling build(batchInputShape).`);return If(this.weights)}build(e){this.built=!0}getWeights(e=!1){return v1(e?this.trainableWeights:this.weights)}setWeights(e){P(()=>{const n=this.weights;if(n.length!==e.length)throw new E(`You called setWeights(weights) on layer "${this.name}" with a weight list of length ${e.length}, but the layer was expecting ${n.length} weights. Provided weights: ${e}...`);if(n.length===0)return;const s=[],r=v1(n);for(let o=0;oo.apply(u.read())),i==null&&(i=!0),i?this._trainableWeights.push(u):this._nonTrainableWeights.push(u),u}setFastWeightInitDuringBuild(e){this.fastWeightInitDuringBuild=e}addLoss(e){e==null||Array.isArray(e)&&e.length===0||(e=Ke(e),this._losses!==void 0&&this._losses!==null&&this.losses.push(...e))}computeOutputShape(e){return e}computeMask(e,n){if(!this.supportsMasking){if(n!=null)if(Array.isArray(n))n.forEach(s=>{if(s!=null)throw new TypeError(`Layer ${this.name} does not support masking, but was passed an inputMask.`)});else throw new TypeError(`Layer ${this.name} does not support masking, but was passed an inputMask.`);return null}return n}setMaskMetadata(e,n,s){if(!this.supportsMasking)return;const r=this.computeMask(e,s),o=Ke(n),i=Ke(r);if(o.length!==i.length)throw new Error(`${this.name} outputs ${o.length} tensors but ${o.length} masks for those tensors`);for(let a=0;ae.dispose()),this.weights.length}assertNotDisposed(){if(this._refCount===0)throw new Error(`Layer '${this.name}' is already disposed.`)}dispose(){if(!this.built)throw new Error(`Cannot dispose Layer ${this.name} because it has not been built yet.`);if(this._refCount===null)throw new Error(`Cannot dispose Layer ${this.name} because it has not been used yet.`);this.assertNotDisposed();let e=0;return--this._refCount===0&&(e=this.disposeWeights()),{refCountAfterDispose:this._refCount,numDisposedVariables:e}}}function r5(t){t=Ke(t);const e=[];for(const n of t)e.push(n.shape);return Rn(e)}function o5(t){return"float32"}function DT(t,e,n){if((e==null||n!=null&&n>0)&&(e=t.sourceLayer,n=t.nodeIndex),e.inboundNodes.length===0)return[t];{const s=e.inboundNodes[n];if(s.inboundLayers.length===0)return s.inputTensors;{const r=[];for(let o=0;o1)throw new ur(`Layer ${this.name} has multiple inbound nodes, hence the notion of "layer input" is ill-defined. Use \`getInputAt(nodeIndex)\` instead.`);if(this.inboundNodes.length===0)throw new ur(`Layer ${this.name} is not connected, no input to return.`);return Rn(this.getNodeAtIndex(0,"input").inputTensors)}get output(){if(this.inboundNodes.length===0)throw new ur(`Layer ${this.name} has no inbound nodes.`);if(this.inboundNodes.length>1)throw new ur(`Layer ${this.name} has multiple inbound nodes, hence the notion of "layer output" is ill-defined. Use \`getOutputAt(nodeIndex)\` instead.`);return Rn(this.getNodeAtIndex(0,"output").outputTensors)}get losses(){return this._losses}calculateLosses(){return this.losses.map(e=>e())}get updates(){return this._updates}get built(){return this._built}set built(e){this._built=e}get trainable(){return this.trainable_}set trainable(e){this._trainableWeights.forEach(n=>n.trainable=e),this.trainable_=e}get trainableWeights(){return this.trainable_?this._trainableWeights.filter(e=>e.trainable):[]}set trainableWeights(e){this._trainableWeights=e}get nonTrainableWeights(){return this.trainable?this._trainableWeights.filter(e=>!e.trainable).concat(this._nonTrainableWeights):this._trainableWeights.concat(this._nonTrainableWeights)}set nonTrainableWeights(e){this._nonTrainableWeights=e}get weights(){return this.trainableWeights.concat(this.nonTrainableWeights)}get stateful(){return this._stateful}resetStates(){if(!this.stateful)throw new Error("Cannot call the resetStates() method of a non-stateful Layer object.")}assertInputCompatibility(e){const n=Ke(e);if(this.inputSpec==null||this.inputSpec.length===0)return;const s=Ke(this.inputSpec);if(n.length!==s.length)throw new E(`Layer ${this.name} expects ${s.length} inputs, but it received ${n.length} input tensors. Input received: ${e}`);for(let r=0;ri.maxNDim)throw new E(`Input ${r} is incompatible with layer ${this.name}: expected max_ndim=${i.maxNDim}, found ndim=${a}`);if(i.minNDim!=null&&a=0?l[u]:l[l.length+u];if(h!=null&&[h,null].indexOf(d)===-1)throw new E(`Input ${r} is incompatible with layer ${this.name}: expected axis ${u} of input shape to have value ${h} but got shape ${l}.`)}}if(i.shape!=null)for(let l=0;l{if(!this.built){this.assertInputCompatibility(e);const i=[];for(const a of Ke(e))i.push(a.shape);this.build(Rn(i)),this.built=!0,this.initialWeights&&this.setWeights(this.initialWeights),this._refCount===null&&o&&(this._refCount=1)}if(this.assertInputCompatibility(e),o){let i=this.call(e,n);this.supportsMasking&&this.setMaskMetadata(e,i);const a=Ke(i),l=[];for(let c of a)s.indexOf(c)!==-1&&(c=c.clone()),l.push(c);if(i=Rn(l),this.activityRegularizer!=null)throw new Ie("Layer invocation in the presence of activity regularizer(s) is not supported yet.");return i}else{const i=o5(e),a=this.computeOutputShape(i);let l;const c=i5(e);if(this.warnOnIncompatibleInputShape(Array.isArray(e)?i[0]:i),a!=null&&a.length>0&&Array.isArray(a[0])?l=a.map((u,h)=>new $r(c,u,this,Ke(e),n,this.name,h)):l=new $r(c,a,this,Ke(e),n,this.name),this.addInboundNode(e,l,null,null,i,a,n),this._refCount++,this.activityRegularizer!=null)throw new Ie("Layer invocation in the presence of activity regularizer(s) is not supported yet.");return l}})}warnOnIncompatibleInputShape(e){if(this.batchInputShape!=null)if(e.length!==this.batchInputShape.length)console.warn(`The rank of the input tensor provided (shape: ${JSON.stringify(e)}) does not match that of the batchInputShape (${JSON.stringify(this.batchInputShape)}) of the layer ${this.name}`);else{let n=!1;this.batchInputShape.forEach((s,r)=>{s!=null&&e[r]!=null&&e[r]!==s&&(n=!0)}),n&&console.warn(`The shape of the input tensor (${JSON.stringify(e)}) does not match the expectation of layer ${this.name}: ${JSON.stringify(this.batchInputShape)}`)}}get outputShape(){if(this.inboundNodes==null||this.inboundNodes.length===0)throw new ur(`The layer ${this.name} has never been called and thus has no defined output shape.`);const e=[];for(const n of this.inboundNodes){const s=JSON.stringify(n.outputShapes);e.indexOf(s)===-1&&e.push(s)}if(e.length===1){const n=this.inboundNodes[0].outputShapes;return Array.isArray(n)&&Array.isArray(n[0])&&n.length===1?n[0]:n}else throw new ur(`The layer ${this.name} has multiple inbound nodes with different output shapes. Hence the notion of "output shape" is ill-defined for the layer.`)}countParams(){if(!this.built)throw new ks(`You tried to call countParams() on ${this.name}, but the layer is not built yet. Build it first by calling build(batchInputShape).`);return If(this.weights)}build(e){this.built=!0}getWeights(e=!1){return v1(e?this.trainableWeights:this.weights)}setWeights(e){P(()=>{const n=this.weights;if(n.length!==e.length)throw new E(`You called setWeights(weights) on layer "${this.name}" with a weight list of length ${e.length}, but the layer was expecting ${n.length} weights. Provided weights: ${e}...`);if(n.length===0)return;const s=[],r=v1(n);for(let o=0;oo.apply(u.read())),i==null&&(i=!0),i?this._trainableWeights.push(u):this._nonTrainableWeights.push(u),u}setFastWeightInitDuringBuild(e){this.fastWeightInitDuringBuild=e}addLoss(e){e==null||Array.isArray(e)&&e.length===0||(e=Ke(e),this._losses!==void 0&&this._losses!==null&&this.losses.push(...e))}computeOutputShape(e){return e}computeMask(e,n){if(!this.supportsMasking){if(n!=null)if(Array.isArray(n))n.forEach(s=>{if(s!=null)throw new TypeError(`Layer ${this.name} does not support masking, but was passed an inputMask.`)});else throw new TypeError(`Layer ${this.name} does not support masking, but was passed an inputMask.`);return null}return n}setMaskMetadata(e,n,s){if(!this.supportsMasking)return;const r=this.computeMask(e,s),o=Ke(n),i=Ke(r);if(o.length!==i.length)throw new Error(`${this.name} outputs ${o.length} tensors but ${o.length} masks for those tensors`);for(let a=0;ae.dispose()),this.weights.length}assertNotDisposed(){if(this._refCount===0)throw new Error(`Layer '${this.name}' is already disposed.`)}dispose(){if(!this.built)throw new Error(`Cannot dispose Layer ${this.name} because it has not been built yet.`);if(this._refCount===null)throw new Error(`Cannot dispose Layer ${this.name} because it has not been used yet.`);this.assertNotDisposed();let e=0;return--this._refCount===0&&(e=this.disposeWeights()),{refCountAfterDispose:this._refCount,numDisposedVariables:e}}}function o5(t){t=Ke(t);const e=[];for(const n of t)e.push(n.shape);return Rn(e)}function i5(t){return"float32"}function _T(t,e,n){if((e==null||n!=null&&n>0)&&(e=t.sourceLayer,n=t.nodeIndex),e.inboundNodes.length===0)return[t];{const s=e.inboundNodes[n];if(s.inboundLayers.length===0)return s.inputTensors;{const r=[];for(let o=0;op.name),l=[],c=e.names();for(const p of a)c.indexOf(p)!==-1?l.push(e.getValue(p)):l.push(null);const u=a.join(",")+"|"+e.names().sort().join(",");let d=$f.get(u),h;if(d==null){const p=d5(i,e);d=p.sorted,h=p.recipientCounts,$f.put(u,d),Nf.put(u,h)}h={},r||Object.assign(h,Nf.get(u));const f=new fo(e);for(let p=0;p0,()=>"Expected at least one fetch, got none");let n=[],s={};if(t.length===1){const r=QC(t[0],e);n=r.sorted,s=r.recipientMap}else{const r=new Set;for(const o of t){const{sorted:i,recipientMap:a}=QC(o,e);for(const l of i)r.has(l.name)||(n.push(l),r.add(l.name));for(const l in a)s[l]==null&&(s[l]=new Set),a[l].forEach(c=>s[l].add(c))}}return{sorted:n,recipientCounts:h5(s)}}function h5(t){const e={};for(const n in t)e[n]=t[n].size;return e}function QC(t,e){const n=new Set,s=[],r={};for(const a of e.names())n.add(a);const o=[],i=[];for(o.push(t);o.length>0;){const a=o[o.length-1];if(n.has(a.name)){o.pop();continue}const l=i[i.length-1]===o.length-1;if(a.inputs.length===0||l)o.pop(),s.push(a),n.add(a.name),l&&i.pop();else{i.push(o.length-1);for(const c of a.inputs)r[c.name]==null&&(r[c.name]=new Set),r[c.name].add(a.name),!n.has(c.name)&&o.push(c)}}return{sorted:s,recipientMap:r}}function f5(t){let e;if(t.sourceLayer.inboundNodes.length===1)e=t.sourceLayer.output;else{let n=null;for(let s=0;sp.name),l=[],c=e.names();for(const p of a)c.indexOf(p)!==-1?l.push(e.getValue(p)):l.push(null);const u=a.join(",")+"|"+e.names().sort().join(",");let h=$f.get(u),d;if(h==null){const p=d5(i,e);h=p.sorted,d=p.recipientCounts,$f.put(u,h),Nf.put(u,d)}d={},r||Object.assign(d,Nf.get(u));const f=new fo(e);for(let p=0;p0,()=>"Expected at least one fetch, got none");let n=[],s={};if(t.length===1){const r=QC(t[0],e);n=r.sorted,s=r.recipientMap}else{const r=new Set;for(const o of t){const{sorted:i,recipientMap:a}=QC(o,e);for(const l of i)r.has(l.name)||(n.push(l),r.add(l.name));for(const l in a)s[l]==null&&(s[l]=new Set),a[l].forEach(c=>s[l].add(c))}}return{sorted:n,recipientCounts:f5(s)}}function f5(t){const e={};for(const n in t)e[n]=t[n].size;return e}function QC(t,e){const n=new Set,s=[],r={};for(const a of e.names())n.add(a);const o=[],i=[];for(o.push(t);o.length>0;){const a=o[o.length-1];if(n.has(a.name)){o.pop();continue}const l=i[i.length-1]===o.length-1;if(a.inputs.length===0||l)o.pop(),s.push(a),n.add(a.name),l&&i.pop();else{i.push(o.length-1);for(const c of a.inputs)r[c.name]==null&&(r[c.name]=new Set),r[c.name].add(a.name),!n.has(c.name)&&o.push(c)}}return{sorted:s,recipientMap:r}}function p5(t){let e;if(t.sourceLayer.inboundNodes.length===1)e=t.sourceLayer.output;else{let n=null;for(let s=0;s100,u5);/** + */const m5=W();m5.registerFlag("TOPOLOGICAL_SORT_CACHE_MAX_ENTRIES",()=>100,h5);/** * @license * Copyright 2018 Google LLC * @@ -7705,7 +7705,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */function tv(t,e){return P(()=>dn(me(D(t,t),e,!0)))}class Sd extends Il{getConfig(){return{}}}class _T extends Sd{constructor(e){super(),this.defaultMaxValue=2,this.defaultAxis=0,this.maxValue=e.maxValue!=null?e.maxValue:this.defaultMaxValue,this.axis=e.axis!=null?e.axis:this.defaultAxis}apply(e){return P(()=>{const n=tv(e,this.axis),s=as(n,0,this.maxValue);return D(e,ge(s,J(Mt(),n)))})}getConfig(){return{maxValue:this.maxValue,axis:this.axis}}}_T.className="MaxNorm";Y(_T);class FT extends Sd{constructor(e){super(),this.defaultAxis=0,this.axis=e.axis!=null?e.axis:this.defaultAxis}apply(e){return P(()=>ge(e,J(Mt(),tv(e,this.axis))))}getConfig(){return{axis:this.axis}}}FT.className="UnitNorm";Y(FT);class zT extends Sd{apply(e){return Yi(e)}}zT.className="NonNeg";Y(zT);class OT extends Sd{constructor(e){super(),this.defaultMinValue=0,this.defaultMaxValue=1,this.defaultRate=1,this.defaultAxis=0,this.minValue=e.minValue!=null?e.minValue:this.defaultMinValue,this.maxValue=e.maxValue!=null?e.maxValue:this.defaultMaxValue,this.rate=e.rate!=null?e.rate:this.defaultRate,this.axis=e.axis!=null?e.axis:this.defaultAxis}apply(e){return P(()=>{const n=tv(e,this.axis),s=J(D(this.rate,as(n,this.minValue,this.maxValue)),D(1-this.rate,n));return D(e,ge(s,J(Mt(),n)))})}getConfig(){return{minValue:this.minValue,maxValue:this.maxValue,rate:this.rate,axis:this.axis}}}OT.className="MinMaxNorm";Y(OT);const ZC={maxNorm:"MaxNorm",minMaxNorm:"MinMaxNorm",nonNeg:"NonNeg",unitNorm:"UnitNorm"};function Lt(t){return Gw(t)}function JC(t,e={}){return wd(t,xs.getMap().classNameMap,e,"constraint")}function Bt(t){if(t==null)return null;if(typeof t=="string"){const n={className:t in ZC?ZC[t]:t,config:{}};return JC(n)}else return t instanceof Sd?t:JC(t)}/** + */function tv(t,e){return P(()=>hn(me(D(t,t),e,!0)))}class Sh extends Il{getConfig(){return{}}}class FT extends Sh{constructor(e){super(),this.defaultMaxValue=2,this.defaultAxis=0,this.maxValue=e.maxValue!=null?e.maxValue:this.defaultMaxValue,this.axis=e.axis!=null?e.axis:this.defaultAxis}apply(e){return P(()=>{const n=tv(e,this.axis),s=as(n,0,this.maxValue);return D(e,ge(s,J(Mt(),n)))})}getConfig(){return{maxValue:this.maxValue,axis:this.axis}}}FT.className="MaxNorm";Y(FT);class zT extends Sh{constructor(e){super(),this.defaultAxis=0,this.axis=e.axis!=null?e.axis:this.defaultAxis}apply(e){return P(()=>ge(e,J(Mt(),tv(e,this.axis))))}getConfig(){return{axis:this.axis}}}zT.className="UnitNorm";Y(zT);class OT extends Sh{apply(e){return Yi(e)}}OT.className="NonNeg";Y(OT);class MT extends Sh{constructor(e){super(),this.defaultMinValue=0,this.defaultMaxValue=1,this.defaultRate=1,this.defaultAxis=0,this.minValue=e.minValue!=null?e.minValue:this.defaultMinValue,this.maxValue=e.maxValue!=null?e.maxValue:this.defaultMaxValue,this.rate=e.rate!=null?e.rate:this.defaultRate,this.axis=e.axis!=null?e.axis:this.defaultAxis}apply(e){return P(()=>{const n=tv(e,this.axis),s=J(D(this.rate,as(n,this.minValue,this.maxValue)),D(1-this.rate,n));return D(e,ge(s,J(Mt(),n)))})}getConfig(){return{minValue:this.minValue,maxValue:this.maxValue,rate:this.rate,axis:this.axis}}}MT.className="MinMaxNorm";Y(MT);const ZC={maxNorm:"MaxNorm",minMaxNorm:"MinMaxNorm",nonNeg:"NonNeg",unitNorm:"UnitNorm"};function Lt(t){return Gw(t)}function JC(t,e={}){return wh(t,xs.getMap().classNameMap,e,"constraint")}function Bt(t){if(t==null)return null;if(typeof t=="string"){const n={className:t in ZC?ZC[t]:t,config:{}};return JC(n)}else return t instanceof Sh?t:JC(t)}/** * @license * Copyright 2018 Google LLC * @@ -7713,7 +7713,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */async function ei(t){if(t==null)return;const e=[],n=[],s=[];for(const r in t){const o=t[r];if(typeof o!="number"){const i=o;e.push(i.data()),n.push(r),s.push(i)}}if(e.length>0){const r=await Promise.all(e);for(let o=0;o0){const r=await Promise.all(e);for(let o=0;oJ(this.totals[r],D(o,s)));this.totals[r]=a,i!=null&&i.dispose()}}}async onEpochEnd(e,n){if(n!=null)for(const s of this.params.metrics)this.totals[s]!=null&&(typeof this.totals[s]=="number"?n[s]=this.totals[s]/this.seen:P(()=>{const r=D(ge(1,this.seen),this.totals[s]);n[s]=r,this.totals[s].dispose(),xr(n[s])}))}}class y5 extends Yc{async onTrainBegin(e){this.epoch=[],this.history={}}async onEpochEnd(e,n){n==null&&(n={}),this.epoch.push(e);for(const s in n)this.history[s]==null&&(this.history[s]=[]),this.history[s].push(n[s])}async syncData(){const e=[],n=[],s=[];for(const o in this.history){const i=this.history[o];for(let a=0;anew w5(s,e))}class ps{constructor(){}static registerCallbackConstructor(e,n){I(e>=0&&Number.isInteger(e),()=>`Verbosity level is expected to be an integer >= 0, but got ${e}`),ps.checkForDuplicate(n),ps.constructors[e]==null&&(ps.constructors[e]=[]),ps.constructors[e].push(n)}static checkForDuplicate(e){for(const n in ps.constructors)ps.constructors[+n].forEach(r=>{if(r===e)throw new E("Duplicate callback constructor.")})}static clear(){ps.constructors={}}static createCallbacks(e){const n=[];for(const s in ps.constructors){const r=+s;e>=r&&n.push(...ps.constructors[r])}return n.map(s=>new s)}}ps.constructors={};function LT(t,e,n,s,r,o,i,a,l){const c=new y5,u=[new x5,...ps.createCallbacks(e)];t!=null&&u.push(...t),u.push(c);const d=new g5(u);return d.setParams({epochs:n,initialEpoch:s,samples:r,steps:o,batchSize:i,verbose:e,doValidation:a,metrics:l}),{callbackList:d,history:c}}/** + */var ek;(function(t){t[t.SILENT=0]="SILENT",t[t.VERBOSE=1]="VERBOSE"})(ek||(ek={}));const g5=125;class Yc{constructor(){this.validationData=null}setParams(e){this.params=e}async onEpochBegin(e,n){}async onEpochEnd(e,n){}async onBatchBegin(e,n){}async onBatchEnd(e,n){}async onTrainBegin(e){}async onTrainEnd(e){}setModel(e){}}class x5{constructor(e,n=10){e==null&&(e=[]),this.callbacks=e,this.queueLength=n}append(e){this.callbacks.push(e)}setParams(e){for(const n of this.callbacks)n.setParams(e)}setModel(e){for(const n of this.callbacks)n.setModel(e)}async onEpochBegin(e,n){n==null&&(n={});for(const s of this.callbacks)await s.onEpochBegin(e,n)}async onEpochEnd(e,n){n==null&&(n={});for(const s of this.callbacks)await s.onEpochEnd(e,n)}async onBatchBegin(e,n){n==null&&(n={});for(const s of this.callbacks)await s.onBatchBegin(e,n)}async onBatchEnd(e,n){n==null&&(n={});for(const s of this.callbacks)await s.onBatchEnd(e,n)}async onTrainBegin(e){e==null&&(e={});for(const n of this.callbacks)await n.onTrainBegin(e)}async onTrainEnd(e){e==null&&(e={});for(const n of this.callbacks)await n.onTrainEnd(e)}}class y5 extends Yc{constructor(){super()}async onEpochBegin(e){this.seen=0,this.totals={}}async onBatchEnd(e,n){n==null&&(n={});const s=n.size==null?0:n.size;this.seen+=s;for(const r in n){const o=n[r];if(typeof o=="number")this.totals.hasOwnProperty(r)||(this.totals[r]=0),this.totals[r]=this.totals[r]+o*s;else{let i;r in this.totals?i=this.totals[r]:this.totals[r]=0;const a=P(()=>J(this.totals[r],D(o,s)));this.totals[r]=a,i!=null&&i.dispose()}}}async onEpochEnd(e,n){if(n!=null)for(const s of this.params.metrics)this.totals[s]!=null&&(typeof this.totals[s]=="number"?n[s]=this.totals[s]/this.seen:P(()=>{const r=D(ge(1,this.seen),this.totals[s]);n[s]=r,this.totals[s].dispose(),yr(n[s])}))}}class w5 extends Yc{async onTrainBegin(e){this.epoch=[],this.history={}}async onEpochEnd(e,n){n==null&&(n={}),this.epoch.push(e);for(const s in n)this.history[s]==null&&(this.history[s]=[]),this.history[s].push(n[s])}async syncData(){const e=[],n=[],s=[];for(const o in this.history){const i=this.history[o];for(let a=0;anew v5(s,e))}class ps{constructor(){}static registerCallbackConstructor(e,n){I(e>=0&&Number.isInteger(e),()=>`Verbosity level is expected to be an integer >= 0, but got ${e}`),ps.checkForDuplicate(n),ps.constructors[e]==null&&(ps.constructors[e]=[]),ps.constructors[e].push(n)}static checkForDuplicate(e){for(const n in ps.constructors)ps.constructors[+n].forEach(r=>{if(r===e)throw new E("Duplicate callback constructor.")})}static clear(){ps.constructors={}}static createCallbacks(e){const n=[];for(const s in ps.constructors){const r=+s;e>=r&&n.push(...ps.constructors[r])}return n.map(s=>new s)}}ps.constructors={};function BT(t,e,n,s,r,o,i,a,l){const c=new w5,u=[new y5,...ps.createCallbacks(e)];t!=null&&u.push(...t),u.push(c);const h=new x5(u);return h.setParams({epochs:n,initialEpoch:s,samples:r,steps:o,batchSize:i,verbose:e,doValidation:a,metrics:l}),{callbackList:h,history:c}}/** * @license * Copyright 2018 Google LLC * @@ -7729,7 +7729,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */function br(t,e={},n=!1){return wd(t,xs.getMap().classNameMap,e,"layer",n)}/** + */function Cr(t,e={},n=!1){return wh(t,xs.getMap().classNameMap,e,"layer",n)}/** * @license * Copyright 2018 Google LLC * @@ -7737,7 +7737,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */function Tf(t,e){return P(()=>{t.dtype!=="float32"&&(t=le(t,"float32"));const n=me(bd(t),e,!0),s=xm(n.shape,Mt()),r=dn(jo(n,s));return ge(t,r)})}function Tm(t,e){return P(()=>Rt(bd(ve(e,t)),-1))}function nv(t,e){return P(()=>Rt(xn(ve(e,t)),-1))}function sv(t,e){return P(()=>{const n=ve(t,e),s=as(xn(t),Mt(),Number.MAX_VALUE),r=xn(ge(n,s));return D(100,Rt(r,-1))})}function v5(t,e){return P(()=>{const n=as(e,Mt(),Number.MAX_VALUE),s=Sr(J(1,n)),r=as(t,Mt(),Number.MAX_VALUE),o=Sr(J(1,r));return Rt(bd(ve(s,o)),-1)})}function b5(t,e){return P(()=>{const n=jo(0,ve(1,D(t,e)));return Rt(bd(n),-1)})}function C5(t,e){return P(()=>{const n=jo(0,ve(1,D(t,e)));return Rt(n,-1)})}function k5(t,e){return P(()=>{const n=me(D(t,e),-1),s=qs(D(ve(1,t),e),-1);return jo(0,J(1,ve(s,n)))})}function S5(t,e){return P(()=>{const n=Math.log(2),s=ve(e,t),r=ve(J(s,hd(D(-2,s))),n);return Rt(r,-1)})}function Qc(t,e,n=!1){return P(()=>{if(n)e=iw(e);else{const s=me(e,e.shape.length-1,!0);e=ge(e,s)}return e=as(e,Mt(),1-Mt()),St(me(D(le(t,"float32"),Sr(e)),e.shape.length-1))})}function Ef(t,e,n=!1){return P(()=>{const s=le(vm(G6(t)),"int32");e=as(e,Mt(),1-Mt());const r=e.shape,o=F(lN(s,r[r.length-1]),r);return Qc(o,e,n)})}function I5(t,e){if(!Ue(t.shape,e.shape))throw new E(`logits and labels must have the same shape, but got shapes ${JSON.stringify(t.shape)} and ${JSON.stringify(e.shape)}`);return P(()=>{const n=Yi(e),s=St(xn(e));return J(ve(n,D(e,t)),rN(kr(s)))})}function Em(t,e){return P(()=>{let n;return n=as(e,Mt(),1-Mt()),n=Sr(ge(n,ve(1,n))),Rt(I5(t,n),-1)})}function $5(t,e){return P(()=>{const n=as(t,Mt(),1),s=as(e,Mt(),1);return me(D(t,Sr(ge(n,s))),-1)})}function N5(t,e){return P(()=>{const n=Sr(J(Mt(),e));return Rt(ve(e,D(t,n)),-1)})}function BT(t,e){return P(()=>{const n=Tf(t,-1),s=Tf(e,-1),r=D(n,s);return St(me(r,-1))})}const Rf={meanSquaredError:Tm,meanAbsoluteError:nv,meanAbsolutePercentageError:sv,meanSquaredLogarithmicError:v5,squaredHinge:b5,hinge:C5,categoricalHinge:k5,logcosh:S5,categoricalCrossentropy:Qc,sparseCategoricalCrossentropy:Ef,binaryCrossentropy:Em,kullbackLeiblerDivergence:$5,poisson:N5,cosineProximity:BT};function Tg(t){if(typeof t=="string"){if(t in Rf)return Rf[t];let e=`Unknown loss ${t}`;throw t.toLowerCase().includes("softmaxcrossentropy")&&(e=`Unknown loss ${t}. Use "categoricalCrossentropy" as the string name for tf.losses.softmaxCrossEntropy`),new E(e)}else return t}/** + */function Tf(t,e){return P(()=>{t.dtype!=="float32"&&(t=le(t,"float32"));const n=me(bh(t),e,!0),s=xm(n.shape,Mt()),r=hn(jo(n,s));return ge(t,r)})}function Tm(t,e){return P(()=>Rt(bh(ve(e,t)),-1))}function nv(t,e){return P(()=>Rt(xn(ve(e,t)),-1))}function sv(t,e){return P(()=>{const n=ve(t,e),s=as(xn(t),Mt(),Number.MAX_VALUE),r=xn(ge(n,s));return D(100,Rt(r,-1))})}function b5(t,e){return P(()=>{const n=as(e,Mt(),Number.MAX_VALUE),s=Ir(J(1,n)),r=as(t,Mt(),Number.MAX_VALUE),o=Ir(J(1,r));return Rt(bh(ve(s,o)),-1)})}function C5(t,e){return P(()=>{const n=jo(0,ve(1,D(t,e)));return Rt(bh(n),-1)})}function k5(t,e){return P(()=>{const n=jo(0,ve(1,D(t,e)));return Rt(n,-1)})}function S5(t,e){return P(()=>{const n=me(D(t,e),-1),s=Ys(D(ve(1,t),e),-1);return jo(0,J(1,ve(s,n)))})}function I5(t,e){return P(()=>{const n=Math.log(2),s=ve(e,t),r=ve(J(s,dh(D(-2,s))),n);return Rt(r,-1)})}function Qc(t,e,n=!1){return P(()=>{if(n)e=iw(e);else{const s=me(e,e.shape.length-1,!0);e=ge(e,s)}return e=as(e,Mt(),1-Mt()),St(me(D(le(t,"float32"),Ir(e)),e.shape.length-1))})}function Ef(t,e,n=!1){return P(()=>{const s=le(vm(H6(t)),"int32");e=as(e,Mt(),1-Mt());const r=e.shape,o=F(cN(s,r[r.length-1]),r);return Qc(o,e,n)})}function $5(t,e){if(!Ue(t.shape,e.shape))throw new E(`logits and labels must have the same shape, but got shapes ${JSON.stringify(t.shape)} and ${JSON.stringify(e.shape)}`);return P(()=>{const n=Yi(e),s=St(xn(e));return J(ve(n,D(e,t)),oN(Sr(s)))})}function Em(t,e){return P(()=>{let n;return n=as(e,Mt(),1-Mt()),n=Ir(ge(n,ve(1,n))),Rt($5(t,n),-1)})}function N5(t,e){return P(()=>{const n=as(t,Mt(),1),s=as(e,Mt(),1);return me(D(t,Ir(ge(n,s))),-1)})}function T5(t,e){return P(()=>{const n=Ir(J(Mt(),e));return Rt(ve(e,D(t,n)),-1)})}function VT(t,e){return P(()=>{const n=Tf(t,-1),s=Tf(e,-1),r=D(n,s);return St(me(r,-1))})}const Rf={meanSquaredError:Tm,meanAbsoluteError:nv,meanAbsolutePercentageError:sv,meanSquaredLogarithmicError:b5,squaredHinge:C5,hinge:k5,categoricalHinge:S5,logcosh:I5,categoricalCrossentropy:Qc,sparseCategoricalCrossentropy:Ef,binaryCrossentropy:Em,kullbackLeiblerDivergence:N5,poisson:T5,cosineProximity:VT};function Tg(t){if(typeof t=="string"){if(t in Rf)return Rf[t];let e=`Unknown loss ${t}`;throw t.toLowerCase().includes("softmaxcrossentropy")&&(e=`Unknown loss ${t}. Use "categoricalCrossentropy" as the string name for tf.losses.softmaxCrossEntropy`),new E(e)}else return t}/** * @license * Copyright 2018 Google LLC * @@ -7745,7 +7745,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */function VT(t,e){return P(()=>{const n=D(.5,Es(e)),s=wr(us(e,n),t.dtype);return Rt(Cr(t,s),-1)})}function WT(t,e){return P(()=>wr(Cr(Hc(t,-1),Hc(e,-1)),"float32"))}function T5(t,e){return P(()=>le(me(Ur(Cr(t,1),Cr(e,1))),"float32"))}function E5(t,e){return P(()=>le(me(Ur(Cr(t,0),Cr(e,1))),"float32"))}function R5(t,e){return P(()=>{const n=T5(t,e),s=E5(t,e),r=J(n,s);return le(Cn(us(r,0),ge(n,r),0),"float32")})}function A5(t,e){return Em(t,e)}function D5(t,e){return t.rank===e.rank&&(t=pd(t,[t.rank-1])),e=Hc(e,-1),e.dtype!==t.dtype&&(e=le(e,t.dtype)),le(Cr(t,e),"float32")}const _5=Tm,F5=Tm,z5=nv,O5=nv,M5=sv,P5=sv,UT=Qc,L5=BT,GT=Ef,Af={binaryAccuracy:VT,categoricalAccuracy:WT,precision:R5,categoricalCrossentropy:UT,sparseCategoricalCrossentropy:GT,mse:_5,MSE:F5,mae:z5,MAE:O5,mape:M5,MAPE:P5,cosine:L5};function B5(t){if(typeof t=="string"&&t in Af)return Af[t];if(typeof t!="string"&&t!=null)return t;throw new E(`Unknown metric ${t}`)}function sh(t){if(ur(t!==null,`Unknown LossOrMetricFn ${t}`),typeof t=="string")return t;{let e;for(const n of Object.keys(Rf))if(Rf[n]===t){e=n;break}if(e!==void 0)return e;for(const n of Object.keys(Af))if(Af[n]===t){e=n;break}return e!==void 0?e:t.name}}/** + */function WT(t,e){return P(()=>{const n=D(.5,Rs(e)),s=vr(us(e,n),t.dtype);return Rt(kr(t,s),-1)})}function UT(t,e){return P(()=>vr(kr(Hc(t,-1),Hc(e,-1)),"float32"))}function E5(t,e){return P(()=>le(me(Gr(kr(t,1),kr(e,1))),"float32"))}function R5(t,e){return P(()=>le(me(Gr(kr(t,0),kr(e,1))),"float32"))}function A5(t,e){return P(()=>{const n=E5(t,e),s=R5(t,e),r=J(n,s);return le(Cn(us(r,0),ge(n,r),0),"float32")})}function D5(t,e){return Em(t,e)}function _5(t,e){return t.rank===e.rank&&(t=ph(t,[t.rank-1])),e=Hc(e,-1),e.dtype!==t.dtype&&(e=le(e,t.dtype)),le(kr(t,e),"float32")}const F5=Tm,z5=Tm,O5=nv,M5=nv,P5=sv,L5=sv,GT=Qc,B5=VT,HT=Ef,Af={binaryAccuracy:WT,categoricalAccuracy:UT,precision:A5,categoricalCrossentropy:GT,sparseCategoricalCrossentropy:HT,mse:F5,MSE:z5,mae:O5,MAE:M5,mape:P5,MAPE:L5,cosine:B5};function V5(t){if(typeof t=="string"&&t in Af)return Af[t];if(typeof t!="string"&&t!=null)return t;throw new E(`Unknown metric ${t}`)}function sd(t){if(hr(t!==null,`Unknown LossOrMetricFn ${t}`),typeof t=="string")return t;{let e;for(const n of Object.keys(Rf))if(Rf[n]===t){e=n;break}if(e!==void 0)return e;for(const n of Object.keys(Af))if(Af[n]===t){e=n;break}return e!==void 0?e:t.name}}/** * @license * Copyright 2018 Google LLC * @@ -7753,7 +7753,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */function V5(t){const e={Adagrad:()=>ia.adagrad(.01),Adadelta:()=>ia.adadelta(1,.95,Mt()),Adam:()=>ia.adam(.001,.9,.999,Mt()),Adamax:()=>ia.adamax(.002,.9,.999,Mt(),0),RMSProp:()=>ia.rmsprop(.001,.9,0,Mt()),SGD:()=>ia.sgd(.01)};if(e.adagrad=e.Adagrad,e.adadelta=e.Adadelta,e.adam=e.Adam,e.adamax=e.Adamax,e.rmsprop=e.RMSProp,e.sgd=e.SGD,t in e)return e[t]();throw new E(`Unknown Optimizer ${t}`)}/** + */function W5(t){const e={Adagrad:()=>ia.adagrad(.01),Adadelta:()=>ia.adadelta(1,.95,Mt()),Adam:()=>ia.adam(.001,.9,.999,Mt()),Adamax:()=>ia.adamax(.002,.9,.999,Mt(),0),RMSProp:()=>ia.rmsprop(.001,.9,0,Mt()),SGD:()=>ia.sgd(.01)};if(e.adagrad=e.Adagrad,e.adadelta=e.Adadelta,e.adam=e.Adam,e.adamax=e.Adamax,e.rmsprop=e.RMSProp,e.sgd=e.SGD,t in e)return e[t]();throw new E(`Unknown Optimizer ${t}`)}/** * @license * Copyright 2019 Google LLC * @@ -7769,7 +7769,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */function W5(t,e,n,s=console.log){const r=G5(t),o=["Layer (type)","Input Shape","Output shape","Param #"];r?(e=e||90,n=n||[.32,.61,.89,1]):(e=e||115,n=n||[.24,.48,.7,.8,1]),n[n.length-1]<=1&&(n=n.map(u=>Math.floor(e*u)));let i;if(!r){o.push("Receives inputs"),i=[];for(const u in t.nodesByDepth)i.push(...t.nodesByDepth[u])}s("_".repeat(e)),Df(o,n,s),s("=".repeat(e));const a=t.layers;for(let u=0;u1||r.length===1&&r[0].inboundLayers.length>1){e=!1;break}s.push(...r)}if(e)for(const r of t.layers){let o=!1;for(const i of r.inboundNodes)if(s.indexOf(i)!==-1)if(o){e=!1;break}else o=!0;if(!e)break}return e}function Df(t,e,n=console.log){let s="";for(let r=0;r0&&(s=s.slice(0,s.length-1)+" "),s+=t[r],s=s.slice(0,e[r]),s+=" ".repeat(e[r]-s.length);n(s)}function H5(t,e,n){let s,r;try{r=t.inboundNodes.map(l=>JSON.stringify(l.inputShapes)).join(",")}catch{r="multiple"}try{s=JSON.stringify(t.outputShape)}catch{s="multiple"}const o=t.name,i=t.getClassName(),a=[`${o} (${i})`,r,s,t.countParams().toString()];Df(a,e,n)}function j5(t,e,n,s){let r,o;try{o=t.inboundNodes.map(d=>JSON.stringify(d.inputShapes)).join(",")}catch{o="multiple"}try{r=JSON.stringify(t.outputShape)}catch{r="multiple"}const i=[];for(const d of t.inboundNodes)if(!(n!=null&&n.length>0&&n.indexOf(d)===-1))for(let h=0;hMath.floor(e*u)));let i;if(!r){o.push("Receives inputs"),i=[];for(const u in t.nodesByDepth)i.push(...t.nodesByDepth[u])}s("_".repeat(e)),Df(o,n,s),s("=".repeat(e));const a=t.layers;for(let u=0;u1||r.length===1&&r[0].inboundLayers.length>1){e=!1;break}s.push(...r)}if(e)for(const r of t.layers){let o=!1;for(const i of r.inboundNodes)if(s.indexOf(i)!==-1)if(o){e=!1;break}else o=!0;if(!e)break}return e}function Df(t,e,n=console.log){let s="";for(let r=0;r0&&(s=s.slice(0,s.length-1)+" "),s+=t[r],s=s.slice(0,e[r]),s+=" ".repeat(e[r]-s.length);n(s)}function j5(t,e,n){let s,r;try{r=t.inboundNodes.map(l=>JSON.stringify(l.inputShapes)).join(",")}catch{r="multiple"}try{s=JSON.stringify(t.outputShape)}catch{s="multiple"}const o=t.name,i=t.getClassName(),a=[`${o} (${i})`,r,s,t.countParams().toString()];Df(a,e,n)}function K5(t,e,n,s){let r,o;try{o=t.inboundNodes.map(h=>JSON.stringify(h.inputShapes)).join(",")}catch{o="multiple"}try{r=JSON.stringify(t.outputShape)}catch{r="multiple"}const i=[];for(const h of t.inboundNodes)if(!(n!=null&&n.length>0&&n.indexOf(h)===-1))for(let d=0;d{const e=Object.keys(t);if(e.length===0)return!1;const n=e[0].split("/");return!isNaN(parseInt(n[n.length-1],10))};class Ms extends Ae{constructor(e){if(super({}),this.containerNodes=new Set,this.name=e.name,this.name==null){const y=this.getClassName().toLowerCase();this.name=Im(y)}if(this.supportsMasking=!1,this.trainable_=!0,Array.isArray(e.inputs)?this.inputs=e.inputs.slice():this.inputs=[e.inputs],Array.isArray(e.outputs)?this.outputs=e.outputs.slice():this.outputs=[e.outputs],To(this.inputs).length!==this.inputs.length)throw new E(`The list of inputs passed to the model is redundant. All inputs should only appear once. Found: ${this.inputs.map(y=>y.name)}`);To(this.outputs).length!==this.outputs.length&&console.warn(`The list of outputs passed to the model is redundant. All outputs should only appear once. Found: ${this.outputs.map(y=>y.name)}`),this.inputLayers=[],this.inputLayersNodeIndices=[],this.inputLayersTensorIndices=[],this.outputLayers=[],this.outputLayersNodeIndices=[],this.outputLayersTensorIndices=[],this.layers=[],this.internalContainerRefs=[];for(const y of this.outputs){const w=y.sourceLayer,v=y.nodeIndex,b=y.tensorIndex;this.outputLayers.push(w),this.outputLayersNodeIndices.push(v),this.outputLayersTensorIndices.push(b)}for(const y of this.inputs){const w=y.sourceLayer,v=y.nodeIndex,b=y.tensorIndex;ur(v===0,"input layer has >1 nodes"),ur(b===0,"input layer has >1 tensors"),this.inputLayers.push(w),this.inputLayersNodeIndices.push(v),this.inputLayersTensorIndices.push(b)}this.inputNames=[],this.outputNames=[],this.feedInputShapes=[],this.feedInputNames=[],this.feedOutputNames=[];for(let y=0;yy.shape),this.internalOutputShapes=this.outputs.map(y=>y.shape);const n={},s={},r={},o={},i={},a=[],l=(y,w,v,b,C,k)=>{(b==null||C==null||k==null)&&(b=y.sourceLayer,C=y.nodeIndex,k=y.tensorIndex);const S=b.inboundNodes[C];if(v.indexOf(S)!==-1)throw new Cs(`The tensor ${y.name} at layer "${b.name}" is part of a cycle.`);if(w.indexOf(S)!==-1)return;this.containerNodes.add(Ms.nodeKey(b,C)),b.id in i||(i[b.id]=Object.keys(i).length),v.indexOf(S)===-1&&v.push(S);const $=S.inboundLayers.length;for(let N=0;N<$;N++){const A=S.inputTensors[N],M=S.inboundLayers[N],L=S.nodeIndices[N],V=S.tensorIndices[N];l(A,w,v,M,L,V)}for(w.push(S);v.indexOf(S)>=0;)v.splice(v.indexOf(S),1);a.push(S)},c=[],u=[];for(const y of this.outputs)l(y,c,u);const d=a.slice().reverse();for(const y of d){s[y.id]=y,y.id in n||(n[y.id]=0);let w=n[y.id];const v=r[y.outboundLayer.id]==null?0:r[y.outboundLayer.id];w=Math.max(w,v),r[y.outboundLayer.id]=w,o[y.outboundLayer.id]=y.outboundLayer,n[y.id]=w;for(let b=0;bparseInt(y,10)).sort(eh);this.layers=[];for(const y of p){const w=f[y];w.sort((v,b)=>{const C=i[v.id],k=i[b.id];return Ck?1:0});for(const v of w)v instanceof Ms&&this.internalContainerRefs.push(v),this.layers.push(v)}this.layersByDepth=f,p=Object.keys(h).map(y=>parseInt(y,10)).sort(eh);const g=this.inputs.slice(),x=[];for(const y of p)for(const w of h[y]){const v=w.outboundLayer;if(v!=null){for(const b of w.inputTensors)if(g.indexOf(b)===-1)throw new Cs(`Graph disconnected: cannot obtain value for tensor ${b} at layer "${v.name}". The following previous layers were accessed without issue: ${x}`);for(const b of w.outputTensors)g.push(b);x.push(v.name)}}this.nodesByDepth=h;const m=this.layers.map(y=>y.name);for(const y of m){const w=m.filter(v=>v===y).length;if(w!==1)throw new Cs(`The name "${y}" is used ${w} times in the model. All layer names should be unique. Layer names: `+JSON.stringify(m))}this.outboundNodes=[],this.inboundNodes=[],new Nm({outboundLayer:this,inboundLayers:[],nodeIndices:[],tensorIndices:[],inputTensors:this.inputs,outputTensors:this.outputs,inputMasks:this.inputs.map(y=>null),outputMasks:this.outputs.map(y=>null),inputShapes:this.inputs.map(y=>y.shape),outputShapes:this.outputs.map(y=>y.shape)}),this.built=!0,this._refCount=1}assertNotDisposed(){if(this._refCount===0)throw new Error(`Container '${this.name}' is already disposed.`)}dispose(){this.assertNotDisposed();const e={refCountAfterDispose:null,numDisposedVariables:0};if(--this._refCount===0){for(const n of this.layers)e.numDisposedVariables+=n.dispose().numDisposedVariables;for(const n of this.internalContainerRefs)e.numDisposedVariables+=n.dispose().numDisposedVariables}return e.refCountAfterDispose=this._refCount,e}get trainable(){return this.trainable_}set trainable(e){this.layers.forEach(n=>{n._trainableWeights.forEach(s=>s.trainable=e)}),this.trainable_=e}get trainableWeights(){if(this._trainableWeights.length>0)throw new E("Container instance unexpectedly contains _trainableWeights.The trainable weights of a Container are a union of the trainable weights of its consituent Layers. Its own _trainableWeights must remain an empty Array.");if(!this.trainable)return[];let e=[];for(const n of this.layers)e=e.concat(n.trainableWeights);return e}get nonTrainableWeights(){const e=[];for(const n of this.layers)e.push(...n.nonTrainableWeights);if(!this.trainable){const n=[];for(const s of this.layers)n.push(...s.trainableWeights);return n.concat(e)}return e}get weights(){return this.trainableWeights.concat(this.nonTrainableWeights)}loadWeights(e,n=!0){const s={};let r=0;const o=K5(e);o&&this.parseWeights(e);for(const a of this.layers)for(const[l,c]of a.weights.entries()){const u=o?`${c.name.split("/").slice(0,-1).join("/")+"/"}${l}`:c.originalName;if(s[u]!=null)throw new E(`Duplicate weight name: ${u}`);s[u]=c,r++}const i=[];for(const a in e){let l=a;if(s[a]==null){const c=a.split("/");l=c.slice(0,-2).concat([c[c.length-1]]).join("/")}if(s[l]!=null)i.push([s[l],e[a]]);else if(n)throw new E(`Provided weight data has no target variable: ${a}`);delete s[l]}if(n){const a=[];for(const l in s)a.push(l);if(a.length>0)throw new E(`${a.length} of ${r} weights are not set: ${a}`)}ev(i)}parseWeights(e){for(const n in Object.keys(e)){const s=n.split("/"),r=["vars","layer_checkpoint_dependencies"],o=s.map(i=>i.startsWith("_")?i.slice(1):i).filter(i=>!r.includes(i)).join("/");o!==n&&(e[o]=e[n],delete e[n])}}updatedConfig(){const e=this.getConfig(),n={};return n.className=this.getClassName(),n.config=e,n.kerasVersion=`tfjs-layers ${jT}`,n.backend="TensorFlow.js",n}toJSON(e,n=!0){const s=C1(this.updatedConfig());return n?JSON.stringify(s):s}call(e,n){return P(()=>{e=Ke(e);const s=new fo;for(let r=0;r{e=Ke(e);let s;return n==null?s=Li(null,e.length):s=Ke(n),this.runInternalGraph(e,s)[1]})}computeOutputShape(e){const n=Sf(e);if(n.length!==this.inputLayers.length)throw new E(`Invalid inputShape argument ${e}: model has ${this.inputLayers.length} tensor inputs.`);const s={};for(let a=0;aparseInt(a,10)).sort(eh);if(r.length>1)for(const a of r){const l=this.nodesByDepth[a];for(const c of l){const u=c.outboundLayer;if(this.inputLayers.map(g=>g.id).indexOf(u.id)!==-1)continue;const d=[];for(let g=0;gparseInt(l,10)).sort(eh);for(const l of r){const c=this.nodesByDepth[l];for(const u of c){const d=u.outboundLayer,h=u.inputTensors,f=u.outputTensors,p=new Array;for(const g of h)g.id in s&&p.push(s[g.id]);if(p.length===h.length){let g={},x,m,y,w;if(u.callArgs!=null&&(g=u.callArgs),p.length===1){const[v,b]=p[0];g.mask==null&&(g.mask=b),y=Ke(d.call(v,g)),w=Ke(d.computeMask(v,b)),x=[v],m=[b]}else x=p.map(v=>v[0]),m=p.map(v=>v[1]),g.mask==null&&(g.mask=m),y=Ke(d.call(x,g)),w=Ke(d.computeMask(x,m));if(d.activityRegularizer)throw new Ie("LayersModel invocation with concrete Tensor value(s) in the presence of activity regularizer(s) is not supported yet.");for(let v=0;v{const e=[];for(const n of this.layers)for(let s=0;s0){const g=[];for(let x=0;x0&&x.apply(Rn(y),w)}function c(x){const m=x.name,y=br(x,n.customObjects!=null?n.customObjects:{});y.setFastWeightInitDuringBuild(r),o[m]=y,x.inboundNodes.forEach(v=>{if(!(v instanceof Array))throw new E(`Corrupted configuration, expected array for nodeData: ${v}`);a(y,v)})}const u=n.name,d=n.layers;for(const x of d)c(x);for(;!A6(i);)for(const x of d){const m=o[x.name];if(m.name in i){const y=i[m.name];delete i[m.name];for(const w of y)l(m,w)}}const h=[],f=[],p=n.inputLayers;for(const x of p){const m=x[0],y=x[1],w=x[2];ur(m in o);const b=o[m].inboundNodes[y].outputTensors;h.push(b[w])}const g=n.outputLayers;for(const x of g){const m=x[0],y=x[1],w=x[2];ur(m in o);const b=o[m].inboundNodes[y].outputTensors;f.push(b[w])}return new e({inputs:h,outputs:f,name:u})}get stateful(){if(this._stateful)throw new E("Container instance unexpectedly has _stateful = true. The statefulness of a Container is determined by the Layers it contains. Its _stateful property must remain the default false.");for(const e of this.layers)if(e.stateful)return!0;return!1}resetStates(){P(()=>{this.layers.forEach(e=>{e.stateful&&e.resetStates()})})}}/** + */const X5=t=>{const e=Object.keys(t);if(e.length===0)return!1;const n=e[0].split("/");return!isNaN(parseInt(n[n.length-1],10))};class Ps extends Ae{constructor(e){if(super({}),this.containerNodes=new Set,this.name=e.name,this.name==null){const y=this.getClassName().toLowerCase();this.name=Im(y)}if(this.supportsMasking=!1,this.trainable_=!0,Array.isArray(e.inputs)?this.inputs=e.inputs.slice():this.inputs=[e.inputs],Array.isArray(e.outputs)?this.outputs=e.outputs.slice():this.outputs=[e.outputs],To(this.inputs).length!==this.inputs.length)throw new E(`The list of inputs passed to the model is redundant. All inputs should only appear once. Found: ${this.inputs.map(y=>y.name)}`);To(this.outputs).length!==this.outputs.length&&console.warn(`The list of outputs passed to the model is redundant. All outputs should only appear once. Found: ${this.outputs.map(y=>y.name)}`),this.inputLayers=[],this.inputLayersNodeIndices=[],this.inputLayersTensorIndices=[],this.outputLayers=[],this.outputLayersNodeIndices=[],this.outputLayersTensorIndices=[],this.layers=[],this.internalContainerRefs=[];for(const y of this.outputs){const w=y.sourceLayer,v=y.nodeIndex,b=y.tensorIndex;this.outputLayers.push(w),this.outputLayersNodeIndices.push(v),this.outputLayersTensorIndices.push(b)}for(const y of this.inputs){const w=y.sourceLayer,v=y.nodeIndex,b=y.tensorIndex;hr(v===0,"input layer has >1 nodes"),hr(b===0,"input layer has >1 tensors"),this.inputLayers.push(w),this.inputLayersNodeIndices.push(v),this.inputLayersTensorIndices.push(b)}this.inputNames=[],this.outputNames=[],this.feedInputShapes=[],this.feedInputNames=[],this.feedOutputNames=[];for(let y=0;yy.shape),this.internalOutputShapes=this.outputs.map(y=>y.shape);const n={},s={},r={},o={},i={},a=[],l=(y,w,v,b,C,k)=>{(b==null||C==null||k==null)&&(b=y.sourceLayer,C=y.nodeIndex,k=y.tensorIndex);const S=b.inboundNodes[C];if(v.indexOf(S)!==-1)throw new ks(`The tensor ${y.name} at layer "${b.name}" is part of a cycle.`);if(w.indexOf(S)!==-1)return;this.containerNodes.add(Ps.nodeKey(b,C)),b.id in i||(i[b.id]=Object.keys(i).length),v.indexOf(S)===-1&&v.push(S);const $=S.inboundLayers.length;for(let N=0;N<$;N++){const A=S.inputTensors[N],M=S.inboundLayers[N],L=S.nodeIndices[N],V=S.tensorIndices[N];l(A,w,v,M,L,V)}for(w.push(S);v.indexOf(S)>=0;)v.splice(v.indexOf(S),1);a.push(S)},c=[],u=[];for(const y of this.outputs)l(y,c,u);const h=a.slice().reverse();for(const y of h){s[y.id]=y,y.id in n||(n[y.id]=0);let w=n[y.id];const v=r[y.outboundLayer.id]==null?0:r[y.outboundLayer.id];w=Math.max(w,v),r[y.outboundLayer.id]=w,o[y.outboundLayer.id]=y.outboundLayer,n[y.id]=w;for(let b=0;bparseInt(y,10)).sort(ed);this.layers=[];for(const y of p){const w=f[y];w.sort((v,b)=>{const C=i[v.id],k=i[b.id];return Ck?1:0});for(const v of w)v instanceof Ps&&this.internalContainerRefs.push(v),this.layers.push(v)}this.layersByDepth=f,p=Object.keys(d).map(y=>parseInt(y,10)).sort(ed);const g=this.inputs.slice(),x=[];for(const y of p)for(const w of d[y]){const v=w.outboundLayer;if(v!=null){for(const b of w.inputTensors)if(g.indexOf(b)===-1)throw new ks(`Graph disconnected: cannot obtain value for tensor ${b} at layer "${v.name}". The following previous layers were accessed without issue: ${x}`);for(const b of w.outputTensors)g.push(b);x.push(v.name)}}this.nodesByDepth=d;const m=this.layers.map(y=>y.name);for(const y of m){const w=m.filter(v=>v===y).length;if(w!==1)throw new ks(`The name "${y}" is used ${w} times in the model. All layer names should be unique. Layer names: `+JSON.stringify(m))}this.outboundNodes=[],this.inboundNodes=[],new Nm({outboundLayer:this,inboundLayers:[],nodeIndices:[],tensorIndices:[],inputTensors:this.inputs,outputTensors:this.outputs,inputMasks:this.inputs.map(y=>null),outputMasks:this.outputs.map(y=>null),inputShapes:this.inputs.map(y=>y.shape),outputShapes:this.outputs.map(y=>y.shape)}),this.built=!0,this._refCount=1}assertNotDisposed(){if(this._refCount===0)throw new Error(`Container '${this.name}' is already disposed.`)}dispose(){this.assertNotDisposed();const e={refCountAfterDispose:null,numDisposedVariables:0};if(--this._refCount===0){for(const n of this.layers)e.numDisposedVariables+=n.dispose().numDisposedVariables;for(const n of this.internalContainerRefs)e.numDisposedVariables+=n.dispose().numDisposedVariables}return e.refCountAfterDispose=this._refCount,e}get trainable(){return this.trainable_}set trainable(e){this.layers.forEach(n=>{n._trainableWeights.forEach(s=>s.trainable=e)}),this.trainable_=e}get trainableWeights(){if(this._trainableWeights.length>0)throw new E("Container instance unexpectedly contains _trainableWeights.The trainable weights of a Container are a union of the trainable weights of its consituent Layers. Its own _trainableWeights must remain an empty Array.");if(!this.trainable)return[];let e=[];for(const n of this.layers)e=e.concat(n.trainableWeights);return e}get nonTrainableWeights(){const e=[];for(const n of this.layers)e.push(...n.nonTrainableWeights);if(!this.trainable){const n=[];for(const s of this.layers)n.push(...s.trainableWeights);return n.concat(e)}return e}get weights(){return this.trainableWeights.concat(this.nonTrainableWeights)}loadWeights(e,n=!0){const s={};let r=0;const o=X5(e);o&&this.parseWeights(e);for(const a of this.layers)for(const[l,c]of a.weights.entries()){const u=o?`${c.name.split("/").slice(0,-1).join("/")+"/"}${l}`:c.originalName;if(s[u]!=null)throw new E(`Duplicate weight name: ${u}`);s[u]=c,r++}const i=[];for(const a in e){let l=a;if(s[a]==null){const c=a.split("/");l=c.slice(0,-2).concat([c[c.length-1]]).join("/")}if(s[l]!=null)i.push([s[l],e[a]]);else if(n)throw new E(`Provided weight data has no target variable: ${a}`);delete s[l]}if(n){const a=[];for(const l in s)a.push(l);if(a.length>0)throw new E(`${a.length} of ${r} weights are not set: ${a}`)}ev(i)}parseWeights(e){for(const n in Object.keys(e)){const s=n.split("/"),r=["vars","layer_checkpoint_dependencies"],o=s.map(i=>i.startsWith("_")?i.slice(1):i).filter(i=>!r.includes(i)).join("/");o!==n&&(e[o]=e[n],delete e[n])}}updatedConfig(){const e=this.getConfig(),n={};return n.className=this.getClassName(),n.config=e,n.kerasVersion=`tfjs-layers ${KT}`,n.backend="TensorFlow.js",n}toJSON(e,n=!0){const s=C1(this.updatedConfig());return n?JSON.stringify(s):s}call(e,n){return P(()=>{e=Ke(e);const s=new fo;for(let r=0;r{e=Ke(e);let s;return n==null?s=Li(null,e.length):s=Ke(n),this.runInternalGraph(e,s)[1]})}computeOutputShape(e){const n=Sf(e);if(n.length!==this.inputLayers.length)throw new E(`Invalid inputShape argument ${e}: model has ${this.inputLayers.length} tensor inputs.`);const s={};for(let a=0;aparseInt(a,10)).sort(ed);if(r.length>1)for(const a of r){const l=this.nodesByDepth[a];for(const c of l){const u=c.outboundLayer;if(this.inputLayers.map(g=>g.id).indexOf(u.id)!==-1)continue;const h=[];for(let g=0;gparseInt(l,10)).sort(ed);for(const l of r){const c=this.nodesByDepth[l];for(const u of c){const h=u.outboundLayer,d=u.inputTensors,f=u.outputTensors,p=new Array;for(const g of d)g.id in s&&p.push(s[g.id]);if(p.length===d.length){let g={},x,m,y,w;if(u.callArgs!=null&&(g=u.callArgs),p.length===1){const[v,b]=p[0];g.mask==null&&(g.mask=b),y=Ke(h.call(v,g)),w=Ke(h.computeMask(v,b)),x=[v],m=[b]}else x=p.map(v=>v[0]),m=p.map(v=>v[1]),g.mask==null&&(g.mask=m),y=Ke(h.call(x,g)),w=Ke(h.computeMask(x,m));if(h.activityRegularizer)throw new Ie("LayersModel invocation with concrete Tensor value(s) in the presence of activity regularizer(s) is not supported yet.");for(let v=0;v{const e=[];for(const n of this.layers)for(let s=0;s0){const g=[];for(let x=0;x0&&x.apply(Rn(y),w)}function c(x){const m=x.name,y=Cr(x,n.customObjects!=null?n.customObjects:{});y.setFastWeightInitDuringBuild(r),o[m]=y,x.inboundNodes.forEach(v=>{if(!(v instanceof Array))throw new E(`Corrupted configuration, expected array for nodeData: ${v}`);a(y,v)})}const u=n.name,h=n.layers;for(const x of h)c(x);for(;!D6(i);)for(const x of h){const m=o[x.name];if(m.name in i){const y=i[m.name];delete i[m.name];for(const w of y)l(m,w)}}const d=[],f=[],p=n.inputLayers;for(const x of p){const m=x[0],y=x[1],w=x[2];hr(m in o);const b=o[m].inboundNodes[y].outputTensors;d.push(b[w])}const g=n.outputLayers;for(const x of g){const m=x[0],y=x[1],w=x[2];hr(m in o);const b=o[m].inboundNodes[y].outputTensors;f.push(b[w])}return new e({inputs:d,outputs:f,name:u})}get stateful(){if(this._stateful)throw new E("Container instance unexpectedly has _stateful = true. The statefulness of a Container is determined by the Layers it contains. Its _stateful property must remain the default false.");for(const e of this.layers)if(e.stateful)return!0;return!1}resetStates(){P(()=>{this.layers.forEach(e=>{e.stateful&&e.resetStates()})})}}/** * @license * Copyright 2018 Google LLC * @@ -7793,7 +7793,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */function X5(t,e,n){const s=e.length;if(t==null||Array.isArray(t)&&t.length===0)return e.map(r=>null);if(s===1)return Array.isArray(t)&&t.length===1?t:typeof t=="object"&&e[0]in t?[t[e[0]]]:[t];if(Array.isArray(t)){if(t.length!==s)throw new Error(`Provided ${n} is an array of ${t.length} element(s), but the model has ${s} outputs. Make sure a set of weights is provided for each model output.`);return t}else if(typeof t=="object"&&Object.keys(t).length>0&&typeof t[Object.keys(t)[0]]=="object"){const r=[];return e.forEach(o=>{o in t?r.push(t[o]):r.push(null)}),r}else throw new Error(`The model has multiple (${s}) outputs, so ${n} must be either an array with ${s} elements or an object with ${e} keys. Provided ${n} not understood: ${JSON.stringify(t)}`)}function KT(t,e){return X5(t,e,"classWeight")}async function XT(t,e,n,s){if(n!=null){const r=P(()=>{if(t.shape.length===1)return vi(t);if(t.shape.length===2){if(t.shape[1]>1)return Hc(t,1);if(t.shape[1]===1)return F(t,[t.shape[0]]);throw new Error(`Encountered unexpected last-dimension size (${t.shape[1]}) during handling of class weights. The size is expected to be >= 1.`)}else throw new Error(`Unexpected rank of target (y) tensor (${t.rank}) during handling of class weights. The rank is expected to be 1 or 2.`)}),o=Array.from(await r.data());$e(r);const i=[];return o.forEach(a=>{if(n[a]==null)throw new Error(`classWeight must contain all classes in the training data. The class ${a} exists in the data but not in classWeight`);i.push(n[a])}),Gn(i,"float32")}else return null}function q5(t,e){return D(t,e)}/** + */function q5(t,e,n){const s=e.length;if(t==null||Array.isArray(t)&&t.length===0)return e.map(r=>null);if(s===1)return Array.isArray(t)&&t.length===1?t:typeof t=="object"&&e[0]in t?[t[e[0]]]:[t];if(Array.isArray(t)){if(t.length!==s)throw new Error(`Provided ${n} is an array of ${t.length} element(s), but the model has ${s} outputs. Make sure a set of weights is provided for each model output.`);return t}else if(typeof t=="object"&&Object.keys(t).length>0&&typeof t[Object.keys(t)[0]]=="object"){const r=[];return e.forEach(o=>{o in t?r.push(t[o]):r.push(null)}),r}else throw new Error(`The model has multiple (${s}) outputs, so ${n} must be either an array with ${s} elements or an object with ${e} keys. Provided ${n} not understood: ${JSON.stringify(t)}`)}function XT(t,e){return q5(t,e,"classWeight")}async function qT(t,e,n,s){if(n!=null){const r=P(()=>{if(t.shape.length===1)return vi(t);if(t.shape.length===2){if(t.shape[1]>1)return Hc(t,1);if(t.shape[1]===1)return F(t,[t.shape[0]]);throw new Error(`Encountered unexpected last-dimension size (${t.shape[1]}) during handling of class weights. The size is expected to be >= 1.`)}else throw new Error(`Unexpected rank of target (y) tensor (${t.rank}) during handling of class weights. The rank is expected to be 1 or 2.`)}),o=Array.from(await r.data());$e(r);const i=[];return o.forEach(a=>{if(n[a]==null)throw new Error(`classWeight must contain all classes in the training data. The class ${a} exists in the data but not in classWeight`);i.push(n[a])}),Gn(i,"float32")}else return null}function Y5(t,e){return D(t,e)}/** * @license * Copyright 2018 Google LLC * @@ -7801,7 +7801,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */const Y5=32;function qT(t,e){let n,s;const r=e;n=r.xs,s=r.ys,I(n!=null&&s!=null,()=>`A Dataset iterator for fitDataset() is expected to generate objects of the form \`{xs: xVal, ys: yVal}\`, where the two values may be \`tf.Tensor\`, an array of Tensors, or a map of string to Tensor. The provided Dataset instead generates ${e}`);const o=sk("input",t.inputNames,n),i=sk("output",t.outputNames,s),a=o[0].shape[0];I(o.length===t.inputs.length,()=>`LayersModel has ${t.inputs.length} inputs, but the dataset provides ${o.length} inputs. (Expected input keys: ${JSON.stringify(t.inputNames)})`),I(i.length===t.outputs.length,()=>`LayersModel has ${t.outputs.length} outputs, but the dataset provides ${i.length} outputs. (Expected output keys: ${JSON.stringify(t.outputNames)})`);for(let l=0;l`Batch size mismatch: input ${t.inputNames[l]} has ${o[l].shape[0]}; expected ${a} based on input ${t.inputNames[0]}.`);for(let l=0;l`Batch size mismatch: output ${t.outputNames[l]} has ${i[l].shape[0]}; expected ${a} based on input ${t.inputNames[0]}.`);return{xs:o,ys:i}}function sk(t,e,n){if(n instanceof zt)return[n];if(Array.isArray(n))return I(n.length===e.length,()=>`Received an array of ${n.length} Tensors, but expected ${e.length} to match the ${t} keys ${e}.`),n;{const s=[];for(const r of e){if(n[r]==null)throw new E(`The feature data generated by the dataset lacks the required ${t} key '${r}'.`);s.push(n[r])}return s}}function Q5(t){if(t.length===3)throw new Ie("Validation with sample weights is not implemented yet.");return{xs:t[0],ys:t[1]}}async function Z5(t,e,n){const s=n.batchesPerEpoch!=null;if(I(t.optimizer!=null,()=>"You must compile a model before training/testing. Use LayersModel.compile(modelCompileConfig)."),I(n!=null,()=>"For fitDataset(), the 2nd argument (config) is required, but it is not provided in this call."),I(n.epochs!=null&&n.epochs>0&&Number.isInteger(n.epochs),()=>`For fitDataset(), config.epochs is expected to be a positive integer, but got ${n.epochs}`),I(!s||n.batchesPerEpoch>0&&Number.isInteger(n.batchesPerEpoch),()=>`For fitDataset(), config.batchesPerEpoch is expected to be a positive integer if specified, but got ${n.batchesPerEpoch}`),I(n.validationSplit==null,()=>"`validationSplit` is not supported by `fitDataset()`. Use validationData instead."),t.isTraining)throw new Error("Cannot start training because another fit() call is ongoing.");t.isTraining=!0;try{const r=n.validationData!=null;let o,i;if(r)if(rk(n.validationData))I(n.validationBatches==null||n.validationBatches>0&&Number.isInteger(n.validationBatches),()=>`For fitDataset() with dataset-based validation, config.validationBatches is expected not to be provided, or to be a positive integer, but got ${n.validationBatches}`);else{const x=Q5(n.validationData);o=x.xs,i=x.ys}const a=t.makeTrainFunction(),l=t.getDedupedMetricsNames();let c;r?c=l.slice().concat(l.map(x=>"val_"+x)):c=l.slice();const u=PT(n.callbacks,n.yieldEvery),d=n.verbose==null?1:n.verbose,{callbackList:h,history:f}=LT(u,d,n.epochs,null,null,J5(e,n),null,r,c);h.setModel(t),t.history=f,await h.onTrainBegin(),t.stopTraining_=!1;let p=n.initialEpoch==null?0:n.initialEpoch,g=await e.iterator();for(;p=n.batchesPerEpoch:w.done){if(r){let v;rk(n.validationData)?v=Ke(await t.evaluateDataset(n.validationData,{batches:n.validationBatches})):v=Ke(t.evaluate(o,i,{batchSize:n.validationBatchSize==null?Y5:n.validationBatchSize,verbose:0}));for(let b=0;b0)throw new Ie("Verbose mode is not implemented yet.");I(!s||n.batches>0&&Number.isInteger(n.batches),()=>`Test loop expects \`batches\` to be a positive integer, but received ${JSON.stringify(n.batches)}`);const i=eH(e)?e:await e.iterator();let a=0,l=0;for(;!s||l{if(c.value){const{xs:u,ys:d}=qT(t,c.value),h=u.concat(d),f=P(()=>r(h));if($e(h),l===0)for(let g=0;gJ(o[g],D(p,x))),l>0&&$e(m)}$e(f),a+=p,++l}return o}),c.done){s&&console.warn(`Your dataset iterator ran out of data during evaluateDataset(). Interrupting evalution. Make sure that your dataset can generate at least \`batches\` batches (in this case, ${n.batches} batches). You may need to use the repeat() function when building your dataset.`);break}}for(let c=0;c`A Dataset iterator for fitDataset() is expected to generate objects of the form \`{xs: xVal, ys: yVal}\`, where the two values may be \`tf.Tensor\`, an array of Tensors, or a map of string to Tensor. The provided Dataset instead generates ${e}`);const o=sk("input",t.inputNames,n),i=sk("output",t.outputNames,s),a=o[0].shape[0];I(o.length===t.inputs.length,()=>`LayersModel has ${t.inputs.length} inputs, but the dataset provides ${o.length} inputs. (Expected input keys: ${JSON.stringify(t.inputNames)})`),I(i.length===t.outputs.length,()=>`LayersModel has ${t.outputs.length} outputs, but the dataset provides ${i.length} outputs. (Expected output keys: ${JSON.stringify(t.outputNames)})`);for(let l=0;l`Batch size mismatch: input ${t.inputNames[l]} has ${o[l].shape[0]}; expected ${a} based on input ${t.inputNames[0]}.`);for(let l=0;l`Batch size mismatch: output ${t.outputNames[l]} has ${i[l].shape[0]}; expected ${a} based on input ${t.inputNames[0]}.`);return{xs:o,ys:i}}function sk(t,e,n){if(n instanceof zt)return[n];if(Array.isArray(n))return I(n.length===e.length,()=>`Received an array of ${n.length} Tensors, but expected ${e.length} to match the ${t} keys ${e}.`),n;{const s=[];for(const r of e){if(n[r]==null)throw new E(`The feature data generated by the dataset lacks the required ${t} key '${r}'.`);s.push(n[r])}return s}}function Z5(t){if(t.length===3)throw new Ie("Validation with sample weights is not implemented yet.");return{xs:t[0],ys:t[1]}}async function J5(t,e,n){const s=n.batchesPerEpoch!=null;if(I(t.optimizer!=null,()=>"You must compile a model before training/testing. Use LayersModel.compile(modelCompileConfig)."),I(n!=null,()=>"For fitDataset(), the 2nd argument (config) is required, but it is not provided in this call."),I(n.epochs!=null&&n.epochs>0&&Number.isInteger(n.epochs),()=>`For fitDataset(), config.epochs is expected to be a positive integer, but got ${n.epochs}`),I(!s||n.batchesPerEpoch>0&&Number.isInteger(n.batchesPerEpoch),()=>`For fitDataset(), config.batchesPerEpoch is expected to be a positive integer if specified, but got ${n.batchesPerEpoch}`),I(n.validationSplit==null,()=>"`validationSplit` is not supported by `fitDataset()`. Use validationData instead."),t.isTraining)throw new Error("Cannot start training because another fit() call is ongoing.");t.isTraining=!0;try{const r=n.validationData!=null;let o,i;if(r)if(rk(n.validationData))I(n.validationBatches==null||n.validationBatches>0&&Number.isInteger(n.validationBatches),()=>`For fitDataset() with dataset-based validation, config.validationBatches is expected not to be provided, or to be a positive integer, but got ${n.validationBatches}`);else{const x=Z5(n.validationData);o=x.xs,i=x.ys}const a=t.makeTrainFunction(),l=t.getDedupedMetricsNames();let c;r?c=l.slice().concat(l.map(x=>"val_"+x)):c=l.slice();const u=LT(n.callbacks,n.yieldEvery),h=n.verbose==null?1:n.verbose,{callbackList:d,history:f}=BT(u,h,n.epochs,null,null,eH(e,n),null,r,c);d.setModel(t),t.history=f,await d.onTrainBegin(),t.stopTraining_=!1;let p=n.initialEpoch==null?0:n.initialEpoch,g=await e.iterator();for(;p=n.batchesPerEpoch:w.done){if(r){let v;rk(n.validationData)?v=Ke(await t.evaluateDataset(n.validationData,{batches:n.validationBatches})):v=Ke(t.evaluate(o,i,{batchSize:n.validationBatchSize==null?Q5:n.validationBatchSize,verbose:0}));for(let b=0;b0)throw new Ie("Verbose mode is not implemented yet.");I(!s||n.batches>0&&Number.isInteger(n.batches),()=>`Test loop expects \`batches\` to be a positive integer, but received ${JSON.stringify(n.batches)}`);const i=tH(e)?e:await e.iterator();let a=0,l=0;for(;!s||l{if(c.value){const{xs:u,ys:h}=YT(t,c.value),d=u.concat(h),f=P(()=>r(d));if($e(d),l===0)for(let g=0;gJ(o[g],D(p,x))),l>0&&$e(m)}$e(f),a+=p,++l}return o}),c.done){s&&console.warn(`Your dataset iterator ran out of data during evaluateDataset(). Interrupting evalution. Make sure that your dataset can generate at least \`batches\` batches (in this case, ${n.batches} batches). You may need to use the repeat() function when building your dataset.`);break}}for(let c=0;c0&&Number.isInteger(t),()=>`batchSize is required to be a positive integer, but got ${t}`)}function jl(t,e,n){return t==null?[null]:Array.isArray(t)?t.map(s=>Ci(s,e,n-e)):Ci(t,e,n-e)}function k1(t,e){return P(()=>t==null?null:Array.isArray(t)?t.map(n=>k1(n,e)):kT(t,e.dtype==="int32"?e:le(e,"int32")))}function Rg(t,e){const n=[];let s=0,r=null;for(;s=t&&(r=t),n.push([s,r]),s=r;return n}function YT(t){const e=[];t instanceof zt&&(t=[t]);for(let n=0;nn.push(r.id));else if(e!=null)for(const r in e){const o=e[r];n.push(o.id)}const s=[];if(t instanceof zt)n.indexOf(t.id)===-1&&s.push(t);else if(Array.isArray(t))t.forEach(r=>{n.indexOf(r.id)===-1&&s.push(r)});else if(t!=null)for(const r in t){const o=t[r];n.indexOf(o.id)===-1&&s.push(o)}s.forEach(r=>{r.isDisposed||r.dispose()})}/** + */function Eg(t){I(t>0&&Number.isInteger(t),()=>`batchSize is required to be a positive integer, but got ${t}`)}function jl(t,e,n){return t==null?[null]:Array.isArray(t)?t.map(s=>Ci(s,e,n-e)):Ci(t,e,n-e)}function k1(t,e){return P(()=>t==null?null:Array.isArray(t)?t.map(n=>k1(n,e)):ST(t,e.dtype==="int32"?e:le(e,"int32")))}function Rg(t,e){const n=[];let s=0,r=null;for(;s=t&&(r=t),n.push([s,r]),s=r;return n}function QT(t){const e=[];t instanceof zt&&(t=[t]);for(let n=0;nn.push(r.id));else if(e!=null)for(const r in e){const o=e[r];n.push(o.id)}const s=[];if(t instanceof zt)n.indexOf(t.id)===-1&&s.push(t);else if(Array.isArray(t))t.forEach(r=>{n.indexOf(r.id)===-1&&s.push(r)});else if(t!=null)for(const r in t){const o=t[r];n.indexOf(o.id)===-1&&s.push(o)}s.forEach(r=>{r.isDisposed||r.dispose()})}/** * @license * Copyright 2018 Google LLC * @@ -7817,7 +7817,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */function nH(t){return t instanceof zt}function S1(t){return Array.isArray(t)}function ok(t){return!nH(t)&&!S1(t)}function ik(t,e,n,s=!0,r=""){if(e==null||e.length===0){if(t!=null){let i=!1;if(S1(t)&&t.length>0)i=!0;else if(ok(t)){for(const a in t)if(t.hasOwnProperty(a)){i=!0;break}}else i=!0;if(i)throw new E(`Error when checking model ${r} expected no data, but got ${t}`)}return[]}if(t==null)return e.map(i=>null);let o;if(ok(t)){t=t,o=[];for(const i of e){if(t[i]==null)throw new E(`No data provided for "${i}". Need data for each key in: ${e}`);o.push(t[i])}}else if(S1(t)){if(t=t,t.length!==e.length)throw new E(`Error when checking model ${r}: the Array of Tensors that you are passing to your model is not the size the model expected. Expected to see ${e.length} Tensor(s), but instead got the following list of Tensor(s): ${t}`);o=t}else{if(t=t,e.length>1)throw new E(`The model ${r} expects ${e.length} Tensor(s), but only received one Tensor. Found: Tensor with shape ${t.shape}`);o=[t]}if(o=YT(o),n!=null)for(let i=0;i=0&&c!==u)throw new E(`${r} expected a batch of elements where each example has shape [${n[i].slice(1,n[i].length)}] (i.e.,tensor shape [*,${n[i].slice(1,n[i].length)}]) but the ${r} received an input with ${a.shape[0]} examples, each with shape [${a.shape.slice(1,a.shape.length)}] (tensor shape [${a.shape}])`)}}return o}function sH(t,e,n){const s=To(t.map(o=>o.shape[0]));s.sort();const r=To(e.map(o=>o.shape[0]));if(r.sort(),s.length>1)throw new E(`All input Tensors (x) should have the same number of samples. Got array shapes: ${JSON.stringify(t.map(o=>o.shape))}`);if(r.length>1)throw new E(`All target Tensors (y) should have the same number of samples. Got array shapes: ${JSON.stringify(e.map(o=>o.shape))}`);if(s.length>0&&r.length>0&&!Ue(s,r))throw new E(`Input Tensors should have the same number of samples as target Tensors. Found ${s[0]} input sample(s) and ${r[0]} target sample(s).`)}function rH(t,e,n){const s=[Tm,Em,Qc];for(let r=0;r1)throw new E(`The model expects ${e.length} ${r} Tensors, but only received one Tensor. Found: array with shape ${JSON.stringify(t.shape)}.`);o=[t]}if(n!=null)for(let i=0;i[]);let n;if(typeof t=="string"||typeof t=="function")n=[t];else if(Array.isArray(t)||typeof t=="object")n=t;else throw new TypeError(`Type of metrics argument not understood. Expected an string,function, Array, or Object, found: ${t}`);if(Array.isArray(n))return e.map(s=>n);{const s=[];for(const r of e){let o=n.hasOwnProperty(r)?n[r]:[];Array.isArray(o)||(o=[o]),s.push(o)}return s}}const iH="layers-model";class La extends Ms{constructor(e){super(e),this.isTraining=!1}summary(e,n,s=console.log){if(!this.built)throw new E("This model has never been called, thus its weights have not been created yet. So no summary can be displayed. Build the model first (e.g., by calling it on some test data).");W5(this,e,n,s)}compile(e){if(e.loss==null&&(e.loss=[]),this.loss=e.loss,typeof e.optimizer=="string")this.optimizer_=V5(e.optimizer),this.isOptimizerOwned=!0;else{if(!(e.optimizer instanceof Xo))throw new E("User-defined optimizer must be an instance of tf.Optimizer.");this.optimizer_=e.optimizer,this.isOptimizerOwned=!1}let n=[];if(!Array.isArray(e.loss)&&typeof e.loss!="string"&&typeof e.loss!="function"){e.loss=e.loss;for(const i in e.loss)if(this.outputNames.indexOf(i)===-1)throw new E(`Unknown entry in loss dictionary: "${i}". Only expected the following keys: ${this.outputNames}`);for(const i of this.outputNames)e.loss[i]==null&&console.warn(`Output "${i}" is missing from loss dictionary. We assume this was done on purpose, and we will not be expecting data to be passed to ${i} during training`),n.push(Tg(e.loss[i]))}else if(Array.isArray(e.loss)){if(e.loss.length!==this.outputs.length)throw new E(`When passing an Array as loss, it should have one entry per model output. The model has ${this.outputs.length} output(s), but you passed loss=${e.loss}.`);n=e.loss.map(a=>Tg(a))}else{const i=Tg(e.loss);this.outputs.forEach(a=>{n.push(i)})}this.lossFunctions=n,this.feedOutputNames=[],this.feedOutputShapes=[],this.feedLossFns=[];for(let i=0;i{for(let i=0;i1&&(this.metricsTensors.push([a,i]),this.metricsNames.push(this.outputNames[i]+"_loss"))}});const r=oH(e.metrics,this.outputNames),o=(i,a,l)=>{this.outputNames.length>1&&(a=this.outputNames[i]+"_"+a),this.metricsNames.push(a),this.metricsTensors.push([l,i])};bi("metric",()=>{for(let i=0;i{const u="";let d,h,f;for(const p of c){if(typeof p=="string"&&["accuracy","acc","crossentropy","ce"].indexOf(p)!==-1){const x=this.internalOutputShapes[i];x[x.length-1]===1||this.lossFunctions[i]===Em?["accuracy","acc"].indexOf(p)!==-1?h=VT:["crossentropy","ce"].indexOf(p)!==-1&&(h=A5):this.lossFunctions[i]===Ef?["accuracy","acc"].indexOf(p)!==-1?h=D5:["crossentropy","ce"].indexOf(p)!==-1&&(h=GT):["accuracy","acc"].indexOf(p)!==-1?h=WT:["crossentropy","ce"].indexOf(p)!==-1&&(h=UT);let m;["accuracy","acc"].indexOf(p)!==-1?m="acc":["crossentropy","ce"].indexOf(p)!==-1&&(m="ce"),f=h,d=u+m}else f=B5(p),d=u+sh(p);let g;bi(d,()=>{g=f}),o(i,d,g)}})(a)}}),this.collectedTrainableWeights=this.trainableWeights}checkTrainableWeightsConsistency(){this.collectedTrainableWeights!=null&&this.trainableWeights.length!==this.collectedTrainableWeights.length&&console.warn("Discrepancy between trainableweights and collected trainable weights. Did you set `model.trainable` without calling `model.compile()` afterwards?")}evaluate(e,n,s={}){const r=s.batchSize==null?32:s.batchSize;Eg(r);const i=this.standardizeUserDataXY(e,n,!0,r);try{const a=i[0].concat(i[1]);this.makeTestFunction();const l=this.testFunction,c=this.testLoop(l,a,r,s.verbose,s.steps);return Rn(c)}finally{Os(i[0],e),Os(i[1],n)}}async evaluateDataset(e,n){return this.makeTestFunction(),tH(this,e,n)}checkNumSamples(e,n,s,r="steps"){let o;if(s!=null){if(o=null,n!=null)throw new E(`If ${r} is set, batchSize must be null or undefined.Got batchSize = ${n}`)}else if(e!=null)Array.isArray(e)?o=e[0].shape[0]:o=e.shape[0];else throw new E(`Either the input data should have a defined shape, or ${r} shoud be specified.`);return o}execute(e,n){if(Array.isArray(n)&&n.length===0)throw new E("`outputs` is an empty Array, which is not allowed.");const s=Array.isArray(n),r=s?n:[n],o=this.retrieveSymbolicTensors(r),i=new fo;if(e instanceof zt&&(e=[e]),Array.isArray(e)){if(e.length!==this.inputs.length)throw new E(`The number of inputs provided (${e.length}) does not match the number of inputs of this model (${this.inputs.length}).`);for(let l=0;la.name);for(let a=0;a0){const r=[];throw n.forEach((o,i)=>{o==null&&r.push(e[i])}),new E(`Cannot find SymbolicTensors for output name(s): ${JSON.stringify(r)}`)}return n}predictLoop(e,n=32,s=!1){return P(()=>{const r=this.checkNumSamples(e);if(s)throw new Ie("Verbose predictLoop() is not implemented yet.");const o=Rg(r,n),i=this.outputs.map(a=>[]);for(let a=0;a{const c=o[a][0],u=o[a][1],d=jl(e,c,u),h=[];if(Array.isArray(d))for(let p=0;pi[u].push(c));return Rn(i.map(a=>Dn(a,0)))})}predict(e,n={}){const s=YT(e);ak(s,this.inputNames,this.feedInputShapes,!1);try{const r=n.batchSize==null?32:n.batchSize;return Eg(r),this.predictLoop(s,r)}finally{Os(s,e)}}predictOnBatch(e){ak(e,this.inputNames,this.feedInputShapes,!0);const n=(Array.isArray(e)?e[0]:e).shape[0];return this.predictLoop(e,n)}standardizeUserDataXY(e,n,s=!0,r){if(this.optimizer_==null)throw new Cs("You must compile a model before training/testing. Use LayersModel.compile(modelCompileArgs).");const o=[];for(let i=0;i0&&e[0].shape[0]%r!==0)throw new E(`In a stateful network, you should only pass inputs with a number of samples that is divisible by the batch size ${r}. Found: ${e[0].shape[0]} sample(s).`);return[e,n]}async standardizeUserData(e,n,s,r,o=!0,i){const[a,l]=this.standardizeUserDataXY(e,n,o,i);if(s!=null)throw new Error("sample weight is not supported yet.");let c=null;if(r!=null){const u=KT(r,this.outputNames);c=[];for(let d=0;d{const i=this.checkNumSamples(n,s,o,"steps"),a=[];if(r>0)throw new Ie("Verbose mode is not implemented yet.");if(o!=null)throw new Ie("steps mode in testLoop() is not implemented yet");{const l=Rg(i,s),c=Gn(Zs(0,i));for(let u=0;u1){const i=HC(e.slice(0,s),r);o+=`_${i}`}n.push(o)}return n}makeTrainFunction(){return e=>{const n=[],s=e.slice(0,this.inputs.length),r=e.slice(this.inputs.length,this.inputs.length+this.outputs.length),o=e.slice(this.inputs.length+this.outputs.length,this.inputs.length+this.outputs.length*2),i=[],a=()=>{const d=[];for(let g=0;g1&&g{p=J(p,g)}),p},l=this.collectedTrainableWeights.map(d=>d.read());return[this.optimizer_.minimize(a,!0,l)].concat(i)}}makeTestFunction(){this.testFunction=e=>P(()=>{const n=[];let s;const r=e.slice(0,this.inputs.length),o=e.slice(this.inputs.length,this.inputs.length+this.outputs.length),i=[];for(let c=0;c0){if(x=!0,s.validationData.length===2)l=s.validationData[0],c=s.validationData[1];else throw s.validationData.length===3?new Ie("validationData including sample weights is not supported yet."):new E(`When passing validation data, it must contain 2 (valX, valY) or 3 (valX, valY, valSampleWeight) items; ${s.validationData} is invalid.`);const N=await this.standardizeUserData(l,c,null,null,!0,f);u=N[0],d=N[1],m=u.concat(d)}else if(s.validationSplit!=null&&s.validationSplit>0&&s.validationSplit<1){x=!0;const $=Math.floor(r[0].shape[0]*(1-s.validationSplit)),N=r[0].shape[0];u=jl(r,$,N),i=r,r=jl(r,0,$),d=jl(o,$,N),a=o,o=jl(o,0,$),m=u.concat(d)}else s.validationSteps!=null&&(x=!0);const y=r.concat(o).concat(h);this.checkTrainableWeightsConsistency();const w=this.makeTrainFunction(),v=this.getDedupedMetricsNames();let b,C;x?(this.makeTestFunction(),b=this.testFunction,C=v.slice().concat(v.map($=>"val_"+$))):(b=null,m=[],C=v.slice());const k=PT(s.callbacks,s.yieldEvery);return await this.fitLoop(w,y,v,f,s.epochs,s.verbose,k,b,m,s.shuffle,C,s.initialEpoch,null,null)}finally{this.isTraining=!1,Os(r,e),Os(o,n),Os(i,e),Os(a,n),Os(u,l),Os(d,c),h!=null&&$e(h)}}async fitLoop(e,n,s,r,o,i,a,l,c,u,d,h,f,p){r==null&&(r=32),o==null&&(o=1),u==null&&(u=!0),h==null&&(h=0);let g=!1;if(l!=null&&c!=null&&(g=!0),p!=null&&(g=!0,f==null))throw new E("Can only use `validationSteps` when doing step-wise training, i.e., `stepsPerEpoch` must be set.");const x=this.checkNumSamples(n,r,f,"steps_per_epoch");let m;x!=null&&(m=Zs(0,x)),i==null&&(i=1);const{callbackList:y,history:w}=LT(a,i,o,h,x,f,r,g,d);y.setModel(this),this.history=w,await y.onTrainBegin(),this.stopTraining_=!1;for(let v=h;v{const N=k[S][0],A=k[S][1],M=Ci(C,N,A-N);$.batch=S,$.size=A-N;const L=k1(n,M),V=e(L);for(let B=0;BDr(n))}else{const n=Object.keys(this.loss);e={};const s=this.loss;for(const r of n)if(typeof s[r]=="string")e[r]=Dr(s[r]);else throw new Error("Serialization of non-string loss is not supported.")}return e}getMetricIdentifiers(){if(typeof this.metrics=="string"||typeof this.metrics=="function")return[Dr(sh(this.metrics))];if(Array.isArray(this.metrics))return this.metrics.map(e=>Dr(sh(e)));{const e={};for(const n in this.metrics)e[n]=Dr(sh(this.metrics[n]));return e}}getTrainingConfig(){return{loss:this.getLossIdentifiers(),metrics:this.getMetricIdentifiers(),optimizer_config:{class_name:this.optimizer.getClassName(),config:this.optimizer.getConfig()}}}loadTrainingConfig(e){if(e.weighted_metrics!=null)throw new Error("Loading weight_metrics is not supported yet.");if(e.loss_weights!=null)throw new Error("Loading loss_weights is not supported yet.");if(e.sample_weight_mode!=null)throw new Error("Loading sample_weight_mode is not supported yet.");const n=_f(e.optimizer_config),s=br(n);let r;if(typeof e.loss=="string")r=ii(e.loss);else if(Array.isArray(e.loss))r=e.loss.map(i=>ii(i));else if(e.loss!=null){r={};for(const i in e.loss)r[i]=ii(e.loss[i])}let o;if(Array.isArray(e.metrics))o=e.metrics.map(i=>ii(i));else if(e.metrics!=null){o={};for(const i in e.metrics)o[i]=ii(e.metrics[i])}this.compile({loss:r,metrics:o,optimizer:s})}async save(e,n){if(typeof e=="string"){const c=DP(e);if(c.length===0)throw new E(`Cannot find any save handlers for URL '${e}'`);if(c.length>1)throw new E(`Found more than one (${c.length}) save handlers for URL '${e}'`);e=c[0]}if(e.save==null)throw new E("LayersModel.save() cannot proceed because the IOHandler provided does not have the `save` attribute defined.");const s=await $C(this.getNamedWeights(n)),a={modelTopology:this.toJSON(null,!1),format:iH,generatedBy:`TensorFlow.js tfjs-layers v${jT}`,convertedBy:null};if((n==null?!1:n.includeOptimizer)&&this.optimizer!=null){a.trainingConfig=this.getTrainingConfig();const c="optimizer",{data:u,specs:d}=await $C(await this.optimizer.getWeights(),c);s.specs.push(...d),s.data=SP([s.data,u])}return this.userDefinedMetadata!=null&&(nk(this.userDefinedMetadata,this.name,!0),a.userDefinedMetadata=this.userDefinedMetadata),a.weightData=s.data,a.weightSpecs=s.specs,e.save(a)}setUserDefinedMetadata(e){nk(e,this.name),this.userDefinedMetadata=e}getUserDefinedMetadata(){return this.userDefinedMetadata}}La.className="Model";Y(La);class QT extends La{}QT.className="Functional";Y(QT);/** + */function sH(t){return t instanceof zt}function S1(t){return Array.isArray(t)}function ok(t){return!sH(t)&&!S1(t)}function ik(t,e,n,s=!0,r=""){if(e==null||e.length===0){if(t!=null){let i=!1;if(S1(t)&&t.length>0)i=!0;else if(ok(t)){for(const a in t)if(t.hasOwnProperty(a)){i=!0;break}}else i=!0;if(i)throw new E(`Error when checking model ${r} expected no data, but got ${t}`)}return[]}if(t==null)return e.map(i=>null);let o;if(ok(t)){t=t,o=[];for(const i of e){if(t[i]==null)throw new E(`No data provided for "${i}". Need data for each key in: ${e}`);o.push(t[i])}}else if(S1(t)){if(t=t,t.length!==e.length)throw new E(`Error when checking model ${r}: the Array of Tensors that you are passing to your model is not the size the model expected. Expected to see ${e.length} Tensor(s), but instead got the following list of Tensor(s): ${t}`);o=t}else{if(t=t,e.length>1)throw new E(`The model ${r} expects ${e.length} Tensor(s), but only received one Tensor. Found: Tensor with shape ${t.shape}`);o=[t]}if(o=QT(o),n!=null)for(let i=0;i=0&&c!==u)throw new E(`${r} expected a batch of elements where each example has shape [${n[i].slice(1,n[i].length)}] (i.e.,tensor shape [*,${n[i].slice(1,n[i].length)}]) but the ${r} received an input with ${a.shape[0]} examples, each with shape [${a.shape.slice(1,a.shape.length)}] (tensor shape [${a.shape}])`)}}return o}function rH(t,e,n){const s=To(t.map(o=>o.shape[0]));s.sort();const r=To(e.map(o=>o.shape[0]));if(r.sort(),s.length>1)throw new E(`All input Tensors (x) should have the same number of samples. Got array shapes: ${JSON.stringify(t.map(o=>o.shape))}`);if(r.length>1)throw new E(`All target Tensors (y) should have the same number of samples. Got array shapes: ${JSON.stringify(e.map(o=>o.shape))}`);if(s.length>0&&r.length>0&&!Ue(s,r))throw new E(`Input Tensors should have the same number of samples as target Tensors. Found ${s[0]} input sample(s) and ${r[0]} target sample(s).`)}function oH(t,e,n){const s=[Tm,Em,Qc];for(let r=0;r1)throw new E(`The model expects ${e.length} ${r} Tensors, but only received one Tensor. Found: array with shape ${JSON.stringify(t.shape)}.`);o=[t]}if(n!=null)for(let i=0;i[]);let n;if(typeof t=="string"||typeof t=="function")n=[t];else if(Array.isArray(t)||typeof t=="object")n=t;else throw new TypeError(`Type of metrics argument not understood. Expected an string,function, Array, or Object, found: ${t}`);if(Array.isArray(n))return e.map(s=>n);{const s=[];for(const r of e){let o=n.hasOwnProperty(r)?n[r]:[];Array.isArray(o)||(o=[o]),s.push(o)}return s}}const aH="layers-model";class La extends Ps{constructor(e){super(e),this.isTraining=!1}summary(e,n,s=console.log){if(!this.built)throw new E("This model has never been called, thus its weights have not been created yet. So no summary can be displayed. Build the model first (e.g., by calling it on some test data).");U5(this,e,n,s)}compile(e){if(e.loss==null&&(e.loss=[]),this.loss=e.loss,typeof e.optimizer=="string")this.optimizer_=W5(e.optimizer),this.isOptimizerOwned=!0;else{if(!(e.optimizer instanceof Xo))throw new E("User-defined optimizer must be an instance of tf.Optimizer.");this.optimizer_=e.optimizer,this.isOptimizerOwned=!1}let n=[];if(!Array.isArray(e.loss)&&typeof e.loss!="string"&&typeof e.loss!="function"){e.loss=e.loss;for(const i in e.loss)if(this.outputNames.indexOf(i)===-1)throw new E(`Unknown entry in loss dictionary: "${i}". Only expected the following keys: ${this.outputNames}`);for(const i of this.outputNames)e.loss[i]==null&&console.warn(`Output "${i}" is missing from loss dictionary. We assume this was done on purpose, and we will not be expecting data to be passed to ${i} during training`),n.push(Tg(e.loss[i]))}else if(Array.isArray(e.loss)){if(e.loss.length!==this.outputs.length)throw new E(`When passing an Array as loss, it should have one entry per model output. The model has ${this.outputs.length} output(s), but you passed loss=${e.loss}.`);n=e.loss.map(a=>Tg(a))}else{const i=Tg(e.loss);this.outputs.forEach(a=>{n.push(i)})}this.lossFunctions=n,this.feedOutputNames=[],this.feedOutputShapes=[],this.feedLossFns=[];for(let i=0;i{for(let i=0;i1&&(this.metricsTensors.push([a,i]),this.metricsNames.push(this.outputNames[i]+"_loss"))}});const r=iH(e.metrics,this.outputNames),o=(i,a,l)=>{this.outputNames.length>1&&(a=this.outputNames[i]+"_"+a),this.metricsNames.push(a),this.metricsTensors.push([l,i])};bi("metric",()=>{for(let i=0;i{const u="";let h,d,f;for(const p of c){if(typeof p=="string"&&["accuracy","acc","crossentropy","ce"].indexOf(p)!==-1){const x=this.internalOutputShapes[i];x[x.length-1]===1||this.lossFunctions[i]===Em?["accuracy","acc"].indexOf(p)!==-1?d=WT:["crossentropy","ce"].indexOf(p)!==-1&&(d=D5):this.lossFunctions[i]===Ef?["accuracy","acc"].indexOf(p)!==-1?d=_5:["crossentropy","ce"].indexOf(p)!==-1&&(d=HT):["accuracy","acc"].indexOf(p)!==-1?d=UT:["crossentropy","ce"].indexOf(p)!==-1&&(d=GT);let m;["accuracy","acc"].indexOf(p)!==-1?m="acc":["crossentropy","ce"].indexOf(p)!==-1&&(m="ce"),f=d,h=u+m}else f=V5(p),h=u+sd(p);let g;bi(h,()=>{g=f}),o(i,h,g)}})(a)}}),this.collectedTrainableWeights=this.trainableWeights}checkTrainableWeightsConsistency(){this.collectedTrainableWeights!=null&&this.trainableWeights.length!==this.collectedTrainableWeights.length&&console.warn("Discrepancy between trainableweights and collected trainable weights. Did you set `model.trainable` without calling `model.compile()` afterwards?")}evaluate(e,n,s={}){const r=s.batchSize==null?32:s.batchSize;Eg(r);const i=this.standardizeUserDataXY(e,n,!0,r);try{const a=i[0].concat(i[1]);this.makeTestFunction();const l=this.testFunction,c=this.testLoop(l,a,r,s.verbose,s.steps);return Rn(c)}finally{Ms(i[0],e),Ms(i[1],n)}}async evaluateDataset(e,n){return this.makeTestFunction(),nH(this,e,n)}checkNumSamples(e,n,s,r="steps"){let o;if(s!=null){if(o=null,n!=null)throw new E(`If ${r} is set, batchSize must be null or undefined.Got batchSize = ${n}`)}else if(e!=null)Array.isArray(e)?o=e[0].shape[0]:o=e.shape[0];else throw new E(`Either the input data should have a defined shape, or ${r} shoud be specified.`);return o}execute(e,n){if(Array.isArray(n)&&n.length===0)throw new E("`outputs` is an empty Array, which is not allowed.");const s=Array.isArray(n),r=s?n:[n],o=this.retrieveSymbolicTensors(r),i=new fo;if(e instanceof zt&&(e=[e]),Array.isArray(e)){if(e.length!==this.inputs.length)throw new E(`The number of inputs provided (${e.length}) does not match the number of inputs of this model (${this.inputs.length}).`);for(let l=0;la.name);for(let a=0;a0){const r=[];throw n.forEach((o,i)=>{o==null&&r.push(e[i])}),new E(`Cannot find SymbolicTensors for output name(s): ${JSON.stringify(r)}`)}return n}predictLoop(e,n=32,s=!1){return P(()=>{const r=this.checkNumSamples(e);if(s)throw new Ie("Verbose predictLoop() is not implemented yet.");const o=Rg(r,n),i=this.outputs.map(a=>[]);for(let a=0;a{const c=o[a][0],u=o[a][1],h=jl(e,c,u),d=[];if(Array.isArray(h))for(let p=0;pi[u].push(c));return Rn(i.map(a=>Dn(a,0)))})}predict(e,n={}){const s=QT(e);ak(s,this.inputNames,this.feedInputShapes,!1);try{const r=n.batchSize==null?32:n.batchSize;return Eg(r),this.predictLoop(s,r)}finally{Ms(s,e)}}predictOnBatch(e){ak(e,this.inputNames,this.feedInputShapes,!0);const n=(Array.isArray(e)?e[0]:e).shape[0];return this.predictLoop(e,n)}standardizeUserDataXY(e,n,s=!0,r){if(this.optimizer_==null)throw new ks("You must compile a model before training/testing. Use LayersModel.compile(modelCompileArgs).");const o=[];for(let i=0;i0&&e[0].shape[0]%r!==0)throw new E(`In a stateful network, you should only pass inputs with a number of samples that is divisible by the batch size ${r}. Found: ${e[0].shape[0]} sample(s).`);return[e,n]}async standardizeUserData(e,n,s,r,o=!0,i){const[a,l]=this.standardizeUserDataXY(e,n,o,i);if(s!=null)throw new Error("sample weight is not supported yet.");let c=null;if(r!=null){const u=XT(r,this.outputNames);c=[];for(let h=0;h{const i=this.checkNumSamples(n,s,o,"steps"),a=[];if(r>0)throw new Ie("Verbose mode is not implemented yet.");if(o!=null)throw new Ie("steps mode in testLoop() is not implemented yet");{const l=Rg(i,s),c=Gn(Js(0,i));for(let u=0;u1){const i=HC(e.slice(0,s),r);o+=`_${i}`}n.push(o)}return n}makeTrainFunction(){return e=>{const n=[],s=e.slice(0,this.inputs.length),r=e.slice(this.inputs.length,this.inputs.length+this.outputs.length),o=e.slice(this.inputs.length+this.outputs.length,this.inputs.length+this.outputs.length*2),i=[],a=()=>{const h=[];for(let g=0;g1&&g{p=J(p,g)}),p},l=this.collectedTrainableWeights.map(h=>h.read());return[this.optimizer_.minimize(a,!0,l)].concat(i)}}makeTestFunction(){this.testFunction=e=>P(()=>{const n=[];let s;const r=e.slice(0,this.inputs.length),o=e.slice(this.inputs.length,this.inputs.length+this.outputs.length),i=[];for(let c=0;c0){if(x=!0,s.validationData.length===2)l=s.validationData[0],c=s.validationData[1];else throw s.validationData.length===3?new Ie("validationData including sample weights is not supported yet."):new E(`When passing validation data, it must contain 2 (valX, valY) or 3 (valX, valY, valSampleWeight) items; ${s.validationData} is invalid.`);const N=await this.standardizeUserData(l,c,null,null,!0,f);u=N[0],h=N[1],m=u.concat(h)}else if(s.validationSplit!=null&&s.validationSplit>0&&s.validationSplit<1){x=!0;const $=Math.floor(r[0].shape[0]*(1-s.validationSplit)),N=r[0].shape[0];u=jl(r,$,N),i=r,r=jl(r,0,$),h=jl(o,$,N),a=o,o=jl(o,0,$),m=u.concat(h)}else s.validationSteps!=null&&(x=!0);const y=r.concat(o).concat(d);this.checkTrainableWeightsConsistency();const w=this.makeTrainFunction(),v=this.getDedupedMetricsNames();let b,C;x?(this.makeTestFunction(),b=this.testFunction,C=v.slice().concat(v.map($=>"val_"+$))):(b=null,m=[],C=v.slice());const k=LT(s.callbacks,s.yieldEvery);return await this.fitLoop(w,y,v,f,s.epochs,s.verbose,k,b,m,s.shuffle,C,s.initialEpoch,null,null)}finally{this.isTraining=!1,Ms(r,e),Ms(o,n),Ms(i,e),Ms(a,n),Ms(u,l),Ms(h,c),d!=null&&$e(d)}}async fitLoop(e,n,s,r,o,i,a,l,c,u,h,d,f,p){r==null&&(r=32),o==null&&(o=1),u==null&&(u=!0),d==null&&(d=0);let g=!1;if(l!=null&&c!=null&&(g=!0),p!=null&&(g=!0,f==null))throw new E("Can only use `validationSteps` when doing step-wise training, i.e., `stepsPerEpoch` must be set.");const x=this.checkNumSamples(n,r,f,"steps_per_epoch");let m;x!=null&&(m=Js(0,x)),i==null&&(i=1);const{callbackList:y,history:w}=BT(a,i,o,d,x,f,r,g,h);y.setModel(this),this.history=w,await y.onTrainBegin(),this.stopTraining_=!1;for(let v=d;v{const N=k[S][0],A=k[S][1],M=Ci(C,N,A-N);$.batch=S,$.size=A-N;const L=k1(n,M),V=e(L);for(let B=0;B_r(n))}else{const n=Object.keys(this.loss);e={};const s=this.loss;for(const r of n)if(typeof s[r]=="string")e[r]=_r(s[r]);else throw new Error("Serialization of non-string loss is not supported.")}return e}getMetricIdentifiers(){if(typeof this.metrics=="string"||typeof this.metrics=="function")return[_r(sd(this.metrics))];if(Array.isArray(this.metrics))return this.metrics.map(e=>_r(sd(e)));{const e={};for(const n in this.metrics)e[n]=_r(sd(this.metrics[n]));return e}}getTrainingConfig(){return{loss:this.getLossIdentifiers(),metrics:this.getMetricIdentifiers(),optimizer_config:{class_name:this.optimizer.getClassName(),config:this.optimizer.getConfig()}}}loadTrainingConfig(e){if(e.weighted_metrics!=null)throw new Error("Loading weight_metrics is not supported yet.");if(e.loss_weights!=null)throw new Error("Loading loss_weights is not supported yet.");if(e.sample_weight_mode!=null)throw new Error("Loading sample_weight_mode is not supported yet.");const n=_f(e.optimizer_config),s=Cr(n);let r;if(typeof e.loss=="string")r=ii(e.loss);else if(Array.isArray(e.loss))r=e.loss.map(i=>ii(i));else if(e.loss!=null){r={};for(const i in e.loss)r[i]=ii(e.loss[i])}let o;if(Array.isArray(e.metrics))o=e.metrics.map(i=>ii(i));else if(e.metrics!=null){o={};for(const i in e.metrics)o[i]=ii(e.metrics[i])}this.compile({loss:r,metrics:o,optimizer:s})}async save(e,n){if(typeof e=="string"){const c=_P(e);if(c.length===0)throw new E(`Cannot find any save handlers for URL '${e}'`);if(c.length>1)throw new E(`Found more than one (${c.length}) save handlers for URL '${e}'`);e=c[0]}if(e.save==null)throw new E("LayersModel.save() cannot proceed because the IOHandler provided does not have the `save` attribute defined.");const s=await $C(this.getNamedWeights(n)),a={modelTopology:this.toJSON(null,!1),format:aH,generatedBy:`TensorFlow.js tfjs-layers v${KT}`,convertedBy:null};if((n==null?!1:n.includeOptimizer)&&this.optimizer!=null){a.trainingConfig=this.getTrainingConfig();const c="optimizer",{data:u,specs:h}=await $C(await this.optimizer.getWeights(),c);s.specs.push(...h),s.data=IP([s.data,u])}return this.userDefinedMetadata!=null&&(nk(this.userDefinedMetadata,this.name,!0),a.userDefinedMetadata=this.userDefinedMetadata),a.weightData=s.data,a.weightSpecs=s.specs,e.save(a)}setUserDefinedMetadata(e){nk(e,this.name),this.userDefinedMetadata=e}getUserDefinedMetadata(){return this.userDefinedMetadata}}La.className="Model";Y(La);class ZT extends La{}ZT.className="Functional";Y(ZT);/** * @license * Copyright 2018 Google LLC * @@ -7825,7 +7825,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */async function aH(t,e){if(e==null&&(e={}),typeof t=="string"){const n=_P(t,e);if(n.length===0)n.push(pU(t,e));else if(n.length>1)throw new E(`Found more than one (${n.length}) load handlers for URL '${t}'`);t=n[0]}return lH(t,void 0,e)}async function lH(t,e,n){if(n==null&&(n={}),t.load==null)throw new E("Cannot proceed with model loading because the IOHandler provided does not have the `load` method implemented.");const s=await t.load();let r=s.modelTopology;r.model_config!=null&&(r=r.model_config);const o=n.strict==null?!0:n.strict,i=s.weightData!=null&&s.weightSpecs!=null&&o,a=br(_f(r),e,i),l=s.trainingConfig;if(l!=null&&a.loadTrainingConfig(l),s.userDefinedMetadata!=null&&a.setUserDefinedMetadata(s.userDefinedMetadata),s.weightData!=null){if(s.weightSpecs==null)throw new E("LayersModel artifacts contains weight data, but not weight specs. Therefore loading of weights cannot proceed.");const{modelWeights:c,optimizerWeights:u}=cH(s.weightData,s.weightSpecs);a.loadWeights(c,o),a.optimizer!=null&&u.length>0&&await a.optimizer.setWeights(u),$e(c),$e(u.map(d=>d.tensor))}return a}function cH(t,e){const n=yP(t,e),s={},r=[];return e.forEach(o=>{o.group==="optimizer"?r.push({name:o.name,tensor:n[o.name]}):s[o.name]=n[o.name]}),{modelWeights:s,optimizerWeights:r}}class Zc extends La{constructor(e){if(super({inputs:[],outputs:[]}),e=e||{},this.trainable=!0,this.built=!1,this.name=e.name!=null?e.name:Im("sequential_"),e.layers!=null)for(const n of e.layers)this.add(n)}checkShape(e){if(e.inboundNodes[0].outputTensors[0].shape.some(s=>s<0))throw new E(`Negative dimension size caused by adding layer ${e.name} with input shape [${e.inboundNodes[0].inputTensors[0].shape}]`)}add(e){const n=e instanceof Zc||e instanceof La;let s;if(n){if(s=e,s.outputs.length!==1)throw new E("All layers in a Sequential model should have a single output tensor. For multi-output layers, use the functional API.");if(s.inputs.length!==1)throw new E("All layers in a Sequential model should have a single input tensor. For multi-input layers, use the functional API.")}if(this.outputs.length===0){if(e.inboundNodes.length===0){if(e.batchInputShape==null)throw new E("The first layer in a Sequential model must get an `inputShape` or `batchInputShape` argument.");const r=l5({batchShape:e.batchInputShape,dtype:e.dtype,name:e.name+"_input"});e.apply(r)}if(n)this.outputs=s.outputs,this.inputs=s.inputs;else{if(e.inboundNodes.length!==1)throw new E(`A layer added to a Sequential model must not already be connected somewhere else. LayersModel received layer ${e.name} which has ${e.inboundNodes.length} pre-existing inbound connections.`);if(e.inboundNodes[0].outputTensors.length!==1)throw new E("All layers in a Sequential model should have a single output tensor. For multi-output layers, use the functional API.");this.checkShape(e),this.outputs=[e.inboundNodes[0].outputTensors[0]],this.inputs=DT(this.outputs[0])}this.inboundNodes=[],new Nm({outboundLayer:this,inboundLayers:[],nodeIndices:[],tensorIndices:[],inputTensors:this.inputs,outputTensors:this.outputs,inputMasks:Li(null,this.inputs.length),outputMasks:[null],inputShapes:this.inputs.map(r=>r.shape),outputShapes:this.outputs[0].shape})}else{const r=e.apply(this.outputs[0]);if(Array.isArray(r))throw new TypeError("All layers in a Sequential model should have a single output tensor. For multi-output layers, use the functional API.");this.checkShape(e),this.outputs=[r],this.inboundNodes[0].outputTensors=this.outputs,this.inboundNodes[0].outputShapes=[this.outputs[0].shape]}this.layers.push(e),this.built=!1}pop(){if(this.layers.length===0)throw new TypeError("There are no layers in the model.");if(this.layers.pop(),this.layers.length===0)this.outputs=[],this.inboundNodes=[],this.outboundNodes=[];else{const e=this.layers.length-1;this.layers[e].outboundNodes=[],this.outputs=[this.layers[e].output],this.inboundNodes[0].outputTensors=this.outputs,this.inboundNodes[0].outputShapes=[this.outputs[0].shape]}}call(e,n){return this.model==null&&this.build(),this.model.call(e,n)}build(e){if(Pe(e),this.inputs.length===0||this.outputs.length===0)throw new TypeError("Sequential model cannot be built: model is empty. Add some layers first.");this.model=new La({inputs:this.inputs,outputs:this.outputs[0],name:this.name+"_model"}),this.model.trainable=this.trainable,this.supportsMasking=this.model.supportsMasking,this.inputLayers=this.model.inputLayers,this.inputLayersNodeIndices=this.model.inputLayersNodeIndices,this.inputLayersTensorIndices=this.model.inputLayersTensorIndices,this.outputLayers=this.model.outputLayers,this.outputLayersNodeIndices=this.model.outputLayersNodeIndices,this.outputLayersTensorIndices=this.model.outputLayersTensorIndices,this.nodesByDepth=this.model.nodesByDepth,this.containerNodes=this.model.containerNodes,this.outputNames=this.model.outputNames,this.inputNames=this.model.inputNames,this.built=!0}countParams(){return this.built||this.build(),super.countParams()}summary(e,n,s=console.log){this.built||this.build(),super.summary(e,n,s)}setWeights(e){this.model==null&&this.build(),this.model.setWeights(e)}evaluate(e,n,s={}){if(!this.built)throw new Cs("The model needs to be compiled before being used.");return this.model.evaluate(e,n,s)}async evaluateDataset(e,n){if(!this.built)throw new Cs("The model needs to be compiled before being used.");return this.model.evaluateDataset(e,n)}predict(e,n={}){return this.model==null&&this.build(),this.model.predict(e,n)}predictOnBatch(e){return this.model==null&&this.build(),this.model.predictOnBatch(e)}compile(e){this.build(),this.model.compile(e),this.optimizer_=this.model.optimizer,this.isOptimizerOwned=this.model.isOptimizerOwned,this.loss=this.model.loss,this.metrics=this.model.metrics,this.metricsTensors=this.model.metricsTensors,this.metricsNames=this.model.metricsNames}get optimizer(){return this.model==null?void 0:this.model.optimizer}set optimizer(e){this.model.optimizer=e}async fit(e,n,s={}){if(!this.built)throw new Cs("The model needs to be compiled before being used.");return this.model.fit(e,n,s)}async fitDataset(e,n){if(!this.built)throw new Cs("The model needs to be compiled before being used.");return this.model.fitDataset(e,n)}async trainOnBatch(e,n){return this.model.trainOnBatch(e,n)}static fromConfig(e,n,s={},r=!1){let o,i={};if(n instanceof Array){if(n[0].className==null||n[0].className==="Merge")throw new E("Legacy serialization format not supported yet.");o=n}else I(n.layers!=null,()=>"When the config data for a Sequential model is not an Array, it must be an Object that contains the 'layers' field."),o=n.layers,delete n.layers,i=n;const a=new e(i);if(!(a instanceof Zc))throw new Ie(`Sequential.fromConfig called on non-Sequential input: ${a}`);for(const l of o){const u=br(l,void 0,r);r&&u.setFastWeightInitDuringBuild(!0),a.add(u)}return a}set stopTraining(e){if(this.model==null)throw new E("Cannot set the stopTraining property of a sequential model before it is compiled.");this.model.stopTraining=e}get stopTraining(){if(this.model==null)throw new E("Cannot get the stopTraining property of a sequential model before it is compiled.");return this.model.stopTraining}getConfig(){const e=[];for(const n of this.layers){const s={};s.className=n.getClassName(),s.config=n.getConfig(),e.push(s)}return{name:this.name,layers:e}}}Zc.className="Sequential";Y(Zc);/** + */async function lH(t,e){if(e==null&&(e={}),typeof t=="string"){const n=FP(t,e);if(n.length===0)n.push(mU(t,e));else if(n.length>1)throw new E(`Found more than one (${n.length}) load handlers for URL '${t}'`);t=n[0]}return cH(t,void 0,e)}async function cH(t,e,n){if(n==null&&(n={}),t.load==null)throw new E("Cannot proceed with model loading because the IOHandler provided does not have the `load` method implemented.");const s=await t.load();let r=s.modelTopology;r.model_config!=null&&(r=r.model_config);const o=n.strict==null?!0:n.strict,i=s.weightData!=null&&s.weightSpecs!=null&&o,a=Cr(_f(r),e,i),l=s.trainingConfig;if(l!=null&&a.loadTrainingConfig(l),s.userDefinedMetadata!=null&&a.setUserDefinedMetadata(s.userDefinedMetadata),s.weightData!=null){if(s.weightSpecs==null)throw new E("LayersModel artifacts contains weight data, but not weight specs. Therefore loading of weights cannot proceed.");const{modelWeights:c,optimizerWeights:u}=uH(s.weightData,s.weightSpecs);a.loadWeights(c,o),a.optimizer!=null&&u.length>0&&await a.optimizer.setWeights(u),$e(c),$e(u.map(h=>h.tensor))}return a}function uH(t,e){const n=wP(t,e),s={},r=[];return e.forEach(o=>{o.group==="optimizer"?r.push({name:o.name,tensor:n[o.name]}):s[o.name]=n[o.name]}),{modelWeights:s,optimizerWeights:r}}class Zc extends La{constructor(e){if(super({inputs:[],outputs:[]}),e=e||{},this.trainable=!0,this.built=!1,this.name=e.name!=null?e.name:Im("sequential_"),e.layers!=null)for(const n of e.layers)this.add(n)}checkShape(e){if(e.inboundNodes[0].outputTensors[0].shape.some(s=>s<0))throw new E(`Negative dimension size caused by adding layer ${e.name} with input shape [${e.inboundNodes[0].inputTensors[0].shape}]`)}add(e){const n=e instanceof Zc||e instanceof La;let s;if(n){if(s=e,s.outputs.length!==1)throw new E("All layers in a Sequential model should have a single output tensor. For multi-output layers, use the functional API.");if(s.inputs.length!==1)throw new E("All layers in a Sequential model should have a single input tensor. For multi-input layers, use the functional API.")}if(this.outputs.length===0){if(e.inboundNodes.length===0){if(e.batchInputShape==null)throw new E("The first layer in a Sequential model must get an `inputShape` or `batchInputShape` argument.");const r=c5({batchShape:e.batchInputShape,dtype:e.dtype,name:e.name+"_input"});e.apply(r)}if(n)this.outputs=s.outputs,this.inputs=s.inputs;else{if(e.inboundNodes.length!==1)throw new E(`A layer added to a Sequential model must not already be connected somewhere else. LayersModel received layer ${e.name} which has ${e.inboundNodes.length} pre-existing inbound connections.`);if(e.inboundNodes[0].outputTensors.length!==1)throw new E("All layers in a Sequential model should have a single output tensor. For multi-output layers, use the functional API.");this.checkShape(e),this.outputs=[e.inboundNodes[0].outputTensors[0]],this.inputs=_T(this.outputs[0])}this.inboundNodes=[],new Nm({outboundLayer:this,inboundLayers:[],nodeIndices:[],tensorIndices:[],inputTensors:this.inputs,outputTensors:this.outputs,inputMasks:Li(null,this.inputs.length),outputMasks:[null],inputShapes:this.inputs.map(r=>r.shape),outputShapes:this.outputs[0].shape})}else{const r=e.apply(this.outputs[0]);if(Array.isArray(r))throw new TypeError("All layers in a Sequential model should have a single output tensor. For multi-output layers, use the functional API.");this.checkShape(e),this.outputs=[r],this.inboundNodes[0].outputTensors=this.outputs,this.inboundNodes[0].outputShapes=[this.outputs[0].shape]}this.layers.push(e),this.built=!1}pop(){if(this.layers.length===0)throw new TypeError("There are no layers in the model.");if(this.layers.pop(),this.layers.length===0)this.outputs=[],this.inboundNodes=[],this.outboundNodes=[];else{const e=this.layers.length-1;this.layers[e].outboundNodes=[],this.outputs=[this.layers[e].output],this.inboundNodes[0].outputTensors=this.outputs,this.inboundNodes[0].outputShapes=[this.outputs[0].shape]}}call(e,n){return this.model==null&&this.build(),this.model.call(e,n)}build(e){if(Pe(e),this.inputs.length===0||this.outputs.length===0)throw new TypeError("Sequential model cannot be built: model is empty. Add some layers first.");this.model=new La({inputs:this.inputs,outputs:this.outputs[0],name:this.name+"_model"}),this.model.trainable=this.trainable,this.supportsMasking=this.model.supportsMasking,this.inputLayers=this.model.inputLayers,this.inputLayersNodeIndices=this.model.inputLayersNodeIndices,this.inputLayersTensorIndices=this.model.inputLayersTensorIndices,this.outputLayers=this.model.outputLayers,this.outputLayersNodeIndices=this.model.outputLayersNodeIndices,this.outputLayersTensorIndices=this.model.outputLayersTensorIndices,this.nodesByDepth=this.model.nodesByDepth,this.containerNodes=this.model.containerNodes,this.outputNames=this.model.outputNames,this.inputNames=this.model.inputNames,this.built=!0}countParams(){return this.built||this.build(),super.countParams()}summary(e,n,s=console.log){this.built||this.build(),super.summary(e,n,s)}setWeights(e){this.model==null&&this.build(),this.model.setWeights(e)}evaluate(e,n,s={}){if(!this.built)throw new ks("The model needs to be compiled before being used.");return this.model.evaluate(e,n,s)}async evaluateDataset(e,n){if(!this.built)throw new ks("The model needs to be compiled before being used.");return this.model.evaluateDataset(e,n)}predict(e,n={}){return this.model==null&&this.build(),this.model.predict(e,n)}predictOnBatch(e){return this.model==null&&this.build(),this.model.predictOnBatch(e)}compile(e){this.build(),this.model.compile(e),this.optimizer_=this.model.optimizer,this.isOptimizerOwned=this.model.isOptimizerOwned,this.loss=this.model.loss,this.metrics=this.model.metrics,this.metricsTensors=this.model.metricsTensors,this.metricsNames=this.model.metricsNames}get optimizer(){return this.model==null?void 0:this.model.optimizer}set optimizer(e){this.model.optimizer=e}async fit(e,n,s={}){if(!this.built)throw new ks("The model needs to be compiled before being used.");return this.model.fit(e,n,s)}async fitDataset(e,n){if(!this.built)throw new ks("The model needs to be compiled before being used.");return this.model.fitDataset(e,n)}async trainOnBatch(e,n){return this.model.trainOnBatch(e,n)}static fromConfig(e,n,s={},r=!1){let o,i={};if(n instanceof Array){if(n[0].className==null||n[0].className==="Merge")throw new E("Legacy serialization format not supported yet.");o=n}else I(n.layers!=null,()=>"When the config data for a Sequential model is not an Array, it must be an Object that contains the 'layers' field."),o=n.layers,delete n.layers,i=n;const a=new e(i);if(!(a instanceof Zc))throw new Ie(`Sequential.fromConfig called on non-Sequential input: ${a}`);for(const l of o){const u=Cr(l,void 0,r);r&&u.setFastWeightInitDuringBuild(!0),a.add(u)}return a}set stopTraining(e){if(this.model==null)throw new E("Cannot set the stopTraining property of a sequential model before it is compiled.");this.model.stopTraining=e}get stopTraining(){if(this.model==null)throw new E("Cannot get the stopTraining property of a sequential model before it is compiled.");return this.model.stopTraining}getConfig(){const e=[];for(const n of this.layers){const s={};s.className=n.getClassName(),s.config=n.getConfig(),e.push(s)}return{name:this.name,layers:e}}}Zc.className="Sequential";Y(Zc);/** * @license * Copyright 2018 Google LLC * @@ -7833,7 +7833,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */let fn=class extends Il{getConfig(){return{}}};class ZT extends fn{apply(e,n=1){return j6(e,n)}}ZT.className="elu";Y(ZT);class JT extends fn{apply(e){return pN(e)}}JT.className="selu";Y(JT);class eE extends fn{apply(e){return Yi(e)}}eE.className="relu";Y(eE);class tE extends fn{apply(e){return P(()=>Xc(6,Yi(e)))}}tE.className="relu6";Y(tE);class nE extends fn{apply(e){return e}}nE.className="linear";Y(nE);class sE extends fn{apply(e){return Cl(e)}}sE.className="sigmoid";Y(sE);class rE extends fn{apply(e){return X6(e)}}rE.className="hardSigmoid";Y(rE);class oE extends fn{apply(e){return hd(e)}}oE.className="softplus";Y(oE);class iE extends fn{apply(e){return K6(e)}}iE.className="softsign";Y(iE);class aE extends fn{apply(e){return mm(e)}}aE.className="tanh";Y(aE);let rv=class extends fn{apply(e,n=-1){return iw(e,n)}};rv.className="softmax";Y(rv);class lE extends fn{apply(e,n=-1){return oN(e,n)}}lE.className="logSoftmax";Y(lE);class cE extends fn{apply(e){return P(()=>P(()=>{const n=Math.sqrt(2),s=D(.5,J(1,eN(ge(e,n))));return D(e,s)}))}}cE.className="gelu";Y(cE);class uE extends fn{apply(e){return P(()=>D(.5,D(e,J(1,mm(D(dn(ge(2,Math.PI)),J(e,D(.044715,Oi(e,3)))))))))}}uE.className="gelu_new";Y(uE);class dE extends fn{apply(e){return P(()=>D(e,mm(hd(e))))}}dE.className="mish";Y(dE);class hE extends fn{apply(e,n=1){return P(()=>D(Cl(D(e,n)),e))}}hE.className="swish";Y(hE);function Fo(t){return t.getClassName()}function Ag(t,e={}){return wd(t,xs.getMap().classNameMap,e,"activation")}function zo(t){if(t==null){const e={};return e.className="linear",e.config={},Ag(e)}if(typeof t=="string"){const e={};return e.className=t,e.config={},Ag(e)}else return t instanceof fn?t:Ag(t)}/** + */let fn=class extends Il{getConfig(){return{}}};class JT extends fn{apply(e,n=1){return K6(e,n)}}JT.className="elu";Y(JT);class eE extends fn{apply(e){return mN(e)}}eE.className="selu";Y(eE);class tE extends fn{apply(e){return Yi(e)}}tE.className="relu";Y(tE);class nE extends fn{apply(e){return P(()=>Xc(6,Yi(e)))}}nE.className="relu6";Y(nE);class sE extends fn{apply(e){return e}}sE.className="linear";Y(sE);class rE extends fn{apply(e){return Cl(e)}}rE.className="sigmoid";Y(rE);class oE extends fn{apply(e){return q6(e)}}oE.className="hardSigmoid";Y(oE);class iE extends fn{apply(e){return dh(e)}}iE.className="softplus";Y(iE);class aE extends fn{apply(e){return X6(e)}}aE.className="softsign";Y(aE);class lE extends fn{apply(e){return mm(e)}}lE.className="tanh";Y(lE);let rv=class extends fn{apply(e,n=-1){return iw(e,n)}};rv.className="softmax";Y(rv);class cE extends fn{apply(e,n=-1){return iN(e,n)}}cE.className="logSoftmax";Y(cE);class uE extends fn{apply(e){return P(()=>P(()=>{const n=Math.sqrt(2),s=D(.5,J(1,tN(ge(e,n))));return D(e,s)}))}}uE.className="gelu";Y(uE);class hE extends fn{apply(e){return P(()=>D(.5,D(e,J(1,mm(D(hn(ge(2,Math.PI)),J(e,D(.044715,Oi(e,3)))))))))}}hE.className="gelu_new";Y(hE);class dE extends fn{apply(e){return P(()=>D(e,mm(dh(e))))}}dE.className="mish";Y(dE);class fE extends fn{apply(e,n=1){return P(()=>D(Cl(D(e,n)),e))}}fE.className="swish";Y(fE);function Fo(t){return t.getClassName()}function Ag(t,e={}){return wh(t,xs.getMap().classNameMap,e,"activation")}function zo(t){if(t==null){const e={};return e.className="linear",e.config={},Ag(e)}if(typeof t=="string"){const e={};return e.className=t,e.config={},Ag(e)}else return t instanceof fn?t:Ag(t)}/** * @license * Copyright 2018 Google LLC * @@ -7841,7 +7841,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */function uH(t){if(t!=null&&typeof t!="object")throw new Error(`Argument to L1L2 regularizer's constructor is expected to be an object, but received: ${t}`)}class fE extends Il{}class pE extends fE{constructor(e){super(),uH(e),this.l1=e==null||e.l1==null?.01:e.l1,this.l2=e==null||e.l2==null?.01:e.l2,this.hasL1=this.l1!==0,this.hasL2=this.l2!==0}apply(e){return P(()=>{let n=Kt([1]);return this.hasL1&&(n=J(n,me(D(this.l1,xn(e))))),this.hasL2&&(n=J(n,me(D(this.l2,bd(e))))),F(n,[])})}getConfig(){return{l1:this.l1,l2:this.l2}}static fromConfig(e,n){return new e({l1:n.l1,l2:n.l2})}}pE.className="L1L2";Y(pE);const lk={l1l2:"L1L2"};function Je(t){return Gw(t)}function ck(t,e={}){return wd(t,xs.getMap().classNameMap,e,"regularizer")}function pt(t){if(t==null)return null;if(typeof t=="string"){const n={className:t in lk?lk[t]:t,config:{}};return ck(n)}else return t instanceof fE?t:ck(t)}/** + */function hH(t){if(t!=null&&typeof t!="object")throw new Error(`Argument to L1L2 regularizer's constructor is expected to be an object, but received: ${t}`)}class pE extends Il{}class mE extends pE{constructor(e){super(),hH(e),this.l1=e==null||e.l1==null?.01:e.l1,this.l2=e==null||e.l2==null?.01:e.l2,this.hasL1=this.l1!==0,this.hasL2=this.l2!==0}apply(e){return P(()=>{let n=Kt([1]);return this.hasL1&&(n=J(n,me(D(this.l1,xn(e))))),this.hasL2&&(n=J(n,me(D(this.l2,bh(e))))),F(n,[])})}getConfig(){return{l1:this.l1,l2:this.l2}}static fromConfig(e,n){return new e({l1:n.l1,l2:n.l2})}}mE.className="L1L2";Y(mE);const lk={l1l2:"L1L2"};function Je(t){return Gw(t)}function ck(t,e={}){return wh(t,xs.getMap().classNameMap,e,"regularizer")}function pt(t){if(t==null)return null;if(typeof t=="string"){const n={className:t in lk?lk[t]:t,config:{}};return ck(n)}else return t instanceof pE?t:ck(t)}/** * @license * Copyright 2018 Google LLC * @@ -7849,7 +7849,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */class mE extends Ae{constructor(e){super(e??{}),this.supportsMasking=!0,e!=null&&(this.maxValue=e.maxValue)}call(e,n){e=Ce(e);let s=Yi(e);return this.maxValue!=null&&(s=as(s,0,this.maxValue)),s}computeOutputShape(e){return e}getConfig(){const e={maxValue:this.maxValue},n=super.getConfig();return Object.assign(e,n),e}}mE.className="ReLU";Y(mE);class gE extends Ae{constructor(e){super(e??{}),this.DEFAULT_ALPHA=.3,e==null&&(e={}),this.alpha=e.alpha==null?this.DEFAULT_ALPHA:e.alpha}call(e,n){const s=Ce(e);return Gy(s,this.alpha)}computeOutputShape(e){return e}getConfig(){const e={alpha:this.alpha},n=super.getConfig();return Object.assign(e,n),e}}gE.className="LeakyReLU";Y(gE);class xE extends Ae{constructor(e){if(super(e??{}),this.DEFAULT_ALPHA_INITIALIZER="zeros",e==null&&(e={}),this.supportsMasking=!0,this.alphaInitializer=ft(e.alphaInitializer||this.DEFAULT_ALPHA_INITIALIZER),this.alphaRegularizer=pt(e.alphaRegularizer),this.alphaConstraint=Bt(e.alphaConstraint),e.sharedAxes==null)this.sharedAxes=null;else if(Array.isArray(e.sharedAxes))this.sharedAxes=e.sharedAxes;else if(typeof e.sharedAxes=="number")this.sharedAxes=[e.sharedAxes];else throw new E(`Expected sharedAxes to be a number or an array of numbers, but got ${e.sharedAxes}`)}build(e){e=Pe(e);const n=e.slice(1);if(this.sharedAxes!=null)for(const r of this.sharedAxes)n[r-1]=1;this.alpha=this.addWeight("alpha",n,"float32",this.alphaInitializer,this.alphaRegularizer,!0,this.alphaConstraint);const s={};if(this.sharedAxes!=null)for(let r=1;r{let s=Ce(e);const r=n.mask;if(r!=null){const o=D(ve(Ko(s.shape),le(r,s.dtype)),We(-1e9));s=J(s,o)}return this.axis instanceof Array?this.axis.length>1?kr(ve(s,iN(s,this.axis,!0))):this.softmax(s,this.axis[0]):this.softmax(s,this.axis)})}computeOutputShape(e){return e}getConfig(){const e={axis:this.axis},n=super.getConfig();return Object.assign(e,n),e}}vE.className="Softmax";Y(vE);/** + */class gE extends Ae{constructor(e){super(e??{}),this.supportsMasking=!0,e!=null&&(this.maxValue=e.maxValue)}call(e,n){e=Ce(e);let s=Yi(e);return this.maxValue!=null&&(s=as(s,0,this.maxValue)),s}computeOutputShape(e){return e}getConfig(){const e={maxValue:this.maxValue},n=super.getConfig();return Object.assign(e,n),e}}gE.className="ReLU";Y(gE);class xE extends Ae{constructor(e){super(e??{}),this.DEFAULT_ALPHA=.3,e==null&&(e={}),this.alpha=e.alpha==null?this.DEFAULT_ALPHA:e.alpha}call(e,n){const s=Ce(e);return Gy(s,this.alpha)}computeOutputShape(e){return e}getConfig(){const e={alpha:this.alpha},n=super.getConfig();return Object.assign(e,n),e}}xE.className="LeakyReLU";Y(xE);class yE extends Ae{constructor(e){if(super(e??{}),this.DEFAULT_ALPHA_INITIALIZER="zeros",e==null&&(e={}),this.supportsMasking=!0,this.alphaInitializer=ft(e.alphaInitializer||this.DEFAULT_ALPHA_INITIALIZER),this.alphaRegularizer=pt(e.alphaRegularizer),this.alphaConstraint=Bt(e.alphaConstraint),e.sharedAxes==null)this.sharedAxes=null;else if(Array.isArray(e.sharedAxes))this.sharedAxes=e.sharedAxes;else if(typeof e.sharedAxes=="number")this.sharedAxes=[e.sharedAxes];else throw new E(`Expected sharedAxes to be a number or an array of numbers, but got ${e.sharedAxes}`)}build(e){e=Pe(e);const n=e.slice(1);if(this.sharedAxes!=null)for(const r of this.sharedAxes)n[r-1]=1;this.alpha=this.addWeight("alpha",n,"float32",this.alphaInitializer,this.alphaRegularizer,!0,this.alphaConstraint);const s={};if(this.sharedAxes!=null)for(let r=1;r{let s=Ce(e);const r=n.mask;if(r!=null){const o=D(ve(Ko(s.shape),le(r,s.dtype)),We(-1e9));s=J(s,o)}return this.axis instanceof Array?this.axis.length>1?Sr(ve(s,aN(s,this.axis,!0))):this.softmax(s,this.axis[0]):this.softmax(s,this.axis)})}computeOutputShape(e){return e}getConfig(){const e={axis:this.axis},n=super.getConfig();return Object.assign(e,n),e}}bE.className="Softmax";Y(bE);/** * @license * Copyright 2018 Google LLC * @@ -7857,7 +7857,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */function Ba(t,e,n){if(typeof t=="number")return Li(t,e);if(t.length!==e)throw new E(`The ${n} argument must be an integer or tuple of ${e} integers. Received: ${t.length} elements.`);for(let s=0;s(Nt(e),e==="channelsFirst"?Fe(t,[0,2,3,1]):t))}function bE(t,e){return P(()=>(Nt(e),e==="channelsFirst"?Fe(t,[0,2,3,4,1]):t))}function dH(t,e,n,s=1,r="valid",o,i=1){return P(()=>{if(o==null&&(o=Js()),Nt(o),t.shape.length!==3)throw new E(`The input of a conv1dWithBias operation should be 3, but is ${t.shape.length} instead.`);if(e.shape.length!==3)throw new E(`The kernel for a conv1dWithBias operation should be 3, but is ${e.shape.length} instead`);if(n!=null&&n.shape.length!==1)throw new E(`The bias for a conv1dWithBias operation should be 1, but is ${n.shape.length} instead`);if(o==="channelsFirst"&&(t=Fe(t,[0,2,1])),r==="causal")throw new Ie("The support for CAUSAL padding mode in conv1dWithBias is not implemented yet.");let a=q$(t,e,s,r==="same"?"same":"valid","NWC",i);return n!=null&&(a=nr(a,n)),a})}function uk(t,e,n,s=[1,1],r="valid",o,i,a=null){return P(()=>{if(o==null&&(o=Js()),Nt(o),t.rank!==3&&t.rank!==4)throw new E(`conv2dWithBiasActivation expects input to be of rank 3 or 4, but received ${t.rank}.`);if(e.rank!==3&&e.rank!==4)throw new E(`conv2dWithBiasActivation expects kernel to be of rank 3 or 4, but received ${t.rank}.`);let l=ov(t,o);if(r==="causal")throw new Ie("The support for CAUSAL padding mode in conv1dWithBias is not implemented yet.");return l=dW({x:l,filter:e,strides:s,pad:r==="same"?"same":"valid",dilations:i,dataFormat:"NHWC",bias:n,activation:a}),o==="channelsFirst"&&(l=Fe(l,[0,3,1,2])),l})}function hH(t,e,n,s=[1,1,1],r="valid",o,i){return P(()=>{if(o==null&&(o=Js()),Nt(o),t.rank!==4&&t.rank!==5)throw new E(`conv3dWithBias expects input to be of rank 4 or 5, but received ${t.rank}.`);if(e.rank!==4&&e.rank!==5)throw new E(`conv3dWithBias expects kernel to be of rank 4 or 5, but received ${t.rank}.`);let a=bE(t,o);if(r==="causal")throw new Ie("The support for CAUSAL padding mode in conv3dWithBias is not implemented yet.");return a=c4(a,e,s,r==="same"?"same":"valid","NDHWC",i),n!=null&&(a=nr(a,n)),o==="channelsFirst"&&(a=Fe(a,[0,4,1,2,3])),a})}class Rm extends Ae{constructor(e,n){if(super(n),this.bias=null,this.DEFAULT_KERNEL_INITIALIZER="glorotNormal",this.DEFAULT_BIAS_INITIALIZER="zeros",Rm.verifyArgs(n),this.rank=e,qt(this.rank,"rank"),this.rank!==1&&this.rank!==2&&this.rank!==3)throw new Ie(`Convolution layer for rank other than 1, 2, or 3 (${this.rank}) is not implemented yet.`);if(this.kernelSize=Ba(n.kernelSize,e,"kernelSize"),this.strides=Ba(n.strides==null?1:n.strides,e,"strides"),this.padding=n.padding==null?"valid":n.padding,ds(this.padding),this.dataFormat=n.dataFormat==null?"channelsLast":n.dataFormat,Nt(this.dataFormat),this.activation=zo(n.activation),this.useBias=n.useBias==null?!0:n.useBias,this.biasInitializer=ft(n.biasInitializer||this.DEFAULT_BIAS_INITIALIZER),this.biasConstraint=Bt(n.biasConstraint),this.biasRegularizer=pt(n.biasRegularizer),this.activityRegularizer=pt(n.activityRegularizer),this.dilationRate=Ba(n.dilationRate==null?1:n.dilationRate,e,"dilationRate"),this.rank===1&&Array.isArray(this.dilationRate)&&this.dilationRate.length!==1)throw new E(`dilationRate must be a number or an array of a single number for 1D convolution, but received ${JSON.stringify(this.dilationRate)}`);if(this.rank===2){if(typeof this.dilationRate=="number")this.dilationRate=[this.dilationRate,this.dilationRate];else if(this.dilationRate.length!==2)throw new E(`dilationRate must be a number or array of two numbers for 2D convolution, but received ${JSON.stringify(this.dilationRate)}`)}else if(this.rank===3){if(typeof this.dilationRate=="number")this.dilationRate=[this.dilationRate,this.dilationRate,this.dilationRate];else if(this.dilationRate.length!==3)throw new E(`dilationRate must be a number or array of three numbers for 3D convolution, but received ${JSON.stringify(this.dilationRate)}`)}}static verifyArgs(e){if(ur("kernelSize"in e,"required key 'kernelSize' not in config"),typeof e.kernelSize!="number"&&!Hw(e.kernelSize,"number",1,3))throw new E(`BaseConv expects config.kernelSize to be number or number[] with length 1, 2, or 3, but received ${JSON.stringify(e.kernelSize)}.`)}getConfig(){const e={kernelSize:this.kernelSize,strides:this.strides,padding:this.padding,dataFormat:this.dataFormat,dilationRate:this.dilationRate,activation:Fo(this.activation),useBias:this.useBias,biasInitializer:xt(this.biasInitializer),biasRegularizer:Je(this.biasRegularizer),activityRegularizer:Je(this.activityRegularizer),biasConstraint:Lt(this.biasConstraint)},n=super.getConfig();return Object.assign(e,n),e}}class $l extends Rm{constructor(e,n){super(e,n),this.kernel=null,$l.verifyArgs(n),this.filters=n.filters,qt(this.filters,"filters"),this.kernelInitializer=ft(n.kernelInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.kernelConstraint=Bt(n.kernelConstraint),this.kernelRegularizer=pt(n.kernelRegularizer)}build(e){e=Pe(e);const n=this.dataFormat==="channelsFirst"?1:e.length-1;if(e[n]==null)throw new E(`The channel dimension of the input should be defined. Found ${e[n]}`);const s=e[n],r=this.kernelSize.concat([s,this.filters]);this.kernel=this.addWeight("kernel",r,null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.useBias&&(this.bias=this.addWeight("bias",[this.filters],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint)),this.inputSpec=[{ndim:this.rank+2,axes:{[n]:s}}],this.built=!0}call(e,n){return P(()=>{e=Ce(e);let s;const r=this.bias==null?null:this.bias.read(),o=xT(this.activation.getClassName());if(o!=null&&this.rank===2)s=uk(e,this.kernel.read(),r,this.strides,this.padding,this.dataFormat,this.dilationRate,o);else{if(this.rank===1)s=dH(e,this.kernel.read(),r,this.strides[0],this.padding,this.dataFormat,this.dilationRate[0]);else if(this.rank===2)s=uk(e,this.kernel.read(),r,this.strides,this.padding,this.dataFormat,this.dilationRate);else if(this.rank===3)s=hH(e,this.kernel.read(),r,this.strides,this.padding,this.dataFormat,this.dilationRate);else throw new Ie("convolutions greater than 3D are not implemented yet.");this.activation!=null&&(s=this.activation.apply(s))}return s})}computeOutputShape(e){e=Pe(e);const n=[],s=this.dataFormat==="channelsLast"?e.slice(1,e.length-1):e.slice(2);for(let o=0;o 0 but got ${JSON.stringify(e.filters)}`)}}class Id extends $l{constructor(e){super(2,e),Id.verifyArgs(e)}getConfig(){const e=super.getConfig();return delete e.rank,e}static verifyArgs(e){if(typeof e.kernelSize!="number"&&!Hw(e.kernelSize,"number",1,2))throw new E(`Conv2D expects config.kernelSize to be number or number[] with length 1 or 2, but received ${JSON.stringify(e.kernelSize)}.`)}}Id.className="Conv2D";Y(Id);class $d extends $l{constructor(e){super(3,e),$d.verifyArgs(e)}getConfig(){const e=super.getConfig();return delete e.rank,e}static verifyArgs(e){if(typeof e.kernelSize!="number"&&!(Array.isArray(e.kernelSize)&&(e.kernelSize.length===1||e.kernelSize.length===3)))throw new E(`Conv3D expects config.kernelSize to be number or [number, number, number], but received ${JSON.stringify(e.kernelSize)}.`)}}$d.className="Conv3D";Y($d);class CE extends Id{constructor(e){if(super(e),this.inputSpec=[new Pt({ndim:4})],this.padding!=="same"&&this.padding!=="valid")throw new E(`Conv2DTranspose currently supports only padding modes 'same' and 'valid', but received padding mode ${this.padding}`)}build(e){if(e=Pe(e),e.length!==4)throw new E("Input should have rank 4; Received input shape: "+JSON.stringify(e));const n=this.dataFormat==="channelsFirst"?1:e.length-1;if(e[n]==null)throw new E("The channel dimension of the inputs should be defined. Found `None`.");const s=e[n],r=this.kernelSize.concat([this.filters,s]);this.kernel=this.addWeight("kernel",r,"float32",this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.useBias&&(this.bias=this.addWeight("bias",[this.filters],"float32",this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint)),this.inputSpec=[new Pt({ndim:4,axes:{[n]:s}})],this.built=!0}call(e,n){return P(()=>{let s=Ce(e);if(s.shape.length!==4)throw new E(`Conv2DTranspose.call() expects input tensor to be rank-4, but received a tensor of rank-${s.shape.length}`);const r=s.shape,o=r[0];let i,a;this.dataFormat==="channelsFirst"?(i=2,a=3):(i=1,a=2);const l=r[i],c=r[a],u=this.kernelSize[0],d=this.kernelSize[1],h=this.strides[0],f=this.strides[1],p=dr(l,h,u,this.padding),g=dr(c,f,d,this.padding),x=[o,p,g,this.filters];this.dataFormat!=="channelsLast"&&(s=Fe(s,[0,2,3,1]));let m=Y$(s,this.kernel.read(),x,this.strides,this.padding);return this.dataFormat!=="channelsLast"&&(m=Fe(m,[0,3,1,2])),this.bias!=null&&(m=nr(m,this.bias.read(),this.dataFormat)),this.activation!=null&&(m=this.activation.apply(m)),m})}computeOutputShape(e){e=Pe(e);const n=e.slice();let s,r,o;this.dataFormat==="channelsFirst"?(s=1,r=2,o=3):(s=3,r=1,o=2);const i=this.kernelSize[0],a=this.kernelSize[1],l=this.strides[0],c=this.strides[1];return n[s]=this.filters,n[r]=dr(n[r],l,i,this.padding),n[o]=dr(n[o],c,a,this.padding),n}getConfig(){const e=super.getConfig();return delete e.dilationRate,e}}CE.className="Conv2DTranspose";Y(CE);class kE extends $d{constructor(e){if(super(e),this.inputSpec=[new Pt({ndim:5})],this.padding!=="same"&&this.padding!=="valid")throw new E(`Conv3DTranspose currently supports only padding modes 'same' and 'valid', but received padding mode ${this.padding}`)}build(e){if(e=Pe(e),e.length!==5)throw new E("Input should have rank 5; Received input shape: "+JSON.stringify(e));const n=this.dataFormat==="channelsFirst"?1:e.length-1;if(e[n]==null)throw new E("The channel dimension of the inputs should be defined. Found `None`.");const s=e[n],r=this.kernelSize.concat([this.filters,s]);this.kernel=this.addWeight("kernel",r,"float32",this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.useBias&&(this.bias=this.addWeight("bias",[this.filters],"float32",this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint)),this.inputSpec=[new Pt({ndim:5,axes:{[n]:s}})],this.built=!0}call(e,n){return P(()=>{let s=Ce(e);if(s.shape.length!==5)throw new E(`Conv3DTranspose.call() expects input tensor to be rank-4, but received a tensor of rank-${s.shape.length}`);const r=s.shape,o=r[0];let i,a,l;this.dataFormat==="channelsFirst"?(l=2,i=3,a=4):(l=1,i=2,a=3);const c=r[l],u=r[i],d=r[a],h=this.kernelSize[0],f=this.kernelSize[1],p=this.kernelSize[2],g=this.strides[0],x=this.strides[1],m=this.strides[2],y=dr(c,g,h,this.padding),w=dr(u,x,f,this.padding),v=dr(d,m,p,this.padding),b=[o,y,w,v,this.filters];this.dataFormat!=="channelsLast"&&(s=Fe(s,[0,2,3,4,1]));let C=h4(s,this.kernel.read(),b,this.strides,this.padding);return this.dataFormat!=="channelsLast"&&(C=Fe(C,[0,4,1,2,3])),this.bias!==null&&(C=nr(C,this.bias.read(),this.dataFormat)),this.activation!==null&&(C=this.activation.apply(C)),C})}computeOutputShape(e){e=Pe(e);const n=e.slice();let s,r,o,i;this.dataFormat==="channelsFirst"?(s=1,r=2,o=3,i=4):(s=4,r=1,o=2,i=3);const a=this.kernelSize[0],l=this.kernelSize[1],c=this.kernelSize[2],u=this.strides[0],d=this.strides[1],h=this.strides[2];return n[s]=this.filters,n[r]=dr(n[r],u,a,this.padding),n[o]=dr(n[o],d,l,this.padding),n[i]=dr(n[i],h,c,this.padding),n}getConfig(){const e=super.getConfig();return delete e.dilationRate,e}}kE.className="Conv3DTranspose";Y(kE);class SE extends $l{constructor(e,n){if(super(e,n),this.DEFAULT_DEPTHWISE_INITIALIZER="glorotUniform",this.DEFAULT_POINTWISE_INITIALIZER="glorotUniform",this.depthwiseKernel=null,this.pointwiseKernel=null,n.filters==null)throw new E("The `filters` configuration field is required by SeparableConv, but is unspecified.");if(n.kernelInitializer!=null||n.kernelRegularizer!=null||n.kernelConstraint!=null)throw new E("Fields kernelInitializer, kernelRegularizer and kernelConstraint are invalid for SeparableConv2D. Use depthwiseInitializer, depthwiseRegularizer, depthwiseConstraint, pointwiseInitializer, pointwiseRegularizer and pointwiseConstraint instead.");if(n.padding!=null&&n.padding!=="same"&&n.padding!=="valid")throw new E(`SeparableConv${this.rank}D supports only padding modes: 'same' and 'valid', but received ${JSON.stringify(n.padding)}`);this.depthMultiplier=n.depthMultiplier==null?1:n.depthMultiplier,this.depthwiseInitializer=ft(n.depthwiseInitializer||this.DEFAULT_DEPTHWISE_INITIALIZER),this.depthwiseRegularizer=pt(n.depthwiseRegularizer),this.depthwiseConstraint=Bt(n.depthwiseConstraint),this.pointwiseInitializer=ft(n.depthwiseInitializer||this.DEFAULT_POINTWISE_INITIALIZER),this.pointwiseRegularizer=pt(n.pointwiseRegularizer),this.pointwiseConstraint=Bt(n.pointwiseConstraint)}build(e){if(e=Pe(e),e.length{e=Ce(e);let s;if(this.rank===1)throw new Ie("1D separable convolution is not implemented yet.");return this.rank===2&&(this.dataFormat==="channelsFirst"&&(e=Fe(e,[0,2,3,1])),s=mN(e,this.depthwiseKernel.read(),this.pointwiseKernel.read(),this.strides,this.padding,this.dilationRate,"NHWC")),this.useBias&&(s=nr(s,this.bias.read(),this.dataFormat)),this.activation!=null&&(s=this.activation.apply(s)),this.dataFormat==="channelsFirst"&&(s=Fe(s,[0,3,1,2])),s})}getConfig(){const e=super.getConfig();return delete e.rank,delete e.kernelInitializer,delete e.kernelRegularizer,delete e.kernelConstraint,e.depthwiseInitializer=xt(this.depthwiseInitializer),e.pointwiseInitializer=xt(this.pointwiseInitializer),e.depthwiseRegularizer=Je(this.depthwiseRegularizer),e.pointwiseRegularizer=Je(this.pointwiseRegularizer),e.depthwiseConstraint=Lt(this.depthwiseConstraint),e.pointwiseConstraint=Lt(this.pointwiseConstraint),e}}SE.className="SeparableConv";class IE extends SE{constructor(e){super(2,e)}}IE.className="SeparableConv2D";Y(IE);class Am extends $l{constructor(e){super(1,e),Am.verifyArgs(e),this.inputSpec=[{ndim:3}]}getConfig(){const e=super.getConfig();return delete e.rank,delete e.dataFormat,e}static verifyArgs(e){if(typeof e.kernelSize!="number"&&!Hw(e.kernelSize,"number",1,1))throw new E(`Conv1D expects config.kernelSize to be number or number[] with length 1, but received ${JSON.stringify(e.kernelSize)}.`)}}Am.className="Conv1D";Y(Am);class $E extends Ae{constructor(e){super(e),typeof e.cropping=="number"?this.cropping=[[e.cropping,e.cropping],[e.cropping,e.cropping]]:typeof e.cropping[0]=="number"?this.cropping=[[e.cropping[0],e.cropping[0]],[e.cropping[1],e.cropping[1]]]:this.cropping=e.cropping,this.dataFormat=e.dataFormat===void 0?"channelsLast":e.dataFormat,this.inputSpec=[{ndim:4}]}computeOutputShape(e){return this.dataFormat==="channelsFirst"?[e[0],e[1],e[2]-this.cropping[0][0]-this.cropping[0][1],e[3]-this.cropping[1][0]-this.cropping[1][1]]:[e[0],e[1]-this.cropping[0][0]-this.cropping[0][1],e[2]-this.cropping[1][0]-this.cropping[1][1],e[3]]}call(e,n){return P(()=>{if(e=Ce(e),this.dataFormat==="channelsLast"){const s=nh(e,this.cropping[0][0],e.shape[1]-this.cropping[0][0]-this.cropping[0][1],2);return nh(s,this.cropping[1][0],e.shape[2]-this.cropping[1][1]-this.cropping[1][0],3)}else{const s=nh(e,this.cropping[0][0],e.shape[2]-this.cropping[0][0]-this.cropping[0][1],3);return nh(s,this.cropping[1][0],e.shape[3]-this.cropping[1][1]-this.cropping[1][0],4)}})}getConfig(){const e={cropping:this.cropping,dataFormat:this.dataFormat},n=super.getConfig();return Object.assign(e,n),e}}$E.className="Cropping2D";Y($E);class NE extends Ae{constructor(e){super(e),this.DEFAULT_SIZE=[2,2],this.inputSpec=[{ndim:4}],this.size=e.size==null?this.DEFAULT_SIZE:e.size,this.dataFormat=e.dataFormat==null?"channelsLast":e.dataFormat,Nt(this.dataFormat),this.interpolation=e.interpolation==null?"nearest":e.interpolation,L6(this.interpolation)}computeOutputShape(e){if(this.dataFormat==="channelsFirst"){const n=e[2]==null?null:this.size[0]*e[2],s=e[3]==null?null:this.size[1]*e[3];return[e[0],e[1],n,s]}else{const n=e[1]==null?null:this.size[0]*e[1],s=e[2]==null?null:this.size[1]*e[2];return[e[0],n,s,e[3]]}}call(e,n){return P(()=>{let s=Ce(e);const r=s.shape;if(this.dataFormat==="channelsFirst"){s=Fe(s,[0,2,3,1]);const o=this.size[0]*r[2],i=this.size[1]*r[3],a=this.interpolation==="nearest"?Or.resizeNearestNeighbor(s,[o,i]):Or.resizeBilinear(s,[o,i]);return Fe(a,[0,3,1,2])}else{const o=this.size[0]*r[1],i=this.size[1]*r[2];return this.interpolation==="nearest"?Or.resizeNearestNeighbor(s,[o,i]):Or.resizeBilinear(s,[o,i])}})}getConfig(){const e={size:this.size,dataFormat:this.dataFormat,interpolation:this.interpolation},n=super.getConfig();return Object.assign(e,n),e}}NE.className="UpSampling2D";Y(NE);/** + */function ov(t,e){return P(()=>(Nt(e),e==="channelsFirst"?Fe(t,[0,2,3,1]):t))}function CE(t,e){return P(()=>(Nt(e),e==="channelsFirst"?Fe(t,[0,2,3,4,1]):t))}function dH(t,e,n,s=1,r="valid",o,i=1){return P(()=>{if(o==null&&(o=er()),Nt(o),t.shape.length!==3)throw new E(`The input of a conv1dWithBias operation should be 3, but is ${t.shape.length} instead.`);if(e.shape.length!==3)throw new E(`The kernel for a conv1dWithBias operation should be 3, but is ${e.shape.length} instead`);if(n!=null&&n.shape.length!==1)throw new E(`The bias for a conv1dWithBias operation should be 1, but is ${n.shape.length} instead`);if(o==="channelsFirst"&&(t=Fe(t,[0,2,1])),r==="causal")throw new Ie("The support for CAUSAL padding mode in conv1dWithBias is not implemented yet.");let a=Y$(t,e,s,r==="same"?"same":"valid","NWC",i);return n!=null&&(a=sr(a,n)),a})}function uk(t,e,n,s=[1,1],r="valid",o,i,a=null){return P(()=>{if(o==null&&(o=er()),Nt(o),t.rank!==3&&t.rank!==4)throw new E(`conv2dWithBiasActivation expects input to be of rank 3 or 4, but received ${t.rank}.`);if(e.rank!==3&&e.rank!==4)throw new E(`conv2dWithBiasActivation expects kernel to be of rank 3 or 4, but received ${t.rank}.`);let l=ov(t,o);if(r==="causal")throw new Ie("The support for CAUSAL padding mode in conv1dWithBias is not implemented yet.");return l=dW({x:l,filter:e,strides:s,pad:r==="same"?"same":"valid",dilations:i,dataFormat:"NHWC",bias:n,activation:a}),o==="channelsFirst"&&(l=Fe(l,[0,3,1,2])),l})}function fH(t,e,n,s=[1,1,1],r="valid",o,i){return P(()=>{if(o==null&&(o=er()),Nt(o),t.rank!==4&&t.rank!==5)throw new E(`conv3dWithBias expects input to be of rank 4 or 5, but received ${t.rank}.`);if(e.rank!==4&&e.rank!==5)throw new E(`conv3dWithBias expects kernel to be of rank 4 or 5, but received ${t.rank}.`);let a=CE(t,o);if(r==="causal")throw new Ie("The support for CAUSAL padding mode in conv3dWithBias is not implemented yet.");return a=u4(a,e,s,r==="same"?"same":"valid","NDHWC",i),n!=null&&(a=sr(a,n)),o==="channelsFirst"&&(a=Fe(a,[0,4,1,2,3])),a})}class Rm extends Ae{constructor(e,n){if(super(n),this.bias=null,this.DEFAULT_KERNEL_INITIALIZER="glorotNormal",this.DEFAULT_BIAS_INITIALIZER="zeros",Rm.verifyArgs(n),this.rank=e,qt(this.rank,"rank"),this.rank!==1&&this.rank!==2&&this.rank!==3)throw new Ie(`Convolution layer for rank other than 1, 2, or 3 (${this.rank}) is not implemented yet.`);if(this.kernelSize=Ba(n.kernelSize,e,"kernelSize"),this.strides=Ba(n.strides==null?1:n.strides,e,"strides"),this.padding=n.padding==null?"valid":n.padding,hs(this.padding),this.dataFormat=n.dataFormat==null?"channelsLast":n.dataFormat,Nt(this.dataFormat),this.activation=zo(n.activation),this.useBias=n.useBias==null?!0:n.useBias,this.biasInitializer=ft(n.biasInitializer||this.DEFAULT_BIAS_INITIALIZER),this.biasConstraint=Bt(n.biasConstraint),this.biasRegularizer=pt(n.biasRegularizer),this.activityRegularizer=pt(n.activityRegularizer),this.dilationRate=Ba(n.dilationRate==null?1:n.dilationRate,e,"dilationRate"),this.rank===1&&Array.isArray(this.dilationRate)&&this.dilationRate.length!==1)throw new E(`dilationRate must be a number or an array of a single number for 1D convolution, but received ${JSON.stringify(this.dilationRate)}`);if(this.rank===2){if(typeof this.dilationRate=="number")this.dilationRate=[this.dilationRate,this.dilationRate];else if(this.dilationRate.length!==2)throw new E(`dilationRate must be a number or array of two numbers for 2D convolution, but received ${JSON.stringify(this.dilationRate)}`)}else if(this.rank===3){if(typeof this.dilationRate=="number")this.dilationRate=[this.dilationRate,this.dilationRate,this.dilationRate];else if(this.dilationRate.length!==3)throw new E(`dilationRate must be a number or array of three numbers for 3D convolution, but received ${JSON.stringify(this.dilationRate)}`)}}static verifyArgs(e){if(hr("kernelSize"in e,"required key 'kernelSize' not in config"),typeof e.kernelSize!="number"&&!Hw(e.kernelSize,"number",1,3))throw new E(`BaseConv expects config.kernelSize to be number or number[] with length 1, 2, or 3, but received ${JSON.stringify(e.kernelSize)}.`)}getConfig(){const e={kernelSize:this.kernelSize,strides:this.strides,padding:this.padding,dataFormat:this.dataFormat,dilationRate:this.dilationRate,activation:Fo(this.activation),useBias:this.useBias,biasInitializer:xt(this.biasInitializer),biasRegularizer:Je(this.biasRegularizer),activityRegularizer:Je(this.activityRegularizer),biasConstraint:Lt(this.biasConstraint)},n=super.getConfig();return Object.assign(e,n),e}}class $l extends Rm{constructor(e,n){super(e,n),this.kernel=null,$l.verifyArgs(n),this.filters=n.filters,qt(this.filters,"filters"),this.kernelInitializer=ft(n.kernelInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.kernelConstraint=Bt(n.kernelConstraint),this.kernelRegularizer=pt(n.kernelRegularizer)}build(e){e=Pe(e);const n=this.dataFormat==="channelsFirst"?1:e.length-1;if(e[n]==null)throw new E(`The channel dimension of the input should be defined. Found ${e[n]}`);const s=e[n],r=this.kernelSize.concat([s,this.filters]);this.kernel=this.addWeight("kernel",r,null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.useBias&&(this.bias=this.addWeight("bias",[this.filters],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint)),this.inputSpec=[{ndim:this.rank+2,axes:{[n]:s}}],this.built=!0}call(e,n){return P(()=>{e=Ce(e);let s;const r=this.bias==null?null:this.bias.read(),o=yT(this.activation.getClassName());if(o!=null&&this.rank===2)s=uk(e,this.kernel.read(),r,this.strides,this.padding,this.dataFormat,this.dilationRate,o);else{if(this.rank===1)s=dH(e,this.kernel.read(),r,this.strides[0],this.padding,this.dataFormat,this.dilationRate[0]);else if(this.rank===2)s=uk(e,this.kernel.read(),r,this.strides,this.padding,this.dataFormat,this.dilationRate);else if(this.rank===3)s=fH(e,this.kernel.read(),r,this.strides,this.padding,this.dataFormat,this.dilationRate);else throw new Ie("convolutions greater than 3D are not implemented yet.");this.activation!=null&&(s=this.activation.apply(s))}return s})}computeOutputShape(e){e=Pe(e);const n=[],s=this.dataFormat==="channelsLast"?e.slice(1,e.length-1):e.slice(2);for(let o=0;o 0 but got ${JSON.stringify(e.filters)}`)}}class Ih extends $l{constructor(e){super(2,e),Ih.verifyArgs(e)}getConfig(){const e=super.getConfig();return delete e.rank,e}static verifyArgs(e){if(typeof e.kernelSize!="number"&&!Hw(e.kernelSize,"number",1,2))throw new E(`Conv2D expects config.kernelSize to be number or number[] with length 1 or 2, but received ${JSON.stringify(e.kernelSize)}.`)}}Ih.className="Conv2D";Y(Ih);class $h extends $l{constructor(e){super(3,e),$h.verifyArgs(e)}getConfig(){const e=super.getConfig();return delete e.rank,e}static verifyArgs(e){if(typeof e.kernelSize!="number"&&!(Array.isArray(e.kernelSize)&&(e.kernelSize.length===1||e.kernelSize.length===3)))throw new E(`Conv3D expects config.kernelSize to be number or [number, number, number], but received ${JSON.stringify(e.kernelSize)}.`)}}$h.className="Conv3D";Y($h);class kE extends Ih{constructor(e){if(super(e),this.inputSpec=[new Pt({ndim:4})],this.padding!=="same"&&this.padding!=="valid")throw new E(`Conv2DTranspose currently supports only padding modes 'same' and 'valid', but received padding mode ${this.padding}`)}build(e){if(e=Pe(e),e.length!==4)throw new E("Input should have rank 4; Received input shape: "+JSON.stringify(e));const n=this.dataFormat==="channelsFirst"?1:e.length-1;if(e[n]==null)throw new E("The channel dimension of the inputs should be defined. Found `None`.");const s=e[n],r=this.kernelSize.concat([this.filters,s]);this.kernel=this.addWeight("kernel",r,"float32",this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.useBias&&(this.bias=this.addWeight("bias",[this.filters],"float32",this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint)),this.inputSpec=[new Pt({ndim:4,axes:{[n]:s}})],this.built=!0}call(e,n){return P(()=>{let s=Ce(e);if(s.shape.length!==4)throw new E(`Conv2DTranspose.call() expects input tensor to be rank-4, but received a tensor of rank-${s.shape.length}`);const r=s.shape,o=r[0];let i,a;this.dataFormat==="channelsFirst"?(i=2,a=3):(i=1,a=2);const l=r[i],c=r[a],u=this.kernelSize[0],h=this.kernelSize[1],d=this.strides[0],f=this.strides[1],p=dr(l,d,u,this.padding),g=dr(c,f,h,this.padding),x=[o,p,g,this.filters];this.dataFormat!=="channelsLast"&&(s=Fe(s,[0,2,3,1]));let m=Q$(s,this.kernel.read(),x,this.strides,this.padding);return this.dataFormat!=="channelsLast"&&(m=Fe(m,[0,3,1,2])),this.bias!=null&&(m=sr(m,this.bias.read(),this.dataFormat)),this.activation!=null&&(m=this.activation.apply(m)),m})}computeOutputShape(e){e=Pe(e);const n=e.slice();let s,r,o;this.dataFormat==="channelsFirst"?(s=1,r=2,o=3):(s=3,r=1,o=2);const i=this.kernelSize[0],a=this.kernelSize[1],l=this.strides[0],c=this.strides[1];return n[s]=this.filters,n[r]=dr(n[r],l,i,this.padding),n[o]=dr(n[o],c,a,this.padding),n}getConfig(){const e=super.getConfig();return delete e.dilationRate,e}}kE.className="Conv2DTranspose";Y(kE);class SE extends $h{constructor(e){if(super(e),this.inputSpec=[new Pt({ndim:5})],this.padding!=="same"&&this.padding!=="valid")throw new E(`Conv3DTranspose currently supports only padding modes 'same' and 'valid', but received padding mode ${this.padding}`)}build(e){if(e=Pe(e),e.length!==5)throw new E("Input should have rank 5; Received input shape: "+JSON.stringify(e));const n=this.dataFormat==="channelsFirst"?1:e.length-1;if(e[n]==null)throw new E("The channel dimension of the inputs should be defined. Found `None`.");const s=e[n],r=this.kernelSize.concat([this.filters,s]);this.kernel=this.addWeight("kernel",r,"float32",this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.useBias&&(this.bias=this.addWeight("bias",[this.filters],"float32",this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint)),this.inputSpec=[new Pt({ndim:5,axes:{[n]:s}})],this.built=!0}call(e,n){return P(()=>{let s=Ce(e);if(s.shape.length!==5)throw new E(`Conv3DTranspose.call() expects input tensor to be rank-4, but received a tensor of rank-${s.shape.length}`);const r=s.shape,o=r[0];let i,a,l;this.dataFormat==="channelsFirst"?(l=2,i=3,a=4):(l=1,i=2,a=3);const c=r[l],u=r[i],h=r[a],d=this.kernelSize[0],f=this.kernelSize[1],p=this.kernelSize[2],g=this.strides[0],x=this.strides[1],m=this.strides[2],y=dr(c,g,d,this.padding),w=dr(u,x,f,this.padding),v=dr(h,m,p,this.padding),b=[o,y,w,v,this.filters];this.dataFormat!=="channelsLast"&&(s=Fe(s,[0,2,3,4,1]));let C=f4(s,this.kernel.read(),b,this.strides,this.padding);return this.dataFormat!=="channelsLast"&&(C=Fe(C,[0,4,1,2,3])),this.bias!==null&&(C=sr(C,this.bias.read(),this.dataFormat)),this.activation!==null&&(C=this.activation.apply(C)),C})}computeOutputShape(e){e=Pe(e);const n=e.slice();let s,r,o,i;this.dataFormat==="channelsFirst"?(s=1,r=2,o=3,i=4):(s=4,r=1,o=2,i=3);const a=this.kernelSize[0],l=this.kernelSize[1],c=this.kernelSize[2],u=this.strides[0],h=this.strides[1],d=this.strides[2];return n[s]=this.filters,n[r]=dr(n[r],u,a,this.padding),n[o]=dr(n[o],h,l,this.padding),n[i]=dr(n[i],d,c,this.padding),n}getConfig(){const e=super.getConfig();return delete e.dilationRate,e}}SE.className="Conv3DTranspose";Y(SE);class IE extends $l{constructor(e,n){if(super(e,n),this.DEFAULT_DEPTHWISE_INITIALIZER="glorotUniform",this.DEFAULT_POINTWISE_INITIALIZER="glorotUniform",this.depthwiseKernel=null,this.pointwiseKernel=null,n.filters==null)throw new E("The `filters` configuration field is required by SeparableConv, but is unspecified.");if(n.kernelInitializer!=null||n.kernelRegularizer!=null||n.kernelConstraint!=null)throw new E("Fields kernelInitializer, kernelRegularizer and kernelConstraint are invalid for SeparableConv2D. Use depthwiseInitializer, depthwiseRegularizer, depthwiseConstraint, pointwiseInitializer, pointwiseRegularizer and pointwiseConstraint instead.");if(n.padding!=null&&n.padding!=="same"&&n.padding!=="valid")throw new E(`SeparableConv${this.rank}D supports only padding modes: 'same' and 'valid', but received ${JSON.stringify(n.padding)}`);this.depthMultiplier=n.depthMultiplier==null?1:n.depthMultiplier,this.depthwiseInitializer=ft(n.depthwiseInitializer||this.DEFAULT_DEPTHWISE_INITIALIZER),this.depthwiseRegularizer=pt(n.depthwiseRegularizer),this.depthwiseConstraint=Bt(n.depthwiseConstraint),this.pointwiseInitializer=ft(n.depthwiseInitializer||this.DEFAULT_POINTWISE_INITIALIZER),this.pointwiseRegularizer=pt(n.pointwiseRegularizer),this.pointwiseConstraint=Bt(n.pointwiseConstraint)}build(e){if(e=Pe(e),e.length{e=Ce(e);let s;if(this.rank===1)throw new Ie("1D separable convolution is not implemented yet.");return this.rank===2&&(this.dataFormat==="channelsFirst"&&(e=Fe(e,[0,2,3,1])),s=gN(e,this.depthwiseKernel.read(),this.pointwiseKernel.read(),this.strides,this.padding,this.dilationRate,"NHWC")),this.useBias&&(s=sr(s,this.bias.read(),this.dataFormat)),this.activation!=null&&(s=this.activation.apply(s)),this.dataFormat==="channelsFirst"&&(s=Fe(s,[0,3,1,2])),s})}getConfig(){const e=super.getConfig();return delete e.rank,delete e.kernelInitializer,delete e.kernelRegularizer,delete e.kernelConstraint,e.depthwiseInitializer=xt(this.depthwiseInitializer),e.pointwiseInitializer=xt(this.pointwiseInitializer),e.depthwiseRegularizer=Je(this.depthwiseRegularizer),e.pointwiseRegularizer=Je(this.pointwiseRegularizer),e.depthwiseConstraint=Lt(this.depthwiseConstraint),e.pointwiseConstraint=Lt(this.pointwiseConstraint),e}}IE.className="SeparableConv";class $E extends IE{constructor(e){super(2,e)}}$E.className="SeparableConv2D";Y($E);class Am extends $l{constructor(e){super(1,e),Am.verifyArgs(e),this.inputSpec=[{ndim:3}]}getConfig(){const e=super.getConfig();return delete e.rank,delete e.dataFormat,e}static verifyArgs(e){if(typeof e.kernelSize!="number"&&!Hw(e.kernelSize,"number",1,1))throw new E(`Conv1D expects config.kernelSize to be number or number[] with length 1, but received ${JSON.stringify(e.kernelSize)}.`)}}Am.className="Conv1D";Y(Am);class NE extends Ae{constructor(e){super(e),typeof e.cropping=="number"?this.cropping=[[e.cropping,e.cropping],[e.cropping,e.cropping]]:typeof e.cropping[0]=="number"?this.cropping=[[e.cropping[0],e.cropping[0]],[e.cropping[1],e.cropping[1]]]:this.cropping=e.cropping,this.dataFormat=e.dataFormat===void 0?"channelsLast":e.dataFormat,this.inputSpec=[{ndim:4}]}computeOutputShape(e){return this.dataFormat==="channelsFirst"?[e[0],e[1],e[2]-this.cropping[0][0]-this.cropping[0][1],e[3]-this.cropping[1][0]-this.cropping[1][1]]:[e[0],e[1]-this.cropping[0][0]-this.cropping[0][1],e[2]-this.cropping[1][0]-this.cropping[1][1],e[3]]}call(e,n){return P(()=>{if(e=Ce(e),this.dataFormat==="channelsLast"){const s=nd(e,this.cropping[0][0],e.shape[1]-this.cropping[0][0]-this.cropping[0][1],2);return nd(s,this.cropping[1][0],e.shape[2]-this.cropping[1][1]-this.cropping[1][0],3)}else{const s=nd(e,this.cropping[0][0],e.shape[2]-this.cropping[0][0]-this.cropping[0][1],3);return nd(s,this.cropping[1][0],e.shape[3]-this.cropping[1][1]-this.cropping[1][0],4)}})}getConfig(){const e={cropping:this.cropping,dataFormat:this.dataFormat},n=super.getConfig();return Object.assign(e,n),e}}NE.className="Cropping2D";Y(NE);class TE extends Ae{constructor(e){super(e),this.DEFAULT_SIZE=[2,2],this.inputSpec=[{ndim:4}],this.size=e.size==null?this.DEFAULT_SIZE:e.size,this.dataFormat=e.dataFormat==null?"channelsLast":e.dataFormat,Nt(this.dataFormat),this.interpolation=e.interpolation==null?"nearest":e.interpolation,B6(this.interpolation)}computeOutputShape(e){if(this.dataFormat==="channelsFirst"){const n=e[2]==null?null:this.size[0]*e[2],s=e[3]==null?null:this.size[1]*e[3];return[e[0],e[1],n,s]}else{const n=e[1]==null?null:this.size[0]*e[1],s=e[2]==null?null:this.size[1]*e[2];return[e[0],n,s,e[3]]}}call(e,n){return P(()=>{let s=Ce(e);const r=s.shape;if(this.dataFormat==="channelsFirst"){s=Fe(s,[0,2,3,1]);const o=this.size[0]*r[2],i=this.size[1]*r[3],a=this.interpolation==="nearest"?Mr.resizeNearestNeighbor(s,[o,i]):Mr.resizeBilinear(s,[o,i]);return Fe(a,[0,3,1,2])}else{const o=this.size[0]*r[1],i=this.size[1]*r[2];return this.interpolation==="nearest"?Mr.resizeNearestNeighbor(s,[o,i]):Mr.resizeBilinear(s,[o,i])}})}getConfig(){const e={size:this.size,dataFormat:this.dataFormat,interpolation:this.interpolation},n=super.getConfig();return Object.assign(e,n),e}}TE.className="UpSampling2D";Y(TE);/** * @license * Copyright 2018 Google LLC * @@ -7873,7 +7873,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */function fH(t,e,n=[1,1],s="valid",r,o){return P(()=>{r==null&&(r=Js()),Nt(r);let i=ov(t,r);if(t.rank!==4)throw new E(`Input for depthwiseConv2d is required to be 4-D, but is instead ${t.rank}-D`);if(e.rank!==4)throw new E(`depthwiseKernel is required to be 4-D, but is instead ${e.rank}-D`);return i=By(i,e,n,s==="same"?"same":"valid","NHWC",o),r==="channelsFirst"&&(i=Fe(i,[0,3,1,2])),i})}class TE extends Rm{constructor(e){super(2,e),this.depthwiseKernel=null,this.depthMultiplier=e.depthMultiplier==null?1:e.depthMultiplier,this.depthwiseInitializer=ft(e.depthwiseInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.depthwiseConstraint=Bt(e.depthwiseConstraint),this.depthwiseRegularizer=pt(e.depthwiseRegularizer)}build(e){if(e=Pe(e),e.length<4)throw new E(`Inputs to DepthwiseConv2D should have rank 4. Received input shape: ${JSON.stringify(e)}.`);const n=this.dataFormat==="channelsFirst"?1:3;if(e[n]==null||e[n]<0)throw new E(`The channel dimension of the inputs to DepthwiseConv2D should be defined, but is not (${e[n]}).`);const s=e[n],r=[this.kernelSize[0],this.kernelSize[1],s,this.depthMultiplier];this.depthwiseKernel=this.addWeight("depthwise_kernel",r,null,this.depthwiseInitializer,this.depthwiseRegularizer,!0,this.depthwiseConstraint),this.useBias?this.bias=this.addWeight("bias",[s*this.depthMultiplier],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint):this.bias=null,this.built=!0}call(e,n){return P(()=>{e=Ce(e);let s=fH(e,this.depthwiseKernel.read(),this.strides,this.padding,this.dataFormat,null);return this.useBias&&(s=nr(s,this.bias.read(),this.dataFormat)),this.activation!=null&&(s=this.activation.apply(s)),s})}computeOutputShape(e){e=Pe(e);const n=this.dataFormat==="channelsFirst"?e[2]:e[1],s=this.dataFormat==="channelsFirst"?e[3]:e[2],r=this.dataFormat==="channelsFirst"?e[1]*this.depthMultiplier:e[3]*this.depthMultiplier,o=Ys(n,this.kernelSize[0],this.padding,this.strides[0]),i=Ys(s,this.kernelSize[1],this.padding,this.strides[1]);return this.dataFormat==="channelsFirst"?[e[0],r,o,i]:[e[0],o,i,r]}getConfig(){const e=super.getConfig();return e.depthMultiplier=this.depthMultiplier,e.depthwiseInitializer=xt(this.depthwiseInitializer),e.depthwiseRegularizer=Je(this.depthwiseRegularizer),e.depthwiseConstraint=Lt(this.depthwiseRegularizer),e}}TE.className="DepthwiseConv2D";Y(TE);/** + */function pH(t,e,n=[1,1],s="valid",r,o){return P(()=>{r==null&&(r=er()),Nt(r);let i=ov(t,r);if(t.rank!==4)throw new E(`Input for depthwiseConv2d is required to be 4-D, but is instead ${t.rank}-D`);if(e.rank!==4)throw new E(`depthwiseKernel is required to be 4-D, but is instead ${e.rank}-D`);return i=By(i,e,n,s==="same"?"same":"valid","NHWC",o),r==="channelsFirst"&&(i=Fe(i,[0,3,1,2])),i})}class EE extends Rm{constructor(e){super(2,e),this.depthwiseKernel=null,this.depthMultiplier=e.depthMultiplier==null?1:e.depthMultiplier,this.depthwiseInitializer=ft(e.depthwiseInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.depthwiseConstraint=Bt(e.depthwiseConstraint),this.depthwiseRegularizer=pt(e.depthwiseRegularizer)}build(e){if(e=Pe(e),e.length<4)throw new E(`Inputs to DepthwiseConv2D should have rank 4. Received input shape: ${JSON.stringify(e)}.`);const n=this.dataFormat==="channelsFirst"?1:3;if(e[n]==null||e[n]<0)throw new E(`The channel dimension of the inputs to DepthwiseConv2D should be defined, but is not (${e[n]}).`);const s=e[n],r=[this.kernelSize[0],this.kernelSize[1],s,this.depthMultiplier];this.depthwiseKernel=this.addWeight("depthwise_kernel",r,null,this.depthwiseInitializer,this.depthwiseRegularizer,!0,this.depthwiseConstraint),this.useBias?this.bias=this.addWeight("bias",[s*this.depthMultiplier],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint):this.bias=null,this.built=!0}call(e,n){return P(()=>{e=Ce(e);let s=pH(e,this.depthwiseKernel.read(),this.strides,this.padding,this.dataFormat,null);return this.useBias&&(s=sr(s,this.bias.read(),this.dataFormat)),this.activation!=null&&(s=this.activation.apply(s)),s})}computeOutputShape(e){e=Pe(e);const n=this.dataFormat==="channelsFirst"?e[2]:e[1],s=this.dataFormat==="channelsFirst"?e[3]:e[2],r=this.dataFormat==="channelsFirst"?e[1]*this.depthMultiplier:e[3]*this.depthMultiplier,o=Qs(n,this.kernelSize[0],this.padding,this.strides[0]),i=Qs(s,this.kernelSize[1],this.padding,this.strides[1]);return this.dataFormat==="channelsFirst"?[e[0],r,o,i]:[e[0],o,i,r]}getConfig(){const e=super.getConfig();return e.depthMultiplier=this.depthMultiplier,e.depthwiseInitializer=xt(this.depthwiseInitializer),e.depthwiseRegularizer=Je(this.depthwiseRegularizer),e.depthwiseConstraint=Lt(this.depthwiseRegularizer),e}}EE.className="DepthwiseConv2D";Y(EE);/** * @license * Copyright 2018 Google LLC * @@ -7881,7 +7881,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */function EE(t,e,n,s){if(Array.isArray(t)){if(e!=null||n!=null)throw new E("When inputs is an array, neither initialState or constants should be provided");s!=null&&(n=t.slice(t.length-s,t.length),t=t.slice(0,t.length-s)),t.length>1&&(e=t.slice(1,t.length)),t=t[0]}function r(o){return o==null||Array.isArray(o)?o:[o]}return e=r(e),n=r(n),{inputs:t,initialState:e,constants:n}}function RE(t,e,n,s=!1,r,o,i=!1,a=!1){return P(()=>{const l=e.shape.length;if(l<3)throw new E(`Input should be at least 3D, but is ${l}D.`);const c=[1,0].concat(Zs(2,l));e=Fe(e,c),i&&console.warn("Backend rnn(): the unroll = true option is not applicable to the imperative deeplearn.js backend."),r!=null&&(r=le(le(r,"bool"),"float32"),r.rank===l-1&&(r=En(r,-1)),r=Fe(r,c)),s&&(e=Mi(e,0),r!=null&&(r=Mi(r,0)));const u=[];let d,h=n;const f=e.shape[0],p=Pi(e);let g;r!=null&&(g=Pi(r));for(let m=0;mt(y,h));if(r==null)d=w[0],h=w[1];else{const v=P(()=>{const b=g[m],C=ve(Es(b),b),k=J(D(w[0],b),D(h[0],C)),S=h.map(($,N)=>J(D(w[1][N],b),D($,C)));return{output:k,newStates:S}});d=v.output,h=v.newStates}a&&u.push(d)}let x;return a&&(x=Gr(u,1)),[d,x,h]})}class qo extends Ae{constructor(e){super(e);let n;if(e.cell==null)throw new E("cell property is missing for the constructor of RNN.");if(Array.isArray(e.cell)?n=new lv({cells:e.cell}):n=e.cell,n.stateSize==null)throw new E("The RNN cell should have an attribute `stateSize` (tuple of integers, one integer per RNN state).");this.cell=n,this.returnSequences=e.returnSequences==null?!1:e.returnSequences,this.returnState=e.returnState==null?!1:e.returnState,this.goBackwards=e.goBackwards==null?!1:e.goBackwards,this._stateful=e.stateful==null?!1:e.stateful,this.unroll=e.unroll==null?!1:e.unroll,this.supportsMasking=!0,this.inputSpec=[new Pt({ndim:3})],this.stateSpec=null,this.states_=null,this.numConstants=null,this.keptStates=[]}getStates(){if(this.states_==null){const e=Array.isArray(this.cell.stateSize)?this.cell.stateSize.length:1;return Zs(0,e).map(n=>null)}else return this.states_}setStates(e){this.states_=e}computeOutputShape(e){w1(e)&&(e=e[0]),e=e;let n=this.cell.stateSize;Array.isArray(n)||(n=[n]);const s=n[0];let r;if(this.returnSequences?r=[e[0],e[1],s]:r=[e[0],s],this.returnState){const o=[];for(const i of n)o.push([e[0],i]);return[r].concat(o)}else return r}computeMask(e,n){return P(()=>{Array.isArray(n)&&(n=n[0]);const s=this.returnSequences?n:null;if(this.returnState){const r=this.states.map(o=>null);return[s].concat(r)}else return s})}get states(){if(this.states_==null){const e=Array.isArray(this.cell.stateSize)?this.cell.stateSize.length:1,n=[];for(let s=0;si.shape[i.shape.length-1]),o))throw new E(`An initialState was passed that is not compatible with cell.stateSize. Received stateSpec=${this.stateSpec}; However cell.stateSize is ${this.cell.stateSize}`)}else this.stateSpec=o.map(i=>new Pt({shape:[null,i]}));this.stateful&&this.resetStates()}resetStates(e,n=!1){P(()=>{if(!this.stateful)throw new cr("Cannot call resetStates() on an RNN Layer that is not stateful.");const s=this.inputSpec[0].shape[0];if(s==null)throw new E("If an RNN is stateful, it needs to know its batch size. Specify the batch size of your input tensors: \n- If using a Sequential model, specify the batch size by passing a `batchInputShape` option to your first layer.\n- If using the functional API, specify the batch size by passing a `batchShape` option to your Input layer.");if(this.states_==null)Array.isArray(this.cell.stateSize)?this.states_=this.cell.stateSize.map(r=>Kt([s,r])):this.states_=[Kt([s,this.cell.stateSize])];else if(e==null)$e(this.states_),this.keptStates!=null&&($e(this.keptStates),this.keptStates=[]),Array.isArray(this.cell.stateSize)?this.states_=this.cell.stateSize.map(r=>Kt([s,r])):this.states_[0]=Kt([s,this.cell.stateSize]);else{if(Array.isArray(e)||(e=[e]),e.length!==this.states_.length)throw new E(`Layer ${this.name} expects ${this.states_.length} state(s), but it received ${e.length} state value(s). Input received: ${e}`);n===!0?this.keptStates.push(this.states_.slice()):$e(this.states_);for(let r=0;rxr(r.clone()))})}apply(e,n){let s=n==null?null:n.initialState,r=n==null?null:n.constants;n==null&&(n={});const o=EE(e,s,r,this.numConstants);e=o.inputs,s=o.initialState,r=o.constants;let i=[],a=[];if(s!=null){n.initialState=s,i=i.concat(s),this.stateSpec=[];for(const c of s)this.stateSpec.push(new Pt({shape:c.shape}));a=a.concat(this.stateSpec)}if(r!=null&&(n.constants=r,i=i.concat(r),this.numConstants=r.length),i[0]instanceof Ir){const c=[e].concat(i),u=this.inputSpec.concat(a),d=this.inputSpec;this.inputSpec=u;const h=super.apply(c,n);return this.inputSpec=d,h}else return super.apply(e,n)}call(e,n){return P(()=>{const s=n==null?null:n.mask,r=n==null?null:n.training;let o=n==null?null:n.initialState;e=Ce(e),o==null&&(this.stateful?o=this.states_:o=this.getInitialState(e));const i=Array.isArray(this.cell.stateSize)?this.cell.stateSize.length:1;if(o.length!==i)throw new E(`RNN Layer has ${i} state(s) but was passed ${o.length} initial state(s).`);this.unroll&&console.warn("Ignoring unroll = true for RNN layer, due to imperative backend.");const a={training:r},c=RE((p,g)=>{const x=this.cell.call([p].concat(g),a);return[x[0],x.slice(1)]},e,o,this.goBackwards,s,null,this.unroll,this.returnSequences),u=c[0],d=c[1],h=c[2];this.stateful&&this.resetStates(h,r);const f=this.returnSequences?d:u;return this.returnState?[f].concat(h):f})}getInitialState(e){return P(()=>{let n=Kt(e.shape);return n=me(n,[1,2]),n=vd(n),Array.isArray(this.cell.stateSize)?this.cell.stateSize.map(s=>s>1?x1(n,[1,s]):n):this.cell.stateSize>1?[x1(n,[1,this.cell.stateSize])]:[n]})}get trainableWeights(){return this.trainable?this.cell.trainableWeights:[]}get nonTrainableWeights(){return this.trainable?this.cell.nonTrainableWeights:this.cell.weights}setFastWeightInitDuringBuild(e){super.setFastWeightInitDuringBuild(e),this.cell!=null&&this.cell.setFastWeightInitDuringBuild(e)}getConfig(){const e=super.getConfig(),n={returnSequences:this.returnSequences,returnState:this.returnState,goBackwards:this.goBackwards,stateful:this.stateful,unroll:this.unroll};this.numConstants!=null&&(n.numConstants=this.numConstants);const s=this.cell.getConfig();return this.getClassName()===qo.className&&(n.cell={className:this.cell.getClassName(),config:s}),Object.assign(Object.assign(Object.assign({},s),e),n)}static fromConfig(e,n,s={}){const r=n.cell,o=br(r,s);return new e(Object.assign(n,{cell:o}))}}qo.className="RNN";Y(qo);class Dm extends Ae{}class iv extends Dm{constructor(e){super(e),this.DEFAULT_ACTIVATION="tanh",this.DEFAULT_KERNEL_INITIALIZER="glorotNormal",this.DEFAULT_RECURRENT_INITIALIZER="orthogonal",this.DEFAULT_BIAS_INITIALIZER="zeros",this.units=e.units,qt(this.units,"units"),this.activation=zo(e.activation==null?this.DEFAULT_ACTIVATION:e.activation),this.useBias=e.useBias==null?!0:e.useBias,this.kernelInitializer=ft(e.kernelInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.recurrentInitializer=ft(e.recurrentInitializer||this.DEFAULT_RECURRENT_INITIALIZER),this.biasInitializer=ft(e.biasInitializer||this.DEFAULT_BIAS_INITIALIZER),this.kernelRegularizer=pt(e.kernelRegularizer),this.recurrentRegularizer=pt(e.recurrentRegularizer),this.biasRegularizer=pt(e.biasRegularizer),this.kernelConstraint=Bt(e.kernelConstraint),this.recurrentConstraint=Bt(e.recurrentConstraint),this.biasConstraint=Bt(e.biasConstraint),this.dropout=ll([1,_o([0,e.dropout==null?0:e.dropout])]),this.recurrentDropout=ll([1,_o([0,e.recurrentDropout==null?0:e.recurrentDropout])]),this.dropoutFunc=e.dropoutFunc,this.stateSize=this.units,this.dropoutMask=null,this.recurrentDropoutMask=null}build(e){e=Pe(e),this.kernel=this.addWeight("kernel",[e[e.length-1],this.units],null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.recurrentKernel=this.addWeight("recurrent_kernel",[this.units,this.units],null,this.recurrentInitializer,this.recurrentRegularizer,!0,this.recurrentConstraint),this.useBias?this.bias=this.addWeight("bias",[this.units],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint):this.bias=null,this.built=!0}call(e,n){return P(()=>{if(e=e,e.length!==2)throw new E(`SimpleRNNCell expects 2 input Tensors, got ${e.length}.`);let s=e[1];e=e[0];const r=n.training==null?!1:n.training;0Es(e),rate:this.dropout,training:r,dropoutFunc:this.dropoutFunc})),0Es(s),rate:this.recurrentDropout,training:r,dropoutFunc:this.dropoutFunc}));let o;const i=this.dropoutMask,a=this.recurrentDropoutMask;i!=null?o=vr(D(e,i),this.kernel.read()):o=vr(e,this.kernel.read()),this.bias!=null&&(o=nr(o,this.bias.read())),a!=null&&(s=D(s,a));let l=J(o,vr(s,this.recurrentKernel.read()));return this.activation!=null&&(l=this.activation.apply(l)),[l,l]})}getConfig(){const e=super.getConfig(),n={units:this.units,activation:Fo(this.activation),useBias:this.useBias,kernelInitializer:xt(this.kernelInitializer),recurrentInitializer:xt(this.recurrentInitializer),biasInitializer:xt(this.biasInitializer),kernelRegularizer:Je(this.kernelRegularizer),recurrentRegularizer:Je(this.recurrentRegularizer),biasRegularizer:Je(this.biasRegularizer),activityRegularizer:Je(this.activityRegularizer),kernelConstraint:Lt(this.kernelConstraint),recurrentConstraint:Lt(this.recurrentConstraint),biasConstraint:Lt(this.biasConstraint),dropout:this.dropout,recurrentDropout:this.recurrentDropout};return Object.assign(Object.assign({},e),n)}}iv.className="SimpleRNNCell";Y(iv);class AE extends qo{constructor(e){e.cell=new iv(e),super(e)}call(e,n){return P(()=>{this.cell.dropoutMask!=null&&($e(this.cell.dropoutMask),this.cell.dropoutMask=null),this.cell.recurrentDropoutMask!=null&&($e(this.cell.recurrentDropoutMask),this.cell.recurrentDropoutMask=null);const s=n==null?null:n.mask,r=n==null?null:n.training,o=n==null?null:n.initialState;return super.call(e,{mask:s,training:r,initialState:o})})}static fromConfig(e,n){return new e(n)}}AE.className="SimpleRNN";Y(AE);class av extends Dm{constructor(e){if(super(e),this.DEFAULT_ACTIVATION="tanh",this.DEFAULT_RECURRENT_ACTIVATION="hardSigmoid",this.DEFAULT_KERNEL_INITIALIZER="glorotNormal",this.DEFAULT_RECURRENT_INITIALIZER="orthogonal",this.DEFAULT_BIAS_INITIALIZER="zeros",e.resetAfter)throw new E("GRUCell does not support reset_after parameter set to true.");this.units=e.units,qt(this.units,"units"),this.activation=zo(e.activation===void 0?this.DEFAULT_ACTIVATION:e.activation),this.recurrentActivation=zo(e.recurrentActivation===void 0?this.DEFAULT_RECURRENT_ACTIVATION:e.recurrentActivation),this.useBias=e.useBias==null?!0:e.useBias,this.kernelInitializer=ft(e.kernelInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.recurrentInitializer=ft(e.recurrentInitializer||this.DEFAULT_RECURRENT_INITIALIZER),this.biasInitializer=ft(e.biasInitializer||this.DEFAULT_BIAS_INITIALIZER),this.kernelRegularizer=pt(e.kernelRegularizer),this.recurrentRegularizer=pt(e.recurrentRegularizer),this.biasRegularizer=pt(e.biasRegularizer),this.kernelConstraint=Bt(e.kernelConstraint),this.recurrentConstraint=Bt(e.recurrentConstraint),this.biasConstraint=Bt(e.biasConstraint),this.dropout=ll([1,_o([0,e.dropout==null?0:e.dropout])]),this.recurrentDropout=ll([1,_o([0,e.recurrentDropout==null?0:e.recurrentDropout])]),this.dropoutFunc=e.dropoutFunc,this.implementation=e.implementation,this.stateSize=this.units,this.dropoutMask=null,this.recurrentDropoutMask=null}build(e){e=Pe(e);const n=e[e.length-1];this.kernel=this.addWeight("kernel",[n,this.units*3],null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.recurrentKernel=this.addWeight("recurrent_kernel",[this.units,this.units*3],null,this.recurrentInitializer,this.recurrentRegularizer,!0,this.recurrentConstraint),this.useBias?this.bias=this.addWeight("bias",[this.units*3],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint):this.bias=null,this.built=!0}call(e,n){return P(()=>{if(e=e,e.length!==2)throw new E(`GRUCell expects 2 input Tensors (inputs, h, c), got ${e.length}.`);const s=n.training==null?!1:n.training;let r=e[1];e=e[0],0Es(e),rate:this.dropout,training:s,count:3,dropoutFunc:this.dropoutFunc})),0Es(r),rate:this.recurrentDropout,training:s,count:3,dropoutFunc:this.dropoutFunc}));const o=this.dropoutMask,i=this.recurrentDropoutMask;let a,l,c;0{this.cell.dropoutMask!=null&&($e(this.cell.dropoutMask),this.cell.dropoutMask=null),this.cell.recurrentDropoutMask!=null&&($e(this.cell.recurrentDropoutMask),this.cell.recurrentDropoutMask=null);const s=n==null?null:n.mask,r=n==null?null:n.training,o=n==null?null:n.initialState;return super.call(e,{mask:s,training:r,initialState:o})})}static fromConfig(e,n){return n.implmentation===0&&(n.implementation=1),new e(n)}}DE.className="GRU";Y(DE);class _m extends Dm{constructor(e){super(e),this.DEFAULT_ACTIVATION="tanh",this.DEFAULT_RECURRENT_ACTIVATION="hardSigmoid",this.DEFAULT_KERNEL_INITIALIZER="glorotNormal",this.DEFAULT_RECURRENT_INITIALIZER="orthogonal",this.DEFAULT_BIAS_INITIALIZER="zeros",this.units=e.units,qt(this.units,"units"),this.activation=zo(e.activation===void 0?this.DEFAULT_ACTIVATION:e.activation),this.recurrentActivation=zo(e.recurrentActivation===void 0?this.DEFAULT_RECURRENT_ACTIVATION:e.recurrentActivation),this.useBias=e.useBias==null?!0:e.useBias,this.kernelInitializer=ft(e.kernelInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.recurrentInitializer=ft(e.recurrentInitializer||this.DEFAULT_RECURRENT_INITIALIZER),this.biasInitializer=ft(e.biasInitializer||this.DEFAULT_BIAS_INITIALIZER),this.unitForgetBias=e.unitForgetBias,this.kernelRegularizer=pt(e.kernelRegularizer),this.recurrentRegularizer=pt(e.recurrentRegularizer),this.biasRegularizer=pt(e.biasRegularizer),this.kernelConstraint=Bt(e.kernelConstraint),this.recurrentConstraint=Bt(e.recurrentConstraint),this.biasConstraint=Bt(e.biasConstraint),this.dropout=ll([1,_o([0,e.dropout==null?0:e.dropout])]),this.recurrentDropout=ll([1,_o([0,e.recurrentDropout==null?0:e.recurrentDropout])]),this.dropoutFunc=e.dropoutFunc,this.implementation=e.implementation,this.stateSize=[this.units,this.units],this.dropoutMask=null,this.recurrentDropoutMask=null}build(e){var n;e=Pe(e);const s=e[e.length-1];this.kernel=this.addWeight("kernel",[s,this.units*4],null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.recurrentKernel=this.addWeight("recurrent_kernel",[this.units,this.units*4],null,this.recurrentInitializer,this.recurrentRegularizer,!0,this.recurrentConstraint);let r;if(this.useBias){if(this.unitForgetBias){const o=this.biasInitializer,i=this.units;r=new(n=class extends As{apply(l,c){const u=o.apply([i]),d=new Kw().apply([i]),h=o.apply([i*2]);return KC(KC(u,d),h)}},n.className="CustomInit",n)}else r=this.biasInitializer;this.bias=this.addWeight("bias",[this.units*4],null,r,this.biasRegularizer,!0,this.biasConstraint)}else this.bias=null;this.built=!0}call(e,n){return P(()=>{const s=n.training==null?!1:n.training;if(e=e,e.length!==3)throw new E(`LSTMCell expects 3 input Tensors (inputs, h, c), got ${e.length}.`);let r=e[1];const o=e[2];e=e[0],0Es(e),rate:this.dropout,training:s,count:4,dropoutFunc:this.dropoutFunc})),0Es(r),rate:this.recurrentDropout,training:s,count:4,dropoutFunc:this.dropoutFunc}));const i=this.dropoutMask,a=this.recurrentDropoutMask;let l,c,u,d;0{this.cell.dropoutMask!=null&&($e(this.cell.dropoutMask),this.cell.dropoutMask=null),this.cell.recurrentDropoutMask!=null&&($e(this.cell.recurrentDropoutMask),this.cell.recurrentDropoutMask=null);const s=n==null?null:n.mask,r=n==null?null:n.training,o=n==null?null:n.initialState;return super.call(e,{mask:s,training:r,initialState:o})})}static fromConfig(e,n){return n.implmentation===0&&(n.implementation=1),new e(n)}}_E.className="LSTM";Y(_E);class lv extends Dm{constructor(e){super(e),this.cells=e.cells}get stateSize(){const e=[];for(const n of this.cells.slice().reverse())Array.isArray(n.stateSize)?e.push(...n.stateSize):e.push(n.stateSize);return e}call(e,n){return P(()=>{e=e;let s=e.slice(1);const r=[];for(const a of this.cells.slice().reverse())Array.isArray(a.stateSize)?r.push(s.splice(0,a.stateSize.length)):r.push(s.splice(0,1));r.reverse();const o=[];let i;for(let a=0;a{bi(`RNNCell_${r}`,()=>{s.build(e),Array.isArray(s.stateSize)?n=s.stateSize[0]:n=s.stateSize,e=[e[0],n]})}),this.built=!0}getConfig(){const e=super.getConfig(),n=o=>({className:o.getClassName(),config:o.getConfig()}),r={cells:this.cells.map(n)};return Object.assign(Object.assign({},e),r)}static fromConfig(e,n,s={}){const r=[];for(const o of n.cells)r.push(br(o,s));return new e({cells:r})}get trainableWeights(){if(!this.trainable)return[];const e=[];for(const n of this.cells)e.push(...n.trainableWeights);return e}get nonTrainableWeights(){const e=[];for(const n of this.cells)e.push(...n.nonTrainableWeights);if(!this.trainable){const n=[];for(const s of this.cells)n.push(...s.trainableWeights);return n.concat(e)}return e}getWeights(){const e=[];for(const n of this.cells)e.push(...n.weights);return v1(e)}setWeights(e){const n=[];for(const s of this.cells){const r=s.weights.length,o=e.splice(r);for(let i=0;io!=null?o(e(),n):ST(e(),n),a=()=>Cd(i,e,s);return!r||r<=1?xr(a().clone()):Array(r).fill(void 0).map(a).map(c=>xr(c.clone()))}/** + */function RE(t,e,n,s){if(Array.isArray(t)){if(e!=null||n!=null)throw new E("When inputs is an array, neither initialState or constants should be provided");s!=null&&(n=t.slice(t.length-s,t.length),t=t.slice(0,t.length-s)),t.length>1&&(e=t.slice(1,t.length)),t=t[0]}function r(o){return o==null||Array.isArray(o)?o:[o]}return e=r(e),n=r(n),{inputs:t,initialState:e,constants:n}}function AE(t,e,n,s=!1,r,o,i=!1,a=!1){return P(()=>{const l=e.shape.length;if(l<3)throw new E(`Input should be at least 3D, but is ${l}D.`);const c=[1,0].concat(Js(2,l));e=Fe(e,c),i&&console.warn("Backend rnn(): the unroll = true option is not applicable to the imperative deeplearn.js backend."),r!=null&&(r=le(le(r,"bool"),"float32"),r.rank===l-1&&(r=En(r,-1)),r=Fe(r,c)),s&&(e=Mi(e,0),r!=null&&(r=Mi(r,0)));const u=[];let h,d=n;const f=e.shape[0],p=Pi(e);let g;r!=null&&(g=Pi(r));for(let m=0;mt(y,d));if(r==null)h=w[0],d=w[1];else{const v=P(()=>{const b=g[m],C=ve(Rs(b),b),k=J(D(w[0],b),D(d[0],C)),S=d.map(($,N)=>J(D(w[1][N],b),D($,C)));return{output:k,newStates:S}});h=v.output,d=v.newStates}a&&u.push(h)}let x;return a&&(x=Hr(u,1)),[h,x,d]})}class qo extends Ae{constructor(e){super(e);let n;if(e.cell==null)throw new E("cell property is missing for the constructor of RNN.");if(Array.isArray(e.cell)?n=new lv({cells:e.cell}):n=e.cell,n.stateSize==null)throw new E("The RNN cell should have an attribute `stateSize` (tuple of integers, one integer per RNN state).");this.cell=n,this.returnSequences=e.returnSequences==null?!1:e.returnSequences,this.returnState=e.returnState==null?!1:e.returnState,this.goBackwards=e.goBackwards==null?!1:e.goBackwards,this._stateful=e.stateful==null?!1:e.stateful,this.unroll=e.unroll==null?!1:e.unroll,this.supportsMasking=!0,this.inputSpec=[new Pt({ndim:3})],this.stateSpec=null,this.states_=null,this.numConstants=null,this.keptStates=[]}getStates(){if(this.states_==null){const e=Array.isArray(this.cell.stateSize)?this.cell.stateSize.length:1;return Js(0,e).map(n=>null)}else return this.states_}setStates(e){this.states_=e}computeOutputShape(e){w1(e)&&(e=e[0]),e=e;let n=this.cell.stateSize;Array.isArray(n)||(n=[n]);const s=n[0];let r;if(this.returnSequences?r=[e[0],e[1],s]:r=[e[0],s],this.returnState){const o=[];for(const i of n)o.push([e[0],i]);return[r].concat(o)}else return r}computeMask(e,n){return P(()=>{Array.isArray(n)&&(n=n[0]);const s=this.returnSequences?n:null;if(this.returnState){const r=this.states.map(o=>null);return[s].concat(r)}else return s})}get states(){if(this.states_==null){const e=Array.isArray(this.cell.stateSize)?this.cell.stateSize.length:1,n=[];for(let s=0;si.shape[i.shape.length-1]),o))throw new E(`An initialState was passed that is not compatible with cell.stateSize. Received stateSpec=${this.stateSpec}; However cell.stateSize is ${this.cell.stateSize}`)}else this.stateSpec=o.map(i=>new Pt({shape:[null,i]}));this.stateful&&this.resetStates()}resetStates(e,n=!1){P(()=>{if(!this.stateful)throw new ur("Cannot call resetStates() on an RNN Layer that is not stateful.");const s=this.inputSpec[0].shape[0];if(s==null)throw new E("If an RNN is stateful, it needs to know its batch size. Specify the batch size of your input tensors: \n- If using a Sequential model, specify the batch size by passing a `batchInputShape` option to your first layer.\n- If using the functional API, specify the batch size by passing a `batchShape` option to your Input layer.");if(this.states_==null)Array.isArray(this.cell.stateSize)?this.states_=this.cell.stateSize.map(r=>Kt([s,r])):this.states_=[Kt([s,this.cell.stateSize])];else if(e==null)$e(this.states_),this.keptStates!=null&&($e(this.keptStates),this.keptStates=[]),Array.isArray(this.cell.stateSize)?this.states_=this.cell.stateSize.map(r=>Kt([s,r])):this.states_[0]=Kt([s,this.cell.stateSize]);else{if(Array.isArray(e)||(e=[e]),e.length!==this.states_.length)throw new E(`Layer ${this.name} expects ${this.states_.length} state(s), but it received ${e.length} state value(s). Input received: ${e}`);n===!0?this.keptStates.push(this.states_.slice()):$e(this.states_);for(let r=0;ryr(r.clone()))})}apply(e,n){let s=n==null?null:n.initialState,r=n==null?null:n.constants;n==null&&(n={});const o=RE(e,s,r,this.numConstants);e=o.inputs,s=o.initialState,r=o.constants;let i=[],a=[];if(s!=null){n.initialState=s,i=i.concat(s),this.stateSpec=[];for(const c of s)this.stateSpec.push(new Pt({shape:c.shape}));a=a.concat(this.stateSpec)}if(r!=null&&(n.constants=r,i=i.concat(r),this.numConstants=r.length),i[0]instanceof $r){const c=[e].concat(i),u=this.inputSpec.concat(a),h=this.inputSpec;this.inputSpec=u;const d=super.apply(c,n);return this.inputSpec=h,d}else return super.apply(e,n)}call(e,n){return P(()=>{const s=n==null?null:n.mask,r=n==null?null:n.training;let o=n==null?null:n.initialState;e=Ce(e),o==null&&(this.stateful?o=this.states_:o=this.getInitialState(e));const i=Array.isArray(this.cell.stateSize)?this.cell.stateSize.length:1;if(o.length!==i)throw new E(`RNN Layer has ${i} state(s) but was passed ${o.length} initial state(s).`);this.unroll&&console.warn("Ignoring unroll = true for RNN layer, due to imperative backend.");const a={training:r},c=AE((p,g)=>{const x=this.cell.call([p].concat(g),a);return[x[0],x.slice(1)]},e,o,this.goBackwards,s,null,this.unroll,this.returnSequences),u=c[0],h=c[1],d=c[2];this.stateful&&this.resetStates(d,r);const f=this.returnSequences?h:u;return this.returnState?[f].concat(d):f})}getInitialState(e){return P(()=>{let n=Kt(e.shape);return n=me(n,[1,2]),n=vh(n),Array.isArray(this.cell.stateSize)?this.cell.stateSize.map(s=>s>1?x1(n,[1,s]):n):this.cell.stateSize>1?[x1(n,[1,this.cell.stateSize])]:[n]})}get trainableWeights(){return this.trainable?this.cell.trainableWeights:[]}get nonTrainableWeights(){return this.trainable?this.cell.nonTrainableWeights:this.cell.weights}setFastWeightInitDuringBuild(e){super.setFastWeightInitDuringBuild(e),this.cell!=null&&this.cell.setFastWeightInitDuringBuild(e)}getConfig(){const e=super.getConfig(),n={returnSequences:this.returnSequences,returnState:this.returnState,goBackwards:this.goBackwards,stateful:this.stateful,unroll:this.unroll};this.numConstants!=null&&(n.numConstants=this.numConstants);const s=this.cell.getConfig();return this.getClassName()===qo.className&&(n.cell={className:this.cell.getClassName(),config:s}),Object.assign(Object.assign(Object.assign({},s),e),n)}static fromConfig(e,n,s={}){const r=n.cell,o=Cr(r,s);return new e(Object.assign(n,{cell:o}))}}qo.className="RNN";Y(qo);class Dm extends Ae{}class iv extends Dm{constructor(e){super(e),this.DEFAULT_ACTIVATION="tanh",this.DEFAULT_KERNEL_INITIALIZER="glorotNormal",this.DEFAULT_RECURRENT_INITIALIZER="orthogonal",this.DEFAULT_BIAS_INITIALIZER="zeros",this.units=e.units,qt(this.units,"units"),this.activation=zo(e.activation==null?this.DEFAULT_ACTIVATION:e.activation),this.useBias=e.useBias==null?!0:e.useBias,this.kernelInitializer=ft(e.kernelInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.recurrentInitializer=ft(e.recurrentInitializer||this.DEFAULT_RECURRENT_INITIALIZER),this.biasInitializer=ft(e.biasInitializer||this.DEFAULT_BIAS_INITIALIZER),this.kernelRegularizer=pt(e.kernelRegularizer),this.recurrentRegularizer=pt(e.recurrentRegularizer),this.biasRegularizer=pt(e.biasRegularizer),this.kernelConstraint=Bt(e.kernelConstraint),this.recurrentConstraint=Bt(e.recurrentConstraint),this.biasConstraint=Bt(e.biasConstraint),this.dropout=ll([1,_o([0,e.dropout==null?0:e.dropout])]),this.recurrentDropout=ll([1,_o([0,e.recurrentDropout==null?0:e.recurrentDropout])]),this.dropoutFunc=e.dropoutFunc,this.stateSize=this.units,this.dropoutMask=null,this.recurrentDropoutMask=null}build(e){e=Pe(e),this.kernel=this.addWeight("kernel",[e[e.length-1],this.units],null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.recurrentKernel=this.addWeight("recurrent_kernel",[this.units,this.units],null,this.recurrentInitializer,this.recurrentRegularizer,!0,this.recurrentConstraint),this.useBias?this.bias=this.addWeight("bias",[this.units],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint):this.bias=null,this.built=!0}call(e,n){return P(()=>{if(e=e,e.length!==2)throw new E(`SimpleRNNCell expects 2 input Tensors, got ${e.length}.`);let s=e[1];e=e[0];const r=n.training==null?!1:n.training;0Rs(e),rate:this.dropout,training:r,dropoutFunc:this.dropoutFunc})),0Rs(s),rate:this.recurrentDropout,training:r,dropoutFunc:this.dropoutFunc}));let o;const i=this.dropoutMask,a=this.recurrentDropoutMask;i!=null?o=br(D(e,i),this.kernel.read()):o=br(e,this.kernel.read()),this.bias!=null&&(o=sr(o,this.bias.read())),a!=null&&(s=D(s,a));let l=J(o,br(s,this.recurrentKernel.read()));return this.activation!=null&&(l=this.activation.apply(l)),[l,l]})}getConfig(){const e=super.getConfig(),n={units:this.units,activation:Fo(this.activation),useBias:this.useBias,kernelInitializer:xt(this.kernelInitializer),recurrentInitializer:xt(this.recurrentInitializer),biasInitializer:xt(this.biasInitializer),kernelRegularizer:Je(this.kernelRegularizer),recurrentRegularizer:Je(this.recurrentRegularizer),biasRegularizer:Je(this.biasRegularizer),activityRegularizer:Je(this.activityRegularizer),kernelConstraint:Lt(this.kernelConstraint),recurrentConstraint:Lt(this.recurrentConstraint),biasConstraint:Lt(this.biasConstraint),dropout:this.dropout,recurrentDropout:this.recurrentDropout};return Object.assign(Object.assign({},e),n)}}iv.className="SimpleRNNCell";Y(iv);class DE extends qo{constructor(e){e.cell=new iv(e),super(e)}call(e,n){return P(()=>{this.cell.dropoutMask!=null&&($e(this.cell.dropoutMask),this.cell.dropoutMask=null),this.cell.recurrentDropoutMask!=null&&($e(this.cell.recurrentDropoutMask),this.cell.recurrentDropoutMask=null);const s=n==null?null:n.mask,r=n==null?null:n.training,o=n==null?null:n.initialState;return super.call(e,{mask:s,training:r,initialState:o})})}static fromConfig(e,n){return new e(n)}}DE.className="SimpleRNN";Y(DE);class av extends Dm{constructor(e){if(super(e),this.DEFAULT_ACTIVATION="tanh",this.DEFAULT_RECURRENT_ACTIVATION="hardSigmoid",this.DEFAULT_KERNEL_INITIALIZER="glorotNormal",this.DEFAULT_RECURRENT_INITIALIZER="orthogonal",this.DEFAULT_BIAS_INITIALIZER="zeros",e.resetAfter)throw new E("GRUCell does not support reset_after parameter set to true.");this.units=e.units,qt(this.units,"units"),this.activation=zo(e.activation===void 0?this.DEFAULT_ACTIVATION:e.activation),this.recurrentActivation=zo(e.recurrentActivation===void 0?this.DEFAULT_RECURRENT_ACTIVATION:e.recurrentActivation),this.useBias=e.useBias==null?!0:e.useBias,this.kernelInitializer=ft(e.kernelInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.recurrentInitializer=ft(e.recurrentInitializer||this.DEFAULT_RECURRENT_INITIALIZER),this.biasInitializer=ft(e.biasInitializer||this.DEFAULT_BIAS_INITIALIZER),this.kernelRegularizer=pt(e.kernelRegularizer),this.recurrentRegularizer=pt(e.recurrentRegularizer),this.biasRegularizer=pt(e.biasRegularizer),this.kernelConstraint=Bt(e.kernelConstraint),this.recurrentConstraint=Bt(e.recurrentConstraint),this.biasConstraint=Bt(e.biasConstraint),this.dropout=ll([1,_o([0,e.dropout==null?0:e.dropout])]),this.recurrentDropout=ll([1,_o([0,e.recurrentDropout==null?0:e.recurrentDropout])]),this.dropoutFunc=e.dropoutFunc,this.implementation=e.implementation,this.stateSize=this.units,this.dropoutMask=null,this.recurrentDropoutMask=null}build(e){e=Pe(e);const n=e[e.length-1];this.kernel=this.addWeight("kernel",[n,this.units*3],null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.recurrentKernel=this.addWeight("recurrent_kernel",[this.units,this.units*3],null,this.recurrentInitializer,this.recurrentRegularizer,!0,this.recurrentConstraint),this.useBias?this.bias=this.addWeight("bias",[this.units*3],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint):this.bias=null,this.built=!0}call(e,n){return P(()=>{if(e=e,e.length!==2)throw new E(`GRUCell expects 2 input Tensors (inputs, h, c), got ${e.length}.`);const s=n.training==null?!1:n.training;let r=e[1];e=e[0],0Rs(e),rate:this.dropout,training:s,count:3,dropoutFunc:this.dropoutFunc})),0Rs(r),rate:this.recurrentDropout,training:s,count:3,dropoutFunc:this.dropoutFunc}));const o=this.dropoutMask,i=this.recurrentDropoutMask;let a,l,c;0{this.cell.dropoutMask!=null&&($e(this.cell.dropoutMask),this.cell.dropoutMask=null),this.cell.recurrentDropoutMask!=null&&($e(this.cell.recurrentDropoutMask),this.cell.recurrentDropoutMask=null);const s=n==null?null:n.mask,r=n==null?null:n.training,o=n==null?null:n.initialState;return super.call(e,{mask:s,training:r,initialState:o})})}static fromConfig(e,n){return n.implmentation===0&&(n.implementation=1),new e(n)}}_E.className="GRU";Y(_E);class _m extends Dm{constructor(e){super(e),this.DEFAULT_ACTIVATION="tanh",this.DEFAULT_RECURRENT_ACTIVATION="hardSigmoid",this.DEFAULT_KERNEL_INITIALIZER="glorotNormal",this.DEFAULT_RECURRENT_INITIALIZER="orthogonal",this.DEFAULT_BIAS_INITIALIZER="zeros",this.units=e.units,qt(this.units,"units"),this.activation=zo(e.activation===void 0?this.DEFAULT_ACTIVATION:e.activation),this.recurrentActivation=zo(e.recurrentActivation===void 0?this.DEFAULT_RECURRENT_ACTIVATION:e.recurrentActivation),this.useBias=e.useBias==null?!0:e.useBias,this.kernelInitializer=ft(e.kernelInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.recurrentInitializer=ft(e.recurrentInitializer||this.DEFAULT_RECURRENT_INITIALIZER),this.biasInitializer=ft(e.biasInitializer||this.DEFAULT_BIAS_INITIALIZER),this.unitForgetBias=e.unitForgetBias,this.kernelRegularizer=pt(e.kernelRegularizer),this.recurrentRegularizer=pt(e.recurrentRegularizer),this.biasRegularizer=pt(e.biasRegularizer),this.kernelConstraint=Bt(e.kernelConstraint),this.recurrentConstraint=Bt(e.recurrentConstraint),this.biasConstraint=Bt(e.biasConstraint),this.dropout=ll([1,_o([0,e.dropout==null?0:e.dropout])]),this.recurrentDropout=ll([1,_o([0,e.recurrentDropout==null?0:e.recurrentDropout])]),this.dropoutFunc=e.dropoutFunc,this.implementation=e.implementation,this.stateSize=[this.units,this.units],this.dropoutMask=null,this.recurrentDropoutMask=null}build(e){var n;e=Pe(e);const s=e[e.length-1];this.kernel=this.addWeight("kernel",[s,this.units*4],null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.recurrentKernel=this.addWeight("recurrent_kernel",[this.units,this.units*4],null,this.recurrentInitializer,this.recurrentRegularizer,!0,this.recurrentConstraint);let r;if(this.useBias){if(this.unitForgetBias){const o=this.biasInitializer,i=this.units;r=new(n=class extends Ds{apply(l,c){const u=o.apply([i]),h=new Kw().apply([i]),d=o.apply([i*2]);return KC(KC(u,h),d)}},n.className="CustomInit",n)}else r=this.biasInitializer;this.bias=this.addWeight("bias",[this.units*4],null,r,this.biasRegularizer,!0,this.biasConstraint)}else this.bias=null;this.built=!0}call(e,n){return P(()=>{const s=n.training==null?!1:n.training;if(e=e,e.length!==3)throw new E(`LSTMCell expects 3 input Tensors (inputs, h, c), got ${e.length}.`);let r=e[1];const o=e[2];e=e[0],0Rs(e),rate:this.dropout,training:s,count:4,dropoutFunc:this.dropoutFunc})),0Rs(r),rate:this.recurrentDropout,training:s,count:4,dropoutFunc:this.dropoutFunc}));const i=this.dropoutMask,a=this.recurrentDropoutMask;let l,c,u,h;0{this.cell.dropoutMask!=null&&($e(this.cell.dropoutMask),this.cell.dropoutMask=null),this.cell.recurrentDropoutMask!=null&&($e(this.cell.recurrentDropoutMask),this.cell.recurrentDropoutMask=null);const s=n==null?null:n.mask,r=n==null?null:n.training,o=n==null?null:n.initialState;return super.call(e,{mask:s,training:r,initialState:o})})}static fromConfig(e,n){return n.implmentation===0&&(n.implementation=1),new e(n)}}FE.className="LSTM";Y(FE);class lv extends Dm{constructor(e){super(e),this.cells=e.cells}get stateSize(){const e=[];for(const n of this.cells.slice().reverse())Array.isArray(n.stateSize)?e.push(...n.stateSize):e.push(n.stateSize);return e}call(e,n){return P(()=>{e=e;let s=e.slice(1);const r=[];for(const a of this.cells.slice().reverse())Array.isArray(a.stateSize)?r.push(s.splice(0,a.stateSize.length)):r.push(s.splice(0,1));r.reverse();const o=[];let i;for(let a=0;a{bi(`RNNCell_${r}`,()=>{s.build(e),Array.isArray(s.stateSize)?n=s.stateSize[0]:n=s.stateSize,e=[e[0],n]})}),this.built=!0}getConfig(){const e=super.getConfig(),n=o=>({className:o.getClassName(),config:o.getConfig()}),r={cells:this.cells.map(n)};return Object.assign(Object.assign({},e),r)}static fromConfig(e,n,s={}){const r=[];for(const o of n.cells)r.push(Cr(o,s));return new e({cells:r})}get trainableWeights(){if(!this.trainable)return[];const e=[];for(const n of this.cells)e.push(...n.trainableWeights);return e}get nonTrainableWeights(){const e=[];for(const n of this.cells)e.push(...n.nonTrainableWeights);if(!this.trainable){const n=[];for(const s of this.cells)n.push(...s.trainableWeights);return n.concat(e)}return e}getWeights(){const e=[];for(const n of this.cells)e.push(...n.weights);return v1(e)}setWeights(e){const n=[];for(const s of this.cells){const r=s.weights.length,o=e.splice(r);for(let i=0;io!=null?o(e(),n):IT(e(),n),a=()=>Ch(i,e,s);return!r||r<=1?yr(a().clone()):Array(r).fill(void 0).map(a).map(c=>yr(c.clone()))}/** * @license * Copyright 2020 Google LLC * @@ -7889,7 +7889,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */var pH=function(t,e){var n={};for(var s in t)Object.prototype.hasOwnProperty.call(t,s)&&e.indexOf(s)<0&&(n[s]=t[s]);if(t!=null&&typeof Object.getOwnPropertySymbols=="function")for(var r=0,s=Object.getOwnPropertySymbols(t);r{if(this.cell.dropoutMask!=null&&($e(this.cell.dropoutMask),this.cell.dropoutMask=null),this.cell.recurrentDropoutMask!=null&&($e(this.cell.recurrentDropoutMask),this.cell.recurrentDropoutMask=null),n&&n.constants)throw new E("ConvRNN2D cell does not support constants");const s=n==null?null:n.mask,r=n==null?null:n.training,o=n==null?null:n.initialState;return super.call(e,{mask:s,training:r,initialState:o})})}computeOutputShape(e){let n=this.computeSingleOutputShape(e);return this.returnSequences||(n=[n[0],...n.slice(2)]),this.returnState&&(n=[n,...Array(2).fill([e[0],...n.slice(-3)])]),n}getInitialState(e){return P(()=>{const{stateSize:n}=this.cell,s=e.shape,r=this.computeSingleOutputShape(s),o=[r[0],...r.slice(2)],i=Kt(o);return Array.isArray(n)?Array(n.length).fill(i):[i]})}resetStates(e,n=!1){P(()=>{if(!this.stateful)throw new cr("Cannot call resetStates() on an RNN Layer that is not stateful.");const s=this.inputSpec[0].shape,r=this.computeSingleOutputShape(s),o=[r[0],...r.slice(2)];if(s[0]==null)throw new E("If an RNN is stateful, it needs to know its batch size. Specify the batch size of your input tensors: \n- If using a Sequential model, specify the batch size by passing a `batchInputShape` option to your first layer.\n- If using the functional API, specify the batch size by passing a `batchShape` option to your Input layer.");if(this.getStates()==null)Array.isArray(this.cell.stateSize)?this.states_=this.cell.stateSize.map(()=>Kt(o)):this.states_=[Kt(o)];else if(e==null)$e(this.states_),this.keptStates!=null&&($e(this.keptStates),this.keptStates=[]),Array.isArray(this.cell.stateSize)?this.states_=this.cell.stateSize.map(()=>Kt(o)):this.states_[0]=Kt(o);else{if(Array.isArray(e)||(e=[e]),e.length!==this.states_.length)throw new E(`Layer ${this.name} expects ${this.states_.length} state(s), but it received ${e.length} state value(s). Input received: ${e}`);n?this.keptStates.push(this.states_.slice()):$e(this.states_);for(let a=0;axr(a.clone()))})}computeSingleOutputShape(e){const{dataFormat:n,filters:s,kernelSize:r,padding:o,strides:i,dilationRate:a}=this.cell,l=n==="channelsFirst",c=e[l?3:2],u=e[l?4:3],d=Ys(c,r[0],o,i[0],a[0]),h=Ys(u,r[1],o,i[1],a[1]);return[...e.slice(0,2),...l?[s,d,h]:[d,h,s]]}}FE.className="ConvRNN2D";class cv extends _m{constructor(e){const{filters:n,kernelSize:s,strides:r,padding:o,dataFormat:i,dilationRate:a}=e;super(Object.assign(Object.assign({},e),{units:n})),this.filters=n,qt(this.filters,"filters"),this.kernelSize=Ba(s,2,"kernelSize"),this.kernelSize.forEach(l=>qt(l,"kernelSize")),this.strides=Ba(r||1,2,"strides"),this.strides.forEach(l=>qt(l,"strides")),this.padding=o||"valid",ds(this.padding),this.dataFormat=i||"channelsLast",Nt(this.dataFormat),this.dilationRate=Ba(a||1,2,"dilationRate"),this.dilationRate.forEach(l=>qt(l,"dilationRate"))}build(e){var n;e=Pe(e);const s=this.dataFormat==="channelsFirst"?1:e.length-1;if(e[s]==null)throw new E(`The channel dimension of the input should be defined. Found ${e[s]}`);const r=e[s],o=4,i=this.kernelSize.concat([r,this.filters*o]);this.kernel=this.addWeight("kernel",i,null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint);const a=this.kernelSize.concat([this.filters,this.filters*o]);if(this.recurrentKernel=this.addWeight("recurrent_kernel",a,null,this.recurrentInitializer,this.recurrentRegularizer,!0,this.recurrentConstraint),this.useBias){let l;if(this.unitForgetBias){const c=this.biasInitializer,u=this.filters;l=new(n=class extends As{apply(h,f){const p=c.apply([u]),g=Ko([u]),x=c.apply([u*2]);return jw([p,g,x])}},n.className="CustomInit",n)}else l=this.biasInitializer;this.bias=this.addWeight("bias",[this.filters*o],null,l,this.biasRegularizer,!0,this.biasConstraint)}this.built=!0}call(e,n){return P(()=>{if(e.length!==3)throw new E(`ConvLSTM2DCell expects 3 input Tensors (inputs, h, c), got ${e.length}.`);const s=n.training||!1,r=e[0],o=e[1],i=e[2],a=4;0Es(r),rate:this.dropout,training:s,count:a,dropoutFunc:this.dropoutFunc}));const l=this.dropoutMask,c=(G,X,q)=>!X||!X[q]?G:D(X[q],G);let u=c(r,l,0),d=c(r,l,1),h=c(r,l,2),f=c(r,l,3);0Es(o),rate:this.recurrentDropout,training:s,count:a,dropoutFunc:this.dropoutFunc}));const p=this.recurrentDropoutMask;let g=c(o,p,0),x=c(o,p,1),m=c(o,p,2),y=c(o,p,3);const w=3,[v,b,C,k]=rs(this.kernel.read(),a,w),[S,$,N,A]=this.useBias?rs(this.bias.read(),a):[null,null,null,null];u=this.inputConv(u,v,S,this.padding),d=this.inputConv(d,b,$,this.padding),h=this.inputConv(h,C,N,this.padding),f=this.inputConv(f,k,A,this.padding);const[M,L,V,B]=rs(this.recurrentKernel.read(),a,w);g=this.recurrentConv(g,M),x=this.recurrentConv(x,L),m=this.recurrentConv(m,V),y=this.recurrentConv(y,B);const U=this.recurrentActivation.apply(J(u,g)),K=this.recurrentActivation.apply(J(d,x)),R=J(D(K,i),D(U,this.activation.apply(J(h,m)))),O=D(this.recurrentActivation.apply(J(f,y)),this.activation.apply(R));return[O,O,R]})}getConfig(){const e=super.getConfig(),n=pH(e,["units"]),s={filters:this.filters,kernelSize:this.kernelSize,padding:this.padding,dataFormat:this.dataFormat,dilationRate:this.dilationRate,strides:this.strides};return Object.assign(Object.assign({},n),s)}inputConv(e,n,s,r){const o=zi(e,n,this.strides,r||"valid",this.dataFormat==="channelsFirst"?"NCHW":"NHWC",this.dilationRate);return s?nr(o,s,this.dataFormat):o}recurrentConv(e,n){return zi(e,n,1,"same",this.dataFormat==="channelsFirst"?"NCHW":"NHWC")}}cv.className="ConvLSTM2DCell";Y(cv);class zE extends FE{constructor(e){const n=new cv(e);super(Object.assign(Object.assign({},e),{cell:n}))}static fromConfig(e,n){return new e(n)}}zE.className="ConvLSTM2D";Y(zE);/** + */var mH=function(t,e){var n={};for(var s in t)Object.prototype.hasOwnProperty.call(t,s)&&e.indexOf(s)<0&&(n[s]=t[s]);if(t!=null&&typeof Object.getOwnPropertySymbols=="function")for(var r=0,s=Object.getOwnPropertySymbols(t);r{if(this.cell.dropoutMask!=null&&($e(this.cell.dropoutMask),this.cell.dropoutMask=null),this.cell.recurrentDropoutMask!=null&&($e(this.cell.recurrentDropoutMask),this.cell.recurrentDropoutMask=null),n&&n.constants)throw new E("ConvRNN2D cell does not support constants");const s=n==null?null:n.mask,r=n==null?null:n.training,o=n==null?null:n.initialState;return super.call(e,{mask:s,training:r,initialState:o})})}computeOutputShape(e){let n=this.computeSingleOutputShape(e);return this.returnSequences||(n=[n[0],...n.slice(2)]),this.returnState&&(n=[n,...Array(2).fill([e[0],...n.slice(-3)])]),n}getInitialState(e){return P(()=>{const{stateSize:n}=this.cell,s=e.shape,r=this.computeSingleOutputShape(s),o=[r[0],...r.slice(2)],i=Kt(o);return Array.isArray(n)?Array(n.length).fill(i):[i]})}resetStates(e,n=!1){P(()=>{if(!this.stateful)throw new ur("Cannot call resetStates() on an RNN Layer that is not stateful.");const s=this.inputSpec[0].shape,r=this.computeSingleOutputShape(s),o=[r[0],...r.slice(2)];if(s[0]==null)throw new E("If an RNN is stateful, it needs to know its batch size. Specify the batch size of your input tensors: \n- If using a Sequential model, specify the batch size by passing a `batchInputShape` option to your first layer.\n- If using the functional API, specify the batch size by passing a `batchShape` option to your Input layer.");if(this.getStates()==null)Array.isArray(this.cell.stateSize)?this.states_=this.cell.stateSize.map(()=>Kt(o)):this.states_=[Kt(o)];else if(e==null)$e(this.states_),this.keptStates!=null&&($e(this.keptStates),this.keptStates=[]),Array.isArray(this.cell.stateSize)?this.states_=this.cell.stateSize.map(()=>Kt(o)):this.states_[0]=Kt(o);else{if(Array.isArray(e)||(e=[e]),e.length!==this.states_.length)throw new E(`Layer ${this.name} expects ${this.states_.length} state(s), but it received ${e.length} state value(s). Input received: ${e}`);n?this.keptStates.push(this.states_.slice()):$e(this.states_);for(let a=0;ayr(a.clone()))})}computeSingleOutputShape(e){const{dataFormat:n,filters:s,kernelSize:r,padding:o,strides:i,dilationRate:a}=this.cell,l=n==="channelsFirst",c=e[l?3:2],u=e[l?4:3],h=Qs(c,r[0],o,i[0],a[0]),d=Qs(u,r[1],o,i[1],a[1]);return[...e.slice(0,2),...l?[s,h,d]:[h,d,s]]}}zE.className="ConvRNN2D";class cv extends _m{constructor(e){const{filters:n,kernelSize:s,strides:r,padding:o,dataFormat:i,dilationRate:a}=e;super(Object.assign(Object.assign({},e),{units:n})),this.filters=n,qt(this.filters,"filters"),this.kernelSize=Ba(s,2,"kernelSize"),this.kernelSize.forEach(l=>qt(l,"kernelSize")),this.strides=Ba(r||1,2,"strides"),this.strides.forEach(l=>qt(l,"strides")),this.padding=o||"valid",hs(this.padding),this.dataFormat=i||"channelsLast",Nt(this.dataFormat),this.dilationRate=Ba(a||1,2,"dilationRate"),this.dilationRate.forEach(l=>qt(l,"dilationRate"))}build(e){var n;e=Pe(e);const s=this.dataFormat==="channelsFirst"?1:e.length-1;if(e[s]==null)throw new E(`The channel dimension of the input should be defined. Found ${e[s]}`);const r=e[s],o=4,i=this.kernelSize.concat([r,this.filters*o]);this.kernel=this.addWeight("kernel",i,null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint);const a=this.kernelSize.concat([this.filters,this.filters*o]);if(this.recurrentKernel=this.addWeight("recurrent_kernel",a,null,this.recurrentInitializer,this.recurrentRegularizer,!0,this.recurrentConstraint),this.useBias){let l;if(this.unitForgetBias){const c=this.biasInitializer,u=this.filters;l=new(n=class extends Ds{apply(d,f){const p=c.apply([u]),g=Ko([u]),x=c.apply([u*2]);return jw([p,g,x])}},n.className="CustomInit",n)}else l=this.biasInitializer;this.bias=this.addWeight("bias",[this.filters*o],null,l,this.biasRegularizer,!0,this.biasConstraint)}this.built=!0}call(e,n){return P(()=>{if(e.length!==3)throw new E(`ConvLSTM2DCell expects 3 input Tensors (inputs, h, c), got ${e.length}.`);const s=n.training||!1,r=e[0],o=e[1],i=e[2],a=4;0Rs(r),rate:this.dropout,training:s,count:a,dropoutFunc:this.dropoutFunc}));const l=this.dropoutMask,c=(G,X,q)=>!X||!X[q]?G:D(X[q],G);let u=c(r,l,0),h=c(r,l,1),d=c(r,l,2),f=c(r,l,3);0Rs(o),rate:this.recurrentDropout,training:s,count:a,dropoutFunc:this.dropoutFunc}));const p=this.recurrentDropoutMask;let g=c(o,p,0),x=c(o,p,1),m=c(o,p,2),y=c(o,p,3);const w=3,[v,b,C,k]=rs(this.kernel.read(),a,w),[S,$,N,A]=this.useBias?rs(this.bias.read(),a):[null,null,null,null];u=this.inputConv(u,v,S,this.padding),h=this.inputConv(h,b,$,this.padding),d=this.inputConv(d,C,N,this.padding),f=this.inputConv(f,k,A,this.padding);const[M,L,V,B]=rs(this.recurrentKernel.read(),a,w);g=this.recurrentConv(g,M),x=this.recurrentConv(x,L),m=this.recurrentConv(m,V),y=this.recurrentConv(y,B);const U=this.recurrentActivation.apply(J(u,g)),K=this.recurrentActivation.apply(J(h,x)),R=J(D(K,i),D(U,this.activation.apply(J(d,m)))),O=D(this.recurrentActivation.apply(J(f,y)),this.activation.apply(R));return[O,O,R]})}getConfig(){const e=super.getConfig(),n=mH(e,["units"]),s={filters:this.filters,kernelSize:this.kernelSize,padding:this.padding,dataFormat:this.dataFormat,dilationRate:this.dilationRate,strides:this.strides};return Object.assign(Object.assign({},n),s)}inputConv(e,n,s,r){const o=zi(e,n,this.strides,r||"valid",this.dataFormat==="channelsFirst"?"NCHW":"NHWC",this.dilationRate);return s?sr(o,s,this.dataFormat):o}recurrentConv(e,n){return zi(e,n,1,"same",this.dataFormat==="channelsFirst"?"NCHW":"NHWC")}}cv.className="ConvLSTM2DCell";Y(cv);class OE extends zE{constructor(e){const n=new cv(e);super(Object.assign(Object.assign({},e),{cell:n}))}static fromConfig(e,n){return new e(n)}}OE.className="ConvLSTM2D";Y(OE);/** * @license * Copyright 2018 Google LLC * @@ -7897,7 +7897,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */class uv extends Ae{constructor(e){super(e),this.rate=Math.max(Math.min(e.rate,1),0),this.noiseShape=e.noiseShape,this.seed=e.seed,this.supportsMasking=!0}getNoiseShape(e){if(this.noiseShape==null)return this.noiseShape;const n=e.shape,s=[];for(let r=0;r{this.invokeCallHook(e,n);const s=Ce(e);if(0ST(s,this.rate,o,this.seed),()=>s,r)}return e})}getConfig(){const e={rate:this.rate,noiseShape:this.noiseShape,seed:this.seed},n=super.getConfig();return Object.assign(e,n),e}dispose(){return super.dispose()}}uv.className="Dropout";Y(uv);class OE extends uv{constructor(e){super(e),this.inputSpec=[{ndim:3}]}getNoiseShape(e){const n=e.shape;return[n[0],1,n[2]]}}OE.className="SpatialDropout1D";Y(OE);class ME extends Ae{constructor(e){if(super(e),this.activation=null,this.useBias=!0,this.kernel=null,this.bias=null,this.DEFAULT_KERNEL_INITIALIZER="glorotNormal",this.DEFAULT_BIAS_INITIALIZER="zeros",e.batchInputShape==null&&e.inputShape==null&&e.inputDim!=null){let n=null;e.batchSize!=null&&(n=e.batchSize),this.batchInputShape=[n,e.inputDim]}this.units=e.units,qt(this.units,"units"),this.activation=zo(e.activation),e.useBias!=null&&(this.useBias=e.useBias),this.kernelInitializer=ft(e.kernelInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.biasInitializer=ft(e.biasInitializer||this.DEFAULT_BIAS_INITIALIZER),this.kernelConstraint=Bt(e.kernelConstraint),this.biasConstraint=Bt(e.biasConstraint),this.kernelRegularizer=pt(e.kernelRegularizer),this.biasRegularizer=pt(e.biasRegularizer),this.activityRegularizer=pt(e.activityRegularizer),this.supportsMasking=!0,this.inputSpec=[{minNDim:2}]}build(e){e=Pe(e);const n=e[e.length-1];this.kernel==null&&(this.kernel=this.addWeight("kernel",[n,this.units],null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.useBias&&(this.bias=this.addWeight("bias",[this.units],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint))),this.inputSpec=[{minNDim:2,axes:{[-1]:n}}],this.built=!0}computeOutputShape(e){e=Pe(e);const n=e.slice();return n[n.length-1]=this.units,n}call(e,n){return P(()=>{this.invokeCallHook(e,n);const s=Ce(e),r=xT(this.activation.getClassName());let o;return r!=null?o=vr(s,this.kernel.read(),r,this.bias?this.bias.read():null):(o=vr(s,this.kernel.read()),this.bias!=null&&(o=nr(o,this.bias.read())),this.activation!=null&&(o=this.activation.apply(o))),o})}getConfig(){const e={units:this.units,activation:Fo(this.activation),useBias:this.useBias,kernelInitializer:xt(this.kernelInitializer),biasInitializer:xt(this.biasInitializer),kernelRegularizer:Je(this.kernelRegularizer),biasRegularizer:Je(this.biasRegularizer),activityRegularizer:Je(this.activityRegularizer),kernelConstraint:Lt(this.kernelConstraint),biasConstraint:Lt(this.biasConstraint)},n=super.getConfig();return Object.assign(e,n),e}}ME.className="Dense";Y(ME);class PE extends Ae{constructor(e){e=e||{},super(e),this.inputSpec=[{minNDim:3}],this.dataFormat=e.dataFormat}computeOutputShape(e){e=Pe(e);for(const n of e.slice(1))if(n==null)throw new E(`The shape of the input to "Flatten" is not fully defined (got ${e.slice(1)}). Make sure to pass a complete "input_shape" or "batch_input_shape" argument to the first layer in your model.`);return[e[0],Eo(e,1)]}call(e,n){return P(()=>{this.invokeCallHook(e,n);let s=Ce(e);if(this.dataFormat==="channelsFirst"&&s.rank>1){const r=[0];for(let o=2;o{this.invokeCallHook(e,n);const s=Ce(e);return this.activation.apply(s)})}getConfig(){const e={activation:Fo(this.activation)},n=super.getConfig();return Object.assign(e,n),e}}LE.className="Activation";Y(LE);class BE extends Ae{constructor(e){super(e),this.n=e.n,this.inputSpec=[{ndim:2}]}computeOutputShape(e){return[e[0],this.n,e[1]]}call(e,n){return P(()=>(e=Ce(e),U6(e,this.n)))}getConfig(){const e={n:this.n},n=super.getConfig();return Object.assign(e,n),e}}BE.className="RepeatVector";Y(BE);class VE extends Ae{constructor(e){super(e),this.targetShape=e.targetShape;for(let n=0;n{this.invokeCallHook(e,n);const s=Ce(e),r=s.shape,o=r.slice(0,1).concat(this.fixUnknownDimension(r.slice(1),this.targetShape));return F(s,o)})}getConfig(){const e={targetShape:this.targetShape},n=super.getConfig();return Object.assign(e,n),e}}VE.className="Reshape";Y(VE);class WE extends Ae{constructor(e){if(super(e),e.dims==null)throw new Error("Required configuration field `dims` is missing during Permute constructor call.");if(!Array.isArray(e.dims))throw new Error(`Permute constructor requires \`dims\` to be an Array, but received ${e.dims} instead.`);const n=Zs(1,e.dims.length+1);if(!Ue(e.dims.slice().sort(),n))throw new Error("Invalid permutation `dims`: "+JSON.stringify(e.dims)+" `dims` must contain consecutive integers starting from 1.");this.dims=e.dims,this.dimsIncludingBatch=[0].concat(this.dims),this.inputSpec=[new Pt({ndim:this.dims.length+1})]}computeOutputShape(e){e=Pe(e);const n=e.slice();return this.dims.forEach((s,r)=>{n[r+1]=e[s]}),n}call(e,n){return Fe(Ce(e),this.dimsIncludingBatch)}getConfig(){const e={dims:this.dims},n=super.getConfig();return Object.assign(e,n),e}}WE.className="Permute";Y(WE);class UE extends Ae{constructor(e){super(e??{}),this.supportsMasking=!0,e!=null?this.maskValue=e.maskValue==null?0:e.maskValue:this.maskValue=0}computeOutputShape(e){return e}getConfig(){const e=super.getConfig(),n={maskValue:this.maskValue};return Object.assign(n,e),n}computeMask(e,n){const s=Ce(e);return u1(bf(s,this.maskValue),-1)}call(e,n){return P(()=>{this.invokeCallHook(e,n);const s=Ce(e),i=u1(bf(s,this.maskValue),-1,!0);return D(s,le(i,s.dtype))})}}UE.className="Masking";Y(UE);/** + */class uv extends Ae{constructor(e){super(e),this.rate=Math.max(Math.min(e.rate,1),0),this.noiseShape=e.noiseShape,this.seed=e.seed,this.supportsMasking=!0}getNoiseShape(e){if(this.noiseShape==null)return this.noiseShape;const n=e.shape,s=[];for(let r=0;r{this.invokeCallHook(e,n);const s=Ce(e);if(0IT(s,this.rate,o,this.seed),()=>s,r)}return e})}getConfig(){const e={rate:this.rate,noiseShape:this.noiseShape,seed:this.seed},n=super.getConfig();return Object.assign(e,n),e}dispose(){return super.dispose()}}uv.className="Dropout";Y(uv);class ME extends uv{constructor(e){super(e),this.inputSpec=[{ndim:3}]}getNoiseShape(e){const n=e.shape;return[n[0],1,n[2]]}}ME.className="SpatialDropout1D";Y(ME);class PE extends Ae{constructor(e){if(super(e),this.activation=null,this.useBias=!0,this.kernel=null,this.bias=null,this.DEFAULT_KERNEL_INITIALIZER="glorotNormal",this.DEFAULT_BIAS_INITIALIZER="zeros",e.batchInputShape==null&&e.inputShape==null&&e.inputDim!=null){let n=null;e.batchSize!=null&&(n=e.batchSize),this.batchInputShape=[n,e.inputDim]}this.units=e.units,qt(this.units,"units"),this.activation=zo(e.activation),e.useBias!=null&&(this.useBias=e.useBias),this.kernelInitializer=ft(e.kernelInitializer||this.DEFAULT_KERNEL_INITIALIZER),this.biasInitializer=ft(e.biasInitializer||this.DEFAULT_BIAS_INITIALIZER),this.kernelConstraint=Bt(e.kernelConstraint),this.biasConstraint=Bt(e.biasConstraint),this.kernelRegularizer=pt(e.kernelRegularizer),this.biasRegularizer=pt(e.biasRegularizer),this.activityRegularizer=pt(e.activityRegularizer),this.supportsMasking=!0,this.inputSpec=[{minNDim:2}]}build(e){e=Pe(e);const n=e[e.length-1];this.kernel==null&&(this.kernel=this.addWeight("kernel",[n,this.units],null,this.kernelInitializer,this.kernelRegularizer,!0,this.kernelConstraint),this.useBias&&(this.bias=this.addWeight("bias",[this.units],null,this.biasInitializer,this.biasRegularizer,!0,this.biasConstraint))),this.inputSpec=[{minNDim:2,axes:{[-1]:n}}],this.built=!0}computeOutputShape(e){e=Pe(e);const n=e.slice();return n[n.length-1]=this.units,n}call(e,n){return P(()=>{this.invokeCallHook(e,n);const s=Ce(e),r=yT(this.activation.getClassName());let o;return r!=null?o=br(s,this.kernel.read(),r,this.bias?this.bias.read():null):(o=br(s,this.kernel.read()),this.bias!=null&&(o=sr(o,this.bias.read())),this.activation!=null&&(o=this.activation.apply(o))),o})}getConfig(){const e={units:this.units,activation:Fo(this.activation),useBias:this.useBias,kernelInitializer:xt(this.kernelInitializer),biasInitializer:xt(this.biasInitializer),kernelRegularizer:Je(this.kernelRegularizer),biasRegularizer:Je(this.biasRegularizer),activityRegularizer:Je(this.activityRegularizer),kernelConstraint:Lt(this.kernelConstraint),biasConstraint:Lt(this.biasConstraint)},n=super.getConfig();return Object.assign(e,n),e}}PE.className="Dense";Y(PE);class LE extends Ae{constructor(e){e=e||{},super(e),this.inputSpec=[{minNDim:3}],this.dataFormat=e.dataFormat}computeOutputShape(e){e=Pe(e);for(const n of e.slice(1))if(n==null)throw new E(`The shape of the input to "Flatten" is not fully defined (got ${e.slice(1)}). Make sure to pass a complete "input_shape" or "batch_input_shape" argument to the first layer in your model.`);return[e[0],Eo(e,1)]}call(e,n){return P(()=>{this.invokeCallHook(e,n);let s=Ce(e);if(this.dataFormat==="channelsFirst"&&s.rank>1){const r=[0];for(let o=2;o{this.invokeCallHook(e,n);const s=Ce(e);return this.activation.apply(s)})}getConfig(){const e={activation:Fo(this.activation)},n=super.getConfig();return Object.assign(e,n),e}}BE.className="Activation";Y(BE);class VE extends Ae{constructor(e){super(e),this.n=e.n,this.inputSpec=[{ndim:2}]}computeOutputShape(e){return[e[0],this.n,e[1]]}call(e,n){return P(()=>(e=Ce(e),G6(e,this.n)))}getConfig(){const e={n:this.n},n=super.getConfig();return Object.assign(e,n),e}}VE.className="RepeatVector";Y(VE);class WE extends Ae{constructor(e){super(e),this.targetShape=e.targetShape;for(let n=0;n{this.invokeCallHook(e,n);const s=Ce(e),r=s.shape,o=r.slice(0,1).concat(this.fixUnknownDimension(r.slice(1),this.targetShape));return F(s,o)})}getConfig(){const e={targetShape:this.targetShape},n=super.getConfig();return Object.assign(e,n),e}}WE.className="Reshape";Y(WE);class UE extends Ae{constructor(e){if(super(e),e.dims==null)throw new Error("Required configuration field `dims` is missing during Permute constructor call.");if(!Array.isArray(e.dims))throw new Error(`Permute constructor requires \`dims\` to be an Array, but received ${e.dims} instead.`);const n=Js(1,e.dims.length+1);if(!Ue(e.dims.slice().sort(),n))throw new Error("Invalid permutation `dims`: "+JSON.stringify(e.dims)+" `dims` must contain consecutive integers starting from 1.");this.dims=e.dims,this.dimsIncludingBatch=[0].concat(this.dims),this.inputSpec=[new Pt({ndim:this.dims.length+1})]}computeOutputShape(e){e=Pe(e);const n=e.slice();return this.dims.forEach((s,r)=>{n[r+1]=e[s]}),n}call(e,n){return Fe(Ce(e),this.dimsIncludingBatch)}getConfig(){const e={dims:this.dims},n=super.getConfig();return Object.assign(e,n),e}}UE.className="Permute";Y(UE);class GE extends Ae{constructor(e){super(e??{}),this.supportsMasking=!0,e!=null?this.maskValue=e.maskValue==null?0:e.maskValue:this.maskValue=0}computeOutputShape(e){return e}getConfig(){const e=super.getConfig(),n={maskValue:this.maskValue};return Object.assign(n,e),n}computeMask(e,n){const s=Ce(e);return u1(bf(s,this.maskValue),-1)}call(e,n){return P(()=>{this.invokeCallHook(e,n);const s=Ce(e),i=u1(bf(s,this.maskValue),-1,!0);return D(s,le(i,s.dtype))})}}GE.className="Masking";Y(GE);/** * @license * Copyright 2018 Google LLC * @@ -7905,7 +7905,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */class GE extends Ae{constructor(e){if(super(e),this.embeddings=null,this.DEFAULT_EMBEDDINGS_INITIALIZER="randomUniform",e.batchInputShape==null&&e.inputShape==null){let n=null;e.batchSize!=null&&(n=e.batchSize),e.inputLength==null?this.batchInputShape=[n,null]:this.batchInputShape=[n].concat(Ke(e.inputLength))}this.inputDim=e.inputDim,qt(this.inputDim,"inputDim"),this.outputDim=e.outputDim,qt(this.outputDim,"outputDim"),this.embeddingsInitializer=ft(e.embeddingsInitializer||this.DEFAULT_EMBEDDINGS_INITIALIZER),this.embeddingsRegularizer=pt(e.embeddingsRegularizer),this.activityRegularizer=pt(e.activityRegularizer),this.embeddingsConstraint=Bt(e.embeddingsConstraint),this.maskZero=e.maskZero,this.supportsMasking=e.maskZero,this.inputLength=e.inputLength}build(e){this.embeddings=this.addWeight("embeddings",[this.inputDim,this.outputDim],this.dtype,this.embeddingsInitializer,this.embeddingsRegularizer,!0,this.embeddingsConstraint),this.built=!0}warnOnIncompatibleInputShape(e){}computeMask(e,n){return P(()=>this.maskZero?(e=Ce(e),bf(e,ze(e))):null)}computeOutputShape(e){if(e=Pe(e),this.inputLength==null)return[...e,this.outputDim];const n=Ke(this.inputLength);if(n.length!==e.length-1)throw new E(`"inputLength" is ${this.inputLength}, but received input shape has shape ${e}`);{let s=0;for(let r=0;r{this.invokeCallHook(e,n);let s=Ce(e);s.dtype!=="int32"&&(s=wr(s,"int32"));const r=kT(this.embeddings.read(),F(s,[s.size]));return F(r,Pe(this.computeOutputShape(s.shape)))})}getConfig(){const e={inputDim:this.inputDim,outputDim:this.outputDim,embeddingsInitializer:xt(this.embeddingsInitializer),embeddingsRegularizer:Je(this.embeddingsRegularizer),activityRegularizer:Je(this.activityRegularizer),embeddingsConstraint:Lt(this.embeddingsConstraint),maskZero:this.maskZero,inputLength:this.inputLength},n=super.getConfig();return Object.assign(e,n),e}}GE.className="Embedding";Y(GE);/** + */class HE extends Ae{constructor(e){if(super(e),this.embeddings=null,this.DEFAULT_EMBEDDINGS_INITIALIZER="randomUniform",e.batchInputShape==null&&e.inputShape==null){let n=null;e.batchSize!=null&&(n=e.batchSize),e.inputLength==null?this.batchInputShape=[n,null]:this.batchInputShape=[n].concat(Ke(e.inputLength))}this.inputDim=e.inputDim,qt(this.inputDim,"inputDim"),this.outputDim=e.outputDim,qt(this.outputDim,"outputDim"),this.embeddingsInitializer=ft(e.embeddingsInitializer||this.DEFAULT_EMBEDDINGS_INITIALIZER),this.embeddingsRegularizer=pt(e.embeddingsRegularizer),this.activityRegularizer=pt(e.activityRegularizer),this.embeddingsConstraint=Bt(e.embeddingsConstraint),this.maskZero=e.maskZero,this.supportsMasking=e.maskZero,this.inputLength=e.inputLength}build(e){this.embeddings=this.addWeight("embeddings",[this.inputDim,this.outputDim],this.dtype,this.embeddingsInitializer,this.embeddingsRegularizer,!0,this.embeddingsConstraint),this.built=!0}warnOnIncompatibleInputShape(e){}computeMask(e,n){return P(()=>this.maskZero?(e=Ce(e),bf(e,ze(e))):null)}computeOutputShape(e){if(e=Pe(e),this.inputLength==null)return[...e,this.outputDim];const n=Ke(this.inputLength);if(n.length!==e.length-1)throw new E(`"inputLength" is ${this.inputLength}, but received input shape has shape ${e}`);{let s=0;for(let r=0;r{this.invokeCallHook(e,n);let s=Ce(e);s.dtype!=="int32"&&(s=vr(s,"int32"));const r=ST(this.embeddings.read(),F(s,[s.size]));return F(r,Pe(this.computeOutputShape(s.shape)))})}getConfig(){const e={inputDim:this.inputDim,outputDim:this.outputDim,embeddingsInitializer:xt(this.embeddingsInitializer),embeddingsRegularizer:Je(this.embeddingsRegularizer),activityRegularizer:Je(this.activityRegularizer),embeddingsConstraint:Lt(this.embeddingsConstraint),maskZero:this.maskZero,inputLength:this.inputLength},n=super.getConfig();return Object.assign(e,n),e}}HE.className="Embedding";Y(HE);/** * @license * Copyright 2018 Google LLC * @@ -7913,7 +7913,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */class Ji extends Ae{constructor(e){super(e||{}),this.supportsMasking=!0}mergeFunction(e){throw new Ie}computeElementwiseOpOutputShape(e,n){if(e==null||n==null)return null;if(e.length1)throw new E(`Can not merge tensors with different batch sizes. Got tensors with shapes: ${JSON.stringify(e)}.`);let s=e[0]==null?null:e[0].slice(1);for(let o=1;oo.length);e.indexOf(null)===-1&&To(r).length===1?this.reshapeRequired=!1:this.reshapeRequired=!0}call(e,n){return P(()=>{if(e=e,this.reshapeRequired){const s=[],r=e.map(o=>o.rank);if(r.indexOf(null)===-1){const o=_o(r);for(let i of e){const a=i.rank;for(let l=0;l1){const u=Zs(1,c).concat([0]);s.push(Fe(l,u)),o=!0}else s.push(l)}let i=this.mergeFunction(s);const a=i.rank;if(o){if(a==null){const l=i.shape,c=l.length,u=l[c-1],d=[u].concat(l.slice(0,l.length-1));i=F(Fe(F(i,[-1,u]),[1,0]),d)}else if(a>1){const l=[a-1].concat(Zs(0,a-1));i=Fe(i,l)}}return i}}else return this.mergeFunction(e)})}computeOutputShape(e){e=e;let n;e[0]==null?n=null:n=e[0].slice(1);for(let r=1;r{if(n==null)return null;if(!Array.isArray(n))throw new E("`mask` should be an Array");if(!Array.isArray(e))throw new E("`inputs` should be an Array");if(n.length!==e.length)throw new E(`The Array 'inputs' and 'mask' are expected to have the same length, but have different lengths (${e.length} vs ${n.length})`);if(n.every(r=>r==null))return null;n=n.map(r=>r==null?r:En(r,0));let s=n[0];for(let r=1;r{let n=e[0].clone();for(let s=1;s{let n=e[0].clone();for(let s=1;s{let n=e[0].clone();for(let s=1;s{let n=e[0];for(let s=1;s{let n=e[0];for(let s=1;s1)throw new E("A `Concatenate` layer requires inputs with matching shapes except for the concat axis. Got input shapes: "+JSON.stringify(e))}mergeFunction(e){return P(()=>jw(e,this.axis))}computeOutputShape(e){if(!(Array.isArray(e)&&Array.isArray(e[0])))throw new E("A `Concatenate` layer should be called on a list of inputs.");const n=e,s=n[0].slice(),r=this.axis<0?s.length+this.axis:this.axis;for(const o of n.slice(1)){if(s[r]==null||o[r]==null){s[r]=null;break}s[r]+=o[r]}return s}computeMask(e,n){if(n==null)return null;if(!Array.isArray(n))throw new E("`mask` should be an array for Concatenate");if(!Array.isArray(e))throw new E("`inputs` should be an array for Concatenate");if(n.length!==e.length)throw new E(`Mismatch in the length of mask (${n.length}) and the legnth of inputs (${e.length})`);return P(()=>{let s=!0;if(n.forEach(i=>{if(i!=null){s=!1;return}}),s)return null;const r=[];for(let i=0;i3||e.shape.length>3)throw new Ie("batchDot is not implemented for tensors of 4D or higher rank yet");if(I(t.shape.length>=2,()=>`batchDot requires the rank of x to be >= 2, but got ${t.shape.length}`),I(t.shape.length>=2,()=>`batchDot requires the rank of y to be >= 2, but got ${e.shape.length}`),typeof n=="number"&&(n=[n,n]),t.dtype==="complex64"||e.dtype==="complex64")throw new Ie("batchDot is not implemented for complex64-type Tensors yet.");const s=t.shape.length,r=e.shape.length;n==null&&(n=[s-1,r-2]);const o=n;return P(()=>{let i;if(s>r){i=s-r;const l=[];for(let c=0;cs){i=r-s;const l=[];for(let c=0;c0){let l;s>r?l=s+r-3:l=s-1;const c=[];for(let u=l;u"A `Dot` layer should be called on a list of exactly 2 inputs.");const n=e[0],s=e[1];if(n.length>3||s.length>3)throw new Ie("Dot layer does not support tensors of 4D or higher rank yet.");const r=this.interpretAxes(n,s);if(n[r[0]]!==s[r[1]])throw new E(`Dimension incompatibility: ${n[r[0]]} !== ${s[r[1]]}`)}mergeFunction(e){if(e.length!==2)throw new E(`A \`Dot\` layer must be called on exactly 2 inputs, but received ${e.length} input(s).`);let n=e[0],s=e[1],r;return Array.isArray(this.axes)?r=this.axes.map((o,i)=>Kl(o,e[i].shape.length)):r=[Kl(this.axes,n.shape.length),Kl(this.axes,s.shape.length)],this.normalize&&(n=Tf(n,r[0]),s=Tf(s,r[1])),mH(n,s,r)}interpretAxes(e,n){let s;return Array.isArray(this.axes)?s=this.axes:s=[Kl(this.axes,e.length),Kl(this.axes,n.length)],s}computeOutputShape(e){I(Array.isArray(e)&&e.length===2&&Array.isArray(e[0])&&Array.isArray(e[1]),()=>"A `Dot` layer should be called on a list of exactly 2 inputs.");const n=e[0].slice(),s=e[1].slice();if(n.length>3||s.length>3)throw new Ie("Dot layer does not support tensors of 4D or higher rank yet.");const r=this.interpretAxes(n,s);n.splice(r[0],1),s.splice(r[1],1),s.splice(0,1);const o=n.concat(s);return o.length===1&&o.push(1),o}computeMask(e,n){return null}getConfig(){const e={axes:this.axes,normalize:this.normalize},n=super.getConfig();return Object.assign(e,n),e}}QE.className="Dot";Y(QE);/** + */class Ji extends Ae{constructor(e){super(e||{}),this.supportsMasking=!0}mergeFunction(e){throw new Ie}computeElementwiseOpOutputShape(e,n){if(e==null||n==null)return null;if(e.length1)throw new E(`Can not merge tensors with different batch sizes. Got tensors with shapes: ${JSON.stringify(e)}.`);let s=e[0]==null?null:e[0].slice(1);for(let o=1;oo.length);e.indexOf(null)===-1&&To(r).length===1?this.reshapeRequired=!1:this.reshapeRequired=!0}call(e,n){return P(()=>{if(e=e,this.reshapeRequired){const s=[],r=e.map(o=>o.rank);if(r.indexOf(null)===-1){const o=_o(r);for(let i of e){const a=i.rank;for(let l=0;l1){const u=Js(1,c).concat([0]);s.push(Fe(l,u)),o=!0}else s.push(l)}let i=this.mergeFunction(s);const a=i.rank;if(o){if(a==null){const l=i.shape,c=l.length,u=l[c-1],h=[u].concat(l.slice(0,l.length-1));i=F(Fe(F(i,[-1,u]),[1,0]),h)}else if(a>1){const l=[a-1].concat(Js(0,a-1));i=Fe(i,l)}}return i}}else return this.mergeFunction(e)})}computeOutputShape(e){e=e;let n;e[0]==null?n=null:n=e[0].slice(1);for(let r=1;r{if(n==null)return null;if(!Array.isArray(n))throw new E("`mask` should be an Array");if(!Array.isArray(e))throw new E("`inputs` should be an Array");if(n.length!==e.length)throw new E(`The Array 'inputs' and 'mask' are expected to have the same length, but have different lengths (${e.length} vs ${n.length})`);if(n.every(r=>r==null))return null;n=n.map(r=>r==null?r:En(r,0));let s=n[0];for(let r=1;r{let n=e[0].clone();for(let s=1;s{let n=e[0].clone();for(let s=1;s{let n=e[0].clone();for(let s=1;s{let n=e[0];for(let s=1;s{let n=e[0];for(let s=1;s1)throw new E("A `Concatenate` layer requires inputs with matching shapes except for the concat axis. Got input shapes: "+JSON.stringify(e))}mergeFunction(e){return P(()=>jw(e,this.axis))}computeOutputShape(e){if(!(Array.isArray(e)&&Array.isArray(e[0])))throw new E("A `Concatenate` layer should be called on a list of inputs.");const n=e,s=n[0].slice(),r=this.axis<0?s.length+this.axis:this.axis;for(const o of n.slice(1)){if(s[r]==null||o[r]==null){s[r]=null;break}s[r]+=o[r]}return s}computeMask(e,n){if(n==null)return null;if(!Array.isArray(n))throw new E("`mask` should be an array for Concatenate");if(!Array.isArray(e))throw new E("`inputs` should be an array for Concatenate");if(n.length!==e.length)throw new E(`Mismatch in the length of mask (${n.length}) and the legnth of inputs (${e.length})`);return P(()=>{let s=!0;if(n.forEach(i=>{if(i!=null){s=!1;return}}),s)return null;const r=[];for(let i=0;i3||e.shape.length>3)throw new Ie("batchDot is not implemented for tensors of 4D or higher rank yet");if(I(t.shape.length>=2,()=>`batchDot requires the rank of x to be >= 2, but got ${t.shape.length}`),I(t.shape.length>=2,()=>`batchDot requires the rank of y to be >= 2, but got ${e.shape.length}`),typeof n=="number"&&(n=[n,n]),t.dtype==="complex64"||e.dtype==="complex64")throw new Ie("batchDot is not implemented for complex64-type Tensors yet.");const s=t.shape.length,r=e.shape.length;n==null&&(n=[s-1,r-2]);const o=n;return P(()=>{let i;if(s>r){i=s-r;const l=[];for(let c=0;cs){i=r-s;const l=[];for(let c=0;c0){let l;s>r?l=s+r-3:l=s-1;const c=[];for(let u=l;u"A `Dot` layer should be called on a list of exactly 2 inputs.");const n=e[0],s=e[1];if(n.length>3||s.length>3)throw new Ie("Dot layer does not support tensors of 4D or higher rank yet.");const r=this.interpretAxes(n,s);if(n[r[0]]!==s[r[1]])throw new E(`Dimension incompatibility: ${n[r[0]]} !== ${s[r[1]]}`)}mergeFunction(e){if(e.length!==2)throw new E(`A \`Dot\` layer must be called on exactly 2 inputs, but received ${e.length} input(s).`);let n=e[0],s=e[1],r;return Array.isArray(this.axes)?r=this.axes.map((o,i)=>Kl(o,e[i].shape.length)):r=[Kl(this.axes,n.shape.length),Kl(this.axes,s.shape.length)],this.normalize&&(n=Tf(n,r[0]),s=Tf(s,r[1])),gH(n,s,r)}interpretAxes(e,n){let s;return Array.isArray(this.axes)?s=this.axes:s=[Kl(this.axes,e.length),Kl(this.axes,n.length)],s}computeOutputShape(e){I(Array.isArray(e)&&e.length===2&&Array.isArray(e[0])&&Array.isArray(e[1]),()=>"A `Dot` layer should be called on a list of exactly 2 inputs.");const n=e[0].slice(),s=e[1].slice();if(n.length>3||s.length>3)throw new Ie("Dot layer does not support tensors of 4D or higher rank yet.");const r=this.interpretAxes(n,s);n.splice(r[0],1),s.splice(r[1],1),s.splice(0,1);const o=n.concat(s);return o.length===1&&o.push(1),o}computeMask(e,n){return null}getConfig(){const e={axes:this.axes,normalize:this.normalize},n=super.getConfig();return Object.assign(e,n),e}}ZE.className="Dot";Y(ZE);/** * @license * Copyright 2018 Google LLC * @@ -7921,7 +7921,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */class ZE extends Ae{constructor(e){super(e),this.supportsMasking=!0,this.stddev=e.stddev}computeOutputShape(e){return e}getConfig(){const e=super.getConfig(),n={stddev:this.stddev};return Object.assign(n,e),n}call(e,n){return P(()=>{this.invokeCallHook(e,n);const s=Ce(e);return Cd(()=>J($m(s.shape,0,this.stddev),s),()=>s,n.training||!1)})}}ZE.className="GaussianNoise";Y(ZE);class JE extends Ae{constructor(e){super(e),this.supportsMasking=!0,this.rate=e.rate}computeOutputShape(e){return e}getConfig(){const e=super.getConfig(),n={rate:this.rate};return Object.assign(n,e),n}call(e,n){return P(()=>{this.invokeCallHook(e,n);const s=Ce(e);return this.rate>0&&this.rate<1?Cd(()=>{const o=Math.sqrt(this.rate/(1-this.rate));return D(s,$m(s.shape,1,o))},()=>s,n.training||!1):s})}}JE.className="GaussianDropout";Y(JE);class eR extends Ae{constructor(e){super(e),this.supportsMasking=!0,this.rate=e.rate,this.noiseShape=e.noiseShape}_getNoiseShape(e){return this.noiseShape||Ce(e).shape}computeOutputShape(e){return e}getConfig(){const e=super.getConfig(),n={rate:this.rate};return Object.assign(n,e),n}call(e,n){return P(()=>{if(this.rate<1&&this.rate>0){const s=this._getNoiseShape(e);return Cd(()=>{const o=Ce(e),l=-1.6732632423543772*1.0507009873554805;let c=Xi(fd(s),this.rate);c=wr(c,"float32");const u=((1-this.rate)*(1+this.rate*l**2))**-.5,d=-u*l*this.rate,h=J(D(o,c),D(J(c,-1),l));return J(D(h,u),d)},()=>Ce(e),n.training||!1)}return e})}}eR.className="AlphaDropout";Y(eR);/** + */class JE extends Ae{constructor(e){super(e),this.supportsMasking=!0,this.stddev=e.stddev}computeOutputShape(e){return e}getConfig(){const e=super.getConfig(),n={stddev:this.stddev};return Object.assign(n,e),n}call(e,n){return P(()=>{this.invokeCallHook(e,n);const s=Ce(e);return Ch(()=>J($m(s.shape,0,this.stddev),s),()=>s,n.training||!1)})}}JE.className="GaussianNoise";Y(JE);class eR extends Ae{constructor(e){super(e),this.supportsMasking=!0,this.rate=e.rate}computeOutputShape(e){return e}getConfig(){const e=super.getConfig(),n={rate:this.rate};return Object.assign(n,e),n}call(e,n){return P(()=>{this.invokeCallHook(e,n);const s=Ce(e);return this.rate>0&&this.rate<1?Ch(()=>{const o=Math.sqrt(this.rate/(1-this.rate));return D(s,$m(s.shape,1,o))},()=>s,n.training||!1):s})}}eR.className="GaussianDropout";Y(eR);class tR extends Ae{constructor(e){super(e),this.supportsMasking=!0,this.rate=e.rate,this.noiseShape=e.noiseShape}_getNoiseShape(e){return this.noiseShape||Ce(e).shape}computeOutputShape(e){return e}getConfig(){const e=super.getConfig(),n={rate:this.rate};return Object.assign(n,e),n}call(e,n){return P(()=>{if(this.rate<1&&this.rate>0){const s=this._getNoiseShape(e);return Ch(()=>{const o=Ce(e),l=-1.6732632423543772*1.0507009873554805;let c=Xi(fh(s),this.rate);c=vr(c,"float32");const u=((1-this.rate)*(1+this.rate*l**2))**-.5,h=-u*l*this.rate,d=J(D(o,c),D(J(c,-1),l));return J(D(d,u),h)},()=>Ce(e),n.training||!1)}return e})}}tR.className="AlphaDropout";Y(tR);/** * @license * Copyright 2018 Google LLC * @@ -7929,7 +7929,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */function Jc(t,e,n,s,r,o=.001){let i;if(t.rank===2)i=LL(t,e,n,s,r,o);else if(t.rank===3)i=VL(t,e,n,s,r,o);else if(t.rank===4)i=UL(t,e,n,s,r,o);else throw new Ie(`batchNormalization is not implemented for array of rank ${t.rank} yet`);return i}function gH(t,e,n,s,r=.001){return P(()=>{const o=Ky(t,s),i=o.mean,a=o.variance;return[Jc(t,i,a,n,e,r),i,a]})}function xH(t,e,n,s,r=.001){return P(()=>{const o=Ky(t,s),i=o.mean,a=o.variance,l=[];for(const p of Zs(0,t.rank))s.indexOf(p)!==-1?l.push(1):l.push(t.shape[p]);const c=F(i,l),u=F(a,l),d=e==null?null:F(e,l),h=n==null?null:F(n,l);return[Jc(t,c,u,h,d,r),i,a]})}function yH(t,e,n,s,r=.001){return Ue(s.slice().sort(),Zs(0,t.rank-1))?gH(t,e,n,s,r):xH(t,e,n,s,r)}class tR extends Ae{constructor(e){e==null&&(e={}),super(e),this.supportsMasking=!0,this.axis=e.axis==null?-1:e.axis,this.momentum=e.momentum==null?.99:e.momentum,this.epsilon=e.epsilon==null?.001:e.epsilon,this.center=e.center==null?!0:e.center,this.scale=e.scale==null?!0:e.scale,this.betaInitializer=ft(e.betaInitializer||"zeros"),this.gammaInitializer=ft(e.gammaInitializer||"ones"),this.movingMeanInitializer=ft(e.movingMeanInitializer||"zeros"),this.movingVarianceInitializer=ft(e.movingVarianceInitializer||"ones"),this.betaConstraint=Bt(e.betaConstraint),this.gammaConstraint=Bt(e.gammaConstraint),this.betaRegularizer=pt(e.betaRegularizer),this.gammaRegularizer=pt(e.gammaRegularizer)}build(e){e=Pe(e);const n=this.axis>=0?this.axis:this.axis+e.length,s=e[n];if(s==null)throw new E(`Axis ${n} of input tensor should have a defined dimension but the layer received an input with shape ${JSON.stringify(e)}.`);this.inputSpec=[new Pt({ndim:e.length,axes:{[n]:s}})];const r=[s];this.scale&&(this.gamma=this.addWeight("gamma",r,null,this.gammaInitializer,this.gammaRegularizer,!0,this.gammaConstraint)),this.center&&(this.beta=this.addWeight("beta",r,null,this.betaInitializer,this.betaRegularizer,!0,this.betaConstraint)),this.movingMean=this.addWeight("moving_mean",r,null,this.movingMeanInitializer,null,!1),this.movingVariance=this.addWeight("moving_variance",r,null,this.movingVarianceInitializer,null,!1),this.built=!0}call(e,n){return P(()=>{const s=n.training==null?!1:n.training,r=Ce(e),o=r.shape,i=o.length,a=Zs(0,i),l=this.axis>=0?this.axis:this.axis+i;a.splice(l,1);const c=Li(1,i);c[l]=o[l];const u=a.slice();u.sort();const d=!Ue(u,Zs(0,i).slice(0,i-1)),h=()=>{if(d){const y=F(this.movingMean.read(),c),w=F(this.movingVariance.read(),c),v=this.center?F(this.beta.read(),c):null,b=this.scale?F(this.gamma.read(),c):null;return Jc(r,y,w,v,b,this.epsilon)}else return Jc(r,this.movingMean.read(),this.movingVariance.read(),this.beta==null?null:this.beta.read(),this.gamma==null?null:this.gamma.read(),this.epsilon)};if(!s)return h();const[f,p,g]=yH(r,this.gamma.read(),this.beta.read(),a,this.epsilon),x=(y,w,v)=>{P(()=>{const b=1-v,C=y.read(),k=D(ve(C,w),b);y.write(ve(C,k))})};return(()=>{x(this.movingMean,p,this.momentum),x(this.movingVariance,g,this.momentum)})(),f})}getConfig(){const e={axis:this.axis,momentum:this.momentum,epsilon:this.epsilon,center:this.center,scale:this.scale,betaInitializer:xt(this.betaInitializer),gammaInitializer:xt(this.gammaInitializer),movingMeanInitializer:xt(this.movingMeanInitializer),movingVarianceInitializer:xt(this.movingVarianceInitializer),betaRegularizer:Je(this.betaRegularizer),gammaRegularizer:Je(this.gammaRegularizer),betaConstraint:Lt(this.betaConstraint),gammaConstraint:Lt(this.gammaConstraint)},n=super.getConfig();return Object.assign(e,n),e}}tR.className="BatchNormalization";Y(tR);class nR extends Ae{constructor(e){if(e==null&&(e={}),super(e),this.axis=e.axis==null?-1:e.axis,typeof this.axis=="number"){if(!Number.isInteger(this.axis))throw new Error(`Expected axis to be an integer, but received ${this.axis}`)}else if(Array.isArray(this.axis)){for(const n of this.axis)if(!Number.isInteger(n))throw new Error(`Expected axis to be an array of integers, but received ${JSON.stringify(this.axis)}`)}else throw new Error(`Expected axis to be an integer or an array of integers, but received ${JSON.stringify(this.axis)}`);this.epsilon=e.epsilon==null?.001:e.epsilon,this.center=e.center==null?!0:e.center,this.scale=e.scale==null?!0:e.scale,this.betaInitializer=ft(e.betaInitializer||"zeros"),this.gammaInitializer=ft(e.gammaInitializer||"ones"),this.betaRegularizer=pt(e.betaRegularizer),this.gammaRegularizer=pt(e.gammaRegularizer),this.supportsMasking=!0}build(e){e=Pe(e);const n=e.length;typeof this.axis=="number"&&(this.axis=[this.axis]);for(let o=0;o=n)throw new Error(`Invalid axis: ${o}`);if(this.axis.length!==To(this.axis).length)throw new Error(`Found duplicate axes in: ${this.axis}`);const s=this.axis.map(o=>e[o]),r=!0;this.scale?this.gamma=this.addWeight("gamma",s,"float32",this.gammaInitializer,this.gammaRegularizer,r):this.gamma=null,this.center?this.beta=this.addWeight("beta",s,"float32",this.betaInitializer,this.betaRegularizer,r):this.beta=null,this.built=!0}call(e,n){const s=Ce(e),r=s.shape,o=r.length;return P(()=>{let{mean:a,variance:l}=Ky(s,this.axis,!0);const c=Li(1,o);for(const g of this.axis)c[g]=r[g];const u=g=>g!=null&&g.shape.length!==o?F(g,c):g;let d=this.scale?u(this.gamma.read()):null,h=this.center?u(this.beta.read()):null;const f=[],p=[];for(let g=0;g{const o=Ky(t,s),i=o.mean,a=o.variance;return[Jc(t,i,a,n,e,r),i,a]})}function yH(t,e,n,s,r=.001){return P(()=>{const o=Ky(t,s),i=o.mean,a=o.variance,l=[];for(const p of Js(0,t.rank))s.indexOf(p)!==-1?l.push(1):l.push(t.shape[p]);const c=F(i,l),u=F(a,l),h=e==null?null:F(e,l),d=n==null?null:F(n,l);return[Jc(t,c,u,d,h,r),i,a]})}function wH(t,e,n,s,r=.001){return Ue(s.slice().sort(),Js(0,t.rank-1))?xH(t,e,n,s,r):yH(t,e,n,s,r)}class nR extends Ae{constructor(e){e==null&&(e={}),super(e),this.supportsMasking=!0,this.axis=e.axis==null?-1:e.axis,this.momentum=e.momentum==null?.99:e.momentum,this.epsilon=e.epsilon==null?.001:e.epsilon,this.center=e.center==null?!0:e.center,this.scale=e.scale==null?!0:e.scale,this.betaInitializer=ft(e.betaInitializer||"zeros"),this.gammaInitializer=ft(e.gammaInitializer||"ones"),this.movingMeanInitializer=ft(e.movingMeanInitializer||"zeros"),this.movingVarianceInitializer=ft(e.movingVarianceInitializer||"ones"),this.betaConstraint=Bt(e.betaConstraint),this.gammaConstraint=Bt(e.gammaConstraint),this.betaRegularizer=pt(e.betaRegularizer),this.gammaRegularizer=pt(e.gammaRegularizer)}build(e){e=Pe(e);const n=this.axis>=0?this.axis:this.axis+e.length,s=e[n];if(s==null)throw new E(`Axis ${n} of input tensor should have a defined dimension but the layer received an input with shape ${JSON.stringify(e)}.`);this.inputSpec=[new Pt({ndim:e.length,axes:{[n]:s}})];const r=[s];this.scale&&(this.gamma=this.addWeight("gamma",r,null,this.gammaInitializer,this.gammaRegularizer,!0,this.gammaConstraint)),this.center&&(this.beta=this.addWeight("beta",r,null,this.betaInitializer,this.betaRegularizer,!0,this.betaConstraint)),this.movingMean=this.addWeight("moving_mean",r,null,this.movingMeanInitializer,null,!1),this.movingVariance=this.addWeight("moving_variance",r,null,this.movingVarianceInitializer,null,!1),this.built=!0}call(e,n){return P(()=>{const s=n.training==null?!1:n.training,r=Ce(e),o=r.shape,i=o.length,a=Js(0,i),l=this.axis>=0?this.axis:this.axis+i;a.splice(l,1);const c=Li(1,i);c[l]=o[l];const u=a.slice();u.sort();const h=!Ue(u,Js(0,i).slice(0,i-1)),d=()=>{if(h){const y=F(this.movingMean.read(),c),w=F(this.movingVariance.read(),c),v=this.center?F(this.beta.read(),c):null,b=this.scale?F(this.gamma.read(),c):null;return Jc(r,y,w,v,b,this.epsilon)}else return Jc(r,this.movingMean.read(),this.movingVariance.read(),this.beta==null?null:this.beta.read(),this.gamma==null?null:this.gamma.read(),this.epsilon)};if(!s)return d();const[f,p,g]=wH(r,this.gamma.read(),this.beta.read(),a,this.epsilon),x=(y,w,v)=>{P(()=>{const b=1-v,C=y.read(),k=D(ve(C,w),b);y.write(ve(C,k))})};return(()=>{x(this.movingMean,p,this.momentum),x(this.movingVariance,g,this.momentum)})(),f})}getConfig(){const e={axis:this.axis,momentum:this.momentum,epsilon:this.epsilon,center:this.center,scale:this.scale,betaInitializer:xt(this.betaInitializer),gammaInitializer:xt(this.gammaInitializer),movingMeanInitializer:xt(this.movingMeanInitializer),movingVarianceInitializer:xt(this.movingVarianceInitializer),betaRegularizer:Je(this.betaRegularizer),gammaRegularizer:Je(this.gammaRegularizer),betaConstraint:Lt(this.betaConstraint),gammaConstraint:Lt(this.gammaConstraint)},n=super.getConfig();return Object.assign(e,n),e}}nR.className="BatchNormalization";Y(nR);class sR extends Ae{constructor(e){if(e==null&&(e={}),super(e),this.axis=e.axis==null?-1:e.axis,typeof this.axis=="number"){if(!Number.isInteger(this.axis))throw new Error(`Expected axis to be an integer, but received ${this.axis}`)}else if(Array.isArray(this.axis)){for(const n of this.axis)if(!Number.isInteger(n))throw new Error(`Expected axis to be an array of integers, but received ${JSON.stringify(this.axis)}`)}else throw new Error(`Expected axis to be an integer or an array of integers, but received ${JSON.stringify(this.axis)}`);this.epsilon=e.epsilon==null?.001:e.epsilon,this.center=e.center==null?!0:e.center,this.scale=e.scale==null?!0:e.scale,this.betaInitializer=ft(e.betaInitializer||"zeros"),this.gammaInitializer=ft(e.gammaInitializer||"ones"),this.betaRegularizer=pt(e.betaRegularizer),this.gammaRegularizer=pt(e.gammaRegularizer),this.supportsMasking=!0}build(e){e=Pe(e);const n=e.length;typeof this.axis=="number"&&(this.axis=[this.axis]);for(let o=0;o=n)throw new Error(`Invalid axis: ${o}`);if(this.axis.length!==To(this.axis).length)throw new Error(`Found duplicate axes in: ${this.axis}`);const s=this.axis.map(o=>e[o]),r=!0;this.scale?this.gamma=this.addWeight("gamma",s,"float32",this.gammaInitializer,this.gammaRegularizer,r):this.gamma=null,this.center?this.beta=this.addWeight("beta",s,"float32",this.betaInitializer,this.betaRegularizer,r):this.beta=null,this.built=!0}call(e,n){const s=Ce(e),r=s.shape,o=r.length;return P(()=>{let{mean:a,variance:l}=Ky(s,this.axis,!0);const c=Li(1,o);for(const g of this.axis)c[g]=r[g];const u=g=>g!=null&&g.shape.length!==o?F(g,c):g;let h=this.scale?u(this.gamma.read()):null,d=this.center?u(this.beta.read()):null;const f=[],p=[];for(let g=0;g{if(t.rank!==4)throw new E(`temporalPadding expects input tensor to be 4-D, but received a ${t.rank}-D tensor.`);if(e==null&&(e=[[1,1],[1,1]]),e.length!==2||e[0].length!==2||e[1].length!==2)throw new E("spatial2dPadding expects `padding` to be an Array of two Arrays, each of which is an Array of two integers.");if(n==null&&(n=Js()),n!=="channelsLast"&&n!=="channelsFirst")throw new E(`Unknown data format: ${n}. Supported data formats are 'channelsLast' and 'channelsFirst.`);let s;return n==="channelsFirst"?s=[[0,0],[0,0],e[0],e[1]]:s=[[0,0],e[0],e[1],[0,0]],Xy(t,s)})}class sR extends Ae{constructor(e){if(e==null&&(e={}),super(e),this.dataFormat=e.dataFormat==null?Js():e.dataFormat,e.padding==null)this.padding=[[1,1],[1,1]];else if(typeof e.padding=="number")this.padding=[[e.padding,e.padding],[e.padding,e.padding]];else{if(e.padding=e.padding,e.padding.length!==2)throw new E(`ZeroPadding2D expects padding to be a length-2 array, but received a length-${e.padding.length} array.`);let n,s;if(typeof e.padding[0]=="number")n=[e.padding[0],e.padding[0]],s=[e.padding[1],e.padding[1]];else{if(e.padding=e.padding,e.padding[0].length!==2)throw new E(`ZeroPadding2D expects height padding to be a length-2 array, but received a length-${e.padding[0].length} array.`);if(n=e.padding[0],e.padding[1].length!==2)throw new E(`ZeroPadding2D expects width padding to be a length-2 array, but received a length-${e.padding[1].length} array.`);s=e.padding[1]}this.padding=[n,s]}this.inputSpec=[new Pt({ndim:4})]}computeOutputShape(e){e=Pe(e);let n,s;return this.dataFormat==="channelsFirst"?(e[2]!=null&&e[2]>=0?n=e[2]+this.padding[0][0]+this.padding[0][1]:n=null,e[3]!=null&&e[3]>=0?s=e[3]+this.padding[1][0]+this.padding[1][1]:s=null,[e[0],e[1],n,s]):(e[1]!=null&&e[1]>=0?n=e[1]+this.padding[0][0]+this.padding[0][1]:n=null,e[2]!=null&&e[2]>=0?s=e[2]+this.padding[1][0]+this.padding[1][1]:s=null,[e[0],n,s,e[3]])}call(e,n){return P(()=>wH(Ce(e),this.padding,this.dataFormat))}getConfig(){const e={padding:this.padding,dataFormat:this.dataFormat},n=super.getConfig();return Object.assign(e,n),e}}sR.className="ZeroPadding2D";Y(sR);/** + */function vH(t,e,n){return P(()=>{if(t.rank!==4)throw new E(`temporalPadding expects input tensor to be 4-D, but received a ${t.rank}-D tensor.`);if(e==null&&(e=[[1,1],[1,1]]),e.length!==2||e[0].length!==2||e[1].length!==2)throw new E("spatial2dPadding expects `padding` to be an Array of two Arrays, each of which is an Array of two integers.");if(n==null&&(n=er()),n!=="channelsLast"&&n!=="channelsFirst")throw new E(`Unknown data format: ${n}. Supported data formats are 'channelsLast' and 'channelsFirst.`);let s;return n==="channelsFirst"?s=[[0,0],[0,0],e[0],e[1]]:s=[[0,0],e[0],e[1],[0,0]],Xy(t,s)})}class rR extends Ae{constructor(e){if(e==null&&(e={}),super(e),this.dataFormat=e.dataFormat==null?er():e.dataFormat,e.padding==null)this.padding=[[1,1],[1,1]];else if(typeof e.padding=="number")this.padding=[[e.padding,e.padding],[e.padding,e.padding]];else{if(e.padding=e.padding,e.padding.length!==2)throw new E(`ZeroPadding2D expects padding to be a length-2 array, but received a length-${e.padding.length} array.`);let n,s;if(typeof e.padding[0]=="number")n=[e.padding[0],e.padding[0]],s=[e.padding[1],e.padding[1]];else{if(e.padding=e.padding,e.padding[0].length!==2)throw new E(`ZeroPadding2D expects height padding to be a length-2 array, but received a length-${e.padding[0].length} array.`);if(n=e.padding[0],e.padding[1].length!==2)throw new E(`ZeroPadding2D expects width padding to be a length-2 array, but received a length-${e.padding[1].length} array.`);s=e.padding[1]}this.padding=[n,s]}this.inputSpec=[new Pt({ndim:4})]}computeOutputShape(e){e=Pe(e);let n,s;return this.dataFormat==="channelsFirst"?(e[2]!=null&&e[2]>=0?n=e[2]+this.padding[0][0]+this.padding[0][1]:n=null,e[3]!=null&&e[3]>=0?s=e[3]+this.padding[1][0]+this.padding[1][1]:s=null,[e[0],e[1],n,s]):(e[1]!=null&&e[1]>=0?n=e[1]+this.padding[0][0]+this.padding[0][1]:n=null,e[2]!=null&&e[2]>=0?s=e[2]+this.padding[1][0]+this.padding[1][1]:s=null,[e[0],n,s,e[3]])}call(e,n){return P(()=>vH(Ce(e),this.padding,this.dataFormat))}getConfig(){const e={padding:this.padding,dataFormat:this.dataFormat},n=super.getConfig();return Object.assign(e,n),e}}rR.className="ZeroPadding2D";Y(rR);/** * @license * Copyright 2018 Google LLC * @@ -7945,7 +7945,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */function Fm(t,e,n,s,r,o){return P(()=>{Nt(r),wT(o),ds(s),n==null&&(n=[1,1]),s==null&&(s="valid"),r==null&&(r=Js()),o==null&&(o="max"),t=ov(t,r);let i;const a=s==="same"?"same":"valid";return o==="max"?i=jy(t,e,n,a):i=Oy(t,e,n,a),r==="channelsFirst"&&(i=Fe(i,[0,3,1,2])),i})}function rR(t,e,n,s,r,o){return P(()=>{Nt(r),wT(o),ds(s),n==null&&(n=[1,1,1]),s==null&&(s="valid"),r==null&&(r=Js()),o==null&&(o="max"),t=bE(t,r);let i;const a=s==="same"?"same":"valid";return o==="max"?i=NB(t,e,n,a):i=EL(t,e,n,a),r==="channelsFirst"&&(i=Fe(i,[0,4,1,2,3])),i})}class oR extends Ae{constructor(e){if(e.poolSize==null&&(e.poolSize=2),super(e),typeof e.poolSize=="number")this.poolSize=[e.poolSize];else if(Array.isArray(e.poolSize)&&e.poolSize.length===1&&typeof e.poolSize[0]=="number")this.poolSize=e.poolSize;else throw new E(`poolSize for 1D convolutional layer must be a number or an Array of a single number, but received ${JSON.stringify(e.poolSize)}`);if(qt(this.poolSize,"poolSize"),e.strides==null)this.strides=this.poolSize;else if(typeof e.strides=="number")this.strides=[e.strides];else if(Array.isArray(e.strides)&&e.strides.length===1&&typeof e.strides[0]=="number")this.strides=e.strides;else throw new E(`strides for 1D convolutional layer must be a number or an Array of a single number, but received ${JSON.stringify(e.strides)}`);qt(this.strides,"strides"),this.padding=e.padding==null?"valid":e.padding,ds(this.padding),this.inputSpec=[new Pt({ndim:3})]}computeOutputShape(e){e=Pe(e);const n=Ys(e[1],this.poolSize[0],this.padding,this.strides[0]);return[e[0],n,e[2]]}call(e,n){return P(()=>{this.invokeCallHook(e,n),e=vd(Ce(e),2);const s=this.poolingFunction(Ce(e),[this.poolSize[0],1],[this.strides[0],1],this.padding,"channelsLast");return pd(s,[2])})}getConfig(){const e={poolSize:this.poolSize,padding:this.padding,strides:this.strides},n=super.getConfig();return Object.assign(e,n),e}}class iR extends oR{constructor(e){super(e)}poolingFunction(e,n,s,r,o){return Nt(o),ds(r),Fm(e,n,s,r,o,"max")}}iR.className="MaxPooling1D";Y(iR);class aR extends oR{constructor(e){super(e)}poolingFunction(e,n,s,r,o){return Nt(o),ds(r),Fm(e,n,s,r,o,"avg")}}aR.className="AveragePooling1D";Y(aR);class lR extends Ae{constructor(e){if(e.poolSize==null&&(e.poolSize=[2,2]),super(e),this.poolSize=Array.isArray(e.poolSize)?e.poolSize:[e.poolSize,e.poolSize],e.strides==null)this.strides=this.poolSize;else if(Array.isArray(e.strides)){if(e.strides.length!==2)throw new E(`If the strides property of a 2D pooling layer is an Array, it is expected to have a length of 2, but received length ${e.strides.length}.`);this.strides=e.strides}else this.strides=[e.strides,e.strides];qt(this.poolSize,"poolSize"),qt(this.strides,"strides"),this.padding=e.padding==null?"valid":e.padding,this.dataFormat=e.dataFormat==null?"channelsLast":e.dataFormat,Nt(this.dataFormat),ds(this.padding),this.inputSpec=[new Pt({ndim:4})]}computeOutputShape(e){e=Pe(e);let n=this.dataFormat==="channelsFirst"?e[2]:e[1],s=this.dataFormat==="channelsFirst"?e[3]:e[2];return n=Ys(n,this.poolSize[0],this.padding,this.strides[0]),s=Ys(s,this.poolSize[1],this.padding,this.strides[1]),this.dataFormat==="channelsFirst"?[e[0],e[1],n,s]:[e[0],n,s,e[3]]}call(e,n){return P(()=>(this.invokeCallHook(e,n),this.poolingFunction(Ce(e),this.poolSize,this.strides,this.padding,this.dataFormat)))}getConfig(){const e={poolSize:this.poolSize,padding:this.padding,strides:this.strides,dataFormat:this.dataFormat},n=super.getConfig();return Object.assign(e,n),e}}class cR extends lR{constructor(e){super(e)}poolingFunction(e,n,s,r,o){return Nt(o),ds(r),Fm(e,n,s,r,o,"max")}}cR.className="MaxPooling2D";Y(cR);class uR extends lR{constructor(e){super(e)}poolingFunction(e,n,s,r,o){return Nt(o),ds(r),Fm(e,n,s,r,o,"avg")}}uR.className="AveragePooling2D";Y(uR);class dR extends Ae{constructor(e){if(e.poolSize==null&&(e.poolSize=[2,2,2]),super(e),this.poolSize=Array.isArray(e.poolSize)?e.poolSize:[e.poolSize,e.poolSize,e.poolSize],e.strides==null)this.strides=this.poolSize;else if(Array.isArray(e.strides)){if(e.strides.length!==3)throw new E(`If the strides property of a 3D pooling layer is an Array, it is expected to have a length of 3, but received length ${e.strides.length}.`);this.strides=e.strides}else this.strides=[e.strides,e.strides,e.strides];qt(this.poolSize,"poolSize"),qt(this.strides,"strides"),this.padding=e.padding==null?"valid":e.padding,this.dataFormat=e.dataFormat==null?"channelsLast":e.dataFormat,Nt(this.dataFormat),ds(this.padding),this.inputSpec=[new Pt({ndim:5})]}computeOutputShape(e){e=Pe(e);let n=this.dataFormat==="channelsFirst"?e[2]:e[1],s=this.dataFormat==="channelsFirst"?e[3]:e[2],r=this.dataFormat==="channelsFirst"?e[4]:e[3];return n=Ys(n,this.poolSize[0],this.padding,this.strides[0]),s=Ys(s,this.poolSize[1],this.padding,this.strides[1]),r=Ys(r,this.poolSize[2],this.padding,this.strides[2]),this.dataFormat==="channelsFirst"?[e[0],e[1],n,s,r]:[e[0],n,s,r,e[4]]}call(e,n){return P(()=>(this.invokeCallHook(e,n),this.poolingFunction(Ce(e),this.poolSize,this.strides,this.padding,this.dataFormat)))}getConfig(){const e={poolSize:this.poolSize,padding:this.padding,strides:this.strides,dataFormat:this.dataFormat},n=super.getConfig();return Object.assign(e,n),e}}class hR extends dR{constructor(e){super(e)}poolingFunction(e,n,s,r,o){return Nt(o),ds(r),rR(e,n,s,r,o,"max")}}hR.className="MaxPooling3D";Y(hR);class fR extends dR{constructor(e){super(e)}poolingFunction(e,n,s,r,o){return Nt(o),ds(r),rR(e,n,s,r,o,"avg")}}fR.className="AveragePooling3D";Y(fR);class pR extends Ae{constructor(e){super(e),this.inputSpec=[new Pt({ndim:3})]}computeOutputShape(e){return[e[0],e[2]]}call(e,n){throw new Ie}}class mR extends pR{constructor(e){super(e||{})}call(e,n){return P(()=>{const s=Ce(e);return Rt(s,1)})}}mR.className="GlobalAveragePooling1D";Y(mR);class gR extends pR{constructor(e){super(e||{})}call(e,n){return P(()=>{const s=Ce(e);return qs(s,1)})}}gR.className="GlobalMaxPooling1D";Y(gR);class xR extends Ae{constructor(e){super(e),this.dataFormat=e.dataFormat==null?"channelsLast":e.dataFormat,Nt(this.dataFormat),this.inputSpec=[new Pt({ndim:4})]}computeOutputShape(e){return e=e,this.dataFormat==="channelsLast"?[e[0],e[3]]:[e[0],e[1]]}call(e,n){throw new Ie}getConfig(){const e={dataFormat:this.dataFormat},n=super.getConfig();return Object.assign(e,n),e}}class yR extends xR{call(e,n){return P(()=>{const s=Ce(e);return this.dataFormat==="channelsLast"?Rt(s,[1,2]):Rt(s,[2,3])})}}yR.className="GlobalAveragePooling2D";Y(yR);class wR extends xR{call(e,n){return P(()=>{const s=Ce(e);return this.dataFormat==="channelsLast"?qs(s,[1,2]):qs(s,[2,3])})}}wR.className="GlobalMaxPooling2D";Y(wR);/** + */function Fm(t,e,n,s,r,o){return P(()=>{Nt(r),vT(o),hs(s),n==null&&(n=[1,1]),s==null&&(s="valid"),r==null&&(r=er()),o==null&&(o="max"),t=ov(t,r);let i;const a=s==="same"?"same":"valid";return o==="max"?i=jy(t,e,n,a):i=Oy(t,e,n,a),r==="channelsFirst"&&(i=Fe(i,[0,3,1,2])),i})}function oR(t,e,n,s,r,o){return P(()=>{Nt(r),vT(o),hs(s),n==null&&(n=[1,1,1]),s==null&&(s="valid"),r==null&&(r=er()),o==null&&(o="max"),t=CE(t,r);let i;const a=s==="same"?"same":"valid";return o==="max"?i=TB(t,e,n,a):i=RL(t,e,n,a),r==="channelsFirst"&&(i=Fe(i,[0,4,1,2,3])),i})}class iR extends Ae{constructor(e){if(e.poolSize==null&&(e.poolSize=2),super(e),typeof e.poolSize=="number")this.poolSize=[e.poolSize];else if(Array.isArray(e.poolSize)&&e.poolSize.length===1&&typeof e.poolSize[0]=="number")this.poolSize=e.poolSize;else throw new E(`poolSize for 1D convolutional layer must be a number or an Array of a single number, but received ${JSON.stringify(e.poolSize)}`);if(qt(this.poolSize,"poolSize"),e.strides==null)this.strides=this.poolSize;else if(typeof e.strides=="number")this.strides=[e.strides];else if(Array.isArray(e.strides)&&e.strides.length===1&&typeof e.strides[0]=="number")this.strides=e.strides;else throw new E(`strides for 1D convolutional layer must be a number or an Array of a single number, but received ${JSON.stringify(e.strides)}`);qt(this.strides,"strides"),this.padding=e.padding==null?"valid":e.padding,hs(this.padding),this.inputSpec=[new Pt({ndim:3})]}computeOutputShape(e){e=Pe(e);const n=Qs(e[1],this.poolSize[0],this.padding,this.strides[0]);return[e[0],n,e[2]]}call(e,n){return P(()=>{this.invokeCallHook(e,n),e=vh(Ce(e),2);const s=this.poolingFunction(Ce(e),[this.poolSize[0],1],[this.strides[0],1],this.padding,"channelsLast");return ph(s,[2])})}getConfig(){const e={poolSize:this.poolSize,padding:this.padding,strides:this.strides},n=super.getConfig();return Object.assign(e,n),e}}class aR extends iR{constructor(e){super(e)}poolingFunction(e,n,s,r,o){return Nt(o),hs(r),Fm(e,n,s,r,o,"max")}}aR.className="MaxPooling1D";Y(aR);class lR extends iR{constructor(e){super(e)}poolingFunction(e,n,s,r,o){return Nt(o),hs(r),Fm(e,n,s,r,o,"avg")}}lR.className="AveragePooling1D";Y(lR);class cR extends Ae{constructor(e){if(e.poolSize==null&&(e.poolSize=[2,2]),super(e),this.poolSize=Array.isArray(e.poolSize)?e.poolSize:[e.poolSize,e.poolSize],e.strides==null)this.strides=this.poolSize;else if(Array.isArray(e.strides)){if(e.strides.length!==2)throw new E(`If the strides property of a 2D pooling layer is an Array, it is expected to have a length of 2, but received length ${e.strides.length}.`);this.strides=e.strides}else this.strides=[e.strides,e.strides];qt(this.poolSize,"poolSize"),qt(this.strides,"strides"),this.padding=e.padding==null?"valid":e.padding,this.dataFormat=e.dataFormat==null?"channelsLast":e.dataFormat,Nt(this.dataFormat),hs(this.padding),this.inputSpec=[new Pt({ndim:4})]}computeOutputShape(e){e=Pe(e);let n=this.dataFormat==="channelsFirst"?e[2]:e[1],s=this.dataFormat==="channelsFirst"?e[3]:e[2];return n=Qs(n,this.poolSize[0],this.padding,this.strides[0]),s=Qs(s,this.poolSize[1],this.padding,this.strides[1]),this.dataFormat==="channelsFirst"?[e[0],e[1],n,s]:[e[0],n,s,e[3]]}call(e,n){return P(()=>(this.invokeCallHook(e,n),this.poolingFunction(Ce(e),this.poolSize,this.strides,this.padding,this.dataFormat)))}getConfig(){const e={poolSize:this.poolSize,padding:this.padding,strides:this.strides,dataFormat:this.dataFormat},n=super.getConfig();return Object.assign(e,n),e}}class uR extends cR{constructor(e){super(e)}poolingFunction(e,n,s,r,o){return Nt(o),hs(r),Fm(e,n,s,r,o,"max")}}uR.className="MaxPooling2D";Y(uR);class hR extends cR{constructor(e){super(e)}poolingFunction(e,n,s,r,o){return Nt(o),hs(r),Fm(e,n,s,r,o,"avg")}}hR.className="AveragePooling2D";Y(hR);class dR extends Ae{constructor(e){if(e.poolSize==null&&(e.poolSize=[2,2,2]),super(e),this.poolSize=Array.isArray(e.poolSize)?e.poolSize:[e.poolSize,e.poolSize,e.poolSize],e.strides==null)this.strides=this.poolSize;else if(Array.isArray(e.strides)){if(e.strides.length!==3)throw new E(`If the strides property of a 3D pooling layer is an Array, it is expected to have a length of 3, but received length ${e.strides.length}.`);this.strides=e.strides}else this.strides=[e.strides,e.strides,e.strides];qt(this.poolSize,"poolSize"),qt(this.strides,"strides"),this.padding=e.padding==null?"valid":e.padding,this.dataFormat=e.dataFormat==null?"channelsLast":e.dataFormat,Nt(this.dataFormat),hs(this.padding),this.inputSpec=[new Pt({ndim:5})]}computeOutputShape(e){e=Pe(e);let n=this.dataFormat==="channelsFirst"?e[2]:e[1],s=this.dataFormat==="channelsFirst"?e[3]:e[2],r=this.dataFormat==="channelsFirst"?e[4]:e[3];return n=Qs(n,this.poolSize[0],this.padding,this.strides[0]),s=Qs(s,this.poolSize[1],this.padding,this.strides[1]),r=Qs(r,this.poolSize[2],this.padding,this.strides[2]),this.dataFormat==="channelsFirst"?[e[0],e[1],n,s,r]:[e[0],n,s,r,e[4]]}call(e,n){return P(()=>(this.invokeCallHook(e,n),this.poolingFunction(Ce(e),this.poolSize,this.strides,this.padding,this.dataFormat)))}getConfig(){const e={poolSize:this.poolSize,padding:this.padding,strides:this.strides,dataFormat:this.dataFormat},n=super.getConfig();return Object.assign(e,n),e}}class fR extends dR{constructor(e){super(e)}poolingFunction(e,n,s,r,o){return Nt(o),hs(r),oR(e,n,s,r,o,"max")}}fR.className="MaxPooling3D";Y(fR);class pR extends dR{constructor(e){super(e)}poolingFunction(e,n,s,r,o){return Nt(o),hs(r),oR(e,n,s,r,o,"avg")}}pR.className="AveragePooling3D";Y(pR);class mR extends Ae{constructor(e){super(e),this.inputSpec=[new Pt({ndim:3})]}computeOutputShape(e){return[e[0],e[2]]}call(e,n){throw new Ie}}class gR extends mR{constructor(e){super(e||{})}call(e,n){return P(()=>{const s=Ce(e);return Rt(s,1)})}}gR.className="GlobalAveragePooling1D";Y(gR);class xR extends mR{constructor(e){super(e||{})}call(e,n){return P(()=>{const s=Ce(e);return Ys(s,1)})}}xR.className="GlobalMaxPooling1D";Y(xR);class yR extends Ae{constructor(e){super(e),this.dataFormat=e.dataFormat==null?"channelsLast":e.dataFormat,Nt(this.dataFormat),this.inputSpec=[new Pt({ndim:4})]}computeOutputShape(e){return e=e,this.dataFormat==="channelsLast"?[e[0],e[3]]:[e[0],e[1]]}call(e,n){throw new Ie}getConfig(){const e={dataFormat:this.dataFormat},n=super.getConfig();return Object.assign(e,n),e}}class wR extends yR{call(e,n){return P(()=>{const s=Ce(e);return this.dataFormat==="channelsLast"?Rt(s,[1,2]):Rt(s,[2,3])})}}wR.className="GlobalAveragePooling2D";Y(wR);class vR extends yR{call(e,n){return P(()=>{const s=Ce(e);return this.dataFormat==="channelsLast"?Ys(s,[1,2]):Ys(s,[2,3])})}}vR.className="GlobalMaxPooling2D";Y(vR);/** * @license * Copyright 2018 Google LLC * @@ -7953,7 +7953,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */class vR extends Ae{constructor(e){super(e),this.layer=e.layer}build(e){this.built=!0}get trainable(){return this.layer!=null?this.layer.trainable:!1}set trainable(e){this.layer!=null&&(this.layer.trainable=e)}get trainableWeights(){return this.layer.trainableWeights}get nonTrainableWeights(){return this.layer.nonTrainableWeights}get updates(){return this.layer._updates}get losses(){return this.layer.losses}getWeights(){return this.layer.getWeights()}setWeights(e){this.layer.setWeights(e)}getConfig(){const e={layer:{className:this.layer.getClassName(),config:this.layer.getConfig()}},n=super.getConfig();return Object.assign(e,n),e}setFastWeightInitDuringBuild(e){super.setFastWeightInitDuringBuild(e),this.layer!=null&&this.layer.setFastWeightInitDuringBuild(e)}static fromConfig(e,n,s={}){const r=n.layer,o=br(r,s);delete n.layer;const i={layer:o};return Object.assign(i,n),new e(i)}}class bR extends vR{constructor(e){super(e),this.supportsMasking=!0}build(e){if(e=Pe(e),e.length<3)throw new E(`TimeDistributed layer expects an input shape >= 3D, but received input shape ${JSON.stringify(e)}`);this.inputSpec=[{shape:e}];const n=[e[0]].concat(e.slice(2));this.layer.built||(this.layer.build(n),this.layer.built=!0),super.build(e)}computeOutputShape(e){e=Pe(e);const n=[e[0]].concat(e.slice(2)),s=this.layer.computeOutputShape(n),r=e[1];return[s[0],r].concat(s.slice(1))}call(e,n){return P(()=>(e=Ce(e),RE((i,a)=>[Ce(this.layer.call(i,n)),[]],e,[],!1,null,null,!1,!0)[1]))}}bR.className="TimeDistributed";Y(bR);function vH(t){Zi(P6,"BidirectionalMergeMode",t)}const bH="concat";class CR extends vR{constructor(e){super(e);const n=e.layer.getConfig(),s={};s.className=e.layer.getClassName(),s.config=n,this.forwardLayer=br(s),n.goBackwards=n.goBackwards!==!0;const r={};if(r.className=e.layer.getClassName(),r.config=n,this.backwardLayer=br(r),this.forwardLayer.name="forward_"+this.forwardLayer.name,this.backwardLayer.name="backward_"+this.backwardLayer.name,this.mergeMode=e.mergeMode===void 0?bH:e.mergeMode,vH(this.mergeMode),e.weights)throw new Ie("weights support is not implemented for Bidirectional layer yet.");this._stateful=e.layer.stateful,this.returnSequences=e.layer.returnSequences,this.returnState=e.layer.returnState,this.supportsMasking=!0,this._trainable=!0,this.inputSpec=e.layer.inputSpec,this.numConstants=null}get trainable(){return this._trainable}set trainable(e){this._trainable=e,this.forwardLayer!=null&&(this.forwardLayer.trainable=e),this.backwardLayer!=null&&(this.backwardLayer.trainable=e)}getWeights(){return this.forwardLayer.getWeights().concat(this.backwardLayer.getWeights())}setWeights(e){const n=e.length,s=Math.floor(n/2);this.forwardLayer.setWeights(e.slice(0,s)),this.backwardLayer.setWeights(e.slice(s))}computeOutputShape(e){let n=this.forwardLayer.computeOutputShape(e);Array.isArray(n)&&Array.isArray(n[0])||(n=[n]),n=n;let s,r,o;return this.returnState&&(o=n.slice(1)),s=n[0],s=s,this.mergeMode==="concat"?(s[s.length-1]*=2,r=[s]):this.mergeMode==null?r=[s,s.slice()]:r=[s],this.returnState?this.mergeMode==null?r.concat(o).concat(o.slice()):[s].concat(o).concat(o.slice()):Rn(r)}apply(e,n){let s=n==null?null:n.initialState,r=n==null?null:n.constants;n==null&&(n={});const o=EE(e,s,r,this.numConstants);if(e=o.inputs,s=o.initialState,r=o.constants,Array.isArray(e)&&(s=e.slice(1),e=e[0]),(s==null||s.length===0)&&r==null)return super.apply(e,n);const i=[],a=[];if(s!=null){const c=s.length;if(c%2>0)throw new E("When passing `initialState` to a Bidrectional RNN, the state should be an Array containing the states of the underlying RNNs.");n.initialState=s,i.push(...s);const u=s.map(d=>new Pt({shape:d.shape}));this.forwardLayer.stateSpec=u.slice(0,c/2),this.backwardLayer.stateSpec=u.slice(c/2),a.push(...u)}if(r!=null)throw new Ie("Support for constants in Bidirectional layers is not implemented yet.");const l=i[0]instanceof Ir;for(const c of i)if(c instanceof Ir!==l)throw new E("The initial state of a Bidirectional layer cannot be specified as a mix of symbolic and non-symbolic tensors");if(l){const c=[e].concat(i),u=this.inputSpec.concat(a),d=this.inputSpec;this.inputSpec=u;const h=super.apply(c,n);return this.inputSpec=d,h}else return super.apply(e,n)}call(e,n){return P(()=>{const s=n.initialState;let r,o;if(s==null)r=this.forwardLayer.call(e,n),o=this.backwardLayer.call(e,n);else{const l=s.slice(0,s.length/2),c=s.slice(s.length/2);r=this.forwardLayer.call(e,Object.assign(n,{initialState:l})),o=this.backwardLayer.call(e,Object.assign(n,{initialState:c}))}let i;this.returnState&&(Array.isArray(r)&&(i=r.slice(1).concat(o.slice(1))),r=r[0],o=o[0]),this.returnSequences&&(o=Mi(o,1));let a;return this.mergeMode==="concat"?a=jw([r,o]):this.mergeMode==="sum"?a=J(r,o):this.mergeMode==="ave"?a=D(.5,J(r,o)):this.mergeMode==="mul"?a=D(r,o):this.mergeMode==null&&(a=[r,o]),this.returnState?this.mergeMode==null?a.concat(i):[a].concat(i):a})}resetStates(e){this.forwardLayer.resetStates(),this.backwardLayer.resetStates()}build(e){bi(this.forwardLayer.name,()=>{this.forwardLayer.build(e)}),bi(this.backwardLayer.name,()=>{this.backwardLayer.build(e)}),this.built=!0}computeMask(e,n){Array.isArray(n)&&(n=n[0]);let s;if(this.returnSequences?this.mergeMode==null?s=[n,n]:s=n:this.mergeMode==null?s=[null,null]:s=null,this.returnState){const o=this.forwardLayer.states.map(i=>null);return Array.isArray(s)?s.concat(o).concat(o):[s].concat(o).concat(o)}else return s}get trainableWeights(){return this.forwardLayer.trainableWeights.concat(this.backwardLayer.trainableWeights)}get nonTrainableWeights(){return this.forwardLayer.nonTrainableWeights.concat(this.backwardLayer.nonTrainableWeights)}setFastWeightInitDuringBuild(e){super.setFastWeightInitDuringBuild(e),this.forwardLayer!=null&&this.forwardLayer.setFastWeightInitDuringBuild(e),this.backwardLayer!=null&&this.backwardLayer.setFastWeightInitDuringBuild(e)}getConfig(){const e={mergeMode:this.mergeMode},n=super.getConfig();return Object.assign(e,n),e}static fromConfig(e,n){const s=br(n.layer);if(delete n.layer,n.numConstants!=null)throw new Ie("Deserialization of a Bidirectional layer with numConstants present is not supported yet.");const r=n;return r.layer=s,new e(r)}}CR.className="Bidirectional";Y(CR);/** + */class bR extends Ae{constructor(e){super(e),this.layer=e.layer}build(e){this.built=!0}get trainable(){return this.layer!=null?this.layer.trainable:!1}set trainable(e){this.layer!=null&&(this.layer.trainable=e)}get trainableWeights(){return this.layer.trainableWeights}get nonTrainableWeights(){return this.layer.nonTrainableWeights}get updates(){return this.layer._updates}get losses(){return this.layer.losses}getWeights(){return this.layer.getWeights()}setWeights(e){this.layer.setWeights(e)}getConfig(){const e={layer:{className:this.layer.getClassName(),config:this.layer.getConfig()}},n=super.getConfig();return Object.assign(e,n),e}setFastWeightInitDuringBuild(e){super.setFastWeightInitDuringBuild(e),this.layer!=null&&this.layer.setFastWeightInitDuringBuild(e)}static fromConfig(e,n,s={}){const r=n.layer,o=Cr(r,s);delete n.layer;const i={layer:o};return Object.assign(i,n),new e(i)}}class CR extends bR{constructor(e){super(e),this.supportsMasking=!0}build(e){if(e=Pe(e),e.length<3)throw new E(`TimeDistributed layer expects an input shape >= 3D, but received input shape ${JSON.stringify(e)}`);this.inputSpec=[{shape:e}];const n=[e[0]].concat(e.slice(2));this.layer.built||(this.layer.build(n),this.layer.built=!0),super.build(e)}computeOutputShape(e){e=Pe(e);const n=[e[0]].concat(e.slice(2)),s=this.layer.computeOutputShape(n),r=e[1];return[s[0],r].concat(s.slice(1))}call(e,n){return P(()=>(e=Ce(e),AE((i,a)=>[Ce(this.layer.call(i,n)),[]],e,[],!1,null,null,!1,!0)[1]))}}CR.className="TimeDistributed";Y(CR);function bH(t){Zi(L6,"BidirectionalMergeMode",t)}const CH="concat";class kR extends bR{constructor(e){super(e);const n=e.layer.getConfig(),s={};s.className=e.layer.getClassName(),s.config=n,this.forwardLayer=Cr(s),n.goBackwards=n.goBackwards!==!0;const r={};if(r.className=e.layer.getClassName(),r.config=n,this.backwardLayer=Cr(r),this.forwardLayer.name="forward_"+this.forwardLayer.name,this.backwardLayer.name="backward_"+this.backwardLayer.name,this.mergeMode=e.mergeMode===void 0?CH:e.mergeMode,bH(this.mergeMode),e.weights)throw new Ie("weights support is not implemented for Bidirectional layer yet.");this._stateful=e.layer.stateful,this.returnSequences=e.layer.returnSequences,this.returnState=e.layer.returnState,this.supportsMasking=!0,this._trainable=!0,this.inputSpec=e.layer.inputSpec,this.numConstants=null}get trainable(){return this._trainable}set trainable(e){this._trainable=e,this.forwardLayer!=null&&(this.forwardLayer.trainable=e),this.backwardLayer!=null&&(this.backwardLayer.trainable=e)}getWeights(){return this.forwardLayer.getWeights().concat(this.backwardLayer.getWeights())}setWeights(e){const n=e.length,s=Math.floor(n/2);this.forwardLayer.setWeights(e.slice(0,s)),this.backwardLayer.setWeights(e.slice(s))}computeOutputShape(e){let n=this.forwardLayer.computeOutputShape(e);Array.isArray(n)&&Array.isArray(n[0])||(n=[n]),n=n;let s,r,o;return this.returnState&&(o=n.slice(1)),s=n[0],s=s,this.mergeMode==="concat"?(s[s.length-1]*=2,r=[s]):this.mergeMode==null?r=[s,s.slice()]:r=[s],this.returnState?this.mergeMode==null?r.concat(o).concat(o.slice()):[s].concat(o).concat(o.slice()):Rn(r)}apply(e,n){let s=n==null?null:n.initialState,r=n==null?null:n.constants;n==null&&(n={});const o=RE(e,s,r,this.numConstants);if(e=o.inputs,s=o.initialState,r=o.constants,Array.isArray(e)&&(s=e.slice(1),e=e[0]),(s==null||s.length===0)&&r==null)return super.apply(e,n);const i=[],a=[];if(s!=null){const c=s.length;if(c%2>0)throw new E("When passing `initialState` to a Bidrectional RNN, the state should be an Array containing the states of the underlying RNNs.");n.initialState=s,i.push(...s);const u=s.map(h=>new Pt({shape:h.shape}));this.forwardLayer.stateSpec=u.slice(0,c/2),this.backwardLayer.stateSpec=u.slice(c/2),a.push(...u)}if(r!=null)throw new Ie("Support for constants in Bidirectional layers is not implemented yet.");const l=i[0]instanceof $r;for(const c of i)if(c instanceof $r!==l)throw new E("The initial state of a Bidirectional layer cannot be specified as a mix of symbolic and non-symbolic tensors");if(l){const c=[e].concat(i),u=this.inputSpec.concat(a),h=this.inputSpec;this.inputSpec=u;const d=super.apply(c,n);return this.inputSpec=h,d}else return super.apply(e,n)}call(e,n){return P(()=>{const s=n.initialState;let r,o;if(s==null)r=this.forwardLayer.call(e,n),o=this.backwardLayer.call(e,n);else{const l=s.slice(0,s.length/2),c=s.slice(s.length/2);r=this.forwardLayer.call(e,Object.assign(n,{initialState:l})),o=this.backwardLayer.call(e,Object.assign(n,{initialState:c}))}let i;this.returnState&&(Array.isArray(r)&&(i=r.slice(1).concat(o.slice(1))),r=r[0],o=o[0]),this.returnSequences&&(o=Mi(o,1));let a;return this.mergeMode==="concat"?a=jw([r,o]):this.mergeMode==="sum"?a=J(r,o):this.mergeMode==="ave"?a=D(.5,J(r,o)):this.mergeMode==="mul"?a=D(r,o):this.mergeMode==null&&(a=[r,o]),this.returnState?this.mergeMode==null?a.concat(i):[a].concat(i):a})}resetStates(e){this.forwardLayer.resetStates(),this.backwardLayer.resetStates()}build(e){bi(this.forwardLayer.name,()=>{this.forwardLayer.build(e)}),bi(this.backwardLayer.name,()=>{this.backwardLayer.build(e)}),this.built=!0}computeMask(e,n){Array.isArray(n)&&(n=n[0]);let s;if(this.returnSequences?this.mergeMode==null?s=[n,n]:s=n:this.mergeMode==null?s=[null,null]:s=null,this.returnState){const o=this.forwardLayer.states.map(i=>null);return Array.isArray(s)?s.concat(o).concat(o):[s].concat(o).concat(o)}else return s}get trainableWeights(){return this.forwardLayer.trainableWeights.concat(this.backwardLayer.trainableWeights)}get nonTrainableWeights(){return this.forwardLayer.nonTrainableWeights.concat(this.backwardLayer.nonTrainableWeights)}setFastWeightInitDuringBuild(e){super.setFastWeightInitDuringBuild(e),this.forwardLayer!=null&&this.forwardLayer.setFastWeightInitDuringBuild(e),this.backwardLayer!=null&&this.backwardLayer.setFastWeightInitDuringBuild(e)}getConfig(){const e={mergeMode:this.mergeMode},n=super.getConfig();return Object.assign(e,n),e}static fromConfig(e,n){const s=Cr(n.layer);if(delete n.layer,n.numConstants!=null)throw new Ie("Deserialization of a Bidirectional layer with numConstants present is not supported yet.");const r=n;return r.layer=s,new e(r)}}kR.className="Bidirectional";Y(kR);/** * @license * Copyright 2022 CodeSmith LLC * @@ -7961,7 +7961,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */class kR extends Ae{constructor(e){super(e),this.scale=e.scale,e.offset?this.offset=e.offset:this.offset=0}getConfig(){const e={scale:this.scale,offset:this.offset},n=super.getConfig();return Object.assign(e,n),e}call(e,n){return P(()=>(e=Ce(e),e.dtype!=="float32"&&(e=wr(e,"float32")),J(D(e,this.scale),this.offset)))}}kR.className="Rescaling";Y(kR);/** + */class SR extends Ae{constructor(e){super(e),this.scale=e.scale,e.offset?this.offset=e.offset:this.offset=0}getConfig(){const e={scale:this.scale,offset:this.offset},n=super.getConfig();return Object.assign(e,n),e}call(e,n){return P(()=>(e=Ce(e),e.dtype!=="float32"&&(e=vr(e,"float32")),J(D(e,this.scale),this.offset)))}}SR.className="Rescaling";Y(SR);/** * @license * Copyright 2022 CodeSmith LLC * @@ -7969,7 +7969,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */const{resizeBilinear:CH,cropAndResize:kH}=Or;class SR extends Ae{constructor(e){super(e),this.height=e.height,this.width=e.width}centerCrop(e,n,s,r,o,i,a,l){return P(()=>{let c,u=!1;const d=n/i,h=s/a,f=(r+n)/i,p=(o+s)/a,g=[d,h,f,p],x=[];e.rank===3?(u=!0,c=Gr([e])):c=e;for(let b=0;b{const o=CH(e,[n,s]);return wr(o,r)})}call(e,n){return P(()=>{const s=Ce(e),r=s.dtype,o=s.shape,i=o[o.length-3],a=o[o.length-2];let l=0;i!==this.height&&(l=Math.floor((i-this.height)/2));let c=0;return a!==this.width&&(c=Math.floor((a-this.width)/2),c===0&&(c=1)),l>=0&&c>=0?this.centerCrop(s,l,c,this.height,this.width,i,a,r):this.upsize(e,this.height,this.width,r)})}getConfig(){const e={height:this.height,width:this.width},n=super.getConfig();return Object.assign(e,n),e}computeOutputShape(e){e=Pe(e);const n=e.length-3,s=e.length-2;return e[n]=this.height,e[s]=this.width,e}}SR.className="CenterCrop";Y(SR);/** + */const{resizeBilinear:kH,cropAndResize:SH}=Mr;class IR extends Ae{constructor(e){super(e),this.height=e.height,this.width=e.width}centerCrop(e,n,s,r,o,i,a,l){return P(()=>{let c,u=!1;const h=n/i,d=s/a,f=(r+n)/i,p=(o+s)/a,g=[h,d,f,p],x=[];e.rank===3?(u=!0,c=Hr([e])):c=e;for(let b=0;b{const o=kH(e,[n,s]);return vr(o,r)})}call(e,n){return P(()=>{const s=Ce(e),r=s.dtype,o=s.shape,i=o[o.length-3],a=o[o.length-2];let l=0;i!==this.height&&(l=Math.floor((i-this.height)/2));let c=0;return a!==this.width&&(c=Math.floor((a-this.width)/2),c===0&&(c=1)),l>=0&&c>=0?this.centerCrop(s,l,c,this.height,this.width,i,a,r):this.upsize(e,this.height,this.width,r)})}getConfig(){const e={height:this.height,width:this.width},n=super.getConfig();return Object.assign(e,n),e}computeOutputShape(e){e=Pe(e);const n=e.length-3,s=e.length-2;return e[n]=this.height,e[s]=this.width,e}}IR.className="CenterCrop";Y(IR);/** * @license * Copyright 2022 CodeSmith LLC * @@ -7977,7 +7977,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */function SH(t,e,n,s){let r=Ce(t);if(r.dtype!=="int32"&&(r=wr(r,"int32")),e==="int")return r;const o=r.shape;if(r.rank===0&&(r=En(r,-1)),e==="oneHot"&&r.shape[r.shape.length-1]!==1&&(r=En(r,-1)),r.rank>2)throw new E(`When outputMode is not int, maximum output rank is 2 Received outputMode ${e} and input shape ${o} which would result in output rank ${r.rank}.`);const i=["multiHot","oneHot"].includes(e),a=r;let l;if(typeof s<"u"&&e==="count"?l=RC(a,s,n,i):l=RC(a,[],n,i),e!=="tfIdf")return l;if(s)return D(l,s);throw new E("When outputMode is 'tfIdf', weights must be provided.")}/** + */function IH(t,e,n,s){let r=Ce(t);if(r.dtype!=="int32"&&(r=vr(r,"int32")),e==="int")return r;const o=r.shape;if(r.rank===0&&(r=En(r,-1)),e==="oneHot"&&r.shape[r.shape.length-1]!==1&&(r=En(r,-1)),r.rank>2)throw new E(`When outputMode is not int, maximum output rank is 2 Received outputMode ${e} and input shape ${o} which would result in output rank ${r.rank}.`);const i=["multiHot","oneHot"].includes(e),a=r;let l;if(typeof s<"u"&&e==="count"?l=RC(a,s,n,i):l=RC(a,[],n,i),e!=="tfIdf")return l;if(s)return D(l,s);throw new E("When outputMode is 'tfIdf', weights must be provided.")}/** * @license * Copyright 2022 CodeSmith LLC * @@ -7985,8 +7985,8 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */class IR extends Ae{constructor(e){super(e),this.numTokens=e.numTokens,e.outputMode?this.outputMode=e.outputMode:this.outputMode="multiHot"}getConfig(){const e={numTokens:this.numTokens,outputMode:this.outputMode},n=super.getConfig();return Object.assign(e,n),e}computeOutputShape(e){return e=Pe(e),e==null?[this.numTokens]:this.outputMode==="oneHot"&&e[e.length-1]!==1?(e.push(this.numTokens),e):(e[e.length-1]=this.numTokens,e)}call(e,n){return P(()=>{e=Ce(e),e.dtype!=="int32"&&(e=wr(e,"int32"));let s;if(typeof n.countWeights<"u"){if(this.outputMode!=="count")throw new E(`countWeights is not used when outputMode !== count. - Received countWeights=${n.countWeights}`);s=Ce(n.countWeights)}const r=qs(e),o=wf(e),i=us(this.numTokens,r).bufferSync().get(0),a=Xi(o,0).bufferSync().get(0);if(!(i&&a))throw new E(`Input values must be between 0 < values <= numTokens with numTokens=${this.numTokens}`);return SH(e,this.outputMode,this.numTokens,s)})}}IR.className="CategoryEncoding";Y(IR);/** + */class $R extends Ae{constructor(e){super(e),this.numTokens=e.numTokens,e.outputMode?this.outputMode=e.outputMode:this.outputMode="multiHot"}getConfig(){const e={numTokens:this.numTokens,outputMode:this.outputMode},n=super.getConfig();return Object.assign(e,n),e}computeOutputShape(e){return e=Pe(e),e==null?[this.numTokens]:this.outputMode==="oneHot"&&e[e.length-1]!==1?(e.push(this.numTokens),e):(e[e.length-1]=this.numTokens,e)}call(e,n){return P(()=>{e=Ce(e),e.dtype!=="int32"&&(e=vr(e,"int32"));let s;if(typeof n.countWeights<"u"){if(this.outputMode!=="count")throw new E(`countWeights is not used when outputMode !== count. + Received countWeights=${n.countWeights}`);s=Ce(n.countWeights)}const r=Ys(e),o=wf(e),i=us(this.numTokens,r).bufferSync().get(0),a=Xi(o,0).bufferSync().get(0);if(!(i&&a))throw new E(`Input values must be between 0 < values <= numTokens with numTokens=${this.numTokens}`);return IH(e,this.outputMode,this.numTokens,s)})}}$R.className="CategoryEncoding";Y($R);/** * @license * Copyright 2022 CodeSmith LLC * @@ -7994,7 +7994,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */const IH=["bilinear","nearest"],dk=new Set(IH);class $R extends Ae{constructor(e){if(super(e),this.height=e.height,this.width=e.width,e.interpolation)if(dk.has(e.interpolation))this.interpolation=e.interpolation;else throw new E(`Invalid interpolation parameter: ${e.interpolation} is not implemented`);else this.interpolation="bilinear";this.cropToAspectRatio=!!e.cropToAspectRatio}computeOutputShape(e){e=Pe(e);const n=e[2];return[this.height,this.width,n]}getConfig(){const e={height:this.height,width:this.width,interpolation:this.interpolation,cropToAspectRatio:this.cropToAspectRatio},n=super.getConfig();return Object.assign(e,n),e}call(e,n){return P(()=>{const s=[this.height,this.width];if(this.interpolation==="bilinear")return Or.resizeBilinear(e,s,!this.cropToAspectRatio);if(this.interpolation==="nearest")return Or.resizeNearestNeighbor(e,s,!this.cropToAspectRatio);throw new Error(`Interpolation is ${this.interpolation} but only ${[...dk]} are supported`)})}}$R.className="Resizing";Y($R);/** + */const $H=["bilinear","nearest"],hk=new Set($H);class NR extends Ae{constructor(e){if(super(e),this.height=e.height,this.width=e.width,e.interpolation)if(hk.has(e.interpolation))this.interpolation=e.interpolation;else throw new E(`Invalid interpolation parameter: ${e.interpolation} is not implemented`);else this.interpolation="bilinear";this.cropToAspectRatio=!!e.cropToAspectRatio}computeOutputShape(e){e=Pe(e);const n=e[2];return[this.height,this.width,n]}getConfig(){const e={height:this.height,width:this.width,interpolation:this.interpolation,cropToAspectRatio:this.cropToAspectRatio},n=super.getConfig();return Object.assign(e,n),e}call(e,n){return P(()=>{const s=[this.height,this.width];if(this.interpolation==="bilinear")return Mr.resizeBilinear(e,s,!this.cropToAspectRatio);if(this.interpolation==="nearest")return Mr.resizeNearestNeighbor(e,s,!this.cropToAspectRatio);throw new Error(`Interpolation is ${this.interpolation} but only ${[...hk]} are supported`)})}}NR.className="Resizing";Y(NR);/** * @license * Copyright 2023 CodeSmith LLC * @@ -8002,7 +8002,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */class NR{constructor(e){this.seed=e}next(){if(this.seed!==void 0)return this.seed++}}NR.className="RandomSeed";/** + */class TR{constructor(e){this.seed=e}next(){if(this.seed!==void 0)return this.seed++}}TR.className="RandomSeed";/** * @license * Copyright 2023 CodeSmith LLC * @@ -8010,7 +8010,7 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */class TR extends Ae{constructor(e){super(e),this.randomGenerator=new NR(e.seed)}getConfig(){const e={seed:this.randomGenerator.seed},n=super.getConfig();return Object.assign(e,n),e}}TR.className="BaseRandomLayer";/** + */class ER extends Ae{constructor(e){super(e),this.randomGenerator=new TR(e.seed)}getConfig(){const e={seed:this.randomGenerator.seed},n=super.getConfig();return Object.assign(e,n),e}}ER.className="BaseRandomLayer";/** * @license * Copyright 2023 CodeSmith LLC * @@ -8018,11 +8018,11 @@ body { * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= - */const $H=["bilinear","nearest"],hk=new Set($H);class ER extends TR{constructor(e){super(e);const{factor:n,interpolation:s="bilinear"}=e;if(this.factor=n,Array.isArray(this.factor)&&this.factor.length===2)this.widthLower=this.factor[0],this.widthUpper=this.factor[1];else if(!Array.isArray(this.factor)&&this.factor>0)this.widthLower=-this.factor,this.widthUpper=this.factor;else throw new E(`Invalid factor: ${this.factor}. Must be positive number or tuple of 2 numbers`);if(this.widthLower<-1||this.widthUpper<-1)throw new E(`factor must have values larger than -1. Got: ${this.factor}`);if(this.widthUpper0)this.widthLower=-this.factor,this.widthUpper=this.factor;else throw new E(`Invalid factor: ${this.factor}. Must be positive number or tuple of 2 numbers`);if(this.widthLower<-1||this.widthUpper<-1)throw new E(`factor must have values larger than -1. Got: ${this.factor}`);if(this.widthUpper{const s=Ce(e);this.imgHeight=s.shape[s.shape.length-3];const r=s.shape[s.shape.length-2];this.widthFactor=fd([1],1+this.widthLower,1+this.widthUpper,"float32",this.randomGenerator.next());let o=this.widthFactor.dataSync()[0]*r;o=Math.round(o);const i=[this.imgHeight,o];switch(this.interpolation){case"bilinear":return Or.resizeBilinear(e,i);case"nearest":return Or.resizeNearestNeighbor(e,i);default:throw new Error(`Interpolation is ${this.interpolation} - but only ${[...hk]} are supported`)}})}}ER.className="RandomWidth";Y(ER);/** + `);if(s)if(dk.has(s))this.interpolation=s;else throw new E(`Invalid interpolation parameter: ${s} is not implemented`)}getConfig(){const e={factor:this.factor,interpolation:this.interpolation},n=super.getConfig();return Object.assign(e,n),e}computeOutputShape(e){e=Pe(e);const n=e[2];return[this.imgHeight,-1,n]}call(e,n){return P(()=>{const s=Ce(e);this.imgHeight=s.shape[s.shape.length-3];const r=s.shape[s.shape.length-2];this.widthFactor=fh([1],1+this.widthLower,1+this.widthUpper,"float32",this.randomGenerator.next());let o=this.widthFactor.dataSync()[0]*r;o=Math.round(o);const i=[this.imgHeight,o];switch(this.interpolation){case"bilinear":return Mr.resizeBilinear(e,i);case"nearest":return Mr.resizeNearestNeighbor(e,i);default:throw new Error(`Interpolation is ${this.interpolation} + but only ${[...dk]} are supported`)}})}}RR.className="RandomWidth";Y(RR);/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8037,7 +8037,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const NH=W();NH.registerFlag("KEEP_INTERMEDIATE_TENSORS",()=>!1,t=>{t&&console.warn("Keep intermediate tensors is ON. This will print the values of all intermediate tensors during model inference. Not all models support this mode. For details, check e2e/benchmarks/ model_config.js. This significantly impacts performance.")});/** + */const TH=W();TH.registerFlag("KEEP_INTERMEDIATE_TENSORS",()=>!1,t=>{t&&console.warn("Keep intermediate tensors is ON. This will print the values of all intermediate tensors during model inference. Not all models support this mode. For details, check e2e/benchmarks/ model_config.js. This significantly impacts performance.")});/** * @license * Copyright 2019 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8084,7 +8084,7 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function he(t,e){Array.isArray(t)||(t=[t]),t.forEach(n=>{n!=null&&I(n.dtype!=="complex64",()=>`${e} does not support complex64 tensors in the CPU backend.`)})}/** + */function de(t,e){Array.isArray(t)||(t=[t]),t.forEach(n=>{n!=null&&I(n.dtype!=="complex64",()=>`${e} does not support complex64 tensors in the CPU backend.`)})}/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8099,10 +8099,10 @@ body { * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const TH=kN;class zm extends Mx{nextDataId(){return zm.nextDataId++}constructor(){super(),this.blockSize=48,this.firstUse=!0,this.data=new H2(this,or())}write(e,n,s){this.firstUse&&(this.firstUse=!1,W().get("IS_NODE")&&es(` + */const EH=SN;class zm extends Mx{nextDataId(){return zm.nextDataId++}constructor(){super(),this.blockSize=48,this.firstUse=!0,this.data=new jI(this,ir())}write(e,n,s){this.firstUse&&(this.firstUse=!1,W().get("IS_NODE")&&es(` ============================ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dramatically, install our node backend, visit https://github.com/tensorflow/tfjs-node for more details. -============================`));const r={id:this.nextDataId()};return this.data.set(r,{values:e,dtype:s,refCount:1}),r}makeTensorInfo(e,n,s){let r;if(n==="string"&&s!=null&&s.length>0&&fu(s[0])){const o=s.map(i=>No(i));r=this.write(o,e,n)}else r=this.write(s,e,n);return{dataId:r,shape:e,dtype:n}}refCount(e){return this.data.has(e)?this.data.get(e).refCount:0}incRef(e){const n=this.data.get(e);n.refCount++}decRef(e){if(this.data.has(e)){const n=this.data.get(e);n.refCount--}}move(e,n,s,r,o){this.data.set(e,{values:n,dtype:r,refCount:o})}numDataIds(){return this.data.numDataIds()}async read(e){return this.readSync(e)}readSync(e){const{dtype:n,complexTensorInfos:s}=this.data.get(e);if(n==="complex64"){const r=this.readSync(s.real.dataId),o=this.readSync(s.imag.dataId);return Hr(r,o)}return _M(this.data.get(e).values,n)}bufferSync(e){const n=this.readSync(e.dataId);if(e.dtype==="string")try{const s=n.map(r=>Do(r));return Ee(e.shape,e.dtype,s)}catch{throw new Error("Failed to decode encoded string bytes into utf-8")}return Ee(e.shape,e.dtype,n)}makeOutput(e,n,s){return or().makeTensorFromTensorInfo(this.makeTensorInfo(n,s,e),this)}disposeData(e,n=!1){if(this.data.has(e)){if(this.data.get(e).refCount--,!n&&this.data.get(e).refCount>0)return!1;const{complexTensorInfos:s}=this.data.get(e);s!=null&&(this.disposeData(s.real.dataId,!0),this.disposeData(s.imag.dataId,!0)),this.data.delete(e)}return!0}disposeIntermediateTensorInfo(e){this.disposeData(e.dataId)}async time(e){const n=Tn();return e(),{kernelMs:Tn()-n}}memory(){return{unreliable:!0,reasons:["The reported memory is an upper bound. Due to automatic garbage collection, the true allocated memory may be less."]}}where(e){he([e],"where");const n=this.readSync(e.dataId);return TH(e.shape,n)}dispose(){}floatPrecision(){return 32}epsilon(){return super.epsilon()}}zm.nextDataId=0;/** +============================`));const r={id:this.nextDataId()};return this.data.set(r,{values:e,dtype:s,refCount:1}),r}makeTensorInfo(e,n,s){let r;if(n==="string"&&s!=null&&s.length>0&&fu(s[0])){const o=s.map(i=>No(i));r=this.write(o,e,n)}else r=this.write(s,e,n);return{dataId:r,shape:e,dtype:n}}refCount(e){return this.data.has(e)?this.data.get(e).refCount:0}incRef(e){const n=this.data.get(e);n.refCount++}decRef(e){if(this.data.has(e)){const n=this.data.get(e);n.refCount--}}move(e,n,s,r,o){this.data.set(e,{values:n,dtype:r,refCount:o})}numDataIds(){return this.data.numDataIds()}async read(e){return this.readSync(e)}readSync(e){const{dtype:n,complexTensorInfos:s}=this.data.get(e);if(n==="complex64"){const r=this.readSync(s.real.dataId),o=this.readSync(s.imag.dataId);return jr(r,o)}return FM(this.data.get(e).values,n)}bufferSync(e){const n=this.readSync(e.dataId);if(e.dtype==="string")try{const s=n.map(r=>Do(r));return Ee(e.shape,e.dtype,s)}catch{throw new Error("Failed to decode encoded string bytes into utf-8")}return Ee(e.shape,e.dtype,n)}makeOutput(e,n,s){return ir().makeTensorFromTensorInfo(this.makeTensorInfo(n,s,e),this)}disposeData(e,n=!1){if(this.data.has(e)){if(this.data.get(e).refCount--,!n&&this.data.get(e).refCount>0)return!1;const{complexTensorInfos:s}=this.data.get(e);s!=null&&(this.disposeData(s.real.dataId,!0),this.disposeData(s.imag.dataId,!0)),this.data.delete(e)}return!0}disposeIntermediateTensorInfo(e){this.disposeData(e.dataId)}async time(e){const n=Tn();return e(),{kernelMs:Tn()-n}}memory(){return{unreliable:!0,reasons:["The reported memory is an upper bound. Due to automatic garbage collection, the true allocated memory may be less."]}}where(e){de([e],"where");const n=this.readSync(e.dataId);return EH(e.shape,n)}dispose(){}floatPrecision(){return 32}epsilon(){return super.epsilon()}}zm.nextDataId=0;/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -8117,7 +8117,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function RR(t){const e=new Float32Array(t.length);for(let n=0;n{const{x:e}=t.inputs,n=t.backend;he(e,"abs");let s=new Float32Array(j(e.shape));const r=n.data.get(e.dataId).values;return s=RR(r),n.makeOutput(s,e.shape,e.dtype)},RH={kernelName:pp,backendName:"cpu",kernelFunc:EH};/** + */function AR(t){const e=new Float32Array(t.length);for(let n=0;n{const{x:e}=t.inputs,n=t.backend;de(e,"abs");let s=new Float32Array(j(e.shape));const r=n.data.get(e.dataId).values;return s=AR(r),n.makeOutput(s,e.shape,e.dtype)},AH={kernelName:pp,backendName:"cpu",kernelFunc:RH};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8132,7 +8132,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Tt(t){return(e,n,s,r,o)=>{const i=Se(e,n),a=i.length,l=pe(i),c=j(i),u=cn(o,c),d=e.length,h=n.length,f=pe(e),p=pe(n),g=il(e,i),x=il(n,i);if(g.length+x.length===0)for(let m=0;mw[k]=0);const v=gr(w,d,f),b=y.slice(-h);x.forEach(k=>b[k]=0);const C=gr(b,h,p);u[m]=t(s[v],r[C])}return[u,i]}}/** + */function Tt(t){return(e,n,s,r,o)=>{const i=Se(e,n),a=i.length,l=pe(i),c=j(i),u=cn(o,c),h=e.length,d=n.length,f=pe(e),p=pe(n),g=il(e,i),x=il(n,i);if(g.length+x.length===0)for(let m=0;mw[k]=0);const v=xr(w,h,f),b=y.slice(-d);x.forEach(k=>b[k]=0);const C=xr(b,d,p);u[m]=t(s[v],r[C])}return[u,i]}}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8147,7 +8147,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Vn(t){const{inputs:e,backend:n}=t,{real:s,imag:r}=e,o=n.data.get(s.dataId).values,i=n.data.get(r.dataId).values,a=n.makeTensorInfo(s.shape,"complex64"),l=n.data.get(a.dataId);return l.complexTensorInfos={real:n.makeTensorInfo(s.shape,"float32",o),imag:n.makeTensorInfo(r.shape,"float32",i)},a}const AH={kernelName:Qx,backendName:"cpu",kernelFunc:Vn};/** + */function Vn(t){const{inputs:e,backend:n}=t,{real:s,imag:r}=e,o=n.data.get(s.dataId).values,i=n.data.get(r.dataId).values,a=n.makeTensorInfo(s.shape,"complex64"),l=n.data.get(a.dataId);return l.complexTensorInfos={real:n.makeTensorInfo(s.shape,"float32",o),imag:n.makeTensorInfo(r.shape,"float32",i)},a}const DH={kernelName:Qx,backendName:"cpu",kernelFunc:Vn};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8177,7 +8177,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function $r(t){const{inputs:e,backend:n}=t,{x:s}=e;return n.incRef(s.dataId),{dataId:s.dataId,shape:s.shape,dtype:s.dtype}}const DH={kernelName:Fu,backendName:"cpu",kernelFunc:$r};/** + */function Nr(t){const{inputs:e,backend:n}=t,{x:s}=e;return n.incRef(s.dataId),{dataId:s.dataId,shape:s.shape,dtype:s.dtype}}const _H={kernelName:Fu,backendName:"cpu",kernelFunc:Nr};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8192,7 +8192,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Bi(t){const{inputs:e,backend:n}=t,{input:s}=e,r=n.data.get(s.dataId).complexTensorInfos.real,o=n.data.get(r.dataId).values;return n.makeTensorInfo(r.shape,r.dtype,o)}const _H={kernelName:by,backendName:"cpu",kernelFunc:Bi};/** + */function Bi(t){const{inputs:e,backend:n}=t,{input:s}=e,r=n.data.get(s.dataId).complexTensorInfos.real,o=n.data.get(r.dataId).values;return n.makeTensorInfo(r.shape,r.dtype,o)}const FH={kernelName:by,backendName:"cpu",kernelFunc:Bi};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8207,7 +8207,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function AR(t,e,n,s){if(s==="int32"){const r=Int32Array.from(t);return[e,"int32",r]}if(s==="bool"){const r=Ki([0],n),[o,i]=Tt((a,l)=>a!==l?1:0)(e,[],t,r,"bool");return[i,"bool",o]}throw new Error(`Error in Cast: failed to cast ${n} to ${s}`)}function Mo(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{dtype:o}=s;if(o==="complex64"){if(r.dtype==="complex64")return $r({inputs:{x:r},backend:n});const u=Ff(n,r.shape,r.dtype),d=Mo({inputs:{x:r},backend:n,attrs:{dtype:"float32"}}),h=Vn({inputs:{real:d,imag:u},backend:n});return n.disposeIntermediateTensorInfo(u),n.disposeIntermediateTensorInfo(d),h}if(r.dtype==="complex64"){const u=Bi({inputs:{input:r},backend:n}),d=Mo({inputs:{x:u},backend:n,attrs:{dtype:o}});return n.disposeIntermediateTensorInfo(u),d}if(!K2(r.dtype,o)){const u=$r({inputs:{x:r},backend:n});return{dataId:u.dataId,shape:u.shape,dtype:o}}const i=n.data.get(r.dataId).values,[a,l,c]=AR(i,r.shape,r.dtype,o);return n.makeTensorInfo(a,l,c)}const FH={kernelName:bu,backendName:"cpu",kernelFunc:Mo};/** + */function DR(t,e,n,s){if(s==="int32"){const r=Int32Array.from(t);return[e,"int32",r]}if(s==="bool"){const r=Ki([0],n),[o,i]=Tt((a,l)=>a!==l?1:0)(e,[],t,r,"bool");return[i,"bool",o]}throw new Error(`Error in Cast: failed to cast ${n} to ${s}`)}function Mo(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{dtype:o}=s;if(o==="complex64"){if(r.dtype==="complex64")return Nr({inputs:{x:r},backend:n});const u=Ff(n,r.shape,r.dtype),h=Mo({inputs:{x:r},backend:n,attrs:{dtype:"float32"}}),d=Vn({inputs:{real:h,imag:u},backend:n});return n.disposeIntermediateTensorInfo(u),n.disposeIntermediateTensorInfo(h),d}if(r.dtype==="complex64"){const u=Bi({inputs:{input:r},backend:n}),h=Mo({inputs:{x:u},backend:n,attrs:{dtype:o}});return n.disposeIntermediateTensorInfo(u),h}if(!XI(r.dtype,o)){const u=Nr({inputs:{x:r},backend:n});return{dataId:u.dataId,shape:u.shape,dtype:o}}const i=n.data.get(r.dataId).values,[a,l,c]=DR(i,r.shape,r.dtype,o);return n.makeTensorInfo(a,l,c)}const zH={kernelName:bu,backendName:"cpu",kernelFunc:Mo};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8222,7 +8222,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Wt(t,e,n,s){return n==null?({inputs:r,backend:o})=>{const{a:i,b:a}=r,l=o;he([i,a],t);const c=l.data.get(i.dataId).values,u=l.data.get(a.dataId).values,d=i.dtype==="string"?jr(c):c,h=i.dtype==="string"?jr(u):u,f=s||i.dtype,[p,g]=e(i.shape,a.shape,d,h,f);return l.makeTensorInfo(g,f,p)}:({inputs:r,backend:o})=>{const{a:i,b:a}=r,l=o;if(i.dtype==="complex64"||a.dtype==="complex64"){const c=Mo({inputs:{x:i},backend:l,attrs:{dtype:"complex64"}}),u=l.data.get(c.dataId),d=u.complexTensorInfos.real,h=u.complexTensorInfos.imag,f=l.data.get(d.dataId).values,p=l.data.get(h.dataId).values,g=Mo({inputs:{x:a},backend:l,attrs:{dtype:"complex64"}}),x=l.data.get(g.dataId),m=x.complexTensorInfos.real,y=x.complexTensorInfos.imag,w=l.data.get(m.dataId).values,v=l.data.get(y.dataId).values,[b,C,k]=n(i.shape,a.shape,f,p,w,v),S=l.makeTensorInfo(k,"float32",b),$=l.makeTensorInfo(k,"float32",C),N=Vn({inputs:{real:S,imag:$},backend:l});return l.disposeIntermediateTensorInfo(c),l.disposeIntermediateTensorInfo(g),l.disposeIntermediateTensorInfo(S),l.disposeIntermediateTensorInfo($),N}else{const c=l.data.get(i.dataId).values,u=l.data.get(a.dataId).values,d=s||i.dtype,[h,f]=e(i.shape,a.shape,c,u,d);return l.makeTensorInfo(f,d,h)}}}function dv(t){return(e,n,s,r,o,i)=>{const a=Se(e,n),l=j(a),c=a.length,u=pe(a),d=cn("float32",l),h=cn("float32",l),f=il(e,a),p=il(n,a),g=Hr(s,r),x=Hr(o,i),m=e.length,y=pe(e),w=n.length,v=pe(n);if(f.length+p.length===0)for(let b=0;bk[M]=0);const S=gr(k,m,y),$=C.slice(-w);p.forEach(M=>$[M]=0);const N=gr($,w,v),A=t(g[S*2],g[S*2+1],x[N*2],x[N*2+1]);d[b]=A.real,h[b]=A.imag}return[d,h,a]}}/** + */function Wt(t,e,n,s){return n==null?({inputs:r,backend:o})=>{const{a:i,b:a}=r,l=o;de([i,a],t);const c=l.data.get(i.dataId).values,u=l.data.get(a.dataId).values,h=i.dtype==="string"?Kr(c):c,d=i.dtype==="string"?Kr(u):u,f=s||i.dtype,[p,g]=e(i.shape,a.shape,h,d,f);return l.makeTensorInfo(g,f,p)}:({inputs:r,backend:o})=>{const{a:i,b:a}=r,l=o;if(i.dtype==="complex64"||a.dtype==="complex64"){const c=Mo({inputs:{x:i},backend:l,attrs:{dtype:"complex64"}}),u=l.data.get(c.dataId),h=u.complexTensorInfos.real,d=u.complexTensorInfos.imag,f=l.data.get(h.dataId).values,p=l.data.get(d.dataId).values,g=Mo({inputs:{x:a},backend:l,attrs:{dtype:"complex64"}}),x=l.data.get(g.dataId),m=x.complexTensorInfos.real,y=x.complexTensorInfos.imag,w=l.data.get(m.dataId).values,v=l.data.get(y.dataId).values,[b,C,k]=n(i.shape,a.shape,f,p,w,v),S=l.makeTensorInfo(k,"float32",b),$=l.makeTensorInfo(k,"float32",C),N=Vn({inputs:{real:S,imag:$},backend:l});return l.disposeIntermediateTensorInfo(c),l.disposeIntermediateTensorInfo(g),l.disposeIntermediateTensorInfo(S),l.disposeIntermediateTensorInfo($),N}else{const c=l.data.get(i.dataId).values,u=l.data.get(a.dataId).values,h=s||i.dtype,[d,f]=e(i.shape,a.shape,c,u,h);return l.makeTensorInfo(f,h,d)}}}function hv(t){return(e,n,s,r,o,i)=>{const a=Se(e,n),l=j(a),c=a.length,u=pe(a),h=cn("float32",l),d=cn("float32",l),f=il(e,a),p=il(n,a),g=jr(s,r),x=jr(o,i),m=e.length,y=pe(e),w=n.length,v=pe(n);if(f.length+p.length===0)for(let b=0;bk[M]=0);const S=xr(k,m,y),$=C.slice(-w);p.forEach(M=>$[M]=0);const N=xr($,w,v),A=t(g[S*2],g[S*2+1],x[N*2],x[N*2+1]);h[b]=A.real,d[b]=A.imag}return[h,d,a]}}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8237,7 +8237,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const DR=Tt((t,e)=>t+e),zH=dv((t,e,n,s)=>({real:t+n,imag:e+s})),cl=Wt(bl,DR,zH),OH={kernelName:bl,backendName:"cpu",kernelFunc:cl};/** + */const _R=Tt((t,e)=>t+e),OH=hv((t,e,n,s)=>({real:t+n,imag:e+s})),cl=Wt(bl,_R,OH),MH={kernelName:bl,backendName:"cpu",kernelFunc:cl};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8252,7 +8252,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function hv(t,e,n,s,r){const o=j(s),i=un(r,n);for(let a=0;a=r||(o>0?i[l]+=e[a]:i[l]+=1)}return i}function _R(t,e,n,s=!1){const r=t.shape[0],o=t.shape[1],i=Ee([r,n],e.dtype);for(let a=0;a=n||(s?i.set(1,a,c):e.size>0?i.set(i.get(a,c)+e.get(a,l),a,c):i.set(i.get(a,c)+1,a,c))}return i}/** + */function dv(t,e,n,s,r){const o=j(s),i=un(r,n);for(let a=0;a=r||(o>0?i[l]+=e[a]:i[l]+=1)}return i}function FR(t,e,n,s=!1){const r=t.shape[0],o=t.shape[1],i=Ee([r,n],e.dtype);for(let a=0;a=n||(s?i.set(1,a,c):e.size>0?i.set(i.get(a,c)+e.get(a,l),a,c):i.set(i.get(a,c)+1,a,c))}return i}/** * @license * Copyright 2023 Google LLC. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8267,7 +8267,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const FR=Tt((t,e)=>t&e),MH=Wt(Yx,FR),PH={kernelName:Yx,backendName:"cpu",kernelFunc:MH};/** + */const zR=Tt((t,e)=>t&e),PH=Wt(Yx,zR),LH={kernelName:Yx,backendName:"cpu",kernelFunc:PH};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8282,7 +8282,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Nr(t){return(e,n,s)=>{const r=kt(n,e.length);for(let o=0;o{const r=kt(n,e.length);for(let o=0;o{const{x:i}=s;he(i,t);const a=o,l=a.data.get(i.dataId).values;let c;if(i.dtype==="string"){if(!Array.isArray(l))throw new Error("String tensor's value was not an instance of Array");c=jr(l)}else c=l;const u=n||i.dtype,d=e(c,u,r);return a.makeTensorInfo(i.shape,u,d)}}/** + */function Xe(t,e,n){const s=Tr(e);return Yo(t,s,n)}function Yo(t,e,n){return({inputs:s,attrs:r,backend:o})=>{const{x:i}=s;de(i,t);const a=o,l=a.data.get(i.dataId).values;let c;if(i.dtype==="string"){if(!Array.isArray(l))throw new Error("String tensor's value was not an instance of Array");c=Kr(l)}else c=l;const u=n||i.dtype,h=e(c,u,r);return a.makeTensorInfo(i.shape,u,h)}}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -8312,7 +8312,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const zR=Nr(t=>Math.ceil(t)),LH=Yo(Cu,zR),BH={kernelName:Cu,backendName:"cpu",kernelFunc:LH};/** + */const OR=Tr(t=>Math.ceil(t)),BH=Yo(Cu,OR),VH={kernelName:Cu,backendName:"cpu",kernelFunc:BH};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8327,7 +8327,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function OR(t,e,n,s){const r=kt(n,j(e));if(s&&n!=="string"){let o=0;t.forEach(i=>{const a=j(i.shape);r.set(i.vals,o),o+=a})}else{let o=0;t.forEach(i=>{const a=n==="string"?jr(i.vals):i.vals;let l=0;for(let c=0;c{const a=j(i.shape);r.set(i.vals,o),o+=a})}else{let o=0;t.forEach(i=>{const a=n==="string"?Kr(i.vals):i.vals;let l=0;for(let c=0;ct===e?1:0),PR=Wt(Ep,MR,null,"bool"),VH={kernelName:Ep,backendName:"cpu",kernelFunc:PR};/** + */const PR=Tt((t,e)=>t===e?1:0),LR=Wt(Ep,PR,null,"bool"),WH={kernelName:Ep,backendName:"cpu",kernelFunc:LR};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -8357,7 +8357,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const LR=Nr(t=>Math.exp(t)),BR=Yo(Eu,LR,"float32"),WH={kernelName:Eu,backendName:"cpu",kernelFunc:BR};/** + */const BR=Tr(t=>Math.exp(t)),VR=Yo(Eu,BR,"float32"),UH={kernelName:Eu,backendName:"cpu",kernelFunc:VR};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -8372,7 +8372,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const VR=Nr(t=>Math.expm1(t)),UH=Yo(Ru,VR),GH={kernelName:Ru,backendName:"cpu",kernelFunc:UH};/** + */const WR=Tr(t=>Math.expm1(t)),GH=Yo(Ru,WR),HH={kernelName:Ru,backendName:"cpu",kernelFunc:GH};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -8387,7 +8387,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const WR=Nr(t=>Math.floor(t)),HH=Yo(Au,WR),jH={kernelName:Au,backendName:"cpu",kernelFunc:HH};/** + */const UR=Tr(t=>Math.floor(t)),jH=Yo(Au,UR),KH={kernelName:Au,backendName:"cpu",kernelFunc:jH};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8402,7 +8402,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const UR=Tt((t,e)=>Math.floor(t/e)),KH=Wt(Du,UR,null,"int32"),XH={kernelName:Du,backendName:"cpu",kernelFunc:KH};/** + */const GR=Tt((t,e)=>Math.floor(t/e)),XH=Wt(Du,GR,null,"int32"),qH={kernelName:Du,backendName:"cpu",kernelFunc:XH};/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8417,7 +8417,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function GR(t,e,n,s,r,o,i,a,l){const c=Ee([s,o],n);for(let u=0;u=l/o)throw new Error(`Invalid indices: ${d} does not index into ${a}`);for(let f=0;f=l/o)throw new Error(`Invalid indices: ${h} does not index into ${a}`);for(let f=0;ft>e?1:0),qH=Wt(_p,jR,null,"bool"),YH={kernelName:_p,backendName:"cpu",kernelFunc:qH};/** + */const KR=Tt((t,e)=>t>e?1:0),YH=Wt(_p,KR,null,"bool"),QH={kernelName:_p,backendName:"cpu",kernelFunc:YH};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8462,7 +8462,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const KR=Tt((t,e)=>t>=e?1:0),QH=Wt(_u,KR,null,"bool"),ZH={kernelName:_u,backendName:"cpu",kernelFunc:QH};/** + */const XR=Tt((t,e)=>t>=e?1:0),ZH=Wt(_u,XR,null,"bool"),JH={kernelName:_u,backendName:"cpu",kernelFunc:ZH};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8477,7 +8477,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const XR=Tt((t,e)=>ttt<=e?1:0),tj=Wt(Op,qR,null,"bool"),nj={kernelName:Op,backendName:"cpu",kernelFunc:tj};/** + */const YR=Tt((t,e)=>t<=e?1:0),nj=Wt(Op,YR,null,"bool"),sj={kernelName:Op,backendName:"cpu",kernelFunc:nj};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8507,7 +8507,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function YR(t,e,n){const s=(e-t)/(n-1),r=un(n,"float32");r[0]=t;for(let o=1;oMath.log(t)),sj=Yo(Pu,QR),rj={kernelName:Pu,backendName:"cpu",kernelFunc:sj};/** + */const ZR=Tr(t=>Math.log(t)),rj=Yo(Pu,ZR),oj={kernelName:Pu,backendName:"cpu",kernelFunc:rj};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8537,7 +8537,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function ZR(t,e,n,s){const r=cn(s,j(n));for(let o=0;oa)&&(a=c)}r[o]=a}return r}/** + */function JR(t,e,n,s){const r=cn(s,j(n));for(let o=0;oa)&&(a=c)}r[o]=a}return r}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8552,7 +8552,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const JR=Tt((t,e)=>Math.max(t,e)),oj=Wt(Bu,JR),ij={kernelName:Bu,backendName:"cpu",kernelFunc:oj};/** + */const eA=Tt((t,e)=>Math.max(t,e)),ij=Wt(Bu,eA),aj={kernelName:Bu,backendName:"cpu",kernelFunc:ij};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8567,7 +8567,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const eA=Tt((t,e)=>Math.min(t,e)),aj=Wt(Vu,eA),lj={kernelName:Vu,backendName:"cpu",kernelFunc:aj};/** + */const tA=Tt((t,e)=>Math.min(t,e)),lj=Wt(Vu,tA),cj={kernelName:Vu,backendName:"cpu",kernelFunc:lj};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8582,7 +8582,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const fv=Tt((t,e)=>t*e),cj=dv((t,e,n,s)=>({real:t*n-e*s,imag:t*s+e*n})),Om=Wt(Uu,fv,cj),uj={kernelName:Uu,backendName:"cpu",kernelFunc:Om};/** + */const fv=Tt((t,e)=>t*e),uj=hv((t,e,n,s)=>({real:t*n-e*s,imag:t*s+e*n})),Om=Wt(Uu,fv,uj),hj={kernelName:Uu,backendName:"cpu",kernelFunc:Om};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8597,7 +8597,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function tA(t,e,n){const s=Wo(-1,n);return fv([],e,s,t,n)}function dj(t){const{inputs:e,backend:n}=t,{x:s}=e;he(s,"neg");const r=n.data.get(s.dataId).values,[o,i]=tA(r,s.shape,s.dtype);return n.makeTensorInfo(i,s.dtype,o)}const hj={kernelName:Kp,backendName:"cpu",kernelFunc:dj};/** + */function nA(t,e,n){const s=Wo(-1,n);return fv([],e,s,t,n)}function dj(t){const{inputs:e,backend:n}=t,{x:s}=e;de(s,"neg");const r=n.data.get(s.dataId).values,[o,i]=nA(r,s.shape,s.dtype);return n.makeTensorInfo(i,s.dtype,o)}const fj={kernelName:Kp,backendName:"cpu",kernelFunc:dj};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8612,7 +8612,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const nA=Tt((t,e)=>t!==e?1:0),fj=Wt(Xp,nA,null,"bool"),pj={kernelName:Xp,backendName:"cpu",kernelFunc:fj};/** + */const sA=Tt((t,e)=>t!==e?1:0),pj=Wt(Xp,sA,null,"bool"),mj={kernelName:Xp,backendName:"cpu",kernelFunc:pj};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8627,7 +8627,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function pv(t,e,n,s,r){const o=e.length,i=j(e),a=pe(e),l=pe(r),c=cn(n,j(r));for(let u=0;un.disposeIntermediateTensorInfo(y)),n.makeTensorInfo(m,x,p)}const xj={kernelName:em,backendName:"cpu",kernelFunc:gj};/** + */function rA(t,e,n,s){const[r,o]=Yt(t,s),i=Xn(e,"int32"),a=un(j(r),i),l=j(o);for(let c=0;cn.disposeIntermediateTensorInfo(y)),n.makeTensorInfo(m,x,p)}const yj={kernelName:em,backendName:"cpu",kernelFunc:xj};/** * @license * Copyright 2022 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8672,7 +8672,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function yj(t,e,n){t.forEach((s,r)=>{if(s<0||s>=n){const o=vl(r,e.length,pe(e)).join(",");throw new Error(`indices[${o}] = ${s} is not in [0, ${n})`)}})}function wj(t,e){for(let n=0;nr)throw new Error("Ragged splits must not point past values");for(let o=1;os[o])throw new Error("Ragged splits must be sorted in ascending order")}}function vj(t,e,n,s){const r=[];let o=0;const i=e.length-1+n.length,a=new Array(i).fill(null).map(()=>[0]);wj(n,s);let l=1;for(let c=0;c=0){const g=a[p],x=g[g.length-1]-f[u];for(let m=u;mr[i]=o)}return e}function gk(t,e){const n=t.slice(0,e);for(;n.length{if(s<0||s>=n){const o=vl(r,e.length,pe(e)).join(",");throw new Error(`indices[${o}] = ${s} is not in [0, ${n})`)}})}function vj(t,e){for(let n=0;nr)throw new Error("Ragged splits must not point past values");for(let o=1;os[o])throw new Error("Ragged splits must be sorted in ascending order")}}function bj(t,e,n,s){const r=[];let o=0;const i=e.length-1+n.length,a=new Array(i).fill(null).map(()=>[0]);vj(n,s);let l=1;for(let c=0;c=0){const g=a[p],x=g[g.length-1]-f[u];for(let m=u;mr[i]=o)}return e}function gk(t,e){const n=t.slice(0,e);for(;n.length1)throw new Error("starts must be a scalar or vector");if(r.length>1)throw new Error("limits must be a scalar or vector");if(i.length>1)throw new Error("deltas must be a scalar or vector");const a=e.length===0,l=r.length===0,c=i.length===0,u=[];a||u.push(e[0]),l||u.push(r[0]),c||u.push(i[0]);for(let x=1;x0&&ym)v=0;else if(v=Math.ceil(Math.abs((y-m)/w)),v>xk)throw new Error(`Requires ((limit - start) / delta) <= ${xk}`);h[x+1]=h[x]+v}const f=h[d],p=kt(n,f);let g=0;for(let x=0;x1)throw new Error("starts must be a scalar or vector");if(r.length>1)throw new Error("limits must be a scalar or vector");if(i.length>1)throw new Error("deltas must be a scalar or vector");const a=e.length===0,l=r.length===0,c=i.length===0,u=[];a||u.push(e[0]),l||u.push(r[0]),c||u.push(i[0]);for(let x=1;x0&&ym)v=0;else if(v=Math.ceil(Math.abs((y-m)/w)),v>xk)throw new Error(`Requires ((limit - start) / delta) <= ${xk}`);d[x+1]=d[x]+v}const f=d[h],p=kt(n,f);let g=0;for(let x=0;xs&&(s=o)}return s}static getMaxWidthValueRowID(e){const n=e.length;if(n===0)return 0;let s=0,r=e[0],o=0;for(let i=1;i"Final length of result must be equal to firstDimension."),o}calculateOutputIndexRowSplit(e,n,s,r){const o=e.length,i=[];for(let a=0;a0&&i.length!==e[o-1])throw new Error("Invalid row split size.");return i}calculateOutputIndexValueRowID(e,n,s,r){const o=e.length,i=[];if(o===0)return[];let a=0,l=e[0];if(l>=n.length)throw new Error(`Got currentValueRowId=${l}, which is not less than ${n.length}`);let c=n[l];i.push(c);for(let u=1;u=0&&(++a,a=n.length)throw new Error(`Got nextValueRowId=${d} which is not less than ${n.length}`);c=n[d]}i.push(c)}if(i.length!==e.length)throw new Error("Invalid row ids.");return i}calculateOutputIndex(e,n,s,r){const o=this.getRowPartitionTensor(e),i=this.getRowPartitionTypeByDimension(e);switch(i){case fs.VALUE_ROWIDS:return this.calculateOutputIndexValueRowID(o,n,s,r);case fs.ROW_SPLITS:if(o.length-1>n.length)throw new Error(`Row partition size is greater than output size: ${o.length-1} > ${n.length}`);return this.calculateOutputIndexRowSplit(o,n,s,r);default:throw new Error(`Unsupported partition type: ${fs[i]}`)}}getFirstDimensionSize(){const e=this.rowPartitionValues[0];if(this.rowPartitionTypes.length===0)throw new Error("No row_partition_types given.");const n=this.rowPartitionTypes[0];switch(n){case fs.FIRST_DIM_SIZE:return e[0];case fs.VALUE_ROWIDS:throw new Error("Cannot handle VALUE_ROWIDS in first dimension.");case fs.ROW_SPLITS:return this.rowPartitionValuesShapes[0][0]-1;default:throw new Error(`Cannot handle type ${fs[n]}`)}}compute(){if(this.rowPartitionValues[0].length<=0)throw new Error("Invalid first partition input. Tensor requires at least one element.");const n=this.getFirstDimensionSize(),s=this.calculateOutputSize(n),r=new Array(this.raggedRank+1);r[r.length-1]=1;for(let l=r.length-2;l>=0;--l)r[l]=r[l+1]*s[l+1];const o=wk(s,!1),i=kt(this.valuesDType,j(o));if(r[0]*s[0]>0){let l=this.calculateFirstParentOutputIndex(n,r[0],s[0]);for(let c=1;c<=this.raggedRank;++c)l=this.calculateOutputIndex(c-1,l,r[c],s[c]);this.setOutput(this.raggedRank,l,i,o)}return[o,i]}setOutput(e,n,s,r){if(s.length===0)return;const o=this.values,i=s;let a=r.slice();a=a.slice(e+1);const l=j(a),c=n.length;let u=this.defaultValue;if(u.length!==l&&u.length!==1){const p=this.defaultValueShape;P(()=>{const g=F(u,p);u=Cc(g,a).dataSync()})}let d=0,h=0,f=0;for(let p=0;p<=c;++p){let g=p=c){const x=s.length;g=Math.floor(x/l)}if(g>f)if(this.defaultValue.length===1)i.subarray(f*l,g*l).fill(this.defaultValue[0]),f=g;else for(;g>f;){const x=i.slice(f*l);yk(x,u,l),++f}g<0?(d=p+1,h=f):(d=p,h=f,f=h+1)}}}function yk(t,e,n){for(let s=0;s= 0`);if(s<-1)throw new Error(`Dimension ${s} must be >= -1`);s=-1}n.push(s)}return n}function iA(t,e,n,s,r,o,i,a,l,c){return new zf(t,e,n,s,r,o,i,a,l,c).compute()}/** + */var fs=Us;class zf{constructor(e,n,s,r,o,i,a,l,c,u){this.shape=e,this.shapeShape=n,this.values=s,this.valuesShape=r,this.valuesDType=o,this.defaultValue=i,this.defaultValueShape=a,this.rowPartitionValues=l,this.rowPartitionValuesShapes=c,this.rowPartitionTypes=HN(u),this.raggedRank=jN(this.rowPartitionTypes)}getRowPartitionTypeByDimension(e){return this.rowPartitionTypes[0]===fs.FIRST_DIM_SIZE?this.rowPartitionTypes[e+1]:this.rowPartitionTypes[e]}getRowPartitionTensor(e){return this.rowPartitionTypes[0]===fs.FIRST_DIM_SIZE?this.rowPartitionValues[e+1]:this.rowPartitionValues[e]}getMaxWidth(e){const n=this.getRowPartitionTensor(e-1);switch(this.getRowPartitionTypeByDimension(e-1)){case fs.VALUE_ROWIDS:return zf.getMaxWidthValueRowID(n);case fs.ROW_SPLITS:return zf.getMaxWidthRowSplit(n);default:throw new Error(`Cannot handle partition type ${fs[this.getRowPartitionTypeByDimension(e-1)]}`)}}static getMaxWidthRowSplit(e){const n=e.length;if(n===0||n===1)return 0;let s=0;for(let r=0;rs&&(s=o)}return s}static getMaxWidthValueRowID(e){const n=e.length;if(n===0)return 0;let s=0,r=e[0],o=0;for(let i=1;i"Final length of result must be equal to firstDimension."),o}calculateOutputIndexRowSplit(e,n,s,r){const o=e.length,i=[];for(let a=0;a0&&i.length!==e[o-1])throw new Error("Invalid row split size.");return i}calculateOutputIndexValueRowID(e,n,s,r){const o=e.length,i=[];if(o===0)return[];let a=0,l=e[0];if(l>=n.length)throw new Error(`Got currentValueRowId=${l}, which is not less than ${n.length}`);let c=n[l];i.push(c);for(let u=1;u=0&&(++a,a=n.length)throw new Error(`Got nextValueRowId=${h} which is not less than ${n.length}`);c=n[h]}i.push(c)}if(i.length!==e.length)throw new Error("Invalid row ids.");return i}calculateOutputIndex(e,n,s,r){const o=this.getRowPartitionTensor(e),i=this.getRowPartitionTypeByDimension(e);switch(i){case fs.VALUE_ROWIDS:return this.calculateOutputIndexValueRowID(o,n,s,r);case fs.ROW_SPLITS:if(o.length-1>n.length)throw new Error(`Row partition size is greater than output size: ${o.length-1} > ${n.length}`);return this.calculateOutputIndexRowSplit(o,n,s,r);default:throw new Error(`Unsupported partition type: ${fs[i]}`)}}getFirstDimensionSize(){const e=this.rowPartitionValues[0];if(this.rowPartitionTypes.length===0)throw new Error("No row_partition_types given.");const n=this.rowPartitionTypes[0];switch(n){case fs.FIRST_DIM_SIZE:return e[0];case fs.VALUE_ROWIDS:throw new Error("Cannot handle VALUE_ROWIDS in first dimension.");case fs.ROW_SPLITS:return this.rowPartitionValuesShapes[0][0]-1;default:throw new Error(`Cannot handle type ${fs[n]}`)}}compute(){if(this.rowPartitionValues[0].length<=0)throw new Error("Invalid first partition input. Tensor requires at least one element.");const n=this.getFirstDimensionSize(),s=this.calculateOutputSize(n),r=new Array(this.raggedRank+1);r[r.length-1]=1;for(let l=r.length-2;l>=0;--l)r[l]=r[l+1]*s[l+1];const o=wk(s,!1),i=kt(this.valuesDType,j(o));if(r[0]*s[0]>0){let l=this.calculateFirstParentOutputIndex(n,r[0],s[0]);for(let c=1;c<=this.raggedRank;++c)l=this.calculateOutputIndex(c-1,l,r[c],s[c]);this.setOutput(this.raggedRank,l,i,o)}return[o,i]}setOutput(e,n,s,r){if(s.length===0)return;const o=this.values,i=s;let a=r.slice();a=a.slice(e+1);const l=j(a),c=n.length;let u=this.defaultValue;if(u.length!==l&&u.length!==1){const p=this.defaultValueShape;P(()=>{const g=F(u,p);u=Cc(g,a).dataSync()})}let h=0,d=0,f=0;for(let p=0;p<=c;++p){let g=p=c){const x=s.length;g=Math.floor(x/l)}if(g>f)if(this.defaultValue.length===1)i.subarray(f*l,g*l).fill(this.defaultValue[0]),f=g;else for(;g>f;){const x=i.slice(f*l);yk(x,u,l),++f}g<0?(h=p+1,d=f):(h=p,d=f,f=d+1)}}}function yk(t,e,n){for(let s=0;s= 0`);if(s<-1)throw new Error(`Dimension ${s} must be >= -1`);s=-1}n.push(s)}return n}function aA(t,e,n,s,r,o,i,a,l,c){return new zf(t,e,n,s,r,o,i,a,l,c).compute()}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8717,7 +8717,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function aA(t,e,n,s){const r=t===e,o=t1;if(r||o||i)return un(0,s);const a=Math.abs(Math.ceil((e-t)/n)),l=un(a,s);e1;if(r||o||i)return un(0,s);const a=Math.abs(Math.ceil((e-t)/n)),l=un(a,s);e1/Math.sqrt(t)),Sj=Yo(qu,lA),Ij={kernelName:qu,backendName:"cpu",kernelFunc:Sj};/** + */const cA=Tr(t=>1/Math.sqrt(t)),Ij=Yo(qu,cA),$j={kernelName:qu,backendName:"cpu",kernelFunc:Ij};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8747,7 +8747,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function pi(t,e,n,s,r,o,i,a,l,c){const u=[s/r,r],d=t.values,h=e.values;if(s===0)return Ee(n,e.dtype);const f=l instanceof tn?l:Ee(u,e.dtype);typeof l=="string"||typeof l=="number"?f.values.fill(l):typeof l=="boolean"&&f.values.fill(+l);for(let p=0;p=s/r)throw new Error(`Invalid indices: ${g} does not index into ${n}`);for(let m=0;m=s/r)throw new Error(`Invalid indices: ${g} does not index into ${n}`);for(let m=0;m1/(1+Math.exp(-t))),cA=Xe(ed,t=>1/(1+Math.exp(-t))),Nj={kernelName:ed,backendName:"cpu",kernelFunc:cA};/** + */const Nj=Tr(t=>1/(1+Math.exp(-t))),uA=Xe(eh,t=>1/(1+Math.exp(-t))),Tj={kernelName:eh,backendName:"cpu",kernelFunc:uA};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8777,7 +8777,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function uA(t,e,n,s,r){const o=bw(s,e,n),i=j(n),a=pe(s);if(o){const d=Cw(e,a);return r==="string"?t.slice(d,d+i):t.subarray(d,d+i)}const l=r==="string"?jr(t):t,c=Ee(s,r,l),u=Ee(n,r);for(let d=0;dp+e[g]);u.set(c.get(...f),...h)}return r==="string"?hT(u.values):u.values}function Vi(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{begin:o,size:i}=s;he(r,"slice");const[a,l]=bm(r,o,i);ww(r,a,l);const c=n.data.get(r.dataId).values,u=uA(c,a,l,r.shape,r.dtype);return n.makeTensorInfo(l,r.dtype,u)}const Tj={kernelName:im,backendName:"cpu",kernelFunc:Vi};/** + */function hA(t,e,n,s,r){const o=bw(s,e,n),i=j(n),a=pe(s);if(o){const h=Cw(e,a);return r==="string"?t.slice(h,h+i):t.subarray(h,h+i)}const l=r==="string"?Kr(t):t,c=Ee(s,r,l),u=Ee(n,r);for(let h=0;hp+e[g]);u.set(c.get(...f),...d)}return r==="string"?fT(u.values):u.values}function Vi(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{begin:o,size:i}=s;de(r,"slice");const[a,l]=bm(r,o,i);ww(r,a,l);const c=n.data.get(r.dataId).values,u=hA(c,a,l,r.shape,r.dtype);return n.makeTensorInfo(l,r.dtype,u)}const Ej={kernelName:im,backendName:"cpu",kernelFunc:Vi};/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8792,7 +8792,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function dA(t,e,n,s,r,o,i){const a=e[0],l=o[0],c=new Array(l),u=new Array(a),d=e[1];if(l===0){if(a!==0)throw new Error(JN(a));const x=kt(n,0),m=kt(r,0);return[x,[0,d],m,c,u]}let h=!0,f=0;const p=new Array(l).fill(0);for(let x=0;x=l)throw new Error(tT(x,m,l));++p[m],h=h&&m>=f,f=m}let g=!0;for(let x=0;x0&&(p[x]+=p[x-1])}if(g&&h){const x=t,m=s;for(let y=0;y=l)throw new Error(nT(x,m,l));++p[m],d=d&&m>=f,f=m}let g=!0;for(let x=0;x0&&(p[x]+=p[x-1])}if(g&&d){const x=t,m=s;for(let y=0;y0){f[h-1]=1;for(let x=h-2;x>=0;--x)f[x]=f[x+1]*s[x+1]}const p=[];if(a>0){p[a-1]=1;for(let x=a-2;x>=0;--x)p[x]=p[x+1]*l[x+1]}const g=kt(n,i*a);for(let x=0;x0){f[d-1]=1;for(let x=d-2;x>=0;--x)f[x]=f[x+1]*s[x+1]}const p=[];if(a>0){p[a-1]=1;for(let x=a-2;x>=0;--x)p[x]=p[x+1]*l[x+1]}const g=kt(n,i*a);for(let x=0;x0?r[a-1]+1:0;if(d<0)throw new Error(m1());const h=e.slice();h[0]=d;const f=h.reduce((w,v)=>w*v,1),p=kt(n,f);if(a===0)return d>0&&p.fill(i),[p,h];if(d<=0)throw new Error(m1());let g=0,x=1,m=0,y=r[g];for(;;){let w=0;if(x=w)throw new Error(aT())}if(y<0||y>=d)throw new Error(lT(y,d));y>m&&p.fill(i,m*c,y*c);for(let v=g;v=l[0])throw new Error(cT(v,s[v],l[0]));for(let C=0;Ca)break}return m0?r[a-1]+1:0;if(h<0)throw new Error(m1());const d=e.slice();d[0]=h;const f=d.reduce((w,v)=>w*v,1),p=kt(n,f);if(a===0)return h>0&&p.fill(i),[p,d];if(h<=0)throw new Error(m1());let g=0,x=1,m=0,y=r[g];for(;;){let w=0;if(x=w)throw new Error(lT())}if(y<0||y>=h)throw new Error(cT(y,h));y>m&&p.fill(i,m*c,y*c);for(let v=g;v=l[0])throw new Error(uT(v,s[v],l[0]));for(let C=0;Ca)break}return mMath.sqrt(t)),Rj=Xe(nd,t=>Math.sqrt(t)),Aj={kernelName:nd,backendName:"cpu",kernelFunc:Rj};/** + */const Rj=Tr(t=>Math.sqrt(t)),Aj=Xe(nh,t=>Math.sqrt(t)),Dj={kernelName:nh,backendName:"cpu",kernelFunc:Aj};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8852,7 +8852,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const fA=Tt((t,e)=>{const n=t-e;return n*n}),Dj=Wt(sd,fA),_j={kernelName:sd,backendName:"cpu",kernelFunc:Dj};/** + */const pA=Tt((t,e)=>{const n=t-e;return n*n}),_j=Wt(sh,pA),Fj={kernelName:sh,backendName:"cpu",kernelFunc:_j};/** * @license * Copyright 2023 Google LLC. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8867,7 +8867,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const pA=Nr((t,e)=>{const{pattern:n,replaceGlobal:s,rewrite:r}=e;return t.replace(new RegExp(n,s?"g":""),r)}),Fj=Yo(Iy,pA),zj={kernelName:Iy,backendName:"cpu",kernelFunc:Fj};/** + */const mA=Tr((t,e)=>{const{pattern:n,replaceGlobal:s,rewrite:r}=e;return t.replace(new RegExp(n,s?"g":""),r)}),zj=Yo(Iy,mA),Oj={kernelName:Iy,backendName:"cpu",kernelFunc:zj};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8882,7 +8882,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function mA(t,e,n,s){const r=Ee(t,e.dtype);for(let o=0;o0?0:a-l);let f=0;f+=c*this.leftPad.length;for(let y=0;yy.forEach(w=>g[x++]=w);for(let y=0;y0){m(e[h+d-1]);for(let y=0;y0){let l=n[0];if(l!==0)throw new Error(`First split value must be 0, got ${l}`);for(let c=1;c=l;if(u=u&&n[c]<=s,!u)throw new Error(`Invalid split value ${n[c]}, must be in [${l}, ${s}]`);l=n[c]}if(l!==s)throw new Error(`Last split value must be data size. Expected ${s}, got ${l}`)}const o=r-1,i=kt("int32",r);if(s===0||r===0){const l=new Array(s);for(let c=0;c<=o;++c)i[c]=0;return[l,i]}i[0]=0;for(let l=1;l<=o;++l){const c=n[l]-n[l-1];let u=0;this.nGramWidths.forEach(d=>{u+=this.getNumNGrams(c,d)}),this.preserveShort&&c>0&&u===0&&(u=1),i[l]=i[l-1]+u}const a=new Array(i[o]);for(let l=0;l{const h=n[l+1]-n[l],f=this.getNumNGrams(h,d);this.createNGrams(e,c,a,u,f,d),u+=f}),this.preserveShort&&u===i[l]){const d=n[l+1]-n[l];if(d===0)continue;const h=d+2*this.padWidth;this.createNGrams(e,c,a,u,1,h)}}return[a,i]}}function gA(t,e,n,s,r,o,i,a){return new Oj(n,s,r,o,i,a).compute(t,e)}/** + */class Mj{constructor(e,n,s,r,o,i){this.separator=No(e),this.nGramWidths=n,this.leftPad=No(s),this.rightPad=No(r),this.padWidth=o,this.preserveShort=i}getPadWidth(e){return Math.min(this.padWidth<0?e-1:this.padWidth,e-1)}getNumNGrams(e,n){const s=this.getPadWidth(n);return Math.max(0,e+2*s-n+1)}createNGrams(e,n,s,r,o,i){for(let a=0;a0?0:a-l);let f=0;f+=c*this.leftPad.length;for(let y=0;yy.forEach(w=>g[x++]=w);for(let y=0;y0){m(e[d+h-1]);for(let y=0;y0){let l=n[0];if(l!==0)throw new Error(`First split value must be 0, got ${l}`);for(let c=1;c=l;if(u=u&&n[c]<=s,!u)throw new Error(`Invalid split value ${n[c]}, must be in [${l}, ${s}]`);l=n[c]}if(l!==s)throw new Error(`Last split value must be data size. Expected ${s}, got ${l}`)}const o=r-1,i=kt("int32",r);if(s===0||r===0){const l=new Array(s);for(let c=0;c<=o;++c)i[c]=0;return[l,i]}i[0]=0;for(let l=1;l<=o;++l){const c=n[l]-n[l-1];let u=0;this.nGramWidths.forEach(h=>{u+=this.getNumNGrams(c,h)}),this.preserveShort&&c>0&&u===0&&(u=1),i[l]=i[l-1]+u}const a=new Array(i[o]);for(let l=0;l{const d=n[l+1]-n[l],f=this.getNumNGrams(d,h);this.createNGrams(e,c,a,u,f,h),u+=f}),this.preserveShort&&u===i[l]){const h=n[l+1]-n[l];if(h===0)continue;const d=h+2*this.padWidth;this.createNGrams(e,c,a,u,1,d)}}return[a,i]}}function xA(t,e,n,s,r,o,i,a){return new Mj(n,s,r,o,i,a).compute(t,e)}/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8912,7 +8912,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Mj(t,e,n,s){if(!t.length)return;if(e.length===0){for(let o=0;ot-e),Pj=dv((t,e,n,s)=>({real:t-n,imag:e-s})),gv=Wt(rd,wA,Pj),Lj={kernelName:rd,backendName:"cpu",kernelFunc:gv};/** + */const vA=Tt((t,e)=>t-e),Lj=hv((t,e,n,s)=>({real:t-n,imag:e-s})),gv=Wt(rh,vA,Lj),Bj={kernelName:rh,backendName:"cpu",kernelFunc:gv};/** * @license * Copyright 2019 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -8957,7 +8957,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function vA(t,e){const n=new Array(t.rank);for(let r=0;r{const n=e.value-t.value;return n===0?t.index-e.index:n};function bA(t,e,n=0,s=t.length-1){for(;s>n;){if(s-n>600){const a=s-n+1,l=e-n+1,c=Math.log(a),u=.5*Math.exp(2*c/3),d=.5*Math.sqrt(c*u*(a-u)/a)*Math.sign(l-a/2),h=Math.max(n,Math.floor(e-l*u/a+d)),f=Math.min(s,Math.floor(e+(a-l)*u/a+d));bA(t,e,h,f)}const r=t[e];let o=n,i=s;for(ha(t,n,e),ac(t[s],r)>0&&ha(t,n,s);o0;)i=i-1}ac(t[n],r)===0?ha(t,n,i):(i=i+1,ha(t,i,s)),i<=e&&(n=i+1),e<=i&&(s=i-1)}}function CA(t,e,n,s,r){const o=e[e.length-1],[i,a]=[t.length/o,o],l=cn(n,i*s),c=cn("int32",i*s);for(let d=0;dp[w]={value:y,index:w}),s{const n=e.value-t.value;return n===0?t.index-e.index:n};function CA(t,e,n=0,s=t.length-1){for(;s>n;){if(s-n>600){const a=s-n+1,l=e-n+1,c=Math.log(a),u=.5*Math.exp(2*c/3),h=.5*Math.sqrt(c*u*(a-u)/a)*Math.sign(l-a/2),d=Math.max(n,Math.floor(e-l*u/a+h)),f=Math.min(s,Math.floor(e+(a-l)*u/a+h));CA(t,e,d,f)}const r=t[e];let o=n,i=s;for(da(t,n,e),ac(t[s],r)>0&&da(t,n,s);o0;)i=i-1}ac(t[n],r)===0?da(t,n,i):(i=i+1,da(t,i,s)),i<=e&&(n=i+1),e<=i&&(s=i-1)}}function kA(t,e,n,s,r){const o=e[e.length-1],[i,a]=[t.length/o,o],l=cn(n,i*s),c=cn("int32",i*s);for(let h=0;hp[w]={value:y,index:w}),s{for(let x=0;x{for(let x=0;xnew zm,1);/** + */V$("cpu",()=>new zm,1);/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -9032,7 +9032,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const SA=Xe(Nu,t=>t>=0?t:Math.exp(t)-1),Vj={kernelName:Nu,backendName:"cpu",kernelFunc:SA};/** + */const IA=Xe(Nu,t=>t>=0?t:Math.exp(t)-1),Wj={kernelName:Nu,backendName:"cpu",kernelFunc:IA};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9047,7 +9047,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function IA(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{alpha:o}=s;he([r],"leakyRelu");const i=j(r.shape),a=n.data.get(r.dataId).values,l=cn("float32",i);for(let c=0;ct<0?e*t:t);function $A(t){const{inputs:e,backend:n}=t,{x:s,alpha:r}=e;he([s,r],"prelu");const o=n.data.get(s.dataId).values,i=n.data.get(r.dataId).values,[a,l]=Uj(s.shape,r.shape,o,i,"float32");return n.makeTensorInfo(l,"float32",a)}const Gj={kernelName:Jp,backendName:"cpu",kernelFunc:$A};/** + */const Gj=Tt((t,e)=>t<0?e*t:t);function NA(t){const{inputs:e,backend:n}=t,{x:s,alpha:r}=e;de([s,r],"prelu");const o=n.data.get(s.dataId).values,i=n.data.get(r.dataId).values,[a,l]=Gj(s.shape,r.shape,o,i,"float32");return n.makeTensorInfo(l,"float32",a)}const Hj={kernelName:Jp,backendName:"cpu",kernelFunc:NA};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -9077,7 +9077,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const NA=Xe(ju,t=>Math.max(0,t)),Hj={kernelName:ju,backendName:"cpu",kernelFunc:NA};/** + */const TA=Xe(ju,t=>Math.max(0,t)),jj={kernelName:ju,backendName:"cpu",kernelFunc:TA};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -9092,7 +9092,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const TA=Xe(Ku,t=>Math.min(Math.max(0,t),6)),jj={kernelName:Ku,backendName:"cpu",kernelFunc:TA};/** + */const EA=Xe(Ku,t=>Math.min(Math.max(0,t),6)),Kj={kernelName:Ku,backendName:"cpu",kernelFunc:EA};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9107,7 +9107,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Of(t,e,n,s,r){if(n==="linear")return $r({inputs:{x:e},backend:t});if(n==="relu")return NA({inputs:{x:e},backend:t});if(n==="elu")return SA({inputs:{x:e},backend:t});if(n==="relu6")return TA({inputs:{x:e},backend:t});if(n==="prelu")return $A({inputs:{x:e,alpha:s},backend:t});if(n==="leakyrelu")return IA({inputs:{x:e},backend:t,attrs:{alpha:r}});if(n==="sigmoid")return cA({inputs:{x:e},backend:t});throw new Error(`Activation ${n} has not been implemented for the CPU backend.`)}/** + */function Of(t,e,n,s,r){if(n==="linear")return Nr({inputs:{x:e},backend:t});if(n==="relu")return TA({inputs:{x:e},backend:t});if(n==="elu")return IA({inputs:{x:e},backend:t});if(n==="relu6")return EA({inputs:{x:e},backend:t});if(n==="prelu")return NA({inputs:{x:e,alpha:s},backend:t});if(n==="leakyrelu")return $A({inputs:{x:e},backend:t,attrs:{alpha:r}});if(n==="sigmoid")return uA({inputs:{x:e},backend:t});throw new Error(`Activation ${n} has not been implemented for the CPU backend.`)}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9122,7 +9122,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function st(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{shape:o}=s,i=j(r.shape),a=j2(o,i),l=j(a);I(i===l,()=>`The new shape (${a}) has ${l} elements and the old shape (${r.shape}) has ${i} elements. The new shape and old shape must have the same number of elements.`),n.incRef(r.dataId);const c=n.data.get(r.dataId);if(c.complexTensorInfos!=null){const u=c.complexTensorInfos.real,d=c.complexTensorInfos.imag;u.shape=a,d.shape=a}return{dataId:r.dataId,shape:a,dtype:r.dtype}}const Kj={kernelName:tm,backendName:"cpu",kernelFunc:st};/** + */function st(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{shape:o}=s,i=j(r.shape),a=KI(o,i),l=j(a);I(i===l,()=>`The new shape (${a}) has ${l} elements and the old shape (${r.shape}) has ${i} elements. The new shape and old shape must have the same number of elements.`),n.incRef(r.dataId);const c=n.data.get(r.dataId);if(c.complexTensorInfos!=null){const u=c.complexTensorInfos.real,h=c.complexTensorInfos.imag;u.shape=a,h.shape=a}return{dataId:r.dataId,shape:a,dtype:r.dtype}}const Xj={kernelName:tm,backendName:"cpu",kernelFunc:st};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -9137,7 +9137,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function EA(t){const{inputs:e,backend:n,attrs:s}=t,{a:r,b:o}=e,{transposeA:i,transposeB:a}=s;he([r,o],"matMul");const l=r.shape.length,c=o.shape.length,u=i?r.shape[l-2]:r.shape[l-1],d=a?o.shape[c-1]:o.shape[c-2],h=i?r.shape[l-1]:r.shape[l-2],f=a?o.shape[c-2]:o.shape[c-1],p=r.shape.slice(0,-2),g=o.shape.slice(0,-2),x=j(p),m=j(g),w=Se(r.shape.slice(0,-2),o.shape.slice(0,-2)).concat([h,f]);I(u===d,()=>`Error in matMul: inner shapes (${u}) and (${d}) of Tensors with shapes ${r.shape} and ${o.shape} and transposeA=${i} and transposeB=${a} must match.`);const v=i?[x,u,h]:[x,h,u],b=a?[m,f,d]:[m,d,f],C=st({inputs:{x:r},backend:n,attrs:{shape:v}}),k=st({inputs:{x:o},backend:n,attrs:{shape:b}}),S=i?C.shape[1]:C.shape[2],$=i?C.shape[2]:C.shape[1],N=a?k.shape[1]:k.shape[2],A=Math.max(x,m),M=n.data.get(C.dataId).values,L=n.data.get(k.dataId).values,V=pe(C.shape),B=pe(k.shape),[U,K,R]=i?[V[0],1,V[1]]:[V[0],V[1],1],[O,G,X]=a?[1,B[1],B[0]]:[B[1],1,B[0]],q=$*N,Q=Ee([A,$,N],C.dtype),ee=Q.values,Z=n.blockSize;for(let se=0;se`Error in matMul: inner shapes (${u}) and (${h}) of Tensors with shapes ${r.shape} and ${o.shape} and transposeA=${i} and transposeB=${a} must match.`);const v=i?[x,u,d]:[x,d,u],b=a?[m,f,h]:[m,h,f],C=st({inputs:{x:r},backend:n,attrs:{shape:v}}),k=st({inputs:{x:o},backend:n,attrs:{shape:b}}),S=i?C.shape[1]:C.shape[2],$=i?C.shape[2]:C.shape[1],N=a?k.shape[1]:k.shape[2],A=Math.max(x,m),M=n.data.get(C.dataId).values,L=n.data.get(k.dataId).values,V=pe(C.shape),B=pe(k.shape),[U,K,R]=i?[V[0],1,V[1]]:[V[0],V[1],1],[O,G,X]=a?[1,B[1],B[0]]:[B[1],1,B[0]],q=$*N,Q=Ee([A,$,N],C.dtype),te=Q.values,Z=n.blockSize;for(let se=0;seMath.acos(t)),Zj={kernelName:pu,backendName:"cpu",kernelFunc:Qj};/** + */const Zj=Xe(pu,t=>Math.acos(t)),Jj={kernelName:pu,backendName:"cpu",kernelFunc:Zj};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -9182,7 +9182,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Jj=Xe(mu,t=>Math.acosh(t)),e8={kernelName:mu,backendName:"cpu",kernelFunc:Jj};/** + */const e8=Xe(mu,t=>Math.acosh(t)),t8={kernelName:mu,backendName:"cpu",kernelFunc:e8};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9197,7 +9197,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function t8(t){const{inputs:e,backend:n}=t,s=e;he(e,"addN");const r=s.map(a=>n.data.get(a.dataId).values),o=Ee(s[0].shape,s[0].dtype),i=o.values;for(let a=0;an.data.get(a.dataId).values),o=Ee(s[0].shape,s[0].dtype),i=o.values;for(let a=0;ay&&(y=b,w=v)}f[x]=w}return c.forEach(x=>n.disposeIntermediateTensorInfo(x)),n.makeTensorInfo(u,"int32",f)}const l8={kernelName:mp,backendName:"cpu",kernelFunc:a8};/** + */function l8(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{axis:o}=s;de(r,"argMax");let i=Re(o,r.shape);const a=yt(i,r.shape.length);let l=r;const c=[];a!=null&&(l=Fn({inputs:{x:r},backend:n,attrs:{perm:a}}),c.push(l),i=$t(i.length,l.shape.length)),i=[i[0]],sn("argMax",i,l.shape.length);const[u,h]=Yt(l.shape,i),d=j(u),f=un(d,"int32"),p=j(h),g=n.data.get(l.dataId).values;for(let x=0;xy&&(y=b,w=v)}f[x]=w}return c.forEach(x=>n.disposeIntermediateTensorInfo(x)),n.makeTensorInfo(u,"int32",f)}const c8={kernelName:mp,backendName:"cpu",kernelFunc:l8};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9257,7 +9257,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function c8(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{axis:o}=s;he(r,"argMin");let i=Re(o,r.shape);const a=yt(i,r.shape.length);let l=r;const c=[];a!=null&&(l=Fn({inputs:{x:r},backend:n,attrs:{perm:a}}),c.push(l),i=$t(i.length,l.shape.length)),i=[i[0]],sn("argMin",i,l.shape.length);const[u,d]=Yt(l.shape,i),h=j(u),f=un(h,"int32"),p=j(d),g=n.data.get(l.dataId).values;for(let x=0;xn.disposeIntermediateTensorInfo(x)),n.makeTensorInfo(u,"int32",f)}const u8={kernelName:gp,backendName:"cpu",kernelFunc:c8};/** + */function u8(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{axis:o}=s;de(r,"argMin");let i=Re(o,r.shape);const a=yt(i,r.shape.length);let l=r;const c=[];a!=null&&(l=Fn({inputs:{x:r},backend:n,attrs:{perm:a}}),c.push(l),i=$t(i.length,l.shape.length)),i=[i[0]],sn("argMin",i,l.shape.length);const[u,h]=Yt(l.shape,i),d=j(u),f=un(d,"int32"),p=j(h),g=n.data.get(l.dataId).values;for(let x=0;xn.disposeIntermediateTensorInfo(x)),n.makeTensorInfo(u,"int32",f)}const h8={kernelName:gp,backendName:"cpu",kernelFunc:u8};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -9272,7 +9272,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const d8=Xe(gu,t=>Math.asin(t)),h8={kernelName:gu,backendName:"cpu",kernelFunc:d8};/** + */const d8=Xe(gu,t=>Math.asin(t)),f8={kernelName:gu,backendName:"cpu",kernelFunc:d8};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -9287,7 +9287,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const f8=Xe(xu,t=>Math.asinh(t)),p8={kernelName:xu,backendName:"cpu",kernelFunc:f8};/** + */const p8=Xe(xu,t=>Math.asinh(t)),m8={kernelName:xu,backendName:"cpu",kernelFunc:p8};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -9302,7 +9302,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const m8=Xe(yu,t=>Math.atan(t)),g8={kernelName:yu,backendName:"cpu",kernelFunc:m8};/** + */const g8=Xe(yu,t=>Math.atan(t)),x8={kernelName:yu,backendName:"cpu",kernelFunc:g8};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -9317,7 +9317,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const x8=Tt((t,e)=>Math.atan2(t,e)),y8=Wt(vu,x8),w8={kernelName:vu,backendName:"cpu",kernelFunc:y8};/** + */const y8=Tt((t,e)=>Math.atan2(t,e)),w8=Wt(vu,y8),v8={kernelName:vu,backendName:"cpu",kernelFunc:w8};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -9332,7 +9332,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const v8=Xe(wu,t=>Math.atanh(t)),b8={kernelName:wu,backendName:"cpu",kernelFunc:v8};/** + */const b8=Xe(wu,t=>Math.atanh(t)),C8={kernelName:wu,backendName:"cpu",kernelFunc:b8};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9347,7 +9347,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function xv(t,e,n,s,r,o){const i=r.strideHeight,a=r.strideWidth,l=r.dilationHeight,c=r.dilationWidth,u=r.effectiveFilterHeight,d=r.effectiveFilterWidth,h=r.padInfo.top,f=r.padInfo.left,p=o==="max"?Number.NEGATIVE_INFINITY:Number.POSITIVE_INFINITY,g=Ee(r.outShape,n),x=g.values,m=r.outShape[1]*r.outShape[2]*r.outShape[3],y=r.outShape[2]*r.outShape[3],w=r.outShape[3];for(let v=0;vK?K=Z:o==="avg"&&(R+=Z,O++)}if(isNaN(K))break}const G=M+L*w+k;x[G]=o==="avg"?R/O:K}}}return g}function RA(t,e,n,s,r=!1,o=!1){const i=Ee(s.outShape,"int32"),a=s.strideHeight,l=s.strideWidth,c=s.dilationHeight,u=s.dilationWidth,d=s.effectiveFilterHeight,h=s.effectiveFilterWidth,f=s.padInfo.top,p=s.padInfo.left,g=Ee(e,n,t);for(let x=0;xN&&(N=U,r?A=o?((x*s.inHeight+M)*s.inWidth+V)*s.inChannels+m:(M*s.inWidth+V)*s.inChannels+m:A=L*h+B)}}i.set(A,x,y,C,m)}}return i}function AA(t,e,n,s,r,o){const i=r.strideDepth,a=r.strideHeight,l=r.strideWidth,c=r.dilationDepth,u=r.dilationHeight,d=r.dilationWidth,h=r.effectiveFilterDepth,f=r.effectiveFilterHeight,p=r.effectiveFilterWidth,g=r.padInfo.front,x=r.padInfo.top,m=r.padInfo.left,y=o==="max"?Number.NEGATIVE_INFINITY:Number.POSITIVE_INFINITY,w=Ee(r.outShape,n),v=w.values,b=r.outShape[1]*r.outShape[2]*r.outShape[3]*r.outShape[4],C=r.outShape[2]*r.outShape[3]*r.outShape[4],k=r.outShape[3]*r.outShape[4],S=r.outShape[4];for(let $=0;$ce?ce=Ge:o==="avg"&&(ue+=Ge,xe++),isNaN(ce))break}if(isNaN(ce))break}if(isNaN(ce))break}const be=ie+M;v[be]=o==="avg"?ue/Math.max(xe,1):ce}}}}return w}function C8(t,e){const n=Ee(e.outShape,"int32"),s=e.strideDepth,r=e.strideHeight,o=e.strideWidth,i=e.dilationDepth,a=e.dilationHeight,l=e.dilationWidth,c=e.effectiveFilterDepth,u=e.effectiveFilterHeight,d=e.effectiveFilterWidth,h=e.padInfo.front,f=e.padInfo.top,p=e.padInfo.left;for(let g=0;g=L&&(L=X,V=U*u*d+R*u+G)}}}n.set(V,g,m,b,$,x)}}}return n}/** + */function xv(t,e,n,s,r,o){const i=r.strideHeight,a=r.strideWidth,l=r.dilationHeight,c=r.dilationWidth,u=r.effectiveFilterHeight,h=r.effectiveFilterWidth,d=r.padInfo.top,f=r.padInfo.left,p=o==="max"?Number.NEGATIVE_INFINITY:Number.POSITIVE_INFINITY,g=Ee(r.outShape,n),x=g.values,m=r.outShape[1]*r.outShape[2]*r.outShape[3],y=r.outShape[2]*r.outShape[3],w=r.outShape[3];for(let v=0;vK?K=Z:o==="avg"&&(R+=Z,O++)}if(isNaN(K))break}const G=M+L*w+k;x[G]=o==="avg"?R/O:K}}}return g}function AA(t,e,n,s,r=!1,o=!1){const i=Ee(s.outShape,"int32"),a=s.strideHeight,l=s.strideWidth,c=s.dilationHeight,u=s.dilationWidth,h=s.effectiveFilterHeight,d=s.effectiveFilterWidth,f=s.padInfo.top,p=s.padInfo.left,g=Ee(e,n,t);for(let x=0;xN&&(N=U,r?A=o?((x*s.inHeight+M)*s.inWidth+V)*s.inChannels+m:(M*s.inWidth+V)*s.inChannels+m:A=L*d+B)}}i.set(A,x,y,C,m)}}return i}function DA(t,e,n,s,r,o){const i=r.strideDepth,a=r.strideHeight,l=r.strideWidth,c=r.dilationDepth,u=r.dilationHeight,h=r.dilationWidth,d=r.effectiveFilterDepth,f=r.effectiveFilterHeight,p=r.effectiveFilterWidth,g=r.padInfo.front,x=r.padInfo.top,m=r.padInfo.left,y=o==="max"?Number.NEGATIVE_INFINITY:Number.POSITIVE_INFINITY,w=Ee(r.outShape,n),v=w.values,b=r.outShape[1]*r.outShape[2]*r.outShape[3]*r.outShape[4],C=r.outShape[2]*r.outShape[3]*r.outShape[4],k=r.outShape[3]*r.outShape[4],S=r.outShape[4];for(let $=0;$ce?ce=Ge:o==="avg"&&(ue+=Ge,xe++),isNaN(ce))break}if(isNaN(ce))break}if(isNaN(ce))break}const be=ie+M;v[be]=o==="avg"?ue/Math.max(xe,1):ce}}}}return w}function k8(t,e){const n=Ee(e.outShape,"int32"),s=e.strideDepth,r=e.strideHeight,o=e.strideWidth,i=e.dilationDepth,a=e.dilationHeight,l=e.dilationWidth,c=e.effectiveFilterDepth,u=e.effectiveFilterHeight,h=e.effectiveFilterWidth,d=e.padInfo.front,f=e.padInfo.top,p=e.padInfo.left;for(let g=0;g=L&&(L=X,V=U*u*h+R*u+G)}}}n.set(V,g,m,b,$,x)}}}return n}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9362,7 +9362,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function k8(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e;he(r,"avgPool");const{filterSize:o,strides:i,pad:a,dimRoundingMode:l}=s,c=1;I(hn(i,c),()=>`Error in avgPool: Either strides or dilations must be 1. Got strides ${i} and dilations '${c}'`);const u=Rs(r.shape,o,i,c,a,l);let d;if(u.filterWidth===1&&u.filterHeight===1&&Ue(u.inShape,u.outShape))d=$r({inputs:{x:r},backend:n});else{const h=n.data.get(r.dataId).values,f=pe(r.shape),p=xv(h,r.shape,r.dtype,f,u,"avg");d=n.makeTensorInfo(u.outShape,r.dtype,p.values)}return d}const S8={kernelName:xp,backendName:"cpu",kernelFunc:k8};/** + */function S8(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e;de(r,"avgPool");const{filterSize:o,strides:i,pad:a,dimRoundingMode:l}=s,c=1;I(dn(i,c),()=>`Error in avgPool: Either strides or dilations must be 1. Got strides ${i} and dilations '${c}'`);const u=As(r.shape,o,i,c,a,l);let h;if(u.filterWidth===1&&u.filterHeight===1&&Ue(u.inShape,u.outShape))h=Nr({inputs:{x:r},backend:n});else{const d=n.data.get(r.dataId).values,f=pe(r.shape),p=xv(d,r.shape,r.dtype,f,u,"avg");h=n.makeTensorInfo(u.outShape,r.dtype,p.values)}return h}const I8={kernelName:xp,backendName:"cpu",kernelFunc:S8};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9377,7 +9377,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function I8(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{filterSize:o,strides:i,pad:a,dimRoundingMode:l,dataFormat:c}=s;he(r,"avgPool3d");const u=qr(r.shape,o,i,1,a,l,c),d=n.data.get(r.dataId).values,h=AA(d,r.shape,r.dtype,pe(r.shape),u,"avg");return n.makeTensorInfo(h.shape,"float32",h.values)}const $8={kernelName:yp,backendName:"cpu",kernelFunc:I8};/** + */function $8(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{filterSize:o,strides:i,pad:a,dimRoundingMode:l,dataFormat:c}=s;de(r,"avgPool3d");const u=Yr(r.shape,o,i,1,a,l,c),h=n.data.get(r.dataId).values,d=DA(h,r.shape,r.dtype,pe(r.shape),u,"avg");return n.makeTensorInfo(d.shape,"float32",d.values)}const N8={kernelName:yp,backendName:"cpu",kernelFunc:$8};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9392,7 +9392,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function N8(t){const{inputs:e,backend:n,attrs:s}=t,{dy:r,input:o}=e,{filterSize:i,strides:a,pad:l,dimRoundingMode:c}=s;he([r,o],"avgPool3DGrad");const u=qr(o.shape,i,a,1,l,c),d=u.strideDepth,h=u.strideHeight,f=u.strideWidth,p=u.filterDepth,g=u.filterHeight,x=u.filterWidth,m=u.dilationDepth,y=u.dilationHeight,w=u.dilationWidth,v=u.effectiveFilterDepth,b=u.effectiveFilterHeight,C=u.effectiveFilterWidth,k=v-1-u.padInfo.front,S=C-1-u.padInfo.left,$=b-1-u.padInfo.top,N=Ee(o.shape,"float32"),A=1/(p*g*x),M=n.bufferSync(r);for(let L=0;L=u.outDepth||Math.floor(Q)!==Q))for(let ee=0;ee=u.outHeight||Math.floor(Z)!==Z))for(let se=0;se=u.outWidth||Math.floor(ie)!==ie)continue;const ce=M.get(L,Q,Z,ie,V);X+=ce}}}N.set(X*A,L,B,U,K,V)}return n.makeTensorInfo(N.shape,N.dtype,N.values)}const T8={kernelName:Xx,backendName:"cpu",kernelFunc:N8};/** + */function T8(t){const{inputs:e,backend:n,attrs:s}=t,{dy:r,input:o}=e,{filterSize:i,strides:a,pad:l,dimRoundingMode:c}=s;de([r,o],"avgPool3DGrad");const u=Yr(o.shape,i,a,1,l,c),h=u.strideDepth,d=u.strideHeight,f=u.strideWidth,p=u.filterDepth,g=u.filterHeight,x=u.filterWidth,m=u.dilationDepth,y=u.dilationHeight,w=u.dilationWidth,v=u.effectiveFilterDepth,b=u.effectiveFilterHeight,C=u.effectiveFilterWidth,k=v-1-u.padInfo.front,S=C-1-u.padInfo.left,$=b-1-u.padInfo.top,N=Ee(o.shape,"float32"),A=1/(p*g*x),M=n.bufferSync(r);for(let L=0;L=u.outDepth||Math.floor(Q)!==Q))for(let te=0;te=u.outHeight||Math.floor(Z)!==Z))for(let se=0;se=u.outWidth||Math.floor(ie)!==ie)continue;const ce=M.get(L,Q,Z,ie,V);X+=ce}}}N.set(X*A,L,B,U,K,V)}return n.makeTensorInfo(N.shape,N.dtype,N.values)}const E8={kernelName:Xx,backendName:"cpu",kernelFunc:T8};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9407,7 +9407,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function E8(t){const{inputs:e,backend:n,attrs:s}=t,{dy:r,input:o}=e,i=o;he([r,o],"avgPoolGrad");const{filterSize:a,strides:l,pad:c}=s,u=Rs(i.shape,a,l,1,c),d=u.strideHeight,h=u.strideWidth,f=u.filterHeight,p=u.filterWidth,g=u.dilationHeight,x=u.dilationWidth,m=u.effectiveFilterHeight,y=u.effectiveFilterWidth,w=y-1-u.padInfo.left,v=m-1-u.padInfo.top,b=Ee(i.shape,"float32"),C=1/(f*p),k=n.data.get(r.dataId).values,S=Ee(r.shape,"float32",k);for(let $=0;$=u.outHeight||Math.floor(K)!==K))for(let R=0;R=u.outWidth||Math.floor(O)!==O)continue;const G=S.get($,K,O,N);B+=G}}b.set(B*C,$,A,M,N)}return n.makeTensorInfo(b.shape,b.dtype,b.values)}const R8={kernelName:Kx,backendName:"cpu",kernelFunc:E8};/** + */function R8(t){const{inputs:e,backend:n,attrs:s}=t,{dy:r,input:o}=e,i=o;de([r,o],"avgPoolGrad");const{filterSize:a,strides:l,pad:c}=s,u=As(i.shape,a,l,1,c),h=u.strideHeight,d=u.strideWidth,f=u.filterHeight,p=u.filterWidth,g=u.dilationHeight,x=u.dilationWidth,m=u.effectiveFilterHeight,y=u.effectiveFilterWidth,w=y-1-u.padInfo.left,v=m-1-u.padInfo.top,b=Ee(i.shape,"float32"),C=1/(f*p),k=n.data.get(r.dataId).values,S=Ee(r.shape,"float32",k);for(let $=0;$=u.outHeight||Math.floor(K)!==K))for(let R=0;R=u.outWidth||Math.floor(O)!==O)continue;const G=S.get($,K,O,N);B+=G}}b.set(B*C,$,A,M,N)}return n.makeTensorInfo(b.shape,b.dtype,b.values)}const A8={kernelName:Kx,backendName:"cpu",kernelFunc:R8};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9422,7 +9422,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function A8(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,scale:o,offset:i,mean:a,variance:l}=e;I(a.shape.length===l.shape.length,()=>"Batch normalization gradient requires mean and variance to have equal ranks."),I(i==null||a.shape.length===i.shape.length,()=>"Batch normalization gradient requires mean and offset to have equal ranks."),I(o==null||a.shape.length===o.shape.length,()=>"Batch normalization gradient requires mean and scale to have equal ranks."),he([r,a,l,o,i],"batchNorm");let{varianceEpsilon:c}=s;c==null&&(c=.001);const u=n.data.get(r.dataId).values,d=n.data.get(a.dataId).values,h=n.data.get(l.dataId).values,f=o?n.data.get(o.dataId).values:new Float32Array([1]),p=i?n.data.get(i.dataId).values:new Float32Array([0]),g=new Float32Array(u.length),x=p.length,m=f.length,y=h.length,w=d.length;let v=0,b=0,C=0,k=0;for(let S=0;S=x&&(v=0),b>=w&&(b=0),C>=m&&(C=0),k>=y&&(k=0);return n.makeTensorInfo(r.shape,r.dtype,g)}const D8={kernelName:Ap,backendName:"cpu",kernelFunc:A8};/** + */function D8(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,scale:o,offset:i,mean:a,variance:l}=e;I(a.shape.length===l.shape.length,()=>"Batch normalization gradient requires mean and variance to have equal ranks."),I(i==null||a.shape.length===i.shape.length,()=>"Batch normalization gradient requires mean and offset to have equal ranks."),I(o==null||a.shape.length===o.shape.length,()=>"Batch normalization gradient requires mean and scale to have equal ranks."),de([r,a,l,o,i],"batchNorm");let{varianceEpsilon:c}=s;c==null&&(c=.001);const u=n.data.get(r.dataId).values,h=n.data.get(a.dataId).values,d=n.data.get(l.dataId).values,f=o?n.data.get(o.dataId).values:new Float32Array([1]),p=i?n.data.get(i.dataId).values:new Float32Array([0]),g=new Float32Array(u.length),x=p.length,m=f.length,y=d.length,w=h.length;let v=0,b=0,C=0,k=0;for(let S=0;S=x&&(v=0),b>=w&&(b=0),C>=m&&(C=0),k>=y&&(k=0);return n.makeTensorInfo(r.shape,r.dtype,g)}const _8={kernelName:Ap,backendName:"cpu",kernelFunc:D8};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9437,7 +9437,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function _8(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{blockShape:o,crops:i}=s;he([r],"batchToSpaceND");const a=o.reduce((m,y)=>m*y),l=gd(r.shape,o,a),c=xd(l.length,o.length),u=yd(r.shape,o,a),d=Nw(i,o.length),h=Tw(u,i,o.length),f=st({inputs:{x:r},backend:n,attrs:{shape:l}}),p=Fn({inputs:{x:f},backend:n,attrs:{perm:c}}),g=st({inputs:{x:p},backend:n,attrs:{shape:u}}),x=Vi({inputs:{x:g},backend:n,attrs:{begin:d,size:h}});return n.disposeIntermediateTensorInfo(f),n.disposeIntermediateTensorInfo(p),n.disposeIntermediateTensorInfo(g),x}const F8={kernelName:vp,backendName:"cpu",kernelFunc:_8};/** + */function F8(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{blockShape:o,crops:i}=s;de([r],"batchToSpaceND");const a=o.reduce((m,y)=>m*y),l=gh(r.shape,o,a),c=xh(l.length,o.length),u=yh(r.shape,o,a),h=Nw(i,o.length),d=Tw(u,i,o.length),f=st({inputs:{x:r},backend:n,attrs:{shape:l}}),p=Fn({inputs:{x:f},backend:n,attrs:{perm:c}}),g=st({inputs:{x:p},backend:n,attrs:{shape:u}}),x=Vi({inputs:{x:g},backend:n,attrs:{begin:h,size:d}});return n.disposeIntermediateTensorInfo(f),n.disposeIntermediateTensorInfo(p),n.disposeIntermediateTensorInfo(g),x}const z8={kernelName:vp,backendName:"cpu",kernelFunc:F8};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9452,7 +9452,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function z8(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,weights:o}=e,{size:i}=s,a=n.data.get(r.dataId).values,l=n.data.get(o.dataId).values,c=hv(a,l,o.dtype,o.shape,i);return n.makeTensorInfo([i],o.dtype,c)}const O8={kernelName:qx,backendName:"cpu",kernelFunc:z8};/** + */function O8(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,weights:o}=e,{size:i}=s,a=n.data.get(r.dataId).values,l=n.data.get(o.dataId).values,c=dv(a,l,o.dtype,o.shape,i);return n.makeTensorInfo([i],o.dtype,c)}const M8={kernelName:qx,backendName:"cpu",kernelFunc:O8};/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9467,7 +9467,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function M8(t){const{inputs:e,backend:n}=t,{s0:s,s1:r}=e,o=n.data.get(s.dataId).values,i=n.data.get(r.dataId).values,a=Se(Array.from(o),Array.from(i));return n.makeTensorInfo([a.length],"int32",Int32Array.from(a))}const P8={kernelName:Z2,backendName:"cpu",kernelFunc:M8};/** + */function P8(t){const{inputs:e,backend:n}=t,{s0:s,s1:r}=e,o=n.data.get(s.dataId).values,i=n.data.get(r.dataId).values,a=Se(Array.from(o),Array.from(i));return n.makeTensorInfo([a.length],"int32",Int32Array.from(a))}const L8={kernelName:JI,backendName:"cpu",kernelFunc:P8};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -9482,7 +9482,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const L8=Xe(ku,(t,e)=>{const n=e;return t>n.clipValueMax?n.clipValueMax:t{const n=e;return t>n.clipValueMax?n.clipValueMax:t{const{x:e}=t.inputs,n=t.backend,s=new Float32Array(j(e.shape)),r=n.data.get(e.dataId),o=r.complexTensorInfos.real,i=r.complexTensorInfos.imag,a=n.data.get(o.dataId).values,l=n.data.get(i.dataId).values;for(let c=0;c{const{x:e}=t.inputs,n=t.backend,s=new Float32Array(j(e.shape)),r=n.data.get(e.dataId),o=r.complexTensorInfos.real,i=r.complexTensorInfos.imag,a=n.data.get(o.dataId).values,l=n.data.get(i.dataId).values;for(let c=0;cg.shape);Sw(i,o);let a=yr(e.map(g=>g.shape),o);if(j(a)===0)return n.makeTensorInfo(a,e[0].dtype,[]);const l=e.filter(g=>j(g.shape)>0);if(l.length===1)return $r({inputs:{x:l[0]},backend:n});if(l[0].dtype==="complex64"){const g=l.map(v=>Bi({inputs:{input:v},backend:n})),x=l.map(v=>ul({inputs:{input:v},backend:n})),m=dl({inputs:g,backend:n,attrs:{axis:o}}),y=dl({inputs:x,backend:n,attrs:{axis:o}}),w=Vn({inputs:{real:m,imag:y},backend:n});return g.forEach(v=>n.disposeIntermediateTensorInfo(v)),x.forEach(v=>n.disposeIntermediateTensorInfo(v)),n.disposeIntermediateTensorInfo(m),n.disposeIntermediateTensorInfo(y),w}const c=l.map(g=>{const m=[-1,j(g.shape.slice(o))];return st({inputs:{x:g},backend:n,attrs:{shape:m}})}),u=c.map(g=>({vals:n.data.get(g.dataId).values,shape:g.shape}));a=yr(c.map(g=>g.shape),1);const d=c[0].shape[0]===1,h=OR(u,a,e[0].dtype,d),f=yr(l.map(g=>g.shape),o),p=n.makeTensorInfo(f,e[0].dtype,h);return c.forEach(g=>n.disposeIntermediateTensorInfo(g)),p}const G8={kernelName:Cp,backendName:"cpu",kernelFunc:dl};/** + */function hl(t){const{inputs:e,backend:n,attrs:s}=t,{axis:r}=s,o=Re(r,e[0].shape)[0],i=e.map(g=>g.shape);Sw(i,o);let a=wr(e.map(g=>g.shape),o);if(j(a)===0)return n.makeTensorInfo(a,e[0].dtype,[]);const l=e.filter(g=>j(g.shape)>0);if(l.length===1)return Nr({inputs:{x:l[0]},backend:n});if(l[0].dtype==="complex64"){const g=l.map(v=>Bi({inputs:{input:v},backend:n})),x=l.map(v=>ul({inputs:{input:v},backend:n})),m=hl({inputs:g,backend:n,attrs:{axis:o}}),y=hl({inputs:x,backend:n,attrs:{axis:o}}),w=Vn({inputs:{real:m,imag:y},backend:n});return g.forEach(v=>n.disposeIntermediateTensorInfo(v)),x.forEach(v=>n.disposeIntermediateTensorInfo(v)),n.disposeIntermediateTensorInfo(m),n.disposeIntermediateTensorInfo(y),w}const c=l.map(g=>{const m=[-1,j(g.shape.slice(o))];return st({inputs:{x:g},backend:n,attrs:{shape:m}})}),u=c.map(g=>({vals:n.data.get(g.dataId).values,shape:g.shape}));a=wr(c.map(g=>g.shape),1);const h=c[0].shape[0]===1,d=MR(u,a,e[0].dtype,h),f=wr(l.map(g=>g.shape),o),p=n.makeTensorInfo(f,e[0].dtype,d);return c.forEach(g=>n.disposeIntermediateTensorInfo(g)),p}const H8={kernelName:Cp,backendName:"cpu",kernelFunc:hl};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9542,7 +9542,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function DA(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,filter:o}=e,{strides:i,pad:a,dataFormat:l,dilations:c,dimRoundingMode:u}=s;he([r,o],"conv2d");const d=Yr(l),h=nn(r.shape,o.shape,i,c,a,u,!1,d),f=h.filterHeight,p=h.filterWidth,g=h.dilationHeight,x=h.dilationWidth,m=h.padInfo.left,y=h.padInfo.top,w=h.dataFormat==="channelsLast",v=new tn(h.outShape,r.dtype),b=pe(r.shape),C=pe(o.shape),k=b[0],S=w?b[1]:b[2],$=w?b[2]:1,N=w?1:b[1],A=v.strides[0],M=w?v.strides[1]:v.strides[2],L=w?v.strides[2]:1,V=w?1:v.strides[1],B=n.data.get(r.dataId).values,U=n.data.get(o.dataId).values,K=v.values;for(let R=0;R=h.inHeight)continue;const se=ee*C[0],ie=O+Z*S;for(let ce=0;ce=h.inWidth)continue;const He=se+be*C[1],Ne=ie+ke*$;let Me=He;for(let Be=0;Be=d.inHeight)continue;const se=te*C[0],ie=O+Z*S;for(let ce=0;ce=d.inWidth)continue;const He=se+be*C[1],Ne=ie+ke*$;let Me=He;for(let Be=0;Be=c.inDepth)continue;const R=U*$[0],O=A+K*S[1];for(let G=0;G=c.inHeight)continue;const Z=R+Q*$[1],se=O+ee*S[2];for(let ie=0;ie=c.inWidth)continue;const ke=Z+xe*$[2],He=se+be*c.inChannels;let Ne=ke;for(let Me=0;Me=c.inDepth)continue;const R=U*$[0],O=A+K*S[1];for(let G=0;G=c.inHeight)continue;const Z=R+Q*$[1],se=O+te*S[2];for(let ie=0;ie=c.inWidth)continue;const ke=Z+xe*$[2],He=se+be*c.inChannels;let Ne=ke;for(let Me=0;MeMath.cos(t)),sK={kernelName:Su,backendName:"cpu",kernelFunc:nK};/** + */const sK=Xe(Su,t=>Math.cos(t)),rK={kernelName:Su,backendName:"cpu",kernelFunc:sK};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -9647,7 +9647,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const rK=Xe(Iu,t=>Math.cosh(t)),oK={kernelName:Iu,backendName:"cpu",kernelFunc:rK};/** + */const oK=Xe(Iu,t=>Math.cosh(t)),iK={kernelName:Iu,backendName:"cpu",kernelFunc:oK};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9662,7 +9662,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function iK(t){const{inputs:e,backend:n,attrs:s}=t,{image:r,boxes:o,boxInd:i}=e,{cropSize:a,method:l,extrapolationValue:c}=s,[u,d,h,f]=r.shape,p=o.shape[0],[g,x]=a,m=Ee([p,g,x,f],"float32"),y=n.data.get(o.dataId).values,w=n.data.get(i.dataId).values,v=n.data.get(r.dataId).values,b=pe(r.shape),C=pe(m.shape);for(let k=0;k=u)continue;const V=g>1?(A-$)*(d-1)/(g-1):0,B=x>1?(M-N)*(h-1)/(x-1):0;for(let U=0;U1?$*(d-1)+U*V:.5*($+A)*(d-1);if(K<0||K>d-1){for(let R=0;R1?N*(h-1)+X*B:.5*(N+M)*(h-1);if(q<0||q>h-1){for(let se=0;se1?N*(h-1)+R*B:.5*(N+M)*(h-1);if(O<0||O>h-1){for(let q=0;q=u)continue;const V=g>1?(A-$)*(h-1)/(g-1):0,B=x>1?(M-N)*(d-1)/(x-1):0;for(let U=0;U1?$*(h-1)+U*V:.5*($+A)*(h-1);if(K<0||K>h-1){for(let R=0;R1?N*(d-1)+X*B:.5*(N+M)*(d-1);if(q<0||q>d-1){for(let se=0;se1?N*(d-1)+R*B:.5*(N+M)*(d-1);if(O<0||O>d-1){for(let q=0;qm+p-y-1:(m,y)=>m+y;for(let m=0;mm+p-y-1:(m,y)=>m+y;for(let m=0;mm+p-y-1:(m,y)=>m+y;for(let m=0;mm+p-y-1:(m,y)=>m+y;for(let m=0;m`Only NHWC dataFormat supported on CPU for depthToSpace. Got ${i}`);const a=r.shape[0],l=r.shape[1],c=r.shape[2],u=r.shape[3],d=l*o,h=c*o,f=u/(o*o),p=n.data.get(r.dataId).values,g=new Float32Array(a*d*h*f);let x=0;for(let m=0;m`Only NHWC dataFormat supported on CPU for depthToSpace. Got ${i}`);const a=r.shape[0],l=r.shape[1],c=r.shape[2],u=r.shape[3],h=l*o,d=c*o,f=u/(o*o),p=n.data.get(r.dataId).values,g=new Float32Array(a*h*d*f);let x=0;for(let m=0;m`Error in depthwiseConv2d: Either strides or dilations must be 1. Got strides ${i} and dilations '${h}'`);const f=nn(r.shape,o.shape,i,h,a,c,!0),{filterHeight:p,filterWidth:g,dilationHeight:x,dilationWidth:m,padInfo:y}=f,w=y.left,v=y.top,b=f.outChannels/f.inChannels,C=new tn(f.outShape,r.dtype),k=n.data.get(r.dataId).values,S=n.data.get(o.dataId).values,$=C.values;for(let N=0;N=f.inHeight)continue;const R=U*d[0],O=A+K*u[1];for(let G=0;G=f.inWidth)continue;const Z=R+Q*d[1],se=O+ee*f.inChannels;let ie=X,ce=Z;for(let ue=0;ue`Error in depthwiseConv2d: Either strides or dilations must be 1. Got strides ${i} and dilations '${d}'`);const f=nn(r.shape,o.shape,i,d,a,c,!0),{filterHeight:p,filterWidth:g,dilationHeight:x,dilationWidth:m,padInfo:y}=f,w=y.left,v=y.top,b=f.outChannels/f.inChannels,C=new tn(f.outShape,r.dtype),k=n.data.get(r.dataId).values,S=n.data.get(o.dataId).values,$=C.values;for(let N=0;N=f.inHeight)continue;const R=U*h[0],O=A+K*u[1];for(let G=0;G=f.inWidth)continue;const Z=R+Q*h[1],se=O+te*f.inChannels;let ie=X,ce=Z;for(let ue=0;ue{const{x:s,filter:r}=t,{strides:o,pad:i,dilations:a}=n,l=e,c=l.data.get(s.dataId).values,u=s.shape.length,d=l.data.get(r.dataId).values,h=r.shape.length,{batchSize:f,inHeight:p,inWidth:g,inChannels:x,outHeight:m,outWidth:y,padInfo:w,strideHeight:v,strideWidth:b,filterHeight:C,filterWidth:k,dilationHeight:S,dilationWidth:$,outShape:N}=dd(s.shape,r.shape,o,i,"NHWC",a),A=j(N),M=N.length,L=kt(s.dtype,A);for(let B=0;B=0&&ee=0&&seX&&(X=ue)}}}const q=gr([B,U,R,G],M,pe(N));L[q]=X}}}return{dataId:l.write(Ki(L,s.dtype),N,s.dtype),shape:N,dtype:s.dtype}}};/** + */const SK={kernelName:Tp,backendName:"cpu",kernelFunc:({inputs:t,backend:e,attrs:n})=>{const{x:s,filter:r}=t,{strides:o,pad:i,dilations:a}=n,l=e,c=l.data.get(s.dataId).values,u=s.shape.length,h=l.data.get(r.dataId).values,d=r.shape.length,{batchSize:f,inHeight:p,inWidth:g,inChannels:x,outHeight:m,outWidth:y,padInfo:w,strideHeight:v,strideWidth:b,filterHeight:C,filterWidth:k,dilationHeight:S,dilationWidth:$,outShape:N}=hh(s.shape,r.shape,o,i,"NHWC",a),A=j(N),M=N.length,L=kt(s.dtype,A);for(let B=0;B=0&&te=0&&seX&&(X=ue)}}}const q=xr([B,U,R,G],M,pe(N));L[q]=X}}}return{dataId:l.write(Ki(L,s.dtype),N,s.dtype),shape:N,dtype:s.dtype}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9812,7 +9812,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const SK={kernelName:J0,backendName:"cpu",kernelFunc:({inputs:t,backend:e,attrs:n})=>{const{x:s,filter:r,dy:o}=t,{strides:i,pad:a,dilations:l}=n,c=e,u=Xs(s.shape,c.data.get(s.dataId).values),d=Xs(r.shape,c.data.get(r.dataId).values),{batchSize:h,inHeight:f,inWidth:p,inChannels:g,outHeight:x,outWidth:m,padInfo:y,strideHeight:w,strideWidth:v,filterHeight:b,filterWidth:C,dilationHeight:k,dilationWidth:S,outShape:$}=dd(s.shape,r.shape,i,a,"NHWC",l);I(o.rank===$.length,()=>`Error in ${J0}, dy must have the same rank as output ${$.length}, but got ${o.rank}`);const N=Xs($,c.data.get(o.dataId).values),A=q2(r.shape,r.dtype);for(let L=0;L=0&&Q=0&&ZO&&(O=se,G=q,X=ee)}}}A[G][X][R]+=N[L][V][U][R]}}}return{dataId:c.write(Ki(A,s.dtype),r.shape,r.dtype),shape:r.shape,dtype:r.dtype}}};/** + */const IK={kernelName:J0,backendName:"cpu",kernelFunc:({inputs:t,backend:e,attrs:n})=>{const{x:s,filter:r,dy:o}=t,{strides:i,pad:a,dilations:l}=n,c=e,u=qs(s.shape,c.data.get(s.dataId).values),h=qs(r.shape,c.data.get(r.dataId).values),{batchSize:d,inHeight:f,inWidth:p,inChannels:g,outHeight:x,outWidth:m,padInfo:y,strideHeight:w,strideWidth:v,filterHeight:b,filterWidth:C,dilationHeight:k,dilationWidth:S,outShape:$}=hh(s.shape,r.shape,i,a,"NHWC",l);I(o.rank===$.length,()=>`Error in ${J0}, dy must have the same rank as output ${$.length}, but got ${o.rank}`);const N=qs($,c.data.get(o.dataId).values),A=YI(r.shape,r.dtype);for(let L=0;L=0&&Q=0&&ZO&&(O=se,G=q,X=te)}}}A[G][X][R]+=N[L][V][U][R]}}}return{dataId:c.write(Ki(A,s.dtype),r.shape,r.dtype),shape:r.shape,dtype:r.dtype}}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9827,7 +9827,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const IK={kernelName:Z0,backendName:"cpu",kernelFunc:({inputs:t,backend:e,attrs:n})=>{const{x:s,filter:r,dy:o}=t,{strides:i,pad:a,dilations:l}=n,c=e,u=Xs(s.shape,c.data.get(s.dataId).values),d=Xs(r.shape,c.data.get(r.dataId).values),{batchSize:h,inHeight:f,inWidth:p,inChannels:g,outHeight:x,outWidth:m,padInfo:y,strideHeight:w,strideWidth:v,filterHeight:b,filterWidth:C,dilationHeight:k,dilationWidth:S,outShape:$}=dd(s.shape,r.shape,i,a,"NHWC",l);I(o.rank===$.length,()=>`Error in ${Z0}, dy must have the same rank as output ${$.length}, but got ${o.rank}`);const N=Xs($,c.data.get(o.dataId).values),A=q2(s.shape,s.dtype);for(let L=0;L=0&&Q=0&&ZO&&(O=se,G=Q,X=Z)}}}A[L][G][X][R]+=N[L][V][U][R]}}}return{dataId:c.write(Ki(A,s.dtype),s.shape,s.dtype),shape:s.shape,dtype:s.dtype}}};/** + */const $K={kernelName:Z0,backendName:"cpu",kernelFunc:({inputs:t,backend:e,attrs:n})=>{const{x:s,filter:r,dy:o}=t,{strides:i,pad:a,dilations:l}=n,c=e,u=qs(s.shape,c.data.get(s.dataId).values),h=qs(r.shape,c.data.get(r.dataId).values),{batchSize:d,inHeight:f,inWidth:p,inChannels:g,outHeight:x,outWidth:m,padInfo:y,strideHeight:w,strideWidth:v,filterHeight:b,filterWidth:C,dilationHeight:k,dilationWidth:S,outShape:$}=hh(s.shape,r.shape,i,a,"NHWC",l);I(o.rank===$.length,()=>`Error in ${Z0}, dy must have the same rank as output ${$.length}, but got ${o.rank}`);const N=qs($,c.data.get(o.dataId).values),A=YI(s.shape,s.dtype);for(let L=0;L=0&&Q=0&&ZO&&(O=se,G=Q,X=Z)}}}A[L][G][X][R]+=N[L][V][U][R]}}}return{dataId:c.write(Ki(A,s.dtype),s.shape,s.dtype),shape:s.shape,dtype:s.dtype}}};/** * @license * Copyright 2023 Google LLC. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9842,7 +9842,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function $K(t){const{inputs:e,backend:n,attrs:s}=t,{image:r}=e,{canvas:o,options:i}=s,{contextOptions:a,imageOptions:l}=i||{},c=(l==null?void 0:l.alpha)||1,u=(a==null?void 0:a.contextType)||"2d";if(u!=="2d")throw new Error(`Context type ${a.contextType} is not supported by the CPU backend.`);const d=o.getContext(u,(a==null?void 0:a.contextAttributes)||{});if(d==null)throw new Error(`Could not get the context with ${u} type.`);const[h,f]=r.shape.slice(0,2),p=r.shape.length===2?1:r.shape[2],g=n.data.get(r.dataId).values,x=r.dtype==="float32"?255:1,m=new Uint8ClampedArray(f*h*4);for(let w=0;w1)throw new Error(`Tensor values for a float32 Tensor must be in the range [0 - 1] but encountered ${k}.`)}else if(r.dtype==="int32"&&(k<0||k>255))throw new Error(`Tensor values for a int32 Tensor must be in the range [0 - 255] but encountered ${k}.`);p===1?(v[0]=k*x,v[1]=k*x,v[2]=k*x):v[C]=k*x}const b=w*4;m[b+0]=Math.round(v[0]),m[b+1]=Math.round(v[1]),m[b+2]=Math.round(v[2]),m[b+3]=Math.round(v[3])}o.width=f,o.height=h;const y=new ImageData(m,f,h);return d.putImageData(y,0,0),r}const NK={kernelName:VM,backendName:"cpu",kernelFunc:$K};/** + */function NK(t){const{inputs:e,backend:n,attrs:s}=t,{image:r}=e,{canvas:o,options:i}=s,{contextOptions:a,imageOptions:l}=i||{},c=(l==null?void 0:l.alpha)||1,u=(a==null?void 0:a.contextType)||"2d";if(u!=="2d")throw new Error(`Context type ${a.contextType} is not supported by the CPU backend.`);const h=o.getContext(u,(a==null?void 0:a.contextAttributes)||{});if(h==null)throw new Error(`Could not get the context with ${u} type.`);const[d,f]=r.shape.slice(0,2),p=r.shape.length===2?1:r.shape[2],g=n.data.get(r.dataId).values,x=r.dtype==="float32"?255:1,m=new Uint8ClampedArray(f*d*4);for(let w=0;w1)throw new Error(`Tensor values for a float32 Tensor must be in the range [0 - 1] but encountered ${k}.`)}else if(r.dtype==="int32"&&(k<0||k>255))throw new Error(`Tensor values for a int32 Tensor must be in the range [0 - 255] but encountered ${k}.`);p===1?(v[0]=k*x,v[1]=k*x,v[2]=k*x):v[C]=k*x}const b=w*4;m[b+0]=Math.round(v[0]),m[b+1]=Math.round(v[1]),m[b+2]=Math.round(v[2]),m[b+3]=Math.round(v[3])}o.width=f,o.height=d;const y=new ImageData(m,f,d);return h.putImageData(y,0,0),r}const TK={kernelName:WM,backendName:"cpu",kernelFunc:NK};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9857,7 +9857,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Nd(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{axis:o,keepDims:i}=s;he(r,"sum");let a;r.dtype==="bool"?a=Mo({inputs:{x:r},backend:n,attrs:{dtype:"int32"}}):a=$r({inputs:{x:r},backend:n});const l=a.shape.length,c=Re(o,a.shape),u=yt(c,l);let d=c,h=a;u!=null&&(h=Fn({inputs:{x:a},backend:n,attrs:{perm:u}}),d=$t(d.length,l)),sn("sum",d,h.shape.length);const[f,p]=Yt(h.shape,d),g=Xn(h.dtype,"int32");let x=Ff(n,f,g);const m=j(p),y=n.data.get(x.dataId).values,w=n.data.get(h.dataId).values;for(let v=0;v=0&&(h=Nd({inputs:{x:h},backend:n,attrs:{axis:c[g]-(i.length-f),keepDims:!1}}),p.push(h)),f--)}for(const g of p)g!==h&&n.disposeIntermediateTensorInfo(g);return h}const RK={kernelName:ay,backendName:"cpu",kernelFunc:EK};/** + */function RK(t){const{inputs:e,backend:n,attrs:s}=t,{equation:r}=s,o=e,{allDims:i,summedDims:a,idDims:l}=Ow(r,o.length);Pw(i.length,l,o);const{path:c,steps:u}=Lw(a,l),h=u.length;let d=null,f=i.length;const p=[];for(let g=0;g=0&&(d=Nh({inputs:{x:d},backend:n,attrs:{axis:c[g]-(i.length-f),keepDims:!1}}),p.push(d)),f--)}for(const g of p)g!==d&&n.disposeIntermediateTensorInfo(g);return d}const AK={kernelName:ay,backendName:"cpu",kernelFunc:RK};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9887,7 +9887,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function AK(t){const{inputs:e,backend:n}=t,{dy:s,y:r}=e;he([s,r],"eluGrad");const o=new Float32Array(j(r.shape)),i=n.data.get(r.dataId).values,a=n.data.get(s.dataId).values;for(let l=0;l=0?o[l]=a[l]:o[l]=a[l]*(c+1)}return n.makeTensorInfo(r.shape,"float32",o)}const DK={kernelName:ly,backendName:"cpu",kernelFunc:AK};/** + */function DK(t){const{inputs:e,backend:n}=t,{dy:s,y:r}=e;de([s,r],"eluGrad");const o=new Float32Array(j(r.shape)),i=n.data.get(r.dataId).values,a=n.data.get(s.dataId).values;for(let l=0;l=0?o[l]=a[l]:o[l]=a[l]*(c+1)}return n.makeTensorInfo(r.shape,"float32",o)}const _K={kernelName:ly,backendName:"cpu",kernelFunc:DK};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -9902,7 +9902,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const _K=Ew,FK=Rw,zK=Aw,OK=Dw,MK=_w,PK=Fw,LK=Xe(Tu,t=>{const e=Math.sign(t),n=Math.abs(t),s=1/(1+_K*n);return e*(1-((((PK*s+MK)*s+OK)*s+zK)*s+FK)*s*Math.exp(-n*n))}),BK={kernelName:Tu,backendName:"cpu",kernelFunc:LK};/** + */const FK=Ew,zK=Rw,OK=Aw,MK=Dw,PK=_w,LK=Fw,BK=Xe(Tu,t=>{const e=Math.sign(t),n=Math.abs(t),s=1/(1+FK*n);return e*(1-((((LK*s+PK)*s+MK)*s+OK)*s+zK)*s*Math.exp(-n*n))}),VK={kernelName:Tu,backendName:"cpu",kernelFunc:BK};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9917,7 +9917,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Mf(t){const{inputs:e,backend:n,attrs:s}=t,{input:r}=e,{dim:o}=s,i=r.shape.length,a=r.shape.slice();let l=o;return o<0&&(I(-(i+1)<=o,()=>`Axis must be in the interval [${-(i+1)}, ${i}]`),l=i+o+1),a.splice(l,0,1),st({inputs:{x:r},backend:n,attrs:{shape:a}})}const VK={kernelName:Rp,backendName:"cpu",kernelFunc:Mf};/** + */function Mf(t){const{inputs:e,backend:n,attrs:s}=t,{input:r}=e,{dim:o}=s,i=r.shape.length,a=r.shape.slice();let l=o;return o<0&&(I(-(i+1)<=o,()=>`Axis must be in the interval [${-(i+1)}, ${i}]`),l=i+o+1),a.splice(l,0,1),st({inputs:{x:r},backend:n,attrs:{shape:a}})}const WK={kernelName:Rp,backendName:"cpu",kernelFunc:Mf};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9932,7 +9932,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const WK=Tt((t,e)=>t/e),yv=Wt($u,WK),I1={kernelName:$u,backendName:"cpu",kernelFunc:yv};/** + */const UK=Tt((t,e)=>t/e),yv=Wt($u,UK),I1={kernelName:$u,backendName:"cpu",kernelFunc:yv};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -9947,7 +9947,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function FA(t,e,n){const s=t.shape,r=s[0],o=s[1],i=n.data.get(t.dataId),a=i.complexTensorInfos.real,l=i.complexTensorInfos.imag,c=[r,o],u=j(c),d=cn("float32",u),h=cn("float32",u);for(let x=0;x{const{image:s}=t,r=n,o=cn(s.dtype,j(s.shape)),[i,a,l,c]=s.shape,u=r.data.get(s.dataId).values;for(let h=0;h=0&&w{const{image:s}=t,r=n,o=cn(s.dtype,j(s.shape)),[i,a,l,c]=s.shape,u=r.data.get(s.dataId).values;for(let d=0;d=0&&w=0,()=>`GatherV2: the index value ${b} is not in [0, ${u-1}]`)}let d=a;a==null&&(d=0);const h=j(o.shape),f=Ww(r,o,l,d),p=st({inputs:{x:r},backend:n,attrs:{shape:[f.batchSize,f.outerSize,f.dimSize,f.sliceSize]}}),g=st({inputs:{x:o},backend:n,attrs:{shape:[f.batchSize,h/f.batchSize]}}),x=[f.batchSize,f.outerSize,h/f.batchSize,f.sliceSize],m=n.bufferSync(g),y=n.bufferSync(p),w=HR(y,m,x);return n.disposeIntermediateTensorInfo(p),n.disposeIntermediateTensorInfo(g),n.makeTensorInfo(f.outputShape,w.dtype,w.values)}const rX={kernelName:Dp,backendName:"cpu",kernelFunc:sX};/** + */function rX(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,indices:o}=e,{axis:i,batchDims:a}=s;de([r,o],"gatherV2");const l=Re(i,r.shape)[0],c=n.data.get(o.dataId).values,u=r.shape[l];for(let v=0;v=0,()=>`GatherV2: the index value ${b} is not in [0, ${u-1}]`)}let h=a;a==null&&(h=0);const d=j(o.shape),f=Ww(r,o,l,h),p=st({inputs:{x:r},backend:n,attrs:{shape:[f.batchSize,f.outerSize,f.dimSize,f.sliceSize]}}),g=st({inputs:{x:o},backend:n,attrs:{shape:[f.batchSize,d/f.batchSize]}}),x=[f.batchSize,f.outerSize,d/f.batchSize,f.sliceSize],m=n.bufferSync(g),y=n.bufferSync(p),w=jR(y,m,x);return n.disposeIntermediateTensorInfo(p),n.disposeIntermediateTensorInfo(g),n.makeTensorInfo(f.outputShape,w.dtype,w.values)}const oX={kernelName:Dp,backendName:"cpu",kernelFunc:rX};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10067,7 +10067,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function oX(t){const{inputs:e,backend:n}=t,{input:s}=e,r=j(s.shape),o=s.shape[s.shape.length-1],i=r/o,a=st({inputs:{x:s},backend:n,attrs:{shape:[i,o]}}),l=FA(a,!0,n),c=st({inputs:{x:l},backend:n,attrs:{shape:s.shape}});return n.disposeIntermediateTensorInfo(a),n.disposeIntermediateTensorInfo(l),c}const iX={kernelName:hy,backendName:"cpu",kernelFunc:oX};/** + */function iX(t){const{inputs:e,backend:n}=t,{input:s}=e,r=j(s.shape),o=s.shape[s.shape.length-1],i=r/o,a=st({inputs:{x:s},backend:n,attrs:{shape:[i,o]}}),l=zA(a,!0,n),c=st({inputs:{x:l},backend:n,attrs:{shape:s.shape}});return n.disposeIntermediateTensorInfo(a),n.disposeIntermediateTensorInfo(l),c}const aX={kernelName:dy,backendName:"cpu",kernelFunc:iX};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -10082,7 +10082,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const aX=Xe(zu,t=>Number.isFinite(t)?1:0,"bool"),lX={kernelName:zu,backendName:"cpu",kernelFunc:aX};/** + */const lX=Xe(zu,t=>Number.isFinite(t)?1:0,"bool"),cX={kernelName:zu,backendName:"cpu",kernelFunc:lX};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -10097,7 +10097,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const cX=Xe(Ou,t=>Math.abs(t)===1/0?1:0,"bool"),uX={kernelName:Ou,backendName:"cpu",kernelFunc:cX};/** + */const uX=Xe(Ou,t=>Math.abs(t)===1/0?1:0,"bool"),hX={kernelName:Ou,backendName:"cpu",kernelFunc:uX};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -10112,7 +10112,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const dX=Xe(Mu,t=>Number.isNaN(t)?1:0,"bool"),hX={kernelName:Mu,backendName:"cpu",kernelFunc:dX};/** + */const dX=Xe(Mu,t=>Number.isNaN(t)?1:0,"bool"),fX={kernelName:Mu,backendName:"cpu",kernelFunc:dX};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10127,7 +10127,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function fX(t){const{backend:e,attrs:n}=t,{start:s,stop:r,num:o}=n,i=YR(s,r,o);return e.makeTensorInfo([i.length],"float32",i)}const pX={kernelName:t$,backendName:"cpu",kernelFunc:fX};/** + */function pX(t){const{backend:e,attrs:n}=t,{start:s,stop:r,num:o}=n,i=QR(s,r,o);return e.makeTensorInfo([i.length],"float32",i)}const mX={kernelName:n$,backendName:"cpu",kernelFunc:pX};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -10142,7 +10142,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const mX=Xe(Lu,t=>Math.log1p(t)),gX={kernelName:Lu,backendName:"cpu",kernelFunc:mX};/** + */const gX=Xe(Lu,t=>Math.log1p(t)),xX={kernelName:Lu,backendName:"cpu",kernelFunc:gX};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10157,7 +10157,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const xX=Tt((t,e)=>t&&e),yX=Wt(Mp,xX,null,"bool"),wX={kernelName:Mp,backendName:"cpu",kernelFunc:yX};/** + */const yX=Tt((t,e)=>t&&e),wX=Wt(Mp,yX,null,"bool"),vX={kernelName:Mp,backendName:"cpu",kernelFunc:wX};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -10172,7 +10172,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const vX=Xe(Pp,t=>t?0:1,"bool"),bX={kernelName:Pp,backendName:"cpu",kernelFunc:vX};/** + */const bX=Xe(Pp,t=>t?0:1,"bool"),CX={kernelName:Pp,backendName:"cpu",kernelFunc:bX};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10187,7 +10187,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const CX=Tt((t,e)=>t||e),kX=Wt(Lp,CX,null,"bool"),SX={kernelName:Lp,backendName:"cpu",kernelFunc:kX};/** + */const kX=Tt((t,e)=>t||e),SX=Wt(Lp,kX,null,"bool"),IX={kernelName:Lp,backendName:"cpu",kernelFunc:SX};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10202,7 +10202,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function IX(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{depthRadius:o,bias:i,alpha:a,beta:l}=s;he(r,"LRN");const c=r.shape[3],u=c-1,d=n.data.get(r.dataId).values,h=j(r.shape),f=new Float32Array(h);function p(g){const x=g%c;let m=g-x+Math.max(0,x-o);const y=g-x+Math.min(x+o,u);let w=0;for(;m<=y;m++){const v=d[m];w+=v*v}return w}for(let g=0;g`Error in maxPool: Either strides or dilations must be 1. Got strides ${i} and dilations '${c}'`);const u=Rs(r.shape,o,i,c,a,l);let d;if(u.filterWidth===1&&u.filterHeight===1&&Ue(u.inShape,u.outShape))d=$r({inputs:{x:r},backend:n});else{const h=n.data.get(r.dataId).values,f=pe(r.shape),p=xv(h,r.shape,r.dtype,f,u,"max");d=n.makeTensorInfo(u.outShape,r.dtype,p.values)}return d}const AX={kernelName:Wp,backendName:"cpu",kernelFunc:RX};/** + */function AX(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e;de(r,"maxPool");const{filterSize:o,strides:i,pad:a,dimRoundingMode:l}=s,c=1;I(dn(i,c),()=>`Error in maxPool: Either strides or dilations must be 1. Got strides ${i} and dilations '${c}'`);const u=As(r.shape,o,i,c,a,l);let h;if(u.filterWidth===1&&u.filterHeight===1&&Ue(u.inShape,u.outShape))h=Nr({inputs:{x:r},backend:n});else{const d=n.data.get(r.dataId).values,f=pe(r.shape),p=xv(d,r.shape,r.dtype,f,u,"max");h=n.makeTensorInfo(u.outShape,r.dtype,p.values)}return h}const DX={kernelName:Wp,backendName:"cpu",kernelFunc:AX};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10262,7 +10262,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function DX(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{filterSize:o,strides:i,pad:a,dimRoundingMode:l,dataFormat:c}=s;he(r,"maxPool3d");const u=qr(r.shape,o,i,1,a,l,c),d=n.data.get(r.dataId).values,h=AA(d,r.shape,r.dtype,pe(r.shape),u,"max");return n.makeTensorInfo(h.shape,"float32",h.values)}const _X={kernelName:Up,backendName:"cpu",kernelFunc:DX};/** + */function _X(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{filterSize:o,strides:i,pad:a,dimRoundingMode:l,dataFormat:c}=s;de(r,"maxPool3d");const u=Yr(r.shape,o,i,1,a,l,c),h=n.data.get(r.dataId).values,d=DA(h,r.shape,r.dtype,pe(r.shape),u,"max");return n.makeTensorInfo(d.shape,"float32",d.values)}const FX={kernelName:Up,backendName:"cpu",kernelFunc:_X};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10277,7 +10277,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function FX(t){const{inputs:e,backend:n,attrs:s}=t,{dy:r,input:o}=e,{filterSize:i,strides:a,pad:l,dimRoundingMode:c}=s;he([r,o],"maxPool3DGrad");const u=qr(o.shape,i,a,1,l,c),d=n.bufferSync(o),h=C8(d,u),f=u.strideDepth,p=u.strideHeight,g=u.strideWidth,x=u.dilationDepth,m=u.dilationHeight,y=u.dilationWidth,w=u.effectiveFilterDepth,v=u.effectiveFilterHeight,b=u.effectiveFilterWidth,C=w-1-u.padInfo.front,k=b-1-u.padInfo.left,S=v-1-u.padInfo.top,$=Ee(o.shape,"float32"),N=n.bufferSync(r);for(let A=0;A=u.outDepth||Math.floor(X)!==X))for(let q=0;q=u.outHeight||Math.floor(Q)!==Q))for(let ee=0;ee=u.outWidth||Math.floor(Z)!==Z)continue;const se=w*v*b-1-h.get(A,X,Q,Z,M),ie=G*v*b+q*b+ee,ce=se===ie?1:0;if(ce===0)continue;const ue=N.get(A,X,Q,Z,M);O+=ue*ce}}}$.set(O,A,L,V,B,M)}return n.makeTensorInfo($.shape,$.dtype,$.values)}const zX={kernelName:gy,backendName:"cpu",kernelFunc:FX};/** + */function zX(t){const{inputs:e,backend:n,attrs:s}=t,{dy:r,input:o}=e,{filterSize:i,strides:a,pad:l,dimRoundingMode:c}=s;de([r,o],"maxPool3DGrad");const u=Yr(o.shape,i,a,1,l,c),h=n.bufferSync(o),d=k8(h,u),f=u.strideDepth,p=u.strideHeight,g=u.strideWidth,x=u.dilationDepth,m=u.dilationHeight,y=u.dilationWidth,w=u.effectiveFilterDepth,v=u.effectiveFilterHeight,b=u.effectiveFilterWidth,C=w-1-u.padInfo.front,k=b-1-u.padInfo.left,S=v-1-u.padInfo.top,$=Ee(o.shape,"float32"),N=n.bufferSync(r);for(let A=0;A=u.outDepth||Math.floor(X)!==X))for(let q=0;q=u.outHeight||Math.floor(Q)!==Q))for(let te=0;te=u.outWidth||Math.floor(Z)!==Z)continue;const se=w*v*b-1-d.get(A,X,Q,Z,M),ie=G*v*b+q*b+te,ce=se===ie?1:0;if(ce===0)continue;const ue=N.get(A,X,Q,Z,M);O+=ue*ce}}}$.set(O,A,L,V,B,M)}return n.makeTensorInfo($.shape,$.dtype,$.values)}const OX={kernelName:gy,backendName:"cpu",kernelFunc:zX};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10292,7 +10292,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function OX(t){const{inputs:e,backend:n,attrs:s}=t,{dy:r,input:o,output:i}=e,a=o;he([o,i],"maxPoolGrad");const{filterSize:l,strides:c,pad:u,dimRoundingMode:d}=s,h=Rs(a.shape,l,c,1,u,d),f=n.data.get(a.dataId).values,p=Ee(h.outShape,a.dtype,RA(f,a.shape,a.dtype,h).values),g=h.strideHeight,x=h.strideWidth,m=h.dilationHeight,y=h.dilationWidth,w=h.effectiveFilterHeight,v=h.effectiveFilterWidth,b=v-1-h.padInfo.left,C=w-1-h.padInfo.top,k=Ee(a.shape,"float32"),S=n.data.get(r.dataId).values,$=Ee(r.shape,"float32",S);for(let N=0;N=h.outHeight||Math.floor(R)!==R))for(let O=0;O=h.outWidth||Math.floor(G)!==G)continue;const X=w*v-1-p.get(N,R,G,A),q=K*v+O,Q=X===q?1:0;if(Q===0)continue;const ee=$.get(N,R,G,A);U+=ee*Q}}k.set(U,N,M,L,A)}return n.makeTensorInfo(k.shape,k.dtype,k.values)}const MX={kernelName:my,backendName:"cpu",kernelFunc:OX};/** + */function MX(t){const{inputs:e,backend:n,attrs:s}=t,{dy:r,input:o,output:i}=e,a=o;de([o,i],"maxPoolGrad");const{filterSize:l,strides:c,pad:u,dimRoundingMode:h}=s,d=As(a.shape,l,c,1,u,h),f=n.data.get(a.dataId).values,p=Ee(d.outShape,a.dtype,AA(f,a.shape,a.dtype,d).values),g=d.strideHeight,x=d.strideWidth,m=d.dilationHeight,y=d.dilationWidth,w=d.effectiveFilterHeight,v=d.effectiveFilterWidth,b=v-1-d.padInfo.left,C=w-1-d.padInfo.top,k=Ee(a.shape,"float32"),S=n.data.get(r.dataId).values,$=Ee(r.shape,"float32",S);for(let N=0;N=d.outHeight||Math.floor(R)!==R))for(let O=0;O=d.outWidth||Math.floor(G)!==G)continue;const X=w*v-1-p.get(N,R,G,A),q=K*v+O,Q=X===q?1:0;if(Q===0)continue;const te=$.get(N,R,G,A);U+=te*Q}}k.set(U,N,M,L,A)}return n.makeTensorInfo(k.shape,k.dtype,k.values)}const PX={kernelName:my,backendName:"cpu",kernelFunc:MX};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10307,7 +10307,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function PX(t,e,n,s,r){const o=pe(e),i=xv(t,e,n,o,r,"max"),a=RA(t,e,n,r,!0,s);return[i.values,a.values]}/** + */function LX(t,e,n,s,r){const o=pe(e),i=xv(t,e,n,o,r,"max"),a=AA(t,e,n,r,!0,s);return[i.values,a.values]}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10322,7 +10322,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const LX={kernelName:n$,backendName:"cpu",kernelFunc:({inputs:t,attrs:e,backend:n})=>{const{x:s}=t,{filterSize:r,strides:o,pad:i,includeBatchInIndex:a}=e,l=n;he(s,"MaxPoolWithArgmax");const c=l.data.get(s.dataId).values,u=Rs(s.shape,r,o,[1,1],i),[d,h]=PX(c,s.shape,s.dtype,a,u),f=l.write(d,u.outShape,s.dtype),p=l.write(h,u.outShape,s.dtype);return[{dataId:f,shape:u.outShape,dtype:s.dtype},{dataId:p,shape:u.outShape,dtype:"int32"}]}};/** + */const BX={kernelName:s$,backendName:"cpu",kernelFunc:({inputs:t,attrs:e,backend:n})=>{const{x:s}=t,{filterSize:r,strides:o,pad:i,includeBatchInIndex:a}=e,l=n;de(s,"MaxPoolWithArgmax");const c=l.data.get(s.dataId).values,u=As(s.shape,r,o,[1,1],i),[h,d]=LX(c,s.shape,s.dtype,a,u),f=l.write(h,u.outShape,s.dtype),p=l.write(d,u.outShape,s.dtype);return[{dataId:f,shape:u.outShape,dtype:s.dtype},{dataId:p,shape:u.outShape,dtype:"int32"}]}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10337,7 +10337,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function BX(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{axis:o,keepDims:i}=s,a=Re(o,r.shape),c=Yt(r.shape,a)[1],u=j(c),d=[],h=n.makeTensorInfo([],"float32",new Float32Array([u]));d.push(h);const f=Mo({inputs:{x:r},backend:n,attrs:{dtype:"float32"}});d.push(f);const p=yv({inputs:{a:f,b:h},backend:n});d.push(p);const g=Nd({inputs:{x:p},backend:n,attrs:{axis:o,keepDims:i}});return d.forEach(x=>n.disposeIntermediateTensorInfo(x)),g}const VX={kernelName:Gp,backendName:"cpu",kernelFunc:BX};/** + */function VX(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{axis:o,keepDims:i}=s,a=Re(o,r.shape),c=Yt(r.shape,a)[1],u=j(c),h=[],d=n.makeTensorInfo([],"float32",new Float32Array([u]));h.push(d);const f=Mo({inputs:{x:r},backend:n,attrs:{dtype:"float32"}});h.push(f);const p=yv({inputs:{a:f,b:d},backend:n});h.push(p);const g=Nh({inputs:{x:p},backend:n,attrs:{axis:o,keepDims:i}});return h.forEach(x=>n.disposeIntermediateTensorInfo(x)),g}const WX={kernelName:Gp,backendName:"cpu",kernelFunc:VX};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10352,7 +10352,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function WX(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{axis:o,keepDims:i}=s;he(r,"min");const a=Re(o,r.shape);let l=a;const c=yt(l,r.shape.length);let u=r;c!=null&&(u=Fn({inputs:{x:r},backend:n,attrs:{perm:c}}),l=$t(l.length,r.shape.length)),sn("min",l,u.shape.length);const[d,h]=Yt(u.shape,l),f=j(h),p=un(j(d),u.dtype),g=n.data.get(u.dataId).values;for(let m=0;mw[0]+r.shape[v]+w[1]),l=o.map(w=>w[0]),c=o.map((w,v)=>w[0]+r.shape[v]),u=i==="reflect"?0:1,d=n.data.get(r.dataId).values,h=r.shape.length,f=pe(r.shape),p=j(a),g=a.length,x=pe(a),m=cn(r.dtype,p);for(let w=0;w=c[C]&&(v[C]=(c[C]-1)*2-v[C]+u);v=v.map((C,k)=>C-l[k]);const b=gr(v,h,f);m[w]=d[b]}return{dataId:n.write(m,a,r.dtype),shape:a,dtype:r.dtype}}const HX={kernelName:jp,backendName:"cpu",kernelFunc:GX};/** + */function HX(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{paddings:o,mode:i}=s;de(r,"mirrorPad");const a=o.map((w,v)=>w[0]+r.shape[v]+w[1]),l=o.map(w=>w[0]),c=o.map((w,v)=>w[0]+r.shape[v]),u=i==="reflect"?0:1,h=n.data.get(r.dataId).values,d=r.shape.length,f=pe(r.shape),p=j(a),g=a.length,x=pe(a),m=cn(r.dtype,p);for(let w=0;w=c[C]&&(v[C]=(c[C]-1)*2-v[C]+u);v=v.map((C,k)=>C-l[k]);const b=xr(v,d,f);m[w]=h[b]}return{dataId:n.write(m,a,r.dtype),shape:a,dtype:r.dtype}}const jX={kernelName:jp,backendName:"cpu",kernelFunc:HX};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10382,7 +10382,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const jX=Tt((t,e)=>{const n=t%e;return t<0&&e<0||t>=0&&e>=0?n:(n+e)%e}),KX=Wt(Wu,jX),XX={kernelName:Wu,backendName:"cpu",kernelFunc:KX};/** + */const KX=Tt((t,e)=>{const n=t%e;return t<0&&e<0||t>=0&&e>=0?n:(n+e)%e}),XX=Wt(Wu,KX),qX={kernelName:Wu,backendName:"cpu",kernelFunc:XX};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10397,7 +10397,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function OA(t){const{inputs:e,backend:n,attrs:s}=t,{logits:r}=e,{dim:o}=s,i=r.shape.length;let a=o;if(a===-1&&(a=i-1),a!==i-1)throw Error(`Softmax along a non-last dimension is not yet supported. Logits was rank ${i} and dim was ${a}`);const l=Re([a],r.shape),c=zA({inputs:{x:r},backend:n,attrs:{reductionIndices:l,keepDims:!1}}),u=Dt(c.shape,l),d=st({inputs:{x:c},backend:n,attrs:{shape:u}}),h=gv({inputs:{a:r,b:d},backend:n}),f=BR({inputs:{x:h},backend:n}),p=Nd({inputs:{x:f},backend:n,attrs:{axis:l,keepDims:!1}}),g=st({inputs:{x:p},backend:n,attrs:{shape:u}}),x=yv({inputs:{a:f,b:g},backend:n});return n.disposeIntermediateTensorInfo(c),n.disposeIntermediateTensorInfo(d),n.disposeIntermediateTensorInfo(h),n.disposeIntermediateTensorInfo(f),n.disposeIntermediateTensorInfo(p),n.disposeIntermediateTensorInfo(g),x}const qX={kernelName:um,backendName:"cpu",kernelFunc:OA};/** + */function MA(t){const{inputs:e,backend:n,attrs:s}=t,{logits:r}=e,{dim:o}=s,i=r.shape.length;let a=o;if(a===-1&&(a=i-1),a!==i-1)throw Error(`Softmax along a non-last dimension is not yet supported. Logits was rank ${i} and dim was ${a}`);const l=Re([a],r.shape),c=OA({inputs:{x:r},backend:n,attrs:{reductionIndices:l,keepDims:!1}}),u=Dt(c.shape,l),h=st({inputs:{x:c},backend:n,attrs:{shape:u}}),d=gv({inputs:{a:r,b:h},backend:n}),f=VR({inputs:{x:d},backend:n}),p=Nh({inputs:{x:f},backend:n,attrs:{axis:l,keepDims:!1}}),g=st({inputs:{x:p},backend:n,attrs:{shape:u}}),x=yv({inputs:{a:f,b:g},backend:n});return n.disposeIntermediateTensorInfo(c),n.disposeIntermediateTensorInfo(h),n.disposeIntermediateTensorInfo(d),n.disposeIntermediateTensorInfo(f),n.disposeIntermediateTensorInfo(p),n.disposeIntermediateTensorInfo(g),x}const YX={kernelName:um,backendName:"cpu",kernelFunc:MA};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10412,7 +10412,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function YX(t){const{inputs:e,backend:n,attrs:s}=t,{logits:r}=e,{numSamples:o,seed:i,normalized:a}=s;he(r,"multinomial");const l=a?r:OA({inputs:{logits:r},backend:n,attrs:{dim:-1}}),c=l.shape[0],u=l.shape[1],d=n.data.get(l.dataId).values,h=[c,o],f=un(j(h),"int32");for(let p=0;p=0&&d[h]=0&&h[d]{Lx(o,u.shape,"All tensors passed to stack must have matching shapes"),I(i===u.dtype,()=>"All tensors passed to stack must have matching dtypes")});const a=[],l=e.map(u=>{const d=Mf({inputs:{input:u},backend:n,attrs:{dim:r}});return a.push(d),d}),c=dl({inputs:l,backend:n,attrs:{axis:r}});return a.forEach(u=>n.disposeIntermediateTensorInfo(u)),c}const dq={kernelName:Qp,backendName:"cpu",kernelFunc:PA};/** + */function LA(t){const{inputs:e,backend:n,attrs:s}=t,{axis:r}=s;if(e.length===1)return Mf({inputs:{input:e[0]},backend:n,attrs:{dim:r}});const o=e[0].shape,i=e[0].dtype;e.forEach(u=>{Lx(o,u.shape,"All tensors passed to stack must have matching shapes"),I(i===u.dtype,()=>"All tensors passed to stack must have matching dtypes")});const a=[],l=e.map(u=>{const h=Mf({inputs:{input:u},backend:n,attrs:{dim:r}});return a.push(h),h}),c=hl({inputs:l,backend:n,attrs:{axis:r}});return a.forEach(u=>n.disposeIntermediateTensorInfo(u)),c}const dq={kernelName:Qp,backendName:"cpu",kernelFunc:LA};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10532,7 +10532,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function hq(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{paddings:o,constantValue:i}=s;he(r,"pad");const a=o.map((y,w)=>y[0]+r.shape[w]+y[1]),l=o.map(y=>y[0]),c=n.data.get(r.dataId).values,u=j(r.shape),d=r.shape.length,h=pe(r.shape),f=j(a),p=a.length,g=pe(a),x=cn(r.dtype,f);i!==0&&x.fill(i);for(let y=0;yC+l[k]),b=gr(v,p,g);x[b]=c[y]}return{dataId:n.write(x,a,r.dtype),shape:a,dtype:r.dtype}}const LA={kernelName:Zp,backendName:"cpu",kernelFunc:hq};/** + */function fq(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{paddings:o,constantValue:i}=s;de(r,"pad");const a=o.map((y,w)=>y[0]+r.shape[w]+y[1]),l=o.map(y=>y[0]),c=n.data.get(r.dataId).values,u=j(r.shape),h=r.shape.length,d=pe(r.shape),f=j(a),p=a.length,g=pe(a),x=cn(r.dtype,f);i!==0&&x.fill(i);for(let y=0;yC+l[k]),b=xr(v,p,g);x[b]=c[y]}return{dataId:n.write(x,a,r.dtype),shape:a,dtype:r.dtype}}const BA={kernelName:Zp,backendName:"cpu",kernelFunc:fq};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10547,7 +10547,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const fq=Tt((t,e)=>Math.pow(t,e)),pq=Wt(Gu,fq),mq={kernelName:Gu,backendName:"cpu",kernelFunc:pq};/** + */const pq=Tt((t,e)=>Math.pow(t,e)),mq=Wt(Gu,pq),gq={kernelName:Gu,backendName:"cpu",kernelFunc:mq};/** * @license * Copyright 2022 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10562,7 +10562,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function gq(t){const{inputs:e,backend:n,attrs:s}=t,{paramsNestedSplits:r,paramsDenseValues:o,indices:i}=e,a=r.map(x=>n.data.get(x.dataId).values),l=r.map(x=>x.shape),c=n.data.get(o.dataId).values,u=n.data.get(i.dataId).values,[d,h,f]=rA(a,l,c,o.shape,o.dtype,u,i.shape),p=d.map(x=>n.makeTensorInfo([x.length],"int32",x)),g=n.makeTensorInfo(f,o.dtype,h);return p.concat([g])}const xq={kernelName:r$,backendName:"cpu",kernelFunc:gq};/** + */function xq(t){const{inputs:e,backend:n,attrs:s}=t,{paramsNestedSplits:r,paramsDenseValues:o,indices:i}=e,a=r.map(x=>n.data.get(x.dataId).values),l=r.map(x=>x.shape),c=n.data.get(o.dataId).values,u=n.data.get(i.dataId).values,[h,d,f]=oA(a,l,c,o.shape,o.dtype,u,i.shape),p=h.map(x=>n.makeTensorInfo([x.length],"int32",x)),g=n.makeTensorInfo(f,o.dtype,d);return p.concat([g])}const yq={kernelName:o$,backendName:"cpu",kernelFunc:xq};/** * @license * Copyright 2022 Google LLC. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10577,7 +10577,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function yq(t){const{inputs:e,backend:n}=t,{starts:s,limits:r,deltas:o}=e,i=n.data.get(s.dataId).values,a=n.data.get(r.dataId).values,l=n.data.get(o.dataId).values,[c,u]=oA(i,s.shape,s.dtype,a,r.shape,l,o.shape),d=n.makeTensorInfo([c.length],"int32",c),h=n.makeTensorInfo([u.length],s.dtype,u);return[d,h]}const wq={kernelName:o$,backendName:"cpu",kernelFunc:yq};/** + */function wq(t){const{inputs:e,backend:n}=t,{starts:s,limits:r,deltas:o}=e,i=n.data.get(s.dataId).values,a=n.data.get(r.dataId).values,l=n.data.get(o.dataId).values,[c,u]=iA(i,s.shape,s.dtype,a,r.shape,l,o.shape),h=n.makeTensorInfo([c.length],"int32",c),d=n.makeTensorInfo([u.length],s.dtype,u);return[h,d]}const vq={kernelName:i$,backendName:"cpu",kernelFunc:wq};/** * @license * Copyright 2022 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10592,7 +10592,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function vq(t){const{inputs:e,backend:n,attrs:s}=t,{shape:r,values:o,defaultValue:i,rowPartitionTensors:a}=e,{rowPartitionTypes:l}=s,c=n.data.get(r.dataId).values,u=n.data.get(o.dataId).values,d=n.data.get(i.dataId).values,h=a.map(x=>n.data.get(x.dataId).values),f=a.map(x=>x.shape),[p,g]=iA(c,r.shape,u,o.shape,o.dtype,d,i.shape,h,f,l);return n.makeTensorInfo(p,o.dtype,g)}const bq={kernelName:i$,backendName:"cpu",kernelFunc:vq};/** + */function bq(t){const{inputs:e,backend:n,attrs:s}=t,{shape:r,values:o,defaultValue:i,rowPartitionTensors:a}=e,{rowPartitionTypes:l}=s,c=n.data.get(r.dataId).values,u=n.data.get(o.dataId).values,h=n.data.get(i.dataId).values,d=a.map(x=>n.data.get(x.dataId).values),f=a.map(x=>x.shape),[p,g]=aA(c,r.shape,u,o.shape,o.dtype,h,i.shape,d,f,l);return n.makeTensorInfo(p,o.dtype,g)}const Cq={kernelName:a$,backendName:"cpu",kernelFunc:bq};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10607,7 +10607,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Cq(t){const{backend:e,attrs:n}=t,{start:s,stop:r,dtype:o,step:i}=n,a=aA(s,r,i,o);return e.makeTensorInfo([a.length],o,a)}const kq={kernelName:vy,backendName:"cpu",kernelFunc:Cq};/** + */function kq(t){const{backend:e,attrs:n}=t,{start:s,stop:r,dtype:o,step:i}=n,a=lA(s,r,i,o);return e.makeTensorInfo([a.length],o,a)}const Sq={kernelName:vy,backendName:"cpu",kernelFunc:kq};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -10622,7 +10622,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Sq=Xe(Hu,t=>1/t),Iq={kernelName:Hu,backendName:"cpu",kernelFunc:Sq};/** + */const Iq=Xe(Hu,t=>1/t),$q={kernelName:Hu,backendName:"cpu",kernelFunc:Iq};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10637,7 +10637,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function $q(t){const{inputs:e,backend:n,attrs:s}=t,{images:r}=e,{alignCorners:o,halfPixelCenters:i,size:a}=s;he(r,"resizeBilinear");const l=pe(r.shape),[c,u]=a,[d,h,f,p]=r.shape,g=n.data.get(r.dataId).values,x=new Float32Array(j([d,c,u,p])),m=[o&&c>1?h-1:h,o&&u>1?f-1:f],y=[o&&c>1?c-1:c,o&&u>1?u-1:u];let w=0;const v=m[0]/y[0],b=m[1]/y[1];for(let C=0;C1?d-1:d,o&&u>1?f-1:f],y=[o&&c>1?c-1:c,o&&u>1?u-1:u];let w=0;const v=m[0]/y[0],b=m[1]/y[1];for(let C=0;C1?c-1:c,i&&f>1?u-1:u],x=[i&&h>1?h-1:h,i&&f>1?f-1:f],m=g[0]/x[0],y=g[1]/x[1],w=n.data.get(o.dataId).values;let v=0;for(let b=0;b1?c-1:c,i&&f>1?u-1:u],x=[i&&d>1?d-1:d,i&&f>1?f-1:f],m=g[0]/x[0],y=g[1]/x[1],w=n.data.get(o.dataId).values;let v=0;for(let b=0;b1?h-1:h,o&&u>1?f-1:f],y=[o&&c>1?c-1:c,o&&u>1?u-1:u],w=m[0]/y[0],v=m[1]/y[1];let b=0;for(let C=0;C1?d-1:d,o&&u>1?f-1:f],y=[o&&c>1?c-1:c,o&&u>1?u-1:u],w=m[0]/y[0],v=m[1]/y[1];let b=0;for(let C=0;C1?u-1:u,i&&p>1?d-1:d],y=[i&&f>1?f-1:f,i&&p>1?p-1:p],w=m[0]/y[0],v=m[1]/y[1],b=1/w,C=1/v,k=Math.ceil(b)*2+2,S=Math.ceil(C)*2+2;for(let $=0;$=f)continue;const Q=N+q*l[1],ee=q*w,Z=Math.min(u-1,i?Math.round(ee):Math.floor(ee));if(A===Z)for(let se=0;se=p)continue;const ce=Q+ie*l[2],ue=ie*v,xe=Math.min(d-1,i?Math.round(ue):Math.floor(ue));B===xe&&(G+=x[ce+O])}}g[U+O]=G}}}}return n.makeTensorInfo(r.shape,r.dtype,g)}const _q={kernelName:Cy,backendName:"cpu",kernelFunc:Dq};/** + */function _q(t){const{inputs:e,backend:n,attrs:s}=t,{images:r,dy:o}=e,{alignCorners:i}=s;de([o,r],"resizeNearestNeighborGrad");const a=pe(r.shape),l=pe(o.shape),[c,u,h,d]=r.shape,[,f,p]=o.shape,g=new Float32Array(c*u*h*d),x=n.data.get(o.dataId).values,m=[i&&f>1?u-1:u,i&&p>1?h-1:h],y=[i&&f>1?f-1:f,i&&p>1?p-1:p],w=m[0]/y[0],v=m[1]/y[1],b=1/w,C=1/v,k=Math.ceil(b)*2+2,S=Math.ceil(C)*2+2;for(let $=0;$=f)continue;const Q=N+q*l[1],te=q*w,Z=Math.min(u-1,i?Math.round(te):Math.floor(te));if(A===Z)for(let se=0;se=p)continue;const ce=Q+ie*l[2],ue=ie*v,xe=Math.min(h-1,i?Math.round(ue):Math.floor(ue));B===xe&&(G+=x[ce+O])}}g[U+O]=G}}}}return n.makeTensorInfo(r.shape,r.dtype,g)}const Fq={kernelName:Cy,backendName:"cpu",kernelFunc:_q};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10697,7 +10697,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Fq(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{dims:o}=s;he(r,"reverse");const i=r.shape.length,a=Re(o,r.shape);if(i===0)return $r({inputs:{x:r},backend:n});const l=new tn(r.shape,r.dtype),c=n.bufferSync(r);for(let u=0;uh[f]=r.shape[f]-1-h[f]),l.set(c.get(...h),...d)}return n.makeTensorInfo(l.shape,l.dtype,l.values)}const zq={kernelName:rm,backendName:"cpu",kernelFunc:Fq};/** + */function zq(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{dims:o}=s;de(r,"reverse");const i=r.shape.length,a=Re(o,r.shape);if(i===0)return Nr({inputs:{x:r},backend:n});const l=new tn(r.shape,r.dtype),c=n.bufferSync(r);for(let u=0;ud[f]=r.shape[f]-1-d[f]),l.set(c.get(...d),...h)}return n.makeTensorInfo(l.shape,l.dtype,l.values)}const Oq={kernelName:rm,backendName:"cpu",kernelFunc:zq};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10712,7 +10712,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Oq={kernelName:Ry,backendName:"cpu",kernelFunc:({inputs:t,attrs:e,backend:n})=>{const{image:s}=t,{radians:r,fillValue:o,center:i}=e,a=n,l=cn(s.dtype,j(s.shape)),[c,u,d,h]=s.shape,[f,p]=$w(i,u,d),g=255,x=Math.sin(r),m=Math.cos(r),y=a.data.get(s.dataId).values;for(let v=0;v=0&&V=0&&B{const{image:s}=t,{radians:r,fillValue:o,center:i}=e,a=n,l=cn(s.dtype,j(s.shape)),[c,u,h,d]=s.shape,[f,p]=$w(i,u,h),g=255,x=Math.sin(r),m=Math.cos(r),y=a.data.get(s.dataId).values;for(let v=0;v=0&&V=0&&B{const e=Math.floor(t);return t-e<.5?Math.floor(t):t-e>.5?Math.ceil(t):e%2===0?e:e+1}),Pq={kernelName:Xu,backendName:"cpu",kernelFunc:Mq};/** + */const Pq=Xe(Xu,t=>{const e=Math.floor(t);return t-e<.5?Math.floor(t):t-e>.5?Math.ceil(t):e%2===0?e:e+1}),Lq={kernelName:Xu,backendName:"cpu",kernelFunc:Pq};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10742,7 +10742,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Lq(t){const{inputs:e,backend:n,attrs:s}=t,{indices:r,updates:o}=e,{shape:i}=s,{sliceRank:a,numUpdates:l,sliceSize:c,strides:u,outputSize:d}=Qi(o,r,i),h=!0,f=n.bufferSync(r),p=n.bufferSync(o),g=pi(f,p,i,d,c,l,a,u,0,h);return n.makeTensorInfo(i,g.dtype,g.values)}const Bq={kernelName:a$,backendName:"cpu",kernelFunc:Lq};/** + */function Bq(t){const{inputs:e,backend:n,attrs:s}=t,{indices:r,updates:o}=e,{shape:i}=s,{sliceRank:a,numUpdates:l,sliceSize:c,strides:u,outputSize:h}=Qi(o,r,i),d=!0,f=n.bufferSync(r),p=n.bufferSync(o),g=pi(f,p,i,h,c,l,a,u,0,d);return n.makeTensorInfo(i,g.dtype,g.values)}const Vq={kernelName:l$,backendName:"cpu",kernelFunc:Bq};/** * @license * Copyright 2022 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10757,7 +10757,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Vq(t,e){let n=0,s=t.length,r=0;for(;n1||r.shape.length===1?1:j(r.shape.slice(1));for(let p=0;p1||r.shape.length===1?1:j(r.shape.slice(1));for(let p=0;pt>=0?qq*t:Xq*(Math.exp(t)-1)),Qq={kernelName:Yu,backendName:"cpu",kernelFunc:Yq};/** + */const qq=km,Yq=Sm,Qq=Xe(Yu,t=>t>=0?Yq*t:qq*(Math.exp(t)-1)),Zq={kernelName:Yu,backendName:"cpu",kernelFunc:Qq};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -10817,7 +10817,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Zq=Xe(Ju,t=>t<0?-1:t>0?1:0),Jq={kernelName:Ju,backendName:"cpu",kernelFunc:Zq};/** + */const Jq=Xe(Ju,t=>t<0?-1:t>0?1:0),e7={kernelName:Ju,backendName:"cpu",kernelFunc:Jq};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -10832,7 +10832,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const e7=Xe(Qu,t=>Math.sin(t)),t7={kernelName:Qu,backendName:"cpu",kernelFunc:e7};/** + */const t7=Xe(Qu,t=>Math.sin(t)),n7={kernelName:Qu,backendName:"cpu",kernelFunc:t7};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -10847,7 +10847,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const n7=Xe(Zu,t=>Math.sinh(t)),s7={kernelName:Zu,backendName:"cpu",kernelFunc:n7};/** + */const s7=Xe(Zu,t=>Math.sinh(t)),r7={kernelName:Zu,backendName:"cpu",kernelFunc:s7};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -10862,7 +10862,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const r7=11920928955078125e-23,vk=Math.log(r7)+2,o7=Xe(td,t=>{const e=t>-vk,n=t{const e=t>-vk,n=tNumber(x)))),n.makeTensorInfo([g.length],s.dtype,new Int32Array(g))]}const u7={kernelName:u$,backendName:"cpu",kernelFunc:c7};/** + ${i.shape}`);const a=n.data.get(s.dataId).values,l=n.data.get(r.dataId).values,c=n.data.get(o.dataId).values,u=n.data.get(i.dataId).values[0],[h,d,f,p,g]=dA(a,s.shape,s.dtype,l,r.dtype,c,u);return[n.makeTensorInfo(d,s.dtype,h),n.makeTensorInfo([d[0]],r.dtype,f),n.makeTensorInfo([p.length],"bool",new Uint8Array(p.map(x=>Number(x)))),n.makeTensorInfo([g.length],s.dtype,new Int32Array(g))]}const h7={kernelName:h$,backendName:"cpu",kernelFunc:u7};/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10913,7 +10913,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * ============================================================================= */function d7(t){const{inputs:e,backend:n}=t,{inputIndices:s,inputShape:r,newShape:o}=e;if(s.shape.length!==2)throw new Error(`Input indices should be a matrix but received shape ${s.shape}`);if(r.shape.length!==1)throw new Error(`Input shape should be a vector but received shape - ${r.shape}`);if(o.shape.length!==1)throw new Error(`Target shape should be a vector but received shape ${o.shape}`);const i=Array.from(n.data.get(r.dataId).values),a=n.data.get(s.dataId).values,l=Array.from(n.data.get(o.dataId).values),[c,u,d]=hA(a,s.shape,s.dtype,i,l);return[n.makeTensorInfo(u,s.dtype,c),n.makeTensorInfo([d.length],o.dtype,new Int32Array(d))]}const h7={kernelName:d$,backendName:"cpu",kernelFunc:d7};/** + ${r.shape}`);if(o.shape.length!==1)throw new Error(`Target shape should be a vector but received shape ${o.shape}`);const i=Array.from(n.data.get(r.dataId).values),a=n.data.get(s.dataId).values,l=Array.from(n.data.get(o.dataId).values),[c,u,h]=fA(a,s.shape,s.dtype,i,l);return[n.makeTensorInfo(u,s.dtype,c),n.makeTensorInfo([h.length],o.dtype,new Int32Array(h))]}const f7={kernelName:d$,backendName:"cpu",kernelFunc:d7};/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10928,9 +10928,9 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function f7(t){const{inputs:e,backend:n}=t,{data:s,indices:r,segmentIds:o}=e;if(s.shape.length<1)throw new Error("Data should be at least 1 dimensional but received scalar");if(r.shape.length!==1)throw new Error(`Indices should be a vector but received shape + */function p7(t){const{inputs:e,backend:n}=t,{data:s,indices:r,segmentIds:o}=e;if(s.shape.length<1)throw new Error("Data should be at least 1 dimensional but received scalar");if(r.shape.length!==1)throw new Error(`Indices should be a vector but received shape ${r.shape}`);if(o.shape.length!==1)throw new Error(`Segment ids should be a vector but received shape - ${o.shape}`);if(r.shape[0]!==o.shape[0])throw new Error("segmentIds and indices should have same size.");const i=n.data.get(s.dataId).values,a=n.data.get(r.dataId).values,l=n.data.get(o.dataId).values,[c,u]=mv(i,s.shape,s.dtype,a,l,!0);return n.makeTensorInfo(u,s.dtype,c)}const p7={kernelName:h$,backendName:"cpu",kernelFunc:f7};/** + ${o.shape}`);if(r.shape[0]!==o.shape[0])throw new Error("segmentIds and indices should have same size.");const i=n.data.get(s.dataId).values,a=n.data.get(r.dataId).values,l=n.data.get(o.dataId).values,[c,u]=mv(i,s.shape,s.dtype,a,l,!0);return n.makeTensorInfo(u,s.dtype,c)}const m7={kernelName:f$,backendName:"cpu",kernelFunc:p7};/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10945,9 +10945,9 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function m7(t){const{inputs:e,backend:n}=t,{data:s,indices:r,segmentIds:o}=e;if(s.shape.length<1)throw new Error("Data should be at least 1 dimensional but received scalar");if(r.shape.length!==1)throw new Error(`Indices should be a vector but received shape + */function g7(t){const{inputs:e,backend:n}=t,{data:s,indices:r,segmentIds:o}=e;if(s.shape.length<1)throw new Error("Data should be at least 1 dimensional but received scalar");if(r.shape.length!==1)throw new Error(`Indices should be a vector but received shape ${r.shape}`);if(o.shape.length!==1)throw new Error(`Segment ids should be a vector but received shape - ${o.shape}`);if(r.shape[0]!==o.shape[0])throw new Error("segmentIds and indices should have same size.");const i=n.data.get(s.dataId).values,a=n.data.get(r.dataId).values,l=n.data.get(o.dataId).values,[c,u]=mv(i,s.shape,s.dtype,a,l);return n.makeTensorInfo(u,s.dtype,c)}const g7={kernelName:f$,backendName:"cpu",kernelFunc:m7};/** + ${o.shape}`);if(r.shape[0]!==o.shape[0])throw new Error("segmentIds and indices should have same size.");const i=n.data.get(s.dataId).values,a=n.data.get(r.dataId).values,l=n.data.get(o.dataId).values,[c,u]=mv(i,s.shape,s.dtype,a,l);return n.makeTensorInfo(u,s.dtype,c)}const x7={kernelName:p$,backendName:"cpu",kernelFunc:g7};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10962,7 +10962,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function x7(t){const{inputs:e,backend:n,attrs:s}=t,{sparseIndices:r,sparseValues:o,defaultValue:i}=e,{outputShape:a}=s,{sliceRank:l,numUpdates:c,sliceSize:u,strides:d,outputSize:h}=Qi(o,r,a),f=!1,p=n.bufferSync(r);let g;switch(o.dtype){case"bool":{const x=n.bufferSync(o),m=!!n.data.get(i.dataId).values[0];g=pi(p,x,a,h,u,c,l,d,m,f);break}case"float32":{const x=n.bufferSync(o),m=n.data.get(i.dataId).values[0];g=pi(p,x,a,h,u,c,l,d,m,f);break}case"int32":{const x=n.bufferSync(o),m=n.data.get(i.dataId).values[0];g=pi(p,x,a,h,u,c,l,d,m,f);break}case"string":{const x=n.bufferSync(o),m=Do(n.data.get(i.dataId).values[0]);g=pi(p,x,a,h,u,c,l,d,m,f);break}default:throw new Error(`Unsupported type ${o.dtype}`)}return n.makeTensorInfo(a,g.dtype,g.values)}const y7={kernelName:p$,backendName:"cpu",kernelFunc:x7};/** + */function y7(t){const{inputs:e,backend:n,attrs:s}=t,{sparseIndices:r,sparseValues:o,defaultValue:i}=e,{outputShape:a}=s,{sliceRank:l,numUpdates:c,sliceSize:u,strides:h,outputSize:d}=Qi(o,r,a),f=!1,p=n.bufferSync(r);let g;switch(o.dtype){case"bool":{const x=n.bufferSync(o),m=!!n.data.get(i.dataId).values[0];g=pi(p,x,a,d,u,c,l,h,m,f);break}case"float32":{const x=n.bufferSync(o),m=n.data.get(i.dataId).values[0];g=pi(p,x,a,d,u,c,l,h,m,f);break}case"int32":{const x=n.bufferSync(o),m=n.data.get(i.dataId).values[0];g=pi(p,x,a,d,u,c,l,h,m,f);break}case"string":{const x=n.bufferSync(o),m=Do(n.data.get(i.dataId).values[0]);g=pi(p,x,a,d,u,c,l,h,m,f);break}default:throw new Error(`Unsupported type ${o.dtype}`)}return n.makeTensorInfo(a,g.dtype,g.values)}const w7={kernelName:m$,backendName:"cpu",kernelFunc:y7};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10977,7 +10977,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function w7(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{numOrSizeSplits:o,axis:i}=s,a=Re(i,r.shape)[0],l=Vw(r,o,a),c=new Array(r.shape.length).fill(0),u=r.shape.slice();return l.map(d=>{const h=[...u];h[a]=d;const f=Vi({inputs:{x:r},backend:n,attrs:{begin:c,size:h}});return c[a]+=d,f})}const v7={kernelName:cm,backendName:"cpu",kernelFunc:w7};/** + */function v7(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{numOrSizeSplits:o,axis:i}=s,a=Re(i,r.shape)[0],l=Vw(r,o,a),c=new Array(r.shape.length).fill(0),u=r.shape.slice();return l.map(h=>{const d=[...u];d[a]=h;const f=Vi({inputs:{x:r},backend:n,attrs:{begin:c,size:d}});return c[a]+=h,f})}const b7={kernelName:cm,backendName:"cpu",kernelFunc:v7};/** * @license * Copyright 2019 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -10992,7 +10992,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const b7={kernelName:Sy,backendName:"cpu",kernelFunc:({inputs:t,backend:e})=>{const{x:n}=t,s=e;he(n,"square");const r=s.data.get(n.dataId).values,o=new Float32Array(r.length);for(let a=0;a{const{x:n}=t,s=e;de(n,"square");const r=s.data.get(n.dataId).values,o=new Float32Array(r.length);for(let a=0;a{const n=e;return isNaN(t)?NaN:t>0?1:n.alpha}),k7={kernelName:ld,backendName:"cpu",kernelFunc:C7};/** + */const k7=Xe(lh,(t,e)=>{const n=e;return isNaN(t)?NaN:t>0?1:n.alpha}),S7={kernelName:lh,backendName:"cpu",kernelFunc:k7};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -11022,7 +11022,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function S7(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{begin:o,end:i,strides:a,beginMask:l,endMask:c,ellipsisMask:u,newAxisMask:d,shrinkAxisMask:h}=s;he(r,"stridedSlice");const{finalShapeSparse:f,finalShape:p,isIdentity:g,sliceDim0:x,isSimpleSlice:m,begin:y,end:w,strides:v}=kw(r.shape,o,i,a,l,c,u,d,h);let b;if(g)b=st({inputs:{x:r},backend:n,attrs:{shape:p}});else if(x||m){I(r.shape.length>=1,()=>`Input must have rank at least 1, got: ${r.shape.length}`);const C=vw(y,w,v),k=Vi({inputs:{x:r},backend:n,attrs:{begin:y,size:C}});b=st({inputs:{x:k},backend:n,attrs:{shape:p}}),n.disposeIntermediateTensorInfo(k)}else{const C=n.bufferSync(r),k=mA(f,C,v,y);b=n.makeTensorInfo(p,k.dtype,k.values)}return b}const I7={kernelName:$y,backendName:"cpu",kernelFunc:S7};/** + */function I7(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{begin:o,end:i,strides:a,beginMask:l,endMask:c,ellipsisMask:u,newAxisMask:h,shrinkAxisMask:d}=s;de(r,"stridedSlice");const{finalShapeSparse:f,finalShape:p,isIdentity:g,sliceDim0:x,isSimpleSlice:m,begin:y,end:w,strides:v}=kw(r.shape,o,i,a,l,c,u,h,d);let b;if(g)b=st({inputs:{x:r},backend:n,attrs:{shape:p}});else if(x||m){I(r.shape.length>=1,()=>`Input must have rank at least 1, got: ${r.shape.length}`);const C=vw(y,w,v),k=Vi({inputs:{x:r},backend:n,attrs:{begin:y,size:C}});b=st({inputs:{x:k},backend:n,attrs:{shape:p}}),n.disposeIntermediateTensorInfo(k)}else{const C=n.bufferSync(r),k=gA(f,C,v,y);b=n.makeTensorInfo(p,k.dtype,k.values)}return b}const $7={kernelName:$y,backendName:"cpu",kernelFunc:I7};/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -11037,7 +11037,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function $7(t){const{inputs:e,backend:n,attrs:s}=t,{separator:r,nGramWidths:o,leftPad:i,rightPad:a,padWidth:l,preserveShortSequences:c}=s,{data:u,dataSplits:d}=e,h=n.data.get(u.dataId).values,f=n.data.get(d.dataId).values,[p,g]=gA(h,f,r,o,i,a,l,c);return[n.makeTensorInfo([p.length],"string",p),n.makeTensorInfo(d.shape,"int32",g)]}const N7={kernelName:m$,backendName:"cpu",kernelFunc:$7};/** + */function N7(t){const{inputs:e,backend:n,attrs:s}=t,{separator:r,nGramWidths:o,leftPad:i,rightPad:a,padWidth:l,preserveShortSequences:c}=s,{data:u,dataSplits:h}=e,d=n.data.get(u.dataId).values,f=n.data.get(h.dataId).values,[p,g]=xA(d,f,r,o,i,a,l,c);return[n.makeTensorInfo([p.length],"string",p),n.makeTensorInfo(h.shape,"int32",g)]}const T7={kernelName:g$,backendName:"cpu",kernelFunc:N7};/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -11052,7 +11052,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function T7(t){const{inputs:e,backend:n,attrs:s}=t,{skipEmpty:r}=s,{input:o,delimiter:i}=e;if(o.dtype!=="string")throw new Error("Input must be of datatype string");if(o.shape.length!==1)throw new Error(`Input must be a vector, got shape: ${o.shape}`);if(i.shape.length!==0)throw new Error(`Delimiter must be a scalar, got shape: ${i.shape}`);const a=n.data.get(o.dataId).values,l=n.data.get(i.dataId).values[0],[c,u,d]=xA(a,l,r),h=u.length;return[n.makeTensorInfo([h,2],"int32",c),n.makeTensorInfo([h],"string",u),n.makeTensorInfo([2],"int32",new Int32Array(d))]}const E7={kernelName:g$,backendName:"cpu",kernelFunc:T7};/** + */function E7(t){const{inputs:e,backend:n,attrs:s}=t,{skipEmpty:r}=s,{input:o,delimiter:i}=e;if(o.dtype!=="string")throw new Error("Input must be of datatype string");if(o.shape.length!==1)throw new Error(`Input must be a vector, got shape: ${o.shape}`);if(i.shape.length!==0)throw new Error(`Delimiter must be a scalar, got shape: ${i.shape}`);const a=n.data.get(o.dataId).values,l=n.data.get(i.dataId).values[0],[c,u,h]=yA(a,l,r),d=u.length;return[n.makeTensorInfo([d,2],"int32",c),n.makeTensorInfo([d],"string",u),n.makeTensorInfo([2],"int32",new Int32Array(h))]}const R7={kernelName:x$,backendName:"cpu",kernelFunc:E7};/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -11067,7 +11067,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function R7(t){const{inputs:e,backend:n,attrs:s}=t,{numBuckets:r}=s,{input:o}=e;if(o.dtype!=="string")throw new Error("Input must be of datatype string");if(r<=0)throw new Error("Number of buckets must be at least 1");const i=n.data.get(o.dataId).values,a=yA(i,r);return n.makeTensorInfo(o.shape,"int32",a)}const A7={kernelName:x$,backendName:"cpu",kernelFunc:R7};/** + */function A7(t){const{inputs:e,backend:n,attrs:s}=t,{numBuckets:r}=s,{input:o}=e;if(o.dtype!=="string")throw new Error("Input must be of datatype string");if(r<=0)throw new Error("Number of buckets must be at least 1");const i=n.data.get(o.dataId).values,a=wA(i,r);return n.makeTensorInfo(o.shape,"int32",a)}const D7={kernelName:y$,backendName:"cpu",kernelFunc:A7};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -11082,7 +11082,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const D7=Xe(od,t=>Math.tan(t)),_7={kernelName:od,backendName:"cpu",kernelFunc:D7};/** + */const _7=Xe(oh,t=>Math.tan(t)),F7={kernelName:oh,backendName:"cpu",kernelFunc:_7};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -11097,7 +11097,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const F7=Xe(id,t=>Math.tanh(t)),z7={kernelName:id,backendName:"cpu",kernelFunc:F7};/** + */const z7=Xe(ih,t=>Math.tanh(t)),O7={kernelName:ih,backendName:"cpu",kernelFunc:z7};/** * @license * Copyright 2022 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -11112,7 +11112,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function O7(t){const{inputs:e,backend:n}=t,{tensor:s,indices:r,updates:o}=e,{sliceRank:i,numUpdates:a,sliceSize:l,strides:c,outputSize:u}=Qi(o,r,s.shape),d=!1,h=n.bufferSync(r),f=n.bufferSync(o),p=n.bufferSync(s),g=pi(h,f,s.shape,u,l,a,i,c,p,d);return n.makeTensorInfo(s.shape,g.dtype,g.values)}const M7={kernelName:l$,backendName:"cpu",kernelFunc:O7};/** + */function M7(t){const{inputs:e,backend:n}=t,{tensor:s,indices:r,updates:o}=e,{sliceRank:i,numUpdates:a,sliceSize:l,strides:c,outputSize:u}=Qi(o,r,s.shape),h=!1,d=n.bufferSync(r),f=n.bufferSync(o),p=n.bufferSync(s),g=pi(d,f,s.shape,u,l,a,i,c,p,h);return n.makeTensorInfo(s.shape,g.dtype,g.values)}const P7={kernelName:c$,backendName:"cpu",kernelFunc:M7};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -11127,7 +11127,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function P7(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{reps:o}=s;he(r,"tile");const i=vA(n.bufferSync(r),o);return n.makeTensorInfo(i.shape,i.dtype,i.values)}const L7={kernelName:ad,backendName:"cpu",kernelFunc:P7};/** + */function L7(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{reps:o}=s;de(r,"tile");const i=bA(n.bufferSync(r),o);return n.makeTensorInfo(i.shape,i.dtype,i.values)}const B7={kernelName:ah,backendName:"cpu",kernelFunc:L7};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -11142,7 +11142,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function B7(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{k:o,sorted:i}=s;he(r,"topk");const a=n.data.get(r.dataId).values,[l,c]=CA(a,r.shape,r.dtype,o,i);return[n.makeTensorInfo(l.shape,l.dtype,l.values),n.makeTensorInfo(c.shape,c.dtype,c.values)]}const V7={kernelName:Ny,backendName:"cpu",kernelFunc:B7};/** + */function V7(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{k:o,sorted:i}=s;de(r,"topk");const a=n.data.get(r.dataId).values,[l,c]=kA(a,r.shape,r.dtype,o,i);return[n.makeTensorInfo(l.shape,l.dtype,l.values),n.makeTensorInfo(c.shape,c.dtype,c.values)]}const W7={kernelName:Ny,backendName:"cpu",kernelFunc:V7};/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -11157,7 +11157,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function W7(t){const{inputs:e,attrs:n,backend:s}=t,{image:r,transforms:o}=e,{interpolation:i,fillMode:a,fillValue:l,outputShape:c}=n,[u,d,h,f]=r.shape,[p,g]=c??[d,h],x=[u,p,g,f],m=pe(r.shape),y=m[0],w=m[1],v=m[2],b=pe(x),C=b[0],k=b[1],S=b[2],$=cn(r.dtype,j(x));$.fill(l);const N=s.data.get(r.dataId).values,A=s.data.get(o.dataId).values;for(let L=0;Le-1)if(e<=1)n=0;else{const s=2*e;n-=s*Math.trunc(n/s),n>=e&&(n=s-n-1)}return Ti(0,n,e-1)}function H7(t,e){let n=t;if(n<0)if(e<=1)n=0;else{const s=e-1;n+=e*(Math.trunc(-n/s)+1)}else if(n>e-1)if(e<=1)n=0;else{const s=e-1;n-=e*Math.trunc(n/s)}return Ti(0,n,e-1)}function j7(t,e){return t}function K7(t,e){return Ti(0,t,e-1)}function lc(t,e,n,s,r,o,i,a,l,c,u){const d=i*s+a*r+l*o+c;return 0<=a&&ae-1)if(e<=1)n=0;else{const s=2*e;n-=s*Math.trunc(n/s),n>=e&&(n=s-n-1)}return Ti(0,n,e-1)}function j7(t,e){let n=t;if(n<0)if(e<=1)n=0;else{const s=e-1;n+=e*(Math.trunc(-n/s)+1)}else if(n>e-1)if(e<=1)n=0;else{const s=e-1;n-=e*Math.trunc(n/s)}return Ti(0,n,e-1)}function K7(t,e){return t}function X7(t,e){return Ti(0,t,e-1)}function lc(t,e,n,s,r,o,i,a,l,c,u){const h=i*s+a*r+l*o+c;return 0<=a&&an.disposeIntermediateTensorInfo(p)),f}const t9={kernelName:hm,backendName:"cpu",kernelFunc:e9};/** + */function t9(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,segmentIds:o}=e,{numSegments:i}=s;de(r,"unsortedSegmentSum");const a=r.shape.length,l=o.shape.length,c=[],u=[],h=a-l;let d=o;for(let p=0;pn.disposeIntermediateTensorInfo(p)),f}const n9={kernelName:dm,backendName:"cpu",kernelFunc:t9};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -11217,7 +11217,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const n9=[Yj,RH,Zj,e8,OH,n8,r8,i8,l8,u8,h8,p8,g8,w8,b8,S8,$8,T8,R8,Xj,D8,F8,O8,PH,P8,FH,BH,B8,AH,W8,G8,H8,K8,q8,Q8,J8,tK,sK,oK,aK,cK,dK,fK,mK,gK,yK,vK,CK,kK,SK,IK,NK,RK,Vj,DK,VH,BK,WH,VK,GH,KK,XK,YK,jH,XH,ZK,eX,nX,rX,YH,ZH,DH,iX,U8,lX,uX,hX,Wj,ej,nj,pX,rj,gX,wX,bX,SX,$X,TX,EX,ij,AX,_X,zX,MX,LX,VX,UX,lj,HX,XX,QX,uj,hj,eq,sq,iq,pj,lq,uq,dq,LA,mq,Gj,xj,xq,wq,bq,kq,_H,I1,Iq,Hj,jj,Kj,Nq,Eq,Aq,_q,zq,Oq,Pq,Ij,Bq,Hq,Kq,Qq,Nj,Jq,t7,s7,Tj,qX,i7,l7,u7,h7,p7,g7,y7,v7,Aj,b7,_j,zj,k7,I7,N7,E7,A7,Lj,TK,_7,z7,M7,L7,V7,U7,mj,Q7,J7,t9,cq];for(const t of n9)w$(t);/** + */const s9=[Qj,AH,Jj,t8,MH,s8,o8,a8,c8,h8,f8,m8,x8,v8,C8,I8,N8,E8,A8,qj,_8,z8,M8,LH,L8,zH,VH,V8,DH,U8,H8,j8,X8,Y8,Z8,eK,nK,rK,iK,lK,uK,dK,pK,gK,xK,wK,bK,kK,SK,IK,$K,TK,AK,Wj,_K,WH,VK,UH,WK,HH,XK,qK,QK,KH,qH,JK,tX,sX,oX,QH,JH,_H,aX,G8,cX,hX,fX,Uj,tj,sj,mX,oj,xX,vX,CX,IX,NX,EX,RX,aj,DX,FX,OX,PX,BX,WX,GX,cj,jX,qX,ZX,hj,fj,tq,rq,aq,mj,cq,hq,dq,BA,gq,Hj,yj,yq,vq,Cq,Sq,FH,I1,$q,jj,Kj,Xj,Tq,Rq,Dq,Fq,Oq,Mq,Lq,$j,Vq,jq,Xq,Zq,Tj,e7,n7,r7,Ej,YX,a7,c7,h7,f7,m7,x7,w7,b7,Dj,C7,Fj,Oj,S7,$7,T7,R7,D7,Bj,EK,F7,O7,P7,B7,W7,G7,gj,Z7,e9,n9,uq];for(const t of s9)v$(t);/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -11232,7 +11232,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const ai={},rh={alpha:!1,antialias:!1,premultipliedAlpha:!1,preserveDrawingBuffer:!1,depth:!1,stencil:!1,failIfMajorPerformanceCaveat:!0};function s9(t,e){ai[t]=e}function er(t,e){if(!(t in ai)||e!=null){const s=o9(t,e);if(s!==null)ai[t]=s;else return console.log("Could not get context for WebGL version",t),null}const n=ai[t];return n==null||n.isContextLost()?(delete ai[t],er(t)):(n.disable(n.DEPTH_TEST),n.disable(n.STENCIL_TEST),n.disable(n.BLEND),n.disable(n.DITHER),n.disable(n.POLYGON_OFFSET_FILL),n.disable(n.SAMPLE_COVERAGE),n.enable(n.SCISSOR_TEST),n.enable(n.CULL_FACE),n.cullFace(n.BACK),ai[t])}function r9(t){if(!W().getBool("IS_SAFARI")&&typeof OffscreenCanvas<"u"&&t===2)return new OffscreenCanvas(300,150);if(typeof document<"u")return document.createElement("canvas");throw new Error("Cannot create a canvas in this context")}function o9(t,e){if(t!==1&&t!==2)throw new Error("Cannot get WebGL rendering context, WebGL is disabled.");const n=e??r9(t);return n.addEventListener("webglcontextlost",s=>{s.preventDefault(),delete ai[t]},!1),W().getBool("SOFTWARE_WEBGL_ENABLED")&&(rh.failIfMajorPerformanceCaveat=!1),t===1?n.getContext("webgl",rh)||n.getContext("experimental-webgl",rh):n.getContext("webgl2",rh)}/** + */const ai={},rd={alpha:!1,antialias:!1,premultipliedAlpha:!1,preserveDrawingBuffer:!1,depth:!1,stencil:!1,failIfMajorPerformanceCaveat:!0};function r9(t,e){ai[t]=e}function tr(t,e){if(!(t in ai)||e!=null){const s=i9(t,e);if(s!==null)ai[t]=s;else return console.log("Could not get context for WebGL version",t),null}const n=ai[t];return n==null||n.isContextLost()?(delete ai[t],tr(t)):(n.disable(n.DEPTH_TEST),n.disable(n.STENCIL_TEST),n.disable(n.BLEND),n.disable(n.DITHER),n.disable(n.POLYGON_OFFSET_FILL),n.disable(n.SAMPLE_COVERAGE),n.enable(n.SCISSOR_TEST),n.enable(n.CULL_FACE),n.cullFace(n.BACK),ai[t])}function o9(t){if(!W().getBool("IS_SAFARI")&&typeof OffscreenCanvas<"u"&&t===2)return new OffscreenCanvas(300,150);if(typeof document<"u")return document.createElement("canvas");throw new Error("Cannot create a canvas in this context")}function i9(t,e){if(t!==1&&t!==2)throw new Error("Cannot get WebGL rendering context, WebGL is disabled.");const n=e??o9(t);return n.addEventListener("webglcontextlost",s=>{s.preventDefault(),delete ai[t]},!1),W().getBool("SOFTWARE_WEBGL_ENABLED")&&(rd.failIfMajorPerformanceCaveat=!1),t===1?n.getContext("webgl",rd)||n.getContext("experimental-webgl",rd):n.getContext("webgl2",rd)}/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -11247,7 +11247,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */var eu;(function(t){t[t.DENSE=0]="DENSE",t[t.SHARED_BATCH=1]="SHARED_BATCH"})(eu||(eu={}));var ns;(function(t){t[t.RENDER=0]="RENDER",t[t.UPLOAD=1]="UPLOAD",t[t.PIXELS=2]="PIXELS",t[t.DOWNLOAD=3]="DOWNLOAD"})(ns||(ns={}));var Jt;(function(t){t[t.UNPACKED_FLOAT16=0]="UNPACKED_FLOAT16",t[t.UNPACKED_FLOAT32=1]="UNPACKED_FLOAT32",t[t.PACKED_4X1_UNSIGNED_BYTE=2]="PACKED_4X1_UNSIGNED_BYTE",t[t.PACKED_2X2_FLOAT32=3]="PACKED_2X2_FLOAT32",t[t.PACKED_2X2_FLOAT16=4]="PACKED_2X2_FLOAT16"})(Jt||(Jt={}));function Td(t,e){return[e,t]}function i9(t,e){return t*e}function oh(t){const e=j(t),n=Math.ceil(e/4);return X0(n)}function Nl(t,e){return[Math.max(1,Math.ceil(e/2)),Math.max(1,Math.ceil(t/2))]}function a9(t,e){const[n,s]=Nl(t,e);return n*s*4}function vv(t,e){const n=t;let s,r,o,i,a,l,c,u,d,h;return W().getNumber("WEBGL_VERSION")===2?(s=n.R32F,r=n.R16F,o=n.RGBA16F,i=n.RGBA32F,a=n.RED,c=4,u=1,d=n.HALF_FLOAT,h=n.FLOAT,l=n.RGBA8):(s=t.RGBA,r=t.RGBA,o=t.RGBA,i=n.RGBA,a=t.RGBA,c=4,u=4,d=e!=null?e.HALF_FLOAT_OES:null,h=t.FLOAT,l=t.RGBA),{internalFormatFloat:s,internalFormatHalfFloat:r,internalFormatPackedHalfFloat:o,internalFormatPackedFloat:i,textureFormatFloat:a,downloadTextureFormat:l,downloadUnpackNumChannels:c,defaultNumChannels:u,textureTypeHalfFloat:d,textureTypeFloat:h}}/** + */var eu;(function(t){t[t.DENSE=0]="DENSE",t[t.SHARED_BATCH=1]="SHARED_BATCH"})(eu||(eu={}));var ns;(function(t){t[t.RENDER=0]="RENDER",t[t.UPLOAD=1]="UPLOAD",t[t.PIXELS=2]="PIXELS",t[t.DOWNLOAD=3]="DOWNLOAD"})(ns||(ns={}));var Jt;(function(t){t[t.UNPACKED_FLOAT16=0]="UNPACKED_FLOAT16",t[t.UNPACKED_FLOAT32=1]="UNPACKED_FLOAT32",t[t.PACKED_4X1_UNSIGNED_BYTE=2]="PACKED_4X1_UNSIGNED_BYTE",t[t.PACKED_2X2_FLOAT32=3]="PACKED_2X2_FLOAT32",t[t.PACKED_2X2_FLOAT16=4]="PACKED_2X2_FLOAT16"})(Jt||(Jt={}));function Th(t,e){return[e,t]}function a9(t,e){return t*e}function od(t){const e=j(t),n=Math.ceil(e/4);return X0(n)}function Nl(t,e){return[Math.max(1,Math.ceil(e/2)),Math.max(1,Math.ceil(t/2))]}function l9(t,e){const[n,s]=Nl(t,e);return n*s*4}function vv(t,e){const n=t;let s,r,o,i,a,l,c,u,h,d;return W().getNumber("WEBGL_VERSION")===2?(s=n.R32F,r=n.R16F,o=n.RGBA16F,i=n.RGBA32F,a=n.RED,c=4,u=1,h=n.HALF_FLOAT,d=n.FLOAT,l=n.RGBA8):(s=t.RGBA,r=t.RGBA,o=t.RGBA,i=n.RGBA,a=t.RGBA,c=4,u=4,h=e!=null?e.HALF_FLOAT_OES:null,d=t.FLOAT,l=t.RGBA),{internalFormatFloat:s,internalFormatHalfFloat:r,internalFormatPackedHalfFloat:o,internalFormatPackedFloat:i,textureFormatFloat:a,downloadTextureFormat:l,downloadUnpackNumChannels:c,defaultNumChannels:u,textureTypeHalfFloat:h,textureTypeFloat:d}}/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -11262,11 +11262,11 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function ae(t,e){const n=e();return W().getBool("DEBUG")&&l9(t),n}function l9(t){const e=t.getError();if(e!==t.NO_ERROR)throw new Error("WebGL Error: "+h9(t,e))}const c9=596e-10,u9=65504;function d9(t){return!!(W().getBool("WEBGL_RENDER_FLOAT32_ENABLED")||t===0||c9t.getExtension(e),'Extension "'+e+'" not supported on this browser.')}function f9(t,e){const n=Qr(t,()=>t.createShader(t.VERTEX_SHADER),"Unable to create vertex WebGLShader.");if(ae(t,()=>t.shaderSource(n,e)),ae(t,()=>t.compileShader(n)),t.getShaderParameter(n,t.COMPILE_STATUS)===!1)throw console.log(t.getShaderInfoLog(n)),new Error("Failed to compile vertex shader.");return n}function p9(t,e){const n=Qr(t,()=>t.createShader(t.FRAGMENT_SHADER),"Unable to create fragment WebGLShader.");if(ae(t,()=>t.shaderSource(n,e)),ae(t,()=>t.compileShader(n)),W().get("ENGINE_COMPILE_ONLY"))return n;if(t.getShaderParameter(n,t.COMPILE_STATUS)===!1)throw BA(e,t.getShaderInfoLog(n)),new Error("Failed to compile fragment shader.");return n}const m9=/ERROR: [0-9]+:([0-9]+):/g;function BA(t,e){const n=m9.exec(e);if(n==null){console.log(`Couldn't parse line number in error: ${e}`),console.log(t);return}const s=+n[1],r=t.split(` -`),o=r.length.toString().length+2,i=r.map((d,h)=>Oa((h+1).toString(),o)+d);let a=0;for(let d=0;dt.getExtension(e),'Extension "'+e+'" not supported on this browser.')}function p9(t,e){const n=Zr(t,()=>t.createShader(t.VERTEX_SHADER),"Unable to create vertex WebGLShader.");if(ae(t,()=>t.shaderSource(n,e)),ae(t,()=>t.compileShader(n)),t.getShaderParameter(n,t.COMPILE_STATUS)===!1)throw console.log(t.getShaderInfoLog(n)),new Error("Failed to compile vertex shader.");return n}function m9(t,e){const n=Zr(t,()=>t.createShader(t.FRAGMENT_SHADER),"Unable to create fragment WebGLShader.");if(ae(t,()=>t.shaderSource(n,e)),ae(t,()=>t.compileShader(n)),W().get("ENGINE_COMPILE_ONLY"))return n;if(t.getShaderParameter(n,t.COMPILE_STATUS)===!1)throw VA(e,t.getShaderInfoLog(n)),new Error("Failed to compile fragment shader.");return n}const g9=/ERROR: [0-9]+:([0-9]+):/g;function VA(t,e){const n=g9.exec(e);if(n==null){console.log(`Couldn't parse line number in error: ${e}`),console.log(t);return}const s=+n[1],r=t.split(` +`),o=r.length.toString().length+2,i=r.map((h,d)=>Oa((d+1).toString(),o)+h);let a=0;for(let h=0;ht.createProgram(),"Unable to create WebGLProgram.")}function x9(t,e){if(ae(t,()=>t.linkProgram(e)),!W().get("ENGINE_COMPILE_ONLY")&&t.getProgramParameter(e,t.LINK_STATUS)===!1)throw console.log(t.getProgramInfoLog(e)),new Error("Failed to link vertex and fragment shaders.")}function Dg(t,e){if(ae(t,()=>t.validateProgram(e)),t.getProgramParameter(e,t.VALIDATE_STATUS)===!1)throw console.log(t.getProgramInfoLog(e)),new Error("Shader program validation failed.")}function y9(t,e){const n=Qr(t,()=>t.createBuffer(),"Unable to create WebGLBuffer");return ae(t,()=>t.bindBuffer(t.ARRAY_BUFFER,n)),ae(t,()=>t.bufferData(t.ARRAY_BUFFER,e,t.STATIC_DRAW)),n}function w9(t,e){const n=Qr(t,()=>t.createBuffer(),"Unable to create WebGLBuffer");return ae(t,()=>t.bindBuffer(t.ELEMENT_ARRAY_BUFFER,n)),ae(t,()=>t.bufferData(t.ELEMENT_ARRAY_BUFFER,e,t.STATIC_DRAW)),n}function v9(t){return Qr(t,()=>t.createTexture(),"Unable to create WebGLTexture.")}function b9(t,e){const n=W().getNumber("WEBGL_MAX_TEXTURE_SIZE");if(t<=0||e<=0){const s=`[${t}x${e}]`;throw new Error("Requested texture size "+s+" is invalid.")}if(t>n||e>n){const s=`[${t}x${e}]`,r=`[${n}x${n}]`;throw new Error("Requested texture size "+s+" greater than WebGL maximum on this browser / GPU "+r+".")}}function C9(t){return Qr(t,()=>t.createFramebuffer(),"Unable to create WebGLFramebuffer.")}function Ck(t,e,n,s,r,o,i){const a=t.getAttribLocation(e,n);return a===-1?!1:(ae(t,()=>t.bindBuffer(t.ARRAY_BUFFER,s)),ae(t,()=>t.vertexAttribPointer(a,r,t.FLOAT,!1,o,i)),ae(t,()=>t.enableVertexAttribArray(a)),!0)}function k9(t,e,n){T9(t,n),ae(t,()=>t.activeTexture(t.TEXTURE0+n)),ae(t,()=>t.bindTexture(t.TEXTURE_2D,e))}function S9(t,e,n){return Qr(t,()=>t.getUniformLocation(e,n),'uniform "'+n+'" not present in program.')}function I9(t,e,n){return t.getUniformLocation(e,n)}function $9(t,e,n,s){ae(t,()=>k9(t,e,s)),ae(t,()=>t.uniform1i(n,s))}function _g(t,e,n){ae(t,()=>t.bindFramebuffer(t.FRAMEBUFFER,n)),ae(t,()=>t.framebufferTexture2D(t.FRAMEBUFFER,t.COLOR_ATTACHMENT0,t.TEXTURE_2D,e,0))}function kk(t,e){ae(t,()=>t.bindFramebuffer(t.FRAMEBUFFER,e)),ae(t,()=>t.framebufferTexture2D(t.FRAMEBUFFER,t.COLOR_ATTACHMENT0,t.TEXTURE_2D,null,0))}function ah(t){const e=t.checkFramebufferStatus(t.FRAMEBUFFER);if(e!==t.FRAMEBUFFER_COMPLETE)throw new Error("Error binding framebuffer: "+N9(t,e))}function N9(t,e){switch(e){case t.FRAMEBUFFER_INCOMPLETE_ATTACHMENT:return"FRAMEBUFFER_INCOMPLETE_ATTACHMENT";case t.FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT:return"FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT";case t.FRAMEBUFFER_INCOMPLETE_DIMENSIONS:return"FRAMEBUFFER_INCOMPLETE_DIMENSIONS";case t.FRAMEBUFFER_UNSUPPORTED:return"FRAMEBUFFER_UNSUPPORTED";default:return`unknown error ${e}`}}function Qr(t,e,n){const s=ae(t,()=>e());if(s==null)throw new Error(n);return s}function T9(t,e){const n=t.MAX_COMBINED_TEXTURE_IMAGE_UNITS-1,s=e+t.TEXTURE0;if(sn){const r=`[gl.TEXTURE0, gl.TEXTURE${n}]`;throw new Error(`textureUnit must be in ${r}.`)}}function hl(t,e=2){return j(t.slice(0,t.length-e))}function fl(t){if(t.length===0)throw Error("Cannot get rows and columns of an empty shape array.");return[t.length>1?t[t.length-2]:1,t[t.length-1]]}function lh(t){let e=[1,1,1];return t.length===0||t.length===1&&t[0]===1||(e=[hl(t),...fl(t)]),e}function E9(t,e=!1){let n=W().getNumber("WEBGL_MAX_TEXTURE_SIZE"),s=W().getNumber("WEBGL_MAX_SIZE_FOR_NARROW_TEXTURE");s===1/0&&W().getBool("WEBGL_AUTO_SQUARIFY_NARROW_TEXTURE_SHAPE")&&(s=n/2),e&&(n=n*2,s=s*2,t=t.map((a,l)=>l>=t.length-2?Px(t[l]):t[l]),t.length===1&&(t=[2,t[0]])),t.length!==2&&(t=Vo(t).newShape);let r=j(t),o=null;t.length<=1&&r<=n?o=[1,r]:t.length===2&&t[0]<=n&&t[1]<=n?o=t:t.length===3&&t[0]*t[1]<=n&&t[2]<=n?o=[t[0]*t[1],t[2]]:t.length===3&&t[0]<=n&&t[1]*t[2]<=n?o=[t[0],t[1]*t[2]]:t.length===4&&t[0]*t[1]*t[2]<=n&&t[3]<=n?o=[t[0]*t[1]*t[2],t[3]]:t.length===4&&t[0]<=n&&t[1]*t[2]*t[3]<=n&&(o=[t[0],t[1]*t[2]*t[3]]);const i=o!=null&&Math.max(...o)>s&&Math.min(...o)<=(e?2:1)&&Math.min(...o)>0;if(o==null||i)if(e){const a=hl(t);let l=2,c=2;t.length&&([l,c]=fl(t)),r=a*(l/2)*(c/2),o=X0(r).map(u=>u*2)}else o=X0(r);return o}function ch(t){return t%2===0}function Lf(t,e){if(t=t.slice(-2),e=e.slice(-2),Ue(t,e)||!t.length||!e.length||t[0]===0||t[1]===0||e[0]===0||e[1]===0)return!0;if(t.length!==e.length){const n=t[t.length-1],s=e[e.length-1];if(n===s||ch(n)&&ch(s)&&(t[0]===1||e[0]===1))return!0}return t[1]===e[1]&&ch(t[0])&&ch(e[0])}let Fg,zg;function R9(t){if(Fg==null){const e=er(t);Fg=e.getParameter(e.MAX_TEXTURE_SIZE)}return Fg}function A9(t){if(zg==null){const e=er(t);zg=e.getParameter(e.MAX_TEXTURE_IMAGE_UNITS)}return Math.min(16,zg)}function D9(t){if(t===0)return 0;let e;const n=er(t);return ks(n,"EXT_disjoint_timer_query_webgl2")&&t===2?e=2:ks(n,"EXT_disjoint_timer_query")?e=1:e=0,e}function ks(t,e){return t.getExtension(e)!=null}function Sk(t){try{if(er(t)!=null)return!0}catch(e){return console.log("Error when getting WebGL context: ",e),!1}return!1}function _9(t){if(t===0)return!1;const e=er(t);if(t===1){if(!ks(e,"OES_texture_float"))return!1}else if(!ks(e,"EXT_color_buffer_float"))return!1;return N1(e)}function F9(t){if(t===0)return!1;const e=er(t);if(t===1){if(!ks(e,"OES_texture_float")||!ks(e,"WEBGL_color_buffer_float"))return!1}else{if(ks(e,"EXT_color_buffer_float"))return N1(e);const s="EXT_color_buffer_half_float";if(ks(e,s)){const r=e.getExtension(s);return z9(e,r)}return!1}return N1(e)}function N1(t){const e=vv(t),n=t.createTexture();t.bindTexture(t.TEXTURE_2D,n),t.texImage2D(t.TEXTURE_2D,0,e.internalFormatFloat,1,1,0,e.textureFormatFloat,e.textureTypeFloat,null);const o=t.createFramebuffer();t.bindFramebuffer(t.FRAMEBUFFER,o),t.framebufferTexture2D(t.FRAMEBUFFER,t.COLOR_ATTACHMENT0,t.TEXTURE_2D,n,0);const i=t.checkFramebufferStatus(t.FRAMEBUFFER)===t.FRAMEBUFFER_COMPLETE;return t.bindTexture(t.TEXTURE_2D,null),t.bindFramebuffer(t.FRAMEBUFFER,null),t.deleteTexture(n),t.deleteFramebuffer(o),i}function z9(t,e){const n=vv(t,e),s=t.createTexture();t.bindTexture(t.TEXTURE_2D,s),t.texImage2D(t.TEXTURE_2D,0,n.internalFormatHalfFloat,1,1,0,n.textureFormatFloat,n.textureTypeHalfFloat,null);const i=t.createFramebuffer();t.bindFramebuffer(t.FRAMEBUFFER,i),t.framebufferTexture2D(t.FRAMEBUFFER,t.COLOR_ATTACHMENT0,t.TEXTURE_2D,s,0);const a=t.checkFramebufferStatus(t.FRAMEBUFFER)===t.FRAMEBUFFER_COMPLETE;return t.bindTexture(t.TEXTURE_2D,null),t.bindFramebuffer(t.FRAMEBUFFER,null),t.deleteTexture(s),t.deleteFramebuffer(i),a}function O9(t){return t!==2?!1:er(t).fenceSync!=null}function Ed(t,e){Array.isArray(t)||(t=[t]),t.forEach(n=>{n!=null&&I(n.dtype!=="complex64",()=>`${e} does not support complex64 tensors in the WebGL backend.`)})}/** +`))}function x9(t){return Zr(t,()=>t.createProgram(),"Unable to create WebGLProgram.")}function y9(t,e){if(ae(t,()=>t.linkProgram(e)),!W().get("ENGINE_COMPILE_ONLY")&&t.getProgramParameter(e,t.LINK_STATUS)===!1)throw console.log(t.getProgramInfoLog(e)),new Error("Failed to link vertex and fragment shaders.")}function Dg(t,e){if(ae(t,()=>t.validateProgram(e)),t.getProgramParameter(e,t.VALIDATE_STATUS)===!1)throw console.log(t.getProgramInfoLog(e)),new Error("Shader program validation failed.")}function w9(t,e){const n=Zr(t,()=>t.createBuffer(),"Unable to create WebGLBuffer");return ae(t,()=>t.bindBuffer(t.ARRAY_BUFFER,n)),ae(t,()=>t.bufferData(t.ARRAY_BUFFER,e,t.STATIC_DRAW)),n}function v9(t,e){const n=Zr(t,()=>t.createBuffer(),"Unable to create WebGLBuffer");return ae(t,()=>t.bindBuffer(t.ELEMENT_ARRAY_BUFFER,n)),ae(t,()=>t.bufferData(t.ELEMENT_ARRAY_BUFFER,e,t.STATIC_DRAW)),n}function b9(t){return Zr(t,()=>t.createTexture(),"Unable to create WebGLTexture.")}function C9(t,e){const n=W().getNumber("WEBGL_MAX_TEXTURE_SIZE");if(t<=0||e<=0){const s=`[${t}x${e}]`;throw new Error("Requested texture size "+s+" is invalid.")}if(t>n||e>n){const s=`[${t}x${e}]`,r=`[${n}x${n}]`;throw new Error("Requested texture size "+s+" greater than WebGL maximum on this browser / GPU "+r+".")}}function k9(t){return Zr(t,()=>t.createFramebuffer(),"Unable to create WebGLFramebuffer.")}function Ck(t,e,n,s,r,o,i){const a=t.getAttribLocation(e,n);return a===-1?!1:(ae(t,()=>t.bindBuffer(t.ARRAY_BUFFER,s)),ae(t,()=>t.vertexAttribPointer(a,r,t.FLOAT,!1,o,i)),ae(t,()=>t.enableVertexAttribArray(a)),!0)}function S9(t,e,n){E9(t,n),ae(t,()=>t.activeTexture(t.TEXTURE0+n)),ae(t,()=>t.bindTexture(t.TEXTURE_2D,e))}function I9(t,e,n){return Zr(t,()=>t.getUniformLocation(e,n),'uniform "'+n+'" not present in program.')}function $9(t,e,n){return t.getUniformLocation(e,n)}function N9(t,e,n,s){ae(t,()=>S9(t,e,s)),ae(t,()=>t.uniform1i(n,s))}function _g(t,e,n){ae(t,()=>t.bindFramebuffer(t.FRAMEBUFFER,n)),ae(t,()=>t.framebufferTexture2D(t.FRAMEBUFFER,t.COLOR_ATTACHMENT0,t.TEXTURE_2D,e,0))}function kk(t,e){ae(t,()=>t.bindFramebuffer(t.FRAMEBUFFER,e)),ae(t,()=>t.framebufferTexture2D(t.FRAMEBUFFER,t.COLOR_ATTACHMENT0,t.TEXTURE_2D,null,0))}function ad(t){const e=t.checkFramebufferStatus(t.FRAMEBUFFER);if(e!==t.FRAMEBUFFER_COMPLETE)throw new Error("Error binding framebuffer: "+T9(t,e))}function T9(t,e){switch(e){case t.FRAMEBUFFER_INCOMPLETE_ATTACHMENT:return"FRAMEBUFFER_INCOMPLETE_ATTACHMENT";case t.FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT:return"FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT";case t.FRAMEBUFFER_INCOMPLETE_DIMENSIONS:return"FRAMEBUFFER_INCOMPLETE_DIMENSIONS";case t.FRAMEBUFFER_UNSUPPORTED:return"FRAMEBUFFER_UNSUPPORTED";default:return`unknown error ${e}`}}function Zr(t,e,n){const s=ae(t,()=>e());if(s==null)throw new Error(n);return s}function E9(t,e){const n=t.MAX_COMBINED_TEXTURE_IMAGE_UNITS-1,s=e+t.TEXTURE0;if(sn){const r=`[gl.TEXTURE0, gl.TEXTURE${n}]`;throw new Error(`textureUnit must be in ${r}.`)}}function dl(t,e=2){return j(t.slice(0,t.length-e))}function fl(t){if(t.length===0)throw Error("Cannot get rows and columns of an empty shape array.");return[t.length>1?t[t.length-2]:1,t[t.length-1]]}function ld(t){let e=[1,1,1];return t.length===0||t.length===1&&t[0]===1||(e=[dl(t),...fl(t)]),e}function R9(t,e=!1){let n=W().getNumber("WEBGL_MAX_TEXTURE_SIZE"),s=W().getNumber("WEBGL_MAX_SIZE_FOR_NARROW_TEXTURE");s===1/0&&W().getBool("WEBGL_AUTO_SQUARIFY_NARROW_TEXTURE_SHAPE")&&(s=n/2),e&&(n=n*2,s=s*2,t=t.map((a,l)=>l>=t.length-2?Px(t[l]):t[l]),t.length===1&&(t=[2,t[0]])),t.length!==2&&(t=Vo(t).newShape);let r=j(t),o=null;t.length<=1&&r<=n?o=[1,r]:t.length===2&&t[0]<=n&&t[1]<=n?o=t:t.length===3&&t[0]*t[1]<=n&&t[2]<=n?o=[t[0]*t[1],t[2]]:t.length===3&&t[0]<=n&&t[1]*t[2]<=n?o=[t[0],t[1]*t[2]]:t.length===4&&t[0]*t[1]*t[2]<=n&&t[3]<=n?o=[t[0]*t[1]*t[2],t[3]]:t.length===4&&t[0]<=n&&t[1]*t[2]*t[3]<=n&&(o=[t[0],t[1]*t[2]*t[3]]);const i=o!=null&&Math.max(...o)>s&&Math.min(...o)<=(e?2:1)&&Math.min(...o)>0;if(o==null||i)if(e){const a=dl(t);let l=2,c=2;t.length&&([l,c]=fl(t)),r=a*(l/2)*(c/2),o=X0(r).map(u=>u*2)}else o=X0(r);return o}function cd(t){return t%2===0}function Lf(t,e){if(t=t.slice(-2),e=e.slice(-2),Ue(t,e)||!t.length||!e.length||t[0]===0||t[1]===0||e[0]===0||e[1]===0)return!0;if(t.length!==e.length){const n=t[t.length-1],s=e[e.length-1];if(n===s||cd(n)&&cd(s)&&(t[0]===1||e[0]===1))return!0}return t[1]===e[1]&&cd(t[0])&&cd(e[0])}let Fg,zg;function A9(t){if(Fg==null){const e=tr(t);Fg=e.getParameter(e.MAX_TEXTURE_SIZE)}return Fg}function D9(t){if(zg==null){const e=tr(t);zg=e.getParameter(e.MAX_TEXTURE_IMAGE_UNITS)}return Math.min(16,zg)}function _9(t){if(t===0)return 0;let e;const n=tr(t);return Ss(n,"EXT_disjoint_timer_query_webgl2")&&t===2?e=2:Ss(n,"EXT_disjoint_timer_query")?e=1:e=0,e}function Ss(t,e){return t.getExtension(e)!=null}function Sk(t){try{if(tr(t)!=null)return!0}catch(e){return console.log("Error when getting WebGL context: ",e),!1}return!1}function F9(t){if(t===0)return!1;const e=tr(t);if(t===1){if(!Ss(e,"OES_texture_float"))return!1}else if(!Ss(e,"EXT_color_buffer_float"))return!1;return N1(e)}function z9(t){if(t===0)return!1;const e=tr(t);if(t===1){if(!Ss(e,"OES_texture_float")||!Ss(e,"WEBGL_color_buffer_float"))return!1}else{if(Ss(e,"EXT_color_buffer_float"))return N1(e);const s="EXT_color_buffer_half_float";if(Ss(e,s)){const r=e.getExtension(s);return O9(e,r)}return!1}return N1(e)}function N1(t){const e=vv(t),n=t.createTexture();t.bindTexture(t.TEXTURE_2D,n),t.texImage2D(t.TEXTURE_2D,0,e.internalFormatFloat,1,1,0,e.textureFormatFloat,e.textureTypeFloat,null);const o=t.createFramebuffer();t.bindFramebuffer(t.FRAMEBUFFER,o),t.framebufferTexture2D(t.FRAMEBUFFER,t.COLOR_ATTACHMENT0,t.TEXTURE_2D,n,0);const i=t.checkFramebufferStatus(t.FRAMEBUFFER)===t.FRAMEBUFFER_COMPLETE;return t.bindTexture(t.TEXTURE_2D,null),t.bindFramebuffer(t.FRAMEBUFFER,null),t.deleteTexture(n),t.deleteFramebuffer(o),i}function O9(t,e){const n=vv(t,e),s=t.createTexture();t.bindTexture(t.TEXTURE_2D,s),t.texImage2D(t.TEXTURE_2D,0,n.internalFormatHalfFloat,1,1,0,n.textureFormatFloat,n.textureTypeHalfFloat,null);const i=t.createFramebuffer();t.bindFramebuffer(t.FRAMEBUFFER,i),t.framebufferTexture2D(t.FRAMEBUFFER,t.COLOR_ATTACHMENT0,t.TEXTURE_2D,s,0);const a=t.checkFramebufferStatus(t.FRAMEBUFFER)===t.FRAMEBUFFER_COMPLETE;return t.bindTexture(t.TEXTURE_2D,null),t.bindFramebuffer(t.FRAMEBUFFER,null),t.deleteTexture(s),t.deleteFramebuffer(i),a}function M9(t){return t!==2?!1:tr(t).fenceSync!=null}function Eh(t,e){Array.isArray(t)||(t=[t]),t.forEach(n=>{n!=null&&I(n.dtype!=="complex64",()=>`${e} does not support complex64 tensors in the WebGL backend.`)})}/** * @license * Copyright 2019 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -11281,7 +11281,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const fe=W();fe.registerFlag("HAS_WEBGL",()=>fe.getNumber("WEBGL_VERSION")>0);fe.registerFlag("WEBGL_VERSION",()=>Sk(2)?2:Sk(1)?1:0);fe.registerFlag("WEBGL_CHECK_NUMERICAL_PROBLEMS",()=>!1);fe.registerFlag("WEBGL_BUFFER_SUPPORTED",()=>fe.get("WEBGL_VERSION")===2);fe.registerFlag("WEBGL_CPU_FORWARD",()=>!0);fe.registerFlag("WEBGL_FORCE_F16_TEXTURES",()=>!1);fe.registerFlag("WEBGL_PACK",()=>fe.getBool("HAS_WEBGL"));fe.registerFlag("WEBGL_PACK_NORMALIZATION",()=>fe.getBool("WEBGL_PACK"));fe.registerFlag("WEBGL_PACK_CLIP",()=>fe.getBool("WEBGL_PACK"));fe.registerFlag("WEBGL_PACK_DEPTHWISECONV",()=>fe.getBool("WEBGL_PACK"));fe.registerFlag("WEBGL_PACK_BINARY_OPERATIONS",()=>fe.getBool("WEBGL_PACK"));fe.registerFlag("WEBGL_PACK_UNARY_OPERATIONS",()=>fe.getBool("WEBGL_PACK"));fe.registerFlag("WEBGL_PACK_ARRAY_OPERATIONS",()=>fe.getBool("WEBGL_PACK"));fe.registerFlag("WEBGL_PACK_IMAGE_OPERATIONS",()=>fe.getBool("WEBGL_PACK"));fe.registerFlag("WEBGL_PACK_REDUCE",()=>fe.getBool("WEBGL_PACK"));fe.registerFlag("WEBGL_LAZILY_UNPACK",()=>fe.getBool("WEBGL_PACK"));fe.registerFlag("WEBGL_CONV_IM2COL",()=>fe.getBool("WEBGL_PACK"));fe.registerFlag("WEBGL_PACK_CONV2DTRANSPOSE",()=>fe.getBool("WEBGL_PACK"));fe.registerFlag("WEBGL_MAX_TEXTURE_SIZE",()=>R9(fe.getNumber("WEBGL_VERSION")));fe.registerFlag("WEBGL_MAX_TEXTURES_IN_SHADER",()=>A9(fe.getNumber("WEBGL_VERSION")));fe.registerFlag("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION",()=>{const t=fe.getNumber("WEBGL_VERSION");return t===0?0:D9(t)});fe.registerFlag("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE",()=>fe.getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")>0&&!O$());fe.registerFlag("WEBGL_RENDER_FLOAT32_CAPABLE",()=>_9(fe.getNumber("WEBGL_VERSION")));fe.registerFlag("WEBGL_RENDER_FLOAT32_ENABLED",()=>fe.getBool("WEBGL_FORCE_F16_TEXTURES")?!1:fe.getBool("WEBGL_RENDER_FLOAT32_CAPABLE"));fe.registerFlag("WEBGL_DOWNLOAD_FLOAT_ENABLED",()=>F9(fe.getNumber("WEBGL_VERSION")));fe.registerFlag("WEBGL_FENCE_API_ENABLED",()=>O9(fe.getNumber("WEBGL_VERSION")));fe.registerFlag("WEBGL_SIZE_UPLOAD_UNIFORM",()=>fe.getBool("WEBGL_RENDER_FLOAT32_ENABLED")?4:0);fe.registerFlag("WEBGL_DELETE_TEXTURE_THRESHOLD",()=>-1,t=>{if(typeof t!="number")throw new Error(`WEBGL_DELETE_TEXTURE_THRESHOLD must be a number but got ${t}.`);if(t<0&&t!==-1)throw new Error(`WEBGL_DELETE_TEXTURE_THRESHOLD must be -1 (indicating never delete) or at least 0, but got ${t}.`)});fe.registerFlag("WEBGL_FLUSH_THRESHOLD",()=>O$()?1:-1,t=>{if(typeof t!="number")throw new Error(`WEBGL_FLUSH_THRESHOLD must be a number but got ${t}.`);if(t<0&&t!==-1)throw new Error(`WEBGL_FLUSH_THRESHOLD must be -1 (indicating never manual flush) or at least 0, but got ${t}.`)});fe.registerFlag("CPU_HANDOFF_SIZE_THRESHOLD",()=>128);fe.registerFlag("WEBGL_USE_SHAPES_UNIFORMS",()=>!1);fe.registerFlag("TOPK_LAST_DIM_CPU_HANDOFF_SIZE_THRESHOLD",()=>1e5);fe.registerFlag("TOPK_K_CPU_HANDOFF_THRESHOLD",()=>128);fe.registerFlag("WEBGL_EXP_CONV",()=>!1);fe.registerFlag("SOFTWARE_WEBGL_ENABLED",()=>fe.getBool("IS_TEST"));fe.registerFlag("WEBGL_MAX_SIZE_FOR_NARROW_TEXTURE",()=>1/0);fe.registerFlag("WEBGL_AUTO_SQUARIFY_NARROW_TEXTURE_SHAPE",()=>!1);fe.registerFlag("WEBGL2_ISNAN_CUSTOM",()=>!1);fe.registerFlag("ENGINE_COMPILE_ONLY",()=>!1);/** + */const fe=W();fe.registerFlag("HAS_WEBGL",()=>fe.getNumber("WEBGL_VERSION")>0);fe.registerFlag("WEBGL_VERSION",()=>Sk(2)?2:Sk(1)?1:0);fe.registerFlag("WEBGL_CHECK_NUMERICAL_PROBLEMS",()=>!1);fe.registerFlag("WEBGL_BUFFER_SUPPORTED",()=>fe.get("WEBGL_VERSION")===2);fe.registerFlag("WEBGL_CPU_FORWARD",()=>!0);fe.registerFlag("WEBGL_FORCE_F16_TEXTURES",()=>!1);fe.registerFlag("WEBGL_PACK",()=>fe.getBool("HAS_WEBGL"));fe.registerFlag("WEBGL_PACK_NORMALIZATION",()=>fe.getBool("WEBGL_PACK"));fe.registerFlag("WEBGL_PACK_CLIP",()=>fe.getBool("WEBGL_PACK"));fe.registerFlag("WEBGL_PACK_DEPTHWISECONV",()=>fe.getBool("WEBGL_PACK"));fe.registerFlag("WEBGL_PACK_BINARY_OPERATIONS",()=>fe.getBool("WEBGL_PACK"));fe.registerFlag("WEBGL_PACK_UNARY_OPERATIONS",()=>fe.getBool("WEBGL_PACK"));fe.registerFlag("WEBGL_PACK_ARRAY_OPERATIONS",()=>fe.getBool("WEBGL_PACK"));fe.registerFlag("WEBGL_PACK_IMAGE_OPERATIONS",()=>fe.getBool("WEBGL_PACK"));fe.registerFlag("WEBGL_PACK_REDUCE",()=>fe.getBool("WEBGL_PACK"));fe.registerFlag("WEBGL_LAZILY_UNPACK",()=>fe.getBool("WEBGL_PACK"));fe.registerFlag("WEBGL_CONV_IM2COL",()=>fe.getBool("WEBGL_PACK"));fe.registerFlag("WEBGL_PACK_CONV2DTRANSPOSE",()=>fe.getBool("WEBGL_PACK"));fe.registerFlag("WEBGL_MAX_TEXTURE_SIZE",()=>A9(fe.getNumber("WEBGL_VERSION")));fe.registerFlag("WEBGL_MAX_TEXTURES_IN_SHADER",()=>D9(fe.getNumber("WEBGL_VERSION")));fe.registerFlag("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION",()=>{const t=fe.getNumber("WEBGL_VERSION");return t===0?0:_9(t)});fe.registerFlag("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE",()=>fe.getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")>0&&!M$());fe.registerFlag("WEBGL_RENDER_FLOAT32_CAPABLE",()=>F9(fe.getNumber("WEBGL_VERSION")));fe.registerFlag("WEBGL_RENDER_FLOAT32_ENABLED",()=>fe.getBool("WEBGL_FORCE_F16_TEXTURES")?!1:fe.getBool("WEBGL_RENDER_FLOAT32_CAPABLE"));fe.registerFlag("WEBGL_DOWNLOAD_FLOAT_ENABLED",()=>z9(fe.getNumber("WEBGL_VERSION")));fe.registerFlag("WEBGL_FENCE_API_ENABLED",()=>M9(fe.getNumber("WEBGL_VERSION")));fe.registerFlag("WEBGL_SIZE_UPLOAD_UNIFORM",()=>fe.getBool("WEBGL_RENDER_FLOAT32_ENABLED")?4:0);fe.registerFlag("WEBGL_DELETE_TEXTURE_THRESHOLD",()=>-1,t=>{if(typeof t!="number")throw new Error(`WEBGL_DELETE_TEXTURE_THRESHOLD must be a number but got ${t}.`);if(t<0&&t!==-1)throw new Error(`WEBGL_DELETE_TEXTURE_THRESHOLD must be -1 (indicating never delete) or at least 0, but got ${t}.`)});fe.registerFlag("WEBGL_FLUSH_THRESHOLD",()=>M$()?1:-1,t=>{if(typeof t!="number")throw new Error(`WEBGL_FLUSH_THRESHOLD must be a number but got ${t}.`);if(t<0&&t!==-1)throw new Error(`WEBGL_FLUSH_THRESHOLD must be -1 (indicating never manual flush) or at least 0, but got ${t}.`)});fe.registerFlag("CPU_HANDOFF_SIZE_THRESHOLD",()=>128);fe.registerFlag("WEBGL_USE_SHAPES_UNIFORMS",()=>!1);fe.registerFlag("TOPK_LAST_DIM_CPU_HANDOFF_SIZE_THRESHOLD",()=>1e5);fe.registerFlag("TOPK_K_CPU_HANDOFF_THRESHOLD",()=>128);fe.registerFlag("WEBGL_EXP_CONV",()=>!1);fe.registerFlag("SOFTWARE_WEBGL_ENABLED",()=>fe.getBool("IS_TEST"));fe.registerFlag("WEBGL_MAX_SIZE_FOR_NARROW_TEXTURE",()=>1/0);fe.registerFlag("WEBGL_AUTO_SQUARIFY_NARROW_TEXTURE_SHAPE",()=>!1);fe.registerFlag("WEBGL2_ISNAN_CUSTOM",()=>!1);fe.registerFlag("ENGINE_COMPILE_ONLY",()=>!1);/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -11357,7 +11357,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function ea(t,e,n="index"){const s=pe(e);return s.map((r,o)=>{const i=`int ${t[o]} = ${n} / ${r}`,a=o===s.length-1?`int ${t[o+1]} = ${n} - ${t[o]} * ${r}`:`index -= ${t[o]} * ${r}`;return`${i}; ${a};`}).join("")}function Mm(t,e,n="index"){const s=pe(e);return s.map((r,o)=>{const i=`int ${t[o]} = ${n} / outShapeStrides[${o}]`,a=o===s.length-1?`int ${t[o+1]} = ${n} - ${t[o]} * outShapeStrides[${o}]`:`index -= ${t[o]} * outShapeStrides[${o}]`;return`${i}; ${a};`}).join("")}function M9(t,e){const n=t.length,s=t.map(o=>`${e}[${o}]`),r=new Array(n-1);r[n-2]=s[n-1];for(let o=n-3;o>=0;--o)r[o]=`(${r[o+1]} * ${s[o+1]})`;return r}function P9(t,e,n="index"){const s=t.map((o,i)=>i),r=M9(s,e);return r.map((o,i)=>{const a=`int ${t[i]} = ${n} / ${r[i]}`,l=i===r.length-1?`int ${t[i+1]} = ${n} - ${t[i]} * ${r[i]}`:`index -= ${t[i]} * ${r[i]}`;return`${a}; ${l};`}).join("")}function bv(t){const e=pe(t).map(n=>n.toString());return` + */function ea(t,e,n="index"){const s=pe(e);return s.map((r,o)=>{const i=`int ${t[o]} = ${n} / ${r}`,a=o===s.length-1?`int ${t[o+1]} = ${n} - ${t[o]} * ${r}`:`index -= ${t[o]} * ${r}`;return`${i}; ${a};`}).join("")}function Mm(t,e,n="index"){const s=pe(e);return s.map((r,o)=>{const i=`int ${t[o]} = ${n} / outShapeStrides[${o}]`,a=o===s.length-1?`int ${t[o+1]} = ${n} - ${t[o]} * outShapeStrides[${o}]`:`index -= ${t[o]} * outShapeStrides[${o}]`;return`${i}; ${a};`}).join("")}function P9(t,e){const n=t.length,s=t.map(o=>`${e}[${o}]`),r=new Array(n-1);r[n-2]=s[n-1];for(let o=n-3;o>=0;--o)r[o]=`(${r[o+1]} * ${s[o+1]})`;return r}function L9(t,e,n="index"){const s=t.map((o,i)=>i),r=P9(s,e);return r.map((o,i)=>{const a=`int ${t[i]} = ${n} / ${r[i]}`,l=i===r.length-1?`int ${t[i+1]} = ${n} - ${t[i]} * ${r[i]}`:`index -= ${t[i]} * ${r[i]}`;return`${a}; ${l};`}).join("")}function bv(t){const e=pe(t).map(n=>n.toString());return` int getFlatIndex(ivec3 coords) { return coords.x * ${e[0]} + coords.y * ${e[1]} + coords.z; } @@ -11365,7 +11365,7 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram int getFlatIndex(ivec3 coords) { return coords.x * outShapeStrides[0] + coords.y * outShapeStrides[1] + coords.z; } -`}const VA=` +`}const WA=` const float FLOAT_MAX = 1.70141184e38; const float FLOAT_MIN = 1.17549435e-38; @@ -11419,22 +11419,22 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const{getBroadcastDims:WA}=IU;function L9(t,e,n){const s=[];if(t.forEach(f=>{const p=j(f.shapeInfo.logicalShape);if(f.shapeInfo.isUniform?s.push(`uniform float ${f.name}${p>1?`[${p}]`:""};`):(s.push(`uniform sampler2D ${f.name};`),s.push(`uniform int offset${f.name};`)),n.enableShapeUniforms){const{uniformShape:g}=kv(n.packedInputs,f.shapeInfo.logicalShape,f.shapeInfo.texShape);switch(g.length){case 1:s.push(`uniform int ${f.name}Shape;`);break;case 2:s.push(`uniform ivec2 ${f.name}Shape;`);break;case 3:s.push(`uniform ivec3 ${f.name}Shape;`);break;case 4:s.push(`uniform ivec4 ${f.name}Shape;`);break}s.push(`uniform ivec2 ${f.name}TexShape;`)}}),n.enableShapeUniforms){switch(e.logicalShape.length){case 1:s.push("uniform int outShape;");break;case 2:s.push("uniform ivec2 outShape;"),s.push("uniform int outShapeStrides;");break;case 3:s.push("uniform ivec3 outShape;"),s.push("uniform ivec2 outShapeStrides;");break;case 4:s.push("uniform ivec4 outShape;"),s.push("uniform ivec3 outShapeStrides;");break}s.push("uniform ivec2 outTexShape;")}n.customUniforms&&n.customUniforms.forEach(f=>{s.push(`uniform ${f.type} ${f.name}${f.arrayIndex?`[${f.arrayIndex}]`:""};`)});const r=s.join(` -`),o=t.map(f=>B9(f,e,n.packedInputs,n.enableShapeUniforms)).join(` -`),i=e.texShape,a=$n(),l=U9(a);let c,u,d=j9(a);return e.isPacked?(c=V9(e.logicalShape,i,n.enableShapeUniforms),u=H9(a)):(c=W9(e.logicalShape,i,n.enableShapeUniforms),u=G9(a)),n.packedInputs&&(d+=Y9),[d,l,u,r,c,o,n.userCode].join(` -`)}function Tl(t,e=!1){const n=t.shapeInfo.logicalShape;switch(n.length){case 0:return lY(t,e);case 1:return uY(t,e);case 2:return hY(t,e);case 3:return pY(t,e);case 4:return gY(t,e);case 5:return xY(t);case 6:return yY(t);default:throw new Error(`${n.length}-D input sampling is not yet supported`)}}function UA(t,e){switch(t.shapeInfo.logicalShape.length){case 0:return aY(t);case 1:return cY(t,e);case 2:return dY(t,e);case 3:return fY(t,e);default:return mY(t,e)}}function B9(t,e,n=!1,s){let r="";n?r+=UA(t,s):r+=Tl(t,s);const o=t.shapeInfo.logicalShape,i=e.logicalShape;return o.length<=i.length&&(n?r+=wY(t,e):r+=vY(t,e)),r}function V9(t,e,n){switch(t.length){case 0:return GA();case 1:return Q9(t,e,n);case 2:return oY(t,e,n);case 3:return J9(t,e,n);default:return tY(t,e,n)}}function W9(t,e,n){switch(t.length){case 0:return GA();case 1:return Z9(t,e,n);case 2:return iY(t,e,n);case 3:return eY(t,e,n);case 4:return nY(t,e,n);case 5:return sY(t,e);case 6:return rY(t,e);default:throw new Error(`${t.length}-D output sampling is not yet supported`)}}function U9(t){return` + */const{getBroadcastDims:UA}=$U;function B9(t,e,n){const s=[];if(t.forEach(f=>{const p=j(f.shapeInfo.logicalShape);if(f.shapeInfo.isUniform?s.push(`uniform float ${f.name}${p>1?`[${p}]`:""};`):(s.push(`uniform sampler2D ${f.name};`),s.push(`uniform int offset${f.name};`)),n.enableShapeUniforms){const{uniformShape:g}=kv(n.packedInputs,f.shapeInfo.logicalShape,f.shapeInfo.texShape);switch(g.length){case 1:s.push(`uniform int ${f.name}Shape;`);break;case 2:s.push(`uniform ivec2 ${f.name}Shape;`);break;case 3:s.push(`uniform ivec3 ${f.name}Shape;`);break;case 4:s.push(`uniform ivec4 ${f.name}Shape;`);break}s.push(`uniform ivec2 ${f.name}TexShape;`)}}),n.enableShapeUniforms){switch(e.logicalShape.length){case 1:s.push("uniform int outShape;");break;case 2:s.push("uniform ivec2 outShape;"),s.push("uniform int outShapeStrides;");break;case 3:s.push("uniform ivec3 outShape;"),s.push("uniform ivec2 outShapeStrides;");break;case 4:s.push("uniform ivec4 outShape;"),s.push("uniform ivec3 outShapeStrides;");break}s.push("uniform ivec2 outTexShape;")}n.customUniforms&&n.customUniforms.forEach(f=>{s.push(`uniform ${f.type} ${f.name}${f.arrayIndex?`[${f.arrayIndex}]`:""};`)});const r=s.join(` +`),o=t.map(f=>V9(f,e,n.packedInputs,n.enableShapeUniforms)).join(` +`),i=e.texShape,a=$n(),l=G9(a);let c,u,h=K9(a);return e.isPacked?(c=W9(e.logicalShape,i,n.enableShapeUniforms),u=j9(a)):(c=U9(e.logicalShape,i,n.enableShapeUniforms),u=H9(a)),n.packedInputs&&(h+=Q9),[h,l,u,r,c,o,n.userCode].join(` +`)}function Tl(t,e=!1){const n=t.shapeInfo.logicalShape;switch(n.length){case 0:return cY(t,e);case 1:return hY(t,e);case 2:return fY(t,e);case 3:return mY(t,e);case 4:return xY(t,e);case 5:return yY(t);case 6:return wY(t);default:throw new Error(`${n.length}-D input sampling is not yet supported`)}}function GA(t,e){switch(t.shapeInfo.logicalShape.length){case 0:return lY(t);case 1:return uY(t,e);case 2:return dY(t,e);case 3:return pY(t,e);default:return gY(t,e)}}function V9(t,e,n=!1,s){let r="";n?r+=GA(t,s):r+=Tl(t,s);const o=t.shapeInfo.logicalShape,i=e.logicalShape;return o.length<=i.length&&(n?r+=vY(t,e):r+=bY(t,e)),r}function W9(t,e,n){switch(t.length){case 0:return HA();case 1:return Z9(t,e,n);case 2:return iY(t,e,n);case 3:return eY(t,e,n);default:return nY(t,e,n)}}function U9(t,e,n){switch(t.length){case 0:return HA();case 1:return J9(t,e,n);case 2:return aY(t,e,n);case 3:return tY(t,e,n);case 4:return sY(t,e,n);case 5:return rY(t,e);case 6:return oY(t,e);default:throw new Error(`${t.length}-D output sampling is not yet supported`)}}function G9(t){return` float sampleTexture(sampler2D textureSampler, vec2 uv) { return ${t.texture2D}(textureSampler, uv).r; } - `}function G9(t){return` + `}function H9(t){return` void setOutput(float val) { ${t.output} = vec4(val, 0, 0, 0); } - `}function H9(t){return` + `}function j9(t){return` void setOutput(vec4 val) { ${t.output} = val; } - `}function j9(t){return`${t.version} + `}function K9(t){return`${t.version} precision highp float; precision highp int; precision highp sampler2D; @@ -11489,10 +11489,10 @@ Hi, looks like you are running TensorFlow.js in Node.js. To speed things up dram return fract((p3.x + p3.y) * p3.z); } - ${K9} ${X9} ${q9} - `}const K9=` + ${Y9} + `}const X9=` vec2 uvFromFlat(int texNumR, int texNumC, int index) { int texR = index / texNumC; int texC = index - texR * texNumC; @@ -11504,7 +11504,7 @@ vec2 packedUVfrom1D(int texNumR, int texNumC, int index) { int texC = texelIndex - texR * texNumC; return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR); } -`,X9=` +`,q9=` vec2 packedUVfrom2D(int texelsInLogicalRow, int texNumR, int texNumC, int row, int col) { int texelIndex = (row / 2) * texelsInLogicalRow + (col / 2); @@ -11512,7 +11512,7 @@ vec2 packedUVfrom2D(int texelsInLogicalRow, int texNumR, int texC = texelIndex - texR * texNumC; return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR); } -`,q9=` +`,Y9=` vec2 packedUVfrom3D(int texNumR, int texNumC, int texelsInBatch, int texelsInLogicalRow, int b, int row, int col) { @@ -11521,7 +11521,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, int texC = index - texR * texNumC; return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR); } -`,Y9=` +`,Q9=` float getChannel(vec4 frag, vec2 innerDims) { vec2 modCoord = mod(innerDims, 2.); return modCoord.x == 0. ? @@ -11532,11 +11532,11 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, float modCoord = mod(float(dim), 2.); return modCoord == 0. ? frag.r : frag.g; } -`;function GA(){return` +`;function HA(){return` int getOutputCoords() { return 0; } - `}function Q9(t,e,n){const s=[Math.ceil(e[0]/2),Math.ceil(e[1]/2)];return s[0]===1?n?` + `}function Z9(t,e,n){const s=[Math.ceil(e[0]/2),Math.ceil(e[1]/2)];return s[0]===1?n?` int getOutputCoords() { return 2 * int(resultUV.x * ceil(float(outTexShape[1]) / 2.0)); } @@ -11565,7 +11565,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, vec2(${s[0]}, ${s[1]})); return 2 * (resTexRC.x * ${s[1]} + resTexRC.y); } - `}function Z9(t,e,n){return e[0]===1?n?` + `}function J9(t,e,n){return e[0]===1?n?` int getOutputCoords() { return int(resultUV.x * float(outTexShape[1])); } @@ -11593,7 +11593,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, vec2(${e[0]}, ${e[1]})); return resTexRC.x * ${e[1]} + resTexRC.y; } - `}function J9(t,e,n){if(n)return` + `}function eY(t,e,n){if(n)return` ivec3 getOutputCoords() { ivec2 packedTexShape = ivec2(ceil(float(outTexShape[0]) / 2.0), ceil(float(outTexShape[1]) / 2.0)); int texelsInLogicalRow = int(ceil(float(outShape[2]) / 2.0)); @@ -11624,7 +11624,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, return ivec3(b, r, c); } - `}function eY(t,e,n){if(n)return` + `}function tY(t,e,n){if(n)return` ivec3 getOutputCoords() { ivec2 resTexRC = ivec2(resultUV.yx * vec2(outTexShape[0], outTexShape[1])); @@ -11640,7 +11640,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, ${s} return ivec3(r, c, d); } - `}function tY(t,e,n){if(n)return` + `}function nY(t,e,n){if(n)return` ivec4 getOutputCoords() { ivec2 packedTexShape = ivec2(ceil(float(outTexShape[0]) / 2.0), ceil(float(outTexShape[1]) / 2.0)); ivec2 resTexRC = ivec2(resultUV.yx * @@ -11681,7 +11681,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, return ivec${t.length}(${l}); } - `}function nY(t,e,n){if(n)return` + `}function sY(t,e,n){if(n)return` ivec4 getOutputCoords() { ivec2 resTexRC = ivec2(resultUV.yx * vec2(outTexShape[0], outTexShape[1])); @@ -11697,7 +11697,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, ${s} return ivec4(r, c, d, d2); } - `}function sY(t,e){const n=ea(["r","c","d","d2","d3"],t);return` + `}function rY(t,e){const n=ea(["r","c","d","d2","d3"],t);return` ivec5 getOutputCoords() { ivec2 resTexRC = ivec2(resultUV.yx * vec2(${e[0]}, ${e[1]})); @@ -11709,7 +11709,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, ivec5 outShape = ivec5(r, c, d, d2, d3); return outShape; } - `}function rY(t,e){const n=ea(["r","c","d","d2","d3","d4"],t);return` + `}function oY(t,e){const n=ea(["r","c","d","d2","d3","d4"],t);return` ivec6 getOutputCoords() { ivec2 resTexRC = ivec2(resultUV.yx * vec2(${e[0]}, ${e[1]})); @@ -11720,7 +11720,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, ivec6 result = ivec6(r, c, d, d2, d3, d4); return result; } - `}function oY(t,e,n){const s=[Math.ceil(e[0]/2),Math.ceil(e[1]/2)];if(Ue(t,e))return n?` + `}function iY(t,e,n){const s=[Math.ceil(e[0]/2),Math.ceil(e[1]/2)];if(Ue(t,e))return n?` ivec2 getOutputCoords() { ivec2 packedTexShape = ivec2(ceil(float(outTexShape[0]) / 2.0), ceil(float(outTexShape[1]) / 2.0)); return 2 * ivec2(resultUV.yx * vec2(packedTexShape[0], packedTexShape[1])); @@ -11753,7 +11753,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, return ivec2(r, c); } - `}function iY(t,e,n){return Ue(t,e)?n?` + `}function aY(t,e,n){return Ue(t,e)?n?` ivec2 getOutputCoords() { return ivec2(resultUV.yx * vec2(outTexShape[0], outTexShape[1])); } @@ -11807,11 +11807,11 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, int c = index - r * ${t[1]}; return ivec2(r, c); } - `}function ta(t){return`offset${t}`}function aY(t){const e=t.name,n="get"+e.charAt(0).toUpperCase()+e.slice(1),s=$n();return` + `}function ta(t){return`offset${t}`}function lY(t){const e=t.name,n="get"+e.charAt(0).toUpperCase()+e.slice(1),s=$n();return` vec4 ${n}() { return ${s.texture2D}(${e}, halfCR); } - `}function lY(t,e){const n=t.name,s="get"+n.charAt(0).toUpperCase()+n.slice(1);if(t.shapeInfo.isUniform)return`float ${s}() {return ${n};}`;const[r,o]=t.shapeInfo.texShape;if(r===1&&o===1)return` + `}function cY(t,e){const n=t.name,s="get"+n.charAt(0).toUpperCase()+n.slice(1);if(t.shapeInfo.isUniform)return`float ${s}() {return ${n};}`;const[r,o]=t.shapeInfo.texShape;if(r===1&&o===1)return` float ${s}() { return sampleTexture(${n}, halfCR); } @@ -11825,7 +11825,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, vec2 uv = uvFromFlat(${a}, ${l}, ${i}); return sampleTexture(${n}, uv); } - `}function cY(t,e){const n=t.name,s="get"+n.charAt(0).toUpperCase()+n.slice(1),r=t.shapeInfo.texShape,o=$n();if(e)return` + `}function uY(t,e){const n=t.name,s="get"+n.charAt(0).toUpperCase()+n.slice(1),r=t.shapeInfo.texShape,o=$n();if(e)return` vec4 ${s}(int index) { ivec2 packedTexShape = ivec2(ceil(float(${n}TexShape[0]) / 2.0), ceil(float(${n}TexShape[1]) / 2.0)); vec2 uv = packedUVfrom1D( @@ -11838,7 +11838,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, ${i[0]}, ${i[1]}, index); return ${o.texture2D}(${n}, uv); } - `}function uY(t,e){const n=t.name,s="get"+n.charAt(0).toUpperCase()+n.slice(1);if(t.shapeInfo.isUniform)return` + `}function hY(t,e){const n=t.name,s="get"+n.charAt(0).toUpperCase()+n.slice(1);if(t.shapeInfo.isUniform)return` float ${s}(int index) { ${El(t)} } @@ -11900,18 +11900,18 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, vec2 uv = packedUVfrom2D(${u}, ${c[0]}, ${c[1]}, row, col); return ${l.texture2D}(${s}, uv); } - `}function hY(t,e){const n=t.shapeInfo.logicalShape,s=t.name,r="get"+s.charAt(0).toUpperCase()+s.slice(1),o=t.shapeInfo.texShape;if(o!=null&&Ue(n,o)){if(e)return` + `}function fY(t,e){const n=t.shapeInfo.logicalShape,s=t.name,r="get"+s.charAt(0).toUpperCase()+s.slice(1),o=t.shapeInfo.texShape;if(o!=null&&Ue(n,o)){if(e)return` float ${r}(int row, int col) { vec2 uv = (vec2(col, row) + halfCR) / vec2(${s}TexShape[1], ${s}TexShape[0]); return sampleTexture(${s}, uv); } - `;const h=o[0],f=o[1];return` + `;const d=o[0],f=o[1];return` float ${r}(int row, int col) { - vec2 uv = (vec2(col, row) + halfCR) / vec2(${f}.0, ${h}.0); + vec2 uv = (vec2(col, row) + halfCR) / vec2(${f}.0, ${d}.0); return sampleTexture(${s}, uv); } - `}const{newShape:i,keptDims:a}=Vo(n),l=i;if(l.length=1?u="coords = 0;":u=a.map(y=>`coords.${d[y+c]} = 0;`).join(` -`);let h="";i<2&&o>0?h="coords":h=t.shapeInfo.logicalShape.map((y,w)=>`coords.${d[w+c]}`).join(", ");let f="return outputValue;";const g=j(t.shapeInfo.logicalShape)===1,m=j(e.logicalShape)===1;if(o===1&&!g&&!m)f=` + `}function vY(t,e){const n=t.name,s=n.charAt(0).toUpperCase()+n.slice(1),r="get"+s+"AtOutCoords",o=t.shapeInfo.logicalShape.length,i=e.logicalShape.length,a=UA(t.shapeInfo.logicalShape,e.logicalShape),l=Ze(i),c=i-o;let u;const h=["x","y","z","w","u","v"];o===0?u="":i<2&&a.length>=1?u="coords = 0;":u=a.map(y=>`coords.${h[y+c]} = 0;`).join(` +`);let d="";i<2&&o>0?d="coords":d=t.shapeInfo.logicalShape.map((y,w)=>`coords.${h[w+c]}`).join(", ");let f="return outputValue;";const g=j(t.shapeInfo.logicalShape)===1,m=j(e.logicalShape)===1;if(o===1&&!g&&!m)f=` return vec4(outputValue.xy, outputValue.xy); `;else if(g&&!m)i===1?f=` return vec4(outputValue.x, outputValue.x, 0., 0.); @@ -12234,18 +12234,18 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, vec4 ${r}() { ${l} coords = getOutputCoords(); ${u} - vec4 outputValue = get${s}(${h}); + vec4 outputValue = get${s}(${d}); ${f} } - `}function vY(t,e){const n=t.name,s=n.charAt(0).toUpperCase()+n.slice(1),r="get"+s+"AtOutCoords",o=e.texShape,i=t.shapeInfo.texShape,a=t.shapeInfo.logicalShape.length,l=e.logicalShape.length;if(!t.shapeInfo.isUniform&&a===l&&t.shapeInfo.flatOffset==null&&Ue(i,o))return` + `}function bY(t,e){const n=t.name,s=n.charAt(0).toUpperCase()+n.slice(1),r="get"+s+"AtOutCoords",o=e.texShape,i=t.shapeInfo.texShape,a=t.shapeInfo.logicalShape.length,l=e.logicalShape.length;if(!t.shapeInfo.isUniform&&a===l&&t.shapeInfo.flatOffset==null&&Ue(i,o))return` float ${r}() { return sampleTexture(${n}, resultUV); } - `;const c=Ze(l),u=WA(t.shapeInfo.logicalShape,e.logicalShape),d=l-a;let h;const f=["x","y","z","w","u","v"];a===0?h="":l<2&&u.length>=1?h="coords = 0;":h=u.map(g=>`coords.${f[g+d]} = 0;`).join(` -`);let p="";return l<2&&a>0?p="coords":p=t.shapeInfo.logicalShape.map((g,x)=>`coords.${f[x+d]}`).join(", "),` + `;const c=Ze(l),u=UA(t.shapeInfo.logicalShape,e.logicalShape),h=l-a;let d;const f=["x","y","z","w","u","v"];a===0?d="":l<2&&u.length>=1?d="coords = 0;":d=u.map(g=>`coords.${f[g+h]} = 0;`).join(` +`);let p="";return l<2&&a>0?p="coords":p=t.shapeInfo.logicalShape.map((g,x)=>`coords.${f[x+h]}`).join(", "),` float ${r}() { ${c} coords = getOutputCoords(); - ${h} + ${d} return get${s}(${p}); } `}function Ze(t){if(t<=1)return"int";if(t===2)return"ivec2";if(t===3)return"ivec3";if(t===4)return"ivec4";if(t===5)return"ivec5";if(t===6)return"ivec6";throw Error(`GPU for rank ${t} is not yet supported`)}function kv(t,e,n){const{newShape:s,keptDims:r}=Vo(e),o=e.length,i=t&&o===3&&e[0]===1,a=i?e.slice(1):s,l=!t&&o>1&&!Ue(e,n)&&s.lengtht[n]).join(", ")}/** @@ -12263,7 +12263,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function bY(t,e,n,s){const r=n.map((u,d)=>{const h={logicalShape:u.shape,texShape:u.isUniform?null:u.texData.texShape,isUniform:u.isUniform,isPacked:u.isUniform?!1:u.texData.isPacked,flatOffset:null};return u.texData!=null&&u.texData.slice!=null&&u.texData.slice.flatOffset>0&&(h.flatOffset=u.texData.slice.flatOffset),{name:e.variableNames[d],shapeInfo:h}}),o=r.map(u=>u.shapeInfo),i={logicalShape:s.shape,texShape:s.texData.texShape,isUniform:!1,isPacked:s.texData.isPacked,flatOffset:null},a=L9(r,i,e),l=p9(t.gl,a),c=t.createProgram(l);return W().get("ENGINE_COMPILE_ONLY")?{program:e,fragmentShader:l,source:a,webGLProgram:c,inShapeInfos:o,outShapeInfo:i,variablesLocations:null,customUniformLocations:null,infLoc:null,nanLoc:null,outShapeLocation:null,outShapeStridesLocation:null,outTexShapeLocation:null}:(t.buildVao(c),Object.assign({program:e,fragmentShader:l,source:a,webGLProgram:c,inShapeInfos:o,outShapeInfo:i},HA(t,e,c)))}function HA(t,e,n){const s=[],r=[];let o,i,a,l=null,c=null;c=t.getUniformLocation(n,"NAN",!1),W().getNumber("WEBGL_VERSION")===1&&(l=t.getUniformLocation(n,"INFINITY",!1));const u=!1;for(const d of e.variableNames){const h={name:d,uniform:t.getUniformLocation(n,d,u),offset:t.getUniformLocation(n,`offset${d}`,u)};e.enableShapeUniforms&&(h.shape=t.getUniformLocation(n,`${d}Shape`,u),h.texShape=t.getUniformLocation(n,`${d}TexShape`,u)),s.push(h)}if(e.enableShapeUniforms&&(o=t.getUniformLocation(n,"outShape",u),a=t.getUniformLocation(n,"outShapeStrides",u),i=t.getUniformLocation(n,"outTexShape",u)),e.customUniforms)for(const d of e.customUniforms)r.push(t.getUniformLocation(n,d.name,u));return{variablesLocations:s,customUniformLocations:r,infLoc:l,nanLoc:c,outShapeLocation:o,outShapeStridesLocation:a,outTexShapeLocation:i}}function Ik(t,e){if(t.length!==e.length)throw Error(`Binary was compiled with ${t.length} inputs, but was executed with ${e.length} inputs`);t.forEach((n,s)=>{const r=n.logicalShape,o=e[s],i=o.shape;if(!Ue(r,i))throw Error(`Binary was compiled with different shapes than the current args. Shapes ${r} and ${i} must match`);if(n.isUniform&&o.isUniform)return;const a=n.texShape,l=o.isUniform?null:o.texData.texShape;if(!Ue(a,l))throw Error(`Binary was compiled with different texture shapes than the current args. Shape ${a} and ${l} must match`)})}function CY(t,e,n,s,r){e.program.enableShapeUniforms||(Ik(e.inShapeInfos,n),Ik([e.outShapeInfo],[s]));const o=s.texData.texture,i=s.texData.texShape;s.texData.isPacked?t.setOutputPackedMatrixTexture(o.texture,i[0],i[1]):t.setOutputMatrixTexture(o.texture,i[0],i[1]),t.setProgram(e.webGLProgram),t.bindVertexArray(e.webGLProgram.vao),W().getNumber("WEBGL_VERSION")===1&&e.infLoc!==null&&t.gl.uniform1f(e.infLoc,1/0),e.nanLoc!==null&&t.gl.uniform1f(e.nanLoc,NaN);for(let l=0;l{const a=i.texData!=null&&i.texData.slice!=null&&i.texData.slice.flatOffset>0;if(t.enableShapeUniforms&&!i.isUniform){const l=i.texData.texShape,{useSqueezeShape:c,uniformShape:u,keptDims:d}=kv(t.packedInputs,i.shape,l);let h="",f="",p="";if(u.length===1&&t.packedInputs){const b=[Math.ceil(l[0]/2),Math.ceil(l[1]/2)];h=`${b[0]>1}_${b[1]>1}`}else if(u.length===2&&!t.packedInputs)f=`${u[0]>1}_${u[1]>1}`;else if(u.length>2&&!t.packedInputs){const b=pe(u);p=`${b[0]===l[1]}_${b[b.length-1]===l[1]}`}const g=i.shape.length,x=u.length===2&&Ue(i.shape,l),m=j(i.shape)===1,y=il(i.shape,n.shape),w=!t.packedInputs&&g===n.shape.length&&Ue(l,n.texData.texShape),v=t.packedInputs||u.length>2?"":`${l[0]>1}_${l[1]>1}`;s+=`${g}_${w}_${c?d:""}_${u.length}_${m}_${y}_${x}_${h}_${f}_${p}_${v}_${a}`}else{const l=i.isUniform?"uniform":i.texData.texShape;s+=`${i.shape}_${l}_${a}`}});const r=t.userCode;let o=t.constructor.name;return o+="_"+s+"_"+r+`${W().getNumber("WEBGL_VERSION")}`,o}function pn(t){return W().getBool("WEBGL_USE_SHAPES_UNIFORMS")&&t<=4}/** + */function CY(t,e,n,s){const r=n.map((u,h)=>{const d={logicalShape:u.shape,texShape:u.isUniform?null:u.texData.texShape,isUniform:u.isUniform,isPacked:u.isUniform?!1:u.texData.isPacked,flatOffset:null};return u.texData!=null&&u.texData.slice!=null&&u.texData.slice.flatOffset>0&&(d.flatOffset=u.texData.slice.flatOffset),{name:e.variableNames[h],shapeInfo:d}}),o=r.map(u=>u.shapeInfo),i={logicalShape:s.shape,texShape:s.texData.texShape,isUniform:!1,isPacked:s.texData.isPacked,flatOffset:null},a=B9(r,i,e),l=m9(t.gl,a),c=t.createProgram(l);return W().get("ENGINE_COMPILE_ONLY")?{program:e,fragmentShader:l,source:a,webGLProgram:c,inShapeInfos:o,outShapeInfo:i,variablesLocations:null,customUniformLocations:null,infLoc:null,nanLoc:null,outShapeLocation:null,outShapeStridesLocation:null,outTexShapeLocation:null}:(t.buildVao(c),Object.assign({program:e,fragmentShader:l,source:a,webGLProgram:c,inShapeInfos:o,outShapeInfo:i},jA(t,e,c)))}function jA(t,e,n){const s=[],r=[];let o,i,a,l=null,c=null;c=t.getUniformLocation(n,"NAN",!1),W().getNumber("WEBGL_VERSION")===1&&(l=t.getUniformLocation(n,"INFINITY",!1));const u=!1;for(const h of e.variableNames){const d={name:h,uniform:t.getUniformLocation(n,h,u),offset:t.getUniformLocation(n,`offset${h}`,u)};e.enableShapeUniforms&&(d.shape=t.getUniformLocation(n,`${h}Shape`,u),d.texShape=t.getUniformLocation(n,`${h}TexShape`,u)),s.push(d)}if(e.enableShapeUniforms&&(o=t.getUniformLocation(n,"outShape",u),a=t.getUniformLocation(n,"outShapeStrides",u),i=t.getUniformLocation(n,"outTexShape",u)),e.customUniforms)for(const h of e.customUniforms)r.push(t.getUniformLocation(n,h.name,u));return{variablesLocations:s,customUniformLocations:r,infLoc:l,nanLoc:c,outShapeLocation:o,outShapeStridesLocation:a,outTexShapeLocation:i}}function Ik(t,e){if(t.length!==e.length)throw Error(`Binary was compiled with ${t.length} inputs, but was executed with ${e.length} inputs`);t.forEach((n,s)=>{const r=n.logicalShape,o=e[s],i=o.shape;if(!Ue(r,i))throw Error(`Binary was compiled with different shapes than the current args. Shapes ${r} and ${i} must match`);if(n.isUniform&&o.isUniform)return;const a=n.texShape,l=o.isUniform?null:o.texData.texShape;if(!Ue(a,l))throw Error(`Binary was compiled with different texture shapes than the current args. Shape ${a} and ${l} must match`)})}function kY(t,e,n,s,r){e.program.enableShapeUniforms||(Ik(e.inShapeInfos,n),Ik([e.outShapeInfo],[s]));const o=s.texData.texture,i=s.texData.texShape;s.texData.isPacked?t.setOutputPackedMatrixTexture(o.texture,i[0],i[1]):t.setOutputMatrixTexture(o.texture,i[0],i[1]),t.setProgram(e.webGLProgram),t.bindVertexArray(e.webGLProgram.vao),W().getNumber("WEBGL_VERSION")===1&&e.infLoc!==null&&t.gl.uniform1f(e.infLoc,1/0),e.nanLoc!==null&&t.gl.uniform1f(e.nanLoc,NaN);for(let l=0;l{const a=i.texData!=null&&i.texData.slice!=null&&i.texData.slice.flatOffset>0;if(t.enableShapeUniforms&&!i.isUniform){const l=i.texData.texShape,{useSqueezeShape:c,uniformShape:u,keptDims:h}=kv(t.packedInputs,i.shape,l);let d="",f="",p="";if(u.length===1&&t.packedInputs){const b=[Math.ceil(l[0]/2),Math.ceil(l[1]/2)];d=`${b[0]>1}_${b[1]>1}`}else if(u.length===2&&!t.packedInputs)f=`${u[0]>1}_${u[1]>1}`;else if(u.length>2&&!t.packedInputs){const b=pe(u);p=`${b[0]===l[1]}_${b[b.length-1]===l[1]}`}const g=i.shape.length,x=u.length===2&&Ue(i.shape,l),m=j(i.shape)===1,y=il(i.shape,n.shape),w=!t.packedInputs&&g===n.shape.length&&Ue(l,n.texData.texShape),v=t.packedInputs||u.length>2?"":`${l[0]>1}_${l[1]>1}`;s+=`${g}_${w}_${c?h:""}_${u.length}_${m}_${y}_${x}_${d}_${f}_${p}_${v}_${a}`}else{const l=i.isUniform?"uniform":i.texData.texShape;s+=`${i.shape}_${l}_${a}`}});const r=t.userCode;let o=t.constructor.name;return o+="_"+s+"_"+r+`${W().getNumber("WEBGL_VERSION")}`,o}function pn(t){return W().getBool("WEBGL_USE_SHAPES_UNIFORMS")&&t<=4}/** * @license * Copyright 2019 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -12278,7 +12278,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class SY{constructor(e){this.variableNames=["A"],this.packedInputs=!1,this.packedOutput=!0,this.outPackingScheme=eu.DENSE,this.customUniforms=[{name:"texShape",type:"ivec2"}];const n=$n();this.outputShape=e,this.enableShapeUniforms=pn(this.outputShape.length),this.userCode=` + */class IY{constructor(e){this.variableNames=["A"],this.packedInputs=!1,this.packedOutput=!0,this.outPackingScheme=eu.DENSE,this.customUniforms=[{name:"texShape",type:"ivec2"}];const n=$n();this.outputShape=e,this.enableShapeUniforms=pn(this.outputShape.length),this.userCode=` ivec3 outCoordsFromFlatIndex(int index) { ${this.enableShapeUniforms?Mm(["r","c","d"],e):ea(["r","c","d"],e)} return ivec3(r, c, d); @@ -12313,7 +12313,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class IY{constructor(e){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!0,this.outPackingScheme=eu.DENSE,this.customUniforms=[{name:"texShape",type:"ivec2"}];const n=$n();this.outputShape=e,this.enableShapeUniforms=pn(this.outputShape.length),this.userCode=` + */class $Y{constructor(e){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!0,this.outPackingScheme=eu.DENSE,this.customUniforms=[{name:"texShape",type:"ivec2"}];const n=$n();this.outputShape=e,this.enableShapeUniforms=pn(this.outputShape.length),this.userCode=` ivec3 outCoordsFromFlatIndex(int index) { ${this.enableShapeUniforms?Mm(["r","c","d"],e):ea(["r","c","d"],e)} return ivec3(r, c, d); @@ -12348,8 +12348,8 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class $Y{constructor(e){this.variableNames=["A"],this.outTexUsage=ns.DOWNLOAD;const n=$n();this.outputShape=e,this.userCode=` - ${VA} + */class NY{constructor(e){this.variableNames=["A"],this.outTexUsage=ns.DOWNLOAD;const n=$n();this.outputShape=e,this.userCode=` + ${WA} void main() { float x = getAAtOutCoords(); @@ -12370,8 +12370,8 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class NY{constructor(e){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!1,this.outTexUsage=ns.DOWNLOAD;const n=$n();this.outputShape=e,this.userCode=` - ${VA} + */class TY{constructor(e){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!1,this.outTexUsage=ns.DOWNLOAD;const n=$n();this.outputShape=e,this.userCode=` + ${WA} void main() { ivec3 coords = getOutputCoords(); @@ -12393,9 +12393,9 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const TY={R:0,G:1,B:2,A:3};class $k{constructor(e,n=!1,s="RGBA"){this.variableNames=["A"],this.customUniforms=[{name:"texShape",type:"ivec2"}];const r=$n();this.outputShape=e,this.enableShapeUniforms=pn(this.outputShape.length);let o="result";n&&(o="floor(result * 255. + 0.5)");let i="";for(let a=0;at.bindTexture(a,i)),ae(t,()=>t.texParameteri(a,t.TEXTURE_WRAP_S,t.CLAMP_TO_EDGE)),ae(t,()=>t.texParameteri(a,t.TEXTURE_WRAP_T,t.CLAMP_TO_EDGE)),ae(t,()=>t.texParameteri(a,t.TEXTURE_MIN_FILTER,t.NEAREST)),ae(t,()=>t.texParameteri(a,t.TEXTURE_MAG_FILTER,t.NEAREST)),W().getNumber("WEBGL_VERSION")===1?ae(t,()=>t.texImage2D(a,0,s,e,n,0,r,o,null)):ae(t,()=>t.texStorage2D(a,1,s,e,n)),ae(t,()=>t.bindTexture(t.TEXTURE_2D,null)),{texture:i,texShape:[n,e]}}function jA(t){return t.internalFormatFloat}function _Y(t,e,n,s){const[r,o]=Td(e,n);return Rd(t,r,o,jA(s),s.textureFormatFloat,t.FLOAT)}function KA(t){return t.internalFormatHalfFloat}function FY(t,e,n,s){const[r,o]=Td(e,n);return Rd(t,r,o,KA(s),s.textureFormatFloat,s.textureTypeHalfFloat)}function XA(t){return t.downloadTextureFormat}function zY(t,e,n,s){const[r,o]=Td(e,n);return Rd(t,r,o,XA(s),t.RGBA,t.UNSIGNED_BYTE)}function qA(t){return t.internalFormatPackedFloat}function OY(t,e,n,s){const[r,o]=Nl(e,n);return Rd(t,r,o,qA(s),t.RGBA,t.FLOAT)}function YA(t){return t.internalFormatPackedHalfFloat}function MY(t,e,n,s){const[r,o]=Nl(e,n);return Rd(t,r,o,YA(s),t.RGBA,s.textureTypeHalfFloat)}function PY(t,e,n){return ae(t,()=>t.bindBuffer(t.ARRAY_BUFFER,n)),Ck(t,e,"clipSpacePos",n,3,20,0)&&Ck(t,e,"uv",n,2,20,12)}function LY(t,e,n,s,r,o){ae(t,()=>t.bindTexture(t.TEXTURE_2D,e));let i,a,l;r instanceof Uint8Array?(i=new Uint8Array(n*s*4),a=t.UNSIGNED_BYTE,l=t.RGBA):(i=new Float32Array(n*s*4),a=t.FLOAT,l=o.internalFormatPackedFloat),i.set(r),W().getNumber("WEBGL_VERSION")===2?ae(t,()=>t.texSubImage2D(t.TEXTURE_2D,0,0,0,n,s,t.RGBA,a,i)):ae(t,()=>t.texImage2D(t.TEXTURE_2D,0,l,n,s,0,t.RGBA,a,i)),ae(t,()=>t.bindTexture(t.TEXTURE_2D,null))}function BY(t,e,n){ae(t,()=>t.bindTexture(t.TEXTURE_2D,e)),n.data instanceof Uint8Array?W().getNumber("WEBGL_VERSION")===2?ae(t,()=>t.texSubImage2D(t.TEXTURE_2D,0,0,0,n.width,n.height,t.RGBA,t.UNSIGNED_BYTE,n.data)):ae(t,()=>t.texImage2D(t.TEXTURE_2D,0,t.RGBA,n.width,n.height,0,t.RGBA,t.UNSIGNED_BYTE,n.data)):W().getNumber("WEBGL_VERSION")===2?ae(t,()=>t.texSubImage2D(t.TEXTURE_2D,0,0,0,t.RGBA,t.UNSIGNED_BYTE,n)):ae(t,()=>t.texImage2D(t.TEXTURE_2D,0,t.RGBA,t.RGBA,t.UNSIGNED_BYTE,n)),ae(t,()=>t.bindTexture(t.TEXTURE_2D,null))}function VY(t,e,n,s){const r=t.createBuffer();ae(t,()=>t.bindBuffer(t.PIXEL_PACK_BUFFER,r));const a=4*4*e*n;return ae(t,()=>t.bufferData(t.PIXEL_PACK_BUFFER,a,t.STREAM_READ)),ae(t,()=>t.readPixels(0,0,n,e,t.RGBA,t.FLOAT,0)),ae(t,()=>t.bindBuffer(t.PIXEL_PACK_BUFFER,null)),r}function WY(t,e,n){const s=t,r=new Float32Array(n);return s.bindBuffer(s.PIXEL_PACK_BUFFER,e),s.getBufferSubData(s.PIXEL_PACK_BUFFER,0,r),s.bindBuffer(s.PIXEL_PACK_BUFFER,null),r}function UY(t,e,n,s){const[r,o]=Td(e,n),i=4,a=new Uint8Array(i9(e*n,i));return ae(t,()=>t.readPixels(0,0,r,o,s.downloadTextureFormat,t.UNSIGNED_BYTE,a)),new Float32Array(a.buffer)}function GY(t,e,n,s,r,o,i,a){const l=t,c=new Float32Array(a9(o,i));return l.bindBuffer(l.PIXEL_PACK_BUFFER,e),l.getBufferSubData(l.PIXEL_PACK_BUFFER,0,c),l.bindBuffer(l.PIXEL_PACK_BUFFER,null),c}function HY(t,e,n){const s=new Float32Array(e*n*4);return ae(t,()=>t.readPixels(0,0,n,e,t.RGBA,t.FLOAT,s)),s}/** + }`;return p9(t,n)}function DY(t){const e=new Float32Array([-1,1,0,0,1,-1,-1,0,0,0,1,1,0,1,1,1,-1,0,1,0]);return w9(t,e)}function _Y(t){const e=new Uint16Array([0,1,2,2,1,3]);return v9(t,e)}function Rh(t,e,n,s,r,o){C9(e,n);const i=b9(t),a=t.TEXTURE_2D;return ae(t,()=>t.bindTexture(a,i)),ae(t,()=>t.texParameteri(a,t.TEXTURE_WRAP_S,t.CLAMP_TO_EDGE)),ae(t,()=>t.texParameteri(a,t.TEXTURE_WRAP_T,t.CLAMP_TO_EDGE)),ae(t,()=>t.texParameteri(a,t.TEXTURE_MIN_FILTER,t.NEAREST)),ae(t,()=>t.texParameteri(a,t.TEXTURE_MAG_FILTER,t.NEAREST)),W().getNumber("WEBGL_VERSION")===1?ae(t,()=>t.texImage2D(a,0,s,e,n,0,r,o,null)):ae(t,()=>t.texStorage2D(a,1,s,e,n)),ae(t,()=>t.bindTexture(t.TEXTURE_2D,null)),{texture:i,texShape:[n,e]}}function KA(t){return t.internalFormatFloat}function FY(t,e,n,s){const[r,o]=Th(e,n);return Rh(t,r,o,KA(s),s.textureFormatFloat,t.FLOAT)}function XA(t){return t.internalFormatHalfFloat}function zY(t,e,n,s){const[r,o]=Th(e,n);return Rh(t,r,o,XA(s),s.textureFormatFloat,s.textureTypeHalfFloat)}function qA(t){return t.downloadTextureFormat}function OY(t,e,n,s){const[r,o]=Th(e,n);return Rh(t,r,o,qA(s),t.RGBA,t.UNSIGNED_BYTE)}function YA(t){return t.internalFormatPackedFloat}function MY(t,e,n,s){const[r,o]=Nl(e,n);return Rh(t,r,o,YA(s),t.RGBA,t.FLOAT)}function QA(t){return t.internalFormatPackedHalfFloat}function PY(t,e,n,s){const[r,o]=Nl(e,n);return Rh(t,r,o,QA(s),t.RGBA,s.textureTypeHalfFloat)}function LY(t,e,n){return ae(t,()=>t.bindBuffer(t.ARRAY_BUFFER,n)),Ck(t,e,"clipSpacePos",n,3,20,0)&&Ck(t,e,"uv",n,2,20,12)}function BY(t,e,n,s,r,o){ae(t,()=>t.bindTexture(t.TEXTURE_2D,e));let i,a,l;r instanceof Uint8Array?(i=new Uint8Array(n*s*4),a=t.UNSIGNED_BYTE,l=t.RGBA):(i=new Float32Array(n*s*4),a=t.FLOAT,l=o.internalFormatPackedFloat),i.set(r),W().getNumber("WEBGL_VERSION")===2?ae(t,()=>t.texSubImage2D(t.TEXTURE_2D,0,0,0,n,s,t.RGBA,a,i)):ae(t,()=>t.texImage2D(t.TEXTURE_2D,0,l,n,s,0,t.RGBA,a,i)),ae(t,()=>t.bindTexture(t.TEXTURE_2D,null))}function VY(t,e,n){ae(t,()=>t.bindTexture(t.TEXTURE_2D,e)),n.data instanceof Uint8Array?W().getNumber("WEBGL_VERSION")===2?ae(t,()=>t.texSubImage2D(t.TEXTURE_2D,0,0,0,n.width,n.height,t.RGBA,t.UNSIGNED_BYTE,n.data)):ae(t,()=>t.texImage2D(t.TEXTURE_2D,0,t.RGBA,n.width,n.height,0,t.RGBA,t.UNSIGNED_BYTE,n.data)):W().getNumber("WEBGL_VERSION")===2?ae(t,()=>t.texSubImage2D(t.TEXTURE_2D,0,0,0,t.RGBA,t.UNSIGNED_BYTE,n)):ae(t,()=>t.texImage2D(t.TEXTURE_2D,0,t.RGBA,t.RGBA,t.UNSIGNED_BYTE,n)),ae(t,()=>t.bindTexture(t.TEXTURE_2D,null))}function WY(t,e,n,s){const r=t.createBuffer();ae(t,()=>t.bindBuffer(t.PIXEL_PACK_BUFFER,r));const a=4*4*e*n;return ae(t,()=>t.bufferData(t.PIXEL_PACK_BUFFER,a,t.STREAM_READ)),ae(t,()=>t.readPixels(0,0,n,e,t.RGBA,t.FLOAT,0)),ae(t,()=>t.bindBuffer(t.PIXEL_PACK_BUFFER,null)),r}function UY(t,e,n){const s=t,r=new Float32Array(n);return s.bindBuffer(s.PIXEL_PACK_BUFFER,e),s.getBufferSubData(s.PIXEL_PACK_BUFFER,0,r),s.bindBuffer(s.PIXEL_PACK_BUFFER,null),r}function GY(t,e,n,s){const[r,o]=Th(e,n),i=4,a=new Uint8Array(a9(e*n,i));return ae(t,()=>t.readPixels(0,0,r,o,s.downloadTextureFormat,t.UNSIGNED_BYTE,a)),new Float32Array(a.buffer)}function HY(t,e,n,s,r,o,i,a){const l=t,c=new Float32Array(l9(o,i));return l.bindBuffer(l.PIXEL_PACK_BUFFER,e),l.getBufferSubData(l.PIXEL_PACK_BUFFER,0,c),l.bindBuffer(l.PIXEL_PACK_BUFFER,null),c}function jY(t,e,n){const s=new Float32Array(e*n*4);return ae(t,()=>t.readPixels(0,0,n,e,t.RGBA,t.FLOAT,s)),s}/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -12514,7 +12514,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class Og{constructor(e){this.outputTexture=null,this.program=null,this.disposed=!1,this.itemsToPoll=[];const n=W().getNumber("WEBGL_VERSION");if(e!=null?(this.gl=e,s9(n,e)):this.gl=er(n),e=this.gl,W().getNumber("WEBGL_VERSION")===2){const o=e;this.createVertexArray=()=>ae(o,()=>o.createVertexArray()),this.bindVertexArray=i=>ae(o,()=>o.bindVertexArray(i)),this.deleteVertexArray=i=>ae(o,()=>o.deleteVertexArray(i)),this.getVertexArray=()=>ae(o,()=>o.getParameter(o.VERTEX_ARRAY_BINDING))}else if(e!=null){const o=e.getExtension("OES_vertex_array_object");if(o==null)throw new Error("All WebGL1 implementations are expected to offer OES_vertex_array_object.");this.createVertexArray=()=>ae(e,()=>o.createVertexArrayOES()),this.bindVertexArray=i=>ae(e,()=>o.bindVertexArrayOES(i)),this.deleteVertexArray=i=>ae(e,()=>o.deleteVertexArrayOES(i)),this.getVertexArray=()=>ae(e,()=>e.getParameter(o.VERTEX_ARRAY_BINDING_OES))}let s="WEBGL_color_buffer_float";const r="EXT_color_buffer_half_float";if(this.parallelCompilationExtension=this.gl.getExtension("KHR_parallel_shader_compile"),W().getNumber("WEBGL_VERSION")===1){const o="OES_texture_float",i="OES_texture_half_float";if(this.textureFloatExtension=ih(this.gl,o),ks(this.gl,i))this.textureHalfFloatExtension=ih(this.gl,i);else if(W().get("WEBGL_FORCE_F16_TEXTURES"))throw new Error("GL context does not support half float textures, yet the environment flag WEBGL_FORCE_F16_TEXTURES is set to true.");if(this.colorBufferFloatExtension=this.gl.getExtension(s),ks(this.gl,r))this.colorBufferHalfFloatExtension=ih(this.gl,r);else if(W().get("WEBGL_FORCE_F16_TEXTURES"))throw new Error("GL context does not support color renderable half floats, yet the environment flag WEBGL_FORCE_F16_TEXTURES is set to true.")}else if(s="EXT_color_buffer_float",ks(this.gl,s))this.colorBufferFloatExtension=this.gl.getExtension(s);else if(ks(this.gl,r))this.colorBufferHalfFloatExtension=this.gl.getExtension(r);else throw new Error("GL context does not support color renderable floats");this.vertexBuffer=AY(this.gl),this.indexBuffer=DY(this.gl),this.framebuffer=C9(this.gl),this.textureConfig=vv(this.gl,this.textureHalfFloatExtension)}get debug(){return W().getBool("DEBUG")}dispose(){if(this.disposed)return;this.program!=null&&console.warn("Disposing a GPGPUContext that still has a bound WebGLProgram. This is probably a resource leak, delete the program with GPGPUContext.deleteProgram before disposing."),this.outputTexture!=null&&console.warn("Disposing a GPGPUContext that still has a bound output matrix texture. This is probably a resource leak, delete the output matrix texture with GPGPUContext.deleteMatrixTexture before disposing.");const e=this.gl;ae(e,()=>e.finish()),ae(e,()=>e.bindFramebuffer(e.FRAMEBUFFER,null)),ae(e,()=>e.deleteFramebuffer(this.framebuffer)),ae(e,()=>e.bindBuffer(e.ARRAY_BUFFER,null)),ae(e,()=>e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,null)),ae(e,()=>e.deleteBuffer(this.indexBuffer)),this.disposed=!0}createFloat32MatrixTexture(e,n){return this.throwIfDisposed(),_Y(this.gl,e,n,this.textureConfig)}createFloat16MatrixTexture(e,n){return this.throwIfDisposed(),FY(this.gl,e,n,this.textureConfig)}createUnsignedBytesMatrixTexture(e,n){return this.throwIfDisposed(),zY(this.gl,e,n,this.textureConfig)}uploadPixelDataToTexture(e,n){this.throwIfDisposed(),BY(this.gl,e,n)}uploadDenseMatrixToTexture(e,n,s,r){this.throwIfDisposed(),LY(this.gl,e,n,s,r,this.textureConfig)}createFloat16PackedMatrixTexture(e,n){return this.throwIfDisposed(),MY(this.gl,e,n,this.textureConfig)}createPackedMatrixTexture(e,n){return this.throwIfDisposed(),OY(this.gl,e,n,this.textureConfig)}deleteMatrixTexture(e){this.throwIfDisposed(),this.outputTexture===e&&(kk(this.gl,this.framebuffer),this.outputTexture=null),ae(this.gl,()=>this.gl.deleteTexture(e))}downloadByteEncodedFloatMatrixFromOutputTexture(e,n,s){return this.downloadMatrixDriver(e,()=>UY(this.gl,n,s,this.textureConfig))}downloadPackedMatrixFromBuffer(e,n,s,r,o,i){return GY(this.gl,e,n,s,r,o,i,this.textureConfig)}downloadFloat32MatrixFromBuffer(e,n){return WY(this.gl,e,n)}createBufferFromTexture(e,n,s){this.bindTextureToFrameBuffer(e);const r=VY(this.gl,n,s,this.textureConfig);return this.unbindTextureToFrameBuffer(),r}createAndWaitForFence(){const e=this.createFence(this.gl);return this.pollFence(e)}createFence(e){let n,s;if(W().getBool("WEBGL_FENCE_API_ENABLED")){const r=e,o=r.fenceSync(r.SYNC_GPU_COMMANDS_COMPLETE,0);e.flush(),s=()=>{const i=r.clientWaitSync(o,0,0);return i===r.ALREADY_SIGNALED||i===r.CONDITION_SATISFIED},n=o}else W().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")>0?(n=this.beginQuery(),this.endQuery(),s=()=>this.isQueryAvailable(n,W().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION"))):s=()=>!0;return{query:n,isFencePassed:s}}downloadMatrixFromPackedTexture(e,n,s){return this.downloadMatrixDriver(e,()=>HY(this.gl,n,s))}createProgram(e){this.throwIfDisposed();const n=this.gl;this.vertexShader==null&&(this.vertexShader=RY(n));const s=g9(n);ae(n,()=>n.attachShader(s,this.vertexShader)),ae(n,()=>n.attachShader(s,e)),x9(n,s);const r=Object.assign(s,{vao:this.createVertexArray()});return this.debug&&Dg(n,r),r}buildVao(e){this.setProgram(e),this.bindVertexArray(e.vao);const n=this.gl;ae(n,()=>n.bindBuffer(n.ELEMENT_ARRAY_BUFFER,this.indexBuffer)),PY(n,e,this.vertexBuffer)}deleteProgram(e){this.throwIfDisposed(),e===this.program&&(this.program=null),e!=null&&(ae(this.gl,()=>this.gl.deleteProgram(e)),this.deleteVertexArray(e.vao))}setProgram(e){this.throwIfDisposed(),this.program=e,this.program!=null&&this.debug&&Dg(this.gl,this.program),ae(this.gl,()=>this.gl.useProgram(e))}getUniformLocation(e,n,s=!0){return this.throwIfDisposed(),s?S9(this.gl,e,n):I9(this.gl,e,n)}getAttributeLocation(e,n){return this.throwIfDisposed(),ae(this.gl,()=>this.gl.getAttribLocation(e,n))}getUniformLocationNoThrow(e,n){return this.throwIfDisposed(),this.gl.getUniformLocation(e,n)}setInputMatrixTexture(e,n,s){this.throwIfDisposed(),this.throwIfNoProgram(),$9(this.gl,e,n,s)}setOutputMatrixTexture(e,n,s){this.setOutputMatrixTextureDriver(e,s,n)}setOutputPackedMatrixTexture(e,n,s){this.throwIfDisposed();const[r,o]=Nl(n,s);this.setOutputMatrixTextureDriver(e,r,o)}setOutputMatrixWriteRegion(e,n,s,r){this.setOutputMatrixWriteRegionDriver(s,e,r,n)}setOutputPackedMatrixWriteRegion(e,n,s,r){throw new Error("setOutputPackedMatrixWriteRegion not implemented.")}debugValidate(){this.program!=null&&Dg(this.gl,this.program),ah(this.gl)}executeProgram(){this.throwIfDisposed(),this.throwIfNoProgram();const e=this.gl;if(this.debug){const n=this.getVertexArray();console.assert(n===this.program.vao,"VAO changed between setProgram and executeProgram!"),this.debugValidate()}ae(e,()=>e.drawElements(e.TRIANGLES,6,e.UNSIGNED_SHORT,0))}blockUntilAllProgramsCompleted(){this.throwIfDisposed(),ae(this.gl,()=>this.gl.finish())}getQueryTimerExtension(){return this.disjointQueryTimerExtension==null&&(this.disjointQueryTimerExtension=ih(this.gl,W().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")===2?"EXT_disjoint_timer_query_webgl2":"EXT_disjoint_timer_query")),this.disjointQueryTimerExtension}getQueryTimerExtensionWebGL2(){return this.getQueryTimerExtension()}getQueryTimerExtensionWebGL1(){return this.getQueryTimerExtension()}beginQuery(){if(W().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")===2){const s=this.gl,r=this.getQueryTimerExtensionWebGL2(),o=s.createQuery();return s.beginQuery(r.TIME_ELAPSED_EXT,o),o}const e=this.getQueryTimerExtensionWebGL1(),n=e.createQueryEXT();return e.beginQueryEXT(e.TIME_ELAPSED_EXT,n),n}endQuery(){if(W().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")===2){const n=this.gl,s=this.getQueryTimerExtensionWebGL2();n.endQuery(s.TIME_ELAPSED_EXT);return}const e=this.getQueryTimerExtensionWebGL1();e.endQueryEXT(e.TIME_ELAPSED_EXT)}async waitForQueryAndGetTime(e){return await uC(()=>this.disposed||this.isQueryAvailable(e,W().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION"))),this.getQueryTime(e,W().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION"))}getQueryTime(e,n){if(n===0)return null;if(n===2){const s=this.gl;return s.getQueryParameter(e,s.QUERY_RESULT)/1e6}else{const s=this.getQueryTimerExtensionWebGL1();return s.getQueryObjectEXT(e,s.QUERY_RESULT_EXT)/1e6}}isQueryAvailable(e,n){if(n===0)return!0;if(n===2){const s=this.gl,r=this.getQueryTimerExtensionWebGL2(),o=s.getQueryParameter(e,s.QUERY_RESULT_AVAILABLE);return this.disjoint==null&&(this.disjoint=this.gl.getParameter(r.GPU_DISJOINT_EXT)),o&&!this.disjoint}else{const s=this.getQueryTimerExtensionWebGL1(),r=s.getQueryObjectEXT(e,s.QUERY_RESULT_AVAILABLE_EXT);return this.disjoint==null&&(this.disjoint=this.gl.getParameter(s.GPU_DISJOINT_EXT)),r&&!this.disjoint}}pollFence(e){return new Promise(n=>{this.addItemToPoll(()=>e.isFencePassed(),()=>n())})}pollItems(){const e=jY(this.itemsToPoll.map(n=>n.isDoneFn));for(let n=0;n<=e;++n){const{resolveFn:s}=this.itemsToPoll[n];s()}this.itemsToPoll=this.itemsToPoll.slice(e+1)}addItemToPoll(e,n){if(this.itemsToPoll.push({isDoneFn:e,resolveFn:n}),this.itemsToPoll.length>1)return;let s;"setTimeoutCustom"in W().platform&&(s=W().platform.setTimeoutCustom.bind(W().platform)),uC(()=>(this.pollItems(),this.itemsToPoll.length===0),()=>0,null,s)}bindTextureToFrameBuffer(e){this.throwIfDisposed(),_g(this.gl,e,this.framebuffer),this.debug&&ah(this.gl)}unbindTextureToFrameBuffer(){this.outputTexture!=null?(_g(this.gl,this.outputTexture,this.framebuffer),this.debug&&ah(this.gl)):kk(this.gl,this.framebuffer)}downloadMatrixDriver(e,n){this.bindTextureToFrameBuffer(e);const s=n();return this.unbindTextureToFrameBuffer(),s}setOutputMatrixTextureDriver(e,n,s){this.throwIfDisposed();const r=this.gl;_g(r,e,this.framebuffer),this.debug&&ah(r),this.outputTexture=e,ae(r,()=>r.viewport(0,0,n,s)),ae(r,()=>r.scissor(0,0,n,s))}setOutputMatrixWriteRegionDriver(e,n,s,r){this.throwIfDisposed(),ae(this.gl,()=>this.gl.scissor(e,n,s,r))}throwIfDisposed(){if(this.disposed)throw new Error("Attempted to use disposed GPGPUContext.")}throwIfNoProgram(){if(this.program==null)throw new Error("No GPU program is currently set.")}}function jY(t){let e=0;for(;eae(o,()=>o.createVertexArray()),this.bindVertexArray=i=>ae(o,()=>o.bindVertexArray(i)),this.deleteVertexArray=i=>ae(o,()=>o.deleteVertexArray(i)),this.getVertexArray=()=>ae(o,()=>o.getParameter(o.VERTEX_ARRAY_BINDING))}else if(e!=null){const o=e.getExtension("OES_vertex_array_object");if(o==null)throw new Error("All WebGL1 implementations are expected to offer OES_vertex_array_object.");this.createVertexArray=()=>ae(e,()=>o.createVertexArrayOES()),this.bindVertexArray=i=>ae(e,()=>o.bindVertexArrayOES(i)),this.deleteVertexArray=i=>ae(e,()=>o.deleteVertexArrayOES(i)),this.getVertexArray=()=>ae(e,()=>e.getParameter(o.VERTEX_ARRAY_BINDING_OES))}let s="WEBGL_color_buffer_float";const r="EXT_color_buffer_half_float";if(this.parallelCompilationExtension=this.gl.getExtension("KHR_parallel_shader_compile"),W().getNumber("WEBGL_VERSION")===1){const o="OES_texture_float",i="OES_texture_half_float";if(this.textureFloatExtension=id(this.gl,o),Ss(this.gl,i))this.textureHalfFloatExtension=id(this.gl,i);else if(W().get("WEBGL_FORCE_F16_TEXTURES"))throw new Error("GL context does not support half float textures, yet the environment flag WEBGL_FORCE_F16_TEXTURES is set to true.");if(this.colorBufferFloatExtension=this.gl.getExtension(s),Ss(this.gl,r))this.colorBufferHalfFloatExtension=id(this.gl,r);else if(W().get("WEBGL_FORCE_F16_TEXTURES"))throw new Error("GL context does not support color renderable half floats, yet the environment flag WEBGL_FORCE_F16_TEXTURES is set to true.")}else if(s="EXT_color_buffer_float",Ss(this.gl,s))this.colorBufferFloatExtension=this.gl.getExtension(s);else if(Ss(this.gl,r))this.colorBufferHalfFloatExtension=this.gl.getExtension(r);else throw new Error("GL context does not support color renderable floats");this.vertexBuffer=DY(this.gl),this.indexBuffer=_Y(this.gl),this.framebuffer=k9(this.gl),this.textureConfig=vv(this.gl,this.textureHalfFloatExtension)}get debug(){return W().getBool("DEBUG")}dispose(){if(this.disposed)return;this.program!=null&&console.warn("Disposing a GPGPUContext that still has a bound WebGLProgram. This is probably a resource leak, delete the program with GPGPUContext.deleteProgram before disposing."),this.outputTexture!=null&&console.warn("Disposing a GPGPUContext that still has a bound output matrix texture. This is probably a resource leak, delete the output matrix texture with GPGPUContext.deleteMatrixTexture before disposing.");const e=this.gl;ae(e,()=>e.finish()),ae(e,()=>e.bindFramebuffer(e.FRAMEBUFFER,null)),ae(e,()=>e.deleteFramebuffer(this.framebuffer)),ae(e,()=>e.bindBuffer(e.ARRAY_BUFFER,null)),ae(e,()=>e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,null)),ae(e,()=>e.deleteBuffer(this.indexBuffer)),this.disposed=!0}createFloat32MatrixTexture(e,n){return this.throwIfDisposed(),FY(this.gl,e,n,this.textureConfig)}createFloat16MatrixTexture(e,n){return this.throwIfDisposed(),zY(this.gl,e,n,this.textureConfig)}createUnsignedBytesMatrixTexture(e,n){return this.throwIfDisposed(),OY(this.gl,e,n,this.textureConfig)}uploadPixelDataToTexture(e,n){this.throwIfDisposed(),VY(this.gl,e,n)}uploadDenseMatrixToTexture(e,n,s,r){this.throwIfDisposed(),BY(this.gl,e,n,s,r,this.textureConfig)}createFloat16PackedMatrixTexture(e,n){return this.throwIfDisposed(),PY(this.gl,e,n,this.textureConfig)}createPackedMatrixTexture(e,n){return this.throwIfDisposed(),MY(this.gl,e,n,this.textureConfig)}deleteMatrixTexture(e){this.throwIfDisposed(),this.outputTexture===e&&(kk(this.gl,this.framebuffer),this.outputTexture=null),ae(this.gl,()=>this.gl.deleteTexture(e))}downloadByteEncodedFloatMatrixFromOutputTexture(e,n,s){return this.downloadMatrixDriver(e,()=>GY(this.gl,n,s,this.textureConfig))}downloadPackedMatrixFromBuffer(e,n,s,r,o,i){return HY(this.gl,e,n,s,r,o,i,this.textureConfig)}downloadFloat32MatrixFromBuffer(e,n){return UY(this.gl,e,n)}createBufferFromTexture(e,n,s){this.bindTextureToFrameBuffer(e);const r=WY(this.gl,n,s,this.textureConfig);return this.unbindTextureToFrameBuffer(),r}createAndWaitForFence(){const e=this.createFence(this.gl);return this.pollFence(e)}createFence(e){let n,s;if(W().getBool("WEBGL_FENCE_API_ENABLED")){const r=e,o=r.fenceSync(r.SYNC_GPU_COMMANDS_COMPLETE,0);e.flush(),s=()=>{const i=r.clientWaitSync(o,0,0);return i===r.ALREADY_SIGNALED||i===r.CONDITION_SATISFIED},n=o}else W().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")>0?(n=this.beginQuery(),this.endQuery(),s=()=>this.isQueryAvailable(n,W().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION"))):s=()=>!0;return{query:n,isFencePassed:s}}downloadMatrixFromPackedTexture(e,n,s){return this.downloadMatrixDriver(e,()=>jY(this.gl,n,s))}createProgram(e){this.throwIfDisposed();const n=this.gl;this.vertexShader==null&&(this.vertexShader=AY(n));const s=x9(n);ae(n,()=>n.attachShader(s,this.vertexShader)),ae(n,()=>n.attachShader(s,e)),y9(n,s);const r=Object.assign(s,{vao:this.createVertexArray()});return this.debug&&Dg(n,r),r}buildVao(e){this.setProgram(e),this.bindVertexArray(e.vao);const n=this.gl;ae(n,()=>n.bindBuffer(n.ELEMENT_ARRAY_BUFFER,this.indexBuffer)),LY(n,e,this.vertexBuffer)}deleteProgram(e){this.throwIfDisposed(),e===this.program&&(this.program=null),e!=null&&(ae(this.gl,()=>this.gl.deleteProgram(e)),this.deleteVertexArray(e.vao))}setProgram(e){this.throwIfDisposed(),this.program=e,this.program!=null&&this.debug&&Dg(this.gl,this.program),ae(this.gl,()=>this.gl.useProgram(e))}getUniformLocation(e,n,s=!0){return this.throwIfDisposed(),s?I9(this.gl,e,n):$9(this.gl,e,n)}getAttributeLocation(e,n){return this.throwIfDisposed(),ae(this.gl,()=>this.gl.getAttribLocation(e,n))}getUniformLocationNoThrow(e,n){return this.throwIfDisposed(),this.gl.getUniformLocation(e,n)}setInputMatrixTexture(e,n,s){this.throwIfDisposed(),this.throwIfNoProgram(),N9(this.gl,e,n,s)}setOutputMatrixTexture(e,n,s){this.setOutputMatrixTextureDriver(e,s,n)}setOutputPackedMatrixTexture(e,n,s){this.throwIfDisposed();const[r,o]=Nl(n,s);this.setOutputMatrixTextureDriver(e,r,o)}setOutputMatrixWriteRegion(e,n,s,r){this.setOutputMatrixWriteRegionDriver(s,e,r,n)}setOutputPackedMatrixWriteRegion(e,n,s,r){throw new Error("setOutputPackedMatrixWriteRegion not implemented.")}debugValidate(){this.program!=null&&Dg(this.gl,this.program),ad(this.gl)}executeProgram(){this.throwIfDisposed(),this.throwIfNoProgram();const e=this.gl;if(this.debug){const n=this.getVertexArray();console.assert(n===this.program.vao,"VAO changed between setProgram and executeProgram!"),this.debugValidate()}ae(e,()=>e.drawElements(e.TRIANGLES,6,e.UNSIGNED_SHORT,0))}blockUntilAllProgramsCompleted(){this.throwIfDisposed(),ae(this.gl,()=>this.gl.finish())}getQueryTimerExtension(){return this.disjointQueryTimerExtension==null&&(this.disjointQueryTimerExtension=id(this.gl,W().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")===2?"EXT_disjoint_timer_query_webgl2":"EXT_disjoint_timer_query")),this.disjointQueryTimerExtension}getQueryTimerExtensionWebGL2(){return this.getQueryTimerExtension()}getQueryTimerExtensionWebGL1(){return this.getQueryTimerExtension()}beginQuery(){if(W().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")===2){const s=this.gl,r=this.getQueryTimerExtensionWebGL2(),o=s.createQuery();return s.beginQuery(r.TIME_ELAPSED_EXT,o),o}const e=this.getQueryTimerExtensionWebGL1(),n=e.createQueryEXT();return e.beginQueryEXT(e.TIME_ELAPSED_EXT,n),n}endQuery(){if(W().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION")===2){const n=this.gl,s=this.getQueryTimerExtensionWebGL2();n.endQuery(s.TIME_ELAPSED_EXT);return}const e=this.getQueryTimerExtensionWebGL1();e.endQueryEXT(e.TIME_ELAPSED_EXT)}async waitForQueryAndGetTime(e){return await uC(()=>this.disposed||this.isQueryAvailable(e,W().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION"))),this.getQueryTime(e,W().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_VERSION"))}getQueryTime(e,n){if(n===0)return null;if(n===2){const s=this.gl;return s.getQueryParameter(e,s.QUERY_RESULT)/1e6}else{const s=this.getQueryTimerExtensionWebGL1();return s.getQueryObjectEXT(e,s.QUERY_RESULT_EXT)/1e6}}isQueryAvailable(e,n){if(n===0)return!0;if(n===2){const s=this.gl,r=this.getQueryTimerExtensionWebGL2(),o=s.getQueryParameter(e,s.QUERY_RESULT_AVAILABLE);return this.disjoint==null&&(this.disjoint=this.gl.getParameter(r.GPU_DISJOINT_EXT)),o&&!this.disjoint}else{const s=this.getQueryTimerExtensionWebGL1(),r=s.getQueryObjectEXT(e,s.QUERY_RESULT_AVAILABLE_EXT);return this.disjoint==null&&(this.disjoint=this.gl.getParameter(s.GPU_DISJOINT_EXT)),r&&!this.disjoint}}pollFence(e){return new Promise(n=>{this.addItemToPoll(()=>e.isFencePassed(),()=>n())})}pollItems(){const e=KY(this.itemsToPoll.map(n=>n.isDoneFn));for(let n=0;n<=e;++n){const{resolveFn:s}=this.itemsToPoll[n];s()}this.itemsToPoll=this.itemsToPoll.slice(e+1)}addItemToPoll(e,n){if(this.itemsToPoll.push({isDoneFn:e,resolveFn:n}),this.itemsToPoll.length>1)return;let s;"setTimeoutCustom"in W().platform&&(s=W().platform.setTimeoutCustom.bind(W().platform)),uC(()=>(this.pollItems(),this.itemsToPoll.length===0),()=>0,null,s)}bindTextureToFrameBuffer(e){this.throwIfDisposed(),_g(this.gl,e,this.framebuffer),this.debug&&ad(this.gl)}unbindTextureToFrameBuffer(){this.outputTexture!=null?(_g(this.gl,this.outputTexture,this.framebuffer),this.debug&&ad(this.gl)):kk(this.gl,this.framebuffer)}downloadMatrixDriver(e,n){this.bindTextureToFrameBuffer(e);const s=n();return this.unbindTextureToFrameBuffer(),s}setOutputMatrixTextureDriver(e,n,s){this.throwIfDisposed();const r=this.gl;_g(r,e,this.framebuffer),this.debug&&ad(r),this.outputTexture=e,ae(r,()=>r.viewport(0,0,n,s)),ae(r,()=>r.scissor(0,0,n,s))}setOutputMatrixWriteRegionDriver(e,n,s,r){this.throwIfDisposed(),ae(this.gl,()=>this.gl.scissor(e,n,s,r))}throwIfDisposed(){if(this.disposed)throw new Error("Attempted to use disposed GPGPUContext.")}throwIfNoProgram(){if(this.program==null)throw new Error("No GPU program is currently set.")}}function KY(t){let e=0;for(;e`${t}.${n}`)}function vn(t,e){return e===1?[t]:eD(t,e)}function PQ(t,e){if(t===1)return"rc";let n="";for(let s=0;s`${t}.${n}`)}function vn(t,e){return e===1?[t]:tD(t,e)}function LQ(t,e){if(t===1)return"rc";let n="";for(let s=0;s1&&(o+="thisRC.y += 1;"),s+=` + */class nD{constructor(e,n){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!0,this.customUniforms=[{name:"inputShape",type:"ivec3"}],this.outputShape=e,this.enableShapeUniforms=pn(this.outputShape.length);let s="";for(let r=0;r<4;r++){let o="thisRC = rc;";r%2===1&&(o+="thisRC.z += 1;"),r>1&&(o+="thisRC.y += 1;"),s+=` ${o} ${r>0?"if(thisRC.y < rows && thisRC.z < cols){":""} int flatIndex = getFlatIndex(thisRC); @@ -12613,7 +12613,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, getChannel(getA(inputRC.x, inputRC.y, inputRC.z), inputRCInnerDims); ${r>0?"}":""} `}this.userCode=` - ${BQ(n,this.enableShapeUniforms)} + ${VQ(n,this.enableShapeUniforms)} ${this.enableShapeUniforms?Cv():bv(e)} void main() { @@ -12629,9 +12629,9 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, setOutput(result); } - `}}function BQ(t,e){return` + `}}function VQ(t,e){return` ivec3 inputCoordsFromReshapedOutCoords(int index) { - ${e?P9(["r","c","d"],"inputShape"):ea(["r","c","d"],t)} + ${e?L9(["r","c","d"],"inputShape"):ea(["r","c","d"],t)} return ivec3(r, c, d); } `}/** @@ -12649,7 +12649,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class VQ{constructor(e){this.gpgpu=e,this.numUsedTextures=0,this.numFreeTextures=0,this._numBytesAllocated=0,this._numBytesFree=0,this.freeTextures={},this.usedTextures={},this.logEnabled=!1}acquireTexture(e,n,s){const r=Tk(n,s),o=Ek(e,r,s);o in this.freeTextures||(this.freeTextures[o]=[]),o in this.usedTextures||(this.usedTextures[o]=[]);const i=Nk(e,r,this.gpgpu.gl,this.gpgpu.textureConfig,s);if(this.freeTextures[o].length>0){this.numFreeTextures--,this.numUsedTextures++,this._numBytesFree-=i,this.log();const l=this.freeTextures[o].pop();return this.usedTextures[o].push(l),l}let a;return r===Jt.PACKED_2X2_FLOAT32?a=this.gpgpu.createPackedMatrixTexture(e[0],e[1]):r===Jt.PACKED_2X2_FLOAT16?a=this.gpgpu.createFloat16PackedMatrixTexture(e[0],e[1]):r===Jt.UNPACKED_FLOAT32?a=this.gpgpu.createFloat32MatrixTexture(e[0],e[1]):r===Jt.UNPACKED_FLOAT16?a=this.gpgpu.createFloat16MatrixTexture(e[0],e[1]):r===Jt.PACKED_4X1_UNSIGNED_BYTE&&(a=this.gpgpu.createUnsignedBytesMatrixTexture(e[0],e[1])),this.usedTextures[o].push(a),this.numUsedTextures++,this._numBytesAllocated+=i,this.log(),a}releaseTexture(e,n,s,r){if(this.freeTextures==null)return;const o=Tk(s,r),i=Ek(n,o,r);i in this.freeTextures||(this.freeTextures[i]=[]);const a=Nk(n,o,this.gpgpu.gl,this.gpgpu.textureConfig,r),l=W().getNumber("WEBGL_DELETE_TEXTURE_THRESHOLD");l!==-1&&this._numBytesAllocated>l?(this.gpgpu.deleteMatrixTexture(e.texture),this._numBytesAllocated-=a):(this.freeTextures[i].push(e),this.numFreeTextures++,this._numBytesFree+=a),this.numUsedTextures--;const c=this.usedTextures[i],u=c&&c.indexOf(e);if(u==null||u<0)throw new Error("Cannot release a texture that was never provided by this texture manager");c[u]=c[c.length-1],c.pop(),this.log()}log(){if(!this.logEnabled)return;const e=this.numFreeTextures+this.numUsedTextures;console.log("Free/Used",`${this.numFreeTextures} / ${this.numUsedTextures}`,`(${e})`);const n=this._numBytesFree/this._numBytesAllocated;console.log(`Bytes allocated: ${this._numBytesAllocated}`),console.log(`Bytes unused: ${this._numBytesFree} (${Math.round(100*n)}%)`)}get numBytesAllocated(){return this._numBytesAllocated}get numBytesFree(){return this._numBytesFree}getNumUsedTextures(){return this.numUsedTextures}getNumFreeTextures(){return this.numFreeTextures}dispose(){if(this.freeTextures!=null){for(const e in this.freeTextures)this.freeTextures[e].forEach(n=>{this.gpgpu.deleteMatrixTexture(n.texture)});for(const e in this.usedTextures)this.usedTextures[e].forEach(n=>{this.gpgpu.deleteMatrixTexture(n.texture)});this.freeTextures=null,this.usedTextures=null,this.numUsedTextures=0,this.numFreeTextures=0,this._numBytesAllocated=0,this._numBytesFree=0}}}function WQ(t,e){const n=t;if(e===n.R32F)return 4;if(e===n.R16F)return 2;if(e===n.RGBA32F)return 16;if(e===t.RGBA)return 16;if(e===n.RGBA16F)return 8;if(e===n.RGBA8)return 4;throw new Error(`Unknown internal format ${e}`)}function Nk(t,e,n,s,r){const o=UQ(e,s);let i;if(r){const[l,c]=Nl(t[0],t[1]);i=l*c}else{const[l,c]=Td(t[0],t[1]);i=l*c}const a=WQ(n,o);return i*a}function UQ(t,e){switch(t){case Jt.PACKED_2X2_FLOAT32:return qA(e);case Jt.PACKED_2X2_FLOAT16:return YA(e);case Jt.UNPACKED_FLOAT32:return jA(e);case Jt.UNPACKED_FLOAT16:return KA(e);case Jt.PACKED_4X1_UNSIGNED_BYTE:return XA(e);default:throw new Error(`Unknown physical texture type ${t}`)}}function GQ(t){return W().getBool("WEBGL_RENDER_FLOAT32_ENABLED")?t?Jt.PACKED_2X2_FLOAT32:Jt.UNPACKED_FLOAT32:t?Jt.PACKED_2X2_FLOAT16:Jt.UNPACKED_FLOAT16}function Tk(t,e){if(t===ns.UPLOAD)return Jt.PACKED_2X2_FLOAT32;if(t===ns.RENDER||t==null)return GQ(e);if(t===ns.DOWNLOAD||t===ns.PIXELS)return Jt.PACKED_4X1_UNSIGNED_BYTE;throw new Error(`Unknown logical texture type ${t}`)}function Ek(t,e,n){return`${t[0]}_${t[1]}_${e}_${n}`}/** + */class WQ{constructor(e){this.gpgpu=e,this.numUsedTextures=0,this.numFreeTextures=0,this._numBytesAllocated=0,this._numBytesFree=0,this.freeTextures={},this.usedTextures={},this.logEnabled=!1}acquireTexture(e,n,s){const r=Tk(n,s),o=Ek(e,r,s);o in this.freeTextures||(this.freeTextures[o]=[]),o in this.usedTextures||(this.usedTextures[o]=[]);const i=Nk(e,r,this.gpgpu.gl,this.gpgpu.textureConfig,s);if(this.freeTextures[o].length>0){this.numFreeTextures--,this.numUsedTextures++,this._numBytesFree-=i,this.log();const l=this.freeTextures[o].pop();return this.usedTextures[o].push(l),l}let a;return r===Jt.PACKED_2X2_FLOAT32?a=this.gpgpu.createPackedMatrixTexture(e[0],e[1]):r===Jt.PACKED_2X2_FLOAT16?a=this.gpgpu.createFloat16PackedMatrixTexture(e[0],e[1]):r===Jt.UNPACKED_FLOAT32?a=this.gpgpu.createFloat32MatrixTexture(e[0],e[1]):r===Jt.UNPACKED_FLOAT16?a=this.gpgpu.createFloat16MatrixTexture(e[0],e[1]):r===Jt.PACKED_4X1_UNSIGNED_BYTE&&(a=this.gpgpu.createUnsignedBytesMatrixTexture(e[0],e[1])),this.usedTextures[o].push(a),this.numUsedTextures++,this._numBytesAllocated+=i,this.log(),a}releaseTexture(e,n,s,r){if(this.freeTextures==null)return;const o=Tk(s,r),i=Ek(n,o,r);i in this.freeTextures||(this.freeTextures[i]=[]);const a=Nk(n,o,this.gpgpu.gl,this.gpgpu.textureConfig,r),l=W().getNumber("WEBGL_DELETE_TEXTURE_THRESHOLD");l!==-1&&this._numBytesAllocated>l?(this.gpgpu.deleteMatrixTexture(e.texture),this._numBytesAllocated-=a):(this.freeTextures[i].push(e),this.numFreeTextures++,this._numBytesFree+=a),this.numUsedTextures--;const c=this.usedTextures[i],u=c&&c.indexOf(e);if(u==null||u<0)throw new Error("Cannot release a texture that was never provided by this texture manager");c[u]=c[c.length-1],c.pop(),this.log()}log(){if(!this.logEnabled)return;const e=this.numFreeTextures+this.numUsedTextures;console.log("Free/Used",`${this.numFreeTextures} / ${this.numUsedTextures}`,`(${e})`);const n=this._numBytesFree/this._numBytesAllocated;console.log(`Bytes allocated: ${this._numBytesAllocated}`),console.log(`Bytes unused: ${this._numBytesFree} (${Math.round(100*n)}%)`)}get numBytesAllocated(){return this._numBytesAllocated}get numBytesFree(){return this._numBytesFree}getNumUsedTextures(){return this.numUsedTextures}getNumFreeTextures(){return this.numFreeTextures}dispose(){if(this.freeTextures!=null){for(const e in this.freeTextures)this.freeTextures[e].forEach(n=>{this.gpgpu.deleteMatrixTexture(n.texture)});for(const e in this.usedTextures)this.usedTextures[e].forEach(n=>{this.gpgpu.deleteMatrixTexture(n.texture)});this.freeTextures=null,this.usedTextures=null,this.numUsedTextures=0,this.numFreeTextures=0,this._numBytesAllocated=0,this._numBytesFree=0}}}function UQ(t,e){const n=t;if(e===n.R32F)return 4;if(e===n.R16F)return 2;if(e===n.RGBA32F)return 16;if(e===t.RGBA)return 16;if(e===n.RGBA16F)return 8;if(e===n.RGBA8)return 4;throw new Error(`Unknown internal format ${e}`)}function Nk(t,e,n,s,r){const o=GQ(e,s);let i;if(r){const[l,c]=Nl(t[0],t[1]);i=l*c}else{const[l,c]=Th(t[0],t[1]);i=l*c}const a=UQ(n,o);return i*a}function GQ(t,e){switch(t){case Jt.PACKED_2X2_FLOAT32:return YA(e);case Jt.PACKED_2X2_FLOAT16:return QA(e);case Jt.UNPACKED_FLOAT32:return KA(e);case Jt.UNPACKED_FLOAT16:return XA(e);case Jt.PACKED_4X1_UNSIGNED_BYTE:return qA(e);default:throw new Error(`Unknown physical texture type ${t}`)}}function HQ(t){return W().getBool("WEBGL_RENDER_FLOAT32_ENABLED")?t?Jt.PACKED_2X2_FLOAT32:Jt.UNPACKED_FLOAT32:t?Jt.PACKED_2X2_FLOAT16:Jt.UNPACKED_FLOAT16}function Tk(t,e){if(t===ns.UPLOAD)return Jt.PACKED_2X2_FLOAT32;if(t===ns.RENDER||t==null)return HQ(e);if(t===ns.DOWNLOAD||t===ns.PIXELS)return Jt.PACKED_4X1_UNSIGNED_BYTE;throw new Error(`Unknown logical texture type ${t}`)}function Ek(t,e,n){return`${t[0]}_${t[1]}_${e}_${n}`}/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -12664,7 +12664,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class fr{constructor(e,n){this.variableNames=["A"],this.outputShape=e,this.enableShapeUniforms=pn(this.outputShape.length),this.userCode=` + */class pr{constructor(e,n){this.variableNames=["A"],this.outputShape=e,this.enableShapeUniforms=pn(this.outputShape.length),this.userCode=` float unaryOperation(float x) { ${n} } @@ -12675,11 +12675,11 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, setOutput(y); } - `}}const Ds="if (isnan(x)) return x;",HQ="return x;",Rk="return abs(x);",jQ="return (x >= 0.0) ? x : (exp(x) - 1.0);",KQ=Ds+` + `}}const _s="if (isnan(x)) return x;",jQ="return x;",Rk="return abs(x);",KQ="return (x >= 0.0) ? x : (exp(x) - 1.0);",XQ=_s+` return (x < 0.0) ? 0.0 : x; -`,XQ=Ds+` +`,qQ=_s+` return (x < 0.0) ? 0.0 : min(6.0, x); -`,oo="return x;",qQ="return 1.0 / (1.0 + exp(-1.0 * x));";/** +`,io="return x;",YQ="return 1.0 / (1.0 + exp(-1.0 * x));";/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -12694,7 +12694,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const YQ="return x;",QQ=` + */const QQ="return x;",ZQ=` vec4 result; result.r = (x.r >= 0.0) ? x.r : (exp(x.r) - 1.0); @@ -12703,7 +12703,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, result.a = (x.a >= 0.0) ? x.a : (exp(x.a) - 1.0); return result; -`,ZQ=` +`,JQ=` vec4 result = x * vec4(greaterThanEqual(x, vec4(0.0))); bvec4 isNaN = isnan(x); @@ -12713,7 +12713,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, result.a = isNaN.a ? x.a : result.a; return result; -`,JQ=` +`,eZ=` vec4 result = min(x, vec4(6.)) * vec4(greaterThanEqual(x, vec4(0.0))); bvec4 isNaN = isnan(x); @@ -12723,7 +12723,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, result.a = isNaN.a ? x.a : result.a; return result; -`,eZ="return 1.0 / (1.0 + exp(-1.0 * x));";class po{constructor(e,n){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=e,this.enableShapeUniforms=pn(this.outputShape.length),this.userCode=` +`,tZ="return 1.0 / (1.0 + exp(-1.0 * x));";class po{constructor(e,n){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=e,this.enableShapeUniforms=pn(this.outputShape.length),this.userCode=` vec4 unaryOperation(vec4 x) { ${n} } @@ -12749,7 +12749,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class tZ{constructor(e){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!1,this.outputShape=e,this.enableShapeUniforms=pn(this.outputShape.length);const n=e.length,s=vn("rc",n),r=Ze(n),o=PQ(n,s),i=s.slice(-2),a=n<=1?"rc":`vec2(${i.join(",")})`;this.userCode=` + */class nZ{constructor(e){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!1,this.outputShape=e,this.enableShapeUniforms=pn(this.outputShape.length);const n=e.length,s=vn("rc",n),r=Ze(n),o=LQ(n,s),i=s.slice(-2),a=n<=1?"rc":`vec2(${i.join(",")})`;this.userCode=` void main() { ${r} rc = getOutputCoords(); vec4 packedInput = getA(${o}); @@ -12771,7 +12771,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const nZ=kN,sZ=1e-7,rZ=1e-4,uh={};function oZ(t){return t in uh||(uh[t]={}),uh[t]}const iZ=W().getNumber("CPU_HANDOFF_SIZE_THRESHOLD"),aZ=600;function lZ(){return W().global.screen==null?1024:W().global.screen.height*W().global.screen.width*window.devicePixelRatio*aZ/1024/1024}class Pm extends Mx{nextDataId(){return Pm.nextDataId++}constructor(e){if(super(),this.pendingRead=new WeakMap,this.pendingDisposal=new WeakSet,this.dataRefCount=new WeakMap,this.numBytesInGPU=0,this.uploadWaitMs=0,this.downloadWaitMs=0,this.lastGlFlushTime=0,this.warnedAboutMemory=!1,this.pendingDeletes=0,this.disposed=!1,!W().getBool("HAS_WEBGL"))throw new Error("WebGL is not supported on this device");let n;if(e!=null){if(e instanceof Og)n=e;else{const s=er(W().getNumber("WEBGL_VERSION"),e);n=new Og(s)}this.binaryCache={},this.gpgpuCreatedLocally=!1}else{const s=er(W().getNumber("WEBGL_VERSION"));n=new Og(s),this.binaryCache=oZ(W().getNumber("WEBGL_VERSION")),this.gpgpuCreatedLocally=!0}this.gpgpu=n,this.canvas=this.gpgpu.gl.canvas,this.textureManager=new VQ(this.gpgpu),this.numMBBeforeWarning=lZ(),this.texData=new H2(this,or())}numDataIds(){return this.texData.numDataIds()-this.pendingDeletes}writeTexture(e,n,s,r,o,i){const a=this.makeTensorInfo(n,s),l=this.texData.get(a.dataId);l.isPacked=!1,l.texture={texture:e,texShape:[r,o]},l.texShape=[r,o];const c=lh(n),u=new $k(c,!1,i),d=this.runWebGLProgram(u,[a],s,[[r,o]]);return d.shape=n,l.texture=null,this.disposeIntermediateTensorInfo(a),d.dataId}write(e,n,s){if((W().getBool("WEBGL_CHECK_NUMERICAL_PROBLEMS")||W().getBool("DEBUG"))&&this.checkNumericalProblems(e),s==="complex64"&&e!=null)throw new Error("Cannot write to a complex64 dtype. Please use tf.complex(real, imag).");const r={id:this.nextDataId()};return this.texData.set(r,{shape:n,dtype:s,values:e,usage:ns.UPLOAD,refCount:1}),r}refCount(e){return this.texData.has(e)?this.texData.get(e).refCount:0}incRef(e){const n=this.texData.get(e);n.refCount++}decRef(e){if(this.texData.has(e)){const n=this.texData.get(e);n.refCount--}}move(e,n,s,r,o){if(W().getBool("DEBUG")&&this.checkNumericalProblems(n),r==="complex64")throw new Error("Cannot write to a complex64 dtype. Please use tf.complex(real, imag).");this.texData.set(e,{shape:s,dtype:r,values:n,usage:ns.UPLOAD,refCount:o})}disposeIntermediateTensorInfo(e){this.disposeData(e.dataId)}readSync(e){const n=this.texData.get(e),{values:s,dtype:r,complexTensorInfos:o,slice:i,shape:a,isPacked:l}=n;if(i!=null){let h;l?h=new po(a,oo):h=new fr(a,oo);const f=this.runWebGLProgram(h,[{dataId:e,shape:a,dtype:r}],r),p=this.readSync(f.dataId);return this.disposeIntermediateTensorInfo(f),p}if(s!=null)return this.convertAndCacheOnCPU(e);if(r==="string")return s;const c=this.activeTimers!=null;let u;c&&(u=Tn());let d;if(r==="complex64"){const h=this.readSync(o.real.dataId),f=this.readSync(o.imag.dataId);d=Hr(h,f)}else d=this.getValuesFromTexture(e);return c&&(this.downloadWaitMs+=Tn()-u),this.convertAndCacheOnCPU(e,d)}async read(e){if(this.pendingRead.has(e)){const p=this.pendingRead.get(e);return new Promise(g=>p.push(g))}const n=this.texData.get(e),{values:s,shape:r,slice:o,dtype:i,complexTensorInfos:a,isPacked:l}=n;if(o!=null){let p;l?p=new po(r,oo):p=new fr(r,oo);const g=this.runWebGLProgram(p,[{dataId:e,shape:r,dtype:i}],i),x=this.read(g.dataId);return this.disposeIntermediateTensorInfo(g),x}if(s!=null)return this.convertAndCacheOnCPU(e);if(W().getBool("DEBUG")&&!W().getBool("WEBGL_DOWNLOAD_FLOAT_ENABLED")&&W().getNumber("WEBGL_VERSION")===2)throw new Error("tensor.data() with WEBGL_DOWNLOAD_FLOAT_ENABLED=false and WEBGL_VERSION=2 not yet supported.");let c=null,u;if(i!=="complex64"&&W().get("WEBGL_BUFFER_SUPPORTED")){u=this.decode(e);const p=this.texData.get(u.dataId);c=this.gpgpu.createBufferFromTexture(p.texture.texture,...oh(r))}this.pendingRead.set(e,[]),i!=="complex64"&&await this.gpgpu.createAndWaitForFence();let d;if(i==="complex64"){const p=await Promise.all([this.read(a.real.dataId),this.read(a.imag.dataId)]),g=p[0],x=p[1];d=Hr(g,x)}else if(c==null)d=this.getValuesFromTexture(e);else{const p=j(r);d=this.gpgpu.downloadFloat32MatrixFromBuffer(c,p)}if(u!=null&&this.disposeIntermediateTensorInfo(u),c!=null){const p=this.gpgpu.gl;ae(p,()=>p.deleteBuffer(c))}const h=this.convertAndCacheOnCPU(e,d),f=this.pendingRead.get(e);return this.pendingRead.delete(e),f.forEach(p=>p(h)),this.pendingDisposal.has(e)&&(this.pendingDisposal.delete(e),this.disposeData(e)&&or().removeDataId(e,this),this.pendingDeletes--),h}readToGPU(e,n={}){const s=this.texData.get(e),{values:r,shape:o,slice:i,dtype:a,isPacked:l,texture:c}=s;if(a==="complex64")throw new Error("Does not support reading texture for complex64 dtype.");if(i!=null){let f;l?f=new po(o,oo):f=new fr(o,oo);const p=this.runWebGLProgram(f,[{dataId:e,shape:o,dtype:a}],a),g=this.readToGPU(p,n);return this.disposeIntermediateTensorInfo(p),g}if(c==null)throw r!=null?new Error("Data is not on GPU but on CPU."):new Error("There is no data on GPU or CPU.");const u=this.decode(e,n.customTexShape),d=or().makeTensorFromTensorInfo(u),h=this.texData.get(u.dataId);return Object.assign({tensorRef:d},h.texture)}bufferSync(e){const n=this.readSync(e.dataId);if(e.dtype==="string")try{const s=n.map(r=>Do(r));return Ee(e.shape,e.dtype,s)}catch{throw new Error("Failed to decode encoded string bytes into utf-8")}return Ee(e.shape,e.dtype,n)}checkNumericalProblems(e){if(e!=null)for(let n=0;n0}time(e){const n=this.activeTimers,s=[];let r=!1;this.programTimersStack==null?(this.programTimersStack=s,r=!0):this.activeTimers.push(s),this.activeTimers=s,e();const o=Ei(this.activeTimers.map(l=>l.query)).filter(l=>l!=null),i=Ei(this.activeTimers.map(l=>l.name)).filter(l=>l!=null);this.activeTimers=n,r&&(this.programTimersStack=null);const a={uploadWaitMs:this.uploadWaitMs,downloadWaitMs:this.downloadWaitMs,kernelMs:null,wallMs:null};return(async()=>{if(W().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE")>0){const l=await Promise.all(o);a.kernelMs=TM(l),a.getExtraProfileInfo=()=>l.map((c,u)=>({name:i[u],ms:c})).map(c=>`${c.name}: ${c.ms}`).join(", ")}else a.kernelMs={error:"WebGL query timers are not supported in this environment."};return this.uploadWaitMs=0,this.downloadWaitMs=0,a})()}memory(){return{unreliable:!1,numBytesInGPU:this.numBytesInGPU,numBytesInGPUAllocated:this.textureManager.numBytesAllocated,numBytesInGPUFree:this.textureManager.numBytesFree}}startTimer(){return W().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE")>0?this.gpgpu.beginQuery():{startMs:Tn(),endMs:null}}endTimer(e){return W().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE")>0?(this.gpgpu.endQuery(),e):(e.endMs=Tn(),e)}async getQueryTime(e){if(W().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE")>0)return this.gpgpu.waitForQueryAndGetTime(e);const n=e;return n.endMs-n.startMs}disposeData(e,n=!1){if(this.pendingDisposal.has(e))return!1;if(!this.texData.has(e))return!0;if(n?this.texData.get(e).refCount=0:this.texData.get(e).refCount--,!n&&this.texData.get(e).refCount>0)return!1;if(this.pendingRead.has(e))return this.pendingDisposal.add(e),this.pendingDeletes++,!1;this.releaseGPUData(e);const{complexTensorInfos:s}=this.texData.get(e);return s!=null&&(this.disposeData(s.real.dataId,n),this.disposeData(s.imag.dataId,n)),this.texData.delete(e),!0}releaseGPUData(e){const{texture:n,dtype:s,texShape:r,usage:o,isPacked:i,slice:a}=this.texData.get(e),l=a&&a.origDataId||e,c=this.dataRefCount.get(l);c>1?this.dataRefCount.set(l,c-1):(this.dataRefCount.delete(l),n!=null&&(this.numBytesInGPU-=this.computeBytes(r,s),this.textureManager.releaseTexture(n,r,o,i)));const u=this.texData.get(e);u.texture=null,u.texShape=null,u.isPacked=!1,u.slice=null}getTexture(e){return this.uploadToGPU(e),this.texData.get(e).texture.texture}getDataInfo(e){return this.texData.get(e)}shouldExecuteOnCPU(e,n=iZ){return W().getBool("WEBGL_CPU_FORWARD")&&e.every(s=>this.texData.get(s.dataId).texture==null&&j(s.shape)0&&fu(s[0])){const o=s.map(i=>No(i));r=this.write(o,e,n)}else r=this.write(s,e,n);return this.texData.get(r).usage=null,{dataId:r,shape:e,dtype:n}}makeOutput(e,n,s){return or().makeTensorFromTensorInfo(this.makeTensorInfo(e,n,s),this)}unpackTensor(e){const n=new tZ(e.shape);return this.runWebGLProgram(n,[e],e.dtype)}packTensor(e){const n=new LQ(e.shape);return this.runWebGLProgram(n,[e],e.dtype,null,!0)}packedReshape(e,n){const s=[hl(e.shape),...fl(e.shape)],r={dtype:e.dtype,shape:s,dataId:e.dataId},o=[hl(n),...fl(n)],i=new tD(o,s),a=!0,l=[s],c=this.runWebGLProgram(i,[r],e.dtype,l,a);return{dataId:c.dataId,shape:n,dtype:c.dtype}}decode(e,n){const s=this.texData.get(e),{isPacked:r,shape:o,dtype:i}=s;if(n!=null){const h=j(o),f=n[0]*n[1]*4;I(h<=f,()=>"customTexShape is too small. Row * Column * 4 should be equal or larger than the size of the tensor data.")}const a=lh(o);let l;r?l=new IY(a):l=new SY(a);const c=!0,u=[n??oh(a)],d=this.runWebGLProgram(l,[{shape:a,dtype:i,dataId:e}],i,u,c,n);return{dtype:i,shape:o,dataId:d.dataId}}runWebGLProgram(e,n,s,r,o=!1,i){const a=this.makeTensorInfo(e.outputShape,s),l=this.texData.get(a.dataId);if(e.packedOutput&&(l.isPacked=!0),e.outPackingScheme===eu.DENSE){const m=i??oh(e.outputShape);l.texShape=m.map(y=>y*2)}if(e.outTexUsage!=null&&(l.usage=e.outTexUsage),j(a.shape)===0)return l.values=cn(a.dtype,0),a;const c=[],u=n.map(m=>{if(m.dtype==="complex64")throw new Error("GPGPUProgram does not support complex64 input. For complex64 dtypes, please separate the program into real and imaginary parts.");let y=this.texData.get(m.dataId);if(y.texture==null){if(!e.packedInputs&&j(m.shape)<=W().getNumber("WEBGL_SIZE_UPLOAD_UNIFORM"))return{shape:m.shape,texData:null,isUniform:!0,uniformValues:y.values};e.packedInputs&&(y.isPacked=!0,y.shape=m.shape)}if(this.uploadToGPU(m.dataId),!!y.isPacked!=!!e.packedInputs)m=y.isPacked?this.unpackTensor(m):this.packTensor(m),c.push(m),y=this.texData.get(m.dataId);else if(y.isPacked&&!Lf(y.shape,m.shape)){const w=m,v=m.shape;m.shape=y.shape,m=this.packedReshape(m,v),c.push(m),y=this.texData.get(m.dataId),w.shape=v}return{shape:m.shape,texData:y,isUniform:!1}});this.uploadToGPU(a.dataId);const d={shape:a.shape,texData:l,isUniform:!1},h=kY(e,u,d),f=this.getAndSaveBinary(h,()=>bY(this.gpgpu,e,u,d)),p=this.activeTimers!=null;let g;p&&(g=this.startTimer()),W().get("ENGINE_COMPILE_ONLY")||CY(this.gpgpu,f,u,d,r),c.forEach(m=>this.disposeIntermediateTensorInfo(m)),p&&(g=this.endTimer(g),this.activeTimers.push({name:e.constructor.name,query:this.getQueryTime(g)}));const x=W().getNumber("WEBGL_FLUSH_THRESHOLD");if(x>0){const m=Tn();m-this.lastGlFlushTime>x&&(this.gpgpu.gl.flush(),this.lastGlFlushTime=m)}if(!W().getBool("WEBGL_LAZILY_UNPACK")&&l.isPacked&&o===!1){const m=this.unpackTensor(a);return this.disposeIntermediateTensorInfo(a),m}return a}compileAndRun(e,n,s,r,o=!1){return s=s||n[0].dtype,this.runWebGLProgram(e,n,s,r,o)}getAndSaveBinary(e,n){return e in this.binaryCache||(this.binaryCache[e]=n()),this.binaryCache[e]}getTextureManager(){return this.textureManager}dispose(){this.disposed||(W().getBool("IS_TEST")||Object.keys(this.binaryCache).forEach(n=>{this.gpgpu.deleteProgram(this.binaryCache[n].webGLProgram),delete this.binaryCache[n]}),this.textureManager.dispose(),this.canvas!=null&&typeof HTMLCanvasElement<"u"&&this.canvas instanceof HTMLCanvasElement?this.canvas.remove():this.canvas=null,this.gpgpuCreatedLocally&&(this.gpgpu.program=null,this.gpgpu.dispose()),this.disposed=!0)}floatPrecision(){return this.floatPrecisionValue==null&&(this.floatPrecisionValue=P(()=>{if(!W().get("WEBGL_RENDER_FLOAT32_ENABLED")){const e=W().getBool("DEBUG");W().set("DEBUG",!1);const n=this.abs(We(1e-8)).dataSync()[0];if(W().set("DEBUG",e),n>0)return 32}return 16})),this.floatPrecisionValue}epsilon(){return this.floatPrecision()===32?sZ:rZ}uploadToGPU(e){const n=this.texData.get(e),{shape:s,dtype:r,values:o,texture:i,usage:a,isPacked:l}=n;if(i!=null)return;const c=this.activeTimers!=null;let u;c&&(u=Tn());let d=n.texShape;if(d==null&&(d=E9(s,l),n.texShape=d),o!=null){const h=lh(s);let f,p=d[1],g=d[0];const x=o instanceof Uint8Array||o instanceof Uint8ClampedArray;(l||!x)&&([p,g]=Nl(d[0],d[1])),l?f=new EY(h,x):f=new $k(h,x);const m=x?[g,p]:d,y=this.makeTensorInfo(m,r),w=this.texData.get(y.dataId);x?w.usage=ns.PIXELS:w.usage=ns.UPLOAD,w.texShape=m,this.gpgpu.uploadDenseMatrixToTexture(this.getTexture(y.dataId),p,g,o);const v=[[g,p]],C=this.runWebGLProgram(f,[y],r,v,!0),k=this.texData.get(C.dataId);n.texShape=k.texShape,n.isPacked=k.isPacked,n.usage=k.usage,W().get("ENGINE_COMPILE_ONLY")?this.disposeData(C.dataId):(n.texture=k.texture,n.values=null,this.texData.delete(C.dataId)),this.disposeIntermediateTensorInfo(y),c&&(this.uploadWaitMs+=Tn()-u)}else{const h=this.acquireTexture(d,a,r,l);n.texture=h}}convertAndCacheOnCPU(e,n){const s=this.texData.get(e),{dtype:r}=s;return n!=null&&(s.values=cZ(n,r)),s.values}acquireTexture(e,n,s,r){if(this.numBytesInGPU+=this.computeBytes(e,s),!this.warnedAboutMemory&&this.numBytesInGPU>this.numMBBeforeWarning*1024*1024){const o=(this.numBytesInGPU/1024/1024).toFixed(2);this.warnedAboutMemory=!0,console.warn(`High memory usage in GPU: ${o} MB, most likely due to a memory leak`)}return this.textureManager.acquireTexture(e,n,r)}computeBytes(e,n){return e[0]*e[1]*hf(n)}checkCompileCompletion(){for(const[,e]of Object.entries(this.binaryCache))this.checkCompletion_(e)}async checkCompileCompletionAsync(){const e=[];if(this.gpgpu.parallelCompilationExtension){for(const[,n]of Object.entries(this.binaryCache))e.push(this.checkCompletionAsync_(n));return Promise.all(e)}else{for(const[,n]of Object.entries(this.binaryCache)){const s=new Promise(r=>{try{this.checkCompletion_(n),r(!0)}catch(o){throw o}});e.push(s)}return Promise.all(e)}}async checkCompletionAsync_(e){return this.gpgpu.gl.getProgramParameter(e.webGLProgram,this.gpgpu.parallelCompilationExtension.COMPLETION_STATUS_KHR)?this.checkCompletion_(e):(await WN(),this.checkCompletionAsync_(e))}checkCompletion_(e){if(this.gpgpu.gl.getProgramParameter(e.webGLProgram,this.gpgpu.gl.LINK_STATUS)===!1)throw console.log(this.gpgpu.gl.getProgramInfoLog(e.webGLProgram)),this.gpgpu.gl.getShaderParameter(e.fragmentShader,this.gpgpu.gl.COMPILE_STATUS)===!1?(BA(e.source,this.gpgpu.gl.getShaderInfoLog(e.fragmentShader)),new Error("Failed to compile fragment shader.")):new Error("Failed to link vertex and fragment shaders.");return!0}getUniformLocations(){for(const e of Object.values(this.binaryCache)){this.gpgpu.buildVao(e.webGLProgram);const{variablesLocations:n,customUniformLocations:s,infLoc:r,nanLoc:o,outShapeLocation:i,outShapeStridesLocation:a,outTexShapeLocation:l}=HA(this.gpgpu,e.program,e.webGLProgram);e.variablesLocations=n,e.customUniformLocations=s,e.infLoc=r,e.nanLoc=o,e.outShapeLocation=i,e.outShapeStridesLocation=a,e.outTexShapeLocation=l}}createTensorFromGPUData(e,n,s){e.channels=e.channels||"RGBA";const{texture:r,height:o,width:i,channels:a}=e,l=or().backend;if(!l.gpgpu.gl.isTexture(r))throw new Error("The texture is invalid. Also, please make sure the texture and the TFJS WebGL backend are using the same canvas. If you want to use your own custom canvas, you have to create and use the custom TFJS WebGL backend created from the canvas through 'new tf.MathBackendWebGL(customCanvas)'.");const c=l.writeTexture(r,n,s,o,i,a);return or().makeTensorFromDataId(c,n,s,l)}}Pm.nextDataId=0;function cZ(t,e){if(e==="float32"||e==="complex64")return t;if(e==="int32"||e==="bool"){const n=e==="int32"?new Int32Array(t.length):new Uint8Array(t.length);for(let s=0;sp.push(g))}const n=this.texData.get(e),{values:s,shape:r,slice:o,dtype:i,complexTensorInfos:a,isPacked:l}=n;if(o!=null){let p;l?p=new po(r,io):p=new pr(r,io);const g=this.runWebGLProgram(p,[{dataId:e,shape:r,dtype:i}],i),x=this.read(g.dataId);return this.disposeIntermediateTensorInfo(g),x}if(s!=null)return this.convertAndCacheOnCPU(e);if(W().getBool("DEBUG")&&!W().getBool("WEBGL_DOWNLOAD_FLOAT_ENABLED")&&W().getNumber("WEBGL_VERSION")===2)throw new Error("tensor.data() with WEBGL_DOWNLOAD_FLOAT_ENABLED=false and WEBGL_VERSION=2 not yet supported.");let c=null,u;if(i!=="complex64"&&W().get("WEBGL_BUFFER_SUPPORTED")){u=this.decode(e);const p=this.texData.get(u.dataId);c=this.gpgpu.createBufferFromTexture(p.texture.texture,...od(r))}this.pendingRead.set(e,[]),i!=="complex64"&&await this.gpgpu.createAndWaitForFence();let h;if(i==="complex64"){const p=await Promise.all([this.read(a.real.dataId),this.read(a.imag.dataId)]),g=p[0],x=p[1];h=jr(g,x)}else if(c==null)h=this.getValuesFromTexture(e);else{const p=j(r);h=this.gpgpu.downloadFloat32MatrixFromBuffer(c,p)}if(u!=null&&this.disposeIntermediateTensorInfo(u),c!=null){const p=this.gpgpu.gl;ae(p,()=>p.deleteBuffer(c))}const d=this.convertAndCacheOnCPU(e,h),f=this.pendingRead.get(e);return this.pendingRead.delete(e),f.forEach(p=>p(d)),this.pendingDisposal.has(e)&&(this.pendingDisposal.delete(e),this.disposeData(e)&&ir().removeDataId(e,this),this.pendingDeletes--),d}readToGPU(e,n={}){const s=this.texData.get(e),{values:r,shape:o,slice:i,dtype:a,isPacked:l,texture:c}=s;if(a==="complex64")throw new Error("Does not support reading texture for complex64 dtype.");if(i!=null){let f;l?f=new po(o,io):f=new pr(o,io);const p=this.runWebGLProgram(f,[{dataId:e,shape:o,dtype:a}],a),g=this.readToGPU(p,n);return this.disposeIntermediateTensorInfo(p),g}if(c==null)throw r!=null?new Error("Data is not on GPU but on CPU."):new Error("There is no data on GPU or CPU.");const u=this.decode(e,n.customTexShape),h=ir().makeTensorFromTensorInfo(u),d=this.texData.get(u.dataId);return Object.assign({tensorRef:h},d.texture)}bufferSync(e){const n=this.readSync(e.dataId);if(e.dtype==="string")try{const s=n.map(r=>Do(r));return Ee(e.shape,e.dtype,s)}catch{throw new Error("Failed to decode encoded string bytes into utf-8")}return Ee(e.shape,e.dtype,n)}checkNumericalProblems(e){if(e!=null)for(let n=0;n0}time(e){const n=this.activeTimers,s=[];let r=!1;this.programTimersStack==null?(this.programTimersStack=s,r=!0):this.activeTimers.push(s),this.activeTimers=s,e();const o=Ei(this.activeTimers.map(l=>l.query)).filter(l=>l!=null),i=Ei(this.activeTimers.map(l=>l.name)).filter(l=>l!=null);this.activeTimers=n,r&&(this.programTimersStack=null);const a={uploadWaitMs:this.uploadWaitMs,downloadWaitMs:this.downloadWaitMs,kernelMs:null,wallMs:null};return(async()=>{if(W().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE")>0){const l=await Promise.all(o);a.kernelMs=EM(l),a.getExtraProfileInfo=()=>l.map((c,u)=>({name:i[u],ms:c})).map(c=>`${c.name}: ${c.ms}`).join(", ")}else a.kernelMs={error:"WebGL query timers are not supported in this environment."};return this.uploadWaitMs=0,this.downloadWaitMs=0,a})()}memory(){return{unreliable:!1,numBytesInGPU:this.numBytesInGPU,numBytesInGPUAllocated:this.textureManager.numBytesAllocated,numBytesInGPUFree:this.textureManager.numBytesFree}}startTimer(){return W().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE")>0?this.gpgpu.beginQuery():{startMs:Tn(),endMs:null}}endTimer(e){return W().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE")>0?(this.gpgpu.endQuery(),e):(e.endMs=Tn(),e)}async getQueryTime(e){if(W().getNumber("WEBGL_DISJOINT_QUERY_TIMER_EXTENSION_RELIABLE")>0)return this.gpgpu.waitForQueryAndGetTime(e);const n=e;return n.endMs-n.startMs}disposeData(e,n=!1){if(this.pendingDisposal.has(e))return!1;if(!this.texData.has(e))return!0;if(n?this.texData.get(e).refCount=0:this.texData.get(e).refCount--,!n&&this.texData.get(e).refCount>0)return!1;if(this.pendingRead.has(e))return this.pendingDisposal.add(e),this.pendingDeletes++,!1;this.releaseGPUData(e);const{complexTensorInfos:s}=this.texData.get(e);return s!=null&&(this.disposeData(s.real.dataId,n),this.disposeData(s.imag.dataId,n)),this.texData.delete(e),!0}releaseGPUData(e){const{texture:n,dtype:s,texShape:r,usage:o,isPacked:i,slice:a}=this.texData.get(e),l=a&&a.origDataId||e,c=this.dataRefCount.get(l);c>1?this.dataRefCount.set(l,c-1):(this.dataRefCount.delete(l),n!=null&&(this.numBytesInGPU-=this.computeBytes(r,s),this.textureManager.releaseTexture(n,r,o,i)));const u=this.texData.get(e);u.texture=null,u.texShape=null,u.isPacked=!1,u.slice=null}getTexture(e){return this.uploadToGPU(e),this.texData.get(e).texture.texture}getDataInfo(e){return this.texData.get(e)}shouldExecuteOnCPU(e,n=aZ){return W().getBool("WEBGL_CPU_FORWARD")&&e.every(s=>this.texData.get(s.dataId).texture==null&&j(s.shape)0&&fu(s[0])){const o=s.map(i=>No(i));r=this.write(o,e,n)}else r=this.write(s,e,n);return this.texData.get(r).usage=null,{dataId:r,shape:e,dtype:n}}makeOutput(e,n,s){return ir().makeTensorFromTensorInfo(this.makeTensorInfo(e,n,s),this)}unpackTensor(e){const n=new nZ(e.shape);return this.runWebGLProgram(n,[e],e.dtype)}packTensor(e){const n=new BQ(e.shape);return this.runWebGLProgram(n,[e],e.dtype,null,!0)}packedReshape(e,n){const s=[dl(e.shape),...fl(e.shape)],r={dtype:e.dtype,shape:s,dataId:e.dataId},o=[dl(n),...fl(n)],i=new nD(o,s),a=!0,l=[s],c=this.runWebGLProgram(i,[r],e.dtype,l,a);return{dataId:c.dataId,shape:n,dtype:c.dtype}}decode(e,n){const s=this.texData.get(e),{isPacked:r,shape:o,dtype:i}=s;if(n!=null){const d=j(o),f=n[0]*n[1]*4;I(d<=f,()=>"customTexShape is too small. Row * Column * 4 should be equal or larger than the size of the tensor data.")}const a=ld(o);let l;r?l=new $Y(a):l=new IY(a);const c=!0,u=[n??od(a)],h=this.runWebGLProgram(l,[{shape:a,dtype:i,dataId:e}],i,u,c,n);return{dtype:i,shape:o,dataId:h.dataId}}runWebGLProgram(e,n,s,r,o=!1,i){const a=this.makeTensorInfo(e.outputShape,s),l=this.texData.get(a.dataId);if(e.packedOutput&&(l.isPacked=!0),e.outPackingScheme===eu.DENSE){const m=i??od(e.outputShape);l.texShape=m.map(y=>y*2)}if(e.outTexUsage!=null&&(l.usage=e.outTexUsage),j(a.shape)===0)return l.values=cn(a.dtype,0),a;const c=[],u=n.map(m=>{if(m.dtype==="complex64")throw new Error("GPGPUProgram does not support complex64 input. For complex64 dtypes, please separate the program into real and imaginary parts.");let y=this.texData.get(m.dataId);if(y.texture==null){if(!e.packedInputs&&j(m.shape)<=W().getNumber("WEBGL_SIZE_UPLOAD_UNIFORM"))return{shape:m.shape,texData:null,isUniform:!0,uniformValues:y.values};e.packedInputs&&(y.isPacked=!0,y.shape=m.shape)}if(this.uploadToGPU(m.dataId),!!y.isPacked!=!!e.packedInputs)m=y.isPacked?this.unpackTensor(m):this.packTensor(m),c.push(m),y=this.texData.get(m.dataId);else if(y.isPacked&&!Lf(y.shape,m.shape)){const w=m,v=m.shape;m.shape=y.shape,m=this.packedReshape(m,v),c.push(m),y=this.texData.get(m.dataId),w.shape=v}return{shape:m.shape,texData:y,isUniform:!1}});this.uploadToGPU(a.dataId);const h={shape:a.shape,texData:l,isUniform:!1},d=SY(e,u,h),f=this.getAndSaveBinary(d,()=>CY(this.gpgpu,e,u,h)),p=this.activeTimers!=null;let g;p&&(g=this.startTimer()),W().get("ENGINE_COMPILE_ONLY")||kY(this.gpgpu,f,u,h,r),c.forEach(m=>this.disposeIntermediateTensorInfo(m)),p&&(g=this.endTimer(g),this.activeTimers.push({name:e.constructor.name,query:this.getQueryTime(g)}));const x=W().getNumber("WEBGL_FLUSH_THRESHOLD");if(x>0){const m=Tn();m-this.lastGlFlushTime>x&&(this.gpgpu.gl.flush(),this.lastGlFlushTime=m)}if(!W().getBool("WEBGL_LAZILY_UNPACK")&&l.isPacked&&o===!1){const m=this.unpackTensor(a);return this.disposeIntermediateTensorInfo(a),m}return a}compileAndRun(e,n,s,r,o=!1){return s=s||n[0].dtype,this.runWebGLProgram(e,n,s,r,o)}getAndSaveBinary(e,n){return e in this.binaryCache||(this.binaryCache[e]=n()),this.binaryCache[e]}getTextureManager(){return this.textureManager}dispose(){this.disposed||(W().getBool("IS_TEST")||Object.keys(this.binaryCache).forEach(n=>{this.gpgpu.deleteProgram(this.binaryCache[n].webGLProgram),delete this.binaryCache[n]}),this.textureManager.dispose(),this.canvas!=null&&typeof HTMLCanvasElement<"u"&&this.canvas instanceof HTMLCanvasElement?this.canvas.remove():this.canvas=null,this.gpgpuCreatedLocally&&(this.gpgpu.program=null,this.gpgpu.dispose()),this.disposed=!0)}floatPrecision(){return this.floatPrecisionValue==null&&(this.floatPrecisionValue=P(()=>{if(!W().get("WEBGL_RENDER_FLOAT32_ENABLED")){const e=W().getBool("DEBUG");W().set("DEBUG",!1);const n=this.abs(We(1e-8)).dataSync()[0];if(W().set("DEBUG",e),n>0)return 32}return 16})),this.floatPrecisionValue}epsilon(){return this.floatPrecision()===32?rZ:oZ}uploadToGPU(e){const n=this.texData.get(e),{shape:s,dtype:r,values:o,texture:i,usage:a,isPacked:l}=n;if(i!=null)return;const c=this.activeTimers!=null;let u;c&&(u=Tn());let h=n.texShape;if(h==null&&(h=R9(s,l),n.texShape=h),o!=null){const d=ld(s);let f,p=h[1],g=h[0];const x=o instanceof Uint8Array||o instanceof Uint8ClampedArray;(l||!x)&&([p,g]=Nl(h[0],h[1])),l?f=new RY(d,x):f=new $k(d,x);const m=x?[g,p]:h,y=this.makeTensorInfo(m,r),w=this.texData.get(y.dataId);x?w.usage=ns.PIXELS:w.usage=ns.UPLOAD,w.texShape=m,this.gpgpu.uploadDenseMatrixToTexture(this.getTexture(y.dataId),p,g,o);const v=[[g,p]],C=this.runWebGLProgram(f,[y],r,v,!0),k=this.texData.get(C.dataId);n.texShape=k.texShape,n.isPacked=k.isPacked,n.usage=k.usage,W().get("ENGINE_COMPILE_ONLY")?this.disposeData(C.dataId):(n.texture=k.texture,n.values=null,this.texData.delete(C.dataId)),this.disposeIntermediateTensorInfo(y),c&&(this.uploadWaitMs+=Tn()-u)}else{const d=this.acquireTexture(h,a,r,l);n.texture=d}}convertAndCacheOnCPU(e,n){const s=this.texData.get(e),{dtype:r}=s;return n!=null&&(s.values=uZ(n,r)),s.values}acquireTexture(e,n,s,r){if(this.numBytesInGPU+=this.computeBytes(e,s),!this.warnedAboutMemory&&this.numBytesInGPU>this.numMBBeforeWarning*1024*1024){const o=(this.numBytesInGPU/1024/1024).toFixed(2);this.warnedAboutMemory=!0,console.warn(`High memory usage in GPU: ${o} MB, most likely due to a memory leak`)}return this.textureManager.acquireTexture(e,n,r)}computeBytes(e,n){return e[0]*e[1]*df(n)}checkCompileCompletion(){for(const[,e]of Object.entries(this.binaryCache))this.checkCompletion_(e)}async checkCompileCompletionAsync(){const e=[];if(this.gpgpu.parallelCompilationExtension){for(const[,n]of Object.entries(this.binaryCache))e.push(this.checkCompletionAsync_(n));return Promise.all(e)}else{for(const[,n]of Object.entries(this.binaryCache)){const s=new Promise(r=>{try{this.checkCompletion_(n),r(!0)}catch(o){throw o}});e.push(s)}return Promise.all(e)}}async checkCompletionAsync_(e){return this.gpgpu.gl.getProgramParameter(e.webGLProgram,this.gpgpu.parallelCompilationExtension.COMPLETION_STATUS_KHR)?this.checkCompletion_(e):(await UN(),this.checkCompletionAsync_(e))}checkCompletion_(e){if(this.gpgpu.gl.getProgramParameter(e.webGLProgram,this.gpgpu.gl.LINK_STATUS)===!1)throw console.log(this.gpgpu.gl.getProgramInfoLog(e.webGLProgram)),this.gpgpu.gl.getShaderParameter(e.fragmentShader,this.gpgpu.gl.COMPILE_STATUS)===!1?(VA(e.source,this.gpgpu.gl.getShaderInfoLog(e.fragmentShader)),new Error("Failed to compile fragment shader.")):new Error("Failed to link vertex and fragment shaders.");return!0}getUniformLocations(){for(const e of Object.values(this.binaryCache)){this.gpgpu.buildVao(e.webGLProgram);const{variablesLocations:n,customUniformLocations:s,infLoc:r,nanLoc:o,outShapeLocation:i,outShapeStridesLocation:a,outTexShapeLocation:l}=jA(this.gpgpu,e.program,e.webGLProgram);e.variablesLocations=n,e.customUniformLocations=s,e.infLoc=r,e.nanLoc=o,e.outShapeLocation=i,e.outShapeStridesLocation=a,e.outTexShapeLocation=l}}createTensorFromGPUData(e,n,s){e.channels=e.channels||"RGBA";const{texture:r,height:o,width:i,channels:a}=e,l=ir().backend;if(!l.gpgpu.gl.isTexture(r))throw new Error("The texture is invalid. Also, please make sure the texture and the TFJS WebGL backend are using the same canvas. If you want to use your own custom canvas, you have to create and use the custom TFJS WebGL backend created from the canvas through 'new tf.MathBackendWebGL(customCanvas)'.");const c=l.writeTexture(r,n,s,o,i,a);return ir().makeTensorFromDataId(c,n,s,l)}}Pm.nextDataId=0;function uZ(t,e){if(e==="float32"||e==="complex64")return t;if(e==="int32"||e==="bool"){const n=e==="int32"?new Int32Array(t.length):new Uint8Array(t.length);for(let s=0;snew Pm,2);/** + */P$()&&V$("webgl",()=>new Pm,2);/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -12893,7 +12893,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Yn(t){const{inputs:e,backend:n}=t,{x:s}=e;return n.incRef(s.dataId),{dataId:s.dataId,shape:s.shape,dtype:s.dtype}}const uZ={kernelName:Fu,backendName:"webgl",kernelFunc:Yn};/** + */function Yn(t){const{inputs:e,backend:n}=t,{x:s}=e;return n.incRef(s.dataId),{dataId:s.dataId,shape:s.shape,dtype:s.dtype}}const hZ={kernelName:Fu,backendName:"webgl",kernelFunc:Yn};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -12923,10 +12923,10 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const nD="return (a < 0.) ? b * a : a;",sD=` + */const sD="return (a < 0.) ? b * a : a;",rD=` vec4 aLessThanZero = vec4(lessThan(a, vec4(0.))); return (aLessThanZero * (b * a)) + ((vec4(1.0) - aLessThanZero) * a); -`;function hZ(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{alpha:o}=s,i=n.makeTensorInfo([],"float32",Wo(o,"float32")),a=W().getBool("WEBGL_PACK_BINARY_OPERATIONS")?new Dl(sD,r.shape,i.shape):new Wi(nD,r.shape,i.shape),l=n.runWebGLProgram(a,[r,i],"float32");return n.disposeIntermediateTensorInfo(i),l}const fZ={kernelName:Fp,backendName:"webgl",kernelFunc:hZ};/** +`;function fZ(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{alpha:o}=s,i=n.makeTensorInfo([],"float32",Wo(o,"float32")),a=W().getBool("WEBGL_PACK_BINARY_OPERATIONS")?new Dl(rD,r.shape,i.shape):new Wi(sD,r.shape,i.shape),l=n.runWebGLProgram(a,[r,i],"float32");return n.disposeIntermediateTensorInfo(i),l}const pZ={kernelName:Fp,backendName:"webgl",kernelFunc:fZ};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -12941,10 +12941,10 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const rD="return (a < 0.) ? b * a : a;",oD=` + */const oD="return (a < 0.) ? b * a : a;",iD=` vec4 aLessThanZero = vec4(lessThan(a, vec4(0.))); return (aLessThanZero * (b * a)) + ((vec4(1.0) - aLessThanZero) * a); -`;function pZ(t){const{inputs:e,backend:n}=t,{x:s,alpha:r}=e,o=W().getBool("WEBGL_PACK_BINARY_OPERATIONS")?new Dl(oD,s.shape,r.shape):new Wi(rD,s.shape,r.shape);return n.runWebGLProgram(o,[s,r],"float32")}const mZ={kernelName:Jp,backendName:"webgl",kernelFunc:pZ};/** +`;function mZ(t){const{inputs:e,backend:n}=t,{x:s,alpha:r}=e,o=W().getBool("WEBGL_PACK_BINARY_OPERATIONS")?new Dl(iD,s.shape,r.shape):new Wi(oD,s.shape,r.shape);return n.runWebGLProgram(o,[s,r],"float32")}const gZ={kernelName:Jp,backendName:"webgl",kernelFunc:mZ};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -12959,7 +12959,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const _l="if (isnan(x)) return x;";function Oe({opSnippet:t,packedOpSnippet:e,cpuKernelImpl:n,dtype:s}){return({inputs:r,backend:o})=>{const{x:i}=r,a=o,l=s||i.dtype;if(a.shouldExecuteOnCPU([i])&&n!=null){const d=a.texData.get(i.dataId),h=n(d.values,l);return a.makeTensorInfo(i.shape,l,h)}const c=W().getBool("WEBGL_PACK_UNARY_OPERATIONS")&&e!=null;let u;return c?u=new po(i.shape,e):u=new fr(i.shape,t),a.runWebGLProgram(u,[i],l)}}function rn({opSnippet:t,packedOpSnippet:e,checkOutOfBounds:n=!1,supportsComplex:s=!1,cpuKernelImpl:r,dtype:o}){return({inputs:i,backend:a})=>{const{a:l,b:c}=i,u=a;if(s&&l.dtype==="complex64"){const p=u.texData.get(l.dataId),g=u.texData.get(c.dataId),[x,m]=[[p.complexTensorInfos.real,g.complexTensorInfos.real],[p.complexTensorInfos.imag,g.complexTensorInfos.imag]].map(w=>{const[v,b]=w,C={dataId:v.dataId,dtype:v.dtype,shape:l.shape},k={dataId:b.dataId,dtype:b.dtype,shape:c.shape},S=new Wi(t,l.shape,c.shape);return u.runWebGLProgram(S,[C,k],Xn(v.dtype,b.dtype))}),y=Qo({inputs:{real:x,imag:m},backend:u});return u.disposeIntermediateTensorInfo(x),u.disposeIntermediateTensorInfo(m),y}const d=o||Xn(l.dtype,c.dtype);if((l.dtype==="string"||c.dtype==="string"||u.shouldExecuteOnCPU([l,c]))&&r!=null){const p=u.texData.get(l.dataId).values,g=u.texData.get(c.dataId).values,x=l.dtype==="string"?jr(p):p,m=l.dtype==="string"?jr(g):g,[y,w]=r(l.shape,c.shape,x,m,d),v=u.makeTensorInfo(w,d),b=u.texData.get(v.dataId);return b.values=y,v}const h=W().getBool("WEBGL_PACK_BINARY_OPERATIONS")&&e!=null;let f;return h?f=new Dl(e,l.shape,c.shape,n):f=new Wi(t,l.shape,c.shape),u.runWebGLProgram(f,[l,c],d)}}function tu(t,e=!1){if(t==="linear")return e?YQ:HQ;if(t==="relu")return e?ZQ:KQ;if(t==="elu")return e?QQ:jQ;if(t==="relu6")return e?JQ:XQ;if(t==="prelu")return e?oD:rD;if(t==="leakyrelu")return e?sD:nD;if(t==="sigmoid")return e?eZ:qQ;throw new Error(`Activation ${t} has not been implemented for the WebGL backend.`)}/** + */const _l="if (isnan(x)) return x;";function Oe({opSnippet:t,packedOpSnippet:e,cpuKernelImpl:n,dtype:s}){return({inputs:r,backend:o})=>{const{x:i}=r,a=o,l=s||i.dtype;if(a.shouldExecuteOnCPU([i])&&n!=null){const h=a.texData.get(i.dataId),d=n(h.values,l);return a.makeTensorInfo(i.shape,l,d)}const c=W().getBool("WEBGL_PACK_UNARY_OPERATIONS")&&e!=null;let u;return c?u=new po(i.shape,e):u=new pr(i.shape,t),a.runWebGLProgram(u,[i],l)}}function rn({opSnippet:t,packedOpSnippet:e,checkOutOfBounds:n=!1,supportsComplex:s=!1,cpuKernelImpl:r,dtype:o}){return({inputs:i,backend:a})=>{const{a:l,b:c}=i,u=a;if(s&&l.dtype==="complex64"){const p=u.texData.get(l.dataId),g=u.texData.get(c.dataId),[x,m]=[[p.complexTensorInfos.real,g.complexTensorInfos.real],[p.complexTensorInfos.imag,g.complexTensorInfos.imag]].map(w=>{const[v,b]=w,C={dataId:v.dataId,dtype:v.dtype,shape:l.shape},k={dataId:b.dataId,dtype:b.dtype,shape:c.shape},S=new Wi(t,l.shape,c.shape);return u.runWebGLProgram(S,[C,k],Xn(v.dtype,b.dtype))}),y=Qo({inputs:{real:x,imag:m},backend:u});return u.disposeIntermediateTensorInfo(x),u.disposeIntermediateTensorInfo(m),y}const h=o||Xn(l.dtype,c.dtype);if((l.dtype==="string"||c.dtype==="string"||u.shouldExecuteOnCPU([l,c]))&&r!=null){const p=u.texData.get(l.dataId).values,g=u.texData.get(c.dataId).values,x=l.dtype==="string"?Kr(p):p,m=l.dtype==="string"?Kr(g):g,[y,w]=r(l.shape,c.shape,x,m,h),v=u.makeTensorInfo(w,h),b=u.texData.get(v.dataId);return b.values=y,v}const d=W().getBool("WEBGL_PACK_BINARY_OPERATIONS")&&e!=null;let f;return d?f=new Dl(e,l.shape,c.shape,n):f=new Wi(t,l.shape,c.shape),u.runWebGLProgram(f,[l,c],h)}}function tu(t,e=!1){if(t==="linear")return e?QQ:jQ;if(t==="relu")return e?JQ:XQ;if(t==="elu")return e?ZQ:KQ;if(t==="relu6")return e?eZ:qQ;if(t==="prelu")return e?iD:oD;if(t==="leakyrelu")return e?rD:sD;if(t==="sigmoid")return e?tZ:YQ;throw new Error(`Activation ${t} has not been implemented for the WebGL backend.`)}/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -12974,7 +12974,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class iD{constructor(e,n,s,r=!1,o=!1,i=!1,a=null,l=!1,c=!1){this.variableNames=["matrixA","matrixB"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=s,this.enableShapeUniforms=pn(this.outputShape.length);const u=r?e[1]:e[2],d=Math.ceil(u/2),h=r?"i * 2, rc.y":"rc.y, i * 2",f=o?"rc.z, i * 2":"i * 2, rc.z",p=r?["a.xxyy","a.zzww"]:["a.xxzz","a.yyww"],g=o?["b.xzxz","b.ywyw"]:["b.xyxy","b.zwzw"];let x="",m="";a&&(l?x=`vec4 activation(vec4 a) { + */class aD{constructor(e,n,s,r=!1,o=!1,i=!1,a=null,l=!1,c=!1){this.variableNames=["matrixA","matrixB"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=s,this.enableShapeUniforms=pn(this.outputShape.length);const u=r?e[1]:e[2],h=Math.ceil(u/2),d=r?"i * 2, rc.y":"rc.y, i * 2",f=o?"rc.z, i * 2":"i * 2, rc.z",p=r?["a.xxyy","a.zzww"]:["a.xxzz","a.yyww"],g=o?["b.xzxz","b.ywyw"]:["b.xyxy","b.zwzw"];let x="",m="";a&&(l?x=`vec4 activation(vec4 a) { vec4 b = getPreluActivationWeightsAtOutCoords(); ${a} }`:c?x=`vec4 activation(vec4 a) { @@ -12985,14 +12985,14 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, }`,m="result = activation(result);");const y=i?"result += getBiasAtOutCoords();":"";i&&this.variableNames.push("bias"),l&&this.variableNames.push("preluActivationWeights"),c&&this.variableNames.push("leakyreluAlpha");let w="rc.x",v="rc.x";e[0]`The new shape (${l}) has ${c} elements and the old shape (${r.shape}) has ${a} elements. The new shape and old shape must have the same number of elements.`);const u=i.texData.get(r.dataId);return u.isPacked&&!Lf(r.shape,l)&&!(u.texture!==null&&Lf(u.shape,l))?xZ(r,l,i):(i.incRef(r.dataId),{dataId:r.dataId,shape:l,dtype:r.dtype})}const yZ={kernelName:tm,backendName:"webgl",kernelFunc:re};/** + */function re(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{shape:o}=s,i=n,a=j(r.shape),l=KI(o,a),c=j(l);I(a===c,()=>`The new shape (${l}) has ${c} elements and the old shape (${r.shape}) has ${a} elements. The new shape and old shape must have the same number of elements.`);const u=i.texData.get(r.dataId);return u.isPacked&&!Lf(r.shape,l)&&!(u.texture!==null&&Lf(u.shape,l))?yZ(r,l,i):(i.incRef(r.dataId),{dataId:r.dataId,shape:l,dtype:r.dtype})}const wZ={kernelName:tm,backendName:"webgl",kernelFunc:re};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -13101,7 +13101,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class Fk{constructor(e,n){this.variableNames=["x"];const{windowSize:s,batchSize:r,inSize:o,outSize:i}=e;this.outputShape=[r,i];const a=Math.floor(s/4)*4,l=s%4;let c="sumValue += dot(values, ones);";if(n!=null){const d=1/n;c=`sumValue += dot(values * ${nl(d)?d.toPrecision(2):d}, ones);`}let u="";o%s>0&&(u=` + */class Fk{constructor(e,n){this.variableNames=["x"];const{windowSize:s,batchSize:r,inSize:o,outSize:i}=e;this.outputShape=[r,i];const a=Math.floor(s/4)*4,l=s%4;let c="sumValue += dot(values, ones);";if(n!=null){const h=1/n;c=`sumValue += dot(values * ${nl(h)?h.toPrecision(2):h}, ones);`}let u="";o%s>0&&(u=` if (inIdx < 0 || inIdx >= ${o}) { return 0.0; } @@ -13169,7 +13169,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class wZ{constructor(e,n){this.variableNames=["x"];const{windowSize:s,batchSize:r,inSize:o,outSize:i}=e;this.outputShape=[r,i];let a="0.0",l="";n==="prod"?a="1.0":n==="min"?(a="1.0 / 1e-20",l="min"):n==="max"&&(a="-1.0 / 1e-20",l="max");let c=`${n}(${n}(${n}(minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])`;n==="sum"?c="sumValue":n==="prod"?c="prodValue":n==="all"?c="allValue":n==="any"&&(c="anyValue");const u=Math.floor(s/4)*4,d=s%4;let h=` + */class vZ{constructor(e,n){this.variableNames=["x"];const{windowSize:s,batchSize:r,inSize:o,outSize:i}=e;this.outputShape=[r,i];let a="0.0",l="";n==="prod"?a="1.0":n==="min"?(a="1.0 / 1e-20",l="min"):n==="max"&&(a="-1.0 / 1e-20",l="max");let c=`${n}(${n}(${n}(minMaxValue[0], minMaxValue[1]), minMaxValue[2]), minMaxValue[3])`;n==="sum"?c="sumValue":n==="prod"?c="prodValue":n==="all"?c="allValue":n==="any"&&(c="anyValue");const u=Math.floor(s/4)*4,h=s%4;let d=` if (${n==="sum"}) { sumValue += dot(values, ones); } else if (${n==="prod"}) { @@ -13185,11 +13185,11 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, } } } - `,f="vec4";n==="all"?(a="1.0",h=` + `,f="vec4";n==="all"?(a="1.0",d=` bool reducedAllValue = all(values); float floatedReducedAllValue = float(reducedAllValue); allValue = float(allValue >= 1.0 && floatedReducedAllValue >= 1.0); - `,f="bvec4"):n==="any"&&(a="0.0",h=` + `,f="bvec4"):n==="any"&&(a="0.0",d=` bool reducedAnyValue = any(values); float floatedReducedAnyValue = float(reducedAnyValue); anyValue = float(anyValue >= 1.0 || floatedReducedAnyValue >= 1.0); @@ -13227,11 +13227,11 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, getValue(batch, inIdx + 3) ); - ${h} + ${d} } int inIdx = inOffset + ${u}; - if (${d===1}) { + if (${h===1}) { ${f} values = ${f}( getValue(batch, inIdx), initializationValue, @@ -13239,8 +13239,8 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, initializationValue ); - ${h} - } else if (${d===2}) { + ${d} + } else if (${h===2}) { ${f} values = ${f}( getValue(batch, inIdx), getValue(batch, inIdx + 1), @@ -13248,8 +13248,8 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, initializationValue ); - ${h} - } else if (${d===3}) { + ${d} + } else if (${h===3}) { ${f} values = ${f}( getValue(batch, inIdx), getValue(batch, inIdx + 1), @@ -13257,7 +13257,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, initializationValue ); - ${h} + ${d} } setOutput(${c}); } @@ -13276,7 +13276,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function vZ(t){const e=[];for(;e.length===0||e[e.length-1].outSize!==1;){const n=e.length?e[e.length-1].outSize:t[1],s=Cm(n);e.push({inSize:n,windowSize:s,outSize:Math.ceil(n/s)})}return e}function sa(t,e,n,s){const r=vZ(t.shape);let o=t;for(let i=0;i6)throw Error(`Transpose for rank ${e} is not yet supported`);const n=["resRC.x","resRC.y","resRC.z","resRC.w","resRC.u","resRC.v"],s=new Array(e);for(let r=0;r6)throw Error(`Transpose for rank ${e} is not yet supported`);const n=["resRC.x","resRC.y","resRC.z","resRC.w","resRC.u","resRC.v"],s=new Array(e);for(let r=0;r6)throw Error(`Packed transpose for rank ${this.rank} is not yet supported.`);const r=Ze(this.rank),o=eD("rc",this.rank),i=new Array(this.rank);for(let u=0;u6)throw Error(`Packed transpose for rank ${this.rank} is not yet supported.`);const r=Ze(this.rank),o=tD("rc",this.rank),i=new Array(this.rank);for(let u=0;u`Error in matMul: inner shapes (${d}) and (${h}) of Tensors with shapes ${t.shape} and ${e.shape} and transposeA=${n} and transposeB=${s} must match.`);const b=n?[m,d,f]:[m,f,d],C=s?[y,p,h]:[y,h,p],k=re({inputs:{x:t},backend:r,attrs:{shape:b}}),S=re({inputs:{x:e},backend:r,attrs:{shape:C}}),$=[k,S],N=Math.max(m,y),A=n?k.shape[1]:k.shape[2],M=o!=null,L=i!=null,V=l==="leakyrelu",B=l!=null?tu(l,!0):null,U=M||L||V||B!=null;let K;if((f===1||p===1)&&A>aD&&U===!1){let O=k,G=S;n&&(O=Sn({inputs:{x:k},backend:r,attrs:{perm:[0,2,1]}}),$.push(O)),s&&(G=Sn({inputs:{x:S},backend:r,attrs:{perm:[0,2,1]}}),$.push(G));const X=p!==1,q=p===1;let Q=O;X&&(Q=re({inputs:{x:O},backend:r,attrs:{shape:[N,A,1]}}),$.push(Q));const ee=p===1?2:1;let Z=G;q&&(Z=re({inputs:{x:G},backend:r,attrs:{shape:[N,1,A]}}),$.push(Z));const se=$v({inputs:{a:Q,b:Z},backend:r});K=Bm({inputs:{x:se},backend:r,attrs:{axis:ee,keepDims:!0}}),$.push(se)}else{const O=Xn(t.dtype,e.dtype),G=new iD(b,C,[N,f,p],n,s,M,B,L,V),X=[k,S];if(o!=null&&X.push(o),L&&X.push(i),V){const q=r.makeTensorInfo([],"float32",Wo(a,"float32"));X.push(q),$.push(q)}K=r.runWebGLProgram(G,X,O)}const R=re({inputs:{x:K},backend:r,attrs:{shape:v}});$.push(K);for(const O of $)r.disposeIntermediateTensorInfo(O);return R}/** + */const lD=1e3;function Bf({a:t,b:e,transposeA:n,transposeB:s,backend:r,bias:o=null,preluActivationWeights:i=null,leakyreluAlpha:a=0,activation:l=null}){const c=t.shape.length,u=e.shape.length,h=n?t.shape[c-2]:t.shape[c-1],d=s?e.shape[u-1]:e.shape[u-2],f=n?t.shape[c-1]:t.shape[c-2],p=s?e.shape[u-2]:e.shape[u-1],g=t.shape.slice(0,-2),x=e.shape.slice(0,-2),m=j(g),y=j(x),v=Se(t.shape.slice(0,-2),e.shape.slice(0,-2)).concat([f,p]);I(h===d,()=>`Error in matMul: inner shapes (${h}) and (${d}) of Tensors with shapes ${t.shape} and ${e.shape} and transposeA=${n} and transposeB=${s} must match.`);const b=n?[m,h,f]:[m,f,h],C=s?[y,p,d]:[y,d,p],k=re({inputs:{x:t},backend:r,attrs:{shape:b}}),S=re({inputs:{x:e},backend:r,attrs:{shape:C}}),$=[k,S],N=Math.max(m,y),A=n?k.shape[1]:k.shape[2],M=o!=null,L=i!=null,V=l==="leakyrelu",B=l!=null?tu(l,!0):null,U=M||L||V||B!=null;let K;if((f===1||p===1)&&A>lD&&U===!1){let O=k,G=S;n&&(O=Sn({inputs:{x:k},backend:r,attrs:{perm:[0,2,1]}}),$.push(O)),s&&(G=Sn({inputs:{x:S},backend:r,attrs:{perm:[0,2,1]}}),$.push(G));const X=p!==1,q=p===1;let Q=O;X&&(Q=re({inputs:{x:O},backend:r,attrs:{shape:[N,A,1]}}),$.push(Q));const te=p===1?2:1;let Z=G;q&&(Z=re({inputs:{x:G},backend:r,attrs:{shape:[N,1,A]}}),$.push(Z));const se=$v({inputs:{a:Q,b:Z},backend:r});K=Bm({inputs:{x:se},backend:r,attrs:{axis:te,keepDims:!0}}),$.push(se)}else{const O=Xn(t.dtype,e.dtype),G=new aD(b,C,[N,f,p],n,s,M,B,L,V),X=[k,S];if(o!=null&&X.push(o),L&&X.push(i),V){const q=r.makeTensorInfo([],"float32",Wo(a,"float32"));X.push(q),$.push(q)}K=r.runWebGLProgram(G,X,O)}const R=re({inputs:{x:K},backend:r,attrs:{shape:v}});$.push(K);for(const O of $)r.disposeIntermediateTensorInfo(O);return R}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -13418,7 +13418,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function NZ(t){const{inputs:e,backend:n,attrs:s}=t,{a:r,b:o,bias:i,preluActivationWeights:a}=e,{transposeA:l,transposeB:c,activation:u,leakyreluAlpha:d}=s;return Bf({a:r,b:o,transposeA:l,transposeB:c,backend:n,bias:i,preluActivationWeights:a,leakyreluAlpha:d,activation:u})}const TZ={kernelName:ff,backendName:"webgl",kernelFunc:NZ};/** + */function TZ(t){const{inputs:e,backend:n,attrs:s}=t,{a:r,b:o,bias:i,preluActivationWeights:a}=e,{transposeA:l,transposeB:c,activation:u,leakyreluAlpha:h}=s;return Bf({a:r,b:o,transposeA:l,transposeB:c,backend:n,bias:i,preluActivationWeights:a,leakyreluAlpha:h,activation:u})}const EZ={kernelName:ff,backendName:"webgl",kernelFunc:TZ};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -13433,7 +13433,7 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const zk="return abs(x);";function EZ(t){const{inputs:e,backend:n}=t,{x:s}=e;if(n.shouldExecuteOnCPU([s])&&s.dtype!=="complex64"){const o=n.texData.get(s.dataId),i=ZA(o.values);return n.makeTensorInfo(s.shape,s.dtype,i)}let r;return W().getBool("WEBGL_PACK_UNARY_OPERATIONS")?r=new po(s.shape,zk):r=new fr(s.shape,zk),n.runWebGLProgram(r,[s],s.dtype)}const RZ={kernelName:pp,backendName:"webgl",kernelFunc:EZ};/** + */const zk="return abs(x);";function RZ(t){const{inputs:e,backend:n}=t,{x:s}=e;if(n.shouldExecuteOnCPU([s])&&s.dtype!=="complex64"){const o=n.texData.get(s.dataId),i=JA(o.values);return n.makeTensorInfo(s.shape,s.dtype,i)}let r;return W().getBool("WEBGL_PACK_UNARY_OPERATIONS")?r=new po(s.shape,zk):r=new pr(s.shape,zk),n.runWebGLProgram(r,[s],s.dtype)}const AZ={kernelName:pp,backendName:"webgl",kernelFunc:RZ};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -13448,12 +13448,12 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const AZ=Ds+` + */const DZ=_s+` if (abs(x) > 1.) { return NAN; } return acos(x); -`,DZ=Oe({opSnippet:AZ}),_Z={kernelName:pu,backendName:"webgl",kernelFunc:DZ};/** +`,_Z=Oe({opSnippet:DZ}),FZ={kernelName:pu,backendName:"webgl",kernelFunc:_Z};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -13468,9 +13468,9 @@ vec2 packedUVfrom3D(int texNumR, int texNumC, * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const FZ=Ds+` + */const zZ=_s+` if (x < 1.0) return NAN; -return log(x + sqrt(x * x - 1.0));`,zZ=Oe({opSnippet:FZ}),OZ={kernelName:mu,backendName:"webgl",kernelFunc:zZ};/** +return log(x + sqrt(x * x - 1.0));`,OZ=Oe({opSnippet:zZ}),MZ={kernelName:mu,backendName:"webgl",kernelFunc:OZ};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -13485,7 +13485,7 @@ return log(x + sqrt(x * x - 1.0));`,zZ=Oe({opSnippet:FZ}),OZ={kernelName:mu,back * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Ok="return a + b;",MZ=rn({opSnippet:Ok,packedOpSnippet:Ok,supportsComplex:!0,cpuKernelImpl:KY}),PZ={kernelName:bl,backendName:"webgl",kernelFunc:MZ};/** + */const Ok="return a + b;",PZ=rn({opSnippet:Ok,packedOpSnippet:Ok,supportsComplex:!0,cpuKernelImpl:XY}),LZ={kernelName:bl,backendName:"webgl",kernelFunc:PZ};/** * @license * Copyright 2019 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -13500,7 +13500,7 @@ return log(x + sqrt(x * x - 1.0));`,zZ=Oe({opSnippet:FZ}),OZ={kernelName:mu,back * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class LZ{constructor(e,n){this.outputShape=[],this.outputShape=e,this.variableNames=n.map((o,i)=>`T${i}`);const s=[];this.variableNames.forEach(o=>{s.push(`float v${o} = get${o}AtOutCoords();`)});const r=this.variableNames.map(o=>`v${o}`).join(" + ");this.userCode=` + */class BZ{constructor(e,n){this.outputShape=[],this.outputShape=e,this.variableNames=n.map((o,i)=>`T${i}`);const s=[];this.variableNames.forEach(o=>{s.push(`float v${o} = get${o}AtOutCoords();`)});const r=this.variableNames.map(o=>`v${o}`).join(" + ");this.userCode=` void main() { ${s.join(` `)} @@ -13523,7 +13523,7 @@ return log(x + sqrt(x * x - 1.0));`,zZ=Oe({opSnippet:FZ}),OZ={kernelName:mu,back * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class BZ{constructor(e,n){this.outputShape=[],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=e,this.variableNames=n.map((o,i)=>`T${i}`);const s=[];this.variableNames.forEach(o=>{s.push(`vec4 v${o} = get${o}AtOutCoords();`)});const r=this.variableNames.map(o=>`v${o}`).join(" + ");this.userCode=` + */class VZ{constructor(e,n){this.outputShape=[],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=e,this.variableNames=n.map((o,i)=>`T${i}`);const s=[];this.variableNames.forEach(o=>{s.push(`vec4 v${o} = get${o}AtOutCoords();`)});const r=this.variableNames.map(o=>`v${o}`).join(" + ");this.userCode=` void main() { ${s.join(` `)} @@ -13546,7 +13546,7 @@ return log(x + sqrt(x * x - 1.0));`,zZ=Oe({opSnippet:FZ}),OZ={kernelName:mu,back * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function _h(t){const{inputs:e,backend:n}=t,s=e;if(s.length===1)return Yn({inputs:{x:s[0]},backend:n});if(s.length>W().getNumber("WEBGL_MAX_TEXTURES_IN_SHADER")){const l=Math.floor(s.length/2),c=_h({inputs:s.slice(0,l),backend:n}),u=_h({inputs:s.slice(l),backend:n});return _h({inputs:[c,u],backend:n})}const r=s.map(l=>l.dtype).reduce((l,c)=>Xn(l,c)),o=s.map(l=>l.shape),a=W().getBool("WEBGL_PACK")?new BZ(s[0].shape,o):new LZ(s[0].shape,o);return n.runWebGLProgram(a,s,r)}const VZ={kernelName:Gx,backendName:"webgl",kernelFunc:_h};/** + */function _d(t){const{inputs:e,backend:n}=t,s=e;if(s.length===1)return Yn({inputs:{x:s[0]},backend:n});if(s.length>W().getNumber("WEBGL_MAX_TEXTURES_IN_SHADER")){const l=Math.floor(s.length/2),c=_d({inputs:s.slice(0,l),backend:n}),u=_d({inputs:s.slice(l),backend:n});return _d({inputs:[c,u],backend:n})}const r=s.map(l=>l.dtype).reduce((l,c)=>Xn(l,c)),o=s.map(l=>l.shape),a=W().getBool("WEBGL_PACK")?new VZ(s[0].shape,o):new BZ(s[0].shape,o);return n.runWebGLProgram(a,s,r)}const WZ={kernelName:Gx,backendName:"webgl",kernelFunc:_d};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -13561,7 +13561,7 @@ return log(x + sqrt(x * x - 1.0));`,zZ=Oe({opSnippet:FZ}),OZ={kernelName:mu,back * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function WZ(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{axis:o,keepDims:i}=s,a=r.shape.length,l=Re(o,r.shape);let c=l;const u=yt(c,a);let d=r;u!=null&&(d=Sn({inputs:{x:r},backend:n,attrs:{perm:u}}),c=$t(c.length,a)),sn("all",c,a);const[h,f]=Yt(d.shape,c),p=j(f),g=re({inputs:{x:d},backend:n,attrs:{shape:[-1,p]}}),x=sa(g,g.dtype,"all",n);let m;if(i){const y=Dt(h,l);m=re({inputs:{x},backend:n,attrs:{shape:y}})}else m=re({inputs:{x},backend:n,attrs:{shape:h}});return n.disposeIntermediateTensorInfo(g),n.disposeIntermediateTensorInfo(x),u!=null&&n.disposeIntermediateTensorInfo(d),m}const UZ={kernelName:Hx,backendName:"webgl",kernelFunc:WZ};/** + */function UZ(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{axis:o,keepDims:i}=s,a=r.shape.length,l=Re(o,r.shape);let c=l;const u=yt(c,a);let h=r;u!=null&&(h=Sn({inputs:{x:r},backend:n,attrs:{perm:u}}),c=$t(c.length,a)),sn("all",c,a);const[d,f]=Yt(h.shape,c),p=j(f),g=re({inputs:{x:h},backend:n,attrs:{shape:[-1,p]}}),x=sa(g,g.dtype,"all",n);let m;if(i){const y=Dt(d,l);m=re({inputs:{x},backend:n,attrs:{shape:y}})}else m=re({inputs:{x},backend:n,attrs:{shape:d}});return n.disposeIntermediateTensorInfo(g),n.disposeIntermediateTensorInfo(x),u!=null&&n.disposeIntermediateTensorInfo(h),m}const GZ={kernelName:Hx,backendName:"webgl",kernelFunc:UZ};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -13576,7 +13576,7 @@ return log(x + sqrt(x * x - 1.0));`,zZ=Oe({opSnippet:FZ}),OZ={kernelName:mu,back * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function GZ(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{axis:o,keepDims:i}=s,a=r.shape.length,l=Re(o,r.shape);let c=l;const u=yt(c,a);let d=r;u!=null&&(d=Sn({inputs:{x:r},backend:n,attrs:{perm:u}}),c=$t(c.length,a)),sn("any",c,a);const[h,f]=Yt(d.shape,c),p=j(f),g=re({inputs:{x:d},backend:n,attrs:{shape:[-1,p]}}),x=sa(g,g.dtype,"any",n);let m;if(i){const y=Dt(h,l);m=re({inputs:{x},backend:n,attrs:{shape:y}})}else m=re({inputs:{x},backend:n,attrs:{shape:h}});return n.disposeIntermediateTensorInfo(g),n.disposeIntermediateTensorInfo(x),u!=null&&n.disposeIntermediateTensorInfo(d),m}const HZ={kernelName:jx,backendName:"webgl",kernelFunc:GZ};/** + */function HZ(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{axis:o,keepDims:i}=s,a=r.shape.length,l=Re(o,r.shape);let c=l;const u=yt(c,a);let h=r;u!=null&&(h=Sn({inputs:{x:r},backend:n,attrs:{perm:u}}),c=$t(c.length,a)),sn("any",c,a);const[d,f]=Yt(h.shape,c),p=j(f),g=re({inputs:{x:h},backend:n,attrs:{shape:[-1,p]}}),x=sa(g,g.dtype,"any",n);let m;if(i){const y=Dt(d,l);m=re({inputs:{x},backend:n,attrs:{shape:y}})}else m=re({inputs:{x},backend:n,attrs:{shape:d}});return n.disposeIntermediateTensorInfo(g),n.disposeIntermediateTensorInfo(x),u!=null&&n.disposeIntermediateTensorInfo(h),m}const jZ={kernelName:jx,backendName:"webgl",kernelFunc:HZ};/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -13591,7 +13591,7 @@ return log(x + sqrt(x * x - 1.0));`,zZ=Oe({opSnippet:FZ}),OZ={kernelName:mu,back * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class jZ{constructor(e,n,s){this.variableNames=["A"];const{windowSize:r,batchSize:o,outSize:i}=e;s||this.variableNames.push("bestIndicesA"),this.outputShape=[o,i];const a=n==="max"?">":"<",l=s?"inOffset + i;":"round(getBestIndicesA(batch, inOffset + i));";this.userCode=` + */class KZ{constructor(e,n,s){this.variableNames=["A"];const{windowSize:r,batchSize:o,outSize:i}=e;s||this.variableNames.push("bestIndicesA"),this.outputShape=[o,i];const a=n==="max"?">":"<",l=s?"inOffset + i;":"round(getBestIndicesA(batch, inOffset + i));";this.userCode=` void main() { ivec2 coords = getOutputCoords(); int batch = coords[0]; @@ -13626,7 +13626,7 @@ return log(x + sqrt(x * x - 1.0));`,zZ=Oe({opSnippet:FZ}),OZ={kernelName:mu,back * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class KZ{constructor(e,n,s,r){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!0,I(e.length>2,()=>`Packed arg${s.charAt(0).toUpperCase()+s.slice(1)} supports only inputs with rank above 2.`);const o=e[e.length-1],i=Math.ceil(o/n);this.outputShape=e.slice(0,-1),i>1&&this.outputShape.push(i),r||this.variableNames.push("bestIndicesA");const a=this.outputShape,l=a.length,c=Ze(l),u=vn("coords",l);let d,h;if(i===1){h=l+1;const S=Ze(h);d=` + */class XZ{constructor(e,n,s,r){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!0,I(e.length>2,()=>`Packed arg${s.charAt(0).toUpperCase()+s.slice(1)} supports only inputs with rank above 2.`);const o=e[e.length-1],i=Math.ceil(o/n);this.outputShape=e.slice(0,-1),i>1&&this.outputShape.push(i),r||this.variableNames.push("bestIndicesA");const a=this.outputShape,l=a.length,c=Ze(l),u=vn("coords",l);let h,d;if(i===1){d=l+1;const S=Ze(d);h=` ${S} sourceLocR = ${S}(${u.join()}, 0); ++${u[l-1]}; ${S} sourceLocG = ${S}(${u.join()}, 0); @@ -13634,7 +13634,7 @@ return log(x + sqrt(x * x - 1.0));`,zZ=Oe({opSnippet:FZ}),OZ={kernelName:mu,back ${S} sourceLocA = ${S}(${u.join()}, 0); --${u[l-1]}; ${S} sourceLocB = ${S}(${u.join()}, 0); - --${u[l-2]};`}else h=l,d=` + --${u[l-2]};`}else d=l,h=` ${c} sourceLocR = coords; ++${u[l-1]}; ${c} sourceLocG = coords; @@ -13642,7 +13642,7 @@ return log(x + sqrt(x * x - 1.0));`,zZ=Oe({opSnippet:FZ}),OZ={kernelName:mu,back ${c} sourceLocA = coords; --${u[l-1]}; ${c} sourceLocB = coords; - --${u[l-2]};`;const f=["x","y","z","w","u","v"].slice(0,h),p="."+f[h-1],g=f.map(S=>"int "+S),x=vn("sourceLocR",h-1).concat("inIdx.r"),m=vn("sourceLocG",h-1).concat("inIdx.g"),y=vn("sourceLocB",h-1).concat("inIdx.b"),w=vn("sourceLocA",h-1).concat("inIdx.a"),v=s==="max"?"greaterThan":"lessThan",b=r?"":` + --${u[l-2]};`;const f=["x","y","z","w","u","v"].slice(0,d),p="."+f[d-1],g=f.map(S=>"int "+S),x=vn("sourceLocR",d-1).concat("inIdx.r"),m=vn("sourceLocG",d-1).concat("inIdx.g"),y=vn("sourceLocB",d-1).concat("inIdx.b"),w=vn("sourceLocA",d-1).concat("inIdx.a"),v=s==="max"?"greaterThan":"lessThan",b=r?"":` inIdx = round(vec4(getBestIndicesAChannel(${x.join()}), getBestIndicesAChannel(${m.join()}), getBestIndicesAChannel(${y.join()}), @@ -13664,7 +13664,7 @@ return log(x + sqrt(x * x - 1.0));`,zZ=Oe({opSnippet:FZ}),OZ={kernelName:mu,back ${c} coords = getOutputCoords(); bool hasNextCol = ${u[l-1]} < ${a[l-1]-1}; bool hasNextRow = ${u[l-2]} < ${a[l-2]-1}; - ${d} + ${h} ivec4 srcIdx = ivec4(sourceLocR${p}, sourceLocG${p}, sourceLocB${p}, sourceLocA${p}) * ${n}; ivec4 inIdx = srcIdx; @@ -13703,7 +13703,7 @@ return log(x + sqrt(x * x - 1.0));`,zZ=Oe({opSnippet:FZ}),OZ={kernelName:mu,back * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function lD(t,e,n,s=null){let r=e.shape[0],o=e.shape[1];s!=null&&(r=s.shape[0],o=s.shape[1]);const i=Cm(o),a={windowSize:i,inSize:o,batchSize:r,outSize:Math.ceil(o/i)},l=new jZ(a,n,s==null),c=[e];s!=null&&c.push(s);const u=t.runWebGLProgram(l,c,"int32");if(u.shape[1]===1)return u;const d=lD(t,e,n,u);return t.disposeIntermediateTensorInfo(u),d}function cD(t,e,n,s=null){const r=s!=null?s.shape:e.shape,o=r[r.length-1],i=Cm(o),a=new KZ(r,i,n,s==null),l=s==null?[e]:[e,s],c=t.runWebGLProgram(a,l,"int32");if(c.shape.length===e.shape.length){const u=cD(t,e,n,c);return t.disposeIntermediateTensorInfo(c),u}return c}function uD(t,e,n,s){const r=[n];if(sn("arg"+s.charAt(0).toUpperCase()+s.slice(1),r,e.shape.length),!W().getBool("WEBGL_PACK_REDUCE")||e.shape.length<=2){const o=[],i=t.texData.get(e.dataId),a=i!==null&&i.isPacked;let l=e;a&&(l=t.unpackTensor(e),o.push(l));const[c,u]=Yt(l.shape,r),d=j(u),h=re({inputs:{x:l},backend:t,attrs:{shape:[-1,d]}});o.push(h);const f=lD(t,h,s);o.push(f);const p=re({inputs:{x:f},backend:t,attrs:{shape:c}});return o.forEach(g=>t.disposeIntermediateTensorInfo(g)),p}return cD(t,e,s)}/** + */function cD(t,e,n,s=null){let r=e.shape[0],o=e.shape[1];s!=null&&(r=s.shape[0],o=s.shape[1]);const i=Cm(o),a={windowSize:i,inSize:o,batchSize:r,outSize:Math.ceil(o/i)},l=new KZ(a,n,s==null),c=[e];s!=null&&c.push(s);const u=t.runWebGLProgram(l,c,"int32");if(u.shape[1]===1)return u;const h=cD(t,e,n,u);return t.disposeIntermediateTensorInfo(u),h}function uD(t,e,n,s=null){const r=s!=null?s.shape:e.shape,o=r[r.length-1],i=Cm(o),a=new XZ(r,i,n,s==null),l=s==null?[e]:[e,s],c=t.runWebGLProgram(a,l,"int32");if(c.shape.length===e.shape.length){const u=uD(t,e,n,c);return t.disposeIntermediateTensorInfo(c),u}return c}function hD(t,e,n,s){const r=[n];if(sn("arg"+s.charAt(0).toUpperCase()+s.slice(1),r,e.shape.length),!W().getBool("WEBGL_PACK_REDUCE")||e.shape.length<=2){const o=[],i=t.texData.get(e.dataId),a=i!==null&&i.isPacked;let l=e;a&&(l=t.unpackTensor(e),o.push(l));const[c,u]=Yt(l.shape,r),h=j(u),d=re({inputs:{x:l},backend:t,attrs:{shape:[-1,h]}});o.push(d);const f=cD(t,d,s);o.push(f);const p=re({inputs:{x:f},backend:t,attrs:{shape:c}});return o.forEach(g=>t.disposeIntermediateTensorInfo(g)),p}return uD(t,e,s)}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -13718,7 +13718,7 @@ return log(x + sqrt(x * x - 1.0));`,zZ=Oe({opSnippet:FZ}),OZ={kernelName:mu,back * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function XZ(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{axis:o}=s;let i=Re(o,r.shape);const a=yt(i,r.shape.length);let l=r;const c=[];a!=null&&(l=Sn({inputs:{x:r},backend:n,attrs:{perm:a}}),c.push(l),i=$t(i.length,l.shape.length)),sn("argMax",[i[0]],l.shape.length);const u=uD(n,l,i[0],"max");return c.forEach(d=>n.disposeIntermediateTensorInfo(d)),u}const qZ={kernelName:mp,backendName:"webgl",kernelFunc:XZ};/** + */function qZ(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{axis:o}=s;let i=Re(o,r.shape);const a=yt(i,r.shape.length);let l=r;const c=[];a!=null&&(l=Sn({inputs:{x:r},backend:n,attrs:{perm:a}}),c.push(l),i=$t(i.length,l.shape.length)),sn("argMax",[i[0]],l.shape.length);const u=hD(n,l,i[0],"max");return c.forEach(h=>n.disposeIntermediateTensorInfo(h)),u}const YZ={kernelName:mp,backendName:"webgl",kernelFunc:qZ};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -13733,7 +13733,7 @@ return log(x + sqrt(x * x - 1.0));`,zZ=Oe({opSnippet:FZ}),OZ={kernelName:mu,back * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function YZ(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{axis:o}=s;let i=Re(o,r.shape);const a=yt(i,r.shape.length);let l=r;const c=[];a!=null&&(l=Sn({inputs:{x:r},backend:n,attrs:{perm:a}}),c.push(l),i=$t(i.length,l.shape.length)),sn("argMin",[i[0]],l.shape.length);const u=uD(n,l,i[0],"min");return c.forEach(d=>n.disposeIntermediateTensorInfo(d)),u}const QZ={kernelName:gp,backendName:"webgl",kernelFunc:YZ};/** + */function QZ(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{axis:o}=s;let i=Re(o,r.shape);const a=yt(i,r.shape.length);let l=r;const c=[];a!=null&&(l=Sn({inputs:{x:r},backend:n,attrs:{perm:a}}),c.push(l),i=$t(i.length,l.shape.length)),sn("argMin",[i[0]],l.shape.length);const u=hD(n,l,i[0],"min");return c.forEach(h=>n.disposeIntermediateTensorInfo(h)),u}const ZZ={kernelName:gp,backendName:"webgl",kernelFunc:QZ};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -13748,12 +13748,12 @@ return log(x + sqrt(x * x - 1.0));`,zZ=Oe({opSnippet:FZ}),OZ={kernelName:mu,back * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const ZZ=Ds+` + */const JZ=_s+` if (abs(x) > 1.) { return NAN; } return asin(x); -`,JZ=Oe({opSnippet:ZZ}),eJ={kernelName:gu,backendName:"webgl",kernelFunc:JZ};/** +`,eJ=Oe({opSnippet:JZ}),tJ={kernelName:gu,backendName:"webgl",kernelFunc:eJ};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -13768,7 +13768,7 @@ return log(x + sqrt(x * x - 1.0));`,zZ=Oe({opSnippet:FZ}),OZ={kernelName:mu,back * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const tJ=Ds+"return log(x + sqrt(x * x + 1.0));",nJ=Oe({opSnippet:tJ}),sJ={kernelName:xu,backendName:"webgl",kernelFunc:nJ};/** + */const nJ=_s+"return log(x + sqrt(x * x + 1.0));",sJ=Oe({opSnippet:nJ}),rJ={kernelName:xu,backendName:"webgl",kernelFunc:sJ};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -13783,9 +13783,9 @@ return log(x + sqrt(x * x - 1.0));`,zZ=Oe({opSnippet:FZ}),OZ={kernelName:mu,back * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const rJ=Ds+` + */const oJ=_s+` return atan(x); -`,oJ=Oe({opSnippet:rJ}),iJ={kernelName:yu,backendName:"webgl",kernelFunc:oJ};/** +`,iJ=Oe({opSnippet:oJ}),aJ={kernelName:yu,backendName:"webgl",kernelFunc:iJ};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -13800,16 +13800,16 @@ return log(x + sqrt(x * x - 1.0));`,zZ=Oe({opSnippet:FZ}),OZ={kernelName:mu,back * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const aJ=Iv+` + */const lJ=Iv+` return atan(a, b); -`,lJ=` +`,cJ=` vec4 result = atan(a, b); bvec4 isNaNA = isnan(a); bvec4 isNaNB = isnan(b); bvec4 isNaN = bvec4(isNaNA.x || isNaNB.x, isNaNA.y || isNaNB.y, isNaNA.z || isNaNB.z, isNaNA.w || isNaNB.w); `+na+` return result; -`,cJ=rn({opSnippet:aJ,packedOpSnippet:lJ}),uJ={kernelName:vu,backendName:"webgl",kernelFunc:cJ};/** +`,uJ=rn({opSnippet:lJ,packedOpSnippet:cJ}),hJ={kernelName:vu,backendName:"webgl",kernelFunc:uJ};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -13824,9 +13824,9 @@ return log(x + sqrt(x * x - 1.0));`,zZ=Oe({opSnippet:FZ}),OZ={kernelName:mu,back * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const dJ=Ds+` + */const dJ=_s+` if ((x < -1.0) || (x > 1.0)) return NAN; -return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelName:wu,backendName:"webgl",kernelFunc:hJ};/** +return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,fJ=Oe({opSnippet:dJ}),pJ={kernelName:wu,backendName:"webgl",kernelFunc:fJ};/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -13841,7 +13841,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class nu{constructor(e,n,s,r=!1,o=!1){if(this.variableNames=["x"],n==="avg"&&s)throw new Error("Cannot compute positions for average pool.");const i=e.filterWidth,a=e.strideHeight,l=e.strideWidth,c=e.dilationHeight,u=e.dilationWidth,d=e.effectiveFilterHeight,h=e.effectiveFilterWidth,f=e.padInfo.top,p=e.padInfo.left;this.outputShape=e.outShape;const g=n==="avg",x=`((batch * ${e.inHeight} + xR) * ${e.inWidth} + xC) * ${e.inChannels} + d`,m=`(xR * ${e.inWidth} + xC) * ${e.inChannels} + d`;let y="0.0";if(g||(y="-1.0 / 1e-20"),s){const S=">=";this.userCode=` + */class nu{constructor(e,n,s,r=!1,o=!1){if(this.variableNames=["x"],n==="avg"&&s)throw new Error("Cannot compute positions for average pool.");const i=e.filterWidth,a=e.strideHeight,l=e.strideWidth,c=e.dilationHeight,u=e.dilationWidth,h=e.effectiveFilterHeight,d=e.effectiveFilterWidth,f=e.padInfo.top,p=e.padInfo.left;this.outputShape=e.outShape;const g=n==="avg",x=`((batch * ${e.inHeight} + xR) * ${e.inWidth} + xC) * ${e.inChannels} + d`,m=`(xR * ${e.inWidth} + xC) * ${e.inChannels} + d`;let y="0.0";if(g||(y="-1.0 / 1e-20"),s){const S=">=";this.userCode=` const ivec2 strides = ivec2(${a}, ${l}); const ivec2 pads = ivec2(${f}, ${p}); @@ -13861,7 +13861,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam int minMaxPosition = 0; float avgValue = 0.0; - for (int wR = 0; wR < ${d}; + for (int wR = 0; wR < ${h}; wR += ${c}) { int xR = xRCorner + wR; @@ -13869,7 +13869,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam continue; } - for (int wC = 0; wC < ${h}; + for (int wC = 0; wC < ${d}; wC += ${u}) { int xC = xCCorner + wC; @@ -13886,7 +13886,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam if (value ${S} currMinMaxValue) { minMaxValue = value; minMaxValueFound = 1.0; - minMaxPosition = ${r?o?x:m:`wR * ${h} + wC`}; + minMaxPosition = ${r?o?x:m:`wR * ${d} + wC`}; } } } @@ -13929,7 +13929,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam float avgValue = 0.0; count = 0.0; - for (int wR = 0; wR < ${d}; + for (int wR = 0; wR < ${h}; wR += ${c}) { int xR = xRCorner + wR; @@ -13982,7 +13982,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } setOutput(${v}); } - `}}class Nv{constructor(e,n,s,r=!1,o=!1){if(this.variableNames=["x"],n==="avg"&&s)throw new Error("Cannot compute positions for average pool.");const i=e.filterWidth,a=e.strideDepth,l=e.strideHeight,c=e.strideWidth,u=e.dilationDepth,d=e.dilationHeight,h=e.dilationWidth,f=e.effectiveFilterDepth,p=e.effectiveFilterHeight,g=e.effectiveFilterWidth,x=e.padInfo.front,m=e.padInfo.top,y=e.padInfo.left;this.outputShape=e.outShape;const w=n==="avg";let v="0.0";if(w||(v="-1.0 / 1e-20"),s){const N=">=";this.userCode=` + `}}class Nv{constructor(e,n,s,r=!1,o=!1){if(this.variableNames=["x"],n==="avg"&&s)throw new Error("Cannot compute positions for average pool.");const i=e.filterWidth,a=e.strideDepth,l=e.strideHeight,c=e.strideWidth,u=e.dilationDepth,h=e.dilationHeight,d=e.dilationWidth,f=e.effectiveFilterDepth,p=e.effectiveFilterHeight,g=e.effectiveFilterWidth,x=e.padInfo.front,m=e.padInfo.top,y=e.padInfo.left;this.outputShape=e.outShape;const w=n==="avg";let v="0.0";if(w||(v="-1.0 / 1e-20"),s){const N=">=";this.userCode=` const ivec3 strides = ivec3(${a}, ${l}, ${c}); const ivec3 pads = ivec3(${x}, ${m}, ${y}); @@ -14012,7 +14012,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } for (int wR = 0; wR < ${p}; - wR += ${d}) { + wR += ${h}) { int xR = xRCorner + wR; if (xR < 0 || xR >= ${e.inHeight}) { @@ -14020,7 +14020,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } for (int wC = 0; wC < ${g}; - wC += ${h}) { + wC += ${d}) { int xC = xCCorner + wC; if (xC < 0 || xC >= ${e.inWidth}) { @@ -14092,7 +14092,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } for (int wR = 0; wR < ${p}; - wR += ${d}) { + wR += ${h}) { int xR = xRCorner + wR; if (xR < 0 || xR >= ${e.inHeight}) { @@ -14100,13 +14100,13 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } for (int wC = 0; wC < ${k}; wC += 4) { - int xC = xCCorner + wC * ${h}; + int xC = xCCorner + wC * ${d}; vec4 values = vec4( getValue(batch, xD, xR, xC, ch), - getValue(batch, xD, xR, xC + ${h}, ch), - getValue(batch, xD, xR, xC + 2 * ${h}, ch), - getValue(batch, xD, xR, xC + 3 * ${h}, ch) + getValue(batch, xD, xR, xC + ${d}, ch), + getValue(batch, xD, xR, xC + 2 * ${d}, ch), + getValue(batch, xD, xR, xC + 3 * ${d}, ch) ); ${$} @@ -14125,7 +14125,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } else if (${S===2}) { vec4 values = vec4( getValue(batch, xD, xR, xC, ch), - getValue(batch, xD, xR, xC + ${h}, ch), + getValue(batch, xD, xR, xC + ${d}, ch), initializationValue, initializationValue ); @@ -14134,8 +14134,8 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } else if (${S===3}) { vec4 values = vec4( getValue(batch, xD, xR, xC, ch), - getValue(batch, xD, xR, xC + ${h}, ch), - getValue(batch, xD, xR, xC + 2 * ${h}, ch), + getValue(batch, xD, xR, xC + ${d}, ch), + getValue(batch, xD, xR, xC + 2 * ${d}, ch), initializationValue ); @@ -14160,7 +14160,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function pJ(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e;Ed(r,"avgPool");const{filterSize:o,strides:i,pad:a,dimRoundingMode:l}=s,c=1;I(hn(i,c),()=>`Error in avgPool: Either strides or dilations must be 1. Got strides ${i} and dilations '${c}'`);const u=Rs(r.shape,o,i,c,a,l);if(u.filterWidth===1&&u.filterHeight===1&&Ue(u.inShape,u.outShape))return Yn({inputs:{x:r},backend:n});const d=new nu(u,"avg",!1);return n.runWebGLProgram(d,[r],"float32")}const mJ={kernelName:xp,backendName:"webgl",kernelFunc:pJ};/** + */function mJ(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e;Eh(r,"avgPool");const{filterSize:o,strides:i,pad:a,dimRoundingMode:l}=s,c=1;I(dn(i,c),()=>`Error in avgPool: Either strides or dilations must be 1. Got strides ${i} and dilations '${c}'`);const u=As(r.shape,o,i,c,a,l);if(u.filterWidth===1&&u.filterHeight===1&&Ue(u.inShape,u.outShape))return Yn({inputs:{x:r},backend:n});const h=new nu(u,"avg",!1);return n.runWebGLProgram(h,[r],"float32")}const gJ={kernelName:xp,backendName:"webgl",kernelFunc:mJ};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -14175,7 +14175,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function gJ(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{filterSize:o,strides:i,pad:a,dimRoundingMode:l,dataFormat:c}=s,u=[1,1,1],d=qr(r.shape,o,i,u,a,l,c),h=new Nv(d,"avg",!1);return n.runWebGLProgram(h,[r],"float32")}const xJ={kernelName:yp,backendName:"webgl",kernelFunc:gJ};/** + */function xJ(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{filterSize:o,strides:i,pad:a,dimRoundingMode:l,dataFormat:c}=s,u=[1,1,1],h=Yr(r.shape,o,i,u,a,l,c),d=new Nv(h,"avg",!1);return n.runWebGLProgram(d,[r],"float32")}const yJ={kernelName:yp,backendName:"webgl",kernelFunc:xJ};/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -14190,9 +14190,9 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class yJ{constructor(e){this.variableNames=["dy"],this.outputShape=e.inShape;const n=e.filterHeight,s=e.filterWidth,r=e.strideHeight,o=e.strideWidth,i=e.dilationHeight,a=e.dilationWidth,l=e.effectiveFilterHeight,c=e.effectiveFilterWidth,u=l-1-e.padInfo.top,d=c-1-e.padInfo.left,h=1/(n*s);this.userCode=` - const ivec2 pads = ivec2(${u}, ${d}); - const float avgMultiplier = float(${h}); + */class wJ{constructor(e){this.variableNames=["dy"],this.outputShape=e.inShape;const n=e.filterHeight,s=e.filterWidth,r=e.strideHeight,o=e.strideWidth,i=e.dilationHeight,a=e.dilationWidth,l=e.effectiveFilterHeight,c=e.effectiveFilterWidth,u=l-1-e.padInfo.top,h=c-1-e.padInfo.left,d=1/(n*s);this.userCode=` + const ivec2 pads = ivec2(${u}, ${h}); + const float avgMultiplier = float(${d}); void main() { ivec4 coords = getOutputCoords(); @@ -14232,7 +14232,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } setOutput(dotProd); } - `}}class wJ{constructor(e){this.variableNames=["dy"],this.outputShape=e.inShape;const n=e.filterDepth,s=e.filterHeight,r=e.filterWidth,o=e.strideDepth,i=e.strideHeight,a=e.strideWidth,l=e.dilationDepth,c=e.dilationHeight,u=e.dilationWidth,d=e.effectiveFilterDepth,h=e.effectiveFilterHeight,f=e.effectiveFilterWidth,p=d-1-e.padInfo.front,g=h-1-e.padInfo.top,x=f-1-e.padInfo.left,m=1/(n*s*r);this.userCode=` + `}}class vJ{constructor(e){this.variableNames=["dy"],this.outputShape=e.inShape;const n=e.filterDepth,s=e.filterHeight,r=e.filterWidth,o=e.strideDepth,i=e.strideHeight,a=e.strideWidth,l=e.dilationDepth,c=e.dilationHeight,u=e.dilationWidth,h=e.effectiveFilterDepth,d=e.effectiveFilterHeight,f=e.effectiveFilterWidth,p=h-1-e.padInfo.front,g=d-1-e.padInfo.top,x=f-1-e.padInfo.left,m=1/(n*s*r);this.userCode=` const ivec3 pads = ivec3(${p}, ${g}, ${x}); const float avgMultiplier = float(${m}); @@ -14251,7 +14251,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam // ? = to be determined. : = across all values in that axis. float dotProd = 0.0; - for (int wD = 0; wD < ${d}; + for (int wD = 0; wD < ${h}; wD += ${l}) { float dyD = float(dyDCorner + wD) / ${o}.0; @@ -14260,7 +14260,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } int idyD = int(dyD); - for (int wR = 0; wR < ${h}; + for (int wR = 0; wR < ${d}; wR += ${c}) { float dyR = float(dyRCorner + wR) / ${i}.0; @@ -14303,7 +14303,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function vJ(t){const{inputs:e,backend:n,attrs:s}=t,{dy:r,input:o}=e,i=o,{filterSize:a,strides:l,pad:c,dimRoundingMode:u}=s,d=[1,1,1],h=qr(i.shape,a,l,d,c,u),f=new wJ(h);return n.runWebGLProgram(f,[r],i.dtype)}const bJ={kernelName:Xx,backendName:"webgl",kernelFunc:vJ};/** + */function bJ(t){const{inputs:e,backend:n,attrs:s}=t,{dy:r,input:o}=e,i=o,{filterSize:a,strides:l,pad:c,dimRoundingMode:u}=s,h=[1,1,1],d=Yr(i.shape,a,l,h,c,u),f=new vJ(d);return n.runWebGLProgram(f,[r],i.dtype)}const CJ={kernelName:Xx,backendName:"webgl",kernelFunc:bJ};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -14318,7 +14318,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function CJ(t){const{inputs:e,backend:n,attrs:s}=t,{dy:r,input:o}=e,i=o;Ed([r,o],"avgPoolGrad");const{filterSize:a,strides:l,pad:c}=s,u=Rs(i.shape,a,l,1,c),d=new yJ(u);return n.runWebGLProgram(d,[r],i.dtype)}const kJ={kernelName:Kx,backendName:"webgl",kernelFunc:CJ};/** + */function kJ(t){const{inputs:e,backend:n,attrs:s}=t,{dy:r,input:o}=e,i=o;Eh([r,o],"avgPoolGrad");const{filterSize:a,strides:l,pad:c}=s,u=As(i.shape,a,l,1,c),h=new wJ(u);return n.runWebGLProgram(h,[r],i.dtype)}const SJ={kernelName:Kx,backendName:"webgl",kernelFunc:kJ};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -14333,7 +14333,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function SJ(t){const{inputs:e,backend:n,attrs:s}=t,{a:r,b:o}=e,{transposeA:i,transposeB:a}=s;return Bf({a:r,b:o,transposeA:i,transposeB:a,backend:n})}const IJ={kernelName:wp,backendName:"webgl",kernelFunc:SJ};/** + */function IJ(t){const{inputs:e,backend:n,attrs:s}=t,{a:r,b:o}=e,{transposeA:i,transposeB:a}=s;return Bf({a:r,b:o,transposeA:i,transposeB:a,backend:n})}const $J={kernelName:wp,backendName:"webgl",kernelFunc:IJ};/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -14348,7 +14348,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class $J{constructor(e,n,s,r,o,i){this.outputShape=[],this.variableNames=["x","mean","variance"],Se(e,n),Se(e,s);let a="0.0";r!=null&&(Se(e,r),this.variableNames.push("offset"),a="getOffsetAtOutCoords()");let l="1.0";o!=null&&(Se(e,o),this.variableNames.push("scale"),l="getScaleAtOutCoords()"),this.outputShape=e,this.userCode=` + */class NJ{constructor(e,n,s,r,o,i){this.outputShape=[],this.variableNames=["x","mean","variance"],Se(e,n),Se(e,s);let a="0.0";r!=null&&(Se(e,r),this.variableNames.push("offset"),a="getOffsetAtOutCoords()");let l="1.0";o!=null&&(Se(e,o),this.variableNames.push("scale"),l="getScaleAtOutCoords()"),this.outputShape=e,this.userCode=` void main() { float x = getXAtOutCoords(); float mean = getMeanAtOutCoords(); @@ -14373,7 +14373,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class NJ{constructor(e,n,s,r,o,i){this.packedInputs=!0,this.packedOutput=!0,this.variableNames=["x","mean","variance"],Se(e,n),Se(e,s);let a="vec4(0.0)";r!=null&&(Se(e,r),this.variableNames.push("offset"),a="getOffsetAtOutCoords()");let l="vec4(1.0)";o!=null&&(Se(e,o),this.variableNames.push("scale"),l="getScaleAtOutCoords()"),this.outputShape=e,this.userCode=` + */class TJ{constructor(e,n,s,r,o,i){this.packedInputs=!0,this.packedOutput=!0,this.variableNames=["x","mean","variance"],Se(e,n),Se(e,s);let a="vec4(0.0)";r!=null&&(Se(e,r),this.variableNames.push("offset"),a="getOffsetAtOutCoords()");let l="vec4(1.0)";o!=null&&(Se(e,o),this.variableNames.push("scale"),l="getScaleAtOutCoords()"),this.outputShape=e,this.userCode=` void main() { vec4 offset = ${a}; vec4 scale = ${l}; @@ -14401,7 +14401,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const TJ=({inputs:t,backend:e,attrs:n})=>{const{x:s,mean:r,variance:o,offset:i,scale:a}=t;I(r.shape.length===o.shape.length,()=>"Batch normalization gradient requires mean and variance to have equal ranks."),I(i==null||r.shape.length===i.shape.length,()=>"Batch normalization gradient requires mean and offset to have equal ranks."),I(a==null||r.shape.length===a.shape.length,()=>"Batch normalization gradient requires mean and scale to have equal ranks.");let{varianceEpsilon:l}=n;l==null&&(l=.001);const c=[s,r,o];let u=null;i!=null&&(u=i.shape,c.push(i));let d=null;a!=null&&(d=a.shape,c.push(a));const h=W().getBool("WEBGL_PACK_NORMALIZATION")?new NJ(s.shape,r.shape,o.shape,u,d,l):new $J(s.shape,r.shape,o.shape,u,d,l);return e.runWebGLProgram(h,c,c[0].dtype)},EJ={kernelName:Ap,backendName:"webgl",kernelFunc:TJ};/** + */const EJ=({inputs:t,backend:e,attrs:n})=>{const{x:s,mean:r,variance:o,offset:i,scale:a}=t;I(r.shape.length===o.shape.length,()=>"Batch normalization gradient requires mean and variance to have equal ranks."),I(i==null||r.shape.length===i.shape.length,()=>"Batch normalization gradient requires mean and offset to have equal ranks."),I(a==null||r.shape.length===a.shape.length,()=>"Batch normalization gradient requires mean and scale to have equal ranks.");let{varianceEpsilon:l}=n;l==null&&(l=.001);const c=[s,r,o];let u=null;i!=null&&(u=i.shape,c.push(i));let h=null;a!=null&&(h=a.shape,c.push(a));const d=W().getBool("WEBGL_PACK_NORMALIZATION")?new TJ(s.shape,r.shape,o.shape,u,h,l):new NJ(s.shape,r.shape,o.shape,u,h,l);return e.runWebGLProgram(d,c,c[0].dtype)},RJ={kernelName:Ap,backendName:"webgl",kernelFunc:EJ};/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -14416,7 +14416,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class RJ{constructor(e){this.variableNames=["source"],this.outputShape=e,this.rank=e.length;const n=Ze(this.rank);this.customUniforms=[{name:"start",arrayIndex:this.rank,type:"int"}];const s=AJ(this.rank);let r;const o=e.map((i,a)=>`sourceLoc.${T1[a]} = start[${a}] + coords.${T1[a]};`);r=` + */class AJ{constructor(e){this.variableNames=["source"],this.outputShape=e,this.rank=e.length;const n=Ze(this.rank);this.customUniforms=[{name:"start",arrayIndex:this.rank,type:"int"}];const s=DJ(this.rank);let r;const o=e.map((i,a)=>`sourceLoc.${T1[a]} = start[${a}] + coords.${T1[a]};`);r=` ${n} sourceLoc; ${n} coords = getOutputCoords(); ${o.join(` @@ -14426,7 +14426,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam ${r} setOutput(getSource(${s})); } - `}}const T1=["x","y","z","w","u","v"];function AJ(t){if(t===1)return"sourceLoc";if(t<=6)return T1.slice(0,t).map(e=>"sourceLoc."+e).join(",");throw Error(`Slicing for rank ${t} is not yet supported`)}/** + `}}const T1=["x","y","z","w","u","v"];function DJ(t){if(t===1)return"sourceLoc";if(t<=6)return T1.slice(0,t).map(e=>"sourceLoc."+e).join(",");throw Error(`Slicing for rank ${t} is not yet supported`)}/** * @license * Copyright 2019 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -14441,7 +14441,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class DJ{constructor(e){this.variableNames=["source"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=e,this.rank=e.length,this.customUniforms=[{name:"start",arrayIndex:this.rank,type:"int"}];const n=Ze(this.rank),s=vn("coords",this.rank),r=vn("sourceLoc",this.rank),o=this.rank===1?"sourceLoc":`vec2(${r.slice(-2).join()})`,i=`getChannel(getSource(${r.join()}), ${o})`,a=` + */class _J{constructor(e){this.variableNames=["source"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=e,this.rank=e.length,this.customUniforms=[{name:"start",arrayIndex:this.rank,type:"int"}];const n=Ze(this.rank),s=vn("coords",this.rank),r=vn("sourceLoc",this.rank),o=this.rank===1?"sourceLoc":`vec2(${r.slice(-2).join()})`,i=`getChannel(getSource(${r.join()}), ${o})`,a=` result.x = ${i}; if (++${s[this.rank-1]} < ${e[this.rank-1]}) { ++${r[this.rank-1]}; @@ -14459,7 +14459,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } } `,c=this.rank<=4?`sourceLoc = coords + - ${n}(${e.map((u,d)=>`start[${d}]`).join()});`:e.map((u,d)=>`${r[d]} = ${s[d]} + start[${d}];`).join(` + ${n}(${e.map((u,h)=>`start[${h}]`).join()});`:e.map((u,h)=>`${r[h]} = ${s[h]} + start[${h}];`).join(` `);this.userCode=` void main() { ${n} coords = getOutputCoords(); @@ -14485,7 +14485,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function _J(t,e,n,s){const r=s.texData.get(t.dataId),o=s.makeTensorInfo(n,t.dtype),i=s.texData.get(o.dataId);Object.assign(i,r),i.refCount=1,i.shape=n,i.dtype=t.dtype;let a=Cw(e,pe(t.shape));r.slice&&(a+=r.slice.flatOffset),i.slice={flatOffset:a,origDataId:r.slice&&r.slice.origDataId||t.dataId};const l=s.dataRefCount.get(i.slice.origDataId)||1;return s.dataRefCount.set(i.slice.origDataId,l+1),o}function Fl(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{begin:o,size:i}=s,[a,l]=bm(r,o,i);if(ww(r,a,l),j(l)===0)return n.makeTensorInfo(l,r.dtype,[]);if(n.shouldExecuteOnCPU([r])||r.dtype==="string"){const d=n.texData.get(r.dataId),h=IQ(d.values,a,l,r.shape,r.dtype);return n.makeTensorInfo(l,r.dtype,h)}const{isPacked:c}=n.texData.get(r.dataId),u=bw(r.shape,a,l);if(c||!u){const d=W().getBool("WEBGL_PACK_ARRAY_OPERATIONS")?new DJ(l):new RJ(l),h=[a];return n.runWebGLProgram(d,[r],r.dtype,h)}return n.uploadToGPU(r.dataId),_J(r,a,l,n)}const FJ={kernelName:im,backendName:"webgl",kernelFunc:Fl};/** + */function FJ(t,e,n,s){const r=s.texData.get(t.dataId),o=s.makeTensorInfo(n,t.dtype),i=s.texData.get(o.dataId);Object.assign(i,r),i.refCount=1,i.shape=n,i.dtype=t.dtype;let a=Cw(e,pe(t.shape));r.slice&&(a+=r.slice.flatOffset),i.slice={flatOffset:a,origDataId:r.slice&&r.slice.origDataId||t.dataId};const l=s.dataRefCount.get(i.slice.origDataId)||1;return s.dataRefCount.set(i.slice.origDataId,l+1),o}function Fl(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{begin:o,size:i}=s,[a,l]=bm(r,o,i);if(ww(r,a,l),j(l)===0)return n.makeTensorInfo(l,r.dtype,[]);if(n.shouldExecuteOnCPU([r])||r.dtype==="string"){const h=n.texData.get(r.dataId),d=$Q(h.values,a,l,r.shape,r.dtype);return n.makeTensorInfo(l,r.dtype,d)}const{isPacked:c}=n.texData.get(r.dataId),u=bw(r.shape,a,l);if(c||!u){const h=W().getBool("WEBGL_PACK_ARRAY_OPERATIONS")?new _J(l):new AJ(l),d=[a];return n.runWebGLProgram(h,[r],r.dtype,d)}return n.uploadToGPU(r.dataId),FJ(r,a,l,n)}const zJ={kernelName:im,backendName:"webgl",kernelFunc:Fl};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -14500,7 +14500,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const zJ=t=>{const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{blockShape:o,crops:i}=s;I(r.shape.length<=4,()=>"batchToSpaceND for rank > 4 with a WebGL backend not implemented yet");const a=o.reduce((y,w)=>y*w),l=gd(r.shape,o,a),c=xd(l.length,o.length),u=yd(r.shape,o,a),d=Nw(i,o.length),h=Tw(u,i,o.length),f=[],p=re({inputs:{x:r},backend:n,attrs:{shape:l}}),g=Sn({inputs:{x:p},backend:n,attrs:{perm:c}}),x=re({inputs:{x:g},backend:n,attrs:{shape:u}}),m=Fl({inputs:{x},backend:n,attrs:{begin:d,size:h}});return f.push(p),f.push(g),f.push(x),f.forEach(y=>n.disposeIntermediateTensorInfo(y)),m},OJ={kernelName:vp,backendName:"webgl",kernelFunc:zJ};/** + */const OJ=t=>{const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{blockShape:o,crops:i}=s;I(r.shape.length<=4,()=>"batchToSpaceND for rank > 4 with a WebGL backend not implemented yet");const a=o.reduce((y,w)=>y*w),l=gh(r.shape,o,a),c=xh(l.length,o.length),u=yh(r.shape,o,a),h=Nw(i,o.length),d=Tw(u,i,o.length),f=[],p=re({inputs:{x:r},backend:n,attrs:{shape:l}}),g=Sn({inputs:{x:p},backend:n,attrs:{perm:c}}),x=re({inputs:{x:g},backend:n,attrs:{shape:u}}),m=Fl({inputs:{x},backend:n,attrs:{begin:h,size:d}});return f.push(p),f.push(g),f.push(x),f.forEach(y=>n.disposeIntermediateTensorInfo(y)),m},MJ={kernelName:vp,backendName:"webgl",kernelFunc:OJ};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -14515,7 +14515,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function MJ(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,weights:o}=e,{size:i}=s,a=n.readSync(r.dataId),l=n.readSync(o.dataId),c=QA(a,l,o.dtype,o.shape,i);return n.makeTensorInfo([i],o.dtype,c)}const PJ={kernelName:qx,backendName:"webgl",kernelFunc:MJ};/** + */function PJ(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,weights:o}=e,{size:i}=s,a=n.readSync(r.dataId),l=n.readSync(o.dataId),c=ZA(a,l,o.dtype,o.shape,i);return n.makeTensorInfo([i],o.dtype,c)}const LJ={kernelName:qx,backendName:"webgl",kernelFunc:PJ};/** * @license * Copyright 2023 Google LLC. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -14530,15 +14530,15 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const LJ=` + */const BJ=` int r = int(a.r) & int(b.r); int g = int(a.g) & int(b.g); int rb = int(a.b) & int(b.b); int ra = int(a.a) & int(b.a); return vec4(r, g, rb, ra); -`,BJ=` +`,VJ=` return float(int(a.r) & int(b.r)); -`;function VJ(t){const{inputs:e,backend:n}=t,{a:s,b:r}=e,o=W().getBool("WEBGL_PACK_BINARY_OPERATIONS"),i=W().getNumber("WEBGL_VERSION");if(n.shouldExecuteOnCPU([s,r])||i===1){const l=n.texData.get(s.dataId).values,c=n.texData.get(r.dataId).values,[u,d]=qY(s.shape,r.shape,l,c,s.dtype),h=n.makeTensorInfo(d,s.dtype),f=n.texData.get(h.dataId);return f.values=u,h}let a;return o?a=new Dl(LJ,s.shape,r.shape,!1):a=new Wi(BJ,s.shape,r.shape),n.runWebGLProgram(a,[s,r],s.dtype)}const WJ={kernelName:Yx,backendName:"webgl",kernelFunc:VJ};/** +`;function WJ(t){const{inputs:e,backend:n}=t,{a:s,b:r}=e,o=W().getBool("WEBGL_PACK_BINARY_OPERATIONS"),i=W().getNumber("WEBGL_VERSION");if(n.shouldExecuteOnCPU([s,r])||i===1){const l=n.texData.get(s.dataId).values,c=n.texData.get(r.dataId).values,[u,h]=YY(s.shape,r.shape,l,c,s.dtype),d=n.makeTensorInfo(h,s.dtype),f=n.texData.get(d.dataId);return f.values=u,d}let a;return o?a=new Dl(BJ,s.shape,r.shape,!1):a=new Wi(VJ,s.shape,r.shape),n.runWebGLProgram(a,[s,r],s.dtype)}const UJ={kernelName:Yx,backendName:"webgl",kernelFunc:WJ};/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -14553,7 +14553,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function UJ(t){const{inputs:e,backend:n}=t,{s0:s,s1:r}=e,o=n.readSync(s.dataId),i=n.readSync(r.dataId),a=Se(Array.from(o),Array.from(i));return n.makeTensorInfo([a.length],"int32",Int32Array.from(a))}const GJ={kernelName:Z2,backendName:"webgl",kernelFunc:UJ};/** + */function GJ(t){const{inputs:e,backend:n}=t,{s0:s,s1:r}=e,o=n.readSync(s.dataId),i=n.readSync(r.dataId),a=Se(Array.from(o),Array.from(i));return n.makeTensorInfo([a.length],"int32",Int32Array.from(a))}const HJ={kernelName:JI,backendName:"webgl",kernelFunc:GJ};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -14568,7 +14568,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const HJ="return float(a != b);",dD=rn({opSnippet:HJ,cpuKernelImpl:gQ,dtype:"bool"}),jJ={kernelName:Xp,backendName:"webgl",kernelFunc:dD};/** + */const jJ="return float(a != b);",dD=rn({opSnippet:jJ,cpuKernelImpl:xQ,dtype:"bool"}),KJ={kernelName:Xp,backendName:"webgl",kernelFunc:dD};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -14583,7 +14583,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Ad(t){const{inputs:e,backend:n}=t,{input:s}=e,r=n.texData.get(s.dataId);return Yn({inputs:{x:r.complexTensorInfos.real},backend:n})}const KJ={kernelName:by,backendName:"webgl",kernelFunc:Ad};/** + */function Ah(t){const{inputs:e,backend:n}=t,{input:s}=e,r=n.texData.get(s.dataId);return Yn({inputs:{x:r.complexTensorInfos.real},backend:n})}const XJ={kernelName:by,backendName:"webgl",kernelFunc:Ah};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -14598,7 +14598,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const XJ="return float(int(x));";function qJ(t,e){const n=new fr(t.shape,XJ),s=e.runWebGLProgram(n,[t],"int32");return{dataId:s.dataId,shape:s.shape,dtype:s.dtype}}/** + */const qJ="return float(int(x));";function YJ(t,e){const n=new pr(t.shape,qJ),s=e.runWebGLProgram(n,[t],"int32");return{dataId:s.dataId,shape:s.shape,dtype:s.dtype}}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -14613,7 +14613,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function E1(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{dtype:o}=s;if(o==="complex64"){if(r.dtype==="complex64")return Yn({inputs:{x:r},backend:n});const i=Kt(r.shape),a=E1({inputs:{x:r},backend:n,attrs:{dtype:"float32"}}),l=Qo({inputs:{real:a,imag:i},backend:n});return i.dispose(),n.disposeIntermediateTensorInfo(a),l}if(r.dtype==="complex64"){const i=Ad({inputs:{input:r},backend:n}),a=E1({inputs:{x:i},backend:n,attrs:{dtype:o}});return n.disposeIntermediateTensorInfo(i),a}if(!K2(r.dtype,o)){const i=Yn({inputs:{x:r},backend:n});return{dataId:i.dataId,shape:i.shape,dtype:o}}if(n.shouldExecuteOnCPU([r])){const i=n.texData.get(r.dataId).values,[a,l,c]=YY(i,r.shape,r.dtype,o);return n.makeTensorInfo(a,l,c)}if(o==="int32")return qJ(r,n);if(o==="bool"){const i=n.makeTensorInfo([],"bool",cn("bool",1)),l=dD({inputs:{a:r,b:i},backend:n});return n.disposeIntermediateTensorInfo(i),l}throw new Error(`Error in Cast: failed to cast ${r.dtype} to ${o}`)}const YJ={kernelName:bu,backendName:"webgl",kernelFunc:E1};/** + */function E1(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{dtype:o}=s;if(o==="complex64"){if(r.dtype==="complex64")return Yn({inputs:{x:r},backend:n});const i=Kt(r.shape),a=E1({inputs:{x:r},backend:n,attrs:{dtype:"float32"}}),l=Qo({inputs:{real:a,imag:i},backend:n});return i.dispose(),n.disposeIntermediateTensorInfo(a),l}if(r.dtype==="complex64"){const i=Ah({inputs:{input:r},backend:n}),a=E1({inputs:{x:i},backend:n,attrs:{dtype:o}});return n.disposeIntermediateTensorInfo(i),a}if(!XI(r.dtype,o)){const i=Yn({inputs:{x:r},backend:n});return{dataId:i.dataId,shape:i.shape,dtype:o}}if(n.shouldExecuteOnCPU([r])){const i=n.texData.get(r.dataId).values,[a,l,c]=QY(i,r.shape,r.dtype,o);return n.makeTensorInfo(a,l,c)}if(o==="int32")return YJ(r,n);if(o==="bool"){const i=n.makeTensorInfo([],"bool",cn("bool",1)),l=dD({inputs:{a:r,b:i},backend:n});return n.disposeIntermediateTensorInfo(i),l}throw new Error(`Error in Cast: failed to cast ${r.dtype} to ${o}`)}const QJ={kernelName:bu,backendName:"webgl",kernelFunc:E1};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -14628,7 +14628,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Mk="return ceil(x);",QJ=Oe({opSnippet:Mk,packedOpSnippet:Mk,cpuKernelImpl:QY}),ZJ={kernelName:Cu,backendName:"webgl",kernelFunc:QJ};/** + */const Mk="return ceil(x);",ZJ=Oe({opSnippet:Mk,packedOpSnippet:Mk,cpuKernelImpl:ZY}),JJ={kernelName:Cu,backendName:"webgl",kernelFunc:ZJ};/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -14643,7 +14643,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class JJ{constructor(e){this.variableNames=["A"],this.customUniforms=[{name:"minVal",type:"float"},{name:"maxVal",type:"float"}],this.outputShape=e,this.userCode=` + */class eee{constructor(e){this.variableNames=["A"],this.customUniforms=[{name:"minVal",type:"float"},{name:"maxVal",type:"float"}],this.outputShape=e,this.userCode=` void main() { float value = getAAtOutCoords(); @@ -14669,7 +14669,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class eee{constructor(e){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!0,this.customUniforms=[{name:"minVal",type:"float"},{name:"maxVal",type:"float"}],this.outputShape=e,this.userCode=` + */class tee{constructor(e){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!0,this.customUniforms=[{name:"minVal",type:"float"},{name:"maxVal",type:"float"}],this.outputShape=e,this.userCode=` void main() { vec4 value = getAAtOutCoords(); @@ -14695,7 +14695,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function tee(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{clipValueMin:o,clipValueMax:i}=s;let a;W().getBool("WEBGL_PACK_CLIP")?a=new eee(r.shape):a=new JJ(r.shape);const l=[[o],[i]];return n.runWebGLProgram(a,[r],r.dtype,l)}const nee={kernelName:ku,backendName:"webgl",kernelFunc:tee};/** + */function nee(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{clipValueMin:o,clipValueMax:i}=s;let a;W().getBool("WEBGL_PACK_CLIP")?a=new tee(r.shape):a=new eee(r.shape);const l=[[o],[i]];return n.runWebGLProgram(a,[r],r.dtype,l)}const see={kernelName:ku,backendName:"webgl",kernelFunc:nee};/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -14710,7 +14710,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class see{constructor(e){this.variableNames=["real","imag"],this.outputShape=e,this.userCode=` + */class ree{constructor(e){this.variableNames=["real","imag"],this.outputShape=e,this.userCode=` void main() { float re = abs(getRealAtOutCoords()); float im = abs(getImagAtOutCoords()); @@ -14738,7 +14738,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Pk(t,e){return{dataId:e.dataId,dtype:e.dtype,shape:t.shape}}function ree(t){const{inputs:e,backend:n}=t,{x:s}=e,r=n.texData.get(s.dataId),o=new see(s.shape),i=[Pk(s,r.complexTensorInfos.real),Pk(s,r.complexTensorInfos.imag)];return n.runWebGLProgram(o,i,i[0].dtype)}const oee={kernelName:bp,backendName:"webgl",kernelFunc:ree};/** + */function Pk(t,e){return{dataId:e.dataId,dtype:e.dtype,shape:t.shape}}function oee(t){const{inputs:e,backend:n}=t,{x:s}=e,r=n.texData.get(s.dataId),o=new ree(s.shape),i=[Pk(s,r.complexTensorInfos.real),Pk(s,r.complexTensorInfos.imag)];return n.runWebGLProgram(o,i,i[0].dtype)}const iee={kernelName:bp,backendName:"webgl",kernelFunc:oee};/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -14753,7 +14753,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class iee{constructor(e){this.outputShape=[],this.outputShape=yr(e,1),this.variableNames=e.map((i,a)=>`T${a}`);const n=new Array(e.length-1);n[0]=e[0][1];for(let i=1;i`T${a}`);const n=new Array(e.length-1);n[0]=e[0][1];for(let i=1;i`T${x}`);const l=new Array(e.length-1);l[0]=e[0][n];for(let g=1;g`T${x}`);const l=new Array(e.length-1);l[0]=e[0][n];for(let g=1;g= ${l[g-1]}) { return getChannel( - getT${g}(${dh(a,c,x)}), - vec2(${dh(u,c,x)})); - }`}const f=l.length,p=l[l.length-1];h+=` + getT${g}(${hd(a,c,x)}), + vec2(${hd(u,c,x)})); + }`}const f=l.length,p=l[l.length-1];d+=` return getChannel( - getT${f}(${dh(a,c,p)}), - vec2(${dh(u,c,p)}));`,this.userCode=` + getT${f}(${hd(a,c,p)}), + vec2(${hd(u,c,p)}));`,this.userCode=` float getValue(${a.map(g=>"int "+g)}) { - ${h} + ${d} } void main() { @@ -14814,7 +14814,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } setOutput(result); } - `}}function dh(t,e,n){const s=t.indexOf(e);return t.map((o,i)=>i===s?`${o} - ${n}`:o).join()}/** + `}}function hd(t,e,n){const s=t.indexOf(e);return t.map((o,i)=>i===s?`${o} - ${n}`:o).join()}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -14829,7 +14829,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Vm(t){const{inputs:e,backend:n}=t,{input:s}=e,r=n.texData.get(s.dataId);return Yn({inputs:{x:r.complexTensorInfos.imag},backend:n})}const lee={kernelName:fy,backendName:"webgl",kernelFunc:Vm};/** + */function Vm(t){const{inputs:e,backend:n}=t,{input:s}=e,r=n.texData.get(s.dataId);return Yn({inputs:{x:r.complexTensorInfos.imag},backend:n})}const cee={kernelName:fy,backendName:"webgl",kernelFunc:Vm};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -14844,7 +14844,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function cc(t,e,n){const s=t[0].dtype;if(s==="complex64"){const f=t.map(y=>Ad({inputs:{input:y},backend:n})),p=t.map(y=>Vm({inputs:{input:y},backend:n})),g=cc(f,e,n),x=cc(p,e,n),m=Qo({inputs:{real:g,imag:x},backend:n});return f.forEach(y=>n.disposeIntermediateTensorInfo(y)),p.forEach(y=>n.disposeIntermediateTensorInfo(y)),n.disposeIntermediateTensorInfo(g),n.disposeIntermediateTensorInfo(x),m}let r=n.shouldExecuteOnCPU(t);if(s==="string"&&(r=!0),r){const f=t.map(v=>{const C=[-1,j(v.shape.slice(e))];return re({inputs:{x:v},backend:n,attrs:{shape:C}})}),p=f.map(v=>({vals:n.readSync(v.dataId),shape:v.shape})),g=yr(f.map(v=>v.shape),1),x=f[0].shape[0]===1,m=ZY(p,g,s,x),y=yr(t.map(v=>v.shape),e),w=n.makeTensorInfo(y,s,m);return f.forEach(v=>n.disposeIntermediateTensorInfo(v)),w}const o=t.filter(f=>j(f.shape)>0),i=W().getBool("WEBGL_PACK_ARRAY_OPERATIONS")&&o[0].shape.length>1;if(o.length===1){const f=i?new fr(t[0].shape,oo):new po(t[0].shape,oo);return n.runWebGLProgram(f,t,s)}const a=W().getNumber("WEBGL_MAX_TEXTURES_IN_SHADER");if(o.length>a){const f=[];for(let g=0;gp.shape),e);return n.runWebGLProgram(f,o,s)}const{tensors2D:l,outShape:c}=cee(o,e,n),u=new iee(l.map(f=>f.shape)),d=n.runWebGLProgram(u,l,s);l.forEach(f=>n.disposeIntermediateTensorInfo(f));const h=re({inputs:{x:d},attrs:{shape:c},backend:n});return n.disposeIntermediateTensorInfo(d),h}function cee(t,e,n){const s=yr(t.map(o=>o.shape),e);return{tensors2D:t.map(o=>re({inputs:{x:o},attrs:{shape:[-1,j(o.shape.slice(e))]},backend:n})),outShape:s}}/** + */function cc(t,e,n){const s=t[0].dtype;if(s==="complex64"){const f=t.map(y=>Ah({inputs:{input:y},backend:n})),p=t.map(y=>Vm({inputs:{input:y},backend:n})),g=cc(f,e,n),x=cc(p,e,n),m=Qo({inputs:{real:g,imag:x},backend:n});return f.forEach(y=>n.disposeIntermediateTensorInfo(y)),p.forEach(y=>n.disposeIntermediateTensorInfo(y)),n.disposeIntermediateTensorInfo(g),n.disposeIntermediateTensorInfo(x),m}let r=n.shouldExecuteOnCPU(t);if(s==="string"&&(r=!0),r){const f=t.map(v=>{const C=[-1,j(v.shape.slice(e))];return re({inputs:{x:v},backend:n,attrs:{shape:C}})}),p=f.map(v=>({vals:n.readSync(v.dataId),shape:v.shape})),g=wr(f.map(v=>v.shape),1),x=f[0].shape[0]===1,m=JY(p,g,s,x),y=wr(t.map(v=>v.shape),e),w=n.makeTensorInfo(y,s,m);return f.forEach(v=>n.disposeIntermediateTensorInfo(v)),w}const o=t.filter(f=>j(f.shape)>0),i=W().getBool("WEBGL_PACK_ARRAY_OPERATIONS")&&o[0].shape.length>1;if(o.length===1){const f=i?new pr(t[0].shape,io):new po(t[0].shape,io);return n.runWebGLProgram(f,t,s)}const a=W().getNumber("WEBGL_MAX_TEXTURES_IN_SHADER");if(o.length>a){const f=[];for(let g=0;gp.shape),e);return n.runWebGLProgram(f,o,s)}const{tensors2D:l,outShape:c}=uee(o,e,n),u=new aee(l.map(f=>f.shape)),h=n.runWebGLProgram(u,l,s);l.forEach(f=>n.disposeIntermediateTensorInfo(f));const d=re({inputs:{x:h},attrs:{shape:c},backend:n});return n.disposeIntermediateTensorInfo(h),d}function uee(t,e,n){const s=wr(t.map(o=>o.shape),e);return{tensors2D:t.map(o=>re({inputs:{x:o},attrs:{shape:[-1,j(o.shape.slice(e))]},backend:n})),outShape:s}}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -14859,7 +14859,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function hD(t){const{inputs:e,backend:n,attrs:s}=t,{axis:r}=s,o=Re(r,e[0].shape)[0],i=e.map(c=>c.shape);Sw(i,o);const a=yr(e.map(c=>c.shape),o);if(j(a)===0)return n.makeTensorInfo(a,e[0].dtype,[]);const l=e.filter(c=>j(c.shape)>0);return l.length===1?Yn({inputs:{x:l[0]},backend:n}):cc(l,o,n)}const uee={kernelName:Cp,backendName:"webgl",kernelFunc:hD};/** + */function fD(t){const{inputs:e,backend:n,attrs:s}=t,{axis:r}=s,o=Re(r,e[0].shape)[0],i=e.map(c=>c.shape);Sw(i,o);const a=wr(e.map(c=>c.shape),o);if(j(a)===0)return n.makeTensorInfo(a,e[0].dtype,[]);const l=e.filter(c=>j(c.shape)>0);return l.length===1?Yn({inputs:{x:l[0]},backend:n}):cc(l,o,n)}const hee={kernelName:Cp,backendName:"webgl",kernelFunc:fD};/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -14874,7 +14874,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class fD{constructor(e,n=!1,s=null,r=!1,o=!1){this.variableNames=["x","W"],this.outputShape=e.outShape;const i=e.padInfo.top,a=e.padInfo.left,l=e.strideHeight,c=e.strideWidth,u=e.dilationHeight,d=e.dilationWidth,h=e.filterHeight,f=e.filterWidth,p=Math.floor(e.inChannels/4)*4,g=e.inChannels%4,x=e.dataFormat==="channelsLast",m=x?1:2,y=x?2:3,w=x?3:1;let v="",b="";s&&(r?v=`float activation(float a) { + */class pD{constructor(e,n=!1,s=null,r=!1,o=!1){this.variableNames=["x","W"],this.outputShape=e.outShape;const i=e.padInfo.top,a=e.padInfo.left,l=e.strideHeight,c=e.strideWidth,u=e.dilationHeight,h=e.dilationWidth,d=e.filterHeight,f=e.filterWidth,p=Math.floor(e.inChannels/4)*4,g=e.inChannels%4,x=e.dataFormat==="channelsLast",m=x?1:2,y=x?2:3,w=x?3:1;let v="",b="";s&&(r?v=`float activation(float a) { float b = getPreluActivationWeightsAtOutCoords(); ${s} }`:o?v=`float activation(float a) { @@ -14903,7 +14903,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam // Convolve x(?, ?, d1) with w(:, :, d1, d2) to get y(yR, yC, d2). // ? = to be determined. : = across all values in that axis. float dotProd = 0.0; - for (int wR = 0; wR < ${h}; wR++) { + for (int wR = 0; wR < ${d}; wR++) { int xR = xRCorner + wR * ${u}; if (xR < 0 || xR >= ${e.inHeight}) { @@ -14911,7 +14911,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } for (int wC = 0; wC < ${f}; wC++) { - int xC = xCCorner + wC * ${d}; + int xC = xCCorner + wC * ${h}; if (xC < 0 || xC >= ${e.inWidth}) { continue; @@ -15008,7 +15008,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam ${b} setOutput(result); } - `}}class dee{constructor(e){this.variableNames=["x","W"],this.outputShape=e.outShape;const n=e.padInfo.front,s=e.padInfo.top,r=e.padInfo.left,o=e.strideDepth,i=e.strideHeight,a=e.strideWidth,l=e.dilationDepth,c=e.dilationHeight,u=e.dilationWidth,d=e.filterDepth,h=e.filterHeight,f=e.filterWidth,p=Math.floor(e.inChannels/4)*4,g=e.inChannels%4;this.userCode=` + `}}class dee{constructor(e){this.variableNames=["x","W"],this.outputShape=e.outShape;const n=e.padInfo.front,s=e.padInfo.top,r=e.padInfo.left,o=e.strideDepth,i=e.strideHeight,a=e.strideWidth,l=e.dilationDepth,c=e.dilationHeight,u=e.dilationWidth,h=e.filterDepth,d=e.filterHeight,f=e.filterWidth,p=Math.floor(e.inChannels/4)*4,g=e.inChannels%4;this.userCode=` const ivec3 strides = ivec3(${o}, ${i}, ${a}); const ivec3 pads = ivec3(${n}, ${s}, ${r}); @@ -15026,14 +15026,14 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam // y(yF, yR, yC, d2). ? = to be determined. : = across all // values in that axis. float dotProd = 0.0; - for (int wF = 0; wF < ${d}; wF++) { + for (int wF = 0; wF < ${h}; wF++) { int xF = xFCorner + wF * ${l}; if (xF < 0 || xF >= ${e.inDepth}) { continue; } - for (int wR = 0; wR < ${h}; wR++) { + for (int wR = 0; wR < ${d}; wR++) { int xR = xRCorner + wR * ${c}; if (xR < 0 || xR >= ${e.inHeight}) { @@ -15111,27 +15111,27 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class pD{constructor(e,n=!1,s=null,r=!1,o=!1){this.variableNames=["x","W"],this.packedInputs=!0,this.packedOutput=!0,this.customUniforms=[{name:"pads",type:"ivec2"},{name:"strides",type:"ivec2"},{name:"dilations",type:"ivec2"},{name:"inDims",type:"ivec2"}],this.outputShape=e.outShape,this.enableShapeUniforms=pn(this.outputShape.length);const i=e.padInfo.left,a=e.strideWidth,l=e.dilationWidth,c=e.filterHeight,u=e.filterWidth,d=u;let h=` + */class mD{constructor(e,n=!1,s=null,r=!1,o=!1){this.variableNames=["x","W"],this.packedInputs=!0,this.packedOutput=!0,this.customUniforms=[{name:"pads",type:"ivec2"},{name:"strides",type:"ivec2"},{name:"dilations",type:"ivec2"},{name:"inDims",type:"ivec2"}],this.outputShape=e.outShape,this.enableShapeUniforms=pn(this.outputShape.length);const i=e.padInfo.left,a=e.strideWidth,l=e.dilationWidth,c=e.filterHeight,u=e.filterWidth,h=u;let d=` int xR; int xC; int xCOffset; - vec4 wTexel; vec4 previous; vec4 final;`;for(let x=0;x=0 && xR < inDims[0]) { - `;for(let x=0;x<(d+1)/2;x++){const m=x*2;if(h+=` + `;for(let x=0;x<(h+1)/2;x++){const m=x*2;if(d+=` xC = xCCorner + ${m*l}; - `,a===1){if(m= 0 && xCOffset < inDims[1] && xTexelC${m}Ready == 0) { xTexelC${m} = getX(batch, xR, xCOffset, d1); @@ -15143,9 +15143,9 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } xTexelC${m}Ready = 1; } - `,l===1&&m>0?h+=` + `,l===1&&m>0?d+=` xC${m} = vec4(xTexelC${m-2}.zw, xTexelC${m}.xy); - `:h+=` + `:d+=` xCOffset = xC + 1 - 2; if (xCOffset >= 0 && xCOffset < inDims[1]) { @@ -15161,7 +15161,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } else { xC${m} = vec4(0.0, 0.0, xTexelC${m}.xy); } - `):h+=` + `):d+=` if (xC >= 0 && xC < inDims[1] && xTexelC${m}Ready == 0) { xTexelC${m} = getX(batch, xR, xC, d1); if (xC + 1 >= inDims[1]) { @@ -15171,7 +15171,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } xC${m} = xTexelC${m}; - `,m+1= 0 && xCOffset < inDims[1] && xTexelC${m+1}Ready == 0) { @@ -15184,7 +15184,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } xTexelC${m+1}Ready = 1; } - `,l>1?h+=` + `,l>1?d+=` xCOffset -= 2; if (xCOffset >= 0 && xCOffset < inDims[1]) { previous = getX(batch, xR, xCOffset, d1); @@ -15192,11 +15192,11 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } else { xC${m+1} = vec4(0.0, 0.0, xTexelC${m+1}.xy); } - `:h+=` + `:d+=` xC${m+1} = vec4(xTexelC${m}.zw, xTexelC${m+1}.xy); - `):y===1?h+=` + `):y===1?d+=` xC${m+1} = xTexelC${m}; - `:h+=` + `:d+=` xCOffset = xC + ${y}; if (xCOffset >= 0 && xCOffset < inDims[1] && xTexelC${m+1}Ready == 0) { @@ -15208,7 +15208,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } xC${m+1} = xTexelC${m+1}; - `}}else m= 0 && xCOffset < inDims[1] && xTexelC${m}Ready == 0) { xTexelC${m} = getX(batch, xR, xCOffset, d1); @@ -15231,14 +15231,14 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } xC${m} = vec4(xTexelC${m}.zw, xTexelC${m+1}.zw); - `,m+1= 0 && xCOffset < inDims[1]) { final = getX(batch, xR, xCOffset, d1); } xC${m+1} = vec4(xTexelC${m+1}.xy, final.xy); - `)):(h+=` + `)):(d+=` if(xC >= 0 && xC < inDims[1] && xTexelC${m}Ready == 0) { xTexelC${m} = getX(batch, xR, xC, d1); if (xC + 1 >= inDims[1]) { @@ -15258,25 +15258,25 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam xC${m} = vec4( xTexelC${m}.xy, xTexelC${m+1}.xy); - `,m+1=3?e?[...t.slice(0,-3),t[n-3]*t[n-2],t[n-1]]:[...t.slice(0,-3),t[n-3],t[n-2]*t[n-1]]:!e&&n===1&&t[0]>1?[t[0],1]:null}function mD({x:t,filter:e,convInfo:n,backend:s,bias:r=null,preluActivationWeights:o=null,leakyreluAlpha:i=0,activation:a=null}){const l=t.shape,c=s.texData.get(t.dataId),u=n.inChannels,d=l[0]*l[1]*l[2],h=n.outChannels,f=n.dataFormat==="channelsLast",p=!1,g=!1;let x;const m=[];if(o!=null){const v=Vf(o.shape,f);v!=null&&(o=re({inputs:{x:o},backend:s,attrs:{shape:v}}),m.push(o))}if(r!=null){const v=Vf(r.shape,f);v!=null&&(r=re({inputs:{x:r},backend:s,attrs:{shape:v}}),m.push(r))}if(!((d===1||h===1)&&u>aD)&&c.isPacked&&f&&c.texture!=null&&l[2]%2!==0&&Ue(c.shape.slice(-3),l.slice(-3))){const v=l[0]*l[1]*(l[2]+1),b={dataId:t.dataId,shape:[1,v,n.inChannels],dtype:t.dtype},C=c.shape;c.shape=c.shape.slice(),c.shape[c.shape.length-2]++,I(Lf(c.shape,b.shape),()=>`packed reshape ${c.shape} to ${b.shape} isn't free`);const k=re({inputs:{x:e},backend:s,attrs:{shape:[1,n.inChannels,n.outChannels]}});m.push(k);const S=Bf({a:b,b:k,backend:s,transposeA:p,transposeB:g,bias:r,activation:a,preluActivationWeights:o,leakyreluAlpha:i}),$=s.texData.get(S.dataId);I($.isPacked,()=>"batchMatMul result is expected to be packed"),c.shape=C,$.shape=n.outShape,x=Yn({inputs:{x:S},backend:s}),x.shape=n.outShape,m.push(S)}else{const v=n.outHeight*n.outWidth,b=re({inputs:{x:t},backend:s,attrs:{shape:f?[n.batchSize,v,n.inChannels]:[n.batchSize,n.inChannels,v]}}),C=re({inputs:{x:e},backend:s,attrs:{shape:[1,n.inChannels,n.outChannels]}}),k=Bf({a:f?b:C,b:f?C:b,transposeA:!f,transposeB:g,backend:s,bias:r,activation:a,preluActivationWeights:o,leakyreluAlpha:i});x=re({inputs:{x:k},backend:s,attrs:{shape:n.outShape}}),m.push(b),m.push(C),m.push(k)}for(const v of m)s.disposeIntermediateTensorInfo(v);return x}function gD({x:t,filter:e,convInfo:n,backend:s,bias:r=null,preluActivationWeights:o=null,leakyreluAlpha:i=0,activation:a=null}){const{filterWidth:l,filterHeight:c,inChannels:u,outWidth:d,outHeight:h,dataFormat:f}=n,p=f==="channelsLast",g=l*c*u,x=h*d,m=[n.batchSize,g,x],y=!0,w=!1,v=[];if(o!=null){const R=Vf(o.shape,p);R!=null&&(o=re({inputs:{x:o},backend:s,attrs:{shape:R}}),v.push(o))}if(r!=null){const R=Vf(r.shape,p);R!=null&&(r=re({inputs:{x:r},backend:s,attrs:{shape:R}}),v.push(r))}const b=re({inputs:{x:e},backend:s,attrs:{shape:[1,g,j(e.shape)/g]}});v.push(b);const C=new hee(m,n),k=[t.shape,[n.padInfo.top,n.padInfo.left],[n.strideHeight,n.strideWidth],[n.dilationHeight,n.dilationWidth],[n.inChannels],[n.filterWidth*n.inChannels],[n.outWidth]],S=s.runWebGLProgram(C,[t],"float32",k),$=re({inputs:{x:S},backend:s,attrs:{shape:m}});v.push(S),v.push($);const N=r!=null,A=o!=null,M=a==="leakyrelu",L=a?tu(a,!0):null,V=new iD(p?$.shape:b.shape,p?b.shape:$.shape,p?[n.batchSize,x,n.outChannels]:[n.batchSize,n.outChannels,x],y,w,N,L,A,M),B=p?[$,b]:[b,$];if(r&&B.push(r),A&&B.push(o),M){const R=s.makeTensorInfo([],"float32",Wo(i,"float32"));B.push(R),v.push(R)}const U=s.runWebGLProgram(V,B,"float32"),K=re({inputs:{x:U},backend:s,attrs:{shape:n.outShape}});v.push(U);for(const R of v)s.disposeIntermediateTensorInfo(R);return K}/** + */function Vf(t,e){const n=t.length;return n>=3?e?[...t.slice(0,-3),t[n-3]*t[n-2],t[n-1]]:[...t.slice(0,-3),t[n-3],t[n-2]*t[n-1]]:!e&&n===1&&t[0]>1?[t[0],1]:null}function gD({x:t,filter:e,convInfo:n,backend:s,bias:r=null,preluActivationWeights:o=null,leakyreluAlpha:i=0,activation:a=null}){const l=t.shape,c=s.texData.get(t.dataId),u=n.inChannels,h=l[0]*l[1]*l[2],d=n.outChannels,f=n.dataFormat==="channelsLast",p=!1,g=!1;let x;const m=[];if(o!=null){const v=Vf(o.shape,f);v!=null&&(o=re({inputs:{x:o},backend:s,attrs:{shape:v}}),m.push(o))}if(r!=null){const v=Vf(r.shape,f);v!=null&&(r=re({inputs:{x:r},backend:s,attrs:{shape:v}}),m.push(r))}if(!((h===1||d===1)&&u>lD)&&c.isPacked&&f&&c.texture!=null&&l[2]%2!==0&&Ue(c.shape.slice(-3),l.slice(-3))){const v=l[0]*l[1]*(l[2]+1),b={dataId:t.dataId,shape:[1,v,n.inChannels],dtype:t.dtype},C=c.shape;c.shape=c.shape.slice(),c.shape[c.shape.length-2]++,I(Lf(c.shape,b.shape),()=>`packed reshape ${c.shape} to ${b.shape} isn't free`);const k=re({inputs:{x:e},backend:s,attrs:{shape:[1,n.inChannels,n.outChannels]}});m.push(k);const S=Bf({a:b,b:k,backend:s,transposeA:p,transposeB:g,bias:r,activation:a,preluActivationWeights:o,leakyreluAlpha:i}),$=s.texData.get(S.dataId);I($.isPacked,()=>"batchMatMul result is expected to be packed"),c.shape=C,$.shape=n.outShape,x=Yn({inputs:{x:S},backend:s}),x.shape=n.outShape,m.push(S)}else{const v=n.outHeight*n.outWidth,b=re({inputs:{x:t},backend:s,attrs:{shape:f?[n.batchSize,v,n.inChannels]:[n.batchSize,n.inChannels,v]}}),C=re({inputs:{x:e},backend:s,attrs:{shape:[1,n.inChannels,n.outChannels]}}),k=Bf({a:f?b:C,b:f?C:b,transposeA:!f,transposeB:g,backend:s,bias:r,activation:a,preluActivationWeights:o,leakyreluAlpha:i});x=re({inputs:{x:k},backend:s,attrs:{shape:n.outShape}}),m.push(b),m.push(C),m.push(k)}for(const v of m)s.disposeIntermediateTensorInfo(v);return x}function xD({x:t,filter:e,convInfo:n,backend:s,bias:r=null,preluActivationWeights:o=null,leakyreluAlpha:i=0,activation:a=null}){const{filterWidth:l,filterHeight:c,inChannels:u,outWidth:h,outHeight:d,dataFormat:f}=n,p=f==="channelsLast",g=l*c*u,x=d*h,m=[n.batchSize,g,x],y=!0,w=!1,v=[];if(o!=null){const R=Vf(o.shape,p);R!=null&&(o=re({inputs:{x:o},backend:s,attrs:{shape:R}}),v.push(o))}if(r!=null){const R=Vf(r.shape,p);R!=null&&(r=re({inputs:{x:r},backend:s,attrs:{shape:R}}),v.push(r))}const b=re({inputs:{x:e},backend:s,attrs:{shape:[1,g,j(e.shape)/g]}});v.push(b);const C=new fee(m,n),k=[t.shape,[n.padInfo.top,n.padInfo.left],[n.strideHeight,n.strideWidth],[n.dilationHeight,n.dilationWidth],[n.inChannels],[n.filterWidth*n.inChannels],[n.outWidth]],S=s.runWebGLProgram(C,[t],"float32",k),$=re({inputs:{x:S},backend:s,attrs:{shape:m}});v.push(S),v.push($);const N=r!=null,A=o!=null,M=a==="leakyrelu",L=a?tu(a,!0):null,V=new aD(p?$.shape:b.shape,p?b.shape:$.shape,p?[n.batchSize,x,n.outChannels]:[n.batchSize,n.outChannels,x],y,w,N,L,A,M),B=p?[$,b]:[b,$];if(r&&B.push(r),A&&B.push(o),M){const R=s.makeTensorInfo([],"float32",Wo(i,"float32"));B.push(R),v.push(R)}const U=s.runWebGLProgram(V,B,"float32"),K=re({inputs:{x:U},backend:s,attrs:{shape:n.outShape}});v.push(U);for(const R of v)s.disposeIntermediateTensorInfo(R);return K}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -15399,7 +15399,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function fee(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,filter:o}=e,{strides:i,pad:a,dataFormat:l,dilations:c,dimRoundingMode:u}=s,d=Yr(l),h=nn(r.shape,o.shape,i,c,a,u,!1,d);let f;if(h.filterHeight===1&&h.filterWidth===1&&h.dilationHeight===1&&h.dilationWidth===1&&h.strideHeight===1&&h.strideWidth===1&&(h.padInfo.type==="SAME"||h.padInfo.type==="VALID"))f=mD({x:r,filter:o,convInfo:h,backend:n});else if(h.strideWidth<=2&&d==="channelsLast"&&W().getBool("WEBGL_EXP_CONV")){const g=new pD(h),x=[[h.padInfo.top,h.padInfo.left],[h.strideHeight,h.strideWidth],[h.dilationHeight,h.dilationWidth],[h.inHeight,h.inWidth]];f=n.runWebGLProgram(g,[r,o],"float32",x)}else if(W().getBool("WEBGL_CONV_IM2COL"))f=gD({x:r,filter:o,convInfo:h,backend:n});else{const g=new fD(h);f=n.runWebGLProgram(g,[r,o],"float32")}const p=re({inputs:{x:f},backend:n,attrs:{shape:h.outShape}});return n.disposeIntermediateTensorInfo(f),p}const pee={kernelName:kp,backendName:"webgl",kernelFunc:fee};/** + */function pee(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,filter:o}=e,{strides:i,pad:a,dataFormat:l,dilations:c,dimRoundingMode:u}=s,h=Qr(l),d=nn(r.shape,o.shape,i,c,a,u,!1,h);let f;if(d.filterHeight===1&&d.filterWidth===1&&d.dilationHeight===1&&d.dilationWidth===1&&d.strideHeight===1&&d.strideWidth===1&&(d.padInfo.type==="SAME"||d.padInfo.type==="VALID"))f=gD({x:r,filter:o,convInfo:d,backend:n});else if(d.strideWidth<=2&&h==="channelsLast"&&W().getBool("WEBGL_EXP_CONV")){const g=new mD(d),x=[[d.padInfo.top,d.padInfo.left],[d.strideHeight,d.strideWidth],[d.dilationHeight,d.dilationWidth],[d.inHeight,d.inWidth]];f=n.runWebGLProgram(g,[r,o],"float32",x)}else if(W().getBool("WEBGL_CONV_IM2COL"))f=xD({x:r,filter:o,convInfo:d,backend:n});else{const g=new pD(d);f=n.runWebGLProgram(g,[r,o],"float32")}const p=re({inputs:{x:f},backend:n,attrs:{shape:d.outShape}});return n.disposeIntermediateTensorInfo(f),p}const mee={kernelName:kp,backendName:"webgl",kernelFunc:pee};/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -15414,7 +15414,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class mee{constructor(e){this.variableNames=["x","dy"],this.outputShape=e.filterShape;const n=e.strideHeight,s=e.strideWidth,r=e.padInfo.top,o=e.padInfo.left,i=e.dataFormat==="channelsLast";this.userCode=` + */class gee{constructor(e){this.variableNames=["x","dy"],this.outputShape=e.filterShape;const n=e.strideHeight,s=e.strideWidth,r=e.padInfo.top,o=e.padInfo.left,i=e.dataFormat==="channelsLast";this.userCode=` void main() { ivec4 coords = getOutputCoords(); int wR = coords.x; @@ -15451,13 +15451,13 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } setOutput(dotProd); } - `}}class gee{constructor(e){this.variableNames=["dy","W"],this.outputShape=e.inShape;const n=e.filterHeight,s=e.filterWidth,r=e.strideHeight,o=e.strideWidth,i=e.dataFormat==="channelsLast",a=n-1-e.padInfo.top,l=s-1-e.padInfo.left,c=i?1:2,u=i?2:3,d=i?3:1;this.userCode=` + `}}class xee{constructor(e){this.variableNames=["dy","W"],this.outputShape=e.inShape;const n=e.filterHeight,s=e.filterWidth,r=e.strideHeight,o=e.strideWidth,i=e.dataFormat==="channelsLast",a=n-1-e.padInfo.top,l=s-1-e.padInfo.left,c=i?1:2,u=i?2:3,h=i?3:1;this.userCode=` const ivec2 pads = ivec2(${a}, ${l}); void main() { ivec4 coords = getOutputCoords(); int batch = coords[0]; - int d1 = coords[${d}]; + int d1 = coords[${h}]; ivec2 dyCorner = ivec2(coords[${c}], coords[${u}]) - pads; int dyRCorner = dyCorner.x; @@ -15504,7 +15504,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } setOutput(dotProd); } - `}}class xee{constructor(e){this.variableNames=["x","dy"],this.outputShape=e.filterShape;const n=e.strideDepth,s=e.strideHeight,r=e.strideWidth,o=e.padInfo.front,i=e.padInfo.top,a=e.padInfo.left;this.userCode=` + `}}class yee{constructor(e){this.variableNames=["x","dy"],this.outputShape=e.filterShape;const n=e.strideDepth,s=e.strideHeight,r=e.strideWidth,o=e.padInfo.front,i=e.padInfo.top,a=e.padInfo.left;this.userCode=` void main() { ivec5 coords = getOutputCoords(); int wF = coords.x; @@ -15546,7 +15546,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } setOutput(dotProd); } - `}}class yee{constructor(e){this.variableNames=["dy","W"],this.outputShape=e.inShape;const n=e.filterDepth,s=e.filterHeight,r=e.filterWidth,o=e.strideDepth,i=e.strideHeight,a=e.strideWidth,l=n-1-e.padInfo.front,c=s-1-e.padInfo.top,u=r-1-e.padInfo.left;this.userCode=` + `}}class wee{constructor(e){this.variableNames=["dy","W"],this.outputShape=e.inShape;const n=e.filterDepth,s=e.filterHeight,r=e.filterWidth,o=e.strideDepth,i=e.strideHeight,a=e.strideWidth,l=n-1-e.padInfo.front,c=s-1-e.padInfo.top,u=r-1-e.padInfo.left;this.userCode=` const ivec3 pads = ivec3(${l}, ${c}, ${u}); void main() { @@ -15618,7 +15618,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function wee(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,dy:o}=e,{strides:i,pad:a,dataFormat:l,dimRoundingMode:c,filterShape:u}=s,d=Yr(l),h=nn(r.shape,u,i,1,a,c,!1,d),f=new mee(h);return n.runWebGLProgram(f,[r,o],"float32")}const vee={kernelName:Zx,backendName:"webgl",kernelFunc:wee};/** + */function vee(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,dy:o}=e,{strides:i,pad:a,dataFormat:l,dimRoundingMode:c,filterShape:u}=s,h=Qr(l),d=nn(r.shape,u,i,1,a,c,!1,h),f=new gee(d);return n.runWebGLProgram(f,[r,o],"float32")}const bee={kernelName:Zx,backendName:"webgl",kernelFunc:vee};/** * @license * Copyright 2023 Google LLC. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -15633,7 +15633,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class bee{constructor(e){this.variableNames=["dy","W"],this.packedInputs=!0,this.packedOutput=!0,this.customUniforms=[{name:"strides",type:"vec2"}],this.outputShape=e.inShape,this.enableShapeUniforms=pn(this.outputShape.length);const n=e.filterHeight,s=e.filterWidth,r=n-1-e.padInfo.top,o=s-1-e.padInfo.left;this.userCode=` + */class Cee{constructor(e){this.variableNames=["dy","W"],this.packedInputs=!0,this.packedOutput=!0,this.customUniforms=[{name:"strides",type:"vec2"}],this.outputShape=e.inShape,this.enableShapeUniforms=pn(this.outputShape.length);const n=e.filterHeight,s=e.filterWidth,r=n-1-e.padInfo.top,o=s-1-e.padInfo.left;this.userCode=` const ivec2 pads = ivec2(${r}, ${o}); void main() { @@ -15722,7 +15722,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Cee(t){const{inputs:e,backend:n,attrs:s}=t,{dy:r,filter:o}=e,{inputShape:i,strides:a,pad:l,dataFormat:c,dimRoundingMode:u}=s,d=Yr(c),h=nn(i,o.shape,a,1,l,u,!1,d);if(W().getBool("WEBGL_PACK_CONV2DTRANSPOSE")&&d==="channelsLast"){const f=[[h.strideHeight,h.strideWidth]],p=new bee(h);return n.runWebGLProgram(p,[r,o],"float32",f)}else{const f=new gee(h);return n.runWebGLProgram(f,[r,o],"float32")}}const kee={kernelName:Sp,backendName:"webgl",kernelFunc:Cee};/** + */function kee(t){const{inputs:e,backend:n,attrs:s}=t,{dy:r,filter:o}=e,{inputShape:i,strides:a,pad:l,dataFormat:c,dimRoundingMode:u}=s,h=Qr(c),d=nn(i,o.shape,a,1,l,u,!1,h);if(W().getBool("WEBGL_PACK_CONV2DTRANSPOSE")&&h==="channelsLast"){const f=[[d.strideHeight,d.strideWidth]],p=new Cee(d);return n.runWebGLProgram(p,[r,o],"float32",f)}else{const f=new xee(d);return n.runWebGLProgram(f,[r,o],"float32")}}const See={kernelName:Sp,backendName:"webgl",kernelFunc:kee};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -15737,7 +15737,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function See(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,filter:o}=e,{strides:i,pad:a,dilations:l}=s,c=Go(r.shape,o.shape,i,l,a),u=new dee(c);return n.runWebGLProgram(u,[r,o],"float32")}const Iee={kernelName:Ip,backendName:"webgl",kernelFunc:See};/** + */function Iee(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,filter:o}=e,{strides:i,pad:a,dilations:l}=s,c=Go(r.shape,o.shape,i,l,a),u=new dee(c);return n.runWebGLProgram(u,[r,o],"float32")}const $ee={kernelName:Ip,backendName:"webgl",kernelFunc:Iee};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -15752,7 +15752,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function $ee(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,dy:o}=e,{strides:i,pad:a,filterShape:l}=s,c=Go(r.shape,l,i,1,a),u=new xee(c);return n.runWebGLProgram(u,[r,o],"float32")}const Nee={kernelName:Jx,backendName:"webgl",kernelFunc:$ee};/** + */function Nee(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,dy:o}=e,{strides:i,pad:a,filterShape:l}=s,c=Go(r.shape,l,i,1,a),u=new yee(c);return n.runWebGLProgram(u,[r,o],"float32")}const Tee={kernelName:Jx,backendName:"webgl",kernelFunc:Nee};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -15767,7 +15767,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Tee(t){const{inputs:e,backend:n,attrs:s}=t,{dy:r,filter:o}=e,{pad:i,strides:a,inputShape:l}=s,c=Go(l,o.shape,a,1,i),u=new yee(c);return n.runWebGLProgram(u,[r,o],"float32")}const Eee={kernelName:ey,backendName:"webgl",kernelFunc:Tee};/** + */function Eee(t){const{inputs:e,backend:n,attrs:s}=t,{dy:r,filter:o}=e,{pad:i,strides:a,inputShape:l}=s,c=Go(l,o.shape,a,1,i),u=new wee(c);return n.runWebGLProgram(u,[r,o],"float32")}const Ree={kernelName:ey,backendName:"webgl",kernelFunc:Eee};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -15782,14 +15782,14 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Ree=_l+` + */const Aee=_l+` return cos(x); -`,Aee=` +`,Dee=` vec4 result = cos(x); bvec4 isNaN = isnan(x); ${na} return result; -`,Dee=Oe({opSnippet:Ree,packedOpSnippet:Aee}),_ee={kernelName:Su,backendName:"webgl",kernelFunc:Dee};/** +`,_ee=Oe({opSnippet:Aee,packedOpSnippet:Dee}),Fee={kernelName:Su,backendName:"webgl",kernelFunc:_ee};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -15804,10 +15804,10 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Fee=` + */const zee=` float e2x = exp(-x); return (e2x + 1.0 / e2x) / 2.0; -`,zee=Oe({opSnippet:Fee}),Oee={kernelName:Iu,backendName:"webgl",kernelFunc:zee};/** +`,Oee=Oe({opSnippet:zee}),Mee={kernelName:Iu,backendName:"webgl",kernelFunc:Oee};/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -15822,7 +15822,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class Mee{constructor(e,n,s,r,o){this.variableNames=["Image","Boxes","BoxInd"],this.outputShape=[];const[i,a,l,c]=e,[u]=n,[d,h]=s;this.outputShape=[u,d,h,c];const f=r==="bilinear"?1:0,[p,g]=[`${a-1}.0`,`${l-1}.0`],[x,m,y]=d>1?[`${(a-1)/(d-1)}`,"(y2-y1) * height_ratio",`y1*${p} + float(y)*(height_scale)`]:["0.0","0.0",`0.5 * (y1+y2) * ${p}`],[w,v,b]=h>1?[`${(l-1)/(h-1)}`,"(x2-x1) * width_ratio",`x1*${g} + float(x)*(width_scale)`]:["0.0","0.0",`0.5 * (x1+x2) * ${g}`];this.userCode=` + */class Pee{constructor(e,n,s,r,o){this.variableNames=["Image","Boxes","BoxInd"],this.outputShape=[];const[i,a,l,c]=e,[u]=n,[h,d]=s;this.outputShape=[u,h,d,c];const f=r==="bilinear"?1:0,[p,g]=[`${a-1}.0`,`${l-1}.0`],[x,m,y]=h>1?[`${(a-1)/(h-1)}`,"(y2-y1) * height_ratio",`y1*${p} + float(y)*(height_scale)`]:["0.0","0.0",`0.5 * (y1+y2) * ${p}`],[w,v,b]=d>1?[`${(l-1)/(d-1)}`,"(x2-x1) * width_ratio",`x1*${g} + float(x)*(width_scale)`]:["0.0","0.0",`0.5 * (x1+x2) * ${g}`];this.userCode=` const float height_ratio = float(${x}); const float width_ratio = float(${w}); void main() { @@ -15898,7 +15898,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Pee=t=>{const{inputs:e,backend:n,attrs:s}=t,{image:r,boxes:o,boxInd:i}=e,{cropSize:a,method:l,extrapolationValue:c}=s,u=new Mee(r.shape,o.shape,a,l,c);return n.runWebGLProgram(u,[r,o,i],"float32")},Lee={kernelName:ny,backendName:"webgl",kernelFunc:Pee};var su;(function(t){t.Prod="*",t.Sum="+"})(su||(su={}));class Lk{constructor(e,n,s,r){this.op=e,this.outputShape=n,this.variableNames=["x"],this.customUniforms=[{name:"index",type:"float"}];const o=this.outputShape.length,i=this.op===su.Prod?"1.0":"0.0",a=s?i:`getX(${Bk(o,"coords",this.op)})`,l=this.outputShape[this.outputShape.length-1];let c="",u="";s?(c=r?`end != ${l-1}`:"end != 0",u=r?"end + 1":"end - 1"):(c=r?`end + pow2 < ${l}`:"end >= pow2",u=r?"end + pow2":"end - pow2"),this.userCode=` + */const Lee=t=>{const{inputs:e,backend:n,attrs:s}=t,{image:r,boxes:o,boxInd:i}=e,{cropSize:a,method:l,extrapolationValue:c}=s,u=new Pee(r.shape,o.shape,a,l,c);return n.runWebGLProgram(u,[r,o,i],"float32")},Bee={kernelName:ny,backendName:"webgl",kernelFunc:Lee};var su;(function(t){t.Prod="*",t.Sum="+"})(su||(su={}));class Lk{constructor(e,n,s,r){this.op=e,this.outputShape=n,this.variableNames=["x"],this.customUniforms=[{name:"index",type:"float"}];const o=this.outputShape.length,i=this.op===su.Prod?"1.0":"0.0",a=s?i:`getX(${Bk(o,"coords",this.op)})`,l=this.outputShape[this.outputShape.length-1];let c="",u="";s?(c=r?`end != ${l-1}`:"end != 0",u=r?"end + 1":"end - 1"):(c=r?`end + pow2 < ${l}`:"end >= pow2",u=r?"end + pow2":"end - pow2"),this.userCode=` void main() { ${Ze(o)} coords = getOutputCoords(); int end = ${Vk(o,"coords",this.op)}; @@ -15926,7 +15926,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function xD(t,e,n,s,r,o){const i=e.shape.length,a=yt([s],i);let l=e;a!=null&&(l=Sn({inputs:{x:e},backend:n,attrs:{perm:a}}));const c=$t(1,i)[0];if(c!==i-1)throw new Error(`WebGL cumprod shader expects an inner-most axis=${e.shape.length-1} but got axis=${s}`);const u=l.shape[c];let d=Yn({inputs:{x:l},backend:n});for(let h=0;h<=Math.ceil(Math.log2(u))-1;h++){const f=new Lk(t,l.shape,!1,o),p=[[h]],g=d;d=n.runWebGLProgram(f,[d],d.dtype,p),n.disposeIntermediateTensorInfo(g)}if(r){const h=new Lk(t,l.shape,r,o),f=d;d=n.runWebGLProgram(h,[d],d.dtype),n.disposeIntermediateTensorInfo(f)}if(a!=null){const h=Ho(a),f=Sn({inputs:{x:d},backend:n,attrs:{perm:h}});return n.disposeIntermediateTensorInfo(d),n.disposeIntermediateTensorInfo(l),f}return d}/** + */function yD(t,e,n,s,r,o){const i=e.shape.length,a=yt([s],i);let l=e;a!=null&&(l=Sn({inputs:{x:e},backend:n,attrs:{perm:a}}));const c=$t(1,i)[0];if(c!==i-1)throw new Error(`WebGL cumprod shader expects an inner-most axis=${e.shape.length-1} but got axis=${s}`);const u=l.shape[c];let h=Yn({inputs:{x:l},backend:n});for(let d=0;d<=Math.ceil(Math.log2(u))-1;d++){const f=new Lk(t,l.shape,!1,o),p=[[d]],g=h;h=n.runWebGLProgram(f,[h],h.dtype,p),n.disposeIntermediateTensorInfo(g)}if(r){const d=new Lk(t,l.shape,r,o),f=h;h=n.runWebGLProgram(d,[h],h.dtype),n.disposeIntermediateTensorInfo(f)}if(a!=null){const d=Ho(a),f=Sn({inputs:{x:h},backend:n,attrs:{perm:d}});return n.disposeIntermediateTensorInfo(h),n.disposeIntermediateTensorInfo(l),f}return h}/** * @license * Copyright 2022 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -15941,7 +15941,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Bee(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{axis:o,exclusive:i,reverse:a}=s;return xD(su.Prod,r,n,o,i,a)}const Vee={kernelName:ty,backendName:"webgl",kernelFunc:Bee};/** + */function Vee(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{axis:o,exclusive:i,reverse:a}=s;return yD(su.Prod,r,n,o,i,a)}const Wee={kernelName:ty,backendName:"webgl",kernelFunc:Vee};/** * @license * Copyright 2022 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -15956,7 +15956,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Wee(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{axis:o,exclusive:i,reverse:a}=s;return xD(su.Sum,r,n,o,i,a)}const Uee={kernelName:$p,backendName:"webgl",kernelFunc:Wee};/** + */function Uee(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{axis:o,exclusive:i,reverse:a}=s;return yD(su.Sum,r,n,o,i,a)}const Gee={kernelName:$p,backendName:"webgl",kernelFunc:Uee};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -15971,7 +15971,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Gee(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,weights:o}=e,{size:i,binaryOutput:a}=s;if(r.shape.length===1){const l=n.readSync(r.dataId),c=n.readSync(o.dataId),u=QA(l,c,o.dtype,o.shape,i);return n.makeTensorInfo([i],o.dtype,u)}else if(r.shape.length===2){const l=n.bufferSync(r),c=n.bufferSync(o),u=XY(l,c,i,a);return n.makeTensorInfo(u.shape,o.dtype,u.values)}throw new Error(`Error in denseBincount: input must be at most rank 2, but got rank${r.shape.length}.`)}const Hee={kernelName:sy,backendName:"webgl",kernelFunc:Gee};/** + */function Hee(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,weights:o}=e,{size:i,binaryOutput:a}=s;if(r.shape.length===1){const l=n.readSync(r.dataId),c=n.readSync(o.dataId),u=ZA(l,c,o.dtype,o.shape,i);return n.makeTensorInfo([i],o.dtype,u)}else if(r.shape.length===2){const l=n.bufferSync(r),c=n.bufferSync(o),u=qY(l,c,i,a);return n.makeTensorInfo(u.shape,o.dtype,u.values)}throw new Error(`Error in denseBincount: input must be at most rank 2, but got rank${r.shape.length}.`)}const jee={kernelName:sy,backendName:"webgl",kernelFunc:Hee};/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -15986,7 +15986,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class jee{constructor(e,n,s){this.variableNames=["x"],this.outputShape=[],this.outputShape=e,this.blockSize=n,this.dataFormat=s,this.userCode=` + */class Kee{constructor(e,n,s){this.variableNames=["x"],this.outputShape=[],this.outputShape=e,this.blockSize=n,this.dataFormat=s,this.userCode=` void main() { ivec4 coords = getOutputCoords(); int b = coords[0]; @@ -16020,7 +16020,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Kee(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{blockSize:o,dataFormat:i}=s,a=r.shape[0],l=i==="NHWC"?r.shape[1]:r.shape[2],c=i==="NHWC"?r.shape[2]:r.shape[3],u=i==="NHWC"?r.shape[3]:r.shape[1],d=l*o,h=c*o,f=u/(o*o),p=i==="NHWC"?[a,d,h,f]:[a,f,d,h],g=new jee(p,o,i);return n.runWebGLProgram(g,[r],r.dtype)}const Xee={kernelName:ry,backendName:"webgl",kernelFunc:Kee};/** + */function Xee(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{blockSize:o,dataFormat:i}=s,a=r.shape[0],l=i==="NHWC"?r.shape[1]:r.shape[2],c=i==="NHWC"?r.shape[2]:r.shape[3],u=i==="NHWC"?r.shape[3]:r.shape[1],h=l*o,d=c*o,f=u/(o*o),p=i==="NHWC"?[a,h,d,f]:[a,f,h,d],g=new Kee(p,o,i);return n.runWebGLProgram(g,[r],r.dtype)}const qee={kernelName:ry,backendName:"webgl",kernelFunc:Xee};/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -16035,7 +16035,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class yD{constructor(e,n=!1,s=null,r=!1,o=!1){this.variableNames=["x","W"],this.customUniforms=[{name:"pads",type:"ivec2"},{name:"strides",type:"ivec2"},{name:"dilations",type:"ivec2"},{name:"inDims",type:"ivec2"}],this.outputShape=e.outShape,this.enableShapeUniforms=pn(this.outputShape.length);const i=e.filterHeight,a=e.filterWidth,l=e.outChannels/e.inChannels;let c="",u="";s&&(r?c=`float activation(float a) { + */class wD{constructor(e,n=!1,s=null,r=!1,o=!1){this.variableNames=["x","W"],this.customUniforms=[{name:"pads",type:"ivec2"},{name:"strides",type:"ivec2"},{name:"dilations",type:"ivec2"},{name:"inDims",type:"ivec2"}],this.outputShape=e.outShape,this.enableShapeUniforms=pn(this.outputShape.length);const i=e.filterHeight,a=e.filterWidth,l=e.outChannels/e.inChannels;let c="",u="";s&&(r?c=`float activation(float a) { float b = getPreluActivationWeightsAtOutCoords(); ${s} }`:o?c=`float activation(float a) { @@ -16045,7 +16045,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam float activation(float x) { ${s} } - `,u="result = activation(result);");const d=n?"result += getBiasAtOutCoords();":"";n&&this.variableNames.push("bias"),r&&this.variableNames.push("preluActivationWeights"),o&&this.variableNames.push("leakyreluAlpha"),this.userCode=` + `,u="result = activation(result);");const h=n?"result += getBiasAtOutCoords();":"";n&&this.variableNames.push("bias"),r&&this.variableNames.push("preluActivationWeights"),o&&this.variableNames.push("leakyreluAlpha"),this.userCode=` ${c} void main() { @@ -16084,7 +16084,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } float result = dotProd; - ${d} + ${h} ${u} setOutput(result); } @@ -16103,16 +16103,16 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class wD{constructor(e,n=!1,s=null,r=!1,o=!1){this.variableNames=["x","W"],this.packedInputs=!0,this.packedOutput=!0,this.customUniforms=[{name:"pads",type:"ivec2"},{name:"strides",type:"ivec2"},{name:"dilations",type:"ivec2"},{name:"inDims",type:"ivec2"}],this.outputShape=e.outShape,this.enableShapeUniforms=pn(this.outputShape.length);const i=e.outChannels/e.inChannels,a=e.padInfo.left,l=e.strideWidth,c=e.dilationWidth,u=e.filterHeight,d=e.filterWidth,h=d;let f=` + */class vD{constructor(e,n=!1,s=null,r=!1,o=!1){this.variableNames=["x","W"],this.packedInputs=!0,this.packedOutput=!0,this.customUniforms=[{name:"pads",type:"ivec2"},{name:"strides",type:"ivec2"},{name:"dilations",type:"ivec2"},{name:"inDims",type:"ivec2"}],this.outputShape=e.outShape,this.enableShapeUniforms=pn(this.outputShape.length);const i=e.outChannels/e.inChannels,a=e.padInfo.left,l=e.strideWidth,c=e.dilationWidth,u=e.filterHeight,h=e.filterWidth,d=h;let f=` int xR; int xC; int xCOffset; - vec4 wTexel; vec4 previous; vec4 final;`;for(let m=0;m=0 && xR < inDims[0]) { - `;for(let m=0;m<(h+1)/2;m++){const y=m*2;if(f+=` + `;for(let m=0;m<(d+1)/2;m++){const y=m*2;if(f+=` xC = xCCorner + ${y*c}; - `,l===1){if(y= 0 && xCOffset < inDims[1] && xTexelC${y}Ready == 0) { xTexelC${y} = getX(batch, xR, xCOffset, d1); @@ -16162,7 +16162,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } xC${y} = xTexelC${y}; - `,y+1= 0 && xCOffset < inDims[1] && xTexelC${y+1}Ready == 0) { @@ -16199,7 +16199,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } xC${y+1} = xTexelC${y+1}; - `}}else y= 0 && xCOffset < inDims[1] && xTexelC${y}Ready == 0) { xTexelC${y} = getX(batch, xR, xCOffset, d1); @@ -16222,7 +16222,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } xC${y} = vec4(xTexelC${y}.zw, xTexelC${y+1}.zw); - `,y+1= 0 && xCOffset < inDims[1]) { @@ -16249,12 +16249,12 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam xC${y} = vec4( xTexelC${y}.xy, xTexelC${y+1}.xy); - `,y+1`Error in depthwiseConv2d: Either strides or dilations must be 1. Got strides ${i} and dilations '${u}'`);const d=nn(r.shape,o.shape,i,u,a,c,!0);let h;W().getBool("WEBGL_PACK_DEPTHWISECONV")&&d.strideWidth<=2&&d.outChannels/d.inChannels===1?h=new wD(d):h=new yD(d);const f=[[d.padInfo.top,d.padInfo.left],[d.strideHeight,d.strideWidth],[d.dilationHeight,d.dilationWidth],[d.inHeight,d.inWidth]];return n.runWebGLProgram(h,[r,o],"float32",f)}const Yee={kernelName:Np,backendName:"webgl",kernelFunc:qee};/** + */function Yee(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,filter:o}=e,{strides:i,pad:a,dilations:l,dimRoundingMode:c}=s;let u=l;u==null&&(u=[1,1]),I(dn(i,u),()=>`Error in depthwiseConv2d: Either strides or dilations must be 1. Got strides ${i} and dilations '${u}'`);const h=nn(r.shape,o.shape,i,u,a,c,!0);let d;W().getBool("WEBGL_PACK_DEPTHWISECONV")&&h.strideWidth<=2&&h.outChannels/h.inChannels===1?d=new vD(h):d=new wD(h);const f=[[h.padInfo.top,h.padInfo.left],[h.strideHeight,h.strideWidth],[h.dilationHeight,h.dilationWidth],[h.inHeight,h.inWidth]];return n.runWebGLProgram(d,[r,o],"float32",f)}const Qee={kernelName:Np,backendName:"webgl",kernelFunc:Yee};/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -16322,7 +16322,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class Qee{constructor(e){this.variableNames=["x","dy"],this.outputShape=e.filterShape;const n=e.strideHeight,s=e.strideWidth,r=e.padInfo.top,o=e.padInfo.left,i=e.outChannels/e.inChannels;this.userCode=` + */class Zee{constructor(e){this.variableNames=["x","dy"],this.outputShape=e.filterShape;const n=e.strideHeight,s=e.strideWidth,r=e.padInfo.top,o=e.padInfo.left,i=e.outChannels/e.inChannels;this.userCode=` void main() { ivec4 coords = getOutputCoords(); int wR = coords.x; @@ -16357,7 +16357,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } setOutput(dotProd); } - `}}class Zee{constructor(e){this.variableNames=["dy","W"],this.outputShape=e.inShape;const n=e.filterHeight,s=e.filterWidth,r=e.strideHeight,o=e.strideWidth,i=n-1-e.padInfo.top,a=s-1-e.padInfo.left,l=e.outChannels/e.inChannels;this.userCode=` + `}}class Jee{constructor(e){this.variableNames=["dy","W"],this.outputShape=e.inShape;const n=e.filterHeight,s=e.filterWidth,r=e.strideHeight,o=e.strideWidth,i=n-1-e.padInfo.top,a=s-1-e.padInfo.left,l=e.outChannels/e.inChannels;this.userCode=` const ivec2 pads = ivec2(${i}, ${a}); void main() { @@ -16417,7 +16417,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Jee(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,dy:o}=e,{strides:i,dilations:a,pad:l,dimRoundingMode:c,filterShape:u}=s,d=nn(r.shape,u,i,a,l,c,!0),h=new Qee(d);return n.runWebGLProgram(h,[r,o],"float32")}const ete={kernelName:oy,backendName:"webgl",kernelFunc:Jee};/** + */function ete(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,dy:o}=e,{strides:i,dilations:a,pad:l,dimRoundingMode:c,filterShape:u}=s,h=nn(r.shape,u,i,a,l,c,!0),d=new Zee(h);return n.runWebGLProgram(d,[r,o],"float32")}const tte={kernelName:oy,backendName:"webgl",kernelFunc:ete};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -16432,7 +16432,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function tte(t){const{inputs:e,backend:n,attrs:s}=t,{dy:r,filter:o}=e,{strides:i,dilations:a,pad:l,dimRoundingMode:c,inputShape:u}=s,d=nn(u,o.shape,i,a,l,c,!0),h=new Zee(d);return n.runWebGLProgram(h,[r,o],"float32")}const nte={kernelName:iy,backendName:"webgl",kernelFunc:tte};/** + */function nte(t){const{inputs:e,backend:n,attrs:s}=t,{dy:r,filter:o}=e,{strides:i,dilations:a,pad:l,dimRoundingMode:c,inputShape:u}=s,h=nn(u,o.shape,i,a,l,c,!0),d=new Jee(h);return n.runWebGLProgram(d,[r,o],"float32")}const ste={kernelName:iy,backendName:"webgl",kernelFunc:nte};/** * @license * Copyright 2019 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -16447,7 +16447,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class ste{constructor(e){this.variableNames=["X"],this.outputShape=[e,e],this.userCode=` + */class rte{constructor(e){this.variableNames=["X"],this.outputShape=[e,e],this.userCode=` void main() { ivec2 coords = getOutputCoords(); float val = coords[0] == coords[1] ? getX(coords[0]) : 0.0; @@ -16468,7 +16468,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function rte(t){const{inputs:e,backend:n}=t,{x:s}=e,r=[...s.shape,...s.shape],o=j(s.shape),i=re({inputs:{x:s},backend:n,attrs:{shape:[o]}}),a=new ste(o),l=n.runWebGLProgram(a,[i],i.dtype),c=re({inputs:{x:l},backend:n,attrs:{shape:r}});return n.disposeIntermediateTensorInfo(i),n.disposeIntermediateTensorInfo(l),c}const ote={kernelName:J2,backendName:"webgl",kernelFunc:rte};/** + */function ote(t){const{inputs:e,backend:n}=t,{x:s}=e,r=[...s.shape,...s.shape],o=j(s.shape),i=re({inputs:{x:s},backend:n,attrs:{shape:[o]}}),a=new rte(o),l=n.runWebGLProgram(a,[i],i.dtype),c=re({inputs:{x:l},backend:n,attrs:{shape:r}});return n.disposeIntermediateTensorInfo(i),n.disposeIntermediateTensorInfo(l),c}const ite={kernelName:e$,backendName:"webgl",kernelFunc:ote};/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -16483,9 +16483,9 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class ite{constructor(e){this.variableNames=["x","W"],this.outputShape=e.outShape;const{inHeight:n,inWidth:s,padInfo:r,strideHeight:o,strideWidth:i,filterHeight:a,filterWidth:l,dilationHeight:c,dilationWidth:u}=e,{top:d,left:h}=r;this.userCode=` + */class ate{constructor(e){this.variableNames=["x","W"],this.outputShape=e.outShape;const{inHeight:n,inWidth:s,padInfo:r,strideHeight:o,strideWidth:i,filterHeight:a,filterWidth:l,dilationHeight:c,dilationWidth:u}=e,{top:h,left:d}=r;this.userCode=` const ivec2 strides = ivec2(${o}, ${i}); - const ivec2 pads = ivec2(${d}, ${h}); + const ivec2 pads = ivec2(${h}, ${d}); const float neg_infinity = -3.4e38; void main() { @@ -16536,7 +16536,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function ate(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,filter:o}=e,{strides:i,pad:a,dilations:l}=s,c=dd(r.shape,o.shape,i,a,"NHWC",l);let u;const d=new ite(c);u=n.runWebGLProgram(d,[r,o],"float32");const h=re({inputs:{x:u},backend:n,attrs:{shape:c.outShape}});return n.disposeIntermediateTensorInfo(u),h}const lte={kernelName:Tp,backendName:"webgl",kernelFunc:ate};/** + */function lte(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,filter:o}=e,{strides:i,pad:a,dilations:l}=s,c=hh(r.shape,o.shape,i,a,"NHWC",l);let u;const h=new ate(c);u=n.runWebGLProgram(h,[r,o],"float32");const d=re({inputs:{x:u},backend:n,attrs:{shape:c.outShape}});return n.disposeIntermediateTensorInfo(u),d}const cte={kernelName:Tp,backendName:"webgl",kernelFunc:lte};/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -16551,7 +16551,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function cte(t){const{inputs:e,backend:n,attrs:s}=t,{equation:r}=s,o=e,{allDims:i,summedDims:a,idDims:l}=Ow(r,o.length);Pw(i.length,l,o);const{path:c,steps:u}=Lw(a,l),d=u.length;let h=null,f=i.length;const p=[];for(let g=0;g=0&&(h=Bm({inputs:{x:h},backend:n,attrs:{axis:c[g]-(i.length-f),keepDims:!1}}),p.push(h)),f--)}for(const g of p)g!==h&&n.disposeIntermediateTensorInfo(g);return h}const ute={kernelName:ay,backendName:"webgl",kernelFunc:cte};/** + */function ute(t){const{inputs:e,backend:n,attrs:s}=t,{equation:r}=s,o=e,{allDims:i,summedDims:a,idDims:l}=Ow(r,o.length);Pw(i.length,l,o);const{path:c,steps:u}=Lw(a,l),h=u.length;let d=null,f=i.length;const p=[];for(let g=0;g=0&&(d=Bm({inputs:{x:d},backend:n,attrs:{axis:c[g]-(i.length-f),keepDims:!1}}),p.push(d)),f--)}for(const g of p)g!==d&&n.disposeIntermediateTensorInfo(g);return d}const hte={kernelName:ay,backendName:"webgl",kernelFunc:ute};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -16566,7 +16566,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const dte="return (x >= 0.0) ? x : (exp(x) - 1.0);",hte=` + */const dte="return (x >= 0.0) ? x : (exp(x) - 1.0);",fte=` vec4 result; result.r = (x.r >= 0.0) ? x.r : (exp(x.r) - 1.0); @@ -16575,7 +16575,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam result.a = (x.a >= 0.0) ? x.a : (exp(x.a) - 1.0); return result; -`,fte=Oe({opSnippet:dte,packedOpSnippet:hte}),pte={kernelName:Nu,backendName:"webgl",kernelFunc:fte};/** +`,pte=Oe({opSnippet:dte,packedOpSnippet:fte}),mte={kernelName:Nu,backendName:"webgl",kernelFunc:pte};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -16590,10 +16590,10 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const mte="return (b >= 0.0) ? a : a * (b + 1.0);",gte=` + */const gte="return (b >= 0.0) ? a : a * (b + 1.0);",xte=` vec4 bGTEZero = vec4(greaterThanEqual(b, vec4(0.))); return (bGTEZero * a) + ((vec4(1.0) - bGTEZero) * (a * (b + vec4(1.0)))); -`,xte=t=>{const{inputs:e,backend:n}=t,{dy:s,y:r}=e,o=W().getBool("WEBGL_PACK_BINARY_OPERATIONS")?new Dl(gte,s.shape,r.shape):new Wi(mte,s.shape,r.shape);return n.runWebGLProgram(o,[s,r],s.dtype)},yte={kernelName:ly,backendName:"webgl",kernelFunc:xte};/** +`,yte=t=>{const{inputs:e,backend:n}=t,{dy:s,y:r}=e,o=W().getBool("WEBGL_PACK_BINARY_OPERATIONS")?new Dl(xte,s.shape,r.shape):new Wi(gte,s.shape,r.shape);return n.runWebGLProgram(o,[s,r],s.dtype)},wte={kernelName:ly,backendName:"webgl",kernelFunc:yte};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -16608,9 +16608,9 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const wte=` + */const vte=` return vec4(equal(a, b)); -`,vte="return float(a == b);",bte=rn({opSnippet:vte,packedOpSnippet:wte,dtype:"bool",cpuKernelImpl:JY}),Cte={kernelName:Ep,backendName:"webgl",kernelFunc:bte};/** +`,bte="return float(a == b);",Cte=rn({opSnippet:bte,packedOpSnippet:vte,dtype:"bool",cpuKernelImpl:eQ}),kte={kernelName:Ep,backendName:"webgl",kernelFunc:Cte};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -16625,7 +16625,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const kte=` + */const Ste=` // Error function is calculated approximately with elementary function. // See "Handbook of Mathematical Functions with Formulas, // Graphs, and Mathematical Tables", Abramowitz and Stegun. @@ -16640,7 +16640,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam x = abs(x); float t = 1.0 / (1.0 + p * x); return sign * (1.0 - (((((a5*t + a4)*t) + a3)*t + a2)*t + a1)*t*exp(-x*x)); -`,Ste=Oe({opSnippet:kte}),Ite={kernelName:Tu,backendName:"webgl",kernelFunc:Ste};/** +`,Ite=Oe({opSnippet:Ste}),$te={kernelName:Tu,backendName:"webgl",kernelFunc:Ite};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -16655,9 +16655,9 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const $te=_l+` + */const Nte=_l+` return exp(x); -`,Nte=` +`,Tte=` vec4 result = exp(x); bvec4 isNaN = isnan(x); result.r = isNaN.r ? x.r : result.r; @@ -16666,7 +16666,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam result.a = isNaN.a ? x.a : result.a; return result; -`,vD=Oe({opSnippet:$te,packedOpSnippet:Nte,cpuKernelImpl:eQ,dtype:"float32"}),Tte={kernelName:Eu,backendName:"webgl",kernelFunc:vD};/** +`,bD=Oe({opSnippet:Nte,packedOpSnippet:Tte,cpuKernelImpl:tQ,dtype:"float32"}),Ete={kernelName:Eu,backendName:"webgl",kernelFunc:bD};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -16681,7 +16681,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function R1(t){const{inputs:e,attrs:n,backend:s}=t,{dim:r}=n,{input:o}=e,i=o.shape.length,a=o.shape.slice();let l=r;return r<0&&(I(-(i+1)<=r,()=>`Axis must be in the interval [${-(i+1)}, ${i}]`),l=i+r+1),a.splice(l,0,1),re({inputs:{x:o},backend:s,attrs:{shape:a}})}const Ete={kernelName:Rp,backendName:"webgl",kernelFunc:R1};/** + */function R1(t){const{inputs:e,attrs:n,backend:s}=t,{dim:r}=n,{input:o}=e,i=o.shape.length,a=o.shape.slice();let l=r;return r<0&&(I(-(i+1)<=r,()=>`Axis must be in the interval [${-(i+1)}, ${i}]`),l=i+r+1),a.splice(l,0,1),re({inputs:{x:o},backend:s,attrs:{shape:a}})}const Rte={kernelName:Rp,backendName:"webgl",kernelFunc:R1};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -16696,7 +16696,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Wk="return exp(x) - 1.0;",Rte=Oe({opSnippet:Wk,packedOpSnippet:Wk,cpuKernelImpl:tQ}),Ate={kernelName:Ru,backendName:"webgl",kernelFunc:Rte};/** + */const Wk="return exp(x) - 1.0;",Ate=Oe({opSnippet:Wk,packedOpSnippet:Wk,cpuKernelImpl:nQ}),Dte={kernelName:Ru,backendName:"webgl",kernelFunc:Ate};/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -16759,7 +16759,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function bD(t,e,n){const s=n.texData.get(t.dataId),r=j(t.shape),o=t.shape[t.shape.length-1],i=r/o,a=re({inputs:{x:t},backend:n,attrs:{shape:[i,o]}}),l=a.shape,c=new Uk("real",l,e),u=new Uk("imag",l,e),d=[{dataId:s.complexTensorInfos.real.dataId,dtype:s.complexTensorInfos.real.dtype,shape:l},{dataId:s.complexTensorInfos.imag.dataId,dtype:s.complexTensorInfos.imag.dtype,shape:l}],h=n.runWebGLProgram(c,d,"float32"),f=n.runWebGLProgram(u,d,"float32"),p=Qo({inputs:{real:h,imag:f},backend:n});n.disposeIntermediateTensorInfo(h),n.disposeIntermediateTensorInfo(f);const g=re({inputs:{x:p},backend:n,attrs:{shape:t.shape}});return n.disposeIntermediateTensorInfo(a),n.disposeIntermediateTensorInfo(p),g}/** + */function CD(t,e,n){const s=n.texData.get(t.dataId),r=j(t.shape),o=t.shape[t.shape.length-1],i=r/o,a=re({inputs:{x:t},backend:n,attrs:{shape:[i,o]}}),l=a.shape,c=new Uk("real",l,e),u=new Uk("imag",l,e),h=[{dataId:s.complexTensorInfos.real.dataId,dtype:s.complexTensorInfos.real.dtype,shape:l},{dataId:s.complexTensorInfos.imag.dataId,dtype:s.complexTensorInfos.imag.dtype,shape:l}],d=n.runWebGLProgram(c,h,"float32"),f=n.runWebGLProgram(u,h,"float32"),p=Qo({inputs:{real:d,imag:f},backend:n});n.disposeIntermediateTensorInfo(d),n.disposeIntermediateTensorInfo(f);const g=re({inputs:{x:p},backend:n,attrs:{shape:t.shape}});return n.disposeIntermediateTensorInfo(a),n.disposeIntermediateTensorInfo(p),g}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -16774,7 +16774,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Dte(t){const{inputs:e,backend:n}=t,{input:s}=e;return bD(s,!1,n)}const _te={kernelName:cy,backendName:"webgl",kernelFunc:Dte};/** + */function _te(t){const{inputs:e,backend:n}=t,{input:s}=e;return CD(s,!1,n)}const Fte={kernelName:cy,backendName:"webgl",kernelFunc:_te};/** * @license * Copyright 2019 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -16789,7 +16789,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class Fte{constructor(e,n){this.outputShape=[],this.customUniforms=[{name:"value",type:"float"}],this.variableNames=["x"],this.outputShape=e,this.userCode=` + */class zte{constructor(e,n){this.outputShape=[],this.customUniforms=[{name:"value",type:"float"}],this.variableNames=["x"],this.outputShape=e,this.userCode=` void main() { // Input can be obtained from uniform value. setOutput(value); @@ -16809,7 +16809,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Dd(t){const{backend:e,attrs:n}=t,{shape:s,value:r}=n;let{dtype:o}=n;if(o=o||wl(r),o==="string"){const i=kt(o,j(s));return i.fill(r),e.makeTensorInfo(s,o,i)}else{const i=new Fte(s,r),a=[[r]];return e.runWebGLProgram(i,[],o,a)}}const zte={kernelName:uy,backendName:"webgl",kernelFunc:Dd};/** + */function Dh(t){const{backend:e,attrs:n}=t,{shape:s,value:r}=n;let{dtype:o}=n;if(o=o||wl(r),o==="string"){const i=kt(o,j(s));return i.fill(r),e.makeTensorInfo(s,o,i)}else{const i=new zte(s,r),a=[[r]];return e.runWebGLProgram(i,[],o,a)}}const Ote={kernelName:uy,backendName:"webgl",kernelFunc:Dh};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -16824,7 +16824,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class Ote{constructor(e){this.variableNames=["Image"],this.outputShape=[];const n=e[2];this.outputShape=e,this.userCode=` + */class Mte{constructor(e){this.variableNames=["Image"],this.outputShape=[];const n=e[2];this.outputShape=e,this.userCode=` void main() { ivec4 coords = getOutputCoords(); int x = coords[2]; @@ -16853,7 +16853,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Mte={kernelName:dy,backendName:"webgl",kernelFunc:({inputs:t,backend:e})=>{const{image:n}=t,s=e,r=new Ote(n.shape);return s.runWebGLProgram(r,[n],n.dtype)}};/** + */const Pte={kernelName:hy,backendName:"webgl",kernelFunc:({inputs:t,backend:e})=>{const{image:n}=t,s=e,r=new Mte(n.shape);return s.runWebGLProgram(r,[n],n.dtype)}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -16868,7 +16868,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Gk="return floor(x);",Pte=Oe({opSnippet:Gk,packedOpSnippet:Gk,cpuKernelImpl:nQ}),Lte={kernelName:Au,backendName:"webgl",kernelFunc:Pte};/** + */const Gk="return floor(x);",Lte=Oe({opSnippet:Gk,packedOpSnippet:Gk,cpuKernelImpl:sQ}),Bte={kernelName:Au,backendName:"webgl",kernelFunc:Lte};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -16883,7 +16883,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Bte=` + */const Vte=` float s = sign(a) * sign(b); int ia = round(a); int ib = round(b); @@ -16893,7 +16893,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } else { return NAN; } -`,Vte=` +`,Wte=` ivec4 ia = round(a); ivec4 ib = round(b); bvec4 cond = notEqual(ib, ivec4(0)); @@ -16914,7 +16914,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam result[3] = idiv(ia[3], ib[3], s[3]); } return vec4(result); -`,Wte=rn({opSnippet:Bte,packedOpSnippet:Vte,dtype:"int32"}),Ute={kernelName:Du,backendName:"webgl",kernelFunc:Wte};/** +`,Ute=rn({opSnippet:Vte,packedOpSnippet:Wte,dtype:"int32"}),Gte={kernelName:Du,backendName:"webgl",kernelFunc:Ute};/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -16929,7 +16929,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class Gte{constructor(e){this.variableNames=["A"];const n=$n(),[s,r]=e;this.outputShape=e,this.userCode=` + */class Hte{constructor(e){this.variableNames=["A"];const n=$n(),[s,r]=e;this.outputShape=e,this.userCode=` void main() { ivec3 coords = getOutputCoords(); int texR = coords[0]; @@ -16966,7 +16966,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class Hte{constructor(e){this.variableNames=["A"],this.packedInputs=!1,this.packedOutput=!0;const n=$n(),[s,r]=e;this.outputShape=e,this.userCode=` + */class jte{constructor(e){this.variableNames=["A"],this.packedInputs=!1,this.packedOutput=!0;const n=$n(),[s,r]=e;this.outputShape=e,this.userCode=` void main() { ivec3 coords = getOutputCoords(); int texR = coords[0]; @@ -17015,7 +17015,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const jte={kernelName:UM,backendName:"webgl",kernelFunc:Kte};let la,Mg=W().getBool("CANVAS2D_WILL_READ_FREQUENTLY_FOR_GPU");function Kte(t){const{inputs:e,backend:n,attrs:s}=t;let{pixels:r}=e;const{numChannels:o}=s,i=typeof HTMLVideoElement<"u"&&r instanceof HTMLVideoElement,a=typeof HTMLImageElement<"u"&&r instanceof HTMLImageElement,[l,c]=i?[r.videoWidth,r.videoHeight]:[r.width,r.height],u=[c,l],d=[c,l,o];if(a||i){const g=W().getBool("CANVAS2D_WILL_READ_FREQUENTLY_FOR_GPU");(la==null||g!==Mg)&&(Mg=g,la=document.createElement("canvas").getContext("2d",{willReadFrequently:Mg})),la.canvas.width=l,la.canvas.height=c,la.drawImage(r,0,0,l,c),r=la.canvas}const h=n.makeTensorInfo(u,"int32");n.texData.get(h.dataId).usage=ns.PIXELS,n.gpgpu.uploadPixelDataToTexture(n.getTexture(h.dataId),r);const f=W().getBool("WEBGL_PACK")?new Hte(d):new Gte(d),p=n.runWebGLProgram(f,[h],"int32");return n.disposeData(h.dataId),p}/** + */const Kte={kernelName:GM,backendName:"webgl",kernelFunc:Xte};let la,Mg=W().getBool("CANVAS2D_WILL_READ_FREQUENTLY_FOR_GPU");function Xte(t){const{inputs:e,backend:n,attrs:s}=t;let{pixels:r}=e;const{numChannels:o}=s,i=typeof HTMLVideoElement<"u"&&r instanceof HTMLVideoElement,a=typeof HTMLImageElement<"u"&&r instanceof HTMLImageElement,[l,c]=i?[r.videoWidth,r.videoHeight]:[r.width,r.height],u=[c,l],h=[c,l,o];if(a||i){const g=W().getBool("CANVAS2D_WILL_READ_FREQUENTLY_FOR_GPU");(la==null||g!==Mg)&&(Mg=g,la=document.createElement("canvas").getContext("2d",{willReadFrequently:Mg})),la.canvas.width=l,la.canvas.height=c,la.drawImage(r,0,0,l,c),r=la.canvas}const d=n.makeTensorInfo(u,"int32");n.texData.get(d.dataId).usage=ns.PIXELS,n.gpgpu.uploadPixelDataToTexture(n.getTexture(d.dataId),r);const f=W().getBool("WEBGL_PACK")?new jte(h):new Hte(h),p=n.runWebGLProgram(f,[d],"int32");return n.disposeData(d.dataId),p}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17030,7 +17030,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Xte(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,filter:o,bias:i,preluActivationWeights:a}=e,{strides:l,pad:c,dataFormat:u,dilations:d,dimRoundingMode:h,activation:f,leakyreluAlpha:p}=s,g=Yr(u),x=nn(r.shape,o.shape,l,d,c,h,!1,g);let m;const y=[],w=i!=null,v=a!=null,b=f==="leakyrelu",C=()=>{const S=[r,o],$=(N,A)=>{if(A==="NCHW"&&N.shape.length===1&&N.shape[0]!==1){const M=re({inputs:{x:N},backend:n,attrs:{shape:[N.shape[0],1,1]}});return y.push(M),M}return N};if(w&&S.push($(i,u)),v&&S.push($(a,u)),b){const N=n.makeTensorInfo([],"float32",Wo(p,"float32"));S.push(N),y.push(N)}return S};if(x.filterHeight===1&&x.filterWidth===1&&x.dilationHeight===1&&x.dilationWidth===1&&x.strideHeight===1&&x.strideWidth===1&&(x.padInfo.type==="SAME"||x.padInfo.type==="VALID"))m=mD({x:r,filter:o,convInfo:x,backend:n,bias:i,activation:f,preluActivationWeights:a,leakyreluAlpha:p});else if(x.strideWidth<=2&&g==="channelsLast"&&W().getBool("WEBGL_EXP_CONV")){const S=f?tu(f,!0):null,$=new pD(x,w,S,v,b),N=[[x.padInfo.top,x.padInfo.left],[x.strideHeight,x.strideWidth],[x.dilationHeight,x.dilationWidth],[x.inHeight,x.inWidth]],A=C();m=n.runWebGLProgram($,A,"float32",N)}else if(W().getBool("WEBGL_CONV_IM2COL"))m=gD({x:r,filter:o,convInfo:x,backend:n,bias:i,activation:f,preluActivationWeights:a,leakyreluAlpha:p});else{const S=f?tu(f,!1):null,$=new fD(x,w,S,v,b),N=C();m=n.runWebGLProgram($,N,"float32")}const k=re({inputs:{x:m},backend:n,attrs:{shape:x.outShape}});return y.push(m),y.forEach(S=>n.disposeIntermediateTensorInfo(S)),k}const qte={kernelName:pf,backendName:"webgl",kernelFunc:Xte};/** + */function qte(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,filter:o,bias:i,preluActivationWeights:a}=e,{strides:l,pad:c,dataFormat:u,dilations:h,dimRoundingMode:d,activation:f,leakyreluAlpha:p}=s,g=Qr(u),x=nn(r.shape,o.shape,l,h,c,d,!1,g);let m;const y=[],w=i!=null,v=a!=null,b=f==="leakyrelu",C=()=>{const S=[r,o],$=(N,A)=>{if(A==="NCHW"&&N.shape.length===1&&N.shape[0]!==1){const M=re({inputs:{x:N},backend:n,attrs:{shape:[N.shape[0],1,1]}});return y.push(M),M}return N};if(w&&S.push($(i,u)),v&&S.push($(a,u)),b){const N=n.makeTensorInfo([],"float32",Wo(p,"float32"));S.push(N),y.push(N)}return S};if(x.filterHeight===1&&x.filterWidth===1&&x.dilationHeight===1&&x.dilationWidth===1&&x.strideHeight===1&&x.strideWidth===1&&(x.padInfo.type==="SAME"||x.padInfo.type==="VALID"))m=gD({x:r,filter:o,convInfo:x,backend:n,bias:i,activation:f,preluActivationWeights:a,leakyreluAlpha:p});else if(x.strideWidth<=2&&g==="channelsLast"&&W().getBool("WEBGL_EXP_CONV")){const S=f?tu(f,!0):null,$=new mD(x,w,S,v,b),N=[[x.padInfo.top,x.padInfo.left],[x.strideHeight,x.strideWidth],[x.dilationHeight,x.dilationWidth],[x.inHeight,x.inWidth]],A=C();m=n.runWebGLProgram($,A,"float32",N)}else if(W().getBool("WEBGL_CONV_IM2COL"))m=xD({x:r,filter:o,convInfo:x,backend:n,bias:i,activation:f,preluActivationWeights:a,leakyreluAlpha:p});else{const S=f?tu(f,!1):null,$=new pD(x,w,S,v,b),N=C();m=n.runWebGLProgram($,N,"float32")}const k=re({inputs:{x:m},backend:n,attrs:{shape:x.outShape}});return y.push(m),y.forEach(S=>n.disposeIntermediateTensorInfo(S)),k}const Yte={kernelName:pf,backendName:"webgl",kernelFunc:qte};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17045,7 +17045,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Yte(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,filter:o,bias:i,preluActivationWeights:a}=e,{strides:l,pad:c,dilations:u,dimRoundingMode:d,activation:h,leakyreluAlpha:f}=s,p=[];let g=u;g==null&&(g=[1,1]),I(hn(l,g),()=>`Error in depthwiseConv2d: Either strides or dilations must be 1. Got strides ${l} and dilations '${g}'`);const x=nn(r.shape,o.shape,l,g,c,d,!0),m=W().getBool("WEBGL_PACK_DEPTHWISECONV")&&x.strideWidth<=2&&x.outChannels/x.inChannels===1,y=h?tu(h,m):null,w=[r,o],v=i!=null,b=a!=null,C=h==="leakyrelu";if(v&&w.push(i),b&&w.push(a),C){const N=n.makeTensorInfo([],"float32",Wo(f,"float32"));w.push(N),p.push(N)}let k;m?k=new wD(x,v,y,b,C):k=new yD(x,v,y,b,C);const S=[[x.padInfo.top,x.padInfo.left],[x.strideHeight,x.strideWidth],[x.dilationHeight,x.dilationWidth],[x.inHeight,x.inWidth]],$=n.runWebGLProgram(k,w,"float32",S);return p.forEach(N=>n.disposeIntermediateTensorInfo(N)),$}const Qte={kernelName:y$,backendName:"webgl",kernelFunc:Yte};class Zte{constructor(e,n,s,r){this.sliceDim=e,this.strides=n,this.paramsShape=r,this.variableNames=["x","indices"],this.outputShape=s;const o=Ze(s.length);let i=` + */function Qte(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,filter:o,bias:i,preluActivationWeights:a}=e,{strides:l,pad:c,dilations:u,dimRoundingMode:h,activation:d,leakyreluAlpha:f}=s,p=[];let g=u;g==null&&(g=[1,1]),I(dn(l,g),()=>`Error in depthwiseConv2d: Either strides or dilations must be 1. Got strides ${l} and dilations '${g}'`);const x=nn(r.shape,o.shape,l,g,c,h,!0),m=W().getBool("WEBGL_PACK_DEPTHWISECONV")&&x.strideWidth<=2&&x.outChannels/x.inChannels===1,y=d?tu(d,m):null,w=[r,o],v=i!=null,b=a!=null,C=d==="leakyrelu";if(v&&w.push(i),b&&w.push(a),C){const N=n.makeTensorInfo([],"float32",Wo(f,"float32"));w.push(N),p.push(N)}let k;m?k=new vD(x,v,y,b,C):k=new wD(x,v,y,b,C);const S=[[x.padInfo.top,x.padInfo.left],[x.strideHeight,x.strideWidth],[x.dilationHeight,x.dilationWidth],[x.inHeight,x.inWidth]],$=n.runWebGLProgram(k,w,"float32",S);return p.forEach(N=>n.disposeIntermediateTensorInfo(N)),$}const Zte={kernelName:w$,backendName:"webgl",kernelFunc:Qte};class Jte{constructor(e,n,s,r){this.sliceDim=e,this.strides=n,this.paramsShape=r,this.variableNames=["x","indices"],this.outputShape=s;const o=Ze(s.length);let i=` int index;`;for(let a=0;a= 0) && (index < ${e[2]}) ? 1.0 : 0.0; setOutput(inBounds * getA(${r})); } - `}}function nne(t,e){const n=["resRC.x","resRC.y","resRC.z","resRC.w"],s=[];for(let r=0;r=0,()=>`GatherV2: the index value ${b} is not in [0, ${w-1}]`)}}const c=Ww(r,o,l,a),u=j(o.shape),d=[],h=re({inputs:{x:r},backend:n,attrs:{shape:[c.batchSize,c.outerSize,c.dimSize,c.sliceSize]}}),f=re({inputs:{x:o},backend:n,attrs:{shape:[c.batchSize,u/c.batchSize]}});d.push(h),d.push(f);const p=[c.batchSize,c.outerSize,u/c.batchSize,c.sliceSize];if(n.shouldExecuteOnCPU([r,o])||r.dtype==="string"){const y=n.bufferSync(f),w=n.bufferSync(h),v=rQ(w,y,p);return d.forEach(b=>n.disposeIntermediateTensorInfo(b)),n.makeTensorInfo(c.outputShape,v.dtype,v.values)}const g=new tne(h.shape,p),x=n.runWebGLProgram(g,[h,f],h.dtype);d.push(x);const m=re({inputs:{x},backend:n,attrs:{shape:c.outputShape}});return d.forEach(y=>n.disposeIntermediateTensorInfo(y)),m}const sne={kernelName:Dp,backendName:"webgl",kernelFunc:CD};/** + */function kD(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,indices:o}=e,{axis:i,batchDims:a}=s,l=Re(i,r.shape)[0];if(W().get("DEBUG")){const y=n.readSync(o.dataId),w=r.shape[l];for(let v=0;v=0,()=>`GatherV2: the index value ${b} is not in [0, ${w-1}]`)}}const c=Ww(r,o,l,a),u=j(o.shape),h=[],d=re({inputs:{x:r},backend:n,attrs:{shape:[c.batchSize,c.outerSize,c.dimSize,c.sliceSize]}}),f=re({inputs:{x:o},backend:n,attrs:{shape:[c.batchSize,u/c.batchSize]}});h.push(d),h.push(f);const p=[c.batchSize,c.outerSize,u/c.batchSize,c.sliceSize];if(n.shouldExecuteOnCPU([r,o])||r.dtype==="string"){const y=n.bufferSync(f),w=n.bufferSync(d),v=oQ(w,y,p);return h.forEach(b=>n.disposeIntermediateTensorInfo(b)),n.makeTensorInfo(c.outputShape,v.dtype,v.values)}const g=new nne(d.shape,p),x=n.runWebGLProgram(g,[d,f],d.dtype);h.push(x);const m=re({inputs:{x},backend:n,attrs:{shape:c.outputShape}});return h.forEach(y=>n.disposeIntermediateTensorInfo(y)),m}const rne={kernelName:Dp,backendName:"webgl",kernelFunc:kD};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17127,9 +17127,9 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const rne="return float(a > b);",one=` + */const one="return float(a > b);",ine=` return vec4(greaterThan(a, b)); -`,ine=rn({opSnippet:rne,packedOpSnippet:one,cpuKernelImpl:oQ,dtype:"bool"}),ane={kernelName:_p,backendName:"webgl",kernelFunc:ine};/** +`,ane=rn({opSnippet:one,packedOpSnippet:ine,cpuKernelImpl:iQ,dtype:"bool"}),lne={kernelName:_p,backendName:"webgl",kernelFunc:ane};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17144,9 +17144,9 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const lne="return float(a >= b);",cne=` + */const cne="return float(a >= b);",une=` return vec4(greaterThanEqual(a, b)); -`,une=rn({opSnippet:lne,packedOpSnippet:cne,dtype:"bool",cpuKernelImpl:iQ}),dne={kernelName:_u,backendName:"webgl",kernelFunc:une};/** +`,hne=rn({opSnippet:cne,packedOpSnippet:une,dtype:"bool",cpuKernelImpl:aQ}),dne={kernelName:_u,backendName:"webgl",kernelFunc:hne};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17161,7 +17161,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function hne(t){const{inputs:e,backend:n}=t,{input:s}=e;return bD(s,!0,n)}const fne={kernelName:hy,backendName:"webgl",kernelFunc:hne};/** + */function fne(t){const{inputs:e,backend:n}=t,{input:s}=e;return CD(s,!0,n)}const pne={kernelName:dy,backendName:"webgl",kernelFunc:fne};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17176,7 +17176,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const pne="return float(!isnan(x) && !isinf(x));",mne=Oe({opSnippet:pne,dtype:"bool"}),gne={kernelName:zu,backendName:"webgl",kernelFunc:mne};/** + */const mne="return float(!isnan(x) && !isinf(x));",gne=Oe({opSnippet:mne,dtype:"bool"}),xne={kernelName:zu,backendName:"webgl",kernelFunc:gne};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17191,7 +17191,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const xne="return float(isinf(x));",yne=Oe({opSnippet:xne,dtype:"bool"}),wne={kernelName:Ou,backendName:"webgl",kernelFunc:yne};/** + */const yne="return float(isinf(x));",wne=Oe({opSnippet:yne,dtype:"bool"}),vne={kernelName:Ou,backendName:"webgl",kernelFunc:wne};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17206,7 +17206,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const vne="return float(isnan(x));",bne=Oe({opSnippet:vne,dtype:"bool"}),Cne={kernelName:Mu,backendName:"webgl",kernelFunc:bne};/** + */const bne="return float(isnan(x));",Cne=Oe({opSnippet:bne,dtype:"bool"}),kne={kernelName:Mu,backendName:"webgl",kernelFunc:Cne};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17221,9 +17221,9 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const kne="return float(a < b);",Sne=` + */const Sne="return float(a < b);",Ine=` return vec4(lessThan(a, b)); -`,Ine=rn({opSnippet:kne,packedOpSnippet:Sne,cpuKernelImpl:aQ,dtype:"bool"}),$ne={kernelName:zp,backendName:"webgl",kernelFunc:Ine};/** +`,$ne=rn({opSnippet:Sne,packedOpSnippet:Ine,cpuKernelImpl:lQ,dtype:"bool"}),Nne={kernelName:zp,backendName:"webgl",kernelFunc:$ne};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17238,9 +17238,9 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Nne="return float(a <= b);",Tne=` + */const Tne="return float(a <= b);",Ene=` return vec4(lessThanEqual(a, b)); -`,Ene=rn({opSnippet:Nne,packedOpSnippet:Tne,cpuKernelImpl:lQ,dtype:"bool"}),Rne={kernelName:Op,backendName:"webgl",kernelFunc:Ene};/** +`,Rne=rn({opSnippet:Tne,packedOpSnippet:Ene,cpuKernelImpl:cQ,dtype:"bool"}),Ane={kernelName:Op,backendName:"webgl",kernelFunc:Rne};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17255,7 +17255,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Ane(t){const{backend:e,attrs:n}=t,{start:s,stop:r,num:o}=n,i=cQ(s,r,o);return e.makeTensorInfo([i.length],"float32",i)}const Dne={kernelName:t$,backendName:"webgl",kernelFunc:Ane};/** + */function Dne(t){const{backend:e,attrs:n}=t,{start:s,stop:r,num:o}=n,i=uQ(s,r,o);return e.makeTensorInfo([i.length],"float32",i)}const _ne={kernelName:n$,backendName:"webgl",kernelFunc:Dne};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17270,9 +17270,9 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const _ne=_l+` + */const Fne=_l+` return x < 0.0 ? 0./0. : log(x); -`,Fne=` +`,zne=` vec4 result = log(x); bvec4 isNaN = isnan(x); result.r = isNaN.r ? x.r : (x.r < 0.0 ? 0./0. : result.r); @@ -17280,7 +17280,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam result.b = isNaN.b ? x.b : (x.b < 0.0 ? 0./0. : result.b); result.a = isNaN.a ? x.a : (x.a < 0.0 ? 0./0. : result.a); return result; -`,zne=Oe({opSnippet:_ne,packedOpSnippet:Fne,cpuKernelImpl:uQ}),One={kernelName:Pu,backendName:"webgl",kernelFunc:zne};/** +`,One=Oe({opSnippet:Fne,packedOpSnippet:zne,cpuKernelImpl:hQ}),Mne={kernelName:Pu,backendName:"webgl",kernelFunc:One};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17295,9 +17295,9 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Mne=_l+` + */const Pne=_l+` return log(1.0 + x); -`,Pne=Oe({opSnippet:Mne}),Lne={kernelName:Lu,backendName:"webgl",kernelFunc:Pne};/** +`,Lne=Oe({opSnippet:Pne}),Bne={kernelName:Lu,backendName:"webgl",kernelFunc:Lne};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17312,11 +17312,11 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Bne="return float(a >= 1.0 && b >= 1.0);",Vne=` + */const Vne="return float(a >= 1.0 && b >= 1.0);",Wne=` return vec4( vec4(greaterThanEqual(a, vec4(1.0))) * vec4(greaterThanEqual(b, vec4(1.0)))); -`,Wne=rn({opSnippet:Bne,packedOpSnippet:Vne,dtype:"bool"}),Une={kernelName:Mp,backendName:"webgl",kernelFunc:Wne};/** +`,Une=rn({opSnippet:Vne,packedOpSnippet:Wne,dtype:"bool"}),Gne={kernelName:Mp,backendName:"webgl",kernelFunc:Une};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17331,7 +17331,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Gne="return float(!(x >= 1.0));",Hne=Oe({opSnippet:Gne}),jne={kernelName:Pp,backendName:"webgl",kernelFunc:Hne};/** + */const Hne="return float(!(x >= 1.0));",jne=Oe({opSnippet:Hne}),Kne={kernelName:Pp,backendName:"webgl",kernelFunc:jne};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17346,12 +17346,12 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Kne="return float(a >= 1.0 || b >= 1.0);",Xne=` + */const Xne="return float(a >= 1.0 || b >= 1.0);",qne=` return min( vec4(greaterThanEqual(a, vec4(1.0))) + vec4(greaterThanEqual(b, vec4(1.0))), vec4(1.0)); -`,qne=rn({opSnippet:Kne,packedOpSnippet:Xne,dtype:"bool"}),Yne={kernelName:Lp,backendName:"webgl",kernelFunc:qne};/** +`,Yne=rn({opSnippet:Xne,packedOpSnippet:qne,dtype:"bool"}),Qne={kernelName:Lp,backendName:"webgl",kernelFunc:Yne};/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17366,7 +17366,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class Qne{constructor(e,n,s,r,o){this.variableNames=["x"],this.outputShape=[];const i=n,a=e[3]-1;this.outputShape=e;let l;const c=`float(${s}) + float(${r}) * sum`;o===.5?l=`inversesqrt(${c})`:o===1?l=`1.0/(${c})`:l=`exp(log(${c}) * float(-${o}));`,this.userCode=` + */class Zne{constructor(e,n,s,r,o){this.variableNames=["x"],this.outputShape=[];const i=n,a=e[3]-1;this.outputShape=e;let l;const c=`float(${s}) + float(${r}) * sum`;o===.5?l=`inversesqrt(${c})`:o===1?l=`1.0/(${c})`:l=`exp(log(${c}) * float(-${o}));`,this.userCode=` void main() { ivec4 coords = getOutputCoords(); int b = coords[0]; @@ -17400,7 +17400,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class Zne{constructor(e,n,s,r,o){this.variableNames=["x"],this.outputShape=[],this.packedInputs=!0,this.packedOutput=!0;const i=n,a=e[3]-1;this.outputShape=e;let l;const c=`float(${s}) + float(${r}) * sum`;o===.5?l=`inversesqrt(${c})`:o===1?l=`1.0/(${c})`:l=`exp(log(${c}) * float(-${o}));`,this.userCode=` + */class Jne{constructor(e,n,s,r,o){this.variableNames=["x"],this.outputShape=[],this.packedInputs=!0,this.packedOutput=!0;const i=n,a=e[3]-1;this.outputShape=e;let l;const c=`float(${s}) + float(${r}) * sum`;o===.5?l=`inversesqrt(${c})`:o===1?l=`1.0/(${c})`:l=`exp(log(${c}) * float(-${o}));`,this.userCode=` void main() { ivec4 coords = getOutputCoords(); int b = coords.x; @@ -17477,7 +17477,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Jne=t=>{const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{depthRadius:o,bias:i,alpha:a,beta:l}=s,c=W().getBool("WEBGL_PACK_NORMALIZATION")?new Zne(r.shape,o,i,a,l):new Qne(r.shape,o,i,a,l);return n.runWebGLProgram(c,[r],r.dtype)},ese={kernelName:Bp,backendName:"webgl",kernelFunc:Jne};/** + */const ese=t=>{const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{depthRadius:o,bias:i,alpha:a,beta:l}=s,c=W().getBool("WEBGL_PACK_NORMALIZATION")?new Jne(r.shape,o,i,a,l):new Zne(r.shape,o,i,a,l);return n.runWebGLProgram(c,[r],r.dtype)},tse={kernelName:Bp,backendName:"webgl",kernelFunc:ese};/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17492,7 +17492,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class tse{constructor(e,n,s,r,o){this.variableNames=["inputImage","outputImage","dy"],this.outputShape=[],this.outputShape=e,this.depth=e[3],this.depthRadius=n,this.bias=s,this.alpha=r,this.beta=o,this.userCode=` + */class nse{constructor(e,n,s,r,o){this.variableNames=["inputImage","outputImage","dy"],this.outputShape=[],this.outputShape=e,this.depth=e[3],this.depthRadius=n,this.bias=s,this.alpha=r,this.beta=o,this.userCode=` void main() { ivec4 coords = getOutputCoords(); int b = coords[0]; @@ -17562,7 +17562,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const nse=t=>{const{inputs:e,backend:n,attrs:s}=t,{x:r,y:o,dy:i}=e,{depthRadius:a,bias:l,alpha:c,beta:u}=s,d=new tse(r.shape,a,l,c,u);return n.runWebGLProgram(d,[r,o,i],r.dtype)},sse={kernelName:py,backendName:"webgl",kernelFunc:nse};/** + */const sse=t=>{const{inputs:e,backend:n,attrs:s}=t,{x:r,y:o,dy:i}=e,{depthRadius:a,bias:l,alpha:c,beta:u}=s,h=new nse(r.shape,a,l,c,u);return n.runWebGLProgram(h,[r,o,i],r.dtype)},rse={kernelName:py,backendName:"webgl",kernelFunc:sse};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17577,7 +17577,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function rse(t,e,n,s){const r=j(e),i=j(t.shape)/r,a=re({inputs:{x:t},attrs:{shape:[i,r]},backend:s}),l=sa(a,t.dtype,"max",s),c=re({inputs:{x:l},attrs:{shape:n},backend:s});return s.disposeIntermediateTensorInfo(a),s.disposeIntermediateTensorInfo(l),c}/** + */function ose(t,e,n,s){const r=j(e),i=j(t.shape)/r,a=re({inputs:{x:t},attrs:{shape:[i,r]},backend:s}),l=sa(a,t.dtype,"max",s),c=re({inputs:{x:l},attrs:{shape:n},backend:s});return s.disposeIntermediateTensorInfo(a),s.disposeIntermediateTensorInfo(l),c}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17592,7 +17592,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function kD(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{reductionIndices:o,keepDims:i}=s,a=r.shape.length,l=Re(o,r.shape);let c=l;const u=yt(c,a),d=u!=null,h=n.shouldExecuteOnCPU([r]);let f=r;if(d){if(h){const w=n.texData.get(f.dataId).values,v=new Array(a);for(let k=0;k`Error in maxPool: Either strides or dilations must be 1. Got strides ${i} and dilations '${c}'`);const u=Rs(r.shape,o,i,c,a,l);if(u.filterWidth===1&&u.filterHeight===1&&Ue(u.inShape,u.outShape))return Yn({inputs:{x:r},backend:n});const d=new nu(u,"max",!1);return n.runWebGLProgram(d,[r],r.dtype)}const dse={kernelName:Wp,backendName:"webgl",kernelFunc:use};/** + */function hse(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e;Eh(r,"maxPool");const{filterSize:o,strides:i,pad:a,dimRoundingMode:l}=s,c=1;I(dn(i,c),()=>`Error in maxPool: Either strides or dilations must be 1. Got strides ${i} and dilations '${c}'`);const u=As(r.shape,o,i,c,a,l);if(u.filterWidth===1&&u.filterHeight===1&&Ue(u.inShape,u.outShape))return Yn({inputs:{x:r},backend:n});const h=new nu(u,"max",!1);return n.runWebGLProgram(h,[r],r.dtype)}const dse={kernelName:Wp,backendName:"webgl",kernelFunc:hse};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17646,7 +17646,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function hse(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{filterSize:o,strides:i,pad:a,dataFormat:l,dimRoundingMode:c}=s,u=[1,1,1],d=qr(r.shape,o,i,u,a,c,l),h=new Nv(d,"max",!1);return n.runWebGLProgram(h,[r],r.dtype)}const fse={kernelName:Up,backendName:"webgl",kernelFunc:hse};/** + */function fse(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{filterSize:o,strides:i,pad:a,dataFormat:l,dimRoundingMode:c}=s,u=[1,1,1],h=Yr(r.shape,o,i,u,a,c,l),d=new Nv(h,"max",!1);return n.runWebGLProgram(d,[r],r.dtype)}const pse={kernelName:Up,backendName:"webgl",kernelFunc:fse};/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17661,7 +17661,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class pse{constructor(e){this.variableNames=["dy","maxPos"],this.outputShape=e.inShape;const n=e.strideHeight,s=e.strideWidth,r=e.dilationHeight,o=e.effectiveFilterHeight,i=e.effectiveFilterWidth,a=o-1-e.padInfo.top,l=i-1-e.padInfo.left,c=o*i-1;this.userCode=` + */class mse{constructor(e){this.variableNames=["dy","maxPos"],this.outputShape=e.inShape;const n=e.strideHeight,s=e.strideWidth,r=e.dilationHeight,o=e.effectiveFilterHeight,i=e.effectiveFilterWidth,a=o-1-e.padInfo.top,l=i-1-e.padInfo.left,c=o*i-1;this.userCode=` const ivec2 pads = ivec2(${a}, ${l}); void main() { @@ -17707,8 +17707,8 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam } setOutput(dotProd); } - `}}class mse{constructor(e){this.variableNames=["dy","maxPos"],this.outputShape=e.inShape;const n=e.strideDepth,s=e.strideHeight,r=e.strideWidth,o=e.dilationDepth,i=e.dilationHeight,a=e.dilationWidth,l=e.effectiveFilterDepth,c=e.effectiveFilterHeight,u=e.effectiveFilterWidth,d=l-1-e.padInfo.front,h=c-1-e.padInfo.top,f=u-1-e.padInfo.left,p=l*c*u-1;this.userCode=` - const ivec3 pads = ivec3(${d}, ${h}, ${f}); + `}}class gse{constructor(e){this.variableNames=["dy","maxPos"],this.outputShape=e.inShape;const n=e.strideDepth,s=e.strideHeight,r=e.strideWidth,o=e.dilationDepth,i=e.dilationHeight,a=e.dilationWidth,l=e.effectiveFilterDepth,c=e.effectiveFilterHeight,u=e.effectiveFilterWidth,h=l-1-e.padInfo.front,d=c-1-e.padInfo.top,f=u-1-e.padInfo.left,p=l*c*u-1;this.userCode=` + const ivec3 pads = ivec3(${h}, ${d}, ${f}); void main() { ivec5 coords = getOutputCoords(); @@ -17786,7 +17786,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function gse(t){const{inputs:e,backend:n,attrs:s}=t,{dy:r,input:o}=e,i=o,{filterSize:a,strides:l,pad:c,dimRoundingMode:u}=s,d=[1,1,1],h=qr(i.shape,a,l,d,c,u),f=new Nv(h,"max",!0),p=n.runWebGLProgram(f,[i],i.dtype),g=new mse(h),x=n.runWebGLProgram(g,[r,p],i.dtype);return n.disposeIntermediateTensorInfo(p),x}const xse={kernelName:gy,backendName:"webgl",kernelFunc:gse};/** + */function xse(t){const{inputs:e,backend:n,attrs:s}=t,{dy:r,input:o}=e,i=o,{filterSize:a,strides:l,pad:c,dimRoundingMode:u}=s,h=[1,1,1],d=Yr(i.shape,a,l,h,c,u),f=new Nv(d,"max",!0),p=n.runWebGLProgram(f,[i],i.dtype),g=new gse(d),x=n.runWebGLProgram(g,[r,p],i.dtype);return n.disposeIntermediateTensorInfo(p),x}const yse={kernelName:gy,backendName:"webgl",kernelFunc:xse};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17801,7 +17801,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function yse(t){const{inputs:e,backend:n,attrs:s}=t,{dy:r,input:o,output:i}=e,a=o;Ed([o,i],"maxPoolGrad");const{filterSize:l,strides:c,pad:u,dimRoundingMode:d}=s,h=Rs(a.shape,l,c,1,u,d),f=!0,p=new nu(h,"max",f),g=n.runWebGLProgram(p,[a],a.dtype),x=new pse(h),m=n.runWebGLProgram(x,[r,g],a.dtype);return n.disposeIntermediateTensorInfo(g),m}const wse={kernelName:my,backendName:"webgl",kernelFunc:yse};/** + */function wse(t){const{inputs:e,backend:n,attrs:s}=t,{dy:r,input:o,output:i}=e,a=o;Eh([o,i],"maxPoolGrad");const{filterSize:l,strides:c,pad:u,dimRoundingMode:h}=s,d=As(a.shape,l,c,1,u,h),f=!0,p=new nu(d,"max",f),g=n.runWebGLProgram(p,[a],a.dtype),x=new mse(d),m=n.runWebGLProgram(x,[r,g],a.dtype);return n.disposeIntermediateTensorInfo(g),m}const vse={kernelName:my,backendName:"webgl",kernelFunc:wse};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17816,7 +17816,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function vse(t,e,n,s){let r=new nu(n,"max",!1);const o=s.runWebGLProgram(r,[t],"float32");r=new nu(n,"max",!0,!0,e);const i=s.runWebGLProgram(r,[t],"float32");return[o,i]}/** + */function bse(t,e,n,s){let r=new nu(n,"max",!1);const o=s.runWebGLProgram(r,[t],"float32");r=new nu(n,"max",!0,!0,e);const i=s.runWebGLProgram(r,[t],"float32");return[o,i]}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17831,7 +17831,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const bse={kernelName:n$,backendName:"webgl",kernelFunc:({inputs:t,attrs:e,backend:n})=>{const{x:s}=t,{filterSize:r,strides:o,pad:i,includeBatchInIndex:a}=e,l=n;I(s.shape.length===4,()=>`Error in maxPool: input must be rank 4 but got rank ${s.shape.length}.`);const c=[1,1];I(hn(o,c),()=>`Error in maxPool: Either strides or dilations must be 1. Got strides ${o} and dilations '${c}'`);const u=Rs(s.shape,r,o,c,i),[d,h]=vse(s,a,u,l);return[d,h]}};/** + */const Cse={kernelName:s$,backendName:"webgl",kernelFunc:({inputs:t,attrs:e,backend:n})=>{const{x:s}=t,{filterSize:r,strides:o,pad:i,includeBatchInIndex:a}=e,l=n;I(s.shape.length===4,()=>`Error in maxPool: input must be rank 4 but got rank ${s.shape.length}.`);const c=[1,1];I(dn(o,c),()=>`Error in maxPool: Either strides or dilations must be 1. Got strides ${o} and dilations '${c}'`);const u=As(s.shape,r,o,c,i),[h,d]=bse(s,a,u,l);return[h,d]}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17846,7 +17846,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Cse(t,e,n,s){const r=j(e),i=j(t.shape)/r,a=re({inputs:{x:t},attrs:{shape:[i,r]},backend:s}),l=sa(a,"float32","mean",s),c=re({inputs:{x:l},attrs:{shape:n},backend:s});return s.disposeIntermediateTensorInfo(a),s.disposeIntermediateTensorInfo(l),c}/** + */function kse(t,e,n,s){const r=j(e),i=j(t.shape)/r,a=re({inputs:{x:t},attrs:{shape:[i,r]},backend:s}),l=sa(a,"float32","mean",s),c=re({inputs:{x:l},attrs:{shape:n},backend:s});return s.disposeIntermediateTensorInfo(a),s.disposeIntermediateTensorInfo(l),c}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17861,7 +17861,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const kse={kernelName:Gp,backendName:"webgl",kernelFunc:({inputs:t,attrs:e,backend:n})=>{const{x:s}=t,{keepDims:r,axis:o}=e,i=n,a=s.shape.length,l=Re(o,s.shape);let c=l;const u=yt(c,a),d=u!=null,h=i.shouldExecuteOnCPU([s]),f=[];let p=s;if(d){if(h){const v=i.texData.get(p.dataId).values,b=new Array(a);for(let S=0;S{const{x:s}=t,{keepDims:r,axis:o}=e,i=n,a=s.shape.length,l=Re(o,s.shape);let c=l;const u=yt(c,a),h=u!=null,d=i.shouldExecuteOnCPU([s]),f=[];let p=s;if(h){if(d){const v=i.texData.get(p.dataId).values,b=new Array(a);for(let S=0;Su[0]+e[d]+u[1]);const r=e.length,o=Ze(r),i=n.map(u=>u[0]).join(","),a=n.map((u,d)=>u[0]+e[d]).join(","),l=["coords[0]","coords[1]","coords[2]","coords[3]"].slice(0,r),c=s==="reflect"?0:1;if(r===1){this.userCode=` + */class Ase{constructor(e,n,s){this.variableNames=["x"],this.outputShape=n.map((u,h)=>u[0]+e[h]+u[1]);const r=e.length,o=Ze(r),i=n.map(u=>u[0]).join(","),a=n.map((u,h)=>u[0]+e[h]).join(","),l=["coords[0]","coords[1]","coords[2]","coords[3]"].slice(0,r),c=s==="reflect"?0:1;if(r===1){this.userCode=` int start = ${i}; int end = ${a}; @@ -17959,22 +17959,22 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class Ase{constructor(e,n,s){this.variableNames=["x"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=n.map((p,g)=>p[0]+e[g]+p[1]);const r=e.length,o=Ze(r),i=n.map(p=>p[0]).join(","),a=n.map((p,g)=>p[0]+e[g]).join(","),l=vn("rc",r),c=vn("source",r),u=`${l[r-1]} < ${this.outputShape[r-1]}`,d=r===1?"source":`vec2(${c.slice(-2).join()})`,h=s==="reflect"?0:1;let f="";if(r===1){const p=` + */class Dse{constructor(e,n,s){this.variableNames=["x"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=n.map((p,g)=>p[0]+e[g]+p[1]);const r=e.length,o=Ze(r),i=n.map(p=>p[0]).join(","),a=n.map((p,g)=>p[0]+e[g]).join(","),l=vn("rc",r),c=vn("source",r),u=`${l[r-1]} < ${this.outputShape[r-1]}`,h=r===1?"source":`vec2(${c.slice(-2).join()})`,d=s==="reflect"?0:1;let f="";if(r===1){const p=` ${o} source = rc; if (source < start) { - source = start * 2 - source - ${h}; + source = start * 2 - source - ${d}; } else if (source >= end) { - source = (end - 1) * 2 - source + ${h}; + source = (end - 1) * 2 - source + ${d}; } source -= start; `;f=` ${o} rc = outputLoc; ${p} - result[0] = getChannel(getX(${c.join()}), ${d}); + result[0] = getChannel(getX(${c.join()}), ${h}); ${l[r-1]} += 1; if(${u}) { ${p} - result[1] = getChannel(getX(${c.join()}), ${d}); + result[1] = getChannel(getX(${c.join()}), ${h}); } `}else{const p=` ${o} source = rc; @@ -17982,27 +17982,27 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam ${o} gte = ${o}(greaterThanEqual(source, end)); ${o} orig = 1 - (lt + gte); source = orig * source + - lt * (start * 2 - source - ${h}) + - gte * ((end - 1) * 2 - source + ${h}); + lt * (start * 2 - source - ${d}) + + gte * ((end - 1) * 2 - source + ${d}); source -= start; `;f=` ${o} rc = outputLoc; ${p} - result[0] = getChannel(getX(${c.join()}), ${d}); + result[0] = getChannel(getX(${c.join()}), ${h}); ${l[r-1]} += 1; if(${u}) { ${p} - result[1] = getChannel(getX(${c.join()}), ${d}); + result[1] = getChannel(getX(${c.join()}), ${h}); } rc = outputLoc; ${l[r-2]} += 1; if(${l[r-2]} < ${this.outputShape[r-2]}) { ${p} - result[2] = getChannel(getX(${c.join()}), ${d}); + result[2] = getChannel(getX(${c.join()}), ${h}); ${l[r-1]} += 1; if(${u}) { ${p} - result[3] = getChannel(getX(${c.join()}), ${d}); + result[3] = getChannel(getX(${c.join()}), ${h}); } } `}this.userCode=` @@ -18030,7 +18030,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Dse=({inputs:t,backend:e,attrs:n})=>{const{x:s}=t,{paddings:r,mode:o}=n,i=W().getBool("WEBGL_PACK_ARRAY_OPERATIONS")?new Ase(s.shape,r,o):new Rse(s.shape,r,o);return e.runWebGLProgram(i,[s],s.dtype)},_se={kernelName:jp,backendName:"webgl",kernelFunc:Dse};/** + */const _se=({inputs:t,backend:e,attrs:n})=>{const{x:s}=t,{paddings:r,mode:o}=n,i=W().getBool("WEBGL_PACK_ARRAY_OPERATIONS")?new Dse(s.shape,r,o):new Ase(s.shape,r,o);return e.runWebGLProgram(i,[s],s.dtype)},Fse={kernelName:jp,backendName:"webgl",kernelFunc:_se};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18045,13 +18045,13 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Fse=`if (b == 0.0) return NAN; - return mod(a, b);`,zse=` + */const zse=`if (b == 0.0) return NAN; + return mod(a, b);`,Ose=` vec4 result = mod(a, b); bvec4 isNaN = equal(b, vec4(0.0)); `+na+` return result; -`,Ose=rn({opSnippet:Fse,packedOpSnippet:zse}),Mse={kernelName:Wu,backendName:"webgl",kernelFunc:Ose};/** +`,Mse=rn({opSnippet:zse,packedOpSnippet:Ose}),Pse={kernelName:Wu,backendName:"webgl",kernelFunc:Mse};/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18066,7 +18066,7 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class Pse{constructor(e,n,s){this.variableNames=["probs"],this.customUniforms=[{name:"seed",type:"float"}],this.outputShape=[e,s],this.userCode=` + */class Lse{constructor(e,n,s){this.variableNames=["probs"],this.customUniforms=[{name:"seed",type:"float"}],this.outputShape=[e,s],this.userCode=` void main() { ivec2 coords = getOutputCoords(); int batch = coords[0]; @@ -18101,11 +18101,11 @@ return (log(1.0 + x) - log(1.0 - x)) / 2.0;`,hJ=Oe({opSnippet:dJ}),fJ={kernelNam * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Lse=` + */const Bse=` if (a == b) { return 1.0; }; -return a / b;`,Bse=` +return a / b;`,Vse=` // vec4 one = vec4(equal(a, b)); // return one + (vec4(1.0) - one) * a / b; vec4 result = a / b; @@ -18123,7 +18123,7 @@ return a / b;`,Bse=` } return result; -`,SD=rn({opSnippet:Lse,packedOpSnippet:Bse,checkOutOfBounds:!0}),Vse={kernelName:$u,backendName:"webgl",kernelFunc:SD};/** +`,ID=rn({opSnippet:Bse,packedOpSnippet:Vse,checkOutOfBounds:!0}),Wse={kernelName:$u,backendName:"webgl",kernelFunc:ID};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18138,7 +18138,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Hk="return a - b;",ID=rn({opSnippet:Hk,packedOpSnippet:Hk,supportsComplex:!0,cpuKernelImpl:FQ}),Wse={kernelName:rd,backendName:"webgl",kernelFunc:ID};/** + */const Hk="return a - b;",$D=rn({opSnippet:Hk,packedOpSnippet:Hk,supportsComplex:!0,cpuKernelImpl:zQ}),Use={kernelName:rh,backendName:"webgl",kernelFunc:$D};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18153,7 +18153,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function $D(t){const{inputs:e,backend:n,attrs:s}=t,{logits:r}=e,{dim:o}=s,i=Re([o],r.shape),a=kD({inputs:{x:r},backend:n,attrs:{reductionIndices:i,keepDims:!1}}),l=Dt(a.shape,i),c=re({inputs:{x:a},backend:n,attrs:{shape:l}}),u=ID({inputs:{a:r,b:c},backend:n}),d=vD({inputs:{x:u},backend:n}),h=Bm({inputs:{x:d},backend:n,attrs:{axis:i,keepDims:!1}}),f=re({inputs:{x:h},backend:n,attrs:{shape:l}}),p=SD({inputs:{a:d,b:f},backend:n});return n.disposeIntermediateTensorInfo(a),n.disposeIntermediateTensorInfo(c),n.disposeIntermediateTensorInfo(u),n.disposeIntermediateTensorInfo(d),n.disposeIntermediateTensorInfo(h),n.disposeIntermediateTensorInfo(f),p}const Use={kernelName:um,backendName:"webgl",kernelFunc:$D};/** + */function ND(t){const{inputs:e,backend:n,attrs:s}=t,{logits:r}=e,{dim:o}=s,i=Re([o],r.shape),a=SD({inputs:{x:r},backend:n,attrs:{reductionIndices:i,keepDims:!1}}),l=Dt(a.shape,i),c=re({inputs:{x:a},backend:n,attrs:{shape:l}}),u=$D({inputs:{a:r,b:c},backend:n}),h=bD({inputs:{x:u},backend:n}),d=Bm({inputs:{x:h},backend:n,attrs:{axis:i,keepDims:!1}}),f=re({inputs:{x:d},backend:n,attrs:{shape:l}}),p=ID({inputs:{a:h,b:f},backend:n});return n.disposeIntermediateTensorInfo(a),n.disposeIntermediateTensorInfo(c),n.disposeIntermediateTensorInfo(u),n.disposeIntermediateTensorInfo(h),n.disposeIntermediateTensorInfo(d),n.disposeIntermediateTensorInfo(f),p}const Gse={kernelName:um,backendName:"webgl",kernelFunc:ND};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18168,7 +18168,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Gse(t){const{inputs:e,backend:n,attrs:s}=t,{logits:r}=e,{numSamples:o,seed:i,normalized:a}=s,l=a?r:$D({inputs:{logits:r},backend:n,attrs:{dim:r.shape.length-1}}),c=l.shape[0],u=l.shape[1],d=new Pse(c,u,o),h=[[i]],f=n.runWebGLProgram(d,[l],"int32",h);return a||n.disposeIntermediateTensorInfo(l),f}const Hse={kernelName:s$,backendName:"webgl",kernelFunc:Gse};/** + */function Hse(t){const{inputs:e,backend:n,attrs:s}=t,{logits:r}=e,{numSamples:o,seed:i,normalized:a}=s,l=a?r:ND({inputs:{logits:r},backend:n,attrs:{dim:r.shape.length-1}}),c=l.shape[0],u=l.shape[1],h=new Lse(c,u,o),d=[[i]],f=n.runWebGLProgram(h,[l],"int32",d);return a||n.disposeIntermediateTensorInfo(l),f}const jse={kernelName:r$,backendName:"webgl",kernelFunc:Hse};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18183,9 +18183,9 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const jse=Ds+` + */const Kse=_s+` return -x; -`,Kse=` +`,Xse=` vec4 result = -x; bvec4 isNaN = isnan(x); @@ -18195,7 +18195,7 @@ return a / b;`,Bse=` result.a = isNaN.a ? x.a : result.a; return result; -`;function Xse(t){const{inputs:e,backend:n}=t,{x:s}=e;if(n.shouldExecuteOnCPU([s])){const o=n.texData.get(s.dataId),[i,a]=mQ(o.values,s.shape,s.dtype);return n.makeTensorInfo(a,s.dtype,i)}let r;return W().getBool("WEBGL_PACK_UNARY_OPERATIONS")?r=new po(s.shape,Kse):r=new fr(s.shape,jse),n.runWebGLProgram(r,[s],s.dtype)}const qse={kernelName:Kp,backendName:"webgl",kernelFunc:Xse};/** +`;function qse(t){const{inputs:e,backend:n}=t,{x:s}=e;if(n.shouldExecuteOnCPU([s])){const o=n.texData.get(s.dataId),[i,a]=gQ(o.values,s.shape,s.dtype);return n.makeTensorInfo(a,s.dtype,i)}let r;return W().getBool("WEBGL_PACK_UNARY_OPERATIONS")?r=new po(s.shape,Xse):r=new pr(s.shape,Kse),n.runWebGLProgram(r,[s],s.dtype)}const Yse={kernelName:Kp,backendName:"webgl",kernelFunc:qse};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18210,7 +18210,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Yse=hw;function Qse(t){es("tf.nonMaxSuppression() in webgl locks the UI thread. Call tf.nonMaxSuppressionAsync() instead");const{inputs:e,backend:n,attrs:s}=t,{boxes:r,scores:o}=e,{maxOutputSize:i,iouThreshold:a,scoreThreshold:l}=s,c=n.readSync(r.dataId),u=n.readSync(o.dataId),{selectedIndices:d}=Yse(c,u,i,a,l);return n.makeTensorInfo([d.length],"int32",new Int32Array(d))}const Zse={kernelName:xy,backendName:"webgl",kernelFunc:Qse};/** + */const Qse=dw;function Zse(t){es("tf.nonMaxSuppression() in webgl locks the UI thread. Call tf.nonMaxSuppressionAsync() instead");const{inputs:e,backend:n,attrs:s}=t,{boxes:r,scores:o}=e,{maxOutputSize:i,iouThreshold:a,scoreThreshold:l}=s,c=n.readSync(r.dataId),u=n.readSync(o.dataId),{selectedIndices:h}=Qse(c,u,i,a,l);return n.makeTensorInfo([h.length],"int32",new Int32Array(h))}const Jse={kernelName:xy,backendName:"webgl",kernelFunc:Zse};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18225,7 +18225,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Jse=fw;function ere(t){es("tf.nonMaxSuppression() in webgl locks the UI thread. Call tf.nonMaxSuppressionAsync() instead");const{inputs:e,backend:n,attrs:s}=t,{boxes:r,scores:o}=e,{maxOutputSize:i,iouThreshold:a,scoreThreshold:l,padToMaxOutputSize:c}=s,u=n.readSync(r.dataId),d=n.readSync(o.dataId),{selectedIndices:h,validOutputs:f}=Jse(u,d,i,a,l,c);return[n.makeTensorInfo([h.length],"int32",new Int32Array(h)),n.makeTensorInfo([],"int32",new Int32Array([f]))]}const tre={kernelName:yy,backendName:"webgl",kernelFunc:ere};/** + */const ere=fw;function tre(t){es("tf.nonMaxSuppression() in webgl locks the UI thread. Call tf.nonMaxSuppressionAsync() instead");const{inputs:e,backend:n,attrs:s}=t,{boxes:r,scores:o}=e,{maxOutputSize:i,iouThreshold:a,scoreThreshold:l,padToMaxOutputSize:c}=s,u=n.readSync(r.dataId),h=n.readSync(o.dataId),{selectedIndices:d,validOutputs:f}=ere(u,h,i,a,l,c);return[n.makeTensorInfo([d.length],"int32",new Int32Array(d)),n.makeTensorInfo([],"int32",new Int32Array([f]))]}const nre={kernelName:yy,backendName:"webgl",kernelFunc:tre};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18240,7 +18240,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const nre=pw;function sre(t){es("tf.nonMaxSuppression() in webgl locks the UI thread. Call tf.nonMaxSuppressionAsync() instead");const{inputs:e,backend:n,attrs:s}=t,{boxes:r,scores:o}=e,{maxOutputSize:i,iouThreshold:a,scoreThreshold:l,softNmsSigma:c}=s,u=n.readSync(r.dataId),d=n.readSync(o.dataId),h=i,f=a,p=l,g=c,{selectedIndices:x,selectedScores:m}=nre(u,d,h,f,p,g);return[n.makeTensorInfo([x.length],"int32",new Int32Array(x)),n.makeTensorInfo([m.length],"float32",new Float32Array(m))]}const rre={kernelName:wy,backendName:"webgl",kernelFunc:sre};/** + */const sre=pw;function rre(t){es("tf.nonMaxSuppression() in webgl locks the UI thread. Call tf.nonMaxSuppressionAsync() instead");const{inputs:e,backend:n,attrs:s}=t,{boxes:r,scores:o}=e,{maxOutputSize:i,iouThreshold:a,scoreThreshold:l,softNmsSigma:c}=s,u=n.readSync(r.dataId),h=n.readSync(o.dataId),d=i,f=a,p=l,g=c,{selectedIndices:x,selectedScores:m}=sre(u,h,d,f,p,g);return[n.makeTensorInfo([x.length],"int32",new Int32Array(x)),n.makeTensorInfo([m.length],"float32",new Float32Array(m))]}const ore={kernelName:wy,backendName:"webgl",kernelFunc:rre};/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18255,7 +18255,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class ore{constructor(e,n,s,r){this.variableNames=["indices"],this.outputShape=[e,n],this.userCode=` + */class ire{constructor(e,n,s,r){this.variableNames=["indices"],this.outputShape=[e,n],this.userCode=` void main() { ivec2 coords = getOutputCoords(); int index = round(getIndices(coords.x)); @@ -18277,7 +18277,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const ire=t=>{const{inputs:e,backend:n,attrs:s}=t,{indices:r}=e,{dtype:o,depth:i,onValue:a,offValue:l}=s,c=j(r.shape),u=new ore(c,i,a,l),d=re({inputs:{x:r},backend:n,attrs:{shape:[c]}}),h=n.runWebGLProgram(u,[d],o);n.disposeIntermediateTensorInfo(d);const f=[...r.shape,i],p=re({inputs:{x:h},backend:n,attrs:{shape:f}});return n.disposeIntermediateTensorInfo(h),p},are={kernelName:Yp,backendName:"webgl",kernelFunc:ire};/** + */const are=t=>{const{inputs:e,backend:n,attrs:s}=t,{indices:r}=e,{dtype:o,depth:i,onValue:a,offValue:l}=s,c=j(r.shape),u=new ire(c,i,a,l),h=re({inputs:{x:r},backend:n,attrs:{shape:[c]}}),d=n.runWebGLProgram(u,[h],o);n.disposeIntermediateTensorInfo(h);const f=[...r.shape,i],p=re({inputs:{x:d},backend:n,attrs:{shape:f}});return n.disposeIntermediateTensorInfo(d),p},lre={kernelName:Yp,backendName:"webgl",kernelFunc:are};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18292,7 +18292,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Wf(t){const{inputs:e,backend:n}=t,{x:s}=e;if(s.dtype==="complex64"){const r=Ad({inputs:{input:s},backend:n}),o=Wf({inputs:{x:r},backend:n}),i=Vm({inputs:{input:s},backend:n}),a=Wf({inputs:{x:i},backend:n}),l=Qo({inputs:{real:o,imag:a},backend:n});return n.disposeIntermediateTensorInfo(r),n.disposeIntermediateTensorInfo(o),n.disposeIntermediateTensorInfo(i),n.disposeIntermediateTensorInfo(a),l}else return Dd({attrs:{shape:s.shape,dtype:s.dtype,value:s.dtype==="string"?"":0},backend:n})}const lre={kernelName:fm,backendName:"webgl",kernelFunc:Wf};/** + */function Wf(t){const{inputs:e,backend:n}=t,{x:s}=e;if(s.dtype==="complex64"){const r=Ah({inputs:{input:s},backend:n}),o=Wf({inputs:{x:r},backend:n}),i=Vm({inputs:{input:s},backend:n}),a=Wf({inputs:{x:i},backend:n}),l=Qo({inputs:{real:o,imag:a},backend:n});return n.disposeIntermediateTensorInfo(r),n.disposeIntermediateTensorInfo(o),n.disposeIntermediateTensorInfo(i),n.disposeIntermediateTensorInfo(a),l}else return Dh({attrs:{shape:s.shape,dtype:s.dtype,value:s.dtype==="string"?"":0},backend:n})}const cre={kernelName:fm,backendName:"webgl",kernelFunc:Wf};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18307,7 +18307,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function ND(t){const{inputs:e,backend:n}=t,{x:s}=e;if(s.dtype==="string")throw new Error("onesLike is not supported under string dtype");if(s.dtype==="complex64"){const r=Ad({inputs:{input:s},backend:n}),o=ND({inputs:{x:r},backend:n}),i=Vm({inputs:{input:s},backend:n}),a=Wf({inputs:{x:i},backend:n}),l=Qo({inputs:{real:o,imag:a},backend:n});return n.disposeIntermediateTensorInfo(r),n.disposeIntermediateTensorInfo(o),n.disposeIntermediateTensorInfo(i),n.disposeIntermediateTensorInfo(a),l}else return Dd({attrs:{shape:s.shape,dtype:s.dtype,value:1},backend:n})}const cre={kernelName:qp,backendName:"webgl",kernelFunc:ND};/** + */function TD(t){const{inputs:e,backend:n}=t,{x:s}=e;if(s.dtype==="string")throw new Error("onesLike is not supported under string dtype");if(s.dtype==="complex64"){const r=Ah({inputs:{input:s},backend:n}),o=TD({inputs:{x:r},backend:n}),i=Vm({inputs:{input:s},backend:n}),a=Wf({inputs:{x:i},backend:n}),l=Qo({inputs:{real:o,imag:a},backend:n});return n.disposeIntermediateTensorInfo(r),n.disposeIntermediateTensorInfo(o),n.disposeIntermediateTensorInfo(i),n.disposeIntermediateTensorInfo(a),l}else return Dh({attrs:{shape:s.shape,dtype:s.dtype,value:1},backend:n})}const ure={kernelName:qp,backendName:"webgl",kernelFunc:TD};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18322,7 +18322,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function ure(t){const{inputs:e,backend:n,attrs:s}=t,{axis:r}=s;if(e.length===1)return R1({inputs:{input:e[0]},backend:n,attrs:{dim:r}});const o=e[0].shape,i=e[0].dtype;e.forEach(u=>{Lx(o,u.shape,"All tensors passed to stack must have matching shapes"),I(i===u.dtype,()=>"All tensors passed to stack must have matching dtypes")});const a=[],l=e.map(u=>{const d=R1({inputs:{input:u},backend:n,attrs:{dim:r}});return a.push(d),d}),c=hD({inputs:l,backend:n,attrs:{axis:r}});return a.forEach(u=>n.disposeIntermediateTensorInfo(u)),c}const dre={kernelName:Qp,backendName:"webgl",kernelFunc:ure};/** + */function hre(t){const{inputs:e,backend:n,attrs:s}=t,{axis:r}=s;if(e.length===1)return R1({inputs:{input:e[0]},backend:n,attrs:{dim:r}});const o=e[0].shape,i=e[0].dtype;e.forEach(u=>{Lx(o,u.shape,"All tensors passed to stack must have matching shapes"),I(i===u.dtype,()=>"All tensors passed to stack must have matching dtypes")});const a=[],l=e.map(u=>{const h=R1({inputs:{input:u},backend:n,attrs:{dim:r}});return a.push(h),h}),c=fD({inputs:l,backend:n,attrs:{axis:r}});return a.forEach(u=>n.disposeIntermediateTensorInfo(u)),c}const dre={kernelName:Qp,backendName:"webgl",kernelFunc:hre};/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18337,7 +18337,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class hre{constructor(e,n,s){this.variableNames=["x"],this.customUniforms=[{name:"value",type:"float"}],this.outputShape=n.map((c,u)=>c[0]+e[u]+c[1]);const r=e.length,o=Ze(r),i=n.map(c=>c[0]).join(","),a=n.map((c,u)=>c[0]+e[u]).join(","),l=["coords[0]","coords[1]","coords[2]","coords[3]"].slice(0,r);if(r===1){this.userCode=` + */class fre{constructor(e,n,s){this.variableNames=["x"],this.customUniforms=[{name:"value",type:"float"}],this.outputShape=n.map((c,u)=>c[0]+e[u]+c[1]);const r=e.length,o=Ze(r),i=n.map(c=>c[0]).join(","),a=n.map((c,u)=>c[0]+e[u]).join(","),l=["coords[0]","coords[1]","coords[2]","coords[3]"].slice(0,r);if(r===1){this.userCode=` int start = ${i}; int end = ${a}; @@ -18377,19 +18377,19 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class fre{constructor(e,n,s){this.variableNames=["x"],this.packedInputs=!0,this.packedOutput=!0,this.customUniforms=[{name:"value",type:"float"}],this.outputShape=n.map((g,x)=>g[0]+e[x]+g[1]);const r=e.length,o=Ze(r),i=n.map(g=>g[0]).join(","),a=n.map((g,x)=>g[0]+e[x]).join(","),l=vn("rc",r),c=vn("source",r),u=`${l[r-1]} < ${this.outputShape[r-1]}`,d=r===1?"source":`vec2(${c.slice(-2).join()})`,h=[`${o} rc = outputLoc;`,`${l[r-1]} += 1; + */class pre{constructor(e,n,s){this.variableNames=["x"],this.packedInputs=!0,this.packedOutput=!0,this.customUniforms=[{name:"value",type:"float"}],this.outputShape=n.map((g,x)=>g[0]+e[x]+g[1]);const r=e.length,o=Ze(r),i=n.map(g=>g[0]).join(","),a=n.map((g,x)=>g[0]+e[x]).join(","),l=vn("rc",r),c=vn("source",r),u=`${l[r-1]} < ${this.outputShape[r-1]}`,h=r===1?"source":`vec2(${c.slice(-2).join()})`,d=[`${o} rc = outputLoc;`,`${l[r-1]} += 1; if(${u}) { `,r===1?"":`} rc = outputLoc; ${l[r-2]} += 1; if(${l[r-2]} < ${this.outputShape[r-2]}) {`,r===1?"":` ${l[r-1]} += 1; if(${u}) {`],f=r===1?"rc < start || rc >= end":"any(lessThan(rc, start)) || any(greaterThanEqual(rc, end))";let p="";for(let g=0,x=r===1?2:4;g{const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{paddings:o,constantValue:i}=s;if(j(r.shape)===0){const c=o.map((u,d)=>u[0]+r.shape[d]+u[1]);return Dd({backend:n,attrs:{shape:c,value:i,dtype:r.dtype}})}const a=W().getBool("WEBGL_PACK_ARRAY_OPERATIONS")?new fre(r.shape,o,i):new hre(r.shape,o,i),l=[[i]];return n.runWebGLProgram(a,[r],r.dtype,l)},pre={kernelName:Zp,backendName:"webgl",kernelFunc:TD};/** + */const ED=t=>{const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{paddings:o,constantValue:i}=s;if(j(r.shape)===0){const c=o.map((u,h)=>u[0]+r.shape[h]+u[1]);return Dh({backend:n,attrs:{shape:c,value:i,dtype:r.dtype}})}const a=W().getBool("WEBGL_PACK_ARRAY_OPERATIONS")?new pre(r.shape,o,i):new fre(r.shape,o,i),l=[[i]];return n.runWebGLProgram(a,[r],r.dtype,l)},mre={kernelName:Zp,backendName:"webgl",kernelFunc:ED};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18431,7 +18431,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const mre=` + */const gre=` if(a < 0.0 && floor(b) < b){ return NAN; } @@ -18440,7 +18440,7 @@ return a / b;`,Bse=` } return (round(mod(b, 2.0)) != 1) ? pow(abs(a), b) : sign(a) * pow(abs(a), b); -`,gre=` +`,xre=` // isModRound1 has 1 for components with round(mod(b, 2.0)) == 1, 0 otherwise. vec4 isModRound1 = vec4(equal(round(mod(b, 2.0)), ivec4(1))); vec4 multiplier = sign(a) * isModRound1 + (vec4(1.0) - isModRound1); @@ -18458,7 +18458,7 @@ return a / b;`,Bse=` bvec4 isNaN = bvec4(isNaN1.x && isNaN2.x, isNaN1.y && isNaN2.y, isNaN1.z && isNaN2.z, isNaN1.w && isNaN2.w); `+na+` return result; -`,xre=rn({opSnippet:mre,packedOpSnippet:gre}),yre={kernelName:Gu,backendName:"webgl",kernelFunc:xre};/** +`,yre=rn({opSnippet:gre,packedOpSnippet:xre}),wre={kernelName:Gu,backendName:"webgl",kernelFunc:yre};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18473,7 +18473,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function wre(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{axis:o,keepDims:i}=s,a=r.shape.length,l=[],c=Re(o,r.shape);let u=c;const d=yt(u,a);let h=r;d!=null&&(h=Sn({inputs:{x:r},backend:n,attrs:{perm:d}}),u=$t(u.length,a),l.push(h)),sn("prod",u,a);let f;if(n.shouldExecuteOnCPU([h])){const p=n.texData.get(h.dataId).values,{outVals:g,outShape:x,outDtype:m}=xQ(h.shape,h.dtype,p,u);f=n.makeTensorInfo(x,m,g)}else{const[p,g]=Yt(h.shape,u),x=j(g),m=re({inputs:{x:h},backend:n,attrs:{shape:[-1,x]}}),y=Dy(r.dtype),w=sa(m,y,"prod",n);f=re({inputs:{x:w},backend:n,attrs:{shape:p}}),l.push(m),l.push(w)}if(i){l.push(f);const p=Dt(f.shape,c);f=re({inputs:{x:f},backend:n,attrs:{shape:p}})}return l.forEach(p=>n.disposeIntermediateTensorInfo(p)),f}const vre={kernelName:em,backendName:"webgl",kernelFunc:wre};/** + */function vre(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{axis:o,keepDims:i}=s,a=r.shape.length,l=[],c=Re(o,r.shape);let u=c;const h=yt(u,a);let d=r;h!=null&&(d=Sn({inputs:{x:r},backend:n,attrs:{perm:h}}),u=$t(u.length,a),l.push(d)),sn("prod",u,a);let f;if(n.shouldExecuteOnCPU([d])){const p=n.texData.get(d.dataId).values,{outVals:g,outShape:x,outDtype:m}=yQ(d.shape,d.dtype,p,u);f=n.makeTensorInfo(x,m,g)}else{const[p,g]=Yt(d.shape,u),x=j(g),m=re({inputs:{x:d},backend:n,attrs:{shape:[-1,x]}}),y=Dy(r.dtype),w=sa(m,y,"prod",n);f=re({inputs:{x:w},backend:n,attrs:{shape:p}}),l.push(m),l.push(w)}if(i){l.push(f);const p=Dt(f.shape,c);f=re({inputs:{x:f},backend:n,attrs:{shape:p}})}return l.forEach(p=>n.disposeIntermediateTensorInfo(p)),f}const bre={kernelName:em,backendName:"webgl",kernelFunc:vre};/** * @license * Copyright 2022 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18488,7 +18488,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function bre(t){const{inputs:e,backend:n,attrs:s}=t,{paramsNestedSplits:r,paramsDenseValues:o,indices:i}=e,{outputRaggedRank:a}=s,l=r.map(m=>n.readSync(m.dataId)),c=r.map(m=>m.shape),u=n.readSync(o.dataId),d=n.readSync(i.dataId),[h,f,p]=yQ(l,c,u,o.shape,o.dtype,d,i.shape,a),g=h.map(m=>n.makeTensorInfo([m.length],"int32",m)),x=n.makeTensorInfo(p,o.dtype,f);return g.concat([x])}const Cre={kernelName:r$,backendName:"webgl",kernelFunc:bre};/** + */function Cre(t){const{inputs:e,backend:n,attrs:s}=t,{paramsNestedSplits:r,paramsDenseValues:o,indices:i}=e,{outputRaggedRank:a}=s,l=r.map(m=>n.readSync(m.dataId)),c=r.map(m=>m.shape),u=n.readSync(o.dataId),h=n.readSync(i.dataId),[d,f,p]=wQ(l,c,u,o.shape,o.dtype,h,i.shape,a),g=d.map(m=>n.makeTensorInfo([m.length],"int32",m)),x=n.makeTensorInfo(p,o.dtype,f);return g.concat([x])}const kre={kernelName:o$,backendName:"webgl",kernelFunc:Cre};/** * @license * Copyright 2022 Google LLC. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18503,7 +18503,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function kre(t){const{inputs:e,backend:n}=t,{starts:s,limits:r,deltas:o}=e,i=n.readSync(s.dataId),a=n.readSync(r.dataId),l=n.readSync(o.dataId),[c,u]=wQ(i,s.shape,s.dtype,a,r.shape,l,o.shape),d=n.makeTensorInfo([c.length],"int32",c),h=n.makeTensorInfo([u.length],s.dtype,u);return[d,h]}const Sre={kernelName:o$,backendName:"webgl",kernelFunc:kre};/** + */function Sre(t){const{inputs:e,backend:n}=t,{starts:s,limits:r,deltas:o}=e,i=n.readSync(s.dataId),a=n.readSync(r.dataId),l=n.readSync(o.dataId),[c,u]=vQ(i,s.shape,s.dtype,a,r.shape,l,o.shape),h=n.makeTensorInfo([c.length],"int32",c),d=n.makeTensorInfo([u.length],s.dtype,u);return[h,d]}const Ire={kernelName:i$,backendName:"webgl",kernelFunc:Sre};/** * @license * Copyright 2022 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18518,7 +18518,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Ire(t){const{inputs:e,backend:n,attrs:s}=t,{shape:r,values:o,defaultValue:i,rowPartitionTensors:a}=e,{rowPartitionTypes:l}=s,c=n.readSync(r.dataId),u=n.readSync(o.dataId),d=n.readSync(i.dataId),h=a.map(x=>n.readSync(x.dataId)),f=a.map(x=>x.shape),[p,g]=vQ(c,r.shape,u,o.shape,o.dtype,d,i.shape,h,f,l);return n.makeTensorInfo(p,o.dtype,g)}const $re={kernelName:i$,backendName:"webgl",kernelFunc:Ire};/** + */function $re(t){const{inputs:e,backend:n,attrs:s}=t,{shape:r,values:o,defaultValue:i,rowPartitionTensors:a}=e,{rowPartitionTypes:l}=s,c=n.readSync(r.dataId),u=n.readSync(o.dataId),h=n.readSync(i.dataId),d=a.map(x=>n.readSync(x.dataId)),f=a.map(x=>x.shape),[p,g]=bQ(c,r.shape,u,o.shape,o.dtype,h,i.shape,d,f,l);return n.makeTensorInfo(p,o.dtype,g)}const Nre={kernelName:a$,backendName:"webgl",kernelFunc:$re};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18533,7 +18533,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const ED=t=>{const{backend:e,attrs:n}=t,{start:s,stop:r,step:o,dtype:i}=n,a=bQ(s,r,o,i);return e.makeTensorInfo([a.length],i,a)},Nre={kernelName:vy,backendName:"webgl",kernelFunc:ED};/** + */const RD=t=>{const{backend:e,attrs:n}=t,{start:s,stop:r,step:o,dtype:i}=n,a=CQ(s,r,o,i);return e.makeTensorInfo([a.length],i,a)},Tre={kernelName:vy,backendName:"webgl",kernelFunc:RD};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18548,7 +18548,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Tre="return 1.0 / x;",Ere=Oe({opSnippet:Tre}),Rre={kernelName:Hu,backendName:"webgl",kernelFunc:Ere};/** + */const Ere="return 1.0 / x;",Rre=Oe({opSnippet:Ere}),Are={kernelName:Hu,backendName:"webgl",kernelFunc:Rre};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18563,9 +18563,9 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Are=Ds+` + */const Dre=_s+` return (x < 0.0) ? 0.0 : x; -`,Dre=` +`,_re=` vec4 result = x * vec4(greaterThanEqual(x, vec4(0.0))); bvec4 isNaN = isnan(x); @@ -18575,7 +18575,7 @@ return a / b;`,Bse=` result.a = isNaN.a ? x.a : result.a; return result; -`,_re=Oe({opSnippet:Are,packedOpSnippet:Dre}),Fre={kernelName:ju,backendName:"webgl",kernelFunc:_re};/** +`,Fre=Oe({opSnippet:Dre,packedOpSnippet:_re}),zre={kernelName:ju,backendName:"webgl",kernelFunc:Fre};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18590,9 +18590,9 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const zre=Ds+` + */const Ore=_s+` return (x < 0.0) ? 0.0 : min(6.0, x); -`,Ore=` +`,Mre=` vec4 result = min(x, vec4(6.)) * vec4(greaterThanEqual(x, vec4(0.0))); bvec4 isNaN = isnan(x); @@ -18602,7 +18602,7 @@ return a / b;`,Bse=` result.a = isNaN.a ? x.a : result.a; return result; -`,Mre=Oe({opSnippet:zre,packedOpSnippet:Ore}),Pre={kernelName:Ku,backendName:"webgl",kernelFunc:Mre};/** +`,Pre=Oe({opSnippet:Ore,packedOpSnippet:Mre}),Lre={kernelName:Ku,backendName:"webgl",kernelFunc:Pre};/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18617,10 +18617,10 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class Lre{constructor(e,n,s,r,o){this.variableNames=["A"],this.outputShape=[];const[i,a,l,c]=e;this.outputShape=[i,n,s,c];const u=[r&&n>1?a-1:a,r&&s>1?l-1:l],d=[r&&n>1?n-1:n,r&&s>1?s-1:s];let h;o?h="(vec2(yRC) + vec2(0.5)) * effectiveInputOverOutputRatioRC - vec2(0.5)":h="vec2(yRC) * effectiveInputOverOutputRatioRC",this.userCode=` + */class Bre{constructor(e,n,s,r,o){this.variableNames=["A"],this.outputShape=[];const[i,a,l,c]=e;this.outputShape=[i,n,s,c];const u=[r&&n>1?a-1:a,r&&s>1?l-1:l],h=[r&&n>1?n-1:n,r&&s>1?s-1:s];let d;o?d="(vec2(yRC) + vec2(0.5)) * effectiveInputOverOutputRatioRC - vec2(0.5)":d="vec2(yRC) * effectiveInputOverOutputRatioRC",this.userCode=` const vec2 effectiveInputOverOutputRatioRC = vec2( - ${u[0]/d[0]}, - ${u[1]/d[1]}); + ${u[0]/h[0]}, + ${u[1]/h[1]}); const vec2 inputShapeRC = vec2(${a}.0, ${l}.0); void main() { @@ -18630,7 +18630,7 @@ return a / b;`,Bse=` ivec2 yRC = coords.yz; // Fractional source index. - vec2 sourceFracIndexRC = ${h}; + vec2 sourceFracIndexRC = ${d}; // Compute the four integer indices. ivec2 sourceFloorRC = ivec2(max(sourceFracIndexRC, vec2(0.0))); @@ -18665,11 +18665,11 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class Bre{constructor(e,n,s,r,o){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=[];const[i,a,l,c]=e;this.outputShape=[i,n,s,c];const u=[r&&n>1?a-1:a,r&&s>1?l-1:l],d=[r&&n>1?n-1:n,r&&s>1?s-1:s];let h;o?h="(vec3(yRC) + vec3(0.5)) * effectiveInputOverOutputRatioRC - vec3(0.5)":h="vec3(yRC) * effectiveInputOverOutputRatioRC",this.userCode=` + */class Vre{constructor(e,n,s,r,o){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=[];const[i,a,l,c]=e;this.outputShape=[i,n,s,c];const u=[r&&n>1?a-1:a,r&&s>1?l-1:l],h=[r&&n>1?n-1:n,r&&s>1?s-1:s];let d;o?d="(vec3(yRC) + vec3(0.5)) * effectiveInputOverOutputRatioRC - vec3(0.5)":d="vec3(yRC) * effectiveInputOverOutputRatioRC",this.userCode=` const vec3 effectiveInputOverOutputRatioRC = vec3( - ${u[0]/d[0]}, - ${u[1]/d[1]}, - ${u[1]/d[1]}); + ${u[0]/h[0]}, + ${u[1]/h[1]}, + ${u[1]/h[1]}); const vec3 inputShapeRC = vec3(${a}.0, ${l}.0, ${l}.0); @@ -18685,7 +18685,7 @@ return a / b;`,Bse=` ivec3 yRC = coords.yzz + ivec3(0, 0, 1); // Fractional source index. - vec3 sourceFracIndexRC = ${h}; + vec3 sourceFracIndexRC = ${d}; // Compute the four integer indices. ivec3 sourceFloorRC = ivec3(max(sourceFracIndexRC, vec3(0.0))); @@ -18757,7 +18757,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Vre(t){const{inputs:e,backend:n,attrs:s}=t,{images:r}=e,{alignCorners:o,halfPixelCenters:i,size:a}=s,[l,c]=a,u=W().getBool("WEBGL_PACK_IMAGE_OPERATIONS")?new Bre(r.shape,l,c,o,i):new Lre(r.shape,l,c,o,i);return n.runWebGLProgram(u,[r],"float32")}const Wre={kernelName:sm,backendName:"webgl",kernelFunc:Vre};/** + */function Wre(t){const{inputs:e,backend:n,attrs:s}=t,{images:r}=e,{alignCorners:o,halfPixelCenters:i,size:a}=s,[l,c]=a,u=W().getBool("WEBGL_PACK_IMAGE_OPERATIONS")?new Vre(r.shape,l,c,o,i):new Bre(r.shape,l,c,o,i);return n.runWebGLProgram(u,[r],"float32")}const Ure={kernelName:sm,backendName:"webgl",kernelFunc:Wre};/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18772,7 +18772,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class Ure{constructor(e,n,s){this.variableNames=["dy"],this.outputShape=[],this.outputShape=n;const[,r,o]=n,[,i,a]=e,l=[s&&i>1?r-1:r,s&&a>1?o-1:o],c=[s&&i>1?i-1:i,s&&a>1?a-1:a],u=l[0]/c[0],d=l[1]/c[1],h=1/u,f=1/d,p=Math.ceil(h)*2+2,g=Math.ceil(f)*2+2;this.userCode=` + */class Gre{constructor(e,n,s){this.variableNames=["dy"],this.outputShape=[],this.outputShape=n;const[,r,o]=n,[,i,a]=e,l=[s&&i>1?r-1:r,s&&a>1?o-1:o],c=[s&&i>1?i-1:i,s&&a>1?a-1:a],u=l[0]/c[0],h=l[1]/c[1],d=1/u,f=1/h,p=Math.ceil(d)*2+2,g=Math.ceil(f)*2+2;this.userCode=` void main() { ivec4 coords = getOutputCoords(); int b = coords[0]; @@ -18783,9 +18783,9 @@ return a / b;`,Bse=` float accumulator = 0.0; const float heightScale = float(${u}); - const float widthScale = float(${d}); + const float widthScale = float(${h}); - const float invHeightScale = float(${h}); + const float invHeightScale = float(${d}); const float invWidthScale = float(${f}); const int winHeight = int(${p}); @@ -18868,7 +18868,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Gre(t){const{inputs:e,backend:n,attrs:s}=t,{images:r,dy:o}=e,{alignCorners:i}=s,a=new Ure(o.shape,r.shape,i);return n.runWebGLProgram(a,[o],o.dtype)}const Hre={kernelName:ky,backendName:"webgl",kernelFunc:Gre};/** + */function Hre(t){const{inputs:e,backend:n,attrs:s}=t,{images:r,dy:o}=e,{alignCorners:i}=s,a=new Gre(o.shape,r.shape,i);return n.runWebGLProgram(a,[o],o.dtype)}const jre={kernelName:ky,backendName:"webgl",kernelFunc:Hre};/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18883,10 +18883,10 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class jre{constructor(e,n,s,r,o){this.variableNames=["A"],this.outputShape=[];const[i,a,l,c]=e;this.outputShape=[i,n,s,c];const u=[r&&n>1?a-1:a,r&&s>1?l-1:l],d=[r&&n>1?n-1:n,r&&s>1?s-1:s],h=r?"0.5":"0.0";let f;o?f="max((vec2(yRC) + vec2(0.5)) * effectiveInputOverOutputRatioRC, vec2(0.0))":f="vec2(yRC) * effectiveInputOverOutputRatioRC",this.userCode=` + */class Kre{constructor(e,n,s,r,o){this.variableNames=["A"],this.outputShape=[];const[i,a,l,c]=e;this.outputShape=[i,n,s,c];const u=[r&&n>1?a-1:a,r&&s>1?l-1:l],h=[r&&n>1?n-1:n,r&&s>1?s-1:s],d=r?"0.5":"0.0";let f;o?f="max((vec2(yRC) + vec2(0.5)) * effectiveInputOverOutputRatioRC, vec2(0.0))":f="vec2(yRC) * effectiveInputOverOutputRatioRC",this.userCode=` const vec2 effectiveInputOverOutputRatioRC = vec2( - ${u[0]/d[0]}, - ${u[1]/d[1]}); + ${u[0]/h[0]}, + ${u[1]/h[1]}); const vec2 inputShapeRC = vec2(${a}.0, ${l}.0); void main() { @@ -18900,7 +18900,7 @@ return a / b;`,Bse=` // Compute the coordinators of nearest neighbor point. ivec2 sourceNearestRC = ivec2( - min(inputShapeRC - 1.0, floor(sourceFracIndexRC + ${h}))); + min(inputShapeRC - 1.0, floor(sourceFracIndexRC + ${d}))); float newValue = getA(b, sourceNearestRC.x, sourceNearestRC.y, d); setOutput(newValue); @@ -18920,11 +18920,11 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class Kre{constructor(e,n,s,r,o){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=[];const[i,a,l,c]=e;this.outputShape=[i,n,s,c];const u=[r&&n>1?a-1:a,r&&s>1?l-1:l],d=[r&&n>1?n-1:n,r&&s>1?s-1:s],h=r?"0.5":"0.0";let f;o?f="max((vec3(yRC) + vec3(0.5)) * effectiveInputOverOutputRatioRC, vec3(0.0))":f="vec3(yRC) * effectiveInputOverOutputRatioRC",this.userCode=` + */class Xre{constructor(e,n,s,r,o){this.variableNames=["A"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=[];const[i,a,l,c]=e;this.outputShape=[i,n,s,c];const u=[r&&n>1?a-1:a,r&&s>1?l-1:l],h=[r&&n>1?n-1:n,r&&s>1?s-1:s],d=r?"0.5":"0.0";let f;o?f="max((vec3(yRC) + vec3(0.5)) * effectiveInputOverOutputRatioRC, vec3(0.0))":f="vec3(yRC) * effectiveInputOverOutputRatioRC",this.userCode=` const vec3 effectiveInputOverOutputRatioRC = vec3( - ${u[0]/d[0]}, - ${u[1]/d[1]}, - ${u[1]/d[1]}); + ${u[0]/h[0]}, + ${u[1]/h[1]}, + ${u[1]/h[1]}); const vec3 inputShapeRC = vec3(${a}.0, ${l}.0, ${l}.0); @@ -18944,7 +18944,7 @@ return a / b;`,Bse=` // Compute the coordinators of nearest neighbor point. ivec3 sourceNearestRC = ivec3( - min(inputShapeRC - 1.0, floor(sourceFracIndexRC + ${h}))); + min(inputShapeRC - 1.0, floor(sourceFracIndexRC + ${d}))); // Should we calculate next column and row elements in 2x2 packed cell. bool hasNextCol = d < ${c-1}; @@ -18976,7 +18976,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Xre(t){const{inputs:e,backend:n,attrs:s}=t,{images:r}=e,{alignCorners:o,halfPixelCenters:i,size:a}=s,[l,c]=a,u=W().getBool("WEBGL_PACK_IMAGE_OPERATIONS")?new Kre(r.shape,l,c,o,i):new jre(r.shape,l,c,o,i);return n.runWebGLProgram(u,[r],r.dtype)}const qre={kernelName:nm,backendName:"webgl",kernelFunc:Xre};/** + */function qre(t){const{inputs:e,backend:n,attrs:s}=t,{images:r}=e,{alignCorners:o,halfPixelCenters:i,size:a}=s,[l,c]=a,u=W().getBool("WEBGL_PACK_IMAGE_OPERATIONS")?new Xre(r.shape,l,c,o,i):new Kre(r.shape,l,c,o,i);return n.runWebGLProgram(u,[r],r.dtype)}const Yre={kernelName:nm,backendName:"webgl",kernelFunc:qre};/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -18991,7 +18991,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class Yre{constructor(e,n,s){this.variableNames=["dy"],this.outputShape=[],this.outputShape=n;const[,r,o]=n,[,i,a]=e,l=[s&&i>1?r-1:r,s&&a>1?o-1:o],c=[s&&i>1?i-1:i,s&&a>1?a-1:a],u=l[0]/c[0],d=l[1]/c[1],h=1/u,f=1/d,p=Math.ceil(h)*2+2,g=Math.ceil(f)*2+2;this.userCode=` + */class Qre{constructor(e,n,s){this.variableNames=["dy"],this.outputShape=[],this.outputShape=n;const[,r,o]=n,[,i,a]=e,l=[s&&i>1?r-1:r,s&&a>1?o-1:o],c=[s&&i>1?i-1:i,s&&a>1?a-1:a],u=l[0]/c[0],h=l[1]/c[1],d=1/u,f=1/h,p=Math.ceil(d)*2+2,g=Math.ceil(f)*2+2;this.userCode=` void main() { ivec4 coords = getOutputCoords(); int b = coords[0]; @@ -19002,9 +19002,9 @@ return a / b;`,Bse=` float accumulator = 0.0; const float heightScale = float(${u}); - const float widthScale = float(${d}); + const float widthScale = float(${h}); - const float invHeightScale = float(${h}); + const float invHeightScale = float(${d}); const float invWidthScale = float(${f}); const int winHeight = int(${p}); @@ -19076,7 +19076,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Qre(t){const{inputs:e,backend:n,attrs:s}=t,{images:r,dy:o}=e,{alignCorners:i}=s,a=new Yre(o.shape,r.shape,i);return n.runWebGLProgram(a,[o],o.dtype)}const Zre={kernelName:Cy,backendName:"webgl",kernelFunc:Qre};/** + */function Zre(t){const{inputs:e,backend:n,attrs:s}=t,{images:r,dy:o}=e,{alignCorners:i}=s,a=new Qre(o.shape,r.shape,i);return n.runWebGLProgram(a,[o],o.dtype)}const Jre={kernelName:Cy,backendName:"webgl",kernelFunc:Zre};/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19091,7 +19091,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class Jre{constructor(e,n){this.variableNames=["x"];const s=e.length;if(s>4)throw new Error(`WebGL backend: Reverse of rank-${s} tensor is not yet supported`);if(this.outputShape=e,s===1){this.userCode=` + */class eoe{constructor(e,n){this.variableNames=["x"];const s=e.length;if(s>4)throw new Error(`WebGL backend: Reverse of rank-${s} tensor is not yet supported`);if(this.outputShape=e,s===1){this.userCode=` void main() { int coord = getOutputCoords(); setOutput(getX(${e[0]} - coord - 1)); @@ -19116,7 +19116,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class eoe{constructor(e,n){this.variableNames=["x"],this.packedInputs=!0,this.packedOutput=!0;const s=e.length;if(s>4)throw new Error(`WebGL backend: Reverse of rank-${s} tensor is not yet supported`);this.outputShape=e;const r=vn("rc",s),o=`${r[s-1]} + 1 < ${this.outputShape[s-1]}`,i=`${r[s-2]} + 1 < ${this.outputShape[s-2]}`,a=Ze(s);s===1?this.userCode=` + */class toe{constructor(e,n){this.variableNames=["x"],this.packedInputs=!0,this.packedOutput=!0;const s=e.length;if(s>4)throw new Error(`WebGL backend: Reverse of rank-${s} tensor is not yet supported`);this.outputShape=e;const r=vn("rc",s),o=`${r[s-1]} + 1 < ${this.outputShape[s-1]}`,i=`${r[s-2]} + 1 < ${this.outputShape[s-2]}`,a=Ze(s);s===1?this.userCode=` void main(){ int rc = getOutputCoords(); vec4 result = vec4(0.); @@ -19139,12 +19139,12 @@ return a / b;`,Bse=` if(${i}) { result.b = ${u(r.slice())}; if(${o}) { - result.a = ${d(r.slice())}; + result.a = ${h(r.slice())}; } } setOutput(result); } - `;function l(p){return h(p)}function c(p){return p[s-1]="("+p[s-1]+" + 1)",h(p)}function u(p){return p[s-2]="("+p[s-2]+" + 1)",h(p)}function d(p){return p[s-1]="("+p[s-1]+" + 1)",p[s-2]="("+p[s-2]+" + 1)",h(p)}function h(p){const g=e.map((y,w)=>f(w,p)),x=g.join(","),m=g.slice(-2).join(",");return`getChannel(getX(${x}), vec2(${m}))`}function f(p,g){return n.indexOf(p)!==-1&&e[p]!==1?`${e[p]} - ${g[p]} - 1`:`${g[p]}`}}}/** + `;function l(p){return d(p)}function c(p){return p[s-1]="("+p[s-1]+" + 1)",d(p)}function u(p){return p[s-2]="("+p[s-2]+" + 1)",d(p)}function h(p){return p[s-1]="("+p[s-1]+" + 1)",p[s-2]="("+p[s-2]+" + 1)",d(p)}function d(p){const g=e.map((y,w)=>f(w,p)),x=g.join(","),m=g.slice(-2).join(",");return`getChannel(getX(${x}), vec2(${m}))`}function f(p,g){return n.indexOf(p)!==-1&&e[p]!==1?`${e[p]} - ${g[p]} - 1`:`${g[p]}`}}}/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19159,7 +19159,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function toe(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{dims:o}=s,i=r.shape.length,a=Re(o,r.shape);if(i===0)return Yn({inputs:{x:r},backend:n});const l=W().getBool("WEBGL_PACK_ARRAY_OPERATIONS")?new eoe(r.shape,a):new Jre(r.shape,a);return n.runWebGLProgram(l,[r],r.dtype)}const noe={kernelName:rm,backendName:"webgl",kernelFunc:toe};/** + */function noe(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{dims:o}=s,i=r.shape.length,a=Re(o,r.shape);if(i===0)return Yn({inputs:{x:r},backend:n});const l=W().getBool("WEBGL_PACK_ARRAY_OPERATIONS")?new toe(r.shape,a):new eoe(r.shape,a);return n.runWebGLProgram(l,[r],r.dtype)}const soe={kernelName:rm,backendName:"webgl",kernelFunc:noe};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19174,7 +19174,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class soe{constructor(e,n){this.variableNames=["Image"],this.outputShape=[],this.customUniforms=[{name:"params",type:"vec4"}];const s=e[1],r=e[2];this.outputShape=e;let o="";typeof n=="number"?o=`float outputValue = ${n.toFixed(2)};`:o=` + */class roe{constructor(e,n){this.variableNames=["Image"],this.outputShape=[],this.customUniforms=[{name:"params",type:"vec4"}];const s=e[1],r=e[2];this.outputShape=e;let o="";typeof n=="number"?o=`float outputValue = ${n.toFixed(2)};`:o=` vec3 fill = vec3(${n.join(",")}); float outputValue = fill[coords[3]];`,this.userCode=` void main() { @@ -19208,7 +19208,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const roe={kernelName:Ry,backendName:"webgl",kernelFunc:({inputs:t,attrs:e,backend:n})=>{const{image:s}=t,{radians:r,fillValue:o,center:i}=e,a=n,l=new soe(s.shape,o),[c,u]=$w(i,s.shape[1],s.shape[2]),d=[[c,u,Math.sin(r),Math.cos(r)]];return a.runWebGLProgram(l,[s],s.dtype,d)}};/** + */const ooe={kernelName:Ry,backendName:"webgl",kernelFunc:({inputs:t,attrs:e,backend:n})=>{const{image:s}=t,{radians:r,fillValue:o,center:i}=e,a=n,l=new roe(s.shape,o),[c,u]=$w(i,s.shape[1],s.shape[2]),h=[[c,u,Math.sin(r),Math.cos(r)]];return a.runWebGLProgram(l,[s],s.dtype,h)}};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19223,7 +19223,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const ooe=` + */const ioe=` // OpenGL ES does not support round function. // The algorithm is based on banker's rounding. float base = floor(x); @@ -19238,7 +19238,7 @@ return a / b;`,Bse=` return base + 1.0; } } -`,ioe=Oe({opSnippet:ooe}),aoe={kernelName:Xu,backendName:"webgl",kernelFunc:ioe};/** +`,aoe=Oe({opSnippet:ioe}),loe={kernelName:Xu,backendName:"webgl",kernelFunc:aoe};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19253,7 +19253,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const loe="return inversesqrt(x);",coe=Oe({opSnippet:loe,cpuKernelImpl:CQ}),uoe={kernelName:qu,backendName:"webgl",kernelFunc:coe};/** + */const coe="return inversesqrt(x);",uoe=Oe({opSnippet:coe,cpuKernelImpl:kQ}),hoe={kernelName:qu,backendName:"webgl",kernelFunc:uoe};/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19268,7 +19268,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class Tv{constructor(e,n,s,r,o,i,a=!0,l=!1){this.variableNames=["updates","indices","defaultValue"],this.outputShape=i;const c=Ze(o.length),u=Ze(i.length);let d="";s===1?d="i":s===2&&(d="i, j");const h=`getIndices(${d})`;let f="";r===1?f="i":r===2&&(f="i, coords[1]");const p=`getUpdates(${f})`;let g="";l&&(g="coords[0], coords[1]");const x=`getDefaultValue(${g})`,m=n>1?"strides[j]":"strides";this.userCode=` + */class Tv{constructor(e,n,s,r,o,i,a=!0,l=!1){this.variableNames=["updates","indices","defaultValue"],this.outputShape=i;const c=Ze(o.length),u=Ze(i.length);let h="";s===1?h="i":s===2&&(h="i, j");const d=`getIndices(${h})`;let f="";r===1?f="i":r===2&&(f="i, coords[1]");const p=`getUpdates(${f})`;let g="";l&&(g="coords[0], coords[1]");const x=`getDefaultValue(${g})`,m=n>1?"strides[j]":"strides";this.userCode=` ${c} strides = ${c}(${o}); void main() { @@ -19278,7 +19278,7 @@ return a / b;`,Bse=` for (int i = 0; i < ${e}; i++) { int flattenedIndex = 0; for (int j = 0; j < ${n}; j++) { - int index = round(${h}); + int index = round(${d}); flattenedIndex += index * ${m}; } if (flattenedIndex == coords[0]) { @@ -19303,7 +19303,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class doe{constructor(e,n,s,r,o,i,a=!0,l=!1){this.variableNames=["updates","indices","defaultValue"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=i;const c=Ze(o.length),u=Ze(i.length);let d="";s===1?d="i":s===2&&(d="i, j");const h=`getIndices(${d})`;let f="";r===1?f="i":r===2&&(f="i, coords[1]");const p=`getUpdates(${f})`;let g="";l&&(g="coords[0], coords[1]");const x=`getDefaultValue(${g})`,m=n>1?"strides[j]":"strides",y=n>1?"strides[j + 1]":"strides";this.userCode=` + */class doe{constructor(e,n,s,r,o,i,a=!0,l=!1){this.variableNames=["updates","indices","defaultValue"],this.packedInputs=!0,this.packedOutput=!0,this.outputShape=i;const c=Ze(o.length),u=Ze(i.length);let h="";s===1?h="i":s===2&&(h="i, j");const d=`getIndices(${h})`;let f="";r===1?f="i":r===2&&(f="i, coords[1]");const p=`getUpdates(${f})`;let g="";l&&(g="coords[0], coords[1]");const x=`getDefaultValue(${g})`,m=n>1?"strides[j]":"strides",y=n>1?"strides[j + 1]":"strides";this.userCode=` ${c} strides = ${c}(${o}); void main() { @@ -19313,7 +19313,7 @@ return a / b;`,Bse=` for (int i = 0; i < ${e}; i+=2) { ivec2 flattenedIndex = ivec2(0); for (int j = 0; j < ${n}; j+=2) { - ivec4 index = round(${h}); + ivec4 index = round(${d}); flattenedIndex += index.xz * ${m}; if (j + 1 < ${n}) { flattenedIndex += index.yw * ${y}; @@ -19355,7 +19355,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function hoe(t){const{inputs:e,backend:n,attrs:s}=t,{indices:r,updates:o}=e,{shape:i}=s,{sliceRank:a,numUpdates:l,sliceSize:c,strides:u,outputSize:d}=Qi(o,r,i),h=[d/c,c];if(d===0)return n.makeTensorInfo(i,r.dtype);const f=re({inputs:{x:r},backend:n,attrs:{shape:[l,a]}}),p=re({inputs:{x:o},backend:n,attrs:{shape:[l,c]}}),g=n.makeTensorInfo([],"float32",new Float32Array([0]));let x;W().getBool("WEBGL_PACK")?x=new doe(l,a,f.shape.length,p.shape.length,u,h):x=new Tv(l,a,f.shape.length,p.shape.length,u,h);const m=n.runWebGLProgram(x,[p,f,g],p.dtype),y=re({inputs:{x:m},backend:n,attrs:{shape:i}});return n.disposeIntermediateTensorInfo(f),n.disposeIntermediateTensorInfo(p),n.disposeIntermediateTensorInfo(m),n.disposeIntermediateTensorInfo(g),y}const foe={kernelName:a$,backendName:"webgl",kernelFunc:hoe};/** + */function foe(t){const{inputs:e,backend:n,attrs:s}=t,{indices:r,updates:o}=e,{shape:i}=s,{sliceRank:a,numUpdates:l,sliceSize:c,strides:u,outputSize:h}=Qi(o,r,i),d=[h/c,c];if(h===0)return n.makeTensorInfo(i,r.dtype);const f=re({inputs:{x:r},backend:n,attrs:{shape:[l,a]}}),p=re({inputs:{x:o},backend:n,attrs:{shape:[l,c]}}),g=n.makeTensorInfo([],"float32",new Float32Array([0]));let x;W().getBool("WEBGL_PACK")?x=new doe(l,a,f.shape.length,p.shape.length,u,d):x=new Tv(l,a,f.shape.length,p.shape.length,u,d);const m=n.runWebGLProgram(x,[p,f,g],p.dtype),y=re({inputs:{x:m},backend:n,attrs:{shape:i}});return n.disposeIntermediateTensorInfo(f),n.disposeIntermediateTensorInfo(p),n.disposeIntermediateTensorInfo(m),n.disposeIntermediateTensorInfo(g),y}const poe={kernelName:l$,backendName:"webgl",kernelFunc:foe};/** * @license * Copyright 2022 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19370,7 +19370,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class poe{constructor(e,n,s,r){this.variableNames=["sortedSequence","values"],this.customUniforms=[{name:"numInputs",type:"int"}],this.outputShape=[e,s];const o="while (left < right) {",i=`for (int i = 0; i < ${Math.ceil(Math.log2(n+1))}; ++i) { if (left >= right) break;`,a=W().getNumber("WEBGL_VERSION")===2?o:i,l=r==="left"?"<":"<=";this.userCode=` + */class moe{constructor(e,n,s,r){this.variableNames=["sortedSequence","values"],this.customUniforms=[{name:"numInputs",type:"int"}],this.outputShape=[e,s];const o="while (left < right) {",i=`for (int i = 0; i < ${Math.ceil(Math.log2(n+1))}; ++i) { if (left >= right) break;`,a=W().getNumber("WEBGL_VERSION")===2?o:i,l=r==="left"?"<":"<=";this.userCode=` int findBound(int batch, float value) { int left = 0; int right = numInputs; @@ -19410,7 +19410,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function moe(t){const{inputs:e,backend:n,attrs:s}=t,{sortedSequence:r,values:o}=e,{side:i}=s,a=new poe(r.shape[0],r.shape[1],o.shape[1],i),l=[[r.shape[1]]];return n.runWebGLProgram(a,[r,o],"int32",l)}const goe={kernelName:c$,backendName:"webgl",kernelFunc:moe};/** + */function goe(t){const{inputs:e,backend:n,attrs:s}=t,{sortedSequence:r,values:o}=e,{side:i}=s,a=new moe(r.shape[0],r.shape[1],o.shape[1],i),l=[[r.shape[1]]];return n.runWebGLProgram(a,[r,o],"int32",l)}const xoe={kernelName:u$,backendName:"webgl",kernelFunc:goe};/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19425,7 +19425,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class xoe{constructor(e,n,s){this.variableNames=["c","a","b"],this.outputShape=n;let r,o;if(s>4)throw Error(`Where for rank ${s} is not yet supported`);if(s===1)o="resRC",r="resRC";else{const a=["resRC.x","resRC.y","resRC.z","resRC.w"],l=[],c=[];for(let u=0;u4)throw Error(`Where for rank ${s} is not yet supported`);if(s===1)o="resRC",r="resRC";else{const a=["resRC.x","resRC.y","resRC.z","resRC.w"],l=[],c=[];for(let u=0;u= 0.0) ? scale * x : scaleAlpha * (exp(x) - 1.0); -`,boe=Oe({opSnippet:voe}),Coe={kernelName:Yu,backendName:"webgl",kernelFunc:boe};/** +`,Coe=Oe({opSnippet:boe}),koe={kernelName:Yu,backendName:"webgl",kernelFunc:Coe};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19486,9 +19486,9 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const koe=_l+` + */const Soe=_l+` return 1.0 / (1.0 + exp(-1.0 * x)); -`,Soe=` +`,Ioe=` vec4 result = 1.0 / (1.0 + exp(-1.0 * x)); bvec4 isNaN = isnan(x); @@ -19498,7 +19498,7 @@ return a / b;`,Bse=` result.a = isNaN.a ? x.a : result.a; return result; -`,Ioe=Oe({opSnippet:koe,packedOpSnippet:Soe,cpuKernelImpl:SQ}),$oe={kernelName:ed,backendName:"webgl",kernelFunc:Ioe};/** +`,$oe=Oe({opSnippet:Soe,packedOpSnippet:Ioe,cpuKernelImpl:IQ}),Noe={kernelName:eh,backendName:"webgl",kernelFunc:$oe};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19513,10 +19513,10 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Noe=` + */const Toe=` if (isnan(x)) { return 0.0; } return sign(x); -`,Toe=Oe({opSnippet:Noe}),Eoe={kernelName:Ju,backendName:"webgl",kernelFunc:Toe};/** +`,Eoe=Oe({opSnippet:Toe}),Roe={kernelName:Ju,backendName:"webgl",kernelFunc:Eoe};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19531,14 +19531,14 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Roe=_l+` + */const Aoe=_l+` return sin(x); -`,Aoe=` +`,Doe=` vec4 result = sin(x); bvec4 isNaN = isnan(x); ${na} return result; -`,Doe=Oe({opSnippet:Roe,packedOpSnippet:Aoe}),_oe={kernelName:Qu,backendName:"webgl",kernelFunc:Doe};/** +`,_oe=Oe({opSnippet:Aoe,packedOpSnippet:Doe}),Foe={kernelName:Qu,backendName:"webgl",kernelFunc:_oe};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19553,10 +19553,10 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Foe=` + */const zoe=` float e2x = exp(x); return (e2x - 1.0 / e2x) / 2.0; -`,zoe=Oe({opSnippet:Foe}),Ooe={kernelName:Zu,backendName:"webgl",kernelFunc:zoe};/** +`,Ooe=Oe({opSnippet:zoe}),Moe={kernelName:Zu,backendName:"webgl",kernelFunc:Ooe};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19571,7 +19571,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Moe=` + */const Poe=` float epsilon = 1.1920928955078125e-7; float threshold = log(epsilon) + 2.0; @@ -19591,7 +19591,7 @@ return a / b;`,Bse=` result = log(exp_x + 1.0); } return result; -`,Poe=Oe({opSnippet:Moe}),Loe={kernelName:td,backendName:"webgl",kernelFunc:Poe};/** +`,Loe=Oe({opSnippet:Poe}),Boe={kernelName:th,backendName:"webgl",kernelFunc:Loe};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19606,7 +19606,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Boe=t=>{const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{blockShape:o,paddings:i}=s;I(r.shape.length<=4,()=>"spaceToBatchND for rank > 4 with a WebGL backend not implemented yet");const a=o.reduce((m,y)=>m*y),l=[[0,0]];l.push(...i);for(let m=1+o.length;mn.disposeIntermediateTensorInfo(m)),x},Voe={kernelName:lm,backendName:"webgl",kernelFunc:Boe};/** + */const Voe=t=>{const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{blockShape:o,paddings:i}=s;I(r.shape.length<=4,()=>"spaceToBatchND for rank > 4 with a WebGL backend not implemented yet");const a=o.reduce((m,y)=>m*y),l=[[0,0]];l.push(...i);for(let m=1+o.length;mn.disposeIntermediateTensorInfo(m)),x},Woe={kernelName:lm,backendName:"webgl",kernelFunc:Voe};/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19621,11 +19621,11 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Woe(t){const{inputs:e,backend:n}=t,{indices:s,values:r,denseShape:o,defaultValue:i}=e;if(o.shape.length!==1)throw new Error(`Dense shape must be a vector, saw: + */function Uoe(t){const{inputs:e,backend:n}=t,{indices:s,values:r,denseShape:o,defaultValue:i}=e;if(o.shape.length!==1)throw new Error(`Dense shape must be a vector, saw: ${o.shape}`);if(s.shape.length!==2)throw new Error(`Indices must be a matrix, saw: ${s.shape}`);if(r.shape.length!==1)throw new Error(`Values must be a vector, saw: ${r.shape}`);if(i.shape.length!==0)throw new Error(`Default value must be a scalar, saw: - ${i.shape}`);const a=n.readSync(s.dataId),l=n.readSync(r.dataId),c=n.readSync(o.dataId),u=n.readSync(i.dataId)[0],[d,h,f,p,g]=$Q(a,s.shape,s.dtype,l,r.dtype,c,u);return[n.makeTensorInfo(h,s.dtype,d),n.makeTensorInfo([h[0]],r.dtype,f),n.makeTensorInfo([p.length],"bool",new Uint8Array(p.map(x=>Number(x)))),n.makeTensorInfo([g.length],s.dtype,new Int32Array(g))]}const Uoe={kernelName:u$,backendName:"webgl",kernelFunc:Woe};/** + ${i.shape}`);const a=n.readSync(s.dataId),l=n.readSync(r.dataId),c=n.readSync(o.dataId),u=n.readSync(i.dataId)[0],[h,d,f,p,g]=NQ(a,s.shape,s.dtype,l,r.dtype,c,u);return[n.makeTensorInfo(d,s.dtype,h),n.makeTensorInfo([d[0]],r.dtype,f),n.makeTensorInfo([p.length],"bool",new Uint8Array(p.map(x=>Number(x)))),n.makeTensorInfo([g.length],s.dtype,new Int32Array(g))]}const Goe={kernelName:h$,backendName:"webgl",kernelFunc:Uoe};/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19640,7 +19640,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Goe(t){const{inputs:e,backend:n}=t,{inputIndices:s,inputShape:r,newShape:o}=e;if(s.shape.length!==2)throw new Error(`Input indices should be a matrix but received shape ${s.shape}`);if(r.shape.length!==1)throw new Error(`Input shape should be a vector but received shape ${r.shape}`);if(o.shape.length!==1)throw new Error(`Target shape should be a vector but received shape ${o.shape}`);const i=Array.from(n.readSync(r.dataId)),a=n.readSync(s.dataId),l=Array.from(n.readSync(o.dataId)),[c,u,d]=NQ(a,s.shape,s.dtype,i,l);return[n.makeTensorInfo(u,s.dtype,c),n.makeTensorInfo([d.length],o.dtype,new Int32Array(d))]}const Hoe={kernelName:d$,backendName:"webgl",kernelFunc:Goe};/** + */function Hoe(t){const{inputs:e,backend:n}=t,{inputIndices:s,inputShape:r,newShape:o}=e;if(s.shape.length!==2)throw new Error(`Input indices should be a matrix but received shape ${s.shape}`);if(r.shape.length!==1)throw new Error(`Input shape should be a vector but received shape ${r.shape}`);if(o.shape.length!==1)throw new Error(`Target shape should be a vector but received shape ${o.shape}`);const i=Array.from(n.readSync(r.dataId)),a=n.readSync(s.dataId),l=Array.from(n.readSync(o.dataId)),[c,u,h]=TQ(a,s.shape,s.dtype,i,l);return[n.makeTensorInfo(u,s.dtype,c),n.makeTensorInfo([h.length],o.dtype,new Int32Array(h))]}const joe={kernelName:d$,backendName:"webgl",kernelFunc:Hoe};/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19655,9 +19655,9 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function joe(t){const{inputs:e,backend:n}=t,{data:s,indices:r,segmentIds:o}=e;if(s.shape.length<1)throw new Error("Data should be at least 1 dimensional but received scalar");if(r.shape.length!==1)throw new Error(`Indices should be a vector but received shape + */function Koe(t){const{inputs:e,backend:n}=t,{data:s,indices:r,segmentIds:o}=e;if(s.shape.length<1)throw new Error("Data should be at least 1 dimensional but received scalar");if(r.shape.length!==1)throw new Error(`Indices should be a vector but received shape ${r.shape}`);if(o.shape.length!==1)throw new Error(`Segment ids should be a vector but received shape - ${o.shape}`);const i=n.readSync(s.dataId),a=n.readSync(r.dataId),l=n.readSync(o.dataId),[c,u]=JA(i,s.shape,s.dtype,a,l,!0);return n.makeTensorInfo(u,s.dtype,c)}const Koe={kernelName:h$,backendName:"webgl",kernelFunc:joe};/** + ${o.shape}`);const i=n.readSync(s.dataId),a=n.readSync(r.dataId),l=n.readSync(o.dataId),[c,u]=eD(i,s.shape,s.dtype,a,l,!0);return n.makeTensorInfo(u,s.dtype,c)}const Xoe={kernelName:f$,backendName:"webgl",kernelFunc:Koe};/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19672,9 +19672,9 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Xoe(t){const{inputs:e,backend:n}=t,{data:s,indices:r,segmentIds:o}=e;if(s.shape.length<1)throw new Error("Data should be at least 1 dimensional but received scalar");if(r.shape.length!==1)throw new Error(`Indices should be a vector but received shape + */function qoe(t){const{inputs:e,backend:n}=t,{data:s,indices:r,segmentIds:o}=e;if(s.shape.length<1)throw new Error("Data should be at least 1 dimensional but received scalar");if(r.shape.length!==1)throw new Error(`Indices should be a vector but received shape ${r.shape}`);if(o.shape.length!==1)throw new Error(`Segment ids should be a vector but received shape - ${o.shape}`);const i=n.readSync(s.dataId),a=n.readSync(r.dataId),l=n.readSync(o.dataId),[c,u]=JA(i,s.shape,s.dtype,a,l);return n.makeTensorInfo(u,s.dtype,c)}const qoe={kernelName:f$,backendName:"webgl",kernelFunc:Xoe};/** + ${o.shape}`);const i=n.readSync(s.dataId),a=n.readSync(r.dataId),l=n.readSync(o.dataId),[c,u]=eD(i,s.shape,s.dtype,a,l);return n.makeTensorInfo(u,s.dtype,c)}const Yoe={kernelName:p$,backendName:"webgl",kernelFunc:qoe};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19689,7 +19689,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Yoe(t){const{inputs:e,backend:n,attrs:s}=t,{sparseIndices:r,sparseValues:o,defaultValue:i}=e,{outputShape:a}=s,{sliceRank:l,numUpdates:c,sliceSize:u,strides:d,outputSize:h}=Qi(o,r,a),f=!1;if(o.dtype==="string"){const m=n.bufferSync(r),y=n.bufferSync(o),w=Do(n.readSync(i.dataId)[0]),v=kQ(m,y,a,h,u,c,l,d,w,f);return n.makeTensorInfo(a,v.dtype,v.values)}const p=new Tv(c,l,r.shape.length,o.shape.length,d,[h,1],f),g=n.runWebGLProgram(p,[o,r,i],o.dtype),x=re({inputs:{x:g},backend:n,attrs:{shape:a}});return n.disposeIntermediateTensorInfo(g),x}const Qoe={kernelName:p$,backendName:"webgl",kernelFunc:Yoe};/** + */function Qoe(t){const{inputs:e,backend:n,attrs:s}=t,{sparseIndices:r,sparseValues:o,defaultValue:i}=e,{outputShape:a}=s,{sliceRank:l,numUpdates:c,sliceSize:u,strides:h,outputSize:d}=Qi(o,r,a),f=!1;if(o.dtype==="string"){const m=n.bufferSync(r),y=n.bufferSync(o),w=Do(n.readSync(i.dataId)[0]),v=SQ(m,y,a,d,u,c,l,h,w,f);return n.makeTensorInfo(a,v.dtype,v.values)}const p=new Tv(c,l,r.shape.length,o.shape.length,h,[d,1],f),g=n.runWebGLProgram(p,[o,r,i],o.dtype),x=re({inputs:{x:g},backend:n,attrs:{shape:a}});return n.disposeIntermediateTensorInfo(g),x}const Zoe={kernelName:m$,backendName:"webgl",kernelFunc:Qoe};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19704,7 +19704,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Zoe(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{numOrSizeSplits:o,axis:i}=s,a=Re(i,r.shape)[0],l=Vw(r,o,a),c=r.shape.length,u=new Array(c).fill(0),d=r.shape.slice();return l.map(h=>{const f=[...d];f[a]=h;const p=Fl({inputs:{x:r},backend:n,attrs:{begin:u,size:f}});return u[a]+=h,p})}const Joe={kernelName:cm,backendName:"webgl",kernelFunc:Zoe};/** + */function Joe(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{numOrSizeSplits:o,axis:i}=s,a=Re(i,r.shape)[0],l=Vw(r,o,a),c=r.shape.length,u=new Array(c).fill(0),h=r.shape.slice();return l.map(d=>{const f=[...h];f[a]=d;const p=Fl({inputs:{x:r},backend:n,attrs:{begin:u,size:f}});return u[a]+=d,p})}const eie={kernelName:cm,backendName:"webgl",kernelFunc:Joe};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19719,7 +19719,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const jk="return sqrt(x);",eie=Oe({opSnippet:jk,packedOpSnippet:jk,cpuKernelImpl:TQ}),tie={kernelName:nd,backendName:"webgl",kernelFunc:eie};/** + */const jk="return sqrt(x);",tie=Oe({opSnippet:jk,packedOpSnippet:jk,cpuKernelImpl:EQ}),nie={kernelName:nh,backendName:"webgl",kernelFunc:tie};/** * @license * Copyright 2019 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19734,7 +19734,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const nie="return x * x;",sie=Oe({opSnippet:nie}),rie={kernelName:Sy,backendName:"webgl",kernelFunc:sie};/** + */const sie="return x * x;",rie=Oe({opSnippet:sie}),oie={kernelName:Sy,backendName:"webgl",kernelFunc:rie};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19749,7 +19749,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Kk="return (a - b) * (a - b);",oie=rn({opSnippet:Kk,packedOpSnippet:Kk}),iie={kernelName:sd,backendName:"webgl",kernelFunc:oie};/** + */const Kk="return (a - b) * (a - b);",iie=rn({opSnippet:Kk,packedOpSnippet:Kk}),aie={kernelName:sh,backendName:"webgl",kernelFunc:iie};/** * @license * Copyright 2023 Google LLC. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19764,7 +19764,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function aie(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e;if(r.dtype!=="string")throw new Error("Input must be of datatype string");const o=n.readSync(r.dataId),i=jr(o),a=EQ(i,"string",s);return n.makeTensorInfo(r.shape,"string",a)}const lie={kernelName:Iy,backendName:"webgl",kernelFunc:aie};/** + */function lie(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e;if(r.dtype!=="string")throw new Error("Input must be of datatype string");const o=n.readSync(r.dataId),i=Kr(o),a=RQ(i,"string",s);return n.makeTensorInfo(r.shape,"string",a)}const cie={kernelName:Iy,backendName:"webgl",kernelFunc:lie};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19779,9 +19779,9 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function cie({inputs:t,attrs:e,backend:n}){const{x:s}=t,r=Ds+` + */function uie({inputs:t,attrs:e,backend:n}){const{x:s}=t,r=_s+` return x > 0.0 ? 1.0 : float(${e.alpha}); - `,o=new fr(s.shape,r);return n.runWebGLProgram(o,[s],s.dtype)}const uie={kernelName:ld,backendName:"webgl",kernelFunc:cie};/** + `,o=new pr(s.shape,r);return n.runWebGLProgram(o,[s],s.dtype)}const hie={kernelName:lh,backendName:"webgl",kernelFunc:uie};/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19819,7 +19819,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function hie(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{begin:o,end:i,strides:a,beginMask:l,endMask:c,ellipsisMask:u,newAxisMask:d,shrinkAxisMask:h}=s,{finalShapeSparse:f,finalShape:p,isIdentity:g,sliceDim0:x,isSimpleSlice:m,begin:y,end:w,strides:v}=kw(r.shape,o,i,a,l,c,u,d,h);let b;if(g)b=re({inputs:{x:r},backend:n,attrs:{shape:p}});else if(x||m){I(r.shape.length>=1,()=>`Input must have rank at least 1, got: ${r.shape.length}`);const k=vw(y,w,v),S=Fl({inputs:{x:r},backend:n,attrs:{begin:y,size:k}});b=re({inputs:{x:S},backend:n,attrs:{shape:p}}),n.disposeIntermediateTensorInfo(S)}else if(n.shouldExecuteOnCPU([r])){const S=n.readSync(r.dataId),$=Ee(r.shape,r.dtype,S),N=RQ(f,$,v,y);b=n.makeTensorInfo(p,r.dtype,N.values)}else{const S=new die(y,v,f);b=n.runWebGLProgram(S,[r],r.dtype)}const C=re({inputs:{x:b},backend:n,attrs:{shape:p}});return n.disposeIntermediateTensorInfo(b),C}const fie={kernelName:$y,backendName:"webgl",kernelFunc:hie};/** + */function fie(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{begin:o,end:i,strides:a,beginMask:l,endMask:c,ellipsisMask:u,newAxisMask:h,shrinkAxisMask:d}=s,{finalShapeSparse:f,finalShape:p,isIdentity:g,sliceDim0:x,isSimpleSlice:m,begin:y,end:w,strides:v}=kw(r.shape,o,i,a,l,c,u,h,d);let b;if(g)b=re({inputs:{x:r},backend:n,attrs:{shape:p}});else if(x||m){I(r.shape.length>=1,()=>`Input must have rank at least 1, got: ${r.shape.length}`);const k=vw(y,w,v),S=Fl({inputs:{x:r},backend:n,attrs:{begin:y,size:k}});b=re({inputs:{x:S},backend:n,attrs:{shape:p}}),n.disposeIntermediateTensorInfo(S)}else if(n.shouldExecuteOnCPU([r])){const S=n.readSync(r.dataId),$=Ee(r.shape,r.dtype,S),N=AQ(f,$,v,y);b=n.makeTensorInfo(p,r.dtype,N.values)}else{const S=new die(y,v,f);b=n.runWebGLProgram(S,[r],r.dtype)}const C=re({inputs:{x:b},backend:n,attrs:{shape:p}});return n.disposeIntermediateTensorInfo(b),C}const pie={kernelName:$y,backendName:"webgl",kernelFunc:fie};/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19834,7 +19834,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function pie(t){const{inputs:e,backend:n,attrs:s}=t,{separator:r,nGramWidths:o,leftPad:i,rightPad:a,padWidth:l,preserveShortSequences:c}=s,{data:u,dataSplits:d}=e,h=n.readSync(u.dataId),f=n.readSync(d.dataId),[p,g]=AQ(h,f,r,o,i,a,l,c);return[n.makeTensorInfo([p.length],"string",p),n.makeTensorInfo(d.shape,"int32",g)]}const mie={kernelName:m$,backendName:"webgl",kernelFunc:pie};/** + */function mie(t){const{inputs:e,backend:n,attrs:s}=t,{separator:r,nGramWidths:o,leftPad:i,rightPad:a,padWidth:l,preserveShortSequences:c}=s,{data:u,dataSplits:h}=e,d=n.readSync(u.dataId),f=n.readSync(h.dataId),[p,g]=DQ(d,f,r,o,i,a,l,c);return[n.makeTensorInfo([p.length],"string",p),n.makeTensorInfo(h.shape,"int32",g)]}const gie={kernelName:g$,backendName:"webgl",kernelFunc:mie};/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19849,7 +19849,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function gie(t){const{inputs:e,backend:n,attrs:s}=t,{skipEmpty:r}=s,{input:o,delimiter:i}=e;if(o.dtype!=="string")throw new Error("Input must be of datatype string");if(o.shape.length!==1)throw new Error(`Input must be a vector, got shape: ${o.shape}`);if(i.shape.length!==0)throw new Error(`Delimiter must be a scalar, got shape: ${i.shape}`);const a=n.readSync(o.dataId),l=n.readSync(i.dataId)[0],[c,u,d]=DQ(a,l,r),h=u.length;return[n.makeTensorInfo([h,2],"int32",c),n.makeTensorInfo([h],"string",u),n.makeTensorInfo([2],"int32",new Int32Array(d))]}const xie={kernelName:g$,backendName:"webgl",kernelFunc:gie};/** + */function xie(t){const{inputs:e,backend:n,attrs:s}=t,{skipEmpty:r}=s,{input:o,delimiter:i}=e;if(o.dtype!=="string")throw new Error("Input must be of datatype string");if(o.shape.length!==1)throw new Error(`Input must be a vector, got shape: ${o.shape}`);if(i.shape.length!==0)throw new Error(`Delimiter must be a scalar, got shape: ${i.shape}`);const a=n.readSync(o.dataId),l=n.readSync(i.dataId)[0],[c,u,h]=_Q(a,l,r),d=u.length;return[n.makeTensorInfo([d,2],"int32",c),n.makeTensorInfo([d],"string",u),n.makeTensorInfo([2],"int32",new Int32Array(h))]}const yie={kernelName:x$,backendName:"webgl",kernelFunc:xie};/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19864,7 +19864,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function yie(t){const{inputs:e,backend:n,attrs:s}=t,{numBuckets:r}=s,{input:o}=e;if(o.dtype!=="string")throw new Error("Input must be of datatype string");if(r<=0)throw new Error("Number of buckets must be at least 1");const i=n.readSync(o.dataId),a=_Q(i,r);return n.makeTensorInfo(o.shape,"int32",a)}const wie={kernelName:x$,backendName:"webgl",kernelFunc:yie};/** + */function wie(t){const{inputs:e,backend:n,attrs:s}=t,{numBuckets:r}=s,{input:o}=e;if(o.dtype!=="string")throw new Error("Input must be of datatype string");if(r<=0)throw new Error("Number of buckets must be at least 1");const i=n.readSync(o.dataId),a=FQ(i,r);return n.makeTensorInfo(o.shape,"int32",a)}const vie={kernelName:y$,backendName:"webgl",kernelFunc:wie};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19879,7 +19879,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const vie="return tan(x);",bie=Oe({opSnippet:vie}),Cie={kernelName:od,backendName:"webgl",kernelFunc:bie};/** + */const bie="return tan(x);",Cie=Oe({opSnippet:bie}),kie={kernelName:oh,backendName:"webgl",kernelFunc:Cie};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19894,10 +19894,10 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const kie=` + */const Sie=` float e2x = exp(-2.0 * abs(x)); return sign(x) * (1.0 - e2x) / (1.0 + e2x); -`,Sie=Oe({opSnippet:kie}),Iie={kernelName:id,backendName:"webgl",kernelFunc:Sie};/** +`,Iie=Oe({opSnippet:Sie}),$ie={kernelName:ih,backendName:"webgl",kernelFunc:Iie};/** * @license * Copyright 2022 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19912,7 +19912,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function $ie(t){const{inputs:e,backend:n,attrs:s}=t,{tensor:r,indices:o,updates:i}=e,{sliceRank:a,numUpdates:l,sliceSize:c,strides:u,outputSize:d}=Qi(i,o,r.shape),h=[d/c,c];if(d===0)return n.makeTensorInfo(r.shape,o.dtype);const f=re({inputs:{x:o},backend:n,attrs:{shape:[l,a]}}),p=re({inputs:{x:i},backend:n,attrs:{shape:[l,c]}}),g=re({inputs:{x:r},backend:n,attrs:{shape:h}}),x=new Tv(l,a,f.shape.length,p.shape.length,u,h,!1,!0),m=n.runWebGLProgram(x,[p,f,g],g.dtype),y=re({inputs:{x:m},backend:n,attrs:{shape:r.shape}});return n.disposeIntermediateTensorInfo(f),n.disposeIntermediateTensorInfo(p),n.disposeIntermediateTensorInfo(g),n.disposeIntermediateTensorInfo(m),y}const Nie={kernelName:l$,backendName:"webgl",kernelFunc:$ie};/** + */function Nie(t){const{inputs:e,backend:n,attrs:s}=t,{tensor:r,indices:o,updates:i}=e,{sliceRank:a,numUpdates:l,sliceSize:c,strides:u,outputSize:h}=Qi(i,o,r.shape),d=[h/c,c];if(h===0)return n.makeTensorInfo(r.shape,o.dtype);const f=re({inputs:{x:o},backend:n,attrs:{shape:[l,a]}}),p=re({inputs:{x:i},backend:n,attrs:{shape:[l,c]}}),g=re({inputs:{x:r},backend:n,attrs:{shape:d}}),x=new Tv(l,a,f.shape.length,p.shape.length,u,d,!1,!0),m=n.runWebGLProgram(x,[p,f,g],g.dtype),y=re({inputs:{x:m},backend:n,attrs:{shape:r.shape}});return n.disposeIntermediateTensorInfo(f),n.disposeIntermediateTensorInfo(p),n.disposeIntermediateTensorInfo(g),n.disposeIntermediateTensorInfo(m),y}const Tie={kernelName:c$,backendName:"webgl",kernelFunc:Nie};/** * @license * Copyright 2017 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19927,12 +19927,12 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class Tie{constructor(e,n){this.variableNames=["A"];const s=new Array(e.length);for(let i=0;i5)throw Error(`Tile for rank ${e} is not yet supported`);if(e===1)return`imod(resRC, ${t[0]})`;const n=["resRC.x","resRC.y","resRC.z","resRC.w","resRC.u"],s=[];for(let r=0;r5)throw Error(`Tile for rank ${e} is not yet supported`);if(e===1)return`imod(resRC, ${t[0]})`;const n=["resRC.x","resRC.y","resRC.z","resRC.w","resRC.u"],s=[];for(let r=0;r5){const l=n.readSync(r.dataId),c=r.dtype==="string"?l.map(h=>Do(h)):l,u=Ee(r.shape,r.dtype,c),d=zQ(u,o);return n.makeTensorInfo(d.shape,d.dtype,d.values)}const i=new Tie(r.shape,o);return n.runWebGLProgram(i,[r],r.dtype)}const Rie={kernelName:ad,backendName:"webgl",kernelFunc:RD};class Aie{constructor(e){this.variableNames=["x","indices"],this.customUniforms=[{name:"n",type:"int"},{name:"firstPass",type:"int"},{name:"negativeInf",type:"float"},{name:"dir",type:"int"},{name:"inc",type:"int"}],this.outputShape=e,this.userCode=` + */function AD(t){const{inputs:e,backend:n,attrs:s}=t,{x:r}=e,{reps:o}=s;if(r.dtype==="string"||r.shape.length>5){const l=n.readSync(r.dataId),c=r.dtype==="string"?l.map(d=>Do(d)):l,u=Ee(r.shape,r.dtype,c),h=OQ(u,o);return n.makeTensorInfo(h.shape,h.dtype,h.values)}const i=new Eie(r.shape,o);return n.runWebGLProgram(i,[r],r.dtype)}const Aie={kernelName:ah,backendName:"webgl",kernelFunc:AD};class Die{constructor(e){this.variableNames=["x","indices"],this.customUniforms=[{name:"n",type:"int"},{name:"firstPass",type:"int"},{name:"negativeInf",type:"float"},{name:"dir",type:"int"},{name:"inc",type:"int"}],this.outputShape=e,this.userCode=` void main() { ivec2 coords = getOutputCoords(); int batch = coords[0]; @@ -19987,7 +19987,7 @@ return a / b;`,Bse=` setOutput(float(i1)); } } - `}}class Die{constructor(e){this.variableNames=["x","indices"],this.customUniforms=[{name:"n",type:"int"},{name:"firstPass",type:"int"},{name:"k",type:"int"}],this.outputShape=e,this.userCode=` + `}}class _ie{constructor(e){this.variableNames=["x","indices"],this.customUniforms=[{name:"n",type:"int"},{name:"firstPass",type:"int"},{name:"k",type:"int"}],this.outputShape=e,this.userCode=` void main() { // Takes max of indices (0, k), (1, k + 1), (2, k + 2) ... ivec2 coords = getOutputCoords(); @@ -20036,7 +20036,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function ti(t,e){e!==null&&t.disposeIntermediateTensorInfo(e)}function Xk(t){let e=1;for(;el){const N=n.readSync(r.dataId),[A,M]=OQ(N,c,r.dtype,o,i);return[n.makeTensorInfo(A.shape,A.dtype,A.values),n.makeTensorInfo(M.shape,M.dtype,M.values)]}if(o===0)return c[c.length-1]=0,[n.makeTensorInfo(c,r.dtype,[]),n.makeTensorInfo(c,"int32",[])];if(u===1)return[r,Dd({attrs:{shape:c,dtype:"int32",value:0},backend:n})];const d=n.texData.get(r.dataId),h=d!==null&&d.isPacked,f=h?n.unpackTensor(r):r,g=j(c)/u,x=re({inputs:{x:f},attrs:{shape:[g,u]},backend:n});h&&ti(n,f);const m=Xk(o),y=Xk(u);let w=null;const v=()=>w===null?[x,x]:[x,w],b=(N,A,M)=>{const L=v(),V=new Aie(M),U=[[u],[w===null?1:0],[Number.NEGATIVE_INFINITY],[N],[A]],K=w;w=n.runWebGLProgram(V,L,"int32",U),ti(n,K)};for(let N=1;N=1;M/=2)b(A,M,[g,y])}for(let N=y;N>m;N/=2){const A=v(),M=new Die([g,N/2]),V=[[u],[w===null?1:0],[m]],B=w;w=n.runWebGLProgram(M,A,"int32",V),ti(n,B);const U=m/2,K=U*2;for(let R=U;R>=1;R/=2)b(K,R,w.shape)}let C=w;w=Fl({inputs:{x:w},backend:n,attrs:{begin:0,size:[g,o]}}),ti(n,C);let k=CD({inputs:{x,indices:w},backend:n,attrs:{axis:1,batchDims:1}});ti(n,x);const S=c.slice(0,-1);S.push(o),C=w,w=re({inputs:{x:w},attrs:{shape:S},backend:n}),ti(n,C);const $=k;return k=re({inputs:{x:k},attrs:{shape:S},backend:n}),ti(n,$),[k,w]}const Fie={kernelName:Ny,backendName:"webgl",kernelFunc:_ie};/** + */function ti(t,e){e!==null&&t.disposeIntermediateTensorInfo(e)}function Xk(t){let e=1;for(;el){const N=n.readSync(r.dataId),[A,M]=MQ(N,c,r.dtype,o,i);return[n.makeTensorInfo(A.shape,A.dtype,A.values),n.makeTensorInfo(M.shape,M.dtype,M.values)]}if(o===0)return c[c.length-1]=0,[n.makeTensorInfo(c,r.dtype,[]),n.makeTensorInfo(c,"int32",[])];if(u===1)return[r,Dh({attrs:{shape:c,dtype:"int32",value:0},backend:n})];const h=n.texData.get(r.dataId),d=h!==null&&h.isPacked,f=d?n.unpackTensor(r):r,g=j(c)/u,x=re({inputs:{x:f},attrs:{shape:[g,u]},backend:n});d&&ti(n,f);const m=Xk(o),y=Xk(u);let w=null;const v=()=>w===null?[x,x]:[x,w],b=(N,A,M)=>{const L=v(),V=new Die(M),U=[[u],[w===null?1:0],[Number.NEGATIVE_INFINITY],[N],[A]],K=w;w=n.runWebGLProgram(V,L,"int32",U),ti(n,K)};for(let N=1;N=1;M/=2)b(A,M,[g,y])}for(let N=y;N>m;N/=2){const A=v(),M=new _ie([g,N/2]),V=[[u],[w===null?1:0],[m]],B=w;w=n.runWebGLProgram(M,A,"int32",V),ti(n,B);const U=m/2,K=U*2;for(let R=U;R>=1;R/=2)b(K,R,w.shape)}let C=w;w=Fl({inputs:{x:w},backend:n,attrs:{begin:0,size:[g,o]}}),ti(n,C);let k=kD({inputs:{x,indices:w},backend:n,attrs:{axis:1,batchDims:1}});ti(n,x);const S=c.slice(0,-1);S.push(o),C=w,w=re({inputs:{x:w},attrs:{shape:S},backend:n}),ti(n,C);const $=k;return k=re({inputs:{x:k},attrs:{shape:S},backend:n}),ti(n,$),[k,w]}const zie={kernelName:Ny,backendName:"webgl",kernelFunc:Fie};/** * @license * Copyright 2021 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -20051,7 +20051,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class zie{constructor(e,n,s,r,o,i){this.variableNames=["Image","Transforms"],this.outputShape=i;const a=s==="nearest"?1:2;let l;switch(r){case"constant":l=1;break;case"reflect":l=2;break;case"wrap":l=3;break;case"nearest":l=4;break;default:l=1;break}this.userCode=` + */class Oie{constructor(e,n,s,r,o,i){this.variableNames=["Image","Transforms"],this.outputShape=i;const a=s==="nearest"?1:2;let l;switch(r){case"constant":l=1;break;case"reflect":l=2;break;case"wrap":l=3;break;case"nearest":l=4;break;default:l=1;break}this.userCode=` float mapCoord(float outCoord, float len) { float inCoord = outCoord; if(${l} == 2) { @@ -20178,7 +20178,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Oie(t){const{inputs:e,backend:n,attrs:s}=t,{image:r,transforms:o}=e,{interpolation:i,fillMode:a,fillValue:l,outputShape:c}=s,[u,d,h,f]=r.shape,[p,g]=c??[d,h],x=[u,p,g,f],m=new zie(d,h,i,a,l,x);return n.runWebGLProgram(m,[r,o],"float32")}const Mie={kernelName:Ty,backendName:"webgl",kernelFunc:Oie};/** + */function Mie(t){const{inputs:e,backend:n,attrs:s}=t,{image:r,transforms:o}=e,{interpolation:i,fillMode:a,fillValue:l,outputShape:c}=s,[u,h,d,f]=r.shape,[p,g]=c??[h,d],x=[u,p,g,f],m=new Oie(h,d,i,a,l,x);return n.runWebGLProgram(m,[r,o],"float32")}const Pie={kernelName:Ty,backendName:"webgl",kernelFunc:Mie};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the License); @@ -20193,7 +20193,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Pie(t){const{inputs:e,attrs:n,backend:s}=t,{axis:r}=n,{x:o}=e;Ed(o,"unique"),console.warn("WARNING: ","UI might be locked temporarily as data is being downloaded");const i=s.readSync(o.dataId),{outputValues:a,outputShape:l,indices:c}=MQ(i,r,o.shape,o.dtype);return[s.makeTensorInfo(l,o.dtype,a),s.makeTensorInfo([c.length],"int32",c)]}const Lie={kernelName:Ey,backendName:"webgl",kernelFunc:Pie};/** + */function Lie(t){const{inputs:e,attrs:n,backend:s}=t,{axis:r}=n,{x:o}=e;Eh(o,"unique"),console.warn("WARNING: ","UI might be locked temporarily as data is being downloaded");const i=s.readSync(o.dataId),{outputValues:a,outputShape:l,indices:c}=PQ(i,r,o.shape,o.dtype);return[s.makeTensorInfo(l,o.dtype,a),s.makeTensorInfo([c.length],"int32",c)]}const Bie={kernelName:Ey,backendName:"webgl",kernelFunc:Lie};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -20208,7 +20208,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Bie(t){const{inputs:e,backend:n,attrs:s}=t,{value:r}=e;let{axis:o}=s;o<0&&(o+=r.shape.length);const i=r,a=i.shape.length,l=r.shape[o],c=new Array(a-1);let u=0;for(let g=0;gn.disposeIntermediateTensorInfo(g)),p}const Vie={kernelName:dm,backendName:"webgl",kernelFunc:Bie};/** + */function Vie(t){const{inputs:e,backend:n,attrs:s}=t,{value:r}=e;let{axis:o}=s;o<0&&(o+=r.shape.length);const i=r,a=i.shape.length,l=r.shape[o],c=new Array(a-1);let u=0;for(let g=0;gn.disposeIntermediateTensorInfo(g)),p}const Wie={kernelName:hm,backendName:"webgl",kernelFunc:Vie};/** * @license * Copyright 2018 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -20223,7 +20223,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */class Wie{constructor(e,n){this.variableNames=["x","segmentIds"];const s=e.windowSize,r=e.batchSize,o=e.inSize,i=e.numSegments,a=i*Math.ceil(o/s);this.outputShape=[r,a];const l="0.0",c="sumValue",u=Math.floor(s/4)*4,d=s%4,h=` + */class Uie{constructor(e,n){this.variableNames=["x","segmentIds"];const s=e.windowSize,r=e.batchSize,o=e.inSize,i=e.numSegments,a=i*Math.ceil(o/s);this.outputShape=[r,a];const l="0.0",c="sumValue",u=Math.floor(s/4)*4,h=s%4,d=` sumValue += dot(values, segFilter); `;let f="";o%s>0&&(f=` if (inIdx < 0 || inIdx >= ${o}) { @@ -20272,11 +20272,11 @@ return a / b;`,Bse=` int(getSegmentIdAtIndex(inIdx + 3)) == currentSeg ? 1 : 0 ); - ${h} + ${d} } int inIdx = inOffset + ${u}; - if (${d===1}) { + if (${h===1}) { vec4 values = vec4( getValue(batch, inIdx), initializationValue, @@ -20293,8 +20293,8 @@ return a / b;`,Bse=` 0 ); - ${h} - } else if (${d===2}) { + ${d} + } else if (${h===2}) { vec4 values = vec4( getValue(batch, inIdx), getValue(batch, inIdx + 1), @@ -20309,8 +20309,8 @@ return a / b;`,Bse=` 0 ); - ${h} - } else if (${d===3}) { + ${d} + } else if (${h===3}) { vec4 values = vec4( getValue(batch, inIdx), getValue(batch, inIdx + 1), @@ -20325,7 +20325,7 @@ return a / b;`,Bse=` 0 ); - ${h} + ${d} } setOutput(${c}); } @@ -20344,7 +20344,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */function Uie(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,segmentIds:o}=e,{numSegments:i}=s,a=r.shape.length,l=[];let c=0;const u=yt([c],a);let d=r;u!=null&&(d=Sn({inputs:{x:r},backend:n,attrs:{perm:u}}),l.push(d),c=$t(1,a)[0]);const h=dT(d.shape,c,i),f=j([d.shape[c]]),p=re({inputs:{x:d},backend:n,attrs:{shape:[-1,f]}});l.push(p);const g=Dy(r.dtype),x=(v,b,C,k,S)=>{const $=v.shape[0],N=v.shape[1],A=uT(N,S),M={windowSize:A,inSize:N,batchSize:$,numSegments:S},L=new Wie(M,b),V=n.compileAndRun(L,[v,C],k);if(l.push(V),V.shape[1]===S)return V;const B=ED({backend:n,attrs:{start:0,stop:S,step:1,dtype:"float32"}}),U=RD({inputs:{x:B},backend:n,attrs:{reps:[N/A]}});return l.push(B),l.push(U),x(V,b,U,k,S)},m=x(p,"unsortedSegmentSum",o,g,i),y=re({inputs:{x:m},backend:n,attrs:{shape:h}});let w=y;if(u!=null){l.push(y);const v=Ho(u);w=Sn({inputs:{x:w},backend:n,attrs:{perm:v}})}return l.forEach(v=>n.disposeIntermediateTensorInfo(v)),w}const Gie={kernelName:hm,backendName:"webgl",kernelFunc:Uie};/** + */function Gie(t){const{inputs:e,backend:n,attrs:s}=t,{x:r,segmentIds:o}=e,{numSegments:i}=s,a=r.shape.length,l=[];let c=0;const u=yt([c],a);let h=r;u!=null&&(h=Sn({inputs:{x:r},backend:n,attrs:{perm:u}}),l.push(h),c=$t(1,a)[0]);const d=dT(h.shape,c,i),f=j([h.shape[c]]),p=re({inputs:{x:h},backend:n,attrs:{shape:[-1,f]}});l.push(p);const g=Dy(r.dtype),x=(v,b,C,k,S)=>{const $=v.shape[0],N=v.shape[1],A=hT(N,S),M={windowSize:A,inSize:N,batchSize:$,numSegments:S},L=new Uie(M,b),V=n.compileAndRun(L,[v,C],k);if(l.push(V),V.shape[1]===S)return V;const B=RD({backend:n,attrs:{start:0,stop:S,step:1,dtype:"float32"}}),U=AD({inputs:{x:B},backend:n,attrs:{reps:[N/A]}});return l.push(B),l.push(U),x(V,b,U,k,S)},m=x(p,"unsortedSegmentSum",o,g,i),y=re({inputs:{x:m},backend:n,attrs:{shape:d}});let w=y;if(u!=null){l.push(y);const v=Ho(u);w=Sn({inputs:{x:w},backend:n,attrs:{perm:v}})}return l.forEach(v=>n.disposeIntermediateTensorInfo(v)),w}const Hie={kernelName:dm,backendName:"webgl",kernelFunc:Gie};/** * @license * Copyright 2020 Google LLC. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); @@ -20359,7 +20359,7 @@ return a / b;`,Bse=` * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= - */const Hie=[TZ,RZ,_Z,OZ,PZ,VZ,UZ,HZ,qZ,QZ,eJ,sJ,iJ,uJ,fJ,mJ,xJ,bJ,kJ,IJ,EJ,OJ,PJ,WJ,GJ,YJ,ZJ,nee,dZ,oee,uee,pee,vee,kee,Iee,Nee,Eee,_ee,Oee,Lee,Vee,Uee,Hee,Xee,Yee,ete,nte,ote,lte,ute,pte,yte,Cte,Ite,Tte,Ete,Ate,_te,zte,Mte,Lte,Ute,jte,qte,Qte,ene,sne,ane,dne,uZ,fne,lee,gne,wne,Cne,fZ,$ne,Rne,Dne,One,Lne,Une,jne,Yne,ese,sse,ose,cse,dse,fse,xse,wse,bse,kse,Ise,Ese,_se,Mse,Hse,gZ,qse,Zse,tre,rre,jJ,are,cre,dre,pre,yre,mZ,vre,Cre,Sre,$re,Nre,KJ,Vse,Rre,Fre,Pre,yZ,Wre,Hre,qre,Zre,noe,roe,aoe,uoe,foe,goe,woe,Coe,$oe,Eoe,_oe,Ooe,FJ,Use,Loe,Voe,Uoe,Hoe,Koe,qoe,Qoe,Joe,tie,rie,iie,lie,uie,fie,mie,xie,wie,Wse,IZ,Cie,Iie,Nie,Rie,Fie,Mie,$Z,Lie,Vie,Gie,lre];for(const t of Hie)w$(t);const ar={tank:0,warrior:1,archer:2,artillery:3},Sc={"advance-wait":4,advance:5,"wait-advance":6,"flank-left":7,"flank-right":8},ru=30,Uf=Math.floor(ru/(So/Io));let Ic=null;async function jie(){try{Ic?console.log("Model is already loaded"):(Ic=await aH(window.location.origin+window.location.pathname+"/tfmodel/model.json"),console.log("Model loaded successfully"))}catch(t){throw console.error("Failed to load the model:",t),t}}function Kie(t){return[t.data.map(e=>e.flat())]}async function Xie(t){if(Ic||await jie(),!Ic)throw new Error("Model not loaded. Call loadModel() first.");const e=qV(Kie(t)),n=Ic.predict(e),s=n.squeeze([0]),r=s.arraySync();return e.dispose(),n.dispose(),s.dispose(),{data:r.map(o=>o.reduce((i,a,l)=>(l%9===0&&i.push(o.slice(l,l+9)),i),[])),cols:ru,rows:Uf}}function AD(t){return t.map(e=>({...e,col:-e.col,row:-e.row}))}function qie(t){const e=ru,n=Uf,s=Array.from({length:n},()=>Array.from({length:e},()=>Array(Object.keys(ar).length+Object.keys(Sc).length).fill(0)));let r=0;for(const o of t)for(let i=0;iu.map(d=>Object.values(ar).map(h=>d[h]))).flat(2),r=Math.min(...s),o=Math.max(...s),i=r+(o-r)*.5;for(let u=0;u[p,t.data[u][d][ar[p]]]).sort((p,g)=>g[1]-p[1]).filter(p=>p[1]>i))==null?void 0:a[0])==null?void 0:l[0],f=(c=Object.keys(Sc).map(p=>[p,t.data[u][d][Sc[p]]]).sort((p,g)=>g[1]-p[1])[0])==null?void 0:c[0];h&&(n[u+","+d]={type:h,command:f})}for(let u=0;u({...o}));let s=Gf(n);if(s<=e)return n;let r=s-e;for(n.sort((o,i)=>i.sizeCol*i.sizeRow-o.sizeCol*o.sizeRow);r>0;){let o=!1;for(let i of n)if(i.sizeCol>1&&i.sizeRow>1){const a=i.sizeCol*i.sizeRow-(i.sizeCol-1)*(i.sizeRow-1);if(a<=0)continue;if(a<=r&&(i.sizeCol-=1,i.sizeRow-=1,r-=a,o=!0,r<=0))break}if(!o){for(let i of n)if(i.sizeCol>1&&i.sizeRow>1){if(i.sizeCol/i.sizeRow>=1?(i.sizeCol-=1,r-=i.sizeRow):(i.sizeRow-=1,r-=i.sizeCol),r<=0)break}else if(i.sizeCol>1&&i.sizeRow===1){if(i.sizeCol-=1,r-=i.sizeRow,r<=0)break}else if(i.sizeRow>1&&i.sizeCol===1&&(i.sizeRow-=1,r-=i.sizeCol,r<=0))break;break}}if(r>0){n.sort((o,i)=>i.sizeCol*i.sizeRow-o.sizeCol*o.sizeRow);for(let o of n){for(;r>0;){if(o.sizeCol>1&&o.sizeRow>1)o.sizeCol-=1,o.sizeRow-=1,r-=o.sizeCol+o.sizeRow+1;else if(o.sizeCol>1)o.sizeCol-=1,r-=o.sizeRow;else if(o.sizeRow>1)o.sizeRow-=1,r-=o.sizeCol;else break;if(o.sizeCol<1||o.sizeRow<1){o.sizeCol=Math.max(o.sizeCol,1),o.sizeRow=Math.max(o.sizeRow,1);break}if(r<=0)break}if(r<=0)break}}return n}function Gf(t){return t.reduce((e,n)=>e+n.sizeCol*n.sizeRow,0)}function Zie(t){var u,d,h;if(t.length===0)return[];let e=1/0,n=1/0,s=-1/0,r=-1/0;t.forEach(f=>{e=Math.min(e,f.col),n=Math.min(n,f.row),s=Math.max(s,f.col+f.sizeCol-1),r=Math.max(r,f.row+f.sizeRow-1)});const o=s-e+1,i=r-n+1,a=Array.from({length:i},()=>Array(o).fill(null));t.forEach(f=>{var p;for(let g=f.row;gf.id))+1;for(let f=0;f{const[t,e]=ye.useState([]),n=ye.useCallback(async s=>{let r;try{r=await Jie(s),console.log("Generated counter plan using AI model"),Gf(r)Ox,updateOppositionPlan:n}},tae=({unit:t,position:e,onModifyUnit:n})=>{const[s,r]=ye.useState(null),o=l=>{r(s===l?null:l)},i=l=>{n(t.id,{type:l}),r(null)},a=l=>{n(t.id,l),r(null)};return De.jsxs(sae,{style:{left:e.x,top:e.y},children:[De.jsxs(qk,{onClick:()=>o("type"),children:[De.jsx(rae,{src:K0[t.type],alt:t.type}),s==="type"&&De.jsx(Yk,{children:["warrior","archer","tank","artillery"].map(l=>De.jsx(iae,{src:K0[l],alt:l,onClick:()=>i(l)},l))})]}),De.jsxs(qk,{onClick:()=>o("formation"),children:[De.jsxs(oae,{children:[t.sizeCol,"x",t.sizeRow]}),s==="formation"&&De.jsx(Yk,{children:nae(t.sizeCol,t.sizeRow).map(l=>De.jsxs(aae,{onClick:()=>a(l),children:[l.sizeCol,"x",l.sizeRow]},`${l.sizeCol}x${l.sizeRow}`))})]})]})};function nae(t,e){const n=t*e;return[{sizeCol:n,sizeRow:1},...Array.from({length:n-1},(s,r)=>({sizeCol:r+1,sizeRow:Math.ceil(n/(r+1))})).filter(s=>s.sizeCol*s.sizeRow<=n),{sizeCol:1,sizeRow:n}]}const sae=In.div` + */const jie=[EZ,AZ,FZ,MZ,LZ,WZ,GZ,jZ,YZ,ZZ,tJ,rJ,aJ,hJ,pJ,gJ,yJ,CJ,SJ,$J,RJ,MJ,LJ,UJ,HJ,QJ,JJ,see,dZ,iee,hee,mee,bee,See,$ee,Tee,Ree,Fee,Mee,Bee,Wee,Gee,jee,qee,Qee,tte,ste,ite,cte,hte,mte,wte,kte,$te,Ete,Rte,Dte,Fte,Ote,Pte,Bte,Gte,Kte,Yte,Zte,tne,rne,lne,dne,hZ,pne,cee,xne,vne,kne,pZ,Nne,Ane,_ne,Mne,Bne,Gne,Kne,Qne,tse,rse,ise,use,dse,pse,yse,vse,Cse,Sse,$se,Rse,Fse,Pse,jse,xZ,Yse,Jse,nre,ore,KJ,lre,ure,dre,mre,wre,gZ,bre,kre,Ire,Nre,Tre,XJ,Wse,Are,zre,Lre,wZ,Ure,jre,Yre,Jre,soe,ooe,loe,hoe,poe,xoe,voe,koe,Noe,Roe,Foe,Moe,zJ,Gse,Boe,Woe,Goe,joe,Xoe,Yoe,Zoe,eie,nie,oie,aie,cie,hie,pie,gie,yie,vie,Use,$Z,kie,$ie,Tie,Aie,zie,Pie,NZ,Bie,Wie,Hie,cre];for(const t of jie)v$(t);const lr={tank:0,warrior:1,archer:2,artillery:3},Sc={"advance-wait":4,advance:5,"wait-advance":6,"flank-left":7,"flank-right":8},ru=30,Uf=Math.floor(ru/(So/Io));let Ic=null;async function Kie(){try{Ic?console.log("Model is already loaded"):(Ic=await lH(window.location.origin+window.location.pathname+"/tfmodel/model.json"),console.log("Model loaded successfully"))}catch(t){throw console.error("Failed to load the model:",t),t}}function Xie(t){return[t.data.map(e=>e.flat())]}async function qie(t){if(Ic||await Kie(),!Ic)throw new Error("Model not loaded. Call loadModel() first.");const e=YV(Xie(t)),n=Ic.predict(e),s=n.squeeze([0]),r=s.arraySync();return e.dispose(),n.dispose(),s.dispose(),{data:r.map(o=>o.reduce((i,a,l)=>(l%9===0&&i.push(o.slice(l,l+9)),i),[])),cols:ru,rows:Uf}}function DD(t){return t.map(e=>({...e,col:-e.col,row:-e.row}))}function Yie(t){const e=ru,n=Uf,s=Array.from({length:n},()=>Array.from({length:e},()=>Array(Object.keys(lr).length+Object.keys(Sc).length).fill(0)));let r=0;for(const o of t)for(let i=0;iu.map(h=>Object.values(lr).map(d=>h[d]))).flat(2),r=Math.min(...s),o=Math.max(...s),i=r+(o-r)*.5;for(let u=0;u[p,t.data[u][h][lr[p]]]).sort((p,g)=>g[1]-p[1]).filter(p=>p[1]>i))==null?void 0:a[0])==null?void 0:l[0],f=(c=Object.keys(Sc).map(p=>[p,t.data[u][h][Sc[p]]]).sort((p,g)=>g[1]-p[1])[0])==null?void 0:c[0];d&&(n[u+","+h]={type:d,command:f})}for(let u=0;u({...o})),s=Gf(n);if(s<=e)return n;let r=s-e;for(n.sort((o,i)=>i.sizeCol*i.sizeRow-o.sizeCol*o.sizeRow);r>0;){let o=!1;for(const i of n)if(i.sizeCol>1&&i.sizeRow>1){const a=i.sizeCol*i.sizeRow-(i.sizeCol-1)*(i.sizeRow-1);if(a<=0)continue;if(a<=r&&(i.sizeCol-=1,i.sizeRow-=1,r-=a,o=!0,r<=0))break}if(!o){for(const i of n)if(i.sizeCol>1&&i.sizeRow>1){if(i.sizeCol/i.sizeRow>=1?(i.sizeCol-=1,r-=i.sizeRow):(i.sizeRow-=1,r-=i.sizeCol),r<=0)break}else if(i.sizeCol>1&&i.sizeRow===1){if(i.sizeCol-=1,r-=i.sizeRow,r<=0)break}else if(i.sizeRow>1&&i.sizeCol===1&&(i.sizeRow-=1,r-=i.sizeCol,r<=0))break;break}}if(r>0){n.sort((o,i)=>i.sizeCol*i.sizeRow-o.sizeCol*o.sizeRow);for(const o of n){for(;r>0;){if(o.sizeCol>1&&o.sizeRow>1)o.sizeCol-=1,o.sizeRow-=1,r-=o.sizeCol+o.sizeRow+1;else if(o.sizeCol>1)o.sizeCol-=1,r-=o.sizeRow;else if(o.sizeRow>1)o.sizeRow-=1,r-=o.sizeCol;else break;if(o.sizeCol<1||o.sizeRow<1){o.sizeCol=Math.max(o.sizeCol,1),o.sizeRow=Math.max(o.sizeRow,1);break}if(r<=0)break}if(r<=0)break}}return n}function Gf(t){return t.reduce((e,n)=>e+n.sizeCol*n.sizeRow,0)}function Jie(t){var u,h,d;if(t.length===0)return[];let e=1/0,n=1/0,s=-1/0,r=-1/0;t.forEach(f=>{e=Math.min(e,f.col),n=Math.min(n,f.row),s=Math.max(s,f.col+f.sizeCol-1),r=Math.max(r,f.row+f.sizeRow-1)});const o=s-e+1,i=r-n+1,a=Array.from({length:i},()=>Array(o).fill(null));t.forEach(f=>{var p;for(let g=f.row;gf.id))+1;for(let f=0;f{const[t,e]=ye.useState([]),n=ye.useCallback(async s=>{let r;try{r=await eae(s),console.log("Generated counter plan using AI model"),Gf(r)Ox,updateOppositionPlan:n}},nae=({unit:t,position:e,onModifyUnit:n})=>{const[s,r]=ye.useState(null),o=l=>{r(s===l?null:l)},i=l=>{n(t.id,{type:l}),r(null)},a=l=>{n(t.id,l),r(null)};return De.jsxs(rae,{style:{left:e.x,top:e.y},children:[De.jsxs(qk,{onClick:()=>o("type"),children:[De.jsx(oae,{src:K0[t.type],alt:t.type}),s==="type"&&De.jsx(Yk,{children:["warrior","archer","tank","artillery"].map(l=>De.jsx(aae,{src:K0[l],alt:l,onClick:()=>i(l)},l))})]}),De.jsxs(qk,{onClick:()=>o("formation"),children:[De.jsxs(iae,{children:[t.sizeCol,"x",t.sizeRow]}),s==="formation"&&De.jsx(Yk,{children:sae(t.sizeCol,t.sizeRow).map(l=>De.jsxs(lae,{onClick:()=>a(l),children:[l.sizeCol,"x",l.sizeRow]},`${l.sizeCol}x${l.sizeRow}`))})]})]})};function sae(t,e){const n=t*e;return[{sizeCol:n,sizeRow:1},...Array.from({length:n-1},(s,r)=>({sizeCol:r+1,sizeRow:Math.ceil(n/(r+1))})).filter(s=>s.sizeCol*s.sizeRow<=n),{sizeCol:1,sizeRow:n}]}const rae=In.div` position: absolute; display: flex; gap: 10px; @@ -20383,10 +20383,10 @@ return a / b;`,Bse=` `,qk=In.div` position: relative; cursor: pointer; -`,rae=In.img` +`,oae=In.img` width: 32px; height: 32px; -`,oae=In.div` +`,iae=In.div` width: 32px; height: 32px; display: flex; @@ -20421,7 +20421,7 @@ return a / b;`,Bse=` transform: scaleY(1); } } -`,iae=In.img` +`,aae=In.img` width: 24px; height: 24px; cursor: pointer; @@ -20430,7 +20430,7 @@ return a / b;`,Bse=` &:hover { transform: scale(1.1); } -`,aae=In.div` +`,lae=In.div` width: 36px; height: 24px; display: flex; @@ -20447,11 +20447,11 @@ return a / b;`,Bse=` &:hover { background-color: #ddd; } -`,Pg=100,Lg=50,ca=10;function lae(t,e,n,s){const r=e.getBoundingClientRect(),o=(t.col+t.sizeCol/2)*n/(e.width/r.width),i=(t.row+t.sizeRow)*s/(e.height/r.height);let a=o+r.left+r.width/2,l=i+r.top+r.height/2;return a+Pg+ca>r.right&&(a=o-Pg+r.left),l+Lg+ca>r.bottom&&(l=i-Lg+r.top+r.height/2),a=Math.max(r.left+ca,Math.min(a,r.right-Pg-ca)),l=Math.max(r.top+ca,Math.min(l,r.bottom-Lg-ca)),{x:a,y:l}}const cae=({units:t})=>{const e=()=>{};return De.jsx(uae,{children:De.jsx(zx,{width:yi,height:wi,cellWidth:is*(yi/yi),cellHeight:Wr*(wi/wi),units:t,selectedUnitId:null,onCellClick:e,onMouseDown:e,onMouseMove:e,onMouseUp:e,onTouchStart:e,onTouchMove:e,onTouchEnd:e,onModifyUnit:e,isPlayerArea:!1})})},uae=In.div` +`,Pg=100,Lg=50,ca=10;function cae(t,e,n,s){const r=e.getBoundingClientRect(),o=(t.col+t.sizeCol/2)*n/(e.width/r.width),i=(t.row+t.sizeRow)*s/(e.height/r.height);let a=o+r.left+r.width/2,l=i+r.top+r.height/2;return a+Pg+ca>r.right&&(a=o-Pg+r.left),l+Lg+ca>r.bottom&&(l=i-Lg+r.top+r.height/2),a=Math.max(r.left+ca,Math.min(a,r.right-Pg-ca)),l=Math.max(r.top+ca,Math.min(l,r.bottom-Lg-ca)),{x:a,y:l}}const uae=({units:t})=>{const e=()=>{};return De.jsx(hae,{children:De.jsx(zx,{width:yi,height:wi,cellWidth:is*(yi/yi),cellHeight:Ur*(wi/wi),units:t,selectedUnitId:null,onCellClick:e,onMouseDown:e,onMouseMove:e,onMouseUp:e,onTouchStart:e,onTouchMove:e,onTouchEnd:e,onModifyUnit:e,isPlayerArea:!1})})},hae=In.div` width: 100%; height: 50%; position: relative; -`,dae=({onStartBattle:t,initialPlayerUnits:e})=>{const[n,s]=ye.useState([]),[r,o]=ye.useState([]),[i,a]=ye.useState(!1),[l,c]=ye.useState({x:0,y:0}),u=ye.useRef(null),{selectedUnit:d,handleUnitSelect:h,setSelectedUnit:f}=WO(n),{handleDragStart:p,handleDragMove:g,handleDragEnd:x,isDragging:m}=VO(n,s),{generateOppositionPlan:y,updateOppositionPlan:w}=eae();ye.useEffect(()=>{s(e??hae),o(y())},[]);const v=ye.useCallback((k,S)=>{s($=>$.map(N=>N.id===k?{...N,...S}:N)),f($=>($==null?void 0:$.id)===k?{...$,...S}:$)},[]),b=ye.useCallback(async()=>{t(n,await w(n))},[n,r,t]),C=ye.useCallback((k,S)=>{h(k,S)},[h]);return ye.useEffect(()=>{if(m)a(!1);else if(d&&u.current){const k=lae(d,u.current.querySelector('canvas[data-is-player-area="true"]'),is,Wr);c(k),a(!0)}else a(!1)},[m,d]),TO(()=>{w(n).then(o)},1e3,[n]),De.jsxs(fae,{ref:u,children:[De.jsx(cae,{units:r}),De.jsx(pae,{children:De.jsx(zx,{isPlayerArea:!0,width:yi,height:wi,cellWidth:is*(yi/yi),cellHeight:Wr*(wi/wi),units:n,selectedUnitId:(d==null?void 0:d.id)||null,onCellClick:C,onMouseDown:p,onMouseMove:g,onMouseUp:x,onTouchStart:p,onTouchMove:g,onTouchEnd:x,onModifyUnit:v})}),i&&d&&De.jsx(tae,{unit:d,position:l,onModifyUnit:v}),De.jsx(mae,{onClick:b,children:"Start Battle"})]})},hae=AD(Ox),fae=In.div` +`,dae=({onStartBattle:t,initialPlayerUnits:e})=>{const[n,s]=ye.useState([]),[r,o]=ye.useState([]),[i,a]=ye.useState(!1),[l,c]=ye.useState({x:0,y:0}),u=ye.useRef(null),{selectedUnit:h,handleUnitSelect:d,setSelectedUnit:f}=UO(n),{handleDragStart:p,handleDragMove:g,handleDragEnd:x,isDragging:m}=WO(n,s),{generateOppositionPlan:y,updateOppositionPlan:w}=tae();ye.useEffect(()=>{s(e??fae),o(y())},[]);const v=ye.useCallback((k,S)=>{s($=>$.map(N=>N.id===k?{...N,...S}:N)),f($=>($==null?void 0:$.id)===k?{...$,...S}:$)},[]),b=ye.useCallback(async()=>{t(n,await w(n))},[n,r,t]),C=ye.useCallback((k,S)=>{d(k,S)},[d]);return ye.useEffect(()=>{if(m)a(!1);else if(h&&u.current){const k=cae(h,u.current.querySelector('canvas[data-is-player-area="true"]'),is,Ur);c(k),a(!0)}else a(!1)},[m,h]),EO(()=>{w(n).then(o)},1e3,[n]),De.jsxs(pae,{ref:u,children:[De.jsx(uae,{units:r}),De.jsx(mae,{children:De.jsx(zx,{isPlayerArea:!0,width:yi,height:wi,cellWidth:is*(yi/yi),cellHeight:Ur*(wi/wi),units:n,selectedUnitId:(h==null?void 0:h.id)||null,onCellClick:C,onMouseDown:p,onMouseMove:g,onMouseUp:x,onTouchStart:p,onTouchMove:g,onTouchEnd:x,onModifyUnit:v})}),i&&h&&De.jsx(nae,{unit:h,position:l,onModifyUnit:v}),De.jsx(gae,{onClick:b,children:"Start Battle"})]})},fae=DD(Ox),pae=In.div` position: absolute; width: 100%; height: 100%; @@ -20460,10 +20460,10 @@ return a / b;`,Bse=` overflow: hidden; display: flex; flex-direction: column; -`,pae=In.div` +`,mae=In.div` flex: 1; position: relative; -`,mae=In.button` +`,gae=In.button` position: absolute; bottom: 20px; left: 50%; @@ -20475,7 +20475,7 @@ return a / b;`,Bse=` border: none; border-radius: 5px; cursor: pointer; -`;function gae(t,e){const n=new CustomEvent(t,{bubbles:!0,detail:e});document.dispatchEvent(n)}function xae(t,e){ye.useEffect(()=>{const n=s=>{e(s.detail)};return document.addEventListener(t,n,!1),()=>{document.removeEventListener(t,n,!1)}},[t,e])}const yae=U2` +`;function xae(t,e){const n=new CustomEvent(t,{bubbles:!0,detail:e});document.dispatchEvent(n)}function yae(t,e){ye.useEffect(()=>{const n=s=>{e(s.detail)};return document.addEventListener(t,n,!1),()=>{document.removeEventListener(t,n,!1)}},[t,e])}const wae=GI` #game-hud { position: fixed; z-index: 2; @@ -20616,10 +20616,9 @@ canvas#layer-default { max-height: 100vh; position: absolute; pointer-events: none; - background: radial-gradient(ellipse at center, #30c530 0%, #30c530 64%, #138c13 100%); z-index: 1; } -`;let mt=0;const DD=mt++,_D=mt++,FD=mt++,wae=mt++,vae=mt++,zD=mt++,OD=mt++,bae=mt++,Cae=mt++,kae=mt++,Sae=mt++,Iae=mt++,MD=mt++,$ae=mt++,Nae=mt++,Tae=mt++,Eae=mt++,Rae=mt++,Aae=mt++,Dae=mt++,_ae=mt++,Fae=mt++,zae=mt++,A1=mt++,D1=mt++,we={EPSILON:Math.pow(2,-16),length:function(t){return Math.sqrt(t[0]*t[0]+t[1]*t[1])},distanceSquared:function(t,e){return Math.pow(t[0]-e[0],2)+Math.pow(t[1]-e[1],2)},distance:function(t,e){return Math.sqrt(this.distanceSquared(t,e))},withinDistance:function(t,e,n){var s=t[0]-e[0],r=t[1]-e[1];if(Math.abs(s)>n||Math.abs(r)>n)return!1;var o=Math.pow(s,2)+Math.pow(r,2);return Math.sqrt(o)1||l>1))return[a,l]}},intersectSphereSphere:function(t,e,n,s,r,o){var i=this.sub(e,t),a=this.sub(s,n),l=r+o,c=this.dot(i,i),u=l*l,d=this.dot(a,a);if(d!=0){var h=2*this.dot(a,i),f=c-u;if(c<=u)return[0,0];var p=h*h-4*d*f;if(!(p<0)){p=Math.sqrt(p);var g=(-h-p)/(2*d),x=(-h+p)/(2*d);return g0;){const r=s-1>>1,o=this.values[r];if(n>=o)break;this.ids[s]=this.ids[r],this.values[s]=o,s=r}this.ids[s]=e,this.values[s]=n}pop(){if(this.length===0)return;const e=this.ids[0];if(this.length--,this.length>0){const n=this.ids[0]=this.ids[this.length],s=this.values[0]=this.values[this.length],r=this.length>>1;let o=0;for(;o=s)break;this.ids[o]=l,this.values[o]=c,o=i}this.ids[o]=n,this.values[o]=s}return e}peek(){if(this.length!==0)return this.ids[0]}peekValue(){if(this.length!==0)return this.values[0]}shrink(){this.ids.length=this.values.length=this.length}}const Qk=[Int8Array,Uint8Array,Uint8ClampedArray,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array],Bg=3;class Ev{static from(e,n=0){if(n%8!==0)throw new Error("byteOffset must be 8-byte aligned.");if(!e||e.byteLength===void 0||e.buffer)throw new Error("Data must be an instance of ArrayBuffer or SharedArrayBuffer.");const[s,r]=new Uint8Array(e,n+0,2);if(s!==251)throw new Error("Data does not appear to be in a Flatbush format.");const o=r>>4;if(o!==Bg)throw new Error(`Got v${o} data when expected v${Bg}.`);const i=Qk[r&15];if(!i)throw new Error("Unrecognized array type.");const[a]=new Uint16Array(e,n+2,1),[l]=new Uint32Array(e,n+4,1);return new Ev(l,a,i,void 0,e,n)}constructor(e,n=16,s=Float64Array,r=ArrayBuffer,o,i=0){if(e===void 0)throw new Error("Missing required argument: numItems.");if(isNaN(e)||e<=0)throw new Error(`Unexpected numItems value: ${e}.`);this.numItems=+e,this.nodeSize=Math.min(Math.max(+n,2),65535),this.byteOffset=i;let a=e,l=a;this._levelBounds=[a*4];do a=Math.ceil(a/this.nodeSize),l+=a,this._levelBounds.push(l*4);while(a!==1);this.ArrayType=s,this.IndexArrayType=l<16384?Uint16Array:Uint32Array;const c=Qk.indexOf(this.ArrayType),u=l*4*this.ArrayType.BYTES_PER_ELEMENT;if(c<0)throw new Error(`Unexpected typed array class: ${s}.`);o&&o.byteLength!==void 0&&!o.buffer?(this.data=o,this._boxes=new this.ArrayType(this.data,i+8,l*4),this._indices=new this.IndexArrayType(this.data,i+8+u,l),this._pos=l*4,this.minX=this._boxes[this._pos-4],this.minY=this._boxes[this._pos-3],this.maxX=this._boxes[this._pos-2],this.maxY=this._boxes[this._pos-1]):(this.data=new r(8+u+l*this.IndexArrayType.BYTES_PER_ELEMENT),this._boxes=new this.ArrayType(this.data,8,l*4),this._indices=new this.IndexArrayType(this.data,8+u,l),this._pos=0,this.minX=1/0,this.minY=1/0,this.maxX=-1/0,this.maxY=-1/0,new Uint8Array(this.data,0,2).set([251,(Bg<<4)+c]),new Uint16Array(this.data,2,1)[0]=n,new Uint32Array(this.data,4,1)[0]=e),this._queue=new Oae}add(e,n,s=e,r=n){const o=this._pos>>2,i=this._boxes;return this._indices[o]=o,i[this._pos++]=e,i[this._pos++]=n,i[this._pos++]=s,i[this._pos++]=r,ethis.maxX&&(this.maxX=s),r>this.maxY&&(this.maxY=r),o}finish(){if(this._pos>>2!==this.numItems)throw new Error(`Added ${this._pos>>2} items when expected ${this.numItems}.`);const e=this._boxes;if(this.numItems<=this.nodeSize){e[this._pos++]=this.minX,e[this._pos++]=this.minY,e[this._pos++]=this.maxX,e[this._pos++]=this.maxY;return}const n=this.maxX-this.minX||1,s=this.maxY-this.minY||1,r=new Uint32Array(this.numItems),o=65535;for(let i=0,a=0;i>2]=c,e[this._pos++]=u,e[this._pos++]=d,e[this._pos++]=h,e[this._pos++]=f}}}search(e,n,s,r,o){if(this._pos!==this._boxes.length)throw new Error("Data not yet indexed - call index.finish().");let i=this._boxes.length-4;const a=[],l=[];for(;i!==void 0;){const c=Math.min(i+this.nodeSize*4,Jk(i,this._levelBounds));for(let u=i;uthis._boxes[u+2]||n>this._boxes[u+3])continue;const d=this._indices[u>>2]|0;i>=this.numItems*4?a.push(d):(o===void 0||o(d))&&l.push(d)}i=a.pop()}return l}neighbors(e,n,s=1/0,r=1/0,o){if(this._pos!==this._boxes.length)throw new Error("Data not yet indexed - call index.finish().");let i=this._boxes.length-4;const a=this._queue,l=[],c=r*r;e:for(;i!==void 0;){const u=Math.min(i+this.nodeSize*4,Jk(i,this._levelBounds));for(let d=i;d>2]|0,f=Zk(e,this._boxes[d],this._boxes[d+2]),p=Zk(n,this._boxes[d+1],this._boxes[d+3]),g=f*f+p*p;g>c||(i>=this.numItems*4?a.push(h<<1,g):(o===void 0||o(h))&&a.push((h<<1)+1,g))}for(;a.length&&a.peek()&1;)if(a.peekValue()>c||(l.push(a.pop()>>1),l.length===s))break e;i=a.length?a.pop()>>1:void 0}return a.clear(),l}}function Zk(t,e,n){return t>1;e[r]>t?s=r:n=r+1}return e[n]}function _1(t,e,n,s,r,o){if(Math.floor(s/o)>=Math.floor(r/o))return;const i=t[s+r>>1];let a=s-1,l=r+1;for(;;){do a++;while(t[a]i);if(a>=l)break;Mae(t,e,n,a,l)}_1(t,e,n,s,l,o),_1(t,e,n,l+1,r,o)}function Mae(t,e,n,s,r){const o=t[s];t[s]=t[r],t[r]=o;const i=4*s,a=4*r,l=e[i],c=e[i+1],u=e[i+2],d=e[i+3];e[i]=e[a],e[i+1]=e[a+1],e[i+2]=e[a+2],e[i+3]=e[a+3],e[a]=l,e[a+1]=c,e[a+2]=u,e[a+3]=d;const h=n[s];n[s]=n[r],n[r]=h}function Pae(t,e){let n=t^e,s=65535^n,r=65535^(t|e),o=t&(e^65535),i=n|s>>1,a=n>>1^n,l=r>>1^s&o>>1^r,c=n&r>>1^o>>1^o;n=i,s=a,r=l,o=c,i=n&n>>2^s&s>>2,a=n&s>>2^s&(n^s)>>2,l^=n&r>>2^s&o>>2,c^=s&r>>2^(n^s)&o>>2,n=i,s=a,r=l,o=c,i=n&n>>4^s&s>>4,a=n&s>>4^s&(n^s)>>4,l^=n&r>>4^s&o>>4,c^=s&r>>4^(n^s)&o>>4,n=i,s=a,r=l,o=c,l^=n&r>>8^s&o>>8,c^=s&r>>8^(n^s)&o>>8,n=l^l>>1,s=c^c>>1;let u=t^e,d=s|65535^(u|n);return u=(u|u<<8)&16711935,u=(u|u<<4)&252645135,u=(u|u<<2)&858993459,u=(u|u<<1)&1431655765,d=(d|d<<8)&16711935,d=(d|d<<4)&252645135,d=(d|d<<2)&858993459,d=(d|d<<1)&1431655765,(d<<1|u)>>>0}function Lae(t){return{searchSoldiers:eS(t.queryObjects("Soldier")),searchArrows:eS(t.queryObjects("Arrow").filter(e=>e.isHit()))}}function eS(t,e){t=[...t];const n=t.length===0?void 0:new Ev(t.length);for(const o of t)n==null||n.add(o.vec[0],o.vec[1],o.vec[0],o.vec[1]);n==null||n.finish();const s=new Map;return{byRect:o=>(n==null?void 0:n.search(o.left,o.top,o.right,o.bottom).map(i=>t[i]))??[],byRadius:(o,i)=>(n==null?void 0:n.neighbors(o[0],o[1],void 0,i).map(a=>t[a]))??[],byProperty:(o,i)=>{if(!s.has(o)){const a=s.set(o,new Map).get(o);t.forEach(l=>{if(o in l){const c=l[o];a.has(c)||a.set(c,[]),a.get(c).push(l)}})}return s.get(o).get(i)??[]},resetPropertyCache:()=>{s.clear()}}}const Hf=class Hf{constructor(e,n,s,r,o){ne(this,"id");ne(this,"vec");ne(this,"direction");ne(this,"objectWidth");ne(this,"objectHeight");this.id=String(Hf.idCounter++),this.vec=[e,n],this.direction=o,this.objectWidth=s,this.objectHeight=r}getTargetVelocity(){}update(e){}render(e){e.save().translate(-this.getWidth()/2,-this.getHeight()/2).fillRect(0,0,this.getWidth(),this.getHeight()).restore()}getX(){return this.vec[0]}setX(e){this.vec[0]=e}getY(){return this.vec[1]}setY(e){this.vec[1]=e}getDirection(){return this.direction}setDirection(e){this.direction=e}getWidth(){return this.objectWidth}getHeight(){return this.objectHeight}getClass(){return"Object"}};ne(Hf,"idCounter",0);let ou=Hf;const tS={arrow:[10,1],ball:[10,10]};class PD extends ou{constructor(n,s,r,o,i){super(n[0],n[1],tS[i][0],tS[i][1],we.atan2(n,s));ne(this,"world");ne(this,"from");ne(this,"to");ne(this,"maxDist");ne(this,"attackBase");ne(this,"type");ne(this,"v");ne(this,"adir");ne(this,"ay");this.world=r,this.from=n,this.to=s,this.maxDist=we.distance(n,s),this.attackBase=o,this.type=i,this.v=we.normalize(we.sub(s,n))}update(n){var s=we.scale(this.v,n*20);this.vec[0]+=s[0],this.vec[1]+=s[1];var r=Math.sin(we.distance(this.from,this.vec)/this.maxDist*Math.PI);this.adir=this.direction-Math.PI/3*(1-r),this.ay=this.vec[1]-r*this.maxDist/10,we.distance(this.from,this.vec)>this.maxDist&&this.world.removeObject(this)}getY(){return this.ay}getDirection(){return this.adir}isHit(){return this.maxDist-we.distance(this.from,this.vec)<10}hit(n,s){n.hitByArrow(this,s)}getAttack(){return this.attackBase}getClass(){return"Arrow"}}class Bae extends ou{constructor(n,s,r){super(n[0],n[1],za*2,za*2,0);ne(this,"time");ne(this,"world");this.time=s,this.world=r}render(n){var s=this.world.getTime()-this.time;s<100&&n.save().arc(0,0,za*Math.min(s/100,1)).restore()}getClass(){return"Explosion"}}class Vae{constructor(e){ne(this,"soldier");ne(this,"velocity",0);ne(this,"targetVelocity",1);ne(this,"force",[0,0]);ne(this,"targetDirection");this.soldier=e,this.targetDirection=e.getDirection()}update(e){this.updateVelocity(e),this.updatePosition(e),this.updateDirection(e),this.updateForce(e)}updateVelocity(e){this.velocity=this.getTargetVelocity()*e+this.velocity*(1-e)}updatePosition(e){this.soldier.setX(this.soldier.getX()+this.force[0]*e),this.soldier.setY(this.soldier.getY()+this.force[1]*e)}updateDirection(e){const n=Math.cos(this.soldier.getDirection())*(1-e),s=Math.sin(this.soldier.getDirection())*(1-e),r=Math.cos(this.targetDirection)*e,o=Math.sin(this.targetDirection)*e;this.soldier.setDirection(Math.atan2(s+o,n+r))}updateForce(e){this.soldier.state.isAlive()&&this.addForce(we.scale([Math.cos(this.soldier.getDirection()),Math.sin(this.soldier.getDirection())],this.velocity*(1-Math.random())*e/2)),this.force=we.sub(this.force,we.scale(this.force,e*.1)),we.length(this.force)0?-.9:10),l=0,c=h.m==1?0:(1-h.m)*(1-h.m)*2e4+32},this.totalReset=function(){this.reset();var h=this._params;return t=h.b*h.b*1e5,e=h.c*h.c*1e5,n=h.e*h.e*1e5+12,((t+e+n)/3|0)*3},this.synthWave=function(h,f){var p=this._params,g=p.s!=1||p.v,x=p.v*p.v*.1,m=1+p.w*3e-4,y=p.s*p.s*p.s*.1,w=1+p.t*1e-4,v=p.s!=1,b=p.x*p.x,C=p.g,k=p.q||p.r,S=p.r*p.r*p.r*.2,$=p.q*p.q*(p.q<0?-1020:1020),N=p.p?((1-p.p)*(1-p.p)*2e4|0)+32:0,A=p.d,M=p.j/2,L=p.k*p.k*.01,V=p.a,B=t,U=1/t,K=1/e,R=1/n,O=5/(1+p.u*p.u*20)*(.01+y);O>.8&&(O=.8),O=1-O;var G=!1,X=0,q=0,Q=0,ee=0,Z=0,se,ie=0,ce,ue=0,xe,be=0,ke,He=0,Ne,Me,Be=0,qe=new Array(1024),Ge=new Array(32);for(let Ut=qe.length;Ut--;)qe[Ut]=0;for(let Ut=Ge.length;Ut--;)Ge[Ut]=Math.random()*2-1;for(var Pn=0;Pn=N&&(He=0,this.reset()),c&&++l>=c&&(c=0,s*=a),o+=i,s*=o,s>r&&(s=r,C>0&&(G=!0)),ce=s,M>0&&(Be+=L,ce*=1+Math.sin(Be)*M),ce|=0,ce<8&&(ce=8),V||(u+=d,u<0?u=0:u>.5&&(u=.5)),++q>B)switch(q=0,++X){case 1:B=e;break;case 2:B=n}switch(X){case 0:Q=q*U;break;case 1:Q=1+(1-q*K)*2*A;break;case 2:Q=1-q*R;break;case 3:Q=0,G=!0}k&&($+=S,xe=$|0,xe<0?xe=-xe:xe>1023&&(xe=1023)),g&&m&&(x*=m,x<1e-5?x=1e-5:x>.1&&(x=.1)),Me=0;for(var _t=8;_t--;){if(ue++,ue>=ce&&(ue%=ce,V==3))for(var _s=Ge.length;_s--;)Ge[_s]=Math.random()*2-1;switch(V){case 0:Ne=ue/ce.5?ke-1:ke)*6.28318531,Ne=1.27323954*ke+.405284735*ke*ke*(ke<0?1:-1),Ne=.225*((Ne<0?-1:1)*Ne*Ne-Ne)+Ne;break;case 3:Ne=Ge[Math.abs(ue*32/ce|0)]}g&&(se=ie,y*=w,y<0?y=0:y>.1&&(y=.1),v?(Z+=(Ne-ie)*y,Z*=O):(ie=Ne,Z=0),ie+=Z,ee+=ie-se,ee*=1-x,Ne=ee),k&&(qe[be%1024]=Ne,Ne+=qe[(be-xe+1024)%1024],be++),Me+=Ne}Me*=.125*Q*b,h[Pn]=Me>=1?32767:Me<=-1?-32768:Me*32767|0}return f}}var Vg=new Uae;const Gae=function(t){Vg._params.setSettings(t);var e=Vg.totalReset(),n=new Uint8Array(((e+1)/2|0)*4+44),s=Vg.synthWave(new Uint16Array(n.buffer,44),e)*2,r=new Uint32Array(n.buffer,0,44);r[0]=1179011410,r[1]=s+36,r[2]=1163280727,r[3]=544501094,r[4]=16,r[5]=65537,r[6]=44100,r[7]=88200,r[8]=1048578,r[9]=1635017060,r[10]=s,s+=44;for(var o=0,i="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",a="data:audio/wav;base64,";o>18]+i[l>>12&63]+i[l>>6&63]+i[l&63]}return a},Wg=typeof window<"u";class Hae{constructor(){this.sounds={},Wg&&(this.audioContext=new(window.AudioContext||window.webkitAudioContext))}async add(e,n,s){if(Wg){this.sounds[e]=[];for(let r=0;r1?n[Math.floor(Math.random()*n.length)]:n[0],r=this.audioContext.createBufferSource();r.buffer=s.buffers[s.tick];const o=this.audioContext.createGain();r.connect(o),o.connect(this.audioContext.destination),r.start(0),s.tick0}isDead(){return this.type==="smoke"?this.life<=0:this.life<=0&&this.z<=0&&Math.abs(this.velocityX)<.01&&Math.abs(this.velocityY)<.01}}const Ug=typeof window<"u";class jae{constructor(e,n){ne(this,"particles",[]);ne(this,"deadParticlesCanvas");ne(this,"deadParticlesContext");Ug&&(this.deadParticlesCanvas=document.createElement("canvas"),this.deadParticlesCanvas.width=e,this.deadParticlesCanvas.height=n,this.deadParticlesContext=this.deadParticlesCanvas.getContext("2d"),this.deadParticlesContext.translate(e/2,n/2))}addParticle(e){Ug&&this.particles.push(e)}update(e){if(!Ug)return;const n=[];this.particles=this.particles.filter(s=>(s.update(e),s.isDead()?(s.type==="blood"&&n.push(s),!1):!0)),this.renderDeadParticles(n)}renderDeadParticles(e){const n=new Path2D;e.forEach(s=>{s.type==="blood"&&(n.moveTo(s.x,s.y-s.z),n.arc(s.x,s.y-s.z,1,0,Math.PI*2),n.closePath())}),this.deadParticlesContext&&(this.deadParticlesContext.fillStyle="red",this.deadParticlesContext.fill(n))}renderDead(e){this.deadParticlesCanvas&&e.drawImage(this.deadParticlesCanvas,-this.deadParticlesCanvas.width/2,-this.deadParticlesCanvas.height/2)}renderActive(e){e.save();const n=new Path2D,s=new Path2D;this.particles.forEach(r=>{const o=r.type==="smoke"?s:n;o.moveTo(r.x,r.y-r.z),o.arc(r.x,r.y-r.z,r.type==="smoke"?Math.min(r.life,2):1,0,Math.PI*2),o.closePath()}),e.fillStyle("red"),e.fill(n),e.fillStyle("rgba(128, 128, 128, 0.5)"),e.fill(s),e.restore()}}function Kae([t,e],[n,s],r){const[o,i]=we.scale(we.normalize([t-n,e-s]),5),a=30+Math.random()*10;for(let l=0;le)&&this.clearEnemy(),!this.enemy&&this.soldier.state.cooldown("seek-"+e,FO)&&this.setEnemy(this.queryEnemy(e)),this.enemy){const n=this.enemy.vec,s=we.distance(this.soldier.vec,n),r=we.atan2(this.soldier.vec,n);this.soldier.movement.setTargetDirection(r);let o=0;return this.soldier.state.canCharge&&s>50&&sthis.soldier.state.attackRange?1+o:0),this.soldier.state.rangeAttack&&s_O&&this.soldier.state.cooldown("arrow",this.soldier.state.rangedCooldown)&&(this.soldier.world.addObject(new PD(this.soldier.vec,this.enemy.vec,this.soldier.world,this.soldier.state.rangeAttack,this.soldier.state.rangeType)),pl.play("arrow"),this.soldier.type==="artillery"&&(this.soldier.state.hitBy(50),Kae(this.soldier.vec,this.enemy.vec,this.soldier.world.particles))),ss.isEnemy(this.soldier)&&s.state.life>0&&we.withinDistance(s.vec,this.soldier.vec,e)&&this.soldier.plan.canClaim(s,this.soldier));if(n.length>0){const s=this.soldier.type==="artillery"?(r,o)=>o.distance(this.soldier)>r.distance(this.soldier)?o:r:(r,o)=>o.distance(this.soldier)this.cooldowns[e]?(this.cooldowns[e]=this.soldier.world.getTime()+n,!0):!1}hitBy(e){this.newLife=Math.max(this.newLife-e,0)}isAlive(){return this.life>0}}function Qae(t,e){const n=Math.cos(e),s=Math.sin(e);return t.map(r=>{const o=r.x*n-r.z*s,i=r.x*s+r.z*n;return{x:o,y:r.y,z:i}})}function Zae(t,e=200){const n=e/(e+t.z);return{x:t.x*n,y:t.y*n,z:t.z}}function Jae(t,e){const n=Math.cos(e)*.3+.7,s=parseInt(t.slice(1),16),r=Math.floor((s>>16&255)*n),o=Math.floor((s>>8&255)*n),i=Math.floor((s&255)*n);return`rgb(${r},${o},${i})`}function ele(t,e,n=!0,s){const r=t.getCtx();r.beginPath(),r.moveTo(e[0].x,e[0].y);for(let o=1;oa[1].zIndex-l[1].zIndex);for(const[a,l]of i){const u=Qae(l.points,s+Math.PI/2).map(h=>Zae(h)),d=Jae(r,s);n.fillStyle=d,ele(e,u)}n.restore()}}let ile=0;class Fh extends ou{constructor(n,s,r,o,i,a,l){r+=(Math.random()-Math.random())/1e3;super(n,s,is,Wr,r);ne(this,"soldierId");ne(this,"plan");ne(this,"world");ne(this,"type");ne(this,"color");ne(this,"movement");ne(this,"targeting");ne(this,"attack");ne(this,"state");ne(this,"soldierRender");ne(this,"lastAttackTime",0);ne(this,"attackDuration",500);this.soldierId=ile++,this.plan=o,this.world=i,this.type=l,this.color=a,this.movement=new Vae(this),this.targeting=new Xae(this),this.attack=new qae(this),this.state=new Yae(this),this.soldierRender=new ole(this),this.initializeTypeSpecificProperties()}initializeTypeSpecificProperties(){switch(this.type){case"warrior":this.initializeWarrior();break;case"tank":this.initializeTank();break;case"archer":this.initializeArcher();break;case"artillery":this.initializeArtillery();break}}initializeWarrior(){this.state.setProperties({seekRange:tC,attackRange:j0,rangeDefence:30,meleeDefence:50,meleeAttack:25,baseSpeed:3,canCharge:!0,isMelee:!0})}initializeTank(){this.state.setProperties({seekRange:tC,attackRange:j0*1.1,rangeDefence:100,meleeDefence:100,meleeAttack:15,life:df*2,newLife:df*2,defenceCooldown:G2/5,weight:3,canCharge:!1,isMelee:!0})}initializeArcher(){this.state.setProperties({seekRange:sC,attackRange:nC,rangeAttack:45,rangeDefence:25,rangedCooldown:rC,meleeDefence:10,meleeAttack:10,rangeType:"arrow"})}initializeArtillery(){this.state.setProperties({seekRange:sC,attackRange:nC*5,weight:10,baseSpeed:.1,rangeAttack:100,rangeDefence:1,rangedCooldown:rC*10,meleeDefence:1,meleeAttack:1,rangeType:"ball"})}update(n){this.state.isAlive()?this.updatePlan():this.targeting.hasEnemy()&&this.targeting.clearEnemy(),this.movement.update(n),this.state.update(n)}updatePlan(){this.targeting.seekEnemy()||this.plan.getCommand(this.world.getTime()).execute(this)}render(n){this.soldierRender.render(n)}distance(n){return this.movement.distance(n)}hitByArrow(n,s){this.attack.hitByArrow(n,s)}isEnemy(n){return this.plan.masterPlan!==n.plan.masterPlan}getClass(){return"Soldier"}}class ale{constructor(){ne(this,"objects");ne(this,"objectsByType");ne(this,"collisionHandlers");ne(this,"edgeRadius");ne(this,"worldTime");ne(this,"particles");this.objects=[],this.objectsByType={Soldier:[],Arrow:[],Explosion:[]},this.collisionHandlers=[],this.edgeRadius=uo*1.5,this.particles=new jae(uo*3,uo*2),this.worldTime=0,this.onCollision(Fh,Fh,this.onSoldierCollision.bind(this)),this.onCollision(Fh,PD,this.onArrowCollision.bind(this))}destroy(){}getTime(){return this.worldTime}getEdgeRadius(){return this.edgeRadius}addObject(...e){for(var n of e)this.objects.push(n),this.objectsByType[n.getClass()].push(n)}removeObject(e){this.objects.splice(this.objects.indexOf(e),1)}queryObjects(e,n){return this.objectsByType[e].filter(s=>!n||n(s))}update(e){var n=Math.min(e,RO);return this.objects.forEach(s=>{this.updateObject(s,n/eC)}),e-=n,this.worldTime+=n,this.collisions(),this.edgeRadius=Math.max(uo*1.5*(1-this.getTime()/6e4),400),this.particles.update(n/eC),e}collisions(){const e=Lae(this),n={},s=this.queryObjects("Arrow",r=>r.isHit());this.queryObjects("Soldier").forEach(r=>{r.state.life<=0||(e.searchSoldiers.byRadius(r.vec,r.getWidth()).forEach(o=>{o.state.life<=0||r===o||n[r.id+o.id]||n[o.id+r.id]||(n[r.id+o.id]=!0,we.withinDistance(r.vec,o.vec,r.getWidth())&&this.triggerCollisions(r,o))}),e.searchArrows.byRadius(r.vec,Math.max(oC,za)).forEach(o=>{o&&we.withinDistance(r.vec,o.vec,o.type==="arrow"?oC:za)&&this.triggerCollisions(r,o)}),we.withinDistance(r.vec,[0,0],this.getEdgeRadius())||r.movement.addForce(we.scale(we.normalize(r.vec),-1)))},this),s.forEach(r=>{this.objects.splice(this.objects.indexOf(r),1),this.objectsByType.Arrow.splice(this.objectsByType.Arrow.indexOf(r),1),r.type==="ball"&&this.addObject(new Bae(r.vec,this.getTime(),this))})}triggerCollisions(e,n){this.collisionHandlers.forEach(function(s){e instanceof s.left&&n instanceof s.right&&s.handler(e,n),n instanceof s.left&&e instanceof s.right&&s.handler(n,e)})}onCollision(e,n,s){this.collisionHandlers.push({left:e,right:n,handler:s})}onSoldierCollision(e,n){var s=we.distance(e.vec,n.vec);if(s===0){var r=we.scale([Math.random()-Math.random(),Math.random()-Math.random()],1/Number.MAX_SAFE_INTEGER);e.movement.addForce(r),n.movement.addForce(we.scale(r,-1))}else{var o=we.scale(we.normalize(we.sub(e.vec,n.vec)),e.getWidth()-s);e.movement.addForce(we.scale(o,1/e.state.weight*n.state.weight)),n.movement.addForce(we.scale(o,-1*e.state.weight/n.state.weight))}}onArrowCollision(e,n){var s=we.distance(n.vec,e.vec);if(n.type==="arrow")n.hit(e,s);else if(n.type==="ball"&&e.state.cooldown("ballhit",150)){n.hit(e,s);var r=we.scale(we.normalize(we.sub(e.vec,n.vec)),e.getWidth()-s);e.movement.addForce(we.scale(r,-.5/e.state.weight*(1-s/za)))}}updateObject(e,n){e.update(n)}getAlive(){return this.queryObjects("Soldier",e=>e.state.life>0).reduce((e,n)=>(e[n.color]=(e[n.color]||0)+1,e),{"#ff0000":0,"#00ff00":0})}getBalance(){var e=this.getAlive(),n=Object.keys(this.getAlive());return e[n[0]]/(e[n[0]]+e[n[1]])}}class Rv{constructor(){ne(this,"startTime",-1);ne(this,"done",!1)}start(e){this.startTime=e}execute(e){}isDone(e){return this.done}}class F1 extends Rv{constructor(n){super();ne(this,"duration");this.duration=n}isDone(n){return!!this.duration&&this.startTime>=0&&n-this.startTime>this.duration}execute(n){n.movement.setTargetVelocity(0)}}class zh extends Rv{constructor(){super()}getTarget(e){return e.plan.formation}execute(e){var n=this.getTarget(e),s=we.distance(e.vec,n),r=we.atan2(e.vec,n);s>50?(e.movement.setTargetVelocity(1),e.movement.setTargetDirection(r)):(e.movement.setTargetVelocity(0),this.done=!0)}}class BD extends zh{constructor(n){super();ne(this,"angle");this.angle=n}getTarget(n){return we.add(we.rotate([200,100*Math.sign(Math.cos(this.angle))],this.angle),n.plan.formation)}}class lle extends BD{getTarget(e){return we.add(we.rotate([200,-100*Math.sign(Math.cos(this.angle))],this.angle),e.plan.formation)}}class ua extends Rv{constructor(){super()}execute(e){e.targeting.seekEnemy(uo)||(this.done=!0)}}class cle{constructor(e,n,s){ne(this,"masterPlan");ne(this,"formation");ne(this,"plan");ne(this,"currentCommand");ne(this,"claims");this.masterPlan=e,this.formation=n,this.plan=s,this.currentCommand=null,this.claims=e.claims}getPosition(){return this.formation}getCommand(e){return(!this.currentCommand||this.currentCommand.isDone(e))&&this.plan.length>0&&(this.currentCommand=this.plan.splice(0,1)[0],this.currentCommand.start(e)),this.currentCommand||(this.currentCommand=new F1),this.currentCommand}canClaim(e,n){if(this.claims[e.soldierId]||(this.claims[e.soldierId]=[]),this.claims[e.soldierId].length<5)return!0;var s=n.distance(e),r=this.claims[e.soldierId].filter(o=>o.distance(e)>s);return r.length===this.claims[e.soldierId].length}unclaim(e,n){var s=this.claims[e.soldierId].indexOf(n);s>=0&&this.claims[e.soldierId].splice(s,1)}claim(e,n){return this.canClaim(e,n)?(this.claims[e.soldierId].push(n),!0):!1}}class ule{constructor(e,n){ne(this,"type");ne(this,"formation");ne(this,"plan");ne(this,"claims");var s=we.atan2(e,[0,0]);this.type=[],this.formation=[],this.plan=[],this.claims={},n.forEach(r=>{for(var o=r.sizeCol*r.sizeRow,i=[r.col*is,r.row*Wr],a=0;a2/3,this.balanceRight.style.width=(1-r)*100+"%",this.balanceRight.dataset.winning=r<1/3}renderResults(e){var n=this.getBalance(e),s="";if(n>1/3&&n<2/3)this.battleResult.innerHTML=`
+`;let mt=0;const _D=mt++,FD=mt++,zD=mt++,vae=mt++,bae=mt++,OD=mt++,MD=mt++,Cae=mt++,kae=mt++,Sae=mt++,Iae=mt++,$ae=mt++,PD=mt++,Nae=mt++,Tae=mt++,Eae=mt++,Rae=mt++,Aae=mt++,Dae=mt++,_ae=mt++,Fae=mt++,zae=mt++,Oae=mt++,A1=mt++,D1=mt++,we={EPSILON:Math.pow(2,-16),length:function(t){return Math.sqrt(t[0]*t[0]+t[1]*t[1])},distanceSquared:function(t,e){return Math.pow(t[0]-e[0],2)+Math.pow(t[1]-e[1],2)},distance:function(t,e){return Math.sqrt(this.distanceSquared(t,e))},withinDistance:function(t,e,n){const s=t[0]-e[0],r=t[1]-e[1];if(Math.abs(s)>n||Math.abs(r)>n)return!1;const o=Math.pow(s,2)+Math.pow(r,2);return Math.sqrt(o)1||l>1))return[a,l]},intersectSphereSphere:function(t,e,n,s,r,o){const i=this.sub(e,t),a=this.sub(s,n),l=r+o,c=this.dot(i,i),u=l*l,h=this.dot(a,a);if(h==0)return;const d=2*this.dot(a,i),f=c-u;if(c<=u)return[0,0];let p=d*d-4*h*f;if(p<0)return;p=Math.sqrt(p);const g=(-d-p)/(2*h),x=(-d+p)/(2*h);return g0;){const r=s-1>>1,o=this.values[r];if(n>=o)break;this.ids[s]=this.ids[r],this.values[s]=o,s=r}this.ids[s]=e,this.values[s]=n}pop(){if(this.length===0)return;const e=this.ids[0];if(this.length--,this.length>0){const n=this.ids[0]=this.ids[this.length],s=this.values[0]=this.values[this.length],r=this.length>>1;let o=0;for(;o=s)break;this.ids[o]=l,this.values[o]=c,o=i}this.ids[o]=n,this.values[o]=s}return e}peek(){if(this.length!==0)return this.ids[0]}peekValue(){if(this.length!==0)return this.values[0]}shrink(){this.ids.length=this.values.length=this.length}}const Qk=[Int8Array,Uint8Array,Uint8ClampedArray,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array],Bg=3;class Ev{static from(e,n=0){if(n%8!==0)throw new Error("byteOffset must be 8-byte aligned.");if(!e||e.byteLength===void 0||e.buffer)throw new Error("Data must be an instance of ArrayBuffer or SharedArrayBuffer.");const[s,r]=new Uint8Array(e,n+0,2);if(s!==251)throw new Error("Data does not appear to be in a Flatbush format.");const o=r>>4;if(o!==Bg)throw new Error(`Got v${o} data when expected v${Bg}.`);const i=Qk[r&15];if(!i)throw new Error("Unrecognized array type.");const[a]=new Uint16Array(e,n+2,1),[l]=new Uint32Array(e,n+4,1);return new Ev(l,a,i,void 0,e,n)}constructor(e,n=16,s=Float64Array,r=ArrayBuffer,o,i=0){if(e===void 0)throw new Error("Missing required argument: numItems.");if(isNaN(e)||e<=0)throw new Error(`Unexpected numItems value: ${e}.`);this.numItems=+e,this.nodeSize=Math.min(Math.max(+n,2),65535),this.byteOffset=i;let a=e,l=a;this._levelBounds=[a*4];do a=Math.ceil(a/this.nodeSize),l+=a,this._levelBounds.push(l*4);while(a!==1);this.ArrayType=s,this.IndexArrayType=l<16384?Uint16Array:Uint32Array;const c=Qk.indexOf(this.ArrayType),u=l*4*this.ArrayType.BYTES_PER_ELEMENT;if(c<0)throw new Error(`Unexpected typed array class: ${s}.`);o&&o.byteLength!==void 0&&!o.buffer?(this.data=o,this._boxes=new this.ArrayType(this.data,i+8,l*4),this._indices=new this.IndexArrayType(this.data,i+8+u,l),this._pos=l*4,this.minX=this._boxes[this._pos-4],this.minY=this._boxes[this._pos-3],this.maxX=this._boxes[this._pos-2],this.maxY=this._boxes[this._pos-1]):(this.data=new r(8+u+l*this.IndexArrayType.BYTES_PER_ELEMENT),this._boxes=new this.ArrayType(this.data,8,l*4),this._indices=new this.IndexArrayType(this.data,8+u,l),this._pos=0,this.minX=1/0,this.minY=1/0,this.maxX=-1/0,this.maxY=-1/0,new Uint8Array(this.data,0,2).set([251,(Bg<<4)+c]),new Uint16Array(this.data,2,1)[0]=n,new Uint32Array(this.data,4,1)[0]=e),this._queue=new Mae}add(e,n,s=e,r=n){const o=this._pos>>2,i=this._boxes;return this._indices[o]=o,i[this._pos++]=e,i[this._pos++]=n,i[this._pos++]=s,i[this._pos++]=r,ethis.maxX&&(this.maxX=s),r>this.maxY&&(this.maxY=r),o}finish(){if(this._pos>>2!==this.numItems)throw new Error(`Added ${this._pos>>2} items when expected ${this.numItems}.`);const e=this._boxes;if(this.numItems<=this.nodeSize){e[this._pos++]=this.minX,e[this._pos++]=this.minY,e[this._pos++]=this.maxX,e[this._pos++]=this.maxY;return}const n=this.maxX-this.minX||1,s=this.maxY-this.minY||1,r=new Uint32Array(this.numItems),o=65535;for(let i=0,a=0;i>2]=c,e[this._pos++]=u,e[this._pos++]=h,e[this._pos++]=d,e[this._pos++]=f}}}search(e,n,s,r,o){if(this._pos!==this._boxes.length)throw new Error("Data not yet indexed - call index.finish().");let i=this._boxes.length-4;const a=[],l=[];for(;i!==void 0;){const c=Math.min(i+this.nodeSize*4,Jk(i,this._levelBounds));for(let u=i;uthis._boxes[u+2]||n>this._boxes[u+3])continue;const h=this._indices[u>>2]|0;i>=this.numItems*4?a.push(h):(o===void 0||o(h))&&l.push(h)}i=a.pop()}return l}neighbors(e,n,s=1/0,r=1/0,o){if(this._pos!==this._boxes.length)throw new Error("Data not yet indexed - call index.finish().");let i=this._boxes.length-4;const a=this._queue,l=[],c=r*r;e:for(;i!==void 0;){const u=Math.min(i+this.nodeSize*4,Jk(i,this._levelBounds));for(let h=i;h>2]|0,f=Zk(e,this._boxes[h],this._boxes[h+2]),p=Zk(n,this._boxes[h+1],this._boxes[h+3]),g=f*f+p*p;g>c||(i>=this.numItems*4?a.push(d<<1,g):(o===void 0||o(d))&&a.push((d<<1)+1,g))}for(;a.length&&a.peek()&1;)if(a.peekValue()>c||(l.push(a.pop()>>1),l.length===s))break e;i=a.length?a.pop()>>1:void 0}return a.clear(),l}}function Zk(t,e,n){return t>1;e[r]>t?s=r:n=r+1}return e[n]}function _1(t,e,n,s,r,o){if(Math.floor(s/o)>=Math.floor(r/o))return;const i=t[s+r>>1];let a=s-1,l=r+1;for(;;){do a++;while(t[a]i);if(a>=l)break;Pae(t,e,n,a,l)}_1(t,e,n,s,l,o),_1(t,e,n,l+1,r,o)}function Pae(t,e,n,s,r){const o=t[s];t[s]=t[r],t[r]=o;const i=4*s,a=4*r,l=e[i],c=e[i+1],u=e[i+2],h=e[i+3];e[i]=e[a],e[i+1]=e[a+1],e[i+2]=e[a+2],e[i+3]=e[a+3],e[a]=l,e[a+1]=c,e[a+2]=u,e[a+3]=h;const d=n[s];n[s]=n[r],n[r]=d}function Lae(t,e){let n=t^e,s=65535^n,r=65535^(t|e),o=t&(e^65535),i=n|s>>1,a=n>>1^n,l=r>>1^s&o>>1^r,c=n&r>>1^o>>1^o;n=i,s=a,r=l,o=c,i=n&n>>2^s&s>>2,a=n&s>>2^s&(n^s)>>2,l^=n&r>>2^s&o>>2,c^=s&r>>2^(n^s)&o>>2,n=i,s=a,r=l,o=c,i=n&n>>4^s&s>>4,a=n&s>>4^s&(n^s)>>4,l^=n&r>>4^s&o>>4,c^=s&r>>4^(n^s)&o>>4,n=i,s=a,r=l,o=c,l^=n&r>>8^s&o>>8,c^=s&r>>8^(n^s)&o>>8,n=l^l>>1,s=c^c>>1;let u=t^e,h=s|65535^(u|n);return u=(u|u<<8)&16711935,u=(u|u<<4)&252645135,u=(u|u<<2)&858993459,u=(u|u<<1)&1431655765,h=(h|h<<8)&16711935,h=(h|h<<4)&252645135,h=(h|h<<2)&858993459,h=(h|h<<1)&1431655765,(h<<1|u)>>>0}function Bae(t){return{searchSoldiers:eS(t.queryObjects("Soldier")),searchArrows:eS(t.queryObjects("Arrow").filter(e=>e.isHit()))}}function eS(t,e){t=[...t];const n=t.length===0?void 0:new Ev(t.length);for(const o of t)n==null||n.add(o.vec[0],o.vec[1],o.vec[0],o.vec[1]);n==null||n.finish();const s=new Map;return{byRect:o=>(n==null?void 0:n.search(o.left,o.top,o.right,o.bottom).map(i=>t[i]))??[],byRadius:(o,i)=>(n==null?void 0:n.neighbors(o[0],o[1],void 0,i).map(a=>t[a]))??[],byProperty:(o,i)=>{if(!s.has(o)){const a=s.set(o,new Map).get(o);t.forEach(l=>{if(o in l){const c=l[o];a.has(c)||a.set(c,[]),a.get(c).push(l)}})}return s.get(o).get(i)??[]},resetPropertyCache:()=>{s.clear()}}}const Hf=class Hf{constructor(e,n,s,r,o){ee(this,"id");ee(this,"vec");ee(this,"direction");ee(this,"objectWidth");ee(this,"objectHeight");this.id=String(Hf.idCounter++),this.vec=[e,n],this.direction=o,this.objectWidth=s,this.objectHeight=r}getTargetVelocity(){}render(e){e.save().translate(-this.getWidth()/2,-this.getHeight()/2).fillRect(0,0,this.getWidth(),this.getHeight()).restore()}getX(){return this.vec[0]}setX(e){this.vec[0]=e}getY(){return this.vec[1]}setY(e){this.vec[1]=e}getDirection(){return this.direction}setDirection(e){this.direction=e}getWidth(){return this.objectWidth}getHeight(){return this.objectHeight}getClass(){return"Object"}};ee(Hf,"idCounter",0);let ou=Hf;const tS={arrow:[10,1],ball:[10,10]};class LD extends ou{constructor(n,s,r,o,i){super(n[0],n[1],tS[i][0],tS[i][1],we.atan2(n,s));ee(this,"world");ee(this,"from");ee(this,"to");ee(this,"maxDist");ee(this,"attackBase");ee(this,"type");ee(this,"v");ee(this,"adir");ee(this,"ay");this.world=r,this.from=n,this.to=s,this.maxDist=we.distance(n,s),this.attackBase=o,this.type=i,this.v=we.normalize(we.sub(s,n))}update(n){const s=we.scale(this.v,n*20);this.vec[0]+=s[0],this.vec[1]+=s[1];const r=Math.sin(we.distance(this.from,this.vec)/this.maxDist*Math.PI);this.adir=this.direction-Math.PI/3*(1-r),this.ay=this.vec[1]-r*this.maxDist/10,we.distance(this.from,this.vec)>this.maxDist&&this.world.removeObject(this)}getY(){return this.ay}getDirection(){return this.adir}isHit(){return this.maxDist-we.distance(this.from,this.vec)<10}hit(n,s){n.hitByArrow(this,s)}getAttack(){return this.attackBase}getClass(){return"Arrow"}}class Vae extends ou{constructor(n,s,r){super(n[0],n[1],za*2,za*2,0);ee(this,"time");ee(this,"world");this.time=s,this.world=r}render(n){const s=this.world.getTime()-this.time;s<100&&n.save().arc(0,0,za*Math.min(s/100,1)).restore()}update(){}getClass(){return"Explosion"}}class Wae{constructor(e){ee(this,"soldier");ee(this,"velocity",0);ee(this,"targetVelocity",1);ee(this,"force",[0,0]);ee(this,"targetDirection");this.soldier=e,this.targetDirection=e.getDirection()}update(e){this.updateVelocity(e),this.updatePosition(e),this.updateDirection(e),this.updateForce(e)}updateVelocity(e){this.velocity=this.getTargetVelocity()*e+this.velocity*(1-e)}updatePosition(e){this.soldier.setX(this.soldier.getX()+this.force[0]*e),this.soldier.setY(this.soldier.getY()+this.force[1]*e)}updateDirection(e){const n=Math.cos(this.soldier.getDirection())*(1-e),s=Math.sin(this.soldier.getDirection())*(1-e),r=Math.cos(this.targetDirection)*e,o=Math.sin(this.targetDirection)*e;this.soldier.setDirection(Math.atan2(s+o,n+r))}updateForce(e){this.soldier.state.isAlive()&&this.addForce(we.scale([Math.cos(this.soldier.getDirection()),Math.sin(this.soldier.getDirection())],this.velocity*(1-Math.random())*e/2)),this.force=we.sub(this.force,we.scale(this.force,e*.1)),we.length(this.force)0?-.9:10),l=0,c=d.m==1?0:(1-d.m)*(1-d.m)*2e4+32},this.totalReset=function(){this.reset();var d=this._params;return t=d.b*d.b*1e5,e=d.c*d.c*1e5,n=d.e*d.e*1e5+12,((t+e+n)/3|0)*3},this.synthWave=function(d,f){var p=this._params,g=p.s!=1||p.v,x=p.v*p.v*.1,m=1+p.w*3e-4,y=p.s*p.s*p.s*.1,w=1+p.t*1e-4,v=p.s!=1,b=p.x*p.x,C=p.g,k=p.q||p.r,S=p.r*p.r*p.r*.2,$=p.q*p.q*(p.q<0?-1020:1020),N=p.p?((1-p.p)*(1-p.p)*2e4|0)+32:0,A=p.d,M=p.j/2,L=p.k*p.k*.01,V=p.a,B=t,U=1/t,K=1/e,R=1/n,O=5/(1+p.u*p.u*20)*(.01+y);O>.8&&(O=.8),O=1-O;var G=!1,X=0,q=0,Q=0,te=0,Z=0,se,ie=0,ce,ue=0,xe,be=0,ke,He=0,Ne,Me,Be=0,qe=new Array(1024),Ge=new Array(32);for(let Ut=qe.length;Ut--;)qe[Ut]=0;for(let Ut=Ge.length;Ut--;)Ge[Ut]=Math.random()*2-1;for(var Pn=0;Pn=N&&(He=0,this.reset()),c&&++l>=c&&(c=0,s*=a),o+=i,s*=o,s>r&&(s=r,C>0&&(G=!0)),ce=s,M>0&&(Be+=L,ce*=1+Math.sin(Be)*M),ce|=0,ce<8&&(ce=8),V||(u+=h,u<0?u=0:u>.5&&(u=.5)),++q>B)switch(q=0,++X){case 1:B=e;break;case 2:B=n}switch(X){case 0:Q=q*U;break;case 1:Q=1+(1-q*K)*2*A;break;case 2:Q=1-q*R;break;case 3:Q=0,G=!0}k&&($+=S,xe=$|0,xe<0?xe=-xe:xe>1023&&(xe=1023)),g&&m&&(x*=m,x<1e-5?x=1e-5:x>.1&&(x=.1)),Me=0;for(var _t=8;_t--;){if(ue++,ue>=ce&&(ue%=ce,V==3))for(var Fs=Ge.length;Fs--;)Ge[Fs]=Math.random()*2-1;switch(V){case 0:Ne=ue/ce.5?ke-1:ke)*6.28318531,Ne=1.27323954*ke+.405284735*ke*ke*(ke<0?1:-1),Ne=.225*((Ne<0?-1:1)*Ne*Ne-Ne)+Ne;break;case 3:Ne=Ge[Math.abs(ue*32/ce|0)]}g&&(se=ie,y*=w,y<0?y=0:y>.1&&(y=.1),v?(Z+=(Ne-ie)*y,Z*=O):(ie=Ne,Z=0),ie+=Z,te+=ie-se,te*=1-x,Ne=te),k&&(qe[be%1024]=Ne,Ne+=qe[(be-xe+1024)%1024],be++),Me+=Ne}Me*=.125*Q*b,d[Pn]=Me>=1?32767:Me<=-1?-32768:Me*32767|0}return f}}var Vg=new Gae;const Hae=function(t){Vg._params.setSettings(t);var e=Vg.totalReset(),n=new Uint8Array(((e+1)/2|0)*4+44),s=Vg.synthWave(new Uint16Array(n.buffer,44),e)*2,r=new Uint32Array(n.buffer,0,44);r[0]=1179011410,r[1]=s+36,r[2]=1163280727,r[3]=544501094,r[4]=16,r[5]=65537,r[6]=44100,r[7]=88200,r[8]=1048578,r[9]=1635017060,r[10]=s,s+=44;for(var o=0,i="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",a="data:audio/wav;base64,";o>18]+i[l>>12&63]+i[l>>6&63]+i[l&63]}return a},Wg=typeof window<"u";class jae{constructor(){this.sounds={},Wg&&(this.audioContext=new(window.AudioContext||window.webkitAudioContext))}async add(e,n,s){if(Wg){this.sounds[e]=[];for(let r=0;r1?n[Math.floor(Math.random()*n.length)]:n[0],r=this.audioContext.createBufferSource();r.buffer=s.buffers[s.tick];const o=this.audioContext.createGain();r.connect(o),o.connect(this.audioContext.destination),r.start(0),s.tick0}isDead(){return this.type==="smoke"?this.life<=0:this.life<=0&&this.z<=this.terrain.getHeightAt([this.x,this.y])&&Math.abs(this.velocityX)<.01&&Math.abs(this.velocityY)<.01}}const Ug=typeof window<"u";class Kae{constructor(e,n,s){ee(this,"particles",[]);ee(this,"deadParticlesCanvas");ee(this,"deadParticlesContext");this.terrain=s,Ug&&(this.deadParticlesCanvas=document.createElement("canvas"),this.deadParticlesCanvas.width=e,this.deadParticlesCanvas.height=n,this.deadParticlesContext=this.deadParticlesCanvas.getContext("2d"),this.deadParticlesContext.translate(e/2,n/2))}addParticle(e){Ug&&this.particles.push(e)}update(e){if(!Ug)return;const n=[];this.particles=this.particles.filter(s=>(s.update(e),s.isDead()?(s.type==="blood"&&n.push(s),!1):!0)),this.renderDeadParticles(n)}renderDeadParticles(e){const n=new Path2D;e.forEach(s=>{s.type==="blood"&&(n.moveTo(s.x,s.y-s.z),n.arc(s.x,s.y-s.z,1,0,Math.PI*2),n.closePath())}),this.deadParticlesContext&&(this.deadParticlesContext.fillStyle="rgba(255, 0, 0, 0.5)",this.deadParticlesContext.fill(n))}renderDead(e){this.deadParticlesCanvas&&e.drawImage(this.deadParticlesCanvas,-this.deadParticlesCanvas.width/2,-this.deadParticlesCanvas.height/2)}renderActive(e){e.save();const n=new Path2D,s=new Path2D;this.particles.forEach(r=>{const o=r.type==="smoke"?s:n;o.moveTo(r.x,r.y-r.z),o.arc(r.x,r.y-r.z,r.type==="smoke"?Math.min(r.life,2):1,0,Math.PI*2),o.closePath()}),e.fillStyle("rgba(255, 0, 0, 0.5)"),e.fill(n),e.fillStyle("rgba(128, 128, 128, 0.5)"),e.fill(s),e.restore()}}function Xae([t,e],[n,s],r){const[o,i]=we.scale(we.normalize([t-n,e-s]),5),a=30+Math.random()*10;for(let l=0;le)&&this.clearEnemy(),!this.enemy&&this.soldier.state.cooldown("seek-"+e,zO)&&this.setEnemy(this.queryEnemy(e)),this.enemy){const n=this.enemy.vec,s=we.distance(this.soldier.vec,n),r=we.atan2(this.soldier.vec,n);this.soldier.movement.setTargetDirection(r);let o=0;return this.soldier.state.canCharge&&s>50&&sthis.soldier.state.attackRange?1+o:0),this.soldier.state.rangeAttack&&sFO&&this.soldier.state.cooldown("arrow",this.soldier.state.rangedCooldown)&&(this.soldier.world.addObject(new LD(this.soldier.vec,this.enemy.vec,this.soldier.world,this.soldier.state.rangeAttack,this.soldier.state.rangeType)),pl.play("arrow"),this.soldier.type==="artillery"&&(this.soldier.state.hitBy(50),Xae(this.soldier.vec,this.enemy.vec,this.soldier.world.particles))),ss.isEnemy(this.soldier)&&s.state.life>0&&we.withinDistance(s.vec,this.soldier.vec,e)&&this.soldier.plan.canClaim(s,this.soldier));if(n.length>0){const s=this.soldier.type==="artillery"?(r,o)=>o.distance(this.soldier)>r.distance(this.soldier)?o:r:(r,o)=>o.distance(this.soldier)this.cooldowns[e]?(this.cooldowns[e]=this.soldier.world.getTime()+n,!0):!1}hitBy(e){this.newLife=Math.max(this.newLife-e,0)}isAlive(){return this.life>0}}function Zae(t,e){const n=Math.cos(e),s=Math.sin(e);return t.map(r=>{const o=r.x*n-r.z*s,i=r.x*s+r.z*n;return{x:o,y:r.y,z:i}})}function Jae(t,e=200){const n=e/(e+t.z);return{x:t.x*n,y:t.y*n,z:t.z}}function ele(t,e,n=1){const s=Math.cos(e)*.3+.7,r=parseInt(t.slice(1),16),o=Math.floor((r>>16&255)*s),i=Math.floor((r>>8&255)*s),a=Math.floor((r&255)*s);return`rgba(${o},${i},${a},${n})`}function tle(t,e,n=!0,s){const r=t.getCtx();r.beginPath(),r.moveTo(e[0].x,e[0].y);for(let o=1;oa[1].zIndex-l[1].zIndex);for(const[,a]of i){const c=Zae(a.points,s+Math.PI/2).map(h=>Jae(h)),u=ele(r,s,this.soldier.state.isAlive()?1:.5);n.fillStyle=u,tle(e,c)}n.restore()}}let ale=0;class Fd extends ou{constructor(n,s,r,o,i,a,l){r+=(Math.random()-Math.random())/1e3;super(n,s,is,Ur,r);ee(this,"soldierId");ee(this,"plan");ee(this,"world");ee(this,"type");ee(this,"color");ee(this,"movement");ee(this,"targeting");ee(this,"attack");ee(this,"state");ee(this,"soldierRender");ee(this,"lastAttackTime",0);ee(this,"attackDuration",500);this.soldierId=ale++,this.plan=o,this.world=i,this.type=l,this.color=a,this.movement=new Wae(this),this.targeting=new qae(this),this.attack=new Yae(this),this.state=new Qae(this),this.soldierRender=new ile(this),this.initializeTypeSpecificProperties()}initializeTypeSpecificProperties(){switch(this.type){case"warrior":this.initializeWarrior();break;case"tank":this.initializeTank();break;case"archer":this.initializeArcher();break;case"artillery":this.initializeArtillery();break}}initializeWarrior(){this.state.setProperties({seekRange:tC,attackRange:j0,rangeDefence:30,meleeDefence:50,meleeAttack:25,baseSpeed:3,canCharge:!0,isMelee:!0})}initializeTank(){this.state.setProperties({seekRange:tC,attackRange:j0*1.1,rangeDefence:100,meleeDefence:100,meleeAttack:15,life:hf*2,newLife:hf*2,defenceCooldown:HI/5,weight:3,canCharge:!1,isMelee:!0})}initializeArcher(){this.state.setProperties({seekRange:sC,attackRange:nC,rangeAttack:45,rangeDefence:25,rangedCooldown:rC,meleeDefence:10,meleeAttack:10,rangeType:"arrow"})}initializeArtillery(){this.state.setProperties({seekRange:sC,attackRange:nC*5,weight:10,baseSpeed:.1,rangeAttack:100,rangeDefence:1,rangedCooldown:rC*10,meleeDefence:1,meleeAttack:1,rangeType:"ball"})}update(n){this.state.isAlive()?this.updatePlan():this.targeting.hasEnemy()&&this.targeting.clearEnemy(),this.movement.update(n),this.state.update()}updatePlan(){this.targeting.seekEnemy()||this.plan.getCommand(this.world.getTime()).execute(this)}render(n){this.soldierRender.render(n)}distance(n){return this.movement.distance(n)}hitByArrow(n,s){this.attack.hitByArrow(n,s)}isEnemy(n){return this.plan.masterPlan!==n.plan.masterPlan}getClass(){return"Soldier"}}function lle(t,e,n){let s=0;for(let r=-1;r<=1;r++)for(let o=-1;o<=1;o++){if(r===0&&o===0)continue;const i=e+r,a=n+o;i>=0&&i=0&&a0?1:0)}return s}function cle(t,e){const n=t.map(s=>[...s]);for(let s=0;s0?n[r][o]=i<2||i>4?0:1:n[r][o]=i===3?1:0}return n}function ule(t,e){const n=t.map(s=>[...s]);for(let s=0;s=0&&c=0&&uArray(s+1).fill(0));for(let h=0;h<=r;h++)for(let d=0;d<=s;d++)o[h][d]=(Math.sin(d/s*2*Math.PI*2)*.25+Math.cos(h/r*Math.PI*3)*.25)*n*3;const i=Math.max(...o.flat()),a=Math.min(...o.flat()),l=o.map(h=>h.map(d=>(d-a)/(i-a))),c=cle(l,5);for(let h=0;h<=r;h++)for(let d=0;d<=s;d++)o[h][d]+=c[h][d]*n*.5;return ule(o,.3)}function dle(t){const e=ws*3,n=ws*2,s=hle(e,n,t);return{width:e,height:n,heightMap:s}}const sS={grass:"#6B8E23",dirt:"#D2B48C"};function fle(t,e,n,s=1){const r=Math.min(Math.max(n/50,0),1),o=(Math.cos(e)*.3+.7)*(.8+r*.4),i=parseInt(t.slice(1),16),a=Math.floor((i>>16&255)*o),l=Math.floor((i>>8&255)*o),c=Math.floor((i&255)*o);return`rgba(${a},${l},${c},${s})`}function ple(t,e,n,s){const r=t[n][e],o=t[n][Math.min(e+1,t[0].length-1)],i=t[Math.min(n+1,t.length-1)][e],a=[s,0,o-r],l=[0,s,i-r],c=[l[1]*a[2]-l[2]*a[1],l[2]*a[0]-l[0]*a[2],l[0]*a[1]-l[1]*a[0]],u=Math.sqrt(c[0]*c[0]+c[1]*c[1]+c[2]*c[2]);return[c[0]/u,c[1]/u,c[2]/u]}function mle(t,e,n,s,r){var a,l;const o=Math.ceil(n/r),i=Math.ceil(s/r);for(let c=0;c20?sS.dirt:sS.grass,k=fle(C,v,b);t.beginPath(),t.moveTo(u*r,g),t.lineTo((u+1)*r,x),t.lineTo((u+1)*r,y),t.lineTo(u*r,m),t.closePath(),t.fillStyle=k,t.fill(),t.strokeStyle="rgba(0,0,0,0.1)",t.stroke()}}function gle(t,e,n,s){const r=document.createElement("canvas");r.width=t,r.height=e;const o=r.getContext("2d");return mle(o,n,t,e,s),r}class xle{constructor(){ee(this,"tileSize",32);ee(this,"offsetX",ws*1.5/this.tileSize);ee(this,"offsetY",ws/this.tileSize);ee(this,"terrainCanvas");ee(this,"heightMap");ee(this,"width");ee(this,"height");const{width:e,height:n,heightMap:s}=dle(this.tileSize);this.width=e,this.height=n,this.heightMap=s,this.terrainCanvas=gle(e,n,s,this.tileSize)}render(e){e.drawImage(this.terrainCanvas,0,0)}getHeightAt(e){const n=e[0]/this.tileSize+this.offsetX,s=e[1]/this.tileSize+this.offsetY,r=Math.floor(n),o=Math.min(r+1,this.heightMap[0].length-1),i=Math.floor(s),a=Math.min(i+1,this.heightMap.length-1),l=this.heightMap[i][r],c=this.heightMap[i][o],u=this.heightMap[a][r],h=this.heightMap[a][o],d=n-r,f=s-i,p=l*(1-d)+c*d,g=u*(1-d)+h*d;return p*(1-f)+g*f}}class yle{constructor(){ee(this,"objects");ee(this,"objectsByType");ee(this,"collisionHandlers");ee(this,"edgeRadius");ee(this,"worldTime");ee(this,"particles");ee(this,"terrain");this.objects=[],this.objectsByType={Soldier:[],Arrow:[],Explosion:[]},this.collisionHandlers=[],this.edgeRadius=ws*1.5,this.terrain=new xle,this.particles=new Kae(ws*3,ws*2,this.terrain),this.worldTime=0,this.onCollision(Fd,Fd,this.onSoldierCollision.bind(this)),this.onCollision(Fd,LD,this.onArrowCollision.bind(this))}destroy(){}getTime(){return this.worldTime}getEdgeRadius(){return this.edgeRadius}addObject(...e){for(const n of e)this.objects.push(n),this.objectsByType[n.getClass()].push(n)}removeObject(e){this.objects.splice(this.objects.indexOf(e),1)}queryObjects(e,n){return this.objectsByType[e].filter(s=>!n||n(s))}update(e){const n=Math.min(e,AO);return this.objects.forEach(s=>{this.updateObject(s,n/eC)}),e-=n,this.worldTime+=n,this.collisions(),this.edgeRadius=Math.max(ws*1.5*(1-this.getTime()/6e4),400),this.particles.update(n/eC),e}collisions(){const e=Bae(this),n={},s=this.queryObjects("Arrow",r=>r.isHit());this.queryObjects("Soldier").forEach(r=>{r.state.life<=0||(e.searchSoldiers.byRadius(r.vec,r.getWidth()).forEach(o=>{o.state.life<=0||r===o||n[r.id+o.id]||n[o.id+r.id]||(n[r.id+o.id]=!0,we.withinDistance(r.vec,o.vec,r.getWidth())&&this.triggerCollisions(r,o))}),e.searchArrows.byRadius(r.vec,Math.max(oC,za)).forEach(o=>{o&&we.withinDistance(r.vec,o.vec,o.type==="arrow"?oC:za)&&this.triggerCollisions(r,o)}),we.withinDistance(r.vec,[0,0],this.getEdgeRadius())||r.movement.addForce(we.scale(we.normalize(r.vec),-1)))},this),s.forEach(r=>{this.objects.splice(this.objects.indexOf(r),1),this.objectsByType.Arrow.splice(this.objectsByType.Arrow.indexOf(r),1),r.type==="ball"&&this.addObject(new Vae(r.vec,this.getTime(),this))})}triggerCollisions(e,n){this.collisionHandlers.forEach(function(s){e instanceof s.left&&n instanceof s.right&&s.handler(e,n),n instanceof s.left&&e instanceof s.right&&s.handler(n,e)})}onCollision(e,n,s){this.collisionHandlers.push({left:e,right:n,handler:s})}onSoldierCollision(e,n){const s=we.distance(e.vec,n.vec);if(s===0){const r=we.scale([Math.random()-Math.random(),Math.random()-Math.random()],1/Number.MAX_SAFE_INTEGER);e.movement.addForce(r),n.movement.addForce(we.scale(r,-1))}else{const r=we.scale(we.normalize(we.sub(e.vec,n.vec)),e.getWidth()-s);e.movement.addForce(we.scale(r,1/e.state.weight*n.state.weight)),n.movement.addForce(we.scale(r,-1*e.state.weight/n.state.weight))}}onArrowCollision(e,n){const s=we.distance(n.vec,e.vec);if(n.type==="arrow")n.hit(e,s);else if(n.type==="ball"&&e.state.cooldown("ballhit",150)){n.hit(e,s);const r=we.scale(we.normalize(we.sub(e.vec,n.vec)),e.getWidth()-s);e.movement.addForce(we.scale(r,-.5/e.state.weight*(1-s/za)))}}updateObject(e,n){e.update(n)}getAlive(){return this.queryObjects("Soldier",e=>e.state.life>0).reduce((e,n)=>(e[n.color]=(e[n.color]||0)+1,e),{"#ff0000":0,"#00ff00":0})}getBalance(){const e=this.getAlive(),n=Object.keys(this.getAlive());return e[n[0]]/(e[n[0]]+e[n[1]])}}class Rv{constructor(){ee(this,"startTime",-1);ee(this,"done",!1)}start(e){this.startTime=e}}class F1 extends Rv{constructor(n){super();ee(this,"duration");this.duration=n}isDone(n){return!!this.duration&&this.startTime>=0&&n-this.startTime>this.duration}execute(n){n.movement.setTargetVelocity(0)}}class zd extends Rv{constructor(){super()}getTarget(e){return e.plan.formation}execute(e){const n=this.getTarget(e),s=we.distance(e.vec,n),r=we.atan2(e.vec,n);s>50?(e.movement.setTargetVelocity(1),e.movement.setTargetDirection(r)):(e.movement.setTargetVelocity(0),this.done=!0)}isDone(){return this.done}}class VD extends zd{constructor(n){super();ee(this,"angle");this.angle=n}getTarget(n){return we.add(we.rotate([200,100*Math.sign(Math.cos(this.angle))],this.angle),n.plan.formation)}}class wle extends VD{getTarget(e){return we.add(we.rotate([200,-100*Math.sign(Math.cos(this.angle))],this.angle),e.plan.formation)}}class ua extends Rv{constructor(){super()}execute(e){e.targeting.seekEnemy(ws)||(this.done=!0)}isDone(){return this.done}}class vle{constructor(e,n,s){ee(this,"masterPlan");ee(this,"formation");ee(this,"plan");ee(this,"currentCommand");ee(this,"claims");this.masterPlan=e,this.formation=n,this.plan=s,this.currentCommand=null,this.claims=e.claims}getPosition(){return this.formation}getCommand(e){return(!this.currentCommand||this.currentCommand.isDone(e))&&this.plan.length>0&&(this.currentCommand=this.plan.splice(0,1)[0],this.currentCommand.start(e)),this.currentCommand||(this.currentCommand=new F1),this.currentCommand}canClaim(e,n){if(this.claims[e.soldierId]||(this.claims[e.soldierId]=[]),this.claims[e.soldierId].length<5)return!0;const s=n.distance(e);return this.claims[e.soldierId].filter(o=>o.distance(e)>s).length===this.claims[e.soldierId].length}unclaim(e,n){const s=this.claims[e.soldierId].indexOf(n);s>=0&&this.claims[e.soldierId].splice(s,1)}claim(e,n){return this.canClaim(e,n)?(this.claims[e.soldierId].push(n),!0):!1}}class ble{constructor(e,n){ee(this,"type");ee(this,"formation");ee(this,"plan");ee(this,"claims");const s=we.atan2(e,[0,0]);this.type=[],this.formation=[],this.plan=[],this.claims={},n.forEach(r=>{const o=r.sizeCol*r.sizeRow,i=[r.col*is,r.row*Ur];for(let a=0;a2/3,this.balanceRight.style.width=(1-r)*100+"%",this.balanceRight.dataset.winning=r<1/3}renderResults(e){var n=this.getBalance(e),s="";if(n>1/3&&n<2/3)this.battleResult.innerHTML=`
DRAW!${s} Click to continue${s}
`;else{var r=n>.3333333333333333?"#ff0000":"#00ff00";return this.battleResult.innerHTML=`
@@ -20627,4 +20626,4 @@ canvas#layer-default { ${n>2/3?this.balanceLeft.dataset.username:this.balanceRight.dataset.username} wins!${s} ${n>2/3?this.balanceRight.dataset.username:this.balanceLeft.dataset.username} defeated!${s} Click to continue${s} -
`,r}}showPause(){}}function VD(t){t=t||hu;var e=Va.layers[t];return e||(Va.layers[t]=new Va(t))}function hle(t){t=t||hu;var e=Va.layers[t];e&&(e.destroy(),delete Va.layers[t])}class Va{constructor(e){ne(this,"element");ne(this,"ctx");this.element=document.createElement("canvas"),this.element.id=e,this.element.width=uo*3,this.element.height=uo*2,this.ctx=this.element.getContext("2d"),document.body.appendChild(this.element)}destroy(){document.body.removeChild(this.element)}getWidth(){return this.element.width}getHeight(){return this.element.height}clear(){return this.ctx.clearRect(0,0,this.getWidth(),this.getHeight()),this}drawText(e,n,s){return this.ctx.fillStyle="white",this.ctx.font="11px serif",this.ctx.fillText(s,e-this.ctx.measureText(s).width/2,n),this}fillStyle(e){return this.ctx.fillStyle=e,this}strokeStyle(e){return this.ctx.strokeStyle=e,this}fillRect(e,n,s,r){return this.ctx.fillRect(e,n,s,r),this}arc(e,n,s){return this.ctx.beginPath(),this.ctx.arc(e,n,s,0,Math.PI*2),this.ctx.stroke(),this}line(e,n,s,r){return this.save(),this.ctx.beginPath(),this.ctx.moveTo(e,n),this.ctx.lineTo(s,r),this.ctx.stroke(),this.restore(),this}drawImage(e,n,s){return this.ctx.drawImage(e,n,s),this}fill(e){this.ctx.fill(e)}scale(e){return this.ctx.scale(e,e),this}translate(e,n){return this.ctx.translate(e,n),this}rotate(e){return this.ctx.rotate(e),this}save(){return this.ctx.save(),this}restore(){return this.ctx.restore(),this}getCtx(){return this.ctx}}ne(Va,"layers",{});function Av(t){var e=VD(hu);e.clear(),e.save().translate(e.getWidth()/2,e.getHeight()/2),t.particles.renderDead(e),t.queryObjects("Soldier",n=>n.state.life===0).forEach(hh),t.queryObjects("Soldier",n=>n.state.life>0).forEach(hh),t.queryObjects("Arrow").forEach(hh),t.queryObjects("Explosion").forEach(hh),t.particles.renderActive(e),e.restore()}function hh(t){var e=VD(hu);e.save().fillStyle("red").translate(t.getX(),t.getY()),t.getClass()!=="Soldier"&&e.rotate(t.getDirection()),t.render(e),e.restore()}function sS(t,e,n,s){for(var r=Math.PI/2*e,o=[0,e*uo/2],i=new ule(o,s),a=0;a0;)a=t.update(a);Av(t)}if(o===zD&&e.render(t),o===OD){var l=e.getBalance(t);if(t.getTime()>6e4||l===0||l===1)return mle(t,e)}if(o===A1||o===D1){const{damage:c,soldier:u}=i;n[o][u.color]+=c,s[o][u.color]++}}}function mle(t,e){return e.renderResults(t),function(s){if(Av(t),s===MD)return hle(hu),e.destroy(),gae("battleEnd"),WD()}}function WD(){return function(e,n){if(e==FD)return fle(n.playerUnits,n.oppositionUnits)}}let uc;function gle(){uc=WD()}function dt(t,e){var n=uc(t,e);n&&n!==uc&&(console.log("Transition from "+uc.name+" to "+n.name),uc=n)}document.addEventListener("visibilitychange",function(){document.hidden?dt(wae):dt(vae)});window.addEventListener("resize",function(){dt(bae)});function da(t,e){ye.useEffect(()=>(window.addEventListener(t,e),()=>{window.removeEventListener(t,e)}),[t,e])}function xle(){return da("keydown",function(t){t.keyCode==37&&dt(Tae),t.keyCode==38&&dt(Rae),t.keyCode==39&&dt(Eae),t.keyCode==40&&dt(Aae),t.keyCode==27&&dt(Cae),dt($ae,t.keyCode)}),da("keyup",function(t){t.keyCode==37&&dt(Dae),t.keyCode==38&&dt(Fae),t.keyCode==39&&dt(_ae),t.keyCode==40&&dt(zae),dt(Nae,t)}),da("mousedown",function(t){dt(kae,t)}),da("mouseup",function(t){dt(Sae,t)}),da("mousemove",function(t){dt(Iae,t)}),da("click",function(t){dt(MD,t)}),null}function yle({onBattleEnd:t,playerUnits:e,oppositionUnits:n}){ye.useEffect(()=>{gle(),dt(FD,{playerUnits:e,oppositionUnits:n});const r=setTimeout(()=>dt(DD),1e3),o=setInterval(()=>dt(zD),100),i=setInterval(()=>dt(OD),1e3);return()=>{clearTimeout(r),clearInterval(o),clearInterval(i)}},[]),xae("battleEnd",()=>{t()});const s=ye.useRef();return EO(()=>{let r=Date.now();s.current&&dt(_D,r-s.current),s.current=r}),De.jsxs(De.Fragment,{children:[De.jsx(yae,{}),De.jsx(xle,{}),De.jsxs("div",{id:"game-hud",children:[De.jsxs("div",{id:"battle-stats",children:[De.jsx("div",{id:"battle-time",children:" "}),De.jsxs("div",{id:"battle-balance",children:[De.jsx("div",{id:"battle-balance-left",children:" "}),De.jsx("div",{id:"battle-balance-right",children:" "})]})]}),De.jsx("div",{id:"battle-result"})]})]})}const wle=()=>{const[t,e]=ye.useState({name:"intro"}),n=()=>{e({name:"designer"})},s=(o,i)=>{e({name:"battle",playerUnits:o,oppositionUnits:i}),console.log("Battle started!")},r=()=>{e({name:"designer",playerUnits:t.name==="battle"?t.playerUnits:void 0})};return De.jsxs(Us.StrictMode,{children:[De.jsx(CO,{}),(t==null?void 0:t.name)==="intro"&&De.jsx($O,{onPlayClick:n}),(t==null?void 0:t.name)==="designer"&&De.jsx(dae,{onStartBattle:s,initialPlayerUnits:t.playerUnits}),(t==null?void 0:t.name)==="battle"&&De.jsx(yle,{onBattleEnd:r,playerUnits:t.playerUnits,oppositionUnits:t.oppositionUnits})]})},vle=Gg.createRoot(document.getElementById("root"));vle.render(De.jsx(wle,{})); +
`,r}}showPause(){}}function WD(t){t=t||du;const e=Va.layers[t];return e||(Va.layers[t]=new Va(t))}function kle(t){t=t||du;const e=Va.layers[t];e&&(e.destroy(),delete Va.layers[t])}class Va{constructor(e){ee(this,"element");ee(this,"ctx");this.element=document.createElement("canvas"),this.element.id=e,this.element.width=ws*3,this.element.height=ws*2,this.ctx=this.element.getContext("2d"),document.body.appendChild(this.element)}destroy(){document.body.removeChild(this.element)}getWidth(){return this.element.width}getHeight(){return this.element.height}clear(){return this.ctx.clearRect(0,0,this.getWidth(),this.getHeight()),this}drawText(e,n,s){return this.ctx.fillStyle="white",this.ctx.font="11px serif",this.ctx.fillText(s,e-this.ctx.measureText(s).width/2,n),this}fillStyle(e){return this.ctx.fillStyle=e,this}strokeStyle(e){return this.ctx.strokeStyle=e,this}fillRect(e,n,s,r){return this.ctx.fillRect(e,n,s,r),this}arc(e,n,s){return this.ctx.beginPath(),this.ctx.arc(e,n,s,0,Math.PI*2),this.ctx.stroke(),this}line(e,n,s,r){return this.save(),this.ctx.beginPath(),this.ctx.moveTo(e,n),this.ctx.lineTo(s,r),this.ctx.stroke(),this.restore(),this}drawImage(e,n,s){return this.ctx.drawImage(e,n,s),this}fill(e){this.ctx.fill(e)}scale(e){return this.ctx.scale(e,e),this}translate(e,n){return this.ctx.translate(e,n),this}rotate(e){return this.ctx.rotate(e),this}save(){return this.ctx.save(),this}restore(){return this.ctx.restore(),this}getCtx(){return this.ctx}}ee(Va,"layers",{});function Av(t){const e=WD(du);e.clear(),t.terrain.render(e),e.save().translate(e.getWidth()/2,e.getHeight()/2),t.particles.renderDead(e),t.queryObjects("Soldier",n=>n.state.life===0).forEach(n=>dd(n,t)),t.queryObjects("Soldier",n=>n.state.life>0).sort((n,s)=>n.getY()-s.getY()).forEach(n=>dd(n,t)),t.queryObjects("Arrow").forEach(n=>dd(n,t)),t.queryObjects("Explosion").forEach(n=>dd(n,t)),t.particles.renderActive(e),e.restore()}function dd(t,e){const n=WD(du);n.save().fillStyle("red").translate(t.getX(),t.getY()-e.terrain.getHeightAt(t.vec)),t.getClass()!=="Soldier"&&n.rotate(t.getDirection()),t.render(n),n.restore()}function rS(t,e,n,s){const r=Math.PI/2*e,o=[0,e*ws/2],i=new ble(o,s);for(let a=0;a0;)a=t.update(a);Av(t)}if(o===OD&&e.render(t),o===MD){const a=e.getBalance(t);if(t.getTime()>6e4||a===0||a===1)return $le(t,e)}if(o===A1||o===D1){const{damage:a,soldier:l}=i;n[o][l.color]+=a,s[o][l.color]++}}}function $le(t,e){return e.renderResults(t),function(s){if(Av(t),s===PD)return kle(du),e.destroy(),xae("battleEnd"),UD()}}function UD(){return function(e,n){if(e==zD)return Sle(n.playerUnits,n.oppositionUnits)}}let uc;function Nle(){uc=UD()}function ht(t,e){const n=uc(t,e);n&&n!==uc&&(console.log("Transition from "+uc.name+" to "+n.name),uc=n)}document.addEventListener("visibilitychange",function(){document.hidden?ht(vae):ht(bae)});window.addEventListener("resize",function(){ht(Cae)});function ha(t,e){ye.useEffect(()=>(window.addEventListener(t,e),()=>{window.removeEventListener(t,e)}),[t,e])}function Tle(){return ha("keydown",function(t){t.keyCode==37&&ht(Eae),t.keyCode==38&&ht(Aae),t.keyCode==39&&ht(Rae),t.keyCode==40&&ht(Dae),t.keyCode==27&&ht(kae),ht(Nae,t.keyCode)}),ha("keyup",function(t){t.keyCode==37&&ht(_ae),t.keyCode==38&&ht(zae),t.keyCode==39&&ht(Fae),t.keyCode==40&&ht(Oae),ht(Tae,t)}),ha("mousedown",function(t){ht(Sae,t)}),ha("mouseup",function(t){ht(Iae,t)}),ha("mousemove",function(t){ht($ae,t)}),ha("click",function(t){ht(PD,t)}),null}function Ele({onBattleEnd:t,playerUnits:e,oppositionUnits:n}){ye.useEffect(()=>{Nle(),ht(zD,{playerUnits:e,oppositionUnits:n});const r=setTimeout(()=>ht(_D),1e3),o=setInterval(()=>ht(OD),100),i=setInterval(()=>ht(MD),1e3);return()=>{clearTimeout(r),clearInterval(o),clearInterval(i)}},[]),yae("battleEnd",()=>{t()});const s=ye.useRef();return RO(()=>{const r=Date.now();s.current&&ht(FD,r-s.current),s.current=r}),De.jsxs(De.Fragment,{children:[De.jsx(wae,{}),De.jsx(Tle,{}),De.jsxs("div",{id:"game-hud",children:[De.jsxs("div",{id:"battle-stats",children:[De.jsx("div",{id:"battle-time",children:" "}),De.jsxs("div",{id:"battle-balance",children:[De.jsx("div",{id:"battle-balance-left",children:" "}),De.jsx("div",{id:"battle-balance-right",children:" "})]})]}),De.jsx("div",{id:"battle-result"})]})]})}const Rle=()=>{const[t,e]=ye.useState({name:"intro"}),n=()=>{e({name:"designer"})},s=(o,i)=>{e({name:"battle",playerUnits:o,oppositionUnits:i}),console.log("Battle started!")},r=()=>{e({name:"designer",playerUnits:t.name==="battle"?t.playerUnits:void 0})};return De.jsxs(Gs.StrictMode,{children:[De.jsx(kO,{}),(t==null?void 0:t.name)==="intro"&&De.jsx(NO,{onPlayClick:n}),(t==null?void 0:t.name)==="designer"&&De.jsx(dae,{onStartBattle:s,initialPlayerUnits:t.playerUnits}),(t==null?void 0:t.name)==="battle"&&De.jsx(Ele,{onBattleEnd:r,playerUnits:t.playerUnits,oppositionUnits:t.oppositionUnits})]})},Ale=Gg.createRoot(document.getElementById("root"));Ale.render(De.jsx(Rle,{})); diff --git a/games/masterplan/index.html b/games/masterplan/index.html index b5eba3b9..97b44424 100644 --- a/games/masterplan/index.html +++ b/games/masterplan/index.html @@ -1,7 +1,7 @@ Master Plan - +